/* ===== Adaptive design system — light + dark, follows the device ===== */
:root{
  color-scheme: light dark;
  --bg:#f5f7fb; --surface:#ffffff; --surface-2:#f4f6fb; --border:#e6eaf1; --border-2:#eef1f6;
  --tx:#0f1728; --mut:#667085; --faint:#98a2b3;
  --acc:#3b5bdb; --up:#12996a; --dn:#e0483d; --warn:#b7791f;
  --up-bg:rgba(18,153,106,.10); --dn-bg:rgba(224,72,61,.10); --acc-bg:rgba(59,91,219,.10); --warn-bg:rgba(183,121,31,.12);
  --r:16px; --r-sm:10px; --navh:62px;
  --shadow:0 1px 2px rgba(16,24,40,.04), 0 4px 16px rgba(16,24,40,.05);
  --shadow-sm:0 1px 2px rgba(16,24,40,.06);
}
@media (prefers-color-scheme: dark){
  :root{
    --bg:#0a0e16; --surface:#141a26; --surface-2:#10151f; --border:#242c3b; --border-2:#1c2330;
    --tx:#eef1f7; --mut:#8b93a7; --faint:#5f6b80;
    --acc:#6b8afd; --up:#34c883; --dn:#ff6060; --warn:#ffb020;
    --up-bg:rgba(52,200,131,.13); --dn-bg:rgba(255,96,96,.13); --acc-bg:rgba(107,138,253,.14); --warn-bg:rgba(255,176,32,.13);
    --shadow:none; --shadow-sm:none;
  }
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--bg); color:var(--tx); -webkit-text-size-adjust:100%;
  font:15px/1.55 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif; -webkit-font-smoothing:antialiased}
b{font-weight:650}
a{color:var(--acc); text-decoration:none}
.up{color:var(--up)} .dn{color:var(--dn)} .mut{color:var(--mut)} .sep{color:var(--faint); margin:0 4px}
.lbl{font-size:11px; letter-spacing:.5px; text-transform:uppercase; font-weight:600; color:var(--mut)}

/* ---- top bar ---- */
.topbar{position:sticky; top:0; z-index:30; display:flex; align-items:center; gap:12px;
  padding:14px 20px; padding-top:calc(14px + env(safe-area-inset-top));
  background:color-mix(in srgb, var(--bg) 82%, transparent); backdrop-filter:blur(12px); border-bottom:1px solid var(--border)}
.topbar .brand{font-weight:700; letter-spacing:-.2px; font-size:16px}
.topbar .brand .who{color:var(--mut); font-weight:500}
.topbar .spacer{flex:1}
.topbar .clock{color:var(--mut); font-variant-numeric:tabular-nums; font-size:12.5px}
.logout{font-size:12.5px; color:var(--mut); border:1px solid var(--border); padding:8px 13px; border-radius:10px; min-height:38px; display:inline-flex; align-items:center; background:var(--surface)}
.logout:hover{color:var(--tx); border-color:var(--acc)}

/* ---- market strip ---- */
.strip{border-bottom:1px solid var(--border); background:var(--surface-2)}
.strip-inner{display:flex; gap:10px; overflow-x:auto; padding:12px 20px; -webkit-overflow-scrolling:touch; scrollbar-width:none}
.strip-inner::-webkit-scrollbar{display:none}
.chip{flex:0 0 auto; background:var(--surface); border:1px solid var(--border); border-radius:12px; padding:9px 13px; min-width:104px; box-shadow:var(--shadow-sm)}
.chip .k{font-size:10.5px; color:var(--mut); text-transform:uppercase; letter-spacing:.4px; font-weight:600}
.chip .v{font-weight:650; font-variant-numeric:tabular-nums; margin-top:3px}
.chip.regime.bull{border-color:color-mix(in srgb,var(--up) 40%,var(--border))} .chip.regime.bull .v{color:var(--up)}
.chip.regime.bear{border-color:color-mix(in srgb,var(--dn) 40%,var(--border))} .chip.regime.bear .v{color:var(--dn)}
.chip.regime.range .v{color:var(--warn)} .chip.regime.highvol .v{color:var(--dn)}
.chip.regime.unknown .v{color:var(--mut)}
.chip .spark{display:block; width:100%; height:20px; margin-top:6px}
.chip .spark polyline{fill:none; stroke-width:1.5; vector-effect:non-scaling-stroke}
.chip .spark polyline.up{stroke:var(--up)} .chip .spark polyline.dn{stroke:var(--dn)}
.strip .asof{flex:0 0 auto; align-self:center; color:var(--faint); font-size:11px; padding-left:6px; white-space:nowrap}
.notes{display:flex; flex-wrap:wrap; gap:7px; padding:0 20px 11px}
.note{color:var(--warn); font-size:11.5px; background:var(--warn-bg); border:1px solid color-mix(in srgb,var(--warn) 30%,transparent); border-radius:8px; padding:3px 9px}

