:root{--paper: #f6f1e6;--ink: #2a2824;--accent: #c4362f;--font-hand: "Patrick Hand", "Gochi Hand", system-ui, sans-serif;--font-title: "Shantell Sans", "Patrick Hand", system-ui, sans-serif;--font-gochi: "Gochi Hand", "Patrick Hand", cursive;--font-retro: "VT323", "Courier New", monospace}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;overflow:hidden;background:#7fc7c0;font-family:var(--font-hand);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;user-select:none;touch-action:none}#app{position:fixed;inset:0}#scene{position:fixed;inset:0;display:block;width:100%;height:100%}#ui{position:fixed;inset:0;pointer-events:none;z-index:10;color:var(--ink)}#ui button{pointer-events:auto;font-family:var(--font-hand);cursor:pointer}.paper{background:var(--paper);border:3px solid var(--ink);border-radius:14px;box-shadow:3px 4px #2a282459}.menu-btn{position:fixed;top:18px;right:18px;width:58px;height:58px;display:grid;place-items:center;transform:rotate(2deg);transition:transform .12s ease}.menu-btn:active{transform:rotate(2deg) scale(.94)}.menu-btn svg{width:30px;height:30px}.menu-btn .dot{position:absolute;top:-5px;right:-5px;width:16px;height:16px;background:var(--accent);border:2.5px solid var(--ink);border-radius:50%;display:none}.menu-btn.notify .dot{display:block}.stack{position:fixed;right:18px;bottom:22px;display:flex;flex-direction:column;gap:14px}.stack button{width:56px;height:56px;display:grid;place-items:center;transition:transform .12s ease}.stack button:nth-child(odd){transform:rotate(-2deg)}.stack button:nth-child(2n){transform:rotate(2deg)}.stack button:active{transform:scale(.92)}.stack svg{width:28px;height:28px}.title-card{position:fixed;left:34px;bottom:40px;font-family:var(--font-title);font-weight:700;font-size:clamp(34px,6vw,64px);line-height:.92;letter-spacing:1px;color:var(--paper);text-shadow:3px 3px 0 var(--ink),-1px -1px 0 var(--ink),1px -1px 0 var(--ink),-1px 1px 0 var(--ink);max-width:8em;opacity:0;transform:translateY(14px);transition:opacity .5s ease,transform .6s ease;pointer-events:none}.title-card.show{opacity:1;transform:translateY(0)}.title-card .clock{font-size:.5em;opacity:.9;display:block;letter-spacing:3px}.inv-chip{position:fixed;top:18px;left:18px;display:none;align-items:center;gap:8px;max-width:min(46vw,320px);padding:7px 12px 7px 9px;font-size:16px}.inv-chip.show{display:flex}.inv-chip .inv-ic{font-size:20px}.inv-chip .inv-tx{font-family:var(--font-hand);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.photo-hint{position:fixed;bottom:22px;left:50%;transform:translate(-50%);padding:8px 16px;font-family:var(--font-retro);font-size:18px;letter-spacing:1px;display:none}body.photo .photo-hint{display:block}.photo-hint.faded{opacity:0;transition:opacity 1s ease}.shutter{position:fixed;bottom:70px;left:50%;transform:translate(-50%);width:72px;height:72px;border-radius:50%;border:4px solid var(--ink);background:var(--paper);display:none;place-items:center;box-shadow:3px 4px #2a282466}body.photo .shutter{display:grid}.shutter span{width:48px;height:48px;border-radius:50%;background:var(--accent);border:2px solid var(--ink)}.shutter:active span{transform:scale(.88)}.flash{position:fixed;inset:0;background:#fff;opacity:0;pointer-events:none;z-index:50}.flash.go{animation:shutterFlash .5s ease-out}@keyframes shutterFlash{0%{opacity:.9}to{opacity:0}}body.photo .menu-btn,body.photo .stack,body.photo .title-card,body.photo .bubbles,body.photo .tutorial,body.photo .prompt,body.photo .inv-chip,body.photo .target-marker{opacity:0!important;pointer-events:none!important}.target-marker{position:fixed;left:0;top:0;display:flex;flex-direction:column;align-items:center;gap:2px;pointer-events:none;z-index:9;will-change:transform}.target-marker .tm-label{font-family:var(--font-hand);font-size:15px;color:var(--paper);background:var(--accent);border:2.5px solid var(--ink);border-radius:9px;padding:2px 8px;white-space:nowrap}.target-marker .tm-arrow{font-size:30px;line-height:1;color:var(--accent);text-shadow:0 0 2px var(--ink),1px 1px 0 var(--ink);display:inline-block}.target-marker .tm-dist{font-family:var(--font-retro);font-size:15px;color:var(--ink);background:var(--paper);border:2px solid var(--ink);border-radius:7px;padding:0 5px}.tutorial{position:fixed;top:18px;left:50%;transform:translate(-50%) translateY(-16px);display:flex;align-items:center;gap:12px;max-width:min(560px,88vw);padding:10px 12px 10px 14px;font-size:17px;line-height:1.2;opacity:0;pointer-events:none;transition:opacity .35s ease,transform .35s ease}.tutorial.show{opacity:1;transform:translate(-50%) translateY(0);pointer-events:auto}.tutorial .tut-step{flex:0 0 auto;display:grid;place-items:center;min-width:34px;height:26px;padding:0 6px;background:var(--accent);color:var(--paper);border:2px solid var(--ink);border-radius:8px;font-size:14px;font-weight:700}.tutorial .tut-text{flex:1 1 auto}.tutorial .tut-skip{flex:0 0 auto;background:none;border:2px solid var(--ink);border-radius:8px;padding:3px 10px;font-size:14px;color:var(--ink);opacity:.7}.tutorial .tut-skip:active{transform:scale(.94)}.prompt{position:fixed;left:50%;bottom:18%;transform:translate(-50%);padding:8px 16px;font-size:19px;opacity:0;transition:opacity .18s ease;pointer-events:none}.prompt.show{opacity:1}.prompt .key{display:inline-grid;place-items:center;min-width:22px;height:22px;padding:0 5px;margin-right:6px;background:var(--ink);color:var(--paper);border-radius:6px;font-size:14px;vertical-align:middle}.scrim{position:fixed;inset:0;background:#2a282447;display:none;pointer-events:auto}.scrim.show{display:block}.panel{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-.6deg);width:min(420px,86vw);max-height:80vh;overflow:auto;padding:22px 22px 26px;pointer-events:auto}.panel{border-width:4px;box-shadow:10px 10px 0 0 var(--ink),18px 18px #7fc7c080}.panel h2{font-family:var(--font-title);font-size:26px;margin-bottom:4px}.map-chart{position:relative;width:100%;height:240px;margin:10px 0 14px;border:3px solid var(--ink);border-radius:14px;overflow:hidden;background:radial-gradient(120% 90% at 50% 30%,#bfe6df,#7fc7c0 70%,#5fa39c);box-shadow:inset 0 0 0 4px #ffffff40}.map-chart:after{content:"";position:absolute;left:0;right:0;top:56%;border-top:2px dashed rgba(42,40,36,.25)}.map-dot{position:absolute;transform:translate(-50%,-50%);background:none;border:none;display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer}.map-pin{width:14px;height:14px;border-radius:50%;border:2.5px solid var(--ink);background:var(--accent);box-shadow:1px 1px #2a282466}.map-name{font-family:var(--font-retro);font-size:13px;line-height:1;letter-spacing:.5px;color:var(--ink);background:var(--paper);border:2px solid var(--ink);border-radius:6px;padding:1px 4px;white-space:nowrap}.map-dot.seen:hover .map-pin{background:#fbe34d;transform:scale(1.15)}.map-dot.locked{cursor:default;opacity:.55}.map-dot.locked .map-pin{background:#2a282459}.map-dot.locked .map-name{opacity:.7}.ctl-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:7px 0;border-top:2px dashed rgba(42,40,36,.2);font-size:17px}.ctl-row:first-of-type{border-top:none}.ctl-key{min-width:64px;padding:5px 10px;font-family:var(--font-retro);font-size:18px;letter-spacing:1px;background:var(--ink);color:var(--paper);border:none;border-radius:8px}.ctl-key.listening{background:var(--accent)}.legacy-link{margin-top:16px;width:100%;background:var(--ink);color:var(--paper);border:none;border-radius:10px;padding:9px;font-family:var(--font-retro);font-size:18px;letter-spacing:1px}.legacy-link:hover{background:var(--accent)}.about-hero{width:100%;height:170px;object-fit:cover;border:3px solid var(--ink);border-radius:12px}.about-gallery{display:flex;gap:8px;margin:8px 0 12px}.about-thumb{flex:1 1 0;height:46px;object-fit:cover;border:2.5px solid var(--ink);border-radius:8px;cursor:pointer;opacity:.6;transition:opacity .2s ease,transform .2s ease}.about-thumb:hover{opacity:1}.about-thumb.sel{opacity:1;outline:2.5px solid var(--accent);outline-offset:1px}.legacy-title{font-family:var(--font-retro);font-size:34px;letter-spacing:3px;color:#2b8f86}.about-p{font-size:16px;line-height:1.45;margin:10px 0}.about-quote{font-family:var(--font-gochi);font-size:22px;display:inline-block;background:#fbe34d;border:3px solid var(--ink);border-radius:12px;padding:3px 14px;transform:rotate(-1.5deg);margin:6px 0 12px}.about-archive{display:inline-block;font-family:var(--font-retro);font-size:17px;letter-spacing:1px;color:var(--accent);margin:4px 0 10px}.about-back{margin-top:6px;background:none;border:2.5px solid var(--ink);border-radius:10px;padding:7px 14px;font-family:var(--font-hand);font-size:17px;color:var(--ink)}.panel .sub{font-size:15px;opacity:.7;margin-bottom:14px}.panel .close{position:absolute;top:14px;right:14px;width:38px;height:38px;display:grid;place-items:center;background:none;border:none;color:var(--ink)}.panel .close svg{width:22px;height:22px}.quest{display:flex;gap:10px;align-items:flex-start;padding:10px 0;border-top:2px dashed rgba(42,40,36,.25);font-size:17px}.quest:first-of-type{border-top:none}.quest .tick{flex:0 0 22px;height:22px;border:2.5px solid var(--ink);border-radius:6px;margin-top:2px;display:grid;place-items:center;font-size:15px}.quest.done{opacity:.55}.quest.done .label{text-decoration:line-through}.grid{display:flex;flex-wrap:wrap;gap:12px;margin-top:6px}.swatch{width:52px;height:52px;border:3px solid var(--ink);border-radius:12px;cursor:pointer;font-size:26px;display:grid;place-items:center;background:var(--paper)}.swatch.sel{outline:3px solid var(--accent);outline-offset:2px}.grid .label-row{width:100%;font-size:15px;opacity:.7;margin-top:8px}.intro{position:fixed;inset:0;background:radial-gradient(120% 95% at 50% 38%,#3c505400 34%,#28343880);display:grid;place-items:center;align-content:center;text-align:center;pointer-events:auto;transition:opacity .8s ease}body.intro-active .menu-btn,body.intro-active .stack,body.intro-active .bubbles,body.intro-active .title-card,.intro.hide{opacity:0;pointer-events:none}.intro-card{position:relative;padding:46px 40px 26px;transform:rotate(-1.2deg);max-width:540px;border-width:4px;border-radius:18px;box-shadow:12px 12px 0 0 var(--ink),22px 22px #7fc7c08c;max-height:92vh;overflow:auto}.intro-emblem{position:absolute;top:-46px;left:50%;width:92px;height:92px;transform:translate(-50%) rotate(3deg);border:4px solid var(--ink);border-radius:50%;background:#fbe34d;object-fit:cover;box-shadow:4px 5px #2a282459;animation:wobble 4s ease-in-out infinite}.intro .kicker{font-family:var(--font-retro);font-size:21px;letter-spacing:3px;text-transform:uppercase;color:#2b8f86;margin-top:6px}.intro h1{font-family:var(--font-gochi);font-weight:400;font-size:clamp(46px,10vw,82px);line-height:.92;letter-spacing:1px;margin:2px 0 8px}.intro .tagline{font-family:var(--font-gochi);font-size:clamp(20px,3.4vw,26px);color:var(--accent);margin-bottom:10px}.intro .lore{font-size:16px;line-height:1.45;margin:0 auto 14px;max-width:30em;opacity:.9}.intro .quote{font-family:var(--font-gochi);font-size:22px;display:inline-block;background:#fbe34d;border:3px solid var(--ink);border-radius:12px;padding:4px 16px;transform:rotate(-1.5deg);margin-bottom:20px}.intro .play{display:block;margin:0 auto;font-family:var(--font-gochi);font-size:27px;padding:10px 38px;background:var(--accent);color:var(--paper);border:3px solid var(--ink);border-radius:16px;box-shadow:4px 5px #2a282473}.intro .play:active{transform:translate(2px,3px);box-shadow:1px 1px #2a282473}.intro .hint{margin-top:16px;font-family:var(--font-retro);font-size:18px;letter-spacing:1px;opacity:.6}.touch-hint{display:none}body.touch .touch-hint{display:block}.intro .credit{margin-top:14px;padding-top:12px;border-top:2px dashed rgba(42,40,36,.25);font-family:var(--font-retro);font-size:15px;letter-spacing:1px;opacity:.55}.intro-float{position:fixed;width:clamp(120px,15vw,200px);border:4px solid var(--ink);border-radius:18px;background:#fff;box-shadow:8px 8px #2a28244d;object-fit:cover;pointer-events:none}.intro-float.f1{top:8%;left:5%;transform:rotate(-9deg);border-radius:50%;animation:floaty 6s ease-in-out infinite}.intro-float.f2{bottom:8%;right:5%;transform:rotate(7deg);animation:floaty 7s ease-in-out infinite 1s}@keyframes floaty{0%,to{transform:translateY(0) rotate(var(--r, -8deg))}50%{transform:translateY(-18px) rotate(var(--r, -8deg))}}.intro-float.f1{--r: -9deg}.intro-float.f2{--r: 7deg}@keyframes wobble{0%,to{transform:translate(-50%) rotate(3deg)}50%{transform:translate(-50%) rotate(-3deg)}}@media (max-width: 720px){.intro-float{display:none}}.bubbles{position:fixed;inset:0;pointer-events:none}.bubble{position:absolute;transform:translate(-50%,-100%);background:var(--paper);border:3px solid var(--ink);border-radius:16px;padding:10px 14px;max-width:230px;font-size:17px;line-height:1.25;box-shadow:2px 3px #2a28244d;will-change:transform}.bubble:after{content:"";position:absolute;left:50%;bottom:-13px;transform:translate(-50%);border:8px solid transparent;border-top-color:var(--ink)}.bubble.indicator{padding:7px 11px;font-weight:700;letter-spacing:2px;font-size:14px}.bubble .next{display:block;text-align:right;font-size:13px;opacity:.55;margin-top:4px}.bubble .choices{display:flex;flex-direction:column;gap:6px;margin-top:8px}.bubble .choice{pointer-events:auto;font-family:var(--font-hand);font-size:16px;text-align:left;background:var(--paper);border:2.5px solid var(--ink);border-radius:10px;padding:5px 10px;cursor:pointer}.bubble .choice:hover{background:var(--accent);color:var(--paper)}.action-btn{position:fixed;left:26px;bottom:30px;width:84px;height:84px;border-radius:50%;background:var(--accent);color:var(--paper);border:3px solid var(--ink);font-size:16px;font-weight:700;display:none;place-items:center;box-shadow:3px 4px #2a282466}.touch .action-btn{display:grid}.action-btn:active{transform:scale(.93)}.touch .desktop-only{display:none}
