*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#191127;
  --bg2:#23133a;
  --bg3:#1f1232;
  --surface:#23133a;
  --border:#3a1c63;
  --text:#e8e9ed;
  --text2:#e1e3e9;
  --text3:#d6d6d6;
  --accent:#883CF0;
  --accent2:#7c3aed;
  --red:#ff4757;
  --orange:#ffa502;
  --blue:#af62c8;
  --purple:#a855f7;
  --green:#00d4aa;
  --glow:0 0 40px rgba(113, 0, 212, 0.12);
}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;line-height:1.6}

/* Grain overlay */
body::after{content:'';position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:9999;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  opacity:.5}

/* Scrollbar */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--text3)}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:100;
  background:#180f26;backdrop-filter:blur(20px);border-bottom:1px solid var(--border);
  padding:0 2rem;height:60px;display:flex;align-items:center;justify-content:space-between}
.nav-logo{font-family:'Instrument Serif',serif;font-size:1.6rem;letter-spacing:-.02em;color:var(--text);
  display:flex;align-items:center;gap:.5rem}
.nav-logo span{color:var(--accent);font-style:italic}
.nav-links{display:flex;gap:2rem;align-items:center}
.nav-links a{color:var(--text2);text-decoration:none;font-size:.85rem;font-weight:500;
  letter-spacing:.03em;text-transform:uppercase;transition:color .3s}
.nav-links a:hover{color:var(--accent)}
.nav-live{display:flex;align-items:center;gap:.4rem;color:var(--accent);font-family:'JetBrains Mono',monospace;font-size:.75rem;font-weight:600}
.nav-live .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);
  animation:pulse-dot 1.5s ease infinite}
@keyframes pulse-dot{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(138, 0, 212, 0.5)}50%{opacity:.7;box-shadow:0 0 0 6px rgba(162, 0, 212, 0)}}

/* ── HERO ── */
.hero{padding:10rem 2rem 5rem;text-align:center;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:800px;height:800px;border-radius:50%;
  background:radial-gradient(circle,rgba(134, 0, 212, 0.06) 0%,transparent 70%);pointer-events:none}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.6rem;
  font-family:'JetBrains Mono',monospace;font-size:.72rem;font-weight:500;color:var(--accent);
  text-transform:uppercase;letter-spacing:.15em;
  background:#1f1232;border:1px solid #3a1c63;
  padding:.45rem 1rem;border-radius:100px;margin-bottom:2rem}
.hero h1{font-family:'Instrument Serif',serif;font-size:clamp(2.8rem,7vw,5.5rem);
  line-height:1.05;letter-spacing:-.03em;max-width:900px;margin:0 auto 1.5rem}
.hero h1 em{font-style:italic;color:var(--accent)}
.hero p{font-size:1.15rem;color:var(--text2);max-width:600px;margin:0 auto 2.5rem;line-height:1.7}
.hero-stats{display:flex;gap:3rem;justify-content:center;flex-wrap:wrap;margin-top:3rem}
.hero-stat{text-align:center}
.hero-stat .num{font-family:'JetBrains Mono',monospace;font-size:2rem;font-weight:600;color:var(--text);
  display:block;line-height:1}
.hero-stat .label{font-size:.75rem;color:var(--text3);text-transform:uppercase;letter-spacing:.1em;margin-top:.4rem}

/* ── TICKER STRIP ── */
.ticker-strip{border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  overflow:hidden;padding:.7rem 0;background:var(--bg2)}
.ticker-track{display:flex;gap:3rem;animation:ticker 30s linear infinite;white-space:nowrap}
.ticker-item{display:flex;align-items:center;gap:.5rem;font-family:'JetBrains Mono',monospace;font-size:.78rem}
.ticker-item .name{color:var(--text);font-weight:600}
.ticker-item .price{color:var(--text2)}
.ticker-item .change{font-weight:600}
.ticker-item .change.up{color:var(--green)}
.ticker-item .change.down{color:var(--red)}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ── SECTIONS ── */
section{padding:5rem 2rem}
.section-header{text-align:center;margin-bottom:3rem}
.section-header h2{font-family:'Instrument Serif',serif;font-size:clamp(2rem,4vw,3rem);
  letter-spacing:-.02em;margin-bottom:.6rem}
.section-header p{color:var(--text2);font-size:1rem;max-width:500px;margin:0 auto}

