:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;--bg:#faf6ee;--fg:#1a1410;--accent:#b3361f;--focus:#1e88e5;--hotspot-bg:#fff;--hotspot-border:#6b5444;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial;--bg:#0e0a07;--fg:#f0e6d2;--hotspot-bg:#1f1812;--hotspot-border:#b39468}}*{box-sizing:border-box}body{background:var(--bg);color:var(--fg);min-height:100vh;margin:0;font-size:1.125rem;line-height:1.5}#app{max-width:1100px;margin:0 auto;padding:1.5rem}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.intro{flex-direction:column;gap:1rem;max-width:700px;display:flex}.welcome{max-width:720px}.welcome h2{color:var(--accent);margin:1.25rem 0 .4rem;font-size:1.4rem}.welcome ul{margin:.4rem 0;padding-left:1.4rem}.welcome li{margin:.35rem 0}.welcome-start-row{justify-content:center;margin:1.5rem 0 .5rem;display:flex}.lever-large{min-height:72px!important;padding:1.25rem 3rem!important;font-size:2rem!important}.menu-help-button{font:inherit;color:var(--accent);border:2px solid var(--accent);cursor:pointer;background:0 0;border-radius:.5rem;align-self:flex-start;min-height:44px;padding:.5rem 1rem;font-size:1rem}.menu-help-button:hover{background:var(--accent);color:#fff}.menu-help-button:focus-visible{outline:4px solid var(--focus);outline-offset:3px}.intro h1{color:var(--accent);margin:0;font-size:2rem}.intro p{margin:0;font-size:1.125rem}.button-row{flex-wrap:wrap;gap:.75rem;display:flex}#start-button,#test-button{font:inherit;border:3px solid var(--hotspot-border);background:var(--hotspot-bg);color:var(--fg);cursor:pointer;border-radius:.75rem;min-height:48px;padding:1rem 2rem;font-size:1.5rem}#test-button{padding:.75rem 1.5rem;font-size:1.125rem}#start-button:focus-visible,#test-button:focus-visible{outline:4px solid var(--focus);outline-offset:4px}.scene{flex-direction:column;gap:1rem;display:flex}.scene h1{color:var(--accent);margin:0;font-size:2rem}.scene-intro{margin:0;font-size:1.125rem}.scene-help{opacity:.75;margin:0;font-size:.95rem}.scene-room{border:3px solid var(--hotspot-border);background:linear-gradient(#d9c8a8 0%,#c4a986 100%);border-radius:1rem;min-height:480px;position:relative;overflow:hidden}@media (prefers-color-scheme:dark){.scene-room{background:linear-gradient(#2a2017 0%,#3d2e22 100%)}}.hotspot{font:inherit;background:var(--hotspot-bg);color:var(--fg);border:2px solid var(--hotspot-border);cursor:pointer;border-radius:.5rem;min-width:44px;min-height:44px;padding:.75rem 1rem;transform:translate(-50%,-50%)}.hotspot:hover{background:var(--accent);color:#fff}.hotspot:focus-visible{outline:4px solid var(--focus);outline-offset:3px;z-index:1}.scene-touch-nav{border-top:1px solid var(--hotspot-border);flex-wrap:wrap;gap:.5rem;margin-top:1rem;padding-top:1rem;display:flex}.scene-touch-nav button{font:inherit;border:2px solid var(--hotspot-border);background:var(--hotspot-bg);min-height:48px;color:var(--fg);cursor:pointer;border-radius:.5rem;flex:auto;padding:.75rem 1.5rem;font-size:1rem}.scene-touch-nav button:hover{background:var(--accent);color:#fff}.scene-touch-nav button:focus-visible{outline:4px solid var(--focus);outline-offset:3px}.scene-back{background:#e0e0e0!important}.edmo-scene{flex-direction:column;gap:1rem;display:flex}.edmo-stage{display:none}.edmo-frame-row{justify-content:center;display:flex}.edmo-frame{font:inherit;color:#1a1410;cursor:pointer;background:#efe1bb;border:4px dashed #6b5444;border-radius:1rem;min-height:64px;padding:.75rem 1.5rem;font-size:1.1rem}.edmo-frame:hover{background:#ffefc8}.edmo-frame:focus-visible{outline:5px solid var(--focus);outline-offset:3px}.edmo-cages{grid-template-columns:repeat(4,minmax(80px,1fr));gap:.75rem;padding:1rem 0;display:grid}.edmo-cage{font:inherit;background:var(--hotspot-bg);min-height:110px;color:var(--fg);border:4px solid var(--hotspot-border);cursor:pointer;border-radius:.75rem;padding:1.25rem .5rem;font-size:3rem;font-weight:700}.edmo-cage:hover{background:var(--accent);color:#fff}.edmo-cage:focus-visible{outline:5px solid var(--focus);outline-offset:3px}.edmo-cage.cleared{opacity:.55}.edmo-cage.hint{background:#ffeb3b;border-color:#b3361f;animation:1s ease-in-out infinite alternate edmo-hint-pulse}@keyframes edmo-hint-pulse{0%{transform:scale(1)}to{transform:scale(1.08)}}.letter-machine-scene{gap:1rem}.letter-machine{border:4px solid var(--hotspot-border);background:linear-gradient(#4a5d77 0%,#2a3a4f 100%);border-radius:1rem;flex-direction:column;align-items:center;gap:1.5rem;padding:2rem;display:flex}.letter-slots{gap:1rem;display:flex}.letter-slot{font:inherit;color:#1a1410;cursor:pointer;background:#f7e6c4;border:4px solid #6b5444;border-radius:.75rem;width:5rem;height:6rem;font-size:4rem;font-weight:700}.letter-slot:hover{background:#fff3d0}.letter-slot:focus-visible{outline:5px solid var(--focus);outline-offset:3px}.lever{font:inherit;background:var(--accent);color:#fff;cursor:pointer;border:4px solid #6b1c10;border-radius:.75rem;min-height:60px;padding:1rem 2rem;font-size:1.5rem}.lever:hover{background:#e64a32}.lever:focus-visible{outline:5px solid var(--focus);outline-offset:3px}.story-wheels{flex-wrap:wrap;justify-content:center;gap:1rem;margin:1rem 0;display:flex}.story-wheel{font:inherit;color:#1a1410;cursor:pointer;background:#fce5b8;border:4px solid #6b5444;border-radius:.75rem;min-width:200px;min-height:90px;padding:1rem;font-size:1.5rem}.story-wheel:hover{background:#ffefc8}.story-wheel:focus-visible{outline:5px solid var(--focus);outline-offset:3px}.rhyme-stage{border:3px solid var(--hotspot-border);background:linear-gradient(#d9c8a8 0%,#b09574 100%);border-radius:1rem;flex-direction:column;align-items:center;gap:1.5rem;padding:2rem 1rem;display:flex}.rhyme-seed{flex-direction:column;align-items:center;gap:.75rem;display:flex}.rhyme-seed-label{margin:0;font-size:1.5rem}.rhyme-choices{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.rhyme-choice{font:inherit;color:#1a1410;cursor:pointer;background:#fff;border:4px solid #6b5444;border-radius:.75rem;min-width:120px;min-height:80px;padding:1rem 1.5rem;font-size:1.5rem}.rhyme-choice:hover{background:var(--accent);color:#fff}.rhyme-choice:focus-visible{outline:5px solid var(--focus);outline-offset:3px}.doghouse-stage{border:3px solid var(--hotspot-border);background:linear-gradient(#8aa37e 0%,#6b8260 100%);border-radius:1rem;flex-direction:column;gap:1.5rem;padding:1.5rem;display:flex}.doghouse-prompt{flex-direction:column;align-items:center;gap:.75rem;display:flex}.doghouse-prompt p{text-align:center;margin:0;font-size:1.25rem}.doghouse-choices{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem;display:grid}.doghouse-choice{font:inherit;color:#1a1410;cursor:pointer;background:#fff;border:3px solid #6b5444;border-radius:.5rem;min-height:64px;font-size:1.25rem}.doghouse-choice:hover{background:var(--accent);color:#fff}.doghouse-choice:focus-visible{outline:5px solid var(--focus);outline-offset:3px}.doghouse-choice.hint{background:#ffeb3b;border-color:#b3361f;animation:1s ease-in-out infinite alternate edmo-hint-pulse}.doghouse-prompt-text{text-align:center;margin:0;font-size:1.25rem}.rhyme-choice.hint{background:#ffeb3b;border-color:#b3361f;animation:1s ease-in-out infinite alternate edmo-hint-pulse}.friend-stage{border:3px solid var(--hotspot-border);background:linear-gradient(#f7d6a8 0%,#d9a86e 100%);border-radius:1rem;flex-direction:column;align-items:center;gap:1rem;padding:1.5rem;display:flex}.friend-desc{text-align:center;margin:0;font-size:1.25rem}
