*{margin:0;padding:0;box-sizing:border-box;}
:root{
  --ff:'Inter',system-ui,-apple-system,sans-serif;
  --mono:'JetBrains Mono','Courier New',monospace;
  --bg:#f5f6fa;--bg2:#f9fafb;
  --surface:#ffffff;--surface2:#fafbfc;
  --border:#e4e7ef;--border2:#d0d5e0;
  --text:#18181b;--text2:#52525b;--text3:#a1a1aa;
  --green:#16a34a;--green-bg:rgba(22,163,74,.08);
  --red:#dc2626;--red-bg:rgba(220,38,38,.07);
  --gold:#b45309;--gold-bg:rgba(180,83,9,.08);
  --blue:#1d4ed8;--indigo:#4338ca;
  --purple:#6d28d9;--navy:#111827;--navy2:#1f2937;
  --sh:0 1px 2px rgba(0,0,0,.05),0 1px 8px rgba(0,0,0,.04);
  --sh-md:0 4px 16px rgba(0,0,0,.08);--sh-lg:0 12px 40px rgba(0,0,0,.12);
  --r:10px;--rs:7px;
  --fs-xs:11px;--fs-sm:12px;--fs-base:13.5px;--fs-md:14.5px;
  --fs-lg:16px;--fs-xl:18px;--fs-2xl:22px;
}
html{scroll-behavior:smooth;}
body{font-family:var(--ff);background:var(--bg);color:var(--text);font-size:var(--fs-base);line-height:1.55;-webkit-font-smoothing:antialiased;letter-spacing:-.01em;}
a{text-decoration:none;color:inherit;}
button{cursor:pointer;font-family:inherit;border:none;background:none;}
input,select{font-family:inherit;}
::-webkit-scrollbar{width:4px;height:4px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:10px;}

