/* First Plan India — trading terminal (premium dark) */
:root{
  --bg:#ffffff; --bg2:#eef2f7;
  --glass:#ffffff; --glass2:#f2f5fa;
  --stroke:rgba(15,23,42,.10); --stroke2:rgba(15,23,42,.18);
  --text:#0f172a; --muted:#566074; --faint:#8a93a6;
  --up:#15a34a; --down:#e0394f; --buy:#2563eb;
  --a1:#6d4dff; --a2:#2563eb; --gold:#b8860b;
  --grad:linear-gradient(120deg,#7c5cff 0%,#2f8bff 100%);
  --grad-soft:linear-gradient(120deg,rgba(124,92,255,.12),rgba(47,139,255,.12));
  --r:16px; --shadow:0 24px 50px -28px rgba(15,23,42,.30); --shadow-sm:0 12px 30px -18px rgba(15,23,42,.16);
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;color:var(--text);background:var(--bg);font-family:"Satoshi","Inter",system-ui,"Segoe UI",Arial,sans-serif;
  line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden}
body::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(900px 600px at 12% -8%, rgba(124,92,255,.06), transparent 60%),
    radial-gradient(800px 600px at 92% 0%, rgba(37,99,235,.05), transparent 55%),
    linear-gradient(180deg,var(--bg),var(--bg2))}
h1,h2{margin:0 0 .4em;font-family:"Clash Display","Satoshi",sans-serif;letter-spacing:-.02em}
h3{margin:0 0 .4em;font-family:"Satoshi","Clash Display",sans-serif;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
.num{text-align:right;font-variant-numeric:tabular-nums}
.muted{color:var(--muted);font-size:.9rem}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:rgba(15,23,42,.20);border-radius:20px;border:3px solid transparent;background-clip:content-box}

.strip{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.74rem;font-weight:600;color:#cfd6ea;
  padding:.45rem 1rem;text-align:center;background:linear-gradient(90deg,rgba(124,92,255,.16),rgba(54,198,255,.16));border-bottom:1px solid var(--stroke)}
.strip .dot{width:7px;height:7px;border-radius:50%;background:var(--up);box-shadow:0 0 10px var(--up)}

