:root{
  --purple:#6546fd; --purple-dark:#4a2fe0; --cyan:#00E5CC;
  --bg:#F8FAFC; --card:#ffffff;
  --ink-1:#0F172A; --ink-2:#334155; --ink-3:#94A3B8; --line:#E2E8F0;
  --green:#16A34A; --red:#DC2626;
  --sidebar:linear-gradient(180deg,#1a1a2e 0%,#16213e 100%);
  --mono:"SFMono-Regular",Consolas,"Liberation Mono",Menlo,monospace;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  background:var(--bg); color:var(--ink-1);
  font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  font-size:14px; line-height:1.5; -webkit-font-smoothing:antialiased;
}
.hidden{display:none !important}
.eyebrow{font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3)}

/* ---------- Shell ---------- */
.shell{display:flex;min-height:100vh}

/* ---------- Sidebar ---------- */
.sidebar{
  width:240px;flex:none;background:var(--sidebar);color:#cdd3e6;
  position:sticky;top:0;height:100vh;display:flex;flex-direction:column;padding:20px 14px;gap:6px;
}
.sb-brand{display:flex;align-items:center;gap:11px;padding:6px 8px 16px}
.sb-brand .mark{width:38px;height:38px;border-radius:11px;flex:none;display:grid;place-items:center;
  font-weight:700;font-size:19px;color:#fff;background:linear-gradient(135deg,var(--cyan),var(--purple))}
.sb-brand strong{color:#fff;font-size:15px;display:block;line-height:1.2}
.sb-brand span{font-size:11.5px;color:#8b93b5}
.sb-label{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:#6b7299;padding:14px 10px 6px}
.navlink{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:9px;color:#c2c8e0;
  font-size:13.5px;cursor:pointer;border:none;background:none;text-align:left;width:100%;font-family:inherit}
.navlink:hover{background:rgba(255,255,255,.06);color:#fff}
.navlink.active{background:var(--purple);color:#fff;font-weight:500}
.navlink.wip{color:#6b7299;opacity:.6}
.navlink.wip:hover{color:#9aa3c4;background:rgba(255,255,255,.04)}
.navlink.wip.active{background:#3a3f5c;color:#cfd4e8;opacity:1}
.wip-tag{font-family:var(--mono);font-size:9.5px;letter-spacing:.04em;opacity:.85;margin-left:auto}
.sb-foot{margin-top:auto;display:flex;flex-direction:column;gap:8px;padding-top:14px}
.sb-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;border-radius:10px;
  border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.05);color:#e7eaf6;cursor:pointer;
  font-size:13px;font-family:inherit;backdrop-filter:blur(4px)}
.sb-btn:hover{background:rgba(255,255,255,.12)}
.sb-status{font-size:12px;color:var(--cyan);display:flex;align-items:center;gap:6px}
.sb-status .dot{width:7px;height:7px;border-radius:50%;background:var(--cyan)}
.sb-meta{font-family:var(--mono);font-size:10px;color:#5e6488}

/* ---------- Main ---------- */
.main{flex:1;min-width:0;padding:28px 32px 48px}
.page-head{margin-bottom:20px}
.page-head h1{margin:0;font-size:21px;font-weight:700;letter-spacing:-.01em}
.page-head p{margin:5px 0 0;color:var(--ink-3);font-size:13.5px}

/* ---------- Control bar ---------- */
.controlbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:18px}
.pillset{display:inline-flex;background:#fff;border:1px solid var(--line);border-radius:999px;padding:3px}
.pill{border:none;background:none;padding:6px 14px;border-radius:999px;cursor:pointer;font-family:inherit;
  font-size:12px;color:var(--ink-2);white-space:nowrap}
.pill.active{background:var(--purple);color:#fff;font-weight:500}
.chip{font-family:var(--mono);font-size:11.5px;border:1px solid var(--line);background:#fff;color:var(--ink-2);
  padding:6px 11px;border-radius:999px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;position:relative}
.chip:hover{border-color:var(--ink-3)}
.chip .ct{color:var(--purple);font-weight:600}
.spacer{flex:1}

/* Filters button + panel */
.filter-wrap{position:relative}
#btn-filters{font-size:12px;padding:7px 14px}
#btn-filters .ct{margin-left:2px}
.filter-panel{position:absolute;right:0;top:120%;z-index:40;width:min(740px,88vw);max-height:72vh;overflow:auto;
  background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 18px 48px rgba(15,23,42,.18);padding:16px}
.fp-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.fp-head strong{font-size:14px}
.btn-link{background:none;border:none;color:var(--purple);cursor:pointer;font-size:12.5px;font-family:inherit}
#slicer-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(215px,1fr));gap:10px}
.fgroup{border:1px solid var(--line);border-radius:10px}
.fgroup>summary{list-style:none;cursor:pointer;font-size:12.5px;font-weight:600;color:var(--ink-1);
  padding:9px 11px;display:flex;justify-content:space-between;align-items:center}
.fgroup>summary::-webkit-details-marker{display:none}
.fgroup>summary::after{content:"▾";color:var(--ink-3);font-size:10px}
.fgroup[open]>summary::after{content:"▴"}
.fgroup .count{color:var(--purple);font-weight:700;font-size:11px;margin-left:6px}
.fgroup .opts{max-height:190px;overflow:auto;padding:2px 8px 8px;border-top:1px solid var(--line)}
.fgroup .opt{display:flex;gap:8px;align-items:center;font-size:12px;color:var(--ink-2);padding:4px 2px;cursor:pointer;font-weight:400}
.fgroup .opt input{accent-color:var(--purple)}
.fsubgroup{border-top:1px solid var(--line)}
.fsubgroup:first-child{border-top:none}
.fsubgroup>summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:6px;padding:6px 2px}
.fsubgroup>summary::-webkit-details-marker{display:none}
.fsubgroup>summary::after{content:"▾";color:var(--ink-3);font-size:9px}
.fsubgroup[open]>summary::after{content:"▴"}
.fsubgroup .opt.grp{font-weight:600;color:var(--ink-1);margin:0;padding:0;flex:1}
.fsubgroup .subcount{color:var(--purple);font-size:10px;font-weight:700;min-width:12px;text-align:right}
.fgroup .opt.sub{padding-left:20px;color:var(--ink-2)}
.fgroup .opt.selall{font-weight:600;color:var(--purple);border-bottom:1px solid var(--line);margin-bottom:3px;padding-bottom:5px}

/* slicer dropdowns (chip-style) */
details.slicer{position:relative}
details.slicer>summary{list-style:none;font-family:var(--mono);font-size:11.5px;border:1px solid var(--line);
  background:#fff;color:var(--ink-2);padding:6px 11px;border-radius:999px;cursor:pointer;display:inline-flex;
  align-items:center;gap:6px;white-space:nowrap}
details.slicer>summary::-webkit-details-marker{display:none}
details.slicer[open]>summary{border-color:var(--purple);color:var(--purple)}
details.slicer .opts{position:absolute;z-index:30;top:110%;left:0;min-width:200px;max-height:260px;overflow:auto;
  background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:0 12px 32px rgba(15,23,42,.14);padding:8px}
details.slicer .opts label{display:flex;gap:8px;align-items:center;font-size:12.5px;color:var(--ink-2);padding:4px 6px;
  border-radius:6px;cursor:pointer}
details.slicer .opts label:hover{background:var(--bg)}
details.slicer .opts input{accent-color:var(--purple)}
.summary-count{color:var(--purple);font-weight:600}

/* date range slider */
.daterange{display:flex;align-items:center;gap:10px;width:100%;margin:2px 0 18px}
.dr-end{font-family:var(--mono);font-size:11px;color:var(--ink-2);background:#fff;border:1px solid var(--line);
  border-radius:7px;padding:4px 9px;white-space:nowrap}
.dr-sliders{position:relative;height:58px;flex:1}
.dr-sliders input[type=range]{position:absolute;left:0;top:0;width:100%;margin:0;-webkit-appearance:none;background:none;pointer-events:none;height:24px}
.dr-sliders input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;pointer-events:auto;width:15px;height:15px;border-radius:50%;background:#fff;border:3px solid var(--purple);cursor:pointer;margin-top:-6px;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.dr-sliders input[type=range]::-moz-range-thumb{pointer-events:auto;width:15px;height:15px;border-radius:50%;background:#fff;border:3px solid var(--purple);cursor:pointer}
.dr-track{position:absolute;left:0;right:0;top:10px;height:4px;border-radius:2px;background:var(--line)}
.dr-fill{position:absolute;top:10px;height:4px;border-radius:2px;background:var(--purple)}
.dr-notches{position:absolute;left:0;right:0;top:6px;height:12px;pointer-events:none;opacity:.6}
.dr-axis{position:absolute;left:0;right:0;top:22px;height:34px;pointer-events:none}
.dr-axis .tick{position:absolute;transform:translateX(-50%);text-align:center}
.dr-axis .tick::before{content:"";position:absolute;top:-4px;left:50%;width:1px;height:4px;background:var(--line);transform:translateX(-50%)}
.dr-axis .tick .tl{display:block;font-family:var(--mono);font-size:8.5px;color:var(--ink-3);line-height:1.2}
.dr-axis .tick-fy::before{height:8px;top:-8px;background:var(--purple)}
.dr-axis .tick-fy .tl{color:var(--ink-2);font-weight:600}
.dr-axis .tick .fy{display:block;font-family:var(--mono);font-size:8.5px;color:var(--purple);font-weight:600;white-space:nowrap;margin-top:1px}

/* ---------- KPI tiles ---------- */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:18px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px 18px;box-shadow:0 1px 2px rgba(15,23,42,.04)}
.kpi .l{font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-3);margin-bottom:8px}
.kpi .v{font-size:25px;font-weight:700;letter-spacing:-.01em;font-variant-numeric:tabular-nums}
.kpi .sub{font-size:11.5px;color:var(--ink-3);margin-top:3px}
.kpi.purple .v{color:var(--purple)} .kpi.teal .v{color:#0c9b88}
.kpi .deltas{display:flex;flex-direction:column;gap:3px;margin-top:9px}
.delta{font-size:11px;font-variant-numeric:tabular-nums;display:flex;gap:6px;align-items:baseline}
.delta .dl{font-family:var(--mono);font-size:9.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);min-width:30px}
.delta.up{color:var(--green)} .delta.down{color:var(--red)} .delta.na{color:var(--ink-3)}

/* fullscreen card */
.card:fullscreen{padding:28px;background:#fff;overflow:auto}
.card:fullscreen canvas{max-height:none;height:80vh !important}
.card:-webkit-full-screen{padding:28px;background:#fff}

/* ---------- Cards & charts ---------- */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px;box-shadow:0 1px 2px rgba(15,23,42,.04);margin-bottom:16px}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:10px}
.card-head h3{margin:0;font-size:14px;font-weight:600;color:var(--ink-1);display:flex;align-items:center;gap:8px}
.card-head h3::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--purple)}
.card-actions{display:flex;align-items:center;gap:8px}
.icon-btn{border:1px solid var(--line);background:#fff;color:var(--ink-2);border-radius:8px;padding:5px 9px;
  cursor:pointer;font-size:11.5px;font-family:var(--mono);display:inline-flex;align-items:center;gap:5px}
.icon-btn:hover{border-color:var(--purple);color:var(--purple)}
.info-btn{width:24px;height:24px;padding:0;justify-content:center;border-radius:50%;font-style:italic;font-weight:700;font-family:Georgia,serif;font-size:13px;line-height:1}
.chart-card canvas{max-height:330px}
/* Chart info modal */
.ci-modal{position:fixed;inset:0;background:rgba(15,23,42,.45);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}
.ci-modal.hidden{display:none}
.ci-box{position:relative;background:#fff;border-radius:14px;max-width:560px;width:100%;max-height:80vh;overflow:auto;padding:24px 26px;box-shadow:0 20px 50px rgba(0,0,0,.25)}
.ci-close{position:absolute;top:12px;right:14px;border:none;background:none;font-size:16px;color:var(--ink-3);cursor:pointer}
.ci-close:hover{color:var(--ink-1)}
.ci-content h3{margin:0 28px 14px 0;font-size:16px;color:var(--ink-1)}
.ci-content h4{margin:14px 0 4px;font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--purple)}
.ci-content p{margin:0;font-size:13px;line-height:1.5;color:var(--ink-2)}
.split-label{font-family:var(--mono);font-size:11px;color:var(--ink-3);display:flex;align-items:center;gap:6px}
.split-label select{font-family:inherit;font-size:12px;border:1px solid var(--line);border-radius:8px;padding:5px 8px;color:var(--ink-2);background:#fff}

/* ---------- Tables ---------- */
.table-scroll{max-height:420px;overflow:auto;border-radius:10px;border:1px solid var(--line)}
.tbl-search-wrap{margin-bottom:8px}
.tbl-search{width:100%;max-width:320px;font-family:var(--mono);font-size:12px;border:1px solid var(--line);border-radius:8px;padding:6px 10px;color:var(--ink-2);background:#fff}
.tbl-search::placeholder{color:var(--ink-3)}
.tbl-search:focus{outline:none;border-color:var(--purple)}
table{width:100%;border-collapse:separate;border-spacing:0;font-size:12px}
th,td{text-align:left;padding:9px 12px;border-bottom:1px solid var(--line);white-space:nowrap}
th{position:sticky;top:0;background:var(--bg);color:var(--ink-3);font-weight:600;font-family:var(--mono);
  text-transform:uppercase;font-size:10.5px;letter-spacing:.05em}
tbody tr:hover{background:#f6f8fc}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}
td:first-child{position:sticky;left:0;background:#fff;box-shadow:1px 0 0 var(--line)}
tbody tr:hover td:first-child{background:#f6f8fc}
a.deal-link{color:var(--purple);text-decoration:none;border-bottom:1px dotted var(--purple)}
a.deal-link:hover{text-decoration:none;border-bottom-style:solid}
a.excl-link{color:#c2c8d4;text-decoration:none;font-weight:700;cursor:pointer;padding:0 2px}
a.excl-link:hover{color:#d4351c}
.excluded-bar{background:#fff4e5;border:1px solid #f3c98a;border-radius:10px;padding:8px 12px;margin-bottom:10px;font-size:12.5px;color:var(--ink-2)}
.excl-chip{display:inline-block;background:#fff;border:1px solid var(--line);border-radius:12px;padding:2px 8px;margin:2px 4px}
.excl-chip .excl-restore{color:var(--purple);text-decoration:none;cursor:pointer;font-weight:700;margin-left:4px}
.excl-clear{color:var(--purple);cursor:pointer;text-decoration:underline;margin-left:8px;white-space:nowrap}
.att-wrap{display:inline-flex;align-items:center;gap:8px;justify-content:flex-end}
.att-bar{display:inline-block;width:90px;height:8px;border-radius:5px;background:#eef1f6;overflow:hidden}
.att-bar span{display:block;height:100%;border-radius:5px}
tbody tr.excluded-row td{background:#fdecea !important;color:#b32d1f;text-decoration:line-through}
tbody tr.excluded-row td a{color:#b32d1f}
tbody tr.excluded-row td a.excl-restore{text-decoration:none;font-weight:700}

/* login overlay */
.login-overlay{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#1e1b4b,#312e81)}
.login-card{background:#fff;border-radius:16px;padding:32px;width:360px;max-width:92vw;box-shadow:0 24px 60px rgba(0,0,0,.35)}
.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:6px}
.login-brand .mark{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:9px;
  background:var(--purple);color:#fff;font-weight:700}
.login-brand strong{display:block;font-size:15px}
.login-brand span{font-size:11px;color:var(--ink-3)}
.login-sub{color:var(--ink-3);font-size:13px;margin:10px 0 18px}
.login-card label{display:block;font-size:12px;color:var(--ink-2);margin-bottom:6px;font-weight:600}
.login-card input{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:9px;font-size:14px;margin-bottom:14px;box-sizing:border-box}
.login-card input:focus{outline:none;border-color:var(--purple);box-shadow:0 0 0 3px rgba(101,70,253,.15)}
.login-btn{width:100%;padding:11px;border:none;border-radius:9px;background:var(--purple);color:#fff;font-weight:600;font-size:14px;cursor:pointer}
.login-btn:hover{filter:brightness(1.05)}
.login-btn:disabled{opacity:.6;cursor:default}
.login-link{display:block;width:100%;margin-top:10px;background:none;border:none;color:var(--purple);font-size:12px;cursor:pointer}
.login-msg{margin-top:14px;font-size:12.5px;min-height:16px}
.login-msg.err{color:#d4351c}
.login-msg.ok{color:#2fa37f}

/* badge / status in header */
.badge{font-family:var(--mono);font-size:10.5px;font-weight:600;padding:4px 10px;border-radius:999px;letter-spacing:.04em}
.badge.live{background:rgba(0,229,204,.14);color:#0c9b88;border:1px solid rgba(0,229,204,.4)}
.badge.sample{background:#fff4e5;color:#b45309;border:1px solid #fed7aa}
.sync-text{font-size:11.5px;color:var(--ink-3)}

/* column picker */
.cols-wrap{position:relative}
.cols-panel{position:absolute;right:0;top:120%;z-index:40;width:230px;max-height:300px;overflow:auto;
  background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:0 14px 36px rgba(15,23,42,.16);padding:8px}
.cols-panel label{display:flex;gap:8px;align-items:center;font-size:12px;color:var(--ink-2);padding:4px 6px;border-radius:6px;cursor:pointer}
.cols-panel label:hover{background:var(--bg)}
.cols-panel input{accent-color:var(--purple)}
tfoot td{position:sticky;bottom:0;background:#f1f5fb;font-weight:600;color:var(--ink-1);border-top:2px solid var(--line)}

/* fullscreen overlay */
.fs-overlay{position:fixed;inset:0;background:rgba(15,23,42,.55);z-index:100;display:flex;padding:32px}
.fs-inner{background:#fff;border-radius:14px;flex:1;padding:20px;overflow:auto;position:relative}

@media (max-width:1000px){
  .sidebar{display:none}
  .grid-2{grid-template-columns:1fr}
  .main{padding:18px}
}

/* Discounting page — pricing breakdown cell (workflow output) */
.disc-breakdown { display:block; max-width:340px; font-family:"DM Mono",ui-monospace,Menlo,Consolas,monospace;
  font-size:10px; line-height:1.45; color:var(--ink-2); white-space:normal; }
td:has(> .disc-breakdown) { vertical-align:top; }

/* Discounting — "view breakdown" button + pop-out modal */
.disc-bd-btn { font:500 10px Inter,system-ui,sans-serif; color:var(--purple); background:rgba(169,156,240,.12);
  border:1px solid rgba(169,156,240,.35); border-radius:6px; padding:1px 6px; margin-left:6px; cursor:pointer; white-space:nowrap; }
.disc-bd-btn:hover { background:rgba(169,156,240,.25); }
.disc-modal { position:fixed; inset:0; z-index:1000; display:flex; align-items:center; justify-content:center;
  background:rgba(15,23,42,.55); backdrop-filter:blur(2px); }
.disc-modal.hidden { display:none; }
.disc-modal-box { background:var(--surface,#fff); color:var(--ink-1,#0F172A); width:min(560px,92vw); max-height:82vh;
  border-radius:12px; box-shadow:0 24px 70px rgba(0,0,0,.4); display:flex; flex-direction:column; overflow:hidden; }
.disc-modal-head { display:flex; align-items:center; justify-content:space-between; gap:10px;
  padding:12px 16px; border-bottom:1px solid var(--line,#E2E8F0); }
.disc-modal-head h3 { margin:0; font:600 14px Inter,system-ui,sans-serif; }
.disc-modal-x { border:none; background:none; font-size:16px; cursor:pointer; color:var(--ink-3,#64748b); line-height:1; }
.disc-modal-body { margin:0; padding:16px; overflow:auto; white-space:pre-wrap;
  font-family:"DM Mono",ui-monospace,Menlo,Consolas,monospace; font-size:12px; line-height:1.55; }

/* Discounting breakdown modal — match dashboard font + larger/clearer (overrides above) */
.disc-modal-box { width:min(700px,94vw); max-height:88vh; border-radius:14px; }
.disc-modal-head { padding:16px 24px; }
.disc-modal-head h3 { font:600 18px Inter,system-ui,sans-serif; }
.disc-modal-body { padding:22px 26px; font-family:Inter,system-ui,sans-serif; font-size:15px;
  line-height:1.85; color:var(--ink-1,#0F172A); white-space:pre-wrap; }

/* Discounting — % discount colour scale (≤0 green · 0–10 amber · >10 red) */
.disc-chip { display:inline-block; min-width:52px; text-align:center; padding:1px 8px; border-radius:999px;
  font-weight:600; font-size:11px; }
.disc-chip.disc-g { background:rgba(34,163,127,.16); color:#15803d; }
.disc-chip.disc-y { background:rgba(243,201,138,.28); color:#a16207; }
.disc-chip.disc-r { background:rgba(235,154,154,.24); color:#b91c1c; }

/* Monthly Deal Movement — movement chip */
.mv-chip { display:inline-block; padding:1px 8px; border-radius:999px; font-weight:600; font-size:11px; color:#0F172A; }