/* ---- tabs: top (desktop) + bottom (mobile) ---- */
.tabs{display:none; gap:6px; padding:14px 20px 0; max-width:1180px; margin:0 auto}
.tab{appearance:none; background:transparent; color:var(--mut); border:none; border-radius:10px; padding:10px 16px; font-size:14.5px; font-weight:600; cursor:pointer}
.tabs .tab.active{color:var(--tx); background:var(--surface); box-shadow:var(--shadow-sm)}
.bottomnav{position:fixed; left:0; right:0; bottom:0; z-index:40; display:flex;
  height:calc(var(--navh) + env(safe-area-inset-bottom)); padding-bottom:env(safe-area-inset-bottom);
  background:color-mix(in srgb, var(--bg) 90%, transparent); backdrop-filter:blur(14px); border-top:1px solid var(--border)}
.bottomnav .tab{flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:3px; border-radius:0; background:none; color:var(--mut); font-size:11px}
.bottomnav .tab.active{color:var(--acc)}
.bottomnav .tab svg{width:22px; height:22px; stroke:currentColor; fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round}

/* ---- panes + cards ---- */
main{padding:18px 20px calc(var(--navh) + env(safe-area-inset-bottom) + 24px)}
.tabpane{display:none}
.tabpane.active{display:block}
.grid{display:grid; grid-template-columns:1fr; gap:16px}
.card{background:var(--surface); border:1px solid var(--border); border-radius:var(--r); padding:20px; box-shadow:var(--shadow)}
.card-h{display:flex; align-items:baseline; justify-content:space-between; gap:10px; font-weight:650; font-size:15.5px; margin-bottom:16px}
.card-h .asof{font-weight:400; color:var(--faint); font-size:11px}
.empty{color:var(--mut); padding:10px 0}
.loading{color:var(--mut); padding:24px 20px}
.soon{color:var(--mut); font-size:12px; margin-top:14px; padding-top:12px; border-top:1px dashed var(--border)}
.line{margin-top:10px}

/* ---- hero: money-first ---- */
.hero .hero-top{display:flex; align-items:flex-start; justify-content:space-between; gap:12px}
.hero .hpnl{font-size:38px; font-weight:750; letter-spacing:-.8px; line-height:1.04; margin-top:8px; font-variant-numeric:tabular-nums}
.hero .hsub{color:var(--mut); font-size:13px; margin-top:6px}
.livebadge{color:var(--up); font-size:11px; font-weight:700; letter-spacing:.3px; border:1px solid color-mix(in srgb,var(--up) 45%,transparent); background:var(--up-bg); padding:4px 10px; border-radius:20px; white-space:nowrap; animation:pulse 1.8s ease-in-out infinite}
.badge-flat{color:var(--mut); border:1px solid var(--border); background:var(--surface-2); font-size:11px; font-weight:600; padding:4px 10px; border-radius:20px; white-space:nowrap}
@keyframes pulse{0%,100%{opacity:1} 50%{opacity:.45}}

/* ---- positions list ---- */
.poslist{display:flex; flex-direction:column; margin-top:16px}
.pos{display:flex; align-items:center; justify-content:space-between; gap:12px; padding:13px 0; border-top:1px solid var(--border-2)}
.pos-l{display:flex; flex-direction:column; gap:3px; min-width:0}
.pos-l .sym{font-weight:650}
.pos .posdir{font-size:12px; font-weight:600; color:var(--mut)}
.pos-r{display:flex; flex-direction:column; align-items:flex-end; gap:3px; font-variant-numeric:tabular-nums; white-space:nowrap}
.pos .posentry{font-size:12px; color:var(--mut)}
.pos .pospnl{font-weight:700; font-size:15px}

