@import url(https://fonts.googleapis.com/css2?family=Fredoka:wght@400;500;600&family=Space+Grotesk:wght@400;500;600&display=swap);body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*,:after,:before{box-sizing:border-box}:root{--ink:#0f172a;--mid:#1f2937;--card:#fff;--accent:#7c3aed;--accent-2:#22d3ee;--muted:#6b7280;--border:#e5e7eb;--bg:radial-gradient(circle at 15% 20%,#f9e3ff 0,#0000 30%),radial-gradient(circle at 80% 0%,#e0f2fe 0,#0000 25%),linear-gradient(135deg,#f8fafc,#eef2ff 60%,#e0f2fe);--radius-lg:20px;--radius-md:16px;--radius-sm:12px;--border-soft:1px solid #0f172a14;--border-subtle:1px solid #0000000f;--shadow-soft:0 8px 24px #00000014;--shadow-soft-hover:0 12px 30px #0000001f}body{background:radial-gradient(circle at 15% 20%,#f9e3ff 0,#0000 30%),radial-gradient(circle at 80% 0,#e0f2fe 0,#0000 25%),linear-gradient(135deg,#f8fafc,#eef2ff 60%,#e0f2fe);background:var(--bg);overflow-x:hidden}.app{color:#0f172a;color:var(--ink);font-family:Fredoka,Space Grotesk,Segoe UI,system-ui,sans-serif;min-height:100vh;padding:14px 6vw 36px}.login-hero{align-items:stretch;background:linear-gradient(135deg,#e0eaffd1,#ebf7ffc7 48%,#ffeef8c2);border:1px solid #ffffff9e;border-radius:32px;box-shadow:0 22px 50px #0f172a1f;display:flex;gap:20px;margin:0 auto;max-width:1120px;padding:26px;width:100%}.login-title{color:#2f2a7a;font-size:clamp(44px,5.8vw,66px);line-height:1.02;margin:0}.login-hero-media{background:#0000;border:none;border-radius:26px;display:grid;flex:1.05 1;min-height:100%;padding:0}.login-illustration{background:linear-gradient(145deg,#7dc6ff47,#c6e7ff8a 54%,#f4faffcc);border-radius:26px;box-shadow:0 16px 30px #46548224;display:grid;height:100%;min-height:560px;overflow:hidden;padding:12px;place-items:center;position:relative;width:100%}.login-illustration-img{border-radius:20px;box-shadow:0 8px 18px #4654822e;height:100%;object-fit:cover;width:100%}.story-loading{grid-gap:10px;color:#6b7280;color:var(--muted);display:grid;gap:10px;min-height:220px;padding:24px 10px;place-items:center}.spinner{animation:spin .9s linear infinite;border:4px solid #7c3aed2e;border-radius:999px;border-top-color:#7c3aedf2;height:34px;width:34px}@keyframes spin{to{transform:rotate(1turn)}}.girl-logo{height:240px;position:relative;width:240px}.girl-hair{background:radial-gradient(circle at 40% 20%,#ffffff14,#0000 40%),linear-gradient(145deg,#2f1f15,#4b2f1d 60%,#2d1a11);border-radius:120px 120px 100px 100px;box-shadow:0 12px 28px #2f1f1547;height:160px;left:18px;overflow:visible;position:absolute;right:18px;top:24px}.girl-face{background:#ffd8b8;border-radius:80px;box-shadow:0 12px 24px #ffa67a40;display:grid;height:118px;left:58px;place-items:center;position:absolute;right:58px;top:78px;z-index:2}.girl-eye{background:#2f2a7a;border-radius:50%;height:14px;left:36px;position:absolute;top:44px;width:14px}.girl-eye.right{left:auto;right:36px}.girl-cheek{background:#f472b666;border-radius:12px;height:12px;left:30px;position:absolute;top:74px;width:22px}.girl-cheek.right{left:auto;right:30px}.girl-smile{border:6px solid #2f2a7a;border-radius:0 0 40px 40px;border-top:none;bottom:22px;height:30px;left:50%;position:absolute;transform:translateX(-50%);width:52px}.girl-shoulders{background:linear-gradient(90deg,#7c3aed,#5b21b6);border-radius:24px;bottom:24px;box-shadow:0 12px 22px #7c3aed4d;height:70px;left:26px;position:absolute;right:26px}.girl-book{background:linear-gradient(120deg,#ffd166,#fcd34d 40%,#fca5a5);border:8px solid #f59e0b;border-radius:16px;bottom:0;box-shadow:0 12px 20px #0000001f;height:78px;left:46px;position:absolute;right:46px;z-index:1}.girl-curl{background:radial-gradient(circle at 30% 30%,#3b261c,#2a1a11 70%);border-radius:50%;box-shadow:0 10px 18px #2a1a1147;height:80px;opacity:.9;position:absolute;width:80px}.girl-curl.c1{left:-6px;top:24px}.girl-curl.c2{right:-14px;top:10px}.girl-curl.c3{bottom:-10px;left:16px}.girl-collar{background:#fff2e5;border-radius:12px;bottom:62px;box-shadow:0 6px 12px #00000014;height:16px;left:34px;position:absolute;right:34px;z-index:3}.login-btn{align-items:center;border-radius:16px;display:inline-flex;font-size:18px;gap:10px;justify-content:center;min-height:54px;width:100%}.login-btn-secondary{border:1px solid #4c1d9552}.login-welcome-card{grid-gap:12px;align-content:start;background:#ffffffdb;border:1px solid #ffffffad;border-radius:26px;box-shadow:0 16px 36px #0f172a1f;display:grid;flex:0.95 1;gap:12px;min-height:100%;padding:26px 22px}.login-welcome-title{color:#312e81;font-size:clamp(28px,2.9vw,38px);line-height:1.12;margin:0}.login-welcome-sub{color:#0f172ab8;font-size:clamp(16px,1.45vw,20px);font-weight:700;margin:0 0 8px}.login-sample-note{color:#4c1d95d6;font-size:14px;font-weight:700;margin:-4px 0 2px;text-align:center}.login-info-card{background:#6366f11c;border:1px solid #0f172a1a;border-radius:12px;padding:10px 12px}.login-info-title{color:#1e293beb;font-size:14px;font-weight:800}.login-info-sub{color:#1e293bbd;font-size:13px;font-weight:600;margin-top:2px}.ms-logo{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(2,12px);grid-template-rows:repeat(2,12px)}.ms-square{border-radius:2px;height:12px;width:12px}.ms-square.red{background:#f35325}.ms-square.green{background:#81bc06}.ms-square.blue{background:#05a6f0}.ms-square.yellow{background:#ffba08}.login-subtitle{color:#2f2a7a;font-size:24px;font-weight:700;margin:0}.privacy-note{background:#ffffffe6;border:1px solid #0f172a1f;border-radius:12px;color:#0f172ad1;font-size:13px;font-weight:600;line-height:1.4;margin-top:2px;padding:10px 12px;width:100%}.topbar{display:flex;justify-content:space-between;margin-bottom:6px}.brand,.topbar{align-items:center}.brand{cursor:pointer;display:inline-flex;font-size:20px;font-weight:800;gap:8px}.logo-mark{background:#7c3aed;border-radius:12px;color:#fff;display:grid;font-weight:800;height:32px;place-items:center;width:32px}.nav{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.nav-toggle{background:#fff;border:1px solid #0f172a29;border-radius:12px;box-shadow:0 6px 16px #00000014;color:#0f172a;cursor:pointer;display:none;font-size:22px;font-weight:900;height:40px;line-height:1;width:40px}.app-notice{align-items:center;background:#f59e0b24;border:1px solid #f59e0b47;border-radius:14px;color:#0f172ad9;display:flex;font-weight:700;gap:10px;justify-content:space-between;margin:10px auto 0;padding:12px;width:min(980px,92vw)}.app-notice-text{flex:1 1 auto}.app-notice-close{background:#ffffffb3;border:1px solid #0f172a1a;border-radius:10px;cursor:pointer;font-size:18px;font-weight:900;height:34px;line-height:1;width:34px}.nav-btn{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border);border-radius:9999px;box-shadow:0 6px 16px #0000000f;cursor:pointer;font-weight:700;height:38px;padding:0 14px}.nav-btn.active{background:#7c3aed;border-color:#7c3aed;box-shadow:0 10px 22px #0000001f,inset 0 0 0 2px #ffffff40;color:#fff}.nav-btn.premium{background:linear-gradient(135deg,#7c3aed,#22d3ee);border-color:#0000;box-shadow:0 12px 26px #7c3aed38;color:#fff}.app-footer{align-items:center;color:#0f172ab3;flex-wrap:wrap;gap:14px;margin:26px auto 0;width:min(980px,92vw)}.app-footer,.cookie-banner{display:flex;justify-content:center}.cookie-banner{bottom:16px;left:0;padding:0 12px;position:fixed;right:0;z-index:50}.cookie-banner-card{grid-gap:10px;background:#fffffff2;border:1px solid #0f172a1f;border-radius:18px;box-shadow:0 18px 50px #0f172a2e;display:grid;gap:10px;padding:14px;width:min(980px,96vw)}.cookie-banner-title{color:#0f172aeb;font-weight:900}.cookie-banner-text{color:#0f172abf;font-weight:600}.cookie-banner-actions{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.legal-page{margin:14px auto 0;width:min(980px,92vw)}.legal-card{background:#ffffffeb;border:1px solid #0f172a1a;border-radius:22px;box-shadow:0 16px 40px #0f172a14;padding:22px 18px}.legal-top{align-items:center;display:flex;gap:12px;justify-content:space-between}.legal-actions{display:flex;gap:10px;margin-top:12px}.page-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:22px}.panel{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border);border-radius:18px;box-shadow:0 8px 20px #0f172a14;padding:18px}.panel.accent{background:linear-gradient(145deg,#5ad5e8,#36b1ff);color:#0f172a}.panel.soft{background:#e9fbf5}.dashboard-shell{background:#fffdf7;padding:14px}.dash-hero-banner,.dashboard-shell{border:1px solid #0000000f;border:var(--border-subtle);border-radius:20px;border-radius:var(--radius-lg);box-shadow:0 8px 24px #00000014;box-shadow:var(--shadow-soft)}.dash-hero-banner{grid-gap:8px;align-items:start;background:#ffffffdb;display:grid;gap:8px;grid-template-columns:1fr;margin-bottom:2px;padding:10px 14px 6px;position:relative}.dash-hero-banner:before{display:none}.dash-hero-left{align-items:flex-start;display:flex;gap:12px}.dash-hero-mascot-wrap{background:#0000;border:none;box-shadow:none;padding:0}.dash-hero-mascot{border-radius:0;display:block;filter:drop-shadow(0 14px 20px rgba(15,23,42,.12));height:108px;object-fit:contain;width:180px}.dash-hero-copy{align-self:flex-start;display:flex;flex-direction:column;justify-content:flex-start;margin-top:0}.dash-hero-copy .eyebrow{margin:0 0 4px}.dash-hero-title{color:#2f2a7a;font-size:clamp(20px,2.8vw,32px);line-height:1.08;margin:0;white-space:nowrap}.dash-hero-sub{color:#0f172abf;font-size:14px;font-weight:700;line-height:1.15;margin:0}.continue-card{align-items:stretch;background:#fff;border:1px solid #0f172a14;border:var(--border-soft);box-shadow:0 8px 18px #0f172a1a;display:inline-flex;flex-direction:column;gap:8px;justify-self:end;max-width:100%;padding:14px;width:300px}.continue-card,.resume-section .resume-card{border-radius:16px;border-radius:var(--radius-md)}.resume-section .resume-card{grid-gap:10px;background:#ffffffd6;border:1px solid #0000000f;border:var(--border-subtle);box-shadow:0 8px 24px #00000014;box-shadow:var(--shadow-soft);display:grid;gap:10px;padding:16px;width:min(100%,420px)}.resume-section .continue-card{justify-self:start}.continue-card.empty{opacity:.7}.continue-row{align-items:center;display:flex;gap:10px;margin-bottom:8px}.continue-play{background:#fffc;border:1px solid #0f172a1f;border-radius:999px;box-shadow:0 10px 18px #0f172a14;color:#7c3aed;display:grid;font-size:14px;height:36px;place-items:center;width:36px}.continue-storyname{color:#0f172a;font-size:16px;font-weight:900;max-width:240px}.continue-icon{background:#7c3aed0f;border:none;border-radius:12px;border-radius:var(--radius-sm);display:block;height:122px;margin-bottom:8px;object-fit:cover;object-position:center;padding:0;width:100%}.continue-btn{align-items:center;align-self:flex-start;background:linear-gradient(135deg,#7c3aedf2,#22d3eee6);border:1px solid #0000000f;border-radius:999px;box-shadow:0 8px 18px #0f172a1f;display:inline-flex;gap:10px;height:38px;justify-content:center;min-width:110px;padding:8px 16px;transition:transform .14s ease,box-shadow .14s ease;width:auto}.continue-btn:hover{box-shadow:0 12px 26px #0f172a29;transform:translateY(-1px)}.continue-btn:focus-visible{outline:2px solid #7c3aedb3;outline-offset:2px}.continue-btn:after{content:"→";display:inline-block;font-size:16px;font-weight:900;line-height:1;opacity:.95}.dash-top{align-items:center;display:flex;justify-content:space-between;margin-bottom:14px}.ms-mark{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(2,14px);grid-template-rows:repeat(2,14px)}.avatar-small{background:linear-gradient(180deg,#fcb045,#fd1d1d);border-radius:50%;height:44px;width:44px}.dash-hero-card{background:#5146c6;border-radius:18px;color:#fff;margin-bottom:18px;padding:22px}.dash-hero-card .dash-hero-title{font-size:26px;margin:4px 0}.dash-hero-card .dash-hero-sub{font-size:16px;margin:0;opacity:.9}.dash-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}.section{margin:8px 0 4px}.kid-mode-panel{background:#ffffffb8;border:1px solid #0f172a14;border-radius:14px;padding:12px}.kid-mode-head{align-items:center;display:flex;gap:10px;justify-content:space-between}.kid-picker-label{color:#334155;display:block;font-weight:800;margin-bottom:6px;margin-top:8px}.kid-picker-select{background:#fff;border:1px solid #0f172a33;border-radius:12px;font:inherit;max-width:360px;min-width:240px;padding:10px 12px;width:100%}.section-title{color:#2f2a7a;margin:0 0 10px}.topic-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,minmax(180px,1fr))}.topic-grid.tiles{grid-template-columns:repeat(3,minmax(220px,1fr))}.topic-tile{grid-gap:0;border:1px solid #0000000f;border:var(--border-subtle);border-radius:16px;border-radius:var(--radius-md);box-shadow:0 6px 18px #00000014;color:#0f172a;cursor:pointer;display:grid;font-weight:900;gap:0;min-height:230px;padding:10px;transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease}.topic-tile:hover{border-color:#0000001f;box-shadow:0 12px 30px #0000001f;box-shadow:var(--shadow-soft-hover);transform:translateY(-2px)}.topic-tile.is-locked,.topic-tile:disabled{cursor:not-allowed;opacity:.7;transform:none}.topic-tile:focus-visible{outline:3px solid #7c3aed59;outline-offset:3px}.topic-tile-frame{background:#ffffffa6;border:1px solid #0000000f;border:var(--border-subtle);border-radius:12px;border-radius:var(--radius-sm);display:grid;height:210px;overflow:hidden;padding:8px;place-items:center;width:100%}.topic-tile-img{border-radius:10px;border-radius:calc(var(--radius-sm) - 2px);display:block;filter:drop-shadow(0 12px 16px rgba(15,23,42,.12));height:100%;object-fit:cover;object-position:center bottom;position:relative;top:-14px;transform:scale(1.06,.9);transform-origin:center center;width:100%}.topic-actions{display:flex;justify-content:flex-end;margin-top:10px}.badge-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(3,minmax(180px,1fr))}.badge-item{grid-gap:6px;background:linear-gradient(180deg,#fffffff0,#fffc);border:1px solid #0f172a1a;border-radius:20px;box-shadow:0 10px 20px #0f172a14;display:grid;gap:6px;justify-items:center;padding:12px 12px 10px;position:relative;text-align:center;transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease}.badge-item:before{background:#94a3b859;border-radius:999px;content:"";height:4px;left:12px;position:absolute;right:12px;top:6px}.badge-item:hover{border-color:#0f172a29;box-shadow:0 14px 26px #0f172a1f;transform:translateY(-2px)}.badge-item.earned{background:linear-gradient(145deg,#7c3aed29,#22d3ee24,#fffffff2);border-color:#7c3aed4d}.badge-item.earned:before{display:none}.badge-item.locked:before{background:linear-gradient(90deg,#94a3b8,#cbd5e1)}.badge-item.coming-soon:before{background:linear-gradient(90deg,#f59e0b,#f97316)}.badge-item.earned:after{background:#ffffffeb;border:1px solid #7c3aed38;border-radius:999px;box-shadow:0 6px 12px #0f172a24;color:#7c3aed;content:"★";display:grid;font-size:12px;font-weight:900;height:20px;place-items:center;position:absolute;right:12px;top:10px;width:20px}.badge-emoji{background:#ffffffdb;border:1px solid #0f172a1a;border-radius:14px;box-shadow:inset 0 1px 0 #ffffffe6,0 8px 14px #0f172a14;display:grid;font-size:24px;height:46px;place-items:center;width:46px}.badge-emoji.badge-icon svg{filter:drop-shadow(0 10px 14px rgba(15,23,42,.14));height:30px;width:30px}.badge-logo{border-radius:10px;height:34px;object-fit:cover;width:34px}.badge-emoji.badge-letter{color:#0f172ad9;font-size:22px;font-weight:900}.badge-name{font-size:15px;font-weight:900;letter-spacing:.01em;line-height:1.2}.badge-sub{background:#94a3b829;border:1px solid #94a3b83d;border-radius:999px;color:#0f172ab8;font-size:12px;font-weight:800;padding:4px 9px}.badge-item.earned .badge-sub{background:#7c3aed29;border-color:#7c3aed47;color:#4c1d95}.badge-item.coming-soon .badge-sub{background:#fb923c29;border-color:#fb923c4d;color:#9a3412}.howto-section{margin-top:18px}.howto-sub{color:#0f172abd;font-weight:600;margin:0 0 12px}.howto-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(4,minmax(180px,1fr))}.howto-card{grid-gap:8px;background:linear-gradient(160deg,#fffffff0,#f4f8ffe6);border:1px solid #0f172a1a;border-radius:18px;box-shadow:0 10px 20px #0f172a14;display:grid;gap:8px;padding:14px 12px 12px;position:relative}.howto-step{background:#7c3aed26;border-radius:999px;color:#5b21b6;display:grid;font-size:12px;font-weight:900;height:24px;place-items:center;position:absolute;right:10px;top:10px;width:24px}.howto-icon{background:#ffffffe6;border:1px solid #0f172a14;border-radius:12px;display:grid;font-size:22px;height:42px;place-items:center;width:42px}.howto-title{color:#0f172a;font-size:17px;font-weight:900}.howto-text{color:#0f172ab8;font-size:13px;font-weight:600;line-height:1.4;margin:0}.faq-section{margin-top:16px}.faq-sub{color:#0f172abd;font-weight:600;margin:0 0 12px}.faq-list{grid-gap:10px;display:grid;gap:10px}.faq-item{background:#ffffffeb;border:1px solid #0f172a14;border-radius:16px;box-shadow:0 8px 16px #0f172a14;padding:0 12px}.faq-item:first-child{border-color:#7c3aed3d}.faq-item:nth-child(2){border-color:#f59e0b47}.faq-item:nth-child(3){border-color:#14b8a647}.faq-item:nth-child(4){border-color:#ec489947}.faq-item:nth-child(5){border-color:#22c55e47}.faq-question{grid-gap:8px;align-items:center;color:#0f172a;cursor:pointer;display:grid;font-weight:900;gap:8px;grid-template-columns:26px 1fr 24px;list-style:none;padding:12px 0}.faq-question::-webkit-details-marker{display:none}.faq-icon{background:#ffffffe6;border:1px solid #0f172a1f;border-radius:999px;color:#0f172acc;display:grid;font-size:13px;height:24px;place-items:center;width:24px}.faq-question-text{font-size:17px;line-height:1.25}.faq-toggle{background:#7c3aed1f;border-radius:999px;color:#5b21b6;display:grid;font-size:0;height:20px;place-items:center;width:20px}.faq-toggle:before{content:"+";font-size:14px;font-weight:900}.faq-item[open] .faq-toggle:before{content:"-"}.faq-answer{color:#0f172ac2;font-size:14px;font-weight:600;line-height:1.5;margin:0;padding:0 0 12px 34px}.history-card,.topic-card{grid-gap:8px;border:none;border-radius:16px;box-shadow:0 10px 18px #0f172a1f;color:#13203b;cursor:pointer;display:grid;font-weight:700;gap:8px;justify-items:start;padding:14px}.topic-icon{font-size:28px}.topic-title{font-size:16px}.history-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.hero-spot{background:#d6f1ff;border-radius:16px;display:grid;height:150px;margin:12px 0;place-items:center}.kid-avatar{background:linear-gradient(180deg,#fbbf24,#f59e0b);border-radius:40px;height:120px;position:relative;width:120px}.back-link{cursor:pointer;font-weight:700;margin-bottom:8px}.input-placeholder{background:#fffc;border-radius:8px;height:16px;margin:10px 0}.accent-btn{background:#f59e0b;color:#0f172a;width:100%}.page-grid.dashboard-page .panel{min-height:260px}.color-dots{display:flex;gap:8px}.dot{border-radius:10px;display:inline-block;height:12px;width:22px}.dot.yellow{background:#fcd34d}.dot.blue{background:#3b82f6}.card-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));margin-top:14px}.tile{background:#cdb7ff;border:none;border-radius:14px;box-shadow:0 10px 16px #7c3aed33;color:#24155f;cursor:pointer;font-weight:700;padding:14px}.quick-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}.chip-btn{background:#7c3aed;border:none;border-radius:12px;color:#fff;font-weight:700;padding:10px 12px}.pill{align-items:center;background:#7c3aed1a;border-radius:999px;color:#5b21b6;display:inline-flex;font-size:13px;font-weight:600;gap:8px;padding:8px 14px}.hero{grid-gap:28px;align-items:stretch;display:grid;gap:28px;grid-template-columns:1.3fr 1fr;margin-bottom:32px}.hero__text h1{font-size:clamp(28px,5vw,48px);line-height:1.1;margin:14px 0 12px}.hero__glow{color:#7c3aed;color:var(--accent)}.lede{color:#6b7280;color:var(--muted);margin-bottom:22px;max-width:640px}.center{text-align:center}.input-row{grid-gap:14px;align-items:end;display:grid;gap:14px;grid-template-columns:1.1fr 1fr;margin-bottom:14px}.input-group{display:flex;flex-direction:column;gap:6px}.input-group label{color:#1f2937;color:var(--mid);font-weight:600}input,textarea{background:#fff;border:2px solid #e5e7eb;border:2px solid var(--border);border-radius:14px;font-family:inherit;font-size:15px;padding:12px 14px;transition:border .2s ease,box-shadow .2s ease;width:100%}input:focus,textarea:focus{border-color:#7c3aed;border-color:var(--accent);box-shadow:0 10px 30px #7c3aed1a;outline:none}textarea{min-height:120px;resize:vertical}.cta-row{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.btn{border:none;border-radius:14px;cursor:pointer;font-size:14px;font-weight:700;padding:12px 16px;transition:transform .15s ease,box-shadow .2s ease,background .2s ease}.btn.primary{background:linear-gradient(135deg,#7c3aed,#8b5cf6);background:linear-gradient(135deg,var(--accent),#8b5cf6);box-shadow:0 12px 30px #7c3aed40;color:#fff}.btn.secondary{background:#e0f2fe;color:#0ea5e9}.btn.ghost{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border);color:#1f2937;color:var(--mid)}.btn.link{background:#0000;box-shadow:none;color:#7c3aed;color:var(--accent)}.btn.wide{width:100%}.btn:hover{transform:translateY(-2px)}.chips{display:flex;flex-wrap:wrap;gap:10px}.chip{background:#22d3ee26;border-radius:999px;color:#0ea5e9;font-size:13px;font-weight:600;padding:8px 12px}.hero__card{background:#0b1431;border-radius:20px;box-shadow:0 20px 40px #0f172a40;color:#e5edff;overflow:hidden;padding:20px 22px;position:relative}.hero__card:after{background:radial-gradient(circle at 40% 30%,#22d3ee33,#0000 35%),radial-gradient(circle at 80% 10%,#7c3aed40,#0000 30%);content:"";inset:0;position:absolute;z-index:0}.hero__card h3{margin:0 0 8px}.steps{grid-gap:8px;display:grid;gap:8px;margin:0;padding-left:18px;position:relative;z-index:1}.steps--compact{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));padding-left:0}.step-line{color:#dbeafe;margin:2px 0 0}.hero__badge{background:#ffffff1f;border-radius:12px;color:#c7d2fe;display:inline-flex;font-weight:700;margin-top:14px;padding:8px 12px;z-index:1}.grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.card{background:#fff;background:var(--card);border:1px solid #e5e7eb;border:1px solid var(--border);border-radius:20px;box-shadow:0 18px 30px #0f172a0f;padding:18px}.card__head{align-items:flex-start;display:flex;gap:12px;justify-content:space-between;margin-bottom:10px}.eyebrow{color:#6b7280;color:var(--muted);font-size:11px;font-weight:700;letter-spacing:.08em;margin:0 0 4px;text-transform:uppercase}h2{font-size:22px;margin:0}.story__text{color:#1f2937;color:var(--mid);line-height:1.55;margin:10px 0 14px}.fact-row{grid-gap:12px;align-items:center;display:grid;gap:12px;grid-template-columns:2fr 1fr}.fact-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.fact{background:#0ea5e91f;border-radius:12px;color:#0ea5e9;display:inline-flex;font-weight:600;padding:10px 12px}.tts{grid-gap:6px;display:grid;gap:6px;justify-items:start}.quiz textarea{margin:8px 0 12px}.quiz__placeholder{background:#f8fafc;border:1px dashed #e5e7eb;border:1px dashed var(--border);border-radius:12px;color:#6b7280;color:var(--muted);font-weight:600;padding:16px}.quiz-page{background:radial-gradient(circle at 20% 10%,#a855f72e 0,#0000 40%),radial-gradient(circle at 80% 30%,#22d3ee29 0,#0000 45%),linear-gradient(135deg,#f8fafc,#eef2ff 50%,#fce7f3);border-radius:24px;display:grid;min-height:60vh;padding:18px 0;place-items:center}.quiz-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffd1;border:1px solid #7c3aed2e;border-radius:22px;box-shadow:0 18px 44px #0f172a29;padding:22px;width:min(520px,100%)}.quiz-card-wide{width:min(820px,96vw)}.quiz-top{grid-gap:10px;align-items:center;display:grid;gap:10px;grid-template-columns:46px 1fr 46px;margin-bottom:12px}.quiz-back{background:#fffc;border:1px solid #0f172a14;border-radius:14px;cursor:pointer;font-weight:900;height:44px;width:44px}.quiz-top-title{color:#5b21b6;font-size:22px;font-weight:900;letter-spacing:.2px;text-align:center}.quiz-avatar{background:#fff;border:1px solid #0f172a1f;border-radius:50%;box-shadow:0 8px 16px #0f172a24;height:46px;overflow:hidden;width:46px}.quiz-avatar-img{display:block;height:100%;object-fit:cover;object-position:center;width:100%}.quiz-story-art{background:#ffffffc2;border:1px solid #0f172a1a;border-radius:16px;box-shadow:0 10px 22px #0f172a14;height:clamp(170px,28vw,240px);margin-bottom:12px;overflow:hidden;width:100%}.quiz-story-art-img{display:block;height:100%;object-fit:cover;object-position:center;width:100%}.quiz-progress{grid-gap:10px;align-items:center;display:grid;gap:10px;grid-template-columns:auto 1fr auto;margin:8px 0 12px}.quiz-dots{align-items:center;display:flex;gap:8px}.quiz-dot{background:#7c3aed2e;border-radius:999px;height:12px;width:12px}.quiz-dot.active{background:#a855f7}.quiz-progress-text{color:#0f172a99;font-weight:800;text-align:center}.quiz-speak{background:#fffc;border:1px solid #0f172a14;border-radius:14px;cursor:pointer;font-size:18px;height:44px;width:44px}.quiz-question-card{grid-gap:10px;background:#fffc;border:1px solid #0f172a14;border-radius:18px;box-shadow:0 12px 26px #0f172a14;display:grid;gap:10px;justify-items:center;margin-bottom:12px;padding:18px 16px}.quiz-question-icon{background:linear-gradient(135deg,#22d3ee38,#a855f738);border-radius:18px;display:grid;height:56px;overflow:hidden;place-items:center;width:56px}.quiz-question-logo{border-radius:12px;height:36px;object-fit:cover;width:36px}.quiz-question-text{color:#0f172a;font-size:22px;font-weight:900;line-height:1.25;text-align:center}.quiz-options{grid-gap:10px;display:grid;gap:10px;margin-top:10px}.quiz-option{align-items:center;background:#ffffffe6;border:1px solid #0f172a1a;border-radius:16px;box-shadow:0 10px 18px #0f172a0f;cursor:pointer;display:flex;gap:10px;justify-content:space-between;padding:14px;text-align:left}.quiz-option.selected{background:#22d3ee1f;border-color:#22d3eeb3}.quiz-option-label{color:#0f172ad1;font-weight:800}.quiz-option-mark{border:2px solid #0f172a29;border-radius:999px;color:#0ea5e9;display:grid;flex:0 0 auto;font-weight:900;height:26px;place-items:center;width:26px}.quiz-option.selected .quiz-option-mark{background:#22d3ee29;border-color:#22d3eeb3}.quiz-next{margin-top:14px}.quiz-feedback{grid-gap:12px;display:grid;gap:12px}.quiz-feedback-title{color:#0f172a;font-size:22px;font-weight:900;margin:6px 0 0}.quiz-feedback-list{grid-gap:12px;display:grid;gap:12px;max-height:min(56vh,520px);overflow:auto;padding:2px}.quiz-feedback-card{background:#fffc;border:1px solid #0f172a14;border-radius:18px;box-shadow:0 12px 26px #0f172a14;padding:16px}.quiz-feedback-head{align-items:center;display:flex;gap:10px;justify-content:space-between;margin-bottom:8px}.quiz-feedback-emoji{background:linear-gradient(135deg,#22d3ee38,#a855f738);border-radius:14px;display:grid;flex:0 0 auto;height:36px;place-items:center;width:36px}.quiz-feedback-level{color:#0f172a99;flex:1 1 auto;font-size:12px;font-weight:900;letter-spacing:.8px;text-transform:uppercase}.quiz-feedback-text{color:#0f172ad1;font-weight:800;line-height:1.35}.quiz-feedback-cta{color:#0f172ab8;font-weight:800;text-align:center}.quiz-feedback-link{background:#0000;border:none;color:#7c3aed;cursor:pointer;font-weight:900;padding:0;text-decoration:underline}@media (max-width:600px){.quiz-card{padding:18px;width:min(460px,96vw)}.quiz-question-text{font-size:20px}}.feedback-page{display:grid;min-height:60vh;place-items:center}.feedback-card{background:#ffe8a3;border:1px solid #fcd34d;border-radius:20px;box-shadow:0 16px 30px #00000014;padding:22px;width:min(720px,94vw)}.feedback-section{background:#ffffff8c;border:1px solid #0f172a0f;border-radius:16px;margin-top:14px;padding:16px}.feedback-title{color:#0f172a;margin:0 0 10px}.field{grid-gap:6px;display:grid;gap:6px;margin-top:12px}.field-label{color:#0f172acc;font-weight:600}.rating-row{grid-gap:12px;align-items:center;display:grid;gap:12px;grid-template-columns:140px 1fr;margin-top:10px}.rating-label{font-weight:700}.rating-options{display:flex;flex-wrap:wrap;gap:10px}.rating-pill{background:#ffffffe6;border:1px solid #0f172a1f;border-radius:999px;cursor:pointer;font-weight:800;padding:8px 12px}.rating-pill.active{background:#7c3aed1f;border-color:#7c3aed73}.feedback-actions{grid-gap:10px;display:grid;gap:10px;margin-top:16px}.feedback-cta{background:linear-gradient(135deg,#7c3aed,#22d3ee);border:none;box-shadow:0 14px 26px #7c3aed47;letter-spacing:.2px}.feedback-cta:hover{transform:translateY(-1px)}.feedback-cta:active{transform:translateY(0)}.feedback-thanks{grid-gap:10px;display:grid;gap:10px;margin-top:16px}.parents-page{display:grid;min-height:60vh;place-items:center}.parents-card{background:#fffdf7;border:1px solid #0f172a14;border-radius:22px;box-shadow:0 18px 40px #0f172a1f;padding:22px;width:min(900px,96vw)}.parents-head{align-items:center;display:flex;gap:12px;justify-content:space-between}.parents-title{margin:0}.parents-metrics{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));margin-top:14px}.metric{background:#7c3aed14;border:1px solid #7c3aed2e;border-radius:16px;padding:14px}.metric-label{color:#0f172ab3;font-weight:700;margin-bottom:6px}.metric-label-row{align-items:center;display:flex;gap:10px;justify-content:space-between}.metric-value-row{align-items:baseline;display:flex;gap:10px}.info-btn{background:#ffffffe6;border:1px solid #0f172a29;border-radius:999px;color:#0f172acc;cursor:pointer;display:grid;font-weight:900;height:26px;line-height:1;place-items:center;width:26px}.info-btn:hover{background:#fff}.tag{align-items:center;border:1px solid #0000;border-radius:999px;display:inline-flex;font-size:12px;font-weight:900;line-height:1;padding:4px 10px;white-space:nowrap}.tag-excellent{background:#10b98124;border-color:#10b98147;color:#047857}.tag-good{background:#22d3ee29;border-color:#22d3ee4d;color:#0369a1}.tag-needs{background:#f59e0b29;border-color:#f59e0b52;color:#92400e}.metric-help{background:#ffffffb3;border:1px solid #0f172a14;border-radius:14px;margin-top:10px;padding:10px 12px}.metric-help-title{color:#0f172ad9;font-weight:900;margin-bottom:4px}.metric-help-text{color:#0f172ab8;font-size:13px;font-weight:700;line-height:1.35}.metric-value{color:#0f172a;font-size:28px;font-weight:900}.parents-section{background:#ffffffb3;border:1px solid #0f172a0f;border-radius:16px;margin-top:14px;padding:16px}.parent-privacy-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(2,minmax(220px,1fr));margin-top:10px}.parent-field{grid-gap:6px;display:grid;gap:6px}.parent-field span{color:#0f172ac7;font-weight:800}.parent-field input,.parent-field select{background:#fffffff2;border:1px solid #0f172a26;border-radius:12px;font:inherit;padding:10px 12px;width:100%}.parent-field input[readonly]{background:#94a3b81f}.parent-check{align-items:flex-start;color:#0f172ad1;display:flex;font-weight:700;gap:8px;margin-top:10px}.parent-check input[type=checkbox]{flex:0 0 20px;height:20px;margin:2px 0 0;min-width:20px;padding:0;width:20px}.parent-check span{flex:1 1 auto}.parent-privacy-section .hint{text-align:left}.parent-privacy-section .parents-actions{flex-wrap:wrap;gap:8px;justify-content:flex-start}.pbar{margin-top:10px}.pbar-top{display:flex;gap:12px;justify-content:space-between;margin-bottom:6px}.pbar-label{align-items:center;display:inline-flex;font-weight:800;gap:10px}.pbar-value{color:#0f172ab3;font-weight:800}.pbar-track{background:#7c3aed1f;border-radius:999px;height:12px;overflow:hidden}.pbar-fill{background:linear-gradient(135deg,#7c3aed,#22d3ee);border-radius:999px;height:100%}.journey-chart{grid-gap:6px;align-items:end;display:grid;gap:6px;grid-template-columns:repeat(14,1fr);height:140px;margin-top:10px}.journey-bar{align-items:flex-end;background:#0f172a0f;border-radius:10px;display:flex;height:100%;overflow:hidden}.journey-fill{background:linear-gradient(180deg,#22d3ee,#7c3aed);border-radius:10px 10px 0 0;width:100%}.journey-labels{color:#0f172aa6;display:flex;font-weight:700;justify-content:space-between;margin-top:8px}.parents-list{grid-gap:10px;display:grid;gap:10px;margin-top:10px}.parents-actions{display:flex;justify-content:flex-end;margin-top:8px}.parents-row{grid-gap:12px;align-items:center;background:#7c3aed0f;border:1px solid #7c3aed24;border-radius:14px;display:grid;gap:12px;grid-template-columns:1fr 240px;padding:12px}.parents-story{color:#0f172a;font-weight:800}.parents-level{color:#0f172abf;font-weight:800;text-align:right}.admin-page{display:grid;min-height:60vh;place-items:center}.admin-card{background:#fffdf7;border:1px solid #0f172a14;border-radius:22px;box-shadow:0 18px 40px #0f172a1f;padding:22px;width:min(1100px,96vw)}.admin-head{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between}.admin-actions{align-items:center;display:inline-flex;gap:10px}.admin-table-head{color:#0f172ab8;font-weight:800;padding:0 12px 8px}.admin-row,.admin-table-head{grid-gap:12px;display:grid;gap:12px;grid-template-columns:2fr 1.2fr 1.2fr .8fr}.admin-row{align-items:center;background:#7c3aed0f;border:1px solid #7c3aed24;border-radius:14px;padding:12px}.admin-user{color:#0f172a;font-weight:800;overflow-wrap:anywhere}@media (max-width:900px){.admin-table-head{display:none}.admin-row{gap:6px;grid-template-columns:1fr}}.quiz-hero-art{background:linear-gradient(135deg,#8ec5ff,#b6a2ff);border-radius:16px;color:#fff;display:grid;font-size:48px;height:140px;margin-bottom:12px;place-items:center}.question{font-weight:700;margin:10px 0}.option-list{grid-gap:10px;display:grid;gap:10px}.option{background:#10b981;border:none;border-radius:12px;color:#fff;cursor:pointer;font-weight:700;padding:12px}.games-page{grid-gap:16px;display:grid;gap:16px}.games-hero{align-items:center;background:linear-gradient(120deg,#22d3ee,#a855f7);border-radius:18px;color:#0f172a;display:flex;gap:12px;justify-content:space-between;padding:18px}.games-title{font-size:clamp(24px,4vw,34px);margin:6px 0 4px}.games-sub{color:#0f172acc;margin:0;max-width:540px}.games-grid{grid-gap:12px;align-items:start;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.games-grid.icons{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.number-run-card{background:#fff;border:1px solid #e4ebf7;border-radius:18px;box-shadow:0 16px 32px #0f172a1a;grid-column:1/-1}.number-run-card,.number-run-play{grid-gap:12px;display:grid;gap:12px;padding:14px}.number-run-play{background:linear-gradient(145deg,#fdf2f8,#e0f2fe);border:1px solid #e5e7eb;border-radius:16px}.number-run-target{align-items:center;background:#0ea5e9;border-radius:12px;color:#fff;display:inline-flex;font-weight:800;gap:10px;padding:8px 12px;width:-webkit-fit-content;width:fit-content}.number-run-target .label{font-size:12px;letter-spacing:.08em;text-transform:uppercase}.number-run-target .value{font-size:20px}.number-run-track{display:flex;flex-wrap:wrap;gap:10px}.number-run-coin{background:linear-gradient(145deg,#fcd34d,#fbbf24);border:none;border-radius:14px;box-shadow:0 10px 16px #facc1559;color:#422006;cursor:pointer;font-weight:800;padding:12px 14px}.number-run-message{background:#0ea5e91f;border-radius:12px;color:#0f172a;font-weight:700;padding:10px 12px}.level-select{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:10px;display:inline-flex;gap:6px;padding:6px 8px}.level-select select{background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;font-weight:700;padding:6px 8px}.tictac-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(3,80px);justify-content:center;margin:10px 0}.tictac-cell{background:#fff;border:2px solid #e5e7eb;border-radius:12px;box-shadow:0 10px 16px #0f172a14;cursor:pointer;font-size:32px;font-weight:900;height:80px;width:80px}.game-card{grid-gap:0;background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 12px 28px #0f172a14;display:grid;gap:0;overflow:hidden}.game-card.small{min-height:240px}.game-card.icon-card{cursor:pointer;text-align:left;transition:transform .15s ease,box-shadow .2s ease}.game-card.icon-card:hover{box-shadow:0 14px 30px #0f172a1f;transform:translateY(-2px)}.game-card.icon-card .game-info{gap:6px}.number-run-card,.puzzle-card{grid-gap:12px;background:#fff;border:1px solid #e4ebf7;border-radius:18px;box-shadow:0 16px 32px #0f172a1a;display:grid;gap:12px;grid-column:1/-1;padding:14px}.puzzle-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(90px,1fr))}.puzzle-modes{display:flex;flex-wrap:wrap;gap:8px}.puzzle-tile{background:linear-gradient(145deg,#eef2ff,#e0f2fe);border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 10px 16px #0f172a14;color:#0f172a;cursor:pointer;font-size:26px;font-weight:800;padding:18px 12px}.puzzle-tile.flipped{background:#fff;border-color:#cbd5e1}.puzzle-tile.matched{background:#22c55e29;border-color:#22c55e}.runner-card{grid-gap:12px;background:#fff;border:1px solid #e4ebf7;border-radius:18px;box-shadow:0 16px 32px #0f172a1a;display:grid;gap:12px;grid-column:1/-1;padding:14px}.runner-head{align-items:center;display:flex;gap:12px;justify-content:space-between}.runner-title{font-size:22px;margin:4px 0 2px}.runner-controls{align-items:center;display:flex;gap:10px}.score-badge{background:linear-gradient(135deg,#22d3ee,#3b82f6);border-radius:14px;box-shadow:0 12px 20px #3b82f640;color:#0f172a;min-width:80px;padding:10px 12px;text-align:center}.runner-playfield{background:linear-gradient(180deg,#e0f2fe,#bfdbfe 60%,#fef3c7);border:1px solid #e0f2fe;border-radius:16px;box-shadow:inset 0 -4px 0 #0f172a14;cursor:pointer;height:260px;overflow:hidden;position:relative}.runner-playfield.over{filter:saturate(.85)}.runner-sky{background:radial-gradient(circle at 12% 18%,#ffffff80,#0000 28%),radial-gradient(circle at 70% 12%,#ffffff59,#0000 25%);inset:0;position:absolute}.runner-ground{background:repeating-linear-gradient(90deg,#fcd34d 0 16px,#fbbf24 16px 32px);border-top:4px solid #f59e0b;bottom:0;height:36px;left:0;position:absolute;right:0}.runner-santa{background:linear-gradient(180deg,#f43f5e,#d62839 70%,#a61b2a);border-radius:20px;box-shadow:0 12px 20px #f43f5e47;height:58px;left:18%;overflow:visible;position:absolute;transition:bottom 50ms linear;width:48px}.runner-santa .hat-top{background:#c0262d;border-radius:28px;box-shadow:inset -4px -4px 0 #0000001f;height:26px;left:6px;position:absolute;top:-20px;width:38px}.runner-santa .hat-brim{background:#fff;border-radius:12px;box-shadow:0 4px 8px #0f172a1f;height:12px;left:4px;position:absolute;top:-8px;width:44px}.runner-santa .hat-pom{background:#fff;border-radius:50%;box-shadow:0 4px 6px #0f172a1f;height:12px;position:absolute;right:-4px;top:-14px;width:12px}.runner-santa .face{background:#ffe2c7;border-radius:24px;box-shadow:inset 0 -3px 0 #0000000f;height:30px;left:8px;position:absolute;top:0;width:36px}.runner-santa .beard{background:#fff;border-radius:20px;box-shadow:0 6px 10px #00000014;height:30px;left:-2px;position:absolute;top:18px;width:52px}.runner-santa .mustache{background:#fff;border-radius:12px;box-shadow:inset 0 -2px 0 #0000000f;height:12px;left:12px;position:absolute;top:15px;width:30px}.runner-santa .nose{background:#ffc9a8;border-radius:10px;height:10px;left:22px;position:absolute;top:8px;width:12px}.runner-santa .eye{background:#0f172a;border-radius:50%;height:6px;position:absolute;top:5px;width:6px}.runner-santa .eye.left{left:12px}.runner-santa .eye.right{right:12px}.runner-santa .mouth{background:#0f172a;border-radius:0 0 10px 10px;height:6px;left:22px;position:absolute;top:22px;width:10px}.runner-santa .belt{border-radius:10px;bottom:14px;left:-4px;right:-4px}.runner-santa .belt,.runner-santa .buckle{background:#4b1e0a;height:12px;position:absolute}.runner-santa .buckle{border:3px solid #f4b41a;border-radius:4px;bottom:12px;left:16px;width:18px}.runner-santa .cuff{background:#fff;bottom:32px;height:10px}.runner-santa .cuff,.runner-santa:after{border-radius:10px;left:4px;position:absolute;right:4px}.runner-santa:after{background:#422006;bottom:-10px;content:"";height:14px}.runner-coin{background:linear-gradient(145deg,#fef3c7,#fcd34d 60%,#fbbf24);border-radius:14px;box-shadow:0 10px 16px #facc1559;height:32px;position:absolute;width:24px}.runner-coin:after{background:#f3ede0;border-radius:6px;bottom:-18px;box-shadow:inset 0 0 0 2px #fcd34d59;content:"";height:22px;width:6px}.runner-coin:after,.runner-message{left:50%;position:absolute;transform:translateX(-50%)}.runner-message{background:#ffffffd9;border-radius:999px;box-shadow:0 8px 16px #0f172a1f;color:#0f172a;font-weight:800;padding:6px 12px;top:10px}.runner-status{background:#7c3aed1f;border-radius:12px;color:#5b21b6;font-weight:700;padding:10px 12px}.runner-start{margin-top:8px}.game-thumb{height:180px;overflow:hidden;position:relative}.game-card.small .game-thumb{height:140px}.game-thumb.icon{display:grid;padding:12px;place-items:center}.game-thumb.floppy{background:linear-gradient(180deg,#38bdf8,#0ea5e9 70%,#22d3ee)}.game-thumb.santa{background:linear-gradient(180deg,#bfdbfe,#a5b4fc 60%,#fef3c7)}.santa-runner{background:linear-gradient(180deg,#f43f5e,#e11d48);border-radius:16px;box-shadow:0 12px 20px #f43f5e47;display:grid;height:54px;place-items:center;position:relative;width:48px}.santa-runner:before{background:#fff;border-radius:10px;box-shadow:0 4px 10px #0f172a29;content:"";height:18px;left:10px;position:absolute;top:-10px;width:28px}.santa-runner:after{background:#0f172a;border-radius:8px;bottom:-6px;content:"";height:10px;left:6px;position:absolute;width:36px}.coin.floating{animation:floatCoin 1.4s ease-in-out infinite;background:radial-gradient(circle at 30% 30%,#fef9c3,#facc15 60%,#d97706 100%);border-radius:50%;box-shadow:0 10px 16px #facc1559;height:22px;width:22px}@keyframes floatCoin{0%{transform:translateY(0)}50%{transform:translateY(-8px)}to{transform:translateY(0)}}.pipe{background:linear-gradient(180deg,#22c55e,#16a34a);border:4px solid #15803d;border-radius:10px;position:absolute;width:60px}.pipe.top{height:110px;left:22%;top:-10px}.pipe.bottom{bottom:-10px;height:110px;right:18%}.bird{background:#fbbf24;border-radius:12px 12px 10px 10px;box-shadow:0 10px 14px #0000001f;height:34px;left:44%;position:absolute;top:44%;width:44px}.bird:after{background:#0f172a;border-radius:50%;content:"";height:12px;position:absolute;right:-10px;top:10px;width:12px}.game-thumb.math-rush{background:linear-gradient(135deg,#fef3c7,#e0f2fe)}.game-thumb.puzzle{background:linear-gradient(145deg,#e0f2fe,#ede9fe);display:grid;place-items:center}.game-thumb.ttt{background:linear-gradient(145deg,#fef2f2,#e2e8f0);display:grid;place-items:center}.ttt-grid{grid-gap:6px;color:#0f172a;display:grid;font-weight:800;gap:6px;grid-template-columns:repeat(3,24px);grid-template-rows:repeat(3,24px)}.ttt-grid span{background:#fff;border-radius:6px;box-shadow:0 6px 12px #0f172a1f;display:grid;height:24px;place-items:center;width:24px}.puzzle-piece{background:#22c55e;border-radius:18px;box-shadow:0 12px 18px #22c55e47;height:68px;width:68px}.puzzle-piece.two{background:#7c3aed;box-shadow:0 12px 18px #7c3aed47;height:52px;margin-top:-10px;width:52px}.coin{background:#facc15;border-radius:50%;box-shadow:0 0 0 6px #facc1566;height:42px;left:36%;position:absolute;top:28%;width:42px}.coin.small{height:30px;left:60%;top:55%;width:30px}.runner{background:linear-gradient(135deg,#f472b6,#ec4899);border-radius:14px;bottom:24px;box-shadow:0 12px 22px #ec489959;height:46px;left:18%;position:absolute;width:46px}.game-info{align-items:center;display:flex;gap:12px;justify-content:space-between;padding:14px}.game-desc{color:#475569;margin:4px 0 0}.pill.ready{background:#22c55e24;color:#15803d}.coming-soon .game-info{justify-content:flex-start}.coming-badge{background:#0f172ad1;border-radius:999px;box-shadow:0 10px 18px #00000040;color:#fff;font-size:12px;font-weight:800;padding:6px 10px;position:absolute;right:10px;top:10px}.math-page{display:grid;min-height:65vh;place-items:center}.math-card{background:linear-gradient(160deg,#f3e8ff,#fffef7 50%,#e0f2fe);border:1px solid #e5e7eb;border-radius:22px;box-shadow:0 18px 38px #0f172a1f;padding:22px;width:min(620px,100%)}.math-head{align-items:center;display:flex;gap:16px;justify-content:space-between}.math-title{font-size:26px;margin:4px 0}.math-sub{color:#475569;margin:0}.math-score{background:#0ea5e9;border-radius:16px;box-shadow:0 12px 20px #0ea5e94d;color:#fff;min-width:88px;padding:10px 12px;text-align:center}.score-number{display:block;font-size:28px;font-weight:800;line-height:1}.score-label{font-size:13px;font-weight:700;opacity:.92}.math-problem{grid-gap:10px;align-items:center;background:#fff;border:1px solid #e4ebf7;border-radius:16px;box-shadow:inset 0 0 0 1px #7c3aed14;display:grid;gap:10px;grid-template-columns:1fr auto 1fr;justify-items:center;margin:18px 0 12px;padding:14px}.math-question{color:#1f2937;font-size:28px;font-weight:800}.math-question.mark{color:#7c3aed}.math-equals{color:#475569;font-size:24px;font-weight:700}.math-form{grid-gap:12px;display:grid;gap:12px}.math-label{color:#1f2937;font-weight:700}.math-actions{display:flex;flex-wrap:wrap;gap:10px}.math-message{background:#7c3aed1a;border-radius:12px;color:#5b21b6;font-weight:700;margin-top:10px;padding:12px}.math-hints{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}.hint-pill{background:#0ea5e91f;border-radius:999px;color:#0ea5e9;font-size:13px;font-weight:700;padding:8px 12px}.story-shell{background:radial-gradient(circle at top left,#ffffffeb,#fff0 34%),linear-gradient(180deg,#f8f4ef,#fcfaf7);border:1px solid #bba69442;border-radius:30px;box-shadow:0 20px 42px #0f172a1f;margin:0 auto;max-width:1340px;min-height:calc(100vh - 128px);padding:24px;position:relative}.story-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:18px;justify-content:space-between;margin-bottom:18px}.story-header-copy{grid-gap:8px;display:grid;gap:8px;max-width:760px;min-width:0}.story-breadcrumb{align-items:center;color:#7c5a42;display:inline-flex;font-size:12px;font-weight:800;gap:8px;letter-spacing:.03em;text-transform:uppercase}.story-breadcrumb-sep{opacity:.5}.story-title{color:#0f1c3f;font-size:clamp(24px,2.6vw,36px);line-height:1.05;margin:0;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.story-subtitle{color:#5f6b7a;font-size:17px;font-weight:600;margin:0}.story-header-actions{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.story-layout{grid-gap:20px;align-items:start;display:grid;gap:20px;grid-template-columns:minmax(0,1.22fr) minmax(320px,.78fr)}.story-card{grid-gap:14px;background:#ffffffeb;border:1px solid #bba69438;border-radius:24px;box-shadow:0 14px 30px #0f172a14;display:grid;gap:14px;min-height:100%;padding:18px 18px 16px}.story-card-top{grid-gap:12px;border-bottom:1px solid #0f172a14;display:grid;gap:12px;padding-bottom:12px}.story-chip-row{display:flex;flex-wrap:wrap;gap:8px}.story-chip{align-items:center;background:#f973161a;border:1px solid #f973162e;border-radius:999px;color:#c2410c;display:inline-flex;font-size:12px;font-weight:900;letter-spacing:.02em;min-height:32px;padding:6px 12px;text-transform:uppercase}.story-chip.muted{background:#0f172a0d;border-color:#0f172a14;color:#475569}.audio-row{grid-gap:12px;align-items:center;display:grid;gap:12px;grid-template-columns:auto 1fr}.story-audio-options{display:flex;flex-wrap:wrap;gap:12px}.story-audio-option{align-items:center;color:#475569e6;display:inline-flex;font-size:11px;font-weight:800;gap:8px;letter-spacing:.05em;text-transform:uppercase}.story-audio-option select{background:#fff;border:1px solid #0f172a14;border-radius:999px;color:#0f172a;font-weight:700;min-height:34px;padding:4px 14px}.play-btn{background:#f97316;border:none;border-radius:999px;box-shadow:0 8px 18px #f9731647;color:#fff;cursor:pointer;font-weight:800;height:38px;width:38px}.play-btn.stop{background:#7c3aed;box-shadow:0 8px 18px #7c3aed3d}.progress-wrap{grid-gap:10px;align-items:center;display:grid;gap:10px;grid-template-columns:1fr auto}.progress{background:#e2e8f0;border-radius:999px;height:8px;overflow:hidden;position:relative}.progress-bar{background:linear-gradient(90deg,#7c3aed,#8b5cf6);height:100%;left:0;position:absolute;top:0;width:45%}.progress-page-chip{background:#f1f5f9f2;border:1px solid #0f172a14;border-radius:999px;color:#64748b;font-size:10px;font-weight:900;letter-spacing:.04em;min-height:30px;padding:4px 10px;text-transform:uppercase}.progress-page-chip,.speed-option,.speed-segment{align-items:center;display:inline-flex}.speed-segment{background:#f1f5f9;border:1px solid #0f172a14;border-radius:999px;gap:4px;padding:3px}.speed-btn{background:#0000;border:none;border-radius:999px;color:#64748b;cursor:pointer;font-size:11px;font-weight:900;height:28px;min-width:38px}.speed-btn.active{background:#fff;box-shadow:0 1px 2px #0f172a24;color:#f97316}.volume{font-size:18px}.story-body{grid-gap:12px;display:grid;gap:12px;padding:0}.story-actions{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.story__text.large{text-wrap:pretty;color:#24324a;font-size:clamp(16px,1.55vw,18px);line-height:1.72;margin:0}.story__text.large:first-letter{color:#f97316;float:left;font-size:3.4em;font-weight:900;line-height:.82;padding-right:10px;padding-top:6px}.story-reading-surface{background:linear-gradient(180deg,#fffffff5,#fff8f0f0);border:1px solid #bba69433;border-radius:22px;box-shadow:inset 0 1px 0 #ffffffe6;padding:26px 26px 24px}.story-pager{grid-gap:10px;border-top:1px solid #0f172a14;display:grid;gap:10px;margin-top:8px;padding-top:10px}.story-page-indicator{color:#0f172aa6;font-weight:800;text-align:center}.story-pager-actions{align-items:center;display:flex;gap:12px;justify-content:space-between}.story-page-link{align-items:center;background:#0000;border:none;border-radius:999px;color:#0f172ad1;cursor:pointer;display:inline-flex;font-weight:900;gap:10px;justify-content:center;padding:6px 8px;transition:background .14s ease,transform .14s ease,color .14s ease}.story-page-link:hover{background:#7c3aed14;color:#0f172aeb;transform:translateY(-1px)}.story-page-link:focus-visible{outline:2px solid #7c3aeda6;outline-offset:2px}.story-page-link-next{color:#7c3aedeb}.story-page-link-icon{font-size:16px;font-weight:900;line-height:1}.next-btn{justify-self:end}.story-inline-actions{display:none}.icon-btn{background:linear-gradient(135deg,#f8fafc,#eef2f7);border:1px solid #d8dee9;border-radius:12px;box-shadow:0 6px 16px #0f172a14;cursor:pointer;display:grid;height:42px;place-items:center;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease;width:42px}.icon-btn .icon{font-size:18px}.icon-btn.skip{border-color:#93c5fd}.icon-btn.quiz{border-color:#f59e0b}.icon-btn:hover{box-shadow:0 10px 20px #0f172a1f;transform:translateY(-1px)}.story-illustration{background:linear-gradient(180deg,#efe9e5,#e7dfdb);border-radius:22px;display:grid;min-height:460px;overflow:hidden;padding:0;place-items:stretch;position:relative}.story-illustration-img{background:#0000;border:none;border-radius:0;height:100%;max-height:none;object-fit:cover;object-position:center;width:100%}.story-side{grid-gap:0;display:grid;gap:0}.story-illustration-card{background:#ffffffeb;border:1px solid #bba69438;border-radius:24px;box-shadow:0 14px 30px #0f172a14;display:grid;overflow:hidden}.story-illustration-footer{grid-gap:4px;display:grid;gap:4px;padding:14px 16px 16px}.story-illustration-kicker{color:#f97316;font-size:11px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.story-illustration-title{color:#0f172a;font-size:24px;font-weight:900}.story-quiz-panel{grid-gap:10px;display:grid;gap:10px}.story-quiz-panel-inline{margin-top:6px;padding-top:6px}.story-quiz-btn{border-radius:14px;box-shadow:0 12px 22px #0f172a1f;font-weight:900;min-height:52px}.story-quiz-btn.btn.ghost{background:#0f172a0d;border:1px solid #0f172a14;box-shadow:none;color:#0f172a7a}.story-quiz-note{color:#0f172a9e;font-size:12px;font-weight:700;margin:0;text-align:center}.story-hint{margin:0;text-align:left}.sample-upsell-panel{grid-gap:10px;background:linear-gradient(135deg,#7c3aed14,#22d3ee14);border:1px solid #7c3aed3d;border-radius:14px;display:grid;gap:10px;justify-items:start;margin-top:10px;padding:12px}.sample-upsell-text{color:#0f172ad1;font-weight:700;margin:0}@media (min-width:961px){.story-layout{align-items:stretch}.story-card{min-height:clamp(640px,80vh,860px)}.story-body{min-height:0}.story-side{position:-webkit-sticky;position:sticky;top:18px}}.moon{background:linear-gradient(145deg,#ffd966,#ffb347);border-radius:50%;box-shadow:-12px 0 0 #ffca7a;height:160px;left:56%;position:absolute;top:48%;transform:translate(-50%,-50%);width:160px}.cloud{border-radius:80px;bottom:30%;box-shadow:0 10px 24px #00000014;height:70px;left:18%;width:140px}.cloud,.cloud:after{background:#7b8df5;position:absolute}.cloud:after{border-radius:60px;content:"";height:60px;left:30px;top:-20px;width:80px}.stars{grid-gap:40px;color:#ffd966;display:grid;font-size:20px;gap:40px;inset:12%;place-items:center;position:absolute}.story-controls{border-top:1px solid #0f172a14;margin-top:6px;padding-top:10px}.badge-row{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-top:14px}.badge-card{align-items:center;background:#4b9af7;border-radius:12px;color:#fff;display:flex;font-weight:700;gap:10px;justify-content:center;padding:12px;text-align:center}.badge-icon{background:radial-gradient(circle at 30% 30%,#fff 0 18%,#0000 19%),radial-gradient(circle at 70% 35%,#ffffffd9 0 12%,#0000 13%),linear-gradient(145deg,#fbbf24,#f59e0b 45%,#d97706);border-radius:10px;box-shadow:0 10px 18px #0000002e;flex:0 0 auto;height:28px;width:28px}.badge-card.purple{background:#7c3aed;cursor:pointer}.steps-row{display:flex;font-weight:700;gap:8px;justify-content:center;margin-top:12px}.step.current{color:#0f1c3f}.step.done{color:#0ea5e9}.quiz__actions{display:flex;flex-wrap:wrap;gap:10px}.feedback{background:#7c3aed14;border-radius:12px;color:#7c3aed;color:var(--accent);font-weight:600;margin-top:10px;padding:12px}.error{color:#b91c1c;font-weight:600;margin-top:6px}.hint{color:#0f172ab3;font-weight:700;margin-top:10px;text-align:center}.modal-backdrop{background:#0f172a73;display:grid;inset:0;padding:20px;place-items:center;position:fixed;z-index:50}.modal-card{background:#fffdf7;border:1px solid #f5e7d3;border-radius:18px;box-shadow:0 18px 48px #0f172a38;padding:18px 16px;width:min(520px,100%)}.modal-card h3{color:#0f172a;font-size:22px;margin:0 0 8px}.modal-card p{color:#0f172ac7;font-weight:600;margin:0 0 10px}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:12px}.badge{background:#22c55e24;border-radius:10px;color:#15803d;font-weight:700;padding:8px 10px}.journal__list{grid-gap:8px;color:#1f2937;color:var(--mid);display:grid;gap:8px;margin:0;padding-left:18px}@media (max-width:960px){.dash-hero-banner{grid-template-columns:1fr}.dash-hero-left{align-items:flex-start;flex-direction:column}.dash-hero-mascot{height:auto;width:min(320px,70vw)}.fact-row,.hero,.input-row{grid-template-columns:1fr}.topbar{align-items:center;flex-direction:row;gap:10px;justify-content:space-between;position:relative}.nav-toggle{align-items:center;display:inline-flex;justify-content:center}.nav{align-items:stretch;background:#fffffff5;border:1px solid #0f172a1a;border-radius:14px;box-shadow:0 12px 24px #0f172a1f;display:none;flex-direction:column;gap:8px;margin-top:8px;padding:10px;width:100%}.nav.open{display:flex}.nav .nav-btn{border-radius:12px;min-height:42px;text-align:left;width:100%}.nav .nav-btn,.nav .nav-btn.active,.nav .nav-btn.premium{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border);box-shadow:0 6px 16px #0000000f;color:#0f172a}.topic-grid{grid-template-columns:repeat(2,minmax(160px,1fr))}.topic-grid.tiles{grid-template-columns:repeat(2,minmax(180px,1fr))}.badge-grid,.howto-grid{grid-template-columns:repeat(2,minmax(160px,1fr))}.story-shell{border-radius:22px;min-height:auto;padding:18px}.story-subtitle{font-size:15px}.story-card{padding:14px}.story-layout{grid-template-columns:1fr}.story-title{max-width:none}.story-side{order:-1}.story-illustration{min-height:260px}.story-body{max-height:none;overflow:visible}.steps-row{flex-wrap:wrap}}@media (max-width:768px){.login-hero{grid-gap:14px;border-radius:22px;display:grid;gap:14px;grid-template-columns:1fr;padding:24px 16px 28px;width:100%}.login-hero-media{border-radius:18px;padding:8px}.login-welcome-card{border-radius:18px;padding:18px 14px}.login-welcome-title{font-size:clamp(24px,6.6vw,34px)}.login-welcome-sub{font-size:15px}.login-info-title{font-size:13px}.login-info-sub{font-size:12px}.login-title{font-size:clamp(38px,10vw,50px);line-height:1.05;text-align:center}.login-illustration{aspect-ratio:1/1;border-radius:18px;height:auto;max-width:100%;min-height:0;padding:12px}.login-illustration-img{border-radius:16px}.login-btn{font-size:16px;min-height:46px;width:100%}.privacy-note{font-size:14px}.dash-hero-title{white-space:normal}.dash-hero-left{flex-direction:column}.dash-hero-copy,.dash-hero-left{align-items:center;text-align:center}}@media (max-width:600px){.app{padding:10px 10px 28px}.topbar{margin-bottom:8px}.brand{font-size:16px;gap:6px}.logo-mark{border-radius:8px;font-size:13px;height:24px;width:24px}.login-hero{border-radius:18px;gap:12px;grid-template-columns:1fr;padding:18px 12px 20px}.login-hero-media{border-radius:14px;padding:6px}.login-welcome-card{border-radius:14px;gap:10px;padding:14px 10px}.login-welcome-title{font-size:24px}.login-welcome-sub{font-size:14px}.login-sample-note{font-size:12px}.login-title{font-size:clamp(34px,11.5vw,44px)}.login-illustration{border-radius:14px;padding:8px}.login-illustration-img{border-radius:12px}.login-btn{font-size:15px;min-height:44px}.privacy-note{font-size:14px;line-height:1.45;padding:10px}.app-footer{gap:8px;justify-content:center;margin-top:16px}.app-footer .btn.link{font-size:13px;padding:8px 6px}.parents-card{padding:14px;width:min(900px,94vw)}.parents-head{align-items:flex-start}.parent-privacy-grid{gap:8px;grid-template-columns:1fr}.parent-field{min-width:0}.parent-check{grid-gap:8px;align-items:start;display:grid;gap:8px;grid-template-columns:26px 1fr}.parent-check span{min-width:0}.parent-check span,.parent-privacy-section .privacy-note{overflow-wrap:anywhere;word-break:break-word}.quiz-top{grid-template-columns:40px 1fr 40px}.quiz-back{border-radius:12px}.quiz-avatar,.quiz-back{height:40px;width:40px}.badge-grid,.howto-grid,.topic-grid,.topic-grid.tiles{grid-template-columns:1fr}.story-header{align-items:flex-start}.story-breadcrumb{flex-wrap:wrap}.story-header-actions{display:grid;grid-template-columns:1fr;width:100%}.story-header-actions .btn{width:100%}.story-illustration{min-height:220px}.story-illustration-img{max-height:300px}.moon{height:140px;width:140px}.audio-row.story-controls{grid-template-columns:auto 1fr}.audio-row.story-controls .progress{width:100%}.progress-wrap{gap:8px;grid-template-columns:1fr}.progress-page-chip{justify-self:start}.play-btn{height:42px;width:42px}.progress{height:10px}.story-audio-options{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.story-audio-option{justify-content:space-between;width:100%}.story-audio-option select{max-width:190px;width:100%}.story-pager-actions{align-items:stretch;flex-direction:column}.story-reading-surface{padding:18px 16px}.story-title{font-size:clamp(22px,7.4vw,32px);line-height:1.08}.story__text.large:first-letter{font-size:2.6em;padding-right:8px;padding-top:4px}}@media (max-width:480px){.parents-head{align-items:flex-start;flex-direction:column}.parents-head .btn{align-self:flex-start}.story-audio-options{grid-template-columns:1fr}}
/*# sourceMappingURL=main.04747844.css.map*/