.brand{display:flex;align-items:center;gap:.55rem;font-weight:800}
.brand.center{justify-content:center;margin-bottom:.4rem}
.brand-mark{display:grid;place-items:center;width:32px;height:32px;border-radius:9px;font-family:"Clash Display";font-size:.8rem;font-weight:700;color:#fff;background:var(--grad)}
.brand-text{font-family:"Clash Display";font-size:1.05rem;font-weight:600}
.brand-text em{font-style:normal;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

.btn{border:0;border-radius:11px;padding:.7rem 1.2rem;font-size:.92rem;font-weight:700;cursor:pointer;font-family:inherit;transition:filter .2s,transform .08s}
.btn:active{transform:translateY(1px)}
.btn-primary{color:#06101e;background:var(--grad)}
.btn-primary:hover{filter:brightness(1.07)}
.btn.full{width:100%;margin-top:.3rem}
.link{background:none;border:0;color:var(--a2);cursor:pointer;font:inherit;text-decoration:underline;padding:0}
.err{color:var(--down);font-size:.8rem;margin:.5rem 0 0;background:rgba(255,84,112,.1);border:1px solid rgba(255,84,112,.3);border-radius:10px;padding:.5rem .7rem}

/* auth */
.auth{min-height:100vh;display:grid;place-items:center;padding:2rem 1rem}
.auth-card{width:100%;max-width:400px;background:var(--glass);border:1px solid var(--stroke2);border-radius:20px;padding:2rem 1.8rem;box-shadow:var(--shadow);backdrop-filter:blur(18px)}
.auth-sub{color:var(--muted);font-size:.9rem;text-align:center;margin:.2rem 0 1.3rem}
.auth-tabs{display:grid;grid-template-columns:1fr 1fr;background:rgba(0,0,0,.25);border:1px solid var(--stroke);border-radius:11px;padding:3px;gap:3px;margin-bottom:1.2rem}
.auth-tabs button{border:0;background:transparent;color:var(--muted);font-weight:700;padding:.55rem;border-radius:8px;cursor:pointer;font-family:inherit}
.auth-tabs button.active{background:var(--grad);color:#06101e}
.field2{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.9rem;font-size:.76rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600}
.field2 input{padding:.7rem;background:rgba(0,0,0,.25);border:1px solid var(--stroke2);border-radius:10px;color:var(--text);font-size:1rem;font-family:inherit}
input:focus{outline:none;border-color:var(--a2);box-shadow:0 0 0 3px rgba(54,198,255,.18)}
.auth-demo{font-size:.8rem;color:var(--muted);text-align:center;margin:1rem 0 0}

/* nav */
.nav{display:flex;align-items:center;gap:1rem;padding:.6rem 1.1rem;background:rgba(8,11,19,.8);backdrop-filter:blur(14px);border-bottom:1px solid var(--stroke);position:sticky;top:0;z-index:50}
.nav-spacer{flex:1}
.live{display:flex;align-items:center;gap:.4rem;font-size:.76rem;color:var(--muted);font-weight:600}
.live i{width:8px;height:8px;border-radius:50%;background:var(--up);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(22,199,132,.55)}70%{box-shadow:0 0 0 7px rgba(22,199,132,0)}100%{box-shadow:0 0 0 0 rgba(22,199,132,0)}}
.balance-pill{display:flex;flex-direction:column;align-items:flex-end;line-height:1.15;background:var(--glass);border:1px solid var(--stroke);border-radius:11px;padding:.32rem .8rem}
.bp-label{font-size:.58rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.balance-pill strong{font-size:1rem;font-variant-numeric:tabular-nums}
.bp-delta{font-size:.66rem;font-weight:700}
.bp-delta.up{color:var(--up)}.bp-delta.down{color:var(--down)}
.usermenu{position:relative}
.user-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--stroke2);background:var(--grad-soft);color:#fff;font-weight:800;cursor:pointer;font-family:"Clash Display"}
.user-pop{position:absolute;right:0;top:44px;background:rgba(16,20,32,.97);border:1px solid var(--stroke2);border-radius:12px;padding:.6rem;min-width:220px;box-shadow:var(--shadow);z-index:60}
.user-email{font-size:.8rem;color:var(--muted);padding:.3rem .5rem .6rem;border-bottom:1px solid var(--stroke);margin-bottom:.4rem;word-break:break-all}
.user-act{display:block;width:100%;text-align:left;background:none;border:0;color:var(--text);padding:.55rem .5rem;border-radius:8px;cursor:pointer;font:inherit;font-size:.86rem}
.user-act:hover{background:var(--glass2)}.user-act.danger{color:#ffb3bf}

/* terminal grid */
.terminal{display:grid;grid-template-columns:270px 1fr 340px;gap:.8rem;padding:.8rem;align-items:start}
.panel{background:var(--glass);border:1px solid var(--stroke);border-radius:var(--r);box-shadow:var(--shadow-sm);backdrop-filter:blur(12px)}

/* watchlist */
.watchlist{padding:.8rem;display:flex;flex-direction:column;gap:.6rem;height:calc(100vh - 110px);position:sticky;top:84px}
.wl-search{padding:.55rem .7rem;background:rgba(0,0,0,.25);border:1px solid var(--stroke2);border-radius:10px;color:var(--text);font-size:.88rem;font-family:inherit}
.wl-cats{display:flex;flex-wrap:wrap;gap:.3rem}
.wl-cats button{border:1px solid var(--stroke);background:transparent;color:var(--muted);border-radius:20px;padding:.2rem .6rem;font-size:.72rem;font-weight:600;cursor:pointer;font-family:inherit}
.wl-cats button.active{background:var(--grad);color:#06101e;border-color:transparent}
.wl-list{overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:2px}
.wl-item{display:grid;grid-template-columns:1fr auto;gap:.1rem .5rem;padding:.5rem .55rem;border-radius:9px;cursor:pointer;border:1px solid transparent}
.wl-item:hover{background:var(--glass)}
.wl-item.active{background:var(--glass2);border-color:var(--stroke2)}
.wl-nm{font-weight:600;font-size:.86rem}
.wl-sym{font-size:.68rem;color:var(--muted)}
.wl-px{font-variant-numeric:tabular-nums;font-weight:700;font-size:.86rem;text-align:right}
.wl-chg{font-size:.72rem;font-weight:700;text-align:right}
.wl-chg.up{color:var(--up)}.wl-chg.down{color:var(--down)}

/* center column */
.center{display:flex;flex-direction:column;gap:.8rem;min-width:0}
.chart-panel{padding:.8rem .9rem}
.chart-head{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:.6rem}
.ct-name{display:flex;align-items:baseline;gap:.5rem}
.ct-name #c-name{font-family:"Clash Display";font-size:1.15rem;font-weight:700}
.ct-price{display:flex;align-items:baseline;gap:.6rem;margin-top:.15rem}
.ct-price #c-price{font-size:1.5rem;font-weight:800;font-variant-numeric:tabular-nums}
.chg{font-weight:700;font-variant-numeric:tabular-nums}
.chg.up{color:var(--up)}.chg.down{color:var(--down)}
.tf{display:flex;gap:.3rem;background:rgba(0,0,0,.25);border:1px solid var(--stroke);border-radius:10px;padding:3px}
.tf button{border:0;background:transparent;color:var(--muted);font-weight:700;padding:.32rem .55rem;border-radius:7px;cursor:pointer;font-family:inherit;font-size:.76rem}
.tf button.active{background:var(--grad);color:#06101e}
.chart-container{height:clamp(440px,62vh,820px);width:100%}

/* lower tabs */
.lower{padding:.8rem .9rem}
.ltabs{display:flex;gap:.4rem;margin-bottom:.8rem}
.ltab{border:1px solid var(--stroke);background:transparent;color:var(--muted);border-radius:20px;padding:.35rem .9rem;font-size:.8rem;font-weight:700;cursor:pointer;font-family:inherit}
.ltab.active{background:var(--grad);color:#06101e;border-color:transparent}

/* financials */
.fin-content{font-size:.9rem}
.fin-about{color:var(--muted);font-size:.85rem;line-height:1.6;margin:.2rem 0 1rem}
.fin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.7rem;margin-bottom:1.2rem}
.fin-stat{background:rgba(0,0,0,.2);border:1px solid var(--stroke);border-radius:11px;padding:.7rem .8rem}
.fin-stat span{display:block;font-size:.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.fin-stat b{font-size:1.05rem;font-variant-numeric:tabular-nums}
.fin-src{font-size:.72rem;color:var(--faint);margin-top:.6rem}
.fin-empty{color:var(--muted);padding:1.5rem;text-align:center}

/* tables */
.table-wrap{overflow-x:auto}
table.prices{width:100%;border-collapse:collapse;font-size:.9rem}
table.prices th{text-align:left;color:var(--muted);font-weight:600;font-size:.68rem;text-transform:uppercase;letter-spacing:.05em;padding:.5rem .5rem;border-bottom:1px solid var(--stroke)}
table.prices td{padding:.55rem .5rem;border-bottom:1px solid var(--stroke)}
table.prices tr:last-child td{border-bottom:0}
.mkt-name{font-weight:600}.mkt-sym{color:var(--muted);font-size:.7rem;margin-left:.35rem}
.pos-dir{font-weight:700;font-size:.72rem;padding:.16rem .5rem;border-radius:7px}
.pos-dir.buy{color:var(--buy);background:rgba(77,140,255,.14)}.pos-dir.sell{color:var(--down);background:rgba(255,84,112,.14)}
.pnl.up{color:var(--up);font-weight:700}.pnl.down{color:var(--down);font-weight:700}
.btn-close{background:var(--glass2);border:1px solid var(--stroke2);color:var(--text);border-radius:8px;padding:.35rem .8rem;cursor:pointer;font-weight:700;font-size:.8rem;font-family:inherit}
.btn-close:hover{background:rgba(255,84,112,.16);border-color:rgba(255,84,112,.4)}
.empty{padding:1.2rem 0;text-align:center}

/* right column */
.rightcol{display:flex;flex-direction:column;gap:.8rem;position:sticky;top:84px}
.account-card{padding:1rem 1.1rem}
.hc-head{display:flex;justify-content:space-between;align-items:center}
.hc-title{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600}
.hc-pnl{font-size:.82rem;font-weight:700;padding:.18rem .55rem;border-radius:20px;background:var(--glass2)}
.hc-pnl.up{color:var(--up);background:rgba(22,199,132,.12)}.hc-pnl.down{color:var(--down);background:rgba(255,84,112,.12)}
.hc-equity{font-family:"Satoshi";font-size:1.9rem;font-weight:900;margin:.2rem 0 .7rem;font-variant-numeric:tabular-nums}
.hc-stats{display:grid;grid-template-columns:1fr 1fr;gap:.5rem .8rem}
.hc-stats div{display:flex;justify-content:space-between;border-top:1px solid var(--stroke);padding-top:.45rem;font-size:.84rem}
.hc-stats span{color:var(--muted)}.hc-stats strong{font-variant-numeric:tabular-nums}

/* ticket */
.ticket{padding:1rem 1.1rem}
.ticket-name{display:flex;justify-content:space-between;align-items:center;margin-bottom:.7rem;font-weight:700;font-size:1.02rem}
.tag{background:var(--glass2);color:var(--muted);font-size:.66rem;padding:.18rem .55rem;border-radius:20px;font-weight:600}
.seg{display:grid;grid-template-columns:1fr 1fr;background:rgba(0,0,0,.25);border:1px solid var(--stroke);border-radius:11px;padding:3px;margin-bottom:.7rem;gap:3px}
.seg-btn{border:0;background:transparent;color:var(--muted);font-weight:700;padding:.5rem;border-radius:8px;cursor:pointer;font-family:inherit}
.seg-btn.sell.active{background:rgba(255,84,112,.16);color:var(--down)}
.seg-btn.buy.active{background:rgba(77,140,255,.18);color:var(--buy)}
.ticket-prices{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;margin-bottom:.8rem}
.px{border:1.5px solid var(--stroke);border-radius:11px;padding:.55rem;cursor:pointer;display:flex;flex-direction:column;align-items:center;background:rgba(0,0,0,.18);color:var(--text);font-weight:700;font-variant-numeric:tabular-nums;transition:border-color .15s,background .15s,box-shadow .15s}
.px:hover{border-color:var(--stroke2);background:rgba(255,255,255,.04)}
.px span{font-size:.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.px b{font-size:1.1rem;margin-top:.12rem;color:var(--text)}
.px.sell b{color:var(--down)}
.px.buy b{color:var(--buy)}
.px.sell.active{border-color:var(--down);background:rgba(255,84,112,.12);box-shadow:0 0 0 1px rgba(255,84,112,.25) inset}
.px.buy.active{border-color:var(--buy);background:rgba(77,140,255,.12);box-shadow:0 0 0 1px rgba(77,140,255,.25) inset}
.field{display:flex;flex-direction:column;gap:.4rem;font-size:.74rem;color:var(--muted);margin-bottom:.7rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600}
.field em{font-style:normal;text-transform:none;letter-spacing:0;color:var(--faint);font-weight:500}
.stepper{display:grid;grid-template-columns:40px 1fr 40px;gap:.4rem}
.stepper button{border:1px solid var(--stroke2);background:var(--glass);color:var(--text);border-radius:9px;font-size:1.2rem;cursor:pointer;font-family:inherit}
.stepper input{padding:.55rem;background:rgba(0,0,0,.22);border:1px solid var(--stroke2);border-radius:9px;font-size:1.02rem;color:var(--text);text-align:center;font-family:inherit;font-variant-numeric:tabular-nums}
.levs{display:grid;grid-template-columns:repeat(4,1fr);gap:.4rem}
.levs button{border:1px solid var(--stroke);background:rgba(0,0,0,.18);color:var(--muted);border-radius:9px;padding:.45rem 0;font-weight:700;cursor:pointer;font-family:inherit;font-size:.82rem}
.levs button.active{background:var(--grad);color:#06101e;border-color:transparent}
.ticket-meta{display:flex;justify-content:space-between;gap:1rem;margin:.1rem 0 .4rem}
.ticket-meta span{color:var(--muted);display:block;font-size:.66rem;text-transform:uppercase;letter-spacing:.05em}
.ticket-meta b{font-variant-numeric:tabular-nums;font-size:1rem}

/* toasts */
.toasts{position:fixed;right:1.1rem;bottom:1.1rem;z-index:100;display:flex;flex-direction:column;gap:.55rem}
.toast{min-width:230px;max-width:330px;background:rgba(16,20,32,.94);border:1px solid var(--stroke2);border-left:3px solid var(--a2);border-radius:11px;padding:.65rem .85rem;box-shadow:var(--shadow);font-size:.85rem;animation:tin .3s ease both}
.toast.ok{border-left-color:var(--up)}.toast.bad{border-left-color:var(--down)}
.toast b{display:block;font-size:.8rem;margin-bottom:.1rem}.toast.hide{animation:tout .3s ease both}
@keyframes tin{from{opacity:0;transform:translateX(24px)}to{opacity:1;transform:none}}
@keyframes tout{to{opacity:0;transform:translateX(24px)}}

@media(max-width:1080px){
  .terminal{grid-template-columns:1fr}
  .watchlist,.rightcol{position:static;height:auto}
  .wl-list{max-height:280px}
}

/* options chain */
.opt-head{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:.7rem}
.opt-info b{font-size:1rem}
.opt-meta{color:var(--muted);font-size:.8rem;margin-left:.6rem}
.opt-expiries{display:flex;gap:.3rem;flex-wrap:wrap}
.opt-expiries button{border:1px solid var(--stroke);background:rgba(0,0,0,.18);color:var(--muted);border-radius:8px;padding:.3rem .6rem;font-size:.76rem;font-weight:700;cursor:pointer;font-family:inherit}
.opt-expiries button.active{background:var(--grad);color:#06101e;border-color:transparent}
.opt-table .call{color:var(--up);font-weight:700}
.opt-table .put{color:var(--down);font-weight:700}
.opt-table .strike-col{text-align:center;font-weight:800;background:rgba(255,255,255,.03)}
.opt-table tr.atm{background:rgba(124,92,255,.12)}
.opt-table tr.atm .strike-col{color:var(--a2)}

/* indicators dropdown + chips */
.ind-bar{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin:.15rem 0 .5rem}
.ind-menu{position:relative}
.ind-toggle{border:1px solid var(--stroke2);background:var(--glass);color:var(--text);border-radius:9px;padding:.32rem .7rem;font-size:.78rem;font-weight:700;cursor:pointer;font-family:inherit;transition:.15s}
.ind-toggle:hover{background:var(--glass2)}
.ind-pop{width:100%;max-height:320px;overflow-y:auto;background:rgba(255,255,255,.03);border:1px solid var(--stroke2);border-radius:12px;padding:.7rem;margin-bottom:.6rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.7rem}
.ind-group{display:flex;flex-direction:column;gap:.3rem}
.ind-gtitle{font-size:.62rem;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);font-weight:700;margin-bottom:.1rem}
.ind-item{border:1px solid var(--stroke);background:rgba(0,0,0,.18);color:var(--muted);border-radius:8px;padding:.34rem .5rem;font-size:.74rem;font-weight:600;cursor:pointer;font-family:inherit;text-align:left;transition:.12s}
.ind-item:hover{color:#fff;border-color:var(--stroke2)}
.ind-item.active{background:var(--grad);color:#06101e;border-color:transparent}
.ind-active{display:flex;flex-wrap:wrap;gap:.3rem}
.ind-chip{display:inline-flex;align-items:center;gap:.3rem;background:var(--glass2);border:1px solid var(--stroke2);border-radius:20px;padding:.18rem .25rem .18rem .6rem;font-size:.72rem;font-weight:700;color:var(--text)}
.ind-chip button{border:0;background:rgba(255,255,255,.08);color:var(--muted);width:16px;height:16px;border-radius:50%;cursor:pointer;font-size:.8rem;line-height:1;display:grid;place-items:center}
.ind-chip button:hover{background:var(--down);color:#fff}
/* oscillator sub-panes (stacked, synced) */
.osc-container{display:none;flex-direction:column;gap:.3rem;width:100%;margin-top:.4rem}
.osc-pane{position:relative;height:130px;width:100%;border-top:1px solid var(--stroke)}
.osc-name{position:absolute;top:4px;left:8px;z-index:3;font-size:.68rem;font-weight:700;color:var(--muted);pointer-events:none}

/* open interest */
.oi-head{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:.6rem}
.oi-info b{font-size:1rem}
.oi-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(118px,1fr));gap:.5rem;margin-bottom:.8rem}
.oi-stat{background:rgba(0,0,0,.2);border:1px solid var(--stroke);border-radius:10px;padding:.5rem .7rem}
.oi-stat span{display:block;font-size:.6rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.oi-stat b{font-size:1.02rem;font-variant-numeric:tabular-nums}
.oi-stat b.up{color:var(--up)}.oi-stat b.down{color:var(--down)}
.oi-bars{display:flex;flex-direction:column;gap:2px;font-size:.76rem}
.oi-row{display:grid;grid-template-columns:1fr 84px 1fr;align-items:center;gap:.4rem}
.oi-head-row{color:var(--muted);font-size:.64rem;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.2rem}
.oi-head-row .oi-side{justify-content:center}
.oi-row.atm{background:rgba(124,92,255,.12);border-radius:6px}
.oi-side{display:flex;align-items:center;gap:.4rem;overflow:hidden}
.oi-side.put{justify-content:flex-end}
.oi-side.call{justify-content:flex-start}
.oi-bar{height:14px;border-radius:3px;display:inline-block;min-width:1px}
.oi-bar.put{background:linear-gradient(90deg,transparent,rgba(22,199,132,.75))}
.oi-bar.call{background:linear-gradient(90deg,rgba(255,84,112,.75),transparent)}
.oi-val{font-variant-numeric:tabular-nums;color:var(--muted);white-space:nowrap}
.oi-strike{text-align:center;font-weight:800;font-variant-numeric:tabular-nums;background:rgba(255,255,255,.03);border-radius:5px;padding:.15rem 0}
.oi-row.atm .oi-strike{color:var(--a2)}

/* strategy builder */
.strat-head{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:.6rem}
.strat-presets{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.7rem}
.strat-presets button{border:1px solid var(--stroke);background:rgba(0,0,0,.18);color:var(--muted);border-radius:8px;padding:.3rem .6rem;font-size:.74rem;font-weight:700;cursor:pointer;font-family:inherit;transition:.12s}
.strat-presets button:hover{color:#fff;border-color:var(--stroke2)}
.strat-body{display:grid;grid-template-columns:1fr 1.25fr;gap:1rem;align-items:start}
.strat-legs-head{display:flex;justify-content:space-between;align-items:center;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:700;margin-bottom:.4rem}
.leg-row{display:grid;grid-template-columns:auto auto 1fr 52px auto 22px;gap:.35rem;align-items:center;margin-bottom:.35rem}
.leg-row select,.leg-row input{padding:.35rem;background:rgba(0,0,0,.22);border:1px solid var(--stroke2);border-radius:7px;color:var(--text);font-size:.76rem;font-family:inherit}
.leg-row .leg-lots{text-align:center}
.leg-prem{font-size:.72rem;color:var(--muted);font-variant-numeric:tabular-nums;white-space:nowrap}
.leg-del{border:0;background:rgba(255,255,255,.08);color:var(--muted);width:22px;height:22px;border-radius:6px;cursor:pointer;line-height:1}
.leg-del:hover{background:var(--down);color:#fff}
.strat-canvas{width:100%;height:230px;display:block;background:#ffffff;border:1px solid rgba(15,23,42,.12);border-radius:10px}
.strat-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(94px,1fr));gap:.45rem;margin-top:.6rem}
@media(max-width:900px){.strat-body{grid-template-columns:1fr}}

/* chart tools + full-screen */
.chart-tools{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.chart-max-btn{border:1px solid var(--stroke2);background:var(--glass);color:var(--text);border-radius:9px;padding:.32rem .7rem;font-size:.76rem;font-weight:700;cursor:pointer;font-family:inherit}
.chart-max-btn:hover{background:var(--glass2)}
body.chart-full .watchlist,body.chart-full .rightcol,body.chart-full .lower{display:none!important}
body.chart-full .terminal{display:block;padding:.5rem}
body.chart-full .center{display:block}
body.chart-full .chart-panel{position:fixed;inset:60px 8px 8px 8px;z-index:60;overflow:auto;margin:0}
body.chart-full .chart-container{height:calc(100vh - 210px)}
body.chart-full .osc-pane{height:150px}

/* volatility cone */
.vol-cone{display:flex;flex-direction:column;gap:.35rem;font-size:.8rem;margin-bottom:.6rem}
.cone-row{display:grid;grid-template-columns:54px 1fr 64px;align-items:center;gap:.6rem}
.cone-head{color:var(--muted);font-size:.64rem;text-transform:uppercase;letter-spacing:.05em}
.cone-win{font-weight:700}
.cone-val{text-align:right;font-variant-numeric:tabular-nums;font-weight:700}
.cone-track{position:relative;height:14px;background:rgba(255,255,255,.05);border-radius:7px}
.cone-range{position:absolute;top:3px;height:8px;border-radius:4px;background:linear-gradient(90deg,rgba(54,198,255,.5),rgba(124,92,255,.6))}
.cone-med{position:absolute;top:0;width:2px;height:14px;background:rgba(255,255,255,.6)}
.cone-cur{position:absolute;top:1px;width:10px;height:10px;border-radius:50%;background:var(--gold);transform:translateX(-5px);box-shadow:0 0 6px var(--gold)}

/* open interest page */
.oi-badges{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.6rem}
.oi-badge{display:inline-flex;align-items:center;gap:.35rem;background:var(--glass2);border:1px solid var(--stroke);border-radius:8px;padding:.28rem .6rem;font-size:.8rem;font-weight:700;font-variant-numeric:tabular-nums}
.oi-badge i{font-style:normal;font-size:.58rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:600}
.oi-badge.up{color:var(--up)}.oi-badge.down{color:var(--down)}
.oi-subtabs{display:flex;gap:.4rem;margin-bottom:.6rem}
.oi-subtab{border:1px solid var(--stroke);background:transparent;color:var(--muted);border-radius:20px;padding:.32rem .85rem;font-size:.78rem;font-weight:700;cursor:pointer;font-family:inherit;transition:.15s}
.oi-subtab:hover{color:#fff;border-color:var(--stroke2)}
.oi-subtab.active{background:var(--grad);color:#06101e;border-color:transparent}
.oi-canvas{width:100%;height:440px;display:block}
.oi-legend{display:flex;flex-wrap:wrap;gap:.85rem;margin:.45rem 0;font-size:.72rem;color:var(--muted)}
.oi-legend .lg{display:inline-flex;align-items:center;gap:.35rem}
.oi-legend .lg i{width:10px;height:10px;border-radius:2px;display:inline-block}
.oi-buildup .bu{font-weight:700;font-size:.74rem;padding:.12rem .45rem;border-radius:6px}
.bu.lb{color:var(--up);background:rgba(22,199,132,.14)}
.bu.sb{color:var(--down);background:rgba(255,84,112,.14)}
.bu.lu{color:#e9a23b;background:rgba(233,162,59,.14)}
.bu.sc{color:var(--buy);background:rgba(77,140,255,.14)}
body.chart-full .oi-canvas{height:520px}

/* ===================== LANDING ===================== */
#landing{max-width:1240px;margin:0 auto;padding:0 1.2rem 2rem}
.lnav{display:flex;align-items:center;gap:1.2rem;padding:1rem .2rem;position:sticky;top:0;z-index:30;background:rgba(7,10,18,.7);backdrop-filter:blur(12px)}
.lnav-links{display:flex;gap:1.1rem;flex:1}
.lnav-links a{font-size:.9rem;font-weight:600;color:var(--muted)}
.lnav-links a:hover{color:#fff}
.lnav-cta{display:flex;gap:.6rem}
.btn-ghost{background:var(--glass);color:var(--text);border:1px solid var(--stroke2);border-radius:11px;padding:.6rem 1.1rem;font-weight:700;font-family:inherit;cursor:pointer;font-size:.92rem}
.btn-ghost:hover{background:var(--glass2)}
.lhero{position:relative;padding:2.5rem 0 1rem}
.lhero-glow{position:absolute;inset:-60px -20% auto;height:420px;z-index:-1;background:radial-gradient(60% 100% at 50% 0,rgba(124,92,255,.25),transparent 70%)}
.lhero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:2.4rem;align-items:center;perspective:1000px}
.lhero h1{font-size:clamp(2.2rem,4.6vw,3.6rem);font-weight:800;line-height:1.05}
.lhero .lead{color:var(--muted);font-size:1.06rem;max-width:52ch;margin:.6rem 0 0}
.lhero-actions{display:flex;gap:.8rem;margin:1.6rem 0;flex-wrap:wrap}
.lhero-visual{position:relative;border-radius:20px;border:1px solid var(--stroke2);background:var(--glass);box-shadow:var(--shadow);overflow:hidden;transition:transform .15s ease-out;transform-style:preserve-3d}
.lhero-canvas{width:100%;height:340px;display:block}
.lhero-badge{position:absolute;top:12px;left:14px;font-size:.62rem;font-weight:800;letter-spacing:.1em;color:#06101e;background:var(--up);padding:.18rem .5rem;border-radius:6px}
.lsection{padding:2.6rem 0 .5rem}
.lsec-head{text-align:center;margin-bottom:1.4rem}
.lsec-head h2{font-size:1.8rem}
.lcourses{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}
.lcourse{background:var(--glass);border:1px solid var(--stroke);border-radius:16px;padding:1.2rem;cursor:pointer;transition:.2s;position:relative;overflow:hidden}
.lcourse:hover{transform:translateY(-4px);border-color:var(--stroke2);box-shadow:var(--shadow-sm);background:var(--glass2)}
.lcourse .ccode{display:grid;place-items:center;width:42px;height:42px;border-radius:11px;font-family:"Clash Display";font-weight:700;font-size:.85rem;color:#fff;background:var(--grad);margin-bottom:.8rem}
.lcourse h3{font-size:1.08rem;margin:0 0 .2rem}
.lcourse .clevel{font-size:.68rem;text-transform:uppercase;letter-spacing:.05em;color:var(--gold);font-weight:700}
.lcourse p{color:var(--muted);font-size:.86rem;margin:.4rem 0 0}
.lcourse .clessons{margin-top:.6rem;font-size:.74rem;color:var(--a2);font-weight:700}
.lfeat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}
.lfeat{background:rgba(0,0,0,.2);border:1px solid var(--stroke);border-radius:14px;padding:1.1rem}
.lfeat b{font-size:1rem}.lfeat p{color:var(--muted);font-size:.86rem;margin:.3rem 0 0}
.lblog{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}
.lblogcard{background:var(--glass);border:1px solid var(--stroke);border-radius:14px;padding:1.1rem;cursor:pointer;transition:.2s}
.lblogcard:hover{transform:translateY(-3px);border-color:var(--stroke2)}
.lblogcard .btag{font-size:.64rem;text-transform:uppercase;letter-spacing:.05em;color:var(--a2);font-weight:700}
.lblogcard h3{font-size:1.02rem;margin:.3rem 0}
.lblogcard p{color:var(--muted);font-size:.85rem;margin:0}
.lnews{padding:2.6rem 0}
.lnews-card{background:var(--grad-soft);border:1px solid var(--stroke2);border-radius:20px;padding:2rem;text-align:center}
.lnews-form{display:flex;gap:.5rem;justify-content:center;max-width:440px;margin:1rem auto 0;flex-wrap:wrap}
.lnews-form input{flex:1;min-width:200px;padding:.7rem;background:rgba(0,0,0,.3);border:1px solid var(--stroke2);border-radius:11px;color:var(--text);font-family:inherit}
.lnews-msg{font-size:.85rem;margin:.6rem 0 0;color:var(--up)}
.lfoot{border-top:1px solid var(--stroke);margin-top:2rem;padding:2rem 0 0;color:var(--muted)}
.lfoot-cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:1.5rem}
.lfoot-cols h4{font-size:.8rem;color:var(--text);margin:0 0 .5rem}
.lfoot-cols a{display:block;font-size:.84rem;color:var(--muted);margin-bottom:.3rem}
.lfoot-cols a:hover{color:#fff}
.lfoot-legal{font-size:.75rem;text-align:center;padding:1.4rem 0;margin-top:1rem;border-top:1px solid var(--stroke)}

/* ===================== GALLERY ===================== */
.lgallery{columns:340px;column-gap:1rem}
.gphoto{position:relative;display:block;width:100%;margin:0 0 1rem;padding:0;border:1px solid var(--stroke);border-radius:16px;overflow:hidden;cursor:pointer;background:var(--glass);break-inside:avoid;box-shadow:var(--shadow-sm);transition:transform .2s ease,border-color .2s,box-shadow .2s}
.gphoto:hover{transform:translateY(-4px);border-color:var(--a2);box-shadow:var(--shadow)}
.gphoto img{display:block;width:100%;height:auto;transition:transform .4s ease}
.gphoto:hover img{transform:scale(1.05)}
.gcap{position:absolute;left:0;right:0;bottom:0;padding:1.5rem .95rem .85rem;font-size:.84rem;font-weight:700;color:#fff;line-height:1.35;background:linear-gradient(to top,rgba(4,6,12,.85),rgba(4,6,12,.35) 55%,transparent);opacity:0;transform:translateY(10px);transition:opacity .25s,transform .25s;pointer-events:none}
.gphoto:hover .gcap{opacity:1;transform:none}

/* ===================== VISIT / LOCATION ===================== */
.lvisit{display:grid;grid-template-columns:.85fr 1.15fr;gap:1.2rem;align-items:stretch}
.lvisit-info{background:var(--glass);border:1px solid var(--stroke2);border-radius:18px;padding:1.6rem;box-shadow:var(--shadow-sm)}
.lvisit-info h3{font-size:1.25rem;margin:0 0 .4rem}
.lv-addr{color:var(--muted);font-size:.95rem;line-height:1.6;margin:0 0 1.1rem}
.lv-rows{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.2rem}
.lv-row{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.6rem .85rem;background:var(--glass2);border:1px solid var(--stroke);border-radius:11px;transition:border-color .15s}
.lv-row span{font-size:.68rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:700}
.lv-row b{font-variant-numeric:tabular-nums;font-size:.95rem}
.lv-row:hover{border-color:var(--a2)}
.lv-dir{display:inline-block;text-align:center}
.lvisit-map{border:1px solid var(--stroke2);border-radius:18px;overflow:hidden;min-height:360px;box-shadow:var(--shadow-sm)}
.lvisit-map iframe{width:100%;height:100%;min-height:360px;border:0;display:block}

/* ===================== LIGHTBOX ===================== */
.lightbox{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;background:rgba(4,6,12,.92);backdrop-filter:blur(4px)}
.lightbox .lb-img{max-width:90vw;max-height:84vh;border-radius:12px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lb-close,.lb-prev,.lb-next{position:absolute;background:rgba(255,255,255,.14);border:1px solid var(--stroke2);color:#fff;cursor:pointer;border-radius:50%;display:grid;place-items:center;line-height:1}
.lb-close{top:1.1rem;right:1.1rem;width:42px;height:42px;font-size:1.4rem}
.lb-prev,.lb-next{top:50%;transform:translateY(-50%);width:48px;height:48px;font-size:1.9rem}
.lb-prev{left:1.1rem}.lb-next{right:1.1rem}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{background:var(--a2);border-color:var(--a2)}
.lb-cap{position:absolute;left:0;right:0;bottom:0;text-align:center;color:#e8ecf5;font-size:.92rem;font-weight:600;padding:1.3rem 4rem;background:linear-gradient(to top,rgba(4,6,12,.72),transparent);pointer-events:none}
.lb-count{position:absolute;top:1.25rem;left:1.25rem;color:#cfd6ea;font-size:.8rem;font-weight:700;letter-spacing:.04em;background:rgba(255,255,255,.1);border:1px solid var(--stroke2);border-radius:20px;padding:.3rem .75rem}
@media(max-width:760px){.lvisit{grid-template-columns:1fr}}

/* ===================== AUTH MODAL ===================== */
.auth-modal{position:fixed;inset:0;z-index:100;display:grid;place-items:center;background:rgba(4,6,12,.7);backdrop-filter:blur(6px);padding:1rem}
.auth-modal .auth-card{position:relative}
.auth-close{position:absolute;top:.6rem;right:.7rem;border:0;background:none;color:var(--muted);font-size:1.4rem;cursor:pointer;line-height:1}
.auth-close:hover{color:#fff}

/* ===================== NAV VIEWS ===================== */
.nav-views{display:flex;gap:.3rem}
.nav-view{border:0;background:transparent;color:var(--muted);font-weight:700;font-size:.86rem;padding:.4rem .8rem;border-radius:9px;cursor:pointer;font-family:inherit}
.nav-view:hover{color:#fff;background:var(--glass)}
.nav-view.active{background:var(--grad);color:#06101e}
.view-page{max-width:1100px;margin:0 auto;padding:1.4rem 1.2rem}

/* ===================== ACADEMY ===================== */
.aca-head{margin-bottom:1.2rem}
.aca-head h2{font-size:1.6rem}
.aca-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}
.aca-card{background:var(--glass);border:1px solid var(--stroke);border-radius:16px;padding:1.2rem;cursor:pointer;transition:.2s}
.aca-card:hover{transform:translateY(-4px);border-color:var(--stroke2);background:var(--glass2)}
.aca-card .ccode{display:grid;place-items:center;width:42px;height:42px;border-radius:11px;font-family:"Clash Display";font-weight:700;font-size:.85rem;color:#fff;background:var(--grad);margin-bottom:.7rem}
.aca-card h3{font-size:1.05rem;margin:0}
.aca-card .clevel{font-size:.66rem;text-transform:uppercase;letter-spacing:.05em;color:var(--gold);font-weight:700}
.aca-card p{color:var(--muted);font-size:.85rem;margin:.4rem 0 0}
.course-detail .back{background:none;border:0;color:var(--a2);cursor:pointer;font:inherit;font-weight:700;margin-bottom:.8rem}
.course-detail h2{font-size:1.5rem;margin:0}
.course-detail .csub{color:var(--muted);margin:.2rem 0 1.2rem}
.lesson{background:var(--glass);border:1px solid var(--stroke);border-radius:14px;padding:1.1rem 1.2rem;margin-bottom:.8rem}
.lesson h3{font-size:1.05rem;margin:0 0 .5rem;display:flex;gap:.5rem;align-items:center}
.lesson .lnum{display:grid;place-items:center;width:24px;height:24px;border-radius:7px;background:var(--grad);color:#06101e;font-size:.74rem;font-weight:800}
.lesson p{color:var(--muted);font-size:.92rem;line-height:1.65;margin:.4rem 0 0}
.course-practice{display:inline-block;margin-top:.4rem;background:var(--grad);color:#06101e;border:0;border-radius:11px;padding:.7rem 1.2rem;font-weight:800;cursor:pointer;font-family:inherit}

/* ===================== BLOG ===================== */
.blog-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}
.post-card{background:var(--glass);border:1px solid var(--stroke);border-radius:14px;padding:1.2rem;cursor:pointer;transition:.2s}
.post-card:hover{transform:translateY(-3px);border-color:var(--stroke2)}
.post-card .btag{font-size:.64rem;text-transform:uppercase;letter-spacing:.05em;color:var(--a2);font-weight:700}
.post-card h3{font-size:1.08rem;margin:.3rem 0}
.post-card .pmeta,.post .pmeta{font-size:.74rem;color:var(--faint)}
.post-card p{color:var(--muted);font-size:.88rem;margin:.3rem 0 0}
.post{max-width:740px}
.post .back{background:none;border:0;color:var(--a2);cursor:pointer;font:inherit;font-weight:700;margin-bottom:.8rem}
.post h1{font-size:1.8rem;margin:.2rem 0}
.post p{color:var(--text);opacity:.92;line-height:1.8;margin:1rem 0;font-size:1rem}
@media(max-width:900px){.lhero-grid{grid-template-columns:1fr}.lfoot-cols{grid-template-columns:1fr 1fr}.lnav-links{display:none}}

/* hidden attribute must always win over class display rules */
[hidden]{display:none !important}

/* OI controls + hover tooltip */
.oi-controls{display:flex;gap:.4rem;flex-wrap:wrap;align-items:center}
.oi-select{background:rgba(0,0,0,.3);border:1px solid var(--stroke2);color:var(--text);border-radius:9px;padding:.4rem .6rem;font-family:inherit;font-size:.82rem;font-weight:700;cursor:pointer}
.oi-ctrl{border:1px solid var(--stroke2);background:var(--glass);color:var(--text);border-radius:9px;padding:.4rem .7rem;font-size:.76rem;font-weight:700;cursor:pointer;font-family:inherit}
.oi-ctrl:hover{background:var(--glass2)}
.oi-subtabs-row{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:.5rem}
.oi-tf{display:flex;gap:.25rem;background:rgba(0,0,0,.25);border:1px solid var(--stroke);border-radius:9px;padding:3px}
.oi-tf button{border:0;background:transparent;color:var(--muted);font-weight:700;font-size:.72rem;padding:.3rem .55rem;border-radius:6px;cursor:pointer;font-family:inherit}
.oi-tf button.active{background:var(--grad);color:#06101e}
.oi-chart-wrap{position:relative}
.oi-tooltip{position:absolute;z-index:20;min-width:218px;background:rgba(10,14,24,.97);border:1px solid var(--stroke2);border-radius:10px;padding:.6rem .7rem;box-shadow:var(--shadow);pointer-events:none;font-size:.76rem;backdrop-filter:blur(6px)}
.oit-strike{font-weight:800;font-size:.95rem;margin-bottom:.35rem;border-bottom:1px solid var(--stroke);padding-bottom:.3rem}
.oit-row{display:flex;justify-content:space-between;gap:1rem;padding:.07rem 0;font-variant-numeric:tabular-nums}
.oit-row span{color:var(--muted)}
.oit-row.c span,.oit-row.c b{color:#46c98a}
.oit-row.p span,.oit-row.p b{color:#ff8088}
.oit-row small{color:var(--muted);font-weight:500}

/* strategy 3D surface + target date */
.strat-target{display:flex;align-items:center;gap:.6rem;margin:.8rem 0 .3rem;font-size:.8rem;color:var(--muted)}
.strat-target input[type=range]{flex:1;max-width:300px;accent-color:var(--a2)}
.strat-target b{color:var(--text);min-width:60px}
.strat-3d-head{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:700;margin:.7rem 0 .3rem;display:flex;justify-content:space-between;align-items:center}
.strat-surface{width:100%;height:300px;display:block;background:rgba(0,0,0,.22);border:1px solid var(--stroke);border-radius:12px}
.oi-build-strat{margin-top:.7rem;width:100%;background:var(--grad-soft);border:1px solid var(--stroke2);color:var(--text);border-radius:11px;padding:.7rem;font-weight:700;cursor:pointer;font-family:inherit;transition:.15s}
.oi-build-strat:hover{filter:brightness(1.12);border-color:var(--a2)}

/* full-page strategy builder */
.sb{display:flex;flex-direction:column;gap:1rem}
.sb-top{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.sb-sym{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap}
.sb-sym .oi-select{font-weight:700}
.sb-spot{font-size:1.15rem;font-weight:800;color:var(--text)}
.sb-meta{font-size:.78rem;color:var(--muted)}
.sb-top-right{display:flex;align-items:center;gap:.5rem}
.sb-lbl{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:700}
.sb-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.55rem}
.sb-stat{background:var(--panel2,rgba(255,255,255,.02));border:1px solid var(--stroke);border-radius:12px;padding:.6rem .7rem;display:flex;flex-direction:column;gap:.25rem}
.sb-stat .lab{font-size:.66rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:700;display:flex;align-items:center;justify-content:space-between;gap:.3rem}
.sb-stat .val{font-size:1.05rem;font-weight:800;color:var(--text)}
.sb-stat .val.up{color:var(--up,#22c55e)}
.sb-stat .val.down{color:var(--down,#ef4444)}
.sb-toggle{display:inline-flex;border:1px solid var(--stroke);border-radius:7px;overflow:hidden}
.sb-toggle button{background:transparent;border:0;color:var(--muted);font:inherit;font-size:.62rem;font-weight:700;padding:.1rem .4rem;cursor:pointer}
.sb-toggle button.active{background:var(--a2);color:#04121f}
.sb-main{display:grid;grid-template-columns:300px 1fr;gap:1rem;align-items:start}
.sb-left{padding:.9rem}
.sb-cats{display:flex;gap:.4rem;margin-bottom:.6rem;flex-wrap:wrap}
.sb-cat{flex:1;min-width:72px;background:transparent;border:1px solid var(--stroke);color:var(--muted);border-radius:999px;padding:.4rem .2rem;font:inherit;font-size:.76rem;font-weight:700;cursor:pointer;transition:.15s}
.sb-cat.active{background:var(--grad-soft);border-color:var(--a2);color:var(--text)}
.sb-hint{font-size:.72rem;color:var(--muted);margin:.2rem 0 .6rem}
.sb-cards{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;max-height:560px;overflow-y:auto}
.sb-card{background:rgba(0,0,0,.18);border:1px solid var(--stroke);border-radius:11px;padding:.5rem;cursor:pointer;transition:.15s;display:flex;flex-direction:column;gap:.35rem}
.sb-card:hover{border-color:var(--a2);transform:translateY(-2px)}
.sb-card.active{border-color:var(--a2);background:var(--grad-soft)}
.sb-card canvas{width:100%;height:54px;display:block}
.sb-card span{font-size:.72rem;font-weight:700;color:var(--text);line-height:1.15;text-align:center}
.sb-right{display:flex;flex-direction:column;gap:1rem;min-width:0}
.sb-chartcard{padding:.9rem}
.sb-ct-row{display:flex;gap:.3rem;border-bottom:1px solid var(--stroke);margin-bottom:.7rem;flex-wrap:wrap}
.sb-ct{background:transparent;border:0;border-bottom:2px solid transparent;color:var(--muted);font:inherit;font-size:.82rem;font-weight:700;padding:.45rem .7rem;cursor:pointer;margin-bottom:-1px}
.sb-ct.active{color:var(--text);border-bottom-color:var(--a2)}
.sb-legend{display:flex;gap:1rem;flex-wrap:wrap;font-size:.72rem;color:var(--muted);margin-bottom:.5rem;align-items:center}
.sb-legend .dot{display:inline-block;width:9px;height:9px;border-radius:2px;margin-right:.3rem;vertical-align:middle}
.sb-legend .ln{display:inline-block;width:16px;height:0;border-top:3px solid;margin-right:.3rem;vertical-align:middle}
.fs-canvas{width:100%;height:380px;display:block}
.fs-surface{width:100%;height:340px;display:block;background:rgba(0,0,0,.22);border:1px solid var(--stroke);border-radius:12px}
.sb-table{width:100%;border-collapse:collapse;font-size:.8rem}
.sb-table th,.sb-table td{padding:.4rem .6rem;text-align:right;border-bottom:1px solid var(--stroke)}
.sb-table th:first-child,.sb-table td:first-child{text-align:left}
.sb-table th{color:var(--muted);font-weight:700;font-size:.7rem;text-transform:uppercase;letter-spacing:.03em;position:sticky;top:0;background:var(--bg)}
.sb-table td.up{color:var(--up,#22c55e)}
.sb-table td.down{color:var(--down,#ef4444)}
.sb-table tr.now td{background:rgba(56,189,248,.08);font-weight:700}
.sb-tablewrap{max-height:400px;overflow-y:auto}
.sb-legs{padding:.9rem}
@media(max-width:1000px){.sb-main{grid-template-columns:1fr}.sb-cards{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));max-height:none}}
.sb-cursor{display:flex;align-items:center;gap:.6rem;margin:.7rem 0 .2rem;font-size:.78rem;color:var(--muted);flex-wrap:wrap}
.sb-cursor-lab{font-weight:700;color:var(--text)}
.sb-cursor-pct{color:var(--a2);font-weight:700;min-width:48px}
.sb-cursor input[type=range]{flex:1;min-width:160px;accent-color:#22c55e}
.sb-cursor b{color:var(--text);min-width:80px;text-align:right}
.sb-extra{display:grid;grid-template-columns:1fr 1fr;gap:1rem;padding:.9rem}
.sb-extra h4{font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin:0 0 .5rem;font-weight:700}
.sb-extra .row{display:flex;justify-content:space-between;gap:1rem;font-size:.82rem;padding:.28rem 0;border-bottom:1px solid var(--stroke)}
.sb-extra .row b{color:var(--text)}
.sb-glot{display:flex;align-items:center;gap:.5rem;font-size:.78rem;color:var(--muted);margin-bottom:.6rem;cursor:pointer}
@media(max-width:700px){.sb-extra{grid-template-columns:1fr}}
.sb-canvas-wrap{position:relative;width:100%}
.sb-canvas-wrap .fs-canvas{cursor:crosshair}
.sb-tip{position:absolute;z-index:5;pointer-events:none;min-width:172px;background:rgba(15,23,42,.97);border:1px solid var(--stroke2);border-radius:12px;padding:.6rem .7rem;box-shadow:0 12px 30px rgba(0,0,0,.45);font-size:.8rem}
.sb-tip .t-h{font-size:.68rem;color:var(--muted);text-align:center}
.sb-tip .t-p{text-align:center;margin:.15rem 0 .5rem;font-size:.85rem}
.sb-tip .t-p b{font-size:1.15rem;color:var(--text);margin-right:.25rem}
.sb-tip .t-s{font-size:.66rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;border-top:1px solid var(--stroke);padding-top:.45rem;margin-bottom:.3rem}
.sb-tip .t-r{display:flex;justify-content:space-between;gap:1.2rem;padding:.18rem 0;color:var(--text)}
.sb-tip .up{color:var(--up,#22c55e)}
.sb-tip .down{color:var(--down,#ef4444)}
.sb-charthead{display:flex;justify-content:space-between;align-items:center;gap:.6rem;border-bottom:1px solid var(--stroke);margin-bottom:.7rem;flex-wrap:wrap}
.sb-charthead .sb-ct-row{border-bottom:0;margin-bottom:0}
.sb-chartctrls{display:flex;gap:.4rem;align-items:center;flex-wrap:wrap}
.sb-chartctrls .oi-select{font-size:.74rem;padding:.3rem .45rem}
.sb-zoom{width:28px;height:28px;border:1px solid var(--stroke);background:transparent;color:var(--text);border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;line-height:1}
.sb-zoom:hover{border-color:var(--a2);background:var(--grad-soft)}
.sb-sc-head{display:flex;align-items:center;gap:.8rem;margin-bottom:.6rem;flex-wrap:wrap}
.sb-sc-tabs{display:flex;gap:.3rem}
.sb-sc{background:transparent;border:1px solid var(--stroke);color:var(--muted);border-radius:7px;padding:.25rem .6rem;font:inherit;font-size:.74rem;font-weight:700;cursor:pointer}
.sb-sc.active{background:var(--grad-soft);border-color:var(--a2);color:var(--text)}
.sb-sc-tf{display:flex;gap:.25rem;margin-left:auto}
.sb-sc-tf button{background:transparent;border:1px solid var(--stroke);color:var(--muted);border-radius:6px;padding:.2rem .45rem;font:inherit;font-size:.7rem;cursor:pointer}
.sb-sc-tf button.active{border-color:var(--a2);color:var(--text)}
.fs-sc-chart{width:100%;height:360px;border:1px solid var(--stroke);border-radius:12px;overflow:hidden}


/* ===================== GLOBAL LIGHT THEME OVERRIDES ===================== */
.strip{color:#475569}
.nav{background:rgba(255,255,255,.88)}
.user-btn{color:var(--text)}
.user-pop{background:#ffffff}
.user-act.danger{color:var(--down)}
.auth-tabs{background:rgba(15,23,42,.05)}
.field2 input{background:#ffffff}
.wl-search{background:#ffffff}
.wl-item:hover{background:#f2f5fa}
.tf,.seg,.oi-tf{background:rgba(15,23,42,.04)}
.fin-stat,.oi-stat,.lfeat,.ind-pop,.ind-item,.strat-presets button,.levs button,.px{background:#f5f7fb}
.px:hover{background:#eef2f8}
.stepper input,.leg-row select,.leg-row input,.lnews-form input,.oi-select{background:#ffffff}
.opt-table .strike-col,.oi-strike{background:rgba(15,23,42,.045)}
.ind-chip button,.leg-del{background:rgba(15,23,42,.07)}
.cone-track{background:rgba(15,23,42,.06)}
.cone-med{background:rgba(15,23,42,.55)}
.strat-surface,.fs-surface,.sb-card{background:#f5f7fb}
.toast,.oi-tooltip,.sb-tip{background:#ffffff;color:var(--text)}
.nav-view:hover,.ind-item:hover,.oi-subtab:hover,.strat-presets button:hover,.lnav-links a:hover,.lfoot-cols a:hover,.auth-close:hover{color:var(--text)}
.lnav{background:rgba(255,255,255,.88);border-bottom:1px solid var(--stroke)}

/* ===================== BLOG (premium reading + cards) ===================== */
.bx-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.1rem;margin-top:.4rem}
.bx-card{background:#fff;border:1px solid var(--stroke);border-radius:16px;overflow:hidden;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;display:flex;flex-direction:column}
.bx-card:hover{transform:translateY(-3px);box-shadow:0 16px 34px -22px rgba(15,23,42,.4)}
.bx-card-hero{height:120px;overflow:hidden}
.bx-card-hero svg{width:100%;height:100%;display:block}
.bx-card-body{padding:.9rem 1rem 1.1rem}
.bx-card-body h3{margin:.3rem 0;font-size:1.05rem;line-height:1.25}
.bx-card-body p{color:var(--muted);font-size:.9rem;margin:.2rem 0 .6rem}
.bx-read{color:var(--a2);font-weight:700;font-size:.78rem}
.btag{font-size:.7rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--a2)}
.bx{max-width:760px;margin:0 auto;padding-bottom:2rem}
.bx-hero{height:220px;border-radius:18px;overflow:hidden;margin:.4rem 0 1.2rem;box-shadow:0 18px 40px -28px rgba(15,23,42,.5)}
.bx-hero svg{width:100%;height:100%;display:block}
.bx-title{font-size:clamp(1.7rem,3.4vw,2.5rem);line-height:1.12;margin:.5rem 0 .3rem}
.bx-dek{font-size:1.15rem;color:#334155;margin:.2rem 0 .5rem}
.bx .pmeta{color:var(--muted);font-size:.85rem;margin-bottom:1.2rem}
.bx-kt{background:#f5f7fb;border:1px solid var(--stroke);border-radius:14px;padding:1rem 1.2rem;margin:1.2rem 0}
.bx-kt h3{margin:0 0 .5rem;font-size:1rem}
.bx-kt ul{margin:0;padding-left:1.1rem}.bx-kt li{margin:.3rem 0;color:#334155}
.bx-toc{border-left:3px solid var(--a2);background:rgba(37,99,235,.05);border-radius:0 10px 10px 0;padding:.7rem 1rem;margin:1.2rem 0;font-size:.92rem}
.bx-toc ol{margin:.3rem 0 0;padding-left:1.2rem}.bx-toc a{color:#334155;text-decoration:none}.bx-toc a:hover{color:var(--a2)}
.bx-sec{margin:1.6rem 0}
.bx-sec h2{font-size:1.4rem;line-height:1.2;margin:0 0 .6rem;scroll-margin-top:80px}
.bx-sec p{line-height:1.8;margin:.7rem 0;color:#1f2937}
.bx-sec ul{padding-left:1.2rem}.bx-sec li{margin:.35rem 0;line-height:1.7;color:#1f2937}
.bx-sec blockquote{border-left:4px solid var(--a2);margin:1rem 0;padding:.4rem 1rem;font-style:italic;color:#334155;background:rgba(37,99,235,.04);border-radius:0 8px 8px 0}
.bx-fig{margin:1rem 0;background:#fff;border:1px solid var(--stroke);border-radius:12px;padding:.8rem}
.bx-fig svg{width:100%;height:auto;display:block}
.bx-faq{margin-top:2rem;border-top:1px solid var(--stroke);padding-top:1rem}
.bx-faq details{border:1px solid var(--stroke);border-radius:10px;padding:.6rem .9rem;margin:.5rem 0;background:#fff}
.bx-faq summary{cursor:pointer;font-weight:600;list-style:none}
.bx-faq summary::-webkit-details-marker{display:none}
.bx-faq details[open]{background:#f8fafc}
.bx-faq p{margin:.6rem 0 0;color:#334155;line-height:1.7}
.bx-disc{margin-top:1.6rem;font-size:.85rem}
.bx-overlay{max-width:820px;text-align:left;max-height:88vh;overflow:auto}
#view-blog .back{background:transparent;border:0;color:var(--a2);font-weight:700;cursor:pointer;font-size:.95rem;padding:.3rem 0;font-family:inherit}

/* ===================== COURSE PLAYER + PPT SLIDES ===================== */
.cwrap{max-width:1000px;margin:0 auto}
.cwrap .back{background:transparent;border:0;color:var(--a2);font-weight:700;cursor:pointer;font-size:.95rem;padding:.3rem 0;font-family:inherit}
.chead{display:flex;align-items:center;gap:1rem;margin:.4rem 0 .3rem}
.ccode-lg{width:54px;height:54px;border-radius:14px;background:var(--grad);color:#06101e;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.05rem;flex:0 0 auto}
.chead h2{margin:0}
.cintro{color:#334155;line-height:1.7;margin:.4rem 0 1.2rem;max-width:75ch}
.cbody{display:grid;grid-template-columns:248px 1fr;gap:1.4rem;align-items:start}
.cnav{display:flex;flex-direction:column;gap:.25rem;position:sticky;top:74px;max-height:calc(100vh - 96px);overflow:auto}
.cnav-item{display:flex;gap:.5rem;align-items:flex-start;text-align:left;background:transparent;border:1px solid transparent;border-radius:9px;padding:.5rem .6rem;cursor:pointer;font-family:inherit;font-size:.85rem;color:var(--muted);line-height:1.3}
.cnav-item:hover{background:var(--glass2);color:var(--text)}
.cnav-item.active{background:rgba(37,99,235,.08);color:var(--text);border-color:rgba(37,99,235,.25);font-weight:600}
.cnav-n{flex:0 0 auto;width:20px;height:20px;border-radius:50%;background:var(--glass2);display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700}
.cnav-item.active .cnav-n{background:var(--a2);color:#fff}
.clesson{min-width:0}
.clesson-head{display:flex;gap:.6rem;align-items:center;margin-bottom:.9rem}
.clesson-head .lnum{flex:0 0 auto}
.clesson-head h3{margin:0;font-size:1.4rem}
.cprose p{line-height:1.8;color:#1f2937;margin:.7rem 0}
.cex{background:#f5f7fb;border:1px solid var(--stroke);border-left:4px solid var(--a2);border-radius:0 10px 10px 0;padding:.8rem 1rem;margin:1.1rem 0}
.cex p{margin:.3rem 0 0;color:#334155;line-height:1.7}
.ckp{background:rgba(21,163,74,.06);border:1px solid rgba(21,163,74,.2);border-radius:10px;padding:.8rem 1rem;margin:1.1rem 0}
.ckp ul{margin:.4rem 0 0;padding-left:1.1rem}.ckp li{margin:.3rem 0;color:#334155}
.cnavbtns{display:flex;justify-content:space-between;align-items:center;margin-top:1.4rem;gap:1rem}
.cdeck{background:linear-gradient(135deg,#0f172a,#1e293b);border-radius:16px;padding:1.2rem 1.3rem;margin:0 0 1.2rem;color:#e8edf6;box-shadow:0 16px 40px -26px rgba(15,23,42,.6)}
.cslides{position:relative;min-height:188px}
.cslide{display:none}.cslide.active{display:block;animation:cfade .25s ease}
@keyframes cfade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.cslide-n{font-size:.7rem;color:#94a3b8;letter-spacing:.05em;text-transform:uppercase;margin-bottom:.3rem}
.cslide h4{margin:.1rem 0 .7rem;font-size:1.2rem;color:#fff}
.cslide ul{margin:0;padding-left:1.1rem}.cslide li{margin:.45rem 0;line-height:1.6;color:#dbe3f0}
.cslide-fig{margin-top:.8rem;background:#fff;border-radius:10px;padding:.6rem;max-width:420px}
.cslide-fig svg{width:100%;height:auto;display:block}
.cdeck-nav{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1rem}
.cd-prev,.cd-next{background:rgba(255,255,255,.1);border:0;color:#fff;width:34px;height:34px;border-radius:50%;cursor:pointer;font-size:1.3rem;line-height:1}
.cd-prev:hover,.cd-next:hover{background:rgba(255,255,255,.22)}
.cdots{display:flex;gap:.4rem;align-items:center}
.cdot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.25);cursor:pointer;transition:width .15s ease}
.cdot.active{background:var(--a2);width:22px;border-radius:5px}
@media(max-width:760px){.cbody{grid-template-columns:1fr}.cnav{flex-direction:row;flex-wrap:wrap;position:static;max-height:none}.cnav-item{font-size:.78rem}}

/* ===================== ACADEMY LEVEL CATALOG ===================== */
.aca-tabs{display:flex;gap:.4rem;flex-wrap:wrap;margin:.2rem 0 1.1rem}
.aca-tab{background:var(--glass2);border:1px solid var(--stroke);color:var(--muted);border-radius:999px;padding:.42rem .95rem;cursor:pointer;font-family:inherit;font-size:.85rem;font-weight:600}
.aca-tab:hover{color:var(--text)}
.aca-tab.active{background:var(--grad);color:#06101e;border-color:transparent}
.aca-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.55rem}
.aca-tier{font-size:.64rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;padding:.2rem .55rem;border-radius:999px}
.t-beginner{background:rgba(21,163,74,.14);color:#15803d}
.t-intermediate{background:rgba(37,99,235,.14);color:#1d4ed8}
.t-advanced{background:rgba(168,85,247,.16);color:#7c3aed}

/* ============================================================
   PREMIUM LANDING REDESIGN  (custom First Plan India)
   ============================================================ */
#landing .sub{color:var(--muted);font-size:.95rem}
.eyebrow{display:inline-block;font-family:"Satoshi",sans-serif;font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--a2);margin-bottom:.6rem}
.eyebrow.on-grad{color:rgba(255,255,255,.9)}
.grad{background:linear-gradient(100deg,#7c5cff,#2f8bff 55%,#0bb3c9);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.btn-lg{padding:.92rem 1.6rem;font-size:1.02rem;border-radius:14px}
.btn-light{background:#fff;color:#1b2440;border:1px solid #fff;border-radius:12px;padding:.7rem 1.1rem;font-weight:800;cursor:pointer;font-family:inherit}
.btn-light:hover{background:#eef2ff}

/* nav */
#landing .lnav{background:rgba(255,255,255,.82);border-bottom:1px solid var(--stroke);padding:1rem 1.2rem}
.lnav-links a{font-weight:600;transition:color .15s}
.lnav-links a:hover{color:var(--text)}

/* reveal on scroll */
.js .reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.js .reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.js .reveal{opacity:1!important;transform:none!important}}

/* HERO */
.hero{position:relative;padding:3.6rem 0 2.4rem;overflow:visible}
.hero-orb{position:absolute;border-radius:50%;filter:blur(72px);z-index:-1;pointer-events:none;opacity:.55}
.hero-orb-a{width:520px;height:520px;top:-170px;left:-130px;background:radial-gradient(circle,rgba(124,92,255,.5),transparent 65%)}
.hero-orb-b{width:480px;height:480px;top:-90px;right:-120px;background:radial-gradient(circle,rgba(47,139,255,.45),transparent 65%)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:2.6rem;align-items:center}
.pill{display:inline-flex;align-items:center;gap:.5rem;font-size:.78rem;font-weight:700;color:var(--text);background:var(--glass);border:1px solid var(--stroke2);border-radius:999px;padding:.42rem .9rem;box-shadow:var(--shadow-sm)}
.pill-dot{width:8px;height:8px;border-radius:50%;background:var(--up);box-shadow:0 0 0 4px rgba(21,163,74,.18)}
.hero h1{font-family:"Clash Display",sans-serif;font-size:clamp(2.7rem,5.6vw,4.6rem);line-height:1.02;font-weight:700;letter-spacing:-.025em;margin:1.1rem 0 0}
.hero-lead{color:var(--muted);font-size:1.14rem;line-height:1.6;max-width:56ch;margin:1.1rem 0 0}
.hero-cta{display:flex;gap:.8rem;flex-wrap:wrap;margin:1.8rem 0 1.3rem}
.hero-proof{display:flex;align-items:center;gap:.9rem;flex-wrap:wrap}
.stars{color:#f5a623;font-size:1rem;font-weight:700;letter-spacing:.06em}
.stars span{color:var(--muted);font-size:.84rem;margin-left:.4rem;letter-spacing:0;font-weight:600}
.hero-proof-dot{width:5px;height:5px;border-radius:50%;background:var(--faint)}
.hero-proof-txt{color:var(--muted);font-size:.84rem;font-weight:600}
.hero-visual{position:relative;transition:transform .2s ease-out;transform-style:preserve-3d}
.hv-card{background:var(--glass);border:1px solid var(--stroke2);border-radius:20px;box-shadow:var(--shadow);padding:1rem 1rem .9rem}
.hv-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}
.hv-sym{font-weight:800;font-size:.92rem;display:flex;align-items:center;gap:.45rem}
.hv-live{width:8px;height:8px;border-radius:50%;background:var(--up);box-shadow:0 0 8px var(--up);animation:pulse 1.8s infinite;display:inline-block}
.hv-tf{font-size:.7rem;font-weight:700;color:var(--muted);background:var(--glass2);border:1px solid var(--stroke);border-radius:7px;padding:.2rem .5rem}
.hero-visual .lhero-canvas{width:100%;height:300px;display:block;border-radius:12px}
.hv-foot{display:flex;justify-content:space-between;align-items:flex-end;margin-top:.6rem;padding-top:.6rem;border-top:1px solid var(--stroke)}
.hv-eq span{display:block;font-size:.64rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:700}
.hv-eq b{font-family:"Clash Display";font-size:1.35rem;font-weight:700}
.hv-chg{font-weight:800;font-size:1rem}
.hv-chg.up{color:var(--up)}
.hv-float{position:absolute;background:rgba(16,20,32,.94);color:#fff;border:1px solid var(--stroke2);border-radius:12px;padding:.55rem .8rem;font-size:.78rem;font-weight:700;box-shadow:var(--shadow)}
.hv-float .dotg{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--up);margin-right:.4rem}
.hv-float-1{left:-26px;top:34%;animation:floaty 4s ease-in-out infinite}
.hv-float-2{right:-18px;bottom:16%;display:flex;flex-direction:column;line-height:1.15;animation:floaty 5s ease-in-out infinite reverse}
.hv-float-2 b{color:#46d08a;font-family:"Clash Display";font-size:1.05rem}
.hv-float-2 span{font-size:.62rem;color:#aab4cc;text-transform:uppercase;letter-spacing:.05em}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

/* TICKER */
.ticker{margin:.6rem 0 0;border-top:1px solid var(--stroke);border-bottom:1px solid var(--stroke);background:var(--glass);overflow:hidden;white-space:nowrap}
.ticker-track{display:inline-block;padding:.6rem 0;animation:tickerScroll 60s linear infinite;will-change:transform}
.ticker:hover .ticker-track{animation-play-state:paused}
.tk{display:inline-flex;align-items:center;gap:.4rem;margin:0 1.4rem;font-size:.84rem;font-weight:700;color:var(--text)}
.tk b{color:var(--muted);font-weight:700}
.tk i{font-style:normal;font-weight:800}
.tk i.up{color:var(--up)}.tk i.down{color:var(--down)}
@keyframes tickerScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* STATS */
.lstats{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;padding:2.6rem 0;margin:.2rem 0;border-bottom:1px solid var(--stroke)}
.lstat{text-align:center}
.lstat b{display:block;font-family:"Clash Display";font-size:clamp(2rem,3.6vw,3rem);font-weight:700;line-height:1;background:linear-gradient(120deg,#7c5cff,#2f8bff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.lstat span{display:block;margin-top:.45rem;font-size:.82rem;color:var(--muted);font-weight:600}

/* section heads */
.lsec-head{max-width:700px;margin:0 auto 2.1rem;text-align:center}
.lsec-head h2{font-family:"Clash Display";font-size:clamp(1.9rem,3.6vw,2.7rem);font-weight:700;letter-spacing:-.02em}
.lsec-head .sub{color:var(--muted);font-size:1.04rem;margin:.55rem auto 0;max-width:60ch}
.lsec-foot{text-align:center;margin-top:2.2rem}

/* COURSES */
.lcourses{grid-template-columns:repeat(auto-fill,minmax(264px,1fr));gap:1.1rem}
.lcourse{border-radius:18px;padding:1.4rem}
.lcourse::before{content:"";position:absolute;inset:0;background:var(--grad-soft);opacity:0;transition:.25s;pointer-events:none}
.lcourse:hover::before{opacity:1}
.lcourse>*{position:relative}
.lcourse .ccode{box-shadow:0 10px 22px -10px rgba(124,92,255,.65);color:#fff}
.lcourse h3{font-family:"Clash Display";font-size:1.14rem;font-weight:600}
.lcourse .clessons{display:inline-flex;align-items:center;gap:.3rem;transition:gap .15s}
.lcourse:hover .clessons{gap:.55rem}

/* STEPS */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.step{background:var(--glass);border:1px solid var(--stroke);border-radius:18px;padding:1.7rem;box-shadow:var(--shadow-sm)}
.step-n{display:grid;place-items:center;width:48px;height:48px;border-radius:14px;font-family:"Clash Display";font-weight:700;font-size:1.3rem;color:#fff;background:linear-gradient(135deg,#7c5cff,#2f8bff);margin-bottom:1rem;box-shadow:0 10px 22px -10px rgba(124,92,255,.7)}
.step h3{font-family:"Clash Display";font-size:1.28rem;font-weight:600;margin:0 0 .3rem}
.step p{color:var(--muted);font-size:.95rem;margin:0;line-height:1.6}

/* BENTO */
.bento{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.bento-cell{background:var(--glass);border:1px solid var(--stroke);border-radius:18px;padding:1.5rem;box-shadow:var(--shadow-sm);transition:transform .2s,border-color .2s,box-shadow .2s}
.bento-cell:hover{transform:translateY(-4px);border-color:var(--a2);box-shadow:var(--shadow)}
.bento-lg{grid-row:span 2;display:flex;flex-direction:column}
.bento-mark{font-size:1.55rem;margin-bottom:.55rem;line-height:1}
.bento-cell h3{font-family:"Clash Display";font-size:1.12rem;font-weight:600;margin:0 0 .25rem}
.bento-cell p{color:var(--muted);font-size:.9rem;margin:0;line-height:1.55}
.bento-lg h3{font-size:1.5rem}
.bento-lg p{font-size:1rem}
.bento-spark{margin-top:auto;padding-top:1.1rem}
.bento-spark canvas{width:100%;height:auto;display:block;opacity:.9}

/* REVIEWS */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.review{margin:0;background:var(--glass);border:1px solid var(--stroke);border-radius:18px;padding:1.6rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:.85rem}
.review-stars{color:#f5a623;letter-spacing:.1em;font-size:1.05rem}
.review blockquote{margin:0;font-size:.98rem;line-height:1.65;color:var(--text)}
.review figcaption{display:flex;align-items:center;gap:.7rem;margin-top:auto}
.review-av{display:grid;place-items:center;width:42px;height:42px;border-radius:50%;font-family:"Clash Display";font-weight:700;color:#fff;background:linear-gradient(135deg,#7c5cff,#2f8bff)}
.review-who b{display:block;font-size:.92rem}
.review-who span{font-size:.74rem;color:var(--muted)}

/* MENTOR */
.mentor{display:grid;grid-template-columns:1.1fr .9fr;gap:2.2rem;align-items:center}
.mentor-copy h2{font-family:"Clash Display";font-size:clamp(1.7rem,3vw,2.4rem);font-weight:700}
.mentor-copy p{color:var(--muted);font-size:1.02rem;line-height:1.7;margin:.6rem 0 1.2rem}
.ticks{list-style:none;padding:0;margin:0 0 1.5rem;display:grid;gap:.65rem}
.ticks li{position:relative;padding-left:2rem;font-weight:600;font-size:.96rem}
.ticks li::before{content:"";position:absolute;left:0;top:0;width:22px;height:22px;border-radius:50%;background:var(--grad-soft);border:1px solid var(--a2)}
.ticks li::after{content:"";position:absolute;left:8px;top:4px;width:5px;height:10px;border:solid var(--a2);border-width:0 2px 2px 0;transform:rotate(45deg)}
.mentor-card{position:relative;background:linear-gradient(160deg,rgba(124,92,255,.1),rgba(47,139,255,.08));border:1px solid var(--stroke2);border-radius:22px;padding:2rem;box-shadow:var(--shadow)}
.mentor-badge{display:grid;place-items:center;width:54px;height:54px;border-radius:16px;font-family:"Clash Display";font-weight:700;font-size:1.2rem;color:#fff;background:linear-gradient(135deg,#7c5cff,#2f8bff);margin-bottom:1.1rem}
.mentor-quote{font-family:"Clash Display";font-size:1.32rem;font-weight:600;line-height:1.4;letter-spacing:-.01em}
.mentor-by{margin-top:1.2rem}
.mentor-by b{display:block}
.mentor-by span{font-size:.82rem;color:var(--muted)}

/* FAQ */
.faqs{max-width:800px;margin:0 auto;display:grid;gap:.7rem}
.faq{background:var(--glass);border:1px solid var(--stroke);border-radius:14px;padding:.1rem 1.2rem;transition:border-color .2s,box-shadow .2s}
.faq[open]{border-color:var(--a2);box-shadow:var(--shadow-sm)}
.faq summary{cursor:pointer;list-style:none;padding:1.05rem 0;font-weight:700;font-size:1.02rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--a2);font-weight:400;line-height:1;transition:transform .2s}
.faq[open] summary::after{transform:rotate(45deg)}
.faq p{color:var(--muted);line-height:1.65;margin:0 0 1.05rem;font-size:.96rem}

/* FINAL CTA */
.lcta{padding:3.2rem 0}
.lcta-card{position:relative;overflow:hidden;text-align:center;border-radius:28px;padding:3.6rem 1.5rem;background:linear-gradient(135deg,#5b3df0,#2f6df6 55%,#0bb3c9);color:#fff;box-shadow:0 40px 80px -40px rgba(47,109,246,.7)}
.lcta-glow{position:absolute;inset:0;background:radial-gradient(620px 320px at 50% -12%,rgba(255,255,255,.28),transparent 60%);pointer-events:none}
.lcta-card>*{position:relative}
.lcta-card h2{font-family:"Clash Display";font-size:clamp(2.1rem,4.2vw,3.1rem);font-weight:700;color:#fff;margin:0}
.lcta-card>p{max-width:60ch;margin:.85rem auto 0;color:rgba(255,255,255,.92);font-size:1.06rem;line-height:1.6}
.lcta-actions{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;margin:1.8rem 0 0}
.lcta .btn-primary{background:#fff;color:#2740a6}
.lcta .btn-primary:hover{filter:none;background:#eef2ff}
.lcta .btn-ghost{background:rgba(255,255,255,.14);color:#fff;border-color:rgba(255,255,255,.45)}
.lcta .btn-ghost:hover{background:rgba(255,255,255,.24)}
.lcta .lnews-form{max-width:470px;margin:1.7rem auto 0}
.lcta .lnews-form input{flex:1;min-width:220px;padding:.75rem 1rem;border-radius:12px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.4);color:#fff;font-family:inherit}
.lcta .lnews-form input::placeholder{color:rgba(255,255,255,.75)}
.lnews-msg{font-size:.85rem;margin:.7rem 0 0;color:#eafff2}

/* FOOTER */
.lfoot{border-top:1px solid var(--stroke);margin-top:2.6rem;padding-top:2.4rem}
.lfoot-cols{grid-template-columns:1.7fr 1fr 1fr 1.3fr}
.lfoot-brand .brand{margin-bottom:.6rem}
.lfoot-cols h4{font-family:"Clash Display";font-weight:600}

/* responsive */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr}
  .hero-visual{margin-top:1rem}
  .lstats{grid-template-columns:repeat(2,1fr);gap:1.6rem}
  .steps,.bento,.reviews{grid-template-columns:1fr}
  .bento-lg{grid-row:auto}
  .mentor{grid-template-columns:1fr}
  .lfoot-cols{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .hero h1{font-size:2.5rem}
  .hv-float-1{left:-6px}.hv-float-2{right:-4px}
}

/* ============================================================
   MOBILE NAVIGATION AND LAYOUT COMPONENTS (DESKTOP DEFAULTS)
   ============================================================ */
.lnav-toggle {
  display: none;
  background: transparent;
  border: 0;
  cursor: pointer;
  padding: .4rem;
  z-index: 100;
  flex-direction: column;
  gap: 5px;
  align-items: center;
  justify-content: center;
}
.lnav-toggle span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--text);
  border-radius: 9px;
  transition: transform .2s, opacity .2s;
}
.lnav-mobile {
  position: fixed;
  inset: 0;
  background: rgba(8, 11, 19, 0.6);
  backdrop-filter: blur(8px);
  z-index: 200;
  display: flex;
  justify-content: flex-end;
}
.lnav-mobile[hidden] {
  display: none !important;
}
.lnav-mobile-card {
  width: 280px;
  height: 100%;
  background: var(--bg);
  border-left: 1px solid var(--stroke);
  padding: 2.2rem 1.6rem;
  display: flex;
  flex-direction: column;
  gap: 2rem;
  position: relative;
  box-shadow: -10px 0 30px rgba(0,0,0,0.5);
  animation: slideIn .25s ease-out;
}
@keyframes slideIn {
  from { transform: translateX(100%); }
  to { transform: translateX(0); }
}
.lnav-mobile-close {
  position: absolute;
  top: 1rem;
  right: 1.2rem;
  background: transparent;
  border: 0;
  color: var(--muted);
  font-size: 2.2rem;
  cursor: pointer;
  line-height: 1;
  padding: 0;
}
.lnav-mobile-close:hover {
  color: var(--text);
}
.lnav-mobile-links {
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
}
.lnav-mobile-links a {
  color: var(--muted);
  font-size: 1.15rem;
  font-weight: 700;
  text-decoration: none;
  transition: color .15s;
}
.lnav-mobile-links a:hover {
  color: var(--text);
}
.lnav-mobile-cta {
  display: flex;
  flex-direction: column;
  gap: .8rem;
  margin-top: auto;
}
.lnav-mobile-cta .btn {
  width: 100%;
  padding: .75rem;
  text-align: center;
  font-weight: 700;
}

.terminal-mobile-nav {
  display: none;
}

/* ============================================================
   MOBILE / RESPONSIVE  (entire portal — iOS + Android)
   ============================================================ */
@media (max-width: 760px){
  body{font-size:16px}
  /* landing */
  #landing{padding:0 1rem 2rem}
  .lsection{padding:2.1rem 0 .3rem}
  .hero{padding:2rem 0 1.4rem}
  .lsec-head{margin-bottom:1.4rem}
  .lsec-head h2{font-size:1.7rem}
  .lsec-head .sub{font-size:.98rem}
  .hero-lead{font-size:1.05rem}
  .hero-cta{gap:.6rem}
  .hero-cta .btn{flex:1 1 auto;text-align:center}
  .lnav{gap:.6rem}
  .lnav-cta{gap:.4rem}
  .lnav-cta .btn{padding:.55rem .85rem;font-size:.86rem}
  .lstats{grid-template-columns:repeat(2,1fr);gap:1.3rem;padding:2rem 0}
  .lstat:last-child{grid-column:1 / -1}
  .lstat span{font-size:.84rem}
  .ticker-track{animation-duration:42s!important}
  .lcta-card{padding:2.6rem 1.2rem}
  .lcta .lnews-form{flex-direction:column}
  .lcta .lnews-form .btn{width:100%}
  /* mobile landing header overrides */
  .lnav-toggle {
    display: flex;
  }
  .lnav-cta .btn {
    display: none !important;
  }

  /* terminal / app */
  .nav{flex-wrap:wrap;gap:.5rem;padding:.5rem .7rem}
  .nav-views{order:3;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:.25rem;padding-bottom:.15rem}
  .nav-view{font-size:.92rem;padding:.45rem .75rem;white-space:nowrap}
  .balance-pill{padding:.3rem .65rem}
  .balance-pill strong{font-size:.98rem}
  .view-page{padding:1rem .8rem}

  /* Mobile terminal tabs styling */
  .terminal-mobile-nav {
    display: flex;
    background: var(--glass);
    border: 1px solid var(--stroke);
    border-radius: 12px;
    margin: .6rem;
    padding: .2rem;
    gap: .2rem;
  }
  .tm-tab {
    flex: 1;
    border: 0;
    background: transparent;
    color: var(--muted);
    font-weight: 700;
    font-size: .88rem;
    padding: .5rem;
    border-radius: 9px;
    cursor: pointer;
    font-family: inherit;
    transition: background .15s, color .15s;
  }
  .tm-tab.active {
    background: var(--grad);
    color: #06101e;
  }

  /* Toggle terminal sections on mobile */
  .terminal:not(.show-watchlist) .watchlist {
    display: none !important;
  }
  .terminal:not(.show-chart) .center {
    display: none !important;
  }
  .terminal:not(.show-trade) .rightcol {
    display: none !important;
  }

  .terminal{padding:.6rem;gap:.7rem;grid-template-columns:1fr !important}
  .watchlist{height:auto;position:static}
  .wl-list{max-height:calc(100vh - 200px) !important}
  .rightcol{position:static}
  .chart-container{height:56vh}

  /* Make lower tabs scrollable instead of wrapping */
  .ltabs {
    overflow-x: auto;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 5px;
    display: flex;
    gap: .4rem;
  }
  .ltab {
    flex: 0 0 auto;
  }

  .aca-grid,.lcourses,.blog-list,.lblog{grid-template-columns:1fr}
  /* bump tiny fonts so nothing is unreadable on phones */
  .wl-sym,.bp-label,.hc-title,.fin-stat span,.oi-stat span,.ticket-meta span,.cone-head,.px span,.tag,.lfoot-cols a,.opt-meta,.csub{font-size:.8rem}
  .wl-nm{font-size:.95rem}
  .wl-px{font-size:.95rem}
  .wl-chg{font-size:.84rem}
  .field,.field2{font-size:.82rem}
  table.prices,.opt-table,.sb-table{font-size:.92rem}
  .ltab,.wl-cats button,.tf button,.oi-subtab,.strat-presets button{font-size:.85rem}
  .cprose p,.lesson p,.post p{font-size:1rem;line-height:1.75}
  .clesson-head h3,.lesson h3{font-size:1.12rem}
  /* strategy builder + sensible stacking */
  .sb-main{grid-template-columns:1fr}
  .sb-cards{grid-template-columns:repeat(auto-fill,minmax(108px,1fr));max-height:none}
  .strat-body{grid-template-columns:1fr}
  /* modal full width */
  .auth-modal{padding:.7rem}
  .auth-card{max-width:100%;padding:1.6rem 1.3rem}
  /* map */
  .lvisit-map,.lvisit-map iframe{min-height:300px}
  /* gallery comfortable single/double column */
  .lgallery{columns:200px;column-gap:.7rem}
}
@media (max-width: 430px){
  .hero h1{font-size:2.25rem}
  .lsec-head h2{font-size:1.5rem}
  .brand-text{font-size:1rem}
  .lnav{padding:.8rem .9rem}
  .lnav-cta .btn{padding:.5rem .7rem;font-size:.82rem}
  .lstats b{font-size:2.1rem}
  .lgallery{columns:1;column-gap:0}
  .nav-view{font-size:.88rem;padding:.4rem .6rem}
  .hc-equity{font-size:1.6rem}
  .nav .live{display:none !important}
}

/* ============================================================
   PREMIUM COURSE CARDS (image header + learn more)
   ============================================================ */
.lcourse,.aca-card{padding:0;overflow:hidden;border-radius:18px;background:var(--glass);border:1px solid var(--stroke);display:flex;flex-direction:column;cursor:pointer;transition:transform .2s,border-color .2s,box-shadow .2s}
.lcourse:hover,.aca-card:hover{transform:translateY(-5px);border-color:var(--stroke2);box-shadow:var(--shadow);background:var(--glass)}
.lcourse::before{display:none}
.lc-hero{position:relative;aspect-ratio:16 / 9;overflow:hidden;background:var(--glass2)}
.lc-hero img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .55s ease}
.lcourse:hover .lc-hero img,.aca-card:hover .lc-hero img{transform:scale(1.06)}
.lc-tag,.aca-card .aca-tier{position:absolute;top:.7rem;left:.7rem;z-index:2;font-size:.62rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;padding:.32rem .65rem;border-radius:999px;background:rgba(10,14,24,.74);color:#fff;backdrop-filter:blur(4px);margin:0;border:0}
.lc-body{padding:1.2rem 1.3rem 1.35rem;display:flex;flex-direction:column;gap:.45rem;flex:1}
.lc-body h3{font-family:"Clash Display";font-size:1.2rem;font-weight:600;margin:0;line-height:1.18}
.lc-body p{color:var(--muted);font-size:.9rem;line-height:1.5;margin:0;flex:1}
.lc-more{align-self:flex-start;margin-top:.8rem;border:1px solid var(--stroke2);border-radius:999px;padding:.5rem 1.1rem;font-weight:700;color:var(--text);display:inline-flex;align-items:center;gap:.5rem;font-size:.86rem;transition:background .18s,border-color .18s}
.lcourse:hover .lc-more,.aca-card:hover .lc-more{border-color:var(--a2);background:var(--grad-soft)}
.lc-more i{color:var(--a2);font-style:normal;transition:transform .15s}
.lcourse:hover .lc-more i,.aca-card:hover .lc-more i{transform:translateX(3px)}

/* kill any horizontal overflow on mobile (decorative orbs/floats) */
html{overflow-x:hidden}
@media (max-width: 760px){
  .hero{overflow:hidden}
  .hero-orb-a{left:-190px;width:340px;height:340px}
  .hero-orb-b{right:-170px;width:320px;height:320px}
  .hv-float-1{left:0}
  .hv-float-2{right:0}
}

/* order ticket: stop loss / target + risk-reward */
.ticket-sltp{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
.ticket-sltp .field{margin-bottom:.7rem}
.ticket-sltp input{padding:.55rem;background:rgba(0,0,0,.22);border:1px solid var(--stroke2);border-radius:9px;color:var(--text);font-size:.95rem;font-family:inherit;font-variant-numeric:tabular-nums;width:100%}
.ticket-rr{display:flex;gap:.8rem;justify-content:center;font-size:.8rem;color:var(--muted);margin:-.1rem 0 .7rem}
.ticket-rr b{font-variant-numeric:tabular-nums}
.rr-loss{color:var(--down)}
.rr-gain{color:var(--up)}
.pos-sltp{display:flex;gap:.35rem;margin-top:.25rem}
.pos-sltp span{font-size:.6rem;font-weight:700;padding:.06rem .36rem;border-radius:5px}
.pos-sltp .sl{color:var(--down);background:rgba(255,84,112,.12)}
.pos-sltp .tp{color:var(--up);background:rgba(22,199,132,.12)}

/* ===================== LANGUAGE TOGGLE + HINDI TYPE ===================== */
.strip{position:relative;padding-right:3.6rem}
.lang-toggle{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);display:inline-flex;align-items:center;gap:.22rem;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:999px;padding:.16rem .55rem;font-size:.72rem;font-weight:800;cursor:pointer;font-family:inherit;line-height:1.2;z-index:3}
.lang-toggle:hover{background:rgba(255,255,255,.28)}
.lang-toggle .lt-sep{opacity:.45;font-weight:400}
.lang-toggle .lt-en,.lang-toggle .lt-hi{opacity:.5;transition:opacity .15s}
.lang-toggle[data-lang="en"] .lt-en{opacity:1}
.lang-toggle[data-lang="hi"] .lt-hi{opacity:1}
html.lang-hi body{font-family:"Noto Sans Devanagari","Satoshi",system-ui,sans-serif}
html.lang-hi h1,html.lang-hi h2,html.lang-hi h3,html.lang-hi h4,html.lang-hi .hero h1,html.lang-hi .lsec-head h2,html.lang-hi .lcta-card h2,html.lang-hi .mentor-quote,html.lang-hi .lstat b,html.lang-hi .brand-text,html.lang-hi .step-n,html.lang-hi .hv-eq b{font-family:"Baloo 2","Noto Sans Devanagari",sans-serif}

/* prominent language buttons (nav + app top bar) */
.lang-btn{display:inline-flex;align-items:center;gap:.42rem;cursor:pointer;font-family:inherit;font-weight:700;border-radius:999px;border:1px solid var(--stroke2);background:var(--glass);color:var(--text);padding:.5rem .85rem;font-size:.9rem;line-height:1;transition:background .15s,border-color .15s,transform .15s;white-space:nowrap}
.lang-btn:hover{border-color:var(--a2);background:var(--grad-soft);transform:translateY(-1px)}
.lang-btn .lang-ico{display:grid;place-items:center;width:20px;height:20px;border-radius:50%;background:var(--grad);color:#fff;font-size:.72rem;font-weight:800;font-family:"Baloo 2","Noto Sans Devanagari","Clash Display",sans-serif}
.lang-btn-app{padding:.42rem .7rem;font-size:.82rem}
/* make the strip toggle a touch brighter too */
.lang-toggle{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.45)}
@media (max-width: 560px){
  .lnav-cta .lang-btn{padding:.45rem .55rem;font-size:0;gap:0}
  .lnav-cta .lang-btn .lang-ico{font-size:.78rem}
}

/* ===================== PERFORMANCE REPORT ===================== */
.rpt{padding:.2rem}
.rpt-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.7rem;margin-bottom:1.1rem}
.rpt-card{background:var(--glass2);border:1px solid var(--stroke);border-radius:12px;padding:.7rem .85rem}
.rpt-card span{display:block;font-size:.68rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:700;margin-bottom:.25rem}
.rpt-card b{font-size:1.15rem;font-variant-numeric:tabular-nums}
.rpt-section-title{font-weight:800;font-size:.92rem;margin:1.1rem 0 .6rem;color:var(--text)}
.rpt-chart{background:var(--glass2);border:1px solid var(--stroke);border-radius:12px;padding:.5rem}
.rpt-chart canvas{width:100%;display:block}
.rpt-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(132px,1fr));gap:.6rem}
.rpt-stat{background:var(--glass2);border:1px solid var(--stroke);border-radius:11px;padding:.6rem .75rem}
.rpt-stat span{display:block;font-size:.66rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:700;margin-bottom:.2rem}
.rpt-stat b{font-size:1rem;font-variant-numeric:tabular-nums}
.rpt-card b.up,.rpt-stat b.up{color:var(--up)}
.rpt-card b.down,.rpt-stat b.down{color:var(--down)}
.rpt-table th,.rpt-table td{white-space:nowrap}
.rpt-tag{font-size:.6rem;font-weight:800;padding:.1rem .4rem;border-radius:5px;text-transform:uppercase;letter-spacing:.03em}
.rpt-tag.sl{color:var(--down);background:rgba(255,84,112,.13)}
.rpt-tag.tp{color:var(--up);background:rgba(22,199,132,.13)}
.rpt-tag.man{color:var(--muted);background:var(--glass2);border:1px solid var(--stroke)}
.rpt-date{font-size:.78rem;color:var(--muted)}

/* ===================== ON-CHART POSITION BADGES ===================== */
.chart-pos-overlay{position:absolute;inset:0;pointer-events:none;z-index:5}
.cpos{position:absolute;right:64px;transform:translateY(-50%);display:flex;align-items:center;gap:.4rem;padding:.16rem .28rem .16rem .5rem;border-radius:8px;font-size:.7rem;font-weight:800;background:rgba(16,20,32,.92);border:1px solid var(--stroke2);color:#fff;pointer-events:auto;white-space:nowrap;box-shadow:0 4px 14px rgba(0,0,0,.35);backdrop-filter:blur(4px)}
.cpos.up{border-color:rgba(22,199,132,.6)}
.cpos.down{border-color:rgba(255,84,112,.6)}
.cpos-info{opacity:.85;font-size:.64rem;letter-spacing:.02em}
.cpos-pnl{font-variant-numeric:tabular-nums}
.cpos.up .cpos-pnl{color:#16c784}
.cpos.down .cpos-pnl{color:#ff5470}
.cpos-x{background:rgba(255,255,255,.14);border:none;color:#fff;width:17px;height:17px;border-radius:50%;cursor:pointer;font-size:.62rem;line-height:1;display:grid;place-items:center;padding:0;transition:background .15s}
.cpos-x:hover{background:#ff5470}
