/* ---------- Reset & base ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:"Space Grotesk",system-ui,sans-serif;
  font-weight:500;
  color:var(--ink);
  background:var(--cream);
  overflow-x:hidden;
  line-height:1.5;
}
img,svg{max-width:100%;display:block}
button{font:inherit;border:0;background:transparent;cursor:pointer;color:inherit}
a{color:inherit;text-decoration:none}

/* ---------- Accessibility ---------- */
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ---------- Pee-wee's Playhouse palette ---------- */
:root{
  --pink:#FF4FA1;        /* hot bubblegum */
  --cyan:#1FC8DB;        /* playhouse turquoise */
  --yellow:#FFD23F;      /* school-bus yellow */
  --green:#22C55E;       /* kelly green */
  --purple:#8B5CF6;      /* grape soda */
  --orange:#FF6B1A;      /* atomic orange */
  --red:#E63946;         /* fire-engine red */
  --mint:#7DD3C0;        /* atomic mint */
  --ink:#1B1B1F;
  --cream:#FFF3D4;       /* warm playhouse cream */
  --shadow:#1B1B1F;
  --offset:6px;
  --offset-sm:4px;
}

/* ---------- Pee-wee Playhouse background: red dots on cream ---------- */
.bg-squiggles{
  position:fixed;inset:0;z-index:-1;pointer-events:none;
  background-color:var(--cream);
  background-image:
    radial-gradient(circle, var(--red) 9px, transparent 10px),
    radial-gradient(circle, var(--cyan) 6px, transparent 7px);
  background-size:90px 90px, 90px 90px;
  background-position:0 0, 45px 45px;
}
.bg-squiggles::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(255,243,212,.55) 0%, rgba(255,243,212,.85) 100%);
  pointer-events:none;
}

/* ---------- Reusable patterns: checkerboard + polka + atomic ---------- */
.pattern-check{
  background-image:
    linear-gradient(45deg, var(--ink) 25%, transparent 25%),
    linear-gradient(-45deg, var(--ink) 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, var(--ink) 75%),
    linear-gradient(-45deg, transparent 75%, var(--ink) 75%);
  background-size:24px 24px;
  background-position:0 0, 0 12px, 12px -12px, -12px 0;
}
.pattern-dots{
  background-image:radial-gradient(circle, var(--ink) 3px, transparent 4px);
  background-size:24px 24px;
}

/* ---------- Reusable: chunky outlined block ---------- */
.block{
  background:var(--cream);
  border:3px solid var(--ink);
  box-shadow:var(--offset) var(--offset) 0 var(--ink);
  border-radius:14px;
}
.wrap{max-width:1100px;margin:0 auto;padding:0 24px}

/* ---------- Nav ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  background:var(--cream);
  border-bottom:3px solid var(--ink);
  padding:14px 0;
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}
.logo{
  font-family:"Bungee",sans-serif;
  font-size:clamp(1.1rem,3vw,1.5rem);
  letter-spacing:.02em;
  display:flex;align-items:center;gap:10px;
  color:var(--ink);
}
.logo .swirl{width:34px;height:34px;animation:spin 14s linear infinite}
.nav-cta{
  font-family:"Bungee",sans-serif;
  font-size:.85rem;
  background:var(--pink);
  color:var(--cream);
  padding:10px 16px;
  border:3px solid var(--ink);
  border-radius:10px;
  box-shadow:var(--offset-sm) var(--offset-sm) 0 var(--ink);
  transition:transform .15s,box-shadow .15s;
}
.nav-cta:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink)}
.nav-cta:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink)}

.nav-links{display:flex;align-items:center;gap:18px}
.nav-link-merch{
  font-family:"Lilita One",cursive;
  font-size:.85rem;
  color:var(--ink);
  text-decoration:underline;
  text-decoration-thickness:2px;
  text-decoration-color:var(--cyan);
  text-underline-offset:3px;
  padding:4px 2px;
  position:relative;
  transition:color .2s,text-decoration-color .2s;
}
.nav-link-merch:hover{color:var(--pink);text-decoration-color:var(--pink)}
.nav-link-merch::after{
  content:"soon";
  font-family:"Lilita One",cursive;
  font-size:.6rem;
  margin-left:5px;
  padding:1px 6px;
  background:var(--yellow);
  border:1.5px solid var(--ink);
  border-radius:999px;
  vertical-align:1px;
  text-transform:lowercase;
}
@media (max-width:640px){
  .nav-link-merch{font-size:.75rem}
}

/* ---------- Cameo logo: white pill wrapper for buttons ---------- */
.cameo-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:#fff;
  padding:6px 11px;
  border-radius:8px;
  border:2px solid var(--ink);
  box-shadow:2px 2px 0 var(--ink);
  vertical-align:middle;
  line-height:0;
  margin:0 4px;
}
.cameo-pill img{
  display:block;
  height:1em;
  width:auto;
}
.btn-mega .cameo-pill{padding:8px 13px}
.btn-mega .cameo-pill img{height:1.05em}
.nav-cta .cameo-pill{padding:5px 9px}
.nav-cta .cameo-pill img{height:.9em}

