/* ─────────────────────────────────────────
   DESIGN TOKENS
───────────────────────────────────────── */
:root{
  --bg0:#05080F;--bg1:#090D18;--bg2:#0D1220;--bg3:#111827;
  --c:#00D4FF;--cg:#00E5A0;--ca:#F59E0B;--cr:#FF4D6A;
  --c10:rgba(0,212,255,.1);--c30:rgba(0,212,255,.3);
  --t0:#F0F4FF;--t1:#8892A4;--t2:#4A5568;
  --b:rgba(255,255,255,.07);--ba:rgba(0,212,255,.28);
  --fs:'Sora',system-ui,sans-serif;
  --fm:'JetBrains Mono',ui-monospace,monospace;
  --r:12px;--r2:8px;
}

/* ─────────────────────────────────────────
   RESET  (keep small — only what's used)
───────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--bg0);color:var(--t0);
  font-family:var(--fs);font-size:16px;line-height:1.65;
  overflow-x:hidden;
  /* GPU layer for grid bg — does NOT repaint on scroll */
}
img,svg{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}
a{color:inherit;text-decoration:none}

/* ─────────────────────────────────────────
   GRID BACKGROUND
   position:fixed + will-change:transform   
   = promoted to GPU layer immediately,
   zero main-thread cost on scroll
───────────────────────────────────────── */
#grid-bg{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  will-change:transform;
  background-image:
    linear-gradient(var(--b) 1px,transparent 1px),
    linear-gradient(90deg,var(--b) 1px,transparent 1px);
  background-size:56px 56px;
}

/* ─────────────────────────────────────────
   LAYOUT UTILITIES
───────────────────────────────────────── */
.wrap{position:relative;z-index:1}
.con{max-width:1100px;margin:0 auto;padding:0 20px}
@media(min-width:768px){.con{padding:0 40px}}
@media(min-width:1200px){.con{padding:0 48px}}

/* ─────────────────────────────────────────
   NAV
   No backdrop-filter (triggers compositing
   on every paint — kills mobile perf).
   Use solid semi-transparent bg instead.
───────────────────────────────────────── */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 20px;
  background:rgba(5,8,15,.95);
  border-bottom:1px solid var(--b);
  /* transition only opacity — compositor-only */
  transition:opacity .3s;
}
@media(min-width:768px){#nav{padding:16px 48px}}

.nav-logo{
  display:flex;align-items:center;gap:9px;
  font-family:var(--fm);font-size:15px;font-weight:500;
  letter-spacing:-.01em;
}
.logo-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--c);
  /* animate only opacity + transform = GPU compositor */
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.45;transform:scale(.75)}
}

.nav-links{display:none;align-items:center;gap:28px}
@media(min-width:900px){.nav-links{display:flex}}
.nav-links a{font-size:13.5px;color:var(--t1);transition:color .2s}
.nav-links a:hover{color:var(--t0)}
.nav-pill{
  background:var(--c10);border:1px solid var(--ba);
  color:var(--c)!important;padding:7px 18px;border-radius:6px;
  font-size:13px!important;font-weight:600;
  transition:background .2s!important;
}
.nav-pill:hover{background:rgba(0,212,255,.18)!important}

/* ─────────────────────────────────────────
   HERO
───────────────────────────────────────── */
.hero{
  min-height:100svh;display:flex;align-items:center;
  padding-top:72px;
}
.hero-inner{
  padding:48px 20px 64px;
  display:flex;flex-direction:column;gap:40px;
  max-width:1100px;margin:0 auto;
}
@media(min-width:900px){
  .hero-inner{
    flex-direction:row;
    align-items:center;
    gap:64px;
    padding:80px 48px;
  }
}

/* Hero copy */
.hero-copy{flex:1}

.badge{
  display:inline-flex;align-items:center;gap:7px;
  background:var(--c10);border:1px solid var(--ba);
  border-radius:100px;padding:5px 13px;
  font-family:var(--fm);font-size:11px;color:var(--c);
  letter-spacing:.08em;text-transform:uppercase;
  margin-bottom:24px;
}
.badge-dot{
  width:5px;height:5px;border-radius:50%;background:var(--c);
  animation:pulse 1.5s ease-in-out infinite;
}

h1{
  font-size:clamp(32px,5.5vw,54px);
  font-weight:700;line-height:1.1;
  letter-spacing:-.03em;
  margin-bottom:20px;
}
h1 em{font-style:normal;color:var(--c)}

