/* ── TOKENS (Datylux brand system) ── */
:root{
  /* Light theme (default) */
  --bg:#f4f7fb;--bg-elev:#ffffff;
  --surface:#ffffff;--surface-2:#f8fafc;--surface-3:#eef2f7;
  --border:#e2e8f0;--border-2:#cbd5e1;--border-3:#94a3b8;
  --text:#0f172a;--text-2:#475569;--text-3:#64748b;--text-4:#94a3b8;

  --brand:#2563eb;--brand-2:#0891b2;--brand-3:#38bdf8;
  --brand-soft:rgba(37,99,235,.08);--brand-border:rgba(37,99,235,.28);
  --brand-grad:linear-gradient(135deg,#2563eb 0%,#0891b2 100%);
  --brand-grad-v:linear-gradient(180deg,#2563eb,#0891b2);

  --green:#16a34a;--green-soft:rgba(22,163,74,.08);--green-border:rgba(22,163,74,.28);
  --amber:#d97706;--amber-soft:rgba(217,119,6,.08);--amber-border:rgba(217,119,6,.28);
  --red:#dc2626;--red-soft:rgba(220,38,38,.08);--red-border:rgba(220,38,38,.28);
  --violet:#a78bfa;--pink:#f472b6;--orange:#fb923c;--emerald:#10b981;

  --r:10px;--rs:7px;--r-lg:14px;--r-xl:18px;
  --dur:.18s;--ease:cubic-bezier(.4,0,.2,1);

  /* Legacy aliases — keep existing CSS/JS working unchanged */
  --card:var(--surface);--card2:var(--surface-2);
  --border2:var(--border-2);
  --txt:var(--text);--txt2:var(--text-2);--txt3:var(--text-3);
  --accent:var(--brand);--abg:var(--brand-soft);--aborder:var(--brand-border);
  --gbg:var(--green-soft);--gborder:var(--green-border);
  --ybg:var(--amber-soft);--yborder:var(--amber-border);
  --rbg:var(--red-soft);--rborder:var(--red-border);
}
:root.dark{
  /* Dark theme — deep navy / frost */
  --bg:#061221;--bg-elev:#0a1726;
  --surface:#0b1624;--surface-2:#0f1e30;--surface-3:#132841;
  --border:#1a2d44;--border-2:#243d57;--border-3:#2f4a66;
  --text:#dde8f5;--text-2:#7a9bbf;--text-3:#4d7196;--text-4:#2a4766;

  --brand-soft:rgba(37,99,235,.14);--brand-border:rgba(37,99,235,.38);
  --green:#4ade80;--green-soft:rgba(74,222,128,.12);--green-border:rgba(74,222,128,.32);
  --amber:#fbbf24;--amber-soft:rgba(251,191,36,.12);--amber-border:rgba(251,191,36,.32);
  --red:#f87171;--red-soft:rgba(248,113,113,.12);--red-border:rgba(248,113,113,.32);
}
/* ── RESET ── */
*{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;background:var(--bg);color:var(--txt);font-family:'DM Sans',sans-serif;font-size:14px;}
::-webkit-scrollbar{width:10px;height:10px;}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:999px;border:2px solid var(--bg);}
::-webkit-scrollbar-thumb:hover{background:var(--txt3);}
button,select,input,textarea{font-family:'DM Sans',sans-serif;}
summary::-webkit-details-marker{display:none;}

/* ── TOPBAR ── */

/* ── BAR ROW LAYOUT ── */
/* hidden on desktop, shown on mobile */
/* ── BAR ROWS ── */

/* logo overridden below */
.logo-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);}
.tabs{display:flex;height:100%;overflow-x:auto;scrollbar-width:none;flex:1;margin-left:18px;gap:2px;}
.tabs::-webkit-scrollbar{display:none;}
.tab{padding:7px 14px;margin:auto 0;font-size:13px;font-weight:500;color:var(--txt2);cursor:pointer;
  display:flex;align-items:center;gap:6px;border-radius:8px;
  white-space:nowrap;user-select:none;transition:color var(--dur) var(--ease),background-color .32s var(--ease);}
.tab:hover{color:var(--txt);background:var(--surface-2);}
.tab.on{color:var(--accent);background:var(--abg);}
/* ── LEFT APP PANEL ── */
.app-shell{display:grid;grid-template-columns:248px minmax(0,1fr);align-items:start;flex:1;transition:grid-template-columns var(--dur) var(--ease);}
.bar{background:rgba(255,255,255,.88);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-right:1px solid var(--border);position:sticky;top:0;z-index:100;
  width:248px;height:100vh;display:flex;flex-direction:column;transition:width var(--dur) var(--ease);}
:root.dark .bar{background:rgba(7,14,26,.9);}
.bar-row1{display:flex;flex-direction:column;width:100%;height:100%;padding:16px 14px;gap:12px;flex-shrink:0;}
.bar-row2{display:none;}
.side-head{display:flex;align-items:center;justify-content:space-between;gap:10px;min-height:34px;}
.side-toggle{width:30px;height:30px;padding:0;justify-content:center;flex-shrink:0;}
.side-label{font-size:10px;font-weight:800;color:var(--txt3);text-transform:uppercase;letter-spacing:.1em;padding:8px 8px 0;}
.side-spacer{flex:1;min-height:8px;}
.bar .logo{margin:0;}
.bar .tabs{height:auto;display:grid;gap:4px;margin:0;overflow:visible;flex:0;}
.bar .tab{width:100%;margin:0;padding:10px 12px;justify-content:flex-start;}
.bar-right{display:flex;gap:7px;flex-wrap:wrap;align-items:center;flex-shrink:0;}
.bar-right .fb-btn,.bar-right .guide-btn,.bar-right .ico-btn,.bar-right .btn.ai{
  width:38px;height:38px;justify-content:center;padding:0;border-radius:50%;min-height:38px;font-size:0;}
.bar-right .fb-btn span{display:none;}
.bar-right .guide-btn span{display:inline;font-size:12px;font-weight:700;}
.bar-right .guide-btn{width:auto;min-width:72px;padding:0 14px;border-radius:12px;font-size:12px;}
.bar-right .btn.ai span{display:inline;font-size:11px;}
.bar-right .account-wrap{position:relative;width:auto;}
.bar-right .avatar{width:38px;height:38px;border-radius:50%;justify-content:center;padding:0;gap:0;font-family:'Syne',sans-serif;}
.bar-right .avatar::after{display:none;}
#avatarMenu{max-width:calc(100vw - 24px);box-sizing:border-box;}
.content-wrap{min-width:0;max-width:100%;overflow-x:hidden;}
body.nav-collapsed .app-shell{grid-template-columns:76px minmax(0,1fr);}
body.nav-collapsed .bar{width:76px;}
body.nav-collapsed .logo-txt,body.nav-collapsed .side-label{display:none;}
body.nav-collapsed .side-head{justify-content:center;}
body.nav-collapsed .bar-row1{padding:16px 10px;align-items:center;}
body.nav-collapsed .bar .tab{justify-content:center;width:44px;padding:10px;font-size:0;}
body.nav-collapsed .bar-right .fb-btn,body.nav-collapsed .bar-right .guide-btn,
body.nav-collapsed .bar-right .ico-btn,body.nav-collapsed .bar-right .btn.ai{width:44px;height:44px;min-height:44px;padding:0;font-size:0;}
body.nav-collapsed .bar .tab svg{margin-right:0 !important;}
body.nav-collapsed .bar-right .btn.ai span{display:inline;font-size:11px;}
body.nav-collapsed .bar-right .avatar{width:44px;height:44px;padding:0;justify-content:center;border-radius:50%;}
body.nav-collapsed #avatarMenu{max-width:calc(100vw - 24px);}
body.nav-collapsed .bar-right .guide-btn{width:auto;min-width:58px;height:38px;min-height:38px;padding:0 10px;border-radius:12px;}
body.nav-collapsed .bar-right .guide-btn span{display:inline;font-size:11px;}

/* ── BUTTONS ── */
.btn{padding:6px 12px;border-radius:var(--rs);border:1px solid var(--border);
  background:var(--surface);color:var(--txt2);cursor:pointer;font-size:12.5px;font-weight:500;
  display:flex;align-items:center;gap:6px;transition:all var(--dur) var(--ease);white-space:nowrap;user-select:none;}
