:root{
  --bg:#fafafa; --bg-2:#ffffff; --bg-3:#f4f4f5;
  --border:#e4e4e7; --border-strong:#d4d4d8;
  --text:#09090b; --text-2:#3f3f46; --muted:#71717a; --muted-2:#a1a1aa;
  --accent:#e60023; --accent-soft:#e6002310;
  --good:#16a34a; --good-soft:#16a34a14;
  --warn:#ea580c; --warn-soft:#ea580c14;
  --bad:#dc2626; --bad-soft:#dc262614;
  --info:#2563eb; --info-soft:#2563eb14;
  --shadow-sm:0 1px 2px 0 rgba(0,0,0,0.04);
  --shadow:0 1px 3px 0 rgba(0,0,0,0.06), 0 1px 2px -1px rgba(0,0,0,0.04);
  --shadow-lg:0 10px 15px -3px rgba(0,0,0,0.06), 0 4px 6px -4px rgba(0,0,0,0.04);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:"Inter",-apple-system,BlinkMacSystemFont,sans-serif;font-feature-settings:"cv11","ss01","ss03";-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit}
.mono{font-family:"JetBrains Mono",ui-monospace,monospace;font-feature-settings:"zero","ss02"}

/* upload screen */
.upload-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;background:radial-gradient(ellipse 80% 60% at 50% 0%,#fafafa 0%,#f4f4f5 100%)}
.upload-screen.hidden{display:none}
.upload-shell{max-width:920px;width:100%}
.upload-brand{display:flex;align-items:center;gap:12px;margin-bottom:48px;justify-content:center}
.logo-mark{width:32px;height:32px;background:var(--text);border-radius:8px;display:grid;place-items:center;color:#fff;font-weight:700;font-size:15px;letter-spacing:-.02em}
.upload-brand .title{font-weight:600;font-size:15px;letter-spacing:-.01em}
.upload-brand .sub{font-size:13px;color:var(--muted);margin-left:6px}
.upload-hero{text-align:center;margin-bottom:48px}
.upload-hero h1{font-size:clamp(32px,4.5vw,48px);font-weight:600;letter-spacing:-.035em;line-height:1.05;margin:0 0 14px}
.upload-hero p{font-size:16px;color:var(--muted);max-width:560px;margin:0 auto;line-height:1.55}
.upload-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px}
@media (max-width:760px){.upload-grid{grid-template-columns:1fr}}
.dropzone{background:var(--bg-2);border:1.5px dashed var(--border-strong);border-radius:12px;padding:32px 24px;text-align:center;cursor:pointer;transition:all .15s ease;position:relative;display:flex;flex-direction:column;align-items:center;gap:14px;min-height:220px;justify-content:center}
.dropzone:hover{border-color:var(--text);background:#fff}
.dropzone.dragover{border-color:var(--accent);background:var(--accent-soft);transform:scale(1.005)}
.dropzone.loaded{border-style:solid;border-color:var(--good);background:var(--good-soft)}
.dropzone.error{border-style:solid;border-color:var(--bad);background:var(--bad-soft)}
.dropzone-icon{width:44px;height:44px;border-radius:10px;background:var(--bg-3);display:grid;place-items:center;color:var(--muted)}
.dropzone.loaded .dropzone-icon{background:#fff;color:var(--good)}
.dropzone.error .dropzone-icon{background:#fff;color:var(--bad)}
.dropzone-label{font-weight:600;font-size:15px;letter-spacing:-.01em}
.dropzone-label .required{color:var(--accent);font-size:10px;font-weight:600;margin-left:8px;text-transform:uppercase;letter-spacing:.06em}
.dropzone-label .optional{color:var(--muted);font-size:10px;font-weight:600;margin-left:8px;text-transform:uppercase;letter-spacing:.06em}
.dropzone-desc{font-size:12.5px;color:var(--muted);max-width:280px;line-height:1.5}
.dropzone-status{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--good);background:#fff;padding:6px 12px;border-radius:6px;border:1px solid var(--good);display:none;align-items:center;gap:8px}
.dropzone.loaded .dropzone-status{display:inline-flex}
.dropzone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}
.upload-actions{background:var(--bg-2);border:1px solid var(--border);border-radius:12px;padding:20px 24px;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.upload-info{font-size:13px;color:var(--muted);flex:1;min-width:200px}
.upload-info .key{color:var(--text);font-weight:500}
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:8px;font-weight:500;font-size:14px;letter-spacing:-.005em;border:1px solid transparent;transition:all .12s;white-space:nowrap}
.btn-primary{background:var(--text);color:#fff;border-color:var(--text)}
.btn-primary:hover:not(:disabled){background:#000}
.btn-primary:disabled{background:var(--muted-2);border-color:var(--muted-2);cursor:not-allowed;color:#fff}
.btn-ghost{background:transparent;color:var(--text-2);border-color:var(--border)}
.btn-ghost:hover{background:var(--bg-3);color:var(--text)}
.upload-errors{margin-top:16px;display:none}
.upload-errors.show{display:block}
.upload-error,.upload-warning{border-radius:8px;padding:12px 14px;font-size:13px;display:flex;gap:10px;align-items:flex-start;margin-bottom:8px;line-height:1.45}
.upload-error{background:var(--bad-soft);border:1px solid var(--bad);color:var(--bad)}
.upload-warning{background:var(--warn-soft);border:1px solid var(--warn);color:var(--warn)}
.upload-success{background:var(--good-soft);border:1px solid var(--good);color:var(--good);border-radius:8px;padding:12px 14px;font-size:13px;display:flex;gap:10px;align-items:flex-start;margin-bottom:8px;line-height:1.45}

/* mapper modal */
.mapper-modal{position:fixed;inset:0;background:rgba(9,9,11,0.4);display:none;align-items:center;justify-content:center;z-index:100;padding:24px}
.mapper-modal.show{display:flex}
.mapper-box{background:var(--bg-2);border-radius:12px;max-width:640px;width:100%;max-height:90vh;overflow:auto;padding:28px;box-shadow:var(--shadow-lg)}
.mapper-box h2{margin:0 0 8px;font-size:20px;font-weight:600;letter-spacing:-.02em}
.mapper-box .mapper-desc{font-size:13px;color:var(--muted);margin-bottom:20px;line-height:1.5}
.mapper-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:10px;align-items:center}
.mapper-row label{font-size:13px;font-weight:500}
.mapper-row label .req{color:var(--accent);margin-left:4px}
.mapper-row select{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:6px;background:#fff;font-size:13px;color:var(--text)}
.mapper-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}

/* app shell */
.app{display:none;min-height:100vh}
.app.show{display:block}
.layout{display:grid;grid-template-columns:236px 1fr;min-height:100vh}
@media (max-width:880px){.layout{grid-template-columns:1fr}}

.sidebar{background:var(--bg-2);border-right:1px solid var(--border);padding:24px 14px;position:sticky;top:0;height:100vh;overflow-y:auto}
@media (max-width:880px){.sidebar{position:static;height:auto;border-right:0;border-bottom:1px solid var(--border)}}
.brand{display:flex;align-items:center;gap:10px;padding:0 8px 20px;border-bottom:1px solid var(--border);margin-bottom:14px}
.brand .name{font-weight:600;font-size:14px;letter-spacing:-.01em}
.brand .meta{font-size:11px;color:var(--muted);margin-top:1px;font-family:"JetBrains Mono",monospace}
.nav-section{margin-bottom:18px}
.nav-label{font-size:10px;font-weight:600;color:var(--muted-2);text-transform:uppercase;letter-spacing:.08em;padding:0 8px;margin-bottom:6px}
.nav-item{display:flex;align-items:center;gap:10px;padding:8px 10px 8px 14px;border-radius:6px;cursor:pointer;font-size:13.5px;color:var(--text-2);font-weight:500;letter-spacing:-.005em;transition:all .12s;border:0;background:none;width:100%;text-align:left;margin-bottom:2px;position:relative;--tab-accent:#0A0A0B}
.nav-item::before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:0 2px 2px 0;background:var(--tab-accent);opacity:0;transition:opacity .12s}
.nav-item:hover:not(.disabled){background:var(--bg-3);color:var(--text)}
.nav-item:hover:not(.disabled)::before{opacity:.4}
.nav-item:hover:not(.disabled) .icon{color:var(--tab-accent)}
.nav-item.active{background:var(--bg-3);color:var(--text);font-weight:600}
.nav-item.active::before{opacity:1}
.nav-item.active .icon{color:var(--tab-accent)}
.nav-item .icon{flex-shrink:0;display:grid;place-items:center;transition:color .12s}
.nav-item .badge{margin-left:auto;font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--muted);background:var(--bg-2);padding:2px 6px;border-radius:99px;border:1px solid var(--border)}
.nav-item.active .badge{background:var(--tab-accent);color:#fff;border-color:var(--tab-accent)}
.nav-item.disabled{color:var(--muted-2);cursor:not-allowed}
.nav-item.disabled .lock{margin-left:auto;color:var(--muted-2)}
/* Per-tab accent colors */
.nav-item[data-tab="overview"]{--tab-accent:#0A0A0B}
.nav-item[data-tab="campaigns"]{--tab-accent:#0EA5E9}
.nav-item[data-tab="types"]{--tab-accent:#0891B2}
.nav-item[data-tab="trends"]{--tab-accent:#2563EB}
.nav-item[data-tab="adlevel"]{--tab-accent:#7C3AED}
.nav-item[data-tab="products"]{--tab-accent:#DB2777}
.nav-item[data-tab="ai-campaigns"]{--tab-accent:#E60023}
.nav-item[data-tab="scaling"]{--tab-accent:#EA580C}
.nav-item[data-tab="alerts"]{--tab-accent:#DC2626}
.nav-item[data-tab="raw"]{--tab-accent:#71717A}
.nav-item[data-tab="page-optimizer"]{--tab-accent:#059669}

.main{padding:32px 40px 80px;max-width:1480px}
@media (max-width:880px){.main{padding:24px 20px 60px}}
.page-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:28px;padding-bottom:22px;border-bottom:1px solid var(--border);position:relative}
.page-head::after{content:"";position:absolute;left:0;bottom:-1px;width:60px;height:2px;background:var(--page-accent,#0A0A0B);transition:background .25s,width .25s}
.page-head .titles h1{font-size:28px;font-weight:600;letter-spacing:-.025em;margin:0 0 4px;display:flex;align-items:center;gap:11px}
.page-head .titles h1::before{content:"";display:inline-block;width:9px;height:9px;border-radius:99px;background:var(--page-accent,#0A0A0B);box-shadow:0 0 0 3px color-mix(in srgb,var(--page-accent,#0A0A0B) 18%,transparent);transition:background .25s,box-shadow .25s;flex-shrink:0}
.page-head .titles .crumb{font-size:12px;color:var(--muted);font-family:"JetBrains Mono",monospace;letter-spacing:.02em}
.page-head .actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.toggle-shopify,.margin-control,.range-control{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--bg-2);border:1px solid var(--border);border-radius:8px;font-size:12.5px;color:var(--text-2)}
.date-input{font-family:inherit;font-size:11.5px;color:var(--text);background:#fff;border:1px solid var(--border);border-radius:5px;padding:4px 7px;outline:none;font-feature-settings:"tnum"}
.date-input:focus{border-color:var(--text);background:#fff}
.date-input::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.6}
.date-input::-webkit-calendar-picker-indicator:hover{opacity:1}
.btn-apply{font-family:inherit;font-size:11.5px;font-weight:500;color:#fff;background:var(--text);border:1px solid var(--text);border-radius:5px;padding:4px 10px;cursor:pointer;transition:all .12s}
.btn-apply:hover{opacity:.85}
.btn-apply:disabled{opacity:.4;cursor:not-allowed}
.toggle-active{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--bg-2);border:1px solid var(--border);border-radius:8px;font-size:12.5px;color:var(--text-2);transition:all .15s}
.toggle-active:has(.switch.on){background:#16a34a10;border-color:#16a34a40;color:var(--good)}
.toggle-active:has(.switch.on) span{font-weight:600}
.range-control select{background:transparent;border:0;font-size:12.5px;font-weight:500;color:var(--text);cursor:pointer;outline:none;font-family:inherit;padding:0 16px 0 0;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%2371717a' stroke-width='2.5'><polyline points='6 9 12 15 18 9'/></svg>");background-position:right center;background-repeat:no-repeat;background-size:10px}
.switch{position:relative;width:32px;height:18px;background:var(--border-strong);border-radius:99px;cursor:pointer;transition:background .15s}
.switch::after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;transition:transform .15s;box-shadow:var(--shadow-sm)}
.switch.on{background:var(--good)}
.switch.on::after{transform:translateX(14px)}
.margin-control input[type=range]{width:96px}
.margin-control .val{font-family:"JetBrains Mono",monospace;font-weight:600;color:var(--text);min-width:42px;text-align:right}

.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}
@media (max-width:1100px){.kpi-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:760px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}

/* Agency vs In-house comparison cards */
.source-compare{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.source-card{background:#fff;border:1px solid var(--border);border-radius:8px;overflow:hidden}
.source-card-head{padding:14px 18px}
.source-card-body{display:grid;grid-template-columns:repeat(3,1fr);gap:0;padding:0}
.source-metric{padding:14px 18px;border-right:1px solid var(--border);border-top:1px solid var(--border)}
.source-metric:nth-child(3),.source-metric:nth-child(6){border-right:0}
.source-metric:nth-child(4),.source-metric:nth-child(5),.source-metric:nth-child(6){border-top:1px solid var(--border)}
.source-metric .k{font-size:10.5px;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;display:flex;align-items:center;gap:6px}
.source-metric .v{font-size:19px;font-weight:600;color:var(--text);letter-spacing:-.015em;line-height:1.1;font-feature-settings:"tnum"}
.source-metric.win{background:linear-gradient(180deg,#16a34a08 0%,transparent 100%)}
.win-tag{font-family:"JetBrains Mono",monospace;font-size:8.5px;color:#16a34a;background:#16a34a15;padding:1px 5px;border-radius:3px;text-transform:none;letter-spacing:0;font-weight:600;border:1px solid #16a34a30}
.source-verdict{padding:12px 16px;background:var(--bg-2);border:1px solid var(--border);border-radius:6px;font-size:12.5px;line-height:1.5;color:var(--text-2)}
.kpi-card{background:var(--bg-2);border:1px solid var(--border);border-radius:10px;padding:16px 18px;position:relative;transition:border-color .12s}
.kpi-card:hover{border-color:var(--border-strong)}
.kpi-card .lbl{font-size:10.5px;color:var(--muted);font-weight:600;display:flex;align-items:center;gap:6px;margin-bottom:10px;text-transform:uppercase;letter-spacing:.06em}
.kpi-card .val{font-size:24px;font-weight:600;letter-spacing:-.025em;line-height:1.1}
.kpi-card .val .cur{color:var(--muted);font-weight:500;font-size:16px;margin-right:1px;vertical-align:.06em}
.kpi-card .val .unit{font-size:14px;color:var(--muted);font-weight:500;margin-left:1px}
.kpi-card .sub{margin-top:8px;font-size:11.5px;color:var(--muted);display:flex;align-items:center;gap:6px}
.kpi-card .val.good{color:var(--good)}
.kpi-card .val.bad{color:var(--bad)}
.delta-up{color:var(--good);font-family:"JetBrains Mono",monospace;font-weight:600;font-size:11px;letter-spacing:-.01em}
.delta-down{color:var(--bad);font-family:"JetBrains Mono",monospace;font-weight:600;font-size:11px;letter-spacing:-.01em}
.delta-flat{color:var(--muted);font-family:"JetBrains Mono",monospace;font-weight:600;font-size:11px;letter-spacing:-.01em}

.section{margin-bottom:32px}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap;margin-bottom:14px}
.section-head h2{font-size:18px;font-weight:600;letter-spacing:-.02em;margin:0}
.section-head .desc{font-size:12.5px;color:var(--muted);max-width:52ch;line-height:1.5}
.card{background:var(--bg-2);border:1px solid var(--border);border-radius:10px;padding:20px 22px}
.card.no-pad{padding:0}
.card h3{font-size:14.5px;font-weight:600;letter-spacing:-.01em;margin:0 0 4px}
.card .card-desc{font-size:12.5px;color:var(--muted);margin-bottom:16px;line-height:1.5}
.grid-2{display:grid;grid-template-columns:1.4fr 1fr;gap:16px}
.grid-2-eq{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width:1000px){.grid-2,.grid-2-eq{grid-template-columns:1fr}}

.insight-list{display:flex;flex-direction:column;gap:0}
.insight{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--border);align-items:flex-start}
.insight:last-child{border-bottom:0;padding-bottom:0}
.insight:first-child{padding-top:0}
.insight-marker{flex-shrink:0;width:24px;height:24px;border-radius:6px;display:grid;place-items:center;font-size:11px;font-weight:600;font-family:"JetBrains Mono",monospace}
.insight-marker.crit{background:var(--bad-soft);color:var(--bad)}
.insight-marker.warn{background:var(--warn-soft);color:var(--warn)}
.insight-marker.good{background:var(--good-soft);color:var(--good)}
.insight-marker.info{background:var(--info-soft);color:var(--info)}
.insight-body{flex:1;min-width:0}
.insight-title{font-size:13.5px;font-weight:600;letter-spacing:-.005em;margin-bottom:2px;line-height:1.4}
.insight-detail{font-size:12.5px;color:var(--muted);line-height:1.55}
.insight-detail b{color:var(--text);font-weight:600}

.table-wrap{overflow-x:auto;margin:0 -2px}
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{text-align:left;font-size:10.5px;color:var(--muted);font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:10px 12px 10px 0;border-bottom:1px solid var(--border);white-space:nowrap;user-select:none;background:var(--bg-2)}
thead th.sortable{cursor:pointer;transition:color .1s}
thead th.sortable:hover{color:var(--text)}
thead th.sortable::after{content:" ↕";opacity:.3;font-size:9px}
thead th.sortable.asc::after{content:" ↑";opacity:1;color:var(--accent)}
thead th.sortable.desc::after{content:" ↓";opacity:1;color:var(--accent)}
thead th.num,tbody td.num{text-align:right;font-family:"JetBrains Mono",monospace;font-size:12.5px;padding-right:0}
tbody td{padding:12px 12px 12px 0;border-bottom:1px solid var(--border);vertical-align:top}
tbody tr:last-child td{border-bottom:0}
tbody tr.tr-clickable{cursor:pointer;transition:background .08s}
tbody tr.tr-clickable:hover{background:var(--bg-3)}

.name-cell{font-weight:500;font-size:13.5px;line-height:1.35;max-width:340px;letter-spacing:-.005em}
.name-cell .sub{display:block;font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--muted);font-weight:400;margin-top:3px;letter-spacing:.02em}
.id-chip{display:inline-block;font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--muted);background:var(--bg-3);padding:1px 6px;border-radius:4px;border:1px solid var(--border);margin-left:6px;font-weight:500;letter-spacing:.02em;cursor:pointer;transition:all .1s;vertical-align:1px;user-select:all}
.id-chip:hover{background:var(--text);color:#fff;border-color:var(--text)}
.handle-link{color:var(--info);text-decoration:none;font-family:"JetBrains Mono",monospace;font-size:10.5px;font-weight:500;letter-spacing:.01em}
.handle-link:hover{color:var(--text);text-decoration:underline}
.btn-copy-all{display:inline-flex;align-items:center;gap:0;font-family:inherit;font-size:11.5px;font-weight:500;color:var(--text);background:#fff;border:1px solid var(--border);border-radius:6px;padding:7px 12px;cursor:pointer;transition:all .15s;letter-spacing:-.005em}
.btn-copy-all:hover{background:var(--text);color:#fff;border-color:var(--text)}
.btn-copy-all.copied{background:var(--good);color:#fff;border-color:var(--good)}
.copy-all-wrap{display:flex;justify-content:flex-end;padding:10px 16px;border-top:1px solid var(--border);background:var(--bg-2)}
.name-link{color:var(--text);text-decoration:none;font-weight:500;border-bottom:1px solid var(--border)}
.name-link:hover{color:var(--accent);border-bottom-color:var(--accent)}
.dest-link{color:var(--info);text-decoration:none;font-family:"JetBrains Mono",monospace;font-size:10px}
.dest-link:hover{text-decoration:underline}

.pill{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;font-weight:500;padding:3px 8px;border-radius:99px;line-height:1;white-space:nowrap;letter-spacing:.01em}
.pill .dot{width:5px;height:5px;border-radius:50%;background:currentColor}
.pill-running{background:var(--good-soft);color:var(--good)}
.pill-learning{background:var(--warn-soft);color:var(--warn)}
.pill-paused{background:var(--bg-3);color:var(--muted)}
.pill-archived{background:var(--bad-soft);color:var(--bad)}

.action-pill{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;font-weight:600;padding:4px 9px;border-radius:6px;line-height:1;white-space:nowrap;letter-spacing:.01em}
.action-scale{background:var(--good);color:#fff}
.action-hold{background:var(--bg-3);color:var(--text-2);border:1px solid var(--border-strong)}
.action-down{background:var(--warn-soft);color:var(--warn);border:1px solid var(--warn)}
.action-kill{background:var(--bad);color:#fff}
.action-test{background:var(--info-soft);color:var(--info);border:1px solid var(--info)}
.action-watch{background:var(--bg-3);color:var(--muted);border:1px dashed var(--border-strong)}

.roas{font-family:"JetBrains Mono",monospace;font-weight:600;font-size:13px}
.roas-good{color:var(--good)}
.roas-mid{color:var(--text)}
.roas-warn{color:var(--warn)}
.roas-bad{color:var(--bad)}

.spark{position:relative;height:5px;background:var(--bg-3);border-radius:99px;overflow:hidden;width:100%;margin-top:3px}
.spark > div{position:absolute;left:0;top:0;bottom:0;background:var(--text);border-radius:99px}
.spark > div.bad{background:var(--bad)}
.spark > div.good{background:var(--good)}
.spark > div.warn{background:var(--warn)}

.filterbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.search-input{flex:1;min-width:220px;border:0;background:transparent;padding:6px 0;font-size:14px;border-bottom:1px solid var(--border);color:var(--text);outline:none}
.search-input:focus{border-bottom-color:var(--text)}
.search-input::placeholder{color:var(--muted)}
.chip{font-size:11.5px;font-weight:500;padding:5px 11px;border:1px solid var(--border);border-radius:99px;background:var(--bg-2);color:var(--text-2);cursor:pointer;transition:all .1s;letter-spacing:-.005em}
.chip:hover{border-color:var(--text);color:var(--text)}
.chip.on{background:var(--text);color:#fff;border-color:var(--text)}
.chip .ct{font-family:"JetBrains Mono",monospace;font-size:10px;opacity:.65;margin-left:4px}

.split-row{display:grid;grid-template-columns:1fr auto auto auto auto;gap:14px;align-items:center;padding:10px 0;border-bottom:1px solid var(--border)}
.split-row:last-child{border-bottom:0}
.split-row:first-child{padding-top:0}
.split-row .lbl{font-weight:600;font-size:14px;letter-spacing:-.005em}
.split-row .lbl .meta{display:block;font-size:11px;color:var(--muted);font-weight:400;margin-top:2px;font-family:"JetBrains Mono",monospace}
.split-row .v{font-family:"JetBrains Mono",monospace;font-size:12.5px;text-align:right;min-width:64px}
.split-row .v .k{display:block;font-size:9px;color:var(--muted);font-weight:500;letter-spacing:.06em;text-transform:uppercase;margin-bottom:2px;font-family:"Inter",sans-serif}

.funnel-bar{margin-bottom:14px}
.funnel-bar:last-child{margin-bottom:0}
.funnel-bar .head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.funnel-bar .head .name{font-size:13.5px;font-weight:500}
.funnel-bar .head .val{font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--text-2)}
.funnel-bar .head .val .rate{color:var(--muted);margin-left:8px;font-size:11px}
.funnel-bar .bar{height:10px;background:var(--bg-3);border-radius:4px;overflow:hidden}
.funnel-bar .bar > div{height:100%;background:var(--text);border-radius:4px;transition:width .6s ease}

.type-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}
.type-card{background:var(--bg-2);border:1px solid var(--border);border-radius:10px;padding:16px;transition:all .12s}
.type-card:hover{border-color:var(--border-strong)}
.type-card .name{font-size:13px;font-weight:600;letter-spacing:-.005em;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between}
.type-card .name .ct{font-family:"JetBrains Mono",monospace;font-size:10.5px;color:var(--muted);font-weight:500;background:var(--bg-3);padding:2px 7px;border-radius:99px}
.type-card .roas-big{font-size:24px;font-weight:600;letter-spacing:-.02em;font-family:"JetBrains Mono",monospace;line-height:1}
.type-card .stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px;font-size:11.5px}
.type-card .stats div .k{display:block;color:var(--muted);font-size:10px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:1px}
.type-card .stats div .v{font-family:"JetBrains Mono",monospace;font-weight:500;color:var(--text)}

.empty-state{text-align:center;padding:60px 24px;background:var(--bg-2);border:1px dashed var(--border-strong);border-radius:12px}
.empty-state .icon{width:48px;height:48px;border-radius:12px;background:var(--bg-3);margin:0 auto 16px;display:grid;place-items:center;color:var(--muted)}
.empty-state h3{margin:0 0 6px;font-size:16px;font-weight:600;letter-spacing:-.015em}
.empty-state p{font-size:13.5px;color:var(--muted);max-width:380px;margin:0 auto 18px;line-height:1.55}

.alert{display:flex;gap:14px;padding:14px 16px;border-radius:10px;margin-bottom:8px;border:1px solid;align-items:flex-start}
.alert:last-child{margin-bottom:0}
.alert.crit{background:var(--bad-soft);border-color:#f8b6b6}
.alert.warn{background:var(--warn-soft);border-color:#fbcca6}
.alert.good{background:var(--good-soft);border-color:#b8e3c5}
.alert.info{background:var(--info-soft);border-color:#b3cbf5}
.alert-marker{flex-shrink:0;font-size:10.5px;font-weight:700;font-family:"JetBrains Mono",monospace;padding:3px 8px;border-radius:4px;letter-spacing:.04em;line-height:1.4}
.alert.crit .alert-marker{background:var(--bad);color:#fff}
.alert.warn .alert-marker{background:var(--warn);color:#fff}
.alert.good .alert-marker{background:var(--good);color:#fff}
.alert.info .alert-marker{background:var(--info);color:#fff}
.alert-body{flex:1;min-width:0}
.alert-title{font-size:13.5px;font-weight:600;margin-bottom:3px;letter-spacing:-.005em}
.alert-detail{font-size:12.5px;color:var(--text-2);line-height:1.5}
.alert-detail b{font-weight:600}

.tab-panel{display:none}
.tab-panel.active{display:block;animation:fadeIn .25s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

.foot{margin-top:48px;padding-top:18px;border-top:1px solid var(--border);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:11px;color:var(--muted);font-family:"JetBrains Mono",monospace;letter-spacing:.02em}
.foot a,.foot button{color:var(--muted);text-decoration:underline;background:none;border:0;padding:0;cursor:pointer;font-family:inherit}

.reco-card{background:linear-gradient(180deg,#0a0a0b 0%,#1c1c1f 100%);color:#fff;border-radius:10px;padding:22px 24px;margin-bottom:16px;position:relative;overflow:hidden}
.reco-card .rc-label{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#a1a1aa;margin-bottom:8px}
.reco-card .rc-title{font-size:18px;font-weight:600;letter-spacing:-.015em;line-height:1.4;margin-bottom:10px}
.reco-card .rc-detail{font-size:13px;color:#d4d4d8;line-height:1.55;max-width:80ch}
.reco-card .rc-detail b{color:#fff;font-weight:600}
.reco-card .rc-meta{display:flex;gap:18px;margin-top:14px;padding-top:14px;border-top:1px solid #27272a;font-family:"JetBrains Mono",monospace;font-size:11.5px;color:#a1a1aa;flex-wrap:wrap}
.reco-card .rc-meta b{color:#fff;font-weight:600}

input[type=range]{-webkit-appearance:none;appearance:none;background:transparent}
input[type=range]::-webkit-slider-runnable-track{height:4px;background:var(--border-strong);border-radius:99px}
input[type=range]::-moz-range-track{height:4px;background:var(--border-strong);border-radius:99px}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;background:var(--text);border-radius:50%;margin-top:-5px;cursor:pointer}
input[type=range]::-moz-range-thumb{width:14px;height:14px;background:var(--text);border-radius:50%;cursor:pointer;border:0}

.scale-list{display:flex;flex-direction:column;gap:6px}
.scale-row{display:grid;grid-template-columns:1fr auto auto auto;gap:14px;align-items:center;padding:12px 16px;background:var(--bg-2);border:1px solid var(--border);border-radius:8px}
.scale-row .nm{font-size:13.5px;font-weight:500;letter-spacing:-.005em;min-width:0}
.scale-row .nm .meta{font-size:11px;color:var(--muted);font-family:"JetBrains Mono",monospace;margin-top:2px;display:block}
.scale-row .nums{font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--text-2);text-align:right;min-width:70px}
.scale-row .nums .k{display:block;font-size:9px;color:var(--muted);font-weight:600;letter-spacing:.06em;text-transform:uppercase;margin-bottom:1px;font-family:"Inter",sans-serif}

svg{flex-shrink:0}

/* ===== SESSION RESTORE BANNER ===== */
.session-restore{display:flex;align-items:center;justify-content:space-between;gap:16px;background:color-mix(in srgb,var(--accent) 8%,var(--bg-2));border:1px solid color-mix(in srgb,var(--accent) 30%,var(--border));border-radius:10px;padding:14px 18px;margin-top:12px}
.session-info{display:flex;align-items:center;gap:12px;min-width:0}
.session-info svg{flex-shrink:0;color:var(--accent)}
.session-label{font-size:13px;font-weight:600;color:var(--text);letter-spacing:-.01em}
.session-meta{font-size:12px;color:var(--muted);font-family:"JetBrains Mono",monospace;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.sb-upload{font-size:10px;color:var(--muted);opacity:.7;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