/* Inline (no pill): just the wordmark in body prose */
.cameo-inline{
  display:inline-block;
  height:.95em;
  width:auto;
  vertical-align:middle;
  margin:0 4px;
  position:relative;
  top:-1px;
}

/* ---------- Mega Cameo CTA ---------- */
.btn-mega{
  font-family:"Bungee",sans-serif;
  font-size:clamp(1.1rem,3.4vw,1.7rem);
  background:var(--pink);
  color:var(--cream);
  padding:24px 40px;
  border:5px solid var(--ink);
  border-radius:20px;
  box-shadow:10px 10px 0 var(--ink);
  display:inline-flex;align-items:center;gap:14px;
  transition:transform .15s,box-shadow .15s,background .2s;
  text-transform:uppercase;letter-spacing:.04em;
  position:relative;
}
.btn-mega::before{
  content:"";
  position:absolute;
  inset:-14px -14px auto auto;
  width:40px;height:40px;
  background:var(--yellow);
  border:3px solid var(--ink);
  border-radius:50%;
  box-shadow:3px 3px 0 var(--ink);
  z-index:-1;
}
.btn-mega:hover{transform:translate(-4px,-4px);box-shadow:14px 14px 0 var(--ink);background:var(--orange)}
.btn-mega:active{transform:translate(4px,4px);box-shadow:4px 4px 0 var(--ink)}
.btn-mega .arrow{display:inline-block;font-size:1.2em;transition:transform .2s}
.btn-mega:hover .arrow{transform:translateX(6px)}

/* ---------- Asymmetric Pee-wee accents ---------- */
.atomic-starburst{
  position:absolute;
  pointer-events:none;
  animation:atomic-spin 22s linear infinite;
}
@keyframes atomic-spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
.kidney-blob{
  position:absolute;
  pointer-events:none;
  z-index:-1;
}
.googly-eyes{
  position:absolute;
  display:flex;
  gap:14px;
  pointer-events:none;
}
.googly{
  width:42px;height:42px;
  background:var(--cream);
  border:3px solid var(--ink);
  border-radius:50%;
  position:relative;
  box-shadow:3px 3px 0 var(--ink);
}
.googly::after{
  content:"";
  position:absolute;
  width:18px;height:18px;
  background:var(--ink);
  border-radius:50%;
  top:30%;left:30%;
  animation:googly-roll 4s ease-in-out infinite;
}
.googly:nth-child(2)::after{animation-delay:.6s;animation-duration:5.2s}
@keyframes googly-roll{
  0%{top:30%;left:30%}
  25%{top:42%;left:55%}
  50%{top:55%;left:35%}
  75%{top:35%;left:50%}
  100%{top:30%;left:30%}
}
.tilt-l{transform:rotate(-2.5deg)}
.tilt-r{transform:rotate(2deg)}
.tilt-card-1{transform:rotate(-1.5deg)}
.tilt-card-2{transform:rotate(1deg)}
.tilt-card-3{transform:rotate(-.5deg)}

/* ---------- Terrazzo speckle accent ---------- */
.terrazzo{
  background-color:var(--cream);
  background-image:
    radial-gradient(circle at 20% 30%, var(--pink) 6px, transparent 7px),
    radial-gradient(circle at 70% 60%, var(--cyan) 5px, transparent 6px),
    radial-gradient(circle at 40% 80%, var(--yellow) 7px, transparent 8px),
    radial-gradient(circle at 85% 25%, var(--green) 4px, transparent 5px),
    radial-gradient(circle at 15% 70%, var(--orange) 5px, transparent 6px),
    radial-gradient(circle at 55% 15%, var(--purple) 6px, transparent 7px);
  background-size:200px 200px,180px 180px,220px 220px,160px 160px,210px 210px,170px 170px;
}