.btn:hover{border-color:var(--border-2);color:var(--txt);background:var(--surface-2);}
.btn.on,.btn.active{background:var(--abg);border-color:var(--aborder);color:var(--accent);}
.btn.ai{border-color:var(--aborder);background:var(--abg);color:var(--accent);font-weight:600;}
.btn.ai:hover,.btn.ai.on{background:rgba(37,99,235,.18);color:var(--accent);}
.btn.danger:hover{color:var(--red);border-color:var(--rborder);background:var(--rbg);}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600;}
.btn.primary:hover{background:#1d4ed8;border-color:#1d4ed8;color:#fff;}
.btn.grad{background:var(--brand-grad);border:none;color:#fff;font-weight:600;}
.btn.grad:hover{filter:brightness(1.08);color:#fff;}
.ico-btn{padding:6px 9px;border-radius:var(--rs);border:1px solid var(--border);
  background:transparent;color:var(--txt2);cursor:pointer;font-size:14px;
  display:flex;align-items:center;transition:all var(--dur) var(--ease);}
.ico-btn:hover{border-color:var(--border-2);color:var(--txt);background:var(--surface);}

/* Feedback CTA — distinct amber pill with pulse so users notice it */
.fb-btn{position:relative;display:inline-flex;align-items:center;gap:6px;
  padding:6px 12px;border-radius:var(--rs,7px);
  background:var(--amber-soft);border:1px solid var(--amber-border);
  color:var(--amber);font-size:12px;font-weight:700;text-decoration:none;
  transition:all var(--dur) var(--ease);flex-shrink:0;}
.fb-btn:hover{background:var(--amber);color:#fff;border-color:var(--amber);
  transform:translateY(-1px);box-shadow:0 4px 12px rgba(217,119,6,.25);}
.fb-btn svg{color:inherit;}
.bar-right .fb-btn{align-items:center;justify-content:center;}
.bar-right .fb-btn .fb-dot{display:none;}
.bar-right .fb-btn svg{margin:0;}
.fb-dot{width:7px;height:7px;border-radius:50%;background:var(--amber);
  flex-shrink:0;position:relative;box-shadow:0 0 0 0 rgba(217,119,6,.7);
  animation:fbPulse 2.1s cubic-bezier(.4,0,.6,1) infinite;}
.fb-btn:hover .fb-dot{background:#fff;box-shadow:0 0 0 0 rgba(255,255,255,.6);}
@keyframes fbPulse{
  0%{box-shadow:0 0 0 0 rgba(217,119,6,.55);}
  70%{box-shadow:0 0 0 8px rgba(217,119,6,0);}
  100%{box-shadow:0 0 0 0 rgba(217,119,6,0);}
}
:root.dark .fb-btn{background:var(--amber-soft);border-color:var(--amber-border);color:var(--amber);}
:root.dark .fb-btn:hover{background:var(--amber);color:#040a12;}
@media (prefers-reduced-motion:reduce){ .fb-dot{animation:none;} }
@media (max-width:640px){ .fb-btn{padding:6px 10px;font-size:11.5px;} }
.avatar{width:32px;height:32px;border-radius:50%;background:var(--brand-grad);
  border:none;color:#fff;font-size:11.5px;font-weight:700;
  display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;letter-spacing:-0.01em;}

/* ── SEG CONTROL ── */
.seg{display:inline-flex;background:var(--surface);border:1px solid var(--border);
  border-radius:7px;padding:2px;gap:1px;}
.seg button{padding:5px 11px;border-radius:5px;font-size:12px;font-weight:500;
  border:none;background:transparent;color:var(--txt2);cursor:pointer;transition:all .12s var(--ease);font-family:inherit;}
.seg button:hover{color:var(--txt);}
.seg button.on{background:var(--bg);color:var(--txt);box-shadow:0 1px 2px rgba(0,0,0,.12);}
.seg button:disabled,.seg button.is-disabled{color:var(--txt3);opacity:.42;cursor:not-allowed;background:transparent;box-shadow:none;pointer-events:none;}
.seg button:disabled:hover,.seg button.is-disabled:hover{color:var(--txt3);}
:root:not(.dark) .seg button.on{background:#fff;box-shadow:0 1px 2px rgba(0,0,0,.06);}

/* ── TOOLBAR ── */
.toolbar{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:10px 14px;display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:nowrap;overflow-x:auto;}
.div{width:1px;height:20px;background:var(--border);flex-shrink:0;}
.sp{flex:1;}

/* ── BODY / GRID ── */
.body{padding:18px 20px;width:100%;max-width:1600px;margin:0 auto;overflow-x:hidden;}
.grid2{display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,330px);gap:12px;align-items:start;}
.grid2>*{min-width:0;}
@media(max-width:1100px){.grid2{grid-template-columns:1fr;}}
.rcol{display:flex;flex-direction:column;gap:12px;}
.perf-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:12px;align-items:start;}
.perf-widget{grid-column:span 6;min-width:0;transition:opacity .12s var(--ease),transform .12s var(--ease),box-shadow .12s var(--ease);}
.perf-widget[data-size="narrow"]{grid-column:span 3;}
.perf-widget[data-size="third"]{grid-column:span 4;}
.perf-widget[data-size="half"]{grid-column:span 6;}
.perf-widget[data-size="wide"]{grid-column:span 8;}
.perf-widget[data-size="xl"]{grid-column:span 9;}
.perf-widget[data-size="full"]{grid-column:1 / -1;}
.perf-widget.is-dragging{opacity:.45;transform:scale(.985);}
.perf-widget.is-drop-target>.panel{outline:2px solid var(--accent);outline-offset:3px;}
.perf-widget>.panel{height:100%;margin-bottom:0;}
.perf-widget[data-height="custom"]>.panel{min-height:var(--perf-widget-height,320px);}
.perf-widget[data-height="custom"] .chart-viewport{height:clamp(190px,calc(var(--perf-widget-height,320px) - 120px),560px);}
.perf-widget[data-height="custom"] .twrap{max-height:calc(var(--perf-widget-height,420px) - 94px);}
.perf-widget[data-height="custom"] #annList,.perf-widget[data-height="custom"] #platBreak,.perf-widget[data-height="custom"] #dataSummary{max-height:calc(var(--perf-widget-height,320px) - 86px);overflow-y:auto;}
.perf-kpi-body{padding:12px 14px 14px;}
.perf-kpi-body .kpis{margin-bottom:0;}
.perf-widget-controls{display:none !important;}
.perf-widget-btn{width:26px;height:26px;border:1px solid var(--border);border-radius:var(--rs);background:var(--surface);color:var(--txt2);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0;transition:all .12s var(--ease);}
.perf-widget-btn:hover{color:var(--txt);border-color:var(--border-2);background:var(--surface-2);}
.perf-widget-grip{cursor:grab;}
.perf-widget-grip:active{cursor:grabbing;}
.perf-layout-bar{display:none;align-items:center;justify-content:space-between;gap:10px;margin:-6px 0 14px;padding:10px 12px;border:1px dashed var(--aborder);border-radius:var(--r);background:var(--abg);color:var(--txt2);font-size:12px;}
.perf-layout-bar strong{color:var(--accent);}
.perf-layout-bar.on{display:flex;}
.perf-grid.is-editing .perf-widget>.panel{outline:1.5px dashed var(--aborder);outline-offset:3px;}
.perf-grid.is-editing .perf-widget .phdr{cursor:move;}
.perf-grid.is-editing .perf-widget .phdr button,.perf-grid.is-editing .perf-widget .phdr input,.perf-grid.is-editing .perf-widget .phdr select,.perf-grid.is-editing .perf-widget .phdr .pacts{cursor:auto;}
.perf-widget.is-moving{opacity:.5;transform:scale(.99);pointer-events:none;}
.perf-widget.is-drop-left>.panel{box-shadow:inset 5px 0 0 var(--accent);}
.perf-widget.is-drop-right>.panel{box-shadow:inset -5px 0 0 var(--accent);}
.perf-widget.is-drop-top>.panel{box-shadow:inset 0 5px 0 var(--accent);}
.perf-widget.is-drop-bottom>.panel{box-shadow:inset 0 -5px 0 var(--accent);}
.perf-resize-handle{display:none;position:absolute;z-index:30;background:transparent;}
.perf-grid.is-editing .perf-resize-handle{display:block;}
.perf-resize-handle.e{top:18px;right:-6px;width:12px;bottom:18px;cursor:ew-resize;}
.perf-resize-handle.w{top:18px;left:-6px;width:12px;bottom:18px;cursor:ew-resize;}
.perf-resize-handle.s{left:18px;right:18px;bottom:-6px;height:12px;cursor:ns-resize;}
.perf-resize-handle.n{left:18px;right:18px;top:-6px;height:12px;cursor:ns-resize;}
.perf-resize-handle.se{right:-7px;bottom:-7px;width:16px;height:16px;cursor:nwse-resize;}
.perf-resize-handle.sw{left:-7px;bottom:-7px;width:16px;height:16px;cursor:nesw-resize;}
.perf-resize-handle.ne{right:-7px;top:-7px;width:16px;height:16px;cursor:nesw-resize;}
.perf-resize-handle.nw{left:-7px;top:-7px;width:16px;height:16px;cursor:nwse-resize;}
.perf-grid.is-editing .perf-resize-handle::after{content:"";position:absolute;inset:4px;border-radius:999px;background:var(--accent);opacity:.22;}
.perf-grid.is-editing .perf-resize-handle:hover::after{opacity:.55;}
.perf-widget[data-height="tall"] .chart-viewport{height:340px;}
.perf-widget[data-height="tall"] .twrap{max-height:680px;}
.perf-widget[data-height="tall"] #annList,.perf-widget[data-height="tall"] #platBreak,.perf-widget[data-height="tall"] #dataSummary{max-height:560px;overflow-y:auto;}
@media(max-width:1200px){.perf-widget,.perf-widget[data-size]{grid-column:1 / -1 !important;}}

/* ── KPI CARDS ── */
.kpis{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;margin-bottom:18px;}
@media(max-width:1100px){.kpis{grid-template-columns:repeat(3,1fr);}}
@media(max-width:650px){.kpis{grid-template-columns:repeat(2,1fr);}}
.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:14px 16px;position:relative;overflow:hidden;transition:border-color .15s var(--ease);}
.kpi:hover{border-color:var(--border-2);}
.kpi-bar{position:absolute;top:0;left:0;right:0;height:2px;background:var(--brand-grad);}
.kpi-lbl{font-size:10.5px;font-weight:700;color:var(--txt3);text-transform:uppercase;
  letter-spacing:.09em;margin-bottom:8px;}
.kpi-val{font-family:'DM Mono',ui-monospace,monospace;font-size:24px;font-weight:500;color:var(--txt);
  letter-spacing:-0.02em;font-variant-numeric:tabular-nums;line-height:1.1;}
.kpi-sub{font-size:11px;color:var(--txt3);margin-top:6px;display:flex;align-items:center;gap:6px;}
.badge{display:inline-flex;align-items:center;gap:3px;font-size:10.5px;font-weight:600;
  padding:2px 7px;border-radius:20px;border:1px solid transparent;
  font-family:'DM Mono',ui-monospace,monospace;font-variant-numeric:tabular-nums;}
.badge.up{background:var(--gbg);color:var(--green);border-color:var(--gborder);}
.badge.dn{background:var(--rbg);color:var(--red);border-color:var(--rborder);}
.badge.warn{background:var(--ybg);color:var(--amber);border-color:var(--yborder);}
.badge.neu{background:var(--surface-2);color:var(--txt2);border-color:var(--border);}
.badge.brand{background:var(--abg);color:var(--accent);border-color:var(--aborder);}

/* ── PANEL ── */
.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  overflow:hidden;margin-bottom:12px;min-width:0;max-width:100%;}
.panel:last-child{margin-bottom:0;}
.phdr{padding:14px 18px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap;}
.ptitle{font-size:14px;font-weight:600;color:var(--txt);letter-spacing:-0.01em;}
.psub{font-size:11.5px;color:var(--txt3);margin-top:2px;}
.pacts{display:flex;gap:4px;align-items:center;flex-wrap:wrap;}
.pill{padding:4px 10px;border-radius:18px;font-size:11.5px;font-weight:500;cursor:pointer;
  border:1px solid var(--border);background:transparent;color:var(--txt2);
  transition:all .12s var(--ease);user-select:none;}
.pill:hover{color:var(--txt);border-color:var(--border-2);}
.pill.on{background:var(--abg);border-color:var(--aborder);color:var(--accent);}

/* ── CHART ── */
.cwrap{padding:14px 14px 8px;}
.mchips{display:flex;gap:5px;margin-bottom:12px;flex-wrap:wrap;}
.mchip{padding:4px 11px;border-radius:18px;font-size:11.5px;font-weight:500;cursor:pointer;
  border:1px solid var(--border);background:transparent;color:var(--txt2);transition:all .12s var(--ease);}
.mchip:hover{color:var(--txt);border-color:var(--border-2);}
.mchip.on{background:var(--abg);border-color:var(--aborder);color:var(--accent);}
.chart-controls{gap:6px;align-items:center;}
.chart-controls .mchips{margin:0;align-items:center;}
.chart-controls .mchip,.chart-controls .pill,.chart-controls .ico-btn{height:30px;display:inline-flex;align-items:center;justify-content:center;line-height:1;}
.chart-controls .ico-btn{width:30px;padding:0;}
.chart-viewport{position:relative;width:100%;overflow-x:auto;overflow-y:hidden;height:220px;max-height:none;scrollbar-width:auto;scrollbar-color:var(--border2) transparent;border-radius:var(--rs);}
.chart-viewport.is-zoomed{cursor:grab;}
.chart-viewport.is-dragging{cursor:grabbing;}
.chart-viewport canvas{min-width:100%;max-width:none !important;width:var(--chart-css-width,100%) !important;height:var(--chart-css-height,190px) !important;}
.chart-hover-dot{display:none;position:absolute;z-index:8;width:10px;height:10px;border-radius:50%;background:var(--surface);border:3px solid var(--accent);box-shadow:0 2px 8px rgba(15,23,42,.22);transform:translate(-50%,-50%);pointer-events:none;}
.chart-hover-rule{display:none;position:absolute;z-index:7;width:1px;background:rgba(15,23,42,.22);pointer-events:none;}
:root.dark .chart-hover-rule{background:rgba(226,232,240,.32);}
.chart-metric-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 10px;background:var(--card2);border:1px solid var(--border);border-radius:var(--rs);}
.chart-metric-row label{display:flex;align-items:center;gap:9px;font-size:12px;font-weight:600;color:var(--txt);cursor:pointer;}
.chart-metric-row span{font-size:10px;color:var(--txt3);font-family:'DM Mono',monospace;}

/* ── TABLE ── */
.twrap{width:100%;max-width:100%;overflow-x:auto;max-height:400px;overflow-y:auto;-webkit-overflow-scrolling:touch;scrollbar-width:auto;scrollbar-color:var(--border2) transparent;}
.twrap table{min-width:1180px;}
table{width:100%;border-collapse:collapse;font-size:13px;}
thead{position:sticky;top:0;z-index:2;}
th{padding:10px 14px;text-align:left;font-size:10.5px;font-weight:700;color:var(--txt3);
  text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--border);
  background:var(--surface-2);white-space:nowrap;cursor:pointer;user-select:none;transition:color .1s;}
