.upgrade-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out;padding:1rem}.upgrade-modal{position:relative;width:100%;max-width:380px;background:var(--bg-secondary);border:1px solid rgba(108,92,231,.25);border-radius:16px;padding:2rem 1.5rem;display:flex;flex-direction:column;gap:1.25rem;animation:fadeIn .3s ease-out}.upgrade-modal-close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;color:var(--text-secondary);font-size:1.5rem;line-height:1;cursor:pointer;padding:.25rem .5rem;border-radius:8px;transition:color .2s ease}.upgrade-modal-close:hover{color:var(--text-primary)}.upgrade-modal-title{font-size:1.5rem;font-weight:800;color:var(--text-primary);text-align:center}.upgrade-modal-subtitle{font-size:.9rem;color:var(--text-secondary);text-align:center;margin-top:-.5rem}.upgrade-modal-features{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem 1rem;font-size:.8rem;color:var(--text-secondary);padding:.75rem;background:#6c5ce714;border-radius:10px;margin-top:-.5rem}.upgrade-modal-form{display:flex;flex-direction:column;gap:1rem}.upgrade-modal-field{display:flex;flex-direction:column;gap:.35rem}.upgrade-modal-label{font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.upgrade-modal-input{width:100%;padding:.85rem 1rem;font-size:1rem;font-family:inherit;color:var(--text-primary);background:var(--bg-primary, #0a0a1a);border:2px solid rgba(108,92,231,.2);border-radius:12px;outline:none;transition:border-color .2s ease}.upgrade-modal-input:focus{border-color:var(--accent-glow)}.upgrade-modal-input::placeholder{color:var(--text-secondary);opacity:.5}.upgrade-modal-hint{font-size:.75rem;color:var(--text-secondary);opacity:.8}.upgrade-modal-hint-ok{color:var(--split-good);opacity:1}.upgrade-modal-error{font-size:.85rem;color:var(--danger, #ff6b6b);text-align:center;padding:.5rem;background:#ff6b6b14;border-radius:8px}.upgrade-modal-terms{display:flex;align-items:flex-start;gap:.5rem;cursor:pointer}.upgrade-modal-terms input[type=checkbox]{width:18px;height:18px;margin-top:2px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.upgrade-modal-terms-text{font-size:.8rem;color:var(--text-secondary);line-height:1.4}.upgrade-modal-terms-text a{color:var(--accent-glow);text-decoration:none}.upgrade-modal-terms-text a:hover{text-decoration:underline}.upgrade-modal-submit{margin-top:.25rem;padding:.9rem;font-size:1.05rem;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-glow));border-radius:12px;transition:all .2s ease;box-shadow:0 0 20px #6c5ce74d}.upgrade-modal-submit:disabled{opacity:.5;cursor:default}.upgrade-modal-submit:active:not(:disabled){transform:scale(.97)}@media (min-width: 600px){.upgrade-modal-submit:not(:disabled):hover{background:var(--accent-glow);box-shadow:0 0 30px #a29bfe80;transform:scale(1.02)}}.create-group-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;display:flex;align-items:center;justify-content:center;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out;padding:1rem}.create-group-modal{position:relative;width:100%;max-width:380px;background:var(--bg-secondary);border:1px solid rgba(108,92,231,.25);border-radius:16px;padding:2rem 1.5rem;display:flex;flex-direction:column;gap:1.25rem;animation:fadeIn .3s ease-out}.create-group-close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;color:var(--text-secondary);font-size:1.5rem;line-height:1;cursor:pointer;padding:.25rem .5rem;border-radius:8px;transition:color .2s ease}.create-group-close:hover{color:var(--text-primary)}.create-group-title{font-size:1.5rem;font-weight:800;color:var(--text-primary);text-align:center}.create-group-subtitle{font-size:.9rem;color:var(--text-secondary);text-align:center;margin-top:-.5rem}.create-group-form{display:flex;flex-direction:column;gap:1rem}.create-group-field{display:flex;flex-direction:column;gap:.35rem}.create-group-label{font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.create-group-input{width:100%;padding:.85rem 1rem;font-size:1rem;font-family:inherit;color:var(--text-primary);background:var(--bg-primary, #0a0a1a);border:2px solid rgba(108,92,231,.2);border-radius:12px;outline:none;transition:border-color .2s ease}.create-group-input:focus{border-color:var(--accent-glow)}.create-group-input::placeholder{color:var(--text-secondary);opacity:.5}.create-group-options{display:flex;gap:.5rem}.create-group-option{flex:1;padding:.75rem;font-size:1rem;font-weight:600;color:var(--text-secondary);background:var(--bg-primary);border:2px solid rgba(108,92,231,.2);border-radius:10px;transition:all .2s ease}.create-group-option:hover{border-color:#6c5ce766}.create-group-option.active{color:var(--text-primary);background:#6c5ce726;border-color:var(--accent)}.create-group-error{font-size:.85rem;color:var(--danger, #ff6b6b);text-align:center;padding:.5rem;background:#ff6b6b14;border-radius:8px}.create-group-submit{margin-top:.25rem;padding:.9rem;font-size:1.05rem;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-glow));border-radius:12px;transition:all .2s ease;box-shadow:0 0 20px #6c5ce74d}.create-group-submit:disabled{opacity:.5;cursor:default}.create-group-submit:active:not(:disabled){transform:scale(.97)}.create-group-success{display:flex;flex-direction:column;align-items:center;gap:1rem}.create-group-checkmark{width:60px;height:60px;border-radius:50%;background:#00cec926;border:2px solid var(--success, #00cec9);display:flex;align-items:center;justify-content:center;font-size:1.75rem;color:var(--success, #00cec9)}.create-group-invite{width:100%;display:flex;flex-direction:column;gap:.35rem;margin-top:.5rem}.create-group-invite-row{display:flex;gap:.5rem}.create-group-invite-input{flex:1;padding:.65rem .75rem;font-size:.85rem;font-family:inherit;color:var(--text-secondary);background:var(--bg-primary);border:1px solid rgba(108,92,231,.2);border-radius:8px;overflow:hidden;text-overflow:ellipsis}.create-group-copy{padding:.65rem 1rem;font-size:.85rem;font-weight:600;color:#fff;background:var(--accent);border-radius:8px;white-space:nowrap;transition:all .2s ease}.create-group-copy:active{transform:scale(.95)}.create-group-done{width:100%;margin-top:.5rem;padding:.9rem;font-size:1.05rem;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-glow));border-radius:12px;transition:all .2s ease;box-shadow:0 0 20px #6c5ce74d}.create-group-done:active{transform:scale(.97)}@media (min-width: 600px){.create-group-submit:not(:disabled):hover,.create-group-done:hover{background:var(--accent-glow);box-shadow:0 0 30px #a29bfe80;transform:scale(1.02)}.create-group-copy:hover{background:var(--accent-glow)}}.achievements-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#000c;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .2s ease-out}.achievements-modal{background:var(--bg-secondary);border-radius:20px;width:100%;max-width:420px;max-height:85vh;display:flex;flex-direction:column;border:1px solid rgba(108,92,231,.3);box-shadow:0 0 40px #6c5ce733;animation:slideUp .3s ease-out}.achievements-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid rgba(108,92,231,.15);flex-shrink:0}.achievements-modal-title-row{display:flex;align-items:center;gap:.75rem}.achievements-modal-title{font-size:1.25rem;font-weight:800;color:var(--text-primary);margin:0}.achievements-modal-count{font-size:.85rem;font-weight:700;color:var(--accent-glow);background:#6c5ce726;padding:.25rem .6rem;border-radius:8px}.achievements-modal-close{font-size:1.75rem;color:var(--text-secondary);background:none;border:none;line-height:1;padding:.25rem;cursor:pointer;transition:color .2s ease}.achievements-modal-close:hover{color:var(--text-primary)}.achievements-modal-progress{height:4px;background:#ffffff1a;flex-shrink:0}.achievements-modal-progress-bar{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-glow));border-radius:0 2px 2px 0;transition:width .3s ease}.achievements-modal-content{flex:1;overflow-y:auto;padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.5rem}.achievements-modal-item{display:flex;align-items:center;gap:.75rem;padding:.85rem 1rem;border-radius:12px;cursor:pointer;transition:all .2s ease;border:1px solid transparent}.achievements-modal-item.earned{background:#6c5ce714;border-color:#6c5ce726}.achievements-modal-item.earned:hover{background:#6c5ce71f;border-color:#6c5ce740}.achievements-modal-item.earned.selected{background:#6c5ce726;border-color:#6c5ce759}.achievements-modal-item.locked{background:#ffffff05;border-color:#ffffff0d;opacity:.6}.achievements-modal-item.locked:hover{opacity:.8;background:#ffffff0a}.achievements-modal-item.locked.selected{opacity:.9;background:#ffffff0f;border-color:#ffffff1a}.achievements-modal-item-icon{font-size:1.5rem;flex-shrink:0;width:36px;text-align:center}.achievements-modal-item.locked .achievements-modal-item-icon{filter:grayscale(1);opacity:.5}.achievements-modal-item-info{flex:1;display:flex;flex-direction:column;gap:.15rem;min-width:0}.achievements-modal-item-name{font-size:.95rem;font-weight:700;color:var(--text-primary)}.achievements-modal-item.locked .achievements-modal-item-name{color:var(--text-secondary)}.achievements-modal-item-desc{font-size:.8rem;color:var(--text-secondary);line-height:1.3}.achievements-modal-item.locked .achievements-modal-item-desc{font-style:italic}.achievements-modal-item-check{font-size:1rem;color:var(--split-good);font-weight:700;flex-shrink:0}.achievements-modal-content::-webkit-scrollbar{width:6px}.achievements-modal-content::-webkit-scrollbar-track{background:transparent}.achievements-modal-content::-webkit-scrollbar-thumb{background:#6c5ce74d;border-radius:3px}.achievements-modal-content::-webkit-scrollbar-thumb:hover{background:#6c5ce780}.leaderboards-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:var(--bg-primary);display:flex;flex-direction:column;overflow:hidden;animation:fadeIn .2s ease-out}.leaderboards-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid rgba(108,92,231,.15);flex-shrink:0}.leaderboards-title{font-size:1.5rem;font-weight:800;color:var(--text-primary);margin:0}.leaderboards-close{font-size:2rem;color:var(--text-secondary);background:none;border:none;line-height:1;padding:.25rem;cursor:pointer;transition:color .2s ease}.leaderboards-close:hover{color:var(--text-primary)}.leaderboards-tabs{display:flex;gap:.5rem;padding:1rem 1.5rem;flex-shrink:0}.leaderboards-tab{flex:1;padding:.75rem 1rem;font-size:.9rem;font-weight:700;color:var(--text-secondary);background:var(--bg-secondary);border:1px solid rgba(108,92,231,.15);border-radius:10px;cursor:pointer;transition:all .2s ease}.leaderboards-tab:hover{border-color:#6c5ce74d}.leaderboards-tab.active{color:#fff;background:var(--accent);border-color:var(--accent)}.leaderboards-content{flex:1 1 0;height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding:0 1.5rem 2rem;display:flex;flex-direction:column;gap:1.5rem}.leaderboards-section{background:var(--bg-secondary);border-radius:16px;border:1px solid rgba(108,92,231,.15);flex-shrink:0}.leaderboards-section-header{display:flex;justify-content:space-between;align-items:center;padding:.85rem 1rem;background:#6c5ce714;border-bottom:1px solid rgba(108,92,231,.1);border-radius:16px 16px 0 0}.leaderboards-section-title{font-size:1rem;font-weight:700;color:var(--accent-glow);margin:0}.leaderboards-section-count{font-size:.75rem;color:var(--text-secondary)}.leaderboards-section-content{padding:.5rem .5rem 1rem}.leaderboards-row{display:flex;align-items:center;gap:.5rem;padding:.6rem .75rem;border-radius:8px;transition:background .15s ease}.leaderboards-row:hover{background:#6c5ce70f}.leaderboards-row.current-user{background:#6c5ce71f;border:1px solid rgba(108,92,231,.25)}.leaderboards-rank{font-size:.8rem;font-weight:700;color:var(--text-secondary);min-width:32px}.leaderboards-tag{flex:1;font-size:.9rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:.35rem}.leaderboards-expert{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:.6rem;font-weight:800;color:#12122a;background:linear-gradient(135deg,var(--accent-glow),var(--accent));border-radius:4px}.leaderboards-score{font-size:.8rem;font-variant-numeric:tabular-nums;color:var(--text-secondary);min-width:55px;text-align:right}.leaderboards-grade{font-size:.85rem;font-weight:800;min-width:20px;text-align:center}.leaderboards-grade.grade-S{color:#a29bfe}.leaderboards-grade.grade-A{color:#00cec9}.leaderboards-grade.grade-B{color:#55efc4}.leaderboards-grade.grade-C{color:#fdcb6e}.leaderboards-grade.grade-D{color:#e17055}.leaderboards-grade.grade-F{color:#ff6b6b}.leaderboards-loading,.leaderboards-error,.leaderboards-empty{padding:1.5rem;text-align:center;font-size:.85rem;color:var(--text-secondary)}.leaderboards-error{color:var(--danger)}.leaderboards-content::-webkit-scrollbar{width:6px}.leaderboards-content::-webkit-scrollbar-track{background:transparent}.leaderboards-content::-webkit-scrollbar-thumb{background:#6c5ce74d;border-radius:3px}.leaderboards-content::-webkit-scrollbar-thumb:hover{background:#6c5ce780}.legal-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out;padding:1rem}.legal-modal{position:relative;width:100%;max-width:300px;background:var(--bg-secondary);border:1px solid rgba(108,92,231,.25);border-radius:16px;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;animation:fadeIn .3s ease-out}.legal-modal-close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;color:var(--text-secondary);font-size:1.5rem;line-height:1;cursor:pointer;padding:.25rem .5rem;border-radius:8px;transition:color .2s ease}.legal-modal-close:hover{color:var(--text-primary)}.legal-modal-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);text-align:center}.legal-modal-links{display:flex;flex-direction:column;gap:.5rem}.legal-modal-links a{display:block;padding:.75rem 1rem;font-size:.9rem;font-weight:500;color:var(--text-primary);background:#6c5ce714;border:1px solid rgba(108,92,231,.15);border-radius:10px;text-decoration:none;text-align:center;transition:all .2s ease}.legal-modal-links a:hover{background:#6c5ce726;border-color:#6c5ce74d;color:var(--accent-glow)}.legal-footer{display:flex;justify-content:center;align-items:center;padding:.25rem 0;margin-top:.25rem}.legal-footer-link{font-size:.75rem;color:var(--text-secondary);background:none;border:none;cursor:pointer;padding:.25rem .5rem;transition:color .2s}.legal-footer-link:hover{color:var(--accent-glow)}.start-screen{display:flex;flex-direction:column;height:100%;width:100%;max-width:480px;padding:0;gap:0;animation:fadeIn .6s ease-out}.start-header{flex-shrink:0;padding:2rem 2rem 1rem;text-align:center}.start-title{font-size:3rem;font-weight:800;line-height:1.1;letter-spacing:-.02em}.title-clock{display:block;color:var(--accent-glow);text-shadow:0 0 30px rgba(162,155,254,.4)}.title-blockers{display:block;color:var(--text-primary)}.start-subtitle{margin-top:.75rem;font-size:1.1rem;color:var(--text-secondary)}.start-rules{display:flex;flex-direction:column;gap:1rem;width:100%}.rule{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:var(--bg-secondary);border-radius:12px;border:1px solid rgba(108,92,231,.15)}.rule-number{flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--accent);color:#fff;border-radius:50%;font-size:.85rem;font-weight:700}.rule-text{font-size:.95rem;color:var(--text-secondary);line-height:1.4}.rule-text strong{color:var(--text-primary)}.mode-scroll-container{flex:1;min-height:0;overflow-y:auto;padding:0 2rem;position:relative}.mode-scroll-container.has-more:after{content:"";position:sticky;bottom:0;left:0;right:0;height:40px;background:linear-gradient(to top,var(--bg-primary),transparent);pointer-events:none;display:block}.scroll-indicator{position:sticky;bottom:8px;display:flex;justify-content:center;pointer-events:none;animation:bounceDown 1.5s ease-in-out infinite}.scroll-indicator svg{width:24px;height:24px;color:var(--text-secondary);opacity:.7}@keyframes bounceDown{0%,to{transform:translateY(0)}50%{transform:translateY(6px)}}.mode-selector{display:flex;flex-direction:column;gap:.75rem;width:100%;padding-bottom:.5rem}.mode-selector-label{font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em;font-weight:600;text-align:center}.expert-mode-toggle{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.75rem 1rem;background:#a29bfe14;border:1px solid rgba(162,155,254,.25);border-radius:12px;margin-bottom:.5rem}.expert-mode-label{font-size:.9rem;font-weight:700;color:var(--accent-glow);letter-spacing:.02em}.toggle-switch{position:relative;width:48px;height:26px;background:#ffffff1a;border-radius:13px;border:1px solid rgba(255,255,255,.15);cursor:pointer;transition:all .2s ease;padding:0}.toggle-switch.active{background:var(--accent);border-color:var(--accent-glow)}.toggle-knob{position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .2s ease;box-shadow:0 1px 3px #0000004d}.toggle-switch.active .toggle-knob{transform:translate(22px)}.mode-options{display:flex;flex-direction:column;gap:.6rem}.mode-card{display:flex;flex-direction:column;gap:.15rem;padding:.85rem 1.1rem;background:var(--bg-secondary);border-radius:12px;border:2px solid rgba(108,92,231,.12);text-align:left;transition:all .2s ease;cursor:pointer}.mode-card-active{border-color:var(--accent-glow);background:#6c5ce71a;box-shadow:0 0 16px #a29bfe26}.mode-card-played{opacity:.45;cursor:default;border-color:#ffffff0f}.mode-card-played.mode-card-active{border-color:#ffffff0f;background:var(--bg-secondary);box-shadow:none}.mode-card-header{display:flex;align-items:center;justify-content:space-between}.mode-name{font-size:1.05rem;font-weight:700;color:var(--text-primary)}.mode-card-active:not(.mode-card-played) .mode-name{color:var(--accent-glow)}.mode-played-badge{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--split-good);background:#00cec91a;padding:.15rem .5rem;border-radius:6px}.mode-card-challenge{background:linear-gradient(135deg,#fdcb6e1f,#ffd7000f);border-color:#fdcb6e66;border-width:2px;position:relative;overflow:hidden}.mode-card-challenge:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#fdcb6e,#ffeaa7,#fdcb6e);animation:shimmer 2s ease-in-out infinite}@keyframes shimmer{0%,to{opacity:.6}50%{opacity:1}}.mode-card-challenge:not(.mode-card-played) .mode-name{color:#fdcb6e}.mode-card-challenge.mode-card-active:not(.mode-card-played){background:linear-gradient(135deg,#fdcb6e2e,#ffd7001a);border-color:#fdcb6e;box-shadow:0 0 25px #fdcb6e4d}.mode-card-challenge.mode-card-active:not(.mode-card-played):before{animation:shimmer 1s ease-in-out infinite}.challenge-icon{margin-right:.4rem;font-size:1.1rem}.challenge-date-context{font-size:.75rem;font-weight:600;color:#fdcb6e;text-transform:uppercase;letter-spacing:.08em;opacity:.9}.challenge-event{color:var(--text-primary);font-weight:700}.mode-challenge-badge{font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--accent-glow);background:#a29bfe33;padding:.15rem .5rem;border-radius:6px;margin-left:auto;margin-right:.5rem}.mode-pro-badge{font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:#fdcb6e;background:#fdcb6e26;padding:.15rem .5rem;border-radius:6px;margin-left:auto}.mode-card-locked{opacity:.7;cursor:pointer}.mode-card-locked .mode-description,.mode-card-locked .mode-detail{opacity:.7}.mode-description{font-size:.85rem;color:var(--text-secondary);font-weight:600;font-variant-numeric:tabular-nums}.mode-detail{font-size:.8rem;color:var(--text-secondary);opacity:.7}.start-button{padding:1rem 3rem;font-size:1.25rem;font-weight:700;color:#fff;background:var(--accent);border-radius:16px;transition:all .2s ease;animation:pulse 2s ease-in-out infinite;box-shadow:0 0 30px #6c5ce74d}.start-button:disabled{opacity:.4;animation:none;cursor:default}.start-button:active:not(:disabled){transform:scale(.96)}.locked-section{display:flex;flex-direction:column;align-items:center;gap:.75rem;animation:fadeIn .6s ease-out}.locked-icon{opacity:.6;margin-bottom:.5rem}.locked-message{font-size:1.3rem;font-weight:700;color:var(--text-primary)}.locked-subtitle{font-size:.95rem;color:var(--text-secondary)}.locked-countdown{display:flex;flex-direction:column;align-items:center;gap:.25rem;margin-top:1rem;padding:1.25rem 2rem;background:var(--bg-secondary);border-radius:16px;border:1px solid rgba(108,92,231,.2)}.countdown-label{font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.countdown-time{font-size:2rem;font-weight:800;color:var(--accent-glow);font-variant-numeric:tabular-nums;letter-spacing:.05em}.upgrade-button{margin-top:1rem;padding:.85rem 2rem;font-size:1rem;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-glow));border-radius:12px;box-shadow:0 0 20px #6c5ce766;transition:all .2s ease}.upgrade-button:active{transform:scale(.96)}.start-footer{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1rem 2rem 1.25rem}.signin-link{font-size:.8rem;color:var(--text-secondary);opacity:.6;text-decoration:none;transition:opacity .2s ease}.signin-link:hover{opacity:1;color:var(--accent-glow)}.guest-links{display:flex;align-items:center;gap:.5rem}.guest-links-divider{color:var(--text-secondary);opacity:.4}.upgrade-link{font-size:.8rem;color:var(--accent-glow);background:none;opacity:.8;transition:opacity .2s ease}.upgrade-link:hover{opacity:1}.footer-buttons{display:flex;align-items:center;gap:1.5rem}.achievements-toggle-btn{display:flex;align-items:center;gap:.5rem;font-size:.85rem;font-weight:600;color:var(--text-secondary);background:transparent;padding:.5rem 0;transition:color .2s ease}.achievements-toggle-btn:hover{color:var(--accent-glow)}.leaderboards-toggle-btn{display:flex;align-items:center;gap:.5rem;font-size:.85rem;font-weight:600;color:var(--text-secondary);background:transparent;padding:.5rem 0;transition:color .2s ease}.leaderboards-toggle-btn:hover{color:var(--accent-glow)}.achievements-toggle-count{display:flex;align-items:center;justify-content:center;min-width:20px;height:20px;font-size:.75rem;font-weight:700;color:#fff;background:var(--accent);border-radius:10px;padding:0 .4rem}.groups-toggle-btn{display:flex;align-items:center;gap:.5rem;font-size:.85rem;font-weight:600;color:var(--text-secondary);background:transparent;padding:.5rem 0;transition:color .2s ease}.groups-toggle-btn:hover{color:var(--accent-glow)}.groups-toggle-count{display:flex;align-items:center;justify-content:center;min-width:20px;height:20px;font-size:.75rem;font-weight:700;color:#fff;background:var(--accent);border-radius:10px;padding:0 .4rem}.groups-panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;z-index:200}.groups-panel-overlay.visible{opacity:1;visibility:visible}.groups-panel{position:fixed;top:0;right:0;bottom:0;width:100%;max-width:360px;background:var(--bg-primary);border-left:1px solid rgba(108,92,231,.2);transform:translate(100%);transition:transform .3s ease;z-index:201;display:flex;flex-direction:column}.groups-panel.open{transform:translate(0)}.groups-panel-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid rgba(108,92,231,.15);flex-shrink:0}.groups-panel-title{font-size:1.25rem;font-weight:800;color:var(--text-primary)}.groups-panel-close{font-size:1.75rem;color:var(--text-secondary);background:none;border:none;line-height:1;padding:.25rem;cursor:pointer;transition:color .2s ease}.groups-panel-close:hover{color:var(--text-primary)}.groups-panel-content{flex:1;overflow-y:auto;padding:1rem 1.5rem}.groups-panel-footer{padding:1rem 1.5rem;border-top:1px solid rgba(108,92,231,.15);flex-shrink:0}.groups-create-btn-full{width:100%;padding:.85rem;font-size:1rem;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-glow));border-radius:12px;transition:all .2s ease;box-shadow:0 0 20px #6c5ce74d}.groups-create-btn-full:active{transform:scale(.97)}.groups-list{display:flex;flex-direction:column;gap:.5rem}.groups-item{display:flex;justify-content:space-between;align-items:center;padding:.85rem 1rem;background:var(--bg-secondary);border-radius:12px;border:1px solid rgba(108,92,231,.12);text-decoration:none;transition:all .2s ease}.groups-item:hover{border-color:#6c5ce74d;background:#6c5ce714}.groups-item-name{font-weight:600;font-size:.95rem;color:var(--text-primary)}.groups-item-count{font-size:.8rem;color:var(--text-secondary)}.groups-empty{font-size:.9rem;color:var(--text-secondary);text-align:center;padding:2rem 1rem}@media (min-width: 600px){.start-title{font-size:4rem}.upgrade-button:hover{box-shadow:0 0 30px #a29bfe99;transform:scale(1.03)}.mode-card:not(.mode-card-played):hover{border-color:#a29bfe66;background:#6c5ce70f}.mode-card-active:not(.mode-card-played):hover{border-color:var(--accent-glow);background:#6c5ce71a}.start-button:not(:disabled):hover{background:var(--accent-glow);box-shadow:0 0 40px #a29bfe80;transform:scale(1.05)}.groups-create-btn-full:hover{background:var(--accent-glow);box-shadow:0 0 30px #a29bfe80;transform:scale(1.02)}.groups-item:hover{transform:translate(4px)}}.ready-screen{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;width:100%;max-width:480px;padding:2rem;gap:2rem;animation:fadeIn .4s ease-out}.ready-content{display:flex;flex-direction:column;align-items:center;gap:1.5rem;text-align:center}.ready-mode-badge{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--accent-glow);background:#6c5ce726;padding:.5rem 1rem;border-radius:20px;border:1px solid rgba(162,155,254,.3)}.ready-mode-badge-challenge{background:linear-gradient(135deg,#6c5ce733,#a29bfe1a);border-color:var(--accent-glow);box-shadow:0 0 15px #a29bfe33}.challenge-context{font-size:.9rem;color:var(--text-secondary);margin-bottom:-.5rem}.challenge-time{font-size:4rem;font-weight:800;color:var(--accent-glow);font-variant-numeric:tabular-nums;text-shadow:0 0 30px rgba(162,155,254,.4);line-height:1;margin:-.5rem 0}.challenge-hint{max-width:320px;line-height:1.5}.ready-title{font-size:3rem;font-weight:800;color:var(--text-primary);line-height:1.1}.ready-rules{display:flex;flex-direction:column;gap:.5rem}.ready-rule-main{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.ready-rule-detail{font-size:1rem;color:var(--text-secondary)}.ready-stats{display:flex;align-items:center;gap:1.5rem;padding:1.25rem 2rem;background:var(--bg-secondary);border-radius:16px;border:1px solid rgba(108,92,231,.15)}.ready-stat{display:flex;flex-direction:column;align-items:center;gap:.25rem}.ready-stat-value{font-size:2rem;font-weight:800;color:var(--accent-glow);font-variant-numeric:tabular-nums}.ready-stat-label{font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.ready-stat-divider{width:1px;height:40px;background:#6c5ce733}.ready-hint{font-size:.9rem;color:var(--text-secondary);opacity:.7}.expert-mode-info{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem 1.5rem;background:#a29bfe1a;border:1px solid rgba(162,155,254,.3);border-radius:12px}.expert-badge{font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:#12122a;background:linear-gradient(135deg,var(--accent-glow),var(--accent));padding:.35rem .75rem;border-radius:6px}.expert-mode-desc{font-size:.85rem;color:var(--text-secondary);text-align:center;margin:0}.ready-actions{display:flex;flex-direction:column;align-items:center;gap:1rem}.ready-button{padding:1.25rem 4rem;font-size:1.5rem;font-weight:700;color:#fff;background:var(--accent);border-radius:16px;transition:all .2s ease;animation:pulse 2s ease-in-out infinite;box-shadow:0 0 30px #6c5ce766}.ready-button:active{transform:scale(.96)}.ready-back-link{font-size:.9rem;color:var(--text-secondary);background:transparent;padding:.5rem 1rem;transition:color .2s ease}.ready-back-link:hover{color:var(--accent-glow)}@media (min-width: 600px){.ready-title{font-size:4rem}.ready-button:hover{background:var(--accent-glow);box-shadow:0 0 40px #a29bfe80;transform:scale(1.05)}}.game-screen{display:flex;flex-direction:column;height:100%;width:100%;max-width:480px;padding:1.5rem}.game-top{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding-top:1rem}.splits-remaining{font-size:.9rem;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.08em}.target-display{display:flex;flex-direction:column;align-items:center;gap:.15rem;padding:.6rem 1.8rem;background:#6c5ce71f;border:2px solid rgba(162,155,254,.35);border-radius:16px;animation:targetPop .35s ease-out}.target-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--text-secondary)}.target-value{font-size:2.2rem;font-weight:800;color:var(--accent-glow);text-shadow:0 0 18px rgba(162,155,254,.5);font-variant-numeric:tabular-nums;line-height:1}@keyframes targetPop{0%{opacity:0;transform:scale(.8)}60%{transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.split-target-hint{color:var(--text-secondary);opacity:.5;font-size:.8rem}.timer-display{transition:opacity .1s linear}.timer-value{font-size:3rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--accent-glow);text-shadow:0 0 20px rgba(162,155,254,.4)}.timer-hidden-hint{font-size:1.1rem;color:var(--text-secondary);font-style:italic;animation:fadeIn 1s ease-out;min-height:3rem;display:flex;align-items:center}.timer-hidden-hint.expert-hint{font-size:1.25rem;color:var(--accent-glow);text-shadow:0 0 15px rgba(162,155,254,.3)}.split-recorded{flex:1;font-size:.95rem;color:var(--accent-glow);font-weight:600}.splits-list{flex:1;display:flex;flex-direction:column;gap:.5rem;margin-top:1.5rem;overflow-y:auto;padding-bottom:1rem}.split-row{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--bg-secondary);border-radius:12px;border:1px solid rgba(108,92,231,.1);animation:slideUp .3s ease-out both}.split-index{font-weight:700;color:var(--text-secondary);font-size:.85rem;min-width:28px}.split-time{font-variant-numeric:tabular-nums;color:var(--text-primary);font-weight:500;font-size:.95rem;flex:1}.split-interval{font-variant-numeric:tabular-nums;color:var(--text-secondary);font-size:.9rem;min-width:60px;text-align:right}.split-delta{font-variant-numeric:tabular-nums;font-weight:700;font-size:.9rem;min-width:75px;text-align:right}.delta-good{color:var(--split-good)}.delta-ok{color:var(--split-ok)}.delta-bad{color:var(--split-bad)}.game-bottom{padding:1rem 0 2rem;display:flex;justify-content:center}.split-button{display:flex;flex-direction:column;align-items:center;gap:.25rem;width:100%;max-width:320px;padding:1.25rem 2rem;background:var(--accent);border-radius:16px;box-shadow:0 0 30px #6c5ce74d;transition:all .15s ease;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.split-button:active{transform:scale(.95);background:var(--accent-glow)}.split-button-text{font-size:1.5rem;font-weight:800;color:#fff;letter-spacing:.1em}.split-button-sub{font-size:.8rem;color:#ffffffb3;font-weight:500}@media (min-width: 600px){.timer-value{font-size:4rem}.split-button:hover{background:var(--accent-glow);box-shadow:0 0 40px #a29bfe80;transform:scale(1.03)}.split-button:hover:active{transform:scale(.97)}}.results-screen{display:flex;flex-direction:column;height:100%;width:100%;max-width:480px;overflow-y:auto;-webkit-overflow-scrolling:touch}.results-content{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.results-title{text-align:center;font-size:1.75rem;font-weight:800;color:var(--text-primary);animation:fadeIn .5s ease-out}.challenge-result-context{text-align:center;font-size:.9rem;color:var(--text-secondary);margin-bottom:-.25rem}.results-title-challenge{color:var(--accent-glow);font-size:1.5rem;margin-bottom:-.5rem}.challenge-result-time{text-align:center;font-size:3.5rem;font-weight:800;color:var(--accent-glow);opacity:.5;font-variant-numeric:tabular-nums;line-height:1;margin-bottom:.5rem}.challenge-result-banner{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.25rem 1.5rem;border-radius:16px;text-align:center;animation:slideUp .5s ease-out}.challenge-result-banner.success{background:linear-gradient(135deg,#00cec926,#00cec90d);border:2px solid rgba(0,206,201,.4)}.challenge-result-banner.fail{background:linear-gradient(135deg,#ff6b6b26,#ff6b6b0d);border:2px solid rgba(255,107,107,.4)}.challenge-result-status{font-size:1.5rem;font-weight:800}.challenge-result-banner.success .challenge-result-status{color:var(--split-good)}.challenge-result-banner.fail .challenge-result-status{color:var(--split-bad)}.challenge-result-detail{font-size:.95rem;color:var(--text-secondary);font-variant-numeric:tabular-nums}.grade-section{display:flex;flex-direction:column;align-items:center;gap:.5rem;animation:fadeIn .6s ease-out}.grade-circle{width:90px;height:90px;border-radius:50%;border:4px solid;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary)}.grade-letter{font-size:2.5rem;font-weight:900}.grade-label{font-size:1.1rem;font-weight:700}.grade-detail{font-size:.9rem;color:var(--text-secondary)}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;animation:slideUp .5s ease-out both;animation-delay:.1s}.stat-card{background:var(--bg-secondary);border-radius:12px;padding:.75rem;display:flex;flex-direction:column;gap:.25rem;border:1px solid rgba(108,92,231,.1)}.stat-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.stat-value{font-size:.95rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--text-primary)}.chart-section{animation:slideUp .5s ease-out both;animation-delay:.2s}.chart-title{font-size:.9rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.chart-container{background:var(--bg-secondary);border-radius:12px;padding:.75rem .5rem;border:1px solid rgba(108,92,231,.1)}.splits-detail{animation:slideUp .5s ease-out both;animation-delay:.3s}.detail-row{display:flex;align-items:center;gap:1rem;padding:.6rem 0;border-bottom:1px solid rgba(255,255,255,.04)}.detail-row:last-child{border-bottom:none}.detail-left{flex:1;display:flex;align-items:center;gap:.75rem}.detail-index{font-weight:700;color:var(--text-secondary);font-size:.85rem;min-width:24px}.detail-bar-container{flex:1;height:8px;background:#ffffff0d;border-radius:4px;position:relative;overflow:hidden}.detail-bar{height:100%;border-radius:4px;transition:width .5s ease-out}.detail-bar-target{position:absolute;top:-2px;bottom:-2px;width:2px;background:var(--accent-glow);opacity:.6}.detail-target-label{color:var(--text-secondary);opacity:.5;font-size:.8rem}.detail-right{display:flex;flex-direction:column;align-items:flex-end;min-width:80px}.detail-interval{font-size:.9rem;font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.detail-deviation{font-size:.8rem;font-weight:700;font-variant-numeric:tabular-nums}.results-watermark{text-align:center;font-size:.8rem;color:#6c5ce74d;font-weight:700;letter-spacing:.1em;padding-top:.5rem}.results-actions{display:flex;flex-direction:column;gap:.5rem;padding:1.5rem 1.5rem 1.25rem;position:sticky;bottom:0;background:linear-gradient(to top,var(--bg-primary) 70%,transparent)}.results-actions-row{display:flex;gap:.5rem}.results-actions-row>button{flex:1}.share-button{padding:.7rem 1rem;font-size:.95rem;font-weight:700;color:#fff;background:var(--accent);border-radius:10px;transition:all .2s ease;box-shadow:0 0 15px #6c5ce740}.share-button:disabled{opacity:.6}.share-button:active{transform:scale(.97)}.restart-button{padding:.7rem 1rem;font-size:.95rem;font-weight:600;color:var(--accent-glow);background:#6c5ce726;border-radius:10px;border:1px solid rgba(108,92,231,.3);transition:all .2s ease}.restart-button:active{transform:scale(.97);background:#6c5ce740}.menu-button{padding:.7rem 1rem;font-size:.95rem;font-weight:600;color:var(--text-secondary);background:var(--bg-secondary);border-radius:10px;border:1px solid rgba(108,92,231,.15);transition:all .2s ease}.menu-button:active{transform:scale(.97);background:var(--bg-card)}.ad-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#000000f2;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease-out}.ad-container{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:2rem;width:100%;max-width:400px}.ad-badge{font-size:.7rem;text-transform:uppercase;letter-spacing:.15em;color:var(--text-secondary);background:#ffffff14;padding:.3rem .8rem;border-radius:4px;font-weight:600}.ad-content{display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center;padding:2rem 1.5rem;background:linear-gradient(135deg,#6c5ce726,#a29bfe14);border:1px solid rgba(108,92,231,.3);border-radius:20px;width:100%}.ad-brand{font-size:1.5rem;font-weight:800;background:linear-gradient(135deg,var(--accent-glow),var(--success));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.ad-tagline{font-size:.95rem;color:var(--text-secondary);line-height:1.5}.ad-features{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.ad-feature{font-size:.8rem;padding:.35rem .75rem;background:#00cec91a;border:1px solid rgba(0,206,201,.25);border-radius:20px;color:var(--success);font-weight:600}.ad-cta{margin-top:.5rem;padding:.85rem 2rem;background:var(--accent);color:#fff;font-weight:700;font-size:1rem;border-radius:12px;box-shadow:0 0 20px #6c5ce766;cursor:pointer}.ad-timer{font-size:.85rem;color:var(--text-secondary);font-variant-numeric:tabular-nums;padding:.5rem 1rem}.ad-close{font-size:.9rem;font-weight:600;color:var(--text-secondary);background:#ffffff14;border:1px solid rgba(255,255,255,.15);padding:.6rem 1.5rem;border-radius:10px;cursor:pointer;transition:all .2s ease;animation:fadeIn .3s ease-out}.ad-close:active{transform:scale(.96);background:#ffffff1f}.percentile-banner{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:1rem 1.5rem;margin:0 1rem .5rem;border-radius:12px;animation:bannerSlideIn .5s ease-out}@keyframes bannerSlideIn{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.percentile-banner.top20{background:linear-gradient(135deg,#00cec933,#00cec914);border:1px solid rgba(0,206,201,.4)}.percentile-banner.top10{background:linear-gradient(135deg,#74b9ff33,#74b9ff14);border:1px solid rgba(116,185,255,.4)}.percentile-banner.top5{background:linear-gradient(135deg,#a29bfe40,#6c5ce71a);border:1px solid rgba(162,155,254,.5)}.percentile-banner.top1{background:linear-gradient(135deg,#fdcb6e40,#ffd70026);border:1px solid rgba(255,215,0,.5);animation:bannerSlideIn .5s ease-out,sparkle 2s ease-in-out infinite}@keyframes sparkle{0%,to{box-shadow:0 0 10px #ffd7004d}50%{box-shadow:0 0 20px #ffd70080,0 0 30px #ffd7004d}}.percentile-label{font-size:1.1rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em}.percentile-banner.top20 .percentile-label{color:#00cec9}.percentile-banner.top10 .percentile-label{color:#74b9ff}.percentile-banner.top5 .percentile-label{color:#a29bfe}.percentile-banner.top1 .percentile-label{color:gold}.percentile-rank{font-size:.85rem;color:var(--text-secondary);font-weight:600}.best-score-banner{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem 1.5rem;margin:0 1rem .5rem;border-radius:12px;animation:bannerSlideIn .5s ease-out}.best-score-banner.beat-best{background:linear-gradient(135deg,#55efc433,#00cec91a);border:1px solid rgba(85,239,196,.4)}.best-score-banner.beat-best .best-score-message{color:#55efc4;font-weight:700}.best-score-banner.beat-best.alltime{background:linear-gradient(135deg,#a29bfe40,#6c5ce726);border:1px solid rgba(162,155,254,.5)}.best-score-banner.beat-best.alltime .best-score-message{color:#a29bfe}.best-score-banner.not-best{background:#ffffff0d;border:1px solid rgba(255,255,255,.1)}.best-score-message{font-size:.95rem;font-weight:600;color:var(--text-primary)}.best-score-detail{font-size:.8rem;color:var(--text-secondary)}.ranking-button{padding:.7rem 1rem;font-size:.95rem;font-weight:600;color:var(--accent-glow);background:#6c5ce71a;border-radius:10px;border:1px solid rgba(108,92,231,.3);transition:all .2s ease}.ranking-button:active{transform:scale(.97);background:#6c5ce733}.leaderboard-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#000000e6;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .2s ease-out}.leaderboard-modal{background:var(--bg-secondary);border-radius:16px;width:100%;max-width:400px;max-height:80vh;display:flex;flex-direction:column;border:1px solid rgba(108,92,231,.2);overflow:hidden}.leaderboard-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.06)}.leaderboard-title{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0}.leaderboard-date{font-size:.8rem;color:var(--text-secondary);margin-top:.15rem}.leaderboard-close{font-size:1.5rem;color:var(--text-secondary);background:none;border:none;cursor:pointer;padding:0 .25rem;line-height:1}.leaderboard-content{flex:1;overflow-y:auto;padding:.5rem 0}.leaderboard-loading,.leaderboard-error,.leaderboard-empty{padding:2rem;text-align:center;color:var(--text-secondary)}.leaderboard-error{color:var(--split-bad)}.leaderboard-row{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.03)}.leaderboard-row:last-child{border-bottom:none}.leaderboard-row.current-user{background:#6c5ce726;border-left:3px solid var(--accent)}.leaderboard-rank{font-weight:700;color:var(--text-secondary);font-size:.9rem;min-width:36px}.leaderboard-tag{flex:1;font-weight:600;color:var(--text-primary);font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.leaderboard-score{font-size:.85rem;font-weight:600;color:var(--text-secondary);font-variant-numeric:tabular-nums;min-width:60px;text-align:right}.leaderboard-grade{font-size:.85rem;font-weight:800;min-width:24px;text-align:center}.leaderboard-grade.grade-S{color:#a29bfe}.leaderboard-grade.grade-A{color:#00cec9}.leaderboard-grade.grade-B{color:#55efc4}.leaderboard-grade.grade-C{color:#fdcb6e}.leaderboard-grade.grade-D{color:#e17055}.leaderboard-grade.grade-F{color:#ff6b6b}.group-rankings-section{animation:slideUp .5s ease-out both;animation-delay:.35s}.group-rankings-list{display:flex;flex-direction:column;gap:.5rem}.group-ranking-row{display:flex;justify-content:space-between;align-items:center;padding:.85rem 1rem;background:var(--bg-secondary);border-radius:12px;border:1px solid rgba(108,92,231,.15);text-decoration:none;transition:all .2s ease}.group-ranking-row:hover{border-color:#6c5ce74d;background:#6c5ce714}.group-ranking-name{font-weight:600;color:var(--text-primary);font-size:.95rem}.group-ranking-position{font-weight:700;color:var(--accent-glow);font-size:.95rem}.group-ranking-total{font-weight:500;color:var(--text-secondary);font-size:.85rem}.achievements-section{padding:0 1.5rem;animation:slideUp .5s ease-out both;animation-delay:.4s}.achievements-badges{display:flex;flex-wrap:wrap;gap:.5rem}.achievement-badge{position:relative;display:flex;align-items:center;gap:.4rem;padding:.5rem .75rem;background:#ffd70014;border:1px solid rgba(255,215,0,.2);border-radius:8px;cursor:pointer;transition:all .2s ease}.achievement-badge:hover{background:#ffd70026;border-color:#ffd70066}.achievement-badge.new{animation:achievement-pulse 2s ease-in-out infinite;border-color:#ffd70080;box-shadow:0 0 10px #ffd7004d}@keyframes achievement-pulse{0%,to{box-shadow:0 0 5px #ffd7004d}50%{box-shadow:0 0 15px #ffd70080,0 0 25px #ffd70033}}.achievement-badge-icon{font-size:1rem}.achievement-badge-name{font-size:.8rem;font-weight:600;color:var(--text-primary)}.achievement-badge.selected{background:#ffd70033;border-color:#ffd70080}.achievement-tooltip{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:.5rem;padding:.5rem .75rem;background:var(--bg-secondary);border:1px solid rgba(255,215,0,.3);border-radius:8px;font-size:.75rem;color:var(--text-secondary);white-space:nowrap;z-index:10;box-shadow:0 4px 12px #0000004d;animation:tooltipFadeIn .15s ease-out}.achievement-tooltip:before{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-bottom-color:#ffd7004d}.achievement-tooltip:after{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-bottom-color:var(--bg-secondary)}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%) translateY(-4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media (min-width: 600px){.grade-circle{width:110px;height:110px}.grade-letter{font-size:3rem}.share-button:hover{background:var(--accent-glow);transform:scale(1.02)}.restart-button:hover{background:#6c5ce740;color:var(--text-primary)}.menu-button:hover{background:var(--bg-card);color:var(--text-primary)}.ranking-button:hover{background:#6c5ce733;color:var(--text-primary)}.ad-close:hover{background:#ffffff26;color:var(--text-primary)}.leaderboard-close:hover{color:var(--text-primary)}}.leaderboard-tabs{display:flex;gap:.5rem;margin-top:.5rem}.leaderboard-tab{padding:.4rem .75rem;font-size:.8rem;font-weight:600;color:var(--text-secondary);background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;cursor:pointer;transition:all .2s ease}.leaderboard-tab:hover{background:#ffffff14;color:var(--text-primary)}.leaderboard-tab.active{background:#6c5ce733;border-color:#6c5ce766;color:var(--accent-glow)}.leaderboard-total{font-size:.75rem;color:var(--text-secondary);text-align:center;padding:.5rem;border-bottom:1px solid rgba(255,255,255,.06)}.leaderboard-date{font-size:.8rem;color:var(--text-secondary);padding:.5rem 1.25rem 0}.expert-indicator{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:.65rem;font-weight:800;color:#12122a;background:linear-gradient(135deg,var(--accent-glow),var(--accent));border-radius:4px;margin-left:.35rem;vertical-align:middle}.improvement-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;background:#000000d9;display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;transition:opacity .3s ease;pointer-events:none}.improvement-overlay.visible{opacity:1;pointer-events:auto}.improvement-popup{background:var(--bg-secondary);border-radius:20px;width:100%;max-width:320px;padding:1.5rem;display:flex;flex-direction:column;align-items:center;gap:1rem;border:1px solid rgba(162,155,254,.3);box-shadow:0 0 40px #a29bfe33;transform:scale(.9);transition:transform .3s ease}.improvement-overlay.visible .improvement-popup{transform:scale(1)}.improvement-header{display:flex;flex-direction:column;align-items:center;gap:.5rem}.improvement-icon{font-size:2.5rem;animation:bounce .6s ease infinite alternate}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-5px)}}.improvement-title{font-size:1.25rem;font-weight:800;color:var(--text-primary);text-align:center;margin:0}.improvement-list{width:100%;display:flex;flex-direction:column;gap:.5rem}.improvement-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-radius:10px;background:#ffffff0d}.improvement-item.daily{border-left:3px solid #55efc4}.improvement-item.alltime{border-left:3px solid #a29bfe;background:#a29bfe1a}.improvement-item.group{border-left:3px solid #00cec9}.improvement-label{font-size:.9rem;font-weight:600;color:var(--text-primary)}.improvement-value{font-size:.9rem;font-weight:700;color:#55efc4;font-variant-numeric:tabular-nums}.improvement-close{margin-top:.5rem;padding:.75rem 2rem;font-size:1rem;font-weight:700;color:#fff;background:var(--accent);border-radius:12px;cursor:pointer;transition:all .2s ease}.improvement-close:hover{background:var(--accent-glow);transform:scale(1.02)}.improvement-close:active{transform:scale(.98)}.achievement-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;background:#000000d9;display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;transition:opacity .3s ease;pointer-events:none}.achievement-overlay.visible{opacity:1;pointer-events:auto}.achievement-popup{background:var(--bg-secondary);border-radius:20px;width:100%;max-width:360px;padding:1.5rem;display:flex;flex-direction:column;align-items:center;gap:1rem;border:1px solid rgba(255,215,0,.4);box-shadow:0 0 40px #ffd70040;transform:scale(.9);transition:transform .3s ease}.achievement-overlay.visible .achievement-popup{transform:scale(1)}.achievement-header{display:flex;flex-direction:column;align-items:center;gap:.5rem}.achievement-icon{font-size:2.5rem;animation:achievement-bounce .6s ease infinite alternate}@keyframes achievement-bounce{0%{transform:translateY(0) scale(1)}to{transform:translateY(-5px) scale(1.1)}}.achievement-title{font-size:1.25rem;font-weight:800;color:gold;text-align:center;margin:0;text-shadow:0 0 10px rgba(255,215,0,.5)}.achievement-list{width:100%;display:flex;flex-direction:column;gap:.75rem}.achievement-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:12px;background:#ffd7001a;border:1px solid rgba(255,215,0,.2);animation:achievement-glow 2s ease-in-out infinite}@keyframes achievement-glow{0%,to{box-shadow:0 0 5px #ffd70033}50%{box-shadow:0 0 15px #ffd70066}}.achievement-item-icon{font-size:1.5rem;flex-shrink:0}.achievement-item-content{display:flex;flex-direction:column;gap:.15rem}.achievement-item-name{font-size:1rem;font-weight:700;color:var(--text-primary)}.achievement-item-desc{font-size:.8rem;color:var(--text-secondary)}.achievement-close{margin-top:.5rem;padding:.75rem 2rem;font-size:1rem;font-weight:700;color:#12122a;background:linear-gradient(135deg,gold,#ffb700);border-radius:12px;cursor:pointer;transition:all .2s ease}.achievement-close:hover{transform:scale(1.02);box-shadow:0 0 20px #ffd70080}.achievement-close:active{transform:scale(.98)}.login-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out;padding:1rem}.login-modal{position:relative;width:100%;max-width:380px;background:var(--bg-secondary);border:1px solid rgba(108,92,231,.25);border-radius:16px;padding:2rem 1.5rem;display:flex;flex-direction:column;gap:1.25rem;animation:fadeIn .3s ease-out}.login-modal-close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;color:var(--text-secondary);font-size:1.5rem;line-height:1;cursor:pointer;padding:.25rem .5rem;border-radius:8px;transition:color .2s ease}.login-modal-close:hover{color:var(--text-primary)}.login-modal-title{font-size:1.5rem;font-weight:800;color:var(--text-primary);text-align:center}.login-modal-form{display:flex;flex-direction:column;gap:1rem}.login-modal-field{display:flex;flex-direction:column;gap:.35rem}.login-modal-label{font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.login-modal-input{width:100%;padding:.85rem 1rem;font-size:1rem;font-family:inherit;color:var(--text-primary);background:var(--bg-primary, #0a0a1a);border:2px solid rgba(108,92,231,.2);border-radius:12px;outline:none;transition:border-color .2s ease}.login-modal-input:focus{border-color:var(--accent-glow)}.login-modal-input::placeholder{color:var(--text-secondary);opacity:.5}.login-modal-input-code{text-align:center;letter-spacing:.3em;font-size:1.25rem;font-weight:700}.login-modal-sent{font-size:.9rem;color:var(--text-secondary);text-align:center}.login-modal-sent strong{color:var(--text-primary)}.login-modal-error{font-size:.85rem;color:var(--danger, #ff6b6b);text-align:center;padding:.5rem;background:#ff6b6b14;border-radius:8px}.login-modal-submit{margin-top:.25rem;padding:.9rem;font-size:1.05rem;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-glow));border-radius:12px;transition:all .2s ease;box-shadow:0 0 20px #6c5ce74d}.login-modal-submit:disabled{opacity:.5;cursor:default}.login-modal-submit:active:not(:disabled){transform:scale(.97)}.login-modal-link{background:none;border:none;color:var(--text-secondary);font-size:.85rem;cursor:pointer;text-align:center;padding:.5rem;transition:color .2s ease}.login-modal-link:hover{color:var(--text-primary)}@media (min-width: 600px){.login-modal-submit:not(:disabled):hover{background:var(--accent-glow);box-shadow:0 0 30px #a29bfe80;transform:scale(1.02)}}.join-page{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:1rem;animation:fadeIn .3s ease-out}.join-card{width:100%;max-width:380px;background:var(--bg-secondary);border:1px solid rgba(108,92,231,.25);border-radius:16px;padding:2rem 1.5rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.join-loading{color:var(--text-secondary);font-size:.95rem;padding:2rem 0}.join-error-icon{width:60px;height:60px;border-radius:50%;background:#ff6b6b1a;border:2px solid rgba(255,107,107,.3);display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:800;color:var(--danger, #ff6b6b)}.join-brand{font-size:1.75rem;font-weight:900;color:var(--accent-glow);text-align:center;margin:0;letter-spacing:-.5px}.join-tagline{font-size:.85rem;color:var(--text-secondary);text-align:center;line-height:1.5;margin:0}.join-divider{width:100%;height:1px;background:#6c5ce733;margin:.5rem 0}.join-title{font-size:1.25rem;font-weight:800;color:var(--text-primary);text-align:center;margin:0}.join-group-name{font-size:1.25rem;font-weight:700;color:var(--accent-glow);text-align:center;padding:.5rem 1rem;background:#6c5ce71a;border-radius:8px}.join-stats{display:flex;gap:1rem}.join-stat{font-size:.85rem;color:var(--text-secondary)}.join-error{font-size:.85rem;color:var(--danger, #ff6b6b);text-align:center;padding:.5rem;background:#ff6b6b14;border-radius:8px;width:100%}.join-button{width:100%;padding:.9rem;font-size:1.05rem;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-glow));border-radius:12px;transition:all .2s ease;box-shadow:0 0 20px #6c5ce74d;margin-top:.5rem}.join-button:disabled{opacity:.6;cursor:default}.join-button:active:not(:disabled){transform:scale(.97)}.join-options{display:flex;flex-direction:column;align-items:center;gap:.75rem;width:100%;margin-top:.5rem}.join-info{font-size:.9rem;color:var(--text-secondary);text-align:center}.join-login,.join-upgrade{width:100%;padding:.85rem;font-size:1rem;font-weight:700;border-radius:12px;transition:all .2s ease}.join-upgrade{color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-glow));box-shadow:0 0 20px #6c5ce74d}.join-login{color:var(--text-primary);background:var(--bg-primary);border:1px solid rgba(108,92,231,.3)}.join-dismiss{width:100%;padding:.75rem;font-size:.9rem;font-weight:600;color:var(--text-secondary);background:transparent;border:none;margin-top:.5rem;transition:color .2s ease}.join-dismiss:hover{color:var(--text-primary)}@media (min-width: 600px){.join-button:not(:disabled):hover{background:var(--accent-glow);box-shadow:0 0 30px #a29bfe80;transform:scale(1.02)}.join-upgrade:hover{background:var(--accent-glow);box-shadow:0 0 30px #a29bfe80;transform:scale(1.02)}.join-login:hover{background:#6c5ce71a}}.group-page{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:flex-start;justify-content:center;background:var(--bg-primary);overflow-y:auto;padding:1rem;animation:fadeIn .3s ease-out}.group-container{position:relative;width:100%;max-width:480px;background:var(--bg-secondary);border:1px solid rgba(108,92,231,.25);border-radius:16px;padding:2rem 1.5rem;margin:1rem 0;display:flex;flex-direction:column;gap:1.5rem}.group-close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;color:var(--text-secondary);font-size:1.5rem;line-height:1;cursor:pointer;padding:.25rem .5rem;border-radius:8px;transition:color .2s ease}.group-close:hover{color:var(--text-primary)}.group-loading,.group-error{text-align:center;padding:2rem;color:var(--text-secondary)}.group-error{color:var(--danger, #ff6b6b)}.group-back{padding:.75rem 1.5rem;font-size:.9rem;font-weight:600;color:var(--text-secondary);background:var(--bg-primary);border:1px solid rgba(108,92,231,.2);border-radius:10px;cursor:pointer;align-self:center}.group-name-display{display:flex;align-items:center;justify-content:center;gap:.5rem}.group-name{font-size:1.75rem;font-weight:800;color:var(--text-primary);text-align:center;margin:0}.group-name-edit-btn{background:none;border:none;color:var(--text-secondary);font-size:1.1rem;cursor:pointer;padding:.25rem;border-radius:4px;transition:color .2s ease;line-height:1}.group-name-edit-btn:hover{color:var(--accent-glow)}.group-name-edit{display:flex;flex-direction:column;align-items:center;gap:.75rem}.group-name-input{width:100%;max-width:300px;padding:.75rem 1rem;font-size:1.25rem;font-weight:700;font-family:inherit;color:var(--text-primary);background:var(--bg-primary);border:2px solid var(--accent);border-radius:10px;text-align:center;outline:none}.group-name-input:focus{border-color:var(--accent-glow);box-shadow:0 0 0 3px #6c5ce733}.group-name-actions{display:flex;gap:.5rem}.group-name-save,.group-name-cancel{padding:.5rem 1rem;font-size:.85rem;font-weight:600;border-radius:8px;transition:all .2s ease}.group-name-save{color:#fff;background:var(--accent)}.group-name-save:hover:not(:disabled){background:var(--accent-glow)}.group-name-save:disabled{opacity:.6;cursor:not-allowed}.group-name-cancel{color:var(--text-secondary);background:var(--bg-primary);border:1px solid rgba(255,255,255,.1)}.group-name-cancel:hover:not(:disabled){color:var(--text-primary);border-color:#fff3}.group-name-cancel:disabled{opacity:.6;cursor:not-allowed}.group-meta{font-size:.9rem;color:var(--text-secondary);text-align:center;margin-top:-1rem}.group-action-error{font-size:.85rem;color:var(--danger, #ff6b6b);text-align:center;padding:.5rem;background:#ff6b6b14;border-radius:8px}.group-invite-section{display:flex;flex-direction:column;gap:.5rem}.group-share-invite{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.25rem;font-size:.95rem;font-weight:600;color:#fff;background:var(--accent);border-radius:10px;transition:all .2s ease}.group-share-invite:active{transform:scale(.97)}.group-share-invite .share-icon{width:18px;height:18px}.group-create-invite{padding:.75rem;font-size:.95rem;font-weight:600;color:var(--accent-glow);background:#6c5ce71a;border:1px solid rgba(108,92,231,.3);border-radius:10px;transition:all .2s ease}.group-create-invite:hover{background:#6c5ce733}.group-section-title{font-size:.9rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.group-time-selector{display:flex;gap:.5rem;margin-bottom:.75rem}.group-time-btn{padding:.5rem 1rem;font-size:.85rem;font-weight:600;color:var(--text-secondary);background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;cursor:pointer;transition:all .2s ease}.group-time-btn:hover{background:#ffffff14;color:var(--text-primary)}.group-time-btn.active{background:#6c5ce733;border-color:#6c5ce766;color:var(--accent-glow)}.group-mode-selector{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.75rem}.group-mode-btn{padding:.5rem .75rem;font-size:.8rem;font-weight:600;color:var(--text-secondary);background:var(--bg-primary);border:1px solid rgba(108,92,231,.15);border-radius:8px;transition:all .2s ease}.group-mode-btn:hover{border-color:#6c5ce74d}.group-mode-btn.active{color:var(--text-primary);background:#6c5ce733;border-color:var(--accent)}.group-leaderboard{background:var(--bg-primary);border-radius:12px;border:1px solid rgba(108,92,231,.1);overflow:hidden}.group-lb-loading,.group-lb-empty{padding:1.5rem;text-align:center;color:var(--text-secondary);font-size:.9rem}.group-lb-row{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-bottom:1px solid rgba(255,255,255,.03)}.group-lb-row:last-child{border-bottom:none}.group-lb-row.current-user{background:#6c5ce726;border-left:3px solid var(--accent)}.group-lb-rank{font-weight:700;color:var(--text-secondary);font-size:.9rem;min-width:36px}.group-lb-tag{flex:1;font-weight:600;color:var(--text-primary);font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-lb-score{font-size:.85rem;font-weight:600;color:var(--text-secondary);font-variant-numeric:tabular-nums;min-width:60px;text-align:right}.group-lb-grade{font-size:.85rem;font-weight:800;min-width:24px;text-align:center}.group-lb-grade.grade-S{color:#a29bfe}.group-lb-grade.grade-A{color:#00cec9}.group-lb-grade.grade-B{color:#55efc4}.group-lb-grade.grade-C{color:#fdcb6e}.group-lb-grade.grade-D{color:#e17055}.group-lb-grade.grade-F{color:#ff6b6b}.group-members{background:var(--bg-primary);border-radius:12px;border:1px solid rgba(108,92,231,.1);overflow:hidden}.group-member-row{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid rgba(255,255,255,.03)}.group-member-row:last-child{border-bottom:none}.group-member-info{display:flex;align-items:center;gap:.5rem}.group-member-tag{font-weight:600;color:var(--text-primary);font-size:.95rem}.group-member-badge{font-size:.7rem;font-weight:700;text-transform:uppercase;padding:.2rem .5rem;background:#6c5ce733;color:var(--accent-glow);border-radius:4px}.group-member-remove{font-size:.8rem;font-weight:600;color:var(--danger, #ff6b6b);background:#ff6b6b1a;padding:.35rem .65rem;border-radius:6px;transition:all .2s ease}.group-member-remove:hover{background:#ff6b6b33}.group-actions{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.group-leave-btn,.group-delete-btn{padding:.75rem;font-size:.9rem;font-weight:600;border-radius:10px;transition:all .2s ease}.group-leave-btn{color:var(--text-secondary);background:var(--bg-primary);border:1px solid rgba(255,255,255,.1)}.group-leave-btn:hover{color:var(--text-primary);border-color:#fff3}.group-delete-btn{color:var(--danger, #ff6b6b);background:#ff6b6b14;border:1px solid rgba(255,107,107,.2)}.group-delete-btn:hover{background:#ff6b6b26}.group-confirm{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.group-confirm span{flex:1;min-width:100px;color:var(--text-secondary);font-size:.9rem}.group-confirm-yes,.group-confirm-no{padding:.5rem 1rem;font-size:.85rem;font-weight:600;border-radius:8px}.group-confirm-yes{color:#fff;background:var(--danger, #ff6b6b)}.group-confirm-no{color:var(--text-secondary);background:var(--bg-primary);border:1px solid rgba(255,255,255,.1)}.group-notifications-section{margin:1.5rem 0}.group-notification-toggle{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--bg-card, var(--bg-primary));border-radius:8px;border:1px solid rgba(108,92,231,.1)}.notification-label{font-size:.9rem;color:var(--text-primary)}.toggle-switch{position:relative;display:inline-block;width:50px;height:26px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;right:0;bottom:0;left:0;background:var(--bg-secondary);border-radius:26px;transition:.3s}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background:var(--text-secondary);border-radius:50%;transition:.3s}.toggle-switch input:checked+.toggle-slider{background:var(--accent)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px);background:#fff}.toggle-switch input:disabled+.toggle-slider{opacity:.5;cursor:not-allowed}@media (min-width: 600px){.group-share-invite:hover{background:var(--accent-glow)}.group-close:hover{color:var(--text-primary)}}.expert-unlock-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;background:#000000d9;display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;transition:opacity .3s ease;pointer-events:none}.expert-unlock-overlay.visible{opacity:1;pointer-events:auto}.expert-unlock-popup{background:var(--bg-secondary);border-radius:20px;width:100%;max-width:380px;padding:1.75rem;display:flex;flex-direction:column;align-items:center;gap:1.25rem;border:1px solid rgba(162,155,254,.5);box-shadow:0 0 60px #a29bfe59;transform:scale(.9);transition:transform .3s ease}.expert-unlock-overlay.visible .expert-unlock-popup{transform:scale(1)}.expert-unlock-header{display:flex;flex-direction:column;align-items:center;gap:.5rem}.expert-unlock-icon{font-size:3rem;animation:expert-bounce .6s ease infinite alternate}@keyframes expert-bounce{0%{transform:translateY(0) scale(1)}to{transform:translateY(-8px) scale(1.1)}}.expert-unlock-title{font-size:1.5rem;font-weight:800;color:var(--accent-glow);text-align:center;margin:0;text-shadow:0 0 20px rgba(162,155,254,.6)}.expert-unlock-content{display:flex;flex-direction:column;gap:1rem}.expert-unlock-desc{font-size:.95rem;color:var(--text-secondary);text-align:center;line-height:1.5;margin:0}.expert-unlock-features{display:flex;flex-direction:column;gap:.6rem}.expert-feature{display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem;border-radius:10px;background:#a29bfe1a;border:1px solid rgba(162,155,254,.2)}.expert-feature-icon{font-size:1.1rem;flex-shrink:0}.expert-feature-text{font-size:.85rem;color:var(--text-primary);font-weight:500}.expert-unlock-close{margin-top:.5rem;padding:.85rem 2.5rem;font-size:1rem;font-weight:700;color:#12122a;background:linear-gradient(135deg,var(--accent-glow),var(--accent));border-radius:12px;cursor:pointer;transition:all .2s ease}.expert-unlock-close:hover{transform:scale(1.02);box-shadow:0 0 25px #a29bfe99}.expert-unlock-close:active{transform:scale(.98)}.upgrade-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;background:#000000d9;display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;transition:opacity .3s ease;pointer-events:none}.upgrade-overlay.visible{opacity:1;pointer-events:auto}.upgrade-popup{background:var(--bg-secondary);border-radius:20px;width:100%;max-width:380px;padding:1.75rem;display:flex;flex-direction:column;align-items:center;gap:1.25rem;border:1px solid rgba(253,203,110,.5);box-shadow:0 0 60px #fdcb6e59;transform:scale(.9);transition:transform .3s ease}.upgrade-overlay.visible .upgrade-popup{transform:scale(1)}.upgrade-header{display:flex;flex-direction:column;align-items:center;gap:.5rem}.upgrade-icon{font-size:3rem;animation:upgrade-bounce .6s ease infinite alternate}@keyframes upgrade-bounce{0%{transform:translateY(0) scale(1)}to{transform:translateY(-8px) scale(1.1)}}.upgrade-title{font-size:1.5rem;font-weight:800;color:#fdcb6e;text-align:center;margin:0;text-shadow:0 0 20px rgba(253,203,110,.6)}.upgrade-price{font-size:1.25rem;font-weight:700;color:#00cec9;background:#00cec926;padding:.25rem 1rem;border-radius:20px;border:1px solid rgba(0,206,201,.3)}.upgrade-content{display:flex;flex-direction:column;gap:1rem;width:100%}.upgrade-features{display:flex;flex-direction:column;gap:.6rem}.upgrade-feature{display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem;border-radius:10px;background:#fdcb6e1a;border:1px solid rgba(253,203,110,.2)}.upgrade-feature-icon{font-size:1.1rem;flex-shrink:0}.upgrade-feature-text{font-size:.85rem;color:var(--text-primary);font-weight:500}.upgrade-buttons{display:flex;flex-direction:column;gap:.75rem;width:100%;margin-top:.5rem}.upgrade-btn-primary{padding:.85rem 2.5rem;font-size:1rem;font-weight:700;color:#12122a;background:linear-gradient(135deg,#fdcb6e,#e17055);border-radius:12px;cursor:pointer;transition:all .2s ease;width:100%}.upgrade-btn-primary:hover{transform:scale(1.02);box-shadow:0 0 25px #fdcb6e99}.upgrade-btn-primary:active{transform:scale(.98)}.upgrade-btn-secondary{padding:.6rem 1.5rem;font-size:.9rem;font-weight:600;color:var(--text-secondary);background:transparent;border:1px solid rgba(136,136,187,.3);border-radius:10px;cursor:pointer;transition:all .2s ease;width:100%}.upgrade-btn-secondary:hover{background:#8888bb1a;color:var(--text-primary)}.notification-optin-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;background:#000000d9;display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;transition:opacity .3s ease;pointer-events:none}.notification-optin-overlay.visible{opacity:1;pointer-events:auto}.notification-optin-popup{background:var(--bg-secondary);border-radius:20px;width:100%;max-width:380px;padding:1.75rem;display:flex;flex-direction:column;align-items:center;gap:1.25rem;border:1px solid rgba(108,92,231,.5);box-shadow:0 0 60px #6c5ce759;transform:scale(.9);transition:transform .3s ease}.notification-optin-overlay.visible .notification-optin-popup{transform:scale(1)}.notification-optin-header{display:flex;flex-direction:column;align-items:center;gap:.75rem}.notification-optin-icon{font-size:3rem;animation:notification-ring .6s ease infinite alternate}@keyframes notification-ring{0%{transform:rotate(-10deg) scale(1)}to{transform:rotate(10deg) scale(1.05)}}.notification-optin-title{font-size:1.35rem;font-weight:800;color:var(--accent-glow);text-align:center;margin:0;text-shadow:0 0 20px rgba(108,92,231,.6)}.notification-optin-content{display:flex;flex-direction:column;gap:1rem;width:100%;text-align:center}.notification-optin-text{font-size:1rem;color:var(--text-primary);margin:0;line-height:1.5}.notification-optin-buttons{display:flex;flex-direction:column;gap:.75rem;width:100%;margin-top:.5rem}.notification-optin-btn-primary{padding:.85rem 2.5rem;font-size:1rem;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-glow));border-radius:12px;cursor:pointer;transition:all .2s ease;width:100%;border:none}.notification-optin-btn-primary:hover:not(:disabled){transform:scale(1.02);box-shadow:0 0 25px #6c5ce799}.notification-optin-btn-primary:active:not(:disabled){transform:scale(.98)}.notification-optin-btn-primary:disabled{opacity:.7;cursor:not-allowed}.notification-optin-btn-secondary{padding:.6rem 1.5rem;font-size:.9rem;font-weight:600;color:var(--text-secondary);background:transparent;border:1px solid rgba(136,136,187,.3);border-radius:10px;cursor:pointer;transition:all .2s ease;width:100%}.notification-optin-btn-secondary:hover:not(:disabled){background:#8888bb1a;color:var(--text-primary)}.notification-optin-btn-secondary:disabled{opacity:.5;cursor:not-allowed}.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:900;display:flex;align-items:center;justify-content:center;gap:1rem;padding:1rem 1.5rem;background:var(--bg-secondary);border-top:1px solid rgba(108,92,231,.2);animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.cookie-banner-text{font-size:.85rem;color:var(--text-secondary);margin:0}.cookie-banner-text a{color:var(--accent-glow);text-decoration:none}.cookie-banner-text a:hover{text-decoration:underline}.cookie-banner-accept{padding:.5rem 1.25rem;font-size:.85rem;font-weight:600;color:#fff;background:var(--accent);border:none;border-radius:8px;cursor:pointer;transition:background .2s}.cookie-banner-accept:hover{background:var(--accent-glow)}@media (max-width: 500px){.cookie-banner{flex-direction:column;gap:.75rem;text-align:center}}.app{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-primary);overflow:hidden}.login-page{display:flex;align-items:center;justify-content:center;min-height:100%;padding:2rem}.login-container{display:flex;flex-direction:column;align-items:center;gap:1.5rem;width:100%;max-width:380px;animation:fadeIn .6s ease-out}.login-title{font-size:2.5rem;font-weight:800;line-height:1.1;text-align:center}.login-subtitle{color:var(--text-secondary);font-size:1rem}.login-form{display:flex;flex-direction:column;gap:.75rem;width:100%}.login-label{font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.login-input{width:100%;padding:.85rem 1rem;font-size:1rem;font-family:inherit;color:var(--text-primary);background:var(--bg-secondary);border:2px solid rgba(108,92,231,.2);border-radius:12px;outline:none;transition:border-color .2s ease}.login-input:focus{border-color:var(--accent-glow)}.login-input::placeholder{color:var(--text-secondary);opacity:.5}.login-input-code{text-align:center;font-size:1.5rem;font-weight:700;letter-spacing:.3em;font-variant-numeric:tabular-nums}.login-button{margin-top:.5rem;padding:.9rem;font-size:1.05rem;font-weight:700;color:#fff;background:var(--accent);border-radius:12px;transition:all .2s ease;box-shadow:0 0 20px #6c5ce74d}.login-button:disabled{opacity:.5;cursor:default}.login-button:active:not(:disabled){transform:scale(.97)}.login-error{font-size:.85rem;color:var(--danger);text-align:center;padding:.5rem;background:#ff6b6b14;border-radius:8px}.login-sent-to{font-size:.9rem;color:var(--text-secondary);text-align:center;margin-bottom:.25rem}.login-sent-to strong{color:var(--text-primary)}.login-back-link{font-size:.85rem;color:var(--text-secondary);text-decoration:none;text-align:center;padding:.5rem;background:none;border:none;cursor:pointer;font-family:inherit;transition:color .2s ease}.login-back-link:hover{color:var(--accent-glow)}.login-already-pro-banner{width:100%;padding:1rem;background:#00cec91a;border:1px solid rgba(0,206,201,.3);border-radius:12px;text-align:center}.login-already-pro-banner .banner-icon{font-size:1.5rem;display:block;margin-bottom:.5rem}.login-already-pro-banner p{margin:0;color:var(--split-good);font-weight:600}.login-already-pro-banner .banner-detail{margin-top:.5rem;font-size:.85rem;font-weight:400;color:var(--text-secondary)}@media (min-width: 600px){.login-button:not(:disabled):hover{background:var(--accent-glow);box-shadow:0 0 30px #a29bfe80;transform:scale(1.02)}}*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0a0a1a;--bg-secondary: #12122a;--bg-card: #1a1a3e;--text-primary: #e0e0ff;--text-secondary: #8888bb;--accent: #6c5ce7;--accent-glow: #a29bfe;--success: #00cec9;--warning: #fdcb6e;--danger: #ff6b6b;--split-good: #00cec9;--split-ok: #fdcb6e;--split-bad: #ff6b6b}html,body{height:100%;overflow:hidden}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%}button{font-family:inherit;cursor:pointer;border:none;outline:none}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