/* ── IPO TABLE ── */
.table-controls{display:flex;gap:1rem;justify-content:center;margin-bottom:2rem;flex-wrap:wrap}
.tab-btn{background:var(--surface);color:var(--text2);border:1px solid var(--border);
  padding:.55rem 1.2rem;border-radius:100px;font-size:.82rem;font-weight:500;cursor:pointer;
  font-family:'DM Sans',sans-serif;transition:all .3s}
.tab-btn.active,.tab-btn:hover{background:var(--accent);color:var(--bg);border-color:var(--accent)}

.ipo-table-wrap{max-width:1100px;margin:0 auto;border:1px solid var(--border);border-radius:12px;
  overflow:hidden;background:var(--bg2)}
.ipo-table{width:100%;border-collapse:collapse}
.ipo-table thead{background:var(--surface)}
.ipo-table th{text-align:left;padding:.85rem 1.2rem;font-size:.72rem;font-weight:600;
  color:var(--text3);text-transform:uppercase;letter-spacing:.1em;
  border-bottom:1px solid var(--border)}
.ipo-table td{padding:.85rem 1.2rem;font-size:.88rem;border-bottom:1px solid #3a1c63;
  vertical-align:middle}
.ipo-table tbody tr{transition:background .2s;cursor:pointer}
.ipo-table tbody tr:hover{background:#1f1232}
.company-cell{display:flex;align-items:center;gap:.75rem}
.company-logo{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;
  justify-content:center;font-weight:700;font-size:.75rem;color:#fff;flex-shrink:0}
.company-name{font-weight:600;display:block;line-height:1.2}
.company-ticker{font-family:'JetBrains Mono',monospace;font-size:.72rem;color:var(--text3)}
.status-badge{font-family:'JetBrains Mono',monospace;font-size:.68rem;font-weight:600;
  padding:.25rem .6rem;border-radius:100px;display:inline-block;text-transform:uppercase;letter-spacing:.05em}
.status-badge.live{background:rgba(0,212,170,.12);color:var(--accent)}
.status-badge.upcoming{background:rgba(168,85,247,.12);color:var(--purple)}
.status-badge.filed{background:rgba(255,165,2,.12);color:var(--orange)}
.status-badge.priced{background:rgba(55,66,250,.12);color:#7c83ff}
.price-range{font-family:'JetBrains Mono',monospace;font-size:.82rem}
.valuation{font-family:'JetBrains Mono',monospace;font-weight:500}

/* ── INTERACTIVE CHART ── */
.chart-section{max-width:1100px;margin:0 auto;background:var(--bg2);border:1px solid var(--border);
  border-radius:16px;padding:2rem;position:relative}
.chart-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}
.chart-title{font-family:'Instrument Serif',serif;font-size:1.5rem}
.chart-period{display:flex;gap:.5rem}
.chart-period button{background:transparent;border:1px solid var(--border);color:var(--text2);
  padding:.35rem .8rem;border-radius:6px;font-size:.75rem;cursor:pointer;
  font-family:'JetBrains Mono',monospace;font-weight:500;transition:all .25s}
.chart-period button.active{background:var(--accent);color:var(--bg);border-color:var(--accent)}
.chart-canvas{width:100%;height:320px;position:relative}
.chart-canvas svg{width:100%;height:100%}

/* ── PROCESS SECTION ── */
.process-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:1.5rem;max-width:1100px;margin:0 auto}
.process-card{background:var(--bg2);border:1px solid var(--border);border-radius:16px;
  padding:2rem;position:relative;overflow:hidden;transition:all .4s;cursor:default}
.process-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:var(--glow)}
.process-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--accent),var(--purple));opacity:0;transition:opacity .4s}
.process-card:hover::before{opacity:1}
.process-step{font-family:'JetBrains Mono',monospace;font-size:.65rem;font-weight:600;
  color:var(--accent);text-transform:uppercase;letter-spacing:.15em;margin-bottom:1rem;
  display:flex;align-items:center;gap:.5rem}
.process-step .num{background:rgba(170, 0, 212, 0.1);padding:.2rem .5rem;border-radius:4px}
.process-card h3{font-family:'Instrument Serif',serif;font-size:1.3rem;margin-bottom:.5rem}
.process-card p{font-size:.88rem;color:var(--text2);line-height:1.6}