th:hover{color:var(--txt);}
th.s{color:var(--accent);}
td{padding:10px 14px;border-bottom:1px solid var(--border);color:var(--txt);vertical-align:middle;}
tr:last-child td{border-bottom:none;}
tr{transition:background .1s var(--ease);}
tr:hover td{background:var(--surface-2);}
.cname{font-weight:600;font-size:12px;}
.csub{font-size:10px;color:var(--txt2);margin-top:1px;}
.dot{display:inline-block;width:6px;height:6px;border-radius:50%;margin-right:5px;flex-shrink:0;}
.mono{font-family:'DM Mono',monospace;font-size:11px;}
.campaign-kpi-select{
  min-width:118px;
  max-width:150px;
  background:var(--surface-2);
  border:1px solid var(--border);
  border-radius:var(--rs);
  color:var(--txt);
  font-size:11px;
  padding:5px 7px;
  outline:none;
}
.campaign-kpi-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--abg);}
.campaign-kpi-val{font-size:10px;color:var(--txt3);margin-top:4px;}
.pbar{height:4px;background:var(--bg);border-radius:2px;overflow:hidden;width:72px;}
.pbar-f{height:100%;border-radius:2px;}
.ppct{font-size:10px;margin-top:3px;font-family:'DM Mono',monospace;}

/* ── RIGHT PANELS ── */
.plat-row{padding:9px 16px;display:flex;align-items:center;gap:9px;border-bottom:1px solid var(--border);}
.plat-row:last-child{border-bottom:none;}
.plat-name{font-size:12px;font-weight:600;color:var(--txt);width:68px;flex-shrink:0;}
.plat-bar{flex:1;height:4px;background:var(--bg);border-radius:2px;overflow:hidden;}
.plat-bar-f{height:100%;border-radius:2px;}
.plat-spend{font-size:11px;color:var(--txt2);width:44px;text-align:right;font-family:'DM Mono',monospace;flex-shrink:0;}
.plat-pct{font-size:10px;color:var(--txt3);width:30px;text-align:right;font-family:'DM Mono',monospace;flex-shrink:0;}
.ins-row{padding:10px 16px;display:flex;gap:9px;border-bottom:1px solid var(--border);}
.ins-row:last-child{border-bottom:none;}
.ins-ico{width:22px;height:22px;border-radius:6px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:12px;}
.ins-txt{font-size:12px;color:var(--txt2);line-height:1.55;}
.ins-txt strong{color:var(--txt);}
.goal-panel{padding:12px 14px;border-bottom:1px solid var(--border);display:grid;gap:8px;}
.goal-row{display:grid;grid-template-columns:1fr;gap:8px;}
.goal-select,.goal-input{width:100%;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--rs);color:var(--txt);font-size:12px;padding:7px 9px;outline:none;}
.goal-select:focus,.goal-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--abg);}
.rec-list{display:grid;gap:8px;padding:12px 14px;}
.rec-card{border:1px solid var(--border);background:var(--surface-2);border-radius:var(--r);padding:11px 12px;display:grid;gap:7px;}
.rec-card.high{border-color:var(--aborder);background:linear-gradient(180deg,var(--abg),var(--surface-2));}
.rec-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;}
.rec-title{font-size:12px;font-weight:700;color:var(--txt);line-height:1.35;}
.rec-impact{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);background:var(--abg);border:1px solid var(--aborder);border-radius:999px;padding:3px 7px;white-space:nowrap;}
.rec-body{font-size:11.5px;color:var(--txt2);line-height:1.55;}
.rec-meta{display:flex;gap:6px;flex-wrap:wrap;}
.rec-chip{font-size:10.5px;color:var(--txt3);border:1px solid var(--border);border-radius:999px;padding:3px 7px;background:var(--surface);}
.srow{padding:9px 12px;display:flex;align-items:center;justify-content:space-between;
  border-radius:var(--rs);cursor:pointer;margin:3px 6px;transition:background .12s;}
.srow:hover{background:var(--card2);}
.sname{font-size:12px;font-weight:600;color:var(--txt);}
.smeta{font-size:10px;color:var(--txt2);margin-top:2px;}
.saved-load-wrap{position:relative;flex-shrink:0;}
.saved-drop-menu{display:none;position:fixed;background:var(--card);border:1px solid var(--border2);border-radius:var(--r);
  box-shadow:0 12px 32px rgba(15,23,42,.18);z-index:650;min-width:340px;max-width:min(460px,calc(100vw - 24px));
  max-height:390px;overflow-y:auto;padding:6px;}
#avatarMenu,.actions-menu,.export-menu,.date-drop,.saved-drop-menu,#pacSnapsDropMenu,#pacActionsMenu,#planSnapsDropMenu,#planActionsMenu,#colPickDrop,#colFilterDrop,#pacExpMenu,#planExpMenu,#benchMetAddMenu{
  max-width:calc(100vw - 24px);
  box-sizing:border-box;
}
.saved-drop-head{padding:8px 10px 10px;border-bottom:1px solid var(--border);margin-bottom:4px;}
.saved-drop-title{font-size:12px;font-weight:700;color:var(--txt);}
.saved-drop-sub{font-size:11px;color:var(--txt3);margin-top:2px;}
.saved-drop-empty{padding:18px 14px;text-align:center;font-size:12px;color:var(--txt2);}
.saved-drop-row{padding:10px;border-radius:var(--rs);display:grid;gap:8px;border:1px solid transparent;}
.saved-drop-row:hover{background:var(--surface-2);border-color:var(--border);}
.saved-drop-main{display:flex;align-items:flex-start;gap:10px;}
.saved-drop-info{min-width:0;flex:1;}
.saved-drop-actions{display:flex;gap:6px;flex-wrap:wrap;}
@media(max-width:700px){
  .saved-drop-menu{min-width:calc(100vw - 24px);}
  .saved-drop-actions .pill{font-size:10.5px;padding:4px 8px;}
}

/* ── PACING ── */
.pac-grid{display:grid;gap:8px;}
.pac-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;}
.pac-ph{padding:11px 16px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border);background:var(--card2);}
.pac-ph-name{font-size:14px;font-weight:700;color:var(--txt);flex:1;}
.pac-cr{padding:10px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border);flex-wrap:wrap;}
.pac-cr:last-child{border-bottom:none;}
.pac-cname{flex:1;min-width:120px;}
.pac-ctitle{font-size:12px;font-weight:600;color:var(--txt);}
.pac-stats{display:flex;gap:18px;flex-shrink:0;}
.pst-v{font-size:12px;font-weight:600;color:var(--txt);font-family:'DM Mono',monospace;}
.pst-l{font-size:10px;color:var(--txt2);text-transform:uppercase;letter-spacing:.05em;}
.pac-bc{width:110px;flex-shrink:0;}
.pac-bb{height:5px;background:var(--bg);border-radius:3px;overflow:hidden;margin-bottom:3px;}
.pac-bf{height:100%;border-radius:3px;}
.pac-br{display:flex;justify-content:space-between;font-size:10px;font-family:'DM Mono',monospace;}
.add-form{background:var(--card2);border:1px solid var(--border);border-radius:var(--r);padding:16px;margin-bottom:12px;display:none;}
.frow{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px;}
.fgrp{display:flex;flex-direction:column;gap:4px;flex:1;min-width:110px;}
.flbl{font-size:10px;font-weight:700;color:var(--txt2);text-transform:uppercase;letter-spacing:.07em;}
.finp{background:var(--bg);border:1px solid var(--border2);border-radius:var(--rs);
  padding:7px 10px;font-size:12px;color:var(--txt);outline:none;width:100%;}
.finp:focus{border-color:var(--accent);}

/* ── BENCHMARKS ── */
.bench-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:18px 20px;}
@media(max-width:900px){.bench-grid{grid-template-columns:1fr;}}
.bench-row{padding:9px 16px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border);font-size:12px;}
.bench-row:last-child{border-bottom:none;}
.bench-val{font-family:'DM Mono',monospace;font-size:11px;color:var(--txt);margin-left:auto;margin-right:8px;}
.bench-ind{font-size:10px;color:var(--txt3);margin-right:8px;}
.bench-bw{width:80px;height:4px;background:var(--bg);border-radius:2px;overflow:hidden;margin:0 8px;}
.bench-bf{height:100%;border-radius:2px;}

