/* ============================================================
   tradiae.bet — Landing page.
   Self-contained. No build step. Deploy to any static host.
   ============================================================ */

:root{
  --ink:    #06120E;
  --ink-2:  #0B1A14;
  --ink-3:  #112620;
  --bone:   #E8ECE5;
  --bone-2: #B8BFB4;
  --bone-3: #6E7669;
  --lime:   #C8FF3E;
  --lime-2: #98C12E;
  --gold:   #F2B441;
  --live:   #FF3344;
  --line:        rgba(232,236,229,.10);
  --line-strong: rgba(232,236,229,.22);
  --line-lime:   rgba(200,255,62,.34);
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--ink);
  color:var(--bone);
  font-family:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  font-size:16px;line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  letter-spacing:-.005em;
}
body.is-loading{overflow:hidden;height:100vh}

a{color:inherit}
img,svg{display:block;max-width:100%}
ul,ol{margin:0;padding:0;list-style:none}
button{font:inherit;cursor:pointer}

/* atmospheric backdrop */
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:1;
  background:
    radial-gradient(1200px 800px at 12% -6%, rgba(200,255,62,.07), transparent 55%),
    radial-gradient(1000px 700px at 100% 110%, rgba(255,51,68,.04), transparent 55%);
}
body::after{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:2;mix-blend-mode:overlay;opacity:.10;
  background-image:
    repeating-linear-gradient(0deg, rgba(232,236,229,.02) 0 1px, transparent 1px 3px),
    repeating-linear-gradient(90deg, rgba(232,236,229,.02) 0 1px, transparent 1px 3px);
}

#particles{position:fixed;inset:0;width:100vw;height:100vh;pointer-events:none;z-index:3;opacity:.6}

/* =========================================================
   PRELOADER
   ========================================================= */
.preloader{
  position:fixed;inset:0;z-index:10000;
  background:radial-gradient(circle at 50% 50%, #0B1A14, #06120E 70%);
  display:grid;place-items:center;
  overflow:hidden;
  /* CSS-only auto-exit at 2.4s — guarantees the splash always finishes even if JS fails. */
  animation: plAutoExit .6s 2.4s forwards;
}
.preloader.is-done,
.preloader.is-auto-done{
  opacity:0;visibility:hidden;transform:scale(1.04);
  pointer-events:none;
}
@keyframes plAutoExit{
  to{opacity:0;visibility:hidden;transform:scale(1.04);pointer-events:none}
}
/* CSS-only progress arc animation — fills 0% to 100% over 2.2s.
   703.7 = 2π × 112 (the radius used in the SVG). */
@keyframes plArcFill{
  from{stroke-dashoffset:703.7}
  to  {stroke-dashoffset:0}
}
#pl-progress-arc{
  animation: plArcFill 2.2s ease-out forwards;
}
@keyframes plBarFill{
  from{right:100%}
  to  {right:0%}
}
.preloader__bar-fill{
  animation: plBarFill 2.2s ease-out forwards, plBarShimmer 1.4s linear infinite;
}
.preloader__center{
  position:relative;width:min(420px, 92vw);
  display:flex;flex-direction:column;align-items:center;
  text-align:center;
}
.preloader__mark{
  width:280px;height:280px;
  filter:drop-shadow(0 0 24px rgba(200,255,62,.18));
}

