:root{
  --sans:-apple-system,BlinkMacSystemFont,"SF Pro Display","Inter",system-ui,"Helvetica Neue",Arial,sans-serif;
  --side-bg:#0d0d0f;--side-bg2:#141417;
  --bg:#f1efe8;--card:#ffffff;--bg-3:#ece9df;
  --text:#15161a;--muted:rgba(21,22,26,.6);--faint:rgba(21,22,26,.4);
  --gold:#a6842f;--goldbar:#c5b06f;--gold-2:#bb9a45;
  --up:#5d8a44;--down:#bb4a3a;--info:#5d83ab;--warm:#c98b5e;
  --line:rgba(21,22,26,.1);--line-soft:rgba(21,22,26,.055);
  --grid:rgba(21,22,26,.07);--shadow:0 16px 38px -30px rgba(20,20,20,.3);
  --ease:cubic-bezier(.45,0,.12,1);
}
[data-theme="dark"]{
  --bg:#09090a;--card:#111113;--bg-3:#18181c;
  --text:#f4f1ea;--muted:rgba(244,241,234,.6);--faint:rgba(244,241,234,.34);
  --gold:#d8c48c;--goldbar:#c4af6f;--gold-2:#d8c48c;
  --up:#82b369;--down:#cc5e4e;--info:#7ba0c4;--warm:#cc9a5e;
  --line:rgba(244,241,234,.12);--line-soft:rgba(244,241,234,.07);
  --grid:rgba(244,241,234,.06);--shadow:0 24px 50px -34px rgba(0,0,0,.85);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--sans);background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;
  -webkit-font-smoothing:antialiased;letter-spacing:-.011em}
.num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}
a{color:inherit;text-decoration:none}
.app{display:flex;min-height:100vh}

/* SIDEBAR */
.side{width:248px;flex:none;position:fixed;inset:0 auto 0 0;background:var(--side-bg);color:#ece9e2;
  display:flex;flex-direction:column;padding:20px 16px;z-index:60;transition:transform .3s var(--ease)}
.side .logo{display:flex;align-items:center;padding:8px 8px 2px}
.side .logo .logoimg{width:182px;max-width:100%;height:auto;display:block}
.side .prodlabel{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:rgba(236,233,226,.42);font-weight:600;padding:6px 10px 0}
.side .grp{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:rgba(236,233,226,.34);margin:22px 12px 8px;font-weight:600}
.side nav{display:flex;flex-direction:column;gap:3px}
.side nav a{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:11px;color:rgba(236,233,226,.66);
  font-size:13.5px;font-weight:500;transition:background .2s,color .2s}
