@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--ease-out:cubic-bezier(0, 0, .2, 1);--ease-in-out:cubic-bezier(.4, 0, .2, 1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.start{inset-inline-start:var(--spacing)}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.grow{flex-grow:1}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.border{border-style:var(--tw-border-style);border-width:1px}.break-all{word-break:break-all}.capitalize{text-transform:capitalize}.lowercase{text-transform:lowercase}.uppercase{text-transform:uppercase}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,)}.underline{text-decoration-line:underline}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}}:root,[data-mode=kid]{--bg:#faf6f1;--fg:#3d3229;--primary:#c77b5a;--primary-soft:#f5ece5;--primary-hover:#b06a4a;--accent:#7ea88b;--success:#7ea88b;--danger:#c75f5f;--warning:#d4a24e;--card:#fff;--border:#e8ddd2;--muted:#8c7a6b;--radius:1rem;--font-size-base:1.05rem;--shadow:0 2px 12px #3d32290f;--key-bg:#faf6f1;--key-border:#e0d4c8;--key-target-glow:#c77b5a40;--background:var(--bg);--foreground:var(--fg)}[data-mode=adult]{--bg:#f4f2ee;--fg:#2c2c35;--primary:#6b7c95;--primary-soft:#edf0f5;--primary-hover:#566a82;--accent:#7ea88b;--success:#6b9e7a;--danger:#b85c5c;--warning:#c49a4a;--card:#fff;--border:#ddd9d3;--muted:#7a7a85;--radius:.625rem;--font-size-base:1rem;--shadow:0 1px 8px #2c2c350d;--key-bg:#f4f2ee;--key-border:#d4d0ca;--key-target-glow:#6b7c9533;--background:var(--bg);--foreground:var(--fg)}[data-mode=high-contrast]{--bg:#000;--fg:#fff;--primary:#fc0;--primary-soft:#332b00;--primary-hover:#ffe066;--accent:#0ca;--success:#0c6;--danger:#f44;--warning:#fa0;--card:#111;--border:#444;--muted:#aaa;--radius:.5rem;--font-size-base:1.1rem;--shadow:none;--key-bg:#1a1a1a;--key-border:#666;--key-target-glow:#fc06;--background:var(--bg);--foreground:var(--fg)}[data-font=dyslexia] body{letter-spacing:.05em;font-family:Comic Sans MS,OpenDyslexic,cursive;line-height:1.8}[data-fontsize=sm]{--font-size-base:.875rem}[data-fontsize=md]{--font-size-base:1rem}[data-fontsize=lg]{--font-size-base:1.2rem}[data-fontsize=xl]{--font-size-base:1.5rem}html{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}*,:before,:after{box-sizing:border-box}a{color:inherit;text-decoration:none}body{min-height:100vh;color:var(--fg);font-family:Georgia,Palatino,Times New Roman,serif;font-size:var(--font-size-base);margin:0;line-height:1.6;transition:background .3s,color .3s}[data-mode=kid] body{background:var(--bg);background-image:radial-gradient(circle at 20% 80%,#c77b5a08 0%,#0000 50%),radial-gradient(circle at 80% 20%,#7ea88b08 0%,#0000 50%)}[data-mode=adult] body{background:var(--bg);background-image:radial-gradient(circle at 30% 70%,#6b7c9508 0%,#0000 50%)}[data-mode=high-contrast] body{background:#000}.container-shell{max-width:1200px;margin:0 auto;padding:1.25rem}.app-layout{grid-template-columns:1fr;gap:1.25rem;display:grid}@media (min-width:1100px){.app-layout{grid-template-columns:minmax(0,1fr) 260px;align-items:start}}.progress-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;display:grid}.lesson-stage-grid{grid-template-columns:1fr;gap:1rem;display:grid}@media (min-width:960px){.lesson-stage-grid{grid-template-columns:minmax(0,1.7fr) minmax(280px,.9fr)}}.card{border:1px solid var(--border);border-radius:var(--radius);background:var(--card);box-shadow:var(--shadow);transition:box-shadow .2s,transform .2s}.card:hover{box-shadow:0 4px 16px #3d322914}.btn{border-radius:var(--radius);font-family:inherit;font-weight:600;font-size:var(--font-size-base);cursor:pointer;-webkit-user-select:none;user-select:none;border:1.5px solid #0000;justify-content:center;align-items:center;gap:.5rem;padding:.7rem 1.1rem;transition:all .15s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover);box-shadow:0 3px 10px var(--key-target-glow);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--card);border-color:var(--border);color:var(--fg)}.btn-secondary:hover{background:var(--primary-soft);border-color:var(--primary)}.stat-pill{border:1.5px solid var(--border);background:var(--card);color:var(--muted);border-radius:999px;padding:.4rem .75rem;font-family:Georgia,serif;font-size:.825rem;transition:all .15s}.stat-pill:hover{background:var(--primary-soft);color:var(--primary-hover);border-color:var(--primary)}.lesson-char{border-bottom:2px solid #0000;padding-bottom:2px;transition:color 80ms;position:relative}.lesson-char.current{border-bottom-color:var(--primary);background:var(--primary-soft)}.lesson-char.current:after{content:"▎";color:var(--primary);pointer-events:none;animation:1s step-end infinite cursor-blink;position:absolute;top:-.05em;right:-.2em}.lesson-char.correct{color:var(--success)}.lesson-char.incorrect{color:var(--danger);-webkit-text-decoration:underline wavy var(--danger);-webkit-text-decoration:underline wavy var(--danger);-webkit-text-decoration:underline wavy var(--danger);text-decoration:underline wavy var(--danger)}.keycap{min-width:2.6rem;height:2.6rem;color:var(--fg);cursor:default;-webkit-user-select:none;user-select:none;background:var(--key-bg);border:1.5px solid var(--key-border);box-shadow:0 2px 0 0 var(--key-border), 0 3px 6px #0000000a;border-radius:.5rem;justify-content:center;align-items:center;font-family:Georgia,serif;font-size:.825rem;font-weight:600;display:flex;position:relative}@supports (color:color-mix(in lab, red, red)){.keycap{box-shadow:0 2px 0 0 color-mix(in srgb, var(--key-border) 100%, black 15%), 0 3px 6px #0000000a}}.keycap{transition:transform 80ms,box-shadow 80ms,background 80ms}.keycap:after{content:"";border-radius:inherit;opacity:0;box-shadow:0 0 0 0 var(--key-target-glow);pointer-events:none;z-index:-1;transition:opacity .15s,box-shadow .2s;position:absolute;inset:-3px}.keycap.target{background:var(--primary-soft);border-color:var(--primary);box-shadow:0 2px 0 0 var(--primary-hover), 0 3px 8px var(--key-target-glow);z-index:10;animation:2.5s ease-in-out infinite key-pulse-retro;transform:scale(1.03)}.keycap.is-pressed,.keycap.pressed,.keycap[data-live-pressed=true]{background:var(--primary);color:#fff;border-color:var(--primary-hover);transition:transform 40ms,box-shadow 40ms,background 40ms;transform:translateY(2px)scale(.97);box-shadow:0 0 #0000,0 1px 2px #0000001a}.keycap.is-pressed:after,.keycap.pressed:after,.keycap[data-live-pressed=true]:after{opacity:1;box-shadow:0 0 10px 3px var(--key-target-glow)}.keycap.left-hand{border-bottom:3px solid #d4a24e}.keycap.right-hand{border-bottom:3px solid #8b7ec7}.keycap.space{min-width:14rem}.console-perspective{perspective:none}.keyboard-console{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);-webkit-overflow-scrolling:touch;padding:1rem;overflow-x:auto;transform:none}.progress-track{background:var(--border);border-radius:999px;height:5px;overflow:hidden}.progress-fill{background:var(--primary);border-radius:999px;height:100%;transition:width .3s}.prompt-wrapper{font-family:Courier New,Courier,monospace;font-size:calc(var(--font-size-base)*1.2);letter-spacing:.06em;word-break:break-all;border-radius:var(--radius);border:1px solid var(--border);background:#fffdf9;min-height:4rem;padding:1.25rem;line-height:2.4;position:relative;box-shadow:inset 0 1px 3px #00000008}.prompt-wrapper:before{content:"";pointer-events:none;border-radius:inherit;background:repeating-linear-gradient(#0000 0 2.3em,#c77b5a0f 2.3em 2.35em);position:absolute;inset:0}.prompt-wrapper .lesson-char{color:#c4b9ad}.prompt-wrapper .lesson-char.correct{color:var(--success)}.prompt-wrapper .lesson-char.incorrect{color:var(--danger);-webkit-text-decoration:underline wavy var(--danger);-webkit-text-decoration:underline wavy var(--danger);-webkit-text-decoration:underline wavy var(--danger);text-decoration:underline wavy var(--danger)}.prompt-wrapper .lesson-char.current{color:var(--fg);background:var(--primary-soft);border-bottom-color:var(--primary)}.lesson-input-capture{opacity:0;pointer-events:none;resize:none;border:0;width:1px;height:1px;margin:0;padding:0;position:fixed;top:0;left:0}.oled-screen{color:#c77b5a;letter-spacing:.04em;background:#2a2520;border:1px solid #3d352e;border-radius:.4rem;padding:.5rem .75rem;font-family:Courier New,monospace;font-size:.8rem;box-shadow:inset 0 1px 3px #0003}.oled-screen--amber{color:#d4a24e}.oled-screen--cyan{color:#7ea88b}.oled-screen--red{color:#c75f5f}.oled-screen--white{color:#d4cdc4}.wpm-display{font-variant-numeric:tabular-nums;font-family:Courier New,monospace}.streak-fire{color:#c77b5a;font-weight:800}.achievement-badge{background:var(--primary-soft);color:var(--primary);border-radius:999px;align-items:center;gap:.3rem;padding:.2rem .7rem;font-size:.8rem;font-weight:600;display:inline-flex}@keyframes cursor-blink{0%,49%{opacity:1}50%,to{opacity:0}}@keyframes key-pulse-retro{0%,to{box-shadow:0 2px 0 0 var(--primary-hover), 0 3px 8px var(--key-target-glow)}50%{box-shadow:0 2px 0 0 var(--primary-hover), 0 3px 14px color-mix(in srgb, var(--primary) 40%, transparent)}}@keyframes slide-in-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes confetti-pop{0%{opacity:1;transform:translateY(0)rotate(0)}to{opacity:0;transform:translateY(-20px)rotate(720deg)}}@keyframes hippo-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes star-bounce{0%,to{transform:scale(1)rotate(0)}50%{transform:scale(1.15)rotate(15deg)}}@keyframes star-item-bounce{0%{opacity:0;transform:scale(.3)rotate(-15deg)}50%{opacity:1;transform:scale(1.2)rotate(8deg)}to{opacity:1;transform:scale(1)rotate(0)}}@keyframes state-dot-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}@keyframes shake{0%,to{transform:translate(0)}15%{transform:translate(-4px)}30%{transform:translate(3px)}45%{transform:translate(-3px)}60%{transform:translate(2px)}}.confetti{pointer-events:none;animation:1s ease-out forwards confetti-pop;position:fixed}[data-mode=kid] .hippo-mascot{animation:.6s ease-in-out hippo-bounce}[data-mode=kid] .completion-stars{animation:.8s ease-in-out star-bounce}[data-mode=adult] .hippo-mascot,[data-mode=high-contrast] .hippo-mascot{display:none}.completion-star-item{animation:.5s ease-in-out both star-item-bounce;display:inline-block}.slide-in-up{animation:.3s ease-out both slide-in-up}.error-blocked{outline:2px solid var(--danger);outline-offset:3px;border-radius:var(--radius);animation:.35s cubic-bezier(.36,.07,.19,.97) both shake}h1,h2,h3{letter-spacing:-.3px;font-family:Georgia,Palatino,serif;font-weight:700}[data-mode=kid] h1{font-weight:800}[data-track=adult]{--bg:#0f0f1e;--fg:#d9e6f2;--primary:#4dd0e1;--primary-soft:#4dd0e124;--primary-hover:#80deea;--accent:#ba68c8;--success:#81d4a1;--danger:#f48fb1;--warning:#ffd54f;--card:#1e1e3ad9;--border:#4dd0e14d;--muted:#8a9aa8;--radius:.5rem;--key-bg:#1e1e3ab3;--key-border:#4dd0e159;--key-target-glow:#4dd0e173;--shadow:0 4px 20px #4dd0e11f;--font-display:"Courier New", "Consolas", "Monaco", monospace;--font-body:"Courier New", "Consolas", "Monaco", monospace;--accent-glow:#4dd0e1}[data-track=adult] body{color:var(--fg);background-color:#0f0f1e;background-image:radial-gradient(circle at 15% 15%,#4dd0e114 0%,#0000 50%),radial-gradient(circle at 85% 85%,#ba68c814 0%,#0000 50%);background-position:0 0;background-repeat:repeat;background-size:auto;background-attachment:scroll;background-origin:padding-box;background-clip:border-box}[data-track=adult] body:before{content:"";pointer-events:none;z-index:1;opacity:.5;background:repeating-linear-gradient(0deg,#0000 0 3px,#00000014 3px 4px);position:fixed;inset:0}[data-track=adult] .card{background:var(--card);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border);color:var(--fg);box-shadow:0 0 0 1px #4dd0e10f inset, var(--shadow)}[data-track=adult] .prompt-wrapper{color:var(--fg);border:1px solid var(--border);background:#0a0a19d9;font-family:Courier New,monospace;box-shadow:inset 0 0 24px #4dd0e114}[data-track=adult] .prompt-wrapper:before{display:none}[data-track=adult] .prompt-wrapper .lesson-char{color:#d9e6f259}[data-track=adult] .prompt-wrapper .lesson-char.correct{color:#81d4a1;text-shadow:0 0 6px #81d4a166}[data-track=adult] .prompt-wrapper .lesson-char.current{color:#4dd0e1;text-shadow:0 0 8px #4dd0e199;background:#4dd0e12e}[data-track=adult] .keycap{background:var(--key-bg);border:1px solid var(--key-border);color:var(--fg);text-transform:uppercase;font-family:Courier New,monospace;font-weight:600;box-shadow:0 2px #0006,inset 0 1px #ffffff0a}[data-track=adult] .keycap.target{border-color:var(--primary);color:var(--primary);box-shadow:0 2px 0 0 #0006, 0 0 14px var(--key-target-glow), inset 0 0 8px #4dd0e11f;text-shadow:0 0 6px var(--primary);background:#4dd0e12e}[data-track=adult] .keycap.is-pressed,[data-track=adult] .keycap.pressed{background:var(--primary);color:var(--bg);box-shadow:0 0 14px var(--primary)}[data-track=kids]{--bg:#1e2a4a;--fg:#e8e4d0;--primary:#e5b640;--primary-soft:#e5b64029;--primary-hover:#d4a434;--accent:#7cb5c9;--success:#9dc89a;--danger:#d89cb5;--warning:#e0a878;--card:#263455b8;--border:#e5b64038;--muted:#a8b4c8;--radius:1rem;--key-bg:#26345599;--key-border:#e5b64040;--key-target-glow:#e5b6404d;--shadow:0 4px 16px #00000038;--font-display:system-ui, -apple-system, "Segoe UI", sans-serif;--font-body:system-ui, -apple-system, "Segoe UI", sans-serif;--accent-glow:#e5b640}[data-track=kids] body{color:var(--fg);background:linear-gradient(#1e2a4a 0%,#2a3558 50%,#1e2a4a 100%)}[data-track=kids] body:before{content:"";pointer-events:none;z-index:0;opacity:.6;background-color:#0000;background-image:radial-gradient(2px 2px at 15% 25%,#e5b64038,#0000),radial-gradient(2px 2px at 75% 15%,#7cb5c938,#0000),radial-gradient(2px 2px at 55% 70%,#e5b64029,#0000),radial-gradient(2px 2px at 25% 85%,#7cb5c92e,#0000),radial-gradient(2px 2px at 90% 55%,#e5b64033,#0000);background-position:0 0,0 0,0 0,0 0,0 0;background-repeat:repeat,repeat,repeat,repeat,repeat;background-size:100% 100%;background-attachment:scroll,scroll,scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box,border-box,border-box;position:fixed;inset:0}[data-track=kids] .card{background:var(--card);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1.5px solid var(--border);color:var(--fg);box-shadow:var(--shadow)}[data-track=kids] .prompt-wrapper{color:var(--fg);border:1.5px solid var(--border);background:#16203ad1;font-family:Courier New,monospace}[data-track=kids] .prompt-wrapper:before{display:none}[data-track=kids] .prompt-wrapper .lesson-char{color:#e8e4d066}[data-track=kids] .prompt-wrapper .lesson-char.correct{color:#9dc89a}[data-track=kids] .prompt-wrapper .lesson-char.current{color:var(--fg);background:var(--primary-soft)}[data-track=kids] .keycap{background:var(--key-bg);border-color:var(--key-border);color:var(--fg);font-family:system-ui,sans-serif;font-weight:600;box-shadow:0 2px #0003,inset 0 1px #ffffff08}[data-track=kids] .keycap.target{border-color:var(--primary);color:#fff;box-shadow:0 2px 0 0 #0000004d, 0 0 14px var(--key-target-glow);background:linear-gradient(#e5b64047,#d4a4342e)}[data-track=kids] .keycap.is-pressed,[data-track=kids] .keycap.pressed{background:linear-gradient(180deg, var(--primary), var(--primary-hover));color:#1e2a4a}[data-track=adult] .stat-pill,[data-track=kids] .stat-pill{background:var(--card);border-color:var(--border);color:var(--fg)}[data-track=adult] .stat-pill:hover,[data-track=kids] .stat-pill:hover{background:var(--primary-soft);color:var(--primary);border-color:var(--primary)}[data-track=adult] .btn-secondary,[data-track=kids] .btn-secondary{background:var(--card);border-color:var(--border);color:var(--fg)}:root:not([data-track]){--font-body:"Georgia", "Palatino", serif}:focus-visible{outline:3px solid var(--primary);outline-offset:3px;border-radius:4px}button:focus-visible,a:focus-visible{outline-offset:4px}@keyframes key-ripple{0%{opacity:.8;transform:translate(-50%,-50%)scale(.3)}to{opacity:0;transform:translate(-50%,-50%)scale(3)}}.keycap.is-pressed:before,.keycap.pressed:before{content:"";border-radius:inherit;background:radial-gradient(circle, var(--key-target-glow) 0%, transparent 70%);pointer-events:none;z-index:1;width:100%;height:100%;animation:.5s ease-out key-ripple;position:absolute;top:50%;left:50%}.keyboard-console{background:linear-gradient(180deg, var(--card) 0%, var(--card) 100%);padding:1.5rem 1.25rem 1.25rem;position:relative}@supports (color:color-mix(in lab, red, red)){.keyboard-console{background:linear-gradient(180deg, color-mix(in srgb, var(--card) 98%, black 2%) 0%, var(--card) 100%)}}.keyboard-console{box-shadow:0 4px 0 0 var(--border), 0 6px 16px #00000014, inset 0 1px 0 #fff6}@supports (color:color-mix(in lab, red, red)){.keyboard-console{box-shadow:0 4px 0 0 color-mix(in srgb, var(--border) 100%, black 15%), 0 6px 16px #00000014, inset 0 1px 0 #fff6}}.progress-track{background:var(--border);border-radius:999px;height:8px;position:relative;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--primary) 0%, var(--accent) 100%);border-radius:999px;height:100%;transition:width .3s;position:relative;overflow:hidden}.progress-fill:after{content:"";background:linear-gradient(90deg,#0000 0%,#ffffff4d 50%,#0000 100%);animation:2s ease-in-out infinite progress-sheen;position:absolute;inset:0}@keyframes progress-sheen{0%{transform:translate(-100%)}to{transform:translate(100%)}}.hud-stat{background:linear-gradient(180deg, var(--card) 0%, var(--card) 100%);border-radius:.5rem;align-items:center;gap:.4rem;padding:.5rem .9rem;display:inline-flex}@supports (color:color-mix(in lab, red, red)){.hud-stat{background:linear-gradient(180deg, color-mix(in srgb, var(--card) 100%, white 3%) 0%, color-mix(in srgb, var(--card) 100%, black 3%) 100%)}}.hud-stat{border:1px solid var(--border);box-shadow:0 2px 0 0 var(--border), 0 2px 6px #0000000a}@supports (color:color-mix(in lab, red, red)){.hud-stat{box-shadow:0 2px 0 0 color-mix(in srgb, var(--border) 100%, black 10%), 0 2px 6px #0000000a}}.hud-stat{font-variant-numeric:tabular-nums;font-family:Courier New,monospace;font-size:.85rem}.hud-stat-label{color:var(--muted);letter-spacing:.08em;text-transform:uppercase;font-size:.65rem}.hud-stat-value{color:var(--fg);font-weight:700}@keyframes confetti-fall{0%{opacity:1;transform:translateY(-100vh)rotate(0)}80%{opacity:1}to{opacity:0;transform:translateY(100vh)rotate(720deg)}}.confetti-piece{pointer-events:none;z-index:999;width:8px;height:14px;animation:2s cubic-bezier(.4,0,.6,1) forwards confetti-fall;position:fixed;top:0}.speech-bubble{background:var(--primary-soft);border:1.5px solid var(--primary);border-radius:1rem;align-items:center;min-height:3rem;padding:.75rem 1rem .75rem 3rem;display:flex;position:relative}.speech-bubble:before{content:"";background:var(--primary-soft);border:1.5px solid var(--primary);border-bottom:none;border-right:none;width:1rem;height:1rem;position:absolute;top:-.5rem;left:.75rem;transform:rotate(45deg)}.speech-bubble-icon{background:var(--card);border:1.5px solid var(--primary);border-radius:50%;justify-content:center;align-items:center;width:2rem;height:2rem;font-size:1.1rem;animation:4s ease-in-out infinite speech-idle;display:flex;position:absolute;top:50%;left:.5rem;transform:translateY(-50%)}@keyframes speech-idle{0%,90%,to{transform:translateY(-50%)scale(1)}95%{transform:translateY(-50%)scale(1.05)}}.lesson-char.correct:before{content:"";background:var(--success);border-radius:50%;width:3px;height:3px;position:absolute;bottom:-6px;left:50%;transform:translate(-50%)}@keyframes hippo-idle{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-2px)scale(1.01)}}.hippo-mascot:not(:hover) svg{animation:3s ease-in-out infinite hippo-idle}@keyframes level-up-flash{0%,to{filter:brightness()}50%{filter:brightness(1.3)drop-shadow(0 0 20px gold)}}.level-up-pulse{animation:.6s ease-in-out 3 level-up-flash}.combo-flash{pointer-events:none;z-index:99;opacity:0;animation:.6s ease-out combo-edge;position:fixed;inset:0;box-shadow:inset 0 0 60px 10px}@keyframes combo-edge{0%{opacity:0}30%{opacity:.5}to{opacity:0}}.version-badge{color:var(--muted);background:var(--card);border:1px solid var(--border);opacity:.5;z-index:50;pointer-events:none;border-radius:999px;padding:.15rem .5rem;font-family:Courier New,monospace;font-size:.65rem;position:fixed;top:.5rem;right:.5rem}.title-neon{font-family:var(--font-display,"Georgia", serif);letter-spacing:.03em;color:var(--fg);text-shadow:2px 2px 0 var(--primary-soft), 4px 4px 0 var(--border);font-weight:800}.title-comic{font-family:var(--font-display,sans-serif);letter-spacing:.03em;text-shadow:3px 3px #ff7729,6px 6px #0003;font-weight:900}@keyframes stagger-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.stagger-item{animation:.4s ease-out both stagger-in}.stagger-item:first-child{animation-delay:50ms}.stagger-item:nth-child(2){animation-delay:.1s}.stagger-item:nth-child(3){animation-delay:.15s}.stagger-item:nth-child(4){animation-delay:.2s}.mode-card{transition:transform .25s cubic-bezier(.4,0,.2,1),box-shadow .25s}.mode-card:hover{transform:translateY(-4px)scale(1.01)}.mode-card-arcade:hover{box-shadow:0 0 30px #00e5ff40,0 0 60px #ff00e61a,inset 0 0 40px #00e5ff0f}.mode-card-kids:hover{box-shadow:0 8px 30px #fbbf2459,0 0 60px #f472b633}.settings-sidebar{z-index:100;flex-direction:column;gap:.5rem;display:flex;position:fixed;top:50%;right:0;transform:translateY(-50%)}.settings-sidebar-toggle{background:var(--card);border:1.5px solid var(--border);width:2.5rem;height:2.5rem;color:var(--fg);cursor:pointer;border-right:none;border-radius:999px 0 0 999px;justify-content:center;align-items:center;padding:0;font-size:1.1rem;transition:all .2s;display:flex;box-shadow:-2px 2px 8px #00000014}.settings-sidebar-toggle:hover{background:var(--primary-soft);color:var(--primary-hover);transform:translate(-2px)}.settings-sidebar-panel{background:var(--card);border-left:1.5px solid var(--border);z-index:200;flex-direction:column;gap:1.25rem;width:min(320px,85vw);height:100vh;padding:1.5rem 1.25rem;transition:transform .25s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;right:0;overflow-y:auto;transform:translate(0);box-shadow:-8px 0 24px #0000001a}.settings-sidebar-panel.closed{pointer-events:none;transform:translate(100%)}.settings-sidebar-backdrop{z-index:150;cursor:pointer;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0000004d;position:fixed;inset:0}.settings-sidebar-group{flex-direction:column;gap:.4rem;display:flex}.settings-sidebar-group-label{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:.7rem;font-weight:700}.settings-sidebar-buttons{flex-wrap:wrap;gap:.35rem;display:flex}.settings-sidebar-btn{border:1.5px solid var(--border);min-width:fit-content;color:var(--muted);cursor:pointer;background:0 0;border-radius:999px;flex:1;padding:.45rem .75rem;font-family:inherit;font-size:.8rem;transition:all .15s}.settings-sidebar-btn:hover{border-color:var(--primary);color:var(--primary-hover)}.settings-sidebar-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}@keyframes finger-ready-pulse{0%,to{filter:drop-shadow(0 0 6px)}50%{filter:drop-shadow(0 0 12px)}}.finger-active{animation:1.5s ease-in-out infinite finger-ready-pulse}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}