.hero-sub{
  font-size:clamp(15px,2vw,17px);
  color:var(--t1);line-height:1.7;
  margin-bottom:16px;max-width:460px;
}

.inline-disc{
  font-family:var(--fm);font-size:11px;color:var(--t2);
  border-left:2px solid var(--t2);padding:10px 13px;
  margin-bottom:32px;line-height:1.55;
}

.stats-row{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:8px;
}
.stat-mini{
  background:var(--bg1);border:1px solid var(--b);
  border-radius:var(--r2);padding:10px;text-align:center;
}
.stat-mini b{
  display:block;font-family:var(--fm);
  font-size:clamp(17px,2.5vw,21px);font-weight:700;
  color:var(--t0);letter-spacing:-.02em;
}
.stat-mini span{display:block;font-size:11px;color:var(--t2);margin-top:2px}

/* ─────────────────────────────────────────
   SEARCH WIDGET
───────────────────────────────────────── */
.widget{
  flex:0 0 auto;width:100%;
  background:var(--bg2);border:1px solid var(--b);
  border-radius:var(--r);padding:24px;
  position:relative;overflow:hidden;
}
@media(min-width:900px){.widget{width:440px;padding:28px}}

/* Top accent bar animation — transform only, GPU */
.widget::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--c),transparent);
  animation:accentBar 3s ease-in-out infinite;
  will-change:transform;
}
@keyframes accentBar{
  0%{transform:translateX(-100%);opacity:0}
  15%{opacity:1}
  85%{opacity:1}
  100%{transform:translateX(100%);opacity:0}
}

.w-label{
  font-family:var(--fm);font-size:10.5px;color:var(--t2);
  letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px;
}

/* Chips */
.chips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.chip{
  background:var(--bg3);border:1px solid var(--b);
  border-radius:5px;padding:4px 11px;
  font-family:var(--fm);font-size:11.5px;color:var(--t2);
  transition:color .2s,border-color .2s;
  /* minimum tap target supplement — invisible padding */
  min-height:32px;display:flex;align-items:center;
}
.chip:hover,.chip:focus-visible{color:var(--c);border-color:var(--ba)}

/* Input */
.input-wrap{position:relative;margin-bottom:12px}

#ticker{
  width:100%;
  /* 16px minimum prevents iOS auto-zoom */
  font-size:16px;
  background:var(--bg1);
  border:1.5px solid var(--b);
  border-radius:var(--r2);
  padding:15px 52px 15px 16px;
  font-family:var(--fm);font-weight:500;
  color:var(--t0);letter-spacing:.08em;
  text-transform:uppercase;outline:none;
  /* transition only border-color = no layout */
  transition:border-color .25s,box-shadow .25s;
  /* explicit height → prevents CLS */
  height:52px;
}
#ticker::placeholder{
  color:var(--t2);text-transform:none;
  font-weight:400;letter-spacing:.02em;
}
#ticker:focus{
  border-color:var(--ba);
  box-shadow:0 0 0 3px rgba(0,212,255,.08);
}
.input-ico{
  position:absolute;right:16px;top:50%;
  transform:translateY(-50%);
  color:var(--t2);pointer-events:none;
  transition:color .25s;
}
#ticker:focus~.input-ico{color:var(--c)}

/* Scan overlay — only animates opacity + transform */
.scan-wrap{
  position:absolute;inset:0;border-radius:var(--r2);
  pointer-events:none;overflow:hidden;
  opacity:0;transition:opacity .3s;
}
.scan-wrap.on{opacity:1}
.scan-beam{
  position:absolute;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--c),transparent);
  will-change:transform;
  animation:beam 1.1s linear infinite;
}
@keyframes beam{
  from{transform:translateY(0)}
  to{transform:translateY(52px)}
}

/* Analyze button */
.btn-analyze{
  width:100%;height:52px;
  background:var(--c);color:#03060E;
  border-radius:var(--r2);
  font-size:15px;font-weight:700;letter-spacing:.02em;
  display:flex;align-items:center;justify-content:center;gap:9px;
  /* animate only transform+box-shadow = compositor */
  transition:box-shadow .25s,transform .15s;
  position:relative;overflow:hidden;
}
/* Shimmer — transform only */
.btn-analyze::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);
  transform:translateX(-100%);
  will-change:transform;
}
.btn-analyze:hover{box-shadow:0 6px 28px rgba(0,212,255,.32)}
.btn-analyze:hover::after{
  animation:shimmer .55s ease-out forwards;
}
@keyframes shimmer{to{transform:translateX(100%)}}
.btn-analyze:active{transform:scale(.98)}
.btn-analyze:disabled{opacity:.55;cursor:not-allowed;transform:none}

