:root{--sky-top: #050818;--sky-mid: #131a3a;--sky-bottom: #263470;--gold: #f4d58d;--gold-soft: #ffe6a8;--amber: #e2a14b;--peach: #f3c0a0;--rose: #d79bb0;--green: #9bd6a3;--violet: #b79be6;--paper: #f3e7cd;--paper-edge: #e6d4ad;--ink: #3d2a10;--text: #f4f1ff;--text-dim: #b9bbd8;--card-bg: rgba(255, 255, 255, .06);--card-bg-hover: rgba(255, 255, 255, .12);--card-border: rgba(255, 255, 255, .16);--glow-gold: 0 0 24px rgba(244, 213, 141, .45);--glow-soft: 0 0 40px rgba(183, 155, 230, .25);--font-hand: "Caveat", "Comic Sans MS", cursive;--font-ui: "Nunito", system-ui, -apple-system, "Segoe UI", sans-serif;--gap: 1rem;--radius: 18px;--radius-lg: 28px;--ease: cubic-bezier(.22, .61, .36, 1);--t-screen: .42s}*{box-sizing:border-box}html,body{margin:0;height:100%}body{font-family:var(--font-ui);color:var(--text);background:var(--sky-top);overflow:hidden;-webkit-tap-highlight-color:transparent}#app{position:fixed;top:0;right:0;bottom:0;left:0}button{font-family:inherit;color:inherit;cursor:pointer}.shared-sky{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;background:radial-gradient(120% 90% at 50% 8%,var(--sky-mid),var(--sky-top) 55%),linear-gradient(180deg,var(--sky-top),var(--sky-bottom))}.sky-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(45% 35% at 50% 30%,rgba(244,213,141,.16),transparent 70%);animation:breathe 9s var(--ease) infinite}.sky-stars{position:absolute;top:0;right:0;bottom:0;left:0;will-change:transform}.sky-far{animation:drift-x 90s ease-in-out infinite alternate}.sky-near{animation:drift-x 60s ease-in-out infinite alternate}.star{position:absolute;width:3px;height:3px;border-radius:50%;background:#fff;opacity:.7;box-shadow:0 0 6px #fffc;animation:twinkle 4s ease-in-out infinite}.sky-far .star{width:2px;height:2px;opacity:.45;box-shadow:0 0 4px #fff9}.shooting-star{position:absolute;top:12%;left:-10%;width:120px;height:2px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.9));border-radius:999px;opacity:0;transform:rotate(18deg);animation:shoot 11s ease-in infinite}.screen-host{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1}.screen{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:clamp(1rem,4vh,2.4rem);padding:clamp(1rem,5vw,3rem);text-align:center;animation:fade-in var(--t-screen) var(--ease)}.screen-leaving{animation:fade-out .4s var(--ease) forwards;pointer-events:none}.title{font-family:var(--font-hand);font-size:clamp(3rem,12vw,5.5rem);font-weight:700;margin:0;line-height:1}.heading{font-family:var(--font-hand);font-size:clamp(2.2rem,8vw,3.6rem);font-weight:700;margin:0}.subtitle{color:var(--text-dim);font-size:clamp(1rem,3.5vw,1.3rem);margin:0;max-width:28ch}.hint{color:var(--text-dim);font-style:italic;font-size:.95rem}.glow{text-shadow:var(--glow-gold);color:var(--gold-soft);animation:pulse-glow 5s ease-in-out infinite}.moon-badge{width:56px;height:56px;color:var(--gold);filter:drop-shadow(var(--glow-gold))}.about-link{margin-top:.4rem;background:none;border:none;color:var(--text-dim);font-family:var(--font-hand);font-size:1.3rem;text-decoration:underline;text-underline-offset:4px;text-decoration-thickness:1px;transition:color .16s var(--ease)}.about-link:hover{color:var(--gold-soft)}.about-screen{justify-content:flex-start;padding-top:clamp(2.5rem,8vh,5rem);gap:.8rem}.about-tagline{font-family:var(--font-hand);font-size:clamp(1.3rem,5vw,1.8rem);color:var(--gold-soft);margin:0}.about-body{max-width:58ch;text-align:left;color:var(--text);line-height:1.6;font-size:clamp(1rem,3.5vw,1.12rem);overflow-y:auto;max-height:58vh;max-height:58dvh;padding:0 .4rem;scrollbar-width:none;-ms-overflow-style:none}.about-body::-webkit-scrollbar{width:0;height:0;display:none}.about-body p{margin:0 0 1rem;color:var(--text-dim)}.about-body p:first-child{color:var(--text)}.about-section-title{font-family:var(--font-hand);color:var(--gold-soft);font-size:1.4rem;margin:1.2rem 0 .3rem}.about-contact{margin-top:1rem;color:var(--text-dim)!important}.about-contact a{color:var(--gold-soft);text-decoration:underline;text-underline-offset:3px}.about-contact a:hover{color:var(--gold)}.about-back{margin-top:.6rem}.splash-screen{justify-content:flex-end;padding:0}.splash-bg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;overflow:hidden}.splash-bg-img{width:100%;height:100%;object-fit:cover;object-position:center top}@media (min-aspect-ratio: 1/1){.splash-bg-img{object-fit:contain;object-position:center}}.splash-veil{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(5,8,24,.1) 0%,rgba(5,8,24,.3) 40%,rgba(5,8,24,.82) 78%,rgba(5,8,24,.96) 100%)}.splash-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:clamp(.8rem,3vh,1.6rem);width:100%;padding:clamp(1rem,4vw,2.5rem);padding-bottom:clamp(2rem,7vh,4rem)}.btn{border:1px solid var(--card-border);background:var(--card-bg);color:var(--text);border-radius:999px;padding:.8rem 1.8rem;font-size:1.05rem;transition:transform .18s var(--ease),background .18s var(--ease),box-shadow .18s var(--ease)}.btn:hover{background:var(--card-bg-hover);transform:translateY(-2px)}.btn-primary{background:linear-gradient(180deg,var(--gold-soft),var(--amber));color:#2a1c08;border:none;box-shadow:var(--glow-gold);font-weight:700}.btn-ghost{background:transparent;color:var(--text-dim);border-color:transparent}.choice-row,.pick-row,.category-row,.rating-row,.goodnight-actions{display:flex;flex-wrap:wrap;gap:clamp(1rem,3vw,2rem);align-items:center;justify-content:center}.choice-card,.pick-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;min-width:clamp(9rem,38vw,13rem);min-height:clamp(9rem,30vh,12rem);padding:1.4rem;border:1px solid var(--card-border);background:var(--card-bg);border-radius:var(--radius-lg);transition:transform .2s var(--ease),background .2s var(--ease),box-shadow .2s var(--ease)}.choice-card:hover,.pick-card:hover{transform:translateY(-4px) scale(1.02);background:var(--card-bg-hover);box-shadow:var(--glow-soft)}.choice-icon{width:56px;height:56px;color:var(--gold)}.choice-label{font-family:var(--font-hand);font-size:1.7rem}.pick-title{font-family:var(--font-hand);font-size:1.8rem;color:var(--gold-soft)}.pick-range{font-size:1.5rem;font-weight:700}.pick-sub{color:var(--text-dim);font-size:.95rem}.accent-peach .pick-title{color:var(--peach)}.accent-rose .pick-title{color:var(--rose)}.length-card.is-featured{box-shadow:var(--glow-gold);border-color:#f4d58d80;background:rgba(244,213,141,.08)}.back-btn{position:absolute;top:max(18px,env(safe-area-inset-top));left:calc(56px + max(18px,env(safe-area-inset-left)));width:46px;height:46px;padding:10px;border-radius:50%;border:1px solid var(--card-border);background:rgba(10,14,35,.5);color:var(--gold-soft);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:transform .16s var(--ease),background .16s var(--ease)}.back-btn:hover{transform:scale(1.08);background:rgba(20,26,58,.7)}.back-btn svg{width:100%;height:100%}.category-triangle{position:relative;width:min(92vw,500px);height:min(62vh,420px);margin:.5rem auto}.category-orb{position:absolute;display:flex;flex-direction:column;align-items:center;gap:.6rem;background:none;border:none}.orb-top{top:0;left:50%;transform:translate(-50%)}.orb-bl{bottom:0;left:0}.orb-br{bottom:0;right:0}.orb-dot{width:clamp(5rem,18vw,7rem);height:clamp(5rem,18vw,7rem);border-radius:50%;border:1px solid var(--card-border);overflow:hidden;background:#0a1626;transition:transform .2s var(--ease)}.orb-dot svg{display:block;width:100%;height:100%}.category-orb:hover .orb-dot{transform:scale(1.07)}.category-orb:active .orb-dot{transform:scale(.95)}.fav-heart{position:absolute;top:70%;left:50%;transform:translate(-50%,-50%);width:clamp(3rem,13vw,4.2rem);height:clamp(3rem,13vw,4.2rem);padding:.7rem;border-radius:50%;border:1px solid rgba(255,182,193,.4);background:rgba(22,10,30,.5);color:#ff8fab;filter:drop-shadow(0 0 16px rgba(255,120,150,.55));animation:pulse-heart 2.2s ease-in-out infinite}.fav-heart svg{width:100%;height:100%}.fav-popup{position:absolute;top:0;right:0;bottom:0;left:0;z-index:5;display:flex;align-items:center;justify-content:center}.fav-popup-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:rgba(2,4,14,.6);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.fav-popup-card{position:relative;z-index:1;width:min(88vw,420px);max-height:70vh;max-height:70dvh;overflow-y:auto;background:linear-gradient(180deg,#0c1130,#0a0e26);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:1.2rem;box-shadow:0 20px 60px #0009}.fav-popup-title{font-family:var(--font-hand);color:var(--gold-soft);font-size:1.7rem;margin:0 0 .6rem;text-align:center}.fav-popup-list{display:flex;flex-direction:column;gap:.3rem}.fav-popup-row{display:flex;align-items:center;gap:.6rem;background:none;border:none;color:var(--text);text-align:left;padding:.6rem;border-radius:10px}.fav-popup-row:hover{background:var(--card-bg)}.glow-green .orb-dot{box-shadow:0 0 30px #9bd6a399}.glow-amber .orb-dot{box-shadow:0 0 30px #e2a14b99}.glow-violet .orb-dot{box-shadow:0 0 30px #b79be699}.orb-label{font-family:var(--font-hand);font-size:1.6rem}@media (max-height: 560px){.category-triangle{height:min(78vh,320px)}.orb-dot{width:clamp(3.25rem,16vh,5rem);height:clamp(3.25rem,16vh,5rem)}.orb-label{font-size:1.15rem}.fav-heart{width:clamp(2.4rem,9vh,3.2rem);height:clamp(2.4rem,9vh,3.2rem);padding:.5rem}}.global-controls{position:absolute;top:0;right:0;bottom:0;left:0;z-index:3;pointer-events:none}.ctrl{position:absolute;width:46px;height:46px;padding:9px;border-radius:50%;border:1px solid var(--card-border);background:rgba(10,14,35,.5);color:var(--gold-soft);pointer-events:auto;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:transform .16s var(--ease),background .16s var(--ease)}.ctrl:hover{transform:scale(1.08);background:rgba(20,26,58,.7)}.ctrl svg{width:100%;height:100%}.ctrl-home{top:max(18px,env(safe-area-inset-top));left:max(18px,env(safe-area-inset-left))}.ctrl-settings{top:max(18px,env(safe-area-inset-top));right:max(18px,env(safe-area-inset-right))}.ctrl-mute{bottom:max(18px,env(safe-area-inset-bottom));left:max(18px,env(safe-area-inset-left))}.ctrl-mute.is-muted{color:var(--text-dim)}.intro-screen{cursor:pointer;overflow:hidden}.intro-city{position:absolute;left:0;right:0;bottom:0;height:clamp(90px,18vh,150px);color:#070b1c;animation:intro-city 5s var(--ease) forwards}.intro-city svg{width:100%;height:100%;display:block}.intro-moon-group{position:absolute;left:50%;top:50%;width:clamp(130px,42vw,210px);aspect-ratio:1;transform:translate(-50%,-50%);opacity:0;animation:intro-rise 3s var(--ease) forwards}.intro-moon{width:100%;height:100%;filter:drop-shadow(0 0 30px rgba(244,213,141,.5));animation:intro-breathe 1.8s ease-in-out 3s infinite}.intro-moon svg{width:100%;height:100%;display:block}.eyes-open{animation:fade-to-0 .4s ease 3.7s forwards}.eyes-closed{opacity:0;animation:fade-to-1 .4s ease 3.7s forwards}.intro-zzz{position:absolute;top:-6%;right:-2%;display:flex;align-items:flex-end;gap:4px}.intro-zzz span{font-family:var(--font-hand);color:var(--gold-soft);opacity:0}.intro-zzz span:nth-child(1){font-size:1rem;animation:zzz-float 2.4s ease 4s infinite}.intro-zzz span:nth-child(2){font-size:1.4rem;animation:zzz-float 2.4s ease 4.3s infinite}.intro-zzz span:nth-child(3){font-size:1.9rem;animation:zzz-float 2.4s ease 4.6s infinite}.intro-hint{position:absolute;bottom:clamp(2rem,8vh,4rem);color:var(--text-dim);font-style:italic;animation:fade-in 1s ease 1.6s both}.book-screen,.audiobook-screen{padding:clamp(.5rem,3vw,2rem)}.book-loading{width:100%}.book-stage{position:relative;width:100%;display:flex;align-items:center;justify-content:center}.book-aura{position:absolute;width:min(96vw,760px);height:min(88vh,820px);height:min(88dvh,820px);border-radius:50%;pointer-events:none;opacity:0;filter:blur(28px);background:radial-gradient(closest-side,rgba(244,213,141,.28),transparent 70%);animation:breathe 7s var(--ease) infinite;transition:opacity .6s var(--ease)}.book-stage[data-magic=subtle] .book-aura{opacity:.35}.book-stage[data-magic=medium] .book-aura{opacity:.65}.book-stage[data-magic=strong] .book-aura{opacity:1}.book{position:relative;width:min(92vw,460px);height:min(82vh,720px);height:min(82dvh,720px);background:linear-gradient(180deg,var(--paper),var(--paper-edge));color:var(--ink);border-radius:14px;box-shadow:0 18px 60px #00000080,inset 0 0 0 1px #0000000d;display:flex;flex-direction:column;overflow:hidden}.book-close{position:absolute;top:9px;right:9px;z-index:3;width:40px;height:40px;border-radius:50%;border:1px solid rgba(61,42,16,.25);background:rgba(248,240,224,.72);color:#3d2a10;font-size:1.05rem;line-height:1;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.book-close:hover{background:rgba(248,240,224,.95)}.dog-ear{display:none}.book-page{flex:1;overflow:hidden;display:flex;perspective:1400px}.book-page.turn-peel{animation:page-peel .55s var(--ease)}.book-page.turn-fold{animation:page-fold .6s var(--ease);transform-origin:left center}.page-cover{position:relative;width:100%;height:100%}.cover-img{width:100%;height:100%;object-fit:cover}.cover-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:flex-end;justify-content:center;padding:1.5rem;background:linear-gradient(0deg,rgba(0,0,0,.55),transparent 45%)}.cover-title{font-family:var(--font-hand);color:var(--gold-soft);font-size:clamp(1.8rem,6vw,2.8rem);margin:0;text-align:center;text-shadow:0 2px 10px rgba(0,0,0,.6)}.page-text{display:flex;flex-direction:column;gap:1rem;width:100%;height:100%;padding:clamp(1.2rem,4vw,2rem)}.page-side{min-height:0}.page-illu-wrap{order:0;flex:0 0 auto;display:flex;align-items:center;justify-content:center;max-height:42%}.page-illu{width:100%;height:100%;object-fit:contain;border-radius:10px;max-height:38vh}.page-prose{order:1;flex:1 1 auto;overflow-y:auto;font-family:var(--font-hand);font-size:clamp(1.3rem,4.5vw,1.7rem);line-height:1.5}.page-prose p{margin:0 0 .7rem}.page-crease{display:none}.page-end{display:flex;align-items:center;justify-content:center;width:100%}.end-mark{font-family:var(--font-hand);font-size:clamp(2.4rem,9vw,4rem);color:var(--ink);opacity:.8}.book-nav{display:flex;align-items:center;justify-content:center;gap:1.4rem;padding:.8rem;border-top:1px solid rgba(61,42,16,.12)}.nav-arrow,.nav-heart{width:44px;height:44px;padding:9px;border-radius:50%;border:1px solid rgba(61,42,16,.2);background:rgba(255,255,255,.4);color:var(--ink)}.nav-arrow:disabled{opacity:.3;cursor:default}.nav-next svg{transform:rotate(180deg)}.nav-heart{color:#c0506a;border-color:#c0506a66}.page-indicator{font-weight:700;min-width:3.5rem}@media (min-width: 820px){.book{width:min(94vw,940px);height:min(82vh,660px);height:min(82dvh,660px);border-radius:16px}.book-aura{width:min(99vw,1380px);height:min(94vh,920px);height:min(94dvh,920px)}.page-text{flex-direction:row;gap:0;padding:clamp(1.4rem,3vw,2.4rem)}.page-prose{order:0;flex:1 1 50%;padding-right:clamp(1rem,2.5vw,2rem)}.page-crease{display:block;order:1;flex:0 0 2px;align-self:stretch;margin:0 2px;background:linear-gradient(180deg,transparent,rgba(61,42,16,.18) 12%,rgba(61,42,16,.18) 88%,transparent)}.page-illu-wrap{order:2;flex:1 1 50%;max-height:none;padding-left:clamp(1rem,2.5vw,2rem)}.page-illu{height:100%;max-height:none}.book:not(.cover-page):not(.end-page) .dog-ear{display:block;position:absolute;right:0;bottom:0;width:48px;height:48px;clip-path:polygon(100% 0,100% 100%,0 100%);background:linear-gradient(135deg,rgba(255,255,255,.6),var(--paper-edge));box-shadow:-3px -3px 8px #3d2a102e;pointer-events:none}}.book.orientation-portrait .page-illu{object-fit:contain}.book.orientation-portrait .page-illu-wrap{max-height:56%}@media (max-height: 520px) and (max-width: 819px){.page-illu-wrap,.book.orientation-portrait .page-illu-wrap{max-height:32vh}.page-prose{min-height:4.5em}}@media (min-width: 820px){.book.orientation-portrait .page-illu-wrap{max-height:none}.book.orientation-portrait .cover-img{object-fit:contain}.book.orientation-portrait .page-cover{background:#0b0f24}}.audiobook-screen{padding:clamp(1rem,4vw,2.5rem)}.player-bg{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;z-index:0}.player-bg-strip{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;height:100%;width:max-content;will-change:transform;transition:transform .25s linear}.player-bg-img{height:100%;width:auto;object-fit:cover;flex:0 0 auto}.player-bg-veil{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(0deg,rgba(5,8,24,.96) 8%,rgba(5,8,24,.55) 45%,rgba(5,8,24,.7) 100%)}.player{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:.9rem;width:min(94vw,560px);padding:clamp(1.2rem,4vw,2rem)}.player-close{position:absolute;top:max(2px,env(safe-area-inset-top));right:max(2px,env(safe-area-inset-right));z-index:2;width:44px;height:44px;border-radius:50%;border:1px solid var(--card-border);background:rgba(10,14,35,.55);color:var(--gold-soft);font-size:1.15rem;line-height:1;transition:transform .16s var(--ease),background .16s var(--ease)}.player-close:hover{background:rgba(20,26,58,.7);transform:scale(1.08)}.player-meta{letter-spacing:.12em;color:var(--gold);font-size:.82rem;margin:0}.player-title{font-family:var(--font-hand);font-size:clamp(1.8rem,6vw,2.6rem);margin:0;text-shadow:0 2px 12px rgba(0,0,0,.6)}.player-progress{display:flex;align-items:center;gap:.7rem;width:100%}.progress{flex:1;height:8px;border-radius:999px;background:rgba(255,255,255,.16);cursor:pointer;touch-action:none}.progress-fill{position:relative;height:100%;width:0%;border-radius:999px;background:linear-gradient(90deg,var(--gold-soft),var(--amber));transition:width .15s linear}.progress-fill:after{content:"";position:absolute;right:-7px;top:50%;transform:translateY(-50%);width:15px;height:15px;border-radius:50%;background:var(--gold-soft);box-shadow:0 0 8px #f4d58db3}.time-cur,.time-tot{font-variant-numeric:tabular-nums;font-size:.85rem;color:var(--text-dim);min-width:3rem}.time-cur{text-align:right}.player-controls{display:flex;align-items:center;gap:1.2rem}.player-skip{min-width:56px;height:44px;border-radius:999px;border:1px solid var(--card-border);background:var(--card-bg);color:var(--text);font-weight:700}.player-skip:hover{background:var(--card-bg-hover)}.player-play{width:68px;height:68px;padding:16px;border-radius:50%;border:none;color:#2a1c08;background:linear-gradient(180deg,var(--gold-soft),var(--amber));box-shadow:var(--glow-gold)}.player-play svg{width:100%;height:100%}.player-play[disabled]{opacity:.5}.player-volume{display:flex;align-items:center;gap:.6rem;width:min(78%,280px)}.player-vol-icon{width:20px;height:20px;color:var(--gold-soft);flex:0 0 auto}.player-vol-icon svg{width:100%;height:100%}.player-vol{flex:1;min-width:0;height:4px;accent-color:var(--gold-soft);cursor:pointer}.player-text-btn{margin-top:.3rem;border-radius:999px;padding:.5rem 1.4rem;border:1px solid var(--card-border);background:transparent;color:var(--text-dim)}.player-text{max-height:28vh;max-height:28dvh;overflow-y:auto;width:100%;text-align:left;font-family:var(--font-hand);font-size:1.25rem;line-height:1.5;color:var(--text);background:rgba(5,8,24,.6);border:1px solid var(--card-border);border-radius:var(--radius);padding:1rem 1.2rem;scrollbar-width:none;-ms-overflow-style:none}.player-text::-webkit-scrollbar{width:0;height:0;display:none}.player-text p{margin:0 0 .6rem}@media (max-height: 480px){.audiobook-screen{justify-content:flex-start;overflow-y:auto}}.rating-screen{padding:0}.rating-fallback{padding:clamp(1rem,5vw,3rem);gap:clamp(1rem,4vh,2.4rem)}.rating3d-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;display:block;touch-action:none;cursor:grab;z-index:1}.rating3d-canvas.grab{cursor:grabbing}.rating3d-vig{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:2;background:radial-gradient(78% 66% at 50% 46%,transparent 38%,rgba(0,0,0,.9) 100%)}.rating-card{background:none;border:none;padding:0;transition:transform .2s var(--ease)}.rating-card:hover{transform:translateY(-6px) scale(1.04)}.rating-img{width:clamp(7rem,26vw,11rem);height:auto;filter:drop-shadow(var(--glow-soft))}.sleeping-moon{width:clamp(7rem,26vw,11rem);color:var(--gold);filter:drop-shadow(var(--glow-gold));animation:bob 6s ease-in-out infinite}.zzz{font-family:var(--font-hand);font-size:1.6rem;color:var(--gold-soft);letter-spacing:.3em}.toast-layer{position:absolute;left:0;right:0;bottom:calc(84px + env(safe-area-inset-bottom));z-index:7;display:flex;flex-direction:column;align-items:center;gap:.5rem;pointer-events:none}.toast{background:rgba(10,14,35,.85);border:1px solid var(--card-border);color:var(--gold-soft);padding:.6rem 1.2rem;border-radius:999px;font-size:.95rem;opacity:0;transform:translateY(10px);transition:opacity .3s var(--ease),transform .3s var(--ease)}.toast.show{opacity:1;transform:translateY(0)}.dim-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:5;background:#000;transition:opacity 1.2s var(--ease)}.dim-overlay.hidden{opacity:0;pointer-events:none}.hidden{display:none!important}.settings-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:6}.settings-scrim{position:absolute;top:0;right:0;bottom:0;left:0;background:rgba(2,4,14,.6);opacity:0;transition:opacity .32s var(--ease);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.settings-overlay.open .settings-scrim{opacity:1}.settings-panel{position:absolute;top:0;left:50%;right:auto;width:min(720px,100%);max-height:92vh;max-height:92dvh;overflow-y:auto;background:linear-gradient(180deg,#0c1130,#0a0e26);border:1px solid var(--card-border);border-top:none;border-radius:0 0 var(--radius-lg) var(--radius-lg);box-shadow:0 20px 60px #0009;padding:clamp(1.2rem,4vw,2rem);padding-top:max(clamp(1.2rem,4vw,2rem),env(safe-area-inset-top));transform:translate(-50%,-100%);transition:transform .32s var(--ease)}.settings-overlay.open .settings-panel{transform:translate(-50%)}.settings-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.2rem}.settings-title{font-family:var(--font-hand);color:var(--gold-soft);font-size:clamp(1.8rem,6vw,2.3rem);margin:0}.settings-close{width:42px;height:42px;border-radius:50%;border:1px solid var(--card-border);background:var(--card-bg);color:var(--gold-soft);font-size:1.1rem}.settings-close:hover{background:var(--card-bg-hover)}.settings-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media (min-width: 720px){.settings-grid{grid-template-columns:1fr 1fr}}.settings-group{border:1px solid var(--card-border);border-radius:var(--radius);padding:.8rem 1rem 1rem;margin:0}.settings-group legend{font-family:var(--font-hand);color:var(--gold-soft);font-size:1.3rem;padding:0 .4rem}.radio-pill{display:inline-flex;margin:.25rem .3rem .25rem 0}.radio-pill input{position:absolute;opacity:0;width:0;height:0}.pill-text{display:inline-block;padding:.4rem .9rem;border-radius:999px;border:1px solid var(--card-border);background:var(--card-bg);cursor:pointer;font-size:.92rem;transition:background .15s var(--ease)}.pill-text:hover{background:var(--card-bg-hover)}.radio-pill input:checked+.pill-text{background:linear-gradient(180deg,var(--gold-soft),var(--amber));color:#2a1c08;border-color:transparent;box-shadow:var(--glow-gold)}.radio-pill input:focus-visible+.pill-text{outline:2px solid var(--gold-soft);outline-offset:2px}.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.45rem 0}.toggle-label{font-size:.98rem}.switch{position:relative;width:46px;height:26px;flex:0 0 auto}.switch input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;margin:0;cursor:pointer}.slider{position:absolute;top:0;right:0;bottom:0;left:0;background:rgba(255,255,255,.18);border-radius:999px;transition:background .2s var(--ease)}.slider:before{content:"";position:absolute;width:20px;height:20px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform .2s var(--ease)}.switch input:checked+.slider{background:linear-gradient(90deg,var(--gold-soft),var(--amber))}.switch input:checked+.slider:before{transform:translate(20px)}.settings-group-list{grid-column:1 / -1}.settings-list{max-height:280px;overflow-y:auto;margin-top:.4rem}.list-row{display:flex;align-items:center;gap:.5rem;padding:.2rem 0;border-bottom:1px solid rgba(255,255,255,.06)}.list-open{flex:1;display:flex;align-items:center;gap:.6rem;background:none;border:none;color:var(--text);text-align:left;padding:.4rem;border-radius:10px}.list-open:hover{background:var(--card-bg)}.mode-icon{width:22px;height:22px;color:var(--gold-soft);flex:0 0 auto}.mode-icon svg{width:100%;height:100%}.list-title{flex:1;font-size:.95rem}.list-time{color:var(--text-dim);font-size:.78rem;white-space:nowrap}.list-remove{width:28px;height:28px;border-radius:50%;border:1px solid var(--card-border);background:transparent;color:var(--text-dim)}.list-remove:hover{color:#e89a9a;border-color:#e89a9a80}.list-empty{color:var(--text-dim);font-style:italic;font-size:.9rem;padding:.5rem .3rem;margin:0}.clear-data{margin-top:1.2rem;width:100%;padding:.85rem;border-radius:12px;border:1px solid rgba(232,120,120,.5);background:rgba(232,120,120,.12);color:#f0b8b8;font-weight:700}.clear-data:hover{background:rgba(232,120,120,.22)}.choice-card:active,.pick-card:active,.rating-card:active{transform:scale(.97)}.btn:active{transform:translateY(0) scale(.96)}.ctrl:active,.back-btn:active,.player-skip:active,.player-play:active,.nav-arrow:active,.nav-heart:active,.book-close:active,.settings-close:active,.list-remove:active{transform:scale(.92)}.list-open:active{transform:scale(.99)}button:focus-visible,.radio-pill input:focus-visible+.pill-text,.switch input:focus-visible+.slider{outline:2px solid var(--gold-soft);outline-offset:3px}.moon-badge{animation:bob 6s ease-in-out infinite}@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}@keyframes fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes breathe{0%,to{opacity:.55}50%{opacity:1}}@keyframes twinkle{0%,to{opacity:.25;transform:scale(.8)}50%{opacity:.9;transform:scale(1.1)}}@keyframes pulse-glow{0%,to{text-shadow:0 0 18px rgba(244,213,141,.35);filter:drop-shadow(0 0 14px rgba(244,213,141,.3))}50%{text-shadow:0 0 30px rgba(244,213,141,.6);filter:drop-shadow(0 0 24px rgba(244,213,141,.5))}}@keyframes bob{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes pulse-heart{0%,to{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.12)}}@keyframes fade-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-8px)}}@keyframes drift-x{0%{transform:translate(calc(var(--drift) * -1))}to{transform:translate(var(--drift))}}@keyframes shoot{0%{opacity:0;transform:translate(0) rotate(18deg)}2%{opacity:1}9%{opacity:0;transform:translate(120vw,38vh) rotate(18deg)}to{opacity:0;transform:translate(120vw,38vh) rotate(18deg)}}@keyframes page-peel{0%{transform:translate(7%) rotate(1.4deg);opacity:.35}to{transform:none;opacity:1}}@keyframes page-fold{0%{transform:rotateY(-32deg);opacity:.45}to{transform:rotateY(0);opacity:1}}@keyframes fade-to-0{to{opacity:0}}@keyframes fade-to-1{to{opacity:1}}@keyframes intro-city{0%{transform:translateY(0);opacity:1}55%{opacity:.55}to{transform:translateY(160px);opacity:0}}@keyframes intro-rise{0%{transform:translate(-150%,130%) scale(.55);opacity:0}18%{opacity:1}60%{transform:translate(-62%,-78%) scale(.95)}to{transform:translate(-50%,-50%) scale(1);opacity:1}}@keyframes intro-breathe{0%,to{transform:scale(1) rotate(-1deg)}50%{transform:scale(1.04) rotate(1deg)}}@keyframes zzz-float{0%{opacity:0;transform:translate(0)}25%{opacity:1}to{opacity:0;transform:translate(8px,-34px)}}