/* ── PLANNER ── */
.plan-body{padding:18px 20px;}
.plan-top{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px;}
@media(max-width:1100px){.plan-top{grid-template-columns:1fr 1fr;}}
.plan-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:14px 12px;}
.plan-lbl{font-size:11px;font-weight:700;color:var(--txt2);text-transform:uppercase;letter-spacing:.07em;margin-bottom:8px;}
.pinp{width:100%;background:var(--card2);border:1px solid var(--border2);border-radius:var(--rs);
  padding:8px 12px;font-size:14px;color:var(--txt);font-family:'DM Mono',monospace;outline:none;}
.pinp:focus{border-color:var(--accent);}
.plat-plan-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-bottom:8px;}
.plat-plan-hdr{padding:10px 16px;background:var(--card2);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;}
.plat-cam-row{padding:8px 16px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border);font-size:12px;}
.plat-cam-row:last-child{border-bottom:none;}
.add-plat-btn{padding:10px;background:transparent;border:1.5px dashed var(--border2);border-radius:var(--r);
  color:var(--txt2);cursor:pointer;font-size:13px;font-weight:500;width:100%;transition:all .15s;}
.add-plat-btn:hover{border-color:var(--accent);color:var(--accent);}



/* ── AI PANEL ── */
.ai-panel{position:fixed;right:0;top:0;bottom:0;width:420px;background:var(--bg-elev);
  border-left:1px solid var(--border-2);z-index:200;display:flex;flex-direction:column;
  transform:translateX(100%);transition:transform .28s var(--ease);
  box-shadow:-24px 0 48px rgba(0,0,0,.28);}
.ai-panel.on{transform:none;}
.ai-hdr{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;
  background:linear-gradient(180deg,rgba(37,99,235,.06),transparent);}
.ai-title{font-size:14px;font-weight:700;color:var(--txt);display:flex;align-items:center;gap:8px;letter-spacing:-0.01em;}
.ai-title::before{display:none;}
.ai-title-icon{width:28px;height:28px;border-radius:9px;background:var(--abg);border:1px solid var(--aborder);
  color:var(--accent);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;}
.ai-body{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:12px;}
.ai-compose{display:grid;gap:12px;}
.ai-compose-label,.ai-suggestion-label{font-size:10px;font-weight:800;color:var(--txt3);text-transform:uppercase;letter-spacing:.08em;}
.ai-generate-btn{justify-content:center;min-height:46px;width:100%;}
.ai-suggestions{display:grid;grid-template-columns:1fr 1fr;gap:6px;}
.ai-suggest{border:1px solid var(--border);background:var(--surface-2);color:var(--txt2);border-radius:9px;padding:8px 9px;font-size:11.5px;font-weight:650;line-height:1.25;text-align:left;cursor:pointer;font-family:inherit;transition:border-color var(--dur) var(--ease),background var(--dur) var(--ease),color var(--dur) var(--ease);}
.ai-suggest:hover,.ai-suggest:focus{border-color:var(--aborder);background:var(--abg);color:var(--accent);outline:none;}
.ai-conversation{display:flex;flex-direction:column;gap:12px;}
.bubble{background:var(--surface);border:1px solid var(--border);border-radius:12px;
  padding:12px 14px;font-size:12.5px;color:var(--txt2);line-height:1.6;}
.bubble strong{color:var(--txt);font-weight:600;}
.bubble.u{background:var(--abg);border-color:var(--aborder);color:var(--txt);margin-left:40px;}
.ai-inp-row{padding:14px 20px;border-top:1px solid var(--border);display:flex;gap:8px;background:var(--bg-elev);}
.ai-inp{width:100%;background:var(--surface-2);border:1px solid var(--border);border-radius:12px;
  padding:13px 14px;font-size:13px;color:var(--txt);outline:none;resize:none;min-height:150px;max-height:220px;line-height:1.5;font-family:inherit;}
.ai-inp:focus{border-color:var(--aborder);box-shadow:0 0 0 3px var(--abg);}
.ai-send{padding:0 14px;background:var(--brand-grad);border:none;
  border-radius:10px;color:#fff;cursor:pointer;font-size:12.5px;font-weight:600;
  display:flex;align-items:center;justify-content:center;}
.ai-send:hover{filter:brightness(1.1);}
@media(max-width:520px){
  .ai-panel{width:100%;}
  .ai-suggestions{grid-template-columns:1fr;}
}

/* ── MODALS ── */
.overlay{position:fixed;inset:0;background:rgba(6,18,33,.55);z-index:300;
  display:none;align-items:center;justify-content:center;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);}
.overlay.on{display:flex;}
.modal{background:var(--bg-elev);border:1px solid var(--border-2);border-radius:var(--r-xl);
  padding:24px;width:520px;max-width:92vw;max-height:90vh;overflow-y:auto;
  box-shadow:0 30px 60px rgba(0,0,0,.35);}
.modal h3{font-size:16px;font-weight:700;color:var(--txt);margin-bottom:6px;letter-spacing:-0.01em;}
.modal p{font-size:13px;color:var(--txt2);margin-bottom:18px;line-height:1.5;}
.modal-btns{display:flex;gap:8px;justify-content:flex-end;margin-top:18px;}
.modal-btns button{padding:8px 16px;border-radius:var(--rs);font-size:13px;font-weight:600;
  cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--txt2);transition:all var(--dur) var(--ease);}