/* ─────────────────────────────────────────
   ANALYSIS PANEL
───────────────────────────────────────── */
.analysis{
  display:none;margin-top:20px;
  background:var(--bg1);border:1px solid var(--ba);
  border-radius:var(--r2);padding:18px;
}
.analysis.on{display:block}

.a-head{display:flex;align-items:center;gap:9px;margin-bottom:14px}
.a-ticker{font-family:var(--fm);font-size:15px;font-weight:500;color:var(--c)}
.a-status{font-family:var(--fm);font-size:11px;color:var(--t2);flex:1}

.spin{
  width:15px;height:15px;flex-shrink:0;
  border:2px solid rgba(0,212,255,.25);border-top-color:var(--c);
  border-radius:50%;
  /* transform-only animation */
  animation:spin .7s linear infinite;
  will-change:transform;
}
@keyframes spin{to{transform:rotate(360deg)}}

.dim{display:flex;align-items:center;gap:10px;margin-bottom:9px}
.dim-lbl{
  font-family:var(--fm);font-size:10.5px;color:var(--t1);
  width:140px;flex-shrink:0;
}
.track{flex:1;height:3px;background:var(--b);border-radius:2px;overflow:hidden}
.fill{
  height:100%;border-radius:2px;width:0;
  /* transition is compositor-eligible on width? 
     Actually width triggers layout — but for a small
     element < 3px tall the cost is negligible vs pure
     transform. Using scaleX would need transform-origin
     tricks. width is fine for this use case. */
  transition:width 1.6s cubic-bezier(.4,0,.2,1);
}
.pct{font-family:var(--fm);font-size:10.5px;color:var(--t2);width:28px;text-align:right;flex-shrink:0}

.stream{
  margin-top:10px;font-family:var(--fm);font-size:9.5px;
  color:var(--c);opacity:.6;height:28px;overflow:hidden;
}
.stream-line{
  animation:slideUp .35s ease-out both;
  will-change:transform,opacity;
}
@keyframes slideUp{
  from{transform:translateY(10px);opacity:0}
  to{transform:translateY(0);opacity:1}
}

/* Proof + risk inside widget */
.proof{
  display:flex;flex-wrap:wrap;gap:10px 16px;
  padding:12px 0;
  border-top:1px solid var(--b);margin-top:14px;
}
.proof-i{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--t2)}
.proof-i svg{flex-shrink:0;color:var(--cg)}

.risk-box{
  margin-top:14px;padding:12px 14px;
  background:rgba(245,158,11,.05);
  border:1px solid rgba(245,158,11,.18);
  border-radius:var(--r2);
  display:flex;gap:10px;align-items:flex-start;
}
.risk-box svg{flex-shrink:0;color:var(--ca);margin-top:1px}
.risk-txt{font-size:11px;color:var(--t2);line-height:1.55}
.risk-txt strong{color:var(--ca);font-weight:600}

/* ─────────────────────────────────────────
   SCROLL REVEAL
   Only opacity + translateY — GPU compositor
───────────────────────────────────────── */
.reveal{
  opacity:0;transform:translateY(20px);
  transition:opacity .55s ease,transform .55s ease;
  will-change:opacity,transform;
}
.reveal.in{opacity:1;transform:translateY(0)}

/* Remove will-change after animation to free GPU memory */
.reveal.done{will-change:auto}

/* ─────────────────────────────────────────
   content-visibility: auto
   Tells browser to skip layout/paint of
   off-screen sections until near viewport.
   Biggest single PageSpeed win for long pages.
───────────────────────────────────────── */
.cv{
  content-visibility:auto;
  /* contain-intrinsic-size prevents CLS when
     content-visibility collapses the element */
  contain-intrinsic-size:0 600px;
}

/* ─────────────────────────────────────────
   SECTION SHARED STYLES
───────────────────────────────────────── */
section{position:relative;z-index:1}
.sec{padding:80px 0}
@media(min-width:768px){.sec{padding:112px 0}}

