.loader-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px}.loader-fullscreen{min-height:100vh}.loader-spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.1);border-top-color:var(--red-primary);border-radius:50%;animation:spin 1s linear infinite}.loader-text{color:var(--white-pure);font-size:16px;opacity:.8;margin:0}.admin-guard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1.5rem;background:linear-gradient(135deg,#1a1a2e,#252545);color:#fff}.admin-guard-loading p{font-size:1rem;color:#9ca3af}.admin-guard-forbidden{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#252545);padding:2rem}.forbidden-content{text-align:center;max-width:500px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:3rem 2rem;backdrop-filter:blur(10px)}.forbidden-icon{font-size:4rem;display:block;margin-bottom:1.5rem;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}.forbidden-content h2{font-size:2rem;font-weight:700;margin-bottom:1rem;color:#fff}.forbidden-content p{font-size:1rem;color:#9ca3af;line-height:1.6;margin-bottom:2rem}.back-link{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;background:#dc26261a;border:1px solid rgba(220,38,38,.3);border-radius:8px;color:#dc2626;text-decoration:none;font-weight:600;transition:all .2s ease}.back-link:hover{background:#dc262633;border-color:#dc262680;transform:translateY(-2px)}.premium-guard-blurred-content{filter:blur(8px);pointer-events:none;user-select:none;opacity:.4}.premium-guard-overlay{position:fixed;inset:0;background:linear-gradient(180deg,#1a1a2e80,#1a1a2ee6,#1a1a2ef2);display:flex;align-items:center;justify-content:center;padding:2rem;z-index:1100;margin-left:280px;pointer-events:none}.premium-guard-overlay-card{background:linear-gradient(135deg,#1a1a2efa 0% 100%);border-radius:20px;padding:3rem 2.5rem;max-width:480px;width:100%;box-shadow:0 25px 70px #0009;border:1px solid rgba(255,255,255,.15);text-align:center;backdrop-filter:blur(10px);position:relative;pointer-events:auto}.premium-guard-close{position:absolute;top:1rem;right:1rem;background:transparent;border:none;color:#fff9;cursor:pointer;transition:all .2s ease;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:8px}.premium-guard-close:hover{color:var(--white-pure);background:#ffffff1a}.premium-guard-icon-wrapper{display:flex;justify-content:center;margin-bottom:1.5rem}.premium-guard-icon{background:linear-gradient(135deg,#eab308,#f59e0b);padding:1.25rem;border-radius:50%;display:flex;align-items:center;justify-content:center;animation:iconPulse 2s ease-in-out infinite;box-shadow:0 8px 24px #eab30866}.premium-guard-icon svg{width:48px;height:48px;color:#fff}@keyframes iconPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.premium-guard-title{font-size:1.75rem;font-weight:700;color:#fff;margin-bottom:.75rem;line-height:1.2}.premium-guard-description{color:#ffffffb3;font-size:.9375rem;margin-bottom:2rem;line-height:1.5}.premium-guard-features{list-style:none;padding:0;margin:0 0 2rem;text-align:left;background:#0003;border-radius:12px;padding:1.5rem 1.25rem;border:1px solid rgba(255,255,255,.08)}.premium-guard-features li{display:flex;align-items:flex-start;gap:.875rem;color:#ffffffe6;font-size:.9375rem;padding:.625rem 0;line-height:1.5}.premium-guard-features li:not(:last-child){border-bottom:1px solid rgba(255,255,255,.05)}.premium-guard-check-icon{flex-shrink:0;margin-top:.125rem}.premium-guard-trial-badge{display:inline-block;background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-size:.875rem;font-weight:700;padding:.5rem 1.25rem;border-radius:50px;margin-bottom:1.25rem;box-shadow:0 4px 12px #10b9814d;animation:badgePulse 2s ease-in-out infinite}@keyframes badgePulse{0%,to{transform:scale(1);box-shadow:0 4px 12px #10b9814d}50%{transform:scale(1.02);box-shadow:0 6px 16px #10b98166}}.premium-guard-button{width:100%;padding:1.125rem 1.5rem;background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff;font-weight:700;border:none;border-radius:12px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #dc26264d;font-size:1.0625rem;margin-bottom:.75rem}.premium-guard-button:hover{background:linear-gradient(135deg,#b91c1c,#991b1b);transform:translateY(-2px);box-shadow:0 6px 20px #dc262666}.premium-guard-button:active{transform:translateY(0)}.premium-guard-button-secondary{width:100%;padding:1rem 1.5rem;background:transparent;color:#fffc;font-weight:600;border:2px solid rgba(255,255,255,.2);border-radius:12px;cursor:pointer;transition:all .2s ease;font-size:1rem;margin-bottom:1rem}.premium-guard-button-secondary:hover{background:#ffffff0d;border-color:#ffffff4d;color:#fff;transform:translateY(-1px)}.premium-guard-button-secondary:active{transform:translateY(0)}.premium-guard-trial-info{color:#fff9;font-size:.8125rem;margin:0;font-weight:500}.premium-guard-loading{display:flex;align-items:center;justify-content:center;padding:2rem}.premium-guard-spinner{width:2rem;height:2rem;border:2px solid rgba(220,38,38,.2);border-top-color:#dc2626;border-radius:50%;animation:premium-guard-spin .6s linear infinite}@keyframes premium-guard-spin{to{transform:rotate(360deg)}}@media(max-width:1024px){.premium-guard-overlay{margin-left:0}}@media(max-width:640px){.premium-guard-overlay{padding:1rem}.premium-guard-overlay-card{padding:2.5rem 1.75rem;border-radius:16px}.premium-guard-title{font-size:1.5rem}.premium-guard-description{font-size:.875rem}.premium-guard-features{padding:1.25rem 1rem}.premium-guard-features li{font-size:.875rem;gap:.75rem}.premium-guard-button{font-size:1rem;padding:1rem 1.25rem}}.btn{font-family:inherit;cursor:pointer;transition:all .2s ease;border:none;border-radius:12px;padding:14px 24px;font-size:16px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:52px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--red-primary);color:var(--white-pure);box-shadow:0 4px 12px #dc262666,0 0 20px #dc262633}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #dc262680,0 0 30px #dc26264d;background-color:#ef4444}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background-color:transparent;color:var(--white-pure);border:2px solid var(--white-pure)}.btn-secondary:hover:not(:disabled){background-color:#ffffff1a}.btn-ghost{background-color:transparent;color:#fffc;font-weight:600}.btn-ghost:hover:not(:disabled){color:var(--white-pure)}.btn-danger{background-color:#dc2626;color:var(--white-pure);box-shadow:0 4px 12px #dc262666}.btn-danger:hover:not(:disabled){background-color:#b91c1c;transform:translateY(-2px);box-shadow:0 6px 20px #dc262680}.btn-danger:active:not(:disabled){transform:translateY(0)}.btn-loader{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top-color:var(--white-pure);border-radius:50%;animation:spin .8s linear infinite}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(135deg,#1a1a2e,#252545)}.error-boundary-content{max-width:500px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:24px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:48px 32px;backdrop-filter:blur(10px)}.error-boundary-icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;border-radius:50%;background:#ef44441a;color:#ef4444}.error-boundary-title{font-size:24px;font-weight:700;color:#fff;margin:0}.error-boundary-message{font-size:16px;color:#9ca3af;margin:0;line-height:1.6}.error-boundary-details{width:100%;text-align:left;margin-top:16px}.error-boundary-details summary{cursor:pointer;font-size:14px;color:#9ca3af;padding:8px 12px;background:#ffffff0d;border-radius:8px;user-select:none}.error-boundary-details summary:hover{background:#ffffff1a}.error-boundary-stack{margin-top:12px;padding:12px;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:8px;font-size:12px;color:#f87171;overflow-x:auto;white-space:pre-wrap;word-break:break-word}.error-boundary-button{margin-top:8px;background:linear-gradient(to right,#ef4444,#dc2626)}@media(max-width:768px){.error-boundary-content{padding:32px 24px}.error-boundary-icon{width:64px;height:64px}.error-boundary-title{font-size:20px}.error-boundary-message{font-size:14px}}.install-pwa-prompt{position:fixed;bottom:20px;left:50%;transform:translate(-50%);z-index:9998;width:calc(100% - 40px);max-width:600px;pointer-events:auto}.install-pwa-prompt-content{position:relative;display:flex;align-items:center;gap:16px;background:linear-gradient(135deg,#dc2626f2,#1a1a2ef2);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);border-radius:16px;padding:20px;box-shadow:0 8px 32px #dc262666,0 0 0 1px #ffffff14}.install-pwa-prompt-icon{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#ffffff26;border-radius:12px;color:#fff;animation:pulse-install 2s ease-in-out infinite}.install-pwa-prompt-text{flex:1;min-width:0}.install-pwa-prompt-title{margin:0 0 4px;font-size:16px;font-weight:600;color:#fff;line-height:1.3}.install-pwa-prompt-description{margin:0;font-size:14px;color:#ffffffe6;line-height:1.4}.install-pwa-ios-instructions{margin-top:12px;padding:12px;background:#ffffff1a;border-radius:8px;overflow:hidden}.install-pwa-ios-instructions ol{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px}.install-pwa-ios-instructions li{display:flex;align-items:center;gap:8px;font-size:13px;color:#fffffff2;line-height:1.4}.install-pwa-ios-instructions li svg{flex-shrink:0;opacity:.8}.install-pwa-ios-instructions li span{flex:1}.install-pwa-prompt-actions{display:flex;gap:8px;flex-shrink:0}.install-pwa-prompt-btn{padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.install-pwa-prompt-btn-primary{background:#fff;color:#dc2626;font-weight:700}.install-pwa-prompt-btn-primary:hover{background:#fffffff2;transform:translateY(-1px);box-shadow:0 4px 12px #0000004d}.install-pwa-prompt-btn-secondary{background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3)}.install-pwa-prompt-btn-secondary:hover{background:#ffffff40;transform:translateY(-1px)}.install-pwa-prompt-close{position:absolute;top:12px;right:12px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:none;border-radius:8px;color:#fffc;cursor:pointer;transition:all .2s ease}.install-pwa-prompt-close:hover{background:#fff3;color:#fff}.install-pwa-platform-badge{position:absolute;bottom:-30px;left:50%;transform:translate(-50%);padding:4px 8px;background:#00000080;color:#fff;font-size:10px;border-radius:4px;opacity:.6}@keyframes pulse-install{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@media(min-width:640px)and (max-width:1023px){.install-pwa-prompt{bottom:110px;left:30px;right:30px;width:auto;max-width:500px;margin:0 auto;transform:none}.install-pwa-prompt-content{padding:18px}}@media(max-width:640px){.install-pwa-prompt{bottom:90px;width:calc(100% - 24px);left:12px;transform:none;max-height:calc(100vh - 110px);overflow-y:auto}.install-pwa-prompt-content{flex-direction:column;align-items:stretch;padding:40px 16px 20px;gap:12px}.install-pwa-prompt-icon{align-self:center;width:48px;height:48px}.install-pwa-prompt-text{text-align:center}.install-pwa-prompt-title{font-size:16px}.install-pwa-prompt-description{font-size:13px;line-height:1.5}.install-pwa-ios-instructions{margin-top:12px;text-align:left}.install-pwa-ios-instructions li{font-size:12px}.install-pwa-prompt-actions{width:100%;flex-direction:column;gap:10px}.install-pwa-prompt-btn{width:100%;padding:14px 20px;font-size:15px}.install-pwa-prompt-close{top:10px;right:10px;width:28px;height:28px}.install-pwa-platform-badge{bottom:-25px;font-size:9px}}.update-prompt{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:10000;max-width:560px;width:calc(100% - 32px);pointer-events:all}.update-prompt-content{background:#1a1a2ef2;backdrop-filter:blur(16px);border:1px solid rgba(220,38,38,.3);border-radius:16px;padding:20px 24px;box-shadow:0 12px 40px #00000080,0 0 0 1px #ffffff1a;display:flex;align-items:center;gap:16px;position:relative}.update-prompt-icon{flex-shrink:0;width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,#dc262633,#ef44441a);border:1px solid rgba(220,38,38,.3);display:flex;align-items:center;justify-content:center;color:var(--red-primary, #DC2626)}.update-prompt-icon svg.rotating{animation:rotate 2s linear infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.update-prompt-text{flex:1;min-width:0}.update-prompt-title{color:var(--white-pure, #FFFFFF);font-size:1rem;font-weight:600;margin:0 0 6px}.update-prompt-description{color:#ffffffb3;font-size:.875rem;line-height:1.5;margin:0;display:flex;align-items:center;gap:6px}.update-prompt-description .inline-icon{flex-shrink:0;color:#f59e0b}.update-prompt-actions{display:flex;gap:8px;flex-shrink:0}.update-prompt-btn{display:flex;align-items:center;gap:6px;padding:10px 16px;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;border:none;transition:all .2s ease;white-space:nowrap}.update-prompt-btn-primary{background:var(--red-primary, #DC2626);color:var(--white-pure, #FFFFFF)}.update-prompt-btn-primary:hover:not(:disabled){background:#b91c1c;transform:translateY(-2px);box-shadow:0 4px 12px #dc262666}.update-prompt-btn-primary:disabled{opacity:.5;cursor:not-allowed;background:#dc262680}.update-prompt-btn-secondary{background:#ffffff1a;color:#ffffffe6;border:1px solid rgba(255,255,255,.2)}.update-prompt-btn-secondary:hover{background:#ffffff26;transform:translateY(-2px)}.update-prompt-close{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:6px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#fff9;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.update-prompt-close:hover{background:#ffffff1a;color:#ffffffe6}.update-prompt-progress{position:absolute;bottom:0;left:0;right:0;height:3px;background:#ffffff1a;border-radius:0 0 16px 16px;overflow:hidden}.update-prompt-progress-fill{height:100%;background:linear-gradient(90deg,var(--red-primary, #DC2626),#EF4444);box-shadow:0 0 8px #dc262680}@media(max-width:640px){.update-prompt{bottom:80px;left:12px;right:12px;width:auto;transform:none;max-width:none}.update-prompt-content{padding:16px;gap:12px;flex-direction:column;align-items:stretch}.update-prompt-icon{display:none}.update-prompt-text{text-align:center}.update-prompt-title{font-size:.95rem;margin-bottom:4px}.update-prompt-description{font-size:.8rem;justify-content:center;flex-wrap:wrap}.update-prompt-actions{display:flex;gap:8px;width:100%}.update-prompt-btn{flex:1;padding:12px;font-size:.85rem;justify-content:center}.update-prompt-close{position:absolute;top:8px;right:8px;width:28px;height:28px}}.mini-player{position:fixed;bottom:90px;left:0;right:0;background:linear-gradient(135deg,#1a1a2e,#252545);border-top:1px solid rgba(255,255,255,.1);z-index:999;box-shadow:0 -4px 20px #0000004d}@media(max-width:400px){.mini-player{bottom:85px}}@media(max-width:360px){.mini-player{bottom:80px}}@media(max-width:340px){.mini-player{bottom:75px}}@media(min-width:1024px){.mini-player{bottom:0;left:280px;right:0}}.mini-player-error{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ef444433;border-bottom:1px solid rgba(239,68,68,.3);color:#fca5a5;font-size:.8125rem;overflow:hidden}.mini-player-error span{flex:1}.mini-player-error button{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:#ffffff1a;border:none;border-radius:4px;color:#fff;cursor:pointer;transition:background .2s}.mini-player-error button:hover{background:#fff3}.mini-player-error button:focus-visible{outline:2px solid #EF4444;outline-offset:2px}.mini-player-progress{height:4px;background:#ffffff1a;cursor:pointer;touch-action:none}.mini-player-progress:focus-visible{outline:2px solid #EF4444;outline-offset:2px}.mini-player-progress-fill{height:100%;background:linear-gradient(90deg,#dc2626,#ef4444)}.mini-player-content{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;gap:.5rem}@media(min-width:640px){.mini-player-content{padding:.5rem 1rem;gap:.75rem}}.mini-player-info{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0;cursor:pointer}@media(min-width:640px){.mini-player-info{gap:.75rem}}.mini-player-info:focus-visible{outline:2px solid #EF4444;outline-offset:2px;border-radius:8px}.mini-player-cover{width:40px;height:40px;border-radius:6px;object-fit:cover;flex-shrink:0}@media(min-width:640px){.mini-player-cover{width:44px;height:44px}}.mini-player-cover-placeholder{width:40px;height:40px;border-radius:6px;background:#dc262633;display:flex;align-items:center;justify-content:center;color:#ef4444;flex-shrink:0}@media(min-width:640px){.mini-player-cover-placeholder{width:44px;height:44px}}.mini-player-text{display:flex;flex-direction:column;min-width:0;max-width:100px}@media(min-width:640px){.mini-player-text{max-width:200px}}@media(min-width:1024px){.mini-player-text{max-width:none}}.mini-player-title{font-size:.8125rem;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(min-width:640px){.mini-player-title{font-size:.875rem}}.mini-player-time{font-size:.6875rem;color:#ffffff80;font-family:monospace}@media(min-width:640px){.mini-player-time{font-size:.75rem}}.mini-player-expand{background:none;border:none;color:#ffffff80;cursor:pointer;padding:.25rem;display:none}@media(min-width:640px){.mini-player-expand{display:flex}}.mini-player-expand:focus-visible{outline:2px solid #EF4444;outline-offset:2px;border-radius:4px}.mini-player-controls{display:flex;align-items:center;gap:.125rem}@media(min-width:640px){.mini-player-controls{gap:.25rem}}.mini-player-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:none;border-radius:50%;color:#fffc;cursor:pointer;transition:all .2s ease;min-width:36px;min-height:36px}@media(min-width:640px){.mini-player-btn{width:40px;height:40px;min-width:40px;min-height:40px}}.mini-player-btn:hover:not(:disabled){background:#ffffff1a;color:#fff}.mini-player-btn:focus-visible{outline:2px solid #EF4444;outline-offset:2px}.mini-player-btn:disabled{opacity:.3;cursor:not-allowed}.mini-player-play{width:40px;height:40px;min-width:40px;min-height:40px;background:linear-gradient(135deg,#dc2626,#ef4444);color:#fff}@media(min-width:640px){.mini-player-play{width:44px;height:44px;min-width:44px;min-height:44px}}.mini-player-play:hover:not(:disabled){background:linear-gradient(135deg,#ef4444,#f87171);transform:scale(1.05)}.mini-player-close{color:#ffffff80}.mini-player-close:hover{color:#ef4444}.mini-player-skip-btn{font-size:.625rem;font-weight:700;color:#fff9;width:28px;height:28px;min-width:28px;min-height:28px}@media(min-width:640px){.mini-player-skip-btn{font-size:.7rem;width:32px;height:32px;min-width:32px;min-height:32px}}.mini-player-skip-btn span{font-family:monospace}.mini-player-skip-btn:hover:not(:disabled){color:#ef4444}.mini-player-expanded{overflow:hidden;border-top:1px solid rgba(255,255,255,.1)}.mini-player-subtitles{display:flex;align-items:flex-start;gap:.5rem;padding:.5rem .75rem;background:#0000004d;border-bottom:1px solid rgba(255,255,255,.05);min-height:44px}@media(min-width:640px){.mini-player-subtitles{gap:.75rem;padding:.75rem 1rem;min-height:52px}}.mini-player-subtitles-toggle{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;min-width:32px;min-height:32px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#ffffff80;cursor:pointer;transition:all .2s ease}.mini-player-subtitles-toggle:hover{background:#ffffff1a;color:#fff}.mini-player-subtitles-toggle:focus-visible{outline:2px solid #EF4444;outline-offset:2px}.mini-player-subtitles-toggle.active{background:#dc262633;border-color:#dc26264d;color:#ef4444}.mini-player-subtitle-text{flex:1;margin:0;font-size:.8125rem;line-height:1.4;color:#fff;text-align:center}@media(min-width:640px){.mini-player-subtitle-text{font-size:.9rem;line-height:1.5}}.mini-player-subtitle-empty{color:#ffffff4d}.mini-player-subtitles-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;min-width:36px;min-height:36px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#ffffff80;cursor:pointer;transition:all .2s ease}.mini-player-subtitles-btn:hover{background:#dc262633;border-color:#dc26264d;color:#ef4444}.mini-player-subtitles-btn:focus-visible{outline:2px solid #EF4444;outline-offset:2px}.mini-player-advanced{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem .75rem;flex-wrap:wrap}@media(min-width:640px){.mini-player-advanced{gap:1rem;padding:.75rem 1rem}}.mini-player-speed,.mini-player-mute,.mini-player-playlist-btn{display:flex;align-items:center;justify-content:center;gap:.25rem;padding:.375rem .5rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#ffffffb3;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s ease;min-height:36px}@media(min-width:640px){.mini-player-speed,.mini-player-mute,.mini-player-playlist-btn{padding:.375rem .75rem;font-size:.8125rem}}.mini-player-speed:hover,.mini-player-mute:hover,.mini-player-playlist-btn:hover{background:#ffffff1a;border-color:#fff3;color:#fff}.mini-player-speed:focus-visible,.mini-player-mute:focus-visible,.mini-player-playlist-btn:focus-visible{outline:2px solid #EF4444;outline-offset:2px}.mini-player-playlist-btn.active{background:#dc262633;border-color:#dc26264d;color:#ef4444}.mini-player-playlist{overflow:hidden;border-top:1px solid rgba(255,255,255,.1)}.mini-player-playlist-header{padding:.5rem .75rem;font-size:.6875rem;font-weight:600;color:#ffffff80;text-transform:uppercase;letter-spacing:.05em}@media(min-width:640px){.mini-player-playlist-header{padding:.5rem 1rem;font-size:.75rem}}.mini-player-playlist-items{max-height:200px;overflow-y:auto}.mini-player-playlist-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.625rem .75rem;background:transparent;border:none;border-top:1px solid rgba(255,255,255,.05);color:#ffffffb3;text-align:left;cursor:pointer;transition:background .2s ease}@media(min-width:640px){.mini-player-playlist-item{gap:.75rem;padding:.75rem 1rem}}.mini-player-playlist-item:hover{background:#ffffff0d}.mini-player-playlist-item:focus-visible{outline:2px solid #EF4444;outline-offset:-2px}.mini-player-playlist-item.active{background:#dc26261a;color:#fff}.playlist-item-number{width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border-radius:4px;font-size:.6875rem;font-weight:600;flex-shrink:0}@media(min-width:640px){.playlist-item-number{width:24px;height:24px;font-size:.75rem}}.mini-player-playlist-item.active .playlist-item-number{background:#dc2626;color:#fff}.playlist-item-title{flex:1;font-size:.8125rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(min-width:640px){.playlist-item-title{font-size:.875rem}}.playlist-item-duration{font-size:.6875rem;color:#ffffff80;font-family:monospace}@media(min-width:640px){.playlist-item-duration{font-size:.75rem}}.mini-player-video-btn{display:flex;align-items:center;justify-content:center;gap:.25rem;padding:.375rem .5rem;background:#dc262633;border:1px solid rgba(220,38,38,.3);border-radius:6px;color:#ef4444;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s ease;min-height:36px}@media(min-width:640px){.mini-player-video-btn{padding:.375rem .75rem;font-size:.8125rem}}.mini-player-video-btn:hover{background:#dc26264d;border-color:#dc262680}.mini-player-video-btn:focus-visible{outline:2px solid #EF4444;outline-offset:2px}.mini-player-browser-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;min-width:36px;min-height:36px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#ffffffb3;cursor:pointer;transition:all .2s ease}.mini-player-browser-btn:hover{background:#ffffff1a;border-color:#fff3;color:#fff}.mini-player-browser-btn:focus-visible{outline:2px solid #EF4444;outline-offset:2px}.mini-player-minimize{color:#ffffff80}.mini-player-minimize:hover{color:#3b82f6;background:#3b82f61a}.mini-player-floating{display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#1a1a2e,#252545);border:2px solid rgba(220,38,38,.5);box-shadow:0 4px 20px #0006,0 0 #dc262666;cursor:grab;position:relative;overflow:visible;transition:box-shadow .3s ease,border-color .3s ease}.mini-player-floating:active{cursor:grabbing}.mini-player-floating:hover{border-color:#dc2626cc;box-shadow:0 6px 25px #00000080,0 0 0 4px #dc262633}.mini-player-floating-progress{position:absolute;top:-2px;left:-2px;width:calc(100% + 4px);height:calc(100% + 4px);pointer-events:none}.mini-player-floating-progress-bg{stroke:#ffffff1a}.mini-player-floating-progress-fill{stroke:#dc2626;stroke-linecap:round;transition:stroke-dashoffset .3s ease}.mini-player-floating-content{position:relative;width:44px;height:44px;border-radius:50%;overflow:hidden}.mini-player-floating-cover{width:100%;height:100%;object-fit:cover;pointer-events:none}.mini-player-floating-icon{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#dc262633;color:#ef4444}.mini-player-floating-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0006;color:#fff;opacity:0;transition:opacity .2s ease}.mini-player-floating:hover .mini-player-floating-overlay,.mini-player-floating-overlay:not(.playing){opacity:1}.mini-player-floating-overlay.playing{opacity:0}.mini-player-floating:hover .mini-player-floating-overlay.playing{opacity:1}@keyframes floating-pulse{0%,to{box-shadow:0 4px 20px #0006,0 0 #dc262666}50%{box-shadow:0 4px 20px #0006,0 0 0 6px #dc262600}}.mini-player-floating:has(.mini-player-floating-overlay.playing){animation:floating-pulse 2s ease-in-out infinite}.mini-player-floating-close{position:absolute;top:-6px;right:-6px;width:20px;height:20px;border-radius:50%;background:#1a1a2e;border:1px solid rgba(255,255,255,.2);color:#fff9;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transform:scale(.8);transition:all .2s ease}.mini-player-floating:hover .mini-player-floating-close{opacity:1;transform:scale(1)}.mini-player-floating-close:hover{background:#ef4444;border-color:#ef4444;color:#fff}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.mini-player-floating .animate-spin{animation:spin 1s linear infinite}.snackbar-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:12px;pointer-events:none}.snackbar{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#ffffff14;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.12);border-radius:12px;box-shadow:0 8px 32px #0000004d;color:#fff;font-size:14px;pointer-events:auto;max-width:320px;min-width:240px}.snackbar-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;flex-shrink:0}.snackbar-success .snackbar-icon{background:#10b98133;color:#10b981}.snackbar-error .snackbar-icon{background:#ef444433;color:#ef4444}.snackbar-info .snackbar-icon{background:#3b82f633;color:#3b82f6}.snackbar-message{flex:1;font-size:14px;line-height:1.4}.snackbar-close{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:transparent;border:none;color:#fff9;cursor:pointer;border-radius:4px;transition:all .2s;flex-shrink:0}.snackbar-close:hover{background:#ffffff1a;color:#ffffffe6}@media(max-width:640px){.snackbar-container{bottom:16px;right:16px;left:16px}.snackbar{max-width:100%;min-width:auto}}.battery-optimization-overlay{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:1rem;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.battery-optimization-modal{position:relative;width:100%;max-width:420px;max-height:90vh;overflow-y:auto;background:linear-gradient(180deg,#1a2744,#0f172a);border-radius:1.25rem;border:1px solid rgba(255,255,255,.1);box-shadow:0 25px 50px -12px #00000080}.battery-optimization-header{padding:1.5rem 1.5rem 1rem;text-align:center}.battery-optimization-close{position:absolute;top:1rem;right:1rem;display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border:none;border-radius:50%;background:#ffffff1a;color:#fff9;cursor:pointer;transition:all .2s}.battery-optimization-close:hover{background:#ffffff26;color:#fff}.battery-optimization-icon{display:inline-flex;align-items:center;justify-content:center;width:5rem;height:5rem;margin-bottom:1rem;border-radius:50%;background:linear-gradient(135deg,#22c55e33,#22c55e1a);color:#22c55e}.battery-optimization-icon-medium{background:linear-gradient(135deg,#eab30833,#eab3081a);color:#eab308}.battery-optimization-icon-high{background:linear-gradient(135deg,#ef444433,#ef44441a);color:#ef4444}.battery-optimization-title{margin:0 0 .5rem;font-size:1.25rem;font-weight:700;color:#fff}.battery-optimization-brand{display:flex;align-items:center;justify-content:center;gap:.75rem;margin:0;font-size:.9rem;color:#ffffffb3}.battery-optimization-score{padding:.2rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:600}.battery-optimization-score-low{background:#22c55e33;color:#22c55e}.battery-optimization-score-medium{background:#eab30833;color:#eab308}.battery-optimization-score-high{background:#ef444433;color:#ef4444}.battery-optimization-content{padding:0 1.5rem}.battery-optimization-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;color:#fff9}.battery-optimization-spinner{width:2rem;height:2rem;border:3px solid rgba(255,255,255,.1);border-top-color:#3b82f6;border-radius:50%;animation:battery-spin 1s linear infinite}@keyframes battery-spin{to{transform:rotate(360deg)}}.battery-optimization-warning{display:flex;gap:.75rem;padding:1rem;margin-bottom:1rem;border-radius:.75rem;background:#eab3081a;border:1px solid rgba(234,179,8,.2)}.battery-optimization-warning svg{flex-shrink:0;color:#eab308}.battery-optimization-warning p{margin:0;font-size:.875rem;line-height:1.5;color:#ffffffe6}.battery-optimization-warning-high{background:#ef44441a;border-color:#ef444433}.battery-optimization-warning-high svg{color:#ef4444}.battery-optimization-warning-low{background:#22c55e1a;border-color:#22c55e33}.battery-optimization-warning-low svg{color:#22c55e}.battery-optimization-steps{margin-bottom:1rem}.battery-optimization-steps h3{margin:0 0 .75rem;font-size:.9rem;font-weight:600;color:#ffffffe6}.battery-optimization-steps ol{margin:0;padding-left:1.25rem}.battery-optimization-steps li{margin-bottom:.5rem;font-size:.875rem;line-height:1.5;color:#ffffffb3}.battery-optimization-steps li strong{color:#ffffffe6}.battery-optimization-details{margin-bottom:1rem;border-radius:.75rem;background:#ffffff0d;overflow:hidden}.battery-optimization-details-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.875rem 1rem;border:none;background:transparent;color:#fffc;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s}.battery-optimization-details-toggle:hover{background:#ffffff0d}.battery-optimization-details-content{padding:0 1rem 1rem;font-size:.8125rem;line-height:1.6;color:#ffffffb3;overflow:hidden}.battery-optimization-details-content h3,.battery-optimization-details-content h4{margin:1rem 0 .5rem;color:#ffffffe6;font-size:.875rem}.battery-optimization-details-content p{margin:.5rem 0}.battery-optimization-details-content ul,.battery-optimization-details-content ol{margin:.5rem 0;padding-left:1.25rem}.battery-optimization-details-content a{color:#3b82f6;text-decoration:none}.battery-optimization-details-content a:hover{text-decoration:underline}.battery-optimization-actions{display:flex;gap:.75rem;padding:1rem 1.5rem 1.25rem}.battery-optimization-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1rem;border:none;border-radius:.75rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.battery-optimization-btn-secondary{background:#ffffff1a;color:#fffc}.battery-optimization-btn-secondary:hover{background:#ffffff26;color:#fff}.battery-optimization-btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.battery-optimization-btn-primary:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-1px)}.battery-optimization-attribution{padding:0 1.5rem 1rem;margin:0;font-size:.75rem;text-align:center;color:#fff6}.battery-optimization-attribution a{color:#ffffff80;text-decoration:none}.battery-optimization-attribution a:hover{color:#ffffffb3;text-decoration:underline}@media(max-width:480px){.battery-optimization-modal{max-height:85vh}.battery-optimization-header{padding:1.25rem 1.25rem .75rem}.battery-optimization-content{padding:0 1.25rem}.battery-optimization-actions{flex-direction:column;padding:1rem 1.25rem}.battery-optimization-btn{width:100%}}.notification-permission-modal-overlay{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;padding:1rem;background:#000000bf;backdrop-filter:blur(8px)}.notification-permission-modal{position:relative;background:linear-gradient(135deg,#1a1a2efa,#1e1e3cfa);border:1px solid rgba(220,38,38,.3);border-radius:1.5rem;box-shadow:0 20px 60px #00000080,0 0 40px #dc262633;padding:2.5rem 2rem;max-width:500px;width:100%;max-height:90vh;overflow-y:auto}.notification-permission-modal-close{position:absolute;top:1rem;right:1rem;background:#ffffff1a;border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:#ffffffb3;cursor:pointer;transition:all .2s ease;z-index:1}.notification-permission-modal-close:hover:not(:disabled){background:#fff3;color:#fff;transform:rotate(90deg)}.notification-permission-modal-close:disabled{opacity:.5;cursor:not-allowed}.notification-permission-modal-icon{display:flex;align-items:center;justify-content:center;width:96px;height:96px;background:linear-gradient(135deg,#dc2626,#b91c1c);border-radius:50%;margin:0 auto 1.5rem;color:#fff;box-shadow:0 8px 24px #dc262666}.notification-permission-modal-title{font-size:1.75rem;font-weight:800;color:#fff;text-align:center;margin:0 0 .75rem;line-height:1.2}.notification-permission-modal-description{font-size:1rem;line-height:1.6;color:#fffc;text-align:center;margin:0 0 2rem}.notification-permission-modal-benefits{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.notification-permission-modal-benefit{display:flex;align-items:flex-start;gap:1rem;padding:1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:.75rem;transition:all .2s ease}.notification-permission-modal-benefit:hover{background:#ffffff14;border-color:#dc26264d;transform:translate(4px)}.notification-permission-modal-benefit-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:linear-gradient(135deg,#dc2626,#b91c1c);border-radius:.5rem;color:#fff;flex-shrink:0}.notification-permission-modal-benefit-text{display:flex;flex-direction:column;gap:.25rem;flex:1}.notification-permission-modal-benefit-text strong{font-size:1rem;font-weight:700;color:#fff}.notification-permission-modal-benefit-text span{font-size:.875rem;color:#ffffffb3;line-height:1.4}.notification-permission-modal-privacy{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;background:#3b82f61a;border:1px solid rgba(59,130,246,.3);border-radius:.5rem;font-size:.875rem;color:#60a5fa;margin-bottom:1rem;line-height:1.5}.notification-permission-modal-cookies{padding:.75rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:.5rem;font-size:.8rem;color:#fff9;margin-bottom:2rem;line-height:1.5;text-align:center}.notification-permission-modal-cookies a{color:#60a5fa;text-decoration:none;margin-left:.5rem;font-weight:500;transition:color .2s ease}.notification-permission-modal-cookies a:hover{color:#93c5fd;text-decoration:underline}.notification-permission-modal-actions{display:flex;gap:1rem}.notification-permission-modal-btn{flex:1;padding:1rem 1.5rem;border:none;border-radius:.75rem;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s ease;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:.5rem}.notification-permission-modal-btn:disabled{opacity:.6;cursor:not-allowed}.notification-permission-modal-btn-secondary{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2)}.notification-permission-modal-btn-secondary:hover:not(:disabled){background:#ffffff26;transform:translateY(-2px)}.notification-permission-modal-btn-primary{background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff;box-shadow:0 4px 16px #dc26264d}.notification-permission-modal-btn-primary:hover:not(:disabled){box-shadow:0 6px 20px #dc262666;transform:translateY(-2px)}.notification-permission-modal-btn-primary:active:not(:disabled){transform:translateY(0)}.notification-permission-modal-loading{display:flex;align-items:center;gap:.5rem}.notification-permission-modal-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@media(max-width:640px){.notification-permission-modal{padding:2rem 1.5rem}.notification-permission-modal-icon{width:80px;height:80px}.notification-permission-modal-icon svg{width:40px;height:40px}.notification-permission-modal-title{font-size:1.5rem}.notification-permission-modal-description{font-size:.95rem}.notification-permission-modal-benefit{padding:.875rem}.notification-permission-modal-benefit-icon{width:36px;height:36px}.notification-permission-modal-benefit-text strong{font-size:.95rem}.notification-permission-modal-benefit-text span{font-size:.825rem}.notification-permission-modal-actions{flex-direction:column}.notification-permission-modal-btn{width:100%}}.notification-permission-modal::-webkit-scrollbar{width:8px}.notification-permission-modal::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}.notification-permission-modal::-webkit-scrollbar-thumb{background:#dc262680;border-radius:4px}.notification-permission-modal::-webkit-scrollbar-thumb:hover{background:#dc2626b3}.trial-reminder-banner{position:fixed;top:0;left:0;right:0;z-index:9999;background:linear-gradient(135deg,#f87171,#ef4444);color:#fff;padding:12px 16px;box-shadow:0 2px 12px #00000026}.trial-reminder-banner.urgent{background:linear-gradient(135deg,#ef4444,#dc2626);animation:pulse-urgent 2s ease-in-out infinite}@keyframes pulse-urgent{0%,to{opacity:1}50%{opacity:.95}}.trial-reminder-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:12px}.trial-reminder-icon{flex-shrink:0;width:36px;height:36px;background:#fff3;border-radius:50%;display:flex;align-items:center;justify-content:center}.trial-reminder-text{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.trial-reminder-text strong{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trial-reminder-text span{font-size:13px;opacity:.95;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trial-reminder-button{flex-shrink:0;background:#fff;color:#ef4444;border:none;padding:8px 20px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.trial-reminder-banner.urgent .trial-reminder-button{color:#dc2626}.trial-reminder-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.trial-reminder-button:active{transform:translateY(0)}.trial-reminder-close{flex-shrink:0;background:transparent;border:none;color:#fff;cursor:pointer;padding:4px;border-radius:4px;opacity:.8;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.trial-reminder-close:hover{opacity:1;background:#ffffff1a}@media(max-width:768px){.trial-reminder-banner{padding:10px 12px}.trial-reminder-content{gap:8px}.trial-reminder-icon{width:32px;height:32px}.trial-reminder-text strong{font-size:13px}.trial-reminder-text span{display:none}.trial-reminder-button{padding:6px 16px;font-size:13px}}@media(max-width:480px){.trial-reminder-icon{display:none}.trial-reminder-text strong{font-size:12px}.trial-reminder-button{padding:6px 12px;font-size:12px}}.input-container{display:flex;flex-direction:column;gap:8px;width:100%}.input-label{color:#ffffffe6;font-size:14px;font-weight:600;margin-left:4px}.input-wrapper{position:relative;width:100%}.input{background-color:#fffffff2;color:var(--gray-900);border:1.5px solid rgba(255,255,255,.4);border-radius:12px;padding:0 24px;height:56px;font-size:16px;width:100%;transition:all .2s ease}.input-with-toggle{padding-right:56px}.input-error{border-color:var(--red-error)}.input-error:focus{border-color:var(--red-error);box-shadow:0 0 0 3px #ef44441a}.input-error-text{color:var(--red-error);font-size:13px;margin-left:4px;margin-top:-4px}.input-helper-text{color:#fff9;font-size:13px;margin-left:4px;margin-top:-4px}.input-password-toggle{position:absolute;right:16px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;color:var(--gray-500);transition:color .2s ease;border-radius:6px}.input-password-toggle:hover{color:var(--gray-700);background-color:#0000000d}.input-password-toggle:focus{outline:none;color:var(--red-primary)}.input-password-toggle svg{width:20px;height:20px}.card{position:relative;z-index:1;border-radius:16px;border:1px solid rgba(255,255,255,.15);padding:24px;transition:all .3s ease;backdrop-filter:blur(10px);box-shadow:0 4px 16px #0003;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-webkit-tap-highlight-color:transparent;tap-highlight-color:transparent}.card:active,.card:focus{outline:none}.card:focus-visible{outline:2px solid rgba(255,255,255,.3);outline-offset:2px}.card-default{background-color:#ffffff14}.card-important{background-color:#dc262633;border-color:#dc262666;box-shadow:0 4px 16px #0003,0 0 20px #dc262626}.card-success{background-color:#10b98133;border-color:#10b98166;box-shadow:0 4px 16px #0003,0 0 20px #10b98126}.card-warning{background-color:#f59e0b33;border-color:#f59e0b66;box-shadow:0 4px 16px #0003,0 0 20px #f59e0b26}.auth-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;gap:32px}.auth-header{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center}.auth-logo{width:140px;height:140px;object-fit:contain;animation:float 3s ease-in-out infinite;filter:drop-shadow(0 4px 20px rgba(220,38,38,.3))}.auth-title{font-size:32px;font-weight:700;color:var(--white-pure);margin:0}.auth-subtitle{font-size:16px;color:#ffffffb3;margin:0}.auth-card{width:100%;max-width:450px;display:flex;flex-direction:column;gap:24px}.auth-card-title{font-size:24px;font-weight:700;color:var(--white-pure);text-align:center;margin:0}.auth-card-subtitle{font-size:14px;color:#ffffffb3;text-align:center;margin:-12px 0 0}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-button{width:100%}.auth-divider{display:flex;align-items:center;text-align:center;color:#ffffff80;font-size:14px;margin:8px 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;border-bottom:1px solid rgba(255,255,255,.1)}.auth-divider span{padding:0 16px}.auth-google-button{width:100%}.auth-footer{display:flex;flex-direction:column;gap:12px;align-items:center}.auth-link{background:none;border:none;color:#fffc;font-size:14px;cursor:pointer;padding:4px;transition:color .2s ease;text-decoration:none}.auth-link:hover:not(:disabled){color:var(--red-primary)}.auth-link:disabled{opacity:.5;cursor:not-allowed}@media(max-width:640px){.auth-container{padding:16px;gap:24px}.auth-logo{width:110px;height:110px}.auth-title{font-size:28px}.auth-card{padding:20px}}.app-footer{width:100%;padding:24px 16px;background:transparent;border-top:1px solid rgba(255,255,255,.1);margin-top:auto}.app-footer-content{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:12px}.app-footer-links{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:center}.app-footer-link{color:#ffffffb3;text-decoration:none;font-size:13px;transition:color .2s ease}.app-footer-link:hover{color:#ffffffe6;text-decoration:underline}.app-footer-separator{color:#ffffff4d;font-size:12px;user-select:none}.app-footer-copyright{color:#ffffff80;font-size:12px;margin:0;text-align:center}.app-footer--minimal{padding:16px;margin-top:20px}.app-footer--minimal .app-footer-links{gap:8px}.app-footer--minimal .app-footer-link{font-size:12px}@media(max-width:768px){.app-footer{padding:20px 12px}.app-footer-links{gap:8px}.app-footer-link{font-size:12px}.app-footer-separator{font-size:10px}.app-footer-copyright{font-size:11px}}@media(max-width:480px){.app-footer-links,.app-footer-link{font-size:11px}}.password-strength{display:flex;flex-direction:column;gap:8px;margin-top:-8px;margin-bottom:8px}.password-strength-bars{display:flex;gap:6px;width:100%}.password-strength-bar{flex:1;height:4px;border-radius:2px;background:#ffffff1a;transition:all .3s ease}.password-strength-bar.active{animation:strengthBarGrow .3s ease}@keyframes strengthBarGrow{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.password-strength-label{font-size:12px;font-weight:500;margin:0;transition:color .3s ease;text-align:right}.email-confirmation{display:flex;flex-direction:column;align-items:center;gap:20px;padding:16px 0}.email-confirmation-icon{color:var(--green-success);animation:checkmark .5s ease-in-out}@keyframes checkmark{0%{transform:scale(0);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.email-confirmation-title{font-size:20px;font-weight:600;color:var(--white-pure);margin:0}.email-confirmation-text{font-size:15px;color:#fffc;text-align:center;margin:0;line-height:1.5}.email-confirmation-text strong{color:var(--red-primary);font-weight:600}.email-confirmation-subtitle{font-size:14px;color:#fff9;text-align:center;margin:0}.email-confirmation-actions{display:flex;flex-direction:column;gap:12px;align-items:center;width:100%;margin-top:8px}.email-confirmation-resend{width:100%}.reset-password-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;gap:32px}.reset-password-header{text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px}.reset-password-logo{width:120px;height:120px;object-fit:contain;animation:float 3s ease-in-out infinite;filter:drop-shadow(0 4px 20px rgba(220,38,38,.3))}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.reset-password-title{font-size:32px;font-weight:700;color:var(--white-pure);margin:0;letter-spacing:-.02em}.reset-password-subtitle{font-size:16px;color:var(--white-secondary);margin:0}.reset-password-card{width:100%;max-width:420px;padding:32px}.reset-password-card-title{font-size:24px;font-weight:600;color:var(--white-pure);margin:0 0 8px;text-align:center}.reset-password-card-description{font-size:14px;color:var(--white-secondary);margin:0 0 24px;text-align:center;line-height:1.5}.reset-password-message{padding:12px 16px;border-radius:8px;font-size:14px;margin-bottom:16px;line-height:1.5}.reset-password-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#fca5a5}.reset-password-form{display:flex;flex-direction:column;gap:16px}.reset-password-button{margin-top:8px}.reset-password-footer{margin-top:24px;text-align:center}.reset-password-link{background:none;border:none;color:var(--red-primary);font-size:14px;font-weight:500;cursor:pointer;padding:8px;transition:all .2s ease}.reset-password-link:hover:not(:disabled){color:var(--red-hover);text-decoration:underline}.reset-password-link:disabled{opacity:.5;cursor:not-allowed}.reset-password-success{display:flex;flex-direction:column;align-items:center;gap:16px;padding:24px 0;text-align:center}.reset-password-success-icon{color:var(--green-primary);animation:successPop .5s ease-out}@keyframes successPop{0%{transform:scale(0);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.reset-password-success-title{font-size:24px;font-weight:600;color:var(--white-pure);margin:0}.reset-password-success-text{font-size:14px;color:var(--white-secondary);margin:0;line-height:1.6}@media(max-width:480px){.reset-password-container{padding:16px;gap:24px}.reset-password-card{padding:24px}.reset-password-logo{width:100px;height:100px}.reset-password-title{font-size:28px}}.modal-overlay{position:fixed;inset:0;background-color:#000c;display:flex;align-items:center;justify-content:center;padding:16px;z-index:10000;animation:fadeIn .2s ease;backdrop-filter:blur(4px);overflow-y:auto}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-container{background:linear-gradient(180deg,#1a1a2e,#252545);border-radius:24px;border:1px solid rgba(255,255,255,.2);max-width:600px;width:100%;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:24px;border-bottom:1px solid rgba(255,255,255,.1);background:var(--red-primary);border-radius:24px 24px 0 0}.modal-title{font-size:20px;font-weight:700;color:var(--white-pure);margin:0}.modal-close{background:none;border:none;color:#fff9;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s ease}.modal-close:hover{background-color:#ffffff1a;color:var(--white-pure)}.modal-body{padding:24px;overflow-y:auto}@media(max-width:640px){.modal-overlay{padding:12px}.modal-container{max-height:95vh;max-width:100%}.modal-header,.modal-body{padding:20px}}@media(max-width:400px){.modal-overlay{padding:8px}.modal-header,.modal-body{padding:16px}.modal-title{font-size:18px}}.department-selector{display:flex;flex-direction:column;gap:8px;width:100%}.department-label{color:#ffffffe6;font-size:14px;font-weight:600;margin-left:4px}.department-button{background-color:#fffffff2;color:var(--gray-900);border:1.5px solid rgba(255,255,255,.4);border-radius:12px;padding:0 24px;height:56px;font-size:16px;width:100%;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all .2s ease}.department-button:hover{border-color:var(--red-primary)}.department-button-error{border-color:var(--red-error)}.department-selected{color:var(--gray-900)}.department-placeholder{color:var(--gray-400)}.department-error{color:var(--red-error);font-size:13px;margin-left:4px;margin-top:-4px}.department-modal-content{display:flex;flex-direction:column;gap:16px}.department-list{max-height:400px;overflow-y:auto;display:flex;flex-direction:column;gap:4px}.department-item{background-color:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:12px 16px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:all .2s ease;color:var(--white-pure);font-size:15px;text-align:left}.department-item:hover{background-color:#ffffff1a;border-color:#fff3}.department-item-selected{background-color:#dc262626;border-color:#dc26264d}.department-item-code{font-weight:700;min-width:40px}.department-item-name{flex:1}.department-item-check{color:var(--red-primary);flex-shrink:0}.department-empty{padding:32px;text-align:center;color:#ffffff80}.avatar-selector{display:flex;flex-direction:column;gap:12px;align-items:center}.avatar-label{color:#ffffffe6;font-size:14px;font-weight:600;align-self:flex-start;margin-left:4px}.avatar-preview-container{display:flex;flex-direction:column;align-items:center;gap:8px}.avatar-preview{position:relative;width:120px;height:120px;border-radius:50%;overflow:visible;border:3px solid rgba(255,255,255,.1)}.avatar-image{width:100%;height:100%;object-fit:cover;border-radius:50%}.avatar-edit-button{position:absolute;bottom:-8px;right:-8px;width:40px;height:40px;border-radius:50%;background-color:var(--red-primary);border:3px solid var(--blue-marine-dark);color:var(--white-pure);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0000004d}.avatar-edit-button:hover{transform:scale(1.1);box-shadow:0 4px 12px #dc26264d}.avatar-hint{color:#fff9;font-size:13px;margin:0}.avatar-modal-content{display:flex;flex-direction:column;gap:20px;padding:0 4px}.avatar-tabs{display:flex;gap:8px;padding:4px;background-color:#ffffff0d;border-radius:10px}.avatar-tab{flex:1;padding:10px 16px;background:none;border:none;color:#fff9;font-size:14px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease}.avatar-tab:hover{color:#ffffffe6}.avatar-tab-active{background-color:var(--red-primary);color:var(--white-pure)}.avatar-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;max-height:50vh;overflow-y:auto;padding:4px}.avatar-grid-item{position:relative;aspect-ratio:1;border-radius:12px;overflow:hidden;border:2px solid rgba(255,255,255,.1);background:none;padding:0;cursor:pointer;transition:all .2s ease}.avatar-grid-item:hover{border-color:var(--red-primary);transform:scale(1.05)}.avatar-grid-item img{width:100%;height:100%;object-fit:cover}.avatar-grid-item-selected{border-color:var(--red-primary);border-width:3px}.avatar-grid-item-check{position:absolute;top:8px;right:8px;display:flex;align-items:center;justify-content:center}.avatar-upload{display:flex;flex-direction:column;gap:16px}.avatar-upload-area{border:2px dashed rgba(255,255,255,.2);border-radius:12px;padding:40px 24px;display:flex;flex-direction:column;align-items:center;gap:12px;color:#fff9;transition:all .2s ease}.avatar-upload-area:hover{border-color:#fff6;background-color:#ffffff05}.avatar-upload-text{font-size:16px;font-weight:600;color:#ffffffe6;margin:0}.avatar-upload-hint{font-size:13px;color:#ffffff80;margin:0}.avatar-camera{display:flex;flex-direction:column;gap:20px}.avatar-camera-preview{width:100%;max-width:480px;aspect-ratio:4/3;border-radius:12px;overflow:hidden;background-color:#00000080;display:flex;align-items:center;justify-content:center;margin:0 auto}.avatar-camera-video,.avatar-camera-captured{width:100%;height:100%;object-fit:cover}.avatar-camera-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.avatar-camera-capture{display:flex;align-items:center;gap:8px}@media(max-width:640px){.avatar-grid{grid-template-columns:repeat(2,1fr);gap:10px;max-height:55vh}.avatar-tabs{flex-direction:column}.avatar-tab{width:100%}.avatar-camera-preview{max-width:100%}.avatar-modal-content{padding:0 2px}}@media(max-width:380px){.avatar-grid{grid-template-columns:repeat(2,1fr);gap:8px}.avatar-grid-item{min-height:100px}}.onboarding-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;gap:32px}.onboarding-header{text-align:center;max-width:500px}.onboarding-title{font-size:32px;font-weight:700;color:var(--white-pure);margin:0 0 12px}.onboarding-subtitle{font-size:16px;color:#ffffffb3;margin:0}.onboarding-card{width:100%;max-width:500px}.onboarding-form{display:flex;flex-direction:column;gap:24px}.onboarding-validating{font-size:13px;color:var(--blue-info);margin-top:-16px;margin-left:4px}.onboarding-actions{margin-top:8px}.onboarding-submit{width:100%}.onboarding-footer{text-align:center}.onboarding-footer-text{font-size:13px;color:#ffffff80;margin:0}.onboarding-steps{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:8px}.onboarding-step{display:flex;flex-direction:column;align-items:center;gap:8px;transition:all .3s ease}.onboarding-step-number{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:#ffffff1a;border:2px solid rgba(255,255,255,.2);color:#ffffff80;font-size:18px;font-weight:700;transition:all .3s ease}.onboarding-step.active .onboarding-step-number{background:linear-gradient(135deg,#dc2626,#b91c1c);border-color:#dc2626;color:var(--white-pure);box-shadow:0 4px 16px #dc26264d}.onboarding-step-label{font-size:14px;font-weight:600;color:#ffffff80;transition:color .3s ease}.onboarding-step.active .onboarding-step-label{color:var(--white-pure)}.onboarding-step-divider{width:64px;height:2px;background:#fff3;margin-bottom:24px}.onboarding-terms-form{display:flex;flex-direction:column;gap:24px}.onboarding-terms-header{text-align:center}.onboarding-terms-header h2{font-size:24px;font-weight:700;color:var(--white-pure);margin:0 0 8px}.onboarding-terms-header p{font-size:15px;color:#ffffffb3;margin:0}.onboarding-terms-checkboxes{display:flex;flex-direction:column;gap:16px}.onboarding-checkbox-label{display:flex;align-items:flex-start;gap:12px;padding:16px;background:#ffffff0d;border:2px solid rgba(255,255,255,.1);border-radius:12px;cursor:pointer;transition:all .2s ease}.onboarding-checkbox-label:hover{background:#ffffff14;border-color:#dc26264d}.onboarding-checkbox{appearance:none;width:24px;height:24px;border:2px solid rgba(255,255,255,.3);border-radius:6px;background:#ffffff0d;cursor:pointer;transition:all .2s ease;flex-shrink:0;margin-top:2px;position:relative}.onboarding-checkbox:hover{border-color:#dc262680}.onboarding-checkbox:checked{background:linear-gradient(135deg,#dc2626,#b91c1c);border-color:#dc2626}.onboarding-checkbox:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--white-pure);font-size:16px;font-weight:700}.onboarding-checkbox-text{font-size:15px;line-height:1.6;color:#ffffffe6;flex:1}.onboarding-legal-link{color:#60a5fa;text-decoration:none;font-weight:600;transition:color .2s ease}.onboarding-legal-link:hover{color:#93c5fd;text-decoration:underline}.onboarding-terms-note{padding:12px 16px;background:#3b82f61a;border:1px solid rgba(59,130,246,.3);border-radius:8px}.onboarding-terms-note p{font-size:14px;line-height:1.5;color:#93c5fd;margin:0}.onboarding-actions{display:flex;gap:12px;margin-top:8px}.onboarding-back{flex:1}.onboarding-submit{flex:2}@media(max-width:640px){.onboarding-container{padding:16px;gap:24px}.onboarding-title{font-size:28px}.onboarding-card{padding:20px}.onboarding-steps{gap:12px}.onboarding-step-number{width:40px;height:40px;font-size:16px}.onboarding-step-label{font-size:12px}.onboarding-step-divider{width:48px;margin-bottom:20px}.onboarding-terms-header h2{font-size:20px}.onboarding-terms-header p{font-size:14px}.onboarding-checkbox-label{padding:14px}.onboarding-checkbox-text{font-size:14px}.onboarding-actions{flex-direction:column}.onboarding-back,.onboarding-submit{flex:1;width:100%}}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}*{scrollbar-width:thin;scrollbar-color:#DC2626 rgba(255,255,255,.1)}*::-webkit-scrollbar{width:8px;height:8px}*::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}*::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#dc2626,#ef4444);border-radius:4px;transition:background .3s ease}*::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#ef4444,#f87171)}html{scroll-behavior:smooth;scroll-padding-top:80px}body{overscroll-behavior-y:contain}button,a,input,textarea,select,[role=button],.clickable{outline:none;user-select:none}button:focus,a:focus,input:focus,textarea:focus,select:focus{outline:none}input,textarea{user-select:text}:root{--red-primary: #DC2626;--blue-marine-dark: #1a1a2e;--blue-marine-secondary: #1a1a2e;--white-pure: #FFFFFF;--green-success: #10B981;--orange-warning: #F59E0B;--red-error: #EF4444;--blue-info: #3B82F6;--gray-400: #9CA3AF;--gray-500: #6B7280;--gray-900: #111827;--gradient-from: #1a1a2e;--gradient-to: #252545;--accent-red: #DC2626;--primary: #DC2626;--success: #10B981;--card-bg: rgba(26, 26, 46, .4);--card-bg-hover: rgba(26, 26, 46, .6);--border-color: rgba(255, 255, 255, .2);--text-primary: rgba(255, 255, 255, .95);--text-secondary: rgba(255, 255, 255, .75);--text-tertiary: rgba(255, 255, 255, .55);--hover-bg: rgba(26, 26, 46, .5);--text: rgba(255, 255, 255, .95);--text-muted: rgba(255, 255, 255, .6)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,var(--gradient-from) 0%,var(--gradient-to) 100%);background-attachment:fixed;min-height:100vh;color:var(--white-pure);text-rendering:optimizeLegibility;font-feature-settings:"kern" 1;letter-spacing:-.011em}#root,.app{min-height:100vh}.text-primary{color:var(--white-pure);opacity:.9}.text-secondary{color:#fff9}.text-tertiary{color:#fff6}.card{background-color:#ffffff14;border-radius:16px;border:1px solid rgba(255,255,255,.15);padding:16px;backdrop-filter:blur(10px);box-shadow:0 4px 16px #0003}.btn-primary{background-color:var(--red-primary);color:var(--white-pure);border:none;border-radius:12px;padding:14px 24px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #dc262666,0 0 20px #dc262633}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #dc262680,0 0 30px #dc26264d;background-color:#ef4444}.btn-primary:active{transform:translateY(0)}.btn-secondary{background-color:transparent;color:var(--white-pure);border:2px solid var(--white-pure);border-radius:12px;padding:14px 24px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.btn-secondary:hover{background-color:#ffffff1a}.input{background-color:#fffffff2;color:var(--gray-900);border:1.5px solid rgba(255,255,255,.4);border-radius:12px;padding:0 24px;height:56px;font-size:16px;width:100%;transition:all .2s}.input::placeholder{color:var(--gray-400)}.input:focus{outline:none;border-color:var(--red-primary);border-width:2px;background-color:var(--white-pure);box-shadow:0 0 0 3px #dc26261a}.card-action-button{background:transparent!important;border:none!important;color:var(--white-pure)!important;font-size:12px!important;font-weight:600!important;font-family:Inter,sans-serif!important;cursor:pointer;padding:6px 12px!important;border-radius:8px!important;transition:all .2s ease!important;white-space:nowrap;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-webkit-tap-highlight-color:transparent;tap-highlight-color:transparent}.card-action-button:hover{color:var(--white-pure)!important;background:transparent!important;transform:translate(2px)}.card-action-button:active,.card-action-button:focus{background:transparent!important;outline:none!important}.card-action-button:focus-visible{outline:2px solid rgba(255,255,255,.3)!important;outline-offset:2px}@keyframes spin{to{transform:rotate(360deg)}}@media(min-width:640px)and (max-width:1023px){.admin-container,.admin-blocked-users-container,.admin-feedbacks-container,.admin-questions-container,.admin-reports-container,.admin-security-container,.contest-correction-container,.contest-lobby-container,.contest-ranking-container,.contest-results-container,.contest-session-container,.friends-container,.games-container,.invoices-container,.join-game-container,.journal-container,.journal-detail-container,.legal-page-container,.memento-progress-container,.my-contributions-container,.onboarding-container,.profile-container,.ranking-container,.reset-password-container,.review-selection-container,.sprint-pompier-config-container,.sprint-pompier-game-container,.sprint-pompier-lobby-container,.sprint-pompier-results-container,.sprint-pompier-waiting-room-container,.text-study-session-container,.training-container,.training-config-advanced-container,.training-modes-container,.training-results-container,.training-session-container,.training-wizard-container{max-width:900px;margin-left:auto!important;margin-right:auto!important;padding-bottom:120px!important;padding-left:2.5rem;padding-right:2.5rem}.admin-content,.contest-content,.games-content,.journal-content,.profile-content,.ranking-content,.training-content{max-width:900px;margin-left:auto!important;margin-right:auto!important;padding-left:2.5rem;padding-right:2.5rem}}@media(min-width:1024px){.admin-container,.admin-blocked-users-container,.admin-feedbacks-container,.admin-questions-container,.admin-reports-container,.admin-security-container,.contest-correction-container,.contest-lobby-container,.contest-ranking-container,.contest-results-container,.contest-session-container,.friends-container,.games-container,.invoices-container,.join-game-container,.journal-container,.journal-detail-container,.legal-page-container,.memento-progress-container,.my-contributions-container,.profile-container,.ranking-container,.reset-password-container,.review-selection-container,.sprint-pompier-config-container,.sprint-pompier-game-container,.sprint-pompier-lobby-container,.sprint-pompier-results-container,.sprint-pompier-waiting-room-container,.text-study-session-container,.training-container,.training-config-advanced-container,.training-modes-container,.training-results-container,.training-session-container,.training-wizard-container{margin-left:280px!important;margin-right:0!important;max-width:1400px!important;padding-bottom:2rem!important}.onboarding-container{margin-left:auto!important;margin-right:auto!important;max-width:600px!important}}