.modal-btns button:hover{border-color:var(--border-2);color:var(--txt);}
.modal-btns button.primary{background:var(--accent);color:#fff;border-color:var(--accent);}
.modal-btns button.primary:hover{background:#1d4ed8;color:#fff;}
.link-target-row{display:grid;gap:6px;margin:12px 0;}
.link-target-row label{font-size:11px;font-weight:700;color:var(--txt2);text-transform:uppercase;letter-spacing:.07em;}
.link-platform-row{display:flex;gap:8px;align-items:center;margin:12px 0;}
.link-target-row select,.link-platform-row select,.link-platform-row input{background:var(--surface);border:1px solid var(--border);border-radius:10px;color:var(--txt);font:inherit;font-size:13px;padding:9px 11px;outline:none;}
.link-platform-row select:focus,.link-platform-row input:focus{border-color:var(--aborder);box-shadow:0 0 0 3px var(--abg);}
.link-target-row select:focus{border-color:var(--aborder);box-shadow:0 0 0 3px var(--abg);}
.link-campaign-list{border:1px solid var(--border);border-radius:12px;overflow:hidden;max-height:310px;overflow-y:auto;background:var(--surface);}
.link-campaign-item{display:flex;align-items:flex-start;gap:10px;padding:11px 12px;border-bottom:1px solid var(--border);cursor:pointer;}
.link-campaign-item:last-child{border-bottom:none;}
.link-campaign-item:hover{background:var(--surface-2);}
.link-campaign-item input{margin-top:3px;accent-color:var(--accent);}
.link-campaign-name{font-size:13px;font-weight:700;color:var(--txt);}
.link-campaign-meta{font-size:11px;color:var(--txt3);margin-top:2px;}
.link-status{font-size:12px;color:var(--txt2);line-height:1.45;margin-top:8px;min-height:18px;}
.link-status.err{color:var(--red);}
.drop-zone{border:2px dashed var(--border2);border-radius:var(--r);padding:28px 20px;
  text-align:center;cursor:pointer;transition:all .15s;margin-bottom:16px;}
.drop-zone:hover,.drop-zone.drag{border-color:var(--accent);background:var(--abg);}
.drop-zone p{font-size:13px;color:var(--txt2);}
.drop-zone strong{color:var(--accent);}
.file-entry{display:flex;align-items:center;gap:8px;padding:8px;background:var(--card2);
  border:1px solid var(--border);border-radius:var(--rs);margin-bottom:6px;}
.fsel{flex:1;background:var(--bg);border:1px solid var(--border2);border-radius:5px;
  padding:4px 8px;font-size:11px;color:var(--txt);outline:none;}

/* ── COMPARE PANEL ── */
.cmp-panel{background:var(--card2);border:1px solid var(--border);border-radius:var(--r);
  overflow:hidden;margin-bottom:12px;display:none;}
.cmp-panel.on{display:block;}
.cmp-results{background:var(--card);border:1px solid var(--border);border-radius:var(--r);
  padding:14px;margin-bottom:12px;display:none;}
.cmp-results.on{display:block;}
.cmp-table{width:100%;border-collapse:collapse;font-size:12px;}
.cmp-table th,.cmp-table td{padding:7px 10px;border-bottom:1px solid var(--border);}
.cmp-table th{font-size:10px;font-weight:700;color:var(--txt2);text-transform:uppercase;background:var(--card2);}
.cmp-table tr:last-child td{border-bottom:none;}

/* ── EXPORT MENU ── */
.export-menu{position:fixed;background:var(--card);border:1px solid var(--border2);
  border-radius:var(--r);box-shadow:0 8px 24px rgba(0,0,0,.15);z-index:400;min-width:200px;display:none;}
.export-menu.on{display:block;}
.export-item{width:100%;padding:10px 14px;background:transparent;border:none;
  color:var(--txt);font-size:13px;text-align:left;cursor:pointer;display:flex;align-items:center;gap:8px;}
.export-item:hover{background:var(--card2);}
.export-divider{height:1px;background:var(--border);margin:3px 0;}

/* ── PDF MODAL EXTRAS ── */
.check-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;}
.check-item{display:flex;align-items:center;gap:8px;padding:8px 10px;
  background:var(--card2);border:1px solid var(--border);border-radius:var(--rs);cursor:pointer;font-size:12px;color:var(--txt);}
.logo-up{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.logo-preview{width:80px;height:40px;background-size:contain;background-repeat:no-repeat;
  background-position:center;border:1px solid var(--border);border-radius:var(--rs);display:none;}

/* ── DATE DROP ── */
.date-drop{position:fixed;background:var(--card);border:1px solid var(--border2);
  border-radius:var(--r);box-shadow:0 12px 32px rgba(0,0,0,.15);z-index:400;
  padding:14px;width:280px;display:none;}
.date-drop.on{display:block;}
.dp-pre-row{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:12px;}
.dp-pre{padding:4px 9px;border-radius:5px;font-size:11px;font-weight:500;cursor:pointer;
  border:1px solid var(--border);background:transparent;color:var(--txt2);}
.dp-pre:hover,.dp-pre.on{background:var(--abg);border-color:var(--aborder);color:var(--accent);}
.dp-inputs{display:flex;gap:6px;align-items:center;}
.dp-in{flex:1;background:var(--card2);border:1px solid var(--border2);border-radius:var(--rs);
  padding:6px 8px;font-size:11px;color:var(--txt);outline:none;}
.dp-in:focus{border-color:var(--accent);}

/* ── TOAST ── */
.toast{position:fixed;bottom:20px;right:20px;background:var(--txt);color:var(--bg);
  border-radius:var(--r);padding:10px 16px;font-size:13px;font-weight:500;
  box-shadow:0 8px 24px rgba(0,0,0,.24);z-index:999;
  transform:translateY(60px);opacity:0;transition:all .25s var(--ease);pointer-events:none;}
.toast.on{transform:none;opacity:1;}

/* ── SECTION HIDE/SHOW ── */
.section{display:none;}
.section.on{display:block;}

/* ── LOGO ── */
.logo{display:flex;align-items:center;gap:9px;margin-right:0;flex-shrink:0;text-decoration:none;}
.logo-dot{display:none;}
.logo-bar{width:6px;height:26px;background:linear-gradient(180deg,#2563eb,#0891b2);border-radius:3px;flex-shrink:0;}
.logo-txt{font-family:'Syne',sans-serif;font-size:16px;font-weight:800;color:var(--txt);letter-spacing:-0.02em;}

/* ── BAR TWO-ROW LAYOUT ── */
.bar-top{display:flex;align-items:center;width:100%;padding:0 20px;height:52px;gap:8px;flex-shrink:0;}
/* bar-nav desktop rule removed */
.mob-nav-btn{display:none;align-items:center;gap:6px;background:var(--bg);border:1px solid var(--border);
  border-radius:6px;color:var(--txt);font-size:13px;font-weight:600;padding:6px 10px;cursor:pointer;white-space:nowrap;touch-action:manipulation;-webkit-tap-highlight-color:transparent;}
.mob-nav-menu{position:fixed;top:52px;left:0;right:0;z-index:1000;background:var(--card);
  border-bottom:1px solid var(--border);box-shadow:0 8px 24px rgba(0,0,0,.12);display:flex;flex-direction:column;pointer-events:auto;}
.mob-nav-item{display:flex;align-items:center;gap:10px;padding:14px 20px;font-size:14px;font-weight:500;
  color:var(--txt2);border-bottom:1px solid var(--border);cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;user-select:none;}
.mob-nav-item:last-child{border-bottom:none;}
.mob-nav-item:hover,.mob-nav-item.on{background:var(--abg);color:var(--accent);}
.mob-nav-item.on{font-weight:700;}

/* ── AI BUTTON (brand gradient) ── */
.btn.ai{border:none;background:var(--brand-grad);color:#fff;font-weight:600;padding:6px 14px;letter-spacing:.01em;}
.btn.ai:hover,.btn.ai.on{filter:brightness(1.08);color:#fff;background:var(--brand-grad);}

/* ── AVATAR ── */
.avatar{width:32px;height:32px;border-radius:50%;background:var(--brand-grad);border:none;
  color:#fff;font-size:11.5px;font-weight:700;display:flex;align-items:center;justify-content:center;
  font-family:'Syne',sans-serif;letter-spacing:-0.01em;
  text-decoration:none;cursor:pointer;flex-shrink:0;overflow:hidden;background-repeat:no-repeat;
  background-size:cover;background-position:center;}

/* ── ACTIONS DROPDOWN ── */
.actions-menu{position:fixed;z-index:600;background:var(--card);border:1px solid var(--border2);
  border-radius:var(--r);box-shadow:0 8px 32px rgba(0,0,0,.18);min-width:210px;padding:4px;}
.am-item{display:flex;align-items:center;gap:9px;padding:9px 14px;font-size:13px;color:var(--txt2);
  cursor:pointer;border-radius:6px;white-space:nowrap;width:100%;background:none;border:none;
  font-family:'DM Sans',sans-serif;text-align:left;}
.am-item:hover{background:var(--bg);color:var(--txt);}
.am-sep{height:1px;background:var(--border);margin:4px 8px;}
.am-sub{position:relative;}
.am-sub-menu{position:absolute;right:calc(100% + 4px);left:auto;top:0;background:var(--card);
  border:1px solid var(--border2);border-radius:var(--r);box-shadow:0 8px 24px rgba(0,0,0,.12);
  min-width:180px;padding:4px;z-index:601;display:none;}
/* am-sub-menu toggled by click, not hover */

/* ── TOUR ── */
#tour-overlay{position:fixed;inset:0;z-index:9000;pointer-events:none;}
#tour-spotlight{position:fixed;z-index:9001;border-radius:8px;pointer-events:none;
  box-shadow:0 0 0 4000px rgba(0,0,0,0.55);}
#tour-card{position:fixed;z-index:9002;background:var(--card);border:1px solid var(--border2);
  border-radius:14px;box-shadow:0 12px 40px rgba(0,0,0,.25);width:320px;
  max-width:calc(100vw - 24px);padding:22px;box-sizing:border-box;pointer-events:auto;}
#tour-card .tc-step{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;
  color:var(--accent);margin-bottom:8px;}
#tour-card .tc-title{font-size:16px;font-weight:700;color:var(--txt);margin-bottom:8px;line-height:1.3;}
#tour-card .tc-body{font-size:13px;color:var(--txt2);line-height:1.6;margin-bottom:18px;}
#tour-card .tc-btns{display:flex;align-items:center;gap:8px;}
#tour-card .tc-next{background:var(--accent);border:none;border-radius:7px;color:#fff;
  padding:8px 18px;font-size:13px;font-weight:700;cursor:pointer;flex:1;pointer-events:auto;}
#tour-card .tc-skip{background:transparent;border:none;color:var(--txt3);font-size:12px;cursor:pointer;padding:4px 8px;}
#tour-card .tc-dots{display:flex;gap:5px;margin-right:auto;flex-wrap:wrap;}
#tour-card .tc-dot{width:6px;height:6px;border-radius:50%;background:var(--border2);cursor:pointer;}
#tour-card .tc-dot.on{background:var(--accent);}
#tour-arrow{position:fixed;z-index:9003;width:12px;height:12px;background:var(--card);
  border-top:1px solid var(--border2);border-left:1px solid var(--border2);}

/* ── COLUMN FILTER STYLES ── */
.cpf-col{display:grid;grid-template-columns:1fr auto;align-items:center;gap:8px;
  padding:10px 0;border-bottom:1px solid var(--border);}
.cpf-col:last-child{border-bottom:none;}
.cpf-label{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--txt);cursor:pointer;}
.cpf-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);display:inline-block;margin-left:5px;vertical-align:middle;}
.cpf-controls{display:flex;align-items:center;gap:5px;justify-content:flex-end;flex-wrap:wrap;}
.cpf-sel{font-size:11px;padding:3px 6px;border:1px solid var(--border2);border-radius:5px;background:var(--bg);color:var(--txt);}
.cpf-num{width:64px;font-size:11px;padding:3px 5px;border:1px solid var(--border2);border-radius:5px;background:var(--bg);color:var(--txt);}
.cpf-chip{font-size:11px;padding:2px 8px;border:1px solid var(--border2);border-radius:10px;color:var(--txt2);cursor:pointer;background:var(--bg);}
.cpf-chip.on{background:var(--abg);border-color:var(--aborder);color:var(--accent);font-weight:600;}
.cpf-clr{background:none;border:none;color:var(--txt3);cursor:pointer;font-size:15px;padding:0 3px;line-height:1;}

/* ── TABLE WIDTHS ── */
.perf-tbl{table-layout:fixed;width:100%;}
.perf-tbl th:first-child,.perf-tbl td:first-child{width:auto;}
.perf-tbl th:nth-child(2),.perf-tbl td:nth-child(2){width:110px;}
.perf-tbl th:nth-child(n+3),.perf-tbl td:nth-child(n+3){width:90px;}
.cname{font-weight:600;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block;max-width:100%;}
.csub{font-size:10px;color:var(--txt3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}

/* ── MOBILE SAVED PANEL ── */
.mob-saved-panel{display:none;background:var(--card);border:1px solid var(--border);
  border-radius:var(--r);margin-top:12px;overflow:hidden;}

/* ── FOOTER LINKS ── */
.footer-links{display:flex;gap:18px;flex-wrap:wrap;align-items:center;}
.footer-links a{font-size:12px;color:var(--txt3);text-decoration:none;}
.footer-links a:hover{color:var(--txt2);}

/* ── BODY/LAYOUT ── */
body{min-height:100vh;display:flex;flex-direction:column;}
.content-wrap{flex:1;}

/* ── MOBILE ≤640px ── */
@media(max-width:640px){
  html,body{overflow-x:hidden;max-width:100vw;}
  .app-shell{display:block;}
  .bar{position:sticky;top:0;bottom:auto;width:100%;height:auto;min-height:0;border-right:none;border-bottom:1px solid var(--border);}
  .bar-row1{height:48px;flex-direction:row;align-items:center;padding:0 12px;}
  .side-head{width:100%;}
  .bar-row1 .side-head{width:auto;flex:1;}
  .bar-row1 .bar-right{display:flex;gap:4px;}
  .bar-row1 .bar-right .fb-btn,.bar-row1 .bar-right .guide-btn{display:none;}
  .bar-row1 .bar-right .ico-btn,.bar-row1 .bar-right .btn.ai{width:auto;min-height:30px;padding:6px 9px;}
  .bar-row1 .bar-right .avatar{width:32px;height:32px;border-radius:50%;padding:0;justify-content:center;}
  .bar-row1 .bar-right .avatar::after{display:none;}
  .side-toggle,.side-label,.side-spacer,.bar .tabs{display:none !important;}
  .tabs{display:none !important;}
  .bar-row2{display:flex !important;padding:0 12px 8px;}
  .mob-nav-btn{display:flex !important;width:100%;}
  .bar-right{gap:4px;}
  .guide-btn{font-size:11px !important;padding:4px 8px !important;}

  .body{padding:10px;}
  .toolbar{flex-wrap:wrap;gap:6px;padding:8px 10px;}
  .kpis{grid-template-columns:repeat(2,1fr) !important;gap:8px;}
  .kpi{padding:10px;}
  .grid2{grid-template-columns:1fr !important;}
  .rcol{display:none !important;}
  .mchips{overflow-x:auto;flex-wrap:nowrap !important;scrollbar-width:none;}
  .mchips::-webkit-scrollbar{display:none;}
  #platBtns{overflow-x:auto;flex-wrap:nowrap !important;scrollbar-width:none;}
  #platBtns::-webkit-scrollbar{display:none;}
  .tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:calc(100vw - 20px);}  
  .twrap{overflow-x:auto;max-width:calc(100vw - 20px);-webkit-overflow-scrolling:touch;}
  #perfTable{min-width:600px;}
  table{min-width:0;width:100%;}
  td,th{padding:6px 8px;font-size:12px;}
  .seg{overflow-x:auto;flex-wrap:nowrap;}
  .pacts{flex-wrap:wrap;gap:4px;}
  .pacts .mchips{order:1;width:100%;}
  .pacts .div{display:none;}
  .pacts #pD,.pacts #pW,.pacts #pM{order:2;}
  #tour-card{width:calc(100vw - 24px) !important;max-width:340px !important;}
  #aiPanel{width:100% !important;right:0 !important;left:0 !important;border-radius:0 !important;}
  .mob-saved-panel{display:block;}
  footer > div{flex-direction:column;align-items:center;text-align:center;gap:14px;}
  .footer-links{display:grid;grid-template-columns:repeat(3,auto);justify-content:center;gap:12px 20px;}
  .actions-menu .am-sub-menu{position:fixed;left:8px !important;right:8px !important;width:auto !important;top:auto !important;}
    }