/* ---- metric row (risk) ---- */
.metrics{display:grid; grid-template-columns:1fr 1fr; gap:12px}
.metric{background:var(--surface-2); border-radius:var(--r-sm); padding:14px 16px}
.metric .mv{font-size:20px; font-weight:700; margin-top:5px; font-variant-numeric:tabular-nums}
.gauge-row{display:grid; grid-template-columns:1fr auto; align-items:center; gap:10px; margin:14px 0 6px}
.gauge{grid-column:1 / -1; height:10px; background:var(--surface-2); border-radius:6px; overflow:hidden; margin-top:8px}
.gauge-fill{height:100%; background:var(--up); border-radius:6px; transition:width .5s ease}
.gauge-fill.warn{background:var(--warn)} .gauge-fill.hot{background:var(--dn)}
.gauge-val{font-variant-numeric:tabular-nums; font-weight:650}
.breaker{display:inline-flex; align-items:center; gap:6px; font-size:12px; font-weight:600; padding:5px 11px; border-radius:20px; margin-top:14px}
.breaker.ok{color:var(--up); background:var(--up-bg)} .breaker.warn{color:var(--warn); background:var(--warn-bg)} .breaker.hot{color:var(--dn); background:var(--dn-bg)}

/* ---- tables ---- */
.tscroll{overflow-x:auto; -webkit-overflow-scrolling:touch}
.tbl{width:100%; border-collapse:collapse; font-variant-numeric:tabular-nums; font-size:13.5px}
.tbl th{font-size:10.5px; color:var(--mut); text-transform:uppercase; letter-spacing:.5px; text-align:left; padding:9px 10px; border-bottom:1px solid var(--border); font-weight:600; white-space:nowrap}
.tbl td{padding:11px 10px; border-bottom:1px solid var(--border-2); white-space:nowrap}
.tbl tr:last-child td{border-bottom:none}
.tbl .r{text-align:right}
.tbl.caps{margin-top:14px}

/* ---- ideas ---- */
.ideas-sub{font-size:11px; color:var(--mut); text-transform:uppercase; letter-spacing:.5px; margin:16px 0 8px; font-weight:600}
.ideas-sub:first-child{margin-top:2px}
.idea{border:1px solid var(--border); border-left:3px solid var(--faint); border-radius:12px; padding:13px 15px; margin-bottom:9px; background:var(--surface)}
.idea-top{display:flex; align-items:center; gap:9px; flex-wrap:wrap}
.idea .sym{font-weight:650}
.idea .dir{font-size:12px; font-weight:600}
.idea .conv{font-size:11px; color:var(--mut); border:1px solid var(--border); border-radius:6px; padding:1px 7px}
.idea .idstatus{font-size:11.5px; color:var(--mut)}
.idea .rnow{margin-left:auto; font-variant-numeric:tabular-nums; font-weight:700; font-size:14px}
.idea-lvls{color:var(--mut); font-size:12px; margin-top:6px; font-variant-numeric:tabular-nums}
.idea-fut{font-size:12px; color:var(--acc); margin-top:5px; font-weight:500}
.tag{font-size:9.5px; font-weight:700; letter-spacing:.4px; padding:2px 7px; border-radius:20px}
.tag.taken{background:var(--acc-bg); color:var(--acc); border:1px solid color-mix(in srgb,var(--acc) 35%,transparent)}
.st-tg{border-left-color:var(--up)} .st-tg .idstatus{color:var(--up)}
.st-sl{border-left-color:var(--dn)} .st-sl .idstatus{color:var(--dn)}
.st-tgsl{border-left-color:var(--warn)} .st-tgsl .idstatus{color:var(--warn)}
.st-open{border-left-color:var(--acc)}
.st-pending{border-left-color:var(--faint)}

/* ---- pre-trade coach ---- */
.coach-flag{font-size:13px; font-weight:600; padding:11px 13px; border-radius:12px; margin-bottom:13px}
.coach-flag.leak{color:var(--dn); background:var(--dn-bg); border:1px solid color-mix(in srgb,var(--dn) 30%,transparent)}
.coach-flag.ok{color:var(--up); background:var(--up-bg); border:1px solid color-mix(in srgb,var(--up) 30%,transparent)}
.coach-stats{display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:13px}
.coach-stats > div{background:var(--surface-2); border-radius:var(--r-sm); padding:12px 14px}
.coach-stats b{display:block; font-size:21px; font-weight:700; font-variant-numeric:tabular-nums}
.coach-stats span{font-size:11px; color:var(--mut)}
.coach-stats > div.up b{color:var(--up)} .coach-stats > div.dn b{color:var(--dn)}
.coach-rule{font-size:12.5px; color:var(--mut); border-top:1px dashed var(--border); padding-top:12px}

