/* ═══════════════════════════════════════════════
   BRAIIN IR — Global Stylesheet (Mobile‑First)
   ═══════════════════════════════════════════════ */

/* ---------- CSS Variables ---------- */
:root {
  --bg:          #F7F9FC;
  --surface:     #FFFFFF;
  --surface-2:   #F3F6FB;
  --line:        rgba(15,30,60,.09);
  --line-strong: rgba(15,30,60,.16);
  --text:        #0D1B2A;
  --muted:       #5A6B7E;
  --muted-2:     #8FA0B4;
  --accent:      #0D6EFD;
  --up:          #059669;
  --down:        #DC2626;
  --maxw:        1240px;
  --ease:        cubic-bezier(.22,.61,.36,1);
  --r:           12px;

  /* hero */
  --hero-bg: linear-gradient(160deg,rgba(4,14,34,.90) 0%,rgba(5,24,52,.82) 50%,rgba(3,28,16,.86) 100%);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--text);font-family:'Manrope',system-ui,sans-serif;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
svg{display:block}

/* ---------- Typography ---------- */
h1,h2,h3,h4,h5{font-family:'Sora',sans-serif;line-height:1.15;letter-spacing:-.02em;font-weight:700;color:var(--text)}
h1{font-size:clamp(26px,6vw,56px)}
h2{font-size:clamp(22px,4vw,40px)}
h3{font-size:clamp(18px,2.8vw,24px)}
h4{font-size:clamp(15px,2vw,18px)}
p{font-size:15px;color:var(--muted)}
.mono{font-family:'IBM Plex Mono',monospace}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 16px}
@media(min-width:600px){.wrap{padding:0 24px}}
@media(min-width:960px){.wrap{padding:0 32px}}
.sec{padding:52px 0}
@media(min-width:768px){.sec{padding:80px 0}}

/* ---------- Pulse animation ---------- */
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(5,150,105,.5)}
  70%{box-shadow:0 0 0 8px rgba(5,150,105,0)}
  100%{box-shadow:0 0 0 0 rgba(5,150,105,0)}
}
.dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--up);animation:pulse 2.4s infinite;flex-shrink:0}

/* ════════════════════════════════════
   TOP BAR — unified container (ticker + nav)
   ════════════════════════════════════ */
.topbar{position:sticky;top:0;z-index:50}
/* On the home hero: float over the hero image, transparent */
.topbar-hero{position:absolute;left:0;right:0;top:0}
.topbar-hero.scrolled{position:fixed}

/* ── TICKER BAR ── */
.ticker-bar{
  background:#fff;
  border-bottom:1px solid var(--line);
  overflow:hidden;
  position:relative;
  z-index:1;
  transition:background .3s,border-color .3s;
}
.topbar-hero:not(.scrolled) .ticker-bar{
  background:rgba(2,10,28,.42);
  border-bottom-color:rgba(255,255,255,.08);
}
.ticker-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:38px;gap:12px;flex-wrap:nowrap;overflow:hidden;
  font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--muted);
}
.ticker-left{display:flex;align-items:center;gap:8px;white-space:nowrap}
.ticker-right{display:none;align-items:center;gap:14px;white-space:nowrap}
@media(min-width:600px){.ticker-right{display:flex}}
.t-sym{color:var(--text);font-weight:700}
.t-price{color:var(--text)}
.ticker-right b{color:var(--text)}
.t-up{color:var(--up)}
.t-down{color:var(--down)}
/* Hero (transparent) — make ticker text light */
.topbar-hero:not(.scrolled) .ticker-inner{color:rgba(255,255,255,.6)}
.topbar-hero:not(.scrolled) .t-sym,
.topbar-hero:not(.scrolled) .t-price,
.topbar-hero:not(.scrolled) .ticker-right b{color:#fff}

/* ════════════════════════════════════
   HEADER / NAV
   ════════════════════════════════════ */
.site-header{
  position:relative;
  z-index:2;
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
  box-shadow:0 2px 16px rgba(0,0,0,.06);
  transition:background .3s,box-shadow .3s,border-color .3s;
}
/* Hero (transparent) header */
.topbar-hero:not(.scrolled) .site-header{
  background:transparent;
  backdrop-filter:none;
  border-bottom:1px solid rgba(255,255,255,.10);
  box-shadow:none;
}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;height:64px;gap:12px;position:relative;z-index:2}
@media(min-width:768px){.nav-wrap{height:70px}}