/* ── CALCULATOR ── */
.calc-section{max-width:700px;margin:0 auto}
.calc-card{background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:2.5rem}
.calc-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:2rem}
.calc-field label{display:block;font-size:.72rem;font-weight:600;color:var(--text3);
  text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem}
.calc-field input,.calc-field select{width:100%;background:var(--bg);border:1px solid var(--border);
  color:var(--text);padding:.7rem 1rem;border-radius:8px;font-size:.95rem;
  font-family:'JetBrains Mono',monospace;transition:border-color .3s;outline:none}
.calc-field input:focus,.calc-field select:focus{border-color:var(--accent)}
.calc-field select option{background:var(--bg)}
.calc-result{background:var(--bg);border:1px solid var(--border);border-radius:12px;
  padding:1.5rem;text-align:center}
.calc-result .big-num{font-family:'JetBrains Mono',monospace;font-size:2.2rem;font-weight:600;
  color:var(--accent);display:block;margin-bottom:.3rem}
.calc-result .desc{font-size:.82rem;color:var(--text2)}
.calc-result-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1rem}
.calc-mini{background:var(--surface);border-radius:8px;padding:1rem;text-align:center}
.calc-mini .val{font-family:'JetBrains Mono',monospace;font-weight:600;font-size:1.1rem;display:block}
.calc-mini .val.green{color:var(--green)}.calc-mini .val.red{color:var(--red)}
.calc-mini .lbl{font-size:.7rem;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;margin-top:.2rem}

/* ── GLOSSARY ── */
.glossary-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem}
.glossary-item{background:var(--bg2);border:1px solid var(--border);border-radius:12px;
  overflow:hidden;transition:all .3s;cursor:pointer}
.glossary-item:hover{border-color:#5e309d}
.glossary-q{padding:1rem 1.2rem;display:flex;justify-content:space-between;align-items:center;
  font-weight:600;font-size:.92rem}
.glossary-q .arrow{color:var(--text3);transition:transform .3s;font-size:1.2rem}
.glossary-item.open .arrow{transform:rotate(45deg);color:var(--accent)}
.glossary-a{padding:0 1.2rem;max-height:0;overflow:hidden;transition:all .4s ease;
  font-size:.86rem;color:var(--text2);line-height:1.7}
.glossary-item.open .glossary-a{max-height:200px;padding:0 1.2rem 1rem}

/* ── NEWSLETTER ── */
.newsletter{max-width:700px;margin:0 auto;text-align:center;
  background:linear-gradient(135deg,#3a1c63,#684895);
  border:1px solid #3a1c63;border-radius:20px;padding:3.5rem 2rem}
.newsletter h2{font-family:'Instrument Serif',serif;font-size:2rem;margin-bottom:.5rem}
.newsletter p{color:var(--text2);margin-bottom:2rem;font-size:.95rem}
.newsletter-form{display:flex;gap:.8rem;max-width:440px;margin:0 auto}
.newsletter-form input{flex:1;background:var(--bg);border:1px solid var(--border);color:var(--text);
  padding:.75rem 1.2rem;border-radius:10px;font-size:.9rem;outline:none;font-family:'DM Sans',sans-serif}
.newsletter-form input:focus{border-color:var(--accent)}
.newsletter-form button{background:var(--accent);color:var(--bg);border:none;padding:.75rem 1.5rem;
  border-radius:10px;font-weight:600;font-size:.9rem;cursor:pointer;white-space:nowrap;
  font-family:'DM Sans',sans-serif;transition:all .3s}
.newsletter-form button:hover{background:var(--accent2);transform:scale(1.03)}

/* ── FOOTER ── */
footer{border-top:1px solid var(--border);padding:3rem 2rem;text-align:center}
footer p{font-size:.78rem;color:var(--text3)}
footer a{color:var(--accent);text-decoration:none}

/* ── ANIMATIONS ── */
.fade-in{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}
.stagger-1{transition-delay:.1s}.stagger-2{transition-delay:.2s}.stagger-3{transition-delay:.3s}
.stagger-4{transition-delay:.4s}.stagger-5{transition-delay:.5s}

/* ── RESPONSIVE ── */
@media(max-width:768px){
  .nav-links{display:none}
  .hero{padding:8rem 1.5rem 3rem}
  .hero-stats{gap:1.5rem}
  .calc-grid{grid-template-columns:1fr}
  .newsletter-form{flex-direction:column}
  section{padding:3rem 1.5rem}
  .chart-header{flex-direction:column}
}