/* ---- research ---- */
.stat-row{display:flex; gap:12px}
.stat{flex:1; background:var(--surface-2); border-radius:var(--r-sm); padding:14px; text-align:center}
.sv{font-size:26px; font-weight:750; font-variant-numeric:tabular-nums}
.sk{font-size:11px; color:var(--mut); text-transform:uppercase; letter-spacing:.4px; margin-top:3px}
.learn{font-size:10px; color:var(--mut); border:1px solid var(--border); border-radius:5px; padding:0 5px; margin-left:5px}
.engines{display:flex; flex-direction:column; gap:12px}
.engine{border-top:1px solid var(--border-2); padding-top:12px}
.engine:first-child{border-top:none; padding-top:0}
.ename{font-weight:600; margin-left:9px}
.enote{color:var(--mut); font-size:12px; margin-top:5px}
.pill{display:inline-block; font-size:10.5px; font-weight:700; letter-spacing:.4px; text-transform:uppercase; padding:2px 8px; border-radius:20px; background:var(--surface-2); color:var(--mut); border:1px solid var(--border)}
.pill.live{color:var(--up); background:var(--up-bg); border-color:color-mix(in srgb,var(--up) 35%,transparent)}
.pill.signal{color:var(--acc); background:var(--acc-bg); border-color:color-mix(in srgb,var(--acc) 35%,transparent)}
.pill.forwardpaper{color:var(--warn); background:var(--warn-bg); border-color:color-mix(in srgb,var(--warn) 35%,transparent)}
.pill.realbuttiny{color:var(--warn); background:var(--warn-bg)}
.pill.dead{color:var(--dn); background:var(--dn-bg); border-color:color-mix(in srgb,var(--dn) 35%,transparent)}
.pill.no{color:var(--mut)}
.health{list-style:none; margin:0; padding:0}
.health li{padding:9px 0; border-top:1px solid var(--border-2)}
.health li:first-child{border-top:none}

