/* ========================================================
   TOM THE LIZARD — fan landing page
   Inspired by the layout language of marketing landing pages
   (giant condensed display type, soft warm palette, 3D mascot).
   All artwork here is original CSS/SVG-rendered placeholders.
   ======================================================== */

:root{
  --cream:#F8E2BB;
  --cream-2:#F4D8A8;
  --cream-3:#FCEBC8;
  --salmon:#F8C9B6;
  --lavender:#D6CDD9;
  --red:#E8442C;
  --red-dark:#C13821;
  --red-soft:#F89880;
  --ink:#2A1F12;
  --green:#3E8E50;     /* lizard accent (kept subtle) */
  --green-dark:#1F5A2C;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--cream);color:var(--ink);font-family:'Inter',system-ui,sans-serif;line-height:1.45;-webkit-font-smoothing:antialiased}
body.is-loading{overflow:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ============================================
   LOADING SCREEN
   ============================================ */
.loader{
  position:fixed;inset:0;z-index:9999;
  background:radial-gradient(ellipse at 50% 35%, #FFE4B0 0%, var(--cream) 60%, var(--cream-2) 100%);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .65s ease, visibility .65s ease;
}
.loader.is-hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader-inner{text-align:center;padding:0 24px}
.loader-mark{
  position:relative;width:140px;height:140px;margin:0 auto 28px;
}
.loader-img{
  width:100%;height:100%;border-radius:50%;object-fit:cover;
  background:#fff;
  box-shadow:0 24px 50px rgba(80,30,10,.22), 0 4px 8px rgba(0,0,0,.06);
  animation:loader-bob 2.2s ease-in-out infinite;
}
.loader-ring{
  position:absolute;inset:-14px;border-radius:50%;
  border:3px solid transparent;
  border-top-color:var(--red);
  border-right-color:var(--red-soft);
  animation:loader-spin 1.1s linear infinite;
}
.loader-word{
  font-family:'Anton',sans-serif;color:var(--red);
  font-size:2.6rem;letter-spacing:.04em;line-height:1;
}
.loader-bar{
  width:240px;max-width:60vw;height:3px;
  background:rgba(232,68,44,.15);
  border-radius:99px;overflow:hidden;
  margin:18px auto 14px;position:relative;
}
.loader-bar span{
  position:absolute;inset:0;width:35%;
  background:linear-gradient(90deg,transparent,var(--red),transparent);
  border-radius:99px;
  animation:loader-bar 1.4s ease-in-out infinite;
}
.loader-tag{
  font-family:'Barlow Condensed',sans-serif;font-weight:600;letter-spacing:.18em;
  text-transform:uppercase;color:var(--red);font-size:.78rem;opacity:.7;
}
@keyframes loader-spin{to{transform:rotate(360deg)}}
@keyframes loader-bob{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-6px)}
}
@keyframes loader-bar{
  0%{left:-40%}
  100%{left:100%}
}

/* -------- TYPE -------- */
.display{font-family:'Anton','Bebas Neue','Barlow Condensed',sans-serif;font-weight:400;letter-spacing:-0.01em;line-height:.92;color:var(--red);text-transform:uppercase}
.display-l{font-size:clamp(2rem,4vw,4rem)}
.display-xl{font-size:clamp(3rem,7vw,7rem)}
.display-xxl{font-size:clamp(4rem,12vw,12rem)}
.center{text-align:center}
.right{text-align:right}
.red{color:var(--red)}
.muted{color:#6b5a40;font-size:.9rem}
strong.loud{display:block;font-family:'Anton',sans-serif;color:var(--red);font-size:clamp(2.4rem,6vw,6rem);line-height:.9;margin-top:1rem;letter-spacing:-.01em}

/* -------- NAV -------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 32px;
  pointer-events:none;
}
.nav > *{pointer-events:auto}
.logo{
  display:flex;align-items:center;gap:10px;
  font-family:'Anton',sans-serif;color:var(--red);
  font-size:1.4rem;letter-spacing:.02em;
}
.logo-img{
  width:38px;height:38px;border-radius:50%;
  object-fit:cover;background:#fff;
  box-shadow:0 6px 14px rgba(80,30,10,.2), 0 1px 2px rgba(0,0,0,.06);
}
.nav-actions{display:flex;align-items:center;gap:10px;pointer-events:auto}
.nav-pill{
  display:flex;gap:18px;align-items:center;
  background:rgba(252,235,200,.7);
  backdrop-filter:blur(8px);
  border-radius:999px;
  padding:12px 22px;
  font-family:'Barlow Condensed',sans-serif;font-weight:700;
  font-size:.8rem;color:var(--red);letter-spacing:.08em;
  text-transform:uppercase;
}
.nav-pill a{transition:opacity .2s}
.nav-pill a:hover{opacity:.6}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  border:none;cursor:pointer;
  font-family:'Barlow Condensed',sans-serif;font-weight:800;letter-spacing:.08em;
  text-transform:uppercase;font-size:.85rem;
  padding:14px 26px;border-radius:999px;
  transition:transform .15s ease, background .2s;
}
.btn:hover{transform:translateY(-1px)}
.btn-launch{background:#fff;color:var(--red)}
.btn-red{background:var(--red);color:#fff}
.btn-white{background:#fff;color:var(--red)}
.btn-x{
  background:#000;color:#fff;
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 18px;
}
.btn-x svg{width:14px;height:14px}
.btn-x span{font-size:.78rem;letter-spacing:.06em}

/* ============================================
   CINEMATIC SCENE — fused hero + nano scroll-pinned stage
   ============================================ */
.cinematic{
  position:relative;
  height:100vh;
  overflow:hidden;
  background:#F4D8A8;
}
/* Both videos share the same fullscreen positioning and crop. */
.cine-video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
  z-index:0;
  pointer-events:none;
  transform:scale(1.2);
  transform-origin:42% 36%;
  will-change:transform;
}
/* The nano video is layered on top of the hero video. JS toggles visibility
   at the exact scroll point where hero ends — since nano's first frame is
   identical to hero's last frame, the swap is invisible. */
.cine-nano{opacity:0}

/* Backwards-compat: keep .hero / .hero-video selectors working in case
   they're referenced elsewhere. */
.hero{position:relative;min-height:100vh;height:100vh;overflow:hidden;background:var(--cream)}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center center;z-index:0;pointer-events:none;transform:scale(1.2);transform-origin:42% 36%;will-change:transform}
/* Soft vignette so the navbar reads cleanly over the video, and the
   bottom edge melts into the NANO section (which uses the same cream). */