.tag{
  display:flex;align-items:center;gap:10px;
  font-family:var(--fm);font-size:10.5px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--c);margin-bottom:14px;
}
.tag::before{content:'';width:20px;height:1px;background:var(--c)}

h2{
  font-size:clamp(26px,3.5vw,40px);
  font-weight:700;letter-spacing:-.025em;line-height:1.15;
  margin-bottom:14px;
}
.sec-sub{
  font-size:clamp(14px,1.8vw,17px);color:var(--t1);
  max-width:520px;line-height:1.7;margin-bottom:56px;
}

/* ─────────────────────────────────────────
   HOW IT WORKS
───────────────────────────────────────── */
.steps{
  display:grid;gap:16px;
  grid-template-columns:1fr;
}
@media(min-width:640px){.steps{grid-template-columns:repeat(3,1fr)}}

.step{
  background:var(--bg2);border:1px solid var(--b);
  border-radius:var(--r);padding:28px 24px;
  transition:border-color .3s,transform .3s;
}
.step:hover{border-color:var(--ba);transform:translateY(-3px)}

.step-num{
  font-family:var(--fm);font-size:10px;color:var(--c);
  letter-spacing:.1em;opacity:.65;margin-bottom:18px;
}
.ico-wrap{
  width:44px;height:44px;border-radius:10px;
  background:var(--c10);border:1px solid var(--ba);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:18px;
}
.step h3{font-size:16px;font-weight:600;margin-bottom:8px;letter-spacing:-.01em}
.step p{font-size:13.5px;color:var(--t1);line-height:1.65}

/* ─────────────────────────────────────────
   METHODOLOGY
───────────────────────────────────────── */
.meth-bg{background:var(--bg1)}

.meth-grid{
  display:grid;gap:20px;
  grid-template-columns:1fr;
}
@media(min-width:768px){.meth-grid{grid-template-columns:1fr 1fr}}

.mcard{
  background:var(--bg2);border:1px solid var(--b);
  border-radius:var(--r);overflow:hidden;
}
.mcard-head{
  padding:14px 20px;border-bottom:1px solid var(--b);
  display:flex;align-items:center;gap:10px;
}
.mcard-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.mcard-title{font-family:var(--fm);font-size:11px;color:var(--t1);letter-spacing:.04em}
.mcard-body{padding:20px}

.src-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:9px 0;border-bottom:1px solid var(--b);font-size:12.5px;
}
.src-row:last-child{border:0}
.src-name{color:var(--t1)}
.tag-pill{
  font-family:var(--fm);font-size:9.5px;
  padding:3px 8px;border-radius:4px;font-weight:500;
}
.live{background:rgba(0,229,160,.1);color:var(--cg);border:1px solid rgba(0,229,160,.2)}
.daily{background:rgba(0,212,255,.08);color:var(--c);border:1px solid rgba(0,212,255,.15)}
.wkly{background:rgba(255,255,255,.04);color:var(--t2);border:1px solid var(--b)}

.dim-row{display:flex;gap:11px;padding:11px 0;border-bottom:1px solid var(--b)}
.dim-row:last-child{border:0}
.dim-blt{
  width:6px;height:6px;border-radius:50%;
  background:var(--c);margin-top:7px;flex-shrink:0;
}
.dim-n{font-size:13px;font-weight:600;display:block;margin-bottom:3px}
.dim-d{font-size:12px;color:var(--t2);line-height:1.55}

.lim-row{display:flex;gap:10px;padding:11px 0;border-bottom:1px solid var(--b);font-size:12.5px}
.lim-row:last-child{border:0}
.lim-ico{color:var(--ca);flex-shrink:0;margin-top:1px;font-size:14px}
.lim-txt{color:var(--t1);line-height:1.55}

/* ─────────────────────────────────────────
   SAMPLE REPORT
───────────────────────────────────────── */
.report{
  background:var(--bg2);border:1px solid var(--b);
  border-radius:var(--r);overflow:hidden;
  position:relative;
}
.report-bar{
  background:var(--bg3);padding:12px 20px;
  display:flex;align-items:center;gap:10px;
  border-bottom:1px solid var(--b);
}
.dots{display:flex;gap:5px}
.dot{width:9px;height:9px;border-radius:50%}
.bar-title{font-family:var(--fm);font-size:11px;color:var(--t2);margin-left:8px}

