/* ============================================================
   SNAKE WIF HAT — $SSSSS  ·  static site for Cloudflare Pages
   ============================================================ */

:root{
  --cream:      #f1efe6;
  --cream-2:    #e9e6d8;
  --ink:        #111111;
  --paper:      #ffffff;
  --slate:      #5d6a61;   /* roadmap bg */
  --slate-dark: #424d46;
  --gold:       #ffc83d;
  --gold-deep:  #e9a900;
  --snek:       #c9a36a;
  --line:       3px solid var(--ink);
  --radius:     18px;
  --shadow:     6px 6px 0 var(--ink);
  --shadow-sm:  4px 4px 0 var(--ink);
  --maxw:       1120px;
  --ff-cartoon: "Luckiest Guy", system-ui, sans-serif;
  --ff-hand:    "Caveat Brush", "Comic Sans MS", cursive;
  --ff-sans:    "Roboto", system-ui, -apple-system, Segoe UI, sans-serif;
}

*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  margin:0;
  font-family: var(--ff-hand);
  font-size: 20px;
  line-height: 1.5;
  color: var(--ink);
  background: var(--cream);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img{ max-width:100%; display:block; }
a{ color: inherit; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:.4em;
  font-family: var(--ff-hand);
  font-size: 1.25rem;
  letter-spacing:.5px;
  padding:.55em 1.3em;
  border:var(--line);
  border-radius: 999px;
  background: var(--paper);
  color: var(--ink);
  text-decoration:none;
  cursor:pointer;
  box-shadow: var(--shadow-sm);
  transition: transform .12s ease, box-shadow .12s ease, background .15s ease;
}
.btn:hover{ transform: translate(-2px,-2px); box-shadow: 6px 6px 0 var(--ink); }
.btn:active{ transform: translate(2px,2px); box-shadow: 1px 1px 0 var(--ink); }
.btn--gold{ background: var(--gold); }
.btn--gold:hover{ background: var(--gold-deep); }
.btn--ghost{ background: transparent; }

/* ---------- Section titles ---------- */
.section-title{
  font-family: var(--ff-sans);
  font-weight: 900;
  letter-spacing: 1px;
  text-align:center;
  margin: 0 0 .6em;
  line-height: .95;
  font-size: clamp(2.6rem, 8vw, 5.5rem);
}
.section-title--filled{ color: var(--ink); }
.section-title--outline{
  color: transparent;
  -webkit-text-stroke: 2px var(--ink);
  text-stroke: 2px var(--ink);
}
.section-title--white{
  color: var(--paper);
  text-shadow: 3px 3px 0 rgba(0,0,0,.35);
}

/* ---------- Generic card ---------- */
.card{
  background: var(--paper);
  border: var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}

/* ============================================================
   CHAR REVEAL
   ============================================================ */
.char-reveal{ visibility: hidden; }
.char-reveal.is-ready{ visibility: visible; }
.cr-word{ display:inline-block; white-space:nowrap; }
.cr-char{
  display:inline-block;
  opacity:0;
  transform: translateY(.5em) rotate(8deg) scale(.6);
  filter: blur(4px);
}
.char-reveal.is-in .cr-char{
  animation: charIn .5s cubic-bezier(.2,.9,.3,1.3) both;
  animation-delay: var(--d, 0s);
}
@keyframes charIn{
  0%{ opacity:0; transform: translateY(.6em) rotate(10deg) scale(.5); filter: blur(5px); }
  60%{ opacity:1; filter: blur(0); }
  100%{ opacity:1; transform: translateY(0) rotate(0) scale(1); filter: blur(0); }
}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position: sticky; top:0; z-index: 50;
  display:flex; align-items:center; gap: 1.2rem;
  padding:.6rem clamp(1rem, 4vw, 2.4rem);
  background: rgba(241,239,230,.85);
  backdrop-filter: blur(8px);
  border-bottom: var(--line);
}
.nav__brand{
  display:flex; align-items:center; gap:.5rem;
  font-family: var(--ff-cartoon); font-size:1.3rem; text-decoration:none;
}
.nav__brand img{ border:2px solid var(--ink); border-radius:10px; }
.nav__links{ display:flex; gap:1.1rem; margin-left:auto; font-size:1.15rem; }
.nav__links a{ text-decoration:none; }
.nav__links a:hover{ text-decoration: underline wavy; text-underline-offset:4px; }
.nav__cta{ font-size:1.05rem; padding:.4em 1em; }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position: relative;
  background:
    radial-gradient(120% 80% at 50% -10%, #fffdf5 0%, var(--cream) 55%, var(--cream-2) 100%);
  padding: clamp(2rem, 6vw, 4rem) 1rem clamp(5rem, 9vw, 7rem);
  text-align:center;
}
.hero__inner{ max-width: 860px; margin:0 auto; }
.hero__title{
  font-family: var(--ff-cartoon);
  font-weight: 400;
  font-size: clamp(3rem, 12vw, 8rem);
  line-height: .95;
  margin: 0;
  color: #fff;
  -webkit-text-stroke: clamp(3px, .9vw, 7px) var(--ink);
  paint-order: stroke fill;
  text-shadow: 7px 8px 0 rgba(0,0,0,.18);
}
.hero__sub{
  font-size: clamp(1.1rem, 3vw, 1.6rem);
  margin:.6rem 0 1.4rem;
  opacity:.85;
}

