/* POS Taxes Portal v1.5.0 — Full Design */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700;800&family=DM+Sans:wght@400;500;600&display=swap');

:root{
  --navy:#1a4d6e;--navy2:#0f3349;--teal:#2eb8d4;--teal2:#58c8e0;
  --sky:#e0f7fc;--ink:#0d1f2d;--slate:#445566;--muted:#7a8fa0;
  --border:#e4edf5;--bg:#f4f7fa;--white:#fff;
  --green:#10b981;--amber:#f59e0b;--red:#ef4444;--purple:#7c3aed;
  --sidebar-w:230px;
  --font-head:'Sora',sans-serif;--font-body:'DM Sans',sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
body{font-family:var(--font-body);background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5;}

/* =============================================
   ADMIN LAYOUT — dark sidebar + main
   ============================================= */
.pos-portal-layout{display:flex;min-height:100vh;width:100%;}

/* SIDEBAR */
.pos-sidebar{
  width:var(--sidebar-w);min-height:100vh;flex-shrink:0;
  background:linear-gradient(180deg,var(--navy2) 0%,var(--navy) 100%);
  display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;
  z-index:100;overflow:hidden;
}
.pos-sidebar::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.02'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/svg%3E") repeat;
}
.pos-sidebar-logo{padding:22px 20px 18px;border-bottom:1px solid rgba(255,255,255,.08);position:relative;}
.pos-sidebar-logo-text{font-family:var(--font-head);font-weight:800;font-size:17px;color:#fff;letter-spacing:-.3px;}
.pos-sidebar-logo-sub{font-size:11px;color:rgba(255,255,255,.35);margin-top:2px;}

.pos-sidebar-user{padding:12px 20px;display:flex;align-items:center;gap:10px;border-bottom:1px solid rgba(255,255,255,.08);position:relative;}
.pos-sidebar-av{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--teal2));display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:700;font-size:13px;color:#fff;flex-shrink:0;}
.pos-sidebar-uname{font-family:var(--font-head);font-size:13px;font-weight:600;color:#fff;line-height:1.2;}
.pos-sidebar-urole{font-size:11px;color:rgba(255,255,255,.4);margin-top:1px;}

.pos-sidebar-nav{flex:1;padding:10px 0;overflow-y:auto;position:relative;}
.pos-nav-section{padding:8px 20px 3px;font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,.22);}
.pos-nav-item{display:flex;align-items:center;gap:10px;padding:9px 20px;color:rgba(255,255,255,.58);font-size:13px;font-weight:500;transition:all .15s;border-left:3px solid transparent;text-decoration:none;cursor:pointer;position:relative;}
.pos-nav-item:hover{color:#fff;background:rgba(255,255,255,.06);}
.pos-nav-item.active{color:#fff;background:rgba(46,184,212,.12);border-left-color:var(--teal);}
.pos-nav-icon{width:16px;height:16px;flex-shrink:0;opacity:.7;}
.pos-nav-item.active .pos-nav-icon{opacity:1;}
.pos-nav-badge{margin-left:auto;font-size:10px;font-weight:700;padding:1px 6px;border-radius:99px;line-height:1.6;color:#fff;}
.pos-nav-badge.red{background:var(--red);}
.pos-nav-badge.amber{background:var(--amber);}

.pos-sidebar-footer{padding:14px 20px;border-top:1px solid rgba(255,255,255,.08);position:relative;}
.pos-sidebar-footer a{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.35);font-size:12px;text-decoration:none;transition:color .15s;}
.pos-sidebar-footer a:hover{color:rgba(255,255,255,.7);}

/* MAIN CONTENT AREA */
.pos-main{margin-left:var(--sidebar-w);flex:1;min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden;}

.pos-topbar{display:flex;align-items:flex-start;justify-content:space-between;padding:22px 28px 0;flex-shrink:0;flex-wrap:wrap;gap:12px;}
.pos-topbar-title{font-family:var(--font-head);font-size:22px;font-weight:800;color:var(--ink);letter-spacing:-.4px;}
.pos-topbar-sub{font-size:13px;color:var(--muted);margin-top:3px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.pos-topbar-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}

.pos-content{padding:20px 28px 40px;flex:1;}

/* =============================================
   BUTTONS
   ============================================= */
.pos-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:10px;font-family:var(--font-head);font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .15s;text-decoration:none!important;}
.pos-btn-primary{background:var(--teal);color:#fff!important;}
.pos-btn-primary:hover{background:#25a0ba;}
.pos-btn-ghost{background:var(--white);color:var(--slate)!important;border:1px solid var(--border);}
.pos-btn-ghost:hover{background:var(--bg);}
.pos-btn-glass{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);color:#fff!important;border-radius:8px;padding:6px 12px;font-size:12px;font-weight:600;}
.pos-btn-glass:hover{background:rgba(255,255,255,.18);}
.pos-btn-danger{background:#fee2e2;color:#b91c1c!important;border:1px solid #fca5a5;}
.pos-btn-sm{padding:5px 11px;font-size:12px;}
.pos-btn-logout{background:transparent;border:none;color:rgba(255,255,255,.4)!important;font-size:12px;padding:0;gap:6px;}
.pos-btn-logout:hover{color:rgba(255,255,255,.8)!important;}

/* =============================================
   BADGE / PILLS
   ============================================= */
.pos-badge{display:inline-block;font-size:11px;font-weight:700;padding:3px 9px;border-radius:99px;}
.pos-badge-teal{background:rgba(46,184,212,.12);color:#0e6e84;border:1px solid rgba(46,184,212,.3);}
.pos-badge-green{background:rgba(16,185,129,.1);color:#065f46;border:1px solid #10b981;}
.pos-badge-amber{background:rgba(245,158,11,.1);color:#92400e;border:1px solid #f59e0b;}
.pos-badge-red{background:rgba(239,68,68,.1);color:#7f1d1d;border:1px solid #ef4444;}
.pos-badge-purple{background:rgba(124,58,237,.1);color:#4c1d95;border:1px solid #7c3aed;}
.pos-badge-owner{background:linear-gradient(135deg,#fdf4ff,#f5f3ff);color:#7c3aed;border:1px solid #ddd6fe;}

/* =============================================
   MESSAGE BOARD
   ============================================= */
.pos-message-board{background:linear-gradient(135deg,var(--navy2),var(--navy));border-radius:16px;padding:20px 24px;margin-bottom:22px;position:relative;overflow:hidden;}
.pos-message-board::before{content:'';position:absolute;right:-20px;top:-20px;width:120px;height:120px;border-radius:50%;background:rgba(46,184,212,.12);}
.pos-message-board-label{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:5px;}
.pos-message-board-text{font-size:14px;color:rgba(255,255,255,.9);line-height:1.6;font-style:italic;position:relative;}
.pos-message-board-actions{margin-top:12px;display:flex;gap:8px;position:relative;}

/* =============================================
   KPI CARDS
   ============================================= */
.pos-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px;}
@media(max-width:1200px){.pos-kpi-grid{grid-template-columns:repeat(2,1fr);}}
.pos-kpi-card{background:var(--white);border-radius:16px;border:1px solid var(--border);padding:18px 20px;position:relative;overflow:hidden;transition:transform .2s,box-shadow .2s;cursor:default;}
.pos-kpi-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.08);}
.pos-kpi-card::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:16px 16px 0 0;}
.pos-kpi-card.blue::after{background:linear-gradient(90deg,var(--teal),var(--teal2));}
.pos-kpi-card.green::after{background:linear-gradient(90deg,#10b981,#34d399);}
.pos-kpi-card.amber::after{background:linear-gradient(90deg,#f59e0b,#fbbf24);}
.pos-kpi-card.red::after{background:linear-gradient(90deg,#ef4444,#f87171);}
.pos-kpi-card.purple::after{background:linear-gradient(90deg,#7c3aed,#a78bfa);}
.pos-kpi-icon{font-size:22px;margin-bottom:10px;}
.pos-kpi-value{font-family:var(--font-head);font-size:34px;font-weight:800;line-height:1;color:var(--ink);letter-spacing:-.5px;}
.pos-kpi-label{font-size:11px;color:var(--muted);font-weight:600;margin-top:5px;text-transform:uppercase;letter-spacing:.4px;}
.pos-kpi-trend{margin-top:8px;font-size:12px;font-weight:600;}
.pos-kpi-trend.up{color:var(--green);}
.pos-kpi-trend.warn{color:var(--amber);}
.pos-kpi-trend.alert{color:var(--red);}

/* =============================================
   PIPELINE KANBAN
   ============================================= */
.pos-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:8px;}
.pos-section-title{font-family:var(--font-head);font-size:15px;font-weight:700;color:var(--ink);}
.pos-section-sub{font-size:12px;color:var(--muted);margin-top:2px;}

.pos-pipeline{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:22px;}
@media(max-width:1200px){.pos-pipeline{grid-template-columns:repeat(3,1fr);}}
@media(max-width:800px){.pos-pipeline{grid-template-columns:1fr 1fr;}}
.pos-pipeline-col{background:var(--white);border-radius:14px;border:1px solid var(--border);overflow:hidden;}
.pos-pipeline-head{padding:10px 12px;font-family:var(--font-head);font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);}
.pos-pipeline-head.s1{background:rgba(245,158,11,.08);color:#92400e;}
.pos-pipeline-head.s2{background:rgba(46,184,212,.08);color:#0e6e84;}
.pos-pipeline-head.s3{background:rgba(59,130,246,.08);color:#1e40af;}
.pos-pipeline-head.s4{background:rgba(124,58,237,.08);color:#4c1d95;}
.pos-pipeline-head.s5{background:rgba(16,185,129,.08);color:#065f46;}
.pos-pipeline-count{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;color:#fff;}
.s1 .pos-pipeline-count{background:#f59e0b;}
.s2 .pos-pipeline-count{background:var(--teal);}
.s3 .pos-pipeline-count{background:#3b82f6;}
.s4 .pos-pipeline-count{background:#7c3aed;}
.s5 .pos-pipeline-count{background:#10b981;}
.pos-pipeline-cards{padding:8px;display:flex;flex-direction:column;gap:6px;min-height:60px;}
.pos-pipeline-card{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:9px 11px;transition:all .15s;}
.pos-pipeline-card:hover{background:#edf3f8;border-color:#c5d5e5;transform:translateX(2px);}
.pos-pipeline-card-name{font-weight:600;font-size:12px;color:var(--ink);line-height:1.3;}
.pos-pipeline-card-meta{font-size:11px;color:var(--muted);margin-top:3px;}
.pos-pipeline-flag{display:inline-block;font-size:10px;font-weight:700;padding:1px 6px;border-radius:4px;margin-top:4px;}
.pos-flag-stale{background:rgba(245,158,11,.12);color:#92400e;}
.pos-flag-new{background:rgba(46,184,212,.12);color:#0e6e84;}
.pos-pipeline-empty{font-size:11px;color:var(--muted);padding:8px 0;text-align:center;font-style:italic;}

/* =============================================
   BOTTOM PANELS GRID
   ============================================= */
.pos-panels-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;}
@media(max-width:1100px){.pos-panels-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:700px){.pos-panels-grid{grid-template-columns:1fr;}}
.pos-panel{background:var(--white);border-radius:16px;border:1px solid var(--border);padding:18px 20px;}
.pos-panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.pos-panel-title{font-family:var(--font-head);font-size:13px;font-weight:700;color:var(--ink);}

/* Activity */
.pos-activity-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);}
.pos-activity-item:last-child{border-bottom:none;}
.pos-activity-av{width:32px;height:32px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:700;font-size:12px;color:#fff;}
.pos-activity-info{flex:1;min-width:0;}
.pos-activity-name{font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.pos-activity-meta{font-size:11px;color:var(--muted);margin-top:1px;}
.pos-activity-time{font-size:11px;color:var(--muted);flex-shrink:0;}

/* Files */
.pos-file-item{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid var(--border);}
.pos-file-item:last-child{border-bottom:none;}
.pos-file-icon{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;}
.pos-file-icon.pdf{background:rgba(239,68,68,.1);}
.pos-file-icon.img{background:rgba(59,130,246,.1);}
.pos-file-icon.doc{background:rgba(124,58,237,.1);}
.pos-file-name{font-weight:600;font-size:12px;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.pos-file-size{font-size:11px;color:var(--muted);flex-shrink:0;}

/* Billing rows */
.pos-pay-row{display:flex;align-items:center;justify-content:space-between;padding:7px 0;border-bottom:1px solid var(--border);}
.pos-pay-row:last-child{border-bottom:none;}
.pos-pay-name{font-weight:600;font-size:12px;}
.pos-pay-date{font-size:11px;color:var(--muted);margin-top:1px;}
.pos-pay-amt{font-size:12px;font-weight:700;color:var(--ink);}
.pos-pay-pill{font-size:10px;font-weight:700;padding:2px 8px;border-radius:99px;border:1.5px solid;}
.pos-pay-pill.paid{color:#065f46;border-color:#10b981;background:rgba(16,185,129,.08);}
.pos-pay-pill.due{color:#92400e;border-color:#f59e0b;background:rgba(245,158,11,.08);}
.pos-pay-pill.overdue{color:#7f1d1d;border-color:#ef4444;background:rgba(239,68,68,.08);}

/* =============================================
   CLIENTS TABLE
   ============================================= */
.pos-clients-wrap{padding:0;}
.pos-clients-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap;}
.pos-filter-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:14px;}
.pos-search-input{height:36px;border:1px solid var(--border);border-radius:10px;padding:0 12px;font-size:13px;min-width:220px;font-family:var(--font-body);background:#fff;outline:none;}
.pos-search-input:focus{border-color:var(--teal);}
.pos-table-wrap{background:var(--white);border:1px solid var(--border);border-radius:14px;overflow:hidden;}
.pos-table-wrap .wp-list-table{border:none!important;margin:0!important;}
.pos-table-wrap .wp-list-table th,.pos-table-wrap .wp-list-table td{padding:11px 14px!important;font-size:13px!important;border-bottom:1px solid var(--border)!important;}
.pos-table-wrap .wp-list-table thead th{background:#f8fafc!important;font-weight:700!important;font-size:12px!important;border-bottom:2px solid var(--border)!important;color:var(--slate)!important;}
.pos-table-wrap .wp-list-table tbody tr:last-child td{border-bottom:none!important;}
.pos-table-wrap .wp-list-table tbody tr:hover td{background:#f8fafc!important;}
.pos-table-wrap .tablenav{padding:10px 14px!important;border-top:1px solid var(--border);background:#fafbfc;}
.pos-table-wrap .tablenav-pages{margin:0!important;}

/* Stage pills */
.pos-stage-pill{display:inline-flex;align-items:center;padding:3px 10px;border-radius:99px;font-weight:700;font-size:11px;border:1.5px solid;white-space:nowrap;}
.pos-stage-pill[data-stage="1"]{background:rgba(245,158,11,.1);border-color:#f59e0b;color:#92400e;}
.pos-stage-pill[data-stage="2"]{background:rgba(46,184,212,.1);border-color:#2eb8d4;color:#0e6e84;}
.pos-stage-pill[data-stage="3"]{background:rgba(59,130,246,.1);border-color:#3b82f6;color:#1e40af;}
.pos-stage-pill[data-stage="4"]{background:rgba(124,58,237,.1);border-color:#7c3aed;color:#4c1d95;}
.pos-stage-pill[data-stage="5"]{background:rgba(16,185,129,.1);border-color:#10b981;color:#065f46;}
.pos-stage-select{border-radius:99px!important;padding:4px 10px!important;font-weight:700;font-size:12px;border:1.5px solid var(--border)!important;cursor:pointer;background:#fff;font-family:var(--font-body);}
.pos-stage-select[data-stage="1"]{background:rgba(245,158,11,.08)!important;border-color:#f59e0b!important;color:#92400e!important;}
.pos-stage-select[data-stage="2"]{background:rgba(46,184,212,.08)!important;border-color:#2eb8d4!important;color:#0e6e84!important;}
.pos-stage-select[data-stage="3"]{background:rgba(59,130,246,.08)!important;border-color:#3b82f6!important;color:#1e40af!important;}
.pos-stage-select[data-stage="4"]{background:rgba(124,58,237,.08)!important;border-color:#7c3aed!important;color:#4c1d95!important;}
.pos-stage-select[data-stage="5"]{background:rgba(16,185,129,.08)!important;border-color:#10b981!important;color:#065f46!important;}
.pos-stage-save-btn{height:28px;padding:0 10px;border-radius:6px;border:1px solid var(--navy);background:var(--navy);color:#fff;cursor:pointer;font-size:11px;font-weight:700;font-family:var(--font-head);}
.pos-action-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap;}
.pos-note-input{width:130px;height:27px;font-size:12px;border-radius:6px;border:1px solid var(--border);padding:0 7px;font-family:var(--font-body);}
.pos-save-note-btn{height:28px;padding:0 10px;border-radius:6px;border:1px solid var(--teal);background:var(--teal);color:#fff;cursor:pointer;font-size:12px;font-weight:700;}
.pos-files-btn{display:inline-flex;align-items:center;padding:4px 10px;border-radius:6px;border:1px solid var(--border);background:#fff;color:var(--slate)!important;font-size:12px;text-decoration:none!important;font-weight:600;}
.pos-lang-select{border-radius:6px;padding:4px 7px;font-size:12px;border:1px solid var(--border);cursor:pointer;}
.pos-no-upload{color:var(--red);font-size:11px;}
.pos-stale-badge{display:inline-block;background:rgba(245,158,11,.12);color:#92400e;border:1px solid #f59e0b;border-radius:4px;font-size:10px;font-weight:700;padding:1px 5px;margin-left:4px;}
.pos-zoho-link{color:#e05c0a;font-weight:700;font-size:12px;text-decoration:none;}
.pos-sync-btn{height:26px;padding:0 10px;border-radius:6px;border:1px solid #e05c0a;background:#fff;color:#e05c0a;cursor:pointer;font-size:11px;font-weight:700;}
.pos-sync-btn:hover{background:#e05c0a;color:#fff;}
.pos-muted-sm{color:var(--muted);font-size:12px;}
.pos-zoho-badge{display:inline-block;font-size:11px;font-weight:700;padding:3px 10px;border-radius:99px;}
.pos-zoho-on{background:rgba(16,185,129,.1);color:#065f46;border:1px solid #10b981;}
.pos-zoho-off{background:rgba(239,68,68,.08);color:#991b1b;border:1px solid #ef4444;}

/* Owner board in clients page */
.pos-owner-board{background:linear-gradient(135deg,#fdf8ff,#f0f9ff);border:2px solid #c4b5fd;border-radius:14px;padding:16px 20px;margin-bottom:16px;}
.pos-owner-board-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;font-family:var(--font-head);font-weight:700;color:#4c1d95;}
.pos-owner-chip{background:#7c3aed;color:#fff;border-radius:99px;padding:2px 10px;font-size:11px;font-weight:700;}
.pos-owner-fields{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
@media(max-width:700px){.pos-owner-fields{grid-template-columns:1fr;}}
.pos-owner-field label{display:block;font-weight:700;font-size:12px;margin-bottom:5px;color:#4c1d95;text-transform:uppercase;letter-spacing:.4px;}
.pos-owner-field textarea{width:100%;border:1px solid #c4b5fd;border-radius:8px;padding:8px;font-size:13px;background:#fff;resize:vertical;font-family:var(--font-body);}
.pos-staff-msg{background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #fcd34d;border-radius:10px;padding:10px 14px;margin-bottom:14px;font-size:13px;color:#92400e;}

/* =============================================
   LOGIN / REGISTER PAGE
   ============================================= */
.pos-login-wrap{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:40px 16px;background:linear-gradient(135deg,#0d1f2d 0%,#1a4d6e 55%,#0e5a72 100%);}
.pos-login-card{width:100%;max-width:440px;background:#fff;border-radius:20px;padding:36px 40px;box-shadow:0 32px 64px rgba(0,0,0,.3);}
.pos-reg-card{max-width:500px;}
.pos-login-brand{text-align:center;margin-bottom:22px;}
.pos-login-brand img{max-width:180px;height:auto;}
.pos-login-sub{margin:8px 0 0;color:var(--muted);font-size:13px;}
.pos-login-alert{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.25);color:#991b1b;padding:10px 14px;border-radius:10px;margin:0 0 16px;font-size:13px;}
.pos-login-alert-ok{background:rgba(16,185,129,.08);border-color:rgba(16,185,129,.3);color:#065f46;}
.pos-login-field{margin:12px 0;}
.pos-login-field label{display:block;font-weight:700;font-size:11px;color:var(--ink);margin-bottom:5px;text-transform:uppercase;letter-spacing:.4px;}
.pos-login-card input[type=text],
.pos-login-card input[type=password],
.pos-login-card input[type=email],
.pos-login-card input[type=tel],
.pos-login-card input[type=date]{width:100%;border-radius:12px;border:1.5px solid var(--border);padding:11px 14px;font-size:14px;outline:none;transition:border .15s,box-shadow .15s;background:#fafbfc;font-family:var(--font-body);color:var(--ink);}
.pos-login-card input:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(46,184,212,.15);background:#fff;}
.pos-login-card select{width:100%;border-radius:12px;border:1.5px solid var(--border);padding:11px 14px;font-size:14px;outline:none;background:#fafbfc;font-family:var(--font-body);color:var(--ink);cursor:pointer;}
.pos-login-card select:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(46,184,212,.15);}
.pos-login-remember{margin:10px 0 14px;font-size:13px;color:var(--muted);}
.pos-login-btn{display:block;width:100%;border:0;border-radius:12px;padding:13px;font-family:var(--font-head);font-weight:700;font-size:15px;color:#fff!important;background:linear-gradient(135deg,var(--navy),var(--teal));cursor:pointer;text-align:center;text-decoration:none!important;transition:opacity .15s,transform .1s;}
.pos-login-btn:hover{opacity:.88;transform:translateY(-1px);}
.pos-login-links{margin-top:14px;text-align:center;font-size:12px;color:var(--muted);}
.pos-login-links a{color:var(--teal);text-decoration:none;font-weight:600;}
.pos-login-divider{display:flex;align-items:center;gap:10px;margin:18px 0 12px;color:#94a3b8;font-size:12px;}
.pos-login-divider::before,.pos-login-divider::after{content:'';flex:1;height:1px;background:var(--border);}
.pos-login-request-btn{display:block;width:100%;text-align:center;padding:11px;border-radius:12px;border:1.5px solid var(--border);background:#f8fafc;color:var(--navy)!important;font-family:var(--font-head);font-weight:700;font-size:13px;text-decoration:none!important;transition:all .15s;}
.pos-login-request-btn:hover{border-color:var(--teal);background:var(--sky);color:#0e6e84!important;}
.pos-reg-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
@media(max-width:480px){.pos-reg-row{grid-template-columns:1fr;}}
.pos-field-hint{font-size:11px;font-weight:400;color:var(--muted);margin-left:5px;}
.pos-reg-agree{margin:12px 0 0;font-size:12px;color:var(--slate);display:flex;gap:8px;align-items:flex-start;line-height:1.5;}
.pos-reg-agree input[type=checkbox]{margin-top:2px;accent-color:var(--teal);flex-shrink:0;width:14px;height:14px;}
.pos-logout-btn{display:inline-flex;align-items:center;padding:7px 14px;border-radius:99px;font-size:12px;font-weight:600;text-decoration:none;background:#f1f5f9;color:#334155;border:1px solid #e2e8f0;}
.pos-logout-btn:hover{background:#fee2e2;color:#b91c1c;}

/* =============================================
   CLIENT PORTAL (frontend)
   ============================================= */

/* -- Page-level background when portal is present -- */
body:has(.pos-portal-wrap) {
  background:
    radial-gradient(ellipse 80% 60% at 20% 10%, rgba(46,184,212,.18) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 85% 80%, rgba(16,185,129,.1) 0%, transparent 55%),
    linear-gradient(160deg, #0b1f30 0%, #0f3349 45%, #0d4a60 75%, #124060 100%) !important;
  min-height: 100vh;
}

/* -- Main wrap: centered, max-width -- */
.pos-portal-wrap {
  width: 100%;
  max-width: 1080px;
  margin: 0 auto;
  padding: 28px 24px 72px;
}

/* -- Notices -- */
.pos-notice {
  padding: 13px 18px;
  border-radius: 12px;
  margin: 0 0 16px;
  font-size: 14px;
  border: 1px solid;
  backdrop-filter: blur(8px);
}
.pos-notice.success { border-color: #6ee7b7; background: rgba(16,185,129,.12); color: #d1fae5; }
.pos-notice.error   { border-color: #fca5a5; background: rgba(239,68,68,.1);   color: #fee2e2; }

/* -- Client message banner -- */
.pos-client-msg {
  background: rgba(46,184,212,.1);
  border: 1px solid rgba(46,184,212,.3);
  border-radius: 14px;
  padding: 13px 18px;
  margin: 0 0 20px;
  font-size: 14px;
  color: #cff5fb;
  backdrop-filter: blur(8px);
}

/* -- Header row -- */
.pos-portal-client-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 22px;
  flex-wrap: wrap;
}
.pos-status-card {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 14px;
  padding: 10px 18px;
  backdrop-filter: blur(10px);
}
.pos-status-label {
  font-size: 12px;
  font-weight: 700;
  color: rgba(255,255,255,.5);
  text-transform: uppercase;
  letter-spacing: .5px;
}
/* Clickable Get Started pill (stage 1 only) */
.pos-status-pill-cta {
  cursor: pointer;
  background: linear-gradient(135deg, #22c55e, #16a34a);
  border: none;
  color: #fff !important;
  font-size: 13px;
  font-weight: 700;
  border-radius: 999px;
  padding: 6px 14px;
  transition: transform .15s, box-shadow .15s;
  animation: pos-step-breathe 2.4s ease-in-out infinite;
}
.pos-status-pill-cta:hover {
  transform: scale(1.04);
  box-shadow: 0 4px 16px rgba(34,197,94,.4);
}

.pos-status-pill {
  background: linear-gradient(135deg, rgba(46,184,212,.25), rgba(46,184,212,.12));
  color: #7de8f8;
  border: 1px solid rgba(46,184,212,.4);
  border-radius: 99px;
  padding: 4px 14px;
  font-size: 13px;
  font-weight: 700;
}

/* -- Sign out button -- */
.pos-logout-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 20px;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.7) !important;
  border: 1px solid rgba(255,255,255,.12);
  transition: all .15s;
  backdrop-filter: blur(8px);
}
.pos-logout-btn:hover { background: rgba(239,68,68,.15); color: #fca5a5 !important; border-color: rgba(239,68,68,.3); }

/* -- TABS -- */
.pos-portal-tabs {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin: 0 0 24px;
  padding: 0;
  list-style: none;
}
.pos-portal-tabs li { display: contents; }
.pos-portal-tabs button {
  appearance: none;
  border: 1.5px solid rgba(255,255,255,.15);
  background: rgba(255,255,255,.07);
  padding: 12px 22px;
  border-radius: 12px;
  cursor: pointer;
  font-weight: 600;
  color: rgba(255,255,255,.7);
  transition: all .18s;
  font-size: 14px;
  font-family: var(--font-body);
  backdrop-filter: blur(8px);
  white-space: nowrap;
}
.pos-portal-tabs button:hover {
  background: rgba(255,255,255,.14);
  color: #fff;
  border-color: rgba(255,255,255,.3);
  transform: translateY(-1px);
}
.pos-portal-tabs button.active {
  background: linear-gradient(135deg, var(--teal), #1a9ab5);
  border-color: transparent;
  color: #fff;
  box-shadow: 0 4px 16px rgba(46,184,212,.35);
  transform: translateY(-1px);
}

/* -- Panels -- */
.pos-portal-panel { display: none; animation: pos-fade-up .25s ease both; }
.pos-portal-panel.active { display: block; }

/* -- Grid layout inside panels -- */
.pos-portal-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
@media(max-width: 720px) { .pos-portal-grid { grid-template-columns: 1fr; } }

/* -- Content boxes (cards) -- */
.pos-box {
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 20px;
  background: rgba(255,255,255,.06);
  backdrop-filter: blur(16px);
  padding: 28px;
  box-shadow: 0 8px 32px rgba(0,0,0,.2), inset 0 1px 0 rgba(255,255,255,.08);
}
.pos-box h3 {
  margin: 0 0 14px;
  font-family: var(--font-head);
  font-size: 18px;
  color: #fff;
  font-weight: 700;
}
.pos-box p { color: rgba(255,255,255,.65); font-size: 14px; line-height: 1.6; }
.pos-label { font-weight: 700; color: rgba(255,255,255,.5); font-size: 12px; text-transform: uppercase; letter-spacing: .4px; }

/* Checklist */
.pos-list { margin: 12px 0 0 20px; list-style: none; padding: 0; }
.pos-list li {
  margin: 8px 0;
  font-size: 14px;
  color: rgba(255,255,255,.75);
  display: flex;
  align-items: flex-start;
  gap: 10px;
}
.pos-list li::before {
  content: '✓';
  color: var(--teal);
  font-weight: 800;
  font-size: 12px;
  flex-shrink: 0;
  margin-top: 2px;
}

/* -- Tax Process -- */
.pos-tax-box { padding: 28px; }
.pos-tax-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 18px;
  flex-wrap: wrap;
}
.pos-tax-ctas { display: flex; gap: 10px; flex-wrap: wrap; }
.pos-status-wrap {
  background: rgba(0,0,0,.25);
  border-radius: 16px;
  padding: 14px;
  margin: 0 0 18px;
  border: 1px solid rgba(255,255,255,.08);
}
.pos-status {
  display: flex;
  align-items: center;
  gap: 5px;
  background: rgba(255,255,255,.06);
  border-radius: 99px;
  padding: 10px 16px;
  overflow-x: auto;
  border: 1px solid rgba(255,255,255,.08);
}
.pos-status-step {
  display: flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
  font-size: 12px;
  font-weight: 600;
  padding: 3px 6px;
  border-radius: 99px;
  color: rgba(255,255,255,.5);
}
.pos-status-dot {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  background: rgba(255,255,255,.1);
  color: rgba(255,255,255,.4);
  border: 1px solid rgba(255,255,255,.15);
  font-size: 11px;
  flex-shrink: 0;
}
.pos-status-rail { height: 3px; width: 16px; background: rgba(255,255,255,.12); border-radius: 99px; flex-shrink: 0; }
.pos-status-step.done { color: rgba(255,255,255,.8); }
.pos-status-step.done .pos-status-dot { background: var(--green); border-color: var(--green); color: #fff; }
.pos-status-step.done + .pos-status-rail { background: var(--green); }
.pos-status-step.active { color: #fff; }
.pos-status-step.active .pos-status-dot { background: var(--teal); border-color: var(--teal); color: #fff; box-shadow: 0 0 0 3px rgba(46,184,212,.3); }
.pos-tax-steps { display: flex; flex-direction: column; gap: 10px; }
.pos-tax-step {
  display: flex;
  gap: 14px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  padding: 16px;
  background: rgba(255,255,255,.04);
}
.pos-tax-badge {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  border: 2px solid rgba(255,255,255,.15);
  flex-shrink: 0;
  font-size: 13px;
  color: rgba(255,255,255,.4);
}
.pos-tax-content h4 { margin: 0 0 4px; font-size: 14px; font-family: var(--font-head); color: rgba(255,255,255,.85); }
.pos-tax-content p  { margin: 0; color: rgba(255,255,255,.45); font-size: 13px; }
/* Active step — full card breathes green so nobody misses it */
@keyframes pos-step-breathe {
  0%   {
    background: rgba(34,197,94,.12);
    border-color: rgba(34,197,94,.5);
    box-shadow: 0 0 0 0 rgba(34,197,94,.0);
  }
  50%  {
    background: rgba(34,197,94,.22);
    border-color: rgba(34,197,94,.9);
    box-shadow: 0 0 22px 4px rgba(34,197,94,.18);
  }
  100% {
    background: rgba(34,197,94,.12);
    border-color: rgba(34,197,94,.5);
    box-shadow: 0 0 0 0 rgba(34,197,94,.0);
  }
}
.pos-tax-step.is-active {
  animation: pos-step-breathe 2.4s ease-in-out infinite;
  border-width: 2px;
}
.pos-tax-step.is-active .pos-tax-badge {
  background: #22c55e;
  border-color: #22c55e;
  color: #fff;
}
.pos-tax-step.is-active .pos-tax-content h4 {
  color: #4ade80;
}
.pos-tax-step.is-done { background: rgba(16,185,129,.05); border-color: rgba(16,185,129,.2); }
.pos-tax-step.is-done .pos-tax-badge { background: var(--green); border-color: var(--green); color: #fff; }
.pos-badge-complete { color: #fff; padding-right: 20px; font-size: 12px; font-weight: 600; opacity: .7; }
.pos-tax-step.is-todo { opacity: .4; }

/* -- Buttons (client-facing) -- */
.pos-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  padding: 12px 24px;
  border-radius: 12px;
  font-family: var(--font-head);
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  border: none;
  transition: all .18s;
  text-decoration: none !important;
  white-space: nowrap;
}
.pos-btn-primary, .pos-portal-wrap .pos-btn:not(.pos-btn-secondary) {
  background: linear-gradient(135deg, var(--teal), #1a9ab5);
  color: #fff !important;
  box-shadow: 0 4px 16px rgba(46,184,212,.3);
}
.pos-btn-primary:hover, .pos-portal-wrap .pos-btn:not(.pos-btn-secondary):hover {
  opacity: .88;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(46,184,212,.4);
}
.pos-btn-secondary, .pos-portal-wrap .pos-btn-secondary {
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.8) !important;
  border: 1.5px solid rgba(255,255,255,.15);
  backdrop-filter: blur(8px);
}
.pos-btn-secondary:hover, .pos-portal-wrap .pos-btn-secondary:hover {
  background: rgba(255,255,255,.15);
  color: #fff !important;
  border-color: rgba(255,255,255,.25);
}

/* -- Forms -- */
.pos-form .pos-field { margin: 14px 0; }
.pos-form label { display: block; font-weight: 700; margin-bottom: 6px; color: rgba(255,255,255,.7); font-size: 13px; letter-spacing: .2px; }
.pos-form input[type=text],
.pos-form input[type=file],
.pos-form select,
.pos-form textarea {
  width: 100%;
  border: 1.5px solid rgba(255,255,255,.15);
  border-radius: 12px;
  padding: 11px 14px;
  background: rgba(255,255,255,.08);
  font-size: 14px;
  font-family: var(--font-body);
  color: #fff;
  transition: border .15s, box-shadow .15s;
  outline: none;
}
.pos-form input::placeholder { color: rgba(255,255,255,.3); }
.pos-form input:focus,
.pos-form select:focus,
.pos-form textarea:focus {
  border-color: var(--teal);
  box-shadow: 0 0 0 3px rgba(46,184,212,.2);
  background: rgba(255,255,255,.12);
}
.pos-form select { cursor: pointer; }
.pos-form select option { background: #0f3349; color: #fff; }
.pos-form textarea { resize: vertical; }
#pos-file-info { font-size: 12px; margin-top: 6px; color: rgba(255,255,255,.55); }

/* -- Actions row -- */
.pos-actions { display: flex; gap: 10px; margin-top: 16px; flex-wrap: wrap; align-items: center; }

/* -- Documents table -- */
.pos-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.pos-table th, .pos-table td {
  text-align: left;
  border-bottom: 1px solid rgba(255,255,255,.07);
  padding: 11px 10px;
  vertical-align: top;
  color: rgba(255,255,255,.75);
}
.pos-table th { font-weight: 700; color: rgba(255,255,255,.4); font-size: 11px; text-transform: uppercase; letter-spacing: .5px; }
.pos-table tbody tr:hover td { background: rgba(255,255,255,.03); }
.pos-link { color: var(--teal); font-weight: 700; text-decoration: none; }
.pos-link:hover { text-decoration: underline; }
.pos-muted { color: rgba(255,255,255,.4); }

/* -- Billing -- */
.pos-pay-pill { font-size: 11px; font-weight: 700; padding: 3px 10px; border-radius: 99px; border: 1.5px solid; }
.pos-pay-pill[data-pay="paid"]   { color: #6ee7b7; border-color: rgba(16,185,129,.5);  background: rgba(16,185,129,.12); }
.pos-pay-pill[data-pay="unpaid"] { color: #fcd34d; border-color: rgba(245,158,11,.5);  background: rgba(245,158,11,.1); }
.pos-pay-pill[data-pay="open"]   { color: #fca5a5; border-color: rgba(239,68,68,.5);   background: rgba(239,68,68,.1); }

/* -- Billing "no profile" message -- */
.pos-portal-wrap .pos-box p[style*="color:#64748b"] {
  color: rgba(255,255,255,.45) !important;
  font-size: 13px;
}

/* -- FAQ -- */
.pos-portal-wrap .pos-box hr { border: none; border-top: 1px solid rgba(255,255,255,.1); margin-bottom: 18px; }

/* -- Slideout -- */
.pos-slideout-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,.6); opacity: 0; visibility: hidden; pointer-events: none; transition: opacity .18s; z-index: 9998; }
.pos-slideout-backdrop.open { opacity: 1; visibility: visible; pointer-events: auto; }
.pos-slideout {
  position: fixed; top: 0; right: 0; height: 100vh;
  width: 420px; max-width: calc(100vw - 24px);
  background: linear-gradient(160deg, #0f3349, #0d4a60);
  border-left: 1px solid rgba(255,255,255,.1);
  box-shadow: -16px 0 48px rgba(0,0,0,.4);
  transform: translateX(110%); opacity: 0; visibility: hidden;
  transition: transform .22s cubic-bezier(.4,0,.2,1), opacity .18s;
  z-index: 9999; overflow: auto; padding: 28px;
}
.pos-slideout.open { transform: translateX(0); opacity: 1; visibility: visible; pointer-events: auto; }
.pos-slideout-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 22px; }
.pos-slideout-head h3 { margin: 0; font-family: var(--font-head); color: #fff; }
.pos-xbtn {
  appearance: none;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 8px;
  padding: 7px 12px;
  cursor: pointer;
  font-size: 12px;
  color: rgba(255,255,255,.6);
}
.pos-xbtn:hover { background: rgba(239,68,68,.2); color: #fca5a5; }

/* -- Scrollbar -- */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(46,184,212,.35); border-radius: 10px; }

/* -- Animations -- */
@keyframes pos-fade-up { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }
.pos-kpi-card { animation: pos-fade-up .3s ease both; }
.pos-kpi-card:nth-child(1) { animation-delay: .05s; }
.pos-kpi-card:nth-child(2) { animation-delay: .1s; }
.pos-kpi-card:nth-child(3) { animation-delay: .15s; }
.pos-kpi-card:nth-child(4) { animation-delay: .2s; }

/* =============================================
   MOBILE — Client Portal
   ============================================= */
@media (max-width: 640px) {
  .pos-portal-wrap { padding: 16px 14px 60px; }

  .pos-portal-client-header { flex-direction: column; align-items: flex-start; gap: 10px; }
  .pos-status-card { width: 100%; justify-content: space-between; }

  .pos-portal-tabs { gap: 6px; }
  .pos-portal-tabs button { padding: 10px 16px; font-size: 13px; flex: 1 1 auto; text-align: center; }

  .pos-box { padding: 20px 18px; border-radius: 16px; }
  .pos-box h3 { font-size: 16px; }

  .pos-tax-head { flex-direction: column; gap: 12px; }
  .pos-tax-ctas { width: 100%; }
  .pos-tax-ctas .pos-btn { flex: 1; justify-content: center; }

  .pos-status { padding: 8px 10px; gap: 3px; }
  .pos-status-step .pos-status-label { display: none; }
  .pos-status-step.active .pos-status-label { display: inline; }

  .pos-btn { padding: 12px 18px; font-size: 14px; width: 100%; justify-content: center; }
  .pos-actions { flex-direction: column; }
  .pos-actions .pos-btn { width: 100%; }

  .pos-table { font-size: 12px; }
  .pos-table th, .pos-table td { padding: 9px 7px; }

  .pos-portal-grid { grid-template-columns: 1fr; gap: 14px; }

  .pos-slideout { width: 100%; max-width: 100%; border-radius: 20px 20px 0 0; top: auto; bottom: 0; height: 85vh; border-left: none; border-top: 1px solid rgba(255,255,255,.1); transform: translateY(110%); }
  .pos-slideout.open { transform: translateY(0); }
}

@media (min-width: 641px) and (max-width: 900px) {
  .pos-portal-wrap { padding: 20px 20px 60px; }
  .pos-portal-tabs button { padding: 11px 18px; font-size: 13px; }
  .pos-box { padding: 22px; }
}

/* =============================================
   BILLING BALANCE CARD (client portal)
   ============================================= */
.pos-billing-balance-card{display:flex;align-items:center;justify-content:space-between;gap:16px;border-radius:20px;padding:24px 28px;margin-bottom:20px;flex-wrap:wrap;border:1px solid;backdrop-filter:blur(16px);}
.pos-billing-balance-due{background:linear-gradient(135deg,rgba(239,68,68,.15),rgba(245,158,11,.1));border-color:rgba(239,68,68,.3);box-shadow:0 8px 32px rgba(239,68,68,.15);}
.pos-billing-balance-paid{background:linear-gradient(135deg,rgba(16,185,129,.12),rgba(46,184,212,.08));border-color:rgba(16,185,129,.3);}
.pos-billing-balance-amt{font-family:var(--font-head);font-size:36px;font-weight:800;color:#fff;letter-spacing:-.5px;line-height:1;}
.pos-billing-balance-lbl{font-size:13px;color:rgba(255,255,255,.55);margin-top:5px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;}
.pos-billing-pay-btn{background:linear-gradient(135deg,#ef4444,#dc2626)!important;color:#fff!important;box-shadow:0 4px 16px rgba(239,68,68,.4)!important;font-size:16px!important;padding:14px 28px!important;white-space:nowrap;}
.pos-billing-pay-btn:hover{transform:translateY(-2px)!important;box-shadow:0 6px 24px rgba(239,68,68,.5)!important;}
.pos-billing-cell{font-size:13px;}
@media(max-width:640px){
  .pos-billing-balance-card{flex-direction:column;align-items:flex-start;}
  .pos-billing-pay-btn{width:100%;justify-content:center;}
  .pos-billing-balance-amt{font-size:28px;}
}

/* Client portal logo */
.pos-portal-logo {
  margin-bottom: 24px;
}
.pos-portal-logo img {
  height: 42px;
  width: auto;
  display: block;
  filter: drop-shadow(0 2px 8px rgba(0,0,0,.3));
}

/* =========================================================
   CLIENT PORTAL HEADER  (logo + Return Status + Sign Out)
   ========================================================= */
.pos-portal-logo {
  margin-bottom: 20px;
}
.pos-portal-logo img {
  height: 40px;
  width: auto;
  display: block;
  filter: drop-shadow(0 2px 8px rgba(0,0,0,.3));
}
.pos-portal-client-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}
.pos-status-card {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px;
  padding: 8px 16px;
}
.pos-status-label {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .8px;
  text-transform: uppercase;
  color: rgba(255,255,255,.5);
}
.pos-status-pill {
  font-size: 13px;
  font-weight: 700;
  color: #5ee7c6;
  background: rgba(94,231,198,.12);
  border: 1px solid rgba(94,231,198,.3);
  border-radius: 999px;
  padding: 4px 12px;
}
.pos-logout-btn {
  font-size: 13px;
  font-weight: 600;
  color: rgba(255,255,255,.6);
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 8px;
  padding: 8px 16px;
  text-decoration: none;
  transition: all .15s ease;
}
.pos-logout-btn:hover {
  background: rgba(255,255,255,.13);
  color: #fff;
}

/* =========================================================
   FAQ ITEMS
   ========================================================= */
.pos-faq-item {
  margin-bottom: 18px;
}
.pos-faq-q {
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .6px;
  color: rgba(255,255,255,.9);
  margin-bottom: 5px;
}
.pos-faq-a {
  font-size: 14px;
  color: rgba(255,255,255,.6);
  line-height: 1.6;
}

/* =========================================================
   BILLING BALANCE CARDS
   ========================================================= */
.pos-billing-balance-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  border-radius: 16px;
  padding: 24px 28px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.pos-billing-balance-due {
  background: linear-gradient(135deg, rgba(239,68,68,.25), rgba(220,38,38,.15));
  border: 1px solid rgba(239,68,68,.35);
}
.pos-billing-balance-paid {
  background: linear-gradient(135deg, rgba(34,197,94,.2), rgba(16,185,129,.12));
  border: 1px solid rgba(34,197,94,.3);
}
.pos-billing-balance-amt {
  font-size: 32px;
  font-weight: 800;
  color: #fff;
  letter-spacing: -.02em;
}
.pos-billing-balance-lbl {
  font-size: 13px;
  color: rgba(255,255,255,.55);
  margin-top: 4px;
}
.pos-billing-pay-btn {
  background: linear-gradient(135deg,#22c55e,#16a34a) !important;
  border-color: #22c55e !important;
  color: #fff !important;
  font-size: 15px !important;
  padding: 13px 22px !important;
  white-space: nowrap;
}

/* Pay pill in invoice table */
.pos-pay-pill { display:inline-block; padding:2px 10px; border-radius:999px; font-size:11px; font-weight:700; }
.pos-pay-pill[data-pay="paid"]    { background:rgba(34,197,94,.15);  color:#4ade80; border:1px solid rgba(34,197,94,.3); }
.pos-pay-pill[data-pay="unpaid"]  { background:rgba(239,68,68,.15);  color:#f87171; border:1px solid rgba(239,68,68,.3); }
.pos-pay-pill[data-pay="overdue"] { background:rgba(234,179,8,.15);  color:#fbbf24; border:1px solid rgba(234,179,8,.3); }

/* =========================================================
   PORTAL TOP ROW (logo + sign out on same line)
   ========================================================= */
.pos-portal-top-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}
.pos-portal-top-row .pos-portal-logo {
  margin-bottom: 0;
}

/* =========================================================
   OWNER ANNOUNCEMENT BANNER
   ========================================================= */
.pos-client-announcement {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  background: linear-gradient(135deg, rgba(34,197,94,.18), rgba(16,185,129,.1));
  border: 1px solid rgba(34,197,94,.35);
  border-radius: 12px;
  padding: 14px 18px;
  margin-bottom: 20px;
  font-size: 14px;
  font-weight: 500;
  color: #d1fae5;
  line-height: 1.55;
}
.pos-announcement-icon {
  font-size: 18px;
  flex-shrink: 0;
  margin-top: 1px;
}

/* =========================================================
   INFO TAB — Quick-stat chips + CTA box
   ========================================================= */
.pos-info-chip {
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 12px;
  padding: 10px 16px;
  text-align: center;
  min-width: 80px;
}
.pos-info-chip-val {
  font-size: 22px;
  font-weight: 800;
  color: #fff;
  line-height: 1;
}
.pos-info-chip-lbl {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: rgba(255,255,255,.4);
  margin-top: 4px;
}

.pos-cta-box {
  background: linear-gradient(135deg, rgba(46,184,212,.15), rgba(37,110,154,.1));
  border: 1px solid rgba(46,184,212,.3);
  border-radius: 12px;
  padding: 16px 18px;
  margin-top: 4px;
}
.pos-cta-box-title {
  font-weight: 800;
  font-size: 14px;
  color: #fff;
  margin-bottom: 6px;
}
.pos-cta-box-desc {
  font-size: 13px;
  color: rgba(255,255,255,.6);
  line-height: 1.5;
  margin-bottom: 14px;
}

/* Need Help tab — slightly different style */
.pos-tab.pos-tab-chat {
  border-color: rgba(46,184,212,.4);
  color: #58bedb;
}
.pos-tab.pos-tab-chat:hover {
  border-color: #58bedb;
  background: rgba(88,190,219,.08);
}

/* Return Status — stage 1 clickable CTA pill */
.pos-status-pill-cta {
  cursor: pointer;
  background: linear-gradient(135deg, #22c55e, #16a34a);
  border: none;
  color: #fff !important;
  font-size: 13px;
  font-weight: 700;
  border-radius: 999px;
  padding: 5px 14px;
  transition: transform .15s, box-shadow .15s;
  animation: pos-badge-breathe 2.2s ease-in-out infinite;
}
.pos-status-pill-cta:hover {
  transform: scale(1.04);
  box-shadow: 0 4px 14px rgba(34,197,94,.4);
}

/* =========================================================
   LANGUAGE TOGGLE SWITCH
   ========================================================= */
.pos-portal-toprow-right {
  display: flex;
  align-items: center;
  gap: 14px;
}

.pos-lang-switch {
  display: flex;
  align-items: center;
  gap: 7px;
  user-select: none;
}

.pos-lang-label {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .8px;
  color: rgba(255,255,255,.35);
  transition: color .2s;
  cursor: pointer;
}
.pos-lang-label.is-active {
  color: #fff;
}

.pos-lang-toggle {
  position: relative;
  width: 42px;
  height: 24px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 999px;
  cursor: pointer;
  padding: 0;
  transition: background .2s;
  flex-shrink: 0;
}
.pos-lang-toggle:hover {
  background: rgba(255,255,255,.18);
}

.pos-lang-knob {
  position: absolute;
  top: 3px;
  left: 3px;
  width: 16px;
  height: 16px;
  background: #fff;
  border-radius: 50%;
  transition: transform .22s cubic-bezier(.4,0,.2,1);
  box-shadow: 0 1px 4px rgba(0,0,0,.3);
}
.pos-lang-knob.is-es {
  transform: translateX(18px);
}

/* Client Dashboard sub-label under logo */
.pos-portal-logo-sub {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: rgba(255,255,255,.4);
  margin-top: 4px;
}
