:root{
  --bg:#071A2D;
  --bg2:#0b2746;
  --card:rgba(255,255,255,.06);
  --stroke:rgba(255,255,255,.12);
  --text:#EAF2FF;
  --muted:rgba(234,242,255,.74);
  --blue:#1d4ed8;
  --gold:#f5c542;
  --shadow: 0 24px 90px rgba(0,0,0,.28);
  --font-head: "Space Grotesk", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --font-serif: "Fraunces", ui-serif, Georgia, serif;
  --font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
}

*{ box-sizing:border-box }
html,body{ height:100% }
body{
  margin:0;
  color:var(--text);
  background: radial-gradient(1200px 900px at 30% 10%, rgba(29,78,216,.22), transparent 55%),
              radial-gradient(1100px 900px at 75% 20%, rgba(245,197,66,.16), transparent 55%),
              radial-gradient(900px 900px at 60% 90%, rgba(29,78,216,.12), transparent 60%),
              linear-gradient(180deg, var(--bg), #051427);
  font-family:var(--font-head);
  overflow-x:hidden;
}

a{ color:inherit; text-decoration:none }
.wrap{ width:min(1160px, 92vw); margin:0 auto; position:relative; padding: 30px 0 70px; }

.mono{ font-family:var(--font-mono); letter-spacing:-.01em; }
.subtle{ opacity:.72; }

.bg-grid{
  position:fixed; inset:0;
  background:
    linear-gradient(to right, rgba(255,255,255,.045) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.045) 1px, transparent 1px);
  background-size: 70px 70px;
  mask-image: radial-gradient(circle at 40% 10%, black 0, black 35%, transparent 70%);
  pointer-events:none;
  opacity:.6;
  z-index:0;
}

.bg-orb{
  position:fixed;
  width: 520px; height:520px;
  border-radius:50%;
  filter: blur(44px);
  opacity:.45;
  pointer-events:none;
  z-index:0;
  mix-blend-mode: screen;
}
.orb-a{ left:-160px; top:120px; background: radial-gradient(circle at 30% 30%, rgba(29,78,216,.9), rgba(29,78,216,.0) 60%); }
.orb-b{ right:-200px; top:40px; background: radial-gradient(circle at 30% 30%, rgba(245,197,66,.85), rgba(245,197,66,.0) 58%); }

#constellation{
  position:fixed; inset:0;
  z-index:0;
  pointer-events:none;
  opacity:.65;
}

/* Header */
.topbar{
  position: sticky;
  top: 14px;
  z-index: 50;
  width:min(1160px, 92vw);
  margin: 0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
  padding: 12px 14px;
  border-radius: 999px;
  background: rgba(7,26,45,.62);
  border: 1px solid rgba(255,255,255,.14);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 18px 70px rgba(0,0,0,.22);
}

.brand{ display:flex; align-items:center; gap: 12px; min-width: 240px; }
.brand-mark{
  width: 34px; height:34px;
  border-radius: 12px;
  background:
    radial-gradient(circle at 30% 30%, rgba(245,197,66,.95), rgba(245,197,66,.0) 60%),
    radial-gradient(circle at 70% 70%, rgba(29,78,216,.95), rgba(29,78,216,.0) 62%),
    rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 18px 60px rgba(0,0,0,.18);
}
.brand-name{ font-weight:900; letter-spacing:.06em; font-size: 12px; }
.brand-tag{ font-size: 11px; opacity:.72; margin-top: 2px; }

.nav{ display:flex; gap: 10px; align-items:center; }
.navlink{
  font-size: 12px;
  opacity:.86;
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid transparent;
}
.navlink:hover{ border-color: rgba(255,255,255,.14); background: rgba(255,255,255,.04); opacity:1; }

.topbar-cta{ display:flex; gap: 10px; align-items:center; }