@media(max-width:400px){
  .kpis{grid-template-columns:1fr 1fr !important;}
  .bar-row1{padding:0 12px;height:48px;}
}
  .cwrap{padding:8px;overflow:hidden;}
  .cwrap canvas:not(#chart){max-width:100% !important;width:100% !important;}
  /* Benchmarking tab mobile */
  .bench-body{padding:10px !important;}
  #benchTopCards{grid-template-columns:repeat(2,1fr) !important;}
  .bench-chart-row{grid-template-columns:1fr !important;}
  #benchChartWrap{height:160px !important;}
  #benchMetBtns{flex-wrap:wrap;gap:4px;}
  .bench-grid{gap:8px;padding:10px;}

/* ── PAC TOOLTIP ── */
.pac-tip{position:relative;display:inline-flex;align-items:center;justify-content:center;
  width:13px;height:13px;border-radius:50%;background:var(--abg);border:1px solid var(--aborder);
  color:var(--accent);font-size:8px;font-weight:800;cursor:default;flex-shrink:0;line-height:1;}
.pac-tip::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;
  transform:translateX(-50%);background:#0f172a;color:#e2e8f0;font-size:11px;font-weight:400;
  line-height:1.45;padding:7px 10px;border-radius:6px;white-space:nowrap;pointer-events:none;
  opacity:0;transition:opacity .15s;z-index:9999;min-width:200px;max-width:260px;
  white-space:normal;text-align:left;box-shadow:0 4px 16px rgba(0,0,0,.3);}
.pac-tip::before{content:'';position:absolute;bottom:calc(100% + 2px);left:50%;
  transform:translateX(-50%);border:5px solid transparent;border-top-color:#0f172a;
  pointer-events:none;opacity:0;transition:opacity .15s;z-index:9999;}
.pac-tip:hover::after,.pac-tip:hover::before{opacity:1;}
  /* Pacing platform header mobile */
  .pac-card{overflow:hidden;}
  .pac-days-txt{display:none !important;}
  .pac-flight-row{flex-wrap:wrap !important;gap:4px !important;}
  .pac-date-inp{max-width:120px !important;font-size:10px !important;}


.am-sub-menu.open{display:block !important;}

/* ═══════════════════════════════════════════════════════════════════════
   DESIGN REFRESH LAYER — additive; nothing above this is removed
   ═══════════════════════════════════════════════════════════════════════ */

/* Animated tab underline */
.tabs{position:relative;}
.tab-underline{display:none;}

/* Average-line tooltip on benchmarking bars — instant, no native title delay */
.bench-bar-avg{cursor:help;}
.bench-bar-avg::before{content:'';position:absolute;inset:-4px -8px;}
.bench-bar-avg::after{
  content:attr(data-avg);
  position:absolute;
  bottom:calc(100% + 6px);
  left:50%;
  transform:translateX(-50%);
  background:var(--txt);
  color:var(--card);
  padding:5px 9px;
  border-radius:6px;
  font-size:11px;
  font-weight:600;
  font-family:'DM Mono',monospace;
  white-space:nowrap;
  pointer-events:none;
  opacity:0;
  transition:opacity 0s;
  z-index:20;
  box-shadow:0 2px 8px rgba(0,0,0,.18);
}
.bench-bar-avg:hover::after{opacity:1;}