/* ---- Ideas & Outcomes tab ---- */
.ledger-head{display:flex; align-items:baseline; justify-content:space-between; gap:10px; margin-bottom:14px}
.ledger-head h2{font-size:19px; font-weight:700; margin:0; letter-spacing:-.3px}
.ledger-head .sub{color:var(--mut); font-size:12.5px}
.filters{display:flex; gap:8px; overflow-x:auto; padding-bottom:4px; margin-bottom:16px; scrollbar-width:none}
.filters::-webkit-scrollbar{display:none}
.fchip{flex:0 0 auto; appearance:none; cursor:pointer; font-size:12.5px; font-weight:600; padding:8px 13px; border-radius:20px; border:1px solid var(--border); background:var(--surface); color:var(--mut); white-space:nowrap}
.fchip.active{background:var(--acc); border-color:var(--acc); color:#fff}
.fchip .n{opacity:.7; margin-left:5px; font-variant-numeric:tabular-nums}
.fchip.active .n{opacity:.85}
/* desktop table */
.ledger-table{width:100%; border-collapse:collapse; font-size:13.5px}
.ledger-table th{font-size:10.5px; color:var(--mut); text-transform:uppercase; letter-spacing:.5px; text-align:left; padding:10px 12px; border-bottom:1px solid var(--border); font-weight:600; white-space:nowrap}
.ledger-table td{padding:12px; border-bottom:1px solid var(--border-2); vertical-align:middle}
.ledger-table tr:last-child td{border-bottom:none}
.ledger-table .r{text-align:right; font-variant-numeric:tabular-nums}
.ledger-table .idsym{font-weight:650}
.ledger-table .iddir{font-size:11px; font-weight:600; margin-left:6px}
.ledger-table .learn-txt{color:var(--mut); font-size:12px}
/* mobile cards */
.ledger-cards{display:none; flex-direction:column; gap:10px}
.lcard{border:1px solid var(--border); border-radius:12px; padding:14px; background:var(--surface); box-shadow:var(--shadow-sm)}
.lcard .lc-top{display:flex; align-items:center; gap:8px; flex-wrap:wrap}
.lcard .lc-sym{font-weight:650}
.lcard .lc-r{margin-left:auto; font-weight:700; font-variant-numeric:tabular-nums}
.lcard .lc-meta{color:var(--mut); font-size:12px; margin-top:7px; display:flex; gap:6px; flex-wrap:wrap}
.lcard .lc-learn{color:var(--mut); font-size:12px; margin-top:6px}
/* status chips */
.sc{font-size:11px; font-weight:600; padding:3px 10px; border-radius:20px; white-space:nowrap; display:inline-block}
.sc.live{color:var(--acc); background:var(--acc-bg)} .sc.pending{color:var(--mut); background:var(--surface-2)}
.sc.hit{color:var(--up); background:var(--up-bg)} .sc.stopped{color:var(--dn); background:var(--dn-bg)}
.sc.expired{color:var(--warn); background:var(--warn-bg)}
.took-yes{color:var(--acc); font-weight:600} .took-no{color:var(--faint)}

.foot{color:var(--faint); font-size:11.5px; text-align:center; padding:18px}

/* ---- login ---- */
.login-wrap{min-height:100svh; display:flex; align-items:center; justify-content:center; padding:24px}
.login-card{width:100%; max-width:370px; background:var(--surface); border:1px solid var(--border); border-radius:18px; padding:28px; display:flex; flex-direction:column; gap:14px; box-shadow:var(--shadow)}
.login-card .brand{font-size:20px; font-weight:750; letter-spacing:-.3px}
.login-card .sub{color:var(--mut); font-size:12.5px; margin-top:-9px}
.login-card .pw{background:var(--surface-2); border:1px solid var(--border); border-radius:11px; padding:14px; color:var(--tx); font-size:16px}
.login-card .pw:focus{outline:none; border-color:var(--acc)}
.login-card .go{background:var(--acc); color:#fff; border:none; border-radius:11px; padding:15px; font-size:15px; font-weight:650; cursor:pointer; min-height:50px}
.login-card .go:active{transform:translateY(1px)}
.login-card .tiny{color:var(--mut); font-size:11.5px; text-align:center}
.notice{font-size:12.5px; border-radius:10px; padding:11px 13px}
.notice.err{color:var(--dn); background:var(--dn-bg); border:1px solid color-mix(in srgb,var(--dn) 30%,transparent)}
.notice.warn{color:var(--warn); background:var(--warn-bg); border:1px solid color-mix(in srgb,var(--warn) 30%,transparent)}
.stale{color:var(--warn); padding:16px}

/* ===== desktop ===== */
@media (min-width:820px){
  body{font-size:14px}
  .tabs{display:flex}
  .bottomnav{display:none}
  .topbar{padding-left:28px; padding-right:28px}
  .strip-inner{padding-left:28px; padding-right:28px; scrollbar-width:thin}
  main{max-width:1180px; margin:0 auto; padding:22px 28px 40px}
  .grid{grid-template-columns:1fr 1fr; align-items:start}
  .card.wide{grid-column:1 / -1}
  .coach-stats{grid-template-columns:repeat(4,1fr)}
  .ledger-cards{display:none !important}
}
@media (min-width:1140px){
  .grid.research3{grid-template-columns:1fr 1fr 1fr}
}
/* ===== mobile: ledger becomes cards ===== */
@media (max-width:819px){
  .ledger-table-wrap{display:none}
  .ledger-cards{display:flex}
}

/* ---- trade tickets (the action) ---- */
.tickets{display:grid; grid-template-columns:1fr; gap:12px}
.ticket{border:1px solid var(--border); border-left:3px solid var(--faint); border-radius:12px; padding:15px 16px; background:var(--surface)}
.tk-head{display:flex; align-items:center; gap:8px}
.tk-sym{font-weight:700; font-size:15px; letter-spacing:-.2px}
.tk-dir{font-size:11px; font-weight:700; letter-spacing:.4px; padding:3px 9px; border-radius:7px}
.tk-dir.long{color:var(--up); background:var(--up-bg)} .tk-dir.short{color:var(--dn); background:var(--dn-bg)}
.tk-took{font-size:9.5px; font-weight:700; color:var(--acc); background:var(--acc-bg); border:1px solid color-mix(in srgb,var(--acc) 35%,transparent); padding:2px 7px; border-radius:20px}
.tk-spacer{flex:1}
.tk-conv{font-size:15px; font-weight:700; font-variant-numeric:tabular-nums}
.tk-conv i{font-size:9.5px; color:var(--mut); font-style:normal; text-transform:uppercase; letter-spacing:.4px; margin-left:3px; font-weight:600}
.tk-status{font-size:11.5px; font-weight:600; color:var(--mut); white-space:nowrap}
.tk-status.sc-tg{color:var(--up)} .tk-status.sc-sl{color:var(--dn)} .tk-status.sc-tgsl{color:var(--warn)} .tk-status.sc-open{color:var(--acc)}
.tk-levels{display:grid; grid-template-columns:repeat(4,1fr); gap:8px; margin:13px 0 11px; padding:13px 0; border-top:1px solid var(--border-2); border-bottom:1px solid var(--border-2)}
.tk-levels > div{display:flex; flex-direction:column; gap:4px}
.tl{font-size:10px; color:var(--mut); text-transform:uppercase; letter-spacing:.4px; font-weight:600}
.tv{font-size:16px; font-weight:650; font-variant-numeric:tabular-nums}
.tk-size{font-size:12px; color:var(--acc); font-weight:500}
.tk-why{font-size:11.5px; color:var(--mut); margin-top:6px}
.ticket.st-tg{border-left-color:var(--up)} .ticket.st-sl{border-left-color:var(--dn)}
.ticket.st-tgsl{border-left-color:var(--warn)} .ticket.st-open{border-left-color:var(--acc)}
.metric.hl{background:var(--acc-bg); border:1px solid color-mix(in srgb,var(--acc) 22%,transparent)}
.metric.hl .mv{color:var(--acc)}
.daynote{color:var(--mut); font-size:13px; line-height:1.6}
.daynote b{color:var(--tx)}
@media (min-width:820px){ .tickets{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))} }

