:root{--ease-settle: cubic-bezier(.22, 1, .36, 1);--ease-spring: cubic-bezier(.34, 1.3, .5, 1);--ease-soft: cubic-bezier(.4, 0, .2, 1);--t-quick: .32s;--t-settle: .6s;--t-slow: 1.1s;--breath: 7s}@keyframes weave-in{0%{opacity:0;transform:translateY(10px) scale(.985);filter:blur(7px)}to{opacity:1;transform:none;filter:blur(0)}}@keyframes ink-drift{0%{opacity:0;transform:translate(var(--drift-x, 0),var(--drift-y, -18px)) scale(.6) rotate(var(--drift-r, -8deg));filter:blur(6px)}60%{opacity:.92;filter:blur(0)}to{opacity:.92;transform:translate(0) scale(1) rotate(0);filter:blur(0)}}@keyframes breathe{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-4px) scale(1.012)}}@keyframes word-swell{0%{transform:scale(1)}40%{transform:scale(1.06)}to{transform:scale(1)}}@keyframes bloom{0%{transform:scale(1);box-shadow:0 0 #d69a3e00}45%{transform:scale(1.04);box-shadow:0 0 38px 6px #d69a3e73}to{transform:scale(1);box-shadow:0 0 #d69a3e00}}@keyframes sparkle-rise{0%{opacity:0;transform:translateY(6px) scale(.4)}35%{opacity:1}to{opacity:0;transform:translateY(-22px) scale(1)}}@keyframes star-arrive{0%{opacity:0;transform:translate(-50%,-50%) scale(.2);filter:blur(3px)}70%{opacity:1;transform:translate(-50%,-50%) scale(1.15);filter:blur(0)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}:root{--bg: #f3e9db;--surface: #fffdf8;--surface-soft: #fbf3e8;--ink: #372f27;--muted: #8c8073;--line: #e7daca;--primary: #be6440;--primary-soft: #f1d9ca;--accent: #7f9670;--accent-soft: #dde5d2;--gold: #d69a3e;--mood-dusk: .2;--voice: 0;--font-head: "Newsreader", Georgia, "Times New Roman", serif;--font-body: "Mulish", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--tap: 64px;--radius: 20px;--radius-lg: 28px;--maxw: 600px;--maxw-spread: 1040px;font-synthesis:none;-webkit-text-size-adjust:100%}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:radial-gradient(120% 90% at 50% 0%,var(--surface-soft),var(--bg) 70%);color:var(--ink);font-family:var(--font-body);font-size:18px;line-height:1.5;-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent}::selection{background:#00000014}button{font-family:inherit}.app{position:relative;z-index:1;color:var(--ink);min-height:100%;min-height:100dvh;display:flex;flex-direction:column;max-width:var(--maxw);margin:0 auto;padding:calc(env(safe-area-inset-top) + 14px) 18px calc(18px + env(safe-area-inset-bottom))}.stardust{position:fixed;inset:0;width:100%;height:100%;z-index:0;pointer-events:none}.nightfall{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:0;background:radial-gradient(120% 95% at 50% 8%,#2c2336,#171221 72%);transition:opacity 2.8s var(--ease-soft)}.nightfall--on{opacity:1}.app--night{--bg: #1f1827;--surface: #2a2135;--surface-soft: #251d30;--ink: #f4ead9;--muted: #b3a294;--line: #473a55;--primary: #e08756;--primary-soft: #503528;--accent: #9eb48d;--accent-soft: #33402e;--gold: #e6b566}.app-header:before,.app-title{transition:color 1.2s var(--ease-soft)}.app-header{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 4px 14px;text-align:center}.app-header:before{content:"Tella";font-family:var(--font-head);font-weight:700;font-size:1.35rem;letter-spacing:-.01em;color:var(--primary)}.app-title{font-size:.72rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}.centered{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:20px;padding:24px}.centered h1{font-family:var(--font-head);font-weight:600;font-size:clamp(1.8rem,6vw,2.4rem);line-height:1.12;margin:0}.parent-gate{min-height:100%;display:flex;align-items:center;justify-content:center;padding:24px}.parent-gate__card{width:min(420px,100%);background:var(--surface);border:1.5px solid var(--line);border-radius:var(--radius-lg);box-shadow:0 18px 40px -24px #372f2759;padding:28px 24px 24px;text-align:center}.parent-gate__card h1{font-family:var(--font-head);font-weight:600;font-size:clamp(1.5rem,5vw,1.9rem);line-height:1.15;margin:0 0 10px}.parent-gate__card p{color:color-mix(in srgb,var(--ink) 82%,var(--muted));font-size:.98rem;margin:0 0 16px}.parent-gate__label{display:block;text-align:left;font-size:.82rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin:0 0 6px 4px}.parent-gate__input{width:100%;font:inherit;font-size:1rem;color:var(--ink);background:var(--surface-soft);border:1.5px solid var(--line);border-radius:14px;padding:14px 16px;margin-bottom:14px}.parent-gate__input:focus-visible{outline:2px solid var(--gold);outline-offset:1px}.parent-gate__send{width:100%}.parent-gate__error{color:var(--primary);font-size:.9rem;margin:12px 0 0}.parent-gate__again{font:inherit;font-size:.9rem;background:none;border:none;color:var(--muted);text-decoration:underline;cursor:pointer;padding:6px}.stage{flex:1;display:flex;flex-direction:column;gap:22px;padding-top:4px}.controls,.choice,.comprehension{width:100%;max-width:var(--maxw);margin-inline:auto}.cover{display:flex;flex-direction:column;align-items:center;gap:26px;width:100%}.cover-stage{position:relative;width:min(252px,62vw,29vh);aspect-ratio:11 / 20}.cover-glow{position:absolute;inset:2% 2% 5%;z-index:0;border-radius:50%;background:radial-gradient(closest-side,rgba(214,154,62,.32),transparent 75%);filter:blur(26px)}.cover-contact{position:absolute;left:13%;right:5%;bottom:2px;z-index:0;height:26px;border-radius:50%;background:radial-gradient(closest-side,rgba(55,47,39,.28),transparent 78%);filter:blur(8px)}.cover-float{position:absolute;inset:0;z-index:1;animation:coverFloat 6s ease-in-out infinite}.cover-pageblock{position:absolute;background-image:repeating-linear-gradient(to right,var(--surface) 0 3px,rgba(231,218,202,.6) 3px 4px);box-shadow:inset 0 0 0 1px var(--line)}.cover-pageblock--back{inset:2.8% 3.4% 6.8% 7.5%;border-radius:4px 13px 13px 4px;background-color:var(--surface-soft)}.cover-pageblock--mid{inset:1.5% 5.5% 8.1% 3.8%;border-radius:4px 12px 12px 4px;background-color:var(--surface)}.cover-board{position:absolute;inset:0 7% 9% 0;z-index:2;border-radius:6px 18px 18px 6px;overflow:hidden;box-shadow:0 26px 46px -18px #372f2778,0 8px 16px -10px #372f2754}.cover-board__face{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;user-select:none}.cover-board__face--placeholder{background:radial-gradient(86% 30% at 30% 100%,#3f2c20 60%,transparent 62%),radial-gradient(96% 36% at 78% 100%,#4d3829 58%,transparent 60%),linear-gradient(180deg,#eccaa6,#cf926a 44%,#7c5038)}.cover-board__face--placeholder:before{content:"";position:absolute;top:13%;left:50%;transform:translate(-50%);width:32%;aspect-ratio:1;border-radius:50%;background:radial-gradient(circle at 38% 36%,#fbe9b4,var(--gold));box-shadow:0 0 46px #d69a3e8c}.cover-board__face--placeholder:after{content:"";position:absolute;inset:0;background-image:radial-gradient(1.5px 1.5px at 22% 24%,rgba(255,253,248,.85),transparent),radial-gradient(1.5px 1.5px at 70% 18%,rgba(255,253,248,.75),transparent),radial-gradient(1.5px 1.5px at 84% 33%,rgba(255,253,248,.6),transparent),radial-gradient(1.5px 1.5px at 33% 40%,rgba(255,253,248,.55),transparent),radial-gradient(1.5px 1.5px at 58% 46%,rgba(255,253,248,.5),transparent)}.cover-board__spine{position:absolute;left:0;top:0;bottom:0;width:8%;z-index:3;pointer-events:none;background:linear-gradient(90deg,rgba(55,47,39,.33),rgba(55,47,39,.08) 55%,transparent);box-shadow:inset -1.5px 0 #ffffff47}.cover-board__sheen{position:absolute;top:0;left:0;right:0;height:42%;z-index:3;pointer-events:none;background:linear-gradient(180deg,rgba(255,255,255,.18),transparent)}.cover-board__keyline{position:absolute;inset:10px;z-index:4;pointer-events:none;border-radius:11px;box-shadow:inset 0 0 0 1.5px #d69a3e99,inset 0 0 0 3px #fffdf821}.cover-board__seal{position:absolute;top:18px;left:18px;z-index:5;display:inline-flex;align-items:center;gap:7px;padding:7px 13px 7px 10px;border-radius:999px;background:var(--surface);color:var(--primary);font-family:var(--font-body);font-weight:800;font-size:.75rem;letter-spacing:.01em;line-height:1;box-shadow:0 4px 10px -3px #372f2754,inset 0 1px #ffffffb3,inset 0 0 0 1px #d69a3e54}.cover-board__seal-star{width:14px;height:14px;flex-shrink:0;display:block}.cover-title{text-align:center}.cover-title h1{font-family:var(--font-head);font-weight:600;font-size:clamp(1.7rem,5.5vw,2.05rem);line-height:1.14;margin:0 0 10px;text-wrap:balance}.cover-subtitle{display:inline-flex;align-items:center;gap:7px;margin:0;font-size:.84rem;color:var(--muted)}.cover-rule{width:18px;height:1.5px;background:var(--line)}.cover-subtitle__icon{width:15px;height:15px;flex-shrink:0;display:block}.scene{width:100%;max-width:var(--maxw);margin-inline:auto;display:flex;flex-direction:column;gap:22px;animation:pageIn .42s cubic-bezier(.22,1,.36,1)}.scene-illustration{position:relative;width:100%;aspect-ratio:4 / 3;border-radius:var(--radius-lg);overflow:hidden;background:linear-gradient(170deg,var(--surface-soft),var(--primary-soft));box-shadow:0 16px 34px -18px #372f2766;display:flex;align-items:center;justify-content:center}.illo-parallax{position:absolute;inset:0;transform:translate(var(--px, 0px),var(--py, 0px)) scale(calc(1.06 + var(--kb, 0) * .05));transition:transform .3s var(--ease-soft);will-change:transform}@media (prefers-reduced-motion: reduce){.illo-parallax{transform:none!important}}.scene-illustration img{width:100%;height:100%;object-fit:cover;display:block;user-select:none}.illo-glow{position:absolute;inset:0;z-index:1;pointer-events:none;opacity:0;background:radial-gradient(62% 52% at 50% 42%,rgba(255,226,170,.5),transparent 70%);mix-blend-mode:soft-light}.illo-depth{position:absolute;inset:0;z-index:2;pointer-events:none;box-shadow:inset 0 2px 12px #ffffff1f,inset 0 -30px 52px -24px #281c1280;background:radial-gradient(122% 100% at 50% 28%,transparent 60%,rgba(40,28,18,.16) 100%)}.scene-illustration--empty{aspect-ratio:16 / 5;box-shadow:none}.scene-text{font-family:var(--font-head);font-weight:500;font-size:calc(var(--fit-scale, 1) * clamp(1.35rem,5.4vw,1.6rem));line-height:1.62;color:var(--ink);margin:0;padding:0 4px;text-wrap:pretty;height:clamp(8.5rem,36vh,18rem);overflow:hidden}.scene-text--live{position:relative}.word{display:inline-block;position:relative;z-index:1;color:var(--ink);transition:color var(--t-quick) var(--ease-soft),transform var(--t-quick) var(--ease-spring),text-shadow var(--t-quick) var(--ease-soft);will-change:transform}.word--read{color:#4a4238;color:color-mix(in srgb,var(--ink) 80%,var(--muted))}.word--next{color:var(--ink);text-shadow:0 0 14px rgba(190,100,64,.12)}.word--focus{color:#271f18;transform:scale(calc(1.035 + var(--voice, 0) * .05));text-shadow:0 0 calc(12px + var(--voice, 0) * 16px) rgba(190,100,64,calc(.1 + var(--voice, 0) * .18))}.reading-lamp{position:absolute;left:0;top:0;z-index:0;border-radius:999px;pointer-events:none;opacity:0;background:radial-gradient(60% 80% at 50% 50%,#d69a3e57,#f1d9ca47 55%,#f1d9ca00);box-shadow:0 6px 22px -10px #be644080;transition:transform .46s var(--ease-spring),width .46s var(--ease-spring),height .32s var(--ease-settle),opacity .4s var(--ease-soft)}.reading-lamp--on{opacity:calc(.82 + var(--voice, 0) * .5)}.word--say{color:#b85c39;color:color-mix(in srgb,var(--primary) 88%,var(--ink))}@keyframes word-settle{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}.scene-text--live .word{animation:word-settle .5s var(--ease-settle) backwards}@media (min-width: 820px){.app{max-width:var(--maxw-spread)}.scene{max-width:var(--maxw-spread);display:grid;grid-template-columns:1fr 1fr;align-items:stretch;gap:0;position:relative;min-height:clamp(420px,62vh,700px);background:var(--surface);border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 40px 80px -28px #372f2775,inset 0 0 0 1px var(--line)}.scene-illustration{height:100%;aspect-ratio:auto;border-radius:0;box-shadow:none}.scene-illustration--empty{background:linear-gradient(170deg,var(--surface-soft),var(--primary-soft))}.scene-text{align-self:center;justify-self:center;max-width:34ch;padding:48px 56px;font-size:calc(var(--fit-scale, 1) * clamp(1.5rem,2.4vw,1.9rem));line-height:1.66;height:auto;max-height:100%;overflow:hidden}.scene:after{content:"";position:absolute;top:0;bottom:0;left:50%;width:30px;transform:translate(-50%);pointer-events:none;background:linear-gradient(90deg,transparent,rgba(55,47,39,.12) 44%,rgba(55,47,39,.17) 50%,rgba(55,47,39,.12) 56%,transparent)}}.btn{font:inherit;font-family:var(--font-body);font-weight:800;letter-spacing:.01em;border:none;border-radius:999px;background:var(--surface);color:var(--ink);box-shadow:inset 0 0 0 1.5px var(--line);min-height:var(--tap);padding:0 26px;cursor:pointer;touch-action:manipulation;transition:transform .12s ease,box-shadow .2s ease,background .2s ease}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.45;cursor:default}.controls{margin-top:auto;padding:10px 0 4px}.controls--playing{display:flex;align-items:center;justify-content:center;gap:16px}.controls--done{position:relative;display:flex;align-items:center;justify-content:center;min-height:80px;width:min(360px,100%);margin-inline:auto}.btn--icon{width:52px;min-width:52px;height:52px;min-height:0;padding:0;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--surface);box-shadow:inset 0 0 0 1.5px var(--line);color:var(--muted)}.btn--icon[aria-pressed=true]{color:var(--primary);background:var(--primary-soft);box-shadow:none}.btn--relisten{position:absolute;left:0;width:48px;min-width:48px;height:48px;min-height:0;padding:0;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--surface);box-shadow:inset 0 0 0 1.5px var(--line);color:var(--muted)}.btn--finish{width:80px;min-width:80px;height:80px;padding:0;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--accent);color:#fff;box-shadow:0 12px 28px -8px #7f9670b3;animation:finishPulse 1.8s ease-in-out infinite}.btn--ring{position:relative;width:80px;min-width:80px;height:80px;padding:0;border-radius:50%;background:transparent;box-shadow:none;display:flex;align-items:center;justify-content:center}.ring-svg{position:absolute;inset:0;transform:rotate(-90deg)}.ring-track{fill:none;stroke:var(--line);stroke-width:4}.ring-progress{fill:none;stroke:var(--primary);stroke-width:4;stroke-linecap:round;stroke-dashoffset:0;animation-name:ringSweep;animation-timing-function:linear;animation-fill-mode:forwards}.ring-arrow{position:relative;z-index:1;width:58px;height:58px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 24px -8px #be6440b3}@media (min-width: 820px){.controls--playing{gap:18px}.controls--done{min-height:72px;width:min(320px,100%)}.btn--relisten{width:52px;min-width:52px;height:52px}.btn--finish{width:72px;min-width:72px;height:72px}}.btn--round{width:72px;min-width:72px;height:72px;padding:0;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--primary);color:#fff;box-shadow:0 14px 30px -8px #be6440a6}.btn--next{flex:1;background:var(--primary);color:#fff;font-size:1.1rem;box-shadow:0 8px 20px -6px #be64408c}.btn--start{background:var(--primary);color:#fff;font-family:var(--font-head);font-weight:700;font-size:1.25rem;padding:0 34px;min-height:68px;box-shadow:0 16px 34px -10px #be6440b3}.btn--ghost{background:transparent;box-shadow:none;color:var(--muted);font-weight:700}.choice,.comprehension{margin-top:auto;display:flex;flex-direction:column;gap:14px;padding-bottom:4px}.choice-prompt,.q-prompt{font-family:var(--font-head);font-weight:600;font-size:clamp(1.4rem,5vw,1.7rem);line-height:1.25;margin:0 0 6px}.choice-options,.q-options{display:flex;flex-direction:column;gap:12px}.btn--choice{width:100%;text-align:left;justify-content:flex-start;font-size:1.1rem;font-weight:700;padding:17px 20px;min-height:var(--tap);border-radius:18px;background:var(--surface);box-shadow:inset 0 0 0 2px var(--line)}.btn--correct{background:var(--accent-soft);box-shadow:inset 0 0 0 2px var(--accent)}.btn--picked{box-shadow:inset 0 0 0 2px var(--primary)}.choice-paths{display:flex;flex-wrap:wrap;gap:12px}.choice-path{--door-light: 255, 224, 170;position:relative;flex:1 1 42%;min-width:140px;min-height:clamp(92px,12vh,124px);border:none;border-radius:999px 999px 22px 22px;padding:14px 16px;cursor:pointer;overflow:hidden;color:#fbf3e8;text-shadow:0 1px 10px rgba(20,12,8,.55);font-family:var(--font-head);font-weight:600;font-size:1.1rem;line-height:1.2;text-align:center;display:flex;align-items:center;justify-content:center;touch-action:manipulation;animation:weave-in .65s var(--ease-spring) backwards;transition:transform .3s var(--ease-spring),box-shadow .3s var(--ease-soft),opacity .3s var(--ease-soft),filter .45s var(--ease-soft)}.choice-path--warm{background:linear-gradient(186deg,#3d2738,#6e3f31 58%,#9a5b39);box-shadow:inset 0 0 0 1.5px #d69a3e6b,inset 0 -34px 44px -26px #ffc4788c,0 16px 34px -18px #3721148c}.choice-path--cool{--door-light: 205, 225, 255;background:linear-gradient(186deg,#232a44,#3c4a64 60%,#5d7263);box-shadow:inset 0 0 0 1.5px #aac4ff4d,inset 0 -34px 44px -26px #bedcff6b,0 16px 34px -18px #181e2c8c}.choice-path:before{content:"";position:absolute;left:50%;top:24%;bottom:30%;width:2.5px;transform:translate(-50%);border-radius:3px;background:linear-gradient(180deg,rgba(var(--door-light),0),rgba(var(--door-light),.9));filter:drop-shadow(0 0 7px rgba(var(--door-light),.8));opacity:.55;transition:width .45s var(--ease-soft),opacity .45s var(--ease-soft)}.choice-path__glow{position:absolute;left:16%;right:16%;bottom:0;height:30%;pointer-events:none;background:radial-gradient(60% 100% at 50% 100%,rgba(var(--door-light),.6),transparent 76%);opacity:.55;transition:opacity .45s var(--ease-soft)}.choice-path__label{position:relative;z-index:1}.choice-path:hover{transform:translateY(-4px)}.choice-path:hover:before{width:7px;opacity:.95}.choice-path:hover .choice-path__glow{opacity:.9}.choice-path:active{transform:translateY(-1px) scale(.99)}.choice-path:focus-visible{outline:3px solid var(--gold);outline-offset:3px}.choice-path.is-chosen{animation:bloom .6s var(--ease-spring);filter:brightness(1.14)}.choice-path.is-chosen:before{width:64%;opacity:1}.choice-path.is-chosen .choice-path__glow{opacity:1}.choice-path.is-dimmed{opacity:.4;transform:scale(.97)}.app--choosing .stage .book,.app--choosing .stage .scene{filter:brightness(.96);transition:filter .8s var(--ease-soft)}.q-progress{color:var(--accent);font-size:.78rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;margin:0}.affirmation{display:flex;flex-direction:column;gap:12px;background:var(--accent-soft);border-radius:18px;padding:16px 18px}.affirmation p{margin:0;font-size:1.1rem;font-weight:700;color:var(--ink)}.cozy-quiz{align-items:stretch;gap:16px}.friend-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.story-friend{position:relative;width:60px;height:60px;flex-shrink:0}.friend-aura{position:absolute;inset:-8px;border-radius:50%;background:radial-gradient(closest-side,rgba(214,154,62,.4),transparent 72%);filter:blur(4px);animation:breathe var(--breath) var(--ease-soft) infinite}.friend-face{position:relative;width:100%;height:100%}.friend-body{fill:#fbe9b4;stroke:var(--gold);stroke-width:1.5}.friend-eye{fill:#4a3a22}.friend-eye:not(.friend-eye--happy){transform-box:fill-box;transform-origin:center;animation:friend-blink 4.6s ease-in-out infinite}.friend-eye--happy{fill:none;stroke:#4a3a22;stroke-width:2.4;stroke-linecap:round}.friend-smile{stroke:#4a3a22}.story-friend--asking .friend-face{transform-origin:50% 62%;animation:friend-curious 7s var(--ease-soft) infinite}@keyframes friend-blink{0%,93%,to{transform:scaleY(1)}96%{transform:scaleY(.08)}}@keyframes friend-curious{0%,to{transform:rotate(-2.4deg)}50%{transform:rotate(2.4deg)}}.story-friend--delight{animation:friend-hop .7s var(--ease-spring)}.story-friend--delight .friend-aura{background:radial-gradient(closest-side,rgba(214,154,62,.72),transparent 72%)}@keyframes friend-hop{0%{transform:translateY(0)}30%{transform:translateY(-10px) scale(1.05)}60%{transform:translateY(0) scale(.99)}to{transform:translateY(0)}}.quiz-dots{display:flex;gap:7px}.quiz-dot{width:8px;height:8px;border-radius:50%;background:var(--line);transition:background .3s var(--ease-soft)}.quiz-dot.is-on{background:var(--accent)}.quiz-bubble{position:relative;background:var(--surface);border-radius:20px;padding:18px 20px;box-shadow:inset 0 0 0 1.5px var(--line);transition:background .45s var(--ease-soft),box-shadow .45s var(--ease-soft)}.quiz-bubble--delight{background:var(--accent-soft);box-shadow:inset 0 0 0 1.5px var(--accent)}.quiz-bubble--warm{background:var(--primary-soft);box-shadow:inset 0 0 0 1.5px var(--primary-soft)}.quiz-bubble .q-prompt,.quiz-bubble .q-affirm{margin:0}.q-affirm{font-family:var(--font-head);font-weight:600;font-size:clamp(1.2rem,4.4vw,1.45rem);line-height:1.32;color:var(--ink)}.quiz-sparks{position:absolute;inset:0;pointer-events:none}.quiz-spark{position:absolute;bottom:28%;width:10px;height:10px;border-radius:50%;background:radial-gradient(circle,#fff 0%,var(--gold) 60%,transparent 76%);opacity:0;animation:sparkle-rise 1s var(--ease-soft) both}.end-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:18px}.end-stars{display:flex;gap:8px;align-items:flex-end;color:var(--gold);margin-bottom:4px}.end-stars svg{width:30px;height:30px}.end-stars svg:nth-child(2){width:42px;height:42px;margin-bottom:6px}.end-screen h1{font-family:var(--font-head);font-weight:600;font-size:clamp(2rem,7vw,2.6rem);margin:0}.export-panel{margin-top:24px;width:100%;max-width:var(--maxw);margin-inline:auto;background:var(--surface-soft);border-radius:18px;box-shadow:inset 0 0 0 1.5px var(--line);padding:16px;text-align:left}.export-panel h2{margin:0 0 6px;font-size:.78rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}.export-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}.export-actions .btn{min-height:44px;font-size:.95rem;padding:0 18px}.export-floating{position:fixed;left:50%;bottom:12px;transform:translate(-50%);width:min(var(--maxw),92vw);z-index:10}.muted{color:var(--muted)}h1{font-family:var(--font-head);font-weight:600;line-height:1.15}.ambient-veil{position:fixed;inset:0;z-index:40;pointer-events:none;background:radial-gradient(132% 116% at 50% 42%,transparent 58%,rgba(36,24,16,calc(var(--mood-dusk, .2) * .5)) 100%);transition:background 4s var(--ease-soft)}.incantation .cover-glow{animation:weave-in 1.3s var(--ease-soft) backwards}.incantation .cover-pageblock{animation:weave-in .9s var(--ease-settle) .12s backwards}.incantation-board{animation:board-paint 1.05s var(--ease-settle) .25s backwards}@keyframes board-paint{0%{clip-path:inset(0 100% 0 0 round 6px 18px 18px 6px);opacity:.5;filter:blur(5px)}to{clip-path:inset(0 0 0 0 round 6px 18px 18px 6px);opacity:1;filter:blur(0)}}.ink-name{color:var(--primary);font-weight:800}.ink-letter{display:inline-block;white-space:pre;animation:weave-in .55s var(--ease-spring) backwards}.title-word{display:inline-block;animation:weave-in .7s var(--ease-spring) backwards}.title-word--name{color:var(--primary);text-shadow:0 0 20px rgba(190,100,64,.18)}.incantation-subtitle{animation:weave-in .8s var(--ease-settle) 1.9s backwards}.incantation-motifs{position:absolute;inset:0;pointer-events:none;z-index:3}.incantation-motif{position:absolute;width:34px;height:34px;opacity:.92;filter:drop-shadow(0 3px 8px rgba(190,100,64,.28));animation:ink-drift 1.15s var(--ease-spring) backwards,motif-idle 9s var(--ease-soft) infinite}@keyframes motif-idle{0%,to{transform:none}50%{transform:translateY(-4px) rotate(1.8deg)}}.incantation-motif svg{width:100%;height:100%;display:block}.motif--0{color:var(--gold)}.motif--1{color:var(--accent)}.motif--2{color:var(--primary)}.incantation-start{animation:start-rise .9s var(--ease-spring) 2.3s backwards}.incantation-start:not(:disabled){animation:start-rise .9s var(--ease-spring) 2.3s backwards,start-halo 3.8s ease-in-out 3.4s infinite}@keyframes start-rise{0%{opacity:0;transform:translateY(14px) scale(.96)}to{opacity:1;transform:none}}@keyframes start-halo{0%,to{box-shadow:0 16px 34px -10px #be6440b3}50%{box-shadow:0 16px 34px -10px #be6440b3,0 0 0 12px #be644017}}.keepsake{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:4px}.night-sky{position:relative;display:block;width:min(340px,82vw);height:150px;padding:0;border:none;cursor:pointer;border-radius:24px;overflow:hidden;background:radial-gradient(125% 145% at 50% 0%,#2b3454,#161a2e 72%);box-shadow:inset 0 0 0 1px #ffffff0f,0 18px 36px -20px #14182cd9}.night-sky:focus-visible{outline:3px solid var(--gold);outline-offset:3px}.sky-lines{position:absolute;inset:0;width:100%;height:100%}.sky-lines polyline{fill:none;stroke:#e6d5a066;stroke-width:.6;stroke-linecap:round;stroke-linejoin:round}.sky-star{position:absolute;transform:translate(-50%,-50%);border-radius:50%;background:radial-gradient(circle,#fff 0%,rgba(255,247,214,.55) 50%,transparent 76%);box-shadow:0 0 8px #ffeebecc;animation:twinkle 4.5s var(--ease-soft) infinite}.sky-star--new{background:radial-gradient(circle,#fff 0%,var(--gold) 55%,transparent 80%);box-shadow:0 0 14px 3px #d69a3ed9;animation:star-arrive 1.5s var(--ease-spring) both}@keyframes twinkle{0%,to{opacity:.5}50%{opacity:1}}.sky-caption{margin:0;font-size:.72rem;font-weight:800;letter-spacing:.09em;text-transform:uppercase;color:var(--muted)}.sky-shoot{position:absolute;top:18%;left:8%;width:64px;height:2px;border-radius:2px;transform:rotate(24deg);transform-origin:left center;background:linear-gradient(90deg,#fff4d600,#fff4d6 85%,#fff);box-shadow:0 0 10px #fff0c8e6;opacity:0;animation:sky-shoot 1.15s var(--ease-soft)}@keyframes sky-shoot{0%{opacity:0;transform:rotate(24deg) translate(0) scaleX(.3)}18%{opacity:1}70%{opacity:.9}to{opacity:0;transform:rotate(24deg) translate(230px) scaleX(1)}}.sky-wish{margin:-2px 0 0;font-family:var(--font-head);font-style:italic;font-size:.92rem;color:var(--gold);opacity:.85}.end-memory{margin:0;max-width:30ch;font-size:1.02rem;line-height:1.5;color:var(--muted)}.end-memory em{font-style:normal;font-family:var(--font-head);font-weight:600;color:var(--ink)}.btn--replay-soft{background:transparent;box-shadow:inset 0 0 0 1.5px var(--line);color:var(--primary);font-family:var(--font-head);font-weight:700;font-size:1.05rem;min-height:60px;padding:0 28px;margin-top:4px}@keyframes pageIn{0%{opacity:0;transform:translate(28px)}to{opacity:1;transform:none}}@keyframes ringSweep{0%{stroke-dashoffset:0}to{stroke-dashoffset:var(--ring-c)}}@keyframes finishPulse{0%,to{transform:scale(1)}50%{transform:scale(1.06)}}@keyframes coverFloat{0%,to{transform:translateY(0) rotate(-.4deg)}50%{transform:translateY(-7px) rotate(.4deg)}}@media (prefers-reduced-motion: reduce){*{transition:none!important;animation:none!important}}@media (prefers-contrast: more){:root{--muted: #5f574c;--line: #cdbfa9}}.book{--turn-ms: .7s;position:relative;width:100%;margin:0 auto}.book .scene{animation:none}.book-page{overflow:hidden}.leaf{position:absolute;top:0;height:100%;transform-style:preserve-3d;transform-origin:left center;will-change:transform;z-index:5}.leaf-face{position:absolute;inset:0;overflow:hidden;backface-visibility:hidden;-webkit-backface-visibility:hidden}.leaf-face>.book-page{width:100%;height:100%}.leaf-back{transform:rotateY(180deg)}.leaf-back--blank{background:var(--surface-soft)}.leaf-shadow{position:absolute;inset:0;pointer-events:none;border-radius:inherit;background:linear-gradient(90deg,#372f2738,#372f2700 55%);opacity:0;animation:leaf-shade var(--turn-ms) ease-in-out forwards}@keyframes leaf-shade{0%{opacity:0}35%{opacity:.5}to{opacity:0}}@keyframes leaf-turn{0%{transform:rotateY(0)}to{transform:rotateY(-180deg)}}.book--single{perspective:1600px}.book--single .book-page--full{width:100%;background:var(--bg);border-radius:var(--radius-lg)}.book--single .leaf{left:0;width:100%;border-radius:var(--radius-lg);animation:leaf-turn var(--turn-ms) cubic-bezier(.45,.05,.3,1) forwards}.book--single .leaf-back--blank{border-radius:var(--radius-lg)}@media (min-width: 820px){.book--spread{position:relative;display:flex;align-items:stretch;max-width:var(--maxw-spread);height:clamp(420px,62vh,700px);margin-inline:auto;background:var(--surface);border-radius:var(--radius-lg);overflow:hidden;perspective:2200px;box-shadow:0 40px 80px -28px #372f2775,inset 0 0 0 1px var(--line)}.book--spread .book-page{flex:1 1 0;height:100%;background:var(--surface)}.book--spread .book-page--left{border-radius:var(--radius-lg) 0 0 var(--radius-lg)}.book--spread .book-page--right{border-radius:0 var(--radius-lg) var(--radius-lg) 0;display:flex;align-items:center;justify-content:center}.book-spine{position:absolute;top:0;bottom:0;left:50%;width:30px;transform:translate(-50%);pointer-events:none;z-index:4;background:linear-gradient(90deg,transparent,rgba(55,47,39,.12) 44%,rgba(55,47,39,.17) 50%,rgba(55,47,39,.12) 56%,transparent)}.book--spread .leaf--spread{right:0;width:50%;animation:leaf-turn var(--turn-ms) ease-in-out forwards}}
