/* site.css — shared styles for Sterling's World (lobby + attractions + library + jukebox).
   Extracted from the homepage's inline styles so every page shares one source. */

  :root{
    --cream:#f7ecd6; --cream-2:#f0ddbb; --paper:#fffaf0;
    --ink:#3a2a18; --ink-soft:#6d5a42; --line:#e3cfa6;
    --gold:#d8b878; --wood:#7a4f2a;
    /* land energy temperatures */
    --rest:#1f7a5e; --rest-deep:#0e5743;
    --play:#bd7a16; --play-deep:#8a5810;
    --adv:#d2542b;  --adv-deep:#9c3c1d;
    --radius:20px; --shadow:0 10px 30px -12px rgba(58,32,12,.35);
    --maxw:1180px;
  }
  *{box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    margin:0; color:var(--ink);
    font-family:"Atkinson Hyperlegible",system-ui,sans-serif;
    font-size:17px; line-height:1.6;
    background:
      radial-gradient(1200px 600px at 80% -5%, #ffe9c7 0%, transparent 55%),
      radial-gradient(1000px 700px at -10% 10%, #ffe3d2 0%, transparent 50%),
      var(--cream);
    background-attachment:fixed;
  }
  h1,h2,h3{font-family:"Outfit",sans-serif; margin:0; line-height:1.1; letter-spacing:-.01em}
  a{color:inherit}
  img{display:block; max-width:100%}

  /* ---------- accessibility ---------- */
  .skip{position:absolute; left:-9999px; top:0; background:var(--ink); color:#fff;
        padding:12px 18px; border-radius:0 0 12px 0; z-index:200; font-weight:700}
  .skip:focus{left:0}
  :focus-visible{outline:3px solid var(--ink); outline-offset:3px; border-radius:8px}
  .sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}

  /* ---------- top bar ---------- */
  .topbar{position:sticky; top:0; z-index:100;
    display:flex; align-items:center; gap:14px; flex-wrap:wrap;
    padding:10px clamp(14px,4vw,32px);
    background:rgba(247,236,214,.86); backdrop-filter:blur(8px);
    border-bottom:1px solid var(--line)}
  .brand{display:flex; align-items:center; gap:10px; font-family:"Outfit"; font-weight:800;
    font-size:18px; margin-right:auto; text-decoration:none}
  .brand .pin{width:26px;height:26px;border-radius:7px;object-fit:cover;display:block}
  .jump{display:flex; gap:8px; flex-wrap:wrap}
  .jump a{display:inline-flex; align-items:center; gap:7px; text-decoration:none;
    font-weight:700; font-size:14px; padding:9px 14px; border-radius:999px;
    background:var(--paper); border:1px solid var(--line); color:var(--ink); min-height:42px}
  .jump a:hover{transform:translateY(-1px)}
  .jump a .ic{width:16px;height:16px}
  .j-rest .ic{color:var(--rest)} .j-play .ic{color:var(--play)} .j-adv .ic{color:var(--adv)}


  /* ---------- Hamburger Menu ---------- */
  .menu-btn {
    display: flex; flex-direction: column; justify-content: center; align-items: center; gap: 5px;
    width: 42px; height: 42px; background: var(--paper); border: 1px solid var(--line);
    border-radius: 8px; cursor: pointer; color: var(--ink); margin-left: auto;
  }
  .menu-btn .bar { width: 20px; height: 2px; background: currentColor; transition: transform 0.3s, opacity 0.3s; }
  .menu-btn.open .bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .menu-btn.open .bar:nth-child(2) { opacity: 0; }
  .menu-btn.open .bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

  .side-menu {
    position: fixed; top: 0; right: -300px; width: 280px; height: 100vh;
    background: var(--paper); box-shadow: -4px 0 24px rgba(0,0,0,0.15); z-index: 320;
    transition: right 0.3s ease; padding: 24px; display: flex; flex-direction: column; gap: 16px;
    border-left: 1px solid var(--line);
  }
  .side-menu.open { right: 0; }
  .side-menu-overlay {
    position: fixed; top: 0; right: 0; bottom: 0; left: 0; background: rgba(0,0,0,0.4);
    backdrop-filter: blur(4px); z-index: 315; display: none; opacity: 0; transition: opacity 0.3s;
  }
  .side-menu-overlay.open { display: block; opacity: 1; }

  .side-menu a {
    text-decoration: none; font-family: "Outfit", sans-serif; font-size: 1.4rem; font-weight: 700;
    color: var(--ink); display: flex; align-items: center; gap: 12px; padding: 12px;
    border-radius: 12px; transition: background 0.2s;
  }
  .side-menu a:hover { background: var(--cream); }
  .side-menu a .ic { width: 20px; height: 20px; }

  .menu-close { align-self: flex-end; cursor: pointer; background: none; border: none; font-size: 24px; color: var(--ink-soft); padding: 8px; }

  /* Hide the old jump links */
  .jump { display: none; }

  /* ---------- hero ---------- */
  .hero{position:relative; min-height:clamp(420px,62vh,600px); display:flex; align-items:flex-start;
    overflow:hidden}
  .hero-bg{position:absolute; top:0; right:0; bottom:0; left:0; width:100%; height:100%; object-fit:cover; object-position:center 35%}
  .hero-scrim{position:absolute; top:0; right:0; bottom:0; left:0;
    background:linear-gradient(180deg, rgba(20,8,30,.52) 0%, rgba(20,8,30,.16) 34%, transparent 62%)}
  .hero-inner{position:relative; width:100%; max-width:var(--maxw); margin:0 auto;
    display:block;
    padding:clamp(26px,9vh,72px) clamp(16px,4vw,32px) 0}
  .sterling{width:clamp(150px,22vw,260px); height:auto; filter:drop-shadow(0 18px 18px rgba(0,0,0,.32));
    transform-origin:bottom center}
  .hero-copy{padding-bottom:8px; max-width:640px}
  .hero h1{color:#fff; font-size:clamp(2.4rem,7vw,4.6rem); font-weight:800;
    text-shadow:0 3px 22px rgba(0,0,0,.45)}
  .hero h1 .amp{color:var(--gold)}
  .hero p{color:#fff; font-size:clamp(1rem,2.4vw,1.3rem); margin:.5rem 0 0;
    text-shadow:0 2px 12px rgba(0,0,0,.55); font-weight:400}
  .hero .cue{margin-top:16px; display:inline-flex; align-items:center; gap:8px;
    color:#fff; font-weight:700; font-size:14px; opacity:.95;
    background:rgba(0,0,0,.28); padding:8px 14px; border-radius:999px; text-decoration:none}

  /* ---------- lands ---------- */
  main{max-width:var(--maxw); margin:0 auto; padding:clamp(20px,4vw,40px) 0 60px}
  .land{margin:0 0 clamp(34px,5vw,56px); --accent:var(--rest); --accent-deep:var(--rest-deep)}
  .land.play{--accent:var(--play); --accent-deep:var(--play-deep)}
  .land.adv{--accent:var(--adv); --accent-deep:var(--adv-deep)}

  .land-head{position:relative; margin:0 clamp(12px,3vw,20px); border-radius:var(--radius);
    overflow:hidden; min-height:clamp(150px,22vw,210px); display:flex; align-items:flex-end;
    box-shadow:var(--shadow); border:1px solid rgba(0,0,0,.06)}
  /* The Lobby uses .land-head itself as a single big call-to-action card
     instead of a banner over a rail of small cards. It's an <a>, so it needs
     hover/focus affordances and a tap-to-feedback compress. */
  a.land-head{display:flex; text-decoration:none; color:inherit; cursor:pointer;
    min-height:clamp(180px,32vw,300px);
    transition:transform .18s ease, box-shadow .18s ease; will-change:transform}
  a.land-head:hover{transform:translateY(-3px); box-shadow:0 16px 40px -12px rgba(58,32,12,.45)}
  a.land-head:active{transform:translateY(0)}
  a.land-head:focus-visible{outline:3px solid var(--accent); outline-offset:3px}

  /* Library = a split into click halves (Reader / Audiobook / Kid Zone).
     Each half behaves like a tiny land-head: image + scrim + title-row with
     badge. Equal columns at every width that fits them all in one row; on
     very narrow screens the last card wraps to a full-width row of its own
     instead of squeezing the badge + title beyond readability. */
  .split{display:flex; flex-wrap:wrap; gap:clamp(8px,1.6vw,14px); margin:0 clamp(12px,3vw,20px)}
  .split > a{flex:1 1 220px; position:relative; overflow:hidden; border-radius:var(--radius);
    min-height:clamp(150px,28vw,260px); display:flex; align-items:flex-end;
    text-decoration:none; color:#fff; cursor:pointer;
    box-shadow:var(--shadow); border:1px solid rgba(0,0,0,.06);
    transition:transform .18s ease, box-shadow .18s ease; will-change:transform}
  .split > a:hover{transform:translateY(-3px); box-shadow:0 16px 40px -12px rgba(58,32,12,.45)}
  .split > a:active{transform:translateY(0)}
  .split > a:focus-visible{outline:3px solid var(--accent); outline-offset:3px}
  .split > a > img{position:absolute; top:0; right:0; bottom:0; left:0;
    width:100%; height:100%; object-fit:cover}
  .split > a > .scrim{position:absolute; top:0; right:0; bottom:0; left:0;
    background:linear-gradient(180deg, rgba(0,0,0,.06) 0%, transparent 30%, rgba(0,0,0,.66) 100%)}
  .split-title{position:relative; padding:clamp(12px,2.4vw,20px); width:100%;
    display:flex; align-items:center; gap:10px}
  .split-title .land-badge{width:clamp(36px,6vw,52px); height:clamp(36px,6vw,52px)}
  .split-title h3{font-family:"Outfit", sans-serif; font-weight:800;
    font-size:clamp(1.05rem,3vw,1.6rem); text-shadow:0 2px 14px rgba(0,0,0,.55); line-height:1.1}
  .split-title .sub{display:block; font-size:clamp(.78rem,1.7vw,.95rem);
    font-weight:400; opacity:.95; text-shadow:0 1px 8px rgba(0,0,0,.6); margin-top:3px}
  .land-head img{position:absolute; top:0; right:0; bottom:0; left:0; width:100%; height:100%; object-fit:cover}
  .land-head .scrim{position:absolute; top:0; right:0; bottom:0; left:0;
    background:linear-gradient(180deg, rgba(0,0,0,.06) 0%, transparent 30%, rgba(0,0,0,.62) 100%)}
  .land-title{position:relative; padding:clamp(14px,3vw,24px); color:#fff; width:100%;
    display:flex; align-items:center; gap:14px; flex-wrap:wrap}
  .land-badge{width:clamp(44px,7vw,58px); height:clamp(44px,7vw,58px); border-radius:50%;
    background:var(--accent); display:flex; align-items:center; justify-content:center;
    box-shadow:0 6px 16px rgba(0,0,0,.4); flex:none}
  .land-badge svg{width:56%; height:56%; color:#fff}
  .land-title h2{font-size:clamp(1.5rem,4.2vw,2.3rem); font-weight:800; text-shadow:0 2px 14px rgba(0,0,0,.5)}
  .land-title .sub{font-size:clamp(.85rem,2.2vw,1rem); font-weight:400; opacity:.95;
    text-shadow:0 1px 8px rgba(0,0,0,.6)}
  .land-title .meter{margin-left:auto; display:inline-flex; align-items:center; gap:8px;
    background:rgba(0,0,0,.32); padding:7px 13px; border-radius:999px; font-size:13px; font-weight:700}
  .meter .dots{display:inline-flex; gap:4px}
  .meter .d{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.45)}
  .meter .d.on{background:#fff}

  /* ---------- arcade grid ---------- */
  .arcade-grid{display:grid; grid-template-columns:repeat(auto-fit, minmax(240px, 1fr)); gap:clamp(12px,2vw,18px); padding:8px clamp(12px,3vw,20px) 20px; margin-top:16px}

  /* ---------- card ---------- */
  .card{background:var(--paper); border:1px solid var(--line); border-radius:var(--radius);
    overflow:hidden; text-decoration:none; color:var(--ink); display:flex; flex-direction:column;
    box-shadow:0 6px 18px -10px rgba(58,32,12,.3); transition:transform .2s ease, box-shadow .2s ease}
  .card:hover,.card:focus-visible{transform:translateY(-6px);
    box-shadow:0 18px 34px -14px rgba(58,32,12,.5), 0 0 0 3px var(--accent); outline:none}
  .card figure{margin:0; position:relative; width:100%; padding-top:75%; background:var(--cream-2)}
  .card figure img{position:absolute; top:0; right:0; bottom:0; left:0; width:100%; height:100%; object-fit:cover}
  .card figure::after{content:""; position:absolute; top:0; right:0; bottom:0; left:0; box-shadow:inset 0 -1px 0 rgba(0,0,0,.06)}
  .card .body{padding:14px 16px 16px; display:flex; flex-direction:column; gap:4px; flex:1}
  .card h3{font-size:1.2rem; font-weight:700}
  .card .blurb{color:var(--ink-soft); font-size:.95rem; flex:1}
  .card .foot{display:flex; align-items:center; justify-content:space-between; margin-top:8px}

  .enter{display:inline-flex; align-items:center; gap:6px; font-weight:700; font-size:.95rem; color:var(--accent-deep)}
  .enter svg{width:17px;height:17px}
  .card figure.noart{background:linear-gradient(140deg,var(--accent),var(--accent-deep))}
  .card figure.noart .glyph{position:absolute; top:0;right:0;bottom:0;left:0; display:flex;
    align-items:center; justify-content:center; color:#fff; font-family:"Outfit",sans-serif; font-weight:800; font-size:3.2rem}
  .card .ext-tag{position:absolute; top:10px; right:10px; background:rgba(0,0,0,.55); color:#fff;
    font-size:.72rem; font-weight:700; padding:4px 9px; border-radius:999px}
  .card.soon{cursor:default; pointer-events:none}
  .card.soon figure{filter:saturate(.55) brightness(.85)}
  .card.soon .enter{color:var(--ink-soft)}

  /* ---------- game finder ---------- */
  .game-finder{margin:16px clamp(12px,3vw,20px) 4px; padding:14px 16px;
    background:rgba(255,250,240,.76); border:1px solid rgba(210,84,43,.24); border-radius:14px}
  .game-finder-head{display:flex; align-items:flex-start; justify-content:space-between; gap:16px; flex-wrap:wrap}
  .game-finder h3{font-size:1.15rem; color:var(--adv-deep)}
  .game-finder p{margin:3px 0 0; color:var(--ink-soft); font-size:.94rem; line-height:1.45}
  .randomizer-actions{display:flex; gap:10px; flex-wrap:wrap; align-items:center}
  .randomizer-button{display:inline-flex; align-items:center; gap:10px; min-height:52px; padding:10px 16px;
    border:0; border-radius:999px; background:linear-gradient(180deg,var(--adv),var(--adv-deep)); color:#fff;
    font-family:"Outfit",sans-serif; font-size:.98rem; font-weight:800; cursor:pointer;
    box-shadow:0 4px 0 var(--adv-deep), 0 10px 20px rgba(210,84,43,.22);
    transition:transform .12s ease, box-shadow .12s ease}
  .randomizer-button.secondary{background:linear-gradient(180deg,#7a4f2a,#4d301a); box-shadow:0 4px 0 #3a2414, 0 10px 20px rgba(77,48,26,.2)}
  .randomizer-button svg{width:20px; height:20px; flex:none}
  .randomizer-button span{display:flex; flex-direction:column; align-items:flex-start; line-height:1.05}
  .randomizer-button small{margin-top:3px; font-family:"Atkinson Hyperlegible",system-ui,sans-serif; font-size:.74rem; font-weight:700; opacity:.88}
  .randomizer-button:hover,.randomizer-button:focus-visible{transform:translateY(-2px);
    box-shadow:0 6px 0 var(--adv-deep), 0 14px 24px rgba(210,84,43,.24)}
  .randomizer-button:focus-visible{outline:3px solid var(--ink); outline-offset:3px}
  .randomizer-button.secondary:hover,.randomizer-button.secondary:focus-visible{box-shadow:0 6px 0 #3a2414, 0 14px 24px rgba(77,48,26,.24)}
  .randomizer-button:active{transform:translateY(2px); box-shadow:0 2px 0 var(--adv-deep)}
  .randomizer-button.secondary:active{box-shadow:0 2px 0 #3a2414}
  @media (max-width:620px){
    .randomizer-actions{width:100%}
    .randomizer-button{width:100%; justify-content:flex-start}
  }

  /* ---------- party games ---------- */
  .party-games{max-width:var(--maxw); margin:clamp(18px,4vw,34px) auto; padding:0 clamp(12px,3vw,20px)}
  .party-games-head{display:flex; align-items:end; justify-content:space-between; gap:14px; margin-bottom:14px}
  .party-games h2{font-size:clamp(1.5rem,4.2vw,2.3rem); color:var(--ink)}
  .party-games .sub{display:block; color:var(--ink-soft); font-size:clamp(.88rem,2vw,1rem)}
  .party-games-grid{display:grid; grid-template-columns:minmax(0,360px); gap:16px}
  .party-games .card{width:100%; max-width:360px; flex:none}


  /* ---------- footer ---------- */
  footer{max-width:var(--maxw); margin:0 auto; padding:28px clamp(16px,4vw,32px) 60px;
    border-top:1px solid var(--line); color:var(--ink-soft); font-size:.9rem; text-align:center}
  footer strong{color:var(--ink)}

  /* ---------- motion / reveal ---------- */
  .reveal{transition:opacity .6s ease, transform .6s ease}
  .js .reveal:not(.in){opacity:0; transform:translateY(26px)}
  .arcade-grid .card{transition:transform .2s ease, box-shadow .2s ease, opacity .5s ease}
  @keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
  .sterling{animation:floaty 6s ease-in-out infinite}
  @keyframes heroup{from{opacity:0; transform:translateY(26px)}to{opacity:1; transform:none}}
  .hero-copy{animation:heroup .8s .15s both}

  @media (prefers-reduced-motion: reduce){
    html{scroll-behavior:auto}
    *{animation:none !important; transition:none !important}
    .reveal, .js .reveal:not(.in){opacity:1; transform:none}
  }
  /* ---------- Entry overlays: medical disclaimer + splash intro (ported) ---------- */
  .disclaimer-overlay{position:fixed; top:0;right:0;bottom:0;left:0; z-index:300; display:flex;
    align-items:center; justify-content:center; background:rgba(20,12,8,.92);
    backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px); padding:20px; opacity:1; transition:opacity .5s ease}
  .disclaimer-overlay.hiding{opacity:0; pointer-events:none}
  .disclaimer-card{max-width:480px; width:100%; background:linear-gradient(180deg,#fffaf0,var(--paper));
    border:3px solid var(--gold); border-radius:22px; padding:30px 26px; text-align:center; box-shadow:0 20px 60px rgba(0,0,0,.5)}
  .disclaimer-card .warn-icon{font-size:2.4rem; margin-bottom:8px}
  .disclaimer-card h2{font-family:"Outfit",sans-serif; font-size:1.5rem; color:var(--ink); font-weight:800; margin-bottom:12px}
  .disclaimer-card p{color:var(--ink-soft); font-size:.95rem; line-height:1.6; margin-bottom:14px; text-align:left}
  .disclaimer-card p strong{color:var(--ink)}
  .disclaimer-card .highlight{background:rgba(210,84,43,.12); border-left:4px solid var(--adv);
    padding:12px 16px; border-radius:0 10px 10px 0; margin-bottom:18px; text-align:left; font-size:.9rem; color:var(--ink-soft); line-height:1.6}
  .disclaimer-card .highlight strong{color:var(--adv-deep)}
  .disclaimer-accept{background:linear-gradient(180deg,var(--adv),var(--adv-deep)); color:#fff; border:0;
    font-family:"Outfit",sans-serif; font-weight:700; font-size:1.1rem; padding:.9em 2em; border-radius:999px; cursor:pointer;
    box-shadow:0 4px 0 var(--adv-deep), 0 8px 20px rgba(210,84,43,.3); transition:transform .12s ease; min-height:52px}
  .disclaimer-accept:active{transform:translateY(3px); box-shadow:0 1px 0 var(--adv-deep)}
  .disclaimer-accept:focus-visible{outline:3px solid var(--ink); outline-offset:4px}

  .splash{position:fixed; top:0;right:0;bottom:0;left:0; z-index:290; background:#05060c; display:none;
    align-items:center; justify-content:center; overflow:hidden; opacity:1; transition:opacity .6s ease}
  .splash.show{display:flex}
  .splash.fading{opacity:0}
  .splash video{position:absolute; top:0;right:0;bottom:0;left:0; width:100%; height:100%; object-fit:cover; background:#05060c}
  .splash-skip{position:absolute; right:24px; bottom:max(24px,env(safe-area-inset-bottom)); z-index:292;
    background:rgba(0,0,0,.65); color:#fff; border:2px solid rgba(255,255,255,.85); font-family:"Outfit",sans-serif; font-weight:700;
    font-size:1.05rem; padding:.7em 1.5em; border-radius:999px; cursor:pointer; min-height:48px;
    backdrop-filter:blur(4px); -webkit-backdrop-filter:blur(4px)}
  .splash-skip:focus-visible{outline:3px solid var(--gold); outline-offset:2px}
  .splash-hint{position:absolute; left:24px; bottom:max(26px,env(safe-area-inset-bottom)); z-index:292;
    color:rgba(255,255,255,.85); font-family:"Outfit",sans-serif; font-size:1.2rem; letter-spacing:.04em; font-weight:700; text-shadow:0 2px 6px rgba(0,0,0,.6)}
  @media (prefers-reduced-motion:reduce){ .disclaimer-overlay,.splash{transition:none} }
  /* Returning visitors who accepted within 30 days skip the gate (class set by an early script). */
  .sw-consented .disclaimer-overlay{display:none!important}
  /* Opt-in welcome tour launcher */
  #tourLaunch{position:fixed;left:max(12px,env(safe-area-inset-left));bottom:max(12px,env(safe-area-inset-bottom));z-index:200;
    background:var(--ink);color:var(--paper);border:none;border-radius:999px;padding:11px 16px;cursor:pointer;
    font:800 .85rem/1 "Outfit",system-ui,sans-serif;box-shadow:0 10px 26px -10px rgba(0,0,0,.5)}
  #tourLaunch[hidden]{display:none}
  #tourLaunch:focus-visible{outline:3px solid var(--gold);outline-offset:2px}






  /* ---------- Guided Modal ---------- */
  .guide-overlay {
    position: fixed; top: 0; right: 0; bottom: 0; left: 0; z-index: 410;
    display: none; align-items: center; justify-content: center;
    background: rgba(20, 12, 8, 0.92); backdrop-filter: blur(8px);
    padding: 20px; opacity: 1; transition: opacity 0.5s ease;
  }
  .guide-overlay.show { display: flex !important; }
  .guide-overlay.hiding { opacity: 0; pointer-events: none; }
  .guide-card {
    max-width: 480px; width: 100%; background: linear-gradient(180deg, #fffaf0, var(--paper));
    border: 3px solid var(--play); border-radius: 22px; padding: 30px 26px; text-align: center;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
  }
  .guide-card h2 { font-family: "Outfit", sans-serif; font-size: 1.8rem; color: var(--ink); font-weight: 800; margin-bottom: 12px; }
  .guide-card p { color: var(--ink-soft); font-size: 1.05rem; line-height: 1.6; margin-bottom: 24px; }
  .guide-kicker{font-family:"Outfit",sans-serif; font-weight:800; color:var(--play-deep); text-transform:uppercase;
    letter-spacing:.08em; font-size:.78rem; margin:0 0 8px !important}
  .guide-steps { display: flex; justify-content: center; gap: 8px; margin-bottom: 20px; }
  .guide-step-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--line); }
  .guide-step-dot.active { background: var(--play); transform:scale(1.2); }
  .guide-actions{display:flex; justify-content:center; gap:10px; flex-wrap:wrap}
  .guide-btn {
    background: linear-gradient(180deg, var(--play), var(--play-deep)); color: #fff; border: 0;
    font-family: "Outfit", sans-serif; font-weight: 700; font-size: 1.1rem; padding: 0.9em 1.5em; border-radius: 999px; cursor: pointer;
    box-shadow: 0 4px 0 var(--play-deep), 0 8px 20px rgba(189, 122, 22, 0.3); transition: transform 0.12s ease; min-height: 52px;
  }
  .guide-link{background:transparent; color:var(--ink-soft); border:0; font-family:"Atkinson Hyperlegible",system-ui,sans-serif;
    font-weight:700; padding:.75em .85em; min-height:44px; cursor:pointer; text-decoration:underline}
  .guide-btn:active { transform: translateY(3px); box-shadow: 0 1px 0 var(--play-deep); }
  .guide-btn:focus-visible,.guide-link:focus-visible { outline: 3px solid var(--ink); outline-offset: 4px; }
/* ---------- Preloader (Sterling, shows while the page loads) ---------- */
  #loader{position:fixed; top:0;right:0;bottom:0;left:0; z-index:400; display:flex; flex-direction:column;
    align-items:center; justify-content:center; gap:16px; padding:24px;
    background:radial-gradient(1000px 600px at 50% 32%, #ffe9c7, transparent 60%), var(--cream);
    transition:opacity .5s ease}
  #loader.loaded{opacity:0; pointer-events:none}
  #loader img{width:clamp(130px,26vw,210px); height:auto; filter:drop-shadow(0 14px 16px rgba(0,0,0,.18));
    animation:loadbob 2.4s ease-in-out infinite}
  #loader .lw{font-family:"Outfit",sans-serif; font-weight:800; font-size:clamp(1.4rem,5vw,2rem); color:var(--ink)}
  #loader .bar{width:min(240px,60vw); height:8px; border-radius:999px; background:var(--cream-2); overflow:hidden; position:relative}
  #loader .bar::after{content:""; position:absolute; top:0; left:-40%; height:100%; width:40%;
    background:linear-gradient(90deg, transparent, var(--play), var(--adv), transparent); border-radius:999px;
    animation:loadsweep 1.2s ease-in-out infinite}
  #loader .lt{font-family:"Atkinson Hyperlegible",sans-serif; font-size:.9rem; color:var(--ink-soft)}
  @keyframes loadbob{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
  @keyframes loadsweep{0%{left:-40%}100%{left:100%}}
  @media (prefers-reduced-motion:reduce){
    #loader{transition:none}
    #loader img{animation:none}
    #loader .bar::after{animation:none; left:0; width:100%; opacity:.5}
  }
  /* ---------- Community jukebox (standalone) ---------- */
  .j-jb .ic{color:#8a4bbf}
  .jukebox{margin:0 clamp(12px,3vw,20px) clamp(34px,5vw,56px); --accent:#8a4bbf; --accent-deep:#5e2f86}
  .jb-head{display:flex; align-items:center; gap:14px; margin-bottom:16px; padding:0 4px}
  .jb-badge{width:clamp(44px,7vw,58px); height:clamp(44px,7vw,58px); border-radius:50%; flex:none;
    background:linear-gradient(140deg,var(--accent),var(--accent-deep)); color:#fff; display:flex;
    align-items:center; justify-content:center; font-family:"Outfit",sans-serif; font-weight:800; font-size:1.6rem;
    box-shadow:0 6px 16px rgba(94,47,134,.4)}
  .jb-head h2{font-family:"Outfit",sans-serif; font-weight:800; font-size:clamp(1.5rem,4.2vw,2.3rem); color:var(--ink)}
  .jb-head .sub{color:var(--ink-soft); font-size:clamp(.85rem,2.2vw,1rem)}
  .jb-grid{display:grid; grid-template-columns:1fr; gap:18px}
  @media(min-width:780px){ .jb-grid{grid-template-columns:1fr 320px} }
  .jb-player{background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:10px; box-shadow:var(--shadow)}
  .jb-player iframe{display:block; width:100%; height:420px; border:0; border-radius:12px}
  .jb-soon{position:relative; border-radius:var(--radius); overflow:hidden; border:1px solid var(--line);
    box-shadow:var(--shadow); background:var(--paper); display:flex; flex-direction:column}
  .jb-soon img{width:100%; height:auto; display:block}
  .jb-soon p{margin:0; padding:14px 16px; color:var(--ink-soft); font-size:.95rem; line-height:1.5}
  .jb-soon p strong{color:var(--accent-deep)}

  /* Floating background-music control after the disclaimer kicks it off. */



/* ---- games gallery ---- */

    /* Compact two-column list of all the other games — small icon + label. */
    .party-games .gg-surprise{display:inline-flex;align-items:center;border:none;
      background:linear-gradient(140deg,var(--adv),var(--adv-deep,#b23f1f));
      color:#fff;font:800 .9rem/1 "Outfit",system-ui,sans-serif;padding:10px 16px;border-radius:999px;cursor:pointer;
      box-shadow:0 8px 20px -8px rgba(210,84,43,.6)}
    .party-games .gg-surprise:active{transform:translateY(1px)}
    .party-games .more-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:0 clamp(12px,3vw,20px)}
    .party-games .more-card{display:flex;align-items:center;gap:11px;min-width:0;text-decoration:none;
      background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:8px 11px 8px 8px;color:var(--ink);
      transition:transform .15s ease, box-shadow .15s ease}
    .party-games .more-card:hover,.party-games .more-card:focus-visible{transform:translateY(-3px);
      box-shadow:0 12px 24px -16px rgba(0,0,0,.5);outline:none}
    .party-games .more-card .more-ic{width:54px;height:54px;flex:none;border-radius:11px;object-fit:cover;background:var(--cream-2)}
    .party-games .more-card .more-ic.noart{display:flex;align-items:center;justify-content:center;font-size:1.6rem;
      background:linear-gradient(140deg,#3a59c9,#161b3d);color:#fff}
    .party-games .more-card .more-text{display:flex;flex-direction:column;min-width:0}
    .party-games .more-card .more-text strong{font:800 .88rem/1.15 "Outfit",system-ui;color:var(--ink);
      display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
    .party-games .more-card .more-text small{color:var(--ink-soft);font-size:.72rem;
      white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    .party-games .more-card .ext-pill{font:800 .56rem/1 "Outfit",system-ui;color:var(--ink-soft);
      border:1px solid var(--line);border-radius:999px;padding:2px 6px;margin-top:3px;align-self:flex-start}
    .party-games .more-card.gg-hide{display:none}
    /* Color-coded cards. */
    .party-games .more-card.c-green{background:rgba(31,122,94,.14);border-color:rgba(31,122,94,.55)}
    .party-games .more-card.c-green:hover,.party-games .more-card.c-green:focus-visible{background:rgba(31,122,94,.22)}
    .party-games .more-card.c-blue{background:rgba(58,89,201,.14);border-color:rgba(58,89,201,.55)}
    .party-games .more-card.c-blue:hover,.party-games .more-card.c-blue:focus-visible{background:rgba(58,89,201,.22)}
    #gg-recent{margin:0 clamp(12px,3vw,20px) 12px}
    #gg-recent h3{margin:0 0 8px;font:800 1rem/1 "Outfit",system-ui;color:var(--ink-soft)}
    #gg-recent .more-grid{margin:0}
    #gg-recent[hidden]{display:none}
    #pwa-nudge{position:fixed;left:50%;transform:translateX(-50%);bottom:max(16px,env(safe-area-inset-bottom));z-index:9980;
      background:var(--ink);color:var(--paper);border-radius:14px;padding:12px 14px;display:flex;gap:12px;align-items:center;
      box-shadow:0 14px 40px -12px rgba(0,0,0,.5);max-width:min(92vw,440px);font:600 .9rem/1.35 "Atkinson Hyperlegible",system-ui}
    #pwa-nudge[hidden]{display:none}
    #pwa-nudge button{border:none;border-radius:10px;padding:9px 12px;font:800 .85rem/1 "Outfit",system-ui;cursor:pointer}
    #pwa-nudge .pin{background:var(--gold);color:var(--ink)}
    #pwa-nudge .x{background:transparent;color:var(--paper);opacity:.7}
    @media (prefers-reduced-motion: reduce){.party-games .gg-surprise:active{transform:none}}
  

/* ---- Lobby doors (homepage): four big destination tiles ------------------ */
.lobby{display:grid;gap:14px;grid-template-columns:1fr;margin:18px auto 8px;
  max-width:var(--maxw,1100px);padding:0 clamp(12px,3vw,20px)}
@media(min-width:680px){.lobby{grid-template-columns:1fr 1fr}}
.door{position:relative;display:block;border-radius:var(--radius,20px);overflow:hidden;
  min-height:158px;text-decoration:none;color:#fff;border:1px solid var(--line);
  box-shadow:0 16px 36px -20px rgba(0,0,0,.55);transition:transform .15s ease, box-shadow .15s ease}
.door:hover,.door:focus-visible{transform:translateY(-3px);box-shadow:0 22px 44px -20px rgba(0,0,0,.6);outline:none}
.door img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.door .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.04) 35%,rgba(0,0,0,.62))}
.door .door-title{position:absolute;left:16px;right:16px;bottom:14px;display:flex;align-items:flex-end;gap:11px}
.door .door-ic{font-size:1.7rem;line-height:1;filter:drop-shadow(0 2px 6px rgba(0,0,0,.55))}
.door .door-title h2{margin:0;font:800 1.45rem/1 "Outfit",system-ui,sans-serif;text-shadow:0 2px 10px rgba(0,0,0,.55)}
.door .door-title .sub{display:block;margin-top:4px;color:#fff;opacity:.93;
  font:600 .82rem/1.25 "Atkinson Hyperlegible",system-ui,sans-serif;text-shadow:0 1px 6px rgba(0,0,0,.5)}
/* Lobby "surprise me" button row */
.lobby-extra{display:flex;justify-content:center;margin:6px auto 26px;padding:0 16px}
.lobby-surprise{display:inline-flex;align-items:center;gap:8px;border:none;cursor:pointer;
  background:linear-gradient(140deg,var(--adv),var(--adv-deep,#b23f1f));color:#fff;
  font:800 1rem/1 "Outfit",system-ui,sans-serif;padding:13px 22px;border-radius:999px;
  box-shadow:0 10px 24px -10px rgba(210,84,43,.65)}
.lobby-surprise:active{transform:translateY(1px)}
/* Attractions page: zone heading */
.zone-head{max-width:var(--maxw,1100px);margin:26px auto 4px;padding:0 clamp(12px,3vw,20px)}
.zone-head h2{margin:0;font:800 1.45rem/1.1 "Outfit",system-ui,sans-serif;color:var(--ink)}
.zone-head .sub{display:block;margin-top:4px;color:var(--ink-soft);font-size:.92rem}
.zone-sub{max-width:var(--maxw,1100px);margin:14px auto 2px;padding:0 clamp(12px,3vw,20px);
  font:800 .85rem/1 "Outfit",system-ui,sans-serif;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft)}
@media (prefers-reduced-motion: reduce){.door,.lobby-surprise:active{transition:none;transform:none}}

/* Ride card without a poster: gradient figure + big glyph. */
.card figure.noart{display:grid;place-items:center;background:linear-gradient(140deg,#13243f,#0a1830);font-size:3rem;color:#fff}

/* Clearer vibe-group headers on the attractions page. */
.zone-group{max-width:var(--maxw,1100px);margin:0 auto;padding:18px clamp(12px,3vw,20px) 0;
  display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.zone-group h3{margin:0;font:800 1.2rem/1 "Outfit",system-ui,sans-serif;color:var(--ink)}
.zone-group .zg-sub{color:var(--ink-soft);font-size:.86rem}
.zone-group + .arcade-grid{margin-top:8px}