/* ---------- Section divider: zigzag ---------- */
.zigzag{
  display:block;width:100%;height:24px;
  background:var(--ink);
  -webkit-mask:linear-gradient(135deg,transparent 50%,#000 50%) 0 0/12px 24px repeat-x,
    linear-gradient(45deg,transparent 50%,#000 50%) 0 0/12px 24px repeat-x;
  mask:linear-gradient(135deg,transparent 50%,#000 50%) 0 0/12px 24px repeat-x,
    linear-gradient(45deg,transparent 50%,#000 50%) 0 0/12px 24px repeat-x;
  margin:30px 0;
}

/* ---------- Reel: center video properly ---------- */
.reel{
  max-width:600px;
}

/* ---------- Interactive cursor ---------- */
.cursor-dot,
.cursor-ring{
  position:fixed;
  top:0;left:0;
  pointer-events:none;
  z-index:9999;
  transform:translate(-50%,-50%);
  will-change:transform;
}
.cursor-dot{
  font-size:48px;
  line-height:1;
  display:grid;place-items:center;
  filter:drop-shadow(2px 3px 0 var(--ink));
  user-select:none;
  transition:font-size .2s,transform .12s linear;
  transform:translate(-50%,-50%) rotate(-8deg);
  font-family:"Apple Color Emoji","Segoe UI Emoji","Noto Color Emoji",sans-serif;
}
.cursor-ring{
  width:42px;height:42px;
  border:3px solid var(--pink);
  border-radius:50%;
  transition:transform .12s linear,width .25s,height .25s,border-color .2s,background .2s;
  background:rgba(255,79,161,.06);
}
.cursor-trail{
  position:fixed;
  top:0;left:0;
  pointer-events:none;
  z-index:9998;
  width:10px;height:10px;
  border-radius:50%;
  transform:translate(-50%,-50%);
  animation:cursor-trail-fade .8s ease-out forwards;
}
@keyframes cursor-trail-fade{
  0%{opacity:.9;transform:translate(-50%,-50%) scale(1)}
  100%{opacity:0;transform:translate(-50%,-50%) scale(.2)}
}
.cursor-active .cursor-dot{font-size:60px;animation:cursor-wiggle .5s ease-in-out infinite}
@keyframes cursor-wiggle{
  0%,100%{transform:translate(-50%,-50%) rotate(-8deg)}
  50%{transform:translate(-50%,-50%) rotate(8deg)}
}
.cursor-active .cursor-ring{
  width:60px;height:60px;
  border-color:var(--yellow);
  background:rgba(255,210,63,.12);
}
.cursor-click .cursor-ring{
  animation:cursor-click .35s ease-out;
}
@keyframes cursor-click{
  0%{transform:translate(-50%,-50%) scale(.5)}
  60%{transform:translate(-50%,-50%) scale(1.4)}
  100%{transform:translate(-50%,-50%) scale(1)}
}
@media (hover:none),(pointer:coarse),(prefers-reduced-motion:reduce){
  .cursor-dot,.cursor-ring,.cursor-trail{display:none !important}
  body{cursor:auto !important}
}
@media (hover:hover) and (pointer:fine){
  body{cursor:none}
  body a,body button,body [role=button],body summary,body input,body textarea{cursor:none}
}

/* ---------- Sub-nav (topic links) ---------- */
.sub-nav{
  background:var(--cream);
  border-bottom:3px solid var(--ink);
  padding:10px 0;
  overflow-x:auto;
}
.sub-nav-inner{
  display:flex;gap:10px;flex-wrap:nowrap;justify-content:center;min-width:max-content;padding:0 16px;
}
.sub-nav a{
  font-family:"Bungee",sans-serif;
  font-size:.7rem;
  background:var(--cream);
  border:2px solid var(--ink);
  border-radius:8px;
  padding:6px 12px;
  white-space:nowrap;
  box-shadow:2px 2px 0 var(--ink);
  transition:transform .15s,background .2s,color .2s;
  text-transform:uppercase;
}
.sub-nav a:hover{background:var(--yellow);transform:translate(-2px,-2px);box-shadow:4px 4px 0 var(--ink)}
.sub-nav a[aria-current="page"]{background:var(--pink);color:var(--cream)}

/* ---------- Breadcrumbs ---------- */
.breadcrumbs{
  font-family:"Lilita One",cursive;
  font-size:.95rem;
  padding:18px 0 0;
  color:var(--ink);
  opacity:.85;
}
.breadcrumbs ol{list-style:none;display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.breadcrumbs li::after{content:"›";margin-left:8px;opacity:.5}
.breadcrumbs li:last-child::after{content:""}
.breadcrumbs a{text-decoration:underline;text-decoration-thickness:2px;text-decoration-color:var(--pink)}
.breadcrumbs [aria-current="page"]{font-weight:bold}

/* ---------- Hero ---------- */
.hero{position:relative;padding:60px 0 80px;overflow:hidden}
.hero h1{
  font-family:"Bungee",sans-serif;
  font-size:clamp(2.5rem,9vw,6.5rem);
  line-height:.95;
  letter-spacing:-.01em;
  text-align:center;
  text-transform:uppercase;
  text-shadow:
    4px 4px 0 var(--cyan),
    8px 8px 0 var(--ink);
  color:var(--yellow);
  -webkit-text-stroke:3px var(--ink);
  animation:wobble 3s ease-in-out infinite;
}
.hero h1 .lo{display:inline-block;animation:bounce 1.6s ease-in-out infinite}
.hero h1 .lo:nth-child(2){animation-delay:.1s;color:var(--pink);text-shadow:4px 4px 0 var(--cyan),8px 8px 0 var(--ink)}
.hero h1 .lo:nth-child(3){animation-delay:.2s;color:var(--green);text-shadow:4px 4px 0 var(--purple),8px 8px 0 var(--ink)}
.hero h1 .lo:nth-child(4){animation-delay:.3s;color:var(--orange);text-shadow:4px 4px 0 var(--cyan),8px 8px 0 var(--ink)}
.hero p.tag{
  font-family:"Lilita One",cursive;
  font-size:clamp(1.1rem,2.6vw,1.6rem);
  text-align:center;
  margin:20px auto 30px;
  max-width:720px;
  background:var(--cream);
  display:inline-block;
  padding:8px 18px;
  border:3px solid var(--ink);
  border-radius:999px;
  box-shadow:4px 4px 0 var(--ink);
  transform:rotate(-1.5deg);
}
.tag-wrap{text-align:center}
.intro-prose{
  font-family:"Space Grotesk",system-ui,sans-serif;
  font-size:clamp(1rem,2vw,1.15rem);
  text-align:center;
  max-width:760px;
  margin:24px auto 0;
  line-height:1.6;
}
.hero .ctas{display:flex;flex-wrap:wrap;justify-content:center;gap:16px;margin-top:24px}

/* ---------- Buttons ---------- */
.btn-primary{
  font-family:"Bungee",sans-serif;
  font-size:clamp(1rem,2.4vw,1.2rem);
  background:var(--pink);
  color:var(--cream);
  padding:18px 28px;
  border:4px solid var(--ink);
  border-radius:14px;
  box-shadow:var(--offset) var(--offset) 0 var(--ink);
  display:inline-flex;align-items:center;gap:10px;
  transition:transform .15s,box-shadow .15s,background .2s;
  text-transform:uppercase;letter-spacing:.04em;
}
.btn-primary:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--ink);background:var(--orange)}
.btn-primary:active{transform:translate(3px,3px);box-shadow:3px 3px 0 var(--ink)}
.btn-primary .arrow{display:inline-block;transition:transform .2s}
.btn-primary:hover .arrow{transform:translateX(4px)}

.btn-flush{
  font-family:"Bungee",sans-serif;
  font-size:1rem;
  background:var(--cyan);
  color:var(--ink);
  padding:18px 24px;
  border:4px solid var(--ink);
  border-radius:14px;
  box-shadow:var(--offset) var(--offset) 0 var(--ink);
  display:inline-flex;align-items:center;gap:10px;
  transition:transform .15s,box-shadow .15s;
  text-transform:uppercase;
}
.btn-flush:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--ink);background:var(--green)}
.btn-flush:active{transform:translate(3px,3px);box-shadow:3px 3px 0 var(--ink)}
.btn-flush.flushing{animation:shake .4s ease-in-out 4}

/* ---------- Floating squiggles ---------- */
.float{position:absolute;pointer-events:none;animation:float 6s ease-in-out infinite}
.float.f1{top:8%;left:6%;width:80px;animation-delay:0s}
.float.f2{top:18%;right:8%;width:90px;animation-delay:.6s}
.float.f3{bottom:10%;left:10%;width:70px;animation-delay:1.2s}
.float.f4{bottom:16%;right:12%;width:100px;animation-delay:1.8s}
.float.f5{top:50%;left:2%;width:60px;animation-delay:2.4s}
.float.f6{top:55%;right:3%;width:60px;animation-delay:3s}

/* ---------- Toilet stage ---------- */
.toilet-stage{
  position:relative;
  margin:30px auto 0;
  width:min(280px,60vw);
  aspect-ratio:1;
  background:var(--purple);
  border:4px solid var(--ink);
  border-radius:24px;
  box-shadow:8px 8px 0 var(--ink);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  animation:tilt 4s ease-in-out infinite;
}
.toilet-stage::before{
  content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(45deg,transparent 0 16px,rgba(255,255,255,.08) 16px 18px);
  pointer-events:none;
}
.toilet-stage svg{width:60%;height:60%;filter:drop-shadow(0 4px 0 var(--ink))}
.toilet-stage img{
  width:100%;height:100%;
  object-fit:cover;
  filter:drop-shadow(0 4px 0 var(--ink));
}
.toilet-stage .stage-label{
  position:absolute;bottom:10px;left:50%;transform:translateX(-50%);
  font-family:"Bungee",sans-serif;
  font-size:.65rem;
  background:var(--cream);
  color:var(--ink);
  padding:4px 10px;
  border:2px solid var(--ink);
  border-radius:6px;
  text-transform:uppercase;
  letter-spacing:.1em;
  white-space:nowrap;
}

/* ---------- Section base ---------- */
section{padding:80px 0;position:relative}
.section-title{
  font-family:"Bungee",sans-serif;
  font-size:clamp(1.8rem,5vw,3rem);
  text-align:center;
  margin-bottom:14px;
  text-transform:uppercase;
  color:var(--ink);
}
.section-title .accent{color:var(--pink)}
.section-sub{
  font-family:"Lilita One",cursive;
  text-align:center;
  font-size:clamp(1rem,2vw,1.2rem);
  color:var(--ink);
  opacity:.85;
  margin-bottom:50px;
}

/* ---------- Bit grid (3 cards) ---------- */
.bit-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px}
.card{padding:28px 24px;position:relative;transition:transform .2s,box-shadow .2s}
.card:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--ink)}
.card .icon{
  width:64px;height:64px;
  border:3px solid var(--ink);border-radius:50%;
  display:grid;place-items:center;
  margin-bottom:18px;
  font-size:1.8rem;
  box-shadow:4px 4px 0 var(--ink);
}
.card.c1 .icon{background:var(--pink);color:var(--cream)}
.card.c2 .icon{background:var(--cyan);color:var(--ink)}
.card.c3 .icon{background:var(--yellow);color:var(--ink)}
.card h3{font-family:"Bungee",sans-serif;font-size:1.15rem;margin-bottom:10px;text-transform:uppercase}
.card p{font-size:1rem;line-height:1.55}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;align-items:stretch}
.step{padding:30px 24px;text-align:center;position:relative}
.step .num{
  font-family:"Bungee",sans-serif;
  font-size:3rem;
  color:var(--cream);
  -webkit-text-stroke:3px var(--ink);
  text-shadow:4px 4px 0 var(--pink);
  margin-bottom:12px;line-height:1;
}
.step:nth-child(2) .num{text-shadow:4px 4px 0 var(--cyan)}
.step:nth-child(3) .num{text-shadow:4px 4px 0 var(--green)}
.step h4{font-family:"Bungee",sans-serif;font-size:1rem;text-transform:uppercase;margin-bottom:8px}
.step p{font-size:.95rem;line-height:1.5}