/* ── Toolbar: grouped filters with labels + dividers ── */
.toolbar{gap:10px !important;}
.filt-group{display:inline-flex;align-items:center;gap:7px;flex-shrink:0;}
.filt-group-lbl{font-size:10px;font-weight:700;color:var(--txt4,#94a3b8);text-transform:uppercase;letter-spacing:.08em;}
:root.dark .filt-group-lbl{color:#4d7196;}
.app-plan-badge{font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;}
.app-plan-badge.free{color:var(--accent);}
.app-plan-badge.individual{color:#2563eb;}
.app-plan-badge.pro{color:var(--green);}
.app-plan-badge.enterprise{color:#7c3aed;}
.app-plan-badge.test{color:#0891b2;}

/* ── Test-plan Safe Zone Tester ── */
.safe-zone-app-body{
  padding:10px 12px;
  max-width:100%;
  margin:0;
}
.safe-zone-app-shell{
  width:100%;
  min-height:calc(100vh - 24px);
  border:1px solid var(--border);
  background:linear-gradient(180deg,var(--surface),var(--surface-2));
  border-radius:var(--r-xl);
  overflow:hidden;
  box-shadow:0 16px 38px rgba(15,23,42,.08);
}
:root.dark .safe-zone-app-shell{box-shadow:0 18px 42px rgba(0,0,0,.32);}
.safe-zone-app-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:14px;
  padding:12px 14px;
  border-bottom:1px solid var(--border);
  background:
    radial-gradient(circle at 82% 0,rgba(8,145,178,.13),transparent 34%),
    linear-gradient(135deg,rgba(37,99,235,.08),rgba(8,145,178,.07));
}
.safe-zone-eyebrow{
  font:800 10px/1 'DM Mono',monospace;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:5px;
}
.safe-zone-app-head h2{
  margin:0;
  font:800 21px/1.08 'Syne','DM Sans',sans-serif;
  color:var(--txt);
  letter-spacing:-.035em;
}
.safe-zone-app-head p{
  margin:5px 0 0;
  max-width:760px;
  color:var(--txt2);
  font-size:12.5px;
  line-height:1.4;
}
.safe-zone-head-pill{
  flex-shrink:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:26px;
  padding:0 11px;
  border:1px solid var(--aborder);
  border-radius:999px;
  background:var(--abg);
  color:var(--accent);
  font:800 11px/1 'DM Mono',monospace;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.safe-zone-workbench{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  align-items:start;
  padding:12px;
}
.safe-zone-control-panel,
.safe-zone-preview-panel{
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  background:rgba(255,255,255,.76);
  box-shadow:0 10px 26px rgba(15,23,42,.06);
}
:root.dark .safe-zone-control-panel,
:root.dark .safe-zone-preview-panel{
  background:rgba(11,22,36,.86);
  box-shadow:0 12px 30px rgba(0,0,0,.22);
}
.safe-zone-control-panel{
  position:relative;
  top:auto;
  padding:12px;
  display:grid;
  grid-template-columns:minmax(190px,.85fr) minmax(130px,.42fr) minmax(280px,1.3fr) minmax(210px,.7fr);
  gap:12px;
  align-items:stretch;
}
.safe-zone-panel-section{min-width:0;}
.safe-zone-panel-section+.safe-zone-panel-section{
  border-top:0;
  border-left:1px solid var(--border);
  margin-top:0;
  padding-top:0;
  padding-left:12px;
}
.safe-zone-section-label{
  display:block;
  font:800 10px/1 'DM Mono',monospace;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--txt3);
  margin-bottom:8px;
}
.safe-zone-upload-drop{
  min-height:84px;
  border:1.5px dashed var(--border-2);
  border-radius:var(--r-lg);
  background:
    linear-gradient(180deg,rgba(37,99,235,.06),rgba(8,145,178,.04)),
    var(--surface-2);
  display:grid;
  grid-template-columns:40px minmax(0,1fr);
  grid-template-rows:auto auto;
  column-gap:10px;
  place-items:center start;
  text-align:left;
  padding:12px;
  color:var(--txt2);
  cursor:pointer;
  transition:border-color .15s ease,transform .15s ease,background .15s ease;
}
.safe-zone-upload-drop:hover,
.safe-zone-upload-drop.dragging{
  border-color:var(--accent);
  background:var(--abg);
  transform:translateY(-1px);
}
.safe-zone-upload-drop input{display:none;}
.safe-zone-upload-drop strong{
  display:block;
  color:var(--txt);
  font-size:13.5px;
  margin-top:0;
}
.safe-zone-upload-drop span:last-child{
  display:block;
  max-width:none;
  font-size:11.5px;
  line-height:1.35;
}
.safe-zone-upload-icon{
  grid-row:1 / span 2;
  width:38px;
  height:38px;
  display:grid;
  place-items:center;
  border-radius:13px;
  color:var(--accent);
  background:var(--abg);
  border:1px solid var(--aborder);
}
.safe-zone-upload-icon svg{
  width:20px;
  height:20px;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.safe-zone-creative-meta{
  margin-top:7px;
  color:var(--txt3);
  font-size:11.5px;
  line-height:1.35;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.safe-zone-select{
  width:100%;
  appearance:none;
  border:1px solid var(--border-2);
  border-radius:var(--r);
  padding:9px 34px 9px 10px;
  background:
    linear-gradient(45deg,transparent 50%,var(--txt2) 50%) calc(100% - 19px) 50%/7px 7px no-repeat,
    var(--surface);
  color:var(--txt);
  font:800 13px/1 'DM Sans',sans-serif;
}
.safe-zone-placement-list{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(130px,1fr));
  gap:8px;
  max-height:126px;
  overflow:auto;
  padding-right:3px;
}
.safe-zone-placement-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) 30px;
  gap:8px;
  align-items:center;
  border:1px solid var(--border);
  background:var(--surface-2);
  border-radius:var(--r);
  padding:8px;
}
.safe-zone-placement-row strong{
  display:block;
  font-size:12.5px;
  line-height:1.25;
  color:var(--txt);
}
.safe-zone-placement-row span{
  display:block;
  margin-top:3px;
  color:var(--txt3);
  font-size:10.5px;
  line-height:1.25;
}
.safe-zone-add-placement{
  width:30px;
  height:30px;
  border-radius:10px;
  border:1px solid var(--aborder);
  background:var(--surface);
  color:var(--accent);
  font-size:18px;
  line-height:1;
  cursor:pointer;
  transition:all .15s ease;
}
.safe-zone-add-placement:hover{
  background:var(--accent);
  color:#fff;
  transform:translateY(-1px);
}
.safe-zone-add-placement.added{
  background:var(--gbg);
  color:var(--green);
  border-color:var(--gborder);
  font-size:15px;
}
.safe-zone-panel-section:nth-child(4){
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:8px 10px;
  align-content:start;
}
.safe-zone-panel-section:nth-child(4) .safe-zone-range-row{grid-column:1 / -1;}
.safe-zone-panel-section:nth-child(4) .safe-zone-range-input{
  grid-column:1 / -1;
  margin:0 0 2px;
}
.safe-zone-panel-section:nth-child(4) .safe-zone-section-label{
  margin:0;
  align-self:center;
}
.safe-zone-panel-section:nth-child(4) .safe-zone-segmented{grid-column:1 / -1;}
.safe-zone-panel-section:nth-child(4) .safe-zone-secondary-btn{
  grid-column:1 / -1;
  margin-top:0;
  padding:9px;
}
.safe-zone-range-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  color:var(--txt2);
  font-size:12px;
  font-weight:800;
}
.safe-zone-range-input{
  width:100%;
  accent-color:var(--accent);
}
.safe-zone-segmented{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:4px;
  padding:4px;
  border:1px solid var(--border);
  border-radius:999px;
  background:var(--surface-3);
}
.safe-zone-segmented button{
  border:none;
  border-radius:999px;
  padding:8px 10px;
  background:transparent;
  color:var(--txt2);
  cursor:pointer;
  font:800 12.5px/1 'DM Sans',sans-serif;
}
.safe-zone-segmented button.active{
  background:var(--surface);
  color:var(--accent);
  box-shadow:0 4px 14px rgba(15,23,42,.1);
}
:root.dark .safe-zone-segmented button.active{box-shadow:0 4px 14px rgba(0,0,0,.28);}
.safe-zone-secondary-btn{
  width:100%;
  border:1px solid var(--border-2);
  background:var(--surface);
  color:var(--txt2);
  border-radius:var(--r);
  font:800 12.5px/1 'DM Sans',sans-serif;
  cursor:pointer;
}
.safe-zone-secondary-btn:hover{border-color:var(--accent);color:var(--accent);}
.safe-zone-preview-panel{padding:14px;min-height:calc(100vh - 250px);}
.safe-zone-preview-toolbar{
  display:flex;
  gap:18px;
  justify-content:space-between;
  align-items:flex-start;
  border-bottom:1px solid var(--border);
  padding-bottom:12px;
  margin-bottom:12px;
}
.safe-zone-preview-toolbar h3{
  margin:0;
  color:var(--txt);
  font:800 19px/1.1 'Syne','DM Sans',sans-serif;
  letter-spacing:-.025em;
}
.safe-zone-preview-toolbar p{
  margin:5px 0 0;
  color:var(--txt2);
  font-size:12.5px;
  line-height:1.45;
  max-width:720px;
}
.safe-zone-legend{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:8px;
  min-width:220px;
}
.safe-zone-legend span{
  display:inline-flex;
  align-items:center;
  gap:7px;
  border:1px solid var(--border);
  background:var(--surface);
  color:var(--txt2);
  border-radius:999px;
  padding:7px 9px;
  font-size:11.5px;
  font-weight:800;
}
.safe-zone-legend i{width:12px;height:12px;border-radius:4px;display:block;}
.safe-zone-legend-safe{border:2px solid var(--green);}
.safe-zone-legend-danger{background:rgba(239,68,68,.62);}
.safe-zone-empty-state{
  min-height:260px;
  display:grid;
  place-items:center;
  border:1px dashed var(--border-2);
  border-radius:var(--r-lg);
  background:rgba(255,255,255,.45);
  color:var(--txt3);
  text-align:center;
  padding:28px;
}
:root.dark .safe-zone-empty-state{background:rgba(15,30,48,.5);}
.safe-zone-empty-state strong{
  display:block;
  color:var(--txt);
  font-size:15px;
  margin-bottom:6px;
}
.safe-zone-empty-state span{
  display:block;
  max-width:380px;
  line-height:1.45;
}
.safe-zone-empty-state.hidden{display:none;}
.safe-zone-preview-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:16px;
}
.safe-zone-preview-card{
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  background:var(--surface);
  box-shadow:0 10px 26px rgba(15,23,42,.07);
  overflow:hidden;
}
:root.dark .safe-zone-preview-card{box-shadow:0 12px 28px rgba(0,0,0,.22);}
.safe-zone-preview-card-head{
  display:flex;
  align-items:flex-start;
  gap:11px;
  padding:14px;
  border-bottom:1px solid var(--border);
}
.safe-zone-platform-chip{
  width:39px;
  height:39px;
  border-radius:12px;
  display:grid;
  place-items:center;
  flex:0 0 auto;
  color:#fff;
  font:900 12px/1 'DM Sans',sans-serif;
  box-shadow:0 9px 20px rgba(37,99,235,.18);
}
.safe-zone-preview-title{min-width:0;flex:1;}
.safe-zone-preview-title strong{
  display:block;
  color:var(--txt);
  font-size:14px;
  line-height:1.25;
}
.safe-zone-preview-title span{
  display:block;
  margin-top:4px;
  color:var(--txt3);
  font-size:11.5px;
  line-height:1.3;
}
.safe-zone-remove-preview{
  width:32px;
  height:32px;
  border:none;
  border-radius:10px;
  background:var(--surface-2);
  color:var(--txt3);
  cursor:pointer;
  font-size:21px;
  line-height:1;
}
.safe-zone-remove-preview:hover{background:var(--rbg);color:var(--red);}
.safe-zone-mock-frame{
  margin:14px;
  border-radius:20px;
  background:#07111f;
  padding:12px;
  border:1px solid rgba(16,26,46,.16);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.06);
}
.safe-zone-mock-top{
  display:flex;
  align-items:center;
  gap:8px;
  color:#c7d7ec;
  margin-bottom:10px;
  font-size:10.5px;
}
.safe-zone-mock-avatar{
  width:23px;
  height:23px;
  border-radius:50%;
  background:linear-gradient(135deg,#2563eb,#38bdf8);
}
.safe-zone-mock-sponsored{
  margin-left:auto;
  color:#7186a3;
  font-family:'DM Mono',monospace;
}
.safe-zone-creative-stage{
  --ratio:1/1;
  --overlay-alpha:.58;
  position:relative;
  width:100%;
  aspect-ratio:var(--ratio);
  max-height:520px;
  margin:0 auto;
  overflow:hidden;
  border-radius:16px;
  background:
    linear-gradient(135deg,rgba(37,99,235,.24),rgba(8,145,178,.1)),
    repeating-linear-gradient(45deg,rgba(255,255,255,.06) 0 8px,transparent 8px 16px),
    #101b2e;
  display:grid;
  place-items:center;
}
.safe-zone-creative-stage[data-orientation="vertical"]{max-width:300px;}
.safe-zone-creative-stage[data-orientation="square"]{max-width:410px;}
.safe-zone-creative-stage[data-orientation="landscape"]{max-width:100%;}
.safe-zone-creative-media{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:var(--fit-mode,cover);
}
.safe-zone-creative-placeholder{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  text-align:center;
  padding:26px;
  color:#d7e6fb;
  font:800 16px/1.35 'DM Sans',sans-serif;
}
.safe-zone-safe-rect{
  position:absolute;
  border:2px solid rgba(22,163,74,.96);
  box-shadow:0 0 0 999px rgba(6,17,31,.03),0 0 24px rgba(22,163,74,.28);
  border-radius:9px;
  pointer-events:none;
  z-index:8;
}
.safe-zone-safe-rect::after{
  content:"Safe area";
  position:absolute;
  left:8px;
  top:8px;
  background:rgba(22,163,74,.92);
  color:#fff;
  border-radius:999px;
  padding:4px 8px;
  font-size:9.5px;
  font-weight:900;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.safe-zone-danger-zone{
  position:absolute;
  background:
    linear-gradient(135deg,rgba(255,255,255,.18) 0 10%,transparent 10% 50%,rgba(255,255,255,.14) 50% 60%,transparent 60% 100%),
    rgba(239,68,68,var(--overlay-alpha));
  background-size:18px 18px;
  border:1px solid rgba(255,255,255,.22);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:7px;
  font-size:9.5px;
  font-weight:900;
  letter-spacing:.04em;
  text-transform:uppercase;
  line-height:1.2;
  pointer-events:none;
  z-index:5;
}
.safe-zone-danger-zone.side-zone{
  writing-mode:vertical-rl;
  text-orientation:mixed;
  padding:5px 3px;
}
.safe-zone-mock-bottom{
  display:flex;
  justify-content:space-between;
  gap:10px;
  align-items:center;
  color:#91a7c1;
  margin-top:10px;
  font-size:10.5px;
}
.safe-zone-mock-actions{
  display:flex;
  gap:7px;
  align-items:center;
}
.safe-zone-mock-actions i{
  width:6px;
  height:6px;
  border-radius:50%;
  background:#526782;
}
.safe-zone-placement-note{
  margin:0 14px 14px;
  color:var(--txt2);
  font-size:12px;
  line-height:1.45;
}
.safe-zone-placement-note span{
  display:block;
  margin-top:9px;
  color:var(--txt3);
  font-size:10.5px;
  font-family:'DM Mono',monospace;
}
@media(max-width:900px){
  .safe-zone-workbench{grid-template-columns:1fr;}
  .safe-zone-control-panel{grid-template-columns:1fr 1fr;}
  .safe-zone-panel-section+.safe-zone-panel-section{
    border-left:0;
    padding-left:0;
    border-top:1px solid var(--border);
    padding-top:12px;
  }
  .safe-zone-placement-list{max-height:220px;}
}
@media(max-width:640px){
  .safe-zone-app-body{padding:10px;}
  .safe-zone-app-head{display:block;padding:16px;}
  .safe-zone-head-pill{margin-top:12px;}
  .safe-zone-workbench{padding:12px;gap:12px;}
  .safe-zone-control-panel{grid-template-columns:1fr;}
  .safe-zone-upload-drop{min-height:96px;}
  .safe-zone-preview-toolbar{display:block;}
  .safe-zone-legend{justify-content:flex-start;min-width:0;margin-top:13px;}
  .safe-zone-preview-grid{grid-template-columns:1fr;}
  .safe-zone-control-panel,
  .safe-zone-preview-panel{border-radius:var(--r-lg);}
  .safe-zone-danger-zone{font-size:8.5px;}
  .safe-zone-safe-rect::after{font-size:8.5px;}
}

/* ── KPI tiles: animation + sparkline ── */
.kpi{overflow:hidden;transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .2s cubic-bezier(.4,0,.2,1),border-color .2s cubic-bezier(.4,0,.2,1);opacity:0;transform:translateY(8px);animation:kpiIn .5s cubic-bezier(.4,0,.2,1) forwards;}
.kpi:hover{transform:translateY(-2px);box-shadow:0 4px 14px rgba(15,23,42,.08);border-color:var(--border-2);}
:root.dark .kpi:hover{box-shadow:0 4px 14px rgba(0,0,0,.4);}
#kpis .kpi:nth-child(1){animation-delay:.05s;}
#kpis .kpi:nth-child(2){animation-delay:.10s;}
#kpis .kpi:nth-child(3){animation-delay:.15s;}
#kpis .kpi:nth-child(4){animation-delay:.20s;}
#kpis .kpi:nth-child(5){animation-delay:.25s;}
#kpis .kpi:nth-child(6){animation-delay:.30s;}
#kpis .kpi:nth-child(7){animation-delay:.35s;}
#kpis .kpi:nth-child(8){animation-delay:.40s;}
@keyframes kpiIn{to{opacity:1;transform:translateY(0);}}
.kpi-spark{height:28px;margin:6px -4px 0;pointer-events:none;}
.kpi-spark svg{width:100%;height:100%;overflow:visible;}
.kpi-spark-line{stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:500;stroke-dashoffset:500;animation:drawSpark 1.1s cubic-bezier(.4,0,.2,1) forwards;animation-delay:.3s;}
.kpi-spark-fill{opacity:0;animation:fillIn .5s cubic-bezier(.4,0,.2,1) forwards;animation-delay:1s;}
@keyframes drawSpark{to{stroke-dashoffset:0;}}
@keyframes fillIn{to{opacity:1;}}

/* ── Sections fade in ── */
.section.on{animation:sectionIn .35s cubic-bezier(.4,0,.2,1);}
@keyframes sectionIn{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:translateY(0);}}

/* ═══ BENCHMARK REDESIGN ═══ */
.bench-hero{background:linear-gradient(135deg,var(--surface,var(--card)) 0%,var(--surface-2,var(--card2)) 100%);border:1px solid var(--border);border-radius:var(--r-lg,14px);padding:18px 22px;margin-bottom:16px;display:flex;align-items:center;gap:18px;box-shadow:0 1px 2px rgba(15,23,42,.04);position:relative;overflow:hidden;}
.bench-hero::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--accent),#0891b2);}
.bench-hero-icon{width:44px;height:44px;border-radius:12px;background:var(--abg);color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.bench-hero-text{flex:1;min-width:0;}
.bench-hero-label{font-size:10px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px;}
.bench-hero-headline{font-size:16px;font-weight:600;color:var(--txt);line-height:1.4;}
.bench-hero-headline b{color:var(--accent);font-weight:700;}
.bench-hero-headline .pill-good{display:inline-block;padding:2px 8px;background:var(--gbg,rgba(22,163,74,.1));color:var(--green,#16a34a);border-radius:5px;font-size:13px;font-weight:700;margin:0 2px;}

/* HTML bars */
.bench-bars{display:flex;flex-direction:column;gap:14px;padding:4px 0;}
.bench-bar-row{display:grid;grid-template-columns:120px 1fr 130px;gap:14px;align-items:center;transition:transform .18s cubic-bezier(.4,0,.2,1);}
.bench-bar-row:hover{transform:translateX(2px);}
.bench-bar-label{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--txt);min-width:0;}
.bench-bar-logo{width:22px;height:22px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:11px;flex-shrink:0;}
.bench-bar-track{height:26px;background:var(--bg);border:1px solid var(--border);border-radius:7px;position:relative;overflow:visible;}
.bench-bar-fill{height:100%;border-radius:6px;position:relative;width:0;transition:width .9s cubic-bezier(.4,0,.2,1);}
.bench-bar-fill::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.12));border-radius:6px;}
.bench-bar-avg{position:absolute;top:-4px;bottom:-4px;width:2px;background:var(--txt3);opacity:.45;border-radius:1px;z-index:2;}
.bench-bar-avg::before{content:"avg";position:absolute;top:-13px;left:50%;transform:translateX(-50%);font-size:9px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:.06em;}
.bench-bar-values{display:flex;flex-direction:column;align-items:flex-end;gap:2px;}
.bench-bar-val{font-size:14px;font-weight:700;color:var(--txt);font-variant-numeric:tabular-nums;font-family:'DM Mono',monospace;}
.bench-bar-delta{font-size:11px;font-weight:600;display:flex;align-items:center;gap:3px;white-space:nowrap;}
.bench-bar-delta.good{color:var(--green,#16a34a);}
.bench-bar-delta.bad{color:var(--red,#dc2626);}
.bench-bar-row:hover .bench-bar-fill{filter:brightness(1.08);}

/* ── MOBILE BOTTOM NAV ── */
.mnav{display:none;position:fixed;bottom:0;left:0;right:0;background:rgba(255,255,255,.94);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-top:1px solid var(--border);z-index:95;padding:6px 6px calc(6px + env(safe-area-inset-bottom));}
:root.dark .mnav{background:rgba(7,14,26,.94);}
.mnav-inner{display:grid;grid-template-columns:repeat(auto-fit,minmax(64px,1fr));max-width:640px;margin:0 auto;}
.mnav-btn{display:flex;flex-direction:column;align-items:center;gap:3px;padding:7px 4px;font-size:10.5px;font-weight:600;color:var(--txt3);transition:color .18s;border-radius:8px;background:transparent;border:none;cursor:pointer;font-family:inherit;}
.mnav-btn svg{width:20px;height:20px;transition:transform .18s;}
.mnav-btn.on{color:var(--accent);}
.mnav-btn.on svg{transform:translateY(-1px);}

/* ── MOBILE RESPONSIVE — aligned to App.html's 640px breakpoint ── */
@media (max-width:640px){
  /* Hide existing mobile dropdown, use new bottom nav instead */
  .bar-row2{display:none !important;}
  .mnav{display:block;}
  body{padding-bottom:72px;}
  footer{margin-bottom:72px !important;}

  /* Filter group labels hidden; dividers hidden; groups stretch to fill */
  .filt-group-lbl{display:none;}
  .filt-group{flex:1 1 auto;min-width:0;}
  .toolbar .div{display:none;}

  /* Bench bars: tighter columns */
  .bench-bar-row{grid-template-columns:95px 1fr 95px;gap:10px;}
  .bench-bar-label{font-size:12px;}
  .bench-bar-label > span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .bench-bar-logo{width:20px;height:20px;font-size:10px;}
  .bench-bar-val{font-size:13px;}
  .bench-bar-delta{font-size:10px;}

  /* Hero insight */
  .bench-hero{padding:14px 16px;gap:12px;}
  .bench-hero-icon{width:38px;height:38px;}
  .safe-zone-app-body{padding:10px;}
  .safe-zone-app-shell{border-radius:14px;min-height:calc(100vh - 125px);}
  .safe-zone-app-head{flex-direction:column;padding:16px;}
  .safe-zone-app-head h2{font-size:22px;}
  .bench-hero-headline{font-size:14px;}

  /* KPI sparkline smaller on mobile */
  .kpi-spark{height:22px;}
}
@media (max-width:480px){
  .bench-bar-row{grid-template-columns:80px 1fr 82px;}
}

/* ══ Column chart (Benchmark top performers) ══ */
.col-chart{display:flex;align-items:stretch;justify-content:space-around;gap:6px;padding:4px 0 2px;position:relative;}
.col-chart-empty{color:var(--txt3);font-size:12px;text-align:center;width:100%;padding:60px 0;}
.col-bar{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;gap:5px;position:relative;transition:transform .2s cubic-bezier(.4,0,.2,1);cursor:default;}
.col-bar:hover{transform:translateY(-2px);}
.col-bar-val{font-size:10.5px;font-weight:700;color:var(--txt);font-family:'DM Mono',monospace;white-space:nowrap;min-height:14px;}
.col-bar-track{width:100%;max-width:42px;height:140px;display:flex;align-items:flex-end;justify-content:center;position:relative;}
.col-bar-fill{width:100%;background:var(--accent);border-radius:6px 6px 2px 2px;height:0;transition:height .9s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;}
.col-bar-fill::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.18) 0%,transparent 60%);border-radius:6px 6px 0 0;}
.col-bar:hover .col-bar-fill{filter:brightness(1.08);}
.col-bar-label{font-size:10px;color:var(--txt2);text-align:center;line-height:1.2;margin-top:2px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;max-width:100%;word-break:break-word;min-height:24px;}
.col-bar-plat{font-size:9px;color:var(--txt3);margin-top:1px;text-transform:uppercase;letter-spacing:.05em;}
.col-bar-tip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);background:var(--txt);color:var(--surface,var(--card));padding:6px 10px;border-radius:6px;font-size:11px;font-weight:500;white-space:normal;max-width:200px;text-align:center;opacity:0;pointer-events:none;transition:opacity .15s;z-index:5;box-shadow:0 4px 12px rgba(0,0,0,.18);}
.col-bar:hover .col-bar-tip{opacity:1;}

