/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */
@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-border-style:solid;--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}}}@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;--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{.visible{visibility:visible}.relative{position:relative}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.hidden{display:none}.grow{flex-grow:1}.border{border-style:var(--tw-border-style);border-width:1px}.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}}:root{--font-pixel:"Press Start 2P", monospace;--font-clean:system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--bg-dark:#0f0a1a;--bg-medium:#1a0f2e;--bg-card:#251a40;--bg-card-hover:#2d2050;--accent-gold:gold;--accent-orange:#ff6b35;--accent-red:#f33;--accent-green:#3f6;--text-primary:#f0e6ff;--text-secondary:#9980b3;--text-muted:#665580;--border-color:#3d2b6b}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-dark);color:var(--text-primary);font-family:var(--font-clean);min-height:100vh;overflow-x:hidden}#root{flex-direction:column;min-height:100vh;display:flex}.name-entry-screen{background:radial-gradient(ellipse at center, var(--bg-medium) 0%, var(--bg-dark) 70%);justify-content:center;align-items:center;min-height:100vh;display:flex}.name-entry-card{background:var(--bg-card);border:2px solid var(--border-color);text-align:center;border-radius:12px;width:90%;max-width:420px;padding:48px 40px;box-shadow:0 0 60px #ff6b351a}.logo-area{margin-bottom:32px}.game-title{font-family:var(--font-pixel);color:var(--accent-gold);text-shadow:0 0 20px #ffd70066;margin-bottom:4px;font-size:28px;line-height:1.4}.game-subtitle{font-family:var(--font-pixel);color:var(--accent-orange);text-shadow:0 0 10px #ff6b354d;font-size:16px}.egg-icon{margin-top:16px;font-size:64px;animation:2s ease-in-out infinite egg-bob}.avatar-bounce{margin:16px auto 0;animation:2s ease-in-out infinite egg-bob;display:block}@keyframes egg-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.login-choices{flex-direction:column;gap:10px;display:flex}.login-hint{font-family:var(--font-pixel);color:var(--text-muted);margin-top:12px;font-size:7px;line-height:1.6}.code-input{text-align:center;letter-spacing:8px;font-size:28px!important}.error-text{font-family:var(--font-pixel);color:var(--accent-red);margin-bottom:8px;font-size:9px}.name-label{font-family:var(--font-pixel);color:var(--text-secondary);margin-bottom:12px;font-size:10px;display:block}.name-input{width:100%;font-family:var(--font-pixel);background:var(--bg-dark);border:2px solid var(--border-color);color:var(--text-primary);border-radius:8px;outline:none;margin-bottom:16px;padding:14px 16px;font-size:14px;transition:border-color .2s}.name-input:focus{border-color:var(--accent-gold);box-shadow:0 0 12px #ffd70033}.name-input::placeholder{color:var(--text-muted)}.btn{font-family:var(--font-pixel);cursor:pointer;text-transform:uppercase;border:2px solid #0000;border-radius:8px;padding:14px 24px;font-size:12px;transition:all .2s}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-start{background:linear-gradient(135deg, var(--accent-orange), #ff8c42);color:#fff;border-color:var(--accent-orange);width:100%}.btn-start:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 20px #ff6b3566}.btn-next{background:linear-gradient(135deg, var(--accent-green), #2c5);color:#000;border-color:var(--accent-green)}.btn-next:hover{transform:translateY(-2px);box-shadow:0 4px 20px #3f66}.btn-retry{color:var(--text-primary);border-color:var(--border-color);background:0 0}.btn-retry:hover{border-color:var(--accent-gold);background:#ffd7001a}.btn-logout{color:var(--text-secondary);border-color:var(--border-color);background:0 0;padding:8px 16px;font-size:10px}.btn-logout:hover{border-color:var(--accent-red);color:var(--accent-red)}.btn-back{font-family:var(--font-pixel);color:var(--text-secondary);border:1px solid var(--border-color);cursor:pointer;z-index:100;background:#0f0a1acc;border-radius:6px;padding:8px 12px;font-size:10px;transition:color .2s;position:fixed;top:16px;left:16px}.btn-back:hover{color:var(--accent-gold)}.level-select-screen{background:radial-gradient(ellipse at top, var(--bg-medium) 0%, var(--bg-dark) 60%);min-height:100vh;padding:24px}.level-select-header{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;justify-content:space-between;align-items:center;margin-bottom:32px;padding:16px 20px;display:flex}.player-info{align-items:center;gap:16px;display:flex}.player-name{font-family:var(--font-pixel);color:var(--accent-gold);font-size:14px}.player-points{font-family:var(--font-pixel);color:var(--accent-orange);font-size:12px}.player-info-text{flex-direction:column;gap:4px;display:flex}.evolution-progress-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;max-width:600px;margin-bottom:16px;margin-left:auto;margin-right:auto;padding:14px 18px}.evo-progress-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.evo-progress-label{font-family:var(--font-pixel);color:var(--accent-gold);font-size:10px}.evo-progress-pct{font-family:var(--font-pixel);color:var(--text-secondary);font-size:10px}.evo-progress-bar-track{background:var(--bg-dark);border-radius:5px;height:10px;margin-bottom:10px;overflow:hidden}.evo-progress-bar-fill{background:linear-gradient(90deg, var(--accent-orange), var(--accent-gold));border-radius:5px;min-width:0;height:100%;transition:width .5s ease-out}.evo-progress-details{flex-wrap:wrap;gap:16px;display:flex}.evo-detail{font-family:var(--font-pixel);color:var(--text-muted);align-items:center;gap:4px;font-size:8px;display:flex}.evo-detail.met{color:var(--accent-green)}.evo-detail-icon{font-size:10px}.level-progress-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;max-width:600px;margin-bottom:16px;margin-left:auto;margin-right:auto;padding:14px 18px}.level-progress-bar-fill{background:linear-gradient(90deg, var(--accent-green), #2c5);border-radius:5px;min-width:0;height:100%;transition:width .5s ease-out}.level-select-title{font-family:var(--font-pixel);color:var(--accent-gold);text-align:center;text-shadow:0 0 15px #ffd7004d;margin-bottom:24px;font-size:18px}.level-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;max-width:1000px;margin:0 auto;display:grid}.level-card{background:var(--bg-card);border:2px solid var(--border-color);cursor:pointer;color:inherit;border-radius:10px;flex-direction:column;align-items:center;gap:6px;padding:16px 12px;font-family:inherit;transition:all .2s;display:flex;position:relative}.level-card:hover:not(:disabled){border-color:var(--accent-gold);background:var(--bg-card-hover);transform:translateY(-2px)}.level-card.completed{border-color:#33ff664d}.level-card.current{border-color:var(--accent-gold);box-shadow:0 0 20px #ffd70026}.level-card.locked{opacity:.4;cursor:not-allowed}.level-number{font-family:var(--font-pixel);color:var(--accent-gold);font-size:20px}.level-name{font-family:var(--font-pixel);color:var(--text-secondary);text-align:center;font-size:8px}.level-score{font-family:var(--font-pixel);color:var(--accent-green);font-size:7px}.lock-icon,.check-icon{font-size:14px;position:absolute;top:8px;right:8px}.game-screen{background:var(--bg-dark);flex-direction:column;align-items:center;height:100vh;padding-top:52px;display:flex;overflow:hidden}.game-hud{border-bottom:2px solid var(--border-color);z-index:50;background:#0f0a1af2;justify-content:space-between;align-items:center;padding:8px 16px;display:flex;position:fixed;top:0;left:0;right:0}.hud-left{flex:1;align-items:center;gap:8px;display:flex}.btn-mute{cursor:pointer;opacity:.7;background:0 0;border:none;padding:2px 4px;font-size:16px;transition:opacity .2s}.btn-mute:hover{opacity:1}.btn-back-hud{font-family:var(--font-pixel);color:var(--text-secondary);border:1px solid var(--border-color);cursor:pointer;background:0 0;border-radius:4px;flex-shrink:0;padding:2px 8px;font-size:14px;transition:color .2s}.btn-back-hud:hover{color:var(--accent-gold);border-color:var(--accent-gold)}.btn-back-card{color:var(--text-secondary);border-color:var(--border-color);background:0 0;padding:10px 14px!important}.btn-back-card:hover{color:var(--accent-gold);border-color:var(--accent-gold)}.hud-center{text-align:center;flex:1}.level-title{font-family:var(--font-pixel);color:var(--accent-gold);font-size:10px}.hud-right{flex:1;justify-content:flex-end;gap:16px;display:flex}.stat-display{font-family:var(--font-pixel);color:var(--text-primary);font-size:11px}.hearts-display{flex-wrap:wrap;gap:2px;display:flex}.heart{font-size:14px;transition:all .2s;display:inline-block}.heart-lost{opacity:.3;transform:scale(.8)}.heart-shake{animation:.4s ease-out heart-shake}@keyframes heart-shake{0%{transform:translate(0)scale(1)}25%{transform:translate(-4px)scale(1.2)}50%{transform:translate(4px)scale(.9)}75%{transform:translate(-2px)scale(1)}to{opacity:.3;transform:translate(0)scale(.8)}}.runner-canvas{border:2px solid var(--border-color);width:calc(100% - 32px);min-height:0;image-rendering:pixelated;border-radius:8px;flex:1;margin:12px 16px}.typing-area{flex-shrink:0;width:100%;padding:0 16px 16px}.typing-prompt{background:var(--bg-card);border:2px solid var(--border-color);border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:6px;min-height:120px;padding:24px 32px;display:flex;overflow:hidden}.typing-prompt-line{letter-spacing:2px;word-spacing:8px;white-space:nowrap;text-align:center;font-family:JetBrains Mono,Consolas,Courier New,monospace;font-size:32px;font-weight:500;line-height:1.8}.char-pending{color:#fff}.char-correct{color:var(--accent-green)}.char-current{color:var(--accent-gold);border-bottom:2px solid var(--accent-gold);background:#ffd70026;animation:1s ease-in-out infinite blink-cursor}@keyframes blink-cursor{0%,to{background:#ffd70026}50%{background:#ffd7004d}}.hidden-input{opacity:0;pointer-events:none;width:0;height:0;position:absolute}.level-complete-overlay{z-index:200;background:#0f0a1ae6;justify-content:center;align-items:center;animation:.3s ease-out fade-in;display:flex;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.level-complete-card{background:var(--bg-card);border:2px solid var(--border-color);text-align:center;border-radius:16px;width:90%;max-width:440px;padding:40px;animation:.4s ease-out slide-up}@keyframes slide-up{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.level-complete-title{font-family:var(--font-pixel);margin-bottom:8px;font-size:18px}.level-complete-title.success{color:var(--accent-gold);text-shadow:0 0 20px #ffd70066}.level-complete-title.failed{color:var(--accent-red);text-shadow:0 0 20px #f336}.level-complete-subtitle{font-family:var(--font-pixel);color:var(--text-secondary);margin-bottom:24px;font-size:9px}.badge{font-family:var(--font-pixel);color:var(--accent-gold);border:1px solid var(--accent-gold);background:#ffd7001a;border-radius:6px;margin-bottom:24px;padding:8px 16px;font-size:12px;animation:1.5s ease-in-out infinite alternate badge-glow;display:inline-block}.perfect-forge-particles{pointer-events:none;z-index:201;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.level-complete-card.perfect-forge{border-color:var(--accent-gold);animation:.4s ease-out slide-up,2s ease-in-out .5s infinite perfect-pulse;box-shadow:0 0 40px #ffd7004d,0 0 80px #ff6b3526}@keyframes perfect-pulse{0%,to{box-shadow:0 0 40px #ffd7004d,0 0 80px #ff6b3526}50%{box-shadow:0 0 60px #ffd70080,0 0 100px #ff6b3540}}@keyframes badge-glow{0%{box-shadow:0 0 5px #ffd70033}to{box-shadow:0 0 20px #ffd70080}}.stats-grid{grid-template-columns:1fr 1fr;gap:16px;margin:24px 0;display:grid}.stat{flex-direction:column;gap:4px;display:flex}.stat-label{font-family:var(--font-pixel);color:var(--text-muted);text-transform:uppercase;font-size:8px}.stat-value{font-family:var(--font-pixel);color:var(--text-primary);font-size:16px}.level-complete-avatar{justify-content:center;margin:8px 0;display:flex}.level-complete-actions{justify-content:center;gap:12px;margin-top:24px;display:flex}.enter-hint{font-family:var(--font-pixel);color:var(--text-muted);margin-top:16px;font-size:8px}.evolution-overlay{z-index:300;background:#0a0514f2;justify-content:center;align-items:center;animation:.5s ease-out fade-in;display:flex;position:fixed;inset:0}.evolution-card{background:var(--bg-card);border:2px solid var(--accent-gold);text-align:center;border-radius:16px;width:90%;max-width:420px;padding:48px 40px;animation:.6s ease-out evolution-pop;box-shadow:0 0 60px #ffd7004d,0 0 120px #ff6b3526}@keyframes evolution-pop{0%{opacity:0;transform:scale(.5)rotate(-5deg)}60%{transform:scale(1.1)rotate(1deg)}to{opacity:1;transform:scale(1)rotate(0)}}.evolution-sparkles{margin-bottom:8px;font-size:32px;animation:2s linear infinite sparkle-spin}@keyframes sparkle-spin{0%{transform:rotate(0)scale(1)}50%{transform:rotate(180deg)scale(1.2)}to{transform:rotate(360deg)scale(1)}}.evolution-title{font-family:var(--font-pixel);color:var(--accent-gold);text-shadow:0 0 30px #ffd70080;margin-bottom:16px;font-size:24px}.evolution-avatar{justify-content:center;margin:12px 0;display:flex}.evolution-stage-name{font-family:var(--font-pixel);color:var(--accent-orange);margin-bottom:8px;font-size:16px}.evolution-description{font-family:var(--font-pixel);color:var(--text-secondary);margin-bottom:24px;font-size:9px;line-height:1.6}.tutorial-screen{background:radial-gradient(ellipse at center, var(--bg-medium) 0%, var(--bg-dark) 70%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.tutorial-card{background:var(--bg-card);border:2px solid var(--border-color);text-align:center;border-radius:16px;width:100%;max-width:520px;padding:32px;position:relative}.tutorial-skip{color:var(--text-muted);font-family:var(--font-clean);cursor:pointer;background:0 0;border:none;font-size:13px;transition:color .2s;position:absolute;top:12px;right:16px}.tutorial-skip:hover{color:var(--text-secondary)}.tutorial-dots{justify-content:center;gap:8px;margin-bottom:24px;display:flex}.tutorial-dot{background:var(--border-color);border-radius:50%;width:10px;height:10px;transition:background .3s}.tutorial-dot.active{background:var(--accent-gold)}.tutorial-dot.done{background:var(--accent-green)}.tutorial-step{flex-direction:column;justify-content:center;align-items:center;min-height:240px;display:flex}.tutorial-avatar{margin-bottom:16px}.tutorial-title{font-family:var(--font-pixel);color:var(--accent-gold);text-shadow:0 0 15px #ffd7004d;margin-bottom:16px;font-size:16px}.tutorial-text{font-family:var(--font-clean);color:var(--text-secondary);max-width:440px;margin-bottom:12px;font-size:15px;line-height:1.7}.tutorial-text strong{color:var(--text-primary)}.tutorial-text-bold{font-family:var(--font-clean);color:var(--accent-orange);font-size:15px;font-weight:600;line-height:1.7}.tutorial-hearts-demo{letter-spacing:2px;margin-bottom:16px;font-size:16px}.keyboard-diagram{justify-content:center;margin:16px 0;display:flex}.key-row{gap:4px;display:flex}.key{background:var(--bg-dark);border:2px solid var(--border-color);width:44px;height:48px;font-family:var(--font-clean);color:var(--text-muted);border-radius:6px;flex-direction:column;justify-content:center;align-items:center;font-size:16px;font-weight:600;line-height:1.2;display:flex}.key small{margin-top:2px;font-size:7px;font-weight:400}.key.hint-left{color:#6ae;border-color:#48c}.key.hint-right{color:#e86;border-color:#c64}.key.bump{border-width:2px 2px 4px}.key.dim{opacity:.4}.practice-display{justify-content:center;gap:6px;margin:20px 0;display:flex}.practice-char{border:2px solid var(--border-color);border-radius:6px;justify-content:center;align-items:center;width:44px;height:52px;font-family:JetBrains Mono,Consolas,monospace;font-size:36px;font-weight:600;display:flex}.practice-char.pending{color:var(--text-muted);background:var(--bg-dark)}.practice-char.current{color:var(--accent-gold);border-color:var(--accent-gold);background:#ffd7001a}.practice-char.correct{color:var(--accent-green);background:#33ff6614;border-color:#33ff664d}.tutorial-hint{font-family:var(--font-pixel);color:var(--accent-red);margin-bottom:8px;font-size:9px}.tutorial-success{font-family:var(--font-pixel);color:var(--accent-green);margin-bottom:8px;font-size:10px}.tutorial-nav{justify-content:center;gap:12px;margin-top:20px;display:flex}.parent-login-link{color:var(--text-muted);font-family:var(--font-clean);cursor:pointer;background:0 0;border:none;margin-top:16px;font-size:13px;text-decoration:underline;transition:color .2s}.parent-login-link:hover{color:var(--text-secondary)}.parent-auth-screen{background:var(--bg-dark);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.parent-auth-card{background:var(--bg-card);border:1px solid var(--border-color);text-align:center;border-radius:12px;width:100%;max-width:400px;padding:40px 32px}.parent-auth-title{font-family:var(--font-clean);color:var(--text-primary);margin-bottom:4px;font-size:24px;font-weight:600}.parent-auth-subtitle{color:var(--text-secondary);margin-bottom:24px;font-size:14px}.parent-input{background:var(--bg-dark);border:1px solid var(--border-color);width:100%;color:var(--text-primary);font-size:15px;font-family:var(--font-clean);box-sizing:border-box;border-radius:8px;outline:none;margin-bottom:12px;padding:12px 14px}.parent-input:focus{border-color:var(--accent-orange)}.btn-parent-primary{width:100%;font-family:var(--font-clean);background:var(--accent-orange);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:12px;font-size:15px;font-weight:600;transition:opacity .2s}.btn-parent-primary:hover{opacity:.9}.btn-parent-primary:disabled{opacity:.5;cursor:not-allowed}.btn-parent-secondary{font-family:var(--font-clean);color:var(--text-secondary);border:1px solid var(--border-color);cursor:pointer;background:0 0;border-radius:6px;padding:8px 16px;font-size:14px;transition:border-color .2s}.btn-parent-secondary:hover{border-color:var(--text-secondary)}.btn-parent-danger{font-family:var(--font-clean);color:var(--accent-red);border:1px solid var(--accent-red);cursor:pointer;background:0 0;border-radius:6px;flex-shrink:0;padding:6px 14px;font-size:13px}.btn-parent-danger:hover{background:#ff33331a}.parent-toggle-link{color:var(--text-muted);cursor:pointer;font-size:13px;font-family:var(--font-clean);background:0 0;border:none;margin-top:12px;display:block}.parent-toggle-link:hover{color:var(--text-secondary)}.parent-dashboard{background:var(--bg-dark);max-width:800px;min-height:100vh;margin:0 auto;padding:24px}.parent-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.parent-title{font-family:var(--font-clean);color:var(--text-primary);font-size:22px;font-weight:600}.parent-play-card{background:var(--bg-card);border:2px solid var(--accent-orange);border-radius:10px;justify-content:space-between;align-items:center;margin-bottom:24px;padding:16px 20px;display:flex}.parent-play-info{align-items:center;gap:16px;display:flex}.parent-play-stats{flex-direction:column;gap:2px;display:flex}.parent-play-title{font-family:var(--font-clean);color:var(--text-primary);font-size:16px;font-weight:600}.parent-play-detail{color:var(--text-secondary);font-size:13px}.btn-play-game{font-family:var(--font-clean);background:linear-gradient(135deg, var(--accent-orange), #ff8c42);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:600;transition:opacity .2s}.btn-play-game:hover{opacity:.9}.section-title{font-family:var(--font-clean);color:var(--text-secondary);margin-bottom:12px;font-size:16px;font-weight:600}.leaderboard{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;margin-bottom:24px;overflow:hidden}.leaderboard-table{border-collapse:collapse;width:100%;font-family:var(--font-clean);font-size:14px}.leaderboard-table th{text-align:left;color:var(--text-muted);border-bottom:1px solid var(--border-color);padding:10px 14px;font-size:12px;font-weight:500}.leaderboard-table td{color:var(--text-secondary);border-bottom:1px solid var(--border-color);padding:10px 14px}.leaderboard-table tr:last-child td{border-bottom:none}.leaderboard-first td{color:var(--accent-gold);font-weight:600}.leaderboard-rank{width:40px;font-size:18px}.leaderboard-name{color:var(--text-primary);font-weight:500}.parent-loading,.parent-empty{text-align:center;color:var(--text-secondary);padding:40px 0;font-size:14px}.children-grid{flex-direction:column;gap:12px;margin-bottom:24px;display:flex}.child-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;align-items:center;gap:16px;padding:16px;transition:border-color .2s;display:flex}.child-card:hover{border-color:var(--accent-orange)}.child-card-avatar{cursor:pointer;flex-shrink:0}.child-card-info{cursor:pointer;flex:1}.child-card-name{font-family:var(--font-clean);color:var(--text-primary);margin-bottom:2px;font-size:16px;font-weight:600}.child-card-stat{color:var(--text-secondary);margin-bottom:2px;font-size:13px}.child-card-stage{color:var(--accent-orange);font-size:12px}.btn-generate-code{font-family:var(--font-clean);background:var(--accent-orange);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:6px;flex-shrink:0;padding:8px 14px;font-size:12px;transition:opacity .2s}.btn-generate-code:hover{opacity:.85}.btn-add-child{width:100%;font-family:var(--font-clean);color:var(--text-secondary);border:2px dashed var(--border-color);cursor:pointer;background:0 0;border-radius:10px;padding:14px;font-size:15px;font-weight:600;transition:border-color .2s,color .2s;display:block}.btn-add-child:hover{border-color:var(--accent-orange);color:var(--accent-orange)}.add-child-form{flex-direction:column;gap:8px;display:flex}.add-child-actions{gap:8px;display:flex}.add-child-actions .btn-parent-primary,.add-child-actions .btn-parent-secondary{flex:1}.otp-modal-overlay{z-index:500;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.otp-modal{background:var(--bg-card);border:1px solid var(--border-color);text-align:center;border-radius:16px;width:90%;max-width:360px;padding:32px}.otp-modal-title{font-family:var(--font-clean);color:var(--text-primary);margin-bottom:4px;font-size:20px;font-weight:600}.otp-modal-hint{color:var(--text-secondary);margin-bottom:16px;font-size:13px}.otp-code-display{letter-spacing:12px;color:var(--accent-gold);background:var(--bg-dark);border-radius:8px;margin-bottom:8px;padding:16px;font-family:JetBrains Mono,Consolas,monospace;font-size:48px;font-weight:600}.otp-modal-expiry{color:var(--text-muted);margin-bottom:20px;font-size:12px}.child-detail-summary{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;align-items:center;gap:24px;margin-bottom:16px;padding:20px;display:flex}.child-detail-stats{flex:1;grid-template-columns:1fr 1fr;gap:12px;display:grid}.detail-stat{flex-direction:column;gap:2px;display:flex}.detail-stat-label{color:var(--text-muted);text-transform:uppercase;font-size:11px}.detail-stat-value{font-family:var(--font-clean);color:var(--text-primary);font-size:18px;font-weight:600}.detail-tabs{gap:4px;margin-bottom:16px;display:flex}.detail-tab{font-family:var(--font-clean);background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border-color);cursor:pointer;border-radius:8px;flex:1;padding:10px;font-size:14px;font-weight:500;transition:all .2s}.detail-tab.active{background:var(--accent-orange);color:#fff;border-color:var(--accent-orange)}.chart-title{font-family:var(--font-clean);color:var(--text-secondary);margin:20px 0 8px;font-size:15px;font-weight:600}.chart-container{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;padding:16px 8px}.history-table-wrap{border:1px solid var(--border-color);border-radius:10px;overflow-x:auto}.history-table{border-collapse:collapse;width:100%;font-family:var(--font-clean);font-size:13px}.history-table th{text-align:left;background:var(--bg-card);color:var(--text-muted);border-bottom:1px solid var(--border-color);white-space:nowrap;padding:10px 12px;font-weight:500}.history-table td{color:var(--text-secondary);border-bottom:1px solid var(--border-color);white-space:nowrap;padding:8px 12px}.history-table tr:last-child td{border-bottom:none}.detail-sessions{flex-direction:column;gap:8px;display:flex}.session-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.session-info{flex-direction:column;gap:2px;display:flex}.session-device{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;max-width:300px;font-size:14px;overflow:hidden}.session-date{color:var(--text-muted);font-size:12px}.error-screen{min-height:100vh;font-family:var(--font-pixel);color:var(--accent-red);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@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}