/* Logo (colors via CSS so they recolor on scroll) */
.nav-logo{display:flex;align-items:center;gap:9px;font-family:'Sora',sans-serif;font-weight:800;font-size:18px;letter-spacing:-.03em;text-decoration:none}
.nav-logo-icon{display:flex;align-items:center}
.nav-logo-text{color:var(--text)}
.nav-logo-ai{border:2px solid rgba(13,27,42,.4);border-radius:4px;padding:0 3px;margin:0 1px;font-size:.86em}
.topbar-hero:not(.scrolled) .nav-logo-text{color:#fff}
.topbar-hero:not(.scrolled) .nav-logo-ai{border-color:rgba(255,255,255,.6)}
@media(min-width:768px){.nav-logo{font-size:20px}}

/* Desktop nav links */
.nav-links{display:none;align-items:center;gap:2px}
@media(min-width:1060px){.nav-links{display:flex}}
.nav-link{
  background:none;border:none;padding:8px 11px;border-radius:8px;
  font-family:'Manrope',sans-serif;font-size:13.5px;font-weight:500;
  color:var(--muted);transition:.18s;display:inline-flex;align-items:center;gap:4px;
  text-decoration:none;white-space:nowrap;
}
.nav-link:hover{color:var(--accent);background:rgba(13,110,253,.06)}
.topbar-hero:not(.scrolled) .nav-link{color:rgba(255,255,255,.85)}
.topbar-hero:not(.scrolled) .nav-link:hover{color:#fff;background:rgba(255,255,255,.12)}

/* Dropdown */
.nav-drop{position:relative}
.nav-drop-btn{background:none;border:none;padding:8px 11px;border-radius:8px;font-family:'Manrope',sans-serif;font-size:13.5px;font-weight:500;color:var(--muted);transition:.18s;cursor:pointer;display:inline-flex;align-items:center;gap:4px;white-space:nowrap}
.nav-drop-btn:hover{color:var(--accent);background:rgba(13,110,253,.06)}
.topbar-hero:not(.scrolled) .nav-drop-btn{color:rgba(255,255,255,.85)}
.topbar-hero:not(.scrolled) .nav-drop-btn:hover{color:#fff;background:rgba(255,255,255,.12)}
.nav-drop-menu{
  position:absolute;top:calc(100% + 8px);left:0;min-width:200px;
  background:#fff;border:1px solid var(--line-strong);border-radius:12px;
  padding:6px;opacity:0;visibility:hidden;transform:translateY(6px);
  transition:.2s var(--ease);box-shadow:0 16px 48px rgba(0,0,0,.18);z-index:400;
}
/* Last dropdown (Resources) opens right-aligned so it never overflows the viewport */
.nav-links .nav-drop:last-child .nav-drop-menu{left:auto;right:0}
.nav-drop:hover .nav-drop-menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav-drop-menu a{display:block;padding:10px 13px;border-radius:8px;font-size:13.5px;color:var(--muted);transition:.14s}
.nav-drop-menu a:hover{background:rgba(13,110,253,.06);color:var(--accent)}

/* Hamburger */
.hamburger{display:grid;place-items:center;background:none;border:none;padding:8px;border-radius:8px;color:var(--muted);transition:.18s}
.hamburger:hover{background:rgba(0,0,0,.05);color:var(--text)}
.topbar-hero:not(.scrolled) .hamburger{color:rgba(255,255,255,.85)}
@media(min-width:1060px){.hamburger{display:none}}

/* ════════════════════════════════════
   MOBILE MENU DRAWER
   ════════════════════════════════════ */
.mobile-drawer{
  position:fixed;top:0;right:0;bottom:0;z-index:300;
  width:min(320px,100vw);
  background:#fff;
  transform:translateX(100%);
  transition:.32s var(--ease);
  display:flex;flex-direction:column;
  box-shadow:-4px 0 40px rgba(0,0,0,.15);
  overflow-y:auto;
}
.mobile-drawer.open{transform:translateX(0)}
.drawer-overlay{
  position:fixed;inset:0;z-index:290;
  background:rgba(0,0,0,.45);
  opacity:0;visibility:hidden;transition:.3s;
}
.drawer-overlay.open{opacity:1;visibility:visible}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--line)}
.drawer-close{background:none;border:none;padding:7px;border-radius:8px;color:var(--muted);cursor:pointer}
.drawer-close:hover{background:rgba(0,0,0,.06);color:var(--text)}
.drawer-nav{padding:8px 0;flex:1}
.drawer-nav a,.drawer-nav .drawer-group-btn{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 22px;font-size:16px;font-weight:600;font-family:'Sora',sans-serif;
  color:var(--text);border:none;background:none;width:100%;cursor:pointer;transition:.15s;
}
.drawer-nav a:hover,.drawer-nav .drawer-group-btn:hover{color:var(--accent);background:rgba(13,110,253,.04)}
.drawer-nav a.active{color:var(--accent)}
.drawer-sub{display:none;padding:0 0 8px 20px}
.drawer-sub.open{display:block}
.drawer-sub a{font-size:14.5px;font-weight:500;font-family:'Manrope',sans-serif;color:var(--muted);padding:10px 22px}
.drawer-sub a:hover{color:var(--accent)}
.drawer-divider{height:1px;background:var(--line);margin:8px 0}
.drawer-footer-note{padding:16px 22px;font-size:12px;font-family:'IBM Plex Mono',monospace;color:var(--muted-2)}

/* ════════════════════════════════════
   HERO SECTION
   ════════════════════════════════════ */
.hero{
  position:relative;
  background-image:var(--hero-bg),url('hero-bg.jpg');
  background-size:cover;background-position:center;
  background-color:#050e22;
  /* top padding clears the absolute header + ticker (~110px) so the stock card sits lower */
  padding:130px 0 60px;
}
@media(min-width:768px){.hero{padding:150px 0 80px}}
@media(max-width:480px){.hero{padding:120px 0 48px}}
.hero-grid{
  display:flex;flex-direction:column;gap:36px;
}
@media(min-width:900px){
  .hero-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:52px;align-items:center}
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:rgba(255,255,255,.75);
  padding:6px 14px;border:1px solid rgba(255,255,255,.22);
  border-radius:100px;background:rgba(255,255,255,.08);margin-bottom:18px;
}
.hero h1{color:#fff;margin-bottom:18px;font-size:clamp(28px,5.5vw,58px)}
.hero h1 .hl{
  background:linear-gradient(120deg,#4ade80,#22d3ee);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.hero-sub{color:rgba(255,255,255,.72);font-size:clamp(14px,1.7vw,17px);max-width:52ch;margin-bottom:28px;line-height:1.7}
.hero-actions{display:flex;gap:10px;flex-wrap:wrap}

/* ════════════════════════════════════
   BUTTONS
   ════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;gap:7px;
  font-family:'Manrope',sans-serif;font-weight:600;font-size:14px;
  padding:11px 20px;border-radius:9px;border:1.5px solid transparent;
  transition:.2s;white-space:nowrap;cursor:pointer;text-decoration:none;
}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 4px 14px rgba(13,110,253,.3)}
.btn-primary:hover{background:#0b5ed7;transform:translateY(-1px);box-shadow:0 8px 22px rgba(13,110,253,.35)}
.btn-outline{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.32)}
.btn-outline:hover{background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.6)}
.btn-ghost{background:transparent;color:var(--text);border-color:var(--line-strong)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);background:rgba(13,110,253,.04)}
.btn-sm{padding:8px 15px;font-size:13px}
.btn-full{width:100%;justify-content:center}

/* ════════════════════════════════════
   STOCK CARD
   ════════════════════════════════════ */
.stock-card{
  background:rgba(255,255,255,.97);
  border:1px solid rgba(255,255,255,.25);
  border-radius:16px;padding:22px;
  box-shadow:0 8px 32px rgba(0,0,0,.28);
}
.stock-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px}
.stock-label{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}
.stock-name{font-family:'Sora',sans-serif;font-weight:800;font-size:17px;margin-top:3px}
.stock-name span{color:var(--accent)}
.live-badge{display:inline-flex;align-items:center;gap:6px;font-family:'IBM Plex Mono',monospace;font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.stock-price{font-family:'IBM Plex Mono',monospace;font-size:46px;font-weight:700;letter-spacing:-.02em;margin:14px 0 4px;line-height:1}
.stock-change{display:flex;gap:9px;align-items:center;font-family:'IBM Plex Mono',monospace;font-size:14px;margin-bottom:14px}
.pill{padding:3px 9px;border-radius:6px;font-size:12.5px;font-weight:600}
.pill-up{background:rgba(5,150,105,.1);color:var(--up)}
.pill-down{background:rgba(220,38,38,.1);color:var(--down)}
.stock-spark{width:100%;height:76px;display:block;margin:4px 0 12px}
.stock-stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.stock-stat{background:#F7F9FC;padding:11px 13px}
.stat-k{font-size:10px;color:var(--muted-2);text-transform:uppercase;letter-spacing:.08em;font-family:'IBM Plex Mono',monospace}
.stat-v{font-family:'IBM Plex Mono',monospace;font-size:14px;color:var(--text);margin-top:2px}
.stock-delayed{font-size:10.5px;color:var(--muted-2);margin-top:10px;font-family:'IBM Plex Mono',monospace}

/* ════════════════════════════════════
   SECTION HEADERS
   ════════════════════════════════════ */
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:32px;flex-wrap:wrap}
.sec-label{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:9px}
.sec-head h2{font-size:clamp(22px,3.5vw,38px)}
.sec-head p{color:var(--muted);font-size:14.5px;margin-top:8px;max-width:46ch}

/* PAGE INNER HEADER */
.page-header{
  background:var(--hero-bg),url('hero-bg.jpg') center/cover;
  background-color:#050e22;
  padding:50px 0 42px;
}
@media(min-width:768px){.page-header{padding:64px 0 52px}}
.breadcrumb{font-family:'IBM Plex Mono',monospace;font-size:11px;color:rgba(255,255,255,.5);margin-bottom:10px;display:flex;align-items:center;gap:6px}
.breadcrumb a{color:rgba(255,255,255,.6);transition:.15s}
.breadcrumb a:hover{color:#fff}
.page-header h1{color:#fff;font-size:clamp(24px,4vw,46px)}
.page-header p{color:rgba(255,255,255,.65);font-size:15px;margin-top:10px;max-width:50ch}

/* ════════════════════════════════════
   ABOUT SECTION
   ════════════════════════════════════ */
.about-section{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.about-grid{display:flex;flex-direction:column;gap:32px}
@media(min-width:880px){.about-grid{display:grid;grid-template-columns:1.15fr 1fr;gap:56px;align-items:center}}
.about-lead{font-size:17px;color:#1e3248;line-height:1.65;margin-bottom:12px}
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.stat-card{background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:20px}
.stat-n{font-family:'Sora',sans-serif;font-size:30px;font-weight:800;background:linear-gradient(120deg,var(--accent),#22d3ee);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.stat-l{color:var(--muted);font-size:13px;margin-top:4px}
.verticals{display:grid;grid-template-columns:1fr;gap:14px;margin-top:36px}
@media(min-width:640px){.verticals{grid-template-columns:1fr 1fr}}
@media(min-width:960px){.verticals{grid-template-columns:repeat(3,1fr)}}
.vcard{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px;transition:.22s}
.vcard:hover{transform:translateY(-3px);border-color:rgba(13,110,253,.25);box-shadow:0 8px 28px rgba(0,0,0,.08)}
.vcard-icon{width:44px;height:44px;border-radius:10px;background:rgba(13,110,253,.08);display:grid;place-items:center;margin-bottom:14px;color:var(--accent)}
.vcard h4{font-size:16px;margin-bottom:7px}
.vcard p{font-size:14px}

/* ════════════════════════════════════
   PRESS RELEASES
   ════════════════════════════════════ */
.pr-list{display:flex;flex-direction:column}
.pr-item{display:grid;grid-template-columns:1fr;gap:6px;padding:18px 10px;border-top:1px solid var(--line);cursor:pointer;transition:.18s;border-radius:8px}
.pr-item:hover{background:rgba(13,110,253,.03);padding-left:16px;padding-right:16px}
.pr-item:last-child{border-bottom:1px solid var(--line)}
@media(min-width:600px){.pr-item{grid-template-columns:120px 1fr auto;gap:20px;align-items:center;padding:20px 8px}}
.pr-date{font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--muted)}
.pr-tag{display:inline-block;font-size:10.5px;font-family:'IBM Plex Mono',monospace;text-transform:uppercase;letter-spacing:.07em;color:var(--accent);border:1px solid rgba(13,110,253,.22);padding:2px 8px;border-radius:5px;margin-bottom:6px;background:rgba(13,110,253,.05)}
.pr-item h4{font-size:15px;font-weight:600;line-height:1.4;transition:.15s}
.pr-item:hover h4{color:var(--accent)}
.pr-arrow{color:var(--muted-2);transition:.15s;display:none}
@media(min-width:600px){.pr-arrow{display:block}}
.pr-item:hover .pr-arrow{color:var(--accent);transform:translateX(3px)}

/* ════════════════════════════════════
   FILTER CHIPS
   ════════════════════════════════════ */
.filterbar{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:18px;overflow-x:auto;padding-bottom:4px}
.filterbar::-webkit-scrollbar{display:none}
.chip{font-family:'IBM Plex Mono',monospace;font-size:12px;padding:7px 13px;border-radius:8px;border:1px solid var(--line);background:#fff;color:var(--muted);cursor:pointer;transition:.16s;white-space:nowrap}
.chip:hover{border-color:var(--accent);color:var(--accent)}
.chip.active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}

/* ════════════════════════════════════
   FILINGS TABLE
   ════════════════════════════════════ */
.ftable{background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,.05)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:10px;align-items:center;padding:14px 16px;border-bottom:1px solid var(--line);transition:.15s}
@media(min-width:640px){.frow{grid-template-columns:115px 95px 1fr;gap:14px;padding:14px 20px}}
@media(min-width:900px){.frow{grid-template-columns:115px 95px 1fr 100px;gap:16px}}
.frow:last-child{border-bottom:none}
.frow.head{background:var(--surface-2);font-family:'IBM Plex Mono',monospace;font-size:10.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}
.frow:not(.head):hover{background:rgba(13,110,253,.03)}
.ftype{font-family:'IBM Plex Mono',monospace;font-weight:700;color:var(--accent);font-size:13px}
.fdate{font-family:'IBM Plex Mono',monospace;color:var(--muted);font-size:12.5px}
.fdesc{color:var(--text);font-size:14px;grid-column:1/-1}
@media(min-width:640px){.fdesc{grid-column:auto}}
.flink{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:5px;justify-content:flex-end;transition:.15s;display:none}
@media(min-width:900px){.flink{display:flex}}
.frow:not(.head):hover .flink{color:var(--accent)}
.edgar-note{font-size:11px;color:var(--muted-2);margin-top:10px;font-family:'IBM Plex Mono',monospace;display:flex;align-items:center;gap:7px}

/* ════════════════════════════════════
   TWO-COL PANELS
   ════════════════════════════════════ */
.two-col{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:768px){.two-col{grid-template-columns:1fr 1fr}}
.panel{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px;box-shadow:0 2px 8px rgba(0,0,0,.04)}
.panel h3{font-size:18px;margin-bottom:16px;display:flex;align-items:center;gap:9px}
.panel h3 .pi{color:var(--accent)}
.event-row{display:flex;gap:14px;padding:13px 0;border-top:1px solid var(--line)}
.event-row:first-of-type{border-top:none;padding-top:0}
.ev-cal{flex-shrink:0;width:52px;text-align:center;border:1px solid var(--line);border-radius:9px;padding:7px 0;background:var(--surface-2)}
.ev-cal .m{font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--accent);text-transform:uppercase}
.ev-cal .d{font-family:'Sora',sans-serif;font-size:19px;font-weight:700}
.ev-info h4{font-size:15px;margin-bottom:3px}
.ev-info p{font-size:13px}
.doc-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 0;border-top:1px solid var(--line);cursor:pointer;transition:.15s}
.doc-row:first-of-type{border-top:none;padding-top:0}
.doc-row:hover .doc-name{color:var(--accent)}
.doc-dl-wrap{display:flex;align-items:center;gap:12px}
.doc-icon{width:36px;height:44px;border-radius:6px;background:var(--surface-2);border:1px solid var(--line);display:grid;place-items:center;color:#DC2626;font-family:'IBM Plex Mono',monospace;font-size:8.5px;font-weight:700;flex-shrink:0}
.doc-name{font-size:14px;font-weight:600;transition:.15s}
.doc-meta{font-size:12px;color:var(--muted)}
.doc-dl{color:var(--muted-2);transition:.15s}
.doc-row:hover .doc-dl{color:var(--accent)}

/* ════════════════════════════════════
   PEOPLE GRID
   ════════════════════════════════════ */
.people-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(min-width:640px){.people-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:960px){.people-grid{grid-template-columns:repeat(4,1fr)}}
.person-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px;transition:.22s;box-shadow:0 1px 4px rgba(0,0,0,.04)}
.person-card:hover{transform:translateY(-3px);border-color:rgba(13,110,253,.2);box-shadow:0 8px 24px rgba(0,0,0,.08)}
.person-av{width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:2px solid rgba(13,110,253,.15);display:grid;place-items:center;font-family:'Sora',sans-serif;font-weight:700;font-size:17px;color:var(--accent);margin-bottom:13px}
.person-name{font-size:14.5px;font-weight:700;margin-bottom:3px}
.person-role{color:var(--accent);font-size:12px;font-weight:600;margin-bottom:8px}
.person-bio{font-size:12.5px;color:var(--muted);line-height:1.55;border-top:1px solid var(--line);padding-top:9px;margin-top:4px}

/* ════════════════════════════════════
   EMAIL ALERTS BANNER
   ════════════════════════════════════ */
.alerts-banner{
  background:linear-gradient(135deg,#0a1e3d 0%,#0f3460 60%,#0a2d1f 100%);
  border-radius:16px;padding:36px 24px;position:relative;overflow:hidden;
}
@media(min-width:768px){.alerts-banner{padding:48px}}
.alerts-banner::before{content:"";position:absolute;inset:0;background:url('hero-bg.jpg') center/cover;opacity:.08}
.alerts-inner{position:relative;z-index:1;display:flex;flex-direction:column;gap:24px}
@media(min-width:760px){.alerts-inner{flex-direction:row;align-items:center;justify-content:space-between;gap:36px}}
.alerts-banner h2{color:#fff;font-size:clamp(20px,3vw,32px);margin-bottom:10px}
.alerts-banner p{color:rgba(255,255,255,.65);font-size:15px;max-width:44ch}
.alert-form{display:flex;gap:10px;flex-wrap:wrap;flex-shrink:0}
.alert-input{
  background:rgba(255,255,255,.95);border:1.5px solid rgba(255,255,255,.3);
  border-radius:9px;padding:12px 15px;color:var(--text);font-family:'Manrope',sans-serif;
  font-size:15px;outline:none;transition:.2s;min-width:0;width:100%;
}
@media(min-width:480px){.alert-input{width:260px}}
.alert-input:focus{border-color:#4ade80;box-shadow:0 0 0 3px rgba(74,222,128,.2)}
.alert-msg{font-size:12.5px;font-family:'IBM Plex Mono',monospace;margin-top:6px}

/* ════════════════════════════════════
   CONTACT GRID
   ════════════════════════════════════ */
.contact-grid{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:640px){.contact-grid{grid-template-columns:1fr 1fr}}
.cbox{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px;box-shadow:0 2px 8px rgba(0,0,0,.04)}
.cbox-label{font-family:'IBM Plex Mono',monospace;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.cbox h4{font-size:17px;margin-bottom:5px}
.cbox-sub{color:var(--muted);font-size:13.5px;margin-bottom:4px}
.cbox-row{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--muted);margin-top:10px}
.cbox-row b{color:var(--text);font-weight:500}
.cbox-row a{color:var(--text);transition:.15s}
.cbox-row a:hover{color:var(--accent)}

/* Contact Form */
.contact-form{background:#fff;border:1px solid var(--line);border-radius:14px;padding:28px;box-shadow:0 2px 8px rgba(0,0,0,.04)}
.form-row{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:600px){.form-row{grid-template-columns:1fr 1fr}}
.form-field{margin-bottom:0}
.form-field label{display:block;font-family:'IBM Plex Mono',monospace;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);margin-bottom:7px}
.form-field input,.form-field textarea,.form-field select{
  width:100%;background:var(--surface-2);border:1.5px solid var(--line-strong);
  border-radius:9px;padding:12px 14px;color:var(--text);font-family:'Manrope',sans-serif;
  font-size:15px;outline:none;transition:.18s;
}
.form-field input:focus,.form-field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(13,110,253,.1)}
.form-field textarea{resize:vertical;min-height:120px}

/* ════════════════════════════════════
   FAQ
   ════════════════════════════════════ */
.faq-list{display:flex;flex-direction:column;gap:10px}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;transition:border-color .2s,box-shadow .2s,transform .2s;position:relative}
.faq-item::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent);transform:scaleY(0);transform-origin:top;transition:transform .25s var(--ease)}
.faq-item:hover{box-shadow:0 4px 14px rgba(0,0,0,.06)}
.faq-item.open{border-color:rgba(13,110,253,.3);box-shadow:0 6px 22px rgba(13,110,253,.1)}
.faq-item.open::before{transform:scaleY(1)}
.faq-q{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;cursor:pointer;font-size:15.5px;font-weight:600;gap:14px;user-select:none;min-height:58px;transition:color .15s}
.faq-q:hover{color:var(--accent)}
.faq-item.open .faq-q{color:var(--accent)}
.faq-icon{color:var(--accent);flex-shrink:0;transition:transform .3s var(--ease);width:28px;height:28px;border-radius:7px;background:rgba(13,110,253,.08);display:grid;place-items:center}
.faq-item.open .faq-icon{transform:rotate(45deg);background:var(--accent);color:#fff}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s var(--ease),padding .35s var(--ease);color:var(--muted);font-size:14.5px;line-height:1.75;padding:0 22px}
.faq-item.open .faq-a{max-height:500px;padding:0 22px 22px}

/* ════════════════════════════════════
   EVENTS
   ════════════════════════════════════ */
.events-grid{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:640px){.events-grid{grid-template-columns:1fr 1fr}}
.event-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px;display:flex;gap:16px;align-items:flex-start;transition:.22s;box-shadow:0 1px 4px rgba(0,0,0,.04)}
.event-card:hover{border-color:rgba(13,110,253,.2);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.08)}
.event-cal{flex-shrink:0;width:58px;text-align:center;border:1px solid var(--line);border-radius:9px;padding:9px 0;background:var(--surface-2)}
.event-cal .m{font-family:'IBM Plex Mono',monospace;font-size:10.5px;color:var(--accent);text-transform:uppercase}
.event-cal .d{font-family:'Sora',sans-serif;font-size:21px;font-weight:700}
.event-content h4{font-size:15.5px;font-weight:600;margin-bottom:5px}
.event-content p{font-size:13px}
.event-badge{display:inline-flex;align-items:center;gap:5px;font-family:'IBM Plex Mono',monospace;font-size:10.5px;padding:2px 9px;border-radius:5px;margin-bottom:8px}

/* ════════════════════════════════════
   FOOTER
   ════════════════════════════════════ */
footer{background:#fff;border-top:1px solid var(--line);padding:44px 0 24px;margin-top:20px}
.footer-grid{display:grid;grid-template-columns:1fr;gap:28px;margin-bottom:32px}
@media(min-width:640px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(min-width:960px){.footer-grid{grid-template-columns:1.4fr 1fr 1fr}}
.footer-col-title{font-family:'IBM Plex Mono',monospace;font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--muted-2);margin-bottom:13px}
.footer-links a{display:block;font-size:13.5px;color:var(--muted);padding:5px 0;transition:.14s}
.footer-links a:hover{color:var(--accent)}
.footer-desc{color:var(--muted);font-size:13.5px;margin-top:12px;line-height:1.65;max-width:32ch}
.social-row{display:flex;gap:9px;margin-top:16px}
.social-row a{width:36px;height:36px;border-radius:8px;border:1px solid var(--line);display:grid;place-items:center;color:var(--muted);transition:.18s}
.social-row a:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}
.footer-bar{border-top:1px solid var(--line);padding-top:20px;display:flex;flex-direction:column;gap:8px;font-size:12.5px;color:var(--muted-2)}
@media(min-width:600px){.footer-bar{flex-direction:row;justify-content:space-between;align-items:center}}
.footer-bar b{color:var(--accent)}

/* ════════════════════════════════════
   ALERTS PAGE - PREFERENCES
   ════════════════════════════════════ */
.alerts-page-grid{display:grid;grid-template-columns:1fr;gap:20px;max-width:860px}
@media(min-width:700px){.alerts-page-grid{grid-template-columns:1fr 1fr}}
.pref-row{display:flex;align-items:flex-start;gap:13px;padding:13px 0;border-bottom:1px solid var(--line)}
.pref-check{width:20px;height:20px;border-radius:5px;border:1.5px solid var(--line-strong);cursor:pointer;flex-shrink:0;margin-top:2px;transition:.18s;display:grid;place-items:center}
.pref-check.checked{background:var(--accent);border-color:var(--accent)}
.pref-label{font-size:14.5px;font-weight:600;margin-bottom:2px}
.pref-desc{font-size:12.5px;color:var(--muted)}

/* ════════════════════════════════════
   STOCK PAGE EXTRAS
   ════════════════════════════════════ */
.key-stats-table{width:100%;border-collapse:collapse}
.key-stats-table tr{border-bottom:1px solid var(--line)}
.key-stats-table td{padding:9px 0;font-family:'IBM Plex Mono',monospace;font-size:13px}
.key-stats-table td:first-child{color:var(--muted);width:50%}
.key-stats-table td:last-child{text-align:right;font-weight:600;color:var(--text)}
.range-btns{display:flex;gap:6px;flex-wrap:wrap}
.range-btn{font-family:'IBM Plex Mono',monospace;font-size:12px;padding:5px 12px;border-radius:7px;border:1px solid var(--line);background:transparent;color:var(--muted);cursor:pointer;transition:.15s}
.range-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ════════════════════════════════════
   UTILITIES
   ════════════════════════════════════ */
.text-up{color:var(--up)!important}
.text-down{color:var(--down)!important}
.hidden{display:none!important}
.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mt-8{margin-top:32px}
.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}
@media(max-width:640px){.hide-mobile{display:none!important}}
@media(min-width:641px){.show-mobile{display:none!important}}

/* ════════════════════════════════════
   MOBILE TWEAKS
   ════════════════════════════════════ */
@media(max-width:480px){
  .hero{padding:56px 0 44px}
  .hero h1{font-size:28px}
  .stock-card{padding:18px}
  .stock-price{font-size:38px}
  .frow{padding:12px 14px}
  .panel{padding:18px}
  .person-card{padding:16px}
  .alerts-banner{padding:26px 18px}
  .cbox{padding:20px}
}
