:root{--bg-base: #0b0b0d;--bg-surface: #141417;--bg-surface-2: #1b1b1f;--bg-elevated: #212126;--bg-hover: #26262c;--gold: #d4af37;--gold-bright: #e8c457;--gold-soft: rgba(212, 175, 55, .12);--gold-line: rgba(212, 175, 55, .35);--text-strong: #f4f4f5;--text: #c9c9ce;--text-muted: #8a8a93;--text-faint: #5c5c64;--pos: #4ade80;--neg: #f87171;--warn: #fbbf24;--meta: #4267f0;--google: #34a853;--tiktok: #25f4ee;--snapchat: #f3d800;--border: rgba(255, 255, 255, .07);--border-strong: rgba(255, 255, 255, .12);--radius: 14px;--radius-sm: 9px;--radius-pill: 999px;--shadow: 0 8px 24px rgba(0, 0, 0, .35);--sidebar-w: 248px;--topbar-h: 68px;--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--mono: "SF Mono", "JetBrains Mono", "Cascadia Code", Consolas, monospace}*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:var(--font);background:var(--bg-base);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}.app-shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}.sidebar{background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:22px 16px;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:11px;padding:4px 8px 22px}.brand-mark{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--gold-bright),var(--gold));display:grid;place-items:center;color:#1a1400;font-weight:800;font-size:17px;box-shadow:0 2px 10px #d4af3759}.brand-logo{width:34px;height:34px;border-radius:9px;object-fit:contain;flex:none}.brand-name{font-weight:700;color:var(--text-strong);font-size:16px;letter-spacing:-.01em}.brand-sub{font-size:11px;color:var(--text-faint)}.auth-logo{width:190px;max-width:100%;height:auto;display:block}.nav{display:flex;flex-direction:column;gap:3px;margin-top:8px}.nav-label{font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);padding:14px 12px 6px}.nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:var(--radius-sm);color:var(--text-muted);font-weight:500;cursor:pointer;transition:background .12s,color .12s}.nav-item svg{width:18px;height:18px;flex:none}.nav-item:hover{background:var(--bg-hover);color:var(--text)}.nav-item.active{background:var(--gold-soft);color:var(--gold-bright);box-shadow:inset 2px 0 0 var(--gold)}.sidebar-foot{margin-top:auto;padding:12px;color:var(--text-faint);font-size:11px}.main{display:flex;flex-direction:column;min-width:0}.topbar{min-height:var(--topbar-h);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:16px;flex-wrap:wrap;padding:10px 28px;position:sticky;top:0;z-index:20;background:#0b0b0dd1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.topbar h1{font-size:18px;font-weight:650;color:var(--text-strong);margin:0;letter-spacing:-.01em}.topbar .spacer{flex:1}.topbar-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.select{font-family:inherit;font-size:12.5px;font-weight:600;cursor:pointer;background:var(--bg-surface-2);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-pill);padding:7px 11px;color-scheme:dark;outline:none}.content{padding:26px 28px 60px;max-width:1320px;width:100%}.segmented{display:inline-flex;background:var(--bg-surface-2);border:1px solid var(--border);border-radius:var(--radius-pill);padding:3px}.segmented button{border:0;background:transparent;color:var(--text-muted);padding:6px 13px;border-radius:var(--radius-pill);cursor:pointer;font-size:12.5px;font-weight:600;font-family:inherit;transition:all .12s}.segmented button:hover{color:var(--text)}.segmented button.active{background:var(--gold);color:#1a1400}.date-field{display:inline-flex;align-items:center;gap:6px;background:var(--bg-surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:5px 10px}.date-field input{background:transparent;border:0;color:var(--text);font-family:inherit;font-size:12.5px;color-scheme:dark;outline:none}.date-field span{color:var(--text-faint);font-size:12px}.grid{display:grid;gap:16px}.kpi-grid{grid-template-columns:repeat(4,1fr)}.kpi-grid.secondary{grid-template-columns:repeat(5,1fr);margin-top:16px}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px}.card.hero{background:linear-gradient(160deg,var(--bg-surface-2),var(--bg-surface));border-color:var(--gold-line)}.kpi-label{display:flex;align-items:center;gap:7px;color:var(--text-muted);font-size:12.5px;font-weight:550}.kpi-label svg{width:16px;height:16px;flex:none;color:var(--gold);opacity:.85}.kpi-value{font-size:27px;font-weight:720;color:var(--text-strong);margin:9px 0 4px;letter-spacing:-.02em}.card.hero .kpi-value{color:var(--gold-bright)}.kpi-value.sm{font-size:21px}.kpi-note{font-size:10.5px;font-weight:550;color:var(--text-faint);margin-top:2px;letter-spacing:.01em}.kpi-foot{display:flex;align-items:center;justify-content:space-between;gap:8px}.delta{display:inline-flex;align-items:center;gap:3px;font-size:12px;font-weight:650}.delta.up{color:var(--pos)}.delta.down{color:var(--neg)}.delta.flat{color:var(--text-faint)}.spark{width:86px;height:30px;flex:none}.hint{color:var(--text-faint);font-size:11px;font-weight:500}.panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-top:18px}.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.panel-head h2{font-size:15px;font-weight:650;color:var(--text-strong);margin:0}.panel-head .sub{color:var(--text-muted);font-size:12.5px}.chart-wrap{position:relative;height:300px}.chart-wrap.sm{height:260px}.hm-wrap{overflow-x:auto}.hm-grid{display:grid;grid-template-columns:34px repeat(24,minmax(20px,1fr));gap:3px;min-width:560px}.hm-hourlabel{font-size:9.5px;color:var(--text-faint);text-align:center;padding-bottom:2px}.hm-daylabel{font-size:10.5px;color:var(--text-muted);display:flex;align-items:center}.hm-cell{aspect-ratio:1 / 1;border-radius:3px;min-height:16px;cursor:default;transition:outline .1s}.hm-cell:hover{outline:1.5px solid var(--gold-bright)}.demo-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px}.demo-title{font-size:12px;font-weight:650;color:var(--text-muted);margin-bottom:12px}.demo-row{display:grid;grid-template-columns:56px 1fr 84px 56px;align-items:center;gap:10px;margin-bottom:8px}.demo-label{font-size:12px;color:var(--text)}.demo-track{background:var(--bg-elevated);border-radius:var(--radius-pill);height:14px;overflow:hidden}.demo-fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-bright));border-radius:var(--radius-pill)}.demo-val{font-size:11.5px;color:var(--text-muted);text-align:right;font-variant-numeric:tabular-nums}.demo-spend{font-size:11px;color:var(--text-faint);text-align:right;font-variant-numeric:tabular-nums}@media(max-width:720px){.demo-grid{grid-template-columns:1fr}}.auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.auth-card{width:100%;max-width:340px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px 26px;display:flex;flex-direction:column;gap:12px}.auth-brand{display:flex;align-items:center;gap:10px}.auth-title{font-size:18px;font-weight:700;color:var(--text-strong)}.auth-sub{font-size:12.5px;color:var(--text-muted);margin-bottom:6px}.auth-card input{font-family:inherit;font-size:13px;padding:10px 12px;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--text);outline:none}.auth-card input:focus{border-color:var(--gold-line)}.auth-card .btn{width:100%;padding:10px;margin-top:4px}.auth-err{color:var(--neg);font-size:11.5px;min-height:14px}.user-row{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px}.user-name{font-size:12px;color:var(--text);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logout-btn{font-family:inherit;font-size:11px;font-weight:600;cursor:pointer;color:var(--text-muted);background:transparent;border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:4px 8px}.logout-btn:hover{color:var(--text);border-color:var(--gold-line)}.foot-note{font-size:10.5px;color:var(--text-faint)}.user-list{display:flex;flex-direction:column}.user-item{padding:8px 0;border-bottom:1px solid var(--border)}.user-item:last-child{border-bottom:0}.table-wrap{overflow-x:auto}table.data{width:100%;border-collapse:collapse;font-size:13px}table.data th{text-align:right;color:var(--text-muted);font-weight:600;font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;padding:10px 14px;border-bottom:1px solid var(--border-strong);white-space:nowrap}table.data th:first-child,table.data td:first-child{text-align:left}table.data td{padding:12px 14px;border-bottom:1px solid var(--border);white-space:nowrap}table.data tbody tr:hover{background:var(--bg-surface-2)}table.data td.num{font-variant-numeric:tabular-nums}.campaign-row{cursor:pointer}.cell-flex{display:flex;align-items:center;gap:10px}.caret{color:var(--text-faint);font-size:11px;transition:transform .15s;display:inline-block}.caret.open{transform:rotate(90deg);color:var(--gold)}table.data tr.detail-row:hover{background:transparent}table.data tr.detail-row>td{padding:0;border-bottom:1px solid var(--border);white-space:normal}.product-panel{background:var(--bg-surface-2);padding:6px 14px 14px 38px}.product-summary{font-size:11.5px;color:var(--text-muted);padding:10px 0 8px}table.product-table{font-size:12.5px}table.product-table th{padding:7px 12px;font-size:11px}table.product-table td{padding:7px 12px;border-bottom:1px solid var(--border)}table.product-table th.sortable{cursor:pointer}table.product-table th.sortable:hover{color:var(--text)}table.product-table th.active{color:var(--gold-bright)}.loading.sm{padding:14px;font-size:12px}.thumb{width:40px;height:40px;border-radius:var(--radius-sm);object-fit:cover;display:block;background:var(--bg-elevated)}.thumb-empty{display:flex;align-items:center;justify-content:center;color:var(--text-faint);font-size:14px;border:1px solid var(--border)}td.scale.good{color:var(--pos)}td.scale.ok{color:#e8c457}td.scale.bad,.fatigue{color:var(--neg)}.score-badge{display:inline-block;min-width:30px;text-align:center;padding:3px 8px;border-radius:var(--radius-pill);font-weight:700;font-size:12px}.score-badge.good{background:#4ade8029;color:var(--pos)}.score-badge.ok{background:var(--gold-soft);color:var(--gold-bright)}.score-badge.bad{background:#f8717129;color:var(--neg)}.muted{color:var(--text-muted)}.strong{color:var(--text-strong);font-weight:600}.gold{color:var(--gold-bright);font-weight:650}.pbadge{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;color:var(--text)}.pdot{width:9px;height:9px;border-radius:3px;flex:none}.pdot.META{background:var(--meta)}.pdot.GOOGLE{background:var(--google)}.pdot.TIKTOK{background:var(--tiktok)}.pdot.SNAPCHAT{background:var(--snapchat)}.bucket-bar{display:flex;height:14px;border-radius:var(--radius-pill);overflow:hidden;margin:8px 0 18px;background:var(--bg-surface-2)}.bucket-seg{height:100%}.bucket-seg.matched{background:var(--gold)}.bucket-seg.unmatched{background:#6b6bf0}.bucket-seg.missingUtm{background:#4a4a52}.bucket-seg.directUnknown{background:#2f2f36}.legend{display:flex;flex-wrap:wrap;gap:16px}.legend-item{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--text-muted)}.legend-swatch{width:11px;height:11px;border-radius:3px;flex:none}.section-title{font-size:13px;font-weight:650;color:var(--text-strong);margin:26px 0 10px}.conn-grid{grid-template-columns:repeat(2,1fr)}.conn-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.status-pill{font-size:11.5px;font-weight:650;padding:4px 10px;border-radius:var(--radius-pill)}.status-pill.CONNECTED{background:#4ade8024;color:var(--pos)}.status-pill.DISCONNECTED{background:var(--bg-elevated);color:var(--text-muted)}.status-pill.ERROR{background:#f8717124;color:var(--neg)}.btn{font-family:inherit;font-size:12.5px;font-weight:600;cursor:pointer;padding:7px 14px;border-radius:var(--radius-sm);background:var(--gold);color:#1a1400;border:0}.btn.ghost{background:transparent;border:1px solid var(--border-strong);color:var(--text)}.btn.small{padding:5px 11px;font-size:11.5px}.btn:disabled{opacity:.45;cursor:not-allowed}.status-pill.SUCCESS,.status-pill.CONNECTED{background:#4ade8024;color:var(--pos)}.status-pill.FAILED,.status-pill.ERROR{background:#f8717124;color:var(--neg)}.status-pill.RUNNING,.status-pill.PENDING{background:var(--gold-soft);color:var(--gold-bright)}.status-pill.SKIPPED{background:var(--bg-elevated);color:var(--text-muted)}.conn-actions{display:flex;align-items:center;gap:8px}.conn-form{display:flex;flex-direction:column;gap:8px;margin-top:12px}.conn-form input{font-family:inherit;font-size:12.5px;padding:7px 10px;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--text)}.utm-row{display:flex;align-items:center;gap:10px;margin-top:8px}.utm-field{font-size:12.5px;color:var(--text);min-width:230px;font-variant-numeric:tabular-nums}.utm-arrow{color:var(--text-faint)}.utm-row .select{min-width:170px}@media(max-width:720px){.utm-field{min-width:0}.utm-row{flex-wrap:wrap}}.conn-feedback{font-size:11.5px;margin-top:8px}.conn-feedback.ok{color:var(--pos)}.conn-feedback.err{color:var(--neg)}.loading,.empty{color:var(--text-muted);padding:40px;text-align:center}.note{background:var(--gold-soft);border:1px solid var(--gold-line);border-radius:var(--radius-sm);padding:11px 14px;color:var(--text);font-size:12.5px;margin-bottom:18px}.note b{color:var(--gold-bright)}@media(max-width:1100px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.kpi-grid.secondary{grid-template-columns:repeat(3,1fr)}.conn-grid{grid-template-columns:1fr}}@media(max-width:720px){.app-shell{grid-template-columns:1fr}.sidebar{display:none}}
