/* =====================================================================
   zapIQ — website styles
   Design language: ZoopMoney deck (navy + royal blue + lavender + white)
   ===================================================================== */

:root{
  --navy:#0B1340;
  --navy-2:#0E1024;
  --blue:#3A4FF0;
  --blue-d:#2C3ED4;
  --lav:#DDDFF5;
  --mid:#7B89F5;
  --white:#FFFFFF;
  --off:#F7F8FF;
  --ink:#0B1340;
  --muted:#5B6280;
  --line:#E7E9F6;
  --line-d:rgba(255,255,255,0.12);

  --shadow-card:0 8px 32px rgba(11,19,64,0.08);
  --shadow-float:0 24px 64px rgba(11,19,64,0.16);

  --display:'Space Grotesk', system-ui, sans-serif;
  --body:'Inter', system-ui, sans-serif;
  --mono:'JetBrains Mono', ui-monospace, monospace;

  --wrap:1200px;
  --r:24px;
  --r-lg:32px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; scroll-padding-top:84px; }
body{
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  background:var(--white);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
em{ font-style:italic; color:var(--blue); }

.wrap{ width:100%; max-width:var(--wrap); margin:0 auto; padding:0 28px; }

/* ===================== TYPOGRAPHY ===================== */
.display{
  font-family:var(--display);
  font-weight:600;
  letter-spacing:-0.025em;
  line-height:1.04;
  margin:0;
}
.h1, h1.display{ font-size:clamp(2.6rem, 6vw, 4.6rem); }
.h2{
  font-family:var(--display);
  font-weight:600;
  letter-spacing:-0.02em;
  line-height:1.08;
  font-size:clamp(2rem, 4.2vw, 3.2rem);
  margin:0;
}
.lede{ font-size:clamp(1.05rem,1.6vw,1.3rem); color:var(--muted); max-width:40ch; }

.eyebrow{
  font-family:var(--mono);
  font-size:12px;
  font-weight:500;
  letter-spacing:0.16em;
  text-transform:uppercase;
  margin:0 0 18px;
}
.eyebrow-blue{ color:var(--blue); }
.eyebrow-lav{ color:var(--lav); }
.mono{ font-family:var(--mono); }

.section-head{ max-width:820px; margin:0 auto 56px; text-align:center; }
.section-head .eyebrow{ margin-bottom:14px; }
.section-sub{ color:var(--muted); font-size:1.1rem; margin:18px auto 0; max-width:62ch; }

/* generic section padding */
section{ padding:clamp(72px,9vw,128px) 0; position:relative; }

/* ===================== BUTTONS ===================== */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:var(--display); font-weight:500; font-size:0.98rem;
  padding:13px 24px; border-radius:999px; border:1.5px solid transparent;
  cursor:pointer; transition:transform .15s ease, background .15s ease, border-color .15s ease, box-shadow .15s ease;
  white-space:nowrap; line-height:1;
}
.btn:active{ transform:translateY(1px); }
.btn-primary{ background:var(--blue); color:#fff; border-color:var(--blue); }
.btn-primary:hover{ background:var(--blue-d); border-color:var(--blue-d); box-shadow:0 8px 24px rgba(58,79,240,0.32); }
.btn-outline{ background:transparent; color:var(--blue); border-color:rgba(58,79,240,0.4); }
.btn-outline:hover{ border-color:var(--blue); background:rgba(58,79,240,0.06); }
.btn-ghost-light{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn-ghost-light:hover{ border-color:var(--ink); }
.btn-lg{ padding:16px 30px; font-size:1.05rem; }
.btn-sm{ padding:9px 15px; font-size:0.82rem; }
.btn-block{ width:100%; }

/* light buttons on navy contexts */
.hero .btn-ghost-light,
.final .btn-ghost-light,
.nav .btn-ghost-light{ color:#fff; border-color:rgba(255,255,255,0.32); }
.hero .btn-ghost-light:hover,
.final .btn-ghost-light:hover,
.nav .btn-ghost-light:hover{ border-color:#fff; background:rgba(255,255,255,0.08); }

/* ===================== LOGO / WORDMARK ===================== */
.brand{ display:inline-flex; align-items:center; gap:10px; }
.zap-mark{ display:inline-flex; }
.wm{ font-family:var(--display); font-weight:700; letter-spacing:-0.04em; font-size:1.5rem; line-height:1; }
.wm-zap{ color:inherit; }
.wm-iq{ color:var(--blue); font-style:italic; }

/* ===================== NAV ===================== */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  background:rgba(11,19,64,0); backdrop-filter:blur(0);
  transition:background .25s ease, box-shadow .25s ease, backdrop-filter .25s ease;
}
.nav-inner{ display:flex; align-items:center; gap:24px; height:72px; }
.nav .brand{ color:#fff; }
.nav .wm-iq{ color:var(--lav); }
.nav-links{ display:flex; gap:26px; margin-left:18px; flex:1; }
.nav-links a{
  font-size:0.95rem; color:rgba(255,255,255,0.78); font-weight:500;
  transition:color .15s ease;
}
.nav-links a:hover{ color:#fff; }
.nav-cta{ display:flex; align-items:center; gap:12px; }
.nav-secondary{ font-size:0.92rem; padding:10px 16px; }

.nav.scrolled{ background:rgba(11,19,64,0.92); backdrop-filter:blur(12px); box-shadow:0 1px 0 var(--line-d); }

.nav-burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; padding:8px; cursor:pointer; }
.nav-burger span{ width:24px; height:2px; background:#fff; border-radius:2px; transition:.2s; }

/* ===================== HERO ===================== */
.hero{
  background:linear-gradient(150deg, #0B1340 0%, #16205A 52%, #243088 100%);
  color:#fff; position:relative;
  padding-top:160px; padding-bottom:96px; overflow:hidden;
}
.hero-grid{
  position:absolute; inset:0;
  background-image:
    radial-gradient(circle at 82% 8%, rgba(58,79,240,0.55), transparent 42%),
    radial-gradient(circle at 96% 60%, rgba(123,137,245,0.30), transparent 40%),
    radial-gradient(circle at 8% 88%, rgba(58,79,240,0.22), transparent 44%);
  pointer-events:none;
}
.hero-inner{
  position:relative; z-index:2;
  display:grid; grid-template-columns:1.05fr 0.95fr; gap:56px; align-items:center;
}
.hero-copy h1{ margin:0 0 22px; max-width:16ch; }
.hero .lede{ color:rgba(255,255,255,0.74); }
.hero-actions{ display:flex; gap:14px; margin:34px 0 26px; flex-wrap:wrap; }
.hero-trustline{ font-size:11px; letter-spacing:0.14em; color:rgba(255,255,255,0.5); }

/* pill stack behind hero card (Zoop cover motif) */
.hero-visual{ position:relative; display:flex; justify-content:center; align-items:center; }
.pillstack{
  position:absolute; inset:-6% -10%; display:grid;
  grid-template-columns:repeat(3, 1fr); gap:14px; opacity:.5;
  transform:rotate(-6deg); pointer-events:none;
}
.pl{ height:46px; border-radius:14px; }
.pl-w{ background:#fff; }
.pl-b{ background:var(--blue); }
.pl-l{ background:var(--lav); }
.pl:nth-child(3n+1){ width:78%; }
.pl:nth-child(3n+2){ width:100%; }
.pl:nth-child(3n){ width:120%; }

/* ===================== INTELLIGENCE CARD (hero) ===================== */
.lens-card{
  position:relative; z-index:2; width:340px; max-width:100%;
  background:#0E1633; border:1px solid rgba(255,255,255,0.10);
  border-radius:22px; padding:22px; box-shadow:var(--shadow-float);
  color:#fff;
}
.lens-top{ display:flex; justify-content:space-between; align-items:center; }
.lens-brand{ font-size:12px; letter-spacing:0.16em; color:var(--lav); }
.lens-int{ font-size:9px; letter-spacing:0.18em; color:rgba(255,255,255,0.55); border:1px solid rgba(255,255,255,0.18); padding:3px 7px; border-radius:999px; }
.lens-id{ display:flex; align-items:center; gap:12px; margin:18px 0 4px; }
.lens-avatar{ width:42px; height:42px; border-radius:50%; background:linear-gradient(135deg,var(--blue),var(--mid)); display:flex; align-items:center; justify-content:center; }
.lens-name{ font-family:var(--display); font-weight:600; font-size:1.1rem; }
.lens-sub{ font-size:10px; color:rgba(255,255,255,0.5); letter-spacing:0.06em; }
.lens-block{ margin-top:18px; }
.lens-label{ font-size:9.5px; letter-spacing:0.16em; color:rgba(255,255,255,0.45); margin-bottom:9px; }
.lens-chips{ display:flex; flex-wrap:wrap; gap:8px; }
.chip{ font-size:12px; padding:6px 11px; border-radius:999px; background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.12); }
.chip-on{ background:var(--blue); border-color:var(--blue); }
.lens-bands{ display:flex; gap:8px; }
.lens-bands span{ flex:1; text-align:center; font-family:var(--mono); font-size:12px; padding:7px 0; border-radius:8px; background:rgba(255,255,255,0.05); color:rgba(255,255,255,0.5); }
.lens-bands span.on{ background:var(--blue); color:#fff; }
.lens-prop{ display:flex; justify-content:space-between; font-size:12px; margin-top:10px; }
.lens-prop b{ font-family:var(--display); }
.lens-bar{ height:5px; border-radius:999px; background:rgba(255,255,255,0.08); margin-top:5px; overflow:hidden; }
.lens-bar i{ display:block; height:100%; background:linear-gradient(90deg,var(--blue),var(--mid)); border-radius:999px; }
.lens-foot{ font-size:9px; letter-spacing:0.14em; color:rgba(255,255,255,0.4); margin-top:18px; text-align:center; }

/* ===================== TRUST STRIP ===================== */
.stats-band{ background:var(--off); padding:64px 0; border-bottom:1px solid var(--line); }
.stats-row{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.stats-row.stats-3{ grid-template-columns:repeat(3,1fr); max-width:880px; margin:0 auto; }
.stat{ text-align:center; }
.stat-num{ font-family:var(--display); font-weight:700; font-size:clamp(2.2rem,3.8vw,3.4rem); letter-spacing:-0.03em; line-height:1; color:var(--navy); }
.stat-num span{ font-size:46%; color:var(--blue); margin-left:2px; }
.stat-label{ font-size:11px; letter-spacing:0.12em; text-transform:uppercase; color:var(--muted); margin-top:12px; }
.compliance-strip{ text-align:center; margin:42px auto 0; font-size:12px; letter-spacing:0.14em; color:var(--muted); }

/* ===================== VALUE-PROP BAND ===================== */
.valueband{ text-align:center; background:#fff; padding-top:clamp(64px,7vw,104px); padding-bottom:clamp(48px,6vw,80px); }
.vb-head{ font-size:clamp(2rem,4.6vw,3.6rem); max-width:20ch; margin:0 auto; }
.vb-sub{ color:var(--muted); font-size:clamp(1.05rem,1.6vw,1.25rem); max-width:60ch; margin:26px auto 0; }

/* ===================== THE PLATFORM / MODULES ===================== */
.platform{ background:var(--off); }
.modules{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.module-card{
  background:#fff; border:1px solid var(--line); border-radius:var(--r); padding:30px;
  box-shadow:var(--shadow-card); display:flex; flex-direction:column;
  transition:transform .15s ease, box-shadow .15s ease;
}
.module-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-float); }
.module-card-accent{ background:var(--lav); border-color:transparent; }
.module-cat{ font-size:11px; letter-spacing:0.12em; text-transform:uppercase; color:var(--blue); margin:0 0 14px; }
.module-title{ font-family:var(--display); font-weight:600; font-size:1.5rem; letter-spacing:-0.01em; color:var(--navy); margin:0 0 8px; }
.module-desc{ color:var(--muted); margin:0 0 20px; font-size:0.98rem; }
.module-card-accent .module-desc{ color:#39406a; }
.ticks{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:11px; }
.ticks li{ position:relative; padding-left:26px; color:var(--navy); font-size:0.95rem; }
.ticks li::before{ content:"›"; position:absolute; left:6px; top:-1px; color:var(--blue); font-weight:700; font-size:1.1rem; }

/* ===================== WORKS WITH YOUR STACK ===================== */
.layer{ background:#fff; }
.stack-flow{ display:grid; grid-template-columns:1fr auto 1.15fr auto 1fr; align-items:center; gap:0; }
.stack-node{ background:var(--lav); border-radius:var(--r); padding:34px 28px; text-align:left; }
.stack-node-hero{ background:var(--blue); color:#fff; transform:scale(1.06); box-shadow:0 18px 48px rgba(58,79,240,0.3); z-index:2; }
.node-label{ font-size:11px; letter-spacing:0.12em; text-transform:uppercase; color:var(--blue); }
.stack-node-hero .node-label{ color:rgba(255,255,255,0.8); }
.node-names{ font-family:var(--display); font-weight:600; font-size:1.5rem; letter-spacing:-0.01em; margin:14px 0 8px; color:var(--navy); }
.stack-node-hero .node-names{ color:#fff; }
.node-sub{ font-size:11px; letter-spacing:0.1em; color:var(--muted); }
.stack-node-hero .node-sub{ color:rgba(255,255,255,0.7); }
.stack-conn{ height:0; border-top:2px dashed rgba(91,98,128,0.4); width:100%; min-width:24px; }

/* ===================== JARVIS SHOWPIECE ===================== */
.jarvis{ background:var(--off); }
.browser{ border-radius:16px; overflow:hidden; box-shadow:var(--shadow-float); background:#fff; border:1px solid var(--line); max-width:1080px; margin:0 auto; }
.browser-chrome{ height:44px; background:#EDEEF7; display:flex; align-items:center; gap:8px; padding:0 16px; border-bottom:1px solid var(--line); }
.browser-chrome span[class^="dot-"]{ width:11px; height:11px; border-radius:50%; }
.dot-r{ background:#FF5F57; } .dot-a{ background:#FEBC2E; } .dot-g{ background:#28C840; }
.url{ flex:1; background:#fff; border-radius:8px; height:26px; display:flex; align-items:center; padding:0 12px; font-size:11px; color:var(--muted); margin:0 12px; max-width:520px; }
.chrome-av{ width:26px; height:26px; border-radius:50%; background:var(--navy); color:#fff; font-size:10px; display:flex; align-items:center; justify-content:center; font-family:var(--display); font-weight:600; }

.jrv{ display:grid; grid-template-columns:200px 1fr; min-height:480px; }
.jrv-side{ background:var(--navy); color:#fff; padding:18px 14px; display:flex; flex-direction:column; }
.jrv-brand{ display:flex; align-items:center; gap:8px; padding:4px 6px 14px; border-bottom:1px solid rgba(255,255,255,0.08); }
.jrv-wm{ font-family:var(--display); font-size:0.85rem; font-weight:700; letter-spacing:-0.02em; }
.jrv-wm .wm-iq{ color:var(--lav); }
.jrv-wm em{ font-weight:400; color:rgba(255,255,255,0.55); font-size:0.78rem; }
.jrv-ws{ margin:14px 0; background:#131A3D; border:1px solid rgba(255,255,255,0.1); border-radius:8px; padding:9px 12px; font-size:0.8rem; color:var(--lav); display:flex; justify-content:space-between; }
.jrv-nav{ display:flex; flex-direction:column; gap:2px; }
.jrv-nav a{ padding:9px 12px; border-radius:8px; font-size:0.86rem; color:rgba(255,255,255,0.66); cursor:pointer; }
.jrv-nav a:hover{ background:rgba(255,255,255,0.06); color:#fff; }
.jrv-nav a.on{ background:var(--blue); color:#fff; font-weight:500; }
.jrv-user{ margin-top:auto; display:flex; align-items:center; gap:10px; padding-top:14px; border-top:1px solid rgba(255,255,255,0.08); }
.jrv-uav{ width:30px; height:30px; border-radius:50%; background:linear-gradient(135deg,var(--blue),var(--mid)); display:flex; align-items:center; justify-content:center; font-size:11px; font-family:var(--display); font-weight:600; }
.jrv-uname{ font-size:0.84rem; font-weight:500; }
.jrv-urole{ font-size:9px; letter-spacing:0.12em; color:rgba(255,255,255,0.45); }

.jrv-main{ padding:24px 28px; background:#fff; }
.jrv-crumb{ font-size:10px; letter-spacing:0.12em; color:var(--muted); }
.jrv-stepper{ display:flex; align-items:center; gap:8px; margin:18px 0 26px; flex-wrap:wrap; }
.jstep{ display:inline-flex; align-items:center; gap:7px; font-size:0.8rem; padding:7px 13px; border-radius:999px; border:1px solid var(--line); color:var(--muted); }
.jstep i{ width:17px; height:17px; border-radius:50%; background:#EAECF7; color:var(--muted); display:flex; align-items:center; justify-content:center; font-size:10px; font-style:normal; font-family:var(--display); font-weight:600; }
.jstep.done{ color:var(--blue); border-color:rgba(58,79,240,0.3); background:rgba(58,79,240,0.05); }
.jstep.done i{ background:var(--blue); color:#fff; }
.jstep.on{ color:var(--navy); border-color:var(--navy); font-weight:600; }
.jstep.on i{ background:var(--navy); color:#fff; }
.jstep-sep{ width:22px; height:0; border-top:1.5px dashed var(--line); }

.jrv-cols{ display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.jrv-panel-label{ font-size:10px; letter-spacing:0.14em; color:var(--muted); }
.jrv-lenses{ background:var(--off); border-radius:14px; padding:18px; }
.jrv-lenses .jrv-panel-label{ margin-bottom:14px; }
.jrv-chip{ background:#fff; border:1px solid rgba(58,79,240,0.25); border-radius:999px; padding:9px 14px; font-size:0.85rem; color:var(--navy); margin-bottom:9px; display:flex; justify-content:space-between; }
.jrv-chip span{ color:var(--muted); cursor:pointer; }
.jrv-add{ border:1.5px dashed rgba(58,79,240,0.4); border-radius:999px; padding:9px 14px; font-size:0.85rem; color:var(--blue); text-align:center; cursor:pointer; }

.jrv-preview{ border:1px solid var(--line); border-radius:14px; padding:20px; box-shadow:var(--shadow-card); }
.jrv-preview-top{ display:flex; justify-content:space-between; align-items:center; }
.jrv-live{ font-size:10px; letter-spacing:0.1em; color:var(--blue); display:flex; align-items:center; gap:5px; }
.jrv-live i{ width:7px; height:7px; border-radius:50%; background:var(--blue); display:inline-block; animation:pulse 1.6s infinite; }
@keyframes pulse{ 0%,100%{ opacity:1;} 50%{ opacity:.3; } }
.jrv-bignum{ font-family:var(--display); font-weight:700; font-size:2.8rem; letter-spacing:-0.03em; color:var(--navy); margin:8px 0 2px; }
.jrv-base{ font-size:0.85rem; color:var(--muted); }
.jrv-tierbar{ display:flex; gap:4px; margin:18px 0 8px; }
.jrv-tierbar span{ height:9px; border-radius:999px; }
.jrv-tierlabels{ display:flex; justify-content:space-between; font-size:9px; letter-spacing:0.04em; color:var(--muted); gap:6px; }
.jrv-kpis{ display:grid; grid-template-columns:1fr 1fr; gap:14px; margin:20px 0; padding:16px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.jrv-kpi-label{ font-size:9.5px; letter-spacing:0.12em; color:var(--muted); }
.jrv-kpi-val{ font-family:var(--display); font-weight:700; font-size:1.5rem; color:var(--navy); margin-top:4px; }
.jrv-actions{ display:flex; flex-wrap:wrap; gap:8px; }
.jarvis-strip{ text-align:center; font-size:12px; letter-spacing:0.14em; color:var(--muted); margin:40px auto 0; }

/* ===================== TESTIMONIALS ===================== */
.pull{ background:#fff; }
.pull-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.pull-card{ background:#fff; border:1px solid var(--line); border-radius:var(--r); padding:32px; box-shadow:var(--shadow-card); display:flex; flex-direction:column; }
.pull-tag{ font-size:10.5px; letter-spacing:0.12em; color:var(--blue); text-transform:uppercase; }
.pull-brand{ font-family:var(--display); font-weight:700; font-size:1.7rem; color:var(--navy); margin:16px 0 18px; letter-spacing:-0.02em; }
.pull-brand span{ font-size:0.9rem; font-weight:400; color:var(--muted); }
.pull-quote{ font-style:italic; color:#2c335c; font-size:1.05rem; line-height:1.5; margin:0 0 22px; }
.pull-use{ font-size:10.5px; letter-spacing:0.1em; color:var(--muted); text-transform:uppercase; margin-top:auto; }

/* ===================== SECURITY ===================== */
.security{ background:var(--off); }
.sec-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.sec-card{ background:#fff; border:1px solid var(--line); border-radius:var(--r); padding:28px; box-shadow:var(--shadow-card); }
.sec-tag{ font-size:10.5px; letter-spacing:0.14em; text-transform:uppercase; color:var(--blue); }
.sec-title{ font-family:var(--display); font-weight:600; font-size:1.2rem; margin:14px 0 10px; color:var(--navy); }
.sec-card p{ font-size:0.95rem; color:var(--muted); margin:0; }

/* ===================== FINAL CTA (NAVY) ===================== */
.final{ background:var(--navy); color:#fff; overflow:hidden; text-align:center; }
.final-grid{
  position:absolute; inset:0;
  background-image:
    radial-gradient(circle at 12% 20%, rgba(58,79,240,0.3), transparent 34%),
    radial-gradient(circle at 88% 78%, rgba(123,137,245,0.16), transparent 38%);
}
.final-inner{ position:relative; z-index:2; max-width:880px; }
.final-head{ font-size:clamp(2.2rem,5vw,3.8rem); margin:0 auto; max-width:18ch; }
.final-lede{ color:rgba(255,255,255,0.78); font-size:1.15rem; max-width:54ch; margin:26px auto 36px; }
.final-actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ===================== FOOTER ===================== */
.footer{ background:var(--navy-2); color:rgba(255,255,255,0.7); padding:72px 0 36px; }
.footer-inner{ display:grid; grid-template-columns:1.4fr 2fr; gap:56px; }
.footer .brand{ color:#fff; }
.footer .wm-iq{ color:var(--lav); }
.footer-tag{ margin:18px 0 8px; max-width:30ch; color:rgba(255,255,255,0.6); }
.footer-loc{ font-size:11px; letter-spacing:0.1em; color:rgba(255,255,255,0.4); }
.footer-cols{ display:grid; grid-template-columns:repeat(3,1fr); gap:32px; }
.footer-h{ font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:rgba(255,255,255,0.45); margin:0 0 16px; }
.footer-col a{ display:block; font-size:0.94rem; color:rgba(255,255,255,0.7); padding:5px 0; cursor:pointer; }
.footer-col a:hover{ color:#fff; }
.footer-base{ display:flex; justify-content:space-between; gap:16px; margin-top:48px; padding-top:24px; border-top:1px solid rgba(255,255,255,0.1); }
.footer-base .mono{ font-size:11px; letter-spacing:0.08em; color:rgba(255,255,255,0.4); }

/* ===================== MODAL ===================== */
.modal{ position:fixed; inset:0; z-index:1000; display:none; }
.modal.open{ display:block; }
.modal-backdrop{ position:absolute; inset:0; background:rgba(7,11,30,0.66); backdrop-filter:blur(4px); }
.modal-card{
  position:relative; z-index:2; width:min(640px, calc(100% - 32px));
  margin:5vh auto; max-height:90vh; overflow-y:auto;
  background:#fff; border-radius:var(--r-lg); padding:40px;
  box-shadow:var(--shadow-float); animation:pop .22s ease;
}
@keyframes pop{ from{ opacity:0; transform:translateY(14px) scale(.98);} to{ opacity:1; transform:none; } }
.modal-x{ position:absolute; top:18px; right:20px; background:none; border:0; font-size:1.8rem; line-height:1; color:var(--muted); cursor:pointer; }
.modal-x:hover{ color:var(--ink); }
.modal-title{ font-family:var(--display); font-weight:600; font-size:1.7rem; letter-spacing:-0.01em; margin:6px 0 10px; color:var(--navy); line-height:1.15; }
.modal-sub{ color:var(--muted); margin:0 0 26px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field{ display:block; margin-bottom:16px; }
.field > span{ display:block; font-size:0.82rem; font-weight:500; color:var(--navy); margin-bottom:7px; }
.field > span i{ color:var(--muted); font-weight:400; font-style:normal; }
.field input, .field select, .field textarea{
  width:100%; font-family:var(--body); font-size:0.95rem; color:var(--ink);
  padding:12px 14px; border:1.5px solid var(--line); border-radius:12px; background:var(--off);
  transition:border-color .15s ease, background .15s ease;
}
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-color:var(--blue); background:#fff; }
.field textarea{ resize:vertical; }
.consent{ display:flex; gap:12px; align-items:flex-start; margin:6px 0 22px; cursor:pointer; }
.consent input{ margin-top:3px; width:17px; height:17px; accent-color:var(--blue); flex:0 0 auto; }
.consent span{ font-size:0.85rem; color:var(--muted); line-height:1.5; }
.form-error{ color:#C2362B; font-size:0.85rem; margin:0 0 14px; }
.modal-foot{ text-align:center; font-size:10px; letter-spacing:0.12em; color:var(--muted); margin:16px 0 0; }
.modal-success{ text-align:center; padding:20px 10px; }
.success-mark{ display:flex; justify-content:center; margin-bottom:18px; }
.modal-success .modal-sub{ max-width:46ch; margin:0 auto 28px; }

/* ===================== REVEAL ANIMATION ===================== */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .6s ease, transform .6s ease; }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; transition:none; } html{ scroll-behavior:auto; } }

/* ===================== RESPONSIVE ===================== */
@media (max-width:1024px){
  .stack-flow{ grid-template-columns:1fr; gap:18px; }
  .stack-flow .stack-conn{ display:none; }
  .stack-node-hero{ transform:none; }
  .modules{ grid-template-columns:repeat(2,1fr); }
  .sec-grid{ grid-template-columns:repeat(2,1fr); }
  .stats-row{ grid-template-columns:repeat(2,1fr); gap:32px 24px; }
}
@media (max-width:860px){
  .nav-links, .nav-secondary{ display:none; }
  .nav-burger{ display:flex; }
  .nav-links.mobile-open{
    display:flex; flex-direction:column; position:absolute; top:72px; left:0; right:0;
    background:rgba(11,19,64,0.98); backdrop-filter:blur(12px); padding:18px 28px 24px; gap:4px;
    border-top:1px solid var(--line-d);
  }
  .nav-links.mobile-open a{ padding:12px 0; font-size:1.05rem; }
  .hero-inner{ grid-template-columns:1fr; gap:48px; }
  .hero-visual{ order:-1; }
  .pull-cards{ grid-template-columns:1fr; }
  .footer-inner{ grid-template-columns:1fr; gap:36px; }
}
@media (max-width:560px){
  body{ font-size:16px; }
  .wrap{ padding:0 20px; }
  .stats-row, .stats-row.stats-3{ grid-template-columns:1fr; gap:28px; }
  .modules{ grid-template-columns:1fr; }
  .sec-grid{ grid-template-columns:1fr; }
  .field-row{ grid-template-columns:1fr; gap:0; }
  .modal-card{ padding:28px 22px; }
  .jrv{ grid-template-columns:1fr; }
  .jrv-side{ flex-direction:row; flex-wrap:wrap; align-items:center; gap:10px; }
  .jrv-nav{ flex-direction:row; flex-wrap:wrap; }
  .jrv-user{ display:none; }
  .jrv-cols{ grid-template-columns:1fr; }
  .footer-cols{ grid-template-columns:1fr 1fr; }
  .footer-base{ flex-direction:column; gap:8px; }
  .hero{ padding-top:120px; }
}