/* ---------- Catchphrases ---------- */
.phrases{
  background:var(--purple);
  border:4px solid var(--ink);
  border-radius:24px;
  box-shadow:10px 10px 0 var(--ink);
  padding:50px 30px;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.phrases::before{
  content:"";position:absolute;inset:0;opacity:.18;pointer-events:none;
  background-image:
    radial-gradient(circle at 10% 20%, var(--cream) 3px, transparent 4px),
    radial-gradient(circle at 80% 70%, var(--cream) 3px, transparent 4px),
    radial-gradient(circle at 40% 80%, var(--cream) 3px, transparent 4px);
  background-size:120px 120px,140px 140px,160px 160px;
}
.phrases .phrase-quote{
  font-family:"Bungee",sans-serif;
  font-size:clamp(1.4rem,4.5vw,2.6rem);
  color:var(--yellow);
  text-shadow:4px 4px 0 var(--ink);
  -webkit-text-stroke:2px var(--ink);
  line-height:1.1;
  margin-bottom:18px;
  text-transform:uppercase;
  position:relative;
}
.phrases .phrase-attrib{font-family:"Lilita One",cursive;color:var(--cream);font-size:1.1rem}
.phrase-track{position:relative;min-height:160px;display:grid;place-items:center}
.phrase{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;opacity:0;transform:translateY(20px);transition:opacity .5s,transform .5s}
.phrase.active{opacity:1;transform:translateY(0)}

/* ---------- Video carousel ---------- */
.reel{
  position:relative;
  max-width:660px;
  margin:0 auto;
}
.reel-stage{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:0;
  width:100%;
}
.reel-stage .reel-arrow.prev{margin-right:18px}
.reel-stage .reel-arrow.next{margin-left:28px}
.reel-frame{
  position:relative;
  flex:1 1 auto;
  max-width:480px;
  margin-bottom:10px;
  background:var(--ink);
  border:4px solid var(--ink);
  border-radius:24px;
  box-shadow:10px 10px 0 var(--ink);
  overflow:hidden;
  aspect-ratio:9/16;
  max-height:78vh;
}
.reel-track{position:absolute;inset:0;display:flex;transition:transform .45s cubic-bezier(.22,.61,.36,1);will-change:transform}
.reel-slide{flex:0 0 100%;position:relative;background:var(--ink)}
.reel-slide video{width:100%;height:100%;object-fit:cover;background:var(--ink);display:block}
.reel-slide .play-overlay{
  position:absolute;inset:0;
  display:grid;place-items:center;
  background:rgba(14,11,22,.25);
  cursor:pointer;
  transition:background .2s,opacity .2s;
}
.reel-slide.playing .play-overlay{opacity:0;pointer-events:none}
.play-circle{
  width:96px;height:96px;
  background:var(--yellow);
  border:4px solid var(--ink);
  border-radius:50%;
  box-shadow:6px 6px 0 var(--ink);
  display:grid;place-items:center;
  transition:transform .15s,background .2s;
}
.play-circle svg{width:46px;height:46px;display:block;margin-left:6px}
.reel-slide .play-overlay:hover .play-circle{transform:translate(-2px,-2px) scale(1.05);background:var(--orange)}
.reel-slide .play-overlay:active .play-circle{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink)}
.reel-arrow{
  position:static;
  flex:0 0 auto;
  width:54px;height:54px;
  background:var(--cream);
  border:3px solid var(--ink);
  border-radius:50%;
  box-shadow:4px 4px 0 var(--ink);
  display:grid;place-items:center;
  font-family:"Bungee",sans-serif;
  font-size:1.4rem;
  z-index:5;
  transition:transform .15s,box-shadow .15s,background .2s;
}
.reel-arrow:hover{background:var(--yellow);transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink)}
.reel-arrow:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink)}
.reel-arrow:disabled{opacity:.45;cursor:not-allowed}
.reel-dots{display:flex;justify-content:center;gap:10px;margin-top:22px}
.reel-dots button{
  width:14px;height:14px;
  background:var(--cream);
  border:2px solid var(--ink);
  border-radius:50%;
  box-shadow:2px 2px 0 var(--ink);
  transition:background .2s,transform .15s;
}
.reel-dots button.active{background:var(--pink);transform:scale(1.18)}
.reel-counter{text-align:center;margin-top:14px;font-family:"Bungee",sans-serif;font-size:.85rem;color:var(--ink);opacity:.7}