/* Spinning rings */
.pl-ring{transform-origin:120px 120px}
.pl-ring--outer{animation:plRingA 8s linear infinite}
.pl-ring--mid  {animation:plRingB 6s linear infinite reverse}
.pl-ring--inner{animation:plRingA 4s linear infinite}
@keyframes plRingA{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes plRingB{from{transform:rotate(0)}to{transform:rotate(360deg)}}

/* Burst rays */
.pl-rays{transform-origin:120px 120px}
.pl-rays > g{transform-origin:120px 120px}
.pl-ray{
  transform-origin:120px 120px;
  animation:plRayBurst 1.6s ease-out infinite;
  opacity:0;
}
.pl-rays > g:nth-child(1)  .pl-ray{animation-delay:.00s}
.pl-rays > g:nth-child(2)  .pl-ray{animation-delay:.05s}
.pl-rays > g:nth-child(3)  .pl-ray{animation-delay:.10s}
.pl-rays > g:nth-child(4)  .pl-ray{animation-delay:.15s}
.pl-rays > g:nth-child(5)  .pl-ray{animation-delay:.20s}
.pl-rays > g:nth-child(6)  .pl-ray{animation-delay:.25s}
.pl-rays > g:nth-child(7)  .pl-ray{animation-delay:.30s}
.pl-rays > g:nth-child(8)  .pl-ray{animation-delay:.35s}
.pl-rays > g:nth-child(9)  .pl-ray{animation-delay:.40s}
.pl-rays > g:nth-child(10) .pl-ray{animation-delay:.45s}
.pl-rays > g:nth-child(11) .pl-ray{animation-delay:.50s}
.pl-rays > g:nth-child(12) .pl-ray{animation-delay:.55s}
@keyframes plRayBurst{
  0%   { transform:scale(.5);  opacity:0; }
  12%  { opacity:.95; }
  60%  { transform:scale(1.45); opacity:0; }
  100% { transform:scale(1.6);  opacity:0; }
}

/* Core block pulse + bolt flash */
.pl-core{transform-origin:120px 120px;animation:plCore 1.5s ease-in-out infinite}
@keyframes plCore{
  0%,100%{transform:scale(1);   filter:drop-shadow(0 0 2px #C8FF3E)}
  50%    {transform:scale(1.06);filter:drop-shadow(0 0 10px #C8FF3E)}
}
.pl-bolt{animation:plBolt 1.5s ease-in-out infinite}
@keyframes plBolt{
  0%,100%{fill:#06120E}
  50%    {fill:#FFFFFF}
}

/* Progress arc — controlled by JS via stroke-dashoffset */
#pl-progress-arc{transition:stroke-dashoffset .35s ease}

/* Wordmark + reveal */
.preloader__word{
  margin-top:18px;
  font-family:'Bricolage Grotesque','Archivo','Arial Black',sans-serif;
  font-weight:800;
  font-size:36px;letter-spacing:-1.5px;
  color:var(--bone);
  opacity:0;
  animation:plFade .8s .25s ease forwards;
}
.preloader__brand-dot{color:var(--lime);animation:plDot 1s ease-in-out infinite}
.preloader__brand-tld{color:var(--lime);text-shadow:0 0 14px rgba(200,255,62,.55)}
@keyframes plDot{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes plFade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* Progress bar */
.preloader__bar{
  margin-top:22px;
  width:min(340px, 80vw);height:2px;
  background:rgba(200,255,62,.15);
  position:relative;overflow:hidden;
  opacity:0;animation:plFade .8s .35s ease forwards;
}
.preloader__bar-fill{
  position:absolute;inset:0 100% 0 0;
  background:linear-gradient(90deg, transparent, var(--lime), transparent), var(--lime);
  background-size:200% 100%, 100% 100%;
  transition:right .35s ease;
  animation:plBarShimmer 1.4s linear infinite;
}
@keyframes plBarShimmer{
  0%  {background-position:-100% 0, 0 0}
  100%{background-position: 100% 0, 0 0}
}

/* Status row */
.preloader__status{
  margin-top:14px;
  font-family:'JetBrains Mono', monospace;
  font-size:11px;letter-spacing:1.6px;text-transform:uppercase;
  color:var(--bone-2);
  display:flex;align-items:baseline;gap:10px;
  opacity:0;animation:plFade .8s .45s ease forwards;
}
.preloader__pct{color:var(--lime);font-weight:600;font-size:14px;letter-spacing:0}
.preloader__pct-sym{color:var(--lime);margin-left:2px}
.preloader__sep{color:var(--bone-3)}
.preloader__msg{
  min-width:200px;text-align:left;
  position:relative;display:inline-block;
}
.preloader__msg::after{
  content:'_';color:var(--lime);
  animation:plCaret .8s steps(2) infinite;
}
@keyframes plCaret{50%{opacity:0}}

.preloader__legal{
  margin-top:30px;
  font-family:'JetBrains Mono', monospace;
  font-size:9.5px;letter-spacing:1.6px;text-transform:uppercase;
  color:var(--bone-3);
  opacity:0;animation:plFade .8s .55s ease forwards;
}

/* Exit flash (lime burst over screen) */
.preloader__flash{
  position:fixed;inset:0;pointer-events:none;
  background:radial-gradient(circle at 50% 50%, rgba(200,255,62,1), rgba(200,255,62,.6) 30%, rgba(200,255,62,0) 75%);
  opacity:0;transform:scale(.2);
  mix-blend-mode:screen;
  transition:opacity .25s ease, transform .55s ease;
}
.preloader.is-flashing .preloader__flash{
  opacity:1;transform:scale(2.4);
}

/* =========================================================
   TOP BAR
   ========================================================= */
.top{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;padding:14px 32px;
  background:linear-gradient(180deg, rgba(11,26,20,.92), rgba(11,26,20,.78));
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.top__brand img{height:44px;width:auto}
.top__nav{display:flex;align-items:center;gap:6px;
  font-family:'JetBrains Mono', monospace;
  font-size:11px;letter-spacing:1.4px;text-transform:uppercase;
}
.top__nav a{
  color:var(--bone-2);text-decoration:none;
  padding:8px 14px;border:1px solid transparent;
  transition:color .2s, border-color .2s, background .2s;
}
.top__nav a:hover{color:var(--lime);border-color:var(--line-lime);background:rgba(200,255,62,.04)}
.top__cta{
  background:var(--lime);color:var(--ink) !important;
  border-color:var(--lime) !important;font-weight:700;
}
.top__cta:hover{background:var(--bone);color:var(--ink) !important;border-color:var(--bone) !important}

/* =========================================================
   SECTION GENERAL
   ========================================================= */
.section__head{
  text-align:center;max-width:920px;margin:0 auto 56px;
  padding:0 24px;
}
.section__head .kicker{
  display:inline-block;
  font-family:'JetBrains Mono', monospace;
  font-size:11px;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--lime);font-weight:600;
  margin-bottom:18px;
}
.section__head h2{
  font-family:'Bricolage Grotesque','Archivo',sans-serif;
  font-weight:800;font-size:clamp(40px,5.5vw,82px);
  line-height:.95;letter-spacing:-.035em;
  margin:0;color:var(--bone);
}
.section__head h2 em{color:var(--lime);font-style:normal}

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative;z-index:5;
  padding:80px 32px 120px;
  min-height:min(100vh, 880px);
  display:flex;align-items:center;justify-content:center;
}
.hero__inner{max-width:1080px;width:100%;text-align:center;position:relative}

.hero__chip{
  display:inline-block;
  font-family:'JetBrains Mono', monospace;
  font-size:11px;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--lime);font-weight:600;
  padding:7px 14px;
  border:1px solid var(--line-lime);
  background:rgba(200,255,62,.04);
  margin-bottom:32px;
}

.hero__h1{
  font-family:'Bricolage Grotesque','Archivo',sans-serif;
  font-weight:800;font-size:clamp(56px,8vw,140px);
  line-height:.92;letter-spacing:-.038em;
  margin:0 auto;color:var(--bone);
  max-width:14ch;
  overflow-wrap:break-word;
}
.hero__h1 em{color:var(--lime);font-style:normal;display:inline-block}

.hero__sub{
  max-width:64ch;margin:28px auto 0;
  font-size:17px;line-height:1.55;color:var(--bone-2);
}

.hero__cta{
  margin:42px auto 0;display:flex;gap:14px;flex-wrap:wrap;justify-content:center;
}
.btn{
  display:inline-flex;align-items:center;gap:12px;
  padding:16px 24px;font-family:'JetBrains Mono', monospace;
  font-weight:700;font-size:13px;letter-spacing:1.4px;text-transform:uppercase;
  text-decoration:none;border:1px solid transparent;
  transition:transform .2s ease, background .25s ease, border-color .25s ease, color .25s ease, box-shadow .3s ease;
  position:relative;overflow:hidden;
}
.btn--primary{
  background:var(--lime);color:var(--ink);border-color:var(--lime);
  box-shadow:0 0 0 0 rgba(200,255,62,0);
}
.btn--primary:hover{
  background:var(--bone);border-color:var(--bone);
  transform:translateY(-1px);
  box-shadow:0 12px 32px -8px rgba(200,255,62,.5);
}
.btn--primary svg{transition:transform .25s ease}
.btn--primary:hover svg{transform:translateX(4px)}
.btn--ghost{
  background:transparent;color:var(--bone);
  border-color:var(--line-strong);
}
.btn--ghost:hover{border-color:var(--lime);color:var(--lime)}
.btn--lg{padding:22px 36px;font-size:14px}

.hero__harm{
  margin:32px auto 0;max-width:62ch;
  padding:14px 18px;
  border:1px solid var(--line-lime);
  background:rgba(200,255,62,.05);
  font-size:14px;line-height:1.5;color:var(--bone);
  text-align:left;
}
.hero__harm strong{color:var(--lime);font-weight:700;margin-right:6px;display:inline}
.hero__harm a{color:var(--lime);text-decoration:none;border-bottom:1px solid var(--lime);padding-bottom:1px;font-weight:600}

.hero__meta{
  margin:36px auto 0;display:flex;flex-wrap:wrap;gap:14px 22px;justify-content:center;align-items:center;
  font-family:'JetBrains Mono', monospace;
  font-size:11px;letter-spacing:1.4px;text-transform:uppercase;
  color:var(--bone-3);
}
.hero__meta strong{color:var(--lime);font-weight:600}
.hero__meta a{
  color:var(--bone);text-decoration:none;border-bottom:1px solid var(--lime);padding-bottom:1px;
}
.hero__meta a:hover{color:var(--lime)}
.age-badge{
  display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;border-radius:50%;
  background:var(--lime);color:var(--ink);
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:11px;letter-spacing:0;
}

/* =========================================================
   COVERAGE
   ========================================================= */
.coverage{
  position:relative;z-index:5;
  padding:100px 32px;
  border-top:1px solid var(--line);
  background:linear-gradient(180deg, transparent, rgba(11,26,20,.4) 30%, transparent);
}
.coverage__grid{
  max-width:1240px;margin:0 auto;
  display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:14px;
}
.coverage__grid li{
  display:flex;flex-direction:column;align-items:center;gap:10px;
  padding:24px 12px;
  border:1px solid var(--line);
  background:rgba(20,17,15,.4);
  transition:background .3s, border-color .3s, transform .3s;
  opacity:0;transform:translateY(20px);
}
.coverage__grid li.is-visible{opacity:1;transform:none}
.coverage__grid li:hover{
  background:rgba(200,255,62,.05);
  border-color:var(--line-lime);
  transform:translateY(-4px);
}
.coverage__grid li span:last-child{
  font-family:'JetBrains Mono', monospace;
  font-size:10.5px;letter-spacing:1.4px;text-transform:uppercase;
  color:var(--bone-2);
}
.coverage__ico{
  font-family:'Bricolage Grotesque',sans-serif;
  font-weight:800;font-size:22px;letter-spacing:-1px;
  color:var(--lime);
}
.coverage__note{
  max-width:780px;margin:48px auto 0;text-align:center;
  font-size:14px;color:var(--bone-3);line-height:1.55;
}
.coverage__note em{color:var(--bone-2);font-style:italic}

/* =========================================================
   HOW IT WORKS
   ========================================================= */
.how{
  position:relative;z-index:5;
  padding:100px 32px;
  border-top:1px solid var(--line);
}
.how__steps{
  max-width:1240px;margin:0 auto;
  display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:24px;
}
.step{
  padding:36px 32px;
  border:1px solid var(--line);
  background:rgba(20,17,15,.4);
  position:relative;overflow:hidden;
  opacity:0;transform:translateY(24px);
  transition:opacity .7s ease, transform .7s ease, background .3s, border-color .3s;
}
.step.is-visible{opacity:1;transform:none}
.step:hover{background:rgba(200,255,62,.04);border-color:var(--line-lime)}
.step::before{
  content:attr(data-step);
  position:absolute;right:-18px;bottom:-60px;
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:240px;
  line-height:1;letter-spacing:-.05em;
  color:rgba(200,255,62,.04);pointer-events:none;
  transition:color .35s ease;
}
.step:hover::before{color:rgba(200,255,62,.12)}
.step__num{
  display:inline-block;
  padding:5px 11px;background:var(--lime);color:var(--ink);
  font-family:'JetBrains Mono', monospace;font-weight:700;font-size:11px;letter-spacing:1.5px;
  margin-bottom:18px;
}
.step h3{
  margin:0 0 14px;
  font-family:'Bricolage Grotesque','Archivo',sans-serif;
  font-weight:700;font-size:28px;line-height:1.05;letter-spacing:-.02em;
  position:relative;z-index:1;
}
.step p{
  margin:0;font-size:15px;line-height:1.55;color:var(--bone-2);
  position:relative;z-index:1;
}
.step em{color:var(--lime);font-style:italic}

/* =========================================================
   WAGER WISELY (NCPF accent block)
   ========================================================= */
.wisely{
  position:relative;z-index:5;
  padding:100px 32px;
  border-top:1px solid var(--line);
  background:
    radial-gradient(800px 400px at 50% 0%, rgba(200,255,62,.06), transparent 70%),
    rgba(11,26,20,.5);
}
.wisely__inner{
  max-width:980px;margin:0 auto;text-align:center;
}
.kicker{
  display:inline-block;
  font-family:'JetBrains Mono', monospace;
  font-size:11px;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--lime);font-weight:600;
  margin-bottom:24px;
}
.wisely__tagline{
  font-family:'Bricolage Grotesque','Archivo',sans-serif;
  font-weight:800;font-size:clamp(36px,4.6vw,72px);
  line-height:1;letter-spacing:-.03em;
  margin:0 auto;max-width:18ch;color:var(--bone);
}
.wisely__cta{
  margin:32px auto 0;max-width:62ch;
  font-size:17px;line-height:1.55;color:var(--bone-2);
}
.wisely__cta a{
  color:var(--lime);text-decoration:none;font-weight:600;
  border-bottom:1px solid var(--line-lime);transition:color .2s, border-color .2s;
}
.wisely__cta a:hover{color:var(--bone);border-color:var(--bone)}
.wisely__links{
  margin:48px auto 0;
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;
}
.wisely__link{
  display:flex;flex-direction:column;gap:6px;
  padding:18px 20px;
  border:1px solid var(--line);
  background:rgba(20,17,15,.4);
  color:var(--bone);text-decoration:none;
  transition:background .25s, border-color .25s, transform .25s;
  text-align:left;
}
.wisely__link:hover{
  background:rgba(200,255,62,.06);
  border-color:var(--line-lime);
  transform:translateY(-2px);
}
.wisely__link strong{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:18px;letter-spacing:-.01em;
}
.wisely__link small{
  font-family:'JetBrains Mono', monospace;
  font-size:10px;letter-spacing:1.4px;text-transform:uppercase;
  color:var(--bone-3);
}

/* =========================================================
   FINAL CTA
   ========================================================= */
.final{
  position:relative;z-index:5;
  padding:120px 32px;
  border-top:1px solid var(--line);
  text-align:center;
  background:
    radial-gradient(600px 400px at 50% 60%, rgba(200,255,62,.08), transparent 70%);
}
.final__inner{max-width:880px;margin:0 auto}
.final h2{
  font-family:'Bricolage Grotesque','Archivo',sans-serif;
  font-weight:800;font-size:clamp(44px,6vw,96px);
  line-height:.95;letter-spacing:-.038em;
  margin:0 0 22px;color:var(--bone);
}
.final h2 em{color:var(--lime);font-style:normal}
.final > .final__inner > p{
  font-size:17px;line-height:1.55;color:var(--bone-2);
  max-width:54ch;margin:0 auto 36px;
}
.final em{color:var(--lime);font-style:italic}
.final__small{
  margin-top:28px !important;font-size:12px !important;
  font-family:'JetBrains Mono', monospace;letter-spacing:1.4px;text-transform:uppercase;
  color:var(--bone-3) !important;
}
.final__small a{color:var(--bone-2);text-decoration:none;border-bottom:1px solid var(--lime)}
.final__small a:hover{color:var(--lime)}

/* =========================================================
   FOOTER
   ========================================================= */
.foot{
  position:relative;z-index:5;
  border-top:1px solid var(--line);
  background:rgba(11,26,20,.6);
}
.foot__inner{
  max-width:1240px;margin:0 auto;padding:60px 32px;
  display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:36px;
}
.foot__col h4{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;letter-spacing:2px;text-transform:uppercase;
  color:var(--lime);margin:0 0 16px;font-weight:600;
}
.foot__col p{margin:0 0 12px;font-size:13px;line-height:1.6;color:var(--bone-2)}
.foot__col ul{display:flex;flex-direction:column;gap:8px}
.foot__col li a{
  color:var(--bone-2);text-decoration:none;font-size:13px;
  border-bottom:1px solid transparent;
  transition:color .2s, border-color .2s;
}
.foot__col li a:hover{color:var(--lime);border-color:var(--line-lime)}
.foot__brand img{margin-bottom:18px}
.foot__brand strong{color:var(--bone)}
.foot__legal{
  border-top:1px solid var(--line);
  max-width:1240px;margin:0 auto;padding:24px 32px;
  font-size:12px;line-height:1.6;color:var(--bone-3);
}
.foot__legal em{font-style:italic;color:var(--bone-2)}
.foot__small{margin-top:12px !important;font-size:11px}

/* =========================================================
   NCPF mandatory plate (mandatory black-on-white)
   ========================================================= */
.ncpf{
  position:sticky;bottom:0;left:0;right:0;z-index:40;
  background:#fff;color:#000;
  border-top:2px solid #FFB200;
  border-bottom:1px solid #d4d4d4;
  padding:7px 0;
  font-family:'Inter',system-ui,sans-serif;
}
.ncpf__inner{
  max-width:100%;margin:0;padding:0 14px;
  display:flex;align-items:center;gap:12px;flex-wrap:nowrap;
  overflow:hidden;
}
.ncpf__badge{
  display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:50%;
  background:#000;color:#FFB200;font-weight:800;font-size:10px;flex-shrink:0;
}
.ncpf__line{
  margin:0;font-weight:800;font-size:12.5px;line-height:1.2;
  letter-spacing:-.005em;white-space:nowrap;flex-shrink:0;
  overflow:hidden;text-overflow:ellipsis;max-width:48%;
}
.ncpf__cta{
  margin:0;font-size:11.5px;line-height:1.25;font-weight:500;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  flex:1;min-width:0;text-align:right;
}
.ncpf__cta a{color:#000;text-decoration:underline;font-weight:700}
.ncpf__cta a:hover{color:#B5251D}

/* =========================================================
   AGE GATE (first-visit 18+ confirmation modal)
   ========================================================= */
.agegate{
  position:fixed;inset:0;z-index:9900;
  background:rgba(6,18,14,.94);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  display:grid;place-items:center;padding:20px;
  animation:agegateIn .35s ease;
}
.agegate[hidden]{display:none}
.agegate.is-done{opacity:0;visibility:hidden;transition:opacity .3s, visibility .3s}
@keyframes agegateIn{from{opacity:0;transform:scale(.98)}to{opacity:1;transform:none}}
.agegate__inner{
  max-width:520px;background:var(--ink-2);
  border:1px solid var(--line-lime);padding:36px 32px;
  text-align:center;display:flex;flex-direction:column;gap:18px;align-items:center;
}
.agegate__badge{
  display:inline-flex;align-items:center;justify-content:center;
  width:56px;height:56px;border-radius:50%;
  background:var(--lime);color:var(--ink);
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:20px;
}
.agegate__inner h2{
  margin:0;font-family:'Bricolage Grotesque',sans-serif;font-weight:700;
  font-size:24px;line-height:1.2;letter-spacing:-.015em;color:var(--bone);
}
.agegate__inner p{margin:0;font-size:14px;line-height:1.55;color:var(--bone-2)}
.agegate__cta{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:6px}
.agegate__small{
  margin-top:6px;font-size:11px;color:var(--bone-3);
  font-family:'JetBrains Mono',monospace;letter-spacing:1px;text-transform:uppercase;
}
.agegate__small a{color:var(--lime);text-decoration:none;border-bottom:1px solid var(--line-lime)}

/* =========================================================
   COOKIE BANNER
   ========================================================= */
.cookie-banner{
  position:fixed;left:18px;right:18px;bottom:60px;z-index:60;
  background:var(--ink-2);border:1px solid var(--line-lime);
  padding:18px 22px;
  display:block;
  animation:cookieIn .4s .2s ease both;
}
.cookie-banner[hidden]{display:none}
.cookie-banner.is-done{opacity:0;visibility:hidden;pointer-events:none;transition:opacity .3s, visibility .3s}
@keyframes cookieIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.cookie-banner__inner{
  display:flex;align-items:center;gap:24px;
  max-width:1200px;margin:0 auto;flex-wrap:wrap;
}
.cookie-banner__text{
  flex:1;min-width:280px;font-size:13px;line-height:1.5;color:var(--bone-2);
}
.cookie-banner__text strong{color:var(--bone);font-weight:700;margin-right:4px}
.cookie-banner__text a{color:var(--lime);text-decoration:none;border-bottom:1px solid var(--line-lime)}
.cookie-banner__cta{display:flex;gap:8px;flex-shrink:0}
.cookie-banner__cta .btn{padding:10px 16px;font-size:11px}

/* =========================================================
   HERO helpline + RG inline taglines
   ========================================================= */
.hero__cta-helpline{
  margin:18px auto 0;
  font-family:'JetBrains Mono', monospace;
  font-size:11px;letter-spacing:1.4px;text-transform:uppercase;
  color:var(--bone-2);
}
.hero__cta-helpline a{color:var(--lime);text-decoration:none;border-bottom:1px solid var(--line-lime);font-weight:600}

.coverage__rg,
.how__rg,
.final__rg{
  margin:48px auto 0;text-align:center;
  font-family:'Bricolage Grotesque', sans-serif;
  font-weight:600;font-style:italic;
  font-size:22px;line-height:1.3;letter-spacing:-.005em;
  color:var(--lime);
  max-width:48ch;
}

/* =========================================================
   SCROLL REVEAL
   ========================================================= */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease, transform .8s ease}
.reveal.is-visible{opacity:1;transform:none}

/* =========================================================
   REDUCED MOTION
   ========================================================= */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
  .pl-ray,.pl-ring,.pl-core,.pl-bolt{animation:none !important}
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1000px){
  .how__steps{grid-template-columns:1fr;gap:14px}
  .wisely__links{grid-template-columns:1fr 1fr}
  .foot__inner{grid-template-columns:1fr 1fr}
  .coverage__grid{grid-template-columns:repeat(4,1fr)}
}
@media (max-width:720px){
  .top{padding:10px 14px;gap:8px;flex-wrap:wrap}
  .top__brand{flex:1 1 auto;min-width:0}
  .top__brand img{height:34px;max-width:55vw;width:auto}
  .top__nav{gap:4px;flex-shrink:0;flex:0 0 auto}
  .top__nav a{padding:6px 10px;font-size:9.5px;letter-spacing:.8px}
  .top__nav a:not(.top__cta){display:none !important}
  .top__cta{display:inline-flex !important;padding:6px 10px;font-size:9px;letter-spacing:.6px;gap:6px}

  .hero{padding:36px 14px 64px;min-height:auto}
  .hero__chip{
    font-size:8.5px;letter-spacing:.9px;padding:5px 9px;margin-bottom:18px;
    white-space:normal;max-width:100%;display:inline-block;line-height:1.4;
    word-break:break-word;
  }
  .hero__h1{
    font-size:28px !important;
    max-width:100% !important;
    letter-spacing:-.015em !important;
    line-height:1.08 !important;
    overflow-wrap:anywhere !important;
    word-break:break-word !important;
    hyphens:auto;
  }
  .hero__sub{font-size:14px;margin-top:16px;max-width:100%}
  .hero__cta{margin-top:26px;flex-direction:column;align-items:stretch}
  .btn{padding:14px 18px;font-size:11px;justify-content:center}
  .btn--lg{padding:18px 22px;font-size:12px}
  .hero__meta{
    font-size:9.5px;letter-spacing:1px;gap:8px 14px;margin-top:28px;
    justify-content:flex-start;text-align:left;
  }
  .hero__meta strong{display:inline}

  .coverage,.how,.wisely,.final{padding:64px 16px}
  .section__head{margin-bottom:36px}
  .section__head h2{font-size:clamp(30px,8vw,50px)}
  .coverage__grid{grid-template-columns:repeat(3,1fr);gap:8px}
  .coverage__grid li{padding:18px 8px}
  .coverage__ico{font-size:18px}
  .coverage__grid li span:last-child{font-size:9px;letter-spacing:1px}

  .step{padding:26px 22px}
  .step h3{font-size:22px}
  .step p{font-size:14px}

  .wisely__tagline{font-size:clamp(28px,8vw,42px)}
  .wisely__cta{font-size:15px}
  .wisely__links{grid-template-columns:1fr;gap:10px}

  .final h2{font-size:clamp(32px,8vw,52px)}
  .final > .final__inner > p{font-size:15px}

  .foot__inner{grid-template-columns:1fr;gap:28px;padding:40px 18px}
  .foot__legal{padding:20px 18px;font-size:11px}

  .preloader__mark{width:220px;height:220px}
  .preloader__word{font-size:28px;margin-top:12px}
  .preloader__bar{margin-top:16px;width:min(280px,80vw)}
  .preloader__legal{font-size:8.5px}
}
@media (max-width:720px){
  .ncpf__inner{flex-wrap:wrap;gap:6px 10px;overflow:visible}
  .ncpf__line{flex-basis:calc(100% - 32px);max-width:none;white-space:normal;line-height:1.3;font-size:12px}
  .ncpf__cta{flex-basis:100%;white-space:normal;text-align:left;line-height:1.4;font-size:11px}
  .ncpf__cta a{display:inline-block;padding:2px 0}
}
