:root{
  --cyan:#13b6c6; --coral:#ff6b5e; --grape:#9b6ef0; --grass:#2fbf63;
  --blue:#2f93f0; --yellow:#ffb01f; --pink:#ff7eb6;
  --ink:#16323d; --muted:#5e7178;
  --cyan-t:#d4f6f9; --blue-t:#dcebfe; --yellow-t:#fff0c9;
  --coral-t:#ffe0dc; --grass-t:#d7f6e2; --grape-t:#ebe2fd; --pink-t:#ffe2f0;
  --bg:#e9f8ef;
  --line:4px solid var(--ink);
  --pop:8px 8px 0 var(--ink);
  --pop-sm:5px 5px 0 var(--ink);
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  font-family:'Andika','Nunito',system-ui,sans-serif;
  background:var(--bg);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
}
.wrap{max-width:1120px;margin:0 auto;padding:0 22px}
h1,h2,h3,.display{font-family:'Quicksand',cursive;margin:0}

@keyframes kBob{0%,100%{transform:translateY(0) rotate(var(--r,0deg))}50%{transform:translateY(-12px) rotate(var(--r,0deg))}}
@keyframes kBobB{0%,100%{transform:translateY(0) rotate(var(--r,0deg))}50%{transform:translateY(-18px) rotate(var(--r,0deg))}}
@keyframes kTwinkle{0%,100%{transform:scale(1) rotate(0);opacity:.85}50%{transform:scale(1.25) rotate(20deg);opacity:1}}
@keyframes kFloatX{0%,100%{transform:translateX(0)}50%{transform:translateX(14px)}}

/* ---------- NAV ---------- */
nav.bar{display:flex;align-items:center;justify-content:space-between;padding:22px 0 10px}
.logo{display:flex;align-items:center;gap:12px;text-decoration:none}
.logo .mark{
  width:54px;height:54px;border-radius:16px;background:var(--ink);
  display:grid;place-items:center;box-shadow:3px 6px 0 rgba(0,0,0,.20);
  position:relative;flex:none;
}
.logo .mark::before{content:"";width:27px;height:27px;border-radius:50%;border:7px solid var(--yellow);background:transparent;}
.logo .mark::after{content:"";position:absolute;width:8px;height:15px;background:var(--yellow);border-radius:5px;
  right:9px;bottom:7px;transform:rotate(45deg);}
.logo .word{font-family:'Quicksand',cursive;font-weight:700;font-size:30px;line-height:1}
.logo .word .k{color:var(--cyan)} .logo .word .a{color:var(--coral)}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{font-family:'Quicksand',cursive;font-weight:700;font-size:19px;color:var(--ink);text-decoration:none}
.nav-links a:hover{color:var(--blue)}
.pill-btn{
  font-family:'Quicksand',cursive;font-weight:700;font-size:18px;color:#fff;background:var(--coral);
  border:var(--line);border-radius:30px;padding:9px 22px;box-shadow:var(--pop-sm);cursor:pointer;
  text-decoration:none;
}
.pill-btn:active{transform:translate(3px,3px);box-shadow:2px 2px 0 var(--ink)}