/* hat swapper */
.swapper{
  display:flex; align-items:center; justify-content:center; gap: clamp(.4rem,2vw,1.2rem);
}
.swapper__arrow{
  flex:0 0 auto;
  width: clamp(44px, 9vw, 60px); height: clamp(44px, 9vw, 60px);
  font-size: 2rem; line-height:1;
  font-family: var(--ff-sans); font-weight:900;
  background: var(--paper); color: var(--ink);
  border: var(--line); border-radius: 50%;
  cursor:pointer; box-shadow: var(--shadow-sm);
  transition: transform .12s ease, box-shadow .12s ease, background .15s;
  display:flex; align-items:center; justify-content:center; padding-bottom:4px;
}
.swapper__arrow:hover{ background: var(--gold); transform: translateY(-2px); }
.swapper__arrow:active{ transform: scale(.92); }

.stage{
  position: relative;
  width: clamp(230px, 42vw, 380px);
  aspect-ratio: 1484 / 1530;
  cursor: pointer;
  user-select:none;
}
.stage__snake,
.stage__hat{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit: contain; object-position: center;
  pointer-events:none;
}
.stage__snake{ filter: drop-shadow(4px 8px 6px rgba(0,0,0,.18)); }
.stage__hat{ z-index:2; }
/* hat drop-in animation, retriggered by JS adding .swap */
.stage__hat.swap{ animation: hatDrop .55s cubic-bezier(.2,1.4,.35,1) both; }
@keyframes hatDrop{
  0%{ opacity:0; transform: translateY(-26%) rotate(-12deg) scale(1.08); }
  60%{ opacity:1; }
  100%{ opacity:1; transform: translateY(0) rotate(0) scale(1); }
}
.stage.idle .stage__hat{ animation: hatBob 3.2s ease-in-out infinite; }
@keyframes hatBob{ 0%,100%{ transform: translateY(0) rotate(-1deg);} 50%{ transform: translateY(-2.5%) rotate(1.5deg);} }

/* hat picker thumbnails */
.hatpicker{
  display:flex; flex-wrap:wrap; justify-content:center; gap:.55rem;
  margin: 1.4rem auto 0; max-width: 560px;
}
.hatpicker__chip{
  width: 62px; height: 62px;
  border: var(--line); border-radius: 14px;
  background: var(--paper);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; padding:5px;
  box-shadow: var(--shadow-sm);
  transition: transform .12s ease, box-shadow .12s, background .15s;
}
.hatpicker__chip img{ width:100%; height:100%; object-fit:contain; }
.hatpicker__chip:hover{ transform: translateY(-3px) rotate(-3deg); }
.hatpicker__chip.is-active{ background: var(--gold); transform: translateY(-3px); box-shadow: 2px 2px 0 var(--ink); }
.hatpicker__chip--none{ font-family: var(--ff-hand); font-size:.95rem; line-height:1.05; text-align:center; }

.hero__actions{
  display:flex; gap:.8rem; justify-content:center; flex-wrap:wrap;
  margin-top: 1.8rem;
}

/* ============================================================
   TILT dividers (the "opacity-tilt" shapes from the original)
   ============================================================ */
.tilt{ position:absolute; left:0; right:0; height: clamp(40px, 7vw, 90px); pointer-events:none; z-index:1; }
.tilt--bottom{ bottom:-1px; background: linear-gradient(to bottom left, transparent 49.6%, var(--ink) 50%); }
.tilt--top{ top:-1px; background: linear-gradient(to top right, transparent 49.6%, var(--ink) 50%); }
.tilt--dark.tilt--top{ background: linear-gradient(to top right, transparent 49.6%, var(--slate) 50%); }
.tilt--dark.tilt--bottom{ background: linear-gradient(to bottom left, transparent 49.6%, var(--slate) 50%); }

/* ============================================================
   ABOUT
   ============================================================ */