.btn{
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: var(--text);
  border-radius: 999px;
  padding: 11px 14px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing:.01em;
  cursor:pointer;
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
}
.btn:hover{ transform: translateY(-1px); background: rgba(255,255,255,.09); border-color: rgba(255,255,255,.22); }
.btn:active{ transform: translateY(0px) scale(.99); }

.btn-primary{
  background: linear-gradient(135deg, rgba(29,78,216,.95), rgba(29,78,216,.72));
  border-color: rgba(29,78,216,.65);
  box-shadow: 0 22px 70px rgba(29,78,216,.22);
}
.btn-primary:hover{
  background: linear-gradient(135deg, rgba(29,78,216,1), rgba(29,78,216,.78));
}
.btn-ghost{
  background: rgba(255,255,255,.04);
}
.btn-block{ width:100%; }

/* Side rail */
.rail{
  position: fixed;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  display:flex;
  flex-direction:column;
  gap: 10px;
  z-index: 40;
}
.rail-dot{
  width: 12px; height: 12px;
  border-radius: 50%;
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.18);
  position: relative;
}
.rail-dot:hover{ background: rgba(245,197,66,.8); border-color: rgba(245,197,66,.9); }
.rail-dot::after{
  content: attr(data-tip);
  position:absolute;
  left: 18px;
  top: 50%;
  transform: translateY(-50%);
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(7,26,45,.75);
  border: 1px solid rgba(255,255,255,.14);
  font-size: 11px;
  white-space: nowrap;
  opacity:0;
  pointer-events:none;
  transition: opacity .18s ease;
}
.rail-dot:hover::after{ opacity: 1; }

/* Hero */
.hero{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 22px;
  align-items: stretch;
  position: relative;
  z-index: 1;
  padding-top: 26px;
}
.kicker{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  font-size: 12px;
  opacity:.9;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
}
.k-dot{ width: 8px; height: 8px; border-radius: 50%; background: var(--gold); box-shadow: 0 0 0 4px rgba(245,197,66,.16); }

.hero h1{
  font-family: var(--font-serif);
  font-weight: 700;
  letter-spacing: -0.03em;
  margin: 14px 0 10px;
  font-size: clamp(40px, 5.1vw, 64px);
  line-height: 1.02;
}
.accent{
  background: linear-gradient(135deg, rgba(245,197,66,1), rgba(29,78,216,1));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.sub{
  font-size: 15px;
  opacity: .86;
  max-width: 54ch;
  line-height: 1.6;
}
.sub .strong{ font-weight: 900; opacity: 1; }

.hero-actions{ display:flex; gap: 12px; margin-top: 16px; flex-wrap: wrap; }

.signal-row{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-top: 18px;
}
.signal{
  border-radius: 18px;
  padding: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
}
.sig-top{ font-weight: 900; letter-spacing: -0.01em; }
.sig-sub{ font-size: 12px; opacity:.74; margin-top: 4px; }

.hero-right{
  position: relative;
  border-radius: 28px;
  border: 1px solid rgba(255,255,255,.10);
  background:
    radial-gradient(1200px 900px at 40% 0%, rgba(29,78,216,.26), transparent 55%),
    radial-gradient(900px 800px at 70% 15%, rgba(245,197,66,.20), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  overflow:hidden;
  box-shadow: var(--shadow);
}
.hero-bg{
  position:absolute; inset:0;
  background-image: url("../img/hero-bg.png");
  background-size: cover;
  background-position: center;
  opacity:.32;
  transform: scale(1.06);
  filter: saturate(1.02) contrast(1.02);
  mask-image: radial-gradient(circle at 60% 35%, black 0, black 55%, transparent 78%);
}
.glass-stack{ position:relative; padding: 18px; z-index: 2; display:flex; flex-direction:column; gap: 12px; height:100%; justify-content:center; }

.glass-card{
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(7,26,45,.55);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: 0 18px 70px rgba(0,0,0,.22);
}
.gc-main{ padding: 14px; }
.gc-head{ display:flex; justify-content:space-between; align-items:center; gap: 10px; }
.gc-title{ font-weight: 950; letter-spacing: -0.02em; }
.gc-chip{
  font-size: 11px;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.05);
  opacity:.9;
}

.gc-grid{ display:grid; grid-template-columns: repeat(2, 1fr); gap: 10px; margin-top: 12px; }
.gc-block{
  border-radius: 16px;
  padding: 10px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
}
.gc-label{ font-size: 11px; opacity:.78; }
.gc-value{ font-weight: 900; margin-top: 4px; letter-spacing: -0.01em; }

.gc-meter{ margin-top: 12px; }
.meter-top{ display:flex; justify-content:space-between; align-items:center; opacity:.9; }
.meter-bar{ height: 10px; border-radius: 999px; border: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.04); overflow:hidden; margin-top: 8px; }
.meter-fill{
  display:block; height:100%;
  background: linear-gradient(90deg, rgba(245,197,66,1), rgba(29,78,216,1));
  border-radius: 999px;
  box-shadow: 0 0 0 1px rgba(255,255,255,.12) inset;
}
.meter-sub{ font-size: 11px; opacity:.72; margin-top: 8px; }

