/* ============================================================
   SCOTTISH SUMMER — paper-collage poster + cinematic scroll
   Hero is a fit-to-viewport 3:2 poster (scales to any screen);
   below it: video wall, then story chapters, then footer.
   ============================================================ */

:root{
  --navy:#005EB8;            /* Scotland (Saltire) blue — page background */
  --navy-deep:#004a93;       /* darker blue for depth / video tiles */
  --navy-light:#2a86d6;      /* lighter blue for glows */
  --paper:#ffffff;           /* white — scraps + text on blue */
  --paper-warm:#f4f6f8;
  --lilac:#ff8a3d;           /* accent (light) — cone / Irn-Bru orange */
  --lilac-deep:#f4621e;      /* accent — traffic-cone / Irn-Bru orange */
  --ink:#0a2540;             /* dark navy ink — text on white */
  --saltire:#005EB8;
  --tape:rgba(236,228,210,0.85);
  --shadow:14px 16px 30px rgba(0,0,0,0.32);
  --shadow-sm:6px 7px 0 rgba(0,0,0,0.28);
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:auto;}
body{
  background-color:var(--navy);
  background-image:
    /* soft lighting */
    radial-gradient(circle at 20% 8%, rgba(255,255,255,.10) 0%, rgba(255,255,255,0) 42%),
    radial-gradient(circle at 85% 80%, rgba(0,0,0,.12) 0%, rgba(0,0,0,0) 48%),
    /* faint cone-orange overcheck threads */
    repeating-linear-gradient(90deg, rgba(244,98,30,.065) 0 2px, transparent 2px 88px),
    repeating-linear-gradient(0deg,  rgba(244,98,30,.065) 0 2px, transparent 2px 88px),
    /* mild tartan sett (blue tones) */
    repeating-linear-gradient(90deg, rgba(0,0,0,.07) 0 18px, transparent 18px 44px, rgba(255,255,255,.04) 44px 52px, transparent 52px 88px),
    repeating-linear-gradient(0deg,  rgba(0,0,0,.07) 0 18px, transparent 18px 44px, rgba(255,255,255,.04) 44px 52px, transparent 52px 88px),
    /* subtle twill weave */
    repeating-linear-gradient(45deg, rgba(255,255,255,.03) 0 1px, transparent 1px 5px);
  color:var(--paper);
  font-family:'Oswald',sans-serif;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

/* ---------- page-wide texture overlays ---------- */
.grain{
  position:fixed;inset:0;z-index:9000;pointer-events:none;opacity:.45;
  mix-blend-mode:overlay;
  background-image:
    repeating-linear-gradient(0deg, rgba(255,255,255,.03) 0 1px, transparent 1px 3px),
    repeating-linear-gradient(90deg, rgba(0,0,0,.04) 0 1px, transparent 1px 3px);
}
.vignette{
  position:fixed;inset:0;z-index:8999;pointer-events:none;
  box-shadow:inset 0 0 220px 50px rgba(0,0,0,.5);
}

/* ---------- film-strip scroll progress ---------- */
.filmstrip{
  position:fixed;top:0;left:0;width:7px;height:100vh;z-index:9100;
  background:repeating-linear-gradient(0deg,#0a1226 0 14px,#1a2950 14px 18px);
  border-right:2px solid rgba(0,0,0,.5);
}
.filmstrip__fill{position:absolute;left:1px;top:0;width:3px;height:0%;
  background:var(--lilac);box-shadow:0 0 10px var(--lilac-deep);}

/* dictionary link (fixed corner tab) */
.dict-link{position:fixed;left:50%;bottom:80px;transform:translateX(-50%) rotate(-1.5deg);z-index:9300;
  font-family:'Special Elite',monospace;font-size:13px;letter-spacing:.04em;
  color:#fff;text-decoration:none;background:var(--lilac-deep);padding:7px 14px;
  box-shadow:var(--shadow-sm);transition:transform .15s;white-space:nowrap;}
.dict-link em{font-style:italic;opacity:.85;font-size:11px;}
.dict-link:hover{transform:translateX(-50%) rotate(0) translateY(-2px);}
@media(max-width:760px){.dict-link em{display:none;}.dict-link{font-size:12px;padding:6px 10px;bottom:74px;}}

/* dictionary prompt in footer */
.footer__dict{display:inline-block;margin-top:22px;font-family:'Special Elite',monospace;
  font-size:15px;color:#fff;text-decoration:none;border-bottom:2px dashed var(--lilac);
  padding-bottom:2px;}
.footer__dict:hover{color:var(--lilac);}

/* ============================================================
   BOOKLET ENGINE — paged deck, one screen per page, no scroll
   ============================================================ */
html,body{height:100%;}
body.booklet{overflow:hidden;height:100dvh;}
.book{position:fixed;inset:0;overflow:hidden;perspective:2200px;}
.page{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  padding:8px 18px 114px;opacity:0;visibility:hidden;pointer-events:none;
  transform-origin:center center;transform:scale(.96);
  transition:opacity .5s ease, transform .6s cubic-bezier(.4,.05,.2,1);}
.page.active{opacity:1;visibility:visible;pointer-events:auto;transform:rotateY(0) scale(1);}
.page--cover{align-items:flex-end;}
/* page-turn: pages swing in/out in 3D */
.page.enter-right{opacity:0;visibility:visible;transform:rotateY(58deg) translateX(14%) scale(.9);}
.page.enter-left {opacity:0;visibility:visible;transform:rotateY(-58deg) translateX(-14%) scale(.9);}
.page.exit-left  {opacity:0;visibility:visible;transform:rotateY(-58deg) translateX(-14%) scale(.9);}
.page.exit-right {opacity:0;visibility:visible;transform:rotateY(58deg) translateX(14%) scale(.9);}
.page.active:not(.enter-right):not(.enter-left):not(.exit-left):not(.exit-right){
  opacity:1!important;visibility:visible!important;pointer-events:auto;
}

.page--cover .poster{width:min(95vw,134vh);}

.booknav{position:fixed;left:0;right:0;bottom:38px;z-index:9306;display:flex;
  align-items:center;justify-content:center;gap:14px;pointer-events:none;}
.booknav .nav,.dots{pointer-events:auto;}
.nav{width:44px;height:44px;border:none;background:var(--lilac-deep);color:#fff;
  font-family:'Anton',sans-serif;font-size:24px;line-height:1;cursor:pointer;
  box-shadow:var(--shadow-sm);transform:rotate(-2deg);transition:background .15s,transform .15s;}
.nav--next{transform:rotate(2deg);}
.nav:hover:not([disabled]){background:var(--ink);transform:rotate(0);}
.nav[disabled]{opacity:.3;cursor:default;}
.dots{display:flex;gap:9px;align-items:center;background:rgba(255,255,255,.82);padding:7px 10px;
  box-shadow:4px 5px 0 rgba(0,0,0,.22);transform:rotate(-.8deg);}
.dots button{width:11px;height:11px;border:2px solid var(--saltire);background:transparent;padding:0;
  cursor:pointer;transform:rotate(45deg);transition:background .15s,border-color .15s;}
.dots button.on{background:var(--lilac-deep);border-color:var(--lilac-deep);}
.pageno{position:fixed;right:14px;bottom:20px;z-index:9300;font-family:'Special Elite',monospace;
  color:#fff;font-size:13px;letter-spacing:.12em;opacity:.85;}
.flip-hint{display:none;position:fixed;left:50%;bottom:58px;transform:translateX(-50%);z-index:9300;
  font-family:'Special Elite',monospace;color:#fff;opacity:.8;font-size:12px;letter-spacing:.05em;
  transition:opacity .5s;text-align:center;}
.flip-hint em{opacity:.6;font-size:11px;}
.flip-hint.hide{opacity:0;pointer-events:none;}

/* chapter stage fills the page now (was 100vh scroll scene) */
.page--chap .stage--story{height:100%;}

/* ---- video carousel page ---- */
.page--videos{padding:5vh 0 92px;}
.vpage{display:flex;flex-direction:column;justify-content:center;gap:3vh;width:100%;height:100%;}
.vpage__head{text-align:center;}
.vhint{display:inline-block;margin-left:8px;font-size:12px;opacity:.7;}
/* clickable TikTok hashtag chips */
.vtags{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:9px;margin-top:14px;}
.vtags__lbl{font-family:'Special Elite',monospace;font-size:13px;color:rgba(255,255,255,.85);}
.vtags a{font-family:'Archivo Black',sans-serif;font-size:13px;letter-spacing:.02em;text-decoration:none;
  color:var(--ink);background:#fff;padding:7px 12px;box-shadow:3px 3px 0 rgba(0,0,0,.32);
  transform:rotate(-1.5deg);transition:transform .15s,background .15s,color .15s;cursor:pointer;}
.vtags a:nth-child(even){transform:rotate(1.5deg);}
.vtags a:hover{background:var(--lilac-deep);color:#fff;transform:rotate(0) translateY(-3px);}
.vrow{display:flex;align-items:center;gap:10px;width:100%;}
.video-rail{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;
  padding:12px 20px;flex:1;align-items:center;scrollbar-width:none;scroll-behavior:smooth;}
.video-rail::-webkit-scrollbar{display:none;}
.video-rail .vtile{flex:0 0 auto;height:62vh;max-height:540px;width:auto;
  transform:rotate(var(--rot,-2deg));scroll-snap-align:center;}
.video-rail .vtile__media{height:100%;width:auto;aspect-ratio:9/16;}
.vnav{flex:0 0 auto;width:56px;height:56px;border:none;background:var(--lilac-deep);color:#fff;
  font-family:'Anton',sans-serif;font-size:32px;cursor:pointer;box-shadow:var(--shadow-sm);
  transition:background .15s,transform .15s;}
.vnav:hover{background:#fff;color:var(--ink);transform:scale(1.08);}
.vnext{animation:nudgeR 1.6s ease-in-out infinite;}
@keyframes nudgeR{0%,100%{transform:translateX(0);}50%{transform:translateX(5px);}}
.videos__empty{background:#fff;color:var(--ink);font-family:'Special Elite',monospace;
  padding:34px;transform:rotate(-1.5deg);max-width:420px;margin:0 auto;
  box-shadow:var(--shadow);font-size:18px;text-align:center;}

/* ---- Tartan Army bus drive-by (page 1 <-> 2 transition) ---- */
.busfx{position:fixed;bottom:-13%;left:0;height:64vh;width:auto;z-index:9180;
  visibility:hidden;pointer-events:none;transform-origin:center bottom;
  filter:drop-shadow(0 14px 18px rgba(0,0,0,.5));will-change:transform;}
@media(max-width:760px){.busfx{height:34vh;bottom:-6%;}}

/* ---- game page (iframe embed) ---- */
.page--game{position:absolute;overflow:hidden;}
.game-stage{position:relative;width:min(95vw,134vh);height:100%;max-width:100%;
  display:flex;align-items:center;justify-content:center;}
.gamewrap{display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:1.6vh;width:100%;height:100%;position:relative;z-index:3;pointer-events:none;}
.game-title{font-family:'Anton',sans-serif;text-transform:uppercase;color:var(--paper);
  font-size:clamp(34px,6vw,84px);transform:rotate(-1.5deg);line-height:.9;text-shadow:6px 7px 0 rgba(0,0,0,.22);}
.game-sub{font-family:'Special Elite',monospace;color:var(--lilac);font-size:clamp(13px,1.5vw,17px);}
.game-frame{position:relative;width:min(92vw,56vh);aspect-ratio:4/5;max-height:76vh;
  background:#fff;padding:10px;box-shadow:var(--shadow);transform:rotate(-.6deg);pointer-events:auto;}
.game-frame iframe{width:100%;height:100%;border:0;display:block;background:var(--navy-deep);}
.game-art{position:absolute;z-index:2;margin:0;pointer-events:auto;overflow:visible;
  transform-origin:center bottom;transition:transform .22s ease;will-change:transform,opacity;}
.game-art img{display:block;width:100%;height:auto;position:relative;z-index:1;
  transition:filter .22s ease;
  filter:
    drop-shadow(2px 0 #fff) drop-shadow(-2px 0 #fff)
    drop-shadow(0 2px #fff) drop-shadow(0 -2px #fff)
    drop-shadow(8px 10px 10px rgba(0,0,0,.46))
    contrast(1.04) saturate(1.04);}
.game-art--liberty{left:-2%;bottom:-3%;width:min(31vw,52vh);transform:rotate(-4deg);
  clip-path:inset(2% 7% 0 8%);}
.game-art--strongman{right:1%;bottom:-8%;width:min(27vw,43vh);transform:rotate(3deg);
  clip-path:inset(17% 3% 0 0);}
.game-art--liberty:hover{transform:translateY(-8px) scale(1.035) rotate(-4deg);}
.game-art--strongman:hover{transform:translateY(-8px) scale(1.035) rotate(3deg);}
.game-art:hover img{
  filter:
    drop-shadow(2px 0 #fff) drop-shadow(-2px 0 #fff)
    drop-shadow(0 2px #fff) drop-shadow(0 -2px #fff)
    drop-shadow(0 0 12px rgba(244,98,30,.58))
    drop-shadow(8px 10px 10px rgba(0,0,0,.46))
    contrast(1.06) saturate(1.08);}
@media(max-width:1080px){
  .game-frame{width:min(82vw,54vh);}
  .game-art--liberty{left:-2%;bottom:-3%;width:min(29vw,47vh);}
  .game-art--strongman{right:1%;bottom:-7%;width:min(25vw,40vh);}
}
@media(max-width:760px){
  .game-frame{width:min(90vw,48vh);}
  .game-title{font-size:11vw;}
  .game-sub{font-size:12px;text-align:center;}
  .game-art{opacity:.5;z-index:1;}
  .game-art--liberty{left:0;bottom:-3%;width:34vw;}
  .game-art--strongman{right:0;bottom:-3%;width:30vw;}
}
@media(max-width:520px){
  .game-art{display:none;}
}

/* ---- end page ---- */
.endsheet{display:flex;flex-direction:column;align-items:center;gap:22px;text-align:center;}
.end-heart{position:static;width:70px;height:70px;}
.restart{font-family:'Special Elite',monospace;background:var(--lilac-deep);color:#fff;
  border:none;padding:11px 18px;cursor:pointer;box-shadow:var(--shadow-sm);
  transform:rotate(-1.5deg);font-size:14px;letter-spacing:.03em;transition:transform .15s;}
.restart:hover{transform:rotate(0) translateY(-2px);}

/* ============================================================
   GENERIC SCRAP / PHOTO (torn paper + tape)
   ============================================================ */
.scrap{position:absolute;will-change:transform;}
.scrap--photo{
  background:var(--paper);padding:1.1% 1.1% 2.4%;box-shadow:var(--shadow);
  clip-path:polygon(
    1% 3%, 8% 0, 22% 2%, 40% 0, 58% 3%, 74% 0, 90% 2%, 99% 0,
    100% 14%, 98% 30%, 100% 46%, 98% 62%, 100% 78%, 99% 96%,
    88% 99%, 70% 97%, 52% 100%, 34% 98%, 16% 100%, 4% 98%,
    0 84%, 2% 68%, 0 52%, 2% 36%, 0 20%);
  transition:transform .35s cubic-bezier(.2,.8,.2,1), filter .35s;
}
.scrap--photo::after{content:"";position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(rgba(0,0,0,.05) 1px, transparent 1px);
  background-size:5px 5px;opacity:.5;}
.ph{display:block;width:100%;height:100%;object-fit:cover;
  filter:contrast(1.06) saturate(1.05);}
.scrap--photo:hover{filter:brightness(1.05);transform:rotate(0deg) scale(1.03)!important;z-index:50;}

/* masking tape */
.tape{position:absolute;width:22%;min-width:42px;max-width:130px;aspect-ratio:3/1;
  background:var(--tape);box-shadow:0 3px 6px rgba(0,0,0,.25);opacity:.92;z-index:3;
  background-image:repeating-linear-gradient(90deg, rgba(255,255,255,.18) 0 6px, transparent 6px 12px);}
.tape--tl{top:-5%;left:-4%;transform:rotate(-38deg);}
.tape--tr{top:-5%;right:-4%;transform:rotate(36deg);}
.tape--bl{bottom:-5%;left:-4%;transform:rotate(34deg);}
.tape--br{bottom:-5%;right:-4%;transform:rotate(-37deg);}
.tape--mtl{top:-6%;left:14%;width:34%;transform:rotate(-12deg);}
.tape--mtr{top:-6%;right:14%;width:34%;transform:rotate(10deg);}

/* ---------- paper note scraps ---------- */
.note{position:absolute;background:var(--paper);color:var(--ink);
  font-family:'Special Elite',monospace;box-shadow:var(--shadow-sm);
  padding:1.2% 1.4%;transform:rotate(-2deg);z-index:6;}
.note--lilac{background:var(--lilac);transform:rotate(2deg);}
.note ul{list-style:none;}
.note li{position:relative;padding-left:1.1em;line-height:1.5;white-space:nowrap;}
.note li::before{content:"✓";position:absolute;left:0;color:var(--lilac-deep);font-weight:700;}

/* ============================================================
   DOODLES
   ============================================================ */
.doodle{position:absolute;overflow:visible;pointer-events:none;}
.doodle path,.doodle circle{fill:none;stroke:var(--lilac);stroke-width:5;
  stroke-linecap:round;stroke-linejoin:round;}
.doodle.tick path{stroke:var(--lilac-deep);stroke-width:9;}
.doodle.heart path{stroke:var(--lilac-deep);stroke-width:7;}
.doodle.arrow path,.doodle.big-underline path{stroke:#ffffff;}
.doodle.star path{stroke:var(--lilac-deep);stroke-width:4;}

/* ============================================================
   HERO POSTER  (fit-to-viewport 3:2, scales on every screen)
   ============================================================ */
.hero{min-height:100vh;min-height:100svh;display:flex;align-items:center;
  justify-content:center;padding:2.5vh 0;position:relative;}
.poster{
  position:relative;
  width:min(95vw, 142vh);
  aspect-ratio:3 / 2;
  container-type:size;           /* enables cqw/cqh units below */
}
.poster .scrap--photo .ph{height:100%;object-fit:cover;}   /* controlled crops (each scrap sets aspect-ratio) */

/* headline */
.p-head{position:absolute;left:4%;top:5%;z-index:8;}
.hl{display:block;line-height:.84;}
.hl--top{
  font-family:'Archivo Black',sans-serif;font-size:8.4cqw;
  color:var(--ink);background:var(--paper);padding:.04em .22em .12em;
  transform:rotate(-3deg);box-shadow:var(--shadow-sm);
  clip-path:polygon(0 8%,4% 0,96% 6%,100% 0,99% 88%,95% 100%,4% 94%,1% 100%);
  letter-spacing:-.01em;}
.hl--bottom{
  font-family:'Anton',sans-serif;font-size:10.4cqw;
  color:var(--paper);background:var(--lilac-deep);padding:.02em .2em .12em;
  margin-top:-.04em;margin-left:.3em;transform:rotate(2deg);box-shadow:var(--shadow-sm);
  clip-path:polygon(2% 4%,8% 0,94% 5%,100% 1%,98% 90%,94% 100%,6% 95%,0 100%,2% 12%);}

/* sun */
.p-sun{left:54%;top:2%;width:13%;height:auto;z-index:7;}
.sun__face{fill:#ffd84a;stroke:#e9b400;stroke-width:4;}
.sun__rays path{stroke:#ffd84a;stroke-width:6;}
.sun__glass{fill:#15161a;stroke:#15161a;stroke-width:3;}
.sun__smile{stroke:#15161a;stroke-width:5;fill:none;}

/* photo placements (left/top/width as % of poster) — arranged round the hero,
   each with a deliberate aspect-ratio so the crops are consistent, not accidental */
.p-loch{left:56%;top:8%;width:27%;aspect-ratio:1.85/1;}
.p-tower{display:none;}
.p-check{left:.5%;top:30%;width:auto;font-size:1.08cqw;letter-spacing:.02em;z-index:14;}
.p-crowd{left:2%;top:50%;width:25%;aspect-ratio:1.55/1;}
.p-nessie{left:82%;top:43%;width:17%;aspect-ratio:1.3/1;}
.p-note{left:79.5%;top:30%;width:19%;font-size:2.2cqw;line-height:1.45;text-align:center;letter-spacing:.02em;z-index:30;}
.p-skyline{left:3%;bottom:7%;width:27%;aspect-ratio:1.55/1;}

/* ---- transparent cutout: the man ---- */
.cutout{position:absolute;pointer-events:none;}   /* transparent rects don't block clicks */
.cutout img{width:100%;height:auto;display:block;
  filter:drop-shadow(8px 10px 10px rgba(0,0,0,.45)) contrast(1.04) saturate(1.04);}

/* cow + cone share ONE canvas → overlay identically so the cone sits on the heid */
.cow-img,.cone-img,.cone-img img{position:absolute;inset:0;width:100%;height:100%;}
.cow-img{object-fit:contain;filter:drop-shadow(8px 10px 10px rgba(0,0,0,.4));}
.cone-img{border:0;background:transparent;padding:0;margin:0;cursor:pointer;pointer-events:auto;}
.cone-img img{object-fit:contain;filter:drop-shadow(6px 8px 8px rgba(0,0,0,.35));}
.cone-img:hover img{filter:drop-shadow(0 0 12px var(--lilac-deep)) drop-shadow(6px 8px 8px rgba(0,0,0,.35));}
.p-cone{transform-origin:50% 40%;}

/* "PLAY THE GEMME" cue pointing at the cone */
.play-cue{position:absolute;left:63.5%;top:54%;width:9.5%;z-index:22;cursor:pointer;
  text-align:center;pointer-events:auto;}
.play-cue__txt{display:inline-block;font-family:'Archivo Black',sans-serif;
  font-size:1.12cqw;color:#fff;background:var(--lilac-deep);padding:.38em .55em;
  transform:rotate(-4deg);box-shadow:var(--shadow-sm);letter-spacing:.02em;line-height:1.05;}
.play-cue__arrow{display:block;width:62%;margin:2% auto 0;transform:rotate(7deg);}
.play-cue__arrow path{fill:none;stroke:var(--lilac-deep);stroke-width:6;stroke-linecap:round;stroke-linejoin:round;}
.play-cue__arrow{animation:cueBob 1.3s ease-in-out infinite;}
@keyframes cueBob{0%,100%{transform:translate(0,0) rotate(7deg);}50%{transform:translate(6px,6px) rotate(10deg);}}

/* THE MAN — pushed DOWN so the white bottom bar covers his cut-off legs
   (reads as grounded, not floating). Only his position changes. */
.p-man{left:16%;bottom:-6%;width:74%;z-index:20;}

/* cow + cone GROUP — overlaid same-canvas images, bottom-right, bigger */
.p-cow-group{position:absolute;left:60%;bottom:-2%;width:42%;aspect-ratio:1236/1059;z-index:16;}

.p-star1{width:6%;height:auto;top:8%;right:24%;z-index:18;}
.p-star2{width:4.5%;height:auto;top:36%;left:17%;z-index:18;}

/* ============================================================
   WHITE TORN-PAPER TOKEN RIBBON (persistent, every page)
   ============================================================ */
/* SAME width as the poster (gaps on the sides), just extended down to the bottom.
   container-type lets the original cqw sizes resolve against the bar width. */
.p-ground{position:fixed;left:50%;transform:translateX(-50%);bottom:38px;
  --ground-lift:36px;--ground-drop:38px;--nav-slot:clamp(190px,20cqw,248px);
  width:min(95vw,134vh);container-type:inline-size;z-index:9305;box-sizing:border-box;
  background:transparent;color:var(--ink);display:grid;grid-template-columns:minmax(0,1fr) var(--nav-slot) minmax(0,1fr);
  align-items:center;gap:18px;padding:10px 3.2% 7px;}
.p-ground::before{content:"";position:absolute;left:0;right:0;top:calc(-1 * var(--ground-lift));bottom:calc(-1 * var(--ground-drop));z-index:0;
  background:#fff;box-shadow:0 -8px 18px rgba(0,0,0,.22);pointer-events:none;
  clip-path:polygon(0 18%,5% 5%,10% 18%,16% 3%,22% 18%,28% 4%,34% 18%,40% 3%,46% 18%,52% 4%,58% 18%,64% 3%,70% 18%,76% 4%,82% 18%,88% 3%,94% 18%,100% 5%,100% 100%,0 100%);}
.p-ground > *{position:relative;z-index:1;}
.p-ground .mint{display:inline-flex;align-items:center;gap:.45em;background:var(--ink);color:#fff;border:0;
  font-family:'Special Elite',monospace;font-size:1.16cqw;padding:.48em .62em;cursor:pointer;
  box-shadow:4px 5px 0 rgba(0,0,0,.22);grid-column:1;min-width:0;width:100%;transform:rotate(-.6deg);}
.p-ground .mint__lbl{background:var(--lilac-deep);padding:.12em .45em;font-weight:700;flex:0 0 auto;color:#fff;}
.p-ground .mint__addr{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.p-ground .socials{display:grid;grid-column:3;grid-template-columns:.58fr 1.55fr 1.25fr .75fr;gap:8px;min-width:0;width:100%;align-items:center;}
.p-ground .soc{font-family:'Archivo Black',sans-serif;font-size:1.05cqw;text-decoration:none;color:#fff;
  background:var(--lilac-deep);border:0;padding:.54em .4em;box-shadow:4px 5px 0 rgba(0,0,0,.22);text-align:center;min-width:0;overflow:hidden;text-overflow:ellipsis;
  transform:rotate(.7deg);transition:transform .15s,background .15s,color .15s;white-space:nowrap;}
.p-ground .soc:nth-child(even){transform:rotate(-.7deg);background:var(--ink);}
.p-ground .soc--dict{background:var(--lilac-deep);}
.p-ground .soc:hover{transform:rotate(0) translateY(-2px);background:var(--lilac-deep);color:#fff;}
@media(max-width:760px){
  .booknav{bottom:36px;}
  .p-ground{bottom:36px;--ground-lift:30px;--ground-drop:36px;--nav-slot:148px;width:100%;gap:6px;padding:8px 8px 7px;}
  .p-ground .mint{font-size:9px;padding:.5em .48em;}
  .p-ground .socials{gap:4px;}
  .p-ground .soc{font-size:9px;padding:6px 6px;}
}
@media(max-width:520px){
  .booknav{bottom:34px;}
  .p-ground{bottom:82px;--ground-lift:28px;--ground-drop:82px;--nav-slot:132px;
    grid-template-columns:minmax(0,1fr);
    grid-template-rows:auto auto;padding:8px 7px 6px;gap:6px 5px;}
  .p-ground .mint{grid-column:1 / -1;grid-row:1;font-size:10px;justify-self:center;width:min(92vw,390px);}
  .p-ground .socials{grid-column:1 / -1;grid-row:2;grid-template-columns:.65fr 1.45fr 1.15fr .75fr;gap:4px;width:min(92vw,390px);justify-self:center;}
  .p-ground .soc{font-size:8px;padding:5px 4px;box-shadow:3px 4px 0 rgba(0,0,0,.22);}
}

/* ransom strip */
.ransom{position:absolute;left:50%;bottom:1.5%;transform:translateX(-50%) rotate(-1.5deg);
  display:flex;gap:1%;z-index:7;font-family:'Special Elite',monospace;white-space:nowrap;}
.ransom span{background:var(--paper);color:var(--ink);padding:.4% 1%;
  font-size:2cqw;letter-spacing:.03em;box-shadow:var(--shadow-sm);}
.ransom span:nth-child(2){background:var(--lilac);transform:rotate(1.5deg);}

.scroll-cue{position:absolute;bottom:1.4%;right:2.5%;z-index:9;text-align:right;
  font-family:'Special Elite',monospace;font-size:13px;color:var(--lilac);
  letter-spacing:.1em;line-height:1.4;}
.scroll-cue em{color:rgba(255,255,255,.65);font-size:11px;}

/* ============================================================
   VIDEO WALL
   ============================================================ */
.videos{padding:8vh 4vw 10vh;}
.videos__head{text-align:center;margin-bottom:5vh;}
.vid-title{font-family:'Anton',sans-serif;font-size:clamp(36px,6.5vw,88px);
  color:var(--paper);transform:rotate(-1.5deg);letter-spacing:.01em;}
.vid-sub{font-family:'Special Elite',monospace;color:var(--lilac);margin-top:8px;font-size:clamp(13px,1.6vw,17px);}

.video-grid{display:grid;gap:30px 26px;max-width:1280px;margin:0 auto;
  grid-template-columns:repeat(4,minmax(0,280px));justify-content:center;}
@media(max-width:1100px){.video-grid{grid-template-columns:repeat(3,minmax(0,1fr));}}
@media(max-width:820px){.video-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:20px 16px;}}

.vtile{position:relative;background:var(--paper);padding:10px 10px 26px;
  box-shadow:var(--shadow);cursor:pointer;
  transform:rotate(var(--rot,-2deg));transition:transform .3s cubic-bezier(.2,.8,.2,1);will-change:transform;}
.vtile:nth-child(3n){--rot:2.4deg;}
.vtile:nth-child(4n){--rot:-3deg;}
.vtile:nth-child(5n){--rot:1.5deg;}
.vtile:hover{transform:rotate(0deg) scale(1.035);z-index:5;}
.vtile__media{position:relative;width:100%;aspect-ratio:9/16;background:var(--navy-deep);overflow:hidden;}
.vtile video{width:100%;height:100%;object-fit:cover;display:block;background:#000;}
.vtile__tape{position:absolute;top:-12px;left:50%;transform:translateX(-50%) rotate(-4deg);
  width:120px;height:30px;background:var(--tape);z-index:4;
  background-image:repeating-linear-gradient(90deg,rgba(255,255,255,.18) 0 6px,transparent 6px 12px);
  box-shadow:0 3px 6px rgba(0,0,0,.25);}
.vtile__play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  z-index:3;pointer-events:none;transition:opacity .2s;}
.vtile__play span{width:64px;height:64px;background:rgba(20,22,26,.78);border:3px solid var(--paper);
  display:flex;align-items:center;justify-content:center;
  clip-path:polygon(15% 0,100% 0,100% 100%,15% 100%,40% 50%);}
.vtile__play span::after{content:"";display:block;width:0;height:0;
  border-left:18px solid var(--paper);border-top:12px solid transparent;border-bottom:12px solid transparent;margin-left:6px;}
.vtile.playing .vtile__play{opacity:0;}
.vtile__handle{position:absolute;bottom:6px;left:8px;right:8px;font-family:'Special Elite',monospace;
  font-size:13px;color:var(--ink);display:flex;justify-content:space-between;align-items:center;}
.vtile__mute{pointer-events:auto;background:var(--ink);color:var(--paper);border:none;
  font-family:'Special Elite',monospace;font-size:11px;padding:3px 7px;cursor:pointer;letter-spacing:.04em;}
.vtile__mute:hover{background:var(--lilac-deep);}
.videos__empty{grid-column:1/-1;text-align:center;background:var(--paper);color:var(--ink);
  font-family:'Special Elite',monospace;padding:40px;transform:rotate(-1.5deg);
  max-width:420px;margin:0 auto;box-shadow:var(--shadow);font-size:18px;}

/* ============================================================
   STORY CHAPTERS — clean text / photo split (no overlap clutter)
   ============================================================ */
.chap{overflow:hidden;}
.chap--alt{background:rgba(0,0,0,.06);}
.chaprow{display:flex;align-items:center;justify-content:center;gap:5vw;
  width:100%;max-width:1180px;height:100%;margin:0 auto;padding:0 3vw;}
.chap--alt .chaprow{flex-direction:row-reverse;}
.chaptext{flex:1 1 0;max-width:48%;}
.chapfig{flex:1 1 0;max-width:48%;display:flex;justify-content:center;}
.chapfig .scrap--photo{width:min(100%,460px);}
.chapfig .scrap--photo .ph{height:auto;}

.chap__title{font-family:'Anton',sans-serif;line-height:.9;letter-spacing:-.005em;
  font-size:clamp(36px,5.2vw,82px);color:var(--paper);position:relative;}
.chap__title span{display:block;}
.chap__title .ink{color:var(--lilac);}
.chap__title .ink-lilac{color:var(--ink);background:var(--lilac);padding:0 .12em;
  display:inline-block;transform:rotate(-1.5deg);box-shadow:var(--shadow-sm);margin-top:.06em;}

.chap__body{font-family:'Special Elite',monospace;font-size:clamp(15px,1.5vw,19px);
  line-height:1.6;color:rgba(255,255,255,.94);margin-top:1.1em;max-width:30em;}

.big-num{font-family:'Archivo Black',sans-serif;font-size:clamp(90px,12.5vw,196px);
  line-height:.8;color:var(--lilac-deep);-webkit-text-stroke:2px rgba(255,255,255,.28);
  margin-bottom:.02em;}

.checklist{list-style:none;margin-top:1.1em;font-family:'Anton',sans-serif;
  font-size:clamp(20px,2.6vw,40px);letter-spacing:.02em;}
.checklist li{display:flex;align-items:center;gap:12px;margin:.16em 0;color:var(--paper);}
.checklist li:nth-child(even){color:var(--lilac);}
.checklist .tick{position:static;width:clamp(28px,3vw,40px);height:clamp(28px,3vw,40px);flex:0 0 auto;}

.inline-heart{position:static;display:inline-block;width:clamp(34px,4vw,54px);
  height:clamp(34px,4vw,54px);vertical-align:-.18em;margin-left:.12em;}

/* ============================================================
   DESIGNED CHAPTER PAGES (composition concepts on the real site)
   ============================================================ */
.chap .stage{position:relative;width:100%;max-width:1180px;height:100%;margin:0 auto;}

/* shared scrap bits */
.placeholder{display:flex;align-items:center;justify-content:center;text-align:center;
  background:rgba(255,255,255,.07);border:2px dashed rgba(255,255,255,.65);
  font-family:'Special Elite',monospace;color:rgba(255,255,255,.88);
  font-size:clamp(11px,1.05vw,14px);line-height:1.45;padding:10px;box-shadow:var(--shadow-sm);}
.placeholder b{color:var(--lilac);}
.stamp{font-family:'Archivo Black',sans-serif;color:var(--lilac-deep);
  border:3px solid var(--lilac-deep);background:rgba(255,255,255,.93);
  padding:6px 14px;font-size:clamp(15px,1.7vw,24px);letter-spacing:.04em;
  transform:rotate(-8deg);box-shadow:var(--shadow-sm);}
.scrap__cap{position:absolute;left:6%;right:6%;bottom:5%;font-family:'Special Elite',monospace;
  font-size:clamp(9px,.95vw,12px);color:var(--ink);text-align:center;}
.kickpath path,.co-lines path{stroke:var(--lilac-deep);stroke-width:4;fill:none;stroke-linecap:round;}

/* ---- Page 3: 28-year time capsule ---- */
.chap--years .bignum-bg{position:absolute;right:1%;top:-6%;z-index:0;
  font-family:'Archivo Black',sans-serif;font-size:clamp(200px,42vw,560px);line-height:.8;
  color:#fff;opacity:.12;}
.yr-title{position:absolute;left:3%;top:11%;z-index:4;}
.yr-body{position:absolute;left:3%;top:42%;max-width:31%;z-index:4;margin-top:0;}
.yr-body strong{color:var(--lilac);}
.yr-past{position:absolute;left:3%;bottom:6%;width:31%;aspect-ratio:1.45/1;z-index:3;}
.yr-mctom{position:absolute;right:5%;bottom:9%;width:27%;aspect-ratio:.82/1;z-index:3;}
.kickpath{position:absolute;left:30%;top:30%;width:47%;height:46%;z-index:2;pointer-events:none;}
.yr-score{position:absolute;right:8%;top:15%;z-index:5;}

/* ---- Page 5: cone-over case file ---- */
.co-title{position:absolute;left:3%;top:7%;z-index:5;}
.co-sub{position:absolute;left:3%;top:27%;max-width:25%;z-index:5;
  font-family:'Special Elite',monospace;color:rgba(255,255,255,.92);
  font-size:clamp(13px,1.3vw,16px);line-height:1.5;}
.co-hub{position:absolute;left:44%;top:33%;width:13%;z-index:4;}
.co-lines{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none;}
.co-ev{position:absolute;width:21%;z-index:3;}
.co-ev.scrap--photo,.placeholder.co-ev{aspect-ratio:1.3/1;}
.co-ev1{left:5%;top:13%;}
.co-ev2{right:4%;top:11%;}
.co-ev3{left:5%;bottom:8%;}
.co-ev4{right:4%;bottom:8%;}
.co-stamp{position:absolute;left:50%;bottom:4%;transform:translateX(-50%) rotate(-6deg);z-index:6;}

/* mobile reflow for the designed stage pages */
@media(max-width:760px){
  .chap .stage{display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:1.8vh;height:100%;text-align:center;padding:0 5vw;}
  .chap .stage > *{position:static!important;transform:none!important;
    left:auto!important;right:auto!important;top:auto!important;bottom:auto!important;
    margin:0!important;max-width:92%!important;width:auto;}
  .bignum-bg,.kickpath,.co-lines{display:none!important;}
  .yr-past,.yr-mctom{width:56%!important;}
  .co-hub{width:30%!important;}
  .co-ev1{width:66%!important;}
  .co-ev2,.co-ev3,.co-ev4{display:none!important;}
  .co-sub,.yr-body{font-size:4vw!important;max-width:92%!important;}
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{position:relative;padding:9vh 6vw 12vh;text-align:center;}
.footer__scrap{display:inline-block;background:var(--paper);color:var(--ink);
  padding:26px 44px;transform:rotate(-2deg);box-shadow:var(--shadow);
  clip-path:polygon(0 6%,5% 0,95% 5%,100% 0,99% 92%,94% 100%,6% 95%,2% 100%,0 88%);}
.footer__big{display:block;font-family:'Archivo Black',sans-serif;font-size:clamp(26px,5vw,52px);letter-spacing:-.01em;}
.footer__small{display:block;font-family:'Special Elite',monospace;margin-top:6px;color:var(--lilac-deep);}
.footer__star{width:60px;height:60px;position:absolute;right:18%;top:30%;}

/* ============================================================
   MOBILE / NARROW — keep the BOOKLET (every page fits one screen)
   ============================================================ */
@media(max-width:760px){
  .dict-link em{display:none;}
  .dict-link{font-size:12px;padding:6px 9px;}
  .flip-hint{display:none;}
  .page{padding:0 10px 80px;}
  .nav{width:42px;height:42px;font-size:23px;}

  /* cover poster: already 3:2, just give it the width */
  .page--cover .poster{width:94vw;}

  @media(orientation:portrait){
    .page--cover{align-items:flex-start;padding-top:clamp(34px, 9svh, 78px);}
  }

  /* chapters → stack text + photo, centred, fits one screen */
  .page--chap .chaprow{flex-direction:column !important;gap:2.4vh;height:100%;
    justify-content:center;text-align:center;padding:0 5vw;}
  .chaptext,.chapfig{max-width:100% !important;flex:0 0 auto;}
  .chaptext{text-align:center;display:flex;flex-direction:column;align-items:center;}
  .chap__title{font-size:9.8vw !important;}
  .big-num{font-size:26vw !important;}
  .chap__body{font-size:4vw !important;max-width:92% !important;margin-top:.6em;}
  .checklist{font-size:6vw !important;}
  .checklist li{justify-content:center;}
  .chapfig .scrap--photo{width:74% !important;max-width:74vw;}
  .chapfig .scrap--photo .ph{height:30dvh !important;object-fit:cover;}

  /* video carousel */
  .vtile{height:54vh !important;}
  .vnav{width:38px;height:38px;}
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media(prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important;}
}