.about{ background: var(--cream); padding: clamp(2.5rem,6vw,4.5rem) 1rem; }
.about__inner{ max-width: var(--maxw); margin:0 auto; }
.about__grid{
  display:grid; grid-template-columns: 1.1fr .9fr; gap: clamp(1.5rem,4vw,3rem);
  align-items:center;
}
.about__copy h3{ font-family: var(--ff-sans); font-weight:700; font-size: clamp(1.5rem,3.5vw,2.2rem); margin:.2em 0 .4em; }
.about__copy p{ font-size:1.25rem; margin:0 0 1rem; }
.about__note strong{ color: var(--gold-deep); }
.about__img img{
  border: var(--line); border-radius: var(--radius);
  box-shadow: var(--shadow); transform: rotate(2deg);
}

/* ============================================================
   SHEDDING SEASON  (About-style card with a funky border)
   ============================================================ */
.shed{ background: var(--cream); padding: clamp(3rem, 7vw, 5.5rem) 1rem; }
.shed__inner{ max-width: var(--maxw); margin: 0 auto; }
.shed__grid{
  display: grid; grid-template-columns: .92fr 1.08fr;
  gap: clamp(1.6rem, 4vw, 3.4rem); align-items: center;
}
.shed__copy h3{
  font-family: var(--ff-sans); font-weight: 700;
  font-size: clamp(1.5rem, 3.5vw, 2.2rem); margin: .2em 0 .4em;
}
.shed__copy p{ font-size: 1.25rem; margin: 0 0 1rem; }
.shed__copy strong{ color: var(--gold-deep); }

.shed__img{ margin: 0 28px 28px 0; }   /* room for the stacked shadow */
.shed__img img{
  width: 100%;
  display: block;
  border: 6px solid var(--ink);
  border-radius: 22px;
  transform: rotate(-2deg);
  box-shadow:
    9px 9px 0 var(--gold),
    18px 18px 0 #e85d9a,
    27px 27px 0 #2b6cff;
  transition: transform .2s ease, box-shadow .2s ease;
}
.shed__img img:hover{
  transform: rotate(0);
  box-shadow:
    7px 7px 0 var(--gold),
    14px 14px 0 #e85d9a,
    21px 21px 0 #2b6cff;
}

/* ============================================================
   HOW TO BUY
   ============================================================ */