/* ---------- Contact ---------- */
.contact-card{
  max-width:680px;margin:0 auto;text-align:center;
  padding:48px 30px;
  background:var(--cyan);
  border:4px solid var(--ink);
  border-radius:24px;
  box-shadow:10px 10px 0 var(--ink);
  position:relative;overflow:hidden;
}
.contact-card::before{
  content:"";position:absolute;inset:0;opacity:.2;pointer-events:none;
  background-image:repeating-linear-gradient(-45deg,var(--ink) 0 2px,transparent 2px 18px);
}
.contact-card h2{
  font-family:"Bungee",sans-serif;
  font-size:clamp(1.6rem,4.5vw,2.4rem);
  text-transform:uppercase;
  margin-bottom:10px;
  position:relative;
  color:var(--ink);
}
.contact-card .blurb{
  font-family:"Lilita One",cursive;
  font-size:clamp(1rem,2.2vw,1.2rem);
  margin-bottom:24px;position:relative;color:var(--ink);
}
.email-btn{
  font-family:"Bungee",sans-serif;
  font-size:clamp(.95rem,2.4vw,1.2rem);
  background:var(--yellow);
  color:var(--ink);
  padding:16px 26px;
  border:4px solid var(--ink);
  border-radius:14px;
  box-shadow:var(--offset) var(--offset) 0 var(--ink);
  display:inline-flex;align-items:center;gap:10px;
  transition:transform .15s,box-shadow .15s,background .2s;
  text-transform:none;letter-spacing:.01em;
  position:relative;word-break:break-all;
}
.email-btn:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--ink);background:var(--pink);color:var(--cream)}
.email-btn:active{transform:translate(3px,3px);box-shadow:3px 3px 0 var(--ink)}
.email-btn .at{display:inline-block;animation:wobble 3s ease-in-out infinite}