.hero-vignette{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(180deg,
      rgba(248,226,187,.55) 0%,
      rgba(248,226,187,0) 18%,
      rgba(248,226,187,0) 60%,
      rgba(244,216,168,.4) 82%,
      #F4D8A8 100%);
}
.hero-stage{
  position:relative;z-index:2;
  width:100%;height:100%;
  min-height:560px;
}
.hero-copy{
  position:absolute;
  left:50%;top:18%;
  transform:translateX(-50%);
  text-align:center;
  z-index:4;
  width:min(92%,900px);
  pointer-events:none;
}
.hero-headline{
  font-family:'Anton',sans-serif;
  color:var(--red);
  font-size:clamp(2.4rem,7vw,6.5rem);
  line-height:.92;
  letter-spacing:-.01em;
  text-transform:lowercase;
  text-shadow:0 6px 30px rgba(244,216,168,.6);
}
.hero-tagline{
  margin-top:18px;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:600;
  letter-spacing:.04em;
  color:var(--ink);
  font-size:clamp(.95rem,1.4vw,1.15rem);
  text-shadow:0 2px 10px rgba(244,216,168,.9);
}

/* lizard mascots — pure CSS+SVG */
.liz{
  position:absolute;
  width:calc(160px * var(--s, 1));
  aspect-ratio:1/1.1;
  left:var(--x);top:var(--y);
  transform:translate(-50%,-50%) scale(var(--s,1));
  filter:drop-shadow(0 18px 14px rgba(80,50,20,.18));
  pointer-events:none;
}
.liz::before{
  content:"";
  position:absolute;inset:0;
  background-image:var(--lz, none);
  background-size:contain;background-repeat:no-repeat;background-position:center;
}

/* hero pose, centered, larger */
.liz-hero{
  left:50%;top:55%;
  width:300px;
  z-index:5;
}
.liz-hero.static{position:relative;left:auto;top:auto;transform:none;margin:30px auto 0}

/* CSS-painted lizard body w/ inline SVG via mask  */
.liz-grey{--lz:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 220'><defs><radialGradient id='g' cx='50%25' cy='40%25' r='65%25'><stop offset='0%25' stop-color='%23B8A99A'/><stop offset='65%25' stop-color='%237B6E62'/><stop offset='100%25' stop-color='%234E443B'/></radialGradient></defs><ellipse cx='100' cy='130' rx='72' ry='62' fill='url(%23g)'/><ellipse cx='100' cy='75' rx='55' ry='52' fill='url(%23g)'/><circle cx='80' cy='70' r='15' fill='white'/><circle cx='120' cy='70' r='15' fill='white'/><circle cx='82' cy='72' r='6' fill='%23222'/><circle cx='122' cy='72' r='6' fill='%23222'/><polygon points='95,90 105,90 100,98' fill='%23E07A3A'/><path d='M70 192 Q72 210 60 210 L88 210 Q86 200 86 192 Z' fill='%23E8442C'/><path d='M114 192 Q112 210 100 210 L128 210 Q126 200 126 192 Z' fill='%23E8442C'/></svg>")}

.liz-hero{--lz:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 220 240'><defs><radialGradient id='lg' cx='50%25' cy='40%25' r='70%25'><stop offset='0%25' stop-color='%2386D17C'/><stop offset='55%25' stop-color='%233E8E50'/><stop offset='100%25' stop-color='%231F5A2C'/></radialGradient><radialGradient id='lb' cx='50%25' cy='40%25' r='70%25'><stop offset='0%25' stop-color='%2395DC8B'/><stop offset='100%25' stop-color='%232F7A40'/></radialGradient></defs><ellipse cx='110' cy='150' rx='80' ry='68' fill='url(%23lb)'/><ellipse cx='110' cy='80' rx='62' ry='58' fill='url(%23lg)'/><path d='M65 50 Q75 30 90 45 M155 50 Q145 30 130 45' stroke='%231F5A2C' stroke-width='5' fill='none' stroke-linecap='round'/><circle cx='86' cy='78' r='20' fill='white'/><circle cx='134' cy='78' r='20' fill='white'/><circle cx='90' cy='82' r='10' fill='%23222'/><circle cx='138' cy='82' r='10' fill='%23222'/><circle cx='93' cy='79' r='3' fill='white'/><circle cx='141' cy='79' r='3' fill='white'/><ellipse cx='110' cy='110' rx='8' ry='5' fill='%231F5A2C' opacity='.4'/><path d='M86 130 Q110 150 134 130' stroke='%231F5A2C' stroke-width='4' fill='none' stroke-linecap='round'/><path d='M70 210 Q72 228 60 228 L92 228 Q90 218 90 210 Z' fill='%23E8B53A'/><path d='M130 210 Q128 228 140 228 L108 228 Q110 218 110 210 Z' fill='%23E8B53A'/></svg>")}

/* social bubbles */
.bubble{
  position:absolute;left:var(--bx);top:var(--by);
  background:var(--red);color:#fff;
  font-family:'Barlow Condensed',sans-serif;font-weight:700;letter-spacing:.04em;
  padding:9px 14px 9px 34px;border-radius:8px;
  font-size:.95rem;white-space:nowrap;
  filter:drop-shadow(0 6px 8px rgba(80,30,20,.18));
  z-index:6;
}
.bubble::before{
  content:"";position:absolute;left:8px;top:50%;transform:translateY(-50%);
  width:18px;height:18px;background:#fff;mask-size:contain;-webkit-mask-size:contain;mask-repeat:no-repeat;-webkit-mask-repeat:no-repeat;mask-position:center;-webkit-mask-position:center;
  background:#fff;
}
.bubble::after{
  content:"";position:absolute;left:18px;bottom:-7px;
  width:14px;height:14px;background:var(--red);transform:rotate(45deg);
  z-index:-1;
}
.bub-ig::before{-webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M7 2h10a5 5 0 0 1 5 5v10a5 5 0 0 1-5 5H7a5 5 0 0 1-5-5V7a5 5 0 0 1 5-5zm5 5a5 5 0 1 0 .001 10.001A5 5 0 0 0 12 7zm6.5-1.5a1 1 0 1 0 0 2 1 1 0 0 0 0-2zM12 9a3 3 0 1 1 0 6 3 3 0 0 1 0-6z'/></svg>");mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M7 2h10a5 5 0 0 1 5 5v10a5 5 0 0 1-5 5H7a5 5 0 0 1-5-5V7a5 5 0 0 1 5-5zm5 5a5 5 0 1 0 .001 10.001A5 5 0 0 0 12 7zm6.5-1.5a1 1 0 1 0 0 2 1 1 0 0 0 0-2zM12 9a3 3 0 1 1 0 6 3 3 0 0 1 0-6z'/></svg>")}
.bub-tw::before{-webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M22 5.8c-.7.3-1.5.5-2.3.6.8-.5 1.5-1.3 1.8-2.3-.8.5-1.7.8-2.6 1A4.1 4.1 0 0 0 11.8 9c0 .3 0 .6.1.9C8.3 9.7 5.1 8 3 5.4c-.4.7-.6 1.4-.6 2.2 0 1.4.7 2.7 1.8 3.4-.7 0-1.3-.2-1.9-.5v.1c0 2 1.4 3.6 3.3 4-.7.2-1.4.2-2 .1.5 1.6 2.1 2.8 3.9 2.8a8.3 8.3 0 0 1-6.1 1.7A11.7 11.7 0 0 0 8 21c7.5 0 11.6-6.2 11.6-11.6v-.5C20.4 8.4 21.2 7.2 22 5.8z'/></svg>");mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M22 5.8c-.7.3-1.5.5-2.3.6.8-.5 1.5-1.3 1.8-2.3-.8.5-1.7.8-2.6 1A4.1 4.1 0 0 0 11.8 9c0 .3 0 .6.1.9C8.3 9.7 5.1 8 3 5.4c-.4.7-.6 1.4-.6 2.2 0 1.4.7 2.7 1.8 3.4-.7 0-1.3-.2-1.9-.5v.1c0 2 1.4 3.6 3.3 4-.7.2-1.4.2-2 .1.5 1.6 2.1 2.8 3.9 2.8a8.3 8.3 0 0 1-6.1 1.7A11.7 11.7 0 0 0 8 21c7.5 0 11.6-6.2 11.6-11.6v-.5C20.4 8.4 21.2 7.2 22 5.8z'/></svg>")}
.bub-tk::before{-webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M19 7.5a6.6 6.6 0 0 1-4.4-1.7v8.7a6.5 6.5 0 1 1-6.5-6.5h.4v3a3.6 3.6 0 1 0 2.6 3.5V2h3a3.6 3.6 0 0 0 3.6 3.6h1.3v1.9z'/></svg>");mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M19 7.5a6.6 6.6 0 0 1-4.4-1.7v8.7a6.5 6.5 0 1 1-6.5-6.5h.4v3a3.6 3.6 0 1 0 2.6 3.5V2h3a3.6 3.6 0 0 0 3.6 3.6h1.3v1.9z'/></svg>")}
.hero-stat{
  left:50%;top:30%;transform:translate(-50%,-50%);
  z-index:7;
  background:#fff;color:var(--red);
  box-shadow:0 8px 18px rgba(60,30,10,.25);
}
.hero-stat::after{background:#fff}
.hero-stat::before{background:var(--red)}

/* ============================================
   Nano-phase overlays (text/headline that ride scroll progress in cinematic)
   ============================================ */
.nano-content{
  position:absolute;
  top:0;left:0;right:0;
  z-index:3;
  text-align:center;
  padding:120px 24px 0;
  opacity:0; /* JS reveals on scroll */
  pointer-events:none;
}
.nano-content .display-xxl{
  font-size:clamp(5rem,18vw,18rem);
  text-shadow:0 6px 30px rgba(180,80,30,.18);
}
.nano-content .eq{display:inline-block;transform:translateY(-.15em);margin:0 .15em}
.nano-content .subline{
  font-family:'Barlow Condensed',sans-serif;font-weight:700;letter-spacing:.06em;
  color:var(--red);margin-top:18px;font-size:1rem;
  text-shadow:0 2px 10px rgba(244,216,168,.9);
}

/* ============================================
   TARGET / cards
   ============================================ */
.target{
  display:grid;grid-template-columns:1.1fr 1fr;
  gap:40px;align-items:center;
  padding:80px 8vw;background:var(--cream);
}
.cards{position:relative;height:480px}
.card{
  position:absolute;width:340px;height:210px;
  background:#fff;border-radius:6px;
  box-shadow:0 22px 40px rgba(120,70,20,.18);
}
.card-a{left:0;top:0;transform:rotate(-5deg)}
.card-b{left:22%;top:28%;transform:rotate(3deg)}
.card-c{left:6%;top:58%;transform:rotate(-2deg)}
.card::after{
  content:"";position:absolute;inset:10px;border-radius:3px;
  background-size:cover;background-position:center;background-repeat:no-repeat;
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 10%,#000 90%,transparent 100%);
          mask-image:linear-gradient(90deg,transparent 0,#000 10%,#000 90%,transparent 100%);
}
.card-a::after{background-image:url("assets/images/card-beaver.jpeg")}
.card-b::after{background-image:url("assets/images/card-bear-picnic.jpeg")}
.card-c::after{background-image:url("assets/images/card-deer-news.jpeg")}
.target h2{justify-self:end}

/* Wide cinematic image strip — used in BOMB and BACKED sections */
.scene-strip{
  width:min(92%,1100px);
  margin:0 auto 60px;
  aspect-ratio:16/9;
  background-size:cover;background-position:center;background-repeat:no-repeat;
  filter:drop-shadow(0 30px 40px rgba(80,30,10,.18));
  -webkit-mask-image:
    linear-gradient(90deg,transparent 0,#000 10%,#000 90%,transparent 100%),
    linear-gradient(180deg,transparent 0,#000 7%,#000 93%,transparent 100%);
          mask-image:
    linear-gradient(90deg,transparent 0,#000 10%,#000 90%,transparent 100%),
    linear-gradient(180deg,transparent 0,#000 7%,#000 93%,transparent 100%);
  -webkit-mask-composite:source-in;
          mask-composite:intersect;
}
.scene-bears{background-image:url("assets/images/gecko-bears-sign.jpeg")}
.scene-beach{background-image:url("assets/images/gecko-beach.jpeg")}

/* ============================================
   BOMB / intro
   ============================================ */
.bomb{
  text-align:center;padding:120px 8vw 80px;
  background:radial-gradient(circle at 50% 30%, #FFE4B0 0%, var(--cream) 50%);
  position:relative;
}
.bomb-shape{
  width:240px;height:260px;margin:0 auto 60px;position:relative;
  background:radial-gradient(circle at 35% 35%, #fff 0%, #DCD3C8 70%, #B8AFA3 100%);
  border-radius:50%;
  box-shadow:0 40px 60px -10px rgba(80,40,20,.25), inset -20px -30px 60px rgba(0,0,0,.18);
}
.bomb-shape::before{
  content:"";position:absolute;left:50%;top:-20px;transform:translateX(-50%);
  width:30px;height:50px;background:#1a1a1a;border-radius:6px 6px 4px 4px;
}
.fuse{
  position:absolute;left:50%;top:-50px;transform:translateX(-50%);
  width:30px;height:30px;
  background:radial-gradient(circle, var(--red) 0%, var(--red-dark) 70%, transparent 100%);
  border-radius:50%;
}
.fuse::before,.fuse::after{
  content:"";position:absolute;left:50%;top:0;
  width:3px;height:25px;background:var(--red);
  transform-origin:50% 100%;
}
.fuse::before{transform:translateX(-50%) rotate(-25deg)}
.fuse::after{transform:translateX(-50%) rotate(25deg)}

.bomb h3{max-width:1100px;margin:0 auto;color:var(--red);text-transform:lowercase}
.bomb-dedication{
  margin:24px auto 0;max-width:760px;
  font-family:'Barlow Condensed',sans-serif;font-weight:600;letter-spacing:.14em;
  color:var(--red);font-size:.9rem;text-transform:uppercase;
  display:inline-block;padding:10px 20px;
  border:1.5px solid var(--red);border-radius:999px;
  background:rgba(255,228,176,.5);
}
.bomb-dedication strong{font-weight:800;letter-spacing:.06em}
.bomb-dedication em{font-style:italic;font-weight:600;letter-spacing:.04em;text-transform:none}
.bomb-body{
  max-width:780px;margin:30px auto 0;
  font-family:'Inter',sans-serif;font-size:1.05rem;line-height:1.6;
  color:#3a2918;
}
.target-sub{
  margin-top:18px;
  font-family:'Barlow Condensed',sans-serif;font-weight:600;letter-spacing:.04em;
  color:#5a3f20;font-size:1rem;text-align:right;
}
.trio{
  display:grid;grid-template-columns:repeat(3,1fr);gap:50px;
  max-width:1100px;margin:80px auto 0;text-align:center;
}
.trio h4{
  font-family:'Anton',sans-serif;color:var(--red);font-size:1.2rem;
  letter-spacing:.06em;margin-bottom:14px;
}
.trio p{font-size:.92rem;color:#5e4a2e;line-height:1.55}

/* ============================================
   AI matching
   ============================================ */
.ai{
  background:linear-gradient(180deg,var(--cream),#F2D8B4);
  padding:80px 8vw 120px;overflow:hidden;
}
.ai-title{font-size:clamp(3rem,11vw,11rem);text-align:left;line-height:.9}
.ai-row{
  display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:center;
  margin-top:40px;
}
.ai-copy{font-size:1rem;color:#3a2918;max-width:560px;line-height:1.7}
.ai-copy strong{color:var(--red)}
.astro{
  width:100%;max-width:480px;aspect-ratio:16/9;justify-self:center;
  background-size:cover;background-position:center;background-repeat:no-repeat;
  filter:drop-shadow(0 30px 30px rgba(80,30,10,.2));
  -webkit-mask-image:radial-gradient(ellipse 86% 80% at 50% 50%,#000 52%,transparent 98%);
          mask-image:radial-gradient(ellipse 86% 80% at 50% 50%,#000 52%,transparent 98%);
}
.astro.static{margin:0 auto}
.astro.big{max-width:560px}
.astro.tall{max-width:460px}
.ai .astro      {background-image:url("assets/images/gecko-craft.jpeg")}
.utility .astro {background-image:url("assets/images/gecko-utility.jpeg")}
.defl .astro    {background-image:url("assets/images/gecko-defl.jpeg")}
.roadmap .astro {background-image:url("assets/images/gecko-roadmap.jpeg")}

/* ============================================
   FLOWCHART
   ============================================ */
.flow{
  background:linear-gradient(180deg,#F2D8B4,#FBE3B5);
  padding:80px 8vw 120px;text-align:center;
}
.flow h2{text-align:center}
.flow-sub{
  font-family:'Barlow Condensed',sans-serif;font-weight:700;
  color:var(--red);margin-top:20px;font-size:1rem;
}
.flow-sub span{color:#5a3f20;font-weight:500;display:block;margin-top:6px;font-size:.85rem}

.flow-grid{
  position:relative;max-width:900px;margin:80px auto 0;
  display:grid;grid-template-columns:1fr auto 1fr;gap:24px;align-items:center;
  padding:30px 0 80px;
}
.flow-box{
  border:2px solid var(--red);color:var(--red);
  font-family:'Anton',sans-serif;font-size:1.6rem;letter-spacing:.04em;
  padding:34px 0;border-radius:6px;
}
.flow-line{width:60px;height:2px;background:var(--red);position:relative}
.flow-line::before,.flow-line::after{
  content:"";position:absolute;width:8px;height:8px;border-radius:50%;
  background:var(--red);top:50%;transform:translateY(-50%);
}
.flow-line::before{left:-2px}
.flow-line::after{right:-2px}

.flow-tag{position:absolute;bottom:-10px;text-align:center}
.tag-left{left:8%}
.tag-right{right:8%}
.tag-pill{
  display:inline-block;border:2px solid var(--red);color:var(--red);
  border-radius:999px;padding:8px 16px;
  font-family:'Barlow Condensed',sans-serif;font-weight:700;letter-spacing:.06em;font-size:.78rem;
  background:#FBE3B5;
}
.flow-tag strong{display:block;font-family:'Anton',sans-serif;color:var(--red);font-size:1.6rem;margin-top:8px}
.flow-arc{
  position:absolute;left:10%;right:10%;bottom:0;height:80px;
  border:2px solid var(--red);border-top:none;border-radius:0 0 200px 200px;
}
.flow-pipeline{
  display:flex;flex-wrap:wrap;justify-content:center;align-items:center;
  gap:14px;max-width:1100px;margin:60px auto 0;
}
.pipe-step{
  border:2px solid var(--red);color:var(--red);
  font-family:'Anton',sans-serif;font-size:1.1rem;letter-spacing:.04em;
  padding:18px 24px;border-radius:6px;background:#FBE3B5;text-transform:lowercase;
}
.pipe-step.accent{background:var(--red);color:#fff}
.pipe-arrow{
  font-family:'Anton',sans-serif;color:var(--red);font-size:1.6rem;
}

/* ============================================
   VISION
   ============================================ */
.vision{
  background:radial-gradient(ellipse at 50% 90%, #FBE3B5 0%, var(--cream) 70%);
  padding:80px 4vw 60px;text-align:center;position:relative;overflow:hidden;
}
.vision-title{
  font-size:clamp(5rem,22vw,22rem);
  display:flex;align-items:center;justify-content:center;gap:0;
  color:var(--red);line-height:.85;
  font-family:'Anton',sans-serif;
}
.eye{
  display:inline-block;width:.75em;height:.75em;border-radius:50%;
  background:#fff;border:.08em solid var(--red);position:relative;
  margin:0 -.04em;
}
.eye::after{
  content:"";position:absolute;width:.18em;height:.18em;border-radius:50%;
  background:#1a1a1a;left:50%;top:50%;transform:translate(-50%,-50%);
}

.vision-line{
  font-family:'Barlow Condensed',sans-serif;font-weight:700;letter-spacing:.04em;
  color:var(--red);font-size:clamp(1rem,1.6vw,1.4rem);
  margin-top:60px;max-width:760px;margin-left:auto;margin-right:auto;
}

/* ============================================
   MISSION
   ============================================ */
.mission{
  background:linear-gradient(180deg, var(--cream) 0%, var(--cream) 40%, var(--lavender) 40%, var(--lavender) 100%);
  padding:60px 8vw 120px;text-align:center;position:relative;
}
.mission .display-xxl{
  font-size:clamp(5rem,22vw,22rem);color:#1f1817;
  display:inline-flex;align-items:center;justify-content:center;
}
.o-shape{
  display:inline-block;width:.75em;height:.75em;border-radius:50%;
  background:radial-gradient(circle at 35% 35%, #C8B9C2, #6E5F69);
}
.mission-mascot{
  position:relative;width:min(92%,560px);aspect-ratio:16/9;
  margin:-120px auto 0;
  background:url("assets/images/gecko-hero.jpeg") center/cover no-repeat;
  filter:drop-shadow(0 30px 30px rgba(80,30,10,.2));
  -webkit-mask-image:radial-gradient(ellipse 86% 80% at 50% 50%,#000 52%,transparent 98%);
          mask-image:radial-gradient(ellipse 86% 80% at 50% 50%,#000 52%,transparent 98%);
  z-index:2;
}
.mission-copy{
  font-family:'Barlow Condensed',sans-serif;font-weight:700;color:var(--red);
  font-size:1.2rem;max-width:680px;margin:60px auto 0;letter-spacing:.04em;
}
.counter{
  font-family:'Anton',sans-serif;color:var(--red);
  font-size:clamp(4rem,16vw,16rem);line-height:.9;margin-top:60px;
  letter-spacing:-.01em;
}
.counter::first-letter{color:#F8B5A8}
.counter-cap{
  font-family:'Barlow Condensed',sans-serif;font-weight:600;letter-spacing:.06em;
  color:#3b3340;margin-top:10px;font-size:.95rem;
}

/* ============================================
   TOKENOMICS
   ============================================ */
.token{
  background:linear-gradient(180deg, var(--lavender) 0%, var(--salmon) 35%);
  padding:80px 8vw;text-align:center;
}
.token .display-xxl{font-size:clamp(4rem,16vw,16rem);color:var(--red);line-height:.85}
.token-tag{
  font-family:'Barlow Condensed',sans-serif;font-weight:700;letter-spacing:.04em;
  color:var(--red);margin-top:18px;font-size:1.05rem;
}
.token-row{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
  margin-top:60px;text-align:left;
}
.donut{display:flex;justify-content:center}
.donut-svg{width:min(100%,420px);transform:rotate(-90deg)}
.donut-hole{fill:transparent}
.seg{fill:transparent;stroke-width:6}
.token-table{display:flex;flex-direction:column;gap:6px}
.token-table .row{
  display:grid;grid-template-columns:2fr 1fr 1.4fr;
  border-bottom:1px solid rgba(192,60,40,.3);padding:10px 0;
  font-family:'Barlow Condensed',sans-serif;font-weight:700;letter-spacing:.04em;
  color:var(--red);
}
.token-table .row b{font-family:'Anton',sans-serif;color:var(--red);font-weight:400}
.token-table .row i{font-style:normal;text-align:right;color:#3a2918;font-weight:600}

.dual{
  display:grid;grid-template-columns:1fr 1fr;gap:40px;
  max-width:900px;margin:80px auto 0;
}
.dual-col{text-align:center;position:relative}
.big-pct{font-family:'Anton',sans-serif;color:var(--red);font-size:clamp(3rem,8vw,7rem);line-height:1}
.pill{
  display:inline-flex;align-items:center;gap:8px;
  border:2px solid var(--red);color:var(--red);background:#FFE6D5;
  padding:8px 18px;border-radius:999px;
  font-family:'Barlow Condensed',sans-serif;font-weight:700;letter-spacing:.05em;font-size:.82rem;
  margin-top:14px;
}
.pill .dot{width:14px;height:14px;border-radius:50%;background:var(--green);display:inline-block}
.pill .dot.fire{background:radial-gradient(circle at 50% 30%,#FFD66B,#E8442C 70%)}

/* ============================================
   UTILITY card
   ============================================ */
.utility{
  background:linear-gradient(180deg,var(--salmon),var(--cream));
  padding:80px 8vw;text-align:center;
}
.utility-row{
  display:grid;grid-template-columns:1fr 1.2fr;gap:40px;align-items:center;
  max-width:1100px;margin:60px auto 0;
}
.utility-card{
  background:#FBE3B5;border:1.5px solid var(--red);
  padding:30px;border-radius:6px;text-align:left;color:var(--red);
}
.utility-card h4{font-family:'Anton',sans-serif;letter-spacing:.06em;margin-bottom:14px}
.utility-card ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.utility-card li{
  font-size:.85rem;color:#3a2918;font-weight:500;
  position:relative;padding-left:14px;
}
.utility-card li::before{
  content:"";position:absolute;left:0;top:9px;width:5px;height:5px;
  background:var(--red);border-radius:50%;
}

/* ============================================
   DEFLATIONARY
   ============================================ */
.defl{
  background:var(--cream);padding:80px 8vw;
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
}
.defl-card{border:1.5px solid var(--red);padding:40px;border-radius:6px;color:var(--red)}
.defl-card h4{font-family:'Anton',sans-serif;font-size:2rem;letter-spacing:.02em;margin-bottom:18px;line-height:1}
.defl-card p{color:#3a2918;font-size:.9rem;font-weight:500}

/* ============================================
   ROADMAP
   ============================================ */
.roadmap{
  background:linear-gradient(180deg,var(--cream),#FBE5C9);
  padding:80px 8vw;display:grid;grid-template-columns:auto 1fr;gap:60px;align-items:start;
}
.timeline{display:flex;flex-direction:column;gap:30px;border-left:2px dashed var(--red);padding-left:30px}
.tl{
  background:#FBEDD0;border:1.5px solid var(--red);border-radius:6px;
  padding:24px 28px;color:var(--red);position:relative;
}
.tl::before{
  content:"";position:absolute;left:-37px;top:30px;width:14px;height:14px;border-radius:50%;
  background:var(--red);
}
.tl h5{font-family:'Anton',sans-serif;font-size:1.3rem;letter-spacing:.06em;margin-bottom:10px}
.tl ul{list-style:none;font-family:'Barlow Condensed',sans-serif;font-weight:600;
  letter-spacing:.04em;font-size:.9rem;color:#3a2918;display:flex;flex-direction:column;gap:4px}

/* ============================================
   STRIP
   ============================================ */
.strip{
  background:var(--lavender);padding:60px 8vw;
  position:relative;overflow:hidden;text-align:center;
}
.strip-title{
  font-family:'Anton',sans-serif;color:var(--red);
  font-size:clamp(5rem,18vw,18rem);line-height:.85;opacity:.95;
}
.strip-title span{margin:0 .12em;opacity:.6}
.strip-cols{
  display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:40px;
  font-family:'Barlow Condensed',sans-serif;font-weight:700;letter-spacing:.05em;
  color:var(--red);font-size:.85rem;text-align:left;max-width:1100px;margin-left:auto;margin-right:auto;
}

/* ============================================
   BACKED BY
   ============================================ */
.backed{
  background:var(--cream);padding:60px 8vw;text-align:center;
}
.backed-label{
  font-family:'Barlow Condensed',sans-serif;font-weight:800;letter-spacing:.2em;
  color:#3a2918;margin-bottom:30px;
}
.backers{
  display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:34px 50px;
}
.backer{
  font-family:'Inter',sans-serif;font-weight:700;color:#5a3f20;opacity:.85;
  font-size:1rem;letter-spacing:.02em;
}
.backer.outline{border:1.5px solid #5a3f20;padding:6px 14px;border-radius:2px}
.backed-body{
  margin-top:18px;font-family:'Barlow Condensed',sans-serif;font-weight:600;
  letter-spacing:.04em;color:#3a2918;font-size:1.05rem;line-height:1.5;
}

/* ============================================
   CTA speech
   ============================================ */
.cta{padding:80px 8vw;text-align:center;background:var(--cream)}
.speech{
  position:relative;display:inline-block;background:var(--red);color:#fff;
  padding:30px 50px;border-radius:18px;max-width:520px;
  filter:drop-shadow(0 18px 30px rgba(80,40,20,.18));
}
.speech p{
  font-family:'Anton',sans-serif;letter-spacing:.04em;font-size:1.2rem;line-height:1.1;margin-bottom:18px;
}
.speech::after{
  content:"";position:absolute;left:50%;bottom:-30px;transform:translateX(-50%);
  border:24px solid transparent;border-top-color:var(--red);border-bottom:0;
}

/* CTA bridge text + big X button */
.cta-or{
  margin:80px auto 24px;
  font-family:'Barlow Condensed',sans-serif;font-weight:700;letter-spacing:.16em;
  text-transform:uppercase;color:var(--red);opacity:.7;font-size:.78rem;
}
.x-big{
  display:inline-flex;align-items:center;gap:18px;
  background:#000;color:#fff;
  padding:22px 36px;border-radius:999px;
  box-shadow:0 24px 50px rgba(0,0,0,.28), 0 4px 8px rgba(0,0,0,.12);
  transition:transform .18s ease, box-shadow .25s ease;
  text-decoration:none;
}
.x-big:hover{transform:translateY(-3px);box-shadow:0 30px 60px rgba(0,0,0,.34)}
.x-big-icon{
  width:48px;height:48px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  background:#fff;color:#000;flex-shrink:0;
}
.x-big-icon svg{width:24px;height:24px}
.x-big-text{display:flex;flex-direction:column;align-items:flex-start;line-height:1.05}
.x-big-handle{
  font-family:'Anton',sans-serif;font-size:1.6rem;letter-spacing:.02em;
}
.x-big-sub{
  font-family:'Barlow Condensed',sans-serif;font-weight:600;letter-spacing:.14em;
  text-transform:uppercase;font-size:.72rem;opacity:.7;margin-top:4px;
}

/* ============================================
   FOOTER
   ============================================ */
.footer{
  background:var(--cream);padding:80px 8vw 30px;text-align:center;
}
.egg{
  width:380px;height:280px;margin:0 auto 40px;
  background:radial-gradient(ellipse at 55% 50%, #fff 60%, #F0E5D2 100%);
  border-radius:50%;
  box-shadow:0 30px 30px -10px rgba(80,40,20,.18);
  position:relative;
  filter:drop-shadow(0 6px 0 #F0E5D2);
  transform:scaleX(1.4);
}
.egg .yolk{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:120px;height:120px;border-radius:50%;
  background:radial-gradient(circle at 40% 35%, #FFE17F, #E89B2E);
  box-shadow:inset -10px -10px 20px rgba(160,80,0,.3);
}
.footer-links{
  display:flex;justify-content:center;gap:60px;flex-wrap:wrap;
  font-family:'Anton',sans-serif;color:var(--red);font-size:1.4rem;letter-spacing:.04em;
  margin-top:20px;
}
.more{
  margin-top:10px;color:var(--ink);
  font-family:'Barlow Condensed',sans-serif;font-weight:700;letter-spacing:.04em;
}
.more a{color:var(--red);margin-left:8px;text-decoration:underline}
.foot-bar{
  display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:center;
  margin-top:60px;padding-top:30px;
  font-family:'Barlow Condensed',sans-serif;font-weight:700;letter-spacing:.06em;
  font-size:.78rem;color:var(--red);
}
.foot-legal{display:flex;gap:18px;justify-self:start}
.foot-legal a{text-decoration:underline}
.foot-social{display:flex;gap:18px;justify-self:end;font-size:1.1rem}
.foot-credit{justify-self:end;color:#5a3f20}
.foot-disclaimer{
  max-width:780px;margin:30px auto 0;
  font-family:'Inter',sans-serif;font-size:.78rem;line-height:1.6;
  color:#7a6b50;text-align:center;letter-spacing:.01em;
}

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width:980px){
  .nav-pill{display:none}
  .btn-x span{display:none}
  .btn-x{padding:11px;width:38px;height:38px;justify-content:center}
  .btn-x svg{width:16px;height:16px}
  .x-big{padding:18px 24px;gap:14px}
  .x-big-icon{width:40px;height:40px}
  .x-big-icon svg{width:20px;height:20px}
  .x-big-handle{font-size:1.3rem}
  .bomb-dedication{font-size:.78rem;padding:8px 16px;letter-spacing:.1em}
  .target,.ai-row,.token-row,.utility-row,.defl,.roadmap{grid-template-columns:1fr}
  .trio,.strip-cols,.foot-bar{grid-template-columns:1fr;text-align:center}
  .foot-legal,.foot-social,.foot-credit{justify-self:center}
  .target h2{justify-self:center;text-align:center}
  .cards{height:auto;display:flex;flex-direction:column;gap:24px;align-items:center;padding:20px 0}
  .card{position:relative;left:auto;top:auto;transform:none;width:80vw;max-width:340px;height:auto;aspect-ratio:340/210}
  .liz{width:calc(100px * var(--s, 1))}
  .liz-hero{width:200px}
}