/* ---- honest confidence badge ---- */
.tk-conf{display:flex; align-items:center; gap:8px; margin-top:11px; font-size:12px; font-weight:600; padding:7px 11px; border-radius:9px}
.tk-conf .cf-dot{width:7px; height:7px; border-radius:50%; flex:0 0 auto}
.tk-conf .cf-sub{color:var(--mut); font-weight:400; margin-left:auto; font-size:11px; white-space:nowrap}
.conf-unproven{background:var(--warn-bg); color:var(--warn)} .conf-unproven .cf-dot{background:var(--warn)}
.conf-learning{background:var(--acc-bg); color:var(--acc)} .conf-learning .cf-dot{background:var(--acc)}
.conf-proven{background:var(--up-bg); color:var(--up)} .conf-proven .cf-dot{background:var(--up)}
.conf-flat{background:var(--surface-2); color:var(--mut)} .conf-flat .cf-dot{background:var(--mut)}
.tk-calib{font-size:11px; color:var(--mut); margin-top:5px}
.ideas-note{font-size:12px; color:var(--mut); background:var(--surface-2); border:1px solid var(--border-2); border-radius:10px; padding:10px 13px; margin-bottom:14px; line-height:1.55}
.ideas-note b{color:var(--tx)}

/* ---- pre-trade discipline gate ---- */
.g-pass{color:var(--up); background:var(--up-bg)}
.g-warn{color:var(--warn); background:var(--warn-bg)}
.g-block{color:var(--dn); background:var(--dn-bg)}
.tk-gate{margin-top:10px; font-size:12px; font-weight:600; padding:6px 10px; border-radius:8px}
.gate-form{display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:12px}
.gf-in{display:flex; flex-direction:column; gap:5px}
.gf-in label{font-size:11px; color:var(--mut); text-transform:uppercase; letter-spacing:.4px; font-weight:600}
.gf-in input{background:var(--surface-2); border:1px solid var(--border); border-radius:9px; padding:11px; color:var(--tx); font-size:15px; font-variant-numeric:tabular-nums}
.gf-in input:focus{outline:none; border-color:var(--acc)}
.gate-btn{width:100%; background:var(--acc); color:#fff; border:none; border-radius:10px; padding:13px; font-size:14.5px; font-weight:650; cursor:pointer; min-height:46px}
.gate-result{margin-top:14px}
.gate-verdict{display:flex; align-items:baseline; justify-content:space-between; gap:8px; font-size:15px; font-weight:700; padding:12px 14px; border-radius:10px; margin-bottom:10px}
.gate-verdict .gv-sub{font-size:12px; font-weight:400; opacity:.85; font-variant-numeric:tabular-nums}
.gate-chk{font-size:12.5px; font-weight:500; padding:8px 12px; border-radius:8px; margin-bottom:6px}
.gc-pass{color:var(--up); background:var(--up-bg)} .gc-warn{color:var(--warn); background:var(--warn-bg)} .gc-block{color:var(--dn); background:var(--dn-bg)}
