@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700;900&family=DM+Mono:wght@400;500&family=Nunito:wght@400;600;700;800&display=swap";:root{--bg: #07090F;--sf: #0E1220;--sf2: #151C30;--gold: #FFCA3A;--teal: #4DD9E8;--purple: #C77DFF;--green: #52E08A;--red: #FF6B6B;--text: #E8EDF5;--muted: #8896B8;--border: #1C2438;--font-display: "Playfair Display", Georgia, serif;--font-mono: "DM Mono", "Courier New", monospace;--font-body: "Nunito", system-ui, sans-serif;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--transition: .2s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-tap-highlight-color:transparent}body{background:var(--bg);color:var(--text);font-family:var(--font-body);line-height:1.5}button{font-family:inherit;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.35}.app{min-height:100svh;display:flex;flex-direction:column;align-items:center;padding:0 16px 48px}.header{width:100%;max-width:540px;display:flex;align-items:center;justify-content:space-between;padding:18px 0 12px;border-bottom:1px solid var(--border);margin-bottom:6px}.header__logo{font-family:var(--font-display);font-weight:900;font-size:20px;background:linear-gradient(135deg,var(--gold),var(--teal));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header__tagline{font-family:var(--font-mono);font-size:9px;letter-spacing:3px;color:var(--muted);text-transform:uppercase;margin-top:2px}.header__actions{display:flex;align-items:center;gap:8px}.streak-badge{font-family:var(--font-mono);font-size:13px;color:var(--gold);background:#ffca3a14;padding:4px 10px;border-radius:20px;border:1px solid rgba(255,202,58,.15)}.icon-btn{background:var(--sf);border:1px solid var(--border);color:var(--muted);font-size:15px;width:34px;height:34px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:border-color var(--transition)}.icon-btn:hover{border-color:var(--gold)}.icon-btn--wide{width:auto;padding:0 10px;font-size:12px}.tab-bar{width:100%;max-width:540px;display:flex;margin:12px 0 16px;background:var(--sf);border-radius:var(--radius-lg);padding:4px;border:1px solid var(--border)}.tab-btn{flex:1;font-weight:800;font-size:13px;background:none;border:none;color:var(--muted);padding:10px;border-radius:11px;transition:all var(--transition)}.tab-btn--active{background:var(--sf2);box-shadow:0 2px 12px #0000004d}.tab-btn--daily.tab-btn--active{color:var(--gold)}.tab-btn--battle.tab-btn--active{color:var(--purple)}.region-bar{width:100%;max-width:540px;margin-bottom:10px}.region-bar__row{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.region-btn{font-family:var(--font-mono);font-size:10px;padding:5px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--sf);color:var(--muted);transition:all var(--transition)}.region-btn:hover{border-color:var(--teal);color:var(--teal)}.region-btn--active{background:#4dd9e81a;color:var(--teal);border-color:#4dd9e84d}.level-bar{width:100%;max-width:540px;display:flex;align-items:center;gap:10px;margin-bottom:12px;padding:10px 14px;background:var(--sf);border:1px solid var(--border);border-radius:var(--radius-md)}.level-bar__badge{font-family:var(--font-display);font-weight:900;font-size:18px;color:var(--gold);min-width:32px;text-align:center}.level-bar__info{flex:1;display:flex;flex-direction:column;gap:4px}.level-bar__name{font-family:var(--font-mono);font-size:11px;color:var(--teal);letter-spacing:1.5px;text-transform:uppercase}.level-bar__track{width:100%;height:5px;background:var(--border);border-radius:3px;overflow:hidden}.level-bar__fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--teal));border-radius:3px;transition:width .6s ease}.level-bar__xp{font-family:var(--font-mono);font-size:9px;color:var(--muted);text-align:right}.mode-badge{font-family:var(--font-mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;border-radius:var(--radius-sm);padding:4px 12px;text-align:center;max-width:540px;width:100%;margin-bottom:4px}.mode-badge--blind{color:var(--red);background:#ff6b6b14;border:1px solid rgba(255,107,107,.15)}.mode-badge--scramble{color:var(--purple);background:#c77dff14;border:1px solid rgba(199,125,255,.15)}.challenge-toggle{display:flex;align-items:center;gap:8px;margin-bottom:12px;width:100%;max-width:540px}.challenge-toggle__btn{flex:1;font-weight:700;font-size:12px;padding:8px 14px;border-radius:var(--radius-sm);transition:all var(--transition);text-align:center;border:1px solid var(--border)}.challenge-toggle__btn--off{background:var(--sf);color:var(--muted)}.challenge-toggle__btn--normal{background:#4dd9e81a;color:var(--teal);border-color:#4dd9e84d}.challenge-toggle__btn--on{background:#ff6b6b1a;color:var(--red);border-color:#ff6b6b4d}.key-ref{width:100%;max-width:540px;margin-bottom:12px}.key-ref__toggle{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;background:var(--sf);border:1px solid var(--border);border-radius:var(--radius-md);padding:9px;color:var(--teal);font-family:var(--font-mono);font-size:12px;transition:border-color var(--transition)}.key-ref__toggle:hover{border-color:var(--teal)}.key-ref__cost{font-size:9px;color:var(--red);margin-left:4px}.key-ref__chevron{transition:transform .3s;font-size:10px}.key-ref__chevron--open{transform:rotate(180deg)}.key-ref__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(50px,1fr));gap:3px;padding:8px 0;font-family:var(--font-mono);font-size:11px}.key-ref__cell{background:var(--sf);border:1px solid var(--border);border-radius:7px;padding:5px 3px;text-align:center;color:var(--teal)}.key-ref__letter{font-weight:700;font-size:12px;display:block}.key-ref__number{color:var(--muted);font-size:9px;display:block}.game-timer{width:100%;max-width:540px;display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:8px}.game-timer__icon{font-family:var(--font-mono);font-size:10px;color:var(--muted);letter-spacing:2px}.game-timer__display{font-family:var(--font-mono);font-size:22px;color:var(--teal);padding:7px 18px;background:var(--sf);border:1px solid var(--border);border-radius:var(--radius-md);min-width:90px;text-align:center;transition:color var(--transition)}.game-timer__display--fast{color:var(--green)}.game-timer__display--mid{color:var(--gold)}.game-timer__display--slow{color:var(--red)}.game-timer__display--paused{opacity:.6}.puzzle-area{width:100%;max-width:540px;display:flex;flex-direction:column;gap:12px;margin-bottom:18px}.word-box{background:var(--sf);border-radius:var(--radius-lg);padding:16px 14px 12px;border:1px solid rgba(255,255,255,.06);transition:border-color var(--transition),box-shadow var(--transition);position:relative;box-shadow:inset 0 1px #ffffff08}.word-box--correct{border-color:var(--green);box-shadow:0 0 20px #52e08a1a}.word-box--correct-battle{border-color:var(--purple);box-shadow:0 0 20px #c77dff1a}.word-box--win-glow{animation:wbGlowGreen .6s ease-out both}.word-box--win-glow-b{animation:wbGlowPurple .6s ease-out both}.word-box--wrong{animation:shake .4s;border-color:var(--red);box-shadow:0 0 16px #ff6b6b26}.word-box--right-flash{border-color:var(--green);box-shadow:0 0 16px #52e08a26;animation:rightPulse .6s ease-out}.word-box__label{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:3px;color:var(--muted);margin-bottom:10px}.digit-row{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;margin-bottom:8px}.digit-row--won{animation:digitFade .4s ease-out both}.digit{font-family:var(--font-mono);font-size:26px;color:var(--text);width:32px;height:42px;display:flex;align-items:center;justify-content:center;user-select:none}.separator-zone{width:28px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer}.separator-zone:hover .separator-dot{background:var(--gold);opacity:1;transform:scale(1.4);box-shadow:0 0 8px #ffca3a66}.separator-zone--battle:hover .separator-dot{background:var(--purple);box-shadow:0 0 8px #c77dff66}.separator-dot{width:8px;height:8px;background:#ffca3a59;border-radius:50%;opacity:1;transition:all var(--transition);animation:dotPulse 2s ease-in-out infinite;box-shadow:0 0 4px #ffca3a26}.separator-bar{width:4px;height:32px;background:var(--gold);border-radius:2px;box-shadow:0 0 12px #ffca3a66;animation:separatorPop .2s ease-out}.separator-bar--battle{background:var(--purple);box-shadow:0 0 12px #c77dff66}.letter-display{display:flex;align-items:center;justify-content:center;gap:4px;min-height:34px;flex-wrap:wrap}.letter-cell{font-family:var(--font-display);font-weight:800;font-size:16px;width:31px;height:31px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;animation:letterIn .2s ease-out}.letter-cell--valid{background:#4dd9e81a;color:var(--teal);border:1px solid rgba(77,217,232,.2)}.letter-cell--invalid{background:#ff6b6b1a;color:var(--red);border:1px solid rgba(255,107,107,.2)}.letter-cell--solved{background:#52e08a1f;color:var(--green);border:1px solid rgba(82,224,138,.25)}.letter-cell--solved-b{background:#c77dff1f;color:var(--purple);border:1px solid rgba(199,125,255,.25)}.letter-cell--win-flip{animation:winFlip .5s ease-out both;background:#52e08a2e;color:var(--green);border:1px solid rgba(82,224,138,.4)}.letter-cell--win-flip-b{animation:winFlip .5s ease-out both;background:#c77dff2e;color:var(--purple);border:1px solid rgba(199,125,255,.4)}.scramble-badge{position:absolute;top:-8px;left:-8px;width:22px;height:22px;border-radius:50%;background:var(--purple);color:var(--bg);font-family:var(--font-mono);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2;transition:all var(--transition)}.scramble-badge:hover{transform:scale(1.15)}.scramble-badge--selected{background:var(--gold);box-shadow:0 0 12px #ffca3a66}.controls{width:100%;max-width:540px;display:flex;flex-direction:column;align-items:center;gap:10px}.btn-primary{font-weight:800;font-size:15px;letter-spacing:2px;text-transform:uppercase;background:linear-gradient(135deg,var(--gold),#E5B020);color:#0a0e1a;border:none;border-radius:var(--radius-lg);padding:13px 44px;width:100%;max-width:280px;transition:all var(--transition)}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 24px #ffca3a33}.btn-primary--battle{background:linear-gradient(135deg,var(--purple),#A050E0);color:#fff}.btn-primary--battle:hover:not(:disabled){box-shadow:0 6px 24px #c77dff33}.btn-secondary{font-weight:600;font-size:14px;background:var(--sf2);color:var(--muted);border:1px solid var(--border);border-radius:var(--radius-md);padding:9px 22px;transition:all var(--transition)}.btn-secondary:hover:not(:disabled){border-color:var(--gold);color:var(--gold)}.btn-secondary--speed{background:#ff6b6b1a!important;border-color:#ff6b6b40!important;color:var(--red)!important}.attempts-label{font-family:var(--font-mono);font-size:12px;color:var(--muted)}.hint-panel{background:var(--sf2);border:1px solid var(--border);border-radius:var(--radius-md);padding:10px 14px;width:100%;max-width:540px;margin-bottom:4px}.hint-panel__line{font-size:13px;color:var(--gold);margin-bottom:3px}.hint-panel__line:last-child{margin-bottom:0}.hint-panel__label{font-family:var(--font-mono);font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px}.puzzle-subtitle{width:100%;max-width:540px;text-align:center;font-size:13px;color:var(--muted);margin-bottom:14px}.speed-header{width:100%;max-width:540px;background:linear-gradient(135deg,#ff6b6b14,#ffca3a14);border:1px solid rgba(255,107,107,.2);border-radius:var(--radius-lg);padding:12px 16px;display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.speed-header__title{font-family:var(--font-mono);font-size:12px;font-weight:700;letter-spacing:1.5px;color:var(--red)}.speed-header__timer{font-family:var(--font-mono);font-size:24px;font-weight:700;color:var(--gold)}.speed-header__timer--urgent{color:var(--red);animation:urgentPulse .5s ease-in-out infinite}.speed-header__score{font-family:var(--font-mono);font-size:14px;color:var(--teal)}.overlay{position:fixed;inset:0;background:#0a0e1aeb;display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .3s;padding:20px}.modal{background:var(--sf);border:1px solid var(--border);border-radius:var(--radius-xl);padding:28px 24px;max-width:380px;width:100%;text-align:center;animation:slideUp .3s ease-out}.modal__title{font-family:var(--font-display);font-weight:900;font-size:24px;margin-bottom:4px}.modal__title--win{background:linear-gradient(135deg,var(--gold),var(--green));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.modal__title--battle{background:linear-gradient(135deg,var(--purple),var(--teal));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.modal__title--loss{color:var(--red)}.modal__stars{font-size:24px;margin:8px 0;letter-spacing:4px}.modal__phrase{font-family:var(--font-display);font-weight:800;font-size:18px;color:var(--teal);margin:10px 0}.modal__stat{font-family:var(--font-mono);font-size:11px;color:var(--muted);margin:3px 0}.time-tag{display:inline-block;font-family:var(--font-mono);font-size:13px;padding:3px 10px;border-radius:6px}.time-tag--fast{background:#52e08a1f;color:var(--green)}.time-tag--mid{background:#ffca3a1f;color:var(--gold)}.time-tag--slow{background:#ff6b6b1f;color:var(--red)}.btn-action{font-weight:800;font-size:13px;letter-spacing:1.5px;text-transform:uppercase;background:linear-gradient(135deg,var(--teal),#2BB0C0);color:#0a0e1a;border:none;border-radius:var(--radius-md);padding:12px 32px;cursor:pointer;margin-top:14px;width:100%}.btn-close{background:none;border:1px solid var(--border);color:var(--muted);border-radius:var(--radius-md);padding:9px;font-size:14px;cursor:pointer;margin-top:8px;width:100%;transition:border-color var(--transition),color var(--transition)}.btn-close:hover{border-color:var(--gold);color:var(--gold)}.copy-confirm{font-size:12px;color:var(--green);margin-top:6px}.streak-badges{display:flex;flex-wrap:wrap;gap:4px;justify-content:center;margin-top:6px}.streak-badge-chip{display:inline-flex;align-items:center;gap:4px;font-family:var(--font-mono);font-size:10px;padding:3px 8px;border-radius:6px;background:#ffca3a14;border:1px solid rgba(255,202,58,.15);color:var(--gold)}.cinematic{position:fixed;inset:0;z-index:150;background:#0a0e1af2;display:flex;flex-direction:column;align-items:center;justify-content:center;animation:fadeIn .4s;pointer-events:none}.cinematic__glow{position:absolute;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(255,202,58,.12) 0%,transparent 70%);animation:glowPulse 2s ease-in-out infinite alternate}.cinematic__glow--battle{background:radial-gradient(circle,rgba(199,125,255,.12) 0%,transparent 70%)}.cinematic__phrase{display:flex;flex-wrap:wrap;justify-content:center;gap:6px;max-width:480px;padding:0 20px}.cinematic__word{display:flex;gap:2px}.cinematic__letter{font-family:var(--font-display);font-weight:900;font-size:42px;opacity:0;transform:translateY(20px) scale(.5);color:var(--gold)}.cinematic__letter--show{animation:cinLetter .5s ease-out forwards}.cinematic__letter--battle{color:var(--purple)}.cinematic__stars{margin-top:20px;font-size:32px;letter-spacing:6px;opacity:0;animation:cinStars .6s ease-out forwards}.cinematic__xp{font-family:var(--font-mono);font-size:16px;color:var(--gold);margin-top:12px;opacity:0;animation:cinXp .4s ease-out forwards}.onboarding-overlay{position:fixed;inset:0;background:#04060cf7;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:300;animation:fadeIn .4s;padding:20px}.onboarding-card{max-width:420px;width:100%;text-align:center;animation:slideUp .4s;background:var(--sf);border:1px solid rgba(255,202,58,.12);border-radius:24px;padding:36px 28px;box-shadow:0 0 0 1px #ffca3a0a,0 0 80px #ffca3a0d,0 32px 64px #0009}.onboarding-card h2{font-family:var(--font-display);font-weight:900;font-size:30px;background:linear-gradient(135deg,var(--gold),var(--teal));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:12px;letter-spacing:-.5px}.onboarding-dots{display:flex;justify-content:center;gap:8px;margin-bottom:16px}.onboarding-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:all .3s}.onboarding-dot--active{background:var(--gold);width:22px;border-radius:4px}.onboarding-step{font-family:var(--font-mono);font-size:10px;color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-bottom:16px}.tutorial-msg{font-size:15px;color:#b4c0d8;line-height:1.8;margin-bottom:12px;text-align:center;max-width:380px}.tutorial-msg .hl{color:var(--gold);font-weight:700}.tutorial-msg .hl2{color:var(--teal);font-weight:700}.tutorial-puzzle{background:var(--sf2);border:1px solid rgba(255,202,58,.1);border-radius:var(--radius-lg);padding:20px 18px;margin:16px auto;max-width:360px;box-shadow:inset 0 1px #ffffff08}.tutorial-digit-row{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;margin-bottom:10px}.tutorial-digit{font-family:var(--font-mono);font-size:32px;color:var(--text);width:38px;height:52px;display:flex;align-items:center;justify-content:center;font-weight:500}.tutorial-sep-zone{width:24px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative}.tutorial-sep-zone:hover .tutorial-sep-dot{background:var(--gold);opacity:.7;transform:scale(1.3)}.tutorial-sep-dot{width:7px;height:7px;background:#ffca3a59;border-radius:50%;opacity:1;transition:all var(--transition);box-shadow:0 0 4px #ffca3a26}.tutorial-sep-bar{width:3px;height:34px;background:var(--gold);border-radius:2px;box-shadow:0 0 10px #ffca3a66;animation:separatorPop .2s ease-out}.tutorial-pulse{position:absolute;width:28px;height:28px;border-radius:50%;border:2px solid var(--gold);animation:pulsing 1.2s ease-in-out infinite;pointer-events:none}.tutorial-letter-row{display:flex;align-items:center;justify-content:center;gap:5px;min-height:36px}.tutorial-letter{font-family:var(--font-display);font-weight:800;font-size:18px;width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;transition:all .3s}.tutorial-letter--valid{background:#4dd9e81a;color:var(--teal);border:1px solid rgba(77,217,232,.2)}.tutorial-letter--invalid{background:#ff6b6b1a;color:var(--red);border:1px solid rgba(255,107,107,.2)}.tutorial-letter--solved{background:#52e08a26;color:var(--green);border:1px solid rgba(82,224,138,.3);animation:letterIn .3s ease-out}.tutorial-ok{font-size:14px;color:var(--green);font-weight:700;text-align:center;margin-top:10px;animation:fadeIn .3s}.tutorial-err{font-size:13px;color:var(--red);text-align:center;margin-top:8px;animation:fadeIn .3s}.tutorial-word-label{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:3px;color:var(--muted);margin-bottom:6px;text-align:center}.btn-tutorial-check{font-weight:800;font-size:14px;background:linear-gradient(135deg,var(--gold),#E5B020);color:#0a0e1a;border:none;border-radius:var(--radius-md);padding:11px 32px;cursor:pointer;margin-top:12px;transition:all var(--transition)}.btn-tutorial-check:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #ffca3a33}.onboarding-nav{display:flex;gap:10px;justify-content:center;margin-top:12px}.btn-skip{font-weight:600;font-size:14px;background:none;border:1px solid var(--border);color:var(--muted);border-radius:var(--radius-md);padding:11px 26px;cursor:pointer}.btn-next{font-weight:800;font-size:14px;background:linear-gradient(135deg,var(--gold),#E5B020);color:#0a0e1a;border:none;border-radius:var(--radius-md);padding:11px 32px;cursor:pointer}.celebrate-emoji{font-size:48px;margin:12px 0}.mechanic-overlay{position:fixed;inset:0;background:#0a0e1af2;display:flex;align-items:center;justify-content:center;z-index:300;animation:fadeIn .4s;padding:20px}.mechanic-card{max-width:380px;width:100%;text-align:center;background:var(--sf);border:1px solid var(--border);border-radius:var(--radius-xl);padding:28px 24px;animation:slideUp .4s}.mechanic-icon{font-size:48px;margin-bottom:12px}.mechanic-title{font-family:var(--font-display);font-weight:900;font-size:22px;margin-bottom:8px}.mechanic-title--blind{background:linear-gradient(135deg,var(--red),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.mechanic-title--scramble{background:linear-gradient(135deg,var(--purple),var(--teal));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.mechanic-body{font-size:14px;color:var(--muted);line-height:1.7;margin-bottom:16px}.mechanic-body b{color:var(--text);font-weight:700}.btn-mechanic-go{font-weight:800;font-size:15px;letter-spacing:1.5px;text-transform:uppercase;background:linear-gradient(135deg,var(--gold),var(--teal));color:#0a0e1a;border:none;border-radius:var(--radius-lg);padding:13px 40px;cursor:pointer;width:100%}.battle-hub{width:100%;max-width:540px;display:flex;flex-direction:column;align-items:center;gap:14px}.input-label{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:2px;color:var(--muted);margin-bottom:5px;text-align:center}.phrase-input{width:100%;font-family:var(--font-mono);font-size:16px;letter-spacing:2px;text-transform:uppercase;background:var(--sf);border:2px solid var(--border);border-radius:var(--radius-lg);color:var(--text);padding:14px;outline:none;text-align:center;transition:border-color var(--transition)}.phrase-input::placeholder{color:var(--muted);font-size:13px;text-transform:none;letter-spacing:1px}.phrase-input:focus{border-color:var(--purple)}.phrase-input--sm{font-size:13px}.encoded-preview{width:100%;background:var(--sf);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px;text-align:center}.encoded-preview__label{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:2px;color:var(--muted);margin-bottom:8px}.encoded-preview__digits{font-family:var(--font-mono);font-size:20px;color:var(--purple);letter-spacing:3px;word-break:break-all;line-height:1.6}.encoded-preview__gap{display:inline-block;width:16px}.ambiguity-meter{width:100%;background:var(--sf2);border-radius:var(--radius-md);padding:12px;border:1px solid var(--border)}.ambiguity-meter__label{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:2px;color:var(--muted);margin-bottom:6px}.ambiguity-meter__track{width:100%;height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin-bottom:5px}.ambiguity-meter__fill{height:100%;border-radius:3px;transition:width .4s,background .4s}.ambiguity-meter__count{font-family:var(--font-mono);font-size:12px;color:var(--purple);text-align:right}.coaching-tip{font-size:12px;color:var(--purple);background:#c77dff0f;border:1px solid rgba(199,125,255,.15);border-radius:var(--radius-sm);padding:10px 14px;text-align:center;width:100%;animation:fadeIn .3s}.coaching-tip .tip-hl{color:var(--gold);font-weight:700}.code-box{width:100%;background:var(--sf);border:2px dashed var(--purple);border-radius:var(--radius-lg);padding:18px;text-align:center}.code-box__label{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:2px;color:var(--muted);margin-bottom:6px}.code-textarea{width:100%;font-family:var(--font-mono);font-size:12px;color:var(--purple);background:#c77dff0d;border:1px solid rgba(199,125,255,.2);border-radius:var(--radius-sm);padding:10px;resize:none;outline:none;text-align:center;margin-bottom:10px}.code-textarea:focus{border-color:var(--purple)}.code-box__actions{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.btn-code{font-weight:700;font-size:13px;background:#c77dff1f;color:var(--purple);border:1px solid rgba(199,125,255,.25);border-radius:var(--radius-sm);padding:9px 20px;cursor:pointer}.sub-tabs{display:flex;gap:8px;margin-bottom:4px}.sub-tab{font-weight:700;font-size:13px;background:var(--sf2);color:var(--muted);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 18px;cursor:pointer;transition:all var(--transition)}.sub-tab--active{background:#c77dff1a;color:var(--purple);border-color:#c77dff40}.diff-badge{font-family:var(--font-mono);font-size:10px;letter-spacing:1px;padding:3px 8px;border-radius:6px;display:inline-block}.diff-badge--easy{background:#52e08a1a;color:var(--green)}.diff-badge--medium{background:#ffca3a1a;color:var(--gold)}.diff-badge--hard{background:#c77dff1a;color:var(--purple)}.diff-badge--expert{background:#ff6b6b1a;color:var(--red)}.battle-stats{width:100%;background:var(--sf);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;margin-top:8px}.battle-stats__title{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:2px;color:var(--muted);margin-bottom:10px;text-align:center}.battle-stats__row{display:flex;justify-content:space-between;align-items:center;padding:6px 0}.battle-stats__label{font-size:13px;color:var(--muted)}.battle-stats__value{font-family:var(--font-mono);font-size:14px;font-weight:700;color:var(--teal)}.battle-stats__value--win{color:var(--green)}.battle-stats__value--loss{color:var(--red)}.error-msg{font-size:13px;color:var(--red);text-align:center}.share-card-wrapper{width:100%;margin-top:10px}.share-card-wrapper img{width:100%;border-radius:var(--radius-sm);margin-bottom:8px}.share-card-tagline{font-size:11px;color:var(--muted);margin-bottom:8px;font-style:italic}.share-card-actions{display:flex;gap:8px}.btn-share-dl{flex:1;padding:9px;background:#4dd9e81a;border:1px solid rgba(77,217,232,.25);border-radius:var(--radius-sm);color:var(--teal);font-weight:700;font-size:12px;cursor:pointer}.btn-share-link{flex:1;padding:9px;background:#ffca3a1a;border:1px solid rgba(255,202,58,.25);border-radius:var(--radius-sm);color:var(--gold);font-weight:700;font-size:12px;cursor:pointer}.btn-share-gen{width:100%;padding:10px;background:#4dd9e81a;border:1px solid rgba(77,217,232,.25);border-radius:var(--radius-sm);color:var(--teal);font-weight:700;font-size:13px;cursor:pointer}.level-up-toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:250;text-align:center;animation:levelUpAnim 2s ease-out forwards;pointer-events:none}.level-up-toast h3{font-family:var(--font-display);font-weight:900;font-size:32px;background:linear-gradient(135deg,var(--gold),var(--teal));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.level-up-toast p{font-family:var(--font-mono);font-size:14px;color:var(--teal);margin-top:4px}.confetti-container{position:fixed;inset:0;pointer-events:none;z-index:200;overflow:hidden}.confetti-piece{position:absolute;opacity:0;animation:confettiFall 2.5s ease-out forwards}.feedback-bar{display:flex;justify-content:center;margin-top:16px}.feedback-bar a{font-family:var(--font-body);font-weight:700;font-size:13px;color:var(--teal);background:#4dd9e814;border:1px solid rgba(77,217,232,.25);border-radius:var(--radius-md);padding:10px 24px;text-decoration:none;transition:all var(--transition);animation:feedbackPulse 3s ease-in-out infinite}.feedback-bar a:hover{background:#4dd9e826;border-color:#4dd9e866;transform:translateY(-1px)}.app-footer{margin-top:22px;font-family:var(--font-mono);font-size:10px;color:var(--muted);text-align:center;opacity:.4}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}@keyframes letterIn{0%{opacity:0;transform:scale(.7) translateY(3px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes separatorPop{0%{transform:scaleY(0)}60%{transform:scaleY(1.15)}to{transform:scaleY(1)}}@keyframes dotPulse{0%,to{transform:scale(1);opacity:.6}50%{transform:scale(1.25);opacity:1}}@keyframes pulsing{0%,to{transform:scale(.8);opacity:.3}50%{transform:scale(1.3);opacity:.8}}@keyframes digitFade{0%{opacity:1}to{opacity:.3}}@keyframes rightPulse{0%{box-shadow:0 0 #52e08a00}50%{box-shadow:0 0 20px #52e08a40}to{box-shadow:0 0 16px #52e08a26}}@keyframes urgentPulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes confettiFall{0%{opacity:1;transform:translateY(-20px) rotate(0)}to{opacity:0;transform:translateY(100vh) rotate(720deg)}}@keyframes feedbackPulse{0%,to{box-shadow:0 0 #4dd9e800}50%{box-shadow:0 0 14px #4dd9e826}}@keyframes levelUpAnim{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}15%{opacity:1;transform:translate(-50%,-50%) scale(1.1)}30%{transform:translate(-50%,-50%) scale(1)}80%{opacity:1}to{opacity:0;transform:translate(-50%,-60%)}}@keyframes wbGlowGreen{0%{border-color:var(--border);box-shadow:none}50%{border-color:var(--green);box-shadow:0 0 30px #52e08a33}to{border-color:var(--green);box-shadow:0 0 20px #52e08a1a}}@keyframes wbGlowPurple{0%{border-color:var(--border);box-shadow:none}50%{border-color:var(--purple);box-shadow:0 0 30px #c77dff33}to{border-color:var(--purple);box-shadow:0 0 20px #c77dff1a}}@keyframes winFlip{0%{transform:rotateX(90deg) scale(.5);opacity:0}50%{transform:rotateX(-10deg) scale(1.15);opacity:1}70%{transform:rotateX(5deg) scale(1.05)}to{transform:rotateX(0) scale(1);box-shadow:0 0 12px #52e08a4d}}@keyframes cinLetter{0%{opacity:0;transform:translateY(20px) scale(.5);text-shadow:none}60%{opacity:1;transform:translateY(-4px) scale(1.1);text-shadow:0 0 30px rgba(255,202,58,.5)}to{opacity:1;transform:translateY(0) scale(1);text-shadow:0 0 15px rgba(255,202,58,.2)}}@keyframes cinStars{0%{opacity:0;transform:scale(.3)}50%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}@keyframes cinXp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes glowPulse{0%{transform:scale(.8);opacity:.3}to{transform:scale(1.3);opacity:.6}}@media (max-width: 480px){.digit{font-size:22px;width:28px;height:44px}.separator-zone{width:32px;height:44px}.separator-dot{width:10px;height:10px}.letter-cell{width:28px;height:28px;font-size:13px}.header__logo{font-size:17px}.tutorial-digit{font-size:24px;width:30px;height:40px}.tutorial-sep-zone{min-width:32px;min-height:44px}.tutorial-sep-zone{width:20px}}.auth-overlay{position:fixed;inset:0;z-index:200;background:#000000b3;backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:16px}.auth-modal{background:var(--sf);border:1px solid var(--border);border-radius:var(--radius-xl);padding:28px 24px;width:100%;max-width:400px;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 24px 60px #0009}.auth-close{position:absolute;top:14px;right:14px;background:none;border:none;color:var(--muted);font-size:16px;cursor:pointer;line-height:1;padding:4px 8px;border-radius:6px}.auth-close:hover{color:var(--text)}.auth-title{font-family:var(--font-display);font-size:22px;color:var(--gold);margin:0 0 4px;text-align:center}.auth-subtitle{font-size:13px;color:var(--muted);text-align:center;margin:0 0 18px}.auth-form{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}.auth-input{background:var(--sf2);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);padding:12px 14px;font-size:14px;font-family:var(--font-body);outline:none}.auth-input:focus{border-color:var(--teal)}.auth-btn-primary{background:var(--gold);color:#0a0e1a;border:none;border-radius:var(--radius-md);padding:13px;font-size:14px;font-weight:800;font-family:var(--font-body);cursor:pointer;transition:opacity .15s}.auth-btn-primary:hover:not(:disabled){opacity:.88}.auth-btn-primary:disabled{opacity:.5;cursor:default}.auth-btn-ghost{width:100%;background:none;border:1px solid var(--border);color:var(--muted);border-radius:var(--radius-md);padding:11px;font-size:13px;cursor:pointer;margin-top:8px}.auth-btn-ghost:hover{border-color:var(--red);color:var(--red)}.auth-btn-google{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;background:#fff;color:#333;border:none;border-radius:var(--radius-md);padding:12px;font-size:14px;font-weight:600;font-family:var(--font-body);cursor:pointer;transition:opacity .15s;margin-bottom:4px}.auth-btn-google:hover:not(:disabled){opacity:.9}.auth-divider{display:flex;align-items:center;gap:10px;margin:10px 0;color:var(--muted);font-size:12px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.auth-error{color:var(--red);font-size:12px;margin:0}.auth-success{color:var(--green);font-size:12px;margin:0}.auth-switch{text-align:center;font-size:13px;color:var(--muted);margin:8px 0 0}.auth-link{background:none;border:none;color:var(--teal);cursor:pointer;font-size:13px;text-decoration:underline}.auth-legal{font-size:11px;color:var(--muted);text-align:center;margin:8px 0 0}.auth-legal a{color:var(--teal)}.profile-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:20px}.pstat{background:var(--sf2);border-radius:var(--radius-md);padding:12px 6px;text-align:center}.pstat-num{display:block;font-family:var(--font-mono);font-size:20px;color:var(--gold);font-weight:700}.pstat-label{display:block;font-size:10px;color:var(--muted);margin-top:4px}.auth-label{font-size:12px;color:var(--muted);margin-bottom:4px;display:block}.lb-modal{background:var(--sf);border:1px solid var(--border);border-radius:var(--radius-xl);padding:24px 20px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 24px 60px #0009}.lb-tabs{display:flex;gap:8px;margin-bottom:16px}.lb-tab{flex:1;background:var(--sf2);border:1px solid var(--border);color:var(--muted);border-radius:var(--radius-md);padding:10px 6px;font-size:12px;cursor:pointer;font-family:var(--font-body);transition:all .15s}.lb-tab.active{background:var(--gold);color:#0a0e1a;border-color:var(--gold);font-weight:800}.lb-table{display:flex;flex-direction:column;gap:4px}.lb-header{display:grid;grid-template-columns:48px 1fr 70px 60px 40px;gap:4px;padding:6px 10px;font-size:10px;color:var(--muted);font-family:var(--font-mono);letter-spacing:1px;text-transform:uppercase}.lb-row{display:grid;grid-template-columns:48px 1fr 70px 60px 40px;gap:4px;align-items:center;background:var(--sf2);border-radius:var(--radius-md);padding:10px;border:1px solid transparent;transition:border-color .15s}.lb-row-me{border-color:var(--gold)!important}.lb-rank{font-family:var(--font-mono);font-size:13px;color:var(--gold)}.lb-name{font-size:13px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lb-score{font-family:var(--font-mono);font-size:12px;color:var(--green);text-align:right}.lb-time{font-family:var(--font-mono);font-size:11px;color:var(--teal);text-align:right}.lb-tries{font-family:var(--font-mono);font-size:11px;color:var(--muted);text-align:right}.lb-empty{text-align:center;padding:32px 20px;color:var(--muted);font-size:14px;line-height:1.6}.lb-empty-sub{font-size:12px;margin-top:6px}.lb-loading{text-align:center;padding:32px 20px;color:var(--muted)}.lb-spinner{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 10px}@keyframes spin{to{transform:rotate(360deg)}}.lb-signin-nudge{margin-top:16px;background:#ffca3a14;border:1px solid rgba(255,202,58,.2);border-radius:var(--radius-md);padding:14px;text-align:center}.lb-signin-nudge p{font-size:13px;color:var(--text);margin:0 0 10px}.btn-leaderboard{width:100%;background:var(--sf2);border:1px solid var(--gold);color:var(--gold);border-radius:var(--radius-md);padding:12px;font-size:14px;font-weight:700;font-family:var(--font-body);cursor:pointer;margin-top:8px;transition:background .15s}.btn-leaderboard:hover{background:#ffca3a1a}