.side nav a svg{width:18px;height:18px;flex:none}
.side nav a:hover{background:rgba(255,255,255,.05);color:#fff}
.side nav a.active{background:color-mix(in srgb,var(--goldbar) 18%,transparent);color:#fff}
.side nav a.active svg{color:var(--goldbar)}
.side .foot{margin-top:auto;display:flex;align-items:center;gap:10px;padding:10px 8px;border-top:1px solid rgba(255,255,255,.08)}
.side .foot .av{width:32px;height:32px;border-radius:50%;background:linear-gradient(140deg,var(--goldbar),#9c7c33);color:#191307;display:grid;place-items:center;font-weight:700;font-size:13px}
.side .foot .who b{font-size:13px;color:#fff;display:block;font-weight:600}
.side .foot .who span{font-size:11px;color:rgba(236,233,226,.5)}

/* MAIN */
.main{margin-left:248px;flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{position:sticky;top:0;z-index:40;background:var(--side-bg);display:flex;align-items:center;gap:14px;padding:13px 24px}
.burger{display:none;background:none;border:0;color:#ece9e2;cursor:pointer;padding:6px}
.search{flex:1;max-width:600px;display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.09);border-radius:12px;padding:0 14px;height:44px}
.search svg{color:rgba(236,233,226,.5);flex:none}
.search input{flex:1;background:none;border:0;outline:none;color:#ece9e2;font-family:var(--sans);font-size:14px}
.search input::placeholder{color:rgba(236,233,226,.42)}
.tb-r{margin-left:auto;display:flex;align-items:center;gap:10px}
.fresh{display:flex;align-items:center;gap:7px;font-size:12px;color:rgba(236,233,226,.6)}
.fresh .dot{width:7px;height:7px;border-radius:50%;background:var(--up);box-shadow:0 0 0 3px color-mix(in srgb,var(--up) 30%,transparent)}
.iconbtn{width:40px;height:40px;border:1px solid rgba(255,255,255,.1);border-radius:11px;background:rgba(255,255,255,.04);
  color:#ece9e2;cursor:pointer;display:grid;place-items:center;transition:border-color .2s,color .2s}
.iconbtn:hover{border-color:var(--goldbar);color:var(--goldbar)}
.iconbtn.spin svg{animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
[data-theme="light"] .moon{display:none}[data-theme="dark"] .sun{display:none}

.content{padding:24px;display:flex;flex-direction:column;gap:18px}
.page-h{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.page-h h1{font-size:26px;font-weight:700;letter-spacing:-.03em}
.page-h .sub{font-size:13px;color:var(--muted);margin-top:2px}
.btn{display:inline-flex;align-items:center;gap:8px;height:42px;padding:0 18px;border-radius:11px;font-family:var(--sans);
  font-weight:600;font-size:13.5px;cursor:pointer;border:1px solid transparent;transition:.2s}
.btn-dl{background:var(--card);border-color:var(--line);color:var(--text)}
.btn-dl:hover{border-color:var(--gold)}
.btn-sub{background:var(--goldbar);color:#191307}
.btn-sub:hover{filter:brightness(1.06)}
.btn-rst{background:transparent;color:var(--muted)}
.btn-rst:hover{color:var(--text)}

.filters{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.fil{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line);border-radius:11px;padding:0 6px 0 14px;height:42px;font-size:13px;color:var(--muted)}
.fil select{appearance:none;background:none;border:0;outline:none;color:var(--text);font-weight:600;font-family:var(--sans);font-size:13px;cursor:pointer;padding:0 4px}
.fil select option{background:var(--card);color:var(--text)}
.fil svg{opacity:.5}

/* attention */
.attn{display:flex;gap:13px;align-items:center;border:1px solid color-mix(in srgb,var(--gold) 40%,var(--line));
  background:color-mix(in srgb,var(--gold) 9%,var(--card));border-radius:14px;padding:13px 16px}
.attn .ic{width:28px;height:28px;border-radius:8px;flex:none;display:grid;place-items:center;color:var(--gold);background:color-mix(in srgb,var(--gold) 16%,transparent)}
.attn b{font-weight:600}.attn .cnt{font-size:11px;font-weight:700;color:var(--gold);background:color-mix(in srgb,var(--gold) 18%,transparent);padding:1px 7px;border-radius:999px;margin-left:4px}
.attn p{font-size:13px;color:var(--muted)}
.attn .x{margin-left:auto;background:none;border:0;color:var(--faint);cursor:pointer;font-size:18px;padding:2px 4px}
.attn .x:hover{color:var(--text)}
.attn.gone{display:none}

/* grid + cards */
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.card{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:22px;box-shadow:var(--shadow)}
.c3{grid-column:span 3}.c4{grid-column:span 4}.c5{grid-column:span 5}.c6{grid-column:span 6}.c7{grid-column:span 7}.c8{grid-column:span 8}.c12{grid-column:span 12}
.card-h{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}
.card-h h3{font-size:15.5px;font-weight:600;display:flex;align-items:center;gap:8px}
.card-h .q{width:15px;height:15px;color:var(--faint)}
.badge{font-size:10px;letter-spacing:.07em;text-transform:uppercase;font-weight:600;padding:3px 8px;border-radius:999px;border:1px solid var(--line)}
.badge.live{color:var(--up);border-color:color-mix(in srgb,var(--up) 40%,var(--line))}
.badge.stale{color:var(--gold);border-color:color-mix(in srgb,var(--gold) 45%,var(--line))}

/* KPI */
.kpi .k{font-size:12.5px;color:var(--muted);margin-bottom:12px}
.kpi .v{font-size:30px;font-weight:700;letter-spacing:-.03em;line-height:1}
.kpi .r{display:flex;align-items:center;justify-content:space-between;margin-top:12px}
.kpi .spark{height:30px;width:80px}
.delta{display:inline-flex;align-items:center;gap:4px;font-size:12.5px;font-weight:600}
.delta.good{color:var(--up)}.delta.bad{color:var(--down)}
.delta .note{color:var(--faint);font-weight:500;margin-left:2px}

.chart-wrap{position:relative;height:280px}
.chart-wrap.sm{height:210px}
.legend{display:flex;gap:18px;font-size:12px;color:var(--muted);flex-wrap:wrap}
.legend i{display:inline-block;width:12px;height:3px;border-radius:2px;vertical-align:middle;margin-right:6px}

/* funnel */
.fr{display:grid;grid-template-columns:96px 1fr 54px;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line-soft)}
.fr:last-child{border-bottom:0}
.fr .nm{font-size:13px;font-weight:500}
.fr .bar{height:9px;border-radius:5px;background:linear-gradient(90deg,var(--goldbar),var(--gold-2));min-width:5px;transition:width .6s var(--ease)}
.fr .ct{font-size:14px;font-weight:600;text-align:right}

/* donut legend */
.dleg{display:flex;flex-direction:column;gap:9px;margin-top:6px}
.dleg .row{display:flex;align-items:center;gap:9px;font-size:13px}
.dleg .sw{width:10px;height:10px;border-radius:3px;flex:none}
.dleg .row .pc{margin-left:auto;font-weight:600}
.donut-wrap{display:grid;grid-template-columns:150px 1fr;gap:18px;align-items:center}

/* table */
.tbl{width:100%;border-collapse:collapse}
.tbl th{text-align:right;font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--faint);font-weight:600;padding:0 0 12px}
.tbl th:first-child{text-align:left}
.tbl td{padding:11px 0;border-top:1px solid var(--line-soft);font-size:13.5px;text-align:right}
.tbl td:first-child{text-align:left;font-weight:500}
.roas.hi{color:var(--up);font-weight:600}.roas.lo{color:var(--down);font-weight:600}

/* sov */
.sov .row{display:grid;grid-template-columns:140px 1fr 42px;align-items:center;gap:12px;padding:7px 0}
.sov .nm{font-size:13px}.sov .row.me .nm{color:var(--gold);font-weight:600}
.sov .track{height:8px;border-radius:5px;background:var(--bg-3)}
.sov .fill{height:100%;border-radius:5px;background:var(--info)}
.sov .row.me .fill{background:linear-gradient(90deg,var(--goldbar),var(--gold-2))}
.sov .pct{font-size:12.5px;font-weight:600;text-align:right}

/* stat list */
.stlist{display:flex;flex-direction:column;gap:2px}
.stlist .row{display:flex;align-items:center;justify-content:space-between;padding:13px 0;border-bottom:1px solid var(--line-soft)}
.stlist .row:last-child{border-bottom:0}
.stlist .k{font-size:13px;color:var(--muted)}
.stlist .v{font-size:18px;font-weight:600}
.stlist .rt{display:flex;align-items:center;gap:12px}

/* leaderboard */
.lb-tabs{display:flex;gap:6px}
.lb-tab{font-size:12px;font-weight:600;color:var(--muted);background:transparent;border:1px solid var(--line);border-radius:999px;padding:5px 12px;cursor:pointer;transition:.2s}
.lb-tab:hover{color:var(--text)}
.lb-tab.on{background:color-mix(in srgb,var(--goldbar) 16%,transparent);color:var(--gold);border-color:color-mix(in srgb,var(--goldbar) 40%,var(--line))}
.lb{display:flex;flex-direction:column}
.lb .row{display:grid;grid-template-columns:24px 36px 1fr 150px;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line-soft)}
.lb .row:last-child{border-bottom:0}
.lb .rk{font-size:13px;font-weight:700;color:var(--faint);text-align:center}
.lb .row.top .rk{color:var(--gold)}
.lb .av{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;font-size:11.5px;font-weight:700;color:#191307;background:linear-gradient(140deg,var(--goldbar),#9c7c33)}
.lb .mid{display:flex;flex-direction:column;gap:6px;min-width:0}
.lb .nmline{display:flex;align-items:baseline;gap:8px}
.lb .nm{font-size:13.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lb .ro{font-size:11px;color:var(--muted);flex:none}
.lb .bar{height:7px;border-radius:5px;background:var(--bg-3);overflow:hidden}
.lb .bar i{display:block;height:100%;border-radius:5px;background:linear-gradient(90deg,var(--goldbar),var(--gold-2));transition:width .6s var(--ease)}
.lb .right{text-align:right}
.lb .right .gwp{font-size:14px;font-weight:600}
.lb .right .sub{display:flex;align-items:center;justify-content:flex-end;gap:8px;margin-top:3px}
.lb .sec{font-size:11.5px;color:var(--muted)}
.lb .chip{font-size:11px;font-weight:600;padding:2px 8px;border-radius:999px}
.chip.g{color:var(--up);background:color-mix(in srgb,var(--up) 15%,transparent)}
.chip.b{color:var(--down);background:color-mix(in srgb,var(--down) 15%,transparent)}
.chip.n{color:var(--muted);background:var(--bg-3)}
@media(max-width:420px){.lb .row{grid-template-columns:22px 32px 1fr 96px}.lb .ro{display:none}}

/* industry news feed */
.feed{position:relative;max-height:412px;overflow-y:auto;padding-left:24px;padding-right:6px;scrollbar-width:thin;scrollbar-color:var(--line) transparent}
.feed::-webkit-scrollbar{width:6px}.feed::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}
.feed::before{content:"";position:absolute;left:7px;top:4px;bottom:4px;width:1px;background:var(--line)}
.feed .item{position:relative;padding:13px 0;border-bottom:1px solid var(--line-soft)}
.feed .item:last-child{border-bottom:0}
.feed .item::before{content:"";position:absolute;left:-21px;top:17px;width:9px;height:9px;border-radius:50%;background:var(--goldbar);box-shadow:0 0 0 3px var(--card)}
.feed .item:first-child::before{animation:pulse 2.4s ease-in-out infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 3px var(--card)}50%{box-shadow:0 0 0 3px var(--card),0 0 0 6px color-mix(in srgb,var(--goldbar) 28%,transparent)}}
.feed .ihead{display:flex;align-items:center;gap:9px;margin-bottom:5px}
.feed .src{font-size:11.5px;font-weight:600;color:var(--muted)}
.feed .tm{font-size:11.5px;color:var(--faint);margin-left:auto;white-space:nowrap}
.feed .hl{font-size:13.5px;font-weight:600;line-height:1.35;transition:color .2s;cursor:pointer}
.feed .item:hover .hl{color:var(--gold)}
.cat{font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:3px 8px;border-radius:7px;white-space:nowrap}
.cat.reg{color:var(--gold);background:color-mix(in srgb,var(--goldbar) 16%,transparent)}
.cat.pol{color:var(--info);background:color-mix(in srgb,var(--info) 15%,transparent)}
.cat.mkt{color:var(--up);background:color-mix(in srgb,var(--up) 15%,transparent)}
.cat.len{color:var(--warm);background:color-mix(in srgb,var(--warm) 17%,transparent)}
.cat.risk{color:var(--down);background:color-mix(in srgb,var(--down) 15%,transparent)}
.topics{display:flex;flex-wrap:wrap;gap:8px}
.topic{display:inline-flex;align-items:center;gap:6px;font-size:12px;padding:6px 11px;border:1px solid var(--line);border-radius:999px;color:var(--text);background:var(--bg-3)}
.topic .t{font-weight:700;color:var(--up)}.topic .t.dn{color:var(--down)}.topic .t.fl{color:var(--faint)}

.loading{position:relative;overflow:hidden}.loading>*{opacity:.25}
.loading::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--text) 8%,transparent),transparent);transform:translateX(-100%);animation:sh 1.1s infinite}
@keyframes sh{to{transform:translateX(100%)}}

.overlay{display:none}
@media(max-width:1080px){.c8{grid-column:span 12}.c4{grid-column:span 6}.c7{grid-column:span 12}.c5{grid-column:span 12}.c6{grid-column:span 12}}
@media(max-width:900px){
  .side{transform:translateX(-100%)}
  .side.open{transform:none}
  .main{margin-left:0}
  .burger{display:block}
  .overlay.show{display:block;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:55}
  .c3{grid-column:span 6}
}
@media(max-width:560px){
  .content{padding:16px}
  .c3,.c4{grid-column:span 12}
  .search{max-width:none}
  .fresh{display:none}
  .donut-wrap{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){*{animation-duration:.001s!important;transition:none!important}}

/* ===== shared page components ===== */
.pgintro{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}
.pgintro h1{font-size:26px;font-weight:700;letter-spacing:-.03em}
.pgintro .sub{font-size:13px;color:var(--muted);margin-top:3px;max-width:560px}
.seg{display:inline-flex;background:var(--card);border:1px solid var(--line);border-radius:11px;padding:3px}
.seg button{border:0;background:transparent;color:var(--muted);font-family:var(--sans);font-size:13px;font-weight:600;padding:7px 14px;border-radius:8px;cursor:pointer;transition:.2s}
.seg button.on{background:color-mix(in srgb,var(--goldbar) 18%,transparent);color:var(--gold)}
/* data table */
.dtable{width:100%;border-collapse:collapse}
.dtable th{text-align:left;font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--faint);font-weight:600;padding:0 14px 13px 0}
.dtable th.r,.dtable td.r{text-align:right;padding-right:0}
.dtable td{padding:13px 14px 13px 0;border-top:1px solid var(--line-soft);font-size:13.5px;vertical-align:middle}
.dtable tr:hover td{background:color-mix(in srgb,var(--text) 3%,transparent)}
.dtable .nm{font-weight:600}
.who2{display:flex;align-items:center;gap:9px}
.who2 .av{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-size:11px;font-weight:700;color:#191307;background:linear-gradient(140deg,var(--goldbar),#9c7c33);flex:none}
.pill-s{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;padding:3px 10px;border-radius:999px}
.pill-s::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}
.s-green{color:var(--up);background:color-mix(in srgb,var(--up) 13%,transparent)}
.s-amber{color:var(--gold);background:color-mix(in srgb,var(--goldbar) 15%,transparent)}
.s-red{color:var(--down);background:color-mix(in srgb,var(--down) 13%,transparent)}
.s-slate{color:var(--info);background:color-mix(in srgb,var(--info) 14%,transparent)}
/* report cards */
.repgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.repcard{display:flex;flex-direction:column;gap:10px}
.repcard .ic{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;color:var(--gold);background:color-mix(in srgb,var(--goldbar) 14%,transparent)}
.repcard h3{font-size:15px;font-weight:600}
.repcard p{font-size:12.5px;color:var(--muted);flex:1}
.repcard .row{display:flex;gap:8px;margin-top:6px}
/* settings */
.setrow{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 0;border-bottom:1px solid var(--line-soft)}
.setrow:last-child{border-bottom:0}
.setrow .l b{font-size:14px;font-weight:600;display:block}
.setrow .l span{font-size:12.5px;color:var(--muted)}
.switch{width:44px;height:25px;border-radius:999px;background:var(--bg-3);border:1px solid var(--line);position:relative;cursor:pointer;flex:none;transition:background .25s}
.switch::after{content:"";position:absolute;top:2px;left:2px;width:19px;height:19px;border-radius:50%;background:var(--muted);transition:.25s}
.switch.on{background:color-mix(in srgb,var(--goldbar) 60%,transparent)}
.switch.on::after{left:21px;background:#191307}
.inp{width:100%;height:42px;border:1px solid var(--line);border-radius:11px;background:var(--card);color:var(--text);font-family:var(--sans);font-size:14px;padding:0 14px;outline:none}
.inp:focus{border-color:var(--gold)}
.conn{display:flex;align-items:center;gap:13px;padding:14px 0;border-bottom:1px solid var(--line-soft)}
.conn:last-child{border-bottom:0}
.conn .ico{width:38px;height:38px;border-radius:10px;background:var(--bg-3);display:grid;place-items:center;font-weight:700;color:var(--text);flex:none;font-size:13px}
.conn .nm{font-weight:600;font-size:14px}
.conn .meta{font-size:12px;color:var(--muted)}
@media(max-width:1080px){.repgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.repgrid{grid-template-columns:1fr}.dtable .hide-sm{display:none}}

/* password gate */
html:not(.unlocked){overflow:hidden}
.dgate{position:fixed;inset:0;z-index:999;background:var(--bg);display:flex;align-items:center;justify-content:center;padding:24px}
html.unlocked .dgate{display:none}
.dgate .box{width:100%;max-width:360px;text-align:center}
.dgate img{height:46px;width:auto;margin:0 auto 24px;display:block}
.dgate h2{font-size:22px;font-weight:700;letter-spacing:-.02em;margin-bottom:8px;color:var(--text)}
.dgate .psub{color:var(--muted);font-size:13.5px;margin-bottom:22px}
.dgate form{display:flex;flex-direction:column;gap:10px}
.dgate input{height:48px;border:1px solid var(--line);border-radius:12px;background:var(--card);color:var(--text);font-family:var(--sans);font-size:15px;padding:0 16px;outline:none;text-align:center}
.dgate input:focus{border-color:var(--gold)}
.dgate button{height:48px;border:0;border-radius:12px;background:var(--goldbar);color:#191307;font-family:var(--sans);font-weight:600;font-size:14px;cursor:pointer}
.dgate .err{color:var(--down);font-size:13px;min-height:16px;opacity:0}
.dgate.bad .err{opacity:1}
.dgate.bad .box{animation:gsh .36s}
@keyframes gsh{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-7px)}40%,80%{transform:translateX(7px)}}
