:root{--jw-green: #00c472;--jw-green-dark: #00a860;--jw-green-deeper: #007a47;--jw-green-pale: rgba(0, 196, 114, .12);--jw-blue: #1a56db;--jw-blue-mid: #0062ff;--jw-blue-pale: rgba(26, 86, 219, .1);--red: #ff3b5c;--orange: #ff8c00;--bg: #f2f6ff;--surface: #ffffff;--surface2: #f2f6fb;--border: #d8e3f3;--text: #0a1628;--text-muted: #5f7693;--text-light: #9aafc7;--sidebar-bg: linear-gradient(180deg, #0a1628 0%, #0d1e35 60%, #0a1a2e 100%);--sidebar-text: #c8d8f0;--font-display: "Inter", sans-serif;--font-body: "DM Sans", sans-serif;--radius: 14px;--shadow-1: 0 2px 12px rgba(10, 22, 40, .07);--login-bg: #060f1e;--primary: var(--jw-blue);--green: var(--jw-green);--green-pale: var(--jw-green-pale);--green-deeper: var(--jw-green-deeper);--muted: var(--text-muted);--danger: var(--red)}[data-theme=dark]{--bg: #0b1220;--surface: #0f1c2e;--surface2: #152741;--border: #213a5d;--text: #e8eef6;--text-muted: #9ab1cc;--text-light: #6a88ad;--sidebar-bg: linear-gradient(180deg, #080f1c 0%, #0b1524 60%, #080e1a 100%);--sidebar-text: #8899b4;--login-bg: #060f1e;--shadow-1: 0 2px 12px rgba(0, 0, 0, .35);--jw-green-dark: #00d6a9;--jw-green-pale: rgba(0, 214, 169, .16);--jw-blue-pale: rgba(37, 99, 235, .16);color-scheme:dark}[data-theme=dark] body{background:var(--bg);background-image:radial-gradient(rgba(37,99,235,.1) 1px,transparent 1px);background-size:26px 26px}[data-theme=dark] .page-header h1{background:linear-gradient(135deg,#e8eef6,#4a7fe8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}[data-theme=dark] .form-control{background:var(--surface2);color:var(--text);border-color:var(--border)}[data-theme=dark] select.form-control option{background:var(--surface2);color:var(--text)}[data-theme=dark] .page .btn-ghost,[data-theme=dark] .modal-card .btn-ghost,[data-theme=dark] .btn-ghost{background:var(--surface2);border-color:var(--border);color:var(--text-muted)}[data-theme=dark] .modal-card{box-shadow:0 8px 40px #00000073}[data-theme=dark] .modal-card-head{background:linear-gradient(180deg,#192638 0%,var(--surface) 100%)}[data-theme=dark] .modal-close{background:var(--surface2)}[data-theme=dark] .data-table th{background:linear-gradient(180deg,#192638 0%,var(--surface2) 100%);color:#8aaac8}[data-theme=dark] .data-table td{color:var(--text)}[data-theme=dark] .data-table tr:hover td,[data-theme=dark] .settings-logo-preview,[data-theme=dark] .doc-preview-frame-wrap{background:var(--surface2)}[data-theme=dark] .doc-preview-frame{background:var(--surface)}[data-theme=dark] .line-items-grid-head{color:var(--text-light)}[data-theme=dark] .dash-chart-card{box-shadow:0 2px 12px #00000040}[data-theme=dark] .dash-chart-card .card-header{background:linear-gradient(180deg,#192638 0%,var(--surface) 100%)}[data-theme=dark] .stat-value--green,[data-theme=dark] .form-success,[data-theme=dark] .invoice-total,[data-theme=dark] .banner a,[data-theme=dark] .login-forgot-link{color:var(--jw-green)}[data-theme=dark] .invoice-pos-tabs .btn--active{background:var(--jw-green-pale);border-color:var(--jw-green);color:var(--jw-green)}[data-theme=dark] .picker-item:hover:not(:disabled){background:var(--jw-green-pale)}*{box-sizing:border-box;margin:0;padding:0}html{scrollbar-gutter:stable}html.scroll-locked{overflow:hidden}body{font-family:var(--font-body);font-size:14px;color:var(--text);background:var(--bg);min-height:100vh}#root{min-height:100vh}.app-loading{display:grid;place-items:center;min-height:100vh;color:var(--text-muted)}.app-shell{display:flex;min-height:100vh}.app-sidebar{width:240px;flex-shrink:0;background:var(--sidebar-bg);color:var(--sidebar-text);display:flex;flex-direction:column;padding:16px 12px}.app-brand{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:8px 10px 20px}.app-brand-mark{width:36px;height:36px;border-radius:10px;background:var(--jw-green);color:#0a1628;font-weight:800;display:grid;place-items:center;font-family:var(--font-display)}.app-brand-text{font-family:var(--font-display);font-weight:700;font-size:16px}.app-brand-logo{max-height:40px;max-width:140px;object-fit:contain;border-radius:4px}.app-nav-group{margin-bottom:8px}.app-nav-section{padding:12px 12px 4px;font-size:9.5px;letter-spacing:2px;text-transform:uppercase;color:#ffffff47;font-weight:700}.app-nav-ext{margin-left:auto;font-size:11px;opacity:.6}.app-mobile-toggle,.app-header-menu,.app-sidebar-backdrop{display:none}.app-nav{display:flex;flex-direction:column;gap:2px;flex:1;overflow-y:auto}.app-nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;color:inherit;text-decoration:none;font-size:13px;font-weight:500;opacity:.85}.app-nav-item:hover{background:#ffffff14;opacity:1}.app-nav-item--active{background:linear-gradient(90deg,#00d6a933,#00d6a90d);border-left:3px solid var(--jw-green);color:#fff;font-weight:700;opacity:1}.app-nav-item--optional{opacity:.55}.app-nav-icon{width:1.25rem;text-align:center}.app-sidebar-foot{padding-top:12px;margin-top:auto;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;gap:8px}.app-build-id{font-size:10px;opacity:.5;word-break:break-all}.pwa-install-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;background:#00c47226;border:1.5px solid rgba(0,196,114,.3);color:#00c472;border-radius:8px;padding:8px 12px;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;transition:background .15s ease}.pwa-install-btn:hover{background:#00c47238}.ios-install-intro{text-align:center;margin-bottom:16px}.ios-install-icon{font-size:32px;margin-bottom:8px}.ios-install-intro p{font-size:13px;color:var(--text-muted);margin:0}.ios-install-steps{list-style:none;display:flex;flex-direction:column;gap:10px;margin:0 0 20px;padding:0}.ios-install-step{display:flex;align-items:flex-start;gap:12px;background:var(--surface2);border-radius:10px;padding:12px 14px;border:1px solid var(--border)}.ios-install-step-n{font-size:18px;flex-shrink:0;line-height:1.2}.ios-install-step strong{display:block;font-size:13px;margin-bottom:2px}.ios-install-step p{font-size:12px;color:var(--text-muted);margin:0;line-height:1.4}.app-main{flex:1;padding:24px 28px;overflow:auto;scrollbar-gutter:stable}.app-main-col{flex:1;min-width:0;display:flex;flex-direction:column;min-height:100vh}.app-topbar{flex-shrink:0;display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:10px 20px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:150}.user-menu{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:10px;padding:6px 10px 6px 6px;border:1px solid var(--border);border-radius:10px;background:var(--surface2);color:inherit;cursor:pointer;font:inherit;text-align:left;transition:background .15s ease,border-color .15s ease}.user-menu-trigger:hover{background:var(--bg);border-color:var(--text-muted)}.user-menu-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#00c472,#1a56db);color:#fff;font-weight:800;font-size:13px;display:grid;place-items:center;flex-shrink:0}.user-menu-label{display:flex;flex-direction:column;align-items:flex-start;min-width:0;gap:2px}.user-menu-name{font-size:13px;font-weight:700;line-height:1.2;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-role{font-size:10px;font-weight:700;text-transform:capitalize;color:var(--text-muted)}.user-menu-chevron{font-size:10px;color:var(--text-muted);flex-shrink:0}.user-menu-panel{position:absolute;top:calc(100% + 8px);right:0;z-index:300;min-width:240px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 32px #0a162829;padding:8px}.user-menu-panel-head{padding:10px 12px 12px;border-bottom:1px solid var(--border);margin-bottom:4px}.user-menu-panel-name{font-size:14px;font-weight:700}.user-menu-panel-email{font-size:12px;color:var(--text-muted);margin-top:2px;word-break:break-all}.user-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:none;border-radius:8px;background:none;color:inherit;font:inherit;font-size:13px;font-weight:500;text-align:left;cursor:pointer}.user-menu-item:hover{background:var(--surface2)}.user-menu-item-icon{width:1.25rem;text-align:center;flex-shrink:0}.user-menu-item--danger{color:var(--red)}.user-menu-item--danger:hover{background:#ff3b5c14}.user-menu-divider{height:1px;background:var(--border);margin:4px 0}.user-menu--sidebar{width:100%}.user-menu--sidebar .user-menu-trigger{width:100%;box-sizing:border-box;background:#ffffff0f;border-color:#ffffff1f;color:var(--sidebar-text)}.user-menu--sidebar .user-menu-trigger:hover{background:#ffffff1a;border-color:#fff3}.user-menu--sidebar .user-menu-name{color:#ffffffe6}.user-menu--sidebar .user-menu-role{color:#fff6}.user-menu--sidebar .user-menu-chevron{color:#ffffff59}.user-menu--sidebar .user-menu-panel{top:auto;bottom:calc(100% + 8px);left:0;right:0;min-width:0}.app-page-outlet{flex:1;min-height:0}.page-placeholder{max-width:720px}.page-header h1{font-family:var(--font-display);font-size:26px;font-weight:800;margin-bottom:4px}.page-path{font-size:12px;color:var(--text-muted);font-family:ui-monospace,monospace}.page-blurb{margin-top:16px;color:var(--text-muted);line-height:1.55}.page-note{margin-top:20px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);font-size:13px;color:var(--text-muted)}.page-note code{font-size:12px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;border-radius:10px;border:none;font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;text-decoration:none}.btn-primary{background:linear-gradient(135deg,var(--jw-green) 0%,var(--jw-green-dark) 100%);color:#fff;box-shadow:0 2px 8px #00c4724d}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 16px #00c47266}.page .btn-ghost,.modal-card .btn-ghost,.login-card .btn-ghost{background:var(--surface);color:var(--text-muted);border:1px solid var(--border)}.app-sidebar .btn-ghost{background:transparent;color:var(--sidebar-text);border:1px solid rgba(255,255,255,.2)}.btn-inventory-pick{color:var(--jw-green-deeper)!important;border-color:#00c47259!important}.btn-sm{padding:6px 12px;font-size:12px}.login-page{min-height:100vh;display:flex;background:var(--login-bg);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(0,196,114,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,196,114,.03) 1px,transparent 1px);background-size:40px 40px;pointer-events:none}.login-glow-1,.login-glow-2{position:absolute;border-radius:50%;pointer-events:none}.login-glow-1{top:-80px;left:-100px;width:600px;height:600px;background:radial-gradient(circle,rgba(0,196,114,.22) 0%,transparent 70%)}.login-glow-2{bottom:-120px;right:-80px;width:500px;height:500px;background:radial-gradient(circle,rgba(0,98,255,.2) 0%,transparent 70%)}.login-left{flex:1;display:none;flex-direction:column;justify-content:center;padding:48px 56px;position:relative;z-index:1}.login-brand-logo{width:240px;max-width:100%;height:auto;display:block;margin-bottom:24px;filter:drop-shadow(0 6px 24px rgba(0,196,114,.5)) drop-shadow(0 2px 8px rgba(0,0,0,.5))}.login-card-logo-wrap{display:none;text-align:center;margin-bottom:16px}.login-card-logo{height:64px;width:auto;max-width:100%;filter:drop-shadow(0 4px 12px rgba(0,201,167,.4))}@media (max-width: 960px){.login-card-logo-wrap{display:block}}@media (min-width: 960px){.login-left{display:flex}}.login-tagline{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--jw-green);font-weight:700;margin-bottom:8px}.login-headline{font-family:var(--font-display);font-size:clamp(32px,4vw,48px);font-weight:900;color:#fff;line-height:1.1;letter-spacing:-1px;margin-bottom:16px}.login-headline span{background:linear-gradient(135deg,var(--jw-green),#00e5a0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-desc{font-size:15px;color:#ffffff80;line-height:1.7;max-width:380px;margin-bottom:32px}.login-features{display:flex;flex-direction:column}.lf-item{display:flex;align-items:center;gap:14px;font-size:13.5px;color:#ffffffa6;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.05)}.lf-dot{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;font-size:14px;flex-shrink:0}.lf-dot.green{background:#00c47226;border:1px solid rgba(0,196,114,.3)}.lf-dot.blue{background:#0062ff26;border:1px solid rgba(0,98,255,.3)}.login-trust{display:flex;align-items:center;gap:10px;margin-top:32px;padding:12px 16px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:12px;width:fit-content}.login-trust-text{font-size:12px;color:#fff6;line-height:1.4}.login-right{width:100%;max-width:480px;margin:0 auto;display:flex;align-items:center;justify-content:center;padding:32px 24px;position:relative;z-index:1}@media (min-width: 960px){.login-right{width:460px;max-width:none;margin:0;flex-shrink:0}}.login-card{width:100%;padding:36px 32px;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:24px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 32px 80px #0000004d}.login-card:before{content:"";display:block;height:3px;background:linear-gradient(90deg,var(--jw-green),#00e5a0,var(--jw-green));border-radius:3px;margin-bottom:28px}.login-card-title{font-family:var(--font-display);font-size:24px;font-weight:900;color:#fff;margin-bottom:4px}.login-card-sub{font-size:13px;color:#ffffff61;margin-bottom:24px}.login-card .form-label{color:#ffffff73;font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase}.login-card .form-control{background:#ffffff0d;border:1.5px solid rgba(255,255,255,.1);color:#fff;border-radius:12px}.login-card .form-control:focus{border-color:var(--jw-green);box-shadow:0 0 0 3px #00c4721f}.login-card .form-control::placeholder{color:#fff3}.btn-login{width:100%;padding:14px;border-radius:12px;border:none;background:linear-gradient(135deg,#00c472,#00a860);color:#fff;font-family:var(--font-display);font-size:15px;font-weight:800;cursor:pointer;box-shadow:0 4px 20px #00c47266}.btn-login:hover:not(:disabled){transform:translateY(-2px)}.btn-login:disabled{opacity:.5;cursor:not-allowed}.back-btn{background:none;border:none;color:#fff6;font-size:13px;cursor:pointer;padding:0;margin-bottom:16px}.back-btn:hover{color:#fff}.login-trust-strip{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-top:20px;padding-top:16px;border-top:1px solid rgba(255,255,255,.08);font-size:11px;color:#ffffff59;font-weight:600}.login-title{font-family:var(--font-display);font-size:24px;font-weight:800;color:#fff}.login-sub{margin-top:6px;color:#ffffff73;font-size:13px}.env-status{margin:20px 0;display:grid;grid-template-columns:auto 1fr;gap:8px 16px;font-size:13px}.env-status dt{color:var(--text-muted);font-weight:600}.env-status dd.ok{color:var(--jw-green-dark);font-weight:600}.env-status dd.warn{color:#e67e00;font-weight:600}.login-hint{font-size:12px;color:var(--text-muted);line-height:1.5;margin-bottom:20px}.login-hint code{font-size:11px;background:#0a16280f;padding:2px 5px;border-radius:4px}.login-cta{width:100%}.login-card--wide{max-width:440px}.login-tabs{display:flex;gap:8px;margin:20px 0 12px}.login-card .form-error{background:#ff3b5c1f;border:1px solid rgba(255,59,92,.3);color:#ff8fa3;border-radius:8px;padding:10px 14px}.login-card .form-success{background:#00c4721f;border:1px solid rgba(0,196,114,.3);color:#00e084;border-radius:8px;padding:10px 14px}.login-forgot-link{color:var(--jw-green)}.login-tab{flex:1;padding:8px 12px;border:1px solid var(--border);border-radius:10px;background:transparent;font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;color:var(--text-muted)}.login-tab--active{background:#00d6a91f;border-color:var(--jw-green);color:var(--text)}.login-form{display:flex;flex-direction:column;gap:14px}.form-label{display:flex;flex-direction:column;gap:6px;font-size:12px;font-weight:600;color:var(--text-muted)}.form-control{padding:10px 12px;border:1px solid var(--border);border-radius:10px;font-family:inherit;font-size:14px;background:var(--surface);color:var(--text)}.form-control:focus{outline:2px solid rgba(0,214,169,.35);border-color:var(--jw-green)}.form-error{font-size:13px;color:#ff3b5c;margin-bottom:8px}.form-error.show{display:block}.form-success{font-size:13px;color:var(--jw-green-dark);margin-bottom:8px}.form-success.show{display:block}.form-success--confirm{color:#00a87d;background:#00c9a71a;border:1px solid rgba(0,201,167,.3);border-radius:8px;padding:12px}.refund-type-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}.refund-type-btn{display:flex;flex-direction:column;gap:4px;padding:10px;border-radius:8px;border:2px solid var(--border);background:var(--surface2, #f7f9fb);color:var(--text-muted);font-size:12px;cursor:pointer;text-align:left}.refund-type-btn strong{font-size:12px}.refund-type-btn span{font-size:10px;font-weight:400;opacity:.85}.refund-type-btn--refund.refund-type-btn--active{border-color:#ff3b5c;background:#ff3b5c1a;color:#ff3b5c}.refund-type-btn--credit.refund-type-btn--active{border-color:#e67e00;background:#e67e001a;color:#e67e00}.refund-info-banner{border-radius:6px;padding:10px 14px;margin-bottom:14px;font-size:12px;line-height:1.5}.refund-info-banner--refund{background:#ff3b5c14;border-left:4px solid #ff3b5c}.refund-info-banner--credit{background:#e67e0014;border-left:4px solid #e67e00}.refund-submit--credit{background:#e67e00!important;border-color:#e67e00!important}.update-banner-update:disabled,.update-banner-later:disabled{opacity:.65;cursor:not-allowed}.pw-row{display:flex;gap:8px;align-items:center}.pw-row .form-control{flex:1}.pw-toggle{flex-shrink:0}.login-forgot-row{display:flex;justify-content:flex-end;margin:-4px 0 8px}.login-forgot-link{background:none;border:none;padding:0;font-size:13px;font-weight:600;color:var(--jw-green-dark);cursor:pointer;text-decoration:none}.login-forgot-link:hover{text-decoration:underline;color:var(--jw-green)}.login-foot{margin-top:16px;font-size:11px;color:var(--text-muted);line-height:1.45}.app-header{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;border-bottom:1px solid var(--border);background:var(--surface)}.app-header-user{display:flex;align-items:center;gap:12px}.app-header-avatar{width:40px;height:40px;border-radius:10px;background:var(--jw-green);color:#0a1628;font-weight:800;display:grid;place-items:center}.app-header-name{font-weight:700;font-size:15px}.app-header-meta{font-size:12px;color:var(--text-muted)}.app-header-role{margin-left:8px;padding:2px 8px;border-radius:20px;background:#00d6a926;font-size:10px;font-weight:700;text-transform:capitalize}.app-header-actions{display:flex;gap:8px;align-items:center}.app-header-btn{min-width:40px}.app-toast{position:fixed;bottom:24px;right:24px;left:auto;transform:translateY(calc(100% + 32px));background:#1a2d4a;color:#fff;padding:13px 20px;border-radius:11px;border:1px solid rgba(255,255,255,.15);font-size:13.5px;font-weight:600;z-index:20000;max-width:min(calc(100vw - 48px),380px);box-shadow:0 8px 32px #00000059;transition:transform .25s ease,opacity .25s ease;pointer-events:none;opacity:0;line-height:1.4;word-break:break-word}.app-toast--visible{transform:translateY(0);opacity:1}@media (max-width: 768px){.app-toast{bottom:16px;right:16px;left:16px;max-width:none}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a16288c;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;z-index:10000;padding:20px;overflow:hidden;box-sizing:border-box}.modal-overlay--open{display:flex}.modal-card{display:flex;flex-direction:column;width:100%;max-width:min(480px,calc(100vw - 40px));max-height:min(calc(100dvh - 40px),720px);margin:auto;background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:0;overflow:hidden;box-shadow:0 8px 40px #0a162829,0 2px 8px #0a162814;box-sizing:border-box}.modal-title{font-family:var(--font-display);font-size:18px;font-weight:800;flex:1;min-width:0;line-height:1.35;margin:0;padding:0;color:var(--text);-webkit-text-fill-color:currentColor;background:none}.modal-head-spacer{width:36px;flex-shrink:0}.modal-lead,.modal-sub{margin:0 0 16px;font-size:13px;line-height:1.55;color:var(--text-muted)}.modal-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;margin-top:16px}.modal-actions .btn{min-width:96px;justify-content:center}.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text)}.btn-danger{background:#ff3b5c;color:#fff}.modal-card--wide{max-width:min(800px,calc(100vw - 40px))}.modal-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-shrink:0;padding:22px 26px 18px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,var(--surface) 0%,var(--surface2) 100%);border-radius:18px 18px 0 0;border-top:3px solid var(--jw-green);box-sizing:border-box}.modal-close{flex-shrink:0;border:1.5px solid var(--border);background:var(--bg);font-size:16px;line-height:1;cursor:pointer;color:var(--text-muted);padding:4px 10px;border-radius:7px;margin:0}.modal-card-body{flex:1;min-height:0;min-width:0;overflow-x:auto;overflow-y:auto;padding:20px 26px 26px;-webkit-overflow-scrolling:touch;box-sizing:border-box}.modal-card-body .form-label .form-control,.modal-card-body .form-label select,.modal-card-body .form-label textarea,.modal-card-body .form-label input{width:100%;max-width:100%;box-sizing:border-box}.modal-card-body .form-row-2,.modal-card-body .form-row-3{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.modal-card-body .form-row-3{grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(0,1fr)}.modal-card-body .form-stack{gap:14px}.modal-card-body .modal-actions{margin-top:4px;padding-top:16px;border-top:1px solid var(--border)}.modal-card-body .form-label{margin:0}.modal-card-body .form-error{margin:-8px 0 12px}.modal-card-body .mfa-code-input{text-align:center;font-size:22px;font-weight:700;letter-spacing:.35em;padding:12px 14px;font-variant-numeric:tabular-nums}.page-header--row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px}.page-header h1{font-family:var(--font-display);font-size:26px;font-weight:800}.page-meta{font-size:13px;color:var(--text-muted)}.toolbar{margin-bottom:14px}.toolbar-search{max-width:320px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:20px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.stat-label{font-size:12px;color:var(--text-muted);font-weight:600}.stat-value{font-size:22px;font-weight:800;margin-top:4px}.stat-value--green{color:var(--jw-green-dark)}.stat-value--red{color:#ff3b5c}.stat-sub{font-size:11px;color:var(--text-muted);margin-top:4px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:16px}.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.card-title{font-size:15px;font-weight:700}.table-wrap{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th,.data-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border)}.data-table th{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.cell-sub{font-size:10px;color:#e67e00;margin-top:2px}.empty-cell{text-align:center;padding:24px;color:var(--text-muted)}.badge{display:inline-block;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700}.b-paid{background:#00d6a926;color:var(--jw-green-dark)}.b-pending{background:#ff8c001f;color:#e67e00}.b-overdue{background:#ff3b5c1f;color:#ff3b5c}.b-partial{background:#3d8bff1f;color:#3d8bff}.act-row{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.btn-action{display:inline-flex;align-items:center;gap:4px;white-space:nowrap;padding:4px 8px;line-height:1.2}.btn-action-icon{font-size:14px;line-height:1}.btn-action-label{font-size:11px;font-weight:600}.action-menu__compact{display:none}.action-menu-trigger{font-weight:700}.action-menu-trigger--single{display:inline-flex;align-items:center;gap:6px}.action-menu-trigger-icon{font-size:16px;line-height:1}.btn-icon{border:none;background:transparent;cursor:pointer;font-size:16px;padding:4px;border-radius:6px;line-height:1;transition:background .15s ease,transform .1s ease}.btn-icon:hover{background:var(--surface2)}.btn-icon:active{transform:scale(.94)}#cb-tooltip{position:fixed;background:#0a1628ed;color:#fff;font-size:11.5px;font-weight:600;padding:5px 12px;border-radius:7px;white-space:nowrap;pointer-events:none;z-index:25000;letter-spacing:.2px;box-shadow:0 4px 16px #0000004d;font-family:var(--font-body);display:none}[data-theme=dark] #cb-tooltip{background:#c8dcfff2;color:#0a1628}.clients-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.client-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.client-card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.client-avatar{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;font-weight:800}.client-actions{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end}.client-name{font-size:16px;font-weight:700}.client-meta{font-size:12px;color:var(--text-muted);margin-top:4px}.client-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px;text-align:center}.client-stat-val{display:block;font-weight:700;font-size:14px}.client-stat-lbl{font-size:10px;color:var(--text-muted)}.settings-logo-preview{max-width:160px;max-height:80px;object-fit:contain;margin-bottom:8px;border-radius:8px;background:#f4f7fb;padding:8px}.form-stack{display:flex;flex-direction:column;gap:14px}.form-row-2{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px}.form-row-3{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(0,1fr);gap:12px}.form-hint{font-size:12px;color:var(--text-muted)}.send-doc-info-banner,.send-doc-success-banner{background:var(--jw-green-pale, rgba(0, 196, 114, .08));border:1.5px solid rgba(0,196,114,.3);border-radius:10px;padding:14px 16px;margin-bottom:16px;font-size:13px;color:var(--jw-green-deeper, #0a7a4a)}.send-doc-success-lead{margin:0 0 12px;font-size:14px;font-weight:600}.send-doc-wa-btn{width:100%;max-width:280px}.send-doc-no-phone{margin:0 0 8px}.send-doc-channels{border:1px solid var(--border);border-radius:10px;padding:12px 14px 14px;margin:0}.send-doc-channels-legend{font-size:12px;font-weight:600;color:var(--text-muted);padding:0 6px}.send-doc-channel{margin:8px 0 0}.send-doc-channel-field{margin:8px 0 0 24px}.send-doc-channel--disabled{opacity:.65}.doc-preview-loading{padding:24px;text-align:center}.line-items-head{display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:13px}.modal-overlay--stack{z-index:10050}.line-items-section{margin:16px 0;padding-top:8px;border-top:1px solid var(--border)}.line-items-label{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted);margin-bottom:10px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.line-items-list{display:flex;flex-direction:column}.line-items-grid-head{display:grid;grid-template-columns:minmax(0,1fr) 64px 96px 80px 36px;gap:8px;padding:4px 0 8px;font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--text-light);font-weight:700;border-bottom:2px solid var(--border)}.line-items-grid-head span:nth-child(2),.line-items-grid-head span:nth-child(3){text-align:center}.line-items-grid-head span:nth-child(4){text-align:right}.line-item-row{padding:10px 0;border-bottom:1px solid var(--border)}.line-item-row:last-child{border-bottom:none}.line-item-pill-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:6px;min-width:0}.line-inv-pill{display:inline-flex;align-items:center;gap:4px;flex-shrink:0;font-size:10px;font-weight:700;letter-spacing:.3px;padding:3px 9px;border-radius:6px}.line-inv-pill--service{background:#00c4721f;color:var(--jw-green-deeper)}.line-inv-pill--product{background:#3d8bff1f;color:var(--jw-blue)}.line-item-inventory-hint{font-size:11px;color:var(--text-muted);line-height:1.35;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.line-item-fields-row{display:grid;grid-template-columns:minmax(0,1fr) 64px 96px 80px 36px;gap:8px;align-items:center}.line-item-desc-label,.line-item-qty-label,.line-item-price-label{margin:0;min-width:0}.line-item-desc-input{width:100%;font-size:13px;font-weight:600;padding:8px 10px;box-sizing:border-box}.line-item-num{width:100%;font-size:13px;padding:8px 6px;text-align:center;box-sizing:border-box}.line-item-num--price{text-align:right}.line-item-total{font-size:13px;font-weight:700;color:var(--jw-green-deeper);text-align:right;white-space:nowrap;padding-right:2px}.line-item-remove{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;background:var(--surface2);border-radius:8px;font-size:18px;line-height:1;color:var(--text-muted);cursor:pointer}.line-item-remove:hover:not(:disabled){background:#ff3b5c1a;color:var(--red)}.line-item-remove:disabled{opacity:.35;cursor:not-allowed}.line-items-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.line-items-empty{text-align:center;padding:16px;font-size:13px;color:var(--text-muted)}.totals-section{margin-top:16px;padding:14px 16px;background:var(--surface2);border-radius:10px;border:1px solid var(--border)}.tot-row{display:flex;justify-content:space-between;padding:6px 0;font-size:13px;color:var(--text-muted)}.tot-grand{display:flex;justify-content:space-between;padding-top:10px;margin-top:8px;border-top:2px solid var(--border);font-family:var(--font-display);font-size:18px;font-weight:800;color:var(--text)}.picker-list{margin-top:12px;max-height:min(50vh,360px);overflow-y:auto;display:flex;flex-direction:column;gap:6px}.picker-item{display:flex;justify-content:space-between;align-items:center;gap:12px;width:100%;text-align:left;padding:10px 14px;background:var(--surface2);border:1px solid var(--border);border-radius:8px;cursor:pointer;font:inherit;color:inherit}.picker-item:hover:not(:disabled){border-color:var(--jw-green);background:var(--jw-green-pale)}.picker-item--disabled{opacity:.45;cursor:not-allowed}.picker-item-name{font-weight:600;font-size:13px}.picker-item-desc{font-size:11px;color:var(--text-muted);margin-top:2px}.picker-type-badge{display:inline-block;margin-top:4px;font-size:10px;padding:1px 7px;border-radius:4px;font-weight:600}.picker-type-badge--service{background:#00c4721f;color:var(--jw-green-deeper)}.picker-type-badge--product{background:#3d8bff1f;color:var(--jw-blue)}.picker-stock{display:block;font-size:10px;color:var(--text-muted);margin-top:2px}.picker-item-price{flex-shrink:0;text-align:right}.picker-empty{text-align:center;padding:24px}.page-header h1{font-family:var(--font-display);font-size:26px;font-weight:800;background:linear-gradient(135deg,#0a1628,#1a56db);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-card{box-shadow:var(--shadow-1)}@media (max-width: 700px){.line-items-grid-head{display:none}.line-item-fields-row{grid-template-columns:1fr 1fr;grid-template-areas:"desc desc" "qty price" "total remove";gap:8px}.line-item-desc-label{grid-area:desc}.line-item-qty-label{grid-area:qty}.line-item-price-label{grid-area:price}.line-item-total{grid-area:total;text-align:left;padding:4px 0;font-size:14px}.line-item-remove{grid-area:remove;justify-self:end}.line-item-inventory-hint{white-space:normal;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}}.invoice-total{font-size:20px;font-weight:800;color:var(--jw-green-dark);padding-top:8px}.banner{padding:12px 14px;border-radius:10px;margin-bottom:16px;font-size:13px}.banner--info{background:#00d6a91a;border:1px solid rgba(0,214,169,.3)}.banner a{color:var(--jw-green-dark);font-weight:600}.load-more-wrap{text-align:center;padding:16px 0}.empty-block{text-align:center;padding:40px 20px;color:var(--text-muted)}.row-refund{background:#ff3b5c0a}.text-red{color:#ff3b5c}.mono{font-family:ui-monospace,monospace;font-size:12px}.page-sub{font-size:13px;color:var(--text-muted);margin-top:4px}.page-actions{display:flex;flex-wrap:wrap;gap:8px}.mi-strip{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;margin-bottom:14px}.mi-strip-title{font-size:15px}.mi-strip-sub{font-size:12px;color:var(--text-muted);margin-top:4px}.mi-strip-actions{display:flex;flex-wrap:wrap;gap:8px}.mi-panel{margin-bottom:14px}.stat-grid--4{grid-template-columns:repeat(4,1fr)}.recon-toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:12px}.recon-filter{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;color:var(--text-muted)}.recon-filter .form-control{width:140px}.data-table--compact th,.data-table--compact td{font-size:12px}.text-muted{color:var(--text-light);font-size:11px}.form-check{display:flex;align-items:center;gap:8px;font-size:13px}.wizard-body{font-size:14px;line-height:1.55}.wizard-body ul{font-size:13px;color:var(--text-muted);padding-left:1.2rem}.tab-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.tab-active{background:var(--surface2);border-color:var(--jw-green)}.simple-list{margin:0;padding-left:1.2rem;font-size:13px;line-height:1.6}@media (max-width: 768px){.modal-overlay{align-items:flex-end;padding:0}.modal-card,.modal-card--wide{max-width:100%;max-height:calc(100dvh - env(safe-area-inset-bottom,0px));border-radius:18px 18px 0 0;margin:0}.modal-card-head{padding:18px 16px 14px}.modal-card-body{padding:16px}.modal-actions{flex-direction:column-reverse;align-items:stretch}.modal-actions .btn{width:100%;min-width:0}.modal-card-body .form-row-2,.modal-card-body .form-row-3,.form-row-2,.form-row-3{grid-template-columns:1fr}.stat-grid--4{grid-template-columns:repeat(2,1fr)}.app-mobile-toggle{display:block;position:fixed;top:12px;left:12px;z-index:200;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:8px 12px}.app-header-menu{display:inline-flex}.app-sidebar{position:fixed;left:0;top:0;height:100dvh;z-index:180;transform:translate(-100%);transition:transform .25s ease;box-shadow:4px 0 24px #00000059}.app-sidebar--open{transform:translate(0)}.app-sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:170;background:#00000073;border:none;cursor:pointer}.app-main-col{width:100%}.user-menu-label,.user-menu-chevron{display:none}.user-menu--sidebar .user-menu-label,.user-menu--sidebar .user-menu-chevron{display:flex}.user-menu--sidebar .user-menu-chevron{display:block}.user-menu-trigger{padding:4px}.pwa-install-btn,.action-menu__inline{display:none}.action-menu__compact{display:block}.action-menu-trigger{min-height:44px;min-width:96px;padding:10px 14px}.action-menu--open .action-menu-trigger{visibility:hidden}.data-table .act-cell:has(.action-menu--open){z-index:3}.action-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10001;background:#0a162873;border:none;padding:0;cursor:pointer}.action-menu-sheet{position:fixed;left:0;right:0;bottom:0;z-index:10002;background:var(--surface);border-radius:18px 18px 0 0;box-shadow:0 -8px 32px #0a162826;padding-bottom:env(safe-area-inset-bottom,0px);max-height:min(70dvh,420px);display:flex;flex-direction:column}.action-menu-sheet-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 12px;border-bottom:1px solid var(--border);font-weight:700}.action-menu-sheet-close{border:none;background:var(--surface2);width:36px;height:36px;border-radius:50%;font-size:16px;cursor:pointer;flex-shrink:0}.action-menu-sheet-body{overflow-y:auto;padding:8px 12px 16px;display:grid;gap:8px}.action-menu-sheet-item{display:flex;align-items:center;gap:12px;width:100%;min-height:48px;padding:12px 16px;border:1px solid var(--border);border-radius:12px;background:var(--surface);font:inherit;font-size:15px;font-weight:600;text-align:left;cursor:pointer}.action-menu-sheet-item:active{background:var(--surface2)}.action-menu-sheet-icon{font-size:20px;width:28px;text-align:center;flex-shrink:0}.data-table .act-cell{position:sticky;right:0;background:var(--surface);box-shadow:-6px 0 12px #0a16280f;z-index:1;vertical-align:middle;padding-left:10px;min-width:108px}.table-pagination{flex-direction:column;align-items:stretch}.table-pagination-actions{width:100%;justify-content:space-between}.table-pagination-actions .btn{min-height:44px;min-width:96px;padding:10px 16px}.client-actions{flex:1 1 100%;justify-content:flex-start;margin-top:8px}.client-actions .action-menu__compact{width:100%}.client-actions .action-menu-trigger{width:100%;justify-content:center}.page-actions{flex-direction:column;align-items:stretch;width:100%}.page-actions .btn{min-height:44px;width:100%}}.doc-preview-actions{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}.doc-preview-frame-wrap{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:#f0f4f8;min-height:420px}.doc-preview-frame{width:100%;min-height:520px;border:0;background:#fff}.btn-icon--wa,.btn-action.btn-icon--wa,.doc-preview-wa{color:#25d366}.print-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#fff;display:flex;flex-direction:column;overflow:auto}.print-overlay-bar{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#0a1628;color:#fff;flex-shrink:0}.print-overlay-title{flex:1;font-size:14px;font-weight:700}.print-overlay-body{flex:1;padding:20px;overflow:auto}.empty-state{text-align:center;padding:48px 20px 40px;color:var(--text-muted)}.empty-state--compact{padding:32px 16px}.es-icon{font-size:48px;margin-bottom:16px;display:block}.es-title{font-size:17px;font-weight:800;color:var(--text);margin-bottom:8px}.es-sub{font-size:13px;color:var(--text-muted);line-height:1.6;max-width:360px;margin:0 auto 16px}.es-steps{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:16px}.es-step{font-size:12px;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:8px 12px}.es-step-num{display:inline-flex;width:20px;height:20px;align-items:center;justify-content:center;background:var(--primary);color:#fff;border-radius:50%;font-size:11px;font-weight:700;margin-right:6px}.es-trust{margin-top:12px;font-size:12px;color:var(--text-muted)}.page-dashboard .page-sub{margin:4px 0 0;font-size:13px;color:var(--text-muted)}.dash-quick-actions{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}.dash-quick-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:inherit;font:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s ease,border-color .15s ease}.dash-quick-btn:hover{background:var(--surface2);border-color:var(--jw-green)}.dash-overdue-banner{margin-bottom:16px}.stat-card--link{text-decoration:none;color:inherit;transition:transform .15s ease,box-shadow .15s ease}.stat-card--link:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0a162814}.dash-insight-pad--link{text-decoration:none;color:inherit;transition:background .15s ease,border-color .15s ease}.dash-insight-pad--link:hover{background:var(--surface2);border-color:#00c9a759}.data-table-row--clickable{cursor:pointer}.data-table-row--clickable:hover td{background:var(--surface2)}.banner--warn{background:#ff8c001f;border:1px solid rgba(255,140,0,.35);color:var(--text)}.banner--warn a{color:var(--text);font-weight:700;text-decoration:underline}.stat-grid--hero{grid-template-columns:repeat(4,1fr)}.stat-card--green{border-color:#00c47240}.stat-card--blue{border-color:#1a56db33}.stat-card--orange{border-color:#e67e0040}.stat-card--red{border-color:#ff3b5c40}.stat-icon{font-size:22px;margin-bottom:6px;display:block}.dash-insight-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}.dash-insight-row--month{grid-template-columns:repeat(4,1fr)}.dash-insight-pad{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px}.di-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.di-value{font-size:20px;font-weight:800;color:var(--text);margin:4px 0}.di-hint{font-size:11px;color:var(--text-muted)}.dash-chart-toolbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:10px;margin-bottom:14px}.dash-chart-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:16px;margin-bottom:16px}.dash-extra-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}.dash-chart-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:0 2px 12px #0a16280f}.dash-chart-card .card-header{padding:12px 18px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,var(--surface) 0%,var(--surface2) 100%)}.dash-chart-wrap{position:relative;height:260px;padding:8px 12px 16px}.dash-chart-wrap--short{height:220px}.dash-aging-note{font-size:12px;color:var(--text-muted);padding:0 16px 12px;margin:0}.dash-top-table{width:100%}.dash-top-q{font-size:12px;color:var(--text-muted)}.dash-empty-panel .dash-empty-actions{display:flex;gap:10px;justify-content:center;margin-top:8px}.app-header-user-btn{display:flex;align-items:center;gap:10px;background:none;border:none;cursor:pointer;text-align:left;padding:4px 8px;border-radius:8px;color:inherit;font:inherit}.app-header-user-btn:hover{background:var(--surface2)}.profile-modal-head{display:flex;align-items:center;gap:14px;margin-bottom:20px}.profile-modal-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#00c472,#1a56db);color:#fff;font-weight:800;font-size:20px;display:grid;place-items:center}.settings-section{margin-bottom:20px}.settings-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin:0 0 10px}.settings-panel{background:var(--surface2);border-radius:12px;padding:16px;border:1px solid var(--border)}.settings-panel-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.mfa-badge{font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px;background:#ff3b5c1a;color:var(--red)}.mfa-badge--on{background:#00c4721f;color:var(--jw-green-deeper, #007a47)}.mfa-qr-wrap{display:flex;justify-content:center}.tab-row--wrap,.act-row--wrap{flex-wrap:wrap}.text-green{color:#00a85c}.loyalty-qw-card,.loyalty-qw-intro{margin-bottom:16px}.loyalty-qw-services{border:1px solid var(--border);border-radius:10px;overflow:hidden}.loyalty-qw-services-head{padding:10px 14px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);background:var(--surface2, rgba(10, 22, 40, .04));border-bottom:1px solid var(--border)}.loyalty-qw-service-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;border-bottom:1px solid var(--border)}.loyalty-qw-service-row:last-child{border-bottom:none}.loyalty-qw-service-info{flex:1;min-width:0}.loyalty-qw-qty{width:76px;flex-shrink:0}.loyalty-qw-total{display:flex;align-items:baseline;gap:8px;padding:12px 0;font-size:15px}.loyalty-card-preview{display:flex;flex-direction:column;gap:16px}.loyalty-card-preview-inner{background:linear-gradient(135deg,#0a1628,#1a3060);border-radius:16px;padding:24px;color:#fff;text-align:center}.loyalty-card-preview-label{font-size:11px;letter-spacing:2px;color:#9aafc7;margin-bottom:4px}.loyalty-card-preview-name{font-size:20px;font-weight:800;margin-bottom:2px}.loyalty-card-preview-biz{font-size:12px;color:#9aafc7;margin-bottom:20px}.loyalty-card-preview-qr{border-radius:12px;width:160px;height:160px;display:block;margin:0 auto 16px;background:#fff;padding:8px}.loyalty-card-preview-qr--loading{display:flex;align-items:center;justify-content:center;font-size:12px;color:#6b7e96;text-align:center;min-height:160px}.loyalty-card-preview-balance{font-size:36px;font-weight:900;line-height:1}.loyalty-card-preview-balance-label{font-size:12px;color:#9aafc7;margin-top:4px}.loyalty-card-preview-barcode{font-size:10px;color:#4a6080;margin-top:8px;font-family:ui-monospace,monospace}.loyalty-card-preview-actions{flex-wrap:wrap}.loyalty-card-preview-qr-slot{min-height:176px;display:flex;justify-content:center;align-items:center;margin-bottom:16px}.loyalty-card-public{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 16px;background:#f0f4f8}.loyalty-card-public__loading{color:#6b7e96;font-size:15px}.loyalty-card-public__error{max-width:360px;width:100%;padding:32px 24px;text-align:center}.loyalty-card-public__error-icon{font-size:40px;margin-bottom:12px}.loyalty-card-public__error-msg{color:#ff3b5c;font-weight:600;margin:0}.loyalty-card-public__card{width:100%;max-width:360px;background:linear-gradient(135deg,#0a1628,#1a3060);border-radius:20px;padding:28px 24px;color:#fff;box-shadow:0 20px 60px #0a162866;text-align:center}.loyalty-card-public__biz{font-size:11px;letter-spacing:3px;color:#9aafc7;text-transform:uppercase;margin-bottom:4px}.loyalty-card-public__name{font-size:22px;font-weight:800;margin-bottom:20px}.loyalty-card-public__qr-wrap{background:#fff;border-radius:14px;padding:12px;display:inline-flex;margin-bottom:20px}.loyalty-card-public__qr-img{display:block;border-radius:6px}.loyalty-card-public__balance{font-size:52px;font-weight:900;line-height:1}.loyalty-card-public__balance-label{font-size:13px;color:#9aafc7;margin-top:4px}.loyalty-card-public__row{display:flex;justify-content:space-between;font-size:12px;color:#9aafc7;margin-top:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,.08)}.loyalty-card-public__row span:last-child{color:#fff;font-weight:600}.loyalty-card-public__powered{margin-top:16px;font-size:11px;color:#6b7e96}.loyalty-card-public__powered a{color:#3d8bff;text-decoration:none}.mfa-nudge-banner{position:fixed;bottom:80px;left:50%;transform:translate(-50%);z-index:500;display:flex;align-items:center;gap:14px;max-width:480px;width:calc(100% - 40px);padding:14px 20px;background:#1a3060;border:1px solid rgba(26,86,219,.4);border-radius:14px;box-shadow:0 8px 32px #0006}.mfa-nudge-banner__icon{font-size:24px}.mfa-nudge-banner__text{flex:1}.mfa-nudge-banner__title{font-size:13.5px;font-weight:700;color:#fff;margin-bottom:2px}.mfa-nudge-banner__sub{font-size:12px;color:#fff9}.mfa-nudge-banner__setup{white-space:nowrap}.mfa-nudge-banner__close{background:none;border:none;color:#fff6;cursor:pointer;font-size:18px;padding:0 4px}.loyalty-redeem-panel{max-width:480px;margin:0 auto;padding:20px 0}.loyalty-redeem-search{padding:28px;text-align:center}.loyalty-redeem-search__icon{font-size:40px;margin-bottom:12px}.loyalty-redeem-search__title{font-size:18px;font-weight:700;margin-bottom:6px}.loyalty-redeem-search__sub{margin-bottom:20px}.loyalty-redeem-search__row{display:flex;gap:10px;margin-bottom:16px}.loyalty-redeem-results{text-align:left}.loyalty-redeem-result{display:flex;justify-content:space-between;align-items:center;width:100%;padding:12px 14px;margin-bottom:8px;border:1px solid var(--border);border-radius:8px;background:var(--card-bg);cursor:pointer;text-align:left}.loyalty-redeem-result__name{font-weight:700}.loyalty-redeem-result__phone{font-size:12px;color:var(--text-muted)}.loyalty-redeem-result__bal{font-size:20px;font-weight:800}.loyalty-redeem-result__unit{font-size:11px;font-weight:400}.loyalty-redeem-card{margin-top:16px;padding:24px;text-align:center}.loyalty-redeem-card__avatar{width:64px;height:64px;border-radius:50%;background:var(--jw-blue);display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:800;color:#fff;margin:0 auto 12px}.loyalty-redeem-card__name{font-size:20px;font-weight:800}.loyalty-redeem-card__phone{font-size:13px;color:var(--text-muted);margin-bottom:20px}.loyalty-redeem-card__balance{font-size:48px;font-weight:900;line-height:1}.text-amber{color:#e67e00}.loyalty-redeem-card__meta{font-size:11px;color:var(--text-muted);margin-bottom:24px}.loyalty-redeem-card__actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.loyalty-redeem-card__redeem{background:var(--jw-green)}.loyalty-qr-scanner__video{width:100%;max-height:280px;border-radius:10px;background:#000}.loyalty-qr-scanner__canvas{display:none}.loyalty-qr-scanner__status{text-align:center;margin:12px 0}.loyalty-qw-plate-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:8px}.loyalty-qw-plate-actions{display:flex;gap:8px;flex-shrink:0}.page-admin{max-width:1280px}.admin-hero{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:16px;padding:28px 32px;margin:-24px -28px 24px;background:linear-gradient(135deg,#0a1628,#1a3060);border-radius:0 0 12px 12px}.admin-hero-title{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.admin-hero-title h1{margin:0;font-size:24px;font-weight:800;color:#fff}.admin-badge{background:#00c9a733;color:#00c9a7;font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;letter-spacing:1px}.admin-hero-sub{color:#9aafc7;font-size:13px;margin:8px 0 0}.admin-hero-tools{display:flex;gap:10px;flex-wrap:wrap}.admin-hero-input{width:240px;max-width:100%;background:#ffffff14;border-color:#ffffff26;color:#fff}.admin-hero-select{width:150px}.stat-card--dark{background:linear-gradient(135deg,#0a1628,#1a3060);border-color:#00c9a74d}.stat-card--dark .stat-label{color:#9aafc7}.stat-card--dark .stat-value{color:#00c9a7}.admin-section{margin-bottom:24px}.admin-billing-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:16px;padding:0 20px 20px}@media (max-width: 900px){.admin-billing-grid{grid-template-columns:1fr}}.admin-panel{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:16px;min-height:130px}.admin-panel-head{display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:800;margin-bottom:10px}.admin-upgrade-list{display:flex;flex-direction:column;gap:10px}.admin-upgrade-row{display:flex;justify-content:space-between;gap:10px;padding:10px 12px;border:1px solid var(--border);background:var(--surface);border-radius:10px}.admin-upgrade-meta{min-width:0}.admin-upgrade-actions{display:flex;flex-direction:column;gap:8px;flex-shrink:0}.admin-csv-label{cursor:pointer;margin:10px 0}.admin-csv-preview{margin-top:10px;font-size:12px}.admin-broadcast-form{padding:0 20px 16px;display:flex;flex-direction:column;gap:12px}.broadcast-type-row{display:flex;gap:8px;flex-wrap:wrap}.admin-broadcast-list{list-style:none;margin:0;padding:0 20px 20px}.admin-broadcast-item{display:flex;justify-content:space-between;gap:12px;padding:14px 0;border-bottom:1px solid var(--border)}.admin-broadcast-type{margin-left:8px;font-size:11px;font-weight:700;text-transform:uppercase}.admin-feature-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.admin-feature-chip{display:flex;align-items:center;gap:10px;font-size:13px;cursor:pointer;background:var(--surface2);border:1.5px solid var(--border);border-radius:8px;padding:10px 14px}.admin-tenant-section .card-title{padding:20px 20px 0}.admin-tenant-grid{display:grid;gap:14px;padding:16px 20px 20px}.admin-tenant-card{background:var(--surface);border:1.5px solid var(--border);border-radius:14px;padding:20px 24px;display:grid;grid-template-columns:1fr auto;gap:16px;align-items:start}.admin-tenant-card-main{display:flex;gap:16px;align-items:flex-start;min-width:0}.admin-tenant-card-icon{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;font-size:22px;flex-shrink:0}.admin-tenant-card-body{min-width:0}.admin-tenant-card-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:4px}.admin-tenant-card-head h3{margin:0;font-size:16px;font-weight:800}.admin-tenant-plan,.admin-tenant-status{font-size:11px;font-weight:700;padding:2px 10px;border-radius:20px}.admin-tenant-status--ok{background:#00c9a71a;color:#00c9a7}.admin-tenant-status--warn{background:#e67e001f;color:#e67e00}.admin-tenant-status--bad{background:#e74c3c1f;color:#e74c3c}.admin-tenant-meta{font-size:12px;color:var(--text-muted);margin:0 0 8px}.admin-tenant-feats{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}.admin-tenant-feat{background:#00c9a71a;color:#00c9a7;padding:2px 8px;border-radius:12px;font-size:10px;font-weight:600;text-transform:lowercase}.admin-tenant-feat--muted{background:transparent;color:var(--text-muted);font-weight:500}.admin-tenant-stats{display:flex;gap:16px;flex-wrap:wrap;margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}.admin-tenant-stat-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.admin-tenant-stat-value{font-size:13px;font-weight:700;color:var(--text)}.admin-tenant-stat-value--green{color:#00c9a7;font-weight:800}.admin-tenant-notes{font-size:11px;color:var(--text-muted);font-style:italic;margin:8px 0 0}.admin-tenant-card-actions{display:flex;flex-direction:column;gap:8px;flex-shrink:0}.admin-tenant-toggle--suspend{background:#e74c3c1a;color:#e74c3c;border:1.5px solid rgba(231,76,60,.3)}.admin-tenant-toggle--activate{background:#00c9a71a;color:#00c9a7;border:1.5px solid rgba(0,201,167,.3)}.admin-tenant-delete{background:#e74c3c1a;color:#e74c3c;border:1.5px solid rgba(231,76,60,.3)}.admin-tenant-empty{text-align:center;padding:48px 20px;color:var(--text-muted)}.admin-tenant-empty-icon{font-size:40px;margin-bottom:12px}.admin-attention-bar{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:20px;padding:12px 16px;border-radius:12px;background:linear-gradient(90deg,#00c9a714,#3d8bff0f);border:1px solid rgba(0,201,167,.2)}.admin-attention-label{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.admin-attention-chips{display:flex;flex-wrap:wrap;gap:8px}.admin-attention-chip{border:1px solid transparent;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;background:var(--surface)}.admin-attention-chip--accent{color:#00a88a;border-color:#00c9a759;background:#00c9a71a}.admin-attention-chip--warn{color:#c45a00;border-color:#e67e0059;background:#e67e001a}.admin-attention-chip--muted{color:var(--text-muted);border-color:var(--border)}.admin-hero-refresh{opacity:.85}.admin-hero-refresh-btn{color:#e8f0ff!important;border-color:#fff3!important}.admin-tenant-table-wrap{overflow-x:auto;margin:0 -4px}.admin-tenant-table{width:100%;border-collapse:collapse;font-size:13px}.admin-tenant-table th,.admin-tenant-table td{padding:12px 10px;text-align:left;border-bottom:1px solid var(--border);vertical-align:middle}.admin-tenant-table th{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.admin-th-sort{border:none;background:none;padding:0;font:inherit;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);cursor:pointer}.admin-th-sort:hover{color:var(--text)}.admin-tenant-row:hover td{background:#00c9a70a}.admin-tenant-row-link{display:flex;align-items:center;gap:10px;border:none;background:none;padding:0;text-align:left;cursor:pointer;font:inherit;color:inherit;width:100%}.admin-tenant-row-link strong{display:block}.admin-tenant-row-emoji{font-size:22px;flex-shrink:0}.admin-tenant-plan-pill{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;border:1px solid}.admin-tenant-num{font-weight:700;font-variant-numeric:tabular-nums}.admin-tenant-num--green{color:#00a88a}.admin-tenant-row-actions{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end}.modal-card--wide.modal-card--bare{max-width:min(960px,calc(100vw - 24px))}.tw-shell{position:relative}.tw-close{position:absolute;top:12px;right:12px;z-index:2;border:1px solid rgba(255,255,255,.25);background:#00000040;color:#fff;width:36px;height:36px;border-radius:10px;cursor:pointer;font-size:16px}.tw-hero{padding:24px 24px 16px;background:linear-gradient(135deg,#0a1628,color-mix(in srgb,var(--tw-plan, #3d8bff) 35%,#1a3060));color:#fff}.tw-hero-main{display:flex;gap:16px;align-items:flex-start;padding-right:40px}.tw-hero-emoji{font-size:40px;line-height:1}.tw-hero-title{margin:0 0 4px;font-size:22px;font-weight:800}.tw-hero-email{margin:0 0 10px;color:#9aafc7;font-size:13px}.tw-hero-badges{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.tw-badge{font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px}.tw-badge--muted{background:#ffffff1a;color:#c8d8f0}.tw-quick-bar{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px;padding-top:14px;border-top:1px solid rgba(255,255,255,.12)}.tw-quick-btn{border:1px solid rgba(255,255,255,.2);background:#ffffff14;color:#e8f0ff;border-radius:8px;padding:8px 12px;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit}.tw-quick-btn:hover:not(:disabled){background:#ffffff26}.tw-quick-btn--warn{border-color:#ff3b5c80;color:#ffb3c4}.tw-quick-btn--ok{border-color:#00c47280;color:#7dffc4}.tw-tabs{display:flex;gap:4px;padding:0 16px;background:var(--surface2);border-bottom:1px solid var(--border);overflow-x:auto}.tw-tab{border:none;background:none;padding:12px 14px;font-size:13px;font-weight:700;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;font-family:inherit;white-space:nowrap}.tw-tab--active{color:var(--text);border-bottom-color:#00c9a7}.tw-body{padding:20px 24px 24px;max-height:min(62vh,520px);overflow-y:auto}.tw-grid{display:grid;gap:16px}.tw-grid--2{grid-template-columns:repeat(2,minmax(0,1fr))}.tw-grid--3{grid-template-columns:repeat(3,minmax(0,1fr))}.tw-panel{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:14px 16px}.tw-panel--danger{border-color:#ff3b5c59;background:#ff3b5c0d}.tw-panel-title{margin:0 0 12px;font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.tw-stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:12px}.tw-stat-val{font-size:20px;font-weight:800;font-variant-numeric:tabular-nums}.tw-stat-val--green{color:#00a88a}.tw-stat-lbl{font-size:11px;color:var(--text-muted);margin-top:2px}.tw-revenue-row{display:flex;gap:24px;padding-top:12px;border-top:1px solid var(--border)}.tw-milestone{display:flex;gap:10px;align-items:flex-start;padding:8px 0;border-bottom:1px solid var(--border)}.tw-milestone:last-child{border-bottom:none}.tw-milestone strong{display:block;font-size:13px}.tw-audit-list{list-style:none;margin:0;padding:0}.tw-audit-list li{padding:8px 0;border-bottom:1px solid var(--border);font-size:12px}.tw-audit-list li strong{display:block}.tw-settings .form-control,.tw-panel .form-control{margin-bottom:10px}@media (max-width: 900px){.tw-grid--2,.tw-grid--3{grid-template-columns:1fr}.admin-tenant-row-actions{flex-direction:column;align-items:stretch}.admin-tenant-table th:nth-child(5),.admin-tenant-table td:nth-child(5){display:none}}.admin-delete-options{display:flex;flex-direction:column;gap:10px;margin:16px 0}.admin-delete-opt{display:flex;gap:12px;align-items:flex-start;padding:12px 14px;border:1.5px solid var(--border);border-radius:10px;cursor:pointer}.admin-delete-opt--active{border-color:#1a56db73;background:#1a56db0f}.admin-delete-opt strong{display:block;margin-bottom:2px}@media (max-width: 900px){.admin-tenant-card{grid-template-columns:1fr}.admin-tenant-card-actions{flex-direction:row;flex-wrap:wrap}}.admin-loading-banner{margin:0 0 16px;padding:12px 16px;border-radius:10px;background:var(--surface2);border:1px solid var(--border);color:var(--text-muted);font-size:13px;font-weight:600}.admin-loading-banner--subtle{padding:8px 14px;font-size:12px;font-weight:500;background:#3d8bff0f;border-color:#3d8bff33}.tw-comms{display:flex;flex-direction:column;gap:16px}.tw-tenant-broadcasts{margin-top:4px}.tw-broadcast-list{list-style:none;margin:0;padding:0}.tw-broadcast-item{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}.tw-broadcast-item:last-child{border-bottom:none}.tw-broadcast-main{flex:1;min-width:200px}.tw-broadcast-main strong{margin-right:8px}.tw-broadcast-actions{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex-shrink:0}.admin-load-error{margin:0 0 16px;padding:14px 16px;border-radius:10px;background:#ff3b5c14;border:1px solid rgba(255,59,92,.25);color:var(--text);font-size:13px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.admin-overview .card-header{padding:20px 20px 0}.admin-chart-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:8px 20px 20px}.admin-chart-card{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:14px;min-height:260px;display:flex;flex-direction:column}.admin-chart-title{margin:0 0 10px;font-size:13px;font-weight:800;color:var(--text)}.admin-chart-wrap{position:relative;flex:1;min-height:200px}.admin-chart-wrap--donut{max-width:220px;margin:0 auto;width:100%}@media (max-width: 1100px){.admin-chart-grid{grid-template-columns:1fr}.admin-chart-wrap--donut{max-width:280px}}.settings-login-reminders{align-items:flex-start;gap:10px;padding:10px 14px;background:var(--surface2);border-radius:8px}.mfa-secret-code{display:block;background:var(--surface2);padding:10px;border-radius:8px;font-size:13px;text-align:center;word-break:break-all}.mfa-code-input{text-align:center;font-size:20px;font-weight:700;letter-spacing:6px}.btn-danger-outline{color:var(--red);border-color:#ff3b5c59;width:100%;margin-top:8px}.broadcast-banner{position:sticky;top:0;z-index:200;width:100%;box-sizing:border-box;border-bottom:2px solid rgba(255,255,255,.2)}.broadcast-banner-inner{display:flex;align-items:center;gap:12px;padding:10px 20px;padding-top:calc(10px + env(safe-area-inset-top));flex-wrap:nowrap}.broadcast-banner-icon{font-size:20px;flex-shrink:0;line-height:1}.broadcast-banner-text{flex:1;min-width:0;color:#fff}.broadcast-banner-text strong{display:block;font-size:14px;font-weight:800;margin-bottom:2px}.broadcast-banner-message{font-size:13px;line-height:1.4;opacity:.95}.broadcast-banner-message a{color:#fff;font-weight:700;text-decoration:underline}.broadcast-banner-dismiss{flex-shrink:0;background:#ffffff26;border:none;color:#fff;border-radius:6px;padding:6px 12px;font-size:12px;font-weight:700;cursor:pointer}.broadcast-banner-dismiss:hover{background:#ffffff40}.page-loader{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;min-height:200px;padding:40px 20px;color:var(--muted)}.page-loader-bar{width:120px;height:3px;border-radius:3px;background:var(--border);position:relative;overflow:hidden}.page-loader-bar:after{content:"";position:absolute;left:-40%;width:40%;height:100%;background:var(--green);border-radius:3px;animation:page-loader-slide 1s ease-in-out infinite}@keyframes page-loader-slide{0%{left:-40%}to{left:100%}}.page-loader-text{font-size:13px}.invoice-fx-panel{margin:12px 0 4px;padding:12px 14px;background:var(--surface2);border:1px solid var(--border);border-radius:8px}.invoice-fx-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}.invoice-fx-target{display:flex;align-items:center;min-height:38px}.invoice-fx-result{margin:8px 0 0;font-weight:600;color:var(--text)}.modal-actions--split{justify-content:space-between;align-items:center;gap:12px}.modal-actions--split .modal-actions-left,.modal-actions--split .modal-actions-right{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.batch-bar{display:flex;align-items:center;gap:10px;padding:10px 14px;margin-bottom:12px;background:var(--surface2);border:1px solid var(--border);border-radius:8px}.batch-bar-count{font-size:13px;font-weight:600}.batch-confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:25000;background:#0a1628e0;display:flex;align-items:center;justify-content:center;padding:20px}.batch-confirm-modal{background:var(--surface);border-radius:16px;padding:28px;max-width:380px;width:100%;text-align:center}.batch-confirm-icon{font-size:44px;margin-bottom:14px}.batch-confirm-input{text-transform:uppercase;letter-spacing:2px;font-weight:700}.select-cell{width:36px;text-align:center}.invoice-pos-tabs{display:flex;gap:6px;flex-wrap:wrap}.invoice-pos-tabs .btn--active{background:var(--green-pale);border-color:var(--green);color:var(--green-deeper)}.statement-actions{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}.statement-preview{border:1px solid var(--border);border-radius:8px}.onboarding-step{text-align:center;padding:12px 0}.onboarding-icon{font-size:48px;margin-bottom:12px}.onboarding-dots{display:flex;gap:8px;justify-content:center;margin:16px 0}.onboarding-dot{width:8px;height:8px;border-radius:50%;background:var(--border)}.onboarding-dot--active{background:var(--green)}.idle-warning{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30000;background:#0a1628bf;display:flex;align-items:center;justify-content:center;padding:20px}.idle-warning-inner{background:var(--surface);border-radius:12px;padding:24px;max-width:360px;text-align:center}.update-banner{position:sticky;top:0;z-index:201;width:100%;margin:0;padding:12px 16px;font-size:clamp(12px,3.2vw,14px);font-weight:700;line-height:1.35;text-align:center;color:#fff;background:linear-gradient(135deg,#0a1628,#1a56db);border-bottom:1px solid rgba(255,255,255,.12);box-sizing:border-box}.update-banner-inner{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;max-width:100%}.update-banner-msg{display:inline-flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}.update-banner-icon{font-size:1.35em;line-height:1;filter:drop-shadow(0 1px 1px rgba(0,0,0,.25))}.update-banner-actions{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap}.update-banner-update{background:#fff!important;color:#0062ff!important;border:none!important;border-radius:6px;padding:8px 14px;font-size:12px;font-weight:800;white-space:nowrap}.update-banner-later{background:#ffffff26!important;color:#fff!important;border:none!important;border-radius:6px;padding:8px 12px;font-size:12px;white-space:nowrap}.feedback-ratings{display:flex;flex-direction:column;gap:10px}.feedback-followup-title{font-family:var(--font-display);font-size:16px;font-weight:800;margin:0 0 4px}.feedback-thanks{text-align:center;padding:8px 0 4px}.feedback-thanks-icon{width:48px;height:48px;margin:0 auto 12px;border-radius:50%;background:#00c47226;color:var(--green);font-size:22px;font-weight:800;display:grid;place-items:center}.feedback-thanks p{color:var(--text-muted);margin:0 0 16px;line-height:1.5}.audit-log-filters{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:12px}.audit-log-filters .form-control{width:auto;min-width:140px;font-size:12px;padding:6px 10px}.audit-log-count{margin:0}.audit-clear-btn{color:var(--red, #ff3b5c)!important}.table-pagination{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px;padding:12px 16px;border-top:1px solid var(--border);background:var(--surface2)}.table-pagination-meta{font-size:12px;color:var(--text-muted)}.table-pagination-actions{display:flex;align-items:center;gap:10px}.table-pagination-pages{font-size:12px;color:var(--text-muted);min-width:5rem;text-align:center}.feedback-rating-btn{justify-content:center}.tenant-drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;background:#0a162880;border:none;cursor:pointer}.tenant-drawer{position:fixed;top:0;right:0;bottom:0;width:min(560px,100vw);z-index:501;background:var(--bg);box-shadow:-8px 0 40px #0000004d;overflow-y:auto;display:flex;flex-direction:column}.tenant-drawer-body{padding:20px;flex:1}.tenant-drawer-hero{background:linear-gradient(135deg,#0a1628,#1a3a6b);padding:20px 20px 0;color:#fff}.tenant-drawer-hero-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.tenant-drawer-identity{display:flex;align-items:center;gap:12px;min-width:0}.tenant-drawer-emoji{font-size:28px;line-height:1}.tenant-drawer-name{margin:0;font-size:17px;font-weight:800;color:#fff}.tenant-drawer-email{margin:4px 0 0;font-size:12px;color:#ffffff8c}.tenant-drawer-close{background:#ffffff1a;border:none;color:#fff;border-radius:8px;padding:6px 12px;font-size:13px;cursor:pointer;flex-shrink:0}.tenant-drawer-badges{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px;align-items:center}.tenant-drawer-badge{font-size:11px;font-weight:700;padding:3px 10px;border-radius:100px}.tenant-drawer-joined{font-size:11px;color:#ffffff73}.tenant-drawer-tab{background:none;border:none;border-bottom:2px solid transparent;color:#ffffff8c;padding:10px 12px;font-size:13px;font-weight:600;cursor:pointer}.tenant-drawer-tab--active{color:#fff;border-bottom-color:var(--jw-green)}.tenant-drawer-tabs{display:flex;gap:0;margin-top:16px;border-bottom:1px solid rgba(255,255,255,.1);padding:0;border-top:none}.td-stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}.td-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px;text-align:center}.td-stat-val{font-size:22px;font-weight:800;color:var(--text);margin-bottom:4px}.td-stat-lbl{font-size:11px;color:var(--text-muted);font-weight:600}.td-panel-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:12px;display:flex;flex-direction:column;gap:10px}.td-panel-card--danger{background:#ff3b5c0d;border-color:#ff3b5c33}.td-panel-card-head{font-size:13px;font-weight:700;color:var(--text)}.td-panel-card-head--danger{color:var(--red)}.td-panel-card-title{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.td-revenue-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.td-revenue-val{font-size:20px;font-weight:800;color:var(--text)}.td-revenue-val--green{color:var(--jw-green)}.td-feature-chips{display:flex;gap:6px;flex-wrap:wrap}.td-feature-chip{padding:4px 10px;border-radius:100px;font-size:11px;font-weight:700;background:#6b7e961a;color:var(--text-muted)}.td-feature-chip--on{background:#00c4721f;color:#00c472}.td-activity-item{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}.td-activity-item:last-child{border-bottom:none}.td-activity-dot{width:8px;height:8px;border-radius:50%;background:var(--jw-green);flex-shrink:0;margin-top:5px}.td-activity-label{font-size:13px;font-weight:600;color:var(--text)}.td-activity-when{font-size:11.5px;color:var(--text-muted)}.td-audit-list{list-style:none;margin:0;padding:0}.td-audit-row{display:flex;justify-content:space-between;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);align-items:flex-start}.td-audit-main{font-size:12px;color:var(--text)}.td-audit-main strong{color:var(--jw-blue)}.td-audit-when{color:var(--text-muted);font-size:11px;white-space:nowrap}.setup-checklist{margin-bottom:20px}.setup-checklist-item{display:flex;align-items:center;gap:10px;padding:8px 0;font-size:14px}.setup-checklist--full{background:var(--surface);border:1px solid var(--border);border-radius:16px;overflow:hidden;padding:0}.setup-checklist-head{background:linear-gradient(135deg,#0a1628,#1a3060);padding:18px 24px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.setup-checklist-title{font-size:15px;font-weight:800;color:#fff;margin-bottom:3px}.setup-checklist-sub{font-size:12px;color:#ffffff8c}.setup-checklist-head-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.setup-checklist-progress-text{font-size:12px;color:#ffffffb3}.setup-checklist-btn{background:#ffffff1a;border:none;color:#fff;border-radius:6px;padding:4px 10px;font-size:12px;font-weight:700;cursor:pointer}.setup-checklist-btn--muted{color:#fff9;font-weight:400}.setup-checklist-bar-wrap{height:3px;background:var(--surface2)}.setup-checklist-bar{height:100%;background:var(--jw-green);transition:width .5s ease}.setup-checklist-steps{padding:8px 0}.cl-step{display:flex;align-items:center;gap:14px;padding:14px 24px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .15s}.cl-step:last-child{border-bottom:none}.cl-step:hover{background:var(--surface2)}.cl-step--done{opacity:.6;cursor:default}.cl-step--done:hover{background:transparent}.cl-step-icon{font-size:22px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--surface2);border:1px solid var(--border);border-radius:10px;flex-shrink:0}.cl-step-body{flex:1;min-width:0}.cl-step-title{font-size:14px;font-weight:700;color:var(--text);margin-bottom:3px}.cl-step-title--done{text-decoration:line-through;color:var(--text-muted)}.cl-step-sub{font-size:12px;color:var(--text-muted);line-height:1.4}.cl-step-status{font-size:16px;color:var(--text-muted);flex-shrink:0;width:28px;text-align:center}.cl-step-status--done{color:#00c472;font-size:18px}.trust-card{display:flex;gap:16px;align-items:flex-start;margin-bottom:20px}.trust-card-icon{font-size:28px;flex-shrink:0}.trial-banner{margin:0;padding:12px 24px;font-size:13px;font-weight:700;text-align:center;letter-spacing:.2px;border-bottom:2px solid rgba(0,0,0,.15)}.trial-banner--active{background:#1a56db;color:#fff}.trial-banner--expired{background:#c0392b;color:#fff}.trial-banner-link{color:#fff;text-decoration:underline}.trial-banner-sep{margin:0 8px}.trial-banner-upgrade{background:none;border:none;color:#fff;text-decoration:underline;font-weight:800;cursor:pointer;font-size:inherit;font-family:inherit;padding:0;margin-left:4px}.trial-banner-dismiss{background:#ffffff26;border:1px solid rgba(255,255,255,.3);color:#fff;cursor:pointer;font-size:11px;font-weight:700;padding:4px 10px;border-radius:6px;margin-left:8px}.trial-banner-expired-btn{margin-left:10px;background:#fff;color:#c0392b;border:none;border-radius:8px;padding:6px 12px;font-size:12px;font-weight:800;cursor:pointer}.upgrade-sent-box{background:var(--jw-green-pale, rgba(0, 196, 114, .08));border:1.5px solid rgba(0,196,114,.35);border-radius:10px;padding:14px 16px;margin:14px 0;font-size:13px;line-height:1.55}.ns-sub{margin-top:-8px}.ns-header-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}.ns-header-title{font-size:14px;font-weight:800}.ns-progress-text{font-size:12px;color:var(--text-muted);font-weight:700}.ns-progress-bar-wrap{height:8px;background:var(--bg);border-radius:999px;overflow:hidden;border:1px solid var(--border);margin-bottom:18px}.ns-progress-bar{height:100%;background:linear-gradient(90deg,var(--jw-green),#00e5a0);transition:width .4s ease}.ns-steps{margin-bottom:8px}.ns-step{display:flex;align-items:flex-start;gap:12px;padding:12px;border:1px solid var(--border);border-radius:14px;background:var(--surface);box-shadow:var(--shadow-1);margin-bottom:10px}.ns-step:last-child{margin-bottom:0}.ns-step--done{opacity:.72}.ns-step--done .ns-h{text-decoration:line-through;color:var(--text-muted)}.ns-ico{font-size:20px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--surface2);border-radius:10px;flex-shrink:0}.ns-body{flex:1;min-width:0}.ns-h{font-size:14px;font-weight:800;margin-bottom:4px}.ns-p{font-size:13px;color:var(--text-muted);line-height:1.45;margin-bottom:10px}.ns-actions{display:flex;gap:8px;flex-wrap:wrap}.ns-tip-box{margin-top:16px;padding:14px 16px;border:1px solid var(--border);background:linear-gradient(180deg,var(--surface) 0%,var(--surface2) 100%);border-radius:14px}.ns-tip-label{font-size:12px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px}.ns-tip-text{font-size:13px;line-height:1.5}.reminder-list{list-style:none;margin:0;padding:0}.reminder-list-item{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}.reminder-list-item:last-child{border-bottom:none}.reminder-list-icon{width:38px;height:38px;border-radius:9px;background:#ff3b5c1a;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}.reminder-list-body{flex:1;min-width:0}.reminder-list-title{font-weight:700;font-size:13.5px}.reminder-list-msg{font-size:12px;margin-top:2px;font-weight:600;color:#e67e00}.reminder-list-msg--warn{color:var(--red)}.modal-card--bare{max-width:520px;overflow:hidden}.modal-card--bare .modal-card-body{padding:0}.onboarding-shell{display:flex;flex-direction:column;background:var(--surface);color:var(--text)}.onboarding-dots--top{display:flex;justify-content:center;gap:8px;padding:16px 0 0;background:var(--surface)}.onboarding-hero{padding:28px 24px;text-align:center;color:#fff}.onboarding-hero-icon{font-size:40px;margin-bottom:10px}.onboarding-hero-title{font-size:20px;font-weight:900}.onboarding-hero-sub{font-size:12px;color:#ffffffbf;margin-top:6px;line-height:1.5}.onboarding-body{padding:20px 24px;background:var(--surface);color:var(--text)}.onboarding-roadmap-label{font-size:13px;font-weight:700;margin:0 0 14px;color:var(--text)}.onboarding-roadmap{display:flex;flex-direction:column;gap:12px}.onboarding-roadmap-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--surface2);border:1px solid var(--border);border-radius:10px}.onboarding-roadmap-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;color:#fff}.onboarding-roadmap-title{font-size:13px;font-weight:700;color:var(--text)}.onboarding-roadmap-sub{font-size:11px;color:var(--text-muted)}.onboarding-roadmap-step{margin-left:auto;font-size:11px;color:var(--text-light);white-space:nowrap}.onboarding-intro{font-size:13px;line-height:1.8;margin:0 0 16px;color:var(--text-muted)}.onboarding-bullets{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.onboarding-bullet{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--text)}.onboarding-bullet-n{width:20px;height:20px;border-radius:50%;background:var(--jw-green);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}.onboarding-tip{border-left:3px solid var(--jw-green);padding:10px 12px;border-radius:0 8px 8px 0;font-size:12px;line-height:1.5;color:var(--text)}.onboarding-tip--blue{background:var(--jw-blue-pale);border-left-color:var(--jw-blue-mid)}.onboarding-tip--green{background:var(--jw-green-pale);border-left-color:var(--jw-green)}.onboarding-footer{padding:16px 24px;display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--border);background:var(--surface)}.onboarding-footer-actions{display:flex;gap:10px}.app-main--expired .btn-primary:not(.trial-banner-expired-btn){opacity:.55;pointer-events:none}.invoice-recurring-toggle{margin:8px 0}@media (max-width: 960px){.stat-grid--hero,.dash-insight-row,.dash-insight-row--month{grid-template-columns:repeat(2,1fr)}.dash-chart-grid,.dash-extra-grid{grid-template-columns:1fr}}.admin-app-shell{min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}.admin-session-strip{flex-shrink:0;display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:8px 16px;background:#0a1628f0;border-bottom:1px solid rgba(255,255,255,.08);position:sticky;top:0;z-index:160}.admin-session-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.admin-session-email{font-size:12px;color:#9aafc7;margin-right:auto;max-width:min(50vw,320px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-session-btn{border:1px solid rgba(255,255,255,.15);background:#ffffff0f;color:#e8f0ff;border-radius:8px;padding:6px 12px;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit}.admin-session-btn:hover{background:#ffffff1f}.admin-session-btn--danger{color:#ff8fa8;border-color:#ff3b5c59;background:#ff3b5c1a}.admin-pwa-install.pwa-install-btn{width:auto;padding:6px 12px;font-size:12px;border-radius:8px;background:#3d8bff26;border:1px solid rgba(61,139,255,.35);color:#9ec5ff}.admin-pwa-install.pwa-install-btn:hover{background:#3d8bff40}.admin-app-main{flex:1;min-width:0}.admin-app-main .page-admin{padding-top:0;margin:0 auto;max-width:none}.admin-app-main .admin-hero{margin:0 0 24px;border-radius:0}.admin-app-denied{min-height:100vh;display:grid;place-items:center;padding:24px;background:#0a1628}.admin-app-denied-card{max-width:420px;width:100%;background:#132238;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:28px;text-align:center;color:#e8f0ff}.admin-app-denied-card h1{margin:0 0 8px;font-size:22px}.admin-app-denied-card .btn{margin-top:20px}.admin-login-page{min-height:100vh;display:grid;place-items:center;padding:24px;position:relative;background:#060d18}.admin-login-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 20%,rgba(0,201,167,.12),transparent 45%),radial-gradient(circle at 80% 80%,rgba(26,86,219,.15),transparent 40%),linear-gradient(160deg,#060d18,#0a1628,#0d1e35);pointer-events:none}.admin-login-card{position:relative;width:100%;max-width:420px;background:#132238eb;border:1px solid rgba(255,255,255,.1);border-radius:18px;padding:32px 28px 24px;box-shadow:0 24px 64px #00000073;text-align:center;color:#e8f0ff}.admin-login-card--denied h1{font-size:22px;margin:12px 0 8px}.admin-login-card--denied p{color:#9aafc7;font-size:14px;line-height:1.55;margin:0}.admin-login-icon{font-size:40px;margin-bottom:8px}.admin-login-badge{display:inline-block;font-size:10px;font-weight:700;letter-spacing:1.2px;color:#00c9a7;background:#00c9a71f;border:1px solid rgba(0,201,167,.25);padding:4px 10px;border-radius:20px;margin-bottom:12px}.admin-login-card h1{margin:0 0 6px;font-size:26px;font-weight:800;font-family:var(--font-display);color:#fff}.admin-login-sub{margin:0 0 22px;font-size:13px;color:#9aafc7}.admin-login-form{text-align:left;display:flex;flex-direction:column;gap:14px}.admin-login-label{display:flex;flex-direction:column;gap:6px;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:#9aafc7}.admin-login-input{width:100%;box-sizing:border-box;border:1px solid rgba(255,255,255,.12);background:#ffffff0f;color:#fff;border-radius:10px;padding:11px 12px;font:inherit;font-size:14px}.admin-login-input:focus{outline:none;border-color:#00c9a780;box-shadow:0 0 0 3px #00c9a71f}.admin-login-pw-row{display:flex;gap:8px;align-items:center}.admin-login-pw-row .admin-login-input{flex:1}.admin-login-pw-toggle{flex-shrink:0;width:42px;height:42px;border-radius:10px;border:1px solid rgba(255,255,255,.12);background:#ffffff0f;cursor:pointer}.admin-login-btn{width:100%;margin-top:4px;border:none;border-radius:10px;padding:12px 16px;font-size:14px;font-weight:800;cursor:pointer;font-family:inherit;color:#0a1628;background:linear-gradient(135deg,#00c9a7,#00e5a0)}.admin-login-btn:disabled{opacity:.55;cursor:not-allowed}.admin-login-link{background:none;border:none;color:#7eb8ff;font-size:13px;font-weight:600;cursor:pointer;padding:4px 0;text-align:center;font-family:inherit}.admin-login-error{margin:0;font-size:13px;color:#ff8fa8;background:#ff3b5c1a;border:1px solid rgba(255,59,92,.25);border-radius:8px;padding:8px 10px}.admin-login-success{margin:0;font-size:13px;color:#00c9a7;background:#00c9a71a;border:1px solid rgba(0,201,167,.25);border-radius:8px;padding:8px 10px}.admin-login-foot{margin:20px 0 0;font-size:11px;color:#9aafc7a6}@media (max-width: 640px){.admin-session-strip{flex-direction:column;align-items:stretch}.admin-session-strip-right{justify-content:flex-end}}