/* ── LOADER UPGRADE ── */
#loader{
  position:fixed;inset:0;z-index:9999;
  background:linear-gradient(135deg,#0c0a1e 0%,#0f172a 50%,#0a0f1e 100%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  transition:opacity .5s ease,transform .5s ease;
}
#loader.out{opacity:0;transform:scale(1.04);pointer-events:none;}
.ld-glow{
  position:absolute;width:280px;height:280px;border-radius:50%;
  background:radial-gradient(circle,rgba(79,70,229,.25) 0%,transparent 70%);
  animation:ldPulse 2s ease-in-out infinite;pointer-events:none;
}
@keyframes ldPulse{0%,100%{transform:scale(1);opacity:.6}50%{transform:scale(1.15);opacity:1}}
.ld-icon{font-size:52px;filter:drop-shadow(0 0 20px rgba(79,70,229,.6));animation:ldBob 2s ease-in-out infinite;position:relative;z-index:1;}
@keyframes ldBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.ld-brand{font-family:'Inter',system-ui,sans-serif;font-size:26px;font-weight:800;color:#f1f5f9;letter-spacing:-.5px;position:relative;z-index:1;}
.ld-brand em{font-style:normal;color:#818cf8;}
.ld-tagline{font-size:12px;font-weight:600;color:#64748b;letter-spacing:.8px;text-transform:uppercase;position:relative;z-index:1;}
.ld-track{width:200px;height:4px;background:rgba(255,255,255,.08);border-radius:10px;overflow:hidden;position:relative;z-index:1;}
.ld-fill{height:100%;width:0%;background:linear-gradient(90deg,#4f46e5,#7c3aed,#a5b4fc);border-radius:10px;transition:width .35s cubic-bezier(.4,0,.2,1);box-shadow:0 0 12px rgba(79,70,229,.5);}
.ld-steps{display:flex;flex-direction:column;align-items:center;gap:4px;position:relative;z-index:1;min-height:72px;justify-content:center;}
.ld-step{font-size:12px;font-weight:600;color:#334155;transition:all .3s;padding:2px 12px;border-radius:20px;}
.ld-step.active{color:#a5b4fc;background:rgba(79,70,229,.12);border:1px solid rgba(79,70,229,.2);}
.ld-dots{display:flex;gap:6px;position:relative;z-index:1;}
.ld-dots span{width:6px;height:6px;border-radius:50%;background:#334155;animation:ldDot 1.2s ease-in-out infinite;}
.ld-dots span:nth-child(2){animation-delay:.2s;}
.ld-dots span:nth-child(3){animation-delay:.4s;}
@keyframes ldDot{0%,80%,100%{transform:scale(.7);background:#334155}40%{transform:scale(1);background:#818cf8}}

/* ══ HERO TRUST BAR ══ */
.fo-trust-bar{background:linear-gradient(135deg,#0f172a 0%,#1e293b 60%,#0f2027 100%);padding:13px 16px 11px;position:relative;overflow:hidden;}
.fo-trust-bar::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 70% 50%,rgba(79,70,229,.18) 0%,transparent 70%);pointer-events:none;}
.fo-trust-inner{display:flex;align-items:center;justify-content:space-between;gap:12px;max-width:1200px;margin:0 auto;}
.fo-trust-brand{display:flex;align-items:center;gap:10px;}
.fo-trust-icon{font-size:24px;filter:drop-shadow(0 0 8px rgba(79,70,229,.5));}
.fo-trust-name{font-size:15px;font-weight:800;color:#f1f5f9;letter-spacing:-.3px;}
.fo-trust-tag{background:linear-gradient(90deg,#10b981,#059669);color:#fff;font-size:9px;font-weight:700;padding:1px 6px;border-radius:20px;margin-left:5px;vertical-align:middle;letter-spacing:.5px;}
.fo-trust-sub{font-size:11px;color:#94a3b8;font-weight:500;margin-top:1px;}
.fo-trust-pills{display:flex;gap:6px;flex-wrap:wrap;}
.fo-tpill{display:flex;align-items:center;gap:4px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:4px 10px;font-size:10.5px;font-weight:600;color:#cbd5e1;white-space:nowrap;}
.fo-tpill span{font-size:12px;}
.fo-tpill-green{background:rgba(16,185,129,.12);border-color:rgba(16,185,129,.25);color:#34d399;}

/* ══ MARKET RIBBON ══ */
.fo-ribbon{display:flex;align-items:center;gap:8px;background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:6px 16px;font-size:11px;font-weight:600;}
.fo-ribbon-item{display:flex;align-items:center;gap:5px;}
.fo-ribbon-lbl{color:#475569;}
.fo-ribbon-sep{color:#cbd5e1;font-size:10px;}
.fo-ribbon-spacer{flex:1;}
.fo-ribbon-clock{color:#64748b;font-size:10.5px;font-weight:600;font-variant-numeric:tabular-nums;}
.fo-ribbon-stats strong{color:#4f46e5;}

/* ══ HERO FEATURES + STATS ══ */
.fo-hero-features{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px;}
.fo-hero-features span{font-size:10.5px;font-weight:600;color:#64748b;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:20px;padding:2px 8px;}
.fo-hero-stats{display:flex;align-items:center;gap:0;background:linear-gradient(135deg,#f8f9ff,#f0f4ff);border:1px solid #e0e4ff;border-radius:12px;margin-top:14px;overflow:hidden;}
.fo-hs{flex:1;text-align:center;padding:10px 8px;display:flex;flex-direction:column;gap:2px;}
.fo-hs-div{width:1px;background:#e0e4ff;align-self:stretch;}
.fo-hs-val{font-size:18px;font-weight:800;color:#4f46e5;font-variant-numeric:tabular-nums;line-height:1;font-family:var(--mono);}
.fo-hs-lbl{font-size:9.5px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.4px;}

/* ══ RESPONSIVE ══ */
@media(max-width:480px){
  .fo-trust-inner{flex-direction:column;align-items:flex-start;gap:10px;}
  .fo-trust-pills{gap:5px;}
  .fo-tpill{font-size:10px;padding:3px 8px;}
  .fo-hero-features{gap:4px;}
  .fo-hero-features span{font-size:10px;}
  .fo-hs-val{font-size:15px;}
  .fo-ribbon{padding:5px 12px;}
}

/* ── TOAST ── */
#toast{position:fixed;bottom:68px;left:50%;transform:translateX(-50%);background:var(--navy);color:#fff;padding:8px 18px;border-radius:20px;font-size:var(--fs-sm);font-weight:600;z-index:9000;opacity:0;pointer-events:none;transition:opacity .25s;white-space:nowrap;}
#toast.show{opacity:1;}

/* ── SIDEBAR NAV ── */
.nav{
  position:fixed;top:0;left:0;bottom:0;width:220px;
  background:#fff;border-right:1px solid var(--border);
  box-shadow:1px 0 8px rgba(0,0,0,.04);
  display:flex;flex-direction:column;z-index:800;
  overflow-y:auto;overflow-x:hidden;
  transition:transform .25s cubic-bezier(.4,0,.2,1);
}
.nav-logo{
  font-family:var(--ff);font-size:17px;font-weight:800;color:var(--navy);
  display:flex;align-items:center;gap:9px;
  padding:18px 16px 14px;border-bottom:1px solid var(--border);flex-shrink:0;
}
.nav-logo-box{width:30px;height:30px;background:linear-gradient(135deg,#6d28d9,#4338ca);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:15px;box-shadow:0 2px 6px rgba(109,40,217,.25);flex-shrink:0;}
.nav-logo span{color:var(--purple);}
.nav-links{display:flex;flex-direction:column;gap:1px;padding:10px 8px;flex:1;}
.nav-links a{
  color:var(--text2);font-size:var(--fs-sm);font-weight:500;
  padding:9px 12px;border-radius:8px;transition:.14s;
  display:flex;align-items:center;gap:8px;white-space:nowrap;
}
.nav-links a:hover{color:var(--purple);background:rgba(109,40,217,.06);}
.nav-links a.active{color:var(--purple);font-weight:700;background:rgba(109,40,217,.08);border-left:3px solid var(--purple);padding-left:9px;}
.nav-right{
  display:flex;flex-direction:column;gap:7px;
  padding:10px 12px 16px;border-top:1px solid var(--border);flex-shrink:0;
}
.live-dot{width:6px;height:6px;border-radius:50%;background:var(--green);flex-shrink:0;}
.live-dot.blink{animation:blink 1.4s ease-in-out infinite;}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}
.badge-live{display:flex;align-items:center;gap:4px;background:rgba(22,163,74,.1);border:1px solid rgba(22,163,74,.2);padding:4px 10px;border-radius:20px;width:fit-content;}
.live-lbl{font-size:var(--fs-xs);font-weight:700;color:var(--green);}
#navGift{display:none;font-size:var(--fs-xs);font-weight:700;padding:3px 9px;border-radius:20px;border:1px solid rgba(180,83,9,.25);background:var(--gold-bg);color:var(--gold);font-family:var(--mono);}
.ist-clock{font-size:var(--fs-xs);color:var(--text3);font-family:var(--mono);}
.api-badge{font-size:10px;padding:3px 8px;border-radius:8px;background:var(--bg);font-weight:600;color:var(--text2);border:1px solid var(--border);width:fit-content;}
.btn-login{background:linear-gradient(135deg,#b45309,#d97706);color:#fff;padding:8px 14px;border-radius:8px;font-weight:700;font-size:var(--fs-sm);transition:.14s;border:none;cursor:pointer;box-shadow:0 2px 6px rgba(180,83,9,.25);width:100%;text-align:center;}
.btn-login:hover{transform:translateY(-1px);}
.u-avatar{width:26px;height:26px;border-radius:50%;border:2px solid var(--gold);object-fit:cover;}

/* ── SIDEBAR OVERLAY + HAMBURGER ── */
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.3);z-index:799;opacity:0;transition:opacity .25s;}
.sidebar-overlay.open{display:block;opacity:1;}
.nav.open{transform:translateX(0)!important;}
.ham-btn{display:none;background:none;border:none;cursor:pointer;padding:6px;border-radius:7px;color:var(--navy);font-size:20px;line-height:1;transition:.14s;}
.ham-btn:hover{background:rgba(109,40,217,.07);color:var(--purple);}

/* ── APP BODY ── */
.app-body{margin-left:220px;min-height:100vh;}
@media(min-width:721px){
  .app-body{height:100vh;overflow-y:scroll;scrollbar-width:thin;scrollbar-color:var(--border2) transparent;}
  .app-body::-webkit-scrollbar{width:6px;}
  .app-body::-webkit-scrollbar-track{background:var(--bg);}
  .app-body::-webkit-scrollbar-thumb{background:var(--border2);border-radius:10px;}
}

/* ── MOBILE TOP HEADER ── */
.mob-header{
  display:none;position:sticky;top:0;z-index:700;
  background:#fff;border-bottom:1px solid var(--border);
  height:50px;align-items:center;justify-content:space-between;
  padding:0 14px;box-shadow:0 1px 6px rgba(0,0,0,.05);
}
.mob-header-logo{font-size:16px;font-weight:800;color:var(--navy);display:flex;align-items:center;gap:7px;}
.mob-header-logo-box{width:26px;height:26px;background:linear-gradient(135deg,#6d28d9,#4338ca);border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:13px;}
.mob-header-logo span{color:var(--purple);}
.mob-header-right{display:flex;align-items:center;gap:8px;}
.mob-header-right .btn-login{padding:5px 12px;font-size:var(--fs-xs);width:auto;}

/* ── MOBILE BREADCRUMB ── */
.mob-breadcrumb{
  display:none;align-items:center;gap:6px;
  padding:7px 14px;background:#fff;border-bottom:1px solid var(--border);
  font-size:var(--fs-xs);color:var(--text2);font-weight:500;
  position:sticky;top:50px;z-index:89;
}
.mob-breadcrumb a{color:var(--purple);font-weight:600;}
.mob-breadcrumb-cur{color:var(--text);font-weight:700;}

/* ── MOBILE NAV ── */
.mob-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);z-index:700;padding:4px 0 max(env(safe-area-inset-bottom),8px);box-shadow:0 -1px 12px rgba(0,0,0,.06);}
.mn{flex:1;display:flex;flex-direction:column;align-items:center;gap:1px;padding:5px;min-height:44px;justify-content:center;}
.mn-i{font-size:18px;}
.mn-l{font-size:9px;font-weight:600;color:var(--text2);}
.mn.on .mn-l{color:var(--purple);}
.mn.on .mn-i{filter:drop-shadow(0 0 3px rgba(109,40,217,.4));}

/* ── RESPONSIVE MOBILE ── */
@media(max-width:720px){
  .nav{display:flex!important;position:fixed;top:0;left:0;bottom:0;width:220px;z-index:800;transform:translateX(-220px);box-shadow:4px 0 20px rgba(0,0,0,.15);}
  .app-body{margin-left:0;}
  .mob-header{display:flex;}
  .mob-breadcrumb{display:flex;}
  .ham-btn{display:flex;align-items:center;justify-content:center;}
  .mob-nav{display:flex;}
}

/* ────────────────────────────────────────────
   PAGE HEADER
   ──────────────────────────────────────────── */
.page-hero{
  background:#fff;border-bottom:1px solid var(--border);
  padding:20px 24px 16px;
}
.page-hero-top{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;}
.page-hero-left{display:flex;align-items:center;gap:13px;}
.page-hero-icon{
  width:46px;height:46px;
  background:linear-gradient(135deg,#4f46e5,#7c3aed);
  border-radius:12px;display:grid;place-items:center;
  font-size:22px;flex-shrink:0;
  box-shadow:0 4px 14px rgba(79,70,229,.3);
}
.page-hero-title{font-size:22px;font-weight:800;color:#111827;letter-spacing:-.4px;line-height:1.2;}
.page-hero-sub{font-size:12px;color:#6b7280;margin-top:4px;font-weight:500;display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.page-hero-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;padding:3px 9px;border-radius:20px;border:1px solid;}
.hero-badge-nse{background:#ede9fe;color:#4f46e5;border-color:#c4b5fd;}
.hero-badge-free{background:#d1fae5;color:#065f46;border-color:#6ee7b7;}
.hero-badge-live{background:#f0fdf4;color:#16a34a;border-color:#bbf7d0;display:flex;align-items:center;gap:4px;}
.hero-live-dot{width:5px;height:5px;border-radius:50%;background:#16a34a;animation:blink 1.4s infinite;}

/* ── MINI INDEX STRIP (compact, 3 items) ── */
.fo-index-strip{
  display:flex;gap:8px;padding:10px 24px;
  border-bottom:1px solid var(--border);
  overflow-x:auto;background:#fafafa;
}
.fo-index-strip::-webkit-scrollbar{height:0;}
.foi-card{
  display:flex;align-items:center;gap:9px;
  padding:8px 14px;background:#fff;border:1px solid var(--border);
  border-radius:9px;cursor:pointer;transition:all .13s;
  min-width:160px;flex-shrink:0;
  box-shadow:var(--sh);
}
.foi-card:hover{border-color:var(--purple);box-shadow:var(--sh-md);}
.foi-card.active{border-color:var(--purple);background:#faf5ff;}
.foi-name{font-size:11.5px;font-weight:700;color:#111827;}
.foi-price{font-size:13.5px;font-weight:700;font-family:var(--mono);color:#111827;}
.foi-chg{font-size:11px;font-weight:600;font-family:var(--mono);}
.foi-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}

/* ════════════════════════════════════════════
   MAIN F&O PANEL — White Background
   ════════════════════════════════════════════ */
.fo-wrap{padding:12px 24px 24px;}
@media(max-width:720px){.fo-wrap{padding:8px 8px 80px;}}
.fo-panel{background:#fff;border:1px solid var(--border);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh);}

/* Panel Header */
.fo-header{background:#fff;padding:16px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:10px;}
.fo-header-left{display:flex;align-items:center;gap:11px;}
.fo-header-icon{width:38px;height:38px;background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:10px;display:grid;place-items:center;font-size:18px;flex-shrink:0;box-shadow:0 3px 10px rgba(79,70,229,.22);}
.fo-header-title{font-size:15px;font-weight:700;color:#111827;}
.fo-header-sub{font-size:11px;color:#6b7280;margin-top:2px;font-weight:500;}
.fo-header-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.fo-live-badge{display:flex;align-items:center;gap:5px;background:#f0fdf4;border:1px solid #bbf7d0;padding:4px 11px;border-radius:20px;}
.fo-live-dot{width:6px;height:6px;border-radius:50%;background:#16a34a;animation:blink 1.4s infinite;}
.fo-live-txt{font-size:10px;font-weight:700;color:#16a34a;}
.fo-refresh-btn{display:flex;align-items:center;gap:5px;padding:6px 13px;border:1px solid var(--border);border-radius:8px;font-size:11.5px;font-weight:600;color:#374151;background:#fff;cursor:pointer;transition:all .14s;}
.fo-refresh-btn:hover{background:#f9fafb;border-color:#9ca3af;}
.fo-refresh-btn.spinning svg{animation:spin 1s linear infinite;}
@keyframes spin{to{transform:rotate(360deg)}}
.fo-last-updated{font-size:10px;color:#9ca3af;font-family:var(--mono);}

/* Controls row */
.fo-controls{display:flex;align-items:center;gap:10px;padding:10px 20px;border-bottom:1px solid var(--border);background:#fafafa;flex-wrap:wrap;}
.fo-index-tabs{display:flex;gap:2px;background:#f3f4f6;border-radius:8px;padding:2px;}
.fo-itab{padding:6px 16px;border-radius:6px;font-size:12.5px;font-weight:600;color:#6b7280;cursor:pointer;transition:all .13s;white-space:nowrap;background:none;}
.fo-itab.on{background:#fff;color:#4f46e5;font-weight:700;box-shadow:0 1px 4px rgba(0,0,0,.08);}
.fo-expiry-wrap{display:flex;align-items:center;gap:7px;margin-left:auto;}
.fo-expiry-lbl{font-size:11.5px;font-weight:600;color:#6b7280;}
.fo-expiry-sel{border:1px solid var(--border);border-radius:7px;padding:6px 9px;font-size:12px;background:#fff;color:#111827;outline:none;cursor:pointer;font-family:var(--ff);}
.fo-expiry-countdown{font-size:11px;font-weight:700;color:#dc2626;background:#fff1f2;border:1px solid #fecdd3;padding:3px 10px;border-radius:20px;font-family:var(--mono);}

/* 6-stat strip */
.fo-stats{display:grid;grid-template-columns:repeat(6,1fr);border-bottom:1px solid var(--border);}
@media(max-width:1000px){.fo-stats{grid-template-columns:repeat(3,1fr);}}
@media(max-width:580px){.fo-stats{grid-template-columns:repeat(2,1fr);}}
.fo-stat{padding:13px 16px;border-right:1px solid var(--border);display:flex;flex-direction:column;gap:3px;}
.fo-stat:last-child{border-right:none;}
.fo-stat-lbl{font-size:10px;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.4px;}
.fo-stat-val{font-size:21px;font-weight:700;color:#111827;font-family:var(--mono);line-height:1.1;}
.fo-stat-sub{font-size:10.5px;font-weight:500;color:#6b7280;}
.fo-stat-val.bullish{color:#16a34a;}.fo-stat-val.bearish{color:#dc2626;}.fo-stat-val.neutral{color:#d97706;}

/* PCR + OI two-column body */
.fo-body{display:grid;grid-template-columns:290px 1fr;border-bottom:1px solid var(--border);}
@media(max-width:960px){.fo-body{grid-template-columns:1fr;}}

/* PCR Panel */
.fo-pcr-panel{padding:20px;border-right:1px solid var(--border);}
@media(max-width:960px){.fo-pcr-panel{border-right:none;border-bottom:1px solid var(--border);}}
.fo-section-title{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#9ca3af;margin-bottom:14px;display:flex;align-items:center;gap:6px;}

/* SVG Gauge */
.fo-gauge-wrap{display:flex;flex-direction:column;align-items:center;margin-bottom:18px;}
.fo-gauge{position:relative;width:190px;height:105px;margin:0 auto 8px;}
.fo-gauge-svg{width:100%;height:100%;}
.fo-gauge-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-8%);text-align:center;}
.fo-gauge-pcr{font-size:28px;font-weight:800;font-family:var(--mono);line-height:1;}
.fo-gauge-lbl{font-size:10px;font-weight:600;color:#6b7280;margin-top:2px;}
.fo-gauge-signal{font-size:12px;font-weight:700;padding:5px 16px;border-radius:20px;margin-top:10px;border:1px solid;}

/* PCR Zones */
.fo-pcr-scale{display:grid;grid-template-columns:1fr 1fr 1fr;gap:5px;width:100%;}
.fo-pcr-zone{text-align:center;padding:6px 4px;border-radius:8px;font-size:10px;font-weight:600;line-height:1.4;}

/* PCR History */
.fo-pcr-hist{display:flex;flex-direction:column;gap:6px;margin-top:16px;}
.fo-pcr-hist-row{display:flex;align-items:center;gap:8px;}
.fo-pcr-hist-lbl{font-size:10px;color:#6b7280;width:40px;flex-shrink:0;font-family:var(--mono);}
.fo-pcr-hist-bar-wrap{flex:1;height:14px;background:#f3f4f6;border-radius:20px;overflow:hidden;}
.fo-pcr-hist-bar{height:100%;border-radius:20px;transition:width .5s ease;}
.fo-pcr-hist-val{font-size:10.5px;font-weight:700;width:32px;text-align:right;font-family:var(--mono);}

/* OI Chart Panel */
.fo-oi-panel{padding:20px;}
.fo-oi-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:8px;}
.fo-oi-legend{display:flex;align-items:center;gap:14px;}
.fo-oi-leg-item{display:flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;color:#374151;}
.fo-oi-leg-dot{width:11px;height:11px;border-radius:3px;flex-shrink:0;}
.fo-oi-atm-lbl{font-size:10.5px;font-weight:600;color:#4f46e5;background:#ede9fe;border:1px solid #c4b5fd;padding:3px 10px;border-radius:20px;}
.fo-oi-chart-wrap{position:relative;height:270px;}
@media(max-width:580px){.fo-oi-chart-wrap{height:210px;}}

/* Analysis cards */
.fo-analysis{display:grid;grid-template-columns:repeat(3,1fr);padding:16px 20px;gap:12px;border-bottom:1px solid var(--border);}
@media(max-width:800px){.fo-analysis{grid-template-columns:1fr 1fr;}}
@media(max-width:480px){.fo-analysis{grid-template-columns:1fr;}}
.fo-analysis-card{background:#f9fafb;border:1px solid var(--border);border-radius:10px;padding:14px 16px;}
.fo-ac-lbl{font-size:10px;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.4px;margin-bottom:6px;}
.fo-ac-val{font-size:20px;font-weight:700;color:#111827;font-family:var(--mono);margin-bottom:3px;}
.fo-ac-sub{font-size:11px;color:#6b7280;line-height:1.4;}
.fo-ac-badge{display:inline-block;font-size:10px;font-weight:700;padding:3px 10px;border-radius:20px;margin-top:6px;}

/* Strikes table */
.fo-strikes-wrap{padding:0 20px 20px;}
.fo-strikes-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;flex-wrap:wrap;gap:8px;}
.fo-strikes-tabs{display:flex;gap:2px;background:#f3f4f6;border-radius:7px;padding:2px;width:fit-content;}
.fo-stab{padding:5px 14px;border-radius:5px;font-size:11.5px;font-weight:600;color:#6b7280;cursor:pointer;transition:all .13s;background:none;}
.fo-stab.on{background:#fff;color:#111827;font-weight:700;box-shadow:0 1px 4px rgba(0,0,0,.08);}
.fo-tbl-wrap{overflow-x:auto;}
.fo-strikes-tbl{width:100%;border-collapse:collapse;font-size:12.5px;}
.fo-strikes-tbl th{font-size:10px;font-weight:700;color:#9ca3af;text-transform:uppercase;letter-spacing:.4px;padding:8px 10px;border-bottom:2px solid var(--border);text-align:right;white-space:nowrap;background:#fafafa;}
.fo-strikes-tbl th:first-child,.fo-strikes-tbl td:first-child{text-align:left;}
.fo-strikes-tbl td{padding:8px 10px;border-bottom:1px solid rgba(228,231,239,.5);font-family:var(--mono);color:#374151;text-align:right;}
.fo-strikes-tbl tbody tr:last-child td{border-bottom:none;}
.fo-strikes-tbl tbody tr:hover td{background:#f8f9ff;}
.fo-strikes-tbl td.atm{background:#ede9fe;font-weight:700;color:#4f46e5;}
.fo-oi-bar-cell{display:flex;align-items:center;gap:5px;justify-content:flex-end;}
.fo-oi-mini-bar{height:10px;border-radius:20px;min-width:3px;transition:width .4s ease;}
.fo-chg-up{color:#16a34a;font-weight:700;}.fo-chg-dn{color:#dc2626;font-weight:700;}

/* Market Mood + Footer */
.fo-footer{padding:12px 20px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;background:#fafafa;border-top:1px solid var(--border);}
.fo-mood{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.fo-mood-lbl{font-size:11.5px;font-weight:600;color:#6b7280;}
.fo-mood-bar{width:140px;height:9px;background:linear-gradient(90deg,#dc2626,#f59e0b 50%,#16a34a);border-radius:20px;position:relative;}
.fo-mood-needle{position:absolute;top:-3px;width:15px;height:15px;background:#fff;border:2px solid #374151;border-radius:50%;transform:translateX(-50%);transition:left .6s ease;box-shadow:0 1px 4px rgba(0,0,0,.15);}
.fo-mood-labels{display:flex;justify-content:space-between;font-size:9.5px;color:#9ca3af;font-weight:600;margin-top:3px;width:140px;}
.fo-mood-text{font-size:12.5px;font-weight:700;}
.fo-disclaimer{font-size:10px;color:#9ca3af;line-height:1.5;max-width:400px;}

/* Educational cards row */
.fo-edu{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;padding:16px 20px;border-top:1px solid var(--border);}
/* ── BROKER POPUP ── */
#brokerPopup{
  display:none;
  position:fixed;inset:0;
  z-index:9998;
  align-items:center;justify-content:center;
  background:rgba(15,23,42,.55);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  padding:16px;
}
#brokerPopup.show{display:flex;}
.bp-box{
  background:#fff;
  border-radius:20px;
  width:100%;max-width:680px;
  max-height:90vh;
  overflow-y:auto;
  box-shadow:0 24px 60px rgba(0,0,0,.2);
  animation:bpIn .28s cubic-bezier(.34,1.56,.64,1);
  position:relative;
}
@keyframes bpIn{from{opacity:0;transform:scale(.93) translateY(16px)}to{opacity:1;transform:none}}
/* Header */
.bp-header{
  background:linear-gradient(135deg,#0c0c1d 0%,#1a1040 100%);
  padding:20px 24px 16px;
  border-radius:20px 20px 0 0;
  position:relative;
}
.bp-close{
  position:absolute;top:14px;right:14px;
  width:30px;height:30px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
  border-radius:50%;font-size:15px;color:#fff;
  cursor:pointer;display:grid;place-items:center;
  transition:background .14s;
}
.bp-close:hover{background:rgba(255,255,255,.22);}
.bp-header-title{font-size:18px;font-weight:800;color:#fff;letter-spacing:-.3px;margin-bottom:4px;}
.bp-header-sub{font-size:12px;color:rgba(196,181,253,.8);font-weight:500;}
.bp-header-badges{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap;}
.bp-badge{font-size:10px;font-weight:700;padding:3px 10px;border-radius:20px;border:1px solid;}
.bp-badge-free{background:rgba(34,197,94,.15);color:#4ade80;border-color:rgba(34,197,94,.3);}
.bp-badge-sebi{background:rgba(250,204,21,.12);color:#fcd34d;border-color:rgba(250,204,21,.25);}
.bp-badge-5min{background:rgba(129,140,248,.15);color:#a5b4fc;border-color:rgba(129,140,248,.3);}
/* Timer bar */
.bp-timer-wrap{padding:0 24px;margin-top:-1px;}
.bp-timer-bar{height:3px;background:rgba(129,140,248,.15);border-radius:0;}
.bp-timer-fill{height:100%;background:linear-gradient(90deg,#6d28d9,#4f46e5);border-radius:0;transition:width 1s linear;}
/* Body */
.bp-body{padding:16px 20px 20px;}
.bp-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
@media(max-width:520px){.bp-grid{grid-template-columns:1fr;}}
/* Broker card */
.bp-card{
  border:1.5px solid var(--border);
  border-radius:12px;overflow:hidden;
  transition:all .15s;background:#fff;
  display:flex;flex-direction:column;
}
.bp-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.1);}
.bp-card-top{
  padding:12px 14px;
  display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid var(--border);
}
.bp-card-logo{
  width:34px;height:34px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:900;color:#fff;flex-shrink:0;
}
.bp-card-info{margin-left:9px;flex:1;}
.bp-card-name{font-size:13px;font-weight:700;color:#111827;}
.bp-card-tag{font-size:10px;color:#6b7280;margin-top:1px;}
.bp-card-rating{font-size:11px;color:#f59e0b;font-weight:700;}
.bp-card-body{padding:10px 14px;flex:1;display:flex;flex-direction:column;gap:5px;}
.bp-feat{font-size:11px;color:#374151;display:flex;align-items:flex-start;gap:5px;line-height:1.4;}
.bp-feat::before{content:'✓';color:#16a34a;font-weight:700;flex-shrink:0;margin-top:1px;}
.bp-cta{
  display:flex;align-items:center;justify-content:center;gap:5px;
  margin:8px 12px 12px;padding:9px;
  border-radius:9px;font-size:12.5px;font-weight:700;
  color:#fff;text-decoration:none;
  transition:all .15s;
}
.bp-cta:hover{filter:brightness(1.08);transform:translateY(-1px);}
/* Footer */
.bp-footer{
  padding:12px 20px;
  background:#f9fafb;border-top:1px solid var(--border);
  border-radius:0 0 20px 20px;
  display:flex;align-items:center;justify-content:space-between;
  gap:10px;flex-wrap:wrap;
}
.bp-footer-note{font-size:10px;color:#9ca3af;line-height:1.4;}
.bp-skip{
  font-size:11.5px;font-weight:600;color:#6b7280;
  background:#fff;border:1px solid var(--border);
  padding:7px 16px;border-radius:8px;cursor:pointer;
  transition:all .14s;white-space:nowrap;
}
.bp-skip:hover{background:#f3f4f6;border-color:#9ca3af;}
/* Don't show again checkbox */
.bp-nosee{display:flex;align-items:center;gap:5px;font-size:11px;color:#9ca3af;cursor:pointer;}
.bp-nosee input{cursor:pointer;accent-color:#6d28d9;}

/* Market Mood + Footer */
.fo-footer{padding:12px 40px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;background:#fafafa;border-top:1px solid var(--border);}
.fo-mood{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.fo-mood-lbl{font-size:11.5px;font-weight:600;color:#6b7280;}
.fo-mood-bar{width:140px;height:9px;background:linear-gradient(90deg,#dc2626,#f59e0b 50%,#16a34a);border-radius:20px;position:relative;}
.fo-mood-needle{position:absolute;top:-3px;width:15px;height:15px;background:#fff;border:2px solid #374151;border-radius:50%;transform:translateX(-50%);transition:left .6s ease;box-shadow:0 1px 4px rgba(0,0,0,.15);}
.fo-mood-labels{display:flex;justify-content:space-between;font-size:9.5px;color:#9ca3af;font-weight:600;margin-top:3px;width:140px;}
.fo-mood-text{font-size:12.5px;font-weight:700;}
.fo-disclaimer{font-size:10px;color:#9ca3af;line-height:1.5;max-width:400px;}

/* Educational cards row */
.fo-edu{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;padding:16px 20px;border-top:1px solid var(--border);}
.fo-edu-card{background:#f9fafb;border:1px solid var(--border);border-radius:10px;padding:14px;}
.fo-edu-title{font-size:12px;font-weight:700;color:#111827;margin-bottom:5px;display:flex;align-items:center;gap:5px;}
.fo-edu-body{font-size:11px;color:#6b7280;line-height:1.6;}