.gc-mini{ padding: 12px; }
.mini-title{ font-weight: 950; opacity:.92; }
.pill-row{ display:flex; flex-wrap:wrap; gap: 8px; margin-top: 10px; }
.pill{
  font-size: 11px;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  opacity:.92;
}

/* Marquee */
.marquee{
  margin-top: 18px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  overflow:hidden;
  position: relative;
  z-index: 1;
}
.marquee-track{
  display:flex;
  gap: 22px;
  padding: 12px 18px;
  white-space: nowrap;
  animation: scroll 22s linear infinite;
}
.marquee span{
  font-size: 12px;
  opacity:.84;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(7,26,45,.35);
}
@keyframes scroll{
  from{ transform: translateX(0); }
  to{ transform: translateX(-50%); }
}

/* Sections */
.section{
  position: relative;
  z-index: 1;
  margin-top: 46px;
  padding: 26px;
  border-radius: 28px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  overflow:hidden;
}
.section-head h2{
  font-family: var(--font-serif);
  font-size: clamp(28px, 3.3vw, 44px);
  letter-spacing: -0.03em;
  margin: 10px 0 8px;
}
.lead{ opacity:.86; line-height:1.6; max-width: 80ch; }

.diag{
  background:
    linear-gradient(135deg, rgba(29,78,216,.14), transparent 55%),
    linear-gradient(315deg, rgba(245,197,66,.12), transparent 55%),
    rgba(255,255,255,.03);
}
.diag::before{
  content:"";
  position:absolute; inset:-1px;
  background: linear-gradient(120deg, rgba(255,255,255,.06), transparent 30%);
  clip-path: polygon(0 0, 100% 0, 60% 100%, 0 100%);
  opacity:.55;
  pointer-events:none;
}

/* Tiles */
.tiles{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-top: 16px;
}
.tile{
  text-align:left;
  border-radius: 22px;
  padding: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(7,26,45,.46);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  cursor:pointer;
  transition: transform .2s ease, background .2s ease, border-color .2s ease;
}
.tile:hover{ transform: translateY(-2px); background: rgba(7,26,45,.58); border-color: rgba(255,255,255,.20); }
.tile-ic{ font-size: 20px; }
.tile-title{ display:block; font-weight: 950; margin-top: 10px; letter-spacing: -0.02em; }
.tile-sub{ display:block; margin-top: 6px; opacity:.78; font-size: 12px; }
.tile-foot{ display:inline-block; margin-top: 12px; opacity:.78; }