/* Metric add menu */
#benchMetAddMenu.on{display:block !important;}
#benchMetAddMenu .mma-item{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-radius:5px;cursor:pointer;font-size:12px;color:var(--txt);transition:background .12s;}
#benchMetAddMenu .mma-item:hover{background:var(--surface-2,var(--card2));}
#benchMetAddMenu .mma-item.in{color:var(--txt3);}
#benchMetAddMenu .mma-item .mma-check{color:var(--accent);font-weight:700;}
.bench-control-stack{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap;justify-content:flex-end;}
.bench-control-group{display:flex;flex-direction:column;gap:5px;align-items:flex-end;}
.bench-control-label{font-size:9.5px;font-weight:700;color:var(--txt3);text-transform:uppercase;letter-spacing:.08em;}
.bench-chip-row{display:flex;gap:4px;background:var(--bg);padding:3px;border-radius:7px;flex-wrap:wrap;max-width:100%;overflow-x:auto;scrollbar-width:auto;}
.bench-chip-row::-webkit-scrollbar{height:8px;}

@media (max-width:900px){
  .bench-top-row{grid-template-columns:1fr !important;}
  .bench-control-stack{justify-content:flex-start;width:100%;}
  .bench-control-group{align-items:flex-start;width:100%;}
}
@media (max-width:640px){
  .col-chart{height:180px;padding:16px 2px 2px;}
  .col-bar-fill{max-width:36px;}
  .col-bar-val{font-size:9.5px;}
  .col-bar-label{font-size:9px;}
}