/* ---------- FAQ ---------- */
.faq-list{display:flex;flex-direction:column;gap:14px;max-width:780px;margin:0 auto}
.faq-item{
  background:var(--cream);
  border:3px solid var(--ink);
  border-radius:12px;
  box-shadow:5px 5px 0 var(--ink);
  overflow:hidden;
}
.faq-q{
  width:100%;text-align:left;
  padding:18px 22px;
  font-family:"Bungee",sans-serif;
  font-size:.95rem;text-transform:uppercase;
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  cursor:pointer;
}
.faq-q .toggle{
  font-family:"Bungee",sans-serif;
  background:var(--yellow);
  border:2px solid var(--ink);
  border-radius:8px;
  width:32px;height:32px;
  display:grid;place-items:center;
  flex:0 0 auto;
  transition:transform .2s,background .2s;
}
.faq-item[open] .faq-q .toggle{transform:rotate(45deg);background:var(--pink);color:var(--cream)}
.faq-a{padding:0 22px 20px;font-size:1rem;line-height:1.55}

/* ---------- Final CTA ---------- */
.final-cta{
  text-align:center;padding:80px 24px;
  background:var(--yellow);
  border:4px solid var(--ink);
  border-radius:24px;
  box-shadow:10px 10px 0 var(--ink);
  margin:40px auto;
  max-width:1052px;
  position:relative;overflow:hidden;
}
.final-cta::before{
  content:"";position:absolute;inset:0;opacity:.15;pointer-events:none;
  background-image:repeating-linear-gradient(45deg,var(--ink) 0 2px,transparent 2px 18px);
}
.final-cta h2{font-family:"Bungee",sans-serif;font-size:clamp(1.8rem,5vw,3rem);text-transform:uppercase;margin-bottom:12px;position:relative}
.final-cta p{font-family:"Lilita One",cursive;font-size:clamp(1.1rem,2.4vw,1.4rem);margin-bottom:30px;position:relative}
.final-cta .btn-primary{position:relative;z-index:1}