/* Blueprint layout */
.blueprint{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 18px;
  background:
    radial-gradient(900px 700px at 20% 0%, rgba(29,78,216,.20), transparent 60%),
    radial-gradient(900px 700px at 70% 20%, rgba(245,197,66,.14), transparent 60%),
    rgba(255,255,255,.03);
}
.quote{
  display:flex;
  gap: 12px;
  margin-top: 14px;
  padding: 14px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(7,26,45,.44);
}
.quote-mark{
  width: 34px; height:34px;
  border-radius: 12px;
  display:grid; place-items:center;
  background: rgba(245,197,66,.16);
  border: 1px solid rgba(245,197,66,.35);
  color: var(--gold);
  font-weight: 900;
}
.qt-strong{ font-weight: 950; }
.qt-sub{ opacity:.84; margin-top: 2px; }
.bp-cta{ display:flex; gap: 12px; margin-top: 14px; flex-wrap:wrap; }

.bp-stack{ display:flex; flex-direction:column; gap: 12px; height:100%; justify-content:center; }
.bp-card{
  border-radius: 22px;
  padding: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(7,26,45,.52);
  backdrop-filter: blur(12px);
}
.bp-title{ font-weight: 950; letter-spacing:-.02em; }
.bp-card ul{ margin: 10px 0 0 18px; opacity:.9; }
.bp-card p{ opacity:.84; margin-top: 8px; }
.bp-tags{ display:flex; flex-wrap:wrap; gap: 8px; margin-top: 10px; }
.bp-tags span{
  font-size: 11px;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
}
.bp-card-emph{
  border-color: rgba(245,197,66,.28);
  box-shadow: 0 22px 80px rgba(245,197,66,.10);
}
.bp-big{ font-weight: 950; letter-spacing:-.02em; font-size: 18px; line-height: 1.2; }
.bp-note{ opacity:.8; margin-top: 10px; }

/* Control timeline */
.timeline{
  margin-top: 18px;
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
.tl-step{
  border-radius: 22px;
  padding: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(7,26,45,.44);
  position: relative;
  overflow:hidden;
}
.tl-step::before{
  content:"";
  position:absolute; inset:-1px;
  background: linear-gradient(135deg, rgba(245,197,66,.10), transparent 55%);
  opacity:.6;
}
.tl-step > *{ position:relative; z-index:2; }
.tl-num{
  font-family: var(--font-mono);
  font-weight: 700;
  opacity:.86;
}
.tl-title{ font-weight: 950; margin-top: 10px; letter-spacing:-.02em; }
.tl-sub{ opacity:.82; margin-top: 6px; font-size: 12px; line-height: 1.5; }

/* Pricing */
.pricing{
  background:
    radial-gradient(900px 700px at 30% 10%, rgba(29,78,216,.18), transparent 58%),
    radial-gradient(900px 700px at 75% 20%, rgba(245,197,66,.14), transparent 60%),
    rgba(255,255,255,.03);
}
.price-card{
  margin-top: 18px;
  border-radius: 28px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(7,26,45,.55);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  padding: 18px;
  box-shadow: var(--shadow);
}
.pc-top{ display:flex; justify-content:space-between; align-items:flex-end; gap: 12px; flex-wrap:wrap; }
.pc-name{ font-weight: 950; letter-spacing:-.02em; font-size: 18px; }
.pc-sub{ opacity:.8; margin-top: 4px; }
.pc-amount{
  font-family: var(--font-serif);
  font-weight: 700;
  letter-spacing: -0.03em;
  font-size: 40px;
}
.pc-term{ opacity:.72; margin-top: 2px; }

.pc-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-top: 16px;
}
.pc-col{
  border-radius: 22px;
  padding: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
}
.pc-h{ font-weight: 950; letter-spacing:-.02em; }
.pc-col ul{ margin: 10px 0 0 18px; opacity:.9; }
.pc-col p{ opacity:.86; line-height:1.6; margin-top: 10px; }

.pc-bottom{ display:flex; gap: 12px; margin-top: 14px; flex-wrap:wrap; }

