/* ============================================================
   Baby in the Jungle — styles
   ============================================================ */

:root{
  /* fonts — Comico is commercial; drop a real Comico.woff2 via @font-face
     below and it will be used automatically, otherwise it falls back. */
  --font-jungle: "Caesar Dressing", system-ui, sans-serif;   /* big safari titles */
  --font-marker: "Darumadrop One", system-ui, sans-serif;    /* playful subheads  */
  --font-ui: "Comico", "Quicksand", system-ui, sans-serif;   /* body / UI         */

  /* palette */
  --sky:   #a7dbf0;       /* registry sky blue */
  --sky-d: #8fcde8;
  --yellow:#f4e88c;       /* offset shadow / accents */
  --yellow-d:#ecd95f;
  --cream: #fbf6ea;       /* paper background */
  --cream-2:#f4ecd8;
  --ink:   #1f1b16;       /* hand-drawn outline / text */
  --brown: #4a3110;       /* arch / wood */
  --green: #3f8f3a;       /* jungle green */
  --green-d:#2f6e2c;
  --orange:#e8531f;       /* lion / heat */
  --pink:  #efb3b0;

  --edge: 3px solid var(--ink);
  --r: 22px;
}

/* If you have the real Comico font file, uncomment & point to it:
@font-face{ font-family:"Comico"; src:url("fonts/Comico.woff2") format("woff2"); font-display:swap; }
*/

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--font-ui);
  background:var(--cream);
  color:var(--ink);
  font-size:18px;
  line-height:1.55;
  font-weight:500;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{ display:block; max-width:100%; }
a{ color:inherit; }
section{ scroll-margin-top:96px; }

.wrap{ width:min(1180px, 92vw); margin-inline:auto; }