/* ---------- Footer ---------- */
footer{text-align:center;padding:60px 24px 40px;border-top:3px solid var(--ink);margin-top:40px}
footer .signoff{
  font-family:"Bungee",sans-serif;
  font-size:clamp(1.1rem,3vw,1.6rem);
  text-transform:uppercase;
  margin-bottom:10px;
  display:inline-block;
  padding:8px 16px;
  background:var(--pink);
  color:var(--cream);
  border:3px solid var(--ink);
  border-radius:10px;
  box-shadow:4px 4px 0 var(--ink);
  transform:rotate(-1.5deg);
}
footer p{font-size:.9rem;margin-top:14px;opacity:.7}
footer a{text-decoration:underline}

/* ---------- Landing-page article styles ---------- */
.article-hero{
  padding:50px 0 30px;
  text-align:center;
}
.article-hero h1{
  font-family:"Bungee",sans-serif;
  font-size:clamp(1.9rem,5.5vw,3.2rem);
  line-height:1.05;
  text-transform:uppercase;
  color:var(--ink);
  -webkit-text-stroke:0;
  text-shadow:none;
  animation:none;
  margin-bottom:18px;
  max-width:900px;margin-left:auto;margin-right:auto;
  padding:0 24px;
}
.article-hero h1 .pop{color:var(--pink);text-shadow:3px 3px 0 var(--ink)}
.article-hero .lede{
  font-family:"Lilita One",cursive;
  font-size:clamp(1.1rem,2.5vw,1.4rem);
  max-width:740px;margin:0 auto;padding:0 24px;
  line-height:1.45;
}
.prose{
  font-family:"Space Grotesk",system-ui,sans-serif;
  font-size:1.05rem;line-height:1.7;
  max-width:760px;margin:0 auto;padding:0 24px;
}
.prose p{margin-bottom:1.1em}
.prose h2{
  font-family:"Bungee",sans-serif;
  font-size:clamp(1.4rem,3.5vw,2rem);
  margin:48px 0 16px;
  text-transform:uppercase;
}
.prose h3{
  font-family:"Bungee",sans-serif;
  font-size:clamp(1.1rem,2.6vw,1.4rem);
  margin:32px 0 10px;
  text-transform:uppercase;
  color:var(--ink);
}
.prose ul,.prose ol{margin:0 0 1.1em 1.4em}
.prose li{margin-bottom:.4em}
.prose a{
  color:var(--ink);
  text-decoration:underline;
  text-decoration-thickness:2px;
  text-decoration-color:var(--pink);
  font-weight:bold;
}
.prose a:hover{background:var(--yellow);text-decoration-color:var(--ink)}
.prose strong{font-weight:700}
.prose blockquote{
  border-left:4px solid var(--pink);
  padding:10px 18px;
  margin:1.4em 0;
  background:rgba(255,255,255,.6);
  border-radius:0 12px 12px 0;
  font-family:"Lilita One",cursive;
}