.report-body{display:flex;flex-direction:column}
@media(min-width:640px){.report-body{flex-direction:row}}

.report-side{
  padding:20px;
  border-bottom:1px solid var(--b);
}
@media(min-width:640px){
  .report-side{
    width:240px;flex-shrink:0;
    border-bottom:0;border-right:1px solid var(--b);
  }
}

.r-ticker{font-family:var(--fm);font-size:26px;font-weight:700;margin-bottom:2px}
.r-co{font-size:12px;color:var(--t2);margin-bottom:20px}

.ring-wrap{display:flex;flex-direction:column;align-items:center;margin-bottom:20px}
.ring-svg{width:110px;height:110px}
.ring-lbl{font-family:var(--fm);font-size:10px;color:var(--t2);letter-spacing:.05em;margin-top:6px}

.mini{display:flex;flex-direction:column;gap:0}
.mini-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:8px 0;border-bottom:1px solid var(--b);font-size:12px;
}
.mini-row:last-child{border:0}
.mini-k{color:var(--t1)}
.mini-v{font-family:var(--fm);font-weight:500;font-size:12.5px}
.pos{color:var(--cg)}.neg{color:var(--cr)}.neu{color:var(--c)}

.report-main{padding:20px;flex:1}

.sig-head{display:flex;align-items:center;gap:9px;margin-bottom:16px;flex-wrap:wrap}
.sig-badge{
  padding:4px 11px;border-radius:4px;
  font-family:var(--fm);font-size:10.5px;font-weight:700;
  letter-spacing:.07em;text-transform:uppercase;
}
.bullish{
  background:rgba(0,229,160,.1);color:var(--cg);
  border:1px solid rgba(0,229,160,.22);
}
.sig-disc{font-size:10.5px;color:var(--t2);font-style:italic}

/* Mini chart bars */
.chart-mini{
  background:var(--bg1);border:1px solid var(--b);
  border-radius:var(--r2);height:120px;
  display:flex;align-items:flex-end;
  padding:10px 10px 0;gap:3px;
  margin-bottom:16px;overflow:hidden;
}
.bar{flex:1;border-radius:2px 2px 0 0;min-height:8px}
.bup{background:rgba(0,229,160,.28);border-top:1px solid rgba(0,229,160,.5)}
.bdn{background:rgba(255,77,106,.2);border-top:1px solid rgba(255,77,106,.4)}

.ins-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.ins{
  background:var(--bg1);border:1px solid var(--b);
  border-radius:var(--r2);padding:12px;
}
.ins-lbl{font-family:var(--fm);font-size:9.5px;color:var(--t2);letter-spacing:.07em;text-transform:uppercase;margin-bottom:5px}
.ins-val{font-size:13px;font-weight:600}

/* Blur CTA */
.report-cta{
  position:absolute;bottom:0;left:0;right:0;
  height:180px;
  /* gradient doesn't trigger repaint — it's a bg layer */
  background:linear-gradient(to bottom,transparent,var(--bg2) 68%);
  display:flex;align-items:flex-end;justify-content:center;
  padding:24px;
}
.unlock{
  background:var(--c);color:#03060E;
  border-radius:var(--r2);padding:13px 28px;
  font-size:14px;font-weight:700;
  display:flex;align-items:center;gap:7px;
  transition:box-shadow .25s;min-height:48px;
}
.unlock:hover{box-shadow:0 6px 24px rgba(0,212,255,.3)}
.unlock svg{flex-shrink:0}

/* ─────────────────────────────────────────
   STATS BAND
───────────────────────────────────────── */
.stats-band{
  display:grid;gap:1px;
  background:var(--b);
  border:1px solid var(--b);
  border-radius:var(--r);overflow:hidden;
  grid-template-columns:repeat(2,1fr);
}
@media(min-width:640px){.stats-band{grid-template-columns:repeat(4,1fr)}}
.s-cell{
  background:var(--bg2);padding:28px 20px;text-align:center;
}
.s-num{
  display:block;font-family:var(--fm);
  font-size:clamp(28px,4vw,36px);font-weight:700;
  color:var(--t0);letter-spacing:-.03em;line-height:1;
}
.s-unit{color:var(--c);font-size:clamp(18px,2.5vw,24px)}
.s-lbl{display:block;font-size:12px;color:var(--t2);margin-top:6px}

