:root{
  --bg:#eef1f6; --surface:#ffffff; --surface-2:#f7f9fc; --ink:#16202c; --muted:#647285;
  --line:#e3e9f0; --line-strong:#d3dce6; --brand:#2f6db0; --brand-deep:#234b78;
  --good:#0f8a55; --bad:#d24a40; --warn:#c98a1a;
  --shadow:0 1px 2px rgba(20,40,70,.05),0 8px 24px rgba(20,40,70,.06);
  --shadow-sm:0 1px 2px rgba(20,40,70,.06);
  --radius:16px; --radius-sm:10px; --gap:18px;
  --font:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--bg);color:var(--ink);font-family:var(--font);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
h1,h2,h3{margin:0;font-weight:700;letter-spacing:-.01em}
small{color:var(--muted)}
button{font-family:inherit;cursor:pointer}

/* ---------- layout ---------- */
.layout{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.sidebar{position:sticky;top:0;height:100vh;background:linear-gradient(180deg,#1c2c3e,#16222f);color:#cdd9e6;display:flex;flex-direction:column;padding:22px 16px;gap:8px}
.brand{display:flex;gap:12px;align-items:center;padding:6px 8px 18px}
.brand-mark{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,#3f8fd6,#2f6db0);display:grid;place-items:center;font-weight:800;font-size:20px;color:#fff}
.brand b{display:block;font-size:15px;color:#fff}
.brand small{color:#8fa3ba;font-size:11px}
.nav{display:flex;flex-direction:column;gap:3px;margin-top:6px}
.nav-link{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;color:#aebccd;font-weight:600;transition:.15s}
.nav-link i{font-style:normal;width:20px;text-align:center;font-size:15px;opacity:.85}
.nav-link:hover{background:rgba(255,255,255,.06);color:#fff}
.nav-link.on{background:linear-gradient(135deg,#2f6db0,#2a5e98);color:#fff;box-shadow:0 6px 16px rgba(20,50,90,.35)}
.sidebar-foot{margin-top:auto;display:flex;gap:8px;padding-top:12px;border-top:1px solid rgba(255,255,255,.08)}
.sidebar-foot .ghost{flex:1;text-align:center;padding:8px;border-radius:8px;background:rgba(255,255,255,.05);color:#aebccd;font-size:12px;font-weight:600}
.sidebar-foot .ghost:hover{background:rgba(255,255,255,.12);color:#fff}

.main{min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;padding:26px 30px 14px}
.topbar h1{font-size:23px}
.topbar-title p{margin:3px 0 0;color:var(--muted);font-size:13px}
.period-chip{display:flex;flex-direction:column;align-items:flex-end;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:8px 14px;box-shadow:var(--shadow-sm)}
.period-chip span{font-size:12px;color:var(--muted)}
.period-chip b{font-size:14px}

/* ---------- filterbar ---------- */
.filterbar{position:sticky;top:0;z-index:20;background:rgba(238,241,246,.92);backdrop-filter:blur(10px);padding:10px 30px 14px;border-bottom:1px solid var(--line)}
.filter-presets{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.chip{border:1px solid var(--line-strong);background:var(--surface);color:var(--muted);border-radius:999px;padding:6px 13px;font-size:12.5px;font-weight:600;transition:.12s}
.chip:hover{border-color:var(--brand);color:var(--brand)}
.chip.on{background:var(--brand);border-color:var(--brand);color:#fff;box-shadow:0 4px 12px rgba(47,109,176,.3)}
.filter-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.filter-dates,.filter-sites{display:flex;gap:8px;flex-wrap:wrap}
.filterbar label{font-size:11px;color:var(--muted);font-weight:600;display:flex;flex-direction:column;gap:3px}
.filterbar input[type=date],.filterbar select{border:1px solid var(--line-strong);background:var(--surface);border-radius:9px;padding:7px 9px;font-size:13px;color:var(--ink);font-weight:600}
.site-toggle{flex-direction:row!important;align-items:center;gap:7px;background:var(--surface);border:1px solid var(--line-strong);border-radius:999px;padding:6px 12px 6px 10px;cursor:pointer;font-size:12.5px;color:var(--muted)}
.site-toggle span{font-weight:600}
.site-toggle input{accent-color:var(--c);width:14px;height:14px}
.site-toggle:has(input:checked){border-color:var(--c);color:var(--ink);box-shadow:inset 0 0 0 1px var(--c)}
.ghost.reset{align-self:flex-end;padding:8px 14px;border:1px solid var(--line-strong);border-radius:9px;color:var(--muted);font-weight:600;font-size:12.5px;background:var(--surface)}

/* ---------- content ---------- */
.content{padding:22px 30px 60px;display:flex;flex-direction:column;gap:var(--gap)}
.section-title{display:flex;justify-content:space-between;align-items:baseline;margin:6px 2px 0}
.section-title h2{font-size:16px}
.section-title small{font-size:12.5px}

/* ---------- KPI strip ---------- */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}
.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow-sm)}
.kpi .label{font-size:12px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.03em}
.kpi .value{font-size:26px;font-weight:800;margin:6px 0 2px;letter-spacing:-.02em}
.kpi .sub{font-size:12px;color:var(--muted)}
.kpi.accent{background:linear-gradient(135deg,#2f6db0,#27517f);color:#fff;border:0}
.kpi.accent .label,.kpi.accent .sub{color:#cfe0f2}
.value.good,.good{color:var(--good)} .value.bad,.bad{color:var(--bad)} .value.warn,.warn{color:var(--warn)} .muted{color:var(--muted)}
/* conditional-formatting pills for table cells */
td .pill,b.pill{display:inline-block;padding:1px 8px;border-radius:6px;font-weight:700}
.pill.good{background:#e3f6ec;color:var(--good)} .pill.warn{background:#fdf1dd;color:var(--warn)} .pill.bad{background:#fbe7e5;color:var(--bad)} .pill.muted{background:var(--surface-2);color:var(--muted)}
.kpi.accent .value.good,.kpi.accent .value.bad{color:#fff}

/* ---------- cards grid ---------- */
.grid{display:grid;gap:var(--gap)}
.cols-2{grid-template-columns:repeat(2,1fr)} .cols-3{grid-template-columns:repeat(3,1fr)}
.store-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:var(--gap)}

.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}
.panel-head{display:flex;justify-content:space-between;align-items:flex-start;padding:16px 18px 0}
.panel-head h2{font-size:15px}
.panel-head p{margin:3px 0 0;color:var(--muted);font-size:12.5px}
.panel-body{padding:16px 18px}
.echart{width:100%;height:340px}
.echart.tall{height:420px}
.echart.mini{height:270px}

/* ---------- store card ---------- */
.store-card{background:var(--surface);border:1px solid var(--line);border-top:3px solid var(--c,#2f6db0);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px 18px;display:flex;flex-direction:column;gap:13px}
.store-card .sc-head{display:flex;align-items:center;gap:10px}
.store-card .sc-head h3{font-size:15px}
.store-card .sc-head p{margin:0;color:var(--muted);font-size:12px}
.live-badge{margin-left:auto;display:flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--good)}
.live-badge i{width:8px;height:8px;border-radius:50%;background:var(--good);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(15,138,85,.45)}70%{box-shadow:0 0 0 7px rgba(15,138,85,0)}100%{box-shadow:0 0 0 0 rgba(15,138,85,0)}}
.sc-today{display:grid;grid-template-columns:1fr 1fr;gap:10px;background:var(--surface-2);border-radius:12px;padding:11px 13px}
.sc-today small{font-size:11px;text-transform:uppercase;letter-spacing:.03em;font-weight:600}
.sc-today strong{font-size:19px;font-weight:800;display:block;margin-top:2px}
.sc-funnel{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;text-align:center}
.sc-funnel div{background:var(--surface-2);border-radius:9px;padding:8px 4px}
.sc-funnel small{display:block;font-size:10px;color:var(--muted);font-weight:600}
.sc-funnel strong{font-size:15px}
.sc-period-head{display:flex;justify-content:space-between;align-items:baseline;border-top:1px solid var(--line);padding-top:11px;margin-top:2px}
.sc-period-head span{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--muted)}
.sc-period-head small{font-size:11px;color:var(--muted)}
.sc-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.sc-metrics .tile{background:var(--surface-2);border-radius:10px;padding:8px 10px;display:flex;flex-direction:column;gap:2px}
.sc-metrics .tile small{font-size:10px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sc-metrics .tile b{font-size:14px;font-weight:800}
.sc-metrics .tile.strong{background:linear-gradient(135deg,#eef4fb,#e7eefb)}
.sc-metrics .tile.strong b{font-size:16px}
.ad-split{display:flex;justify-content:space-between;gap:10px;background:linear-gradient(135deg,#f4f8fd,#eef4fb);border:1px solid var(--line);border-radius:11px;padding:9px 12px;font-size:12.5px}
.ad-split b{display:block;font-size:15px;font-weight:800}

/* ---------- tables ---------- */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{position:sticky;top:0;background:var(--surface-2);text-align:right;padding:10px 12px;font-size:11px;text-transform:uppercase;letter-spacing:.03em;color:var(--muted);font-weight:700;border-bottom:1px solid var(--line);white-space:nowrap}
thead th:first-child,tbody td:first-child{text-align:left}
tbody td{padding:10px 12px;text-align:right;border-bottom:1px solid var(--line);white-space:nowrap}
tbody tr:hover{background:var(--surface-2)}
tbody td strong{font-weight:700}
tbody td small{display:block;color:var(--muted);font-size:11px;font-weight:500}
td.empty,.empty{text-align:center;color:var(--muted);padding:26px}
.site-chip{display:inline-flex;align-items:center;gap:6px;font-weight:600}
.site-chip::before{content:"";width:9px;height:9px;border-radius:3px;background:var(--c,#2f6db0)}
.badge{display:inline-block;background:var(--surface-2);border:1px solid var(--line-strong);border-radius:7px;padding:2px 8px;font-size:11px;font-weight:600;color:var(--muted)}
/* truncate long campaign/adset/ad IDs so they never blow up a column */
td small.idtag{display:inline-block;max-width:130px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:bottom}
tbody td strong{display:inline-block;max-width:320px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:bottom}
/* sortable + resizable columns */
th.sortable{cursor:pointer;user-select:none;padding-right:20px}
th.sortable:hover{color:var(--brand)}
th[data-sort-dir]::after{position:absolute;right:9px;font-size:9px;opacity:.9}
th[data-sort-dir=asc]::after{content:"\25B2"}
th[data-sort-dir=desc]::after{content:"\25BC"}
.col-resizer{position:absolute;right:0;top:0;height:100%;width:7px;cursor:col-resize;z-index:2}
.col-resizer:hover{background:var(--brand);opacity:.35}
.total-row td{border-top:2px solid var(--line-strong);background:var(--surface-2);font-weight:700}
.total-row td strong{max-width:none}

/* ---------- status pills (real Meta status) ---------- */
.status-pill{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;font-size:11.5px;font-weight:700}
.status-pill::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}
.status-pill.active{background:#e3f6ec;color:#0f8a55}
.status-pill.paused{background:#fdf0db;color:#b9791a}
.status-pill.archived{background:#eef1f5;color:#7c8aa0}
.status-pill.issue{background:#fbe7e5;color:#c93f36}
.status-pill.pending{background:#e7eefb;color:#2f6db0}
.status-pill.spent,.status-pill.inactive,.status-pill.unknown{background:#eef1f5;color:#7c8aa0}

/* ---------- segmented + search ---------- */
.toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:center;padding:14px 18px;border-bottom:1px solid var(--line)}
.segmented{display:inline-flex;background:var(--surface-2);border:1px solid var(--line-strong);border-radius:10px;padding:3px}
.segmented button,.segmented a{border:0;background:transparent;color:var(--muted);font-weight:600;padding:6px 14px;border-radius:8px;font-size:13px;cursor:pointer}
.segmented button.on,.segmented a.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}
.toolbar input[type=search],.toolbar select{border:1px solid var(--line-strong);border-radius:9px;padding:7px 11px;font-size:13px;background:var(--surface)}
.toolbar input[type=search]{min-width:240px}
.toolbar .spacer{margin-left:auto}
.ads-view{display:none} .ads-view.on{display:block}
.toolbar .ghost{border:1px solid var(--line-strong);background:var(--surface);border-radius:9px;padding:7px 12px;font-size:12.5px;font-weight:600;color:var(--muted)}
.toolbar .ghost:hover{border-color:var(--brand);color:var(--brand)}
/* ---------- ads drill-down tree ---------- */
.ads-tree td{vertical-align:middle}
.tree-row.lvl-adset{background:#fbfcfe}
.tree-row.lvl-ad{background:#f7fafc}
.tree-row[data-has-children]{cursor:pointer}
.tree-row[data-has-children]:hover{background:var(--surface-2)}
.tree-name{display:flex;align-items:center;gap:8px}
.tree-name.indent-1{padding-left:26px}
.tree-name.indent-2{padding-left:50px}
.tree-toggle{border:0;background:var(--surface-2);color:var(--muted);width:20px;height:20px;border-radius:6px;font-size:9px;line-height:1;flex:0 0 auto;transition:transform .15s}
.tree-row.open .tree-toggle{transform:rotate(90deg)}
.tree-spacer{width:20px;flex:0 0 auto;display:inline-block}
.tree-name .status-pill{padding:0;background:none!important;min-width:0;gap:0}
.tree-name strong{max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.child-count{font-style:normal;font-size:11px;color:var(--muted);background:var(--surface-2);border-radius:6px;padding:1px 7px}
/* ---------- orders detail ---------- */
.orders-table .order-detail > td{background:var(--surface-2);padding:0}
.od-grid{display:grid;grid-template-columns:1.5fr 1fr 1.1fr;gap:18px;padding:16px 18px}
.od-block h4{font-size:12px;text-transform:uppercase;letter-spacing:.03em;color:var(--muted);margin-bottom:9px;display:flex;align-items:center;gap:8px}
.od-block h4.mt{margin-top:14px}
.od-items{width:100%;font-size:12px}
.od-items th{background:transparent;position:static;padding:4px 6px}
.od-items td{padding:4px 6px}
.od-dl{display:flex;flex-direction:column}
.od-dl > div{display:flex;justify-content:space-between;gap:12px;padding:4px 0;border-bottom:1px solid var(--line);font-size:12.5px}
.od-dl dt{color:var(--muted)} .od-dl dd{margin:0;font-weight:600;text-align:right}
.od-dl.tracking dd.mono{font-family:ui-monospace,Menlo,monospace;font-size:11px;font-weight:500}
.pager{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;margin-top:16px;font-size:13px;color:var(--muted)}
.pager > span:nth-child(2){text-align:center}
.pager a.ghost{border:1px solid var(--line-strong);background:var(--surface);border-radius:9px;padding:8px 14px;font-weight:600;color:var(--brand)}
.pager a.ghost:first-child{justify-self:start}.pager a.ghost:last-child{justify-self:end}
@media(max-width:900px){.od-grid{grid-template-columns:1fr}}

/* ---------- mini bars (category/brand) ---------- */
.bars{display:flex;flex-direction:column;gap:9px}
.bar-row{display:grid;grid-template-columns:140px 1fr auto;gap:12px;align-items:center;font-size:13px}
.bar-row .name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bar-track{height:9px;border-radius:6px;background:var(--surface-2);overflow:hidden}
.bar-fill{height:100%;border-radius:6px;background:var(--c,#2f6db0)}
.bar-row b{font-weight:700;min-width:78px;text-align:right}

/* ---------- syncs / data status ---------- */
.syncs{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:7px}
.syncs li{display:grid;grid-template-columns:1fr auto;gap:2px 10px;padding:9px 11px;border-radius:10px;background:var(--surface-2);border-left:3px solid var(--good)}
.syncs li.fail{border-left-color:var(--bad)}
.syncs li strong{font-size:12.5px}
.syncs li span{font-size:11px;color:var(--muted);text-align:right}
.syncs li small{grid-column:1/-1;color:var(--muted);font-size:11px}

/* ---------- fullscreen view-change loader ---------- */
.page-loader{position:fixed;inset:0;z-index:1000;display:grid;place-items:center;background:rgba(22,34,47,.55);backdrop-filter:blur(6px);animation:plfade .15s ease}
@keyframes plfade{from{opacity:0}to{opacity:1}}
.pl-card{width:min(420px,86vw);background:var(--surface);border-radius:18px;padding:30px 28px;box-shadow:0 30px 80px rgba(0,0,0,.35);text-align:center}
.pl-spinner{width:42px;height:42px;margin:0 auto 16px;border-radius:50%;border:4px solid var(--line);border-top-color:var(--brand);animation:plspin .8s linear infinite}
@keyframes plspin{to{transform:rotate(360deg)}}
.pl-title{display:block;font-size:17px;font-weight:800;margin-bottom:16px}
.pl-bar{height:9px;border-radius:6px;background:var(--surface-2);overflow:hidden;margin-bottom:10px}
.pl-bar i{display:block;height:100%;width:6%;border-radius:6px;background:linear-gradient(90deg,#3f8fd6,#2f6db0);transition:width .12s linear}
.pl-foot{display:flex;justify-content:space-between;gap:12px;font-size:12.5px;color:var(--muted)}
.pl-foot .pl-pct{font-weight:800;color:var(--ink)}
.pl-detail{text-align:right}

.insight-cols{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.insight-cols h4{font-size:12px;text-transform:uppercase;letter-spacing:.03em;margin-bottom:8px}
.insight-row{display:grid;grid-template-columns:1fr auto auto;gap:9px;align-items:center;padding:7px 0;border-bottom:1px solid var(--line);font-size:13px}
.insight-row .name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600}
.insight-row b{font-weight:700;min-width:72px;text-align:right}
.insight-row small{font-size:11px}
@media(max-width:640px){.insight-cols{grid-template-columns:1fr}}

.note{background:#fff8ea;border:1px solid #f0dcae;color:#8a6516;border-radius:11px;padding:11px 14px;font-size:13px}
.margins{list-style:none;margin:0;padding:0}
.margins li{display:flex;justify-content:space-between;padding:9px 2px;border-bottom:1px solid var(--line)}
/* ---------- settings: margin editor ---------- */
.toasts{display:flex;flex-direction:column;gap:8px}
.toast{padding:10px 14px;border-radius:10px;font-size:13px;font-weight:600}
.toast.success{background:#e3f6ec;color:var(--good)} .toast.error{background:#fbe7e5;color:var(--bad)}
.margin-editor{display:flex;flex-direction:column;gap:7px}
.margin-row{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:center}
.margin-row .mname{font-weight:600;font-size:13px}
.mrate{display:flex;align-items:center;gap:4px;color:var(--muted);font-size:12px}
.mrate input{width:72px;border:1px solid var(--line-strong);border-radius:8px;padding:6px 8px;font-size:13px;text-align:right}
.mini-btn{border:1px solid var(--line-strong);background:var(--surface);border-radius:8px;padding:6px 11px;font-size:12px;font-weight:600;color:var(--brand);cursor:pointer}
.mini-btn:hover{background:var(--surface-2)}
.mini-btn.danger{color:var(--bad);border-color:#f2cfcb;padding:3px 10px;font-size:15px;line-height:1}
.override-form{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.override-form label{display:flex;flex-direction:column;gap:4px;font-size:11px;font-weight:600;color:var(--muted)}
.override-form select,.override-form input{border:1px solid var(--line-strong);border-radius:8px;padding:8px;font-size:13px}
.override-form button{grid-column:1/-1;background:var(--brand);color:#fff;border:0;border-radius:9px;padding:10px;font-weight:700;cursor:pointer}
.hint{font-size:11.5px;color:var(--muted);margin-top:10px}

/* ---------- login ---------- */
.login-wrap{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#1c2c3e,#16222f)}
.login-card{background:var(--surface);border-radius:18px;padding:34px;width:340px;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.login-card h1{font-size:20px;margin-bottom:4px}
.login-card p{color:var(--muted);margin:0 0 20px}
.login-card label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:14px}
.login-card input{width:100%;padding:10px 12px;border:1px solid var(--line-strong);border-radius:10px;margin-top:5px;font-size:14px}
.login-card button{width:100%;padding:11px;border:0;border-radius:10px;background:var(--brand);color:#fff;font-weight:700;font-size:14px;margin-top:6px}
.msg{background:#fbe7e5;color:#c93f36;border-radius:9px;padding:9px 12px;font-size:13px;margin-bottom:14px}

/* ---------- responsive ---------- */
@media(max-width:1080px){
  .layout{grid-template-columns:1fr}
  .sidebar{position:fixed;left:-260px;transition:.2s;z-index:100}
  .cols-2,.cols-3{grid-template-columns:1fr}
}
@media(max-width:680px){
  .topbar,.filterbar,.content{padding-left:16px;padding-right:16px}
  .store-grid{grid-template-columns:1fr}
}

/* ---------- Meta vs Google spend split ---------- */
.platform-split .panel-head{align-items:center}
.split-grandtotal{font-size:22px;font-weight:800;color:var(--ink);letter-spacing:-.01em}
.split-legend{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:12px}
.split-chip{display:flex;align-items:center;gap:8px;background:var(--surface-2);border:1px solid var(--line);border-radius:999px;padding:7px 14px;font-size:13px}
.split-chip .dot{width:11px;height:11px;border-radius:50%;background:var(--c);flex:none}
.split-chip b{color:var(--ink);font-weight:700}
.split-chip .amt{font-weight:800;color:var(--ink)}
.split-chip .pct{color:var(--muted);font-weight:600;font-variant-numeric:tabular-nums}
.split-bar{display:flex;width:100%;height:12px;border-radius:999px;overflow:hidden;background:var(--surface-2);border:1px solid var(--line)}
.split-bar.big{height:30px;border-radius:10px}
.split-bar .seg{display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:800;min-width:2px;white-space:nowrap;overflow:hidden;transition:width .3s ease}
.split-bar .seg+.seg{box-shadow:inset 1px 0 0 rgba(255,255,255,.6)}
.split-bar.big .seg{font-size:13px;letter-spacing:.01em}
td.split-meta,th.split-meta{color:var(--ink)}
td.split-meta small,td.split-google small{display:block;color:var(--muted);font-weight:600;font-size:11px;font-variant-numeric:tabular-nums}
td.split-meta,td.split-google{font-weight:700;font-variant-numeric:tabular-nums}
.table-wrap td .split-bar{min-width:90px}
.hero-kpis{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);margin-bottom:var(--gap)}
.kpi.hero{padding:20px 22px}
.kpi.hero .label small{font-weight:600;text-transform:none;letter-spacing:0;color:var(--muted);margin-left:6px}
.kpi.hero .value{font-size:30px;margin:2px 0}
.kpi-details{margin-top:14px;padding-top:12px;border-top:1px dashed var(--line-strong);display:grid;grid-template-columns:1fr 1fr;gap:6px 22px}
.kpi-details>div{display:flex;justify-content:space-between;align-items:baseline;gap:10px;font-size:12.5px;border-bottom:1px solid var(--line);padding-bottom:5px}
.kpi-details span{color:var(--muted);font-weight:600}
.kpi-details span em{font-style:normal;color:var(--muted);opacity:.8;font-weight:600}
.kpi-details b{color:var(--ink);font-weight:700;font-variant-numeric:tabular-nums;white-space:nowrap}
.kpi-details b.neg{color:var(--bad)}
.kpi-details b.pill{padding:1px 8px}
/* readable on the blue accent card */
.kpi.accent .kpi-details{border-top-color:rgba(255,255,255,.3)}
.kpi.accent .kpi-details>div{border-bottom-color:rgba(255,255,255,.16)}
.kpi.accent .kpi-details span{color:#dbe8f6}
.kpi.accent .kpi-details span em{color:#dbe8f6;opacity:.75}
.kpi.accent .kpi-details b{color:#fff}
.kpi.accent .kpi-details b.neg{color:#ffd4cf}
@media(max-width:900px){.hero-kpis{grid-template-columns:1fr}.kpi-details{grid-template-columns:1fr}}
.split-bar.kpi-bar{height:8px;margin-top:12px}
.kpi-legend{display:flex;flex-direction:column;gap:3px;margin-top:8px}
.kpi-legend span{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--muted);font-weight:600}
.kpi-legend i{width:8px;height:8px;border-radius:50%;background:var(--c);flex:none}
.split-table .col-bar{width:34%}
.split-table td.col-bar .split-bar{height:20px;border-radius:7px;min-width:140px}
.split-table td.col-bar .seg{font-size:11px}

/* ---------- excluded orders ---------- */
.excl-form{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}
.excl-form label{display:flex;flex-direction:column;gap:4px;font-size:11px;color:var(--muted);font-weight:600}
.excl-form input,.excl-form select{border:1px solid var(--line-strong);background:var(--surface);border-radius:9px;padding:8px 10px;font-size:13px;color:var(--ink);font-weight:600;min-width:150px}
.btn{background:var(--brand);color:#fff;border:0;border-radius:9px;padding:9px 16px;font-weight:700;font-size:13px;cursor:pointer}
.btn:hover{background:var(--brand-deep)}
.ghost.tiny{padding:4px 9px;font-size:11.5px;border:1px solid var(--line-strong);border-radius:7px;color:var(--muted);background:var(--surface);cursor:pointer}
.ghost.tiny:hover{color:var(--bad);border-color:var(--bad)}

/* ---------- Meta vs Google performance compare ---------- */
.perf-table{width:100%;border-collapse:collapse}
.perf-table th,.perf-table td{padding:11px 14px;text-align:right;border-bottom:1px solid var(--line)}
.perf-table th:first-child,.perf-table td:first-child{text-align:left}
.perf-table thead th{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.03em;border-bottom:2px solid var(--line-strong)}
.perf-table .perf-col{font-size:14px;color:var(--ink);text-transform:none;letter-spacing:0}
.perf-table .perf-col .dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:7px;vertical-align:middle}
.perf-label{color:var(--muted);font-weight:600}
.perf-cell b{font-size:15px;font-weight:800;font-variant-numeric:tabular-nums}
.perf-cell .delta{display:inline-block;margin-left:9px;padding:2px 8px;border-radius:999px;font-size:11.5px;font-weight:700;background:var(--surface-2);color:var(--muted);min-width:52px;text-align:center}
.perf-cell .delta.good{background:#e3f6ec;color:var(--good)}
.perf-cell .delta.bad{background:#fbe7e5;color:var(--bad)}
.perf-table tbody tr:hover{background:var(--surface-2)}

/* ---------- top products / seasonal ---------- */
.lang-tabs{display:flex;gap:8px;margin-bottom:2px}
.lang-tab{padding:8px 16px;border-radius:999px;border:1px solid var(--line-strong);background:var(--surface);color:var(--muted);font-weight:600;font-size:13px}
.lang-tab:hover{border-color:var(--brand);color:var(--brand)}
.lang-tab.on{background:var(--brand);border-color:var(--brand);color:#fff;box-shadow:0 4px 12px rgba(47,109,176,.3)}
.season-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:6px;align-items:end;height:220px}
.season-col{display:flex;flex-direction:column;align-items:center;gap:4px;height:100%}
.season-bar-wrap{flex:1;width:100%;display:flex;align-items:flex-end}
.season-bar{width:100%;background:var(--brand);border-radius:5px 5px 0 0;min-height:2px;transition:height .3s}
.season-bar.hi{background:var(--good)}
.season-bar.lo{background:var(--line-strong)}
.season-idx{font-size:11px;font-weight:800;color:var(--ink);font-variant-numeric:tabular-nums}
.season-m{font-size:11px;color:var(--muted);text-transform:capitalize}

/* ---------- customer journeys ---------- */
.attr-row{margin-bottom:11px}
.attr-top{display:flex;justify-content:space-between;align-items:baseline;font-size:13px;margin-bottom:4px}
.attr-name{color:var(--ink);font-weight:600;display:flex;align-items:center;gap:7px}
.attr-name i{width:9px;height:9px;border-radius:50%;flex:none}
.attr-top b{font-variant-numeric:tabular-nums}
.attr-bar{height:7px;background:var(--surface-2);border-radius:999px;overflow:hidden}
.attr-bar span{display:block;height:100%;border-radius:999px;transition:width .3s}
.journey-list{display:flex;flex-direction:column;gap:10px}
.journey{border:1px solid var(--line);border-radius:12px;padding:12px 14px;background:var(--surface-2)}
.journey-path{display:flex;flex-wrap:wrap;align-items:center;gap:7px;margin-bottom:8px}
.touch{display:inline-flex;align-items:center;padding:4px 11px;border-radius:999px;font-size:12px;font-weight:700;color:#fff;background:var(--c,#64727f)}
.touch.buy{background:var(--good)}
.journey-path .arrow{color:var(--muted);font-weight:700}
.journey-meta{display:flex;align-items:center;gap:12px;font-size:12.5px;color:var(--muted)}
.journey-meta b{color:var(--ink);font-variant-numeric:tabular-nums;margin-left:auto}

/* ---------- internal detection rule chips ---------- */
.rule-chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:14px}
.rule-chip{display:inline-flex;align-items:center;gap:5px;background:var(--surface-2);border:1px solid var(--line-strong);border-radius:999px;padding:4px 6px 4px 12px;font-size:12.5px;font-weight:600;color:var(--ink)}
.rule-chip.kw{background:#f2edf9;border-color:#d9c9ee;color:#5d3a8a}
.rule-chip .chip-x{border:0;background:transparent;color:var(--muted);font-size:15px;line-height:1;padding:0 4px;cursor:pointer}
.rule-chip .chip-x:hover{color:var(--bad)}

/* ---------- ads: platform + attribution compare ---------- */
.ptbl td:first-child,.ptbl th:first-child{text-align:left}
.ptbl .dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:7px;vertical-align:middle}
.ptbl .total-row td{border-top:2px solid var(--line-strong);background:var(--surface-2);font-weight:800}
.meta-col{background:rgba(49,95,137,.055)}
th.meta-col{color:#315f89}
.attr-note{margin:12px 2px 0;padding:11px 14px;background:var(--surface-2);border:1px solid var(--line);border-radius:10px;font-size:12.5px;color:var(--muted);line-height:1.55}
.attr-note b{color:var(--ink)}
