:root{--bg-window: #f3f5f9;--bg-window-grad: radial-gradient(1100px 540px at 85% -10%, #ffffff 0%, rgba(255, 255, 255, 0) 55%), radial-gradient(900px 500px at -10% 110%, #e8eef6 0%, rgba(232, 238, 246, 0) 55%), #f3f5f9;--bg-card: #ffffff;--sb-bg: linear-gradient(180deg, #131b26 0%, #0e141d 100%);--sb-border: rgba(148, 180, 216, .12);--sb-text: #d7e1ee;--sb-text-dim: #8294a8;--sb-active-bg: rgba(20, 184, 166, .16);--sb-active-text: #5eead4;--sb-hover-bg: rgba(255, 255, 255, .06);--text-primary: #16202e;--text-muted: #64748b;--text-inverted: #ffffff;--accent: #0d9488;--accent-bright: #14b8a6;--accent-soft: rgba(13, 148, 136, .12);--accent-strong: #0f766e;--blue: #0f6cbd;--blue-soft: rgba(15, 108, 189, .12);--violet: #7c3aed;--violet-soft: rgba(124, 58, 237, .1);--green: #1b873f;--green-soft: rgba(27, 135, 63, .12);--warn: #b45309;--warn-soft: rgba(255, 122, 0, .14);--danger: #d32f2f;--danger-soft: rgba(211, 47, 47, .1);--border-subtle: rgba(24, 39, 75, .1);--border-card: rgba(24, 39, 75, .12);--radius-card: 16px;--radius-button: 10px;--radius-pill: 999px;--shadow-card: 0 10px 28px rgba(16, 24, 40, .07), 0 2px 8px rgba(16, 24, 40, .04);--shadow-card-hover: 0 18px 40px rgba(15, 23, 42, .13);--ease: cubic-bezier(.16, 1, .3, 1);--dur: .18s;--font: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", system-ui, sans-serif;color-scheme:light}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font);color:var(--text-primary);background:var(--bg-window-grad);background-attachment:fixed;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}.login-shell{min-height:100vh;display:grid;place-items:center;padding:24px}.login-card{width:100%;max-width:420px;background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-card);box-shadow:var(--shadow-card);padding:36px 32px;display:grid;gap:14px}.login-card h1{margin:0;font-size:1.6rem;letter-spacing:-.02em;line-height:1.2}.login-card>p{margin:0;color:var(--text-muted);font-size:.95rem;line-height:1.55}.eyebrow{font-size:.72rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}.login-form{display:grid;gap:14px;margin-top:6px}.login-form label{display:grid;gap:6px;font-size:.82rem;font-weight:600;color:var(--text-muted)}.login-form input{width:100%;padding:11px 13px;border-radius:var(--radius-button);border:1px solid var(--border-subtle);background:#fff;color:var(--text-primary);font-size:.95rem;font-family:inherit;transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}.login-form input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.login-form button[type=submit]{margin-top:4px;padding:12px 16px;border:none;border-radius:var(--radius-button);background:var(--accent);color:var(--text-inverted);font-size:.95rem;font-weight:700;cursor:pointer;transition:background var(--dur) var(--ease),transform var(--dur) var(--ease)}.login-form button[type=submit]:hover:not(:disabled){background:var(--accent-strong)}.login-form button[type=submit]:active:not(:disabled){transform:translateY(1px)}.login-form button:disabled{opacity:.6;cursor:default}.oauth-section{display:grid;gap:10px;padding-top:14px;border-top:1px solid var(--border-subtle);font-size:.85rem;color:var(--text-muted)}.ghost-button,.oauth-button{padding:11px 14px;border-radius:var(--radius-button);border:1px solid var(--border-subtle);background:#fff;color:var(--text-primary);font-weight:600;cursor:pointer;transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease)}.ghost-button:hover{border-color:var(--accent);background:var(--accent-soft)}.auth-links{display:flex;flex-direction:column;gap:6px;font-size:.85rem}.auth-links a{color:var(--accent);text-decoration:none;font-weight:600}.auth-links a:hover{text-decoration:underline}.success-card{background:var(--green-soft);color:var(--green);border-radius:10px;padding:10px 12px;font-size:.88rem}.portal-shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:16px;padding:20px 14px;background:var(--sb-bg);border-right:1px solid var(--sb-border);color:var(--sb-text)}.brand{display:flex;align-items:center;gap:10px;padding:2px 6px 6px}.brand-mark{width:36px;height:36px;display:grid;place-items:center;border-radius:10px;background:linear-gradient(135deg,var(--accent-bright),var(--accent-strong));color:#fff;font-weight:800;font-size:.82rem;letter-spacing:.02em;box-shadow:0 4px 12px #0d948859;flex-shrink:0}.brand-text{display:grid;gap:1px;min-width:0}.brand-text strong{font-size:1.02rem;letter-spacing:-.01em;color:#fff}.brand-text span{font-size:.64rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--sb-text-dim)}.sidebar nav{display:grid;gap:2px}.nav-section{padding:8px 10px 4px;font-size:.64rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--sb-text-dim)}.sidebar nav a{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;color:var(--sb-text);text-decoration:none;font-size:.9rem;font-weight:600;opacity:.85;transition:background var(--dur) var(--ease),color var(--dur) var(--ease),opacity var(--dur) var(--ease)}.sidebar nav a svg{flex-shrink:0;opacity:.8}.sidebar nav a:hover{background:var(--sb-hover-bg);opacity:1}.sidebar nav a.active{background:var(--sb-active-bg);color:var(--sb-active-text);opacity:1;position:relative}.sidebar nav a.active svg{opacity:1}.sidebar nav a.active:before{content:"";position:absolute;left:-14px;top:8px;bottom:8px;width:3px;border-radius:3px;background:var(--accent-bright)}.business-switcher{width:100%;padding:10px 12px;border-radius:var(--radius-button);border:1px solid var(--sb-border);background:#ffffff0f;color:var(--sb-text);font-size:.88rem;font-weight:700;font-family:inherit}.business-switcher:focus{outline:none;border-color:var(--accent-bright)}.business-switcher option{color:var(--text-primary);background:#fff}.business-name{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:10px;background:#ffffff0d;border:1px solid var(--sb-border);font-size:.86rem;font-weight:700;color:var(--sb-text)}.business-name svg{color:var(--accent-bright);flex-shrink:0}.business-name span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.session-box{display:grid;gap:8px;margin-top:auto;padding:12px;border-radius:12px;background:#ffffff0d;border:1px solid var(--sb-border);font-size:.82rem}.session-email{font-weight:600;color:var(--sb-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.session-box button{display:flex;align-items:center;justify-content:center;gap:7px;padding:8px 10px;border:1px solid var(--sb-border);border-radius:8px;background:transparent;color:var(--sb-text);cursor:pointer;font-weight:600;font-size:.8rem;font-family:inherit;transition:border-color var(--dur) var(--ease),color var(--dur) var(--ease),background var(--dur) var(--ease)}.session-box button:hover{border-color:#f8717180;color:#fca5a5;background:#f8717114}.session-chip{width:fit-content;padding:4px 9px;border-radius:var(--radius-pill);background:var(--sb-active-bg);color:var(--sb-active-text);font-size:.66rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em}.content{padding:26px 32px 48px;min-width:0}.page-header{margin-bottom:18px;display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.page-header h1{margin:0;font-size:1.65rem;letter-spacing:-.02em}.page-header p{margin:4px 0 0;color:var(--text-muted);font-size:.92rem}.readonly-chip{flex-shrink:0;margin-top:6px;padding:5px 12px;border-radius:var(--radius-pill);background:var(--accent-soft);color:var(--accent-strong);font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em}.period-caption{display:flex;align-items:center;gap:7px;margin:0 0 16px;font-size:.82rem;font-weight:600;color:var(--text-muted)}.period-caption svg{color:var(--accent)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(225px,1fr));gap:14px;margin-bottom:18px}.kpi-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-card);box-shadow:var(--shadow-card);padding:16px 18px 14px;display:grid;gap:8px;align-content:start;transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}.kpi-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-card-hover)}.kpi-top{display:flex;align-items:center;gap:9px}.kpi-icon{width:30px;height:30px;display:grid;place-items:center;border-radius:9px;background:var(--accent-soft);color:var(--accent);flex-shrink:0}.kpi-blue .kpi-icon{background:var(--blue-soft);color:var(--blue)}.kpi-green .kpi-icon{background:var(--green-soft);color:var(--green)}.kpi-violet .kpi-icon{background:var(--violet-soft);color:var(--violet)}.kpi-warn .kpi-icon{background:var(--warn-soft);color:var(--warn)}.kpi-muted .kpi-icon{background:#64748b1f;color:var(--text-muted)}.kpi-title{font-size:.74rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted)}.kpi-value{font-size:1.62rem;letter-spacing:-.02em;line-height:1.1}.kpi-value-small{font-size:1.05rem}.kpi-sub{margin:0;font-size:.78rem;color:var(--text-muted);line-height:1.4}.panel{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius-card);box-shadow:var(--shadow-card);margin-bottom:16px;overflow:hidden;min-width:0}.panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;border-bottom:1px solid var(--border-subtle)}.panel-head h2{margin:0;font-size:1rem;letter-spacing:-.01em}.panel-head-side{display:flex;align-items:center;gap:10px}.panel-badge{font-size:.72rem;font-weight:700;color:var(--accent-strong);background:var(--accent-soft);padding:3px 10px;border-radius:var(--radius-pill);white-space:nowrap}.panel-body{padding:0}.panel-body>.trend-chart{display:block;padding:14px 14px 8px}.panel-empty{padding:32px 20px;text-align:center;color:var(--text-muted);font-size:.88rem}.dash-split{display:grid;grid-template-columns:repeat(auto-fit,minmax(330px,1fr));gap:16px;margin-bottom:16px}.dash-split .panel{margin-bottom:0}.dash-split-3{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.segmented{display:inline-flex;gap:2px;padding:3px;border-radius:9px;background:#64748b1a}.segmented button{border:none;background:transparent;padding:5px 11px;border-radius:7px;font-size:.76rem;font-weight:700;font-family:inherit;color:var(--text-muted);cursor:pointer;transition:background var(--dur) var(--ease),color var(--dur) var(--ease);white-space:nowrap}.segmented button:hover{color:var(--text-primary)}.segmented button.active{background:#fff;color:var(--accent-strong);box-shadow:0 1px 3px #1018281f}.trend-chart{width:100%;height:auto}.trend-grid{stroke:#18274b12;stroke-width:1}.trend-line{stroke:var(--accent);stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}.trend-dot{fill:transparent;cursor:pointer}.trend-dot:hover{fill:var(--accent);fill-opacity:.85}.trend-x-label{fill:var(--text-muted);font-size:11px;font-family:var(--font);font-weight:600}.rank-list{list-style:none;margin:0;padding:6px 0}.rank-list li{display:flex;gap:12px;align-items:flex-start;padding:11px 18px}.rank-list li+li{border-top:1px solid var(--border-subtle)}.rank-pos{width:28px;height:28px;display:grid;place-items:center;border-radius:8px;background:#64748b1a;color:var(--text-muted);font-size:.74rem;font-weight:800;flex-shrink:0;margin-top:2px}.rank-list li:first-child .rank-pos{background:var(--accent-soft);color:var(--accent-strong)}.rank-body{flex:1;min-width:0;display:grid;gap:4px}.rank-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px}.rank-name{font-weight:700;font-size:.9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rank-value{font-size:.9rem;white-space:nowrap}.rank-meta{font-size:.76rem;color:var(--text-muted)}.rank-track{height:6px;border-radius:4px;background:#64748b1f;overflow:hidden}.rank-bar{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--accent-bright),var(--accent));transition:width .4s var(--ease)}.delta-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-pill);font-size:.76rem;font-weight:800}.delta-up{background:var(--green-soft);color:var(--green)}.delta-down{background:var(--danger-soft);color:var(--danger)}.delta-flat{background:#64748b1f;color:var(--text-muted)}.stat-rows{list-style:none;margin:0;padding:4px 0}.stat-row{display:flex;align-items:center;gap:11px;padding:10px 18px}.stat-row+.stat-row{border-top:1px solid var(--border-subtle)}.stat-icon{width:28px;height:28px;display:grid;place-items:center;border-radius:8px;background:#64748b1a;color:var(--text-muted);flex-shrink:0}.stat-warn .stat-icon{background:var(--warn-soft);color:var(--warn)}.stat-danger .stat-icon{background:var(--danger-soft);color:var(--danger)}.stat-strong .stat-icon{background:var(--accent-soft);color:var(--accent-strong)}.stat-text{flex:1;min-width:0;display:grid;gap:1px}.stat-label{font-size:.86rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stat-detail{font-size:.74rem;color:var(--text-muted)}.stat-value{font-size:.9rem;white-space:nowrap}.stat-strong .stat-value{font-size:1.02rem}.margin-hero{display:flex;align-items:center;gap:12px;padding:16px 18px 8px}.margin-hero strong{font-size:1.9rem;letter-spacing:-.02em;line-height:1}.compare-rows{display:grid;gap:12px;padding:10px 18px 16px}.compare-row{display:grid;gap:5px}.compare-head{font-size:.78rem;font-weight:700;color:var(--text-muted)}.compare-detail{font-size:.76rem;color:var(--text-muted)}.compare-muted .rank-bar{background:#64748b59}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:14px}.toolbar-meta{font-size:.84rem;font-weight:600;color:var(--text-muted)}.report-picker{display:inline-flex;align-items:center;gap:10px;font-size:.84rem;color:var(--text-muted)}.report-picker select{min-width:240px;padding:8px 12px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text)}.settings-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.search-box{position:relative;display:flex;align-items:center;width:min(360px,100%)}.search-box svg{position:absolute;left:12px;color:var(--text-muted);pointer-events:none}.search-box input{width:100%;padding:10px 13px 10px 38px;border-radius:var(--radius-button);border:1px solid var(--border-subtle);background:#fff;color:var(--text-primary);font-size:.92rem;font-family:inherit;transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}.search-box input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.table-wrap{width:100%;overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.89rem}thead th{position:sticky;top:0;text-align:left;padding:11px 18px;font-size:.72rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted);background:#f7f9fc;border-bottom:1px solid var(--border-subtle);white-space:nowrap}tbody td{padding:11px 18px;border-bottom:1px solid var(--border-subtle)}tbody tr:last-child td{border-bottom:none}tbody tr{transition:background var(--dur) var(--ease)}tbody tr:hover{background:#0d94880a}th.num,td.num{text-align:right;font-variant-numeric:tabular-nums}.cell-strong{font-weight:700}.cell-warn{color:var(--warn)}.cell-danger{color:var(--danger)}.status-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1px;background:var(--border-subtle)}.status-grid div{display:grid;gap:4px;padding:14px 18px;background:var(--bg-card)}.status-grid span{font-size:.74rem;color:var(--text-muted);text-transform:capitalize}.status-grid strong{font-size:1.04rem}.pill{display:inline-flex;align-items:center;padding:3px 10px;border-radius:var(--radius-pill);background:#64748b21;color:var(--text-muted);font-size:.75rem;font-weight:700;text-transform:capitalize;white-space:nowrap}.pill.success{background:var(--green-soft);color:var(--green)}.pill.warning{background:var(--warn-soft);color:var(--warn)}.pill.danger{background:var(--danger-soft);color:var(--danger)}.state-card{display:flex;align-items:center;justify-content:center;gap:12px;background:var(--bg-card);border:1px dashed var(--border-card);border-radius:var(--radius-card);padding:40px 24px;text-align:center;color:var(--text-muted);font-size:.95rem}.spinner{width:18px;height:18px;border-radius:50%;border:2.5px solid var(--accent-soft);border-top-color:var(--accent);animation:portal-spin .7s linear infinite;flex-shrink:0}@keyframes portal-spin{to{transform:rotate(360deg)}}.alert{background:var(--danger-soft);color:var(--danger);border:1px solid rgba(211,47,47,.2);border-radius:10px;padding:11px 14px;font-size:.9rem}.banner-alert{margin-bottom:18px}@media(max-width:980px){.dash-split,.dash-split-3{grid-template-columns:1fr}}@media(max-width:820px){.portal-shell{grid-template-columns:1fr}.sidebar{position:static;height:auto;flex-direction:row;flex-wrap:wrap;align-items:center;gap:10px;padding:14px 16px}.sidebar nav{display:flex;flex-wrap:nowrap;overflow-x:auto;width:100%;order:3}.nav-section{display:none}.sidebar nav a span{white-space:nowrap}.session-box{margin:0 0 0 auto;grid-auto-flow:column;align-items:center;padding:8px 10px}.session-email{max-width:160px}.content{padding:18px 16px 40px}.page-header h1{font-size:1.35rem}.kpi-grid{grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:10px}.kpi-value{font-size:1.35rem}}@media(prefers-reduced-motion:reduce){.kpi-card,.rank-bar,tbody tr,.sidebar nav a{transition:none}.spinner{animation-duration:1.5s}}