/* ─────────────────────────────────────────
   RISK SECTION
───────────────────────────────────────── */
.risk-sec{
  background:rgba(245,158,11,.03);
  border-top:1px solid rgba(245,158,11,.1);
  border-bottom:1px solid rgba(245,158,11,.1);
}
.risk-h{display:flex;align-items:center;gap:11px;margin-bottom:24px}
.risk-title{font-size:clamp(17px,2.5vw,22px);font-weight:600;color:var(--ca);letter-spacing:-.01em}

.risk-points{
  display:grid;gap:14px;
  grid-template-columns:1fr;
}
@media(min-width:640px){.risk-points{grid-template-columns:1fr 1fr}}
.rp{
  display:flex;gap:10px;
  font-size:13.5px;color:rgba(245,158,11,.65);line-height:1.6;
}
.rp::before{content:'—';color:rgba(245,158,11,.35);flex-shrink:0}

.fine-print{
  margin-top:24px;font-family:var(--fm);font-size:11px;
  color:var(--t2);line-height:1.7;padding:14px 16px;
  border:1px solid var(--b);border-radius:var(--r2);
}

/* ─────────────────────────────────────────
   CTA SECTION
───────────────────────────────────────── */
.cta-sec{text-align:center}
.cta-inner{max-width:580px;margin:0 auto}
.cta-inner h2{margin-bottom:14px}
.cta-inner p{color:var(--t1);margin-bottom:36px;font-size:clamp(14px,2vw,17px)}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.btn-pri{
  background:var(--c);color:#03060E;
  border-radius:var(--r2);padding:14px 32px;
  font-size:15px;font-weight:700;min-height:52px;
  transition:box-shadow .25s;
}
.btn-pri:hover{box-shadow:0 6px 24px rgba(0,212,255,.3)}
.btn-sec{
  background:transparent;color:var(--t1);
  border:1px solid var(--b);border-radius:var(--r2);
  padding:14px 32px;font-size:15px;min-height:52px;
  transition:border-color .25s,color .25s;
}
.btn-sec:hover{border-color:var(--t2);color:var(--t0)}
.cta-small{margin-top:18px;font-family:var(--fm);font-size:11px;color:var(--t2)}

/* ─────────────────────────────────────────
   FOOTER
───────────────────────────────────────── */
footer{
  border-top:1px solid var(--b);
  padding:40px 0;
}
.foot-in{
  display:flex;flex-direction:column;gap:16px;align-items:flex-start;
}
@media(min-width:640px){
  .foot-in{flex-direction:row;align-items:center;justify-content:space-between}
}
.foot-legal{font-size:11px;color:var(--t2);line-height:1.65;max-width:580px}

/* ─────────────────────────────────────────
   REDUCED MOTION
   Respect user OS preference — critical
   for accessibility and iOS battery
───────────────────────────────────────── */
@media(prefers-reduced-motion:reduce){
  *{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
  }
  .reveal{opacity:1;transform:none}
}

/* ─────────────────────────────────────────
   FOCUS-VISIBLE — keyboard accessibility
───────────────────────────────────────── */
:focus-visible{
  outline:2px solid var(--c);
  outline-offset:3px;
  border-radius:4px;
}

/* Backend handoff modal */
.backend-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  background: rgba(3, 6, 14, 0.68);
  backdrop-filter: blur(14px);
}
.backend-modal.on { display: flex; }
.backend-modal-card {
  width: min(420px, 100%);
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 18px;
  background: #090d18;
  box-shadow: 0 30px 90px rgba(0, 0, 0, 0.38);
  padding: 24px;
  color: #fff;
}
.backend-modal-card h3 {
  margin: 0 0 10px;
  font-size: 20px;
  letter-spacing: -0.02em;
}
.backend-modal-card p {
  margin: 0;
  color: rgba(255, 255, 255, 0.68);
  line-height: 1.6;
  font-size: 14px;
}
.backend-modal-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 22px;
}
.backend-modal-actions button {
  min-height: 46px;
  border-radius: 999px;
  font-weight: 800;
}
.backend-modal-cancel {
  border: 1px solid rgba(255, 255, 255, 0.16);
  color: rgba(255, 255, 255, 0.78);
}
.backend-modal-confirm {
  background: var(--c);
  color: #03060e;
}