/* Footer */
.footer{
  padding: 26px;
  background: rgba(7,26,45,.55);
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr 1fr;
  gap: 14px;
}
.footer-title{ font-weight: 950; letter-spacing:.04em; }
.footer-sub{ opacity:.78; margin-top: 6px; line-height:1.6; }
.footer-chip{
  margin-top: 12px;
  display:inline-flex;
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
}
.footer-h{ font-weight: 950; margin-bottom: 8px; }
.footer-links{ display:flex; flex-direction:column; gap: 8px; opacity:.86; }
.footer-links a:hover{ opacity:1; text-decoration: underline; }
.legal-row{ display:flex; gap: 10px; flex-wrap:wrap; margin-top: 14px; opacity:.78; }
.legal-row a:hover{ opacity:1; text-decoration: underline; }
.copyright{ margin-top: 18px; opacity:.66; text-align:center; }

/* Modal */
.modal{ position: fixed; inset:0; display:none; z-index: 80; }
.modal[aria-hidden="false"]{ display:block; }
.modal-backdrop{ position:absolute; inset:0; background: rgba(0,0,0,.55); }
.modal-panel{
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  width: min(720px, 92vw);
  border-radius: 26px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(7,26,45,.70);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: 0 28px 120px rgba(0,0,0,.42);
  overflow:hidden;
}
.modal-top{
  display:flex; justify-content:space-between; align-items:center;
  padding: 14px 16px;
  border-bottom: 1px solid rgba(255,255,255,.10);
}
.modal-title{ font-weight: 950; letter-spacing:-.02em; }
.icon-btn{
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  border-radius: 14px;
  width: 36px; height:36px;
  cursor:pointer;
}
.modal-body{ padding: 14px 16px; opacity:.92; line-height:1.7; }
.modal-actions{ padding: 14px 16px; display:flex; gap: 10px; flex-wrap:wrap; border-top: 1px solid rgba(255,255,255,.10); }

/* FAQ inside modal */
.faq summary{
  cursor:pointer;
  font-weight: 900;
  padding: 10px 0;
}
.faq p{ opacity:.86; margin: 0 0 10px; }

/* Mini grid in modal */
.mini-grid{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-top: 12px; }
.mini-card{ border-radius: 18px; padding: 12px; border: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.04); }
.mini-h{ font-weight: 950; letter-spacing:-.02em; }
.mini-s{ opacity:.8; margin-top: 6px; font-size: 12px; }