.buy{ position:relative; background: var(--paper); padding: clamp(4rem,8vw,6rem) 1rem; }
.buy__inner{ max-width: 880px; margin:0 auto; }
.steps{ display:grid; gap: 1.4rem; }
.step{ display:flex; align-items:center; gap: clamp(1rem,3vw,2rem); padding: clamp(1.1rem,3vw,1.8rem); }
.step__icon{ flex:0 0 auto; width: clamp(72px,16vw,118px); }
.step__icon img, .step__icon .pump-badge{ width:100%; border-radius:18px; }
.step__icon img{ border:2px solid var(--ink); }
.pump-badge svg{ width:100%; height:auto; border-radius:18px; border:2px solid var(--ink); display:block; }
.step__body h3{ font-family: var(--ff-sans); font-weight:700; font-size: clamp(1.4rem,3vw,2rem); margin:0 0 .25em; }
.step__body p{ margin:0; font-size:1.2rem; }
.step__body a{ color: #2b6cff; font-weight:700; }

/* ============================================================
   PARTNERS
   ============================================================ */
.partners{ background: var(--cream); padding: clamp(3rem,7vw,5rem) 1rem; }
.partners__inner{ max-width: var(--maxw); margin:0 auto; }
.partners__grid{
  display:grid; grid-template-columns: repeat(auto-fit, minmax(220px,1fr));
  gap:1.2rem;
}
.partner{
  display:flex; align-items:center; justify-content:center; text-align:center;
  min-height: 96px; padding:1rem 1.2rem;
  font-family: var(--ff-hand); font-size:1.5rem; text-decoration:none;
  border-color:#2b6cff; box-shadow: 5px 5px 0 #2b6cff;
  transition: transform .12s ease, box-shadow .12s;
}
.partner:hover{ transform: translate(-2px,-2px); box-shadow: 7px 7px 0 #2b6cff; }
.partner--soon{ color:#3aa655; font-size:2.4rem; cursor:default; }
.partner--soon:hover{ transform:none; box-shadow: 5px 5px 0 #2b6cff; }

/* ============================================================
   ROADMAP
   ============================================================ */
.roadmap{ position:relative; background: var(--slate); padding: clamp(4rem,8vw,6rem) 1rem; }
.roadmap__inner{ max-width: 900px; margin:0 auto; display:grid; gap:1.6rem; }
.phase{ padding: clamp(1.4rem,4vw,2.2rem); background: rgba(255,255,255,.06); border-color: var(--ink); }
.phase h3{
  font-family: var(--ff-sans); font-weight:700;
  font-size: clamp(1.5rem,4vw,2.3rem); margin:0 0 .6em;
  display:flex; align-items:center; gap:.4em; color: var(--ink);
}
.phase__check{ width: clamp(28px,5vw,42px); height:auto; display:inline-block; }
.phase ul{ margin:0; padding-left:1.2em; columns: 1; }
.phase li{ font-size:1.3rem; margin:.18em 0; font-weight:700; }
.phase:nth-child(2) ul{ columns:2; column-gap:2rem; }

/* ============================================================
   SNAKENOMICS
   ============================================================ */
.snakenomics{ background: var(--paper); padding: clamp(3.5rem,7vw,5.5rem) 1rem; }
.snakenomics__inner{ max-width: var(--maxw); margin:0 auto; }
.snakenomics__grid{
  display:grid; grid-template-columns: 1fr 1.1fr; gap: clamp(1.5rem,4vw,3rem); align-items:center;
}
.snakefacts{ list-style:none; margin:0; padding:0; display:grid; gap:1rem; }
.snakefacts li{
  padding:.9em 1.2em; font-size:1.5rem; text-align:center; font-weight:700;
}
.snakenomics__banner img{
  border:var(--line); border-radius: var(--radius);
  box-shadow: var(--shadow); transform: rotate(-1.5deg);
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background: var(--ink); color: var(--paper); padding: clamp(3rem,6vw,4.5rem) 1rem; }
.footer__inner{ max-width: 820px; margin:0 auto; text-align:center; }
.ca{
  display:inline-flex; align-items:center; gap:.7rem; flex-wrap:wrap; justify-content:center;
  max-width:100%;
  background:#1c1c1c; color:#fff;
  border:2px solid #fff; border-radius:14px;
  padding:.7em 1.1em; margin-bottom:1.6rem;
  cursor:pointer; font-family: var(--ff-hand); font-size:1.15rem;
  word-break: break-all;
  transition: border-color .15s, background .15s;
}
.ca:hover{ border-color: var(--gold); }
.ca__label{ color: var(--gold); font-weight:700; }
.ca__value{ letter-spacing:.3px; }
.ca__hint{ font-size:.85rem; opacity:.6; border:1px solid currentColor; border-radius:8px; padding:.05em .5em; }

.socials{ display:flex; gap:.9rem; justify-content:center; margin: 0 0 1.8rem; flex-wrap:wrap; }
.social{
  width:56px; height:56px; border-radius:14px; overflow:hidden;
  border:2px solid #fff;
  transition: transform .12s ease, box-shadow .12s;
  box-shadow: 3px 3px 0 rgba(255,255,255,.25);
}
.social img{ width:100%; height:100%; object-fit:cover; }
.social:hover{ transform: translateY(-3px) rotate(-4deg); box-shadow: 4px 6px 0 var(--gold); }

.disclaimer{ font-size:1.05rem; opacity:.8; max-width:640px; margin:0 auto 1rem; line-height:1.45; }
.copyright{ font-size:1.05rem; opacity:.65; margin:0; }

/* ============================================================
   TOAST
   ============================================================ */
.toast{
  position: fixed; left:50%; bottom: 26px; transform: translate(-50%, 140%);
  background: var(--ink); color:#fff;
  border:2px solid var(--gold); border-radius: 12px;
  padding:.7em 1.3em; font-family: var(--ff-hand); font-size:1.15rem;
  z-index: 100; box-shadow: 0 8px 30px rgba(0,0,0,.3);
  transition: transform .35s cubic-bezier(.2,1.2,.3,1);
}
.toast.show{ transform: translate(-50%, 0); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 820px){
  .nav__links{ display:none; }
  .about__grid,
  .shed__grid,
  .snakenomics__grid{ grid-template-columns: 1fr; }
  .about__img{ order:-1; max-width:420px; margin:0 auto; }
  .shed__img{ max-width:480px; margin:.5rem auto 24px; }
  .phase:nth-child(2) ul{ columns:1; }
}
@media (max-width: 480px){
  body{ font-size:18px; }
  .hatpicker__chip{ width:54px; height:54px; }
  .social{ width:50px; height:50px; }
  .shed__img img{ box-shadow: 6px 6px 0 var(--gold), 12px 12px 0 #e85d9a, 18px 18px 0 #2b6cff; }
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  .char-reveal{ visibility: visible; }
  .cr-char{ opacity:1; transform:none; filter:none; animation:none !important; }
  .stage__hat.swap,
  .stage.idle .stage__hat{ animation:none !important; }
  .btn, .partner, .social, .swapper__arrow, .hatpicker__chip{ transition:none; }
}