/* ---------- Quick-answer table (PAA hijack) ---------- */
.qa-table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  border:3px solid var(--ink);
  border-radius:12px;
  overflow:hidden;
  margin:24px 0;
  background:var(--cream);
  box-shadow:5px 5px 0 var(--ink);
}
.qa-table th,.qa-table td{
  padding:12px 16px;
  text-align:left;
  border-bottom:2px solid var(--ink);
  font-size:.95rem;
  vertical-align:top;
}
.qa-table tr:last-child td{border-bottom:0}
.qa-table th{
  background:var(--cyan);
  font-family:"Bungee",sans-serif;
  text-transform:uppercase;
  font-size:.8rem;
}

/* ---------- Joke library ---------- */
.joke-cat{
  margin:36px 0 18px;
  font-family:"Bungee",sans-serif;
  font-size:1.1rem;
  text-transform:uppercase;
  background:var(--yellow);
  display:inline-block;
  padding:6px 14px;
  border:3px solid var(--ink);
  border-radius:10px;
  box-shadow:3px 3px 0 var(--ink);
  transform:rotate(-1.2deg);
}
.joke{
  background:var(--cream);
  border:3px solid var(--ink);
  border-radius:12px;
  box-shadow:4px 4px 0 var(--ink);
  padding:14px 18px;
  margin-bottom:14px;
  font-family:"Space Grotesk",system-ui,sans-serif;
}
.joke .q{font-weight:700;display:block;margin-bottom:6px}
.joke .a{display:block;color:var(--ink);opacity:.9}

/* ---------- Age-section grid (birthday page) ---------- */
.age-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;
  margin:24px 0;
}
.age-card{
  background:var(--cream);
  border:3px solid var(--ink);
  border-radius:14px;
  box-shadow:5px 5px 0 var(--ink);
  padding:22px 20px;
}
.age-card h3{
  font-family:"Bungee",sans-serif;
  font-size:1rem;
  text-transform:uppercase;
  margin-bottom:8px;
  color:var(--pink);
}
.age-card p{font-size:.95rem;line-height:1.5}

/* ---------- Inline CTA card ---------- */
.inline-cta{
  background:var(--green);
  border:3px solid var(--ink);
  border-radius:14px;
  box-shadow:5px 5px 0 var(--ink);
  padding:24px;
  margin:32px 0;
  text-align:center;
}
.inline-cta p{font-family:"Lilita One",cursive;font-size:1.15rem;margin-bottom:14px}
.inline-cta .btn-primary{font-size:1rem;padding:14px 22px}

/* ---------- Animations ---------- */
@keyframes wobble{0%,100%{transform:rotate(-.5deg)}50%{transform:rotate(.5deg)}}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes float{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-18px) rotate(8deg)}}
@keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes tilt{0%,100%{transform:rotate(-2deg)}50%{transform:rotate(2deg)}}
@keyframes shake{
  0%,100%{transform:translate(0,0) rotate(0)}
  25%{transform:translate(-4px,2px) rotate(-2deg)}
  50%{transform:translate(4px,-2px) rotate(2deg)}
  75%{transform:translate(-3px,-2px) rotate(-1deg)}
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001s !important;animation-iteration-count:1 !important;transition-duration:.001s !important}
}

/* ---------- Mobile ---------- */
@media (max-width:640px){
  .hero{padding:40px 0 60px}
  .hero .ctas{flex-direction:column;align-items:stretch;padding:0 16px}
  .btn-primary,.btn-flush{justify-content:center}
  section{padding:60px 0}
  .float{display:none}
  .final-cta{margin:20px 16px;padding:60px 24px}
  .reel-stage{gap:8px}
  .reel-arrow{width:44px;height:44px;font-size:1.1rem}
  .reel-frame{border-radius:18px;box-shadow:6px 6px 0 var(--ink)}
}