/* Legal pages */
body.legal{ background: linear-gradient(180deg, var(--bg), #041021); }
.legal-top{
  width:min(980px, 92vw);
  margin: 16px auto 0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
}
.legal-wrap{
  width:min(980px, 92vw);
  margin: 16px auto 44px;
  padding: 22px;
  border-radius: 26px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
}
.legal-wrap h1{ font-family: var(--font-serif); letter-spacing:-.03em; }

/* Responsive */
@media (max-width: 980px){
  .rail{ display:none; }
  .hero{ grid-template-columns: 1fr; }
  .tiles{ grid-template-columns: 1fr 1fr; }
  .blueprint{ grid-template-columns: 1fr; }
  .timeline{ grid-template-columns: 1fr 1fr; }
  .footer-grid{ grid-template-columns: 1fr; }
  .pc-grid{ grid-template-columns: 1fr; }
  .nav{ display:none; }
  .brand{ min-width: 0; }
}
@media (max-width: 560px){
  .tiles{ grid-template-columns: 1fr; }
  .timeline{ grid-template-columns: 1fr; }
  .mini-grid{ grid-template-columns: 1fr; }
}


/* =========================
   Rail "warp" transition
   Clean/corporate but cinematic
   ========================= */
.nav-warp{
  position: fixed;
  inset: 0;
  z-index: 9999;
  pointer-events: none;
  opacity: 0;
  transform: scale(1.02);
  background:
    radial-gradient(900px 600px at 20% 30%, rgba(245,197,66,.18), transparent 60%),
    radial-gradient(900px 600px at 80% 70%, rgba(29,78,216,.16), transparent 62%),
    linear-gradient(180deg, rgba(7,26,45,.86), rgba(7,26,45,.92));
  backdrop-filter: blur(10px) saturate(120%);
}

.nav-warp__grid{
  position:absolute; inset:-2px;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(closest-side, rgba(0,0,0,.95), transparent 78%);
  opacity: .55;
  transform: translateZ(0);
}

.nav-warp__beam{
  position:absolute; inset:-40% -40%;
  background: linear-gradient(90deg, transparent, rgba(245,197,66,.18), rgba(255,255,255,.10), rgba(29,78,216,.14), transparent);
  transform: rotate(12deg) translateX(-30%);
  filter: blur(2px);
  opacity: .0;
}

.nav-warp__ring{
  position:absolute; left:50%; top:50%;
  width: 18vmax; height: 18vmax;
  transform: translate(-50%,-50%) scale(.85);
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.10);
  box-shadow:
    0 0 0 1px rgba(245,197,66,.08) inset,
    0 0 48px rgba(29,78,216,.18),
    0 0 120px rgba(245,197,66,.12);
  opacity: 0;
}

.nav-warp__label{
  position:absolute; left: 50%; top: 64%;
  transform: translateX(-50%);
  font-family: var(--font-mono);
  letter-spacing: .18em;
  text-transform: uppercase;
  font-size: 12px;
  color: rgba(255,255,255,.74);
  opacity: 0;
}

.nav-warp.is-on{
  animation: warpIn .46s cubic-bezier(.2,.8,.2,1) forwards;
}
.nav-warp.is-off{
  animation: warpOut .52s cubic-bezier(.2,.8,.2,1) forwards;
}

.nav-warp.is-on .nav-warp__beam{
  animation: beamSweep .62s cubic-bezier(.2,.8,.2,1) forwards;
}
.nav-warp.is-on .nav-warp__ring{
  animation: ringPulse .62s cubic-bezier(.2,.8,.2,1) forwards;
}
.nav-warp.is-on .nav-warp__label{
  animation: labelPop .62s cubic-bezier(.2,.8,.2,1) forwards;
}

@keyframes warpIn{
  from{ opacity:0; transform: scale(1.04); }
  to  { opacity:1; transform: scale(1.00); }
}
@keyframes warpOut{
  0%{ opacity:1; transform: scale(1.00); }
  70%{ opacity:.9; }
  100%{ opacity:0; transform: scale(.995); }
}
@keyframes beamSweep{
  0%{ opacity:0; transform: rotate(12deg) translateX(-34%); }
  18%{ opacity:.9; }
  100%{ opacity:0; transform: rotate(12deg) translateX(34%); }
}
@keyframes ringPulse{
  0%{ opacity:0; transform: translate(-50%,-50%) scale(.72); }
  38%{ opacity:1; }
  100%{ opacity:0; transform: translate(-50%,-50%) scale(1.22); }
}
@keyframes labelPop{
  0%{ opacity:0; transform: translateX(-50%) translateY(6px); }
  35%{ opacity:1; }
  100%{ opacity:0; transform: translateX(-50%) translateY(-6px); }
}

/* Subtle hover upgrade for the rail dots */
.rail-dot{
  transition: transform .18s ease, box-shadow .18s ease, opacity .18s ease;
}
.rail-dot:hover{
  transform: scale(1.12);
  box-shadow: 0 0 0 6px rgba(245,197,66,.10);
}


/* Footer stack (enterprise) */
.site-footer{padding:56px 0;background:rgba(7,26,45,.92);border-top:1px solid rgba(255,255,255,.06)}
.footer-inner{max-width:1120px;margin:0 auto;padding:0 20px}
.footer-brand{margin-bottom:22px}
.footer-title{font-family:var(--font-sans);font-weight:700;letter-spacing:.02em;color:#fff}
.footer-sub{opacity:.76;margin-top:6px}
.footer-cols{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:26px;margin:18px 0 10px}
.footer-head{font-weight:700;color:rgba(255,255,255,.88);margin-bottom:10px}
.footer-link{display:block;color:rgba(255,255,255,.70);text-decoration:none;padding:6px 0}
.footer-link:hover{color:#fff}
.footer-small{margin-top:18px;color:rgba(255,255,255,.55);font-size:13px}

/* Pricing single */
.pricing-single{display:flex;justify-content:center}
.pricing-card{max-width:720px;width:100%;padding:28px;border:1px solid rgba(255,255,255,.10);border-radius:18px;background:rgba(255,255,255,.04);box-shadow:0 18px 60px rgba(0,0,0,.35)}
.pricing-kicker{opacity:.85;margin-bottom:10px}
.pricing-price{font-size:44px;font-weight:800;letter-spacing:-.02em}
.pricing-unit{font-size:16px;opacity:.8;margin-left:6px}
.pricing-list{margin:14px 0 16px}
.pricing-list li{margin:8px 0}
.pricing-notes{opacity:.82;margin:10px 0 18px}
.faq details{border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:14px 16px;background:rgba(255,255,255,.03);margin:10px 0}
.faq summary{cursor:pointer;font-weight:700}
.proof-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.proof-card{padding:22px;border-radius:16px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03)}
.steps{counter-reset:step;list-style:none;padding-left:0}
.steps li{margin:14px 0;padding:18px;border-radius:16px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03)}
.steps h2{margin:0 0 6px}
.cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
@media (max-width: 820px){
  .footer-cols{grid-template-columns:1fr;gap:18px}
  .proof-grid{grid-template-columns:1fr}
}


/* ================================
   Ultra Elite Motion + Design Layer
   (corporate, clean, no color changes)
   ================================ */

.fx-canvas{
  position:fixed;
  inset:0;
  width:100%;
  height:100%;
  z-index:-2;
  pointer-events:none;
}

.fx-noise{
  position:fixed;
  inset:0;
  z-index:-1;
  pointer-events:none;
  opacity:.10;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='320' height='320'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='320' height='320' filter='url(%23n)' opacity='.45'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}

.fx-spotlight{
  position:fixed;
  inset:-20%;
  z-index:-1;
  pointer-events:none;
  background: radial-gradient(420px 420px at var(--mx, 50%) var(--my, 20%), rgba(29,78,216,.22), transparent 60%),
              radial-gradient(520px 520px at calc(var(--mx, 50%) + 12%) calc(var(--my, 20%) + 6%), rgba(245,197,66,.16), transparent 65%);
  filter: blur(16px);
  opacity:.9;
  transition: opacity .3s ease;
}

.top-progress{
  position:fixed;
  top:0; left:0;
  width:100%;
  height:3px;
  z-index:9999;
  background: rgba(255,255,255,.05);
  backdrop-filter: blur(10px);
}
.top-progress__bar{
  display:block;
  height:100%;
  width:0%;
  background: linear-gradient(90deg, rgba(245,197,66,.95), rgba(29,78,216,.95));
  box-shadow: 0 0 18px rgba(245,197,66,.25);
}

/* Nav upgrade */
.header{
  position:sticky;
  top:0;
  z-index:1000;
}
.navlink--book{
  padding:.66rem 1rem !important;
  border-radius:999px;
  border:1px solid rgba(245,197,66,.55);
  background: linear-gradient(180deg, rgba(245,197,66,.92), rgba(245,197,66,.74));
  color:#071A2D !important;
  font-weight:800;
  letter-spacing:.01em;
  box-shadow: 0 14px 40px rgba(245,197,66,.22);
  position:relative;
  overflow:hidden;
}
.navlink--book::after{
  content:"";
  position:absolute; inset:-2px;
  background: radial-gradient(240px 140px at 20% 20%, rgba(255,255,255,.55), transparent 55%);
  transform: translateX(-40%);
  opacity:.0;
  transition: opacity .35s ease, transform .55s ease;
}
.navlink--book:hover::after{ opacity:.7; transform: translateX(0%); }

/* Hero background: animated grid + parallax layers */
.hero-bg{
  background-image:
    radial-gradient(900px 600px at 25% 10%, rgba(29,78,216,.25), transparent 55%),
    radial-gradient(900px 700px at 80% 18%, rgba(245,197,66,.18), transparent 60%),
    linear-gradient(180deg, rgba(7,26,45,.45), rgba(7,26,45,.86)),
    url("../img/hero-bg.png");
  background-size: cover;
  background-position: center;
}
.hero-bg::before{
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(transparent 0 0),
    repeating-linear-gradient(90deg, rgba(255,255,255,.07) 0 1px, transparent 1px 80px),
    repeating-linear-gradient(0deg, rgba(255,255,255,.06) 0 1px, transparent 1px 72px);
  opacity:.10;
  mask-image: radial-gradient(ellipse at 50% 35%, #000 35%, transparent 70%);
  transform: translate3d(var(--px,0px), var(--py,0px), 0);
  transition: transform .2s ease-out;
}
.hero-bg::after{
  content:"";
  position:absolute; inset:-20%;
  background: conic-gradient(from 210deg at 60% 30%, rgba(29,78,216,.18), rgba(245,197,66,.12), rgba(29,78,216,.10), rgba(245,197,66,.10));
  filter: blur(50px);
  opacity:.35;
  animation: floatGlow 14s ease-in-out infinite;
}
@keyframes floatGlow{
  0%,100%{ transform: translate3d(-2%, -1%, 0) scale(1.02) }
  50%{ transform: translate3d(2%, 1%, 0) scale(1.05) }
}

/* Section dividers: subtle animated line */
.section-divider{
  width:min(1180px, 92vw);
  margin:0 auto;
  height:1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.16), transparent);
  position:relative;
}
.section-divider::after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(90deg, transparent, rgba(245,197,66,.85), transparent);
  transform: translateX(-45%);
  opacity:.0;
  animation: sweep 6s ease-in-out infinite;
}
@keyframes sweep{
  0%{ transform: translateX(-55%); opacity:0 }
  25%{ opacity:.65 }
  50%{ transform: translateX(55%); opacity:0 }
  100%{ opacity:0 }
}