/* ---------- shared bits ---------- */
.eyebrow{
  font-family:var(--font-marker);
  font-size:clamp(20px,2.4vw,30px);
  color:var(--green-d);
  letter-spacing:.5px;
  margin:0 0 6px;
  transform:rotate(-2deg);
}
.title-jungle{
  font-family:var(--font-jungle);
  line-height:.98;
  letter-spacing:1px;
  margin:0;
  color:var(--ink);
}
.btn{
  font-family:var(--font-ui);
  font-weight:700;
  font-size:17px;
  border:var(--edge);
  border-radius:999px;
  padding:13px 26px;
  background:var(--yellow);
  color:var(--ink);
  cursor:pointer;
  box-shadow:5px 5px 0 0 var(--ink);
  transition:transform .12s ease, box-shadow .12s ease, background .15s ease;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap:8px;
  line-height:1;
}
.btn:hover{ transform:translate(-2px,-2px); box-shadow:7px 7px 0 0 var(--ink); }
.btn:active{ transform:translate(2px,2px); box-shadow:2px 2px 0 0 var(--ink); }
.btn--sky{ background:var(--sky); }
.btn--green{ background:var(--green); color:#fff; }
.btn--block{ width:100%; justify-content:center; }

/* Loading state for buttons that wait on the network. Disables clicks,
   greys the button, and shows a small spinner before the original text. */
.btn.is-loading{
  pointer-events:none; opacity:.65;
  cursor:wait;
}
.btn.is-loading::before{
  content:""; display:inline-block;
  width:1em; height:1em; margin-right:.55em; vertical-align:-2px;
  border:2px solid currentColor; border-top-color:transparent; border-radius:50%;
  animation: btnSpin .8s linear infinite;
}
@keyframes btnSpin { to { transform: rotate(360deg); } }

/* Full-step spinner overlay used after the last quiz question while the
   server scores the answers. Slots into the .qphoto tile. */
.quiz-finishing{
  position:absolute; inset:0; display:grid; place-items:center;
  background:rgba(255,255,255,.85);
  border-radius:inherit; z-index:2;
}
.quiz-finishing__inner{
  display:flex; flex-direction:column; align-items:center; gap:14px;
  font-family:var(--font-marker); color:var(--ink); font-size:18px;
}
.quiz-finishing__inner::before{
  content:""; width:42px; height:42px;
  border:4px solid var(--ink); border-top-color:transparent; border-radius:50%;
  animation: btnSpin .8s linear infinite;
}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  background:transparent;
  border-bottom:3px solid transparent;
  transition:background .3s ease, border-color .3s ease;
}
.nav--onlight .brand{ color:var(--ink); }
.nav--ondark .brand{ color:#fff; }
.nav{ border-bottom-width:3px; border-bottom-style:solid; }
.nav__inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; padding:14px 0;
}
.brand{
  display:flex; align-items:center; gap:12px;
  font-family:var(--font-marker);
  font-size:clamp(18px,2vw,24px);
  text-decoration:none; color:#fff;
  white-space:nowrap;
}
.brand__dot{
  width:42px; height:auto; flex:none;
  filter:drop-shadow(1px 2px 0 rgba(0,0,0,.22));
}
.nav__links{ display:flex; gap:8px; }
.nav__links a{
  text-decoration:none; font-weight:700; font-size:16px; color:#fff; white-space:nowrap;
  padding:8px 16px; border-radius:999px; border:2px solid rgba(255,255,255,.7);
  transition:background .15s, border-color .15s, transform .15s, color .3s;
}
.nav__links a:hover{ background:rgba(255,255,255,.18); border-color:#fff; transform:translateY(-2px); }
.nav__burger{ display:none; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; height:175vh; background:#382608; }
.hero__stage{
  position:sticky; top:0; height:100vh; overflow:hidden;
  border-bottom:var(--edge);
}
.hero__bg{
  position:absolute; inset:0;
  background:url("/uploads/natureBG.png") center 42%/cover no-repeat;
  will-change:transform;
}
.hero__content{
  position:absolute; left:24%; right:24%; top:0; bottom:0; z-index:2;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; gap:18px; will-change:transform; padding-top:11vh;
}
.hero__welcome{
  font-family:var(--font-jungle); color:#fff;
  font-size:clamp(42px,8vw,60px); line-height:1.02; margin:0;
  text-shadow:3px 3px 0 rgba(0,0,0,.55), 0 2px 16px rgba(0,0,0,.45);
}
.hero__expecting{
  font-family:var(--font-marker); color:#fff;
  font-size:clamp(15px,1.7vw,23px); margin:0; max-width:26ch;
  text-shadow:1px 2px 0 rgba(0,0,0,.42);
}
/* Mobile: shadows almost invisible — just a hint, not a stamp.
   Desktop keeps the heavier "carved" look. */
@media (max-width:640px){
  .hero__welcome{
    text-shadow:2px 2px 0 rgba(0,0,0,.14), 0 1px 8px rgba(0,0,0,.10);
  }
  .hero__expecting{
    text-shadow:1px 1px 0 rgba(0,0,0,.12);
  }
}
.hero__arch{
  position:absolute; left:50%; top:8vh; height:118vh; width:82vmin;
  transform:translateX(-50%); transform-origin:50% 42%;
  border-radius:41vmin 41vmin 0 0;
  box-shadow:
    0 0 0 100vmax #513A10,
    inset 0 10px 24px 6px rgba(0,0,0,.28),
    inset 0 0 48px 8px rgba(0,0,0,.14);
  z-index:3; pointer-events:none; will-change:transform;
}
.hero__hint{
  position:absolute; left:50%; bottom:26px; z-index:4;
  color:#fff; font-family:var(--font-marker); font-size:16px; letter-spacing:.5px;
  animation:hintbob 1.8s ease-in-out infinite;
}
@keyframes hintbob{ 0%,100%{ transform:translate(-50%,0); } 50%{ transform:translate(-50%,8px); } }
.hero__cta{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

@keyframes bob{ 0%,100%{ transform:translateY(0) rotate(var(--rot,0deg)); } 50%{ transform:translateY(-12px) rotate(var(--rot,0deg)); } }
.floaty{ animation:bob 5s ease-in-out infinite; }

/* ============================================================
   GENERIC SECTION
   ============================================================ */
.section{ padding:clamp(64px,9vw,120px) 0; position:relative; }
.section--cream{ background:var(--cream); }

/* home page: butter background → wood brown (matches the arch) */
body.home{ background:#513A10; }
body.item-page{ background:#3f8f3a; }
.item-page .back-link,
.item-page .detail__name,
.item-page .detail__price,
.item-page .detail__body{ color:#fff; }
.item-page .detail__cat{ color:var(--yellow); }
.home .section--cream{ background:#513A10; color:var(--cream); }
.home .section--cream .title-jungle{ color:#fff; }
.home .section--cream .eyebrow{ color:var(--yellow); }
.home .section--cream .lead,
.home .section--cream .reveal-date{ color:var(--cream); }
.section--green{ background:var(--green); color:#fff; }

/* ---- grass + flowers growing up into the green section ---- */
.grass{ position:absolute; left:0; right:0; top:-32px; height:52px; pointer-events:none; }
.grass__blades{ position:absolute; bottom:-1px; left:0; width:100%; height:100%; display:block; color:var(--green); }
.grass__blades path{ fill:currentColor; }
.grass__blades--back{ color:color-mix(in srgb, var(--green) 70%, #000); }
.grass__blades--front{ color:var(--green); }
.grass__flower{ position:absolute; bottom:14px; width:46px; height:46px; transform-origin:bottom center; animation:grass-sway 3.2s ease-in-out infinite; overflow:visible; }
.grass__flower::before{ content:""; position:absolute; left:50%; top:78%; width:4px; height:26px; background:var(--green); transform:translateX(-50%); border-radius:2px; z-index:-1; }
.grass__flower:nth-child(4){ animation-delay:-.4s; }
.grass__flower:nth-child(5){ animation-delay:-1.1s; }
.grass__flower:nth-child(6){ animation-delay:-1.8s; }
.grass__flower:nth-child(7){ animation-delay:-2.4s; }
.grass__flower:nth-child(8){ animation-delay:-.8s; }
@keyframes grass-sway{ 0%,100%{ transform:rotate(-7deg); } 50%{ transform:rotate(7deg); } }
@media(prefers-reduced-motion:reduce){ .grass__flower{ animation:none; } }
.section--green .title-jungle{ color:#fff; }
.section--green .eyebrow{ color:var(--yellow); }
.section__head{ text-align:center; margin-bottom:48px; }
.section__head .title-jungle{ font-size:clamp(38px,6vw,82px); }
.lead{ font-size:clamp(18px,2vw,22px); max-width:60ch; margin:14px auto 0; }

/* welcome critter row */
.critter-row{
  display:grid; grid-template-columns:repeat(3,1fr); gap:24px;
  align-items:end; margin-top:48px;
}
.critter-card{
  border:var(--edge); border-radius:var(--r); background:#fff;
  box-shadow:8px 8px 0 var(--yellow);
  padding:26px; display:grid; place-items:center; min-height:230px;
}
.critter-card img{ width:78%; transition:transform .3s ease; }
.critter-card:hover img{ transform:scale(1.07) rotate(-3deg); }

/* ============================================================
   PANEL CARD (forms / quiz / invite)
   ============================================================ */
.panel{
  background:#fff; border:var(--edge); border-radius:var(--r);
  box-shadow:10px 10px 0 var(--ink);
  padding:clamp(24px,4vw,44px);
}

/* ---------- gender guess ---------- */
.guess-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:36px; align-items:start; }
.field{ margin-bottom:20px; }
.field label{ display:block; font-family:var(--font-marker); font-size:20px; margin-bottom:6px; }
.field input, .field select{
  width:100%; font-family:var(--font-ui); font-size:17px; font-weight:600;
  padding:13px 16px; border:var(--edge); border-radius:14px; background:var(--cream);
  color:var(--ink);
}
.field input:focus, .field select:focus{ outline:none; background:#fff; box-shadow:0 0 0 4px var(--sky); }
.field__hint{ font-family:var(--font-marker); font-size:15px; color:var(--green-d); margin:7px 0 0; }

/* title chips on the sign-in step */
.label-opt{ font-family:var(--font-ui); font-size:14px; font-weight:600; opacity:.6; }
.titlechips{ display:flex; flex-wrap:wrap; gap:8px; }
.titlechip{
  font-family:var(--font-ui); font-size:15px; font-weight:700; cursor:pointer;
  background:#fff; color:var(--ink); border:2px solid var(--ink); border-radius:999px;
  padding:8px 14px; transition:transform .1s, box-shadow .1s, background .12s;
}
.titlechip:hover{ transform:translate(-2px,-2px); box-shadow:3px 3px 0 var(--ink); }
.titlechip.sel{ background:var(--yellow); box-shadow:3px 3px 0 var(--ink); }

.prize{ text-align:center; }
.prize img{ width:88%; margin:0 auto 14px; }
.prize p{ font-family:var(--font-marker); font-size:18px; }

.thanks{
  display:none; margin-top:16px; padding:14px 18px; border:var(--edge); border-radius:14px;
  background:var(--sky); font-family:var(--font-marker); font-size:19px; text-align:center;
}
.thanks.show{ display:block; animation:pop .3s ease; }
@keyframes pop{ from{ transform:scale(.9); opacity:0; } to{ transform:scale(1); opacity:1; } }

/* tally bars */
.tally{ margin-top:60px; }
.tally h3{ font-family:var(--font-jungle); font-size:clamp(26px,3.4vw,42px); text-align:center; margin:0 0 6px; }
.tally__total{ text-align:center; font-family:var(--font-marker); font-size:20px; margin-bottom:30px; color:var(--green-d); }
.tally__cols{ display:grid; grid-template-columns:1fr 1fr; gap:40px; }
.tally__group h4{ font-family:var(--font-marker); font-size:22px; margin:0 0 16px; }
.bar{ margin-bottom:16px; }
.bar__top{ display:flex; justify-content:space-between; font-weight:700; margin-bottom:5px; }
.bar__track{ height:26px; border:var(--edge); border-radius:999px; background:var(--cream); overflow:hidden; }
.bar__fill{ height:100%; width:0; border-radius:999px; transition:width 1s cubic-bezier(.2,.8,.2,1); }
.bar__fill.boi{ background:var(--sky); }
.bar__fill.gurl{ background:var(--pink); }
.bar__fill.nick{ background:var(--yellow); }

/* ---- LIVE GUESSES redesign: tug-of-war + race ---- */
.tally__div{ height:3px; background:repeating-linear-gradient(90deg,var(--ink) 0 14px,transparent 14px 26px); opacity:.25; margin:34px 0 30px; }

/* gender tug of war */
.vs__cap, .race__cap{ font-family:var(--font-marker); font-size:20px; margin:0 0 16px; color:var(--green-d); }
.vs__cap span, .race__cap span{ font-size:16px; opacity:.7; }
.vs__head{ display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:10px; }
.vs__team{ display:flex; align-items:center; gap:10px; }
.vs__team--r{ flex-direction:row; }
.vs__emoji{ font-size:30px; line-height:1; }
.vs__name{ font-family:var(--font-jungle); font-size:clamp(34px,4.6vw,50px); color:var(--ink); }
.vs__pct{ font-family:var(--font-marker); font-size:clamp(26px,4vw,40px); line-height:1; }
.vs__team .vs__pct{ color:var(--sky-d); }
.vs__team--r .vs__pct{ color:var(--pink); }
.vs__track{
  display:flex; height:42px; border:var(--edge); border-radius:999px; overflow:hidden;
  background:var(--cream); box-shadow:4px 4px 0 var(--ink);
}
.vs__fill{ flex:0 0 auto; width:50%; height:100%; transition:width 1.1s cubic-bezier(.2,.8,.2,1); }
.vs__fill--boi{ background:var(--sky); border-right:3px solid var(--ink); }
.vs__fill--gurl{ background:var(--pink); }
.vs__names{ display:flex; justify-content:space-between; gap:24px; margin-top:14px; }
.vs__namecol{ display:flex; flex-wrap:wrap; gap:6px; flex:1; align-content:flex-start; }
.vs__namecol--r{ justify-content:flex-end; }
.namechip{
  font-family:var(--font-ui); font-size:13px; font-weight:600; line-height:1;
  padding:5px 10px; border-radius:999px; border:2px solid var(--ink); white-space:nowrap;
}
.namechip--boi{ background:var(--sky); }
.namechip--gurl{ background:var(--pink); }
@media(max-width:560px){ .namechip{ font-size:12px; padding:4px 8px; } }

/* nickname race */
.race__row{ display:flex; align-items:center; gap:16px; margin-bottom:18px; }
.race__row:last-child{ margin-bottom:0; }
.race__ava{
  flex:0 0 auto; width:54px; height:54px; display:grid; place-items:center; font-size:28px;
  background:var(--cream); border:var(--edge); border-radius:50%; box-shadow:3px 3px 0 var(--ink);
}
.race__main{ flex:1; min-width:0; }
.race__top{ display:flex; justify-content:space-between; align-items:baseline; margin-bottom:6px; }
.race__name{ font-family:var(--font-marker); font-size:21px; color:var(--ink); }
.race__pct{ font-family:var(--font-marker); font-size:22px; color:var(--green-d); }
.race__track{ height:22px; border:var(--edge); border-radius:999px; background:var(--cream); overflow:hidden; }
.race__fill{ height:100%; width:0; border-radius:999px; background:linear-gradient(90deg,var(--yellow),var(--yellow-d)); transition:width 1.1s cubic-bezier(.2,.8,.2,1); }

/* ---------- Big "Play the Game" CTA (lives under the stats panel) ---------- */
.play-cta{
  margin:48px auto 0; max-width:560px;
  text-align:center; color:#fff;
}
.play-cta__hint{
  margin:0 0 14px;
  font-family:var(--font-marker); font-size:18px; opacity:.95;
}
a.play-cta__btn, .play-cta a.play-cta__btn{
  display:inline-block !important;
  font-family:var(--font-jungle) !important;
  font-size:clamp(28px,5vw,40px) !important; line-height:1 !important;
  letter-spacing:.02em !important;
  padding:22px 44px !important;
  background:var(--yellow) !important;
  color:var(--ink) !important;
  border:var(--edge) !important; border-radius:999px !important;
  box-shadow:8px 8px 0 var(--ink) !important;
  text-decoration:none !important;
  transform:translateY(0);
  transition:transform .18s ease, box-shadow .18s ease;
  animation: ctaPulse 2.6s ease-in-out infinite;
}
a.play-cta__btn:hover{
  transform:translate(2px, 2px);
  box-shadow:5px 5px 0 var(--ink) !important;
  animation-play-state:paused;
}
a.play-cta__btn:active{
  transform:translate(6px, 6px);
  box-shadow:1px 1px 0 var(--ink) !important;
}
.play-cta__date{
  margin:18px 0 0;
  font-family:var(--font-marker); font-size:16px; opacity:.85;
}
.play-cta__date strong{ color:var(--yellow); }
@keyframes ctaPulse{
  0%, 100% { transform:translate(0,0)   scale(1);    box-shadow:8px 8px 0 var(--ink); }
  50%      { transform:translate(-2px,-2px) scale(1.025); box-shadow:10px 10px 0 var(--ink); }
}
@media (prefers-reduced-motion: reduce){
  .play-cta__btn{ animation:none; }
}
@media (max-width:540px){
  .play-cta{ margin-top:36px; }
  .play-cta__btn{ padding:18px 30px; }
}

/* ---------- Cub Quiz scoreboard ---------- */
/* Everything in this block is green — see "change all text in this section to green". */
.board, .board *{ color:var(--green-d); }
.board__cap{ font-family:var(--font-marker); font-size:20px; margin:0 0 6px; }
.board__cap span{ font-size:16px; opacity:.78; }
.board__sub{ font-size:14px; line-height:1.45; opacity:.92; margin:0 0 14px; max-width:62ch; }
.board__sub em{ font-style:italic; font-weight:700; }

.board__scroll{
  max-height:300px; overflow-y:auto;
  border:2px solid var(--ink);
  border-radius:14px;
  background:var(--cream);
  box-shadow:6px 6px 0 var(--ink);
}
.board__table{ width:100%; border-collapse:collapse; font-size:15px; }

.board__th{
  position:sticky; top:0; z-index:1;
  background:var(--cream-2);
  text-align:left; padding:10px 12px;
  font-family:var(--font-marker); font-weight:400; font-size:13px; line-height:1.25;
  border-bottom:2px solid var(--green-d);
}
.board__th--rank, .board__th--score, .board__th--time, .board__th--bonus{ text-align:center; }
.board__th--bonus{ font-size:12px; max-width:170px; }

.board__row{ border-bottom:1px dashed rgba(47,110,44,.30); }
.board__row:last-child{ border-bottom:none; }
.board__row.is-bonus{ background:rgba(244,232,140,.45); }

.board__cell{ padding:10px 12px; vertical-align:middle; }
.board__cell--rank{ text-align:center; font-family:var(--font-marker); font-size:18px; width:36px; white-space:nowrap; }
.board__cell--name{ font-weight:700; }
.board__cell--score{ text-align:center; font-family:var(--font-marker); font-size:18px; white-space:nowrap; }
.board__of{ opacity:.55; font-size:14px; }
.board__cell--time{ text-align:center; font-family:var(--font-marker); font-size:15px; white-space:nowrap; opacity:.85; }
.board__cell--bonus{ text-align:center; font-size:20px; white-space:nowrap; line-height:1; }
.board__yes, .board__no{ font-weight:900; font-size:24px; }
/* All green per request. ✗ stays green but muted so eligible names still pop. */
.board .board__yes{ color:var(--green-d); }
.board .board__no{  color:var(--green-d); opacity:.35; }

.board__empty{ text-align:center; padding:24px 12px; opacity:.7; font-family:var(--font-marker); margin:0; }

@media (max-width:520px){
  .board__th, .board__cell{ padding:8px 6px; font-size:13px; }
  .board__th--bonus{ font-size:11px; }
  .board__cell--score, .board__cell--rank{ font-size:16px; }
  .board__yes, .board__no{ font-size:20px; }
}

/* ============================================================
   TRIVIA QUIZ
   ============================================================ */
.quiz{ max-width:760px; margin-inline:auto; }
.quiz__hud{ display:flex; align-items:center; justify-content:space-between; gap:16px; margin-bottom:12px; }
.quiz__count{ font-family:var(--font-marker); font-size:20px; }
.quiz__score{ font-family:var(--font-marker); font-size:20px; background:var(--yellow); border:var(--edge); border-radius:999px; padding:4px 16px; }
.timer{ display:flex; align-items:center; gap:12px; }
.timer__num{ font-family:var(--font-marker); font-size:30px; min-width:34px; text-align:center; }
.timer__track{ width:160px; height:16px; border:var(--edge); border-radius:999px; overflow:hidden; background:var(--cream); }
.timer__fill{ height:100%; width:100%; background:var(--green); transition:width 1s linear, background .3s; }
.timer__fill.warn{ background:var(--orange); }

.quiz__q{ font-family:var(--font-marker); font-size:clamp(24px,3.2vw,34px); line-height:1.2; margin:6px 0 24px; }
.quiz__opts{ display:grid; gap:14px; }
.opt{
  text-align:left; font-family:var(--font-ui); font-weight:600; font-size:18px;
  border:var(--edge); border-radius:16px; background:var(--cream); color:var(--ink);
  padding:16px 20px; cursor:pointer; display:flex; align-items:center; gap:14px;
  transition:transform .1s, background .15s, box-shadow .12s;
}
.opt__key{ width:30px; height:30px; flex:none; border:2px solid var(--ink); border-radius:8px; display:grid; place-items:center; font-family:var(--font-marker); background:#fff; }
.opt:hover:not(:disabled){ transform:translateX(4px); background:#fff; box-shadow:4px 4px 0 var(--ink); }
.opt.correct{ background:var(--green); color:#fff; }
.opt.correct .opt__key{ background:#fff; }
.opt.wrong{ background:var(--orange); color:#fff; }
.opt:disabled{ cursor:default; }
.quiz__fact{ margin-top:18px; font-family:var(--font-marker); font-size:19px; min-height:26px; }
.quiz__next{ margin-top:22px; text-align:right; }

.quiz__start, .quiz__end{ text-align:center; }
.quiz__end{ display:none; }
.quiz__big{ font-family:var(--font-marker); font-size:clamp(40px,7vw,84px); margin:10px 0; }
.quiz__reward{ width:160px; margin:6px auto 18px; }

/* ============================================================
   BABY SHOWER (arch motif)
   ============================================================ */
.shower{ background:var(--sky); border-block:var(--edge); }
.shower__grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:48px; align-items:center; }
.arch-frame{ position:relative; }
.arch-frame img.arch{ width:100%; }
.arch-frame .arch-photo{
  position:absolute; inset:8% 9% 0 9%;
  background:url("/uploads/natureBG.png") center/cover;
  border-radius:300px 300px 0 0;
}
.arch-frame .arch-critter{ position:absolute; bottom:6%; left:50%; transform:translateX(-50%); width:55%; }

.invite h2{ font-family:var(--font-jungle); font-size:clamp(30px,4.4vw,56px); line-height:1; margin:0 0 10px; }
.invite p.intro{ font-family:var(--font-marker); font-size:19px; margin:0 0 26px; }
.dl{ display:grid; gap:16px; }
.dl__row{ background:#fff; border:var(--edge); border-radius:16px; padding:14px 18px; box-shadow:5px 5px 0 var(--yellow); }
.dl__row dt{ font-family:var(--font-marker); color:var(--green-d); font-size:16px; margin-bottom:2px; }
.dl__row dd{ margin:0; font-weight:700; font-size:18px; }
.signoff{ margin-top:24px; font-family:var(--font-marker); font-size:20px; }
.signoff strong{ display:block; font-size:24px; }

/* ============================================================
   REGISTRY
   ============================================================ */
.registry{ background:var(--sky); position:relative; }

/* ---- water-to-shore wave transition ---- */
.shore{ position:absolute; left:0; right:0; top:-76px; height:80px; overflow:hidden; pointer-events:none; }
.shore__wave{ position:absolute; left:0; bottom:-1px; width:200%; height:100%; display:block; will-change:transform; }
.shore__wave path{ fill:var(--sky); }
.shore__wave--back{ bottom:11px; opacity:.6; animation:shore-x 11s linear infinite; }
.shore__wave--back path{ fill:var(--sky-d); }
.shore__wave--crest{ bottom:5px; animation:shore-x 7s linear infinite; }
.shore__wave--crest path{ fill:color-mix(in srgb, var(--sky) 52%, #ffffff); }
.shore__wave--front{ bottom:-1px; animation:shore-x 7s linear infinite; }
@keyframes shore-x{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
@media(prefers-reduced-motion:reduce){ .shore__wave{ animation:none; } }
.tabs{ display:flex; flex-wrap:wrap; gap:12px; justify-content:center; margin-bottom:40px; }
.tab{
  font-family:var(--font-ui); font-weight:700; font-size:17px;
  border:var(--edge); border-radius:999px; background:#fff; color:var(--ink);
  padding:11px 24px; cursor:pointer; box-shadow:4px 4px 0 var(--ink);
  transition:transform .12s, box-shadow .12s, background .15s;
}
.tab:hover{ transform:translate(-2px,-2px); box-shadow:6px 6px 0 var(--ink); }
.tab.active{ background:var(--yellow); }

.cards{ display:grid; grid-template-columns:repeat(4,1fr); gap:26px; }
.card{
  background:#fff; border:var(--edge); border-radius:var(--r); overflow:hidden;
  box-shadow:8px 8px 0 var(--ink); display:flex; flex-direction:column;
  transition:transform .15s ease, box-shadow .15s ease;
}
.card:hover{ transform:translate(-3px,-3px); box-shadow:11px 11px 0 var(--ink); }
.card__img{ aspect-ratio:1/1; background:var(--sky); border-bottom:var(--edge); }
.card__img img{ width:100%; height:100%; object-fit:cover; }
.card__body{ padding:16px 18px 20px; display:flex; flex-direction:column; gap:10px; flex:1; }
.card__name{ font-weight:700; font-size:16px; line-height:1.25; min-height:2.5em; }
.card__price{ font-family:var(--font-marker); font-size:24px; color:var(--green-d); }
.card__btn{
  margin-top:auto; font-family:var(--font-ui); font-weight:700; font-size:15px;
  border:var(--edge); border-radius:999px; background:var(--yellow); color:var(--ink);
  padding:11px 14px; cursor:pointer; box-shadow:3px 3px 0 var(--ink);
  transition:transform .1s, box-shadow .1s, background .15s;
}
.card__btn:hover{ transform:translate(-1px,-1px); box-shadow:5px 5px 0 var(--ink); }
/* Claimed cards: visibly muted so people can scan past them. */
.card.claimed{ opacity:.55; }
.card.claimed:hover{ opacity:.75; }
.card.claimed .card__img{ filter:grayscale(1); }
.card.claimed .card__btn{
  background:#e9e3d6;            /* warm grey */
  color:rgba(31,27,22,.55);
  box-shadow:3px 3px 0 rgba(31,27,22,.4);
  cursor:default;
  pointer-events:none;            /* feel disabled even though the card link still works */
}
.card.claimed .card__btn:hover{ transform:none; box-shadow:3px 3px 0 rgba(31,27,22,.4); }

/* ============================================================
   NO-SHOWER NOTE
   ============================================================ */
.lazy-note{
  display:flex; align-items:center; gap:28px;
  max-width:780px; margin-inline:auto;
  background:var(--yellow); border:var(--edge); border-radius:var(--r);
  box-shadow:9px 9px 0 var(--ink); padding:28px 34px; transform:rotate(-1deg);
}
.lazy-note img{ width:118px; flex:none; }
.lazy-note h3{ font-family:var(--font-marker); font-size:clamp(22px,2.6vw,30px); margin:0 0 8px; }
.lazy-note p{ margin:0; font-size:clamp(16px,1.7vw,19px); }
.lazy-note a{ font-weight:700; text-decoration:underline; }
@media (max-width:640px){
  .lazy-note{ flex-direction:column; text-align:center; gap:14px; padding:24px; }
  .lazy-note img{ width:92px; }
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--ink); color:var(--cream); text-align:center; padding:56px 20px; }
.footer__title{ font-family:var(--font-jungle); font-size:clamp(30px,5vw,60px); color:var(--yellow); margin:0 0 10px; }
.footer__critters{ display:flex; gap:18px; justify-content:center; align-items:flex-end; margin-top:26px; flex-wrap:wrap; }
.footer__critters img{ width:64px; height:auto; }

/* ============================================================
   LIVE GUESSES — homepage stat header
   ============================================================ */
.played-pill{
  display:inline-flex; align-items:baseline; gap:9px; justify-content:center;
  background:none; color:#fff; border:none; border-radius:0;
  padding:0; font-family:var(--font-marker); font-size:clamp(17px,2vw,22px);
  box-shadow:none; margin-top:12px; opacity:.95;
}
.played-pill b{ font-family:var(--font-marker); font-weight:400; font-size:1.7em; color:var(--yellow); }
.guess-note{ text-align:center; font-family:var(--font-marker); margin-top:34px; opacity:.9; color:var(--green-d); }

/* ---- walking critters ---- */
.critter-layer{ position:absolute; top:0; left:0; width:100%; pointer-events:none; z-index:40; }
.critter{ position:absolute; left:0; will-change:transform; }
.critter__face{ will-change:transform; }
.critter img{
  display:block; transform-origin:bottom center;
  filter:drop-shadow(2px 5px 3px rgba(0,0,0,.18));
  animation-iteration-count:infinite; animation-timing-function:ease-in-out;
}
.gait-prowl{  animation-name:gait-prowl; }
.gait-hop{    animation-name:gait-hop;  animation-timing-function:cubic-bezier(.3,.7,.4,1); }
.gait-trot{   animation-name:gait-trot; }
.gait-lumber{ animation-name:gait-lumber; }
.gait-trudge{ animation-name:gait-trudge; }
.gait-stalk{  animation-name:gait-stalk; }
.gait-flop{   animation-name:gait-flop; animation-timing-function:cubic-bezier(.3,.7,.4,1); }

@keyframes gait-prowl{
  0%{ transform:translateY(0) rotate(-2deg); }
  50%{ transform:translateY(-5px) rotate(2deg); }
  100%{ transform:translateY(0) rotate(-2deg); }
}
@keyframes gait-hop{
  0%{ transform:translateY(0) scaleY(1); }
  28%{ transform:translateY(-24px) scaleY(1.06); }
  52%{ transform:translateY(0) scaleY(.88); }
  70%{ transform:translateY(-7px) scaleY(1); }
  100%{ transform:translateY(0) scaleY(1); }
}
@keyframes gait-trot{
  0%{ transform:translateY(0) rotate(-3.5deg); }
  50%{ transform:translateY(-8px) rotate(3.5deg); }
  100%{ transform:translateY(0) rotate(-3.5deg); }
}
@keyframes gait-lumber{
  0%{ transform:translateY(0) rotate(-3deg); }
  25%{ transform:translateY(-3px) rotate(0deg); }
  50%{ transform:translateY(0) rotate(3deg); }
  75%{ transform:translateY(-3px) rotate(0deg); }
  100%{ transform:translateY(0) rotate(-3deg); }
}
@keyframes gait-trudge{
  0%{ transform:translateY(0) rotate(0deg) scaleY(1); }
  50%{ transform:translateY(-3px) rotate(1.5deg) scaleY(1.02); }
  100%{ transform:translateY(0) rotate(0deg) scaleY(1); }
}
@keyframes gait-stalk{
  0%{ transform:translateY(0) rotate(-1.5deg); }
  50%{ transform:translateY(-10px) rotate(1.5deg); }
  100%{ transform:translateY(0) rotate(-1.5deg); }
}
@keyframes gait-flop{
  0%{ transform:translateY(0) scaleY(1) scaleX(1); }
  34%{ transform:translateY(-28px) scaleY(1.09) scaleX(.95); }
  60%{ transform:translateY(0) scaleY(.83) scaleX(1.12); }
  80%{ transform:translateY(-9px) scaleY(1) scaleX(1); }
  100%{ transform:translateY(0) scaleY(1) scaleX(1); }
}

/* ============================================================
   QUIZ PREVIEW — "how the game works"
   ============================================================ */
.how{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin:0 auto 40px; max-width:960px; }
.how__card{
  background:#fff; border:var(--edge); border-radius:var(--r); padding:26px 24px;
  box-shadow:8px 8px 0 var(--yellow); text-align:center; position:relative;
}
.how__round{ font-family:var(--font-marker); font-size:16px; color:var(--green-d); margin:0 0 4px; }
.how__name{ font-family:var(--font-jungle); font-size:clamp(22px,2.6vw,30px); margin:0 0 10px; }
.how__card p{ margin:0 0 14px; font-size:16px; }
.how__pts{
  display:inline-block; font-family:var(--font-marker); font-size:15px;
  background:var(--sky); border:2px solid var(--ink); border-radius:999px; padding:4px 14px;
}
.how__cta{ text-align:center; }
.how__cta .btn--green{ animation:cta-pulse 1.7s ease-in-out infinite; transform-origin:center; }
.how__cta .btn--green:hover{ animation-play-state:paused; }
@keyframes cta-pulse{
  0%,100%{ transform:translateY(0) scale(1); }
  50%{ transform:translateY(-5px) scale(1.045); }
}
@media(prefers-reduced-motion:reduce){ .how__cta .btn--green{ animation:none; } }
.reveal-date{ display:block; margin-top:16px; font-family:var(--font-marker); font-size:17px; }

/* THE PRIZE — golden treasure callout */
.prize{
  max-width:860px; margin:0 auto 40px;
  display:grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap:32px; align-items:center;
  background:linear-gradient(135deg,var(--yellow) 0%, var(--yellow-d) 100%);
  border:var(--edge); border-radius:var(--r); padding:28px 32px;
  box-shadow:8px 8px 0 var(--ink); position:relative;
}
.prize__media{
  width:100%; aspect-ratio:1; display:flex; align-items:center; justify-content:center;
  background:#a7dbf0;            /* sky var */
  border:var(--edge); border-radius:18px;
  box-shadow:6px 6px 0 var(--ink); transform:rotate(-4deg);
  overflow:hidden;
}
.prize__media img{
  width:100%; height:100%; object-fit:contain; display:block;
  /* compensate for the wrapper rotation so the cap sits straight */
  transform:rotate(4deg);
}
.prize__body{ text-align:left; }
.prize__cap{
  font-family:var(--font-marker); font-size:15px; letter-spacing:.05em; text-transform:uppercase;
  color:var(--green-d); margin:0 0 4px;
}
.prize__name{
  font-family:var(--font-jungle);
  font-size:clamp(28px,3.6vw,44px); line-height:1.05;
  margin:0 0 8px;
  color:var(--brown);
}
.prize__aside{
  margin:0 0 16px;
  font-family:var(--font-marker); font-size:14px; line-height:1.35;
  opacity:.7; font-style:italic;
  color:var(--brown);
}
.prize__copy{ margin:0; font-size:17px; line-height:1.45; color:var(--brown); }
.prize__copy strong{
  background:var(--cream); color:var(--ink); padding:1px 8px;
  border-radius:6px; box-shadow:2px 2px 0 var(--ink);
}
@media (max-width:720px){
  .prize{ grid-template-columns: 1fr; gap:22px; text-align:center; padding:22px 22px 26px; }
  .prize__media{ max-width:260px; margin:0 auto; transform:rotate(-3deg); }
  .prize__media img{ transform:rotate(3deg); }
  .prize__body{ text-align:center; }
}

/* THE MAIN GUESS — hero card */
.how-main{
  max-width:720px; margin:0 auto 14px; text-align:center;
  background:#fff; border:var(--edge); border-radius:var(--r);
  padding:38px 34px 34px; box-shadow:10px 10px 0 var(--yellow); position:relative;
}
.how-main__tag{
  font-family:var(--font-marker); font-size:15px; letter-spacing:.06em; text-transform:uppercase;
  color:var(--green-d); margin:0 0 6px;
}
.how-main__name{ font-family:var(--font-jungle); font-size:clamp(34px,5vw,52px); margin:0 0 12px; }
.how-main__copy{ margin:0 auto 18px; font-size:18px; max-width:46ch; }
.how-main .how__pts{ font-size:17px; padding:6px 18px; }

/* THE TIE-BREAKERS — subordinate */
.how-tb{ max-width:720px; margin:0 auto 40px; }
.how-tb__label{
  text-align:center; font-family:var(--font-marker); font-size:16px;
  color:var(--green-d); opacity:.85; margin:0 0 18px;
}
.how-tb__grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.how__card--mini{
  background:transparent; box-shadow:5px 5px 0 var(--yellow);
  padding:20px 20px 22px; opacity:.92;
}
.how__card--mini .how__name{ font-size:clamp(19px,2vw,23px); margin-bottom:8px; }
.how__card--mini p{ font-size:15px; }
.how__card--mini .how__pts{ font-size:14px; padding:3px 12px; }

/* ============================================================
   MULTI-STEP QUIZ FLOW  (quiz.html)
   ============================================================ */
.flow-page{ min-height:100vh; display:flex; flex-direction:column; }
.flow-main{ flex:1; display:flex; align-items:center; justify-content:center; padding:96px 20px 48px; }
.flow{ width:min(620px,94vw); }
.step{ display:none; }
.step.active{ display:block; animation:stepin .4s ease; }
@keyframes stepin{ from{ opacity:0; transform:translateY(20px); } to{ opacity:1; transform:none; } }

.progress{
  position:fixed; top:0; left:0; right:0; z-index:60;
  display:flex; gap:6px; padding:14px 16px; background:var(--cream); border-bottom:var(--edge);
}
.progress__seg{ flex:1; height:8px; border-radius:999px; background:var(--cream-2); border:2px solid var(--ink); overflow:hidden; }
.progress__seg.done{ background:var(--green); }
.progress__seg.now{ background:var(--yellow); }

.flow__round{
  display:inline-block; font-family:var(--font-marker); font-size:18px; color:var(--green-d);
  background:none; border:none; border-radius:0; padding:0; margin-bottom:10px;
  letter-spacing:.04em;
}
.flow__q{ font-family:var(--font-jungle); font-size:clamp(30px,5vw,52px); line-height:1; margin:0 0 14px; }
.flow__sub{ font-family:var(--font-marker); font-size:18px; margin:0 0 28px; }
.signin__note{
  background:var(--cream);
  border:2px dashed var(--ink);
  border-radius:12px;
  padding:14px 16px;
  margin:0 0 22px;
  font-size:14px; line-height:1.45;
  font-family:var(--font-marker);
  color:var(--brown);
}
.signin__note strong{
  background:var(--yellow); color:var(--ink);
  padding:1px 8px; border-radius:6px;
  box-shadow:2px 2px 0 var(--ink);
  display:inline-block; margin:0 2px;
}
.flow__hint{ font-size:15px; opacity:.75; margin:18px 0 0; }

/* big tappable choices (gender / nickname) */
.choices{ display:grid; gap:16px; }
.choices.two{ grid-template-columns:1fr 1fr; }
.choices.three{ grid-template-columns:repeat(3,1fr); }
.choice{
  font-family:var(--font-marker); font-size:22px; cursor:pointer;
  background:#fff; border:var(--edge); border-radius:var(--r); padding:30px 16px;
  box-shadow:7px 7px 0 var(--ink); display:flex; flex-direction:column; align-items:center; gap:10px;
  transition:transform .12s, box-shadow .12s, background .15s;
}
.choice:hover{ transform:translate(-3px,-3px); box-shadow:10px 10px 0 var(--ink); background:var(--sky); }
.choice.sel{ background:var(--green); color:#fff; }
.choice__emoji{ font-size:46px; line-height:1; }

/* animal quiz photo + options */
.qphoto{
  aspect-ratio:4/3; width:100%; max-height:min(42vh,400px); border:var(--edge); border-radius:var(--r); overflow:hidden;
  background:var(--sky); display:grid; place-items:center; margin-bottom:14px;
  box-shadow:7px 7px 0 var(--ink); position:relative;
}
.qphoto img{ width:100%; height:100%; object-fit:contain; object-position:center; }
.qphoto__ph{ text-align:center; font-family:var(--font-marker); color:var(--brown); padding:20px; }
.qphoto__ph .big{ font-size:54px; display:block; margin-bottom:6px; }
.qgrid{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.qopt{
  font-family:var(--font-ui); font-weight:700; font-size:18px; cursor:pointer; text-align:center;
  background:var(--cream); border:var(--edge); border-radius:16px; padding:18px 12px;
  box-shadow:4px 4px 0 var(--ink); transition:transform .1s, box-shadow .1s, background .15s;
}
.qopt:hover{ transform:translate(-2px,-2px); box-shadow:6px 6px 0 var(--ink); background:#fff; }
.qopt.sel{ background:var(--yellow); }

/* sign-in + confirmation cards reuse .panel */
.flow .field input{ background:#fff; }
.err{ color:var(--orange); font-weight:700; font-size:15px; margin:6px 0 0; min-height:18px; }
.already{
  text-align:center; background:var(--sky); border:var(--edge); border-radius:var(--r);
  padding:40px 28px; box-shadow:10px 10px 0 var(--ink);
}
.already img{ width:120px; margin:0 auto 14px; }

.confirm{ text-align:center; }
.confirm__img{ width:130px; margin:0 auto 10px; }
.confirm h2{ font-family:var(--font-jungle); font-size:clamp(30px,5vw,52px); margin:0 0 18px; }
.confirm__list{
  text-align:left; background:var(--cream); border:var(--edge); border-radius:16px;
  padding:20px 24px; margin:0 0 22px; font-size:17px;
}
.confirm__list li{ margin:8px 0; }
.confirm__email{ font-family:var(--font-marker); color:var(--green-d); }
.secret{ font-family:var(--font-marker); font-size:18px; }

/* ============================================================
   REGISTRY DETAIL PAGE  (registry-item.html)
   ============================================================ */
.detail{ padding:110px 0 90px; }
.back-link{ font-family:var(--font-marker); font-size:17px; text-decoration:none; display:inline-flex; gap:8px; align-items:center; margin-bottom:24px; }
.back-link:hover{ text-decoration:underline; }

/* Prev / next pager at the bottom of the item detail page */
.detail__pager{
  margin:64px 0 16px;
  display:grid; grid-template-columns:1fr 1fr; gap:18px;
}
.detail__pager-link{
  display:flex; align-items:center; gap:14px;
  padding:16px 18px;
  background:#fff;
  border:var(--edge); border-radius:14px;
  box-shadow:5px 5px 0 var(--ink);
  text-decoration:none; color:var(--ink);
  min-width:0;
  transition:transform .15s ease, box-shadow .15s ease;
}
.detail__pager-link:hover{
  transform:translate(2px, 2px);
  box-shadow:3px 3px 0 var(--ink);
}
.detail__pager-link--next{ justify-content:flex-end; text-align:right; }
.detail__pager-arrow{
  font-family:var(--font-jungle); font-size:28px; line-height:1;
  color:var(--green-d); flex:0 0 auto;
}
.detail__pager-meta{
  display:flex; flex-direction:column; min-width:0;
}
.detail__pager-label{
  font-family:var(--font-marker); font-size:13px; letter-spacing:.05em;
  text-transform:uppercase; color:var(--green-d); opacity:.8;
}
.detail__pager-name{
  font-family:var(--font-marker); font-size:17px; font-weight:600;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
@media (max-width:560px){
  .detail__pager{ grid-template-columns:1fr; gap:12px; margin-top:44px; }
  .detail__pager-link{ padding:14px 14px; }
  .detail__pager-name{ font-size:15px; }
}
.detail__grid{ display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start; }
.detail__media{
  background:var(--sky); border:var(--edge); border-radius:var(--r); padding:32px;
  box-shadow:10px 10px 0 var(--ink);
}
.detail__media img{ width:100%; aspect-ratio:1/1; object-fit:contain; }
.detail__cat{ font-family:var(--font-marker); color:var(--green-d); font-size:17px; margin:0 0 4px; }
.detail__name{ font-family:var(--font-jungle); font-size:clamp(30px,4.4vw,52px); line-height:1; margin:0 0 12px; }
.detail__price{ font-family:var(--font-marker); font-size:30px; color:var(--ink); margin:0 0 20px; }
.detail__body{ font-size:18px; margin:0 0 26px; }
.detail__shop{ margin-bottom:34px; }

/* claim form */
.claim{ background:#fff; border:var(--edge); border-radius:var(--r); padding:30px; box-shadow:8px 8px 0 var(--yellow); }
.claim h3{ font-family:var(--font-jungle); font-size:clamp(24px,3vw,34px); margin:0 0 20px; }
.radio-cards{ display:grid; gap:12px; margin-bottom:8px; }
.radio-card{
  display:flex; align-items:center; gap:14px; cursor:pointer;
  border:var(--edge); border-radius:16px; padding:14px 18px; background:var(--cream);
  font-weight:600; transition:background .15s, box-shadow .12s, transform .1s;
}
.radio-card:hover{ background:#fff; box-shadow:4px 4px 0 var(--ink); transform:translate(-1px,-1px); }
.radio-card input{ width:22px; height:22px; accent-color:var(--green); flex:none; }
.radio-card.sel{ background:var(--yellow); }
.cond{
  display:none; margin:14px 0 0; padding:18px 20px; border:2px dashed var(--ink);
  border-radius:14px; background:var(--cream); font-size:16px;
}
.cond.show{ display:block; animation:pop .3s ease; }
.amount-row{ display:flex; gap:10px; align-items:stretch; }
.amount-row .amount-cur{ flex:0 0 96px; }
.amount-row input{ flex:1 1 0; min-width:0; -moz-appearance:textfield; appearance:textfield; }
.amount-row input::-webkit-outer-spin-button,
.amount-row input::-webkit-inner-spin-button{ -webkit-appearance:none; margin:0; }
.cond .addr{ font-weight:700; line-height:1.5; }
.cond .qr{ width:120px; margin-top:12px; border:var(--edge); border-radius:12px; }

/* --- Ship-to-address section: styled like a shipping label --- */
.ship__intro{
  margin:0 0 16px;
  font-family:var(--font-marker); font-size:20px; line-height:1.25;
  color:var(--green-d); text-align:center;
}
.ship__card{
  background:#fff; border:2px solid var(--ink); border-radius:12px;
  padding:18px 20px; box-shadow:4px 4px 0 var(--ink);
  position:relative;
}
.ship__helper{
  font-size:14px; opacity:.7; font-weight:500; margin-bottom:8px;
}
.ship__recipient{
  display:flex; flex-wrap:wrap; align-items:baseline; gap:8px 12px;
  margin-bottom:12px;
}
.ship__name{
  font-family:var(--font-marker); font-size:20px; color:var(--ink);
}
.ship__phone{
  font-size:14px; opacity:.7; font-variant-numeric:tabular-nums;
}
.ship__address{
  font-weight:700; font-size:17px; line-height:1.55;
  padding-top:12px; border-top:1px dashed rgba(31,27,22,.25);
}
.ship__note{
  margin:12px 4px 0;
  font-size:13px; font-style:italic; opacity:.7;
}

/* --- Transfer-money section: styled per-country mini-cards --- */
.transfer__intro{
  margin:0 0 16px;
  font-family:var(--font-marker); font-size:20px; line-height:1.25;
  color:var(--green-d); text-align:center;
}
.transfer__grid{
  display:grid; gap:12px;
}
.transfer__option{
  background:#fff; border:2px solid var(--ink); border-radius:12px;
  padding:14px 16px; box-shadow:4px 4px 0 var(--ink);
  position:relative;
}
.transfer__head{
  display:flex; align-items:center; gap:10px; margin-bottom:6px;
}
.transfer__flag{ font-size:22px; line-height:1; }
.transfer__country{
  font-family:var(--font-marker); font-size:17px;
  color:var(--ink);
}
.transfer__method{
  font-size:14px; opacity:.75; font-weight:500; margin-bottom:6px;
}
.transfer__details{
  font-weight:800; font-size:18px; line-height:1.45;
  font-variant-numeric:tabular-nums; letter-spacing:.01em;
  word-break:break-word;
}
@media (min-width:560px){
  /* Side-by-side on slightly wider screens — still legible on phones in landscape */
  .transfer__grid{ grid-template-columns: 1fr; }
}

.claim-done{
  text-align:center; background:var(--green); color:#fff; border:var(--edge); border-radius:var(--r);
  padding:38px 28px; box-shadow:10px 10px 0 var(--ink);
}
.claim-done h3{ font-family:var(--font-jungle); color:#fff; font-size:clamp(26px,4vw,40px); margin:0 0 14px; }
.claim-done .btn{ margin-top:18px; }

.claimed-box{ background:var(--sky); color:var(--ink); border:var(--edge); border-radius:var(--r); padding:30px; box-shadow:8px 8px 0 var(--ink); text-align:center; }
.claimed-box h3{ font-family:var(--font-marker); font-size:22px; margin:0 0 6px; }
.others{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:24px; }

/* claimed ribbon on cards */
.card{ position:relative; }
.card__claimed-tag{
  position:absolute; top:14px; right:-6px; z-index:2;
  background:var(--green); color:#fff; font-family:var(--font-marker); font-size:14px;
  padding:5px 14px; border:2px solid var(--ink); border-radius:6px; box-shadow:2px 2px 0 var(--ink);
  transform:rotate(3deg);
}
.card__teaser{ font-size:14px; opacity:.85; line-height:1.35; min-height:2.6em; }

/* ============================================================
   ADMIN  (admin.html)
   ============================================================ */
.admin-wrap{ width:min(880px,94vw); margin:0 auto; padding:120px 0 80px; }
.admin-card{ background:#fff; border:var(--edge); border-radius:var(--r); box-shadow:8px 8px 0 var(--ink); padding:28px 30px; margin-bottom:26px; }
.admin-card h2{ font-family:var(--font-jungle); font-size:30px; margin:0 0 18px; }
.admin-table{ width:100%; border-collapse:collapse; font-size:15px; }
.admin-table th, .admin-table td{ border:2px solid var(--ink); padding:8px 10px; text-align:left; }
.admin-table th{ background:var(--cream-2); font-family:var(--font-marker); }
.tix{ font-family:var(--font-marker); font-weight:700; }
.gate{ width:min(440px,92vw); margin:140px auto; text-align:center; }

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity .7s ease, transform .7s ease; }
.reveal.in{ opacity:1; transform:none; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:900px){
  .nav__links{
    position:fixed; inset:64px 0 auto 0; flex-direction:column; gap:0;
    background:var(--cream); border-bottom:var(--edge); padding:10px 6vw 18px;
    transform:translateY(-130%); transition:transform .3s ease; z-index:40;
  }
  .nav__links.open{ transform:none; }
  .nav__links a{ border-radius:12px; color:var(--ink); border-color:transparent; }
  .nav__burger{
    display:grid; place-items:center; width:46px; height:46px;
    border:var(--edge); border-radius:12px; background:var(--yellow);
    box-shadow:3px 3px 0 var(--ink); cursor:pointer; font-size:22px;
  }
  .guess-grid{ grid-template-columns:1fr; }
  .shower__grid{ grid-template-columns:1fr; }
  .arch-frame{ max-width:340px; margin:0 auto; }
  .cards{ grid-template-columns:repeat(2,1fr); gap:18px; }
  .critter-row{ gap:14px; }
  .critter-card{ padding:14px; min-height:150px; }
  .tally__cols{ grid-template-columns:1fr; gap:24px; }
  .how{ grid-template-columns:1fr; max-width:480px; }
  .how-tb__grid{ grid-template-columns:1fr; }
  .detail__grid{ grid-template-columns:1fr; gap:28px; }
  .others{ grid-template-columns:1fr; }
}
@media (max-width:560px){
  body{ font-size:16px; }
  .cards{ grid-template-columns:1fr 1fr; }
  .timer__track{ width:90px; }
  .critter--lion, .critter--seal{ display:none; }
  .card__name{ font-size:14px; }
  .choices.three{ grid-template-columns:1fr; }
  .qphoto{ max-height:34vh; }
  .qopt{ padding:14px 10px; font-size:16px; }
}
