@import"https://fonts.googleapis.com/css2?family=Josefin+Sans:wght@300;400;600&display=swap";:root{--color-primary: #4f46e5;--color-primary-hover: #4338ca;--color-secondary: #64748b;--color-background: #ffffff;--color-surface: #f8fafc;--color-text: #1e293b;--color-text-muted: #64748b;--color-border: #e2e8f0;--color-error: #ef4444;--color-success: #22c55e;--font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-family-fancy: "Cinzel", serif;--font-family-body: "Alegreya", serif;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1)}*,*:before,*:after{box-sizing:border-box}*{margin:0}html{-webkit-text-size-adjust:100%}body{line-height:1.5;-webkit-font-smoothing:antialiased}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}body{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text);background-color:var(--color-background)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-base);font-weight:500;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background-color .15s ease;text-decoration:none}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover{background-color:var(--color-primary-hover)}.btn-secondary{background-color:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover{background-color:var(--color-border)}.input{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-base);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-background)}.input:focus{outline:2px solid var(--color-primary);outline-offset:-1px;border-color:var(--color-primary)}.card{background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm)}@keyframes creature-card-enter{0%{opacity:0;transform:scale(.92) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes creature-card-enter-bounce{0%{opacity:0;transform:scale(.3) translateY(40px)}50%{opacity:1;transform:scale(1.08) translateY(-8px)}70%{transform:scale(.96) translateY(3px)}85%{transform:scale(1.02) translateY(-1px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes creature-reveal-glow{0%{box-shadow:inset 0 0 0 1px #facc1580,0 0 16px 2px #facc1540}to{box-shadow:inset 0 0 0 1px transparent,0 0 0 0 transparent}}@keyframes creature-tab-glow{0%,30%{box-shadow:0 0 10px 2px #facc1580;border-color:#facc15b3}to{box-shadow:none;border-color:#ffffff26}}@keyframes creature-poem-line-reveal{0%{background:#facc1526}to{background:transparent}}.creature-card{display:flex;flex-direction:column;align-self:center;width:100%;max-width:380px;background:#0c0a14;border:1px solid rgba(255,255,255,.08);border-radius:1rem;overflow:hidden;min-height:0;animation:creature-card-enter .5s cubic-bezier(.16,1,.3,1) both}.creature-card--entrance{animation:creature-card-enter-bounce .9s cubic-bezier(.22,1,.36,1) both}.creature-card-video-wrap{position:relative;aspect-ratio:1 / 1;overflow:hidden;background:#0a0a14;flex:0 1 auto;min-height:140px}.creature-card-video{display:block;width:100%;height:100%;object-fit:cover}.creature-card-video-overlay{position:absolute;inset:auto 0 0 0;padding:var(--spacing-lg) var(--spacing-md) var(--spacing-md);background:linear-gradient(to top,rgba(8,6,16,.92) 0%,rgba(8,6,16,.5) 60%,transparent 100%);display:flex;flex-direction:column;gap:var(--spacing-xs)}.creature-card-name{font-family:Josefin Sans,sans-serif;font-size:var(--font-size-2xl);font-weight:600;color:#ffffffeb;margin:0;line-height:1.1;letter-spacing:.02em}.creature-card-realm{display:inline-block;align-self:flex-start;font-family:Josefin Sans,sans-serif;font-size:.65rem;font-weight:400;letter-spacing:.12em;text-transform:uppercase;padding:3px 10px;border-radius:var(--radius-full);line-height:1.3}.creature-card-realm--aurora_skies{background:#a78bfa40;color:#c4b5fd}.creature-card-realm--cascadia_falls{background:#22d3ee33;color:#67e8f9}.creature-card-realm--ember_peaks{background:#f9731640;color:#fdba74}.creature-card-realm--frost_hollows{background:#93c5fd40;color:#bfdbfe}.creature-card-realm--twilight_veil{background:#818cf840;color:#a5b4fc}.creature-card-realm--verdant_wilds{background:#4ade8033;color:#86efac}.creature-card-realm--celestial_isles{background:#facc1533;color:#fde68a}.creature-card-tabs{display:flex;border-bottom:1px solid rgba(255,255,255,.06)}.creature-card-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:var(--spacing-sm) var(--spacing-xs);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;color:#fff6;transition:color .2s,border-color .2s,box-shadow .4s}.creature-card-tab:hover:not(.creature-card-tab--locked){color:#ffffffb3}.creature-card-tab--active{color:#ffffffe0;border-bottom-color:#ffffff80}.creature-card-tab--active.creature-card-tab--locked{border-bottom-color:#ffffff26}.creature-card-tab--locked{color:#fff3;cursor:pointer}.creature-card-tab--new{animation:creature-tab-glow 2s ease-out both}.creature-card-tab-label{font-family:Josefin Sans,sans-serif;font-size:.55rem;letter-spacing:.1em;text-transform:uppercase;min-height:.75rem}.creature-card-content{padding:var(--spacing-md);flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;touch-action:pan-y;border-radius:var(--radius-sm);transition:box-shadow .6s ease}.creature-card-content::-webkit-scrollbar{width:4px}.creature-card-content::-webkit-scrollbar-track{background:transparent}.creature-card-content::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}.creature-card-content::-webkit-scrollbar-thumb:hover{background:#ffffff40}.creature-card-content{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent}.creature-card-content--new{animation:creature-reveal-glow 2.5s ease-out .3s both}.creature-card-body{display:flex;flex-direction:column;flex:0 1 260px;min-height:140px}.creature-card-fact-title{font-family:var(--font-family-body);font-size:var(--font-size-lg);font-weight:700;font-style:italic;color:#ffffffd9;margin:0 0 var(--spacing-xs) 0}.creature-card-fact-text{font-family:var(--font-family-body);font-size:var(--font-size-base);color:#ffffffb3;line-height:1.55;margin:0}.creature-card-empty-text{font-family:var(--font-family-body);font-size:var(--font-size-sm);font-style:italic;color:#ffffff40;margin:0;display:flex;align-items:center;justify-content:center;height:100%;text-align:center}.creature-card-locked-text{font-family:var(--font-family-body);font-size:var(--font-size-sm);font-style:italic;color:#fff3;margin:0;display:flex;align-items:center;justify-content:center;height:100%}.creature-card-poem{padding:var(--spacing-md);flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;touch-action:pan-y;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent}.creature-card-poem::-webkit-scrollbar{width:4px}.creature-card-poem::-webkit-scrollbar-track{background:transparent}.creature-card-poem::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}.creature-card-poem::-webkit-scrollbar-thumb:hover{background:#ffffff40}.creature-card-poem-header{display:flex;align-items:center;gap:var(--spacing-xs);color:#fff6;font-family:Josefin Sans,sans-serif;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:var(--spacing-md)}.creature-card-poem-label{color:#fff6}.creature-card-poem-dash{color:#fff3}.creature-card-poem-title{color:#ffffff8c;font-style:italic;text-transform:none;letter-spacing:.02em}.creature-card-poem-lines{display:flex;flex-direction:column;gap:var(--spacing-sm)}.creature-card-poem-line{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:4px 6px;border-radius:var(--radius-sm)}.creature-card-poem-line--new{animation:creature-poem-line-reveal 2s ease-out .3s both}.creature-card-poem-mark{flex-shrink:0;width:3px;height:1.1em;margin-top:.25em;background:#facc1580;border-radius:2px}.creature-card-poem-text{font-family:var(--font-family-body);font-size:var(--font-size-base);font-style:italic;color:#fffc;line-height:1.5}.creature-card-poem-text--locked{font-style:normal;color:#fff3}.creature-card-poem-lock{flex-shrink:0;margin-top:.2em;color:#ffffff26}.creature-card-poem-line--locked{opacity:.6}.creature-card-speak{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-full);color:#ffffff8c;cursor:pointer;transition:color .15s,background .15s,border-color .15s}.creature-card-speak:hover{color:#ffffffe6;background:#ffffff1f;border-color:#fff3}.creature-card-speak--float{float:right;margin:0 0 var(--spacing-xs) var(--spacing-sm)}.creature-card-poem-header .creature-card-speak{margin-left:auto;width:24px;height:24px}.creature-card-hint{font-family:var(--font-family-body);font-size:var(--font-size-sm);color:#ffffff40;text-align:center;margin:var(--spacing-sm) var(--spacing-md) 0;font-style:italic}html,body{background-color:#000}:root{--home-ivory: oklch(.96 .015 85);--home-ivory-dim: oklch(.88 .02 85 / .85);--home-ivory-mute: oklch(.82 .02 85 / .75);--home-gold: oklch(.82 .12 82);--home-gold-soft: oklch(.82 .12 82 / .55);--screen-vignette: radial-gradient(ellipse at 50% 55%, transparent 30%, rgba(0, 0, 0, .55) 100%), linear-gradient(180deg, rgba(0, 0, 0, .25) 0%, rgba(0, 0, 0, 0) 35%, rgba(0, 0, 0, .55) 100%)}html:has(.home-screen),body:has(.home-screen){overflow:hidden;position:fixed;width:100%;height:100%}.home-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2;color:var(--home-ivory);font-family:EB Garamond,Alegreya,serif;display:grid;grid-template-rows:auto 1fr auto;padding:max(env(safe-area-inset-top,0px),18px) 24px max(env(safe-area-inset-bottom,0px),20px);gap:12px;pointer-events:none}.home-screen:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--screen-vignette);pointer-events:none;z-index:-1}.home-screen button,.home-screen a,.home-screen .home-sigil{pointer-events:auto}.home-topbar{display:flex;align-items:center;justify-content:space-between;min-height:2.25rem}.home-crest{font-family:Cinzel,serif;color:var(--home-gold);font-size:13px;letter-spacing:.42em;text-transform:uppercase;text-shadow:0 1px 6px rgba(0,0,0,.6)}.home-crest:before{content:"✦ ";opacity:.8}.home-crest:after{content:"  ✦";opacity:.8}.profile-pill-wrap{position:relative}.profile-pill{display:inline-flex;align-items:center;gap:10px;padding:5px 14px;border:1px solid var(--home-gold-soft);border-radius:999px;background:#00000059;color:var(--home-ivory);font-family:EB Garamond,serif;font-style:italic;letter-spacing:.02em;font-size:15px;cursor:pointer;-webkit-user-select:none;user-select:none;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:background .15s ease,border-color .15s ease}.profile-pill:hover{border-color:var(--home-gold)}.profile-pill-wrap--open .profile-pill{border-color:var(--home-gold);background:#0000008c}.profile-pill-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:12rem}.profile-pill-caret{opacity:.7;font-size:10px;transition:transform .2s ease}.profile-pill-wrap--open .profile-pill-caret{transform:rotate(180deg)}.profile-pill-menu{position:absolute;top:calc(100% + 10px);right:0;min-width:240px;background:#0a0c10d1;border:1px solid var(--home-gold-soft);backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);box-shadow:0 20px 50px #0009,0 0 30px #f4b93c2e;padding:8px;z-index:10;animation:profile-pill-menu-in .18s ease-out}@keyframes profile-pill-menu-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}.profile-pill-section-label{font-family:Cinzel,serif;font-size:9px;letter-spacing:.32em;text-transform:uppercase;color:var(--home-ivory-mute);padding:8px 10px 4px}.profile-pill-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:6px;cursor:pointer;color:var(--home-ivory);font-family:EB Garamond,serif;font-size:16px;width:100%;text-align:left;background:transparent;border:0;-webkit-appearance:none;-moz-appearance:none;appearance:none}.profile-pill-row:hover{background:#ffffff0f}.profile-pill-row--active{background:#00000059;cursor:default}.profile-pill-row--active .profile-pill-row-name{color:var(--home-gold)}.profile-pill-mini-avatar{width:28px;height:28px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#ffffff1f,#000000b3);border:1px solid oklch(.82 .12 82 / .4);display:flex;align-items:center;justify-content:center;font-family:EB Garamond,serif;font-style:italic;font-size:14px;color:var(--home-ivory);flex-shrink:0}.profile-pill-row--active .profile-pill-mini-avatar{border:1.5px solid var(--home-gold);background:radial-gradient(circle at 35% 30%,#f4b93c8c,#4e390ca0 50%,#160e01a9 75%,#030200ae,#000000b3)}.profile-pill-row-name{flex:1;line-height:1.1}.profile-pill-row-meta{font-family:Cinzel,serif;font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:var(--home-gold)}.profile-pill-divider{border:0;border-top:1px solid var(--home-gold-soft);opacity:.35;margin:6px 2px}.profile-pill-row--add .profile-pill-mini-avatar{border:1px dashed oklch(.82 .12 82 / .6);color:var(--home-gold);font-style:normal;font-size:18px}.profile-pill-row--add .profile-pill-row-name{color:var(--home-ivory-dim);font-style:italic}.profile-pill-row--logout .profile-pill-row-name{font-family:Cinzel,serif;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:#f19f91}.profile-pill-icn{width:28px;text-align:center;color:var(--home-ivory-mute);font-size:14px}.home-main{display:flex;flex-direction:column;align-items:center;gap:clamp(12px,2.2vh,22px);text-align:center;min-height:0}.home-ornate-wrap{width:min(62vw,420px);max-width:80%}.home-ornate{display:block;width:100%;height:auto}.home-welcome-line{font-family:Cinzel,serif;font-weight:600;letter-spacing:.38em;text-transform:uppercase;font-size:clamp(11px,1.5vh,14px);color:#000;display:inline-flex;align-items:center;gap:12px;padding:2px 4px;margin:0}.home-welcome-line:before,.home-welcome-line:after{content:"";display:block;width:clamp(18px,4vw,38px);height:1px;background:linear-gradient(90deg,transparent,#000,transparent);opacity:.7}.home-welcome-name{font-family:EB Garamond,serif;font-style:italic;font-size:clamp(28px,5vh,44px);color:#000;line-height:1;margin:-20px 0 4px;font-weight:400}.home-welcome-subtitle{font-family:EB Garamond,serif;font-style:italic;font-size:clamp(18px,2.4vh,24px);color:var(--home-ivory-dim);margin:0;text-shadow:0 2px 10px rgba(0,0,0,.55)}.home-error{color:#f19f91;font-family:EB Garamond,serif;font-size:clamp(14px,1.8vh,16px);margin:0;text-shadow:0 1px 4px rgba(0,0,0,.7)}.home-cta-group{display:flex;flex-direction:column;align-items:center;gap:clamp(14px,2.4vh,22px);margin-top:clamp(22px,5vh,42px)}.home-play{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;font-family:Cinzel,serif;font-weight:500;letter-spacing:.15em;font-size:clamp(16px,2.2vh,22px);color:#fff;padding:18px clamp(38px,6vw,64px);background:linear-gradient(180deg,#f4b93c61,#c87a3080);border:1.5px solid var(--home-gold);box-shadow:inset 0 0 28px #0006,0 0 40px #f4b93c59;position:relative;display:inline-flex;align-items:center;gap:14px;text-shadow:0 2px 8px rgba(0,0,0,.55),0 0 14px rgba(255,255,255,.25);transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.home-play:before,.home-play:after{content:"";position:absolute;top:50%;width:16px;height:1px;background:var(--home-gold);transform:translateY(-.5px)}.home-play:before{left:-24px}.home-play:after{right:-24px}.home-play:hover:not(:disabled){transform:scale(1.02);box-shadow:inset 0 0 28px #0006,0 0 60px #f4b93c8c}.home-play:active:not(:disabled){transform:scale(.98)}.home-play:disabled{cursor:progress;opacity:.75}.home-play-glyph{color:var(--home-gold);font-size:.85em}.home-satellites{display:flex;justify-content:center;gap:clamp(20px,6vw,50px)}.home-satellite{font-family:Cinzel,serif;font-weight:400;letter-spacing:.18em;font-size:clamp(12px,1.5vh,15px);color:#fff;text-decoration:none;padding:9px 16px;border:1px solid var(--home-gold-soft);background:#0000004d;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);transition:background .15s,border-color .15s;cursor:pointer}.home-satellite:hover{background:#00000080;border-color:var(--home-gold)}.home-stats{display:flex;justify-content:center;align-items:stretch;gap:clamp(22px,5vw,44px);padding-top:6px}.home-stats-spacer{min-height:1rem}.home-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.home-stat-k{font-family:Cinzel,serif;letter-spacing:.3em;text-transform:uppercase;font-size:10px;color:var(--home-ivory-mute)}.home-stat-v{font-family:Cinzel,serif;font-weight:600;font-size:clamp(18px,2.6vh,26px);color:var(--home-ivory);letter-spacing:.04em;text-shadow:0 1px 6px rgba(0,0,0,.6)}.home-stat-sep{width:1px;background:var(--home-gold-soft);align-self:stretch;opacity:.7}@media(max-width:520px){.home-screen{padding-left:18px;padding-right:18px}.home-crest{font-size:11px;letter-spacing:.36em}.profile-pill{font-size:13px;padding:4px 12px;gap:8px}.home-ornate-wrap{width:72%}.home-welcome-name{font-size:34px}.home-play{padding:15px 34px;font-size:16px;letter-spacing:.26em}.home-play:before,.home-play:after{width:12px}.home-play:before{left:-18px}.home-play:after{right:-18px}.home-satellite{padding:9px 14px;font-size:12px;letter-spacing:.16em}.home-stats{gap:20px}}@media(max-height:620px)and (max-width:900px){.home-main{gap:8px}.home-cta-group{margin-top:14px;gap:12px}.home-play{padding:12px 28px;font-size:15px}}.profile-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;display:flex;align-items:center;justify-content:center;padding:max(env(safe-area-inset-top,0px),20px) 20px max(env(safe-area-inset-bottom,0px),20px);background:#04060a8c;backdrop-filter:blur(18px) saturate(120%);-webkit-backdrop-filter:blur(18px) saturate(120%);overflow-y:auto;animation:profile-modal-fade-in .18s ease-out}@keyframes profile-modal-fade-in{0%{opacity:0}to{opacity:1}}.profile-modal-card{width:min(420px,100%);margin:auto;background:#0a0c10d1;border:1px solid var(--home-gold-soft);box-shadow:0 20px 60px #000000b3,0 0 40px #f4b93c26;padding:clamp(24px,4vh,36px) clamp(20px,3.5vw,32px);color:var(--home-ivory);font-family:EB Garamond,Alegreya,serif;display:flex;flex-direction:column;align-items:center;text-align:center;animation:profile-modal-card-in .24s cubic-bezier(.2,.8,.2,1)}@keyframes profile-modal-card-in{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}.profile-modal-title{font-family:Cinzel,serif;font-weight:600;font-size:clamp(20px,3vh,26px);letter-spacing:.18em;text-transform:uppercase;color:var(--home-ivory);margin:0 0 8px}.profile-modal-subtitle{font-family:EB Garamond,serif;font-style:italic;font-size:16px;color:var(--home-ivory-dim);margin:0 0 4px;line-height:1.3}.profile-modal-form{width:100%;display:flex;flex-direction:column;align-items:stretch;margin-top:18px}.profile-modal-label{font-family:Cinzel,serif;font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--home-ivory-mute);margin-bottom:8px;text-align:left}.profile-modal-input{font-family:EB Garamond,serif;font-size:18px;padding:12px 14px;background:#0006;border:1px solid var(--home-gold-soft);border-radius:4px;color:var(--home-ivory);width:100%;transition:border-color .15s,background .15s}.profile-modal-input::placeholder{color:var(--home-ivory-mute);font-style:italic}.profile-modal-input:focus{outline:none;border-color:var(--home-gold);background:#0000008c}.profile-modal-input:disabled{opacity:.6;cursor:not-allowed}.profile-modal-error{color:#f19f91;font-family:EB Garamond,serif;font-size:15px;margin:12px 0 0;text-align:center}.profile-modal-submit{margin-top:20px;font-family:Cinzel,serif;font-weight:600;letter-spacing:.3em;text-transform:uppercase;font-size:13px;color:var(--home-ivory);padding:12px 22px;border:1px solid var(--home-gold-soft);background:#0006;cursor:pointer;transition:background .15s,border-color .15s,box-shadow .15s}.profile-modal-submit:hover:not(:disabled){background:#0009;border-color:var(--home-gold);box-shadow:0 0 20px #f4b93c40}.profile-modal-submit:disabled{opacity:.45;cursor:not-allowed}.profile-modal-cancel{margin-top:10px;font-family:Cinzel,serif;letter-spacing:.24em;text-transform:uppercase;font-size:11px;color:var(--home-ivory-mute);background:none;border:0;padding:8px;cursor:pointer;transition:color .15s}.profile-modal-cancel:hover{color:var(--home-ivory)}@media(max-width:520px){.profile-modal-card{padding:22px 18px}.profile-modal-title{font-size:18px}}.welcome-screen{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;min-height:100dvh;padding:clamp(48px,10vh,120px) 24px max(env(safe-area-inset-bottom,0px),24px);overscroll-behavior:none;pointer-events:none;color:var(--home-ivory);font-family:EB Garamond,Alegreya,serif}.welcome-screen:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:var(--screen-vignette);pointer-events:none;z-index:-1}@media(max-width:500px){.welcome-screen{padding-top:clamp(64px,14vh,120px)}}.ornate-header{display:flex;flex-direction:column;align-items:center;text-align:center;line-height:1}.ornate-header-image{display:block;width:min(62vw,420px);max-width:80%;height:auto;margin-bottom:clamp(6px,1.2vh,12px)}.welcome-prelude{font-family:Cinzel,serif;font-weight:500;font-size:clamp(11px,1.5vh,14px);letter-spacing:.38em;text-transform:uppercase;color:#000;display:inline-flex;align-items:center;gap:12px;margin:0}.welcome-prelude:before,.welcome-prelude:after{content:"";display:block;width:clamp(18px,4vw,38px);height:1px;background:linear-gradient(90deg,transparent,#000,transparent);opacity:.7}.welcome-title{font-family:Cinzel,serif;font-size:clamp(44px,8vh,72px);font-weight:600;letter-spacing:.1em;color:#000;line-height:1;margin:2px 0 0}.welcome-subtitle{font-family:EB Garamond,serif;font-style:italic;font-size:clamp(22px,3.5vh,34px);font-weight:400;color:#000;line-height:1;margin:-4px 0 0}.ornate-title{font-family:Cinzel,serif;font-size:clamp(20px,3vh,30px);font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:#000;margin:0}.fading-line-button{--fading-line-light-opacity: .8;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);background:none;border:none;cursor:pointer;padding:var(--spacing-sm) var(--spacing-md);margin-top:var(--spacing-2xl);text-decoration:none}.fading-line{width:15.625rem;height:1px;background:linear-gradient(to right,transparent,#1a1a2e 30%,#1a1a2e 70%,transparent);transition:box-shadow .2s ease}.fading-line-text{font-family:var(--font-family-body);font-size:var(--font-size-2xl);font-weight:400;color:#1a1a2e;line-height:1;transition:text-shadow .2s ease}.fading-line-button:hover .fading-line{box-shadow:0 0 8px #1a1a2e80}.fading-line-button:hover .fading-line-text{text-shadow:0 0 8px rgba(26,26,46,.4)}.fading-line-button--light .fading-line{background:linear-gradient(to right,transparent,rgba(255,255,255,var(--fading-line-light-opacity)) 30%,rgba(255,255,255,var(--fading-line-light-opacity)) 70%,transparent)}.fading-line-button--light .fading-line-text{color:rgba(255,255,255,var(--fading-line-light-opacity))}.fading-line-button--light:hover .fading-line{box-shadow:0 0 8px rgba(255,255,255,calc(var(--fading-line-light-opacity) - .3))}.fading-line-button--light:hover .fading-line-text{text-shadow:0 0 8px rgba(255,255,255,calc(var(--fading-line-light-opacity) - .4))}.fading-line-button--disabled{opacity:.5;cursor:not-allowed}.fading-line-button--disabled:hover .fading-line{box-shadow:none}.fading-line-button--disabled:hover .fading-line-text{text-shadow:none}.ornate-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-family:Cinzel,serif;text-decoration:none;position:relative;transition:transform .2s ease,box-shadow .2s ease,background .2s ease,border-color .15s}.ornate-btn--hero{font-weight:500;letter-spacing:.15em;font-size:clamp(16px,2.2vh,22px);color:#fff;padding:18px clamp(38px,6vw,64px);background:linear-gradient(180deg,#f4b93c61,#c87a3080);border:1.5px solid var(--home-gold);box-shadow:inset 0 0 28px #0006,0 0 40px #f4b93c59;text-shadow:0 2px 8px rgba(0,0,0,.55),0 0 14px rgba(255,255,255,.25)}.ornate-btn--hero:before,.ornate-btn--hero:after{content:"";position:absolute;top:50%;width:16px;height:1px;background:var(--home-gold);transform:translateY(-.5px)}.ornate-btn--hero:before{left:-24px}.ornate-btn--hero:after{right:-24px}.ornate-btn--hero:hover:not(:disabled){transform:scale(1.02);box-shadow:inset 0 0 28px #0006,0 0 60px #f4b93c8c}.ornate-btn--hero:active:not(:disabled){transform:scale(.98)}.ornate-btn--secondary{font-weight:500;letter-spacing:.22em;text-transform:uppercase;font-size:13px;color:var(--home-ivory);padding:12px 22px;min-width:15rem;background:#0006;border:1px solid var(--home-gold-soft)}.ornate-btn--secondary:hover:not(:disabled){background:#0009;border-color:var(--home-gold);box-shadow:0 0 20px #f4b93c40}.ornate-btn:disabled{cursor:not-allowed;opacity:.45}.ornate-btn--hero:disabled{opacity:.6;transform:none}@media(max-width:520px){.ornate-btn--hero{padding:15px 34px;font-size:16px;letter-spacing:.2em}.ornate-btn--hero:before,.ornate-btn--hero:after{width:12px}.ornate-btn--hero:before{left:-18px}.ornate-btn--hero:after{right:-18px}}.welcome-cta{display:flex;justify-content:center;margin-top:clamp(28px,6vh,56px)}.invite-gate{display:flex;flex-direction:column;align-items:center;margin-top:clamp(24px,5vh,48px);gap:16px}.invite-beta-message{font-family:Cinzel,serif;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--home-ivory-mute);margin:0;text-align:center}.invite-form{display:flex;flex-direction:column;align-items:center;gap:14px}.invite-input{font-family:EB Garamond,serif;font-size:18px;text-align:center;padding:12px 14px;border:1px solid var(--home-gold-soft);border-radius:4px;background:#0006;color:var(--home-ivory);width:15rem;transition:border-color .15s,background .15s}.invite-input::placeholder{color:var(--home-ivory-mute);font-style:italic}.invite-input:focus{outline:none;border-color:var(--home-gold);background:#0000008c}.invite-error{color:#f19f91;font-family:EB Garamond,serif;font-size:15px;margin:0;text-align:center}.auth-landing-card{display:flex;flex-direction:column;align-items:center;gap:14px;margin-top:clamp(24px,5vh,48px)}.guest-link{background:none;border:none;font-family:Cinzel,serif;letter-spacing:.24em;text-transform:uppercase;font-size:11px;color:var(--home-ivory-mute);cursor:pointer;padding:8px;margin-top:4px;transition:color .15s,text-shadow .15s}.guest-link:hover:not(:disabled){color:var(--home-ivory);text-shadow:0 0 8px var(--home-gold-soft)}.guest-link:disabled{cursor:not-allowed;opacity:.5}.guest-link--light{color:var(--home-ivory-mute)}.guest-link--light:hover:not(:disabled){color:var(--home-ivory)}.auth-prompt{font-family:EB Garamond,serif;font-style:italic;font-size:clamp(15px,2vh,18px);color:var(--home-ivory-dim);margin:0 0 4px;text-align:center}.back-link{background:none;border:none;font-family:Cinzel,serif;letter-spacing:.24em;text-transform:uppercase;font-size:11px;color:var(--home-ivory-mute);cursor:pointer;padding:8px;margin-top:10px;transition:color .15s,text-shadow .15s}.back-link:hover:not(:disabled){color:var(--home-ivory)}.back-link:disabled{cursor:not-allowed;opacity:.5}.back-link--light{color:var(--home-ivory-mute)}.back-link--light:hover:not(:disabled){color:var(--home-ivory)}.auth-card-dark{width:min(420px,100%);margin-top:clamp(20px,4vh,36px);padding:clamp(24px,4vh,36px) clamp(20px,3.5vw,32px);background:#0a0c10d1;border:1px solid var(--home-gold-soft);border-radius:4px;box-shadow:0 20px 60px #000000b3,0 0 40px #f4b93c26;color:var(--home-ivory);font-family:EB Garamond,Alegreya,serif;display:flex;flex-direction:column;align-items:center;text-align:center}.auth-card-dark .ornate-title{font-family:Cinzel,serif;font-weight:600;letter-spacing:.18em;text-transform:uppercase;font-size:clamp(18px,2.5vh,24px);color:var(--home-ivory);text-shadow:none;margin:0 0 8px}.auth-card-dark .auth-subtitle-dark{font-family:EB Garamond,serif;font-style:italic;font-size:16px;color:var(--home-ivory-dim);margin:0 0 18px;line-height:1.4}.auth-card-dark .auth-subtitle-dark strong{font-style:normal;color:var(--home-ivory)}.auth-card-dark .auth-prompt{margin-bottom:14px}.auth-card-dark form{width:100%;display:flex;flex-direction:column;align-items:stretch}.auth-card-dark .form-group{margin-bottom:14px;width:100%;display:flex;flex-direction:column}.auth-card-dark .form-label-dark{display:block;font-family:Cinzel,serif;font-size:10px;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:var(--home-ivory-mute);margin-bottom:8px;text-align:left}.auth-card-dark .input-dark{width:100%;padding:12px 14px;font-family:EB Garamond,serif;font-size:18px;background:#0006;border:1px solid var(--home-gold-soft);border-radius:4px;color:var(--home-ivory);transition:border-color .15s,background .15s}.auth-card-dark .input-dark::placeholder{color:var(--home-ivory-mute);font-style:italic}.auth-card-dark .input-dark:focus{outline:none;border-color:var(--home-gold);background:#0000008c}.auth-card-dark .input-dark:disabled{opacity:.6;cursor:not-allowed}.auth-card-dark .checkbox-label-dark{display:flex;align-items:flex-start;gap:10px;font-family:EB Garamond,serif;font-size:15px;color:var(--home-ivory-dim);cursor:pointer;text-align:left;line-height:1.35}.auth-card-dark .checkbox-label-dark input[type=checkbox]{margin-top:3px;cursor:pointer;accent-color:var(--home-gold)}.auth-card-dark .checkbox-label-dark a{color:var(--home-gold);text-decoration:underline;text-underline-offset:2px}.auth-card-dark .checkbox-label-dark a:hover{color:var(--home-ivory)}.auth-card-dark .ornate-btn{margin-top:14px;align-self:center}.auth-card-dark .form-error{color:#f19f91;font-family:EB Garamond,serif;font-size:15px;margin:6px 0 0;text-align:center}.auth-card-dark .back-link,.auth-card-dark .back-link--light{color:var(--home-ivory-mute);margin-top:12px}.auth-card-dark .back-link:hover:not(:disabled),.auth-card-dark .back-link--light:hover:not(:disabled){color:var(--home-ivory)}.otp-input-group-dark{display:flex;gap:8px;justify-content:center;margin-bottom:18px}.otp-input-dark{width:2.75rem;height:3.25rem;text-align:center;font-family:Cinzel,serif;font-size:22px;font-weight:600;background:#0006;border:1px solid var(--home-gold-soft);border-radius:4px;color:var(--home-ivory);transition:border-color .15s,background .15s}.otp-input-dark:focus{outline:none;border-color:var(--home-gold);background:#0000008c}.otp-input-dark:disabled{opacity:.6}.learning-card{background:#ffffff1a;border-radius:var(--radius-lg);padding:var(--spacing-xl);max-width:400px;align-self:center;display:flex;flex-direction:column;align-items:center;text-align:center}.learning-card .fading-line-button{margin-top:var(--spacing-lg)}.learning-card-title{font-family:var(--font-family-body);font-size:var(--font-size-2xl);font-weight:400;color:#fffc;margin:0 0 var(--spacing-md) 0}.learning-card-message{font-family:var(--font-family-body);font-size:var(--font-size-base);color:#fffc;line-height:1.5;margin:0}.difficulty-check-buttons{display:flex;flex-direction:column;gap:var(--spacing-md);margin-top:var(--spacing-lg);width:100%}.confusable-reference-panel{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;background:#000000bf;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-md);pointer-events:auto}.confusable-reference-actions{display:flex;justify-content:center;flex-shrink:0}.confusable-reference-actions .arrow-button{width:8rem}.global-keyboard-input{position:fixed;top:-100px;left:0;opacity:0;width:1px;height:1px;border:none;padding:0;margin:0;caret-color:transparent;color:transparent}html:has(.learning-viewport),body:has(.learning-viewport){overflow:hidden;position:fixed;width:100%;height:100%;background:#000}html:has(.welcome-screen),body:has(.welcome-screen){overflow:hidden;position:fixed;width:100%;height:100%}.background-wrapper{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;display:flex;justify-content:center;align-items:center;z-index:0}.background-media{position:relative;width:100vw;height:100dvh;max-width:calc(100dvh * 20 / 9);max-height:calc(100vw * 20 / 9)}.background-media>*{position:absolute;top:0;right:0;bottom:0;left:0}.background-image{width:100%;height:100%;object-fit:cover;object-position:center}.background-fading{animation:fade-to-black 1s ease-out forwards}.background-fading-fast{animation:fade-to-black .25s ease-out forwards}@keyframes fade-to-black{0%{opacity:1}to{opacity:0}}.app-overlay{position:relative;z-index:1;min-height:100dvh;pointer-events:none}button,a,input,select,textarea,[role=button]{pointer-events:auto}.toolbar-icons{--toolbar-nudge: 1.6rem;position:fixed;top:var(--toolbar-nudge);right:min(var(--toolbar-nudge),5vw);z-index:200;display:flex;flex-direction:column;align-items:flex-end;gap:var(--spacing-xs);pointer-events:auto}@media(max-width:500px){.toolbar-icons{top:var(--spacing-sm);right:var(--spacing-sm);left:var(--spacing-sm);flex-direction:row;justify-content:flex-end;gap:var(--spacing-xs)}}.toolbar-button{display:flex;align-items:center;gap:.35rem;background:#00000073;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-md);cursor:pointer;padding:.35rem .65rem;color:#ffffffe6;font-size:var(--font-size-xs);white-space:nowrap;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:background .2s ease,border-color .2s ease}.toolbar-button:hover{background:#0009;border-color:#ffffff59}.settings-anchor{position:relative}.settings-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:199;pointer-events:auto}.settings-menu{position:absolute;top:100%;right:0;margin-top:var(--spacing-xs);z-index:200;background:#000000d9;border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-md);padding:var(--spacing-xs) 0;min-width:180px;pointer-events:auto;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.settings-menu-section-label{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-xs);color:#ffffff80;text-transform:uppercase;letter-spacing:.05em}.settings-menu-item{display:block;width:100%;padding:var(--spacing-sm) var(--spacing-md);background:none;border:none;color:#ffffffe6;font-size:var(--font-size-sm);text-align:left;cursor:pointer;transition:background .15s ease}.settings-menu-item:hover{background:#ffffff1a}.settings-menu-item-active{cursor:default}.settings-menu-check{display:inline-block;width:1.2em;text-align:center;margin-right:var(--spacing-xs);font-size:var(--font-size-sm)}.settings-menu-divider{height:1px;background:#ffffff1f;margin:var(--spacing-xs) 0}html:has(.dashboard-page){background-color:#f4f6fb;scrollbar-gutter:stable}html:has(.dashboard-page) body{background-color:#f4f6fb}.dashboard-page{min-height:100dvh;width:100%;max-width:60rem;margin:0 auto;background:#f4f6fb;color:var(--color-text);padding:var(--spacing-lg) var(--spacing-md) var(--spacing-2xl);font-family:var(--font-family);pointer-events:auto}.main-content:has(.dashboard-page){padding-inline:0}.dashboard-top-bar{display:flex;align-items:center;margin-bottom:var(--spacing-md)}.dashboard-back-button{display:flex;align-items:center;gap:.35rem;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;padding:.4rem .75rem;color:var(--color-text-muted);font-size:var(--font-size-xs);box-shadow:var(--shadow-sm);transition:background .15s ease,color .15s ease,box-shadow .15s ease}.dashboard-back-button:hover{background:#fff;color:var(--color-text);box-shadow:var(--shadow-md)}.dashboard-hero{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.dashboard-avatar{width:3.5rem;height:3.5rem;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl);font-weight:700;box-shadow:0 2px 8px #6366f14d;flex-shrink:0}.dashboard-heading{font-family:var(--font-family);font-size:var(--font-size-3xl);font-weight:700;margin:0;text-align:center;letter-spacing:-.02em}.dashboard-name-picker{position:relative;display:inline-block}.dashboard-name-button{display:inline-flex;align-items:center;gap:.25rem;background:none;border:none;border-bottom:1px dashed var(--color-text-muted);cursor:pointer;font-family:inherit;font-size:inherit;font-weight:inherit;color:inherit;padding:0}.dashboard-name-button:hover{border-bottom-color:var(--color-text)}.dashboard-name-dropdown{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:var(--spacing-xs);background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--spacing-xs) 0;min-width:10rem;z-index:10}.dashboard-name-option{display:block;width:100%;padding:var(--spacing-sm) var(--spacing-md);background:none;border:none;color:var(--color-text);font-size:var(--font-size-sm);text-align:left;cursor:pointer}.dashboard-name-option:hover{background:var(--color-surface)}.dashboard-name-option-active{font-weight:600;cursor:default}.dashboard-tabs{display:flex;gap:var(--spacing-xs);background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:4px;margin-bottom:var(--spacing-lg);box-shadow:var(--shadow-sm);width:fit-content;margin-left:auto;margin-right:auto}.dashboard-tab{padding:var(--spacing-sm) var(--spacing-lg);background:none;border:none;border-radius:var(--radius-md);color:var(--color-text-muted);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:background .15s ease,color .15s ease,box-shadow .15s ease}.dashboard-tab:hover{color:var(--color-text)}.dashboard-tab-active{color:#fff;background:var(--color-primary);box-shadow:0 1px 3px #4f46e54d}.dashboard-tab-active:hover{color:#fff}.dashboard-content{min-height:20rem}.dashboard-placeholder{color:var(--color-text-muted);font-size:var(--font-size-sm);text-align:center;margin-top:var(--spacing-xl)}.dashboard-highlight-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}@media(max-width:500px){.dashboard-highlight-stats{grid-template-columns:repeat(2,1fr)}}.dashboard-stat-card{text-align:center;padding:var(--spacing-md) var(--spacing-sm);background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:var(--radius-lg);box-shadow:0 1px 3px #0000000a,0 4px 12px #00000008;transition:box-shadow .2s ease,transform .2s ease}.dashboard-stat-card:hover{box-shadow:0 2px 8px #0000000f,0 8px 24px #0000000a;transform:translateY(-1px)}.dashboard-stat-card-clickable{cursor:pointer}.dashboard-stat-card-clickable:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.dashboard-stat-value{font-size:var(--font-size-2xl);font-weight:700}.dashboard-stat-label{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:.25rem;font-weight:500}.dashboard-stat-indigo .dashboard-stat-value{color:#4f46e5}.dashboard-stat-amber .dashboard-stat-value{color:#d97706}.dashboard-stat-violet .dashboard-stat-value{color:#7c3aed}.dashboard-stat-teal .dashboard-stat-value{color:#0d9488}.dashboard-stat-emerald .dashboard-stat-value{color:#059669}.dashboard-stat-sky .dashboard-stat-value{color:#0284c7}.dashboard-wordlist-tabs{display:flex;gap:var(--spacing-xs);background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:4px;margin:0 auto var(--spacing-lg);box-shadow:var(--shadow-sm);width:fit-content}@media(max-width:640px){.dashboard-wordlist-tabs{width:100%}.dashboard-wordlist-tab{flex:1;min-width:0;text-align:center;padding:var(--spacing-sm) var(--spacing-xs)}}.dashboard-wordlist-tab{padding:var(--spacing-sm) var(--spacing-md);background:none;border:none;border-radius:var(--radius-md);color:var(--color-text-muted);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:background .15s ease,color .15s ease}.dashboard-tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.25rem;height:1.25rem;padding:0 .35rem;border-radius:var(--radius-full);background:#00000014;font-size:.7rem;font-weight:700;line-height:1;margin-left:.35rem}.dashboard-wordlist-tab-active .dashboard-tab-badge{background:#ffffff40}.dashboard-wordlist-tab:hover{color:var(--color-text);background:var(--color-surface)}.dashboard-wordlist-tab-active{color:#fff;background:var(--color-primary);box-shadow:0 1px 3px #4f46e54d}.dashboard-wordlist-tab-active:hover{color:#fff;background:var(--color-primary-hover)}.dashboard-wordlist-desc{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0 0 var(--spacing-md);line-height:1.5}.dashboard-word-list{display:flex;flex-direction:column;background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:var(--radius-lg);box-shadow:0 1px 3px #0000000a,0 4px 12px #00000008}.dashboard-word-row{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid #f0f1f5}.dashboard-word-row:last-child{border-bottom:none;border-radius:0 0 var(--radius-lg) var(--radius-lg)}.dashboard-word-row:not(.dashboard-word-header):nth-child(odd){background:#fafbfd}.dashboard-word-header{background:var(--color-surface);border-bottom:1px solid var(--color-border);color:var(--color-text-muted);font-size:var(--font-size-sm);font-weight:600;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.dashboard-word-header .dashboard-word-text{font-size:inherit;font-weight:inherit}.dashboard-word-text{font-size:var(--font-size-base);font-weight:500;min-width:7rem}.dashboard-attempt-log{display:flex;align-items:center;gap:3px;flex-wrap:wrap}.dashboard-attempt-dot{position:relative;display:inline-block;width:10px;height:10px;border-radius:50%;cursor:default;flex-shrink:0;padding:8px;background-clip:content-box;-webkit-tap-highlight-color:transparent;transition:transform .1s ease}.dashboard-attempt-dot:after{content:attr(data-tip);position:absolute;bottom:calc(100% + 4px);left:50%;transform:translate(-50%);white-space:nowrap;font-size:13px;color:#fff;background:#000000e6;padding:6px 12px;border-radius:var(--radius-md);pointer-events:none;opacity:0;z-index:10}.dashboard-attempt-dot:hover:after,.dashboard-attempt-dot.dashboard-attempt-dot-active:after{opacity:1}.dashboard-attempt-dot:hover,.dashboard-attempt-dot.dashboard-attempt-dot-active{transform:scale(1.6);z-index:11}.dashboard-attempt-dot:hover:after,.dashboard-attempt-dot.dashboard-attempt-dot-active:after{transform:translate(-50%) scale(.625)}.dashboard-attempt-ok{background:var(--color-success)}.dashboard-attempt-fail{background:var(--color-error)}.dashboard-section-title{font-size:var(--font-size-lg);font-weight:700;margin:0;color:var(--color-text);letter-spacing:-.01em}.dashboard-chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.dashboard-chart-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}@media(max-width:640px){.dashboard-chart-grid{grid-template-columns:1fr}}.dashboard-chart-card{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:0 1px 3px #0000000a,0 4px 12px #00000008}@keyframes dashboard-chart-card-flash{0%,to{box-shadow:0 1px 3px #0000000a,0 4px 12px #00000008;border-color:#0000000f}50%{box-shadow:0 0 0 3px var(--color-primary),0 4px 18px #4f46e540;border-color:var(--color-primary)}}.dashboard-chart-card-flash{animation:dashboard-chart-card-flash .5s ease-in-out 2}.dashboard-search-input-wrap{position:relative;margin-bottom:var(--spacing-md)}.dashboard-search-spinner{display:block;position:absolute;right:var(--spacing-md);top:50%;margin-top:-8px;width:16px;height:16px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .6s linear infinite;pointer-events:none}.dashboard-search-clear{position:absolute;right:var(--spacing-sm);top:50%;margin-top:-12px;display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:none;border:none;cursor:pointer;color:var(--color-text-muted);border-radius:50%;transition:background .15s ease,color .15s ease;padding:0}.dashboard-search-clear:hover{background:var(--color-border);color:var(--color-text)}.dashboard-search-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:var(--font-size-base);background:#fff;color:var(--color-text);outline:none;transition:border-color .15s ease,box-shadow .15s ease}.dashboard-search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #4f46e51a}.dashboard-search-results{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:var(--radius-lg);box-shadow:0 1px 3px #0000000a,0 4px 12px #00000008;overflow:hidden}.dashboard-search-result{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid #f0f1f5}.dashboard-search-result:last-child{border-bottom:none}.dashboard-search-result-text{font-size:var(--font-size-base);font-weight:500}.dashboard-search-add-button{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:600;cursor:pointer;transition:background .15s ease;flex-shrink:0}.dashboard-search-add-button:hover:not(:disabled){background:var(--color-primary-hover)}.dashboard-search-add-button:disabled{background:var(--color-border);color:var(--color-text-muted);cursor:default}.dashboard-queued-time{font-size:var(--font-size-xs);color:var(--color-text-muted)}.dashboard-chart-title-row{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:var(--spacing-sm)}.dashboard-chart-title{font-size:var(--font-size-sm);font-weight:600;margin:0;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.dashboard-chart-avg{font-size:var(--font-size-xs);color:var(--color-text-muted);font-weight:500;white-space:nowrap}.dashboard-range-toggle{display:flex;gap:2px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:2px}.dashboard-range-button{padding:.25rem .75rem;background:none;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-xs);color:var(--color-text-muted);cursor:pointer;transition:background .15s ease,color .15s ease}.dashboard-range-button-active{background:var(--color-primary);color:#fff;font-weight:600}.dashboard-info-tip{position:relative;display:inline-flex;vertical-align:middle;margin-left:4px;top:-1px}.dashboard-info-button{display:inline-flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;padding:2px;color:var(--color-text-muted);opacity:.5;transition:opacity .15s ease;-webkit-tap-highlight-color:transparent}.dashboard-info-button:hover{opacity:1}.dashboard-info-popup{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);width:220px;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-text);color:#fff;font-size:var(--font-size-sm);font-weight:400;line-height:1.45;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:20;text-align:left;white-space:normal;text-transform:none;letter-spacing:normal}.main-content{padding-inline:var(--spacing-xl);min-height:100dvh;display:flex;justify-content:center;align-items:flex-start;pointer-events:none}.auth-container{width:100%;max-width:480px;margin-top:var(--spacing-2xl)}.auth-card{background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-md)}.auth-title{font-size:var(--font-size-2xl);font-weight:600;text-align:center;margin-bottom:var(--spacing-lg)}.auth-subtitle{color:var(--color-text-muted);text-align:center;margin-bottom:var(--spacing-lg)}.form-group{margin-bottom:var(--spacing-md)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:500;margin-bottom:var(--spacing-xs)}.form-error{color:var(--color-error);font-size:var(--font-size-sm);margin-top:var(--spacing-xs)}.checkbox-label{display:flex;align-items:flex-start;gap:var(--spacing-sm);font-size:var(--font-size-sm);cursor:pointer}.checkbox-label input[type=checkbox]{margin-top:2px;cursor:pointer}.checkbox-label a{color:var(--color-primary)}.checkbox-label a:hover{text-decoration:underline}.btn-full{width:100%}.auth-divider{display:flex;align-items:center;margin:var(--spacing-lg) 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;border-bottom:1px solid var(--color-border)}.auth-divider span{padding:0 var(--spacing-md);color:var(--color-text-muted);font-size:var(--font-size-sm)}.auth-options{display:flex;flex-direction:column;gap:var(--spacing-sm)}.auth-link{text-align:center;margin-top:var(--spacing-md)}.auth-link a,.auth-link button{color:var(--color-primary);text-decoration:none;background:none;border:none;cursor:pointer;font-size:inherit}.auth-link a:hover,.auth-link button:hover{text-decoration:underline}.role-select{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.role-option{flex:1;padding:var(--spacing-md);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;text-align:center;transition:border-color .15s ease}.role-option:hover{border-color:var(--color-primary)}.role-option.selected{border-color:var(--color-primary);background-color:#4f46e50d}.role-option-title{font-weight:500;margin-bottom:var(--spacing-xs)}.role-option-desc{font-size:var(--font-size-sm);color:var(--color-text-muted)}.otp-input-group{display:flex;gap:var(--spacing-sm);justify-content:center;margin-bottom:var(--spacing-lg)}.otp-input{width:3rem;height:3.5rem;text-align:center;font-size:var(--font-size-2xl);font-weight:600;border:1px solid var(--color-border);border-radius:var(--radius-md)}.otp-input:focus{outline:2px solid var(--color-primary);outline-offset:-1px;border-color:var(--color-primary)}.dashboard{width:100%;max-width:800px}.dashboard-card{background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl)}.dashboard-title{font-size:var(--font-size-xl);font-weight:600;margin-bottom:var(--spacing-md)}.dashboard-subtitle{color:var(--color-text-muted);margin-bottom:var(--spacing-lg)}.loading-container{display:flex;justify-content:center;align-items:center;min-height:200px}.loading-spinner{width:2.5rem;height:2.5rem;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.speaker-icon .speaker-icon-wave{transform-box:fill-box;transform-origin:center}.speaker-icon--speaking .speaker-icon-wave--inner{animation:speaker-wave-pulse 1.1s ease-in-out infinite}.speaker-icon--speaking .speaker-icon-wave--outer{animation:speaker-wave-pulse 1.1s ease-in-out infinite;animation-delay:.25s}@keyframes speaker-wave-pulse{0%,to{opacity:1}50%{opacity:.15}}@media(prefers-reduced-motion:reduce){.speaker-icon--speaking .speaker-icon-wave--inner,.speaker-icon--speaking .speaker-icon-wave--outer{animation:none}}.intro-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10;display:flex;justify-content:center;align-items:flex-end;padding:var(--spacing-xl);padding-bottom:3rem}.intro-skip-stack{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);color:#ffffffd9;filter:drop-shadow(0 1px 2px rgba(0,0,0,.6))}.intro-skip-stack .fading-line-button{margin-top:0}.learning-viewport{position:fixed;top:0;left:0;right:0;height:var(--visual-viewport-height, 100vh);z-index:10;background:#000;display:flex;flex-direction:column;align-items:center;padding:var(--spacing-md);overflow:hidden;touch-action:none;overscroll-behavior:none}.learning-particles{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none}.learning-viewport-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;width:100%;flex:1;min-height:0}.learning-header{--learning-chrome: rgba(255, 255, 255, .72);display:flex;flex-direction:column;gap:var(--spacing-xs);width:100%;max-width:600px;padding:var(--spacing-sm) 0;flex-shrink:0}.learning-header-row{display:flex;align-items:center;gap:var(--spacing-md);width:100%}.learning-header-row--top{justify-content:space-between}.learning-header-back{background:none;border:none;color:var(--color-text-muted);font-size:var(--font-size-xl);cursor:pointer;padding:var(--spacing-sm);margin:calc(-1 * var(--spacing-sm));border-radius:var(--radius-md);transition:color .15s,background-color .15s;flex-shrink:0}.learning-header-back:hover{color:var(--color-text);background-color:#ffffff1a}.learning-header-goal-anchor{position:relative;display:flex;flex:0 1 auto;width:72%;max-width:420px;min-width:160px;margin:0 auto}.learning-header-goal{position:relative;display:flex;align-items:center;flex:1 1 auto;width:100%;padding:0 28px 0 0;background:none;border:none;cursor:pointer;color:inherit;font:inherit}.learning-header-goal-spacer{flex:1}.learning-header-goal-track{flex:1;height:12px;background:#8b5cf626;border:1px solid rgba(139,92,246,.55);border-radius:6px;overflow:hidden}.learning-header-goal-fill{height:100%;background:linear-gradient(90deg,#7c3aed,#a855f7);box-shadow:0 0 6px #a855f780;transition:width .5s ease}.learning-header-goal-badge{position:absolute;right:4px;top:50%;transform:translateY(-50%);width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;color:#7c3aed;transition:color .4s ease,filter .4s ease;z-index:1}.learning-header-goal-badge--full{color:#a855f7;filter:drop-shadow(0 0 8px rgba(168,85,247,.85)) drop-shadow(0 0 14px rgba(168,85,247,.45));animation:goal-badge-pop .62s ease-out}@keyframes goal-badge-pop{0%{transform:translateY(-50%) scale(1)}40%{transform:translateY(-50%) scale(1.3)}to{transform:translateY(-50%) scale(1)}}.learning-header-goal-icon{width:32px;height:32px}.learning-header-name{color:var(--color-text-muted);font-size:var(--font-size-sm);flex-shrink:0}.learning-header-row--sub{justify-content:space-between}.learning-header-magic-anchor{position:relative;display:inline-flex}.learning-header-magic{display:inline-flex;align-items:center;gap:0;color:#fff;font-size:var(--font-size-lg);font-weight:700;min-width:56px;text-shadow:0 1px 2px rgba(0,0,0,.45);background:none;border:none;padding:0;cursor:pointer;font-family:inherit}.learning-header-magic-icon{width:32px;height:32px;color:var(--learning-chrome);filter:drop-shadow(0 0 4px rgba(255,255,255,.35))}.learning-header-magic-count{font-variant-numeric:tabular-nums;color:#fff}.learning-header-slots{display:flex;align-items:center;gap:var(--spacing-md);flex:1;justify-content:center;min-height:64px}.learning-header-slot-anchor{position:relative;display:inline-flex}.learning-header-collection{background:none;border:none;color:var(--learning-chrome);cursor:pointer;padding:var(--spacing-sm);border-radius:var(--radius-md);transition:color .15s,background-color .15s,filter .15s;display:inline-flex;align-items:center;justify-content:center;min-width:40px}.learning-header-collection svg{width:32px;height:32px;filter:drop-shadow(0 0 4px rgba(255,255,255,.35))}.learning-header-collection:hover{color:#fff;background-color:#ffffff1a}.learning-container{width:100%;max-width:600px;flex:1;display:flex;flex-direction:column;justify-content:center;min-height:0}.purchase-slot{position:relative;width:64px;height:64px;border:none;border-radius:50%;background:#ffffff0d;padding:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:transform .2s ease,box-shadow .2s ease,filter .2s ease}.purchase-slot:disabled{cursor:default;opacity:.6}.purchase-slot-media{position:absolute;top:6px;right:6px;bottom:6px;left:6px;border-radius:50%;overflow:hidden;display:inline-flex;align-items:center;justify-content:center}.purchase-slot-media video,.purchase-slot-media img{width:100%;height:100%;object-fit:cover}.purchase-slot:not(.purchase-slot--ready) .purchase-slot-media{filter:grayscale(1) brightness(.75)}.purchase-slot-ring{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;transform:rotate(-90deg);pointer-events:none}.purchase-slot-ring-track{fill:none;stroke:#ffffff26;stroke-width:3}.purchase-slot-ring-fill{fill:none;stroke:var(--learning-chrome);stroke-width:3;stroke-linecap:round;transition:stroke-dashoffset .6s ease,stroke .3s ease}.purchase-slot--ready{animation:purchase-slot-pulse 2.2s ease-in-out infinite}.purchase-slot--ready:hover{transform:scale(1.05)}.purchase-slot--busy{opacity:.6;pointer-events:none}@keyframes purchase-slot-pulse{0%,to{box-shadow:0 0 #ffffff73,0 0 12px #ffffff4d}50%{box-shadow:0 0 0 8px #fff0,0 0 22px #ffffff80}}.purchase-slot-hand{position:absolute;left:50%;top:100%;width:32px;height:32px;margin-top:4px;color:#fff;pointer-events:none;filter:drop-shadow(0 0 6px rgba(0,0,0,.55)) drop-shadow(0 0 10px rgba(255,255,255,.35));animation:purchase-slot-hand-bob 1.2s ease-in-out infinite}.purchase-slot-hand svg{width:100%;height:100%;stroke-width:2.25}@keyframes purchase-slot-hand-bob{0%,to{transform:translate(-50%)}50%{transform:translate(-50%,8px)}}.overlay-shell{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;display:flex;align-items:center;justify-content:center;padding:var(--spacing-md)}.overlay-shell-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:background-color .6s ease}.purchase-pre-reveal .overlay-shell-backdrop{background:#000000f2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.collectible-reveal .overlay-shell-content{animation:collectible-reveal-fade-in .5s ease-out both}@keyframes collectible-reveal-fade-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.overlay-shell-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-lg);width:100%;max-width:600px;max-height:100%;min-height:0}.daily-goal-hit-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--spacing-xl);max-width:480px}.daily-goal-hit-title{font-size:var(--font-size-xl);font-weight:700;color:#fff;margin:0 0 var(--spacing-md) 0;text-shadow:0 2px 8px rgba(168,85,247,.35)}.daily-goal-hit-message{color:#ffffffd9;font-size:var(--font-size-md);margin:0 0 var(--spacing-xl) 0;line-height:1.5}.daily-goal-hit-buttons{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);width:100%}.explainer-popover{position:absolute;top:calc(100% + 10px);z-index:40;width:max-content;max-width:min(280px,80vw);padding:var(--spacing-md) var(--spacing-lg) var(--spacing-md) var(--spacing-md);background:#100a20f5;border:1px solid rgba(168,85,247,.55);border-radius:var(--radius-md);box-shadow:0 8px 24px #00000080;animation:explainer-popover-fade-in .18s ease-out both}.explainer-popover:before{content:"";position:absolute;bottom:100%;width:12px;height:12px;background:#100a20f5;border-left:1px solid rgba(168,85,247,.55);border-top:1px solid rgba(168,85,247,.55);transform:translateY(50%) rotate(45deg)}.explainer-popover--magic{left:0}.explainer-popover--magic:before{left:14px}.explainer-popover--goal,.explainer-popover--egg,.explainer-popover--rune{left:50%;transform:translate(-50%)}.explainer-popover--goal:before,.explainer-popover--egg:before,.explainer-popover--rune:before{left:50%;margin-left:-6px}.explainer-popover-message{color:#fff;font-size:var(--font-size-sm);line-height:1.45;margin:0;padding-right:var(--spacing-md)}.explainer-popover-close{position:absolute;top:4px;right:4px;width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;background:none;border:none;color:#ffffffb3;font-size:18px;line-height:1;cursor:pointer;border-radius:var(--radius-sm);transition:color .15s,background-color .15s}.explainer-popover-close:hover{color:#fff;background-color:#ffffff1f}@keyframes explainer-popover-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.explainer-popover--goal,.explainer-popover--egg,.explainer-popover--rune{animation:explainer-popover-centered-fade-in .18s ease-out both}@keyframes explainer-popover-centered-fade-in{0%{opacity:0;transform:translate(-50%,-4px)}to{opacity:1;transform:translate(-50%)}}.dance-break{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200;background:#000;display:flex;flex-direction:column;overflow:hidden}.dance-break-title{flex-shrink:0;margin:0;padding:var(--spacing-lg) var(--spacing-md) var(--spacing-md);text-align:center;font-family:Cinzel,serif;font-size:clamp(1.4rem,4vw,2.2rem);letter-spacing:.04em;color:#fff;text-shadow:0 0 12px rgba(168,85,247,.5);z-index:2}.dance-break-stage{flex:1;min-height:0;display:flex;flex-wrap:wrap;align-items:center;justify-content:center;padding:var(--spacing-sm)}.dance-break-empty{color:#fff9;font-size:var(--font-size-md);text-align:center;padding:var(--spacing-lg);max-width:20rem}.dance-break-creature{flex:0 0 auto;width:clamp(96px,16vmin,180px);aspect-ratio:1 / 1;display:flex;align-items:center;justify-content:center;animation-iteration-count:infinite;animation-timing-function:ease-in-out;will-change:transform}.dance-break-video{width:100%;height:100%;object-fit:contain;display:block}.dance-break-creature--a,.dance-break-creature--b,.dance-break-creature--e,.dance-break-creature--f{animation-direction:alternate}.dance-break-creature--a{animation-name:dance-sway}.dance-break-creature--b{animation-name:dance-bob}.dance-break-creature--e{animation-name:dance-diag-ne}.dance-break-creature--f{animation-name:dance-diag-nw}.dance-break-creature--c{animation-name:dance-orbit-cw}.dance-break-creature--d{animation-name:dance-orbit-ccw}@keyframes dance-sway{0%{transform:translate(-12%) rotate(-8deg) scale(.96)}to{transform:translate(12%) rotate(8deg) scale(1.06)}}@keyframes dance-bob{0%{transform:translateY(10%) rotate(4deg) scale(1.06)}to{transform:translateY(-10%) rotate(-4deg) scale(.94)}}@keyframes dance-diag-ne{0%{transform:translate(-9%,7%) rotate(-6deg) scale(.96)}to{transform:translate(9%,-7%) rotate(6deg) scale(1.08)}}@keyframes dance-diag-nw{0%{transform:translate(9%,7%) rotate(6deg) scale(1.08)}to{transform:translate(-9%,-7%) rotate(-6deg) scale(.96)}}@keyframes dance-orbit-cw{0%{transform:translateY(-9%) rotate(0) scale(1)}25%{transform:translate(9%) rotate(8deg) scale(1.06)}50%{transform:translateY(9%) rotate(0) scale(1)}75%{transform:translate(-9%) rotate(-8deg) scale(.94)}to{transform:translateY(-9%) rotate(0) scale(1)}}@keyframes dance-orbit-ccw{0%{transform:translateY(-8%) rotate(0) scale(.94)}25%{transform:translate(-9%) rotate(-8deg) scale(1.06)}50%{transform:translateY(8%) rotate(0) scale(1)}75%{transform:translate(9%) rotate(8deg) scale(1.06)}to{transform:translateY(-8%) rotate(0) scale(.94)}}.dance-break-footer{flex-shrink:0;display:flex;justify-content:center;padding:var(--spacing-md) var(--spacing-md) calc(var(--spacing-lg) + env(safe-area-inset-bottom,0px));z-index:2}.spelling-input{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:var(--spacing-sm);color:#fff;padding:var(--spacing-md)}.spelling-congrats{position:absolute;left:50%;top:50%;font-family:var(--font-family-fancy);font-size:2.25rem;font-weight:400;color:#fff;white-space:nowrap;pointer-events:none;text-shadow:0 0 18px rgba(255,255,255,.4);animation:spelling-congrats-in .7s cubic-bezier(.16,1,.3,1) both;transition:opacity .3s ease}@keyframes spelling-congrats-in{0%{opacity:0;transform:translate(-50%,4.25rem) scale(.7)}60%{opacity:1;transform:translate(-50%,4.25rem) scale(1.08)}to{opacity:1;transform:translate(-50%,4.25rem) scale(1)}}.spelling-title{font-size:var(--font-size-lg);font-weight:500;margin:0}.spelling-repeat{background:#ffffff0f;border:1px solid rgba(255,255,255,.25);color:#fff;cursor:pointer;width:4.5rem;height:3rem;border-radius:var(--radius-md);display:inline-flex;align-items:center;justify-content:center;transition:background-color .15s,border-color .15s,opacity .15s}.spelling-repeat:hover{background:#ffffff24;border-color:#ffffff73}.spelling-hidden-input{position:absolute;opacity:0;pointer-events:none;caret-color:transparent;color:transparent}.spelling-display{font-size:2.5rem;font-weight:400;min-height:3.5rem;border-bottom:2px solid rgba(255,255,255,.3);padding:var(--spacing-xs) var(--spacing-lg);min-width:12.5rem;text-align:center;cursor:text;transition:border-color .2s ease}.spell-line-fade{border-color:transparent!important}.spelling-caret{display:inline-block;width:2px;height:1.2em;background-color:#fff;margin-left:1px;vertical-align:text-bottom;animation:blink 1s step-end infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.spelling-display span{display:inline-block}.letter-pop{animation:letter-pop-in .3s cubic-bezier(.16,1,.3,1) both}@keyframes letter-pop-in{0%{opacity:0;transform:translateY(-8px) scale(1.2)}to{opacity:1;transform:translateY(0) scale(1)}}.spelling-actions{margin-top:var(--spacing-sm);display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);transition:opacity .2s ease}.arrow-button{background:#ffffff0f;border:1px solid rgba(255,255,255,.25);color:#fff;cursor:pointer;width:4.5rem;height:3rem;border-radius:var(--radius-md);display:inline-flex;align-items:center;justify-content:center;transition:background-color .15s,border-color .15s,opacity .15s}.arrow-button:hover:not(:disabled){background:#ffffff24;border-color:#ffffff73}.arrow-button:disabled{opacity:.4;cursor:not-allowed}.spelling-title,.spelling-repeat{transition:opacity .2s ease}.spell-fade-out{opacity:0!important;pointer-events:none}.spell-typed-incorrect{transition:color .2s ease}.spell-letter-delete{color:var(--color-error);text-decoration:underline;text-underline-offset:4px;text-decoration-thickness:2px}@keyframes spell-shake{0%,to{transform:translate(0)}10%{transform:translate(-4px)}20%{transform:translate(4px)}30%{transform:translate(-4px)}40%{transform:translate(4px)}50%{transform:translate(-3px)}60%{transform:translate(3px)}70%{transform:translate(-2px)}80%{transform:translate(2px)}90%{transform:translate(-1px)}}.spell-shake{animation:spell-shake .5s ease-in-out}.spell-letter-insert{color:var(--color-success);text-decoration:underline;text-underline-offset:4px;text-decoration-thickness:2px}@keyframes spell-move-jump{0%{transform:scale(1);margin:0}50%{transform:scale(1.5);margin:0 4px}to{transform:scale(1);margin:0}}@keyframes spell-move-spin{0%{transform:rotateY(0) scale(1)}20%{transform:rotateY(72deg) scale(1.25)}40%{transform:rotateY(144deg) scale(1.35)}60%{transform:rotateY(216deg) scale(1.25)}80%{transform:rotateY(288deg) scale(1.1)}to{transform:rotateY(360deg) scale(1)}}@keyframes spell-move-trampoline{0%{transform:scaleY(1) scaleX(1) translateY(0)}15%{transform:scaleY(.5) scaleX(1.3) translateY(0)}40%{transform:scaleY(1.4) scaleX(.8) translateY(-24px)}60%{transform:scaleY(1.2) scaleX(.9) translateY(-18px)}80%{transform:scaleY(.85) scaleX(1.1) translateY(0)}to{transform:scaleY(1) scaleX(1) translateY(0)}}@keyframes spell-move-wiggle{0%{transform:rotate(0) scale(1)}20%{transform:rotate(25deg) scale(1.3)}50%{transform:rotate(-20deg) scale(1.25)}75%{transform:rotate(10deg) scale(1.1)}to{transform:rotate(0) scale(1)}}@keyframes spell-color-rainbow{0%{color:#fff;text-shadow:none}20%{color:#ff6b6b;text-shadow:0 0 12px currentColor,0 0 24px currentColor}40%{color:#ffd93d;text-shadow:0 0 12px currentColor,0 0 24px currentColor}60%{color:#6bcb77;text-shadow:0 0 12px currentColor,0 0 24px currentColor}80%{color:#4d96ff;text-shadow:0 0 8px currentColor}to{color:#fff;text-shadow:none}}@keyframes spell-color-golden{0%{color:#fff;text-shadow:none}20%{color:#f9ca24;text-shadow:0 0 12px currentColor,0 0 24px currentColor}40%{color:#ffbe76;text-shadow:0 0 14px currentColor,0 0 28px currentColor}60%{color:#f0932b;text-shadow:0 0 12px currentColor,0 0 24px currentColor}80%{color:#ffd93d;text-shadow:0 0 8px currentColor}to{color:#fff;text-shadow:none}}@keyframes spell-color-ocean{0%{color:#fff;text-shadow:none}20%{color:#81ecec;text-shadow:0 0 12px currentColor,0 0 24px currentColor}40%{color:#74b9ff;text-shadow:0 0 14px currentColor,0 0 28px currentColor}60%{color:#a29bfe;text-shadow:0 0 12px currentColor,0 0 24px currentColor}80%{color:#55efc4;text-shadow:0 0 8px currentColor}to{color:#fff;text-shadow:none}}@keyframes spell-color-sunset{0%{color:#fff;text-shadow:none}20%{color:#ff6b6b;text-shadow:0 0 12px currentColor,0 0 24px currentColor}40%{color:#ff9f43;text-shadow:0 0 14px currentColor,0 0 28px currentColor}60%{color:#fd79a8;text-shadow:0 0 12px currentColor,0 0 24px currentColor}80%{color:#e17055;text-shadow:0 0 8px currentColor}to{color:#fff;text-shadow:none}}@keyframes spell-color-frost{0%{color:#fff;text-shadow:none}20%{color:#dfe6e9;text-shadow:0 0 12px currentColor,0 0 24px rgba(116,185,255,.6)}40%{color:#b2bec3;text-shadow:0 0 16px rgba(129,236,236,.8),0 0 32px rgba(116,185,255,.5)}60%{color:#74b9ff;text-shadow:0 0 12px currentColor,0 0 24px currentColor}80%{color:#dfe6e9;text-shadow:0 0 8px currentColor}to{color:#fff;text-shadow:none}}.spelling-display-wrap{position:relative;display:flex;flex-direction:column;align-items:center}.spelling-title-area{text-align:center;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:5.5rem}.spelling-title-area-floating{position:absolute;bottom:100%;left:50%;transform:translate(-50%);min-height:0;padding-bottom:1rem}.spelling-placement-label{font-size:1rem;font-weight:400;opacity:.7;margin-bottom:2rem}.spelling-correct-label{font-size:1rem;font-weight:400;opacity:.7;transition:opacity .2s ease}.spelling-title-word{font-size:3.5rem!important;font-weight:300!important;white-space:nowrap}.spelling-title-word span{display:inline-block}.crash-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;padding:var(--spacing-xl);background:#000;color:#fff;text-align:center}.crash-title{font-family:var(--font-family-fancy);font-size:2rem;font-weight:400;margin:0 0 var(--spacing-md) 0}.crash-message{font-family:var(--font-family-body);font-size:var(--font-size-base);color:var(--color-text-muted);margin:0 0 var(--spacing-lg) 0}.crash-code{font-family:monospace;font-size:var(--font-size-sm);background:#ffffff1a;border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-xl);-webkit-user-select:all;user-select:all}.crash-reload{font-family:var(--font-family-body);font-size:var(--font-size-base);background:#ffffff26;border:none;color:#fff;padding:var(--spacing-sm) var(--spacing-xl);border-radius:var(--radius-md);cursor:pointer;transition:background-color .15s}.crash-reload:hover{background:#ffffff40}.story-text{font-family:Eagle Lake,cursive;font-weight:400;color:#2c1810;line-height:1.5;margin:0}.creature-card{pointer-events:auto}.creature-card-continue{margin-top:var(--spacing-md);padding-bottom:var(--spacing-sm);flex-shrink:0}.creature-card .fading-line-button{margin-top:var(--spacing-md)}.collection-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;background:#0c0a14;display:flex;flex-direction:column;pointer-events:auto}.collection-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);flex-shrink:0;width:100%;max-width:600px;margin:0 auto}.collection-title{font-family:var(--font-family-fancy);font-size:1.25rem;color:#ffffffe6;margin:0;letter-spacing:.05em}.collection-close{background:none;border:none;color:#ffffff80;cursor:pointer;padding:6px;border-radius:var(--radius-sm);transition:color .15s,background-color .15s}.collection-close:hover{color:#ffffffe6;background-color:#ffffff14}.collection-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding:0 var(--spacing-lg) var(--spacing-xl);width:100%;max-width:600px;margin:0 auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent}.collection-body::-webkit-scrollbar{width:4px}.collection-body::-webkit-scrollbar-track{background:transparent}.collection-body::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}.collection-body::-webkit-scrollbar-thumb:hover{background:#ffffff40}.collection-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:40vh;color:#fff6;font-size:var(--font-size-md);gap:var(--spacing-xs)}.collection-empty p{margin:0}.collection-realm{margin-bottom:var(--spacing-xl)}.collection-realm-header{display:flex;align-items:baseline;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);flex-wrap:wrap}.collection-realm-pill{display:inline-block;font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:4px 14px;border-radius:var(--radius-full);line-height:1.3}.collection-realm-counts{font-size:var(--font-size-xs);color:#ffffff59}.collection-creatures{display:flex;flex-wrap:wrap;gap:var(--spacing-lg)}.collection-creature{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs)}.collection-creature-name{font-size:var(--font-size-xs);color:#fff9;text-align:center;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.collection-stack{position:relative;width:88px;touch-action:manipulation;transition:width .45s cubic-bezier(.34,1.56,.64,1)}.collection-thumb{width:88px;display:flex;flex-direction:column;align-items:center;background:#0c0a14;border:2px solid rgba(255,255,255,.08);border-radius:var(--radius-md);padding:0;cursor:pointer;overflow:hidden}.collection-thumb:hover{border-color:#fff3}.collection-thumb-img{width:100%;aspect-ratio:1;object-fit:cover;display:block;background:#ffffff08}.collection-thumb-label{display:block;width:100%;padding:3px 4px;font-size:.6rem;color:#fff9;text-align:center;background:#00000080;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.collection-stack--multi .collection-thumb{position:absolute;top:0;left:0;transition:transform .45s cubic-bezier(.34,1.56,.64,1)}.collection-stack--multi .collection-thumb:first-child{position:relative}.collection-stack--multi:not(.collection-stack--expanded) .collection-thumb:nth-child(2){transform:rotate(4deg) translate(5px,-3px)}.collection-stack--multi:not(.collection-stack--expanded) .collection-thumb:nth-child(3){transform:rotate(-3deg) translate(-4px,-5px)}.collection-stack--multi:not(.collection-stack--expanded) .collection-thumb:nth-child(4){transform:rotate(2deg) translate(7px,-2px)}.collection-stack--expanded{width:calc(var(--card-count) * 88px + (var(--card-count) - 1) * 8px)}.collection-stack--expanded .collection-thumb{transform:translate(calc(var(--stack-index) * 96px))}.collection-card-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;background:#000000bf;display:flex;align-items:center;justify-content:center;padding:var(--spacing-md)}.collection-card-modal{position:relative;display:flex;flex-direction:column;max-width:400px;width:100%;max-height:100%;min-height:0;border-radius:var(--radius-lg)}.collection-card-close{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);z-index:5;background:#00000080;border:none;color:#ffffffb3;cursor:pointer;padding:6px;border-radius:var(--radius-sm);transition:color .15s,background-color .15s}.collection-card-close:hover{color:#fff;background-color:#000000b3}.confusable-card{background:#fff;border-radius:12px;padding:1.5rem;width:min(720px,calc(100vw - 2rem));max-height:85vh;box-sizing:border-box;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;box-shadow:0 2px 12px #00000014;container-type:inline-size;color:#1e293b}.confusable-card-hl{color:#a020c0;font-weight:inherit}.confusable-card-words{display:flex;flex-direction:column;gap:1rem}.confusable-card-word{display:flex;flex-direction:row;gap:1rem;align-items:flex-start}.confusable-card-text{flex:1;min-width:0}.confusable-card-title{font-size:2.5rem;font-weight:800;line-height:1;letter-spacing:-.02em;margin:0 0 .4rem;cursor:pointer;width:fit-content}.confusable-card-sentence{font-size:1.2rem;line-height:1.4;margin:0 0 .85rem;cursor:pointer;color:#111827}.confusable-card-speak-icon{display:inline;margin-left:.35em;color:#94a3b8;flex-shrink:0;transition:color .12s ease}.confusable-card-sentence .confusable-card-speak-icon{vertical-align:-.1em}.confusable-card-notes .confusable-card-speak-icon{vertical-align:-.25em}.confusable-card-sentence:hover .confusable-card-speak-icon,.confusable-card-notes:hover .confusable-card-speak-icon{color:#4f46e5}.confusable-card-sentence strong{font-weight:700}.confusable-card-notes{display:flex;align-items:flex-start;gap:.5rem;font-size:.875rem;line-height:1.45;color:#334155;margin:0;cursor:pointer}.confusable-card-note-icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;color:#111827}.confusable-card-media{flex-shrink:0;width:40%;max-width:160px;aspect-ratio:1 / 1}.confusable-card-image{display:block;width:100%;height:100%;border-radius:12px;object-fit:cover;background:#f1f5f9}.confusable-card-more-row{display:flex;justify-content:center;margin-top:1.25rem}.confusable-card-more{background:#fff;border:1px solid #cbd5e1;border-radius:999px;padding:.5rem 1.1rem;color:#334155;font-family:inherit;font-size:.9rem;cursor:pointer;transition:background-color .12s ease,border-color .12s ease}.confusable-card-more strong{color:#111827;font-weight:700;margin-left:.15rem}.confusable-card-more:hover{background:#f8fafc;border-color:#94a3b8}.confusable-card-more:focus-visible{outline:2px solid #64748b;outline-offset:2px}@container (min-width: 560px){.confusable-card{padding:1.75rem}.confusable-card-words{flex-direction:row;gap:1.5rem}.confusable-card-word{flex:1 1 0;flex-direction:column;gap:.75rem;min-width:0}.confusable-card-media{width:100%;max-width:none;margin-top:auto}}@container (max-width: 559.98px){.confusable-card-word+.confusable-card-word{border-top:1px solid #e2e8f0;padding-top:1rem}}.confusable-card::-webkit-scrollbar{width:6px}.confusable-card::-webkit-scrollbar-track{background:transparent}.confusable-card::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.confusable-card::-webkit-scrollbar-thumb:hover{background:#94a3b8}.confusable-matching{align-self:center;display:flex;flex-direction:column;align-items:stretch;justify-content:center;flex:1;gap:var(--spacing-md);width:100%;max-width:640px;padding:var(--spacing-md)}.confusable-matching-heading{font-family:var(--font-family-body);font-size:var(--font-size-xl);font-weight:400;color:#ffffffd9;margin:0;text-align:center}.confusable-matching-board{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md);align-items:stretch;padding:0 var(--spacing-md)}.confusable-matching-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.confusable-matching-line{stroke:#ffffffd9;stroke-width:3;stroke-linecap:round;transition:stroke .18s ease}.confusable-matching-line[data-correctness=correct]{stroke:#4ade80;stroke-width:4}.confusable-matching-line[data-correctness=incorrect]{stroke:#f87171;stroke-width:4}.confusable-matching-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.3);border-radius:10px;color:#ffffffeb;font-family:var(--font-family-body);font-size:var(--font-size-base);cursor:pointer;transition:background-color .12s ease,border-color .12s ease,transform 80ms ease;min-height:4.75rem;position:relative;z-index:1}.confusable-matching-btn:hover:not(:disabled){background:#ffffff2e;border-color:#ffffff8c}.confusable-matching-btn:active:not(:disabled){transform:scale(.98)}.confusable-matching-btn:disabled{cursor:not-allowed;opacity:.6}.confusable-matching-btn[data-pending]{background:#ffdc7840;border-color:#ffdc78d9;box-shadow:0 0 0 2px #ffdc7866}.confusable-matching-btn[data-connected]{background:#b4dcff2e;border-color:#b4dcffb3}.confusable-matching-btn[data-correctness=correct],.confusable-matching-btn[data-correctness=correct]:hover:not(:disabled){background:#4ade802e;border-color:#4ade80e6;color:#fff}.confusable-matching-btn[data-correctness=correct]:hover:not(:disabled){background:#4ade8047;border-color:#4ade80}.confusable-matching-btn[data-correctness=incorrect],.confusable-matching-btn[data-correctness=incorrect]:hover:not(:disabled){background:#f871712e;border-color:#f87171e6;color:#fff}.confusable-matching-btn[data-correctness=incorrect]:hover:not(:disabled){background:#f8717147;border-color:#f87171}.confusable-matching-btn[data-correctness=correct]:disabled,.confusable-matching-btn[data-correctness=incorrect]:disabled{opacity:1}.confusable-matching-btn-right{font-size:1.5rem;letter-spacing:.01em}.confusable-matching-btn-sentence{justify-content:flex-start;gap:.6rem;text-align:left;padding:.75rem .9rem;line-height:1.25}.confusable-matching-btn-sentence .confusable-matching-speaker{flex-shrink:0;opacity:.85}.confusable-matching-btn-sentence .confusable-matching-sentence{flex:1;word-break:break-word}@media(max-width:520px){.confusable-matching{padding:var(--spacing-sm)}.confusable-matching-board{padding:0;row-gap:var(--spacing-sm);column-gap:1.5rem}.confusable-matching-btn{padding:.5rem .55rem}.confusable-matching-btn-sentence{padding:.5rem .3rem .5rem .5rem;gap:.4rem}.confusable-matching-btn-right{font-size:1.25rem}}.confusable-matching-target{text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px;font-weight:600}.confusable-matching-actions{display:flex;justify-content:center;margin-top:var(--spacing-md)}.confusable-matching-actions .arrow-button{width:8rem}.confusable-matching-placeholder{visibility:hidden;pointer-events:none}