/* Reveal animations */
.reveal{
  opacity:0;
  transform: translateY(18px);
  filter: blur(2px);
  transition: opacity .7s ease, transform .8s cubic-bezier(.2,.8,.2,1), filter .9s ease;
}
.reveal.is-in{
  opacity:1;
  transform: translateY(0);
  filter: blur(0);
}
.reveal[data-reveal="left"]{ transform: translateX(-18px); }
.reveal[data-reveal="right"]{ transform: translateX(18px); }
.reveal[data-reveal="left"].is-in,
.reveal[data-reveal="right"].is-in{ transform: translateX(0); }

/* Premium cards */
.card, .tile, .plan{
  position:relative;
  overflow:hidden;
}
.card::before, .tile::before, .plan::before{
  content:"";
  position:absolute; inset:-2px;
  background: radial-gradient(420px 220px at var(--hx,20%) var(--hy,10%), rgba(245,197,66,.18), transparent 55%),
              radial-gradient(420px 220px at calc(var(--hx,20%) + 30%) calc(var(--hy,10%) + 10%), rgba(29,78,216,.16), transparent 60%);
  opacity:0;
  transition: opacity .35s ease;
  pointer-events:none;
}
.card:hover::before, .tile:hover::before, .plan:hover::before{ opacity:1; }

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  .fx-spotlight{ display:none; }
  .hero-bg::after{ animation:none; }
  .section-divider::after{ animation:none; }
  .reveal{ transition:none; opacity:1; transform:none; filter:none; }
}
