:root{--bg-1: #fde68a;--bg-2: #fca5a5;--bg-3: #a5b4fc;--bg-4: #6ee7b7;--ink: #1f1147;--ink-soft: #4c3a8a;--paper: #ffffff;--paper-soft: #fff7ed;--primary: #7c3aed;--primary-2: #ec4899;--accent: #14b8a6;--good: #16a34a;--bad: #dc2626;--warn: #f59e0b;--radius-xl: 28px;--radius-lg: 20px;--radius-md: 14px;--radius-sm: 10px;--shadow-1: 0 10px 30px rgba(31, 17, 71, .12), 0 2px 6px rgba(31, 17, 71, .06);--shadow-2: 0 18px 50px rgba(31, 17, 71, .18), 0 6px 16px rgba(31, 17, 71, .1);--font: "Fredoka", "Baloo 2", "Nunito", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font);font-weight:500;color:var(--ink);background:radial-gradient(1200px 700px at 10% -10%,var(--bg-1) 0%,transparent 60%),radial-gradient(900px 600px at 110% 10%,var(--bg-2) 0%,transparent 55%),radial-gradient(900px 700px at 100% 110%,var(--bg-3) 0%,transparent 60%),radial-gradient(900px 600px at -10% 110%,var(--bg-4) 0%,transparent 60%),var(--page, #fffaf2);background-attachment:fixed;-webkit-font-smoothing:antialiased;overflow-x:hidden;transition:background-color .4s ease,color .4s ease}button,input,select{font-family:inherit;color:inherit}h1,h2,h3,h4,h5,h6{font-weight:600}button{cursor:pointer;border:none;background:none}.themed-bg{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;z-index:0}.bubble{position:absolute;border-radius:50%;opacity:.28;filter:blur(1px);animation:float 18s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0) translate(0)}50%{transform:translateY(-30px) translate(10px)}}.scape{position:fixed;left:0;right:0;bottom:0;width:100%;height:220px;z-index:0;pointer-events:none;opacity:.68}.scape>span{position:absolute;bottom:8px;display:inline-block;filter:drop-shadow(0 4px 6px rgba(0,0,0,.18))}.scape.jungle{height:260px}.scape.stars{position:fixed;top:0;height:100%}.scape.rainbow{height:320px}.scape.comic .boom{position:absolute;font-weight:600;font-size:28px;color:var(--bad);background:var(--paper);border-radius:18px;padding:6px 14px;box-shadow:var(--shadow-1);transform:rotate(-8deg)}.scape.candy>span{bottom:24px}.themed-bg.theme-space:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(2px 2px at 13% 22%,#fff,transparent 60%),radial-gradient(1px 1px at 28% 78%,#fff,transparent 60%),radial-gradient(1.5px 1.5px at 55% 18%,#cffafe,transparent 60%),radial-gradient(2px 2px at 71% 64%,#fff,transparent 60%),radial-gradient(1px 1px at 88% 41%,#fbcfe8,transparent 60%),radial-gradient(1.5px 1.5px at 41% 51%,#fff,transparent 60%),radial-gradient(1px 1px at 8% 68%,#fff,transparent 60%),radial-gradient(2px 2px at 62% 88%,#fff,transparent 60%),radial-gradient(1px 1px at 95% 8%,#fff,transparent 60%),radial-gradient(1.5px 1.5px at 22% 38%,#fff,transparent 60%);background-size:800px 800px;opacity:.9;animation:twinkle-bg 6s ease-in-out infinite}@keyframes twinkle-bg{0%,to{opacity:.6}50%{opacity:1}}.themed-bg.theme-ice:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(1.5px 1.5px at 14% 22%,#ffffff,transparent 60%),radial-gradient(1.5px 1.5px at 38% 78%,#ffffff,transparent 60%),radial-gradient(2px 2px at 62% 18%,#ffffff,transparent 60%),radial-gradient(1.5px 1.5px at 78% 64%,#ffffff,transparent 60%),radial-gradient(2px 2px at 22% 51%,#ffffff,transparent 60%);opacity:.7}.themed-bg.theme-comic .bubble{opacity:.18}.app{position:relative;z-index:1;min-height:100%;display:flex;flex-direction:column}.topbar{padding:max(14px,env(safe-area-inset-top)) 0 14px;position:sticky;top:0;z-index:10;background:color-mix(in oklab,var(--paper) 78%,transparent);backdrop-filter:blur(10px) saturate(120%);-webkit-backdrop-filter:blur(10px) saturate(120%)}.topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;width:min(1000px,100% - 32px);margin:0 auto;padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);box-sizing:border-box}.brand{display:flex;align-items:center;gap:10px;font-weight:600;font-size:22px;letter-spacing:.2px;min-width:0}.brand .brand-text{display:flex;flex-direction:column;min-width:0;line-height:1.1}.brand .logo{width:50px;height:50px;border-radius:14px;box-shadow:var(--shadow-1);flex-shrink:0;object-fit:cover;display:block}.brand small{color:var(--ink-soft);font-weight:600;font-size:13px;white-space:nowrap}.player-chip{display:inline-flex;align-items:center;gap:8px;background:var(--paper);border-radius:999px;padding:6px 14px 6px 8px;box-shadow:var(--shadow-1);font-weight:600}.player-chip .avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--primary));color:#fff;display:grid;place-items:center;font-size:14px}.player-chip .avatar-img{background:var(--paper-soft);padding:0;overflow:hidden}.player-chip .avatar-img img{width:100%;height:100%;object-fit:cover;display:block}.player-chip .chip-name{max-width:110px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-chip{cursor:pointer;border:none;font-size:14px}.container{flex:1;width:min(1000px,100% - 32px);margin:0 auto;padding:8px 0 40px}.card{background:var(--paper);border-radius:var(--radius-xl);box-shadow:var(--shadow-2);padding:28px}.topics-greeting{text-align:center;padding:24px 8px 4px}.topics-greeting h1{margin:0 0 6px;font-size:clamp(28px,5vw,38px)}.topics-greeting p{margin:0;color:var(--ink-soft);font-size:clamp(15px,2.5vw,18px)}.daily-banner{display:flex;align-items:center;gap:14px;width:100%;margin:20px 0 0;padding:16px 20px;border-radius:var(--radius-xl);background:linear-gradient(135deg,color-mix(in oklab,var(--primary) 22%,var(--paper)),color-mix(in oklab,var(--primary-2) 22%,var(--paper)));color:var(--ink);text-align:left;cursor:pointer;box-shadow:var(--shadow-1);transition:transform .12s ease,box-shadow .12s ease}.daily-banner:hover{transform:translateY(-2px);box-shadow:var(--shadow-2)}.daily-banner.done{background:linear-gradient(135deg,color-mix(in oklab,var(--good) 22%,var(--paper)),color-mix(in oklab,var(--accent) 22%,var(--paper)))}.daily-banner-emoji{font-size:36px;line-height:1;flex-shrink:0}.daily-banner-text{display:flex;flex-direction:column;gap:2px;flex:1}.daily-banner-text strong{font-size:18px;font-weight:600}.daily-banner-text small{color:var(--ink-soft);font-size:13px}.daily-banner-cta{color:var(--ink-soft);font-size:28px;line-height:1}.topics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;margin:28px 0}@media (max-width: 640px){.topics-grid{grid-template-columns:1fr;gap:14px;margin:20px 0}}.topic-card{position:relative;background:var(--paper);border-radius:var(--radius-xl);box-shadow:var(--shadow-2);padding:32px 24px 24px;text-align:left;cursor:pointer;border:3px solid transparent;transition:transform .15s ease,box-shadow .15s ease,border-color .2s;display:grid;gap:8px;min-height:200px;overflow:hidden}.topic-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(120% 80% at 100% 0%,color-mix(in oklab,var(--topic-accent, var(--primary)) 22%,transparent),transparent 60%);pointer-events:none}.topic-card:hover{transform:translateY(-4px);box-shadow:0 24px 60px #1f114738,0 8px 20px #1f11471f;border-color:var(--topic-accent, var(--primary))}.topic-card-emoji{font-size:64px;line-height:1}.topic-card-label{margin:6px 0 2px;font-size:clamp(22px,3.5vw,28px)}.topic-card-tag{margin:0;color:var(--ink-soft);font-size:15px;line-height:1.4}.topic-card-cta{margin-top:12px;display:inline-flex;align-items:center;gap:4px;color:var(--topic-accent, var(--primary));font-weight:600;font-size:16px}.topics-footer{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:24px}.rich-select{position:relative}.rich-select-trigger{display:none}@media (max-width: 640px){.rich-select-trigger{display:flex;align-items:center;gap:12px;width:100%;padding:14px 14px 14px 16px;margin:0 0 8px;background:var(--paper);border-radius:var(--radius-lg);box-shadow:var(--shadow-1);border:2px solid transparent;cursor:pointer;text-align:left;transition:border-color .15s,transform .1s}.rich-select[data-open=true] .rich-select-trigger{border-color:var(--primary)}.rich-select-trigger .trigger-emoji{font-size:26px;line-height:1;flex-shrink:0}.rich-select-trigger .trigger-text{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;line-height:1.2}.rich-select-trigger .trigger-text strong{font-size:16px;font-weight:600;color:var(--ink)}.rich-select-trigger .trigger-desc{font-size:13px;color:var(--ink-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rich-select-trigger .trigger-chevron{color:var(--ink-soft);font-size:14px;flex-shrink:0;transition:transform .15s}.rich-select[data-open=true] .trigger-chevron{transform:rotate(180deg)}.rich-select .rich-select-options{display:none}.rich-select[data-open=true] .rich-select-options{display:block;animation:rich-options-in .18s ease-out}}@keyframes rich-options-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.about-page,.legal-page{max-width:720px;margin:0 auto;padding:28px 24px}.about-page .back-link,.legal-page .back-link{margin-bottom:8px}.legal-page .legal-title{margin:4px 0;font-size:clamp(26px,4.4vw,32px)}.legal-page .legal-meta{margin:0 0 18px;color:var(--ink-soft);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.legal-page .legal-lede{margin:0 0 18px;color:var(--ink-soft);font-size:clamp(15px,2.6vw,17px);line-height:1.45}.legal-page .legal-section{margin:22px 0;padding-top:18px;border-top:1px solid color-mix(in oklab,var(--ink-soft) 15%,transparent)}.legal-page .legal-section:first-of-type{border-top:none;padding-top:0}.legal-page .legal-section h2{font-size:clamp(18px,3vw,22px);margin:0 0 10px}.legal-page .legal-section p{margin:0 0 10px;line-height:1.55;color:var(--ink)}.legal-page .legal-section ul{margin:0 0 10px;padding-left:20px;line-height:1.6}.legal-page .legal-section li{margin-bottom:4px}.legal-page a{color:var(--primary);font-weight:600;text-decoration:none}.legal-page a:hover{text-decoration:underline}.about-page .about-title{margin:4px 0;font-size:clamp(26px,4.4vw,32px)}.about-page .about-lede{margin:0 0 18px;color:var(--ink-soft);font-size:clamp(15px,2.6vw,17px);line-height:1.45}.about-page .about-section{margin:24px 0;padding-top:18px;border-top:1px solid color-mix(in oklab,var(--ink-soft) 15%,transparent)}.about-page .about-section:first-of-type{border-top:none;padding-top:0}.about-page .about-section h2{font-size:clamp(18px,3vw,22px);margin:0 0 10px}.about-page .about-section p{margin:0 0 10px;line-height:1.5;color:var(--ink)}.about-page .about-list{margin:0 0 8px;padding-left:20px;line-height:1.6}.about-page .about-list li{margin-bottom:4px}.about-page a{color:var(--primary);font-weight:600;text-decoration:none}.about-page a:hover{text-decoration:underline}.about-page .text-link{background:none;border:none;padding:0;color:var(--primary);font-weight:600;cursor:pointer;font-size:inherit;font-family:inherit}.about-page .text-link:hover{text-decoration:underline}.about-page .about-actions{display:flex;flex-direction:column;align-items:flex-start;gap:8px}.about-page .about-hint{margin:0;color:var(--ink-soft);font-size:13px}.about-page .about-credit{text-align:center;font-size:14px;color:var(--ink-soft)}.about-page .about-version-num{display:inline-block;padding:2px 10px;border-radius:999px;background:color-mix(in oklab,var(--primary) 10%,var(--paper-soft));color:var(--primary);font-weight:700;font-size:15px;letter-spacing:.02em}.stats-page{max-width:720px;margin:0 auto;padding:28px 24px}.stats-page .back-link{margin-bottom:8px}.stats-page .stats-title{margin:4px 0 6px;font-size:clamp(26px,4.4vw,32px)}.stats-page .stats-lede{margin:0 0 18px;color:var(--ink-soft);font-size:clamp(14px,2.4vw,16px);line-height:1.45}.stats-tabs{display:flex;gap:6px;padding:4px;background:var(--paper-soft);border-radius:999px;margin-bottom:18px;width:fit-content}.stats-tab{border:none;background:transparent;border-radius:999px;padding:8px 16px;font-weight:700;font-size:14px;color:var(--ink-soft);cursor:pointer;transition:background .15s,color .15s}.stats-tab.active{background:var(--paper);color:var(--ink);box-shadow:var(--shadow-1)}.leaderboard-embedded{padding:0}.leaderboard-embedded h2{font-size:22px}.stats-overall{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:16px 0 24px}.stats-overall-tile{background:var(--paper-soft);border-radius:var(--radius-md);box-shadow:var(--shadow-1);padding:14px 10px;text-align:center}.stats-overall-tile .num{font-size:clamp(20px,5vw,26px);font-weight:600;color:var(--primary)}.stats-overall-tile .lbl{font-size:12px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.04em}.stats-topic{margin:22px 0;padding-top:18px;border-top:1px solid color-mix(in oklab,var(--ink-soft) 14%,transparent)}.stats-topic>h2{display:flex;align-items:baseline;gap:10px;margin:0 0 12px;font-size:clamp(18px,3vw,22px)}.stats-topic>h2 small{margin-left:auto;color:var(--ink-soft);font-size:13px;font-weight:600}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:10px}.stats-tile{background:var(--paper-soft);border-radius:var(--radius-md);box-shadow:var(--shadow-1);padding:12px 10px;text-align:center;min-width:0}.stats-tile .num{font-size:22px;font-weight:600;color:var(--ink);word-break:break-word}.stats-tile .lbl{font-size:12px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.04em;margin-top:4px}.stats-tile .lbl small{text-transform:none;letter-spacing:0;font-size:11px;opacity:.8}.stats-recent{margin-top:24px;padding-top:18px;border-top:1px solid color-mix(in oklab,var(--ink-soft) 14%,transparent)}.stats-recent h2{margin:0 0 12px;font-size:clamp(18px,3vw,22px)}.stats-empty{margin:0;color:var(--ink-soft)}.stats-recent-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.stats-recent-row{display:flex;align-items:center;gap:10px;background:var(--paper-soft);border-radius:var(--radius-md);padding:10px 12px}.stats-recent-row .emoji{font-size:22px;flex-shrink:0}.stats-recent-meta{flex:1 1 auto;min-width:0}.stats-recent-title{font-weight:600;font-size:14px;color:var(--ink)}.stats-recent-title small{color:var(--ink-soft);font-weight:600}.stats-recent-sub{font-size:12px;color:var(--ink-soft);margin-top:2px}.stats-recent-score{font-weight:600;color:var(--primary);flex-shrink:0}.back-link{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:transparent;color:var(--ink-soft);font-weight:600;font-size:14px;border-radius:999px;margin:4px 0 14px;cursor:pointer;transition:background .15s,color .15s}.back-link:hover{background:var(--paper);color:var(--ink)}.hero{display:grid;grid-template-columns:1.2fr 1fr;gap:24px;align-items:center}@media (max-width: 760px){.hero{grid-template-columns:1fr}}.hero h1{font-size:clamp(28px,4.4vw,44px);margin:0 0 8px;line-height:1.05}.hero h1 .accent{color:var(--primary)}.hero p{color:var(--ink-soft);font-size:18px;margin:0 0 18px}.hero .cta-row{display:flex;gap:12px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 22px;border-radius:var(--radius-lg);font-weight:600;font-size:18px;background:var(--paper-soft);color:var(--ink);box-shadow:var(--shadow-1);transition:transform .12s ease,box-shadow .12s ease,background .2s}.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-2)}.btn:active{transform:translateY(0)}.btn.primary{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff}.btn.ghost{background:transparent;box-shadow:none}.btn.ghost:hover{background:#ffffff80}.btn.danger{background:var(--bad);color:#fff}.btn.small{padding:8px 14px;font-size:14px;border-radius:12px}.section-title{font-size:22px;margin:22px 4px 12px;display:flex;align-items:baseline;gap:10px}.section-title small{color:var(--ink-soft);font-weight:600;font-size:13px}.tile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}.tile-grid.compact{grid-template-columns:repeat(3,minmax(0,1fr));max-width:720px}@media (max-width: 520px){.tile-grid.compact{grid-template-columns:1fr}}.tile-grid.row-3{grid-template-columns:repeat(3,minmax(0,1fr));max-width:720px}@media (max-width: 520px){.tile-grid.row-3{gap:8px}.tile-grid.row-3 .tile{padding:10px}.tile-grid.row-3 .tile h3{font-size:15px}.tile-grid.row-3 .tile p{font-size:12px}.tile-grid.row-3 .tile .emoji{font-size:22px;margin-bottom:4px}}.tile-grid.row-4{grid-template-columns:repeat(4,minmax(0,1fr));max-width:720px}@media (max-width: 520px){.tile-grid.row-4{gap:8px}.tile-grid.row-4 .tile{padding:10px}.tile-grid.row-4 .tile h3{font-size:14px}.tile-grid.row-4 .tile p{font-size:11px}.tile-grid.row-4 .tile .emoji{font-size:20px;margin-bottom:4px}}.tile-grid.compact-2{grid-template-columns:repeat(2,minmax(0,1fr));max-width:720px}.topic-tile{text-align:center}.topic-tile .emoji{display:block;margin:4px auto 8px}.tile{background:var(--paper);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-1);text-align:left;transition:transform .12s,box-shadow .12s;border:3px solid transparent;position:relative}.tile:hover{transform:translateY(-3px);box-shadow:var(--shadow-2)}.tile.selected{border-color:var(--primary)}.tile .emoji{font-size:28px;line-height:1;display:inline-block;margin-bottom:8px}.tile h3{margin:0 0 4px;font-size:18px}.tile p{margin:0;color:var(--ink-soft);font-size:14px}.diff-tile{padding:14px}.diff-tile .dots{display:flex;gap:4px;margin-top:8px}.diff-tile .dot{width:10px;height:10px;border-radius:50%;background:#e5e7eb}.diff-tile .dot.on{background:var(--primary)}.game{display:grid;grid-template-rows:auto auto 1fr auto;gap:16px}.hud{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap}.hud .pill{background:var(--paper);border-radius:999px;padding:8px 14px;box-shadow:var(--shadow-1);font-weight:600;display:inline-flex;align-items:center;gap:8px}.hud .pill .label{color:var(--ink-soft);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.04em}.hud .pill.streak{background:linear-gradient(135deg,#fff,#ffe4f0)}.hud .pill.score{background:linear-gradient(135deg,#fff,#e0f7f1)}.hud .pill.timer{background:linear-gradient(135deg,#fff,#fff3c4)}.hud .progress{flex:1;min-width:160px;height:10px;background:#efe7ff;border-radius:999px;overflow:hidden;box-shadow:var(--shadow-1)}.hud .progress>div{height:100%;background:linear-gradient(90deg,var(--primary),var(--primary-2));transition:width .25s}.mode-banner{display:flex;align-items:center;justify-content:center;gap:14px;text-align:left}.mode-banner-text{min-width:0}.mode-banner-title{font-size:18px;font-weight:600}.mode-banner-desc{color:var(--ink-soft);font-weight:600;font-size:14px}.question-card{background:var(--paper);border-radius:var(--radius-xl);padding:22px;box-shadow:var(--shadow-2);display:grid;gap:18px;grid-template-columns:1fr 1fr;align-items:center}@media (max-width: 760px){.question-card{grid-template-columns:1fr}}.q-prompt{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}.q-prompt .label{font-size:14px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.q-prompt .big-time{font-size:clamp(40px,7vw,64px);font-weight:600;background:linear-gradient(135deg,var(--primary),var(--primary-2));-webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:1px}.q-prompt .big-words{font-size:clamp(22px,3.5vw,32px);font-weight:600;text-align:center;color:var(--ink)}.math-prompt{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:8px 14px;font-size:clamp(36px,7vw,56px);font-weight:600;line-height:1.1;letter-spacing:.5px}.math-prompt .math-num{color:var(--primary)}.math-prompt .math-op{color:var(--ink-soft);font-weight:600}.math-prompt .math-op.op-mul,.math-prompt .math-op.op-div{color:var(--primary-2)}.math-prompt .math-op.op-eq{color:var(--ink)}.math-prompt .math-blank{display:inline-grid;place-items:center;min-width:1.6em;padding:0 .2em;border-bottom:4px solid var(--primary);color:var(--primary);background:linear-gradient(180deg,transparent 60%,color-mix(in oklab,var(--primary) 12%,transparent) 100%);border-radius:8px 8px 4px 4px}.choices.choices-math{grid-template-columns:1fr 1fr}@media (max-width: 480px){.choices.choices-math{grid-template-columns:1fr 1fr}}.choices.choices-math .choice{font-size:clamp(22px,5vw,28px);font-weight:600;padding:18px 14px}.magic-card{background:var(--paper);border-radius:var(--radius-xl);padding:24px 18px 18px;box-shadow:var(--shadow-2);display:flex;flex-direction:column;align-items:center;gap:18px}.magic-prompt{margin:0;text-align:center;font-size:clamp(15px,2.6vw,18px);color:var(--ink);max-width:36ch}.magic-target{color:var(--primary);font-weight:600;font-size:1.15em}.magic-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;width:min(320px,100% - 16px);padding:6px;background:linear-gradient(135deg,color-mix(in oklab,var(--primary) 8%,var(--paper-soft)),color-mix(in oklab,var(--primary-2) 8%,var(--paper-soft)));border-radius:var(--radius-lg)}.magic-cell{aspect-ratio:1;border-radius:var(--radius-md);font-size:clamp(26px,6vw,34px);font-weight:600;color:var(--ink);cursor:pointer;display:grid;place-items:center;transition:transform .1s,border-color .15s,background .15s;background:var(--paper);border:3px dashed color-mix(in oklab,var(--ink-soft) 35%,transparent)}.magic-cell.locked{background:var(--paper);border:3px solid transparent;box-shadow:var(--shadow-1);cursor:default}.magic-cell.filled{background:var(--paper);border:3px solid var(--primary);box-shadow:var(--shadow-1);color:var(--primary)}.magic-cell.empty{background:transparent}.magic-cell.droppable{background:color-mix(in oklab,var(--primary) 10%,var(--paper));border-color:var(--primary);transform:scale(1.02)}.magic-cell:disabled{cursor:default}.magic-pool{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:8px;width:min(360px,100% - 16px)}@media (max-width: 480px){.magic-pool{grid-template-columns:repeat(3,minmax(0,1fr))}}.magic-tile{aspect-ratio:1;background:var(--paper);border-radius:var(--radius-md);box-shadow:var(--shadow-1);font-size:clamp(20px,5vw,24px);font-weight:600;color:var(--ink);cursor:pointer;border:3px solid transparent;transition:transform .12s,border-color .15s,box-shadow .15s;-webkit-tap-highlight-color:transparent}.magic-tile:active:not(:disabled){transform:translateY(1px)}.magic-tile.selected{border-color:var(--primary);transform:scale(1.08);box-shadow:0 14px 30px #1f11472e}.magic-tile:disabled{opacity:.5;cursor:default}.magic-actions{display:flex;justify-content:center;margin-top:4px}.magic-actions .btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:var(--shadow-1)}.magic-game .hud .pill.streak{display:none}.magic-hero-preview{display:grid;place-items:center;gap:10px;padding:18px 20px 22px;background:linear-gradient(135deg,color-mix(in oklab,var(--accent) 14%,var(--paper)),color-mix(in oklab,var(--primary) 14%,var(--paper)));border-radius:var(--radius-xl);box-shadow:var(--shadow-1);width:min(240px,100%)}.magic-hero-grid{display:grid;grid-template-columns:repeat(3,56px);gap:6px}.magic-hero-grid>span{aspect-ratio:1;display:grid;place-items:center;font-size:22px;font-weight:600;color:var(--primary);background:var(--paper);border-radius:10px;box-shadow:0 2px 6px #1f114714}.magic-hero-caption{font-size:13px;color:var(--ink-soft);font-weight:600;text-transform:uppercase;letter-spacing:.08em}.cross-card{background:var(--paper);border-radius:var(--radius-xl);padding:24px 14px 18px;box-shadow:var(--shadow-2);display:flex;flex-direction:column;align-items:center;gap:18px}.cross-grid{display:grid;gap:3px;width:min(360px,100% - 8px);margin:0 auto;justify-items:stretch;align-items:stretch}.cross-cell{aspect-ratio:1;display:grid;place-items:center;border-radius:8px;font-size:clamp(13px,3.6vw,17px);font-weight:600;color:var(--ink);background:var(--paper);border:1.5px solid color-mix(in oklab,var(--ink-soft) 22%,transparent);cursor:default;-webkit-user-select:none;user-select:none;transition:transform .1s,border-color .15s,background .15s;min-width:0;padding:0}.cross-cell.num-cell.locked{background:var(--paper)}.cross-cell.num-cell.blank{background:color-mix(in oklab,var(--primary) 9%,var(--paper));border-color:color-mix(in oklab,var(--primary) 65%,transparent);cursor:pointer;color:var(--primary)}.cross-cell.num-cell.blank.selected{border-color:var(--primary);border-width:2.5px;background:color-mix(in oklab,var(--primary) 18%,var(--paper));transform:scale(1.05);box-shadow:0 10px 22px #1f11472e;z-index:1}.cross-cell.num-cell.blank.filled{color:var(--primary)}.cross-cell:disabled{opacity:1}.cross-cell.op-cell{color:var(--primary);font-weight:600}.cross-cell.eq-cell{color:var(--ink-soft);font-weight:600}.cross-game .hud .pill.streak,.cross-game .hud .pill.score,.cross-game .hud .progress{display:none}.cross-keypad{width:min(340px,100% - 12px);margin:0 auto}.cross-reveal{background:none;border:none;color:var(--ink-soft);font-size:14px;font-weight:600;padding:8px 12px;border-radius:999px;cursor:pointer;text-decoration:underline;text-underline-offset:4px;margin-top:-4px}.cross-reveal:hover{color:var(--primary)}.cross-hero-preview{display:grid;place-items:center;gap:10px;padding:18px 20px 22px;background:linear-gradient(135deg,color-mix(in oklab,var(--primary) 14%,var(--paper)),color-mix(in oklab,var(--accent) 14%,var(--paper)));border-radius:var(--radius-xl);box-shadow:var(--shadow-1);width:min(260px,100%)}.cross-hero-grid{display:grid;grid-template-columns:repeat(5,36px);grid-auto-rows:36px;gap:4px;--cell-blank: color-mix(in oklab, var(--primary) 20%, var(--paper))}.cross-hero-grid .cell{display:grid;place-items:center;background:var(--paper);border-radius:6px;font-size:15px;font-weight:600;color:var(--ink);border:1.5px solid color-mix(in oklab,var(--ink-soft) 20%,transparent)}.cross-hero-grid .cell.op{color:var(--primary-2);border-color:transparent}.cross-hero-grid .cell.eq{color:var(--ink-soft);border-color:transparent}.cross-hero-grid .cell.blank{background:var(--cell-blank);border:2px solid color-mix(in oklab,var(--primary) 60%,transparent)}.keypad{display:flex;flex-direction:column;gap:12px;width:100%;max-width:360px;margin:0 auto}.keypad-display{background:var(--paper-soft);border-radius:var(--radius-lg);box-shadow:var(--shadow-1);padding:16px 18px;min-height:64px;font-size:36px;font-weight:600;color:var(--primary);text-align:center;letter-spacing:4px;display:flex;align-items:center;justify-content:center}.keypad-placeholder{color:var(--ink-soft);font-weight:600;font-size:15px;letter-spacing:0;opacity:.7}.keypad-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.keypad-key{background:var(--paper);border-radius:var(--radius-md);box-shadow:var(--shadow-1);font-size:26px;font-weight:600;color:var(--ink);padding:18px 0;cursor:pointer;transition:transform .08s ease,box-shadow .12s ease,background .15s;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.keypad-key:active:not(:disabled){transform:translateY(1px);box-shadow:var(--shadow-1)}.keypad-key:disabled{opacity:.45;cursor:not-allowed}.keypad-key.keypad-back{background:linear-gradient(135deg,#fff,#ffe4e4);font-size:22px}.keypad-key.keypad-submit{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;font-size:28px}.keypad-key.keypad-submit:disabled{background:var(--paper);color:var(--ink)}.choices{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media (max-width: 480px){.choices{grid-template-columns:1fr}}.choice{background:var(--paper-soft);border-radius:var(--radius-lg);padding:14px 16px;font-weight:600;font-size:18px;box-shadow:var(--shadow-1);text-align:center;transition:transform .1s ease,background .15s;border:3px solid transparent}.choice:hover{transform:translateY(-2px)}.choice.correct{background:#d1fae5;border-color:var(--good)}.choice.wrong{background:#fee2e2;border-color:var(--bad)}.choice.disabled{pointer-events:none;opacity:.8}.feedback{min-height:32px;margin-top:8px;text-align:center;font-size:22px;font-weight:600}.feedback.good,.feedback.bad{width:fit-content;max-width:90%;margin-left:auto;margin-right:auto;padding:8px 18px;border-radius:999px;background:color-mix(in oklab,var(--paper) 78%,transparent);backdrop-filter:blur(10px) saturate(120%);-webkit-backdrop-filter:blur(10px) saturate(120%);box-shadow:var(--shadow-1)}.feedback.good{color:var(--good)}.feedback.bad{color:var(--bad)}.footer-row{display:flex;justify-content:space-between;align-items:center;gap:12px}.mascot{display:inline-block;font-size:56px;line-height:1;transform-origin:center bottom;animation:bob 3.2s ease-in-out infinite}.mascot.happy{animation:cheer .6s ease 1}.mascot.sad{animation:shake .5s ease 1}@keyframes bob{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes cheer{0%{transform:scale(1) rotate(0)}30%{transform:scale(1.25) rotate(-8deg)}60%{transform:scale(1.15) rotate(8deg)}to{transform:scale(1)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.confetti-piece{position:fixed;top:-10px;width:8px;height:14px;border-radius:2px;animation:fall 1.6s linear forwards;z-index:30}@keyframes fall{to{transform:translateY(110vh) rotate(720deg);opacity:.85}}.clock-wrap{display:flex;justify-content:center;align-items:center}.clock{width:min(100%,320px);height:auto;touch-action:none;-webkit-user-select:none;user-select:none}.clock .face{fill:#fff;stroke:var(--ink);stroke-width:4}.clock .bezel{fill:none;stroke:url(#bezelGradient);stroke-width:10}.clock .tick{stroke:var(--ink)}.clock .tick.major{stroke-width:3}.clock .tick.minor{stroke-width:1.5;opacity:.55}.clock .num{font-weight:600;font-size:16px;fill:var(--ink)}.clock .hand-hour{stroke:var(--ink);stroke-width:7;stroke-linecap:round}.clock .hand-min{stroke:var(--primary);stroke-width:5;stroke-linecap:round}.clock .pivot{fill:var(--primary-2)}.clock .pivot-ring{fill:#fff}.clock .handle{fill:transparent;cursor:grab}.clock .handle.dragging{cursor:grabbing}.clock.interactive .hand-hour,.clock.interactive .hand-min{cursor:grab}.clock .digital-helper{font-size:14px;fill:var(--ink-soft);font-weight:600}.set-instructions{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;font-weight:600;color:var(--ink-soft)}.set-instructions .chip{background:var(--paper-soft);border-radius:999px;padding:6px 12px;box-shadow:var(--shadow-1)}.set-instructions .chip.hour{color:var(--ink)}.set-instructions .chip.min{color:var(--primary)}.set-actions{display:flex;gap:10px;justify-content:center;margin-top:10px}.leaderboard{overflow-x:auto}.leaderboard table{width:100%;border-collapse:collapse;font-weight:600;min-width:640px}.leaderboard-filters{margin-top:14px;display:flex;flex-direction:column;gap:10px}.topic-pills{display:flex;flex-wrap:wrap;gap:6px;padding:4px;background:var(--paper-soft);border-radius:999px;width:fit-content;max-width:100%}.topic-pill{border:none;background:transparent;border-radius:999px;padding:7px 14px;font-weight:700;font-size:13px;color:var(--ink-soft);cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.topic-pill.active{background:var(--paper);color:var(--ink);box-shadow:var(--shadow-1)}.leaderboard-mode-select{padding:8px 12px;border-radius:12px;border:2px solid #e5e7eb;background:var(--paper-soft);font-weight:600;width:100%}.leaderboard-selects{display:flex;flex-wrap:wrap;gap:10px}.leaderboard-scope-field{display:flex;flex-direction:column;gap:4px;min-width:140px;flex:1 1 140px}.leaderboard-scope-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft)}.leaderboard th,.leaderboard td{text-align:left;padding:10px 12px;border-bottom:1px solid #f1ecff}.leaderboard th{color:var(--ink-soft);font-size:13px;text-transform:uppercase;letter-spacing:.04em}.leaderboard tr.you td{background:#faf5ff}.leaderboard .medal{font-size:18px}.result{text-align:center;padding:12px 8px 4px}.result h2{font-size:36px;margin:6px 0 4px}.result .summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;max-width:640px;margin:18px auto}.result .summary .stat{background:var(--paper-soft);padding:14px 12px;border-radius:var(--radius-lg);box-shadow:var(--shadow-1);min-width:0;text-align:center}.result .summary .stat .num{font-size:30px;font-weight:600;color:var(--primary)}.result .summary .stat .lbl{color:var(--ink-soft);font-weight:600}@media (max-width: 640px){.result .summary{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.result .summary .stat{padding:12px 8px}.result .summary .stat .num{font-size:26px}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#140a3273;display:grid;place-items:center;z-index:50}.modal{background:var(--paper);border-radius:var(--radius-xl);padding:22px;width:min(820px,92vw);max-height:92vh;overflow-y:auto;box-shadow:var(--shadow-2)}.modal h3{margin:0 0 10px}.modal input{width:100%;padding:12px 14px;border-radius:var(--radius-md);border:2px solid #e5e7eb;background:var(--paper-soft);font-size:16px;font-weight:600}.modal input:focus{outline:none;border-color:var(--primary)}.foot{position:relative;z-index:5;margin-top:auto;padding:16px 18px calc(16px + env(safe-area-inset-bottom));text-align:center;color:var(--ink);font-size:13px;background:color-mix(in oklab,var(--paper) 90%,transparent);border-top:1px solid color-mix(in oklab,var(--ink-soft) 14%,transparent);backdrop-filter:blur(12px) saturate(120%);-webkit-backdrop-filter:blur(12px) saturate(120%)}.foot .foot-copy{margin-top:4px;font-size:12px;color:var(--ink-soft)}.foot .foot-copy a{color:var(--primary);text-decoration:none;font-weight:600}.foot .foot-copy a:hover{text-decoration:underline}[data-theme=candy]{--bg-1: #fde68a;--bg-2: #fca5a5;--bg-3: #a5b4fc;--bg-4: #6ee7b7;--ink: #1f1147;--ink-soft: #4c3a8a;--paper: #ffffff;--paper-soft: #fff7ed;--primary: #7c3aed;--primary-2: #ec4899;--accent: #14b8a6;--page: #fffaf2}[data-theme=ocean]{--bg-1: #bae6fd;--bg-2: #67e8f9;--bg-3: #93c5fd;--bg-4: #fef3c7;--ink: #0c2a4d;--ink-soft: #1d4e89;--paper: #ffffff;--paper-soft: #f0f9ff;--primary: #0369a1;--primary-2: #0891b2;--accent: #f97316;--page: #ecfeff}[data-theme=jungle]{--bg-1: #bbf7d0;--bg-2: #fed7aa;--bg-3: #fef08a;--bg-4: #86efac;--ink: #1a2e05;--ink-soft: #3f6212;--paper: #ffffff;--paper-soft: #f7fee7;--primary: #15803d;--primary-2: #ea580c;--accent: #ca8a04;--page: #f7fee7}[data-theme=princess]{--bg-1: #fbcfe8;--bg-2: #ddd6fe;--bg-3: #fef9c3;--bg-4: #fed7aa;--ink: #581c87;--ink-soft: #a21caf;--paper: #ffffff;--paper-soft: #fdf2f8;--primary: #db2777;--primary-2: #a855f7;--accent: #facc15;--page: #fdf2f8}[data-theme=space]{--bg-1: rgba(99,102,241,.45);--bg-2: rgba(168,85,247,.45);--bg-3: rgba(236,72,153,.4);--bg-4: rgba(34,211,238,.35);--ink: #f1f5f9;--ink-soft: #cbd5e1;--paper: #1e293b;--paper-soft: #0f172a;--primary: #a78bfa;--primary-2: #f472b6;--accent: #22d3ee;--page: #0b1027;--shadow-1: 0 10px 30px rgba(0, 0, 0, .5), 0 2px 6px rgba(0, 0, 0, .3);--shadow-2: 0 18px 50px rgba(0, 0, 0, .55), 0 6px 16px rgba(0, 0, 0, .35)}[data-theme=space] .clock .face{fill:#0f172a;stroke:#a78bfa}[data-theme=space] .clock .tick{stroke:#cbd5e1}[data-theme=space] .clock .num{fill:#e2e8f0}[data-theme=space] .clock .hand-hour{stroke:#f1f5f9}[data-theme=space] .hud .pill.streak{background:linear-gradient(135deg,#1e293b,#4c1d95)}[data-theme=space] .hud .pill.score{background:linear-gradient(135deg,#1e293b,#0e7490)}[data-theme=space] .hud .pill.timer{background:linear-gradient(135deg,#1e293b,#b45309)}[data-theme=space] .modal input,[data-theme=space] .leaderboard select{background:#0f172a;color:#f1f5f9;border-color:#334155}[data-theme=space] .leaderboard tr.you td{background:#1e1b4b}[data-theme=space] .leaderboard th,[data-theme=space] .leaderboard td{border-bottom-color:#334155}[data-theme=space] .choice.correct{background:#064e3b}[data-theme=space] .choice.wrong{background:#7f1d1d}[data-theme=unicorn]{--bg-1: #fce7f3;--bg-2: #ddd6fe;--bg-3: #c7d2fe;--bg-4: #bae6fd;--ink: #4a044e;--ink-soft: #86198f;--paper: #ffffff;--paper-soft: #fdf4ff;--primary: #c026d3;--primary-2: #6366f1;--accent: #f59e0b;--page: #fdf4ff}[data-theme=dino]{--bg-1: #d9f99d;--bg-2: #fde68a;--bg-3: #fed7aa;--bg-4: #a7f3d0;--ink: #14532d;--ink-soft: #4d7c0f;--paper: #ffffff;--paper-soft: #f7fee7;--primary: #166534;--primary-2: #b45309;--accent: #dc2626;--page: #f0fdf4}[data-theme=superhero]{--bg-1: #fef08a;--bg-2: #fca5a5;--bg-3: #93c5fd;--bg-4: #fdba74;--ink: #1e3a8a;--ink-soft: #1e40af;--paper: #ffffff;--paper-soft: #eff6ff;--primary: #dc2626;--primary-2: #2563eb;--accent: #facc15;--page: #fffbeb}[data-theme=ice]{--bg-1: #dbeafe;--bg-2: #cffafe;--bg-3: #e0e7ff;--bg-4: #d1fae5;--ink: #0c4a6e;--ink-soft: #155e75;--paper: #ffffff;--paper-soft: #f0f9ff;--primary: #2563eb;--primary-2: #06b6d4;--accent: #a78bfa;--page: #f0f9ff}[data-theme=pirate]{--bg-1: #fde68a;--bg-2: #fdba74;--bg-3: #14b8a6;--bg-4: #f59e0b;--ink: #422006;--ink-soft: #78350f;--paper: #fffbeb;--paper-soft: #fef3c7;--primary: #78350f;--primary-2: #f59e0b;--accent: #dc2626;--page: #fef3c7}.theme-picker-wrap{position:relative;display:inline-flex;align-items:center}.theme-toggle{display:inline-flex;align-items:center;gap:8px;background:var(--paper);color:var(--ink);border-radius:999px;padding:6px 12px;font-weight:600;font-size:14px;box-shadow:var(--shadow-1);cursor:pointer;white-space:nowrap;line-height:1}.icon-btn,.sound-toggle,.info-btn{display:inline-grid;place-items:center;width:36px;height:36px;background:var(--paper);border-radius:999px;box-shadow:var(--shadow-1);cursor:pointer;font-size:18px;line-height:1;border:none}.icon-btn:active{transform:scale(.96)}.sound-toggle[aria-pressed=false]{opacity:.7}.info-btn{font-family:Georgia,Times New Roman,serif;font-style:italic;font-weight:700;color:var(--primary)}.theme-toggle .swatch{width:20px;height:20px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-2));border:2px solid #fff;box-shadow:0 0 0 1px #0000000f;flex-shrink:0}.theme-toggle .arrow{opacity:.55;font-size:11px}.theme-popover{position:absolute;top:calc(100% + 8px);right:0;left:auto;z-index:40;width:420px;max-width:calc(100vw - 24px);background:var(--paper);color:var(--ink);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-2);box-sizing:border-box}.theme-popover h4{margin:0 0 12px;font-size:12px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.theme-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;box-sizing:border-box}.theme-card{display:flex;align-items:center;gap:10px;padding:12px;border-radius:var(--radius-md);background:var(--paper-soft);color:var(--ink);font-weight:600;font-size:15px;text-align:left;border:2px solid transparent;transition:transform .1s,border-color .15s,background .15s;cursor:pointer;min-width:0;overflow:hidden;line-height:1.1}.theme-card:hover{transform:translateY(-1px)}.theme-card.active{border-color:var(--primary);background:var(--paper)}.theme-card .emoji{font-size:22px;flex-shrink:0;line-height:1}.theme-card .name{flex:1 1 auto;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.theme-card .swatches{display:inline-flex;flex-shrink:0}.theme-card .sw{width:13px;height:13px;border-radius:50%;border:1.5px solid #fff;box-shadow:0 0 0 1px #0000000f;margin-left:-3px}.theme-card .sw:first-child{margin-left:0}.theme-popover:before{content:"";display:none}@media (max-width: 640px){.theme-popover{position:fixed;top:auto;bottom:max(16px,env(safe-area-inset-bottom));left:12px;right:12px;width:auto;max-width:none;max-height:75vh;overflow-y:auto;padding:18px}.theme-popover:before{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#140a3259;z-index:-1}.theme-grid{gap:10px}.theme-card{padding:14px 12px;font-size:15px;gap:8px}.theme-card .emoji{font-size:24px}.theme-card .swatches{display:none}}.topbar-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}@media (max-width: 760px){.hud{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-template-areas:"score streak timer" "progress progress progress" "round round quit";gap:10px;align-items:center}.hud .pill.score{grid-area:score}.hud .pill.streak{grid-area:streak}.hud .pill.timer{grid-area:timer}.hud .progress{grid-area:progress;width:100%;min-width:0}.hud .pill.round{grid-area:round;justify-content:center}.hud .hud-quit{grid-area:quit;justify-self:end;padding:8px 18px}.hud .pill{width:100%;justify-content:center}}@media (max-width: 640px){.topbar{padding:12px 14px;gap:8px;justify-content:center}.brand{font-size:18px;gap:8px;flex:1 1 auto}.brand .logo{width:42px;height:42px;font-size:18px;border-radius:12px}.brand small{font-size:11px}.topbar-right{gap:6px}.icon-btn{width:32px;height:32px;font-size:16px}.player-chip{padding:4px 10px 4px 4px;font-size:13px;gap:6px}.player-chip .avatar{width:34px;height:34px;font-size:12px}.container{width:min(1000px,100% - 16px);padding:6px 0 40px}.card{padding:18px;border-radius:22px}.question-card{padding:16px;gap:14px}.hud{gap:8px}.hud .pill{padding:6px 8px;font-size:13px;gap:4px}.hud .pill .label{font-size:10px}.mode-banner{gap:10px}.mascot{font-size:44px}.mode-banner-title{font-size:16px}.mode-banner-desc{font-size:13px}.q-prompt .big-time{font-size:clamp(36px,12vw,56px)}.q-prompt .big-words{font-size:clamp(20px,6vw,28px)}.set-actions{flex-wrap:wrap}.set-actions .btn{flex:1 1 140px}}@media (max-width: 360px){.brand small,.player-chip .chip-name{display:none}}.player-modal .player-modal-body{display:grid;grid-template-columns:220px minmax(0,1fr);gap:22px;align-items:start}@media (max-width: 640px){.player-modal .player-modal-body{grid-template-columns:1fr;gap:16px}}.player-modal-left{display:flex;flex-direction:column;gap:12px;align-items:center;text-align:center}.player-modal-left input{width:100%}.avatar-preview{width:180px;height:180px;border-radius:50%;overflow:hidden;background:var(--paper-soft);border:4px solid var(--paper);box-shadow:var(--shadow-2),0 0 0 4px color-mix(in oklab,var(--primary) 35%,transparent);display:grid;place-items:center;font-size:64px;color:var(--ink-soft)}.avatar-preview img{width:100%;height:100%;object-fit:cover;display:block}.avatar-preview-name{font-weight:600;font-size:16px;color:var(--ink);word-break:break-word}@media (max-width: 640px){.avatar-preview{width:130px;height:130px;font-size:48px}}.player-modal-right{min-width:0;display:flex;flex-direction:column;gap:8px}.player-modal-right .avatar-grid{max-height:56vh;overflow-y:auto;padding-right:4px}.avatar-picker-label{font-size:12px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin-bottom:8px}.avatar-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(54px,1fr));gap:8px}.avatar-option{display:grid;place-items:center;aspect-ratio:1 / 1;border-radius:50%;border:2px solid transparent;background:var(--paper-soft);font-size:22px;line-height:1;cursor:pointer;overflow:hidden;padding:0;transition:transform .1s,border-color .15s,background .15s,box-shadow .15s}.avatar-option img{width:100%;height:100%;object-fit:cover;display:block}.avatar-option:hover{transform:translateY(-1px)}.avatar-option.active{border-color:var(--primary);background:var(--paper);box-shadow:0 0 0 3px color-mix(in oklab,var(--primary) 25%,transparent)}@media (max-width: 480px){.avatar-grid{grid-template-columns:repeat(auto-fit,minmax(46px,1fr))}}.settings-page .settings-title{margin:8px 0 6px;font-size:28px}.settings-page .settings-lede{color:var(--ink-soft);margin:0 0 18px}.settings-section{margin-top:22px}.settings-section h2{font-size:14px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft);font-weight:700;margin:0 0 10px}.settings-toggle{display:flex;align-items:center;gap:14px;width:100%;background:var(--paper-soft);border:2px solid transparent;border-radius:var(--radius-lg);padding:14px 16px;cursor:pointer;text-align:left;transition:border-color .15s,background .15s}.settings-toggle.on{border-color:var(--primary);background:var(--paper)}.settings-toggle-icon{font-size:28px;line-height:1;width:44px;height:44px;display:grid;place-items:center;border-radius:50%;background:var(--paper);box-shadow:var(--shadow-1);flex-shrink:0}.settings-toggle.on .settings-toggle-icon{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff}.settings-toggle-text{display:flex;flex-direction:column;gap:2px}.settings-toggle-text strong{font-size:16px}.settings-toggle-text small{color:var(--ink-soft);font-size:13px}.settings-theme-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}@media (min-width: 720px){.settings-theme-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.settings-link{display:flex;align-items:center;justify-content:space-between;width:100%;background:var(--paper-soft);border:none;border-radius:var(--radius-lg);padding:14px 18px;font-size:15px;font-weight:600;color:var(--ink);cursor:pointer;transition:background .15s}.settings-link+.settings-link{margin-top:8px}.settings-link:hover{background:var(--paper)}.settings-link span:last-child{color:var(--ink-soft);font-size:22px;line-height:1}.settings-link.danger{background:color-mix(in oklab,var(--bad) 8%,var(--paper-soft));color:var(--bad);border-left:4px solid var(--bad)}.settings-link.danger:hover{background:color-mix(in oklab,var(--bad) 14%,var(--paper-soft))}.settings-link.danger span:last-child{color:var(--bad)}.settings-hint{margin:8px 6px 0;color:var(--ink-soft);font-size:13px;line-height:1.4}html:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:-1;opacity:0;background-repeat:repeat;background-position:0 0;transition:opacity .4s ease}html[data-bg=off]:before{opacity:0;background:none}html[data-bg=dots]:before{opacity:.06;background-image:radial-gradient(circle,#be185d 1.2px,transparent 1.6px);background-size:22px 22px}html[data-bg=ripple]:before{opacity:.05;background-image:repeating-linear-gradient(0deg,transparent 0 18px,rgba(2,132,199,.5) 18px 19px,transparent 19px 36px)}html[data-bg=leaves]:before{opacity:.05;background-image:repeating-linear-gradient(45deg,transparent 0 20px,rgba(22,101,52,.45) 20px 21px,transparent 21px 42px)}html[data-bg=damask]:before{opacity:.05;background-image:repeating-conic-gradient(from 45deg,rgba(168,85,247,.55) 0deg 6deg,transparent 6deg 90deg);background-size:40px 40px}html[data-bg=starfield]:before{opacity:.35;background-color:transparent;background-image:radial-gradient(1px 1px at 12% 18%,#f8fafc 50%,transparent 51%),radial-gradient(1px 1px at 38% 64%,#c7d2fe 50%,transparent 51%),radial-gradient(1px 1px at 71% 22%,#e9d5ff 50%,transparent 51%),radial-gradient(1px 1px at 84% 78%,#fbcfe8 50%,transparent 51%),radial-gradient(1px 1px at 25% 90%,#93c5fd 50%,transparent 51%),radial-gradient(1px 1px at 56% 8%,#fde68a 50%,transparent 51%);background-size:480px 320px}html[data-bg=clouds]:before{opacity:.05;background-image:repeating-radial-gradient(circle at 25% 50%,rgba(168,85,247,.6) 0 2px,transparent 2px 30px);background-size:80px 80px}html[data-bg=earth]:before{opacity:.06;background-image:repeating-linear-gradient(135deg,transparent 0 8px,rgba(120,53,15,.5) 8px 9px,transparent 9px 18px),repeating-linear-gradient(45deg,transparent 0 12px,rgba(120,53,15,.35) 12px 13px,transparent 13px 26px)}html[data-bg=halftone]:before{opacity:.04;background-image:radial-gradient(circle,#ef4444 1.6px,transparent 2px);background-size:14px 14px}html[data-bg=snow]:before{opacity:.35;background-color:transparent;background-image:radial-gradient(1.5px 1.5px at 18% 26%,#ffffff 50%,transparent 51%),radial-gradient(1.5px 1.5px at 42% 72%,#ffffff 50%,transparent 51%),radial-gradient(1.5px 1.5px at 66% 12%,#ffffff 50%,transparent 51%),radial-gradient(1.5px 1.5px at 88% 58%,#ffffff 50%,transparent 51%),radial-gradient(1.5px 1.5px at 30% 92%,#ffffff 50%,transparent 51%);background-size:360px 240px}html[data-bg=parchment]:before{opacity:.06;background-image:repeating-linear-gradient(0deg,transparent 0 3px,rgba(120,53,15,.4) 3px 4px,transparent 4px 7px),repeating-linear-gradient(90deg,transparent 0 3px,rgba(120,53,15,.3) 3px 4px,transparent 4px 7px)}@media (prefers-reduced-motion: no-preference){html:not([data-bg=off]):before{animation:bg-pattern-drift 60s linear infinite}}@keyframes bg-pattern-drift{0%{background-position:0 0}to{background-position:80px 80px}}html[data-control=candy] .keypad-key,html[data-control=candy] .magic-tile,html[data-control=candy] .magic-cell.filled{background:radial-gradient(circle at 30% 25%,#fff,#fde68a 65%,#fca5a5);color:#7a1734;box-shadow:0 6px #be185d40,0 1px #fff inset;border:2px solid #fbcfe8}html[data-control=glass] .keypad-key,html[data-control=glass] .magic-tile,html[data-control=glass] .magic-cell.filled{background:linear-gradient(135deg,#bae6fdd9,#7dd3fc99);color:#0c4a6e;border:2px solid rgba(255,255,255,.7);box-shadow:0 6px 16px #0284c740,inset 0 1px #fff9}html[data-control=leaf] .keypad-key,html[data-control=leaf] .magic-tile,html[data-control=leaf] .magic-cell.filled{background:linear-gradient(135deg,#bbf7d0,#86efac);color:#14532d;border-radius:22px 8px;border:2px solid #166534;box-shadow:0 4px #14532d59}html[data-control=satin] .keypad-key,html[data-control=satin] .magic-tile,html[data-control=satin] .magic-cell.filled{background:linear-gradient(160deg,#fce7f3,#fbcfe8 60%,#f9a8d4);color:#831843;border:2px solid #fcd34d;box-shadow:0 6px #be185d38,inset 0 1px #fff}html[data-control=holo] .keypad-key,html[data-control=holo] .magic-tile,html[data-control=holo] .magic-cell.filled{background:linear-gradient(135deg,#312e81,#6d28d9 45%,#be185d);color:#f5f3ff;border:2px solid #a78bfa;box-shadow:0 0 14px #a78bfa8c,inset 0 0 10px #f472b659}html[data-control=pastel] .keypad-key,html[data-control=pastel] .magic-tile,html[data-control=pastel] .magic-cell.filled{background:linear-gradient(135deg,#fce7f3,#c7d2fe 50%,#bae6fd);color:#4c1d95;border:2px solid #fff;box-shadow:0 6px #818cf840}html[data-control=stone] .keypad-key,html[data-control=stone] .magic-tile,html[data-control=stone] .magic-cell.filled{background:linear-gradient(135deg,#a8a29e,#78716c);color:#fef3c7;border-radius:18px 14px 22px 10px;border:2px solid #44403c;box-shadow:0 4px #1c191766}html[data-control=comic] .keypad-key,html[data-control=comic] .magic-tile,html[data-control=comic] .magic-cell.filled{background:#fef08a;color:#1f1147;border:3px solid #1f1147;box-shadow:4px 4px #1f1147;border-radius:14px}html[data-control=ice] .keypad-key,html[data-control=ice] .magic-tile,html[data-control=ice] .magic-cell.filled{background:linear-gradient(135deg,#fffffff2,#cffafe 55%,#a5f3fc);color:#0c4a6e;border:2px solid #e0f2fe;box-shadow:0 6px 14px #38bdf84d,inset 0 1px #fff}html[data-control=wood] .keypad-key,html[data-control=wood] .magic-tile,html[data-control=wood] .magic-cell.filled{background:linear-gradient(180deg,#c08552,#8b5a2b);color:#fff8e8;border:2px solid #5b3a1a;box-shadow:0 4px #5b3a1a8c,inset 0 1px #ffffff2e}.clock-hands-lollipop .hand-hour{stroke:#be185d}.clock-hands-lollipop .hand-min{stroke:#f97316}.clock-hands-lollipop .pivot{fill:#fde68a}.clock-hands-seaweed .hand-hour{stroke:#0f766e}.clock-hands-seaweed .hand-min{stroke:#14b8a6}.clock-hands-seaweed .pivot{fill:#fef3c7}.clock-hands-bamboo .hand-hour{stroke:#166534}.clock-hands-bamboo .hand-min{stroke:#84cc16}.clock-hands-bamboo .pivot{fill:#fde68a}.clock-hands-rose .hand-hour{stroke:#9d174d}.clock-hands-rose .hand-min{stroke:#db2777}.clock-hands-rose .pivot{fill:#fcd34d}.clock-hands-comet .hand-hour{stroke:#f5f3ff;stroke-width:8}.clock-hands-comet .hand-min{stroke:#f472b6;stroke-width:6}.clock-hands-comet .pivot{fill:#a78bfa}.clock-hands-wand .hand-hour{stroke:#c026d3}.clock-hands-wand .hand-min{stroke:#f472b6}.clock-hands-wand .pivot{fill:#fef9c3}.clock-hands-bone .hand-hour{stroke:#44403c}.clock-hands-bone .hand-min{stroke:#78716c}.clock-hands-bone .pivot{fill:#fef3c7}.clock-hands-bolt .hand-hour{stroke:#1d4ed8;stroke-width:8}.clock-hands-bolt .hand-min{stroke:#f59e0b;stroke-width:6}.clock-hands-bolt .pivot{fill:#fef08a}.clock-hands-icicle .hand-hour{stroke:#0c4a6e}.clock-hands-icicle .hand-min{stroke:#38bdf8}.clock-hands-icicle .pivot{fill:#e0f2fe}.clock-hands-sword .hand-hour{stroke:#44403c;stroke-width:8}.clock-hands-sword .hand-min{stroke:#d97706;stroke-width:5}.clock-hands-sword .pivot{fill:#fcd34d}.daily-page{padding:24px}.daily-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin:8px 0 24px}.daily-header h1{margin:0 0 4px;font-size:clamp(22px,4vw,32px)}.daily-header p{margin:0;color:var(--ink-soft);font-size:15px}.daily-header-text{flex:1}.daily-progress{text-align:center;min-width:96px;padding:10px 16px;border-radius:var(--radius-lg);background:var(--paper-soft);box-shadow:var(--shadow-1)}.daily-progress-num{font-size:28px;font-weight:700;color:var(--primary);line-height:1}.daily-progress-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft);margin-top:4px}.daily-cards{display:grid;gap:14px}.daily-card{display:flex;align-items:center;gap:16px;width:100%;padding:18px 20px;background:var(--paper);border-radius:var(--radius-xl);border:3px solid transparent;box-shadow:var(--shadow-1);text-align:left;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .15s}.daily-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-2)}.daily-card.done{border-color:color-mix(in oklab,var(--good) 60%,transparent);background:color-mix(in oklab,var(--good) 8%,var(--paper))}.daily-card-emoji{font-size:40px;line-height:1;flex-shrink:0}.daily-card-body{flex:1}.daily-card-body h3{margin:0 0 4px;font-size:18px}.daily-card-body p{margin:0;color:var(--ink-soft);font-size:14px}.daily-card-state{font-size:26px;color:var(--primary);line-height:1}.daily-card.done .daily-card-state{color:var(--good)}.daily-celebrate{margin-top:18px;padding:14px 18px;border-radius:var(--radius-lg);background:linear-gradient(135deg,color-mix(in oklab,var(--good) 22%,var(--paper)),color-mix(in oklab,var(--accent) 22%,var(--paper)));font-weight:600;text-align:center}.daily-card[disabled],.daily-card[aria-disabled=true]{cursor:default;opacity:.85}.daily-card[disabled]:hover,.daily-card[aria-disabled=true]:hover{transform:none;box-shadow:var(--shadow-1)}.daily-result-banner{margin:16px auto 0;max-width:540px;padding:12px 18px;border-radius:var(--radius-lg);background:linear-gradient(135deg,color-mix(in oklab,var(--primary) 18%,var(--paper)),color-mix(in oklab,var(--primary-2) 18%,var(--paper)));font-weight:600;text-align:center;display:flex;flex-direction:column;gap:4px}.daily-result-total{font-size:14px;color:var(--ink-soft)}.daily-result-total strong{color:var(--ink);font-size:16px}.daily-totals{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 18px;margin:0 0 18px;border-radius:var(--radius-lg);background:linear-gradient(135deg,color-mix(in oklab,var(--accent) 14%,var(--paper-soft)),color-mix(in oklab,var(--primary) 14%,var(--paper-soft)));box-shadow:var(--shadow-1)}.daily-totals-total{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.daily-totals-num{font-size:30px;font-weight:700;color:var(--primary);line-height:1}.daily-totals-lbl{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft)}.daily-totals-split{display:flex;gap:10px}.daily-totals-cell{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:56px;padding:6px 10px;border-radius:var(--radius-md);background:var(--paper);box-shadow:var(--shadow-1)}.daily-totals-cell.empty{background:color-mix(in oklab,var(--ink-soft) 6%,var(--paper))}.daily-totals-cell-emoji{font-size:20px;line-height:1}.daily-totals-cell-val{font-weight:700;color:var(--ink)}.daily-totals-cell.empty .daily-totals-cell-val{color:var(--ink-soft)}@media (max-width: 480px){.daily-totals{flex-direction:column;align-items:flex-start}.daily-totals-split{width:100%;justify-content:space-between}.daily-totals-cell{flex:1}}