/* ---------- HERO ---------- */
.hero{
  position:relative;margin:14px 0 60px;border:var(--line);border-radius:34px;
  background:linear-gradient(160deg,#19c2cf 0%, #2f93f0 100%);
  box-shadow:var(--pop);padding:46px 48px;overflow:hidden;
  display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:center;min-height:430px;
}
.hero .badge{
  display:inline-flex;align-items:center;gap:9px;background:#fff;border:var(--line);border-radius:30px;
  padding:9px 18px;font-family:'Quicksand',cursive;font-weight:700;font-size:16px;box-shadow:var(--pop-sm);
}
.hero h1{
  color:#fff;font-weight:800;font-size:clamp(40px,6vw,74px);line-height:.95;margin:18px 0 0;
  text-shadow:4px 4px 0 var(--ink),-2px -2px 0 var(--ink),2px -2px 0 var(--ink),-2px 2px 0 var(--ink);
}
.hero h1 .hi{color:var(--yellow)}
.hero .lead{color:#fff;font-weight:800;font-size:22px;line-height:1.25;margin:20px 0 6px;max-width:30ch;
  text-shadow:2px 2px 0 rgba(22,50,61,.35)}
.hero .reo{color:#eafff7;font-weight:700;font-size:16px;margin:0 0 26px;text-shadow:1px 1px 0 rgba(22,50,61,.3)}
.hero-cta{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.play{
  font-family:'Quicksand',cursive;font-weight:800;font-size:24px;color:var(--ink);background:var(--yellow);
  border:var(--line);border-radius:18px;padding:14px 28px;box-shadow:var(--pop);cursor:pointer;
  display:inline-flex;align-items:center;gap:12px;transition:transform .12s ease,box-shadow .12s ease;
}
.play:hover{transform:translate(-2px,-3px);box-shadow:11px 12px 0 var(--ink)}
.play:active{transform:translate(4px,4px);box-shadow:3px 3px 0 var(--ink)}
.play .tri{width:0;height:0;border-left:18px solid var(--ink);border-top:11px solid transparent;border-bottom:11px solid transparent}
.hero .free{color:#fff;font-weight:800;font-size:16px;text-shadow:1px 1px 0 rgba(22,50,61,.35)}

.hero-text{position:relative;z-index:3}
.stage{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;min-height:360px}
.stage-box{position:relative;width:360px;height:360px;max-width:100%}
.mascot{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:260px;height:260px;border-radius:50%;background:#fff;border:var(--line);box-shadow:var(--pop);
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
/* offset right + up to visually centre the kiwi (the beak skews it left) */
.mascot-img{height:84%;width:auto;object-fit:contain;display:block;transform:translate(9%,-2%)}

/* decorative "case-file" tabs that drift sideways */
.ftab{position:absolute;background:#fff;border-radius:40px;z-index:1;pointer-events:none}
.ftab.a{top:34px;left:-20px;width:150px;height:54px;opacity:.85;animation:kFloatX 9s ease-in-out infinite}
.ftab.b{top:120px;right:-30px;width:190px;height:62px;opacity:.8;animation:kFloatX 11s ease-in-out infinite}

/* floating grapheme stickers */
.sticker{
  position:absolute;background:#fff;border:3px solid var(--ink);display:flex;align-items:center;justify-content:center;
  font-family:'Quicksand',cursive;font-weight:800;font-size:26px;border-radius:18px;box-shadow:4px 4px 0 var(--ink);z-index:3;
}
.sticker.s1{top:0;left:6px;width:62px;height:62px;color:#ff6b5e;--r:-12deg;animation:kBob 4.2s ease-in-out infinite}
.sticker.s2{top:54px;right:0;width:60px;height:60px;color:#9b6ef0;--r:10deg;animation:kBobB 5s ease-in-out infinite}
.sticker.s3{bottom:6px;left:0;width:60px;height:60px;color:#36c96b;--r:8deg;animation:kBob 4.6s ease-in-out infinite}
.sticker.s4{bottom:24px;right:14px;width:56px;height:56px;border-radius:16px;font-size:24px;color:#2f93f0;--r:-7deg;animation:kBobB 5.4s ease-in-out infinite}

/* twinkling CSS stars */
.star{position:absolute;z-index:2;animation:kTwinkle 3s ease-in-out infinite;
  clip-path:polygon(50% 0,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%)}
.star.g{top:40px;right:120px;width:30px;height:30px;background:#ffc62e}
.star.w{bottom:46px;left:46%;width:22px;height:22px;background:#fff;animation-duration:2.4s}

/* ---------- SECTION HEADINGS ---------- */
.sec{margin:60px 0}
.sec h2{text-align:center;font-weight:800;font-size:clamp(28px,4vw,44px);margin-bottom:34px}

/* ---------- STEPS ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.step{
  background:#fff;border:var(--line);border-radius:24px;box-shadow:var(--pop);padding:30px 26px;text-align:center;
}
.step .num{
  width:62px;height:62px;border-radius:50%;border:var(--line);display:grid;place-items:center;margin:0 auto 16px;
  font-family:'Quicksand',cursive;font-weight:800;font-size:30px;color:#fff;box-shadow:var(--pop-sm);
}
.step h3{font-weight:800;font-size:24px;margin-bottom:8px}
.step p{margin:0;color:var(--muted);font-weight:600;font-size:16px;line-height:1.45}

/* ---------- SWITCHER ---------- */
.pick-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:18px;margin-bottom:28px}
.pick-head h2{font-weight:800;font-size:clamp(28px,4vw,44px);text-align:left;margin:0}
.tabs{display:inline-flex;gap:0;background:#fff;border:var(--line);border-radius:30px;box-shadow:var(--pop-sm);overflow:hidden}
.tabs button{
  font-family:'Quicksand',cursive;font-weight:700;font-size:17px;color:var(--muted);background:transparent;
  border:none;padding:11px 22px;cursor:pointer;
}
.tabs button.active{background:var(--cyan);color:#fff}
.tabs button+button{border-left:4px solid var(--ink)}

.grid{display:grid;gap:24px}
.grid.phase{grid-template-columns:repeat(4,1fr)}
.grid.sound{grid-template-columns:repeat(4,1fr)}
.grid.year{grid-template-columns:repeat(4,1fr)}

.card{border:var(--line);border-radius:24px;box-shadow:var(--pop);padding:24px;transition:transform .12s ease,box-shadow .12s ease}
.card:hover{transform:translate(-2px,-2px);box-shadow:10px 10px 0 var(--ink)}

/* phase card */
.pcard .big{font-family:'Quicksand',cursive;font-weight:800;font-size:64px;line-height:.9;color:#fff;
  text-shadow:3px 3px 0 var(--ink),-1px -1px 0 var(--ink),1px -1px 0 var(--ink),-1px 1px 0 var(--ink)}
.pcard h3{font-weight:800;font-size:26px;margin:8px 0 4px}
.pcard .detail{font-family:'Quicksand',cursive;font-weight:700;font-size:22px;letter-spacing:3px;margin-bottom:10px}
.pcard .meta{font-weight:700;color:var(--ink);opacity:.75;font-size:15px;margin-bottom:18px}
.mini{
  font-family:'Quicksand',cursive;font-weight:800;font-size:15px;color:var(--ink);background:#fff;
  border:var(--line);border-radius:14px;padding:8px 16px;box-shadow:var(--pop-sm);cursor:pointer;
  display:inline-flex;align-items:center;gap:8px;transition:transform .12s ease,box-shadow .12s ease;
}
.mini:hover{transform:translate(-2px,-2px);box-shadow:8px 8px 0 var(--ink)}
.mini:active{transform:translate(3px,3px);box-shadow:2px 2px 0 var(--ink)}

/* sound chip */
.scard{text-align:center;background:#fff}
.scard .g{font-family:'Quicksand',cursive;font-weight:800;font-size:46px;line-height:1;
  width:84px;height:84px;border-radius:18px;border:var(--line);display:grid;place-items:center;margin:0 auto 12px;color:#fff;box-shadow:var(--pop-sm)}
.scard .ex{font-weight:800;font-size:17px}
.scard .ph{font-weight:700;color:var(--muted);font-size:14px;margin-top:3px}

/* year card */
.ycard{background:#fff;display:flex;align-items:center;gap:16px}
.ycard .yb{width:60px;height:60px;flex:none;border-radius:16px;border:var(--line);display:grid;place-items:center;
  font-family:'Quicksand',cursive;font-weight:800;font-size:18px;color:#fff;text-align:center;line-height:1;box-shadow:var(--pop-sm);padding:4px}
.ycard .yt{font-weight:800;font-size:19px}
.ycard .ym{font-weight:700;color:var(--muted);font-size:14px;margin-top:2px}

/* phase card (portrait, clickable) */
.pcard{padding:0;overflow:hidden;cursor:pointer;display:flex;flex-direction:column;background:#fff;min-height:300px;
  text-decoration:none;color:var(--ink);transition:transform .12s ease,box-shadow .12s ease}
.pcard:hover{transform:translate(-2px,-5px);box-shadow:10px 13px 0 var(--ink)}
.pcard:hover .pgo{transform:translate(-1px,-2px);box-shadow:4px 5px 0 var(--ink)}
.pcard:active{transform:translate(2px,2px);box-shadow:4px 4px 0 var(--ink)}
.pcard .ptop{height:120px;display:flex;align-items:center;justify-content:center;border-bottom:4px solid var(--ink)}
.pcard .picon{width:86px;height:86px;border-radius:50%;background:#fff;border:4px solid var(--ink);
  display:flex;align-items:center;justify-content:center;font-size:46px;box-shadow:3px 3px 0 var(--ink)}
.pcard .pbody{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:18px 14px 24px;text-align:center}
.pcard .pbody h3{font-weight:700;font-size:25px;margin:0;line-height:1.1}
.pcard .peng{font-weight:700;font-size:16px;margin-top:3px}
.pcard .pyr{font-weight:700;font-size:13px;color:var(--ink);opacity:.6;margin-top:2px}
.pcard .pgo{margin-top:16px;font-family:'Quicksand',cursive;font-weight:700;font-size:15px;color:#fff;
  border:3px solid var(--ink);border-radius:14px;padding:7px 20px;box-shadow:3px 3px 0 var(--ink);
  display:inline-flex;align-items:center;gap:7px;transition:transform .12s ease,box-shadow .12s ease}

/* grouped sounds */
.groups{display:block}
.sgroup{margin-bottom:34px}
.ghead{display:flex;align-items:center;gap:14px;flex-wrap:wrap;border:var(--line);border-radius:20px;
  padding:12px 20px;box-shadow:var(--pop-sm);margin-bottom:20px}
.ghead .gname{font-family:'Quicksand',cursive;font-weight:800;font-size:24px}
.ghead .gyear{font-family:'Quicksand',cursive;font-weight:700;font-size:14px;color:#fff;
  border:3px solid var(--ink);border-radius:18px;padding:3px 12px}
.ghead .gcount{font-family:'Quicksand',cursive;font-weight:700;font-size:14px;color:var(--muted);margin-left:auto}

/* ---------- FEATURED ---------- */
.feature{
  border:var(--line);border-radius:30px;box-shadow:var(--pop);background:linear-gradient(150deg,var(--grape) 0%,#b58bff 100%);
  padding:36px;display:grid;grid-template-columns:1.3fr .7fr;gap:30px;align-items:center;
}
.feature .tag{display:inline-block;background:var(--yellow);border:var(--line);border-radius:24px;padding:6px 16px;
  font-family:'Quicksand',cursive;font-weight:800;font-size:15px;box-shadow:var(--pop-sm)}
.feature h2{color:#fff;font-weight:800;font-size:clamp(28px,4vw,42px);margin:16px 0 12px;text-align:left;
  text-shadow:3px 3px 0 var(--ink),-1px -1px 0 var(--ink),1px -1px 0 var(--ink),-1px 1px 0 var(--ink)}
.feature p{color:#fff;font-weight:700;font-size:17px;line-height:1.45;margin:0 0 22px;max-width:46ch;
  text-shadow:1px 1px 0 rgba(22,50,61,.3)}
.feature .solve{background:var(--coral);color:#fff;font-size:20px}
.cover{position:relative}
.cover .art{aspect-ratio:1;border-radius:22px;background:#fff;border:var(--line);box-shadow:var(--pop-sm);
  display:grid;place-items:center;font-family:'Quicksand',cursive;font-weight:700;color:#9fb1b8;letter-spacing:2px;font-size:13px;text-align:center}
.cover .clues{position:absolute;bottom:-14px;right:-10px;background:var(--yellow);border:var(--line);border-radius:18px;
  padding:7px 14px;font-family:'Quicksand',cursive;font-weight:800;font-size:15px;box-shadow:var(--pop-sm);transform:rotate(-6deg)}

/* ---------- FOOTER ---------- */
footer{background:var(--ink);margin-top:70px;padding:24px 0}
footer .wrap{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
footer .logo{margin:0}
footer .made{font-family:'Quicksand',cursive;font-weight:700;color:#fff;font-size:18px;margin:0;text-align:center}
footer .flinks{display:flex;gap:30px;flex-wrap:wrap}
footer .flinks a{font-family:'Quicksand',cursive;font-weight:700;color:#fff;text-decoration:none;font-size:17px}
footer .flinks a:hover{color:var(--yellow)}
@media(max-width:700px){
  footer .wrap{flex-direction:column;text-align:center}
}

/* ---------- RESPONSIVE ---------- */
@media(max-width:900px){
  .hero{grid-template-columns:1fr;padding:34px 28px}
  .stage{min-height:300px;margin-top:10px}
  .steps{grid-template-columns:1fr}
  .grid.phase{grid-template-columns:1fr 1fr}
  .grid.sound{grid-template-columns:1fr 1fr}
  .grid.year{grid-template-columns:1fr 1fr}
  .feature{grid-template-columns:1fr}
  .nav-links a:not(.pill-btn){display:none}
}
@media(max-width:560px){
  .grid.phase,.grid.sound,.grid.year{grid-template-columns:1fr}
}

/* ================= PHASE PAGES ================= */
.ph-crumb{margin-top:10px}
.ph-crumb .wrap{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.ph-crumb .all{font-family:'Quicksand',cursive;font-weight:700;font-size:15px;color:var(--muted);text-decoration:none}
.ph-tabs{display:flex;gap:7px}
.ph-tab{font-family:'Quicksand',cursive;font-weight:700;font-size:15px;width:34px;height:34px;border-radius:11px;
  display:flex;align-items:center;justify-content:center;border:3px solid var(--ink);background:#fff;color:var(--ink);text-decoration:none}
.ph-tab.active{color:#fff;box-shadow:2px 3px 0 var(--ink)}

.ph-hero{margin-top:14px}
.ph-hero-inner{position:relative;border:var(--line);border-radius:34px;box-shadow:var(--pop);overflow:hidden;padding:34px 38px}
.ph-hero-inner .twinkle{position:absolute;top:20px;right:30px;width:30px;height:30px;background:#fff;
  clip-path:polygon(50% 0,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%);animation:kTwinkle 2.8s ease-in-out infinite}
.ph-hero-row{position:relative;display:flex;align-items:center;gap:28px;flex-wrap:wrap;min-height:118px}
.ph-num{width:96px;height:96px;flex:none;border-radius:24px;background:#fff;border:var(--line);box-shadow:4px 5px 0 var(--ink);
  display:flex;align-items:center;justify-content:center;font-family:'Quicksand',cursive;font-weight:700;font-size:52px}
.ph-info{flex:1;min-width:260px}
.ph-kicker{font-family:'Quicksand',cursive;font-weight:700;font-size:14px;color:#fff;letter-spacing:1.5px;margin:0;text-shadow:1px 1px 0 rgba(22,50,61,.35)}
.ph-info h1{font-weight:700;font-size:42px;color:#fff;margin:4px 0 8px;line-height:1;text-shadow:2px 2px 0 var(--ink)}
.ph-sub{font-weight:800;font-size:18px;color:#fff;margin:0;max-width:560px;text-shadow:1px 1px 0 rgba(22,50,61,.3)}
.ph-soundbox{display:flex;flex-direction:column;gap:10px}
.ph-soundbox .lbl{font-family:'Quicksand',cursive;font-weight:700;font-size:13px;color:#fff;letter-spacing:1px;margin:0}
.ph-soundrow{display:flex;gap:9px;flex-wrap:wrap;max-width:230px}
.ph-chip{font-family:'Quicksand',cursive;font-weight:700;font-size:18px;color:var(--ink);background:#fff;border:3px solid var(--ink);
  border-radius:13px;padding:6px 13px;box-shadow:2px 3px 0 var(--ink)}

/* full-scope "what you'll crack" card under the hero */
.ph-crack{margin-top:18px}
.ph-crack-inner{background:#fff;border:var(--line);border-radius:22px;box-shadow:5px 6px 0 var(--ink);padding:18px 22px}
.ph-crack-lbl{font-family:'Quicksand',cursive;font-weight:700;font-size:15px;color:var(--ink);margin:0 0 12px;letter-spacing:.5px}
.ph-crack-row{display:flex;flex-wrap:wrap;gap:8px}
.crackchip{font-family:'Quicksand',cursive;font-weight:700;font-size:15px;color:var(--ink);background:#fff5da;border:2.5px solid var(--ink);border-radius:11px;padding:4px 11px;box-shadow:2px 2px 0 var(--ink)}
.ph-note{font-weight:700;font-size:13px;color:var(--muted);margin:14px 0 0;font-style:italic;line-height:1.4}

.ph-prog{margin-top:22px}
.ph-prog-inner{display:flex;align-items:center;gap:16px;background:#fff;border:var(--line);border-radius:22px;box-shadow:5px 6px 0 var(--ink);padding:16px 22px;flex-wrap:wrap}
.ph-badge{width:50px;height:50px;flex:none;border-radius:50%;background:var(--grass);border:3px solid var(--ink);
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:22px;color:#fff}
.ph-prog-txt{flex:1;min-width:200px}
.ph-prog-txt p{font-family:'Quicksand',cursive;font-weight:700;font-size:18px;color:var(--ink);margin:0 0 6px}
.ph-bar{height:16px;border-radius:10px;background:#eef3ef;border:2.5px solid var(--ink);overflow:hidden}
.ph-bar i{display:block;height:100%;border-right:2.5px solid var(--ink)}
.ph-starcount{font-family:'Quicksand',cursive;font-weight:700;font-size:14px;color:var(--ink);background:var(--yellow);
  border:3px solid var(--ink);border-radius:18px;padding:7px 15px;white-space:nowrap;box-shadow:2px 3px 0 var(--ink)}

.ph-grid{margin-top:30px}
.ph-gridtitle{font-weight:700;font-size:32px;color:var(--ink);margin:0 0 20px}
.mgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;grid-auto-rows:1fr}
.mcard{display:flex;flex-direction:column;text-decoration:none;background:#fff;border:var(--line);border-radius:24px;overflow:hidden;box-shadow:5px 6px 0 var(--ink);
  transition:transform .12s ease,box-shadow .12s ease}
.mcard:hover{transform:translate(-2px,-3px);box-shadow:7px 9px 0 var(--ink)}
.mcard.locked{opacity:.62;filter:grayscale(.45);cursor:not-allowed}
.mcard.locked:hover{transform:none;box-shadow:5px 6px 0 var(--ink)}
.mcover{position:relative;height:128px;border-bottom:var(--line);display:flex;align-items:center;justify-content:center;
  background-image:repeating-linear-gradient(135deg,rgba(255,255,255,.16) 0 14px,transparent 14px 28px)}
.mcover .art{font-size:56px;filter:drop-shadow(2px 3px 0 rgba(22,50,61,.35))}
.mstatus{position:absolute;top:10px;right:12px;font-family:'Quicksand',cursive;font-weight:700;font-size:12px;color:#fff;
  border:2.5px solid var(--ink);border-radius:14px;padding:4px 10px;letter-spacing:.5px}
.mstage{position:absolute;top:10px;left:12px;font-family:'Quicksand',cursive;font-weight:700;font-size:11px;letter-spacing:.3px;color:var(--ink);background:#fff;border:2.5px solid var(--ink);border-radius:12px;padding:3px 9px}
.mcase{position:absolute;bottom:10px;left:12px;font-family:'Quicksand',cursive;font-weight:700;font-size:12px;color:#fff;
  background:rgba(22,50,61,.78);border-radius:14px;padding:4px 11px;letter-spacing:.5px}
.mbody{padding:16px 18px 18px;flex:1;display:flex;flex-direction:column}
.mtext{flex:1}
.mbody h3{font-weight:700;font-size:20px;color:var(--ink);margin:0 0 5px;line-height:1.1}
.mbody .blurb{font-weight:700;font-size:14px;color:var(--muted);margin:0 0 12px;line-height:1.35}
.msounds{display:flex;align-items:center;gap:7px;flex-wrap:wrap;margin-bottom:14px}
.msounds span{font-family:'Quicksand',cursive;font-weight:700;font-size:13px;color:var(--ink);background:#fff5da;border:2px solid var(--ink);border-radius:11px;padding:3px 9px}
.mfoot{display:flex;align-items:center;justify-content:space-between;gap:10px}
.mstars{display:flex;align-items:center;gap:3px}
.mstars span{font-size:16px;line-height:1}
.mplay{font-family:'Quicksand',cursive;font-weight:700;font-size:15px;border-radius:20px;padding:7px 16px;white-space:nowrap;border:2.5px solid var(--ink)}

.ph-keep{margin-top:40px;padding-bottom:60px}
.ph-keep-inner{border:var(--line);border-radius:26px;box-shadow:var(--pop);padding:30px 36px;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.ph-keep-inner h2{font-weight:700;font-size:28px;color:#fff;margin:0 0 4px;text-shadow:2px 2px 0 var(--ink)}
.ph-keep-inner p{font-family:'Quicksand',cursive;font-weight:700;font-size:17px;color:#fff;margin:0}
.ph-keep-inner a{font-family:'Quicksand',cursive;font-weight:700;font-size:19px;color:var(--ink);background:var(--yellow);border:var(--line);
  padding:14px 30px;border-radius:30px;box-shadow:5px 6px 0 var(--ink);white-space:nowrap;text-decoration:none;transition:transform .12s ease,box-shadow .12s ease}
.ph-keep-inner a:hover{transform:translate(-2px,-2px);box-shadow:7px 9px 0 var(--ink)}

@media(max-width:900px){
  .mgrid{grid-template-columns:1fr 1fr}
  .ph-info h1{font-size:34px}
}
@media(max-width:560px){
  .mgrid{grid-template-columns:1fr}
  .ph-hero-inner,.ph-keep-inner{padding:24px}
}

/* ================= MYSTERY (whodunit) PAGE ================= */
@keyframes kShake{0%,100%{transform:translateX(0)}20%{transform:translateX(-7px)}40%{transform:translateX(7px)}60%{transform:translateX(-5px)}80%{transform:translateX(5px)}}
@keyframes kPop{0%{transform:scale(.6);opacity:0}60%{transform:scale(1.08)}100%{transform:scale(1);opacity:1}}
@keyframes kStampIn{0%{transform:translate(-50%,-50%) rotate(-14deg) scale(1.7);opacity:0}70%{transform:translate(-50%,-50%) rotate(-14deg) scale(.92)}100%{transform:translate(-50%,-50%) rotate(-14deg) scale(1);opacity:1}}
@keyframes kFill{0%{transform:scale(.4);opacity:0}100%{transform:scale(1);opacity:1}}

.mys-top{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:18px 0}
.mys-exit{display:flex;align-items:center;gap:8px;text-decoration:none;font-family:'Quicksand',cursive;font-weight:700;font-size:18px;color:var(--ink)}
.mys-casehead{text-align:center}
.mys-casehead .cno{font-family:'Quicksand',cursive;font-weight:700;font-size:13px;color:var(--muted);margin:0;letter-spacing:1px}
.mys-casehead h1{font-weight:700;font-size:24px;margin:1px 0 0;letter-spacing:-.5px}
.mys-dots{display:flex;align-items:center;gap:8px}
.mys-dot{width:16px;height:16px;border-radius:50%;border:3px solid var(--ink);transition:background .2s ease}

.mys-main{display:grid;grid-template-columns:320px 1fr;gap:26px;align-items:start;padding-bottom:56px}
.mys-suspects{background:#fff;border:var(--line);border-radius:26px;box-shadow:6px 7px 0 var(--ink);padding:20px;position:sticky;top:16px}
.mys-shead{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.mys-shead h2{font-weight:700;font-size:22px;margin:0}
.mys-left{font-family:'Quicksand',cursive;font-weight:700;font-size:13px;color:#fff;background:var(--coral);border:2.5px solid var(--ink);border-radius:18px;padding:3px 11px}
.mys-shint{font-weight:700;font-size:13px;color:var(--muted);margin:0 0 16px}
.mys-slist{display:flex;flex-direction:column;gap:13px}
.scard2{position:relative;display:flex;align-items:center;gap:12px;background:#fff;border:3px solid var(--ink);border-radius:16px;padding:11px 13px;box-shadow:3px 4px 0 var(--ink);transition:all .25s ease}
.scard2.out{background:#f1eee6;box-shadow:none;opacity:.55;filter:grayscale(.6)}
.sring{width:46px;height:46px;flex:none;border-radius:50%;border:3px solid var(--ink);color:#fff;font-family:'Quicksand',cursive;font-weight:700;font-size:22px;display:flex;align-items:center;justify-content:center}
.scard2 h4{font-weight:700;font-size:17px;margin:0;line-height:1.1}
.scard2 .strait{font-weight:700;font-size:12.5px;color:var(--muted);margin:2px 0 0}
.ruledout{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-14deg);background:#ff3b30;color:#fff;font-family:'Quicksand',cursive;font-weight:700;font-size:15px;letter-spacing:2px;padding:4px 14px;border:3px solid var(--ink);border-radius:7px;box-shadow:2px 2px 0 var(--ink)}
.ruledout.anim{animation:kStampIn .35s ease both}

.mys-coach{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.det-kiwi{width:54px;height:54px;flex:none;border-radius:50%;background:var(--yellow);border:3px solid var(--ink);box-shadow:3px 3px 0 var(--ink);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:900;color:var(--ink);text-align:center;line-height:1.1;font-family:'Quicksand',cursive}
.coach-bubble{background:#fff;border:3px solid var(--ink);border-radius:16px;padding:11px 18px;box-shadow:3px 3px 0 var(--ink);font-family:'Quicksand',cursive;font-weight:700;font-size:16px;color:var(--ink)}
.cluecard{position:relative;overflow:hidden;background:#fffdf3;border:var(--line);border-radius:22px;box-shadow:6px 7px 0 var(--ink);padding:24px 28px}
.cluecard .qmark{position:absolute;top:-30px;right:-20px;font-family:'Quicksand',cursive;font-weight:700;font-size:150px;color:var(--ink);opacity:.05;line-height:1}
.clue-tags{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.clue-pill{font-family:'Quicksand',cursive;font-weight:700;font-size:13px;color:#fff;background:var(--grape);border:2.5px solid var(--ink);border-radius:18px;padding:3px 13px}
.clue-inv{font-family:'Quicksand',cursive;font-weight:700;font-size:14px;color:var(--ink)}
.clue-quote{font-family:'Quicksand',cursive;font-weight:700;font-size:22px;line-height:1.3;color:var(--ink);margin:0 0 18px;max-width:660px}
.meter{display:flex;align-items:center;gap:12px;background:#fff;border:3px solid var(--ink);border-radius:18px;padding:11px 16px;box-shadow:3px 4px 0 var(--ink)}
.meter .lbl{font-family:'Quicksand',cursive;font-weight:700;font-size:14px;white-space:nowrap}
.meter .pips{display:flex;gap:9px;flex:1}
.pip{flex:1;height:24px;border-radius:9px;border:2.5px solid var(--ink);background:#eef3ef;color:#fff;font-family:'Quicksand',cursive;font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center}
.pip.on{background:var(--grass);animation:kFill .25s ease both}
.meter .cnt{font-family:'Quicksand',cursive;font-weight:700;font-size:14px;color:var(--muted);white-space:nowrap}

.step-sep{margin-top:22px;border-top:3px dashed #e3dcc4;padding-top:22px}
.q-sub{font-family:'Quicksand',cursive;font-weight:700;font-size:14px;color:var(--muted);margin:0 0 4px}
.q-prompt{font-family:'Quicksand',cursive;font-weight:700;font-size:23px;color:var(--ink);margin:0 0 16px}
.q-options{display:flex;flex-wrap:wrap;gap:14px}
.blankword{font-family:'Quicksand',cursive;font-weight:700;font-size:50px;letter-spacing:4px;color:var(--ink);margin:2px 0 18px}
.blankw{display:inline-block;font-family:'Quicksand',cursive;font-weight:800;color:var(--ink);background:#fff;border:2.5px solid var(--ink);border-radius:9px;padding:0 9px;box-shadow:2px 2px 0 var(--ink);letter-spacing:2px}
.blankw.filled{background:#d7f6e2;border-color:#2fbf63}
.hearbtn{position:absolute;bottom:18px;right:22px;font-family:'Quicksand',cursive;font-weight:700;font-size:14px;color:var(--ink);background:var(--yellow);border:2.5px solid var(--ink);border-radius:16px;padding:5px 14px;box-shadow:2px 2px 0 var(--ink);cursor:pointer;white-space:nowrap}
.hearbtn:active{transform:translate(2px,2px);box-shadow:none}
.introcard{position:relative;overflow:hidden;background:#fffdf3;border:var(--line);border-radius:22px;box-shadow:6px 7px 0 var(--ink);padding:30px 32px}
.introemoji{font-size:58px;line-height:1;display:block;margin-bottom:8px}
.introkicker{font-family:'Quicksand',cursive;font-weight:700;font-size:13px;letter-spacing:1.5px;color:var(--coral);margin:0;padding-right:120px}
.introtitle{font-weight:700;font-size:32px;margin:4px 0 12px;line-height:1.05;color:var(--ink);padding-right:120px}
.introstory{font-weight:700;font-size:18px;line-height:1.45;color:var(--ink);margin:0 0 16px;max-width:640px}
.introhow{position:relative;background:#fff;border:3px solid var(--ink);border-radius:16px;padding:14px 16px;box-shadow:3px 3px 0 var(--ink);margin:0 0 20px;min-height:96px}
.introhow-txt{font-weight:700;font-size:15px;line-height:1.5;color:var(--muted);margin:0;padding-right:120px}
.introhow strong{color:var(--ink)}
/* compact Listen pills — same look/size as the clue-card Listen button */
.ilisten{display:inline-flex;align-items:center;gap:6px;font-family:'Quicksand',cursive;font-weight:700;font-size:14px;color:var(--ink);background:var(--yellow);border:2.5px solid var(--ink);border-radius:16px;padding:5px 14px;box-shadow:2px 2px 0 var(--ink);cursor:pointer;transition:transform .05s;white-space:nowrap}
.ilisten:hover{filter:brightness(1.05)}
.ilisten:active{transform:translate(2px,2px);box-shadow:none}
.icase{position:absolute;top:30px;right:32px}
.ihow{position:absolute;bottom:12px;right:14px}
/* success confetti on the case-closed reveal */
.confetti-wrap{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:9999}
.confetti-piece{position:absolute;top:-24px;width:11px;height:16px;border:1.5px solid rgba(22,50,61,.25);opacity:.95;animation:kConfetti linear forwards}
@keyframes kConfetti{0%{transform:translateY(-24px) rotate(0)}100%{transform:translateY(108vh) rotate(900deg)}}
/* Kākano: picture clue + build-the-word tiles */
.cluepic{font-size:74px;line-height:1;text-align:center;margin:2px 0 6px;filter:drop-shadow(2px 3px 0 rgba(22,50,61,.25))}
.clue-quote.build{color:var(--muted);font-style:italic}
.wbslots{display:flex;gap:10px;justify-content:center;margin:14px 0 16px;flex-wrap:wrap}
.wbslot{width:48px;height:56px;border:3px dashed var(--ink);border-radius:12px;display:flex;align-items:center;justify-content:center;font-family:'Quicksand',cursive;font-weight:700;font-size:30px;color:var(--ink);background:#fff}
.wbslot.on{border-style:solid;background:var(--yellow-t)}
.wbtiles{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.wbtile{width:52px;height:52px;font-family:'Quicksand',cursive;font-weight:700;font-size:26px;color:var(--ink);background:#fff;border:3px solid var(--ink);border-radius:14px;box-shadow:3px 3px 0 var(--ink);cursor:pointer;transition:transform .05s}
.wbtile:hover{background:var(--cyan-t)}
.wbtile:active{transform:translate(2px,2px);box-shadow:none}
.wbtile.used{opacity:.28;pointer-events:none;box-shadow:none;transform:translate(2px,2px)}
.wbtile.wrong{animation:kShake .3s ease;background:var(--coral-t);border-color:var(--coral)}
/* clickable sound/skill chips → find.html */
a.scard{text-decoration:none;color:inherit;cursor:pointer}
a.crackchip{text-decoration:none;color:inherit;cursor:pointer;transition:transform .08s ease,box-shadow .08s ease}
a.crackchip:hover{transform:translate(-1px,-2px);box-shadow:2px 3px 0 var(--ink)}
/* find.html results page */
.find-head{padding:26px 0 8px}
.find-back{display:inline-block;font-family:'Quicksand',cursive;font-weight:700;font-size:14px;color:var(--ink);text-decoration:none;margin-bottom:8px}
.find-back:hover{color:var(--coral)}
.find-head h1{font-weight:700;font-size:30px;color:var(--ink);margin:4px 0 2px;line-height:1.1}
.find-note{font-weight:700;font-size:15px;color:var(--muted);margin:0 0 20px}
@media(max-width:640px){
  .introkicker,.introtitle,.introhow-txt{padding-right:0}
  .icase{position:static;display:block;margin:0 0 12px}
  .introhow{min-height:0}
  .ihow{position:static;display:block;margin-top:12px}
}
.wordbtn{font-family:'Quicksand',cursive;font-weight:700;font-size:26px;color:var(--ink);background:#fff;border:3px solid var(--ink);border-radius:18px;padding:14px 26px;box-shadow:4px 5px 0 var(--ink);cursor:pointer;transition:transform .1s ease}
.spellbtn{min-width:96px;justify-content:center}
.wordbtn:hover{transform:translate(-1px,-2px)}
.wordbtn.wrong{background:#ffe0dc;border-color:#ff3b30;color:#ff3b30;animation:kShake .5s ease}
.tryagain{font-family:'Quicksand',cursive;font-weight:700;font-size:16px;color:var(--coral);margin:16px 0 0}
.kapai-row{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.kapai{font-family:'Quicksand',cursive;font-weight:700;font-size:14px;color:#fff;background:var(--grass);border:2.5px solid var(--ink);border-radius:18px;padding:4px 14px}
.kapai-txt{font-family:'Quicksand',cursive;font-weight:700;font-size:16px;color:var(--grass)}
.bigbtn{font-family:'Quicksand',cursive;font-weight:700;font-size:19px;color:var(--ink);background:var(--yellow);border:var(--line);padding:12px 28px;border-radius:30px;box-shadow:5px 6px 0 var(--ink);cursor:pointer;text-decoration:none;display:inline-block;transition:transform .12s ease,box-shadow .12s ease}
.bigbtn:hover{transform:translate(-2px,-2px);box-shadow:7px 9px 0 var(--ink)}
.bigbtn.alt{background:#fff}
.unlocked{font-family:'Quicksand',cursive;font-weight:700;font-size:14px;color:#fff;background:var(--coral);border:2.5px solid var(--ink);border-radius:18px;padding:4px 14px}
.reason{font-weight:800;font-size:20px;color:var(--ink);margin:14px 0 18px;line-height:1.4}

.reveal{position:relative;overflow:hidden;background:var(--grape);border:var(--line);border-radius:26px;box-shadow:8px 10px 0 var(--ink);padding:38px;text-align:center;animation:kPop .4s ease both}
.reveal .tw{position:absolute;background:var(--yellow);clip-path:polygon(50% 0,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%);animation:kTwinkle 2.6s ease-in-out infinite}
.reveal .kicker{font-family:'Quicksand',cursive;font-weight:700;font-size:15px;color:var(--yellow);letter-spacing:2px;margin:0;text-shadow:1px 1px 0 var(--ink)}
.reveal h2{font-weight:700;font-size:46px;color:#fff;margin:6px 0 2px;text-shadow:2px 2px 0 var(--ink);line-height:1}
.reveal .lead{font-family:'Quicksand',cursive;font-weight:700;font-size:19px;color:#fff;margin:0 0 24px}
.culprit{display:inline-flex;align-items:center;gap:16px;background:#fff;border:var(--line);border-radius:22px;box-shadow:5px 6px 0 var(--ink);padding:18px 28px 18px 18px}
.culprit .sring{width:64px;height:64px;font-size:30px}
.culprit h3{font-weight:700;font-size:28px;margin:0;line-height:1}
.culprit .caught{font-size:15px;font-weight:800;color:var(--coral);margin:3px 0 0}
.reveal .tally{font-family:'Quicksand',cursive;font-weight:700;font-size:16px;color:#fff;margin:26px 0 14px}
.reveal .btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

@media(max-width:820px){
  .mys-main{grid-template-columns:1fr}
  .mys-suspects{position:static}
}
