*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-base: #0a0c10;--bg-surface: #111318;--bg-elevated: #181c24;--bg-card: #1a1f28;--bg-hover: #1f2535;--border: rgba(255,255,255,.07);--border-accent: rgba(99,102,241,.4);--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #475569;--text-micro: #334155;--accent: #6366f1;--accent-light: #818cf8;--accent-glow: rgba(99,102,241,.15);--green: #22c55e;--red: #ef4444;--yellow: #f59e0b;--blue: #3b82f6;--purple: #a855f7;--pink: #ec4899;--cyan: #06b6d4;--orange: #f97316;--font: "Inter", system-ui, sans-serif;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--shadow-card: 0 1px 3px rgba(0,0,0,.4), 0 0 0 1px rgba(255,255,255,.05);--shadow-glow: 0 0 30px rgba(99,102,241,.15);--transition: .15s cubic-bezier(.4,0,.2,1)}html,body,#root{height:100%;font-family:var(--font);background:var(--bg-base);color:var(--text-primary);font-size:13px;line-height:1.5;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app-shell{display:grid;grid-template-columns:220px 1fr;grid-template-rows:48px 1fr;height:100vh;overflow:hidden}.topbar{grid-column:1 / -1;display:flex;align-items:center;padding:0 20px;gap:16px;background:var(--bg-surface);border-bottom:1px solid var(--border);z-index:100}.topbar-logo{display:flex;align-items:center;gap:8px;font-weight:700;font-size:14px;color:var(--text-primary);text-decoration:none;letter-spacing:-.3px}.topbar-logo .logo-dot{width:8px;height:8px;background:var(--accent);border-radius:50%;box-shadow:0 0 8px var(--accent)}.topbar-site-select{margin-left:auto;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-primary);padding:5px 10px;border-radius:var(--radius-sm);font-size:12px;font-family:var(--font);cursor:pointer;outline:none;transition:border-color var(--transition)}.topbar-site-select:hover{border-color:var(--border-accent)}.topbar-realtime{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary);padding:4px 10px;background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border)}.topbar-realtime .pulse{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 6px var(--green);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.topbar-user{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-secondary)}.topbar-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:#fff}.topbar-logout{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:11px;padding:4px 8px;border-radius:var(--radius-sm);transition:all var(--transition)}.topbar-logout:hover{background:var(--bg-elevated);color:var(--text-primary)}.sidebar{background:var(--bg-surface);border-right:1px solid var(--border);padding:12px 8px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.sidebar-section-label{font-size:10px;font-weight:600;color:var(--text-micro);text-transform:uppercase;letter-spacing:.8px;padding:12px 8px 4px}.sidebar-link{display:flex;align-items:center;gap:9px;padding:7px 10px;border-radius:var(--radius-sm);color:var(--text-secondary);text-decoration:none;font-size:12.5px;font-weight:450;transition:all var(--transition);cursor:pointer;border:none;background:none;width:100%;text-align:left}.sidebar-link:hover{background:var(--bg-elevated);color:var(--text-primary)}.sidebar-link.active{background:var(--accent-glow);color:var(--accent-light);border:1px solid var(--border-accent)}.sidebar-link svg{flex-shrink:0;opacity:.7}.sidebar-link.active svg{opacity:1}.main-content{overflow-y:auto;padding:20px 24px;background:var(--bg-base)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:16px}.page-title{font-size:18px;font-weight:700;color:var(--text-primary);letter-spacing:-.5px}.page-subtitle{font-size:12px;color:var(--text-secondary);margin-top:2px}.date-range-bar{display:flex;gap:4px}.date-btn{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary);padding:5px 12px;border-radius:var(--radius-sm);font-size:12px;cursor:pointer;transition:all var(--transition);font-family:var(--font)}.date-btn:hover{border-color:var(--accent);color:var(--text-primary)}.date-btn.active{background:var(--accent-glow);border-color:var(--border-accent);color:var(--accent-light);font-weight:600}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:20px}.kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px;position:relative;overflow:hidden;transition:border-color var(--transition),box-shadow var(--transition)}.kpi-card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-glow)}.kpi-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,var(--accent-glow) 0%,transparent 60%);opacity:0;transition:opacity var(--transition)}.kpi-card:hover:before{opacity:1}.kpi-label{font-size:11px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.kpi-value{font-size:28px;font-weight:800;color:var(--text-primary);letter-spacing:-1px;line-height:1;margin-bottom:6px}.kpi-change{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:500}.kpi-change.up{color:var(--green)}.kpi-change.down{color:var(--red)}.kpi-change.flat{color:var(--text-muted)}.chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px;margin-bottom:16px}.chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.chart-title{font-size:13px;font-weight:600;color:var(--text-primary)}.chart-subtitle{font-size:11px;color:var(--text-muted);margin-top:2px}.data-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}@media (max-width: 1200px){.data-grid{grid-template-columns:1fr}}.data-table-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.data-table-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}.data-table-title{font-size:12px;font-weight:600;color:var(--text-primary)}table.stats-table{width:100%;border-collapse:collapse}table.stats-table th{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding:8px 16px;text-align:left;border-bottom:1px solid var(--border);background:var(--bg-elevated)}table.stats-table td{padding:9px 16px;border-bottom:1px solid rgba(255,255,255,.03);font-size:12px;color:var(--text-primary)}table.stats-table tr:last-child td{border-bottom:none}table.stats-table tr:hover td{background:#ffffff05}.bar-cell{display:flex;align-items:center;gap:8px}.bar-track{flex:1;height:3px;background:var(--bg-elevated);border-radius:99px;overflow:hidden}.bar-fill{height:100%;background:var(--accent);border-radius:99px;transition:width .6s ease}.channel-badge{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:99px;font-size:11px;font-weight:500;border:1px solid transparent}.channel-badge.paid{background:#f59e0b1f;border-color:#f59e0b4d;color:#fbbf24}.channel-badge.organic{background:#22c55e1a;border-color:#22c55e4d;color:#4ade80}.channel-badge.social{background:#3b82f61a;border-color:#3b82f64d;color:#60a5fa}.channel-badge.email{background:#a855f71a;border-color:#a855f74d;color:#c084fc}.channel-badge.referral{background:#06b6d41a;border-color:#06b6d44d;color:#22d3ee}.channel-badge.direct{background:#6366f11a;border-color:#6366f14d;color:#818cf8}.loading-spinner{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--text-muted)}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;color:var(--text-muted);text-align:center;gap:8px}.empty-state svg{opacity:.3;margin-bottom:8px}.empty-state h3{font-size:14px;font-weight:600;color:var(--text-secondary)}.empty-state p{font-size:12px;max-width:280px}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-base);background-image:radial-gradient(ellipse at 20% 50%,rgba(99,102,241,.08) 0%,transparent 60%),radial-gradient(ellipse at 80% 50%,rgba(168,85,247,.06) 0%,transparent 60%)}.auth-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:40px;width:100%;max-width:380px;box-shadow:0 25px 50px #00000080}.auth-logo{display:flex;align-items:center;gap:10px;font-size:20px;font-weight:800;margin-bottom:8px;letter-spacing:-.5px}.auth-logo .dot{width:10px;height:10px;background:var(--accent);border-radius:50%;box-shadow:0 0 10px var(--accent)}.auth-subtitle{color:var(--text-secondary);font-size:13px;margin-bottom:28px}.form-group{margin-bottom:14px}.form-label{display:block;font-size:11px;font-weight:500;color:var(--text-secondary);margin-bottom:5px;text-transform:uppercase;letter-spacing:.4px}.form-input{width:100%;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-primary);padding:9px 12px;border-radius:var(--radius-sm);font-size:13px;font-family:var(--font);outline:none;transition:border-color var(--transition),box-shadow var(--transition)}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.form-input::placeholder{color:var(--text-micro)}.compact-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-soft)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 18px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;font-family:var(--font);cursor:pointer;transition:all var(--transition);border:none;text-decoration:none}.btn-primary{background:var(--accent);color:#fff;width:100%}.btn-primary:hover{background:var(--accent-light);box-shadow:0 0 20px var(--accent-glow)}.btn-primary:active{transform:scale(.98)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border)}.btn-ghost:hover{border-color:var(--accent);color:var(--text-primary)}.btn-danger{background:#ef44441a;color:var(--red);border:1px solid rgba(239,68,68,.3)}.btn-danger:hover{background:#ef444433}.form-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:10px 14px;border-radius:var(--radius-sm);font-size:12px;margin-bottom:14px}.journey-step{display:flex;gap:12px;padding:10px 0;position:relative}.journey-step:not(:last-child):before{content:"";position:absolute;left:11px;top:34px;bottom:0;width:1px;background:var(--border)}.journey-icon{width:24px;height:24px;border-radius:50%;background:var(--bg-elevated);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:10px}.journey-icon.pageview{border-color:var(--accent);background:var(--accent-glow)}.journey-icon.custom{border-color:var(--green);background:#22c55e1a}.journey-icon.heartbeat{border-color:var(--border)}.journey-content{flex:1}.journey-path{font-size:12px;font-weight:500;color:var(--text-primary)}.journey-meta{font-size:11px;color:var(--text-muted);margin-top:2px}.text-sm{font-size:12px}.text-xs{font-size:11px}.text-muted{color:var(--text-muted)}.text-green{color:var(--green)}.text-red{color:var(--red)}.text-accent{color:var(--accent-light)}.font-bold{font-weight:700}.font-mono{font-family:JetBrains Mono,Fira Code,monospace}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tag{display:inline-block;padding:2px 7px;border-radius:99px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.4px}.tag-green{background:#22c55e1f;color:var(--green)}.tag-red{background:#ef44441f;color:var(--red)}.tag-yellow{background:#f59e0b1f;color:var(--yellow)}.tag-blue{background:#3b82f61f;color:var(--blue)}.tag-purple{background:#a855f71f;color:var(--purple)}:root{--amber: #f59e0b;--amber-glow: rgba(245,158,11,.15)}@keyframes spin{to{transform:rotate(360deg)}}td[data-cohort]{position:relative}.portfolio-row{transition:background var(--transition)}.portfolio-row:hover{background:var(--bg-hover)}.severity-high{color:var(--red);background:#ef44441a;border-radius:4px;padding:1px 5px;font-size:10px}.severity-medium{color:var(--amber);background:#f59e0b1a;border-radius:4px;padding:1px 5px;font-size:10px}.severity-low{color:var(--accent-light);background:var(--accent-glow);border-radius:4px;padding:1px 5px;font-size:10px}.btn-export{min-width:180px}.roas-good{color:var(--green)}.roas-ok{color:var(--amber)}.roas-bad{color:var(--red)}.recharts-reference-line-label{fill:var(--text-muted)!important;font-size:10px!important}.chart-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.chart-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.table-scroll{overflow-x:auto}.table-scroll::-webkit-scrollbar{height:4px}.section-divider{display:flex;align-items:center;gap:12px;margin:20px 0 16px}.section-divider:before,.section-divider:after{content:"";flex:1;height:1px;background:var(--border)}.section-divider span{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px}.metric-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:99px;font-size:11px;font-weight:600;background:var(--bg-elevated);border:1px solid var(--border)}
