.navbar{background:#fffffff2;padding:1rem 0;box-shadow:0 1px 3px #00000014,0 1px 2px #0000000f;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.nav-container{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.nav-logo{font-size:1.5rem;font-weight:700;color:var(--primary-color);text-decoration:none;letter-spacing:-.5px}.nav-menu{display:flex;gap:2rem;align-items:center}.nav-link{color:var(--text-secondary);text-decoration:none;transition:color .2s ease;font-weight:500;font-size:.95rem;-webkit-user-select:none;user-select:none}.nav-link:hover{color:var(--primary-color)}.install-btn{color:var(--primary-color)!important;font-weight:600!important;border:1px solid var(--primary-color)!important;padding:.5rem .75rem!important;border-radius:.375rem!important;transition:all .2s ease!important;background:transparent!important;cursor:pointer!important}.install-btn:hover{background:var(--primary-color)!important;color:#fff!important}.nav-btn{background:var(--primary-color);color:#fff;border:none;padding:.6rem 1.5rem;border-radius:8px;cursor:pointer;text-decoration:none;transition:all .2s ease;font-weight:600;font-size:.95rem;box-shadow:0 2px 4px #2563eb33;-webkit-user-select:none;user-select:none}.nav-btn:hover{transform:translateY(-1px);box-shadow:0 4px 8px #4f46e54d}.nav-hamburger{display:none;background:none;border:none;cursor:pointer;padding:.5rem;margin-left:1rem;z-index:110}.hamburger,.hamburger:before,.hamburger:after{display:block;width:28px;height:4px;background:var(--primary-color);border-radius:2px;position:relative;transition:all .3s ease}.hamburger:before,.hamburger:after{content:"";position:absolute;left:0}.hamburger:before{top:-9px}.hamburger:after{top:9px}.hamburger.active{background:transparent}.hamburger.active:before{top:0;transform:rotate(45deg)}.hamburger.active:after{top:0;transform:rotate(-45deg)}.nav-menu-desktop{display:flex;gap:2rem;align-items:center}.nav-menu-mobile{display:none}@media (max-width: 768px){.nav-container{padding:0 1rem}.nav-logo{font-size:1.25rem}.nav-hamburger{display:block}.nav-menu-desktop{display:none}.nav-menu-mobile{display:flex;flex-direction:column;position:absolute;top:64px;left:0;width:100vw;background:#fffffffa;box-shadow:0 2px 8px #00000014;padding:1.5rem 0;gap:1.5rem;z-index:105;transition:transform .3s ease,opacity .3s ease;opacity:0;pointer-events:none;transform:translateY(-20px)}.nav-menu-mobile.open{opacity:1;pointer-events:auto;transform:translateY(0)}.nav-link,.nav-btn{font-size:1.1rem;padding:.8rem 2rem;width:100%;text-align:left}.nav-btn.logout-mobile{background:#ef4444;color:#fff;border:none;font-size:1.15rem;font-weight:700;border-radius:12px;box-shadow:0 2px 8px #ef444426;margin-top:.5rem;margin-bottom:.5rem;padding:1rem 2rem;width:90%;text-align:center;letter-spacing:.5px;transition:background .2s,box-shadow .2s}.nav-btn.logout-mobile:active{background:#dc2626;box-shadow:0 4px 12px #ef444440}.nav-btn.signup-mobile{background:var(--primary-color);color:#fff;border:none;font-size:1.15rem;font-weight:700;border-radius:12px;box-shadow:0 2px 8px #2563eb26;margin-top:.5rem;margin-bottom:.5rem;padding:1rem 2rem;width:90%;text-align:center;letter-spacing:.5px;transition:background .2s,box-shadow .2s}.nav-btn.signup-mobile:active{box-shadow:0 4px 12px #4f46e540;transform:translateY(0)}}.global-player{position:fixed;bottom:0;left:0;right:0;background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid #e5e7eb;z-index:1000;box-shadow:0 -4px 20px #00000014;animation:slideUpPlayer .3s ease}.player-progress-fill{height:100%;background:var(--primary-color);transition:width .1s linear;border-radius:0 2px 2px 0}.player-content{display:grid;grid-template-columns:minmax(180px,1fr) auto minmax(180px,1fr);align-items:center;gap:16px;padding:8px 16px;max-height:72px}.player-track-info{display:flex;align-items:center;gap:8px;min-width:0}.player-track-name{font-size:.875rem;font-weight:500;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.player-track-meta{font-size:.75rem;color:#6b7280}.player-controls{display:flex;align-items:center;gap:8px;justify-content:center}.player-control-btn{background:transparent;border:none;color:#6b7280;cursor:pointer;padding:4px;border-radius:50%;transition:all .15s ease;display:flex;align-items:center;justify-content:center;width:32px;height:32px}.player-control-btn:hover{color:#111827;transform:scale(1.05)}.player-play-btn{width:36px;height:36px;background:#111827;border:none;color:#fff;cursor:pointer;border-radius:50%;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.player-play-btn:hover{transform:scale(1.06);background:#1f2937}.player-time-volume{display:flex;align-items:center;justify-content:flex-end;gap:20px}.player-time{font-size:.75rem;color:#6b7280;font-variant-numeric:tabular-nums;white-space:nowrap;min-width:80px}.player-volume{display:flex;align-items:center;gap:8px;color:#6b7280}.volume-slider{width:80px;height:3px;border-radius:2px;background:#e5e7eb;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background:#111827;cursor:pointer;transition:all .15s ease;opacity:0}.player-volume:hover .volume-slider::-webkit-slider-thumb{opacity:1}.volume-slider::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:#111827;cursor:pointer;border:none;transition:all .15s ease;opacity:0}.player-volume:hover .volume-slider::-moz-range-thumb{opacity:1}@media (max-width: 768px){.global-player{padding-bottom:env(safe-area-inset-bottom);overflow:visible}.player-content{display:flex;flex-direction:row;flex-wrap:nowrap;align-items:center;justify-content:space-between;gap:12px;padding:8px 16px 8px 12px;height:64px}.player-track-info{flex:0 0 auto;min-width:0;gap:6px;max-width:30%}.player-track-name{font-size:.75rem;line-height:1.2}.player-track-meta{display:none}.player-controls{flex-shrink:0;gap:6px;display:flex;align-items:center;margin-left:auto;margin-right:8px}.player-control-btn{width:32px;height:32px;color:#111827;display:flex;align-items:center;justify-content:center;flex-shrink:0}.player-play-btn{width:36px;height:36px;background:#111827!important;color:#fff!important;border:none!important;display:flex;align-items:center;justify-content:center;flex-shrink:0}.player-time-volume{flex-shrink:0;gap:8px}.player-time{font-size:.7rem;min-width:auto}.player-volume{display:none}}@media (max-width: 480px){.player-content{flex-wrap:nowrap;gap:8px;padding:8px 12px 8px 8px;height:64px}.player-track-info{max-width:25%}.player-track-name{font-size:.7rem}.player-time{display:none}.player-controls{gap:2px;display:flex;align-items:center}.player-control-btn{width:28px;height:28px;color:#111827;display:flex;align-items:center;justify-content:center;flex-shrink:0}.player-control-btn svg{width:14px;height:14px}.player-play-btn{width:32px;height:32px;background:#111827!important;color:#fff!important;border:none!important;display:flex;align-items:center;justify-content:center;flex-shrink:0}.player-play-btn svg{width:16px;height:16px}.player-time{font-size:.65rem}}.mobile-player{position:fixed;bottom:0;left:0;right:0;background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid #e5e7eb;z-index:1000;box-shadow:0 -4px 20px #00000014;padding-bottom:env(safe-area-inset-bottom)}.mobile-player-progress-bar{position:absolute;top:0;left:0;right:0;height:4px;background:#e5e7eb;cursor:pointer;transition:height .2s ease}.mobile-player-progress-bar:active{height:8px}.mobile-player-progress-fill{height:100%;background:var(--primary-color, #3b82f6);transition:width .1s linear}.mobile-player-content{display:flex;flex-direction:row;align-items:center;gap:8px;padding:8px 12px;min-height:64px}.mobile-track-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.mobile-track-name{font-size:.75rem;font-weight:500;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-track-meta{font-size:.7rem;color:#6b7280;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-player-controls{display:flex;align-items:center;gap:4px;flex-shrink:0}.mobile-control-btn{background:transparent;border:none;color:#111827;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;flex-shrink:0}.mobile-control-btn:active{transform:scale(.95)}.mobile-play-btn{width:40px;height:40px;background:#3b82f6;border:none;color:#fff;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.mobile-play-btn:active{transform:scale(.95)}.mobile-time{font-size:.7rem;color:#6b7280;font-variant-numeric:tabular-nums;white-space:nowrap;flex-shrink:0;min-width:55px;text-align:right}@media (max-width: 480px){.mobile-player-content{gap:6px;padding:8px 10px}.mobile-track-meta{display:none}.mobile-player-controls{gap:2px}.mobile-control-btn{width:28px;height:28px}.mobile-control-btn svg{width:14px;height:14px}.mobile-play-btn{width:36px;height:36px}.mobile-play-btn svg{width:16px;height:16px}.mobile-time{font-size:.65rem;min-width:50px}}.tts-demo{margin:2rem auto;max-width:500px;background:#fff;border-radius:12px;box-shadow:0 2px 16px #00000012;padding:2rem 1.5rem;text-align:center}.tts-demo h2{margin-bottom:1rem;font-size:1.4rem;color:#2d3748}.tts-demo-form{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.tts-demo-form textarea{resize:vertical;min-height:80px;font-size:1rem;padding:.75rem;border-radius:8px;border:1px solid #cbd5e1;background:#f7fafc;color:#2d3748;transition:border .2s}.tts-demo-form textarea:focus{border-color:#3182ce;outline:none}.tts-demo-form button{align-self:center;min-width:160px}.error-msg{color:#e53e3e;background:#fff5f5;border-radius:6px;padding:.5rem 1rem;margin-bottom:.5rem;font-size:.98rem}.audio-output{margin-top:1rem;display:flex;flex-direction:column;align-items:center;gap:.5rem}.audio-output audio{width:100%;max-width:320px}.audio-output a{margin-top:.5rem}.home-container{padding:2rem 2rem 5rem;max-width:1200px;margin:0 auto}.player-active .home-container{padding-bottom:5rem}.hero{text-align:center}.hero h1{font-size:3.5rem;margin-bottom:1rem;color:var(--primary-color);font-weight:800;letter-spacing:-1px}.subtitle{font-size:1.25rem;color:var(--text-secondary);margin-bottom:2rem;max-width:600px;margin-left:auto;margin-right:auto;line-height:1.7}.cta-buttons{display:flex;gap:1rem;justify-content:center;margin-top:2.5rem}.cta-btn{padding:1rem 2rem;border-radius:10px;text-decoration:none;font-weight:600;font-size:1.1rem;transition:all .2s ease;display:inline-block;-webkit-user-select:none;user-select:none;text-align:center}.cta-btn.primary{background:var(--primary-color);color:#fff;box-shadow:0 4px 12px #2563eb40}.cta-btn.primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #2563eb59}.cta-btn.secondary{background:var(--surface);color:var(--primary-color);border:2px solid var(--border)}.cta-btn.secondary:hover{background:var(--surface-hover);border-color:var(--primary-color);transform:translateY(-2px)}.features{margin-top:5rem}.features h2{text-align:center;font-size:2.5rem;margin-bottom:3rem;color:var(--text-primary);font-weight:700}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}.feature-card{background:#fff;padding:2.5rem;border-radius:16px;text-align:center;transition:all .3s ease;border:1px solid var(--border);box-shadow:0 2px 4px #0000000a}.feature-card:hover{transform:translateY(-5px);box-shadow:0 12px 24px #00000014;border-color:var(--primary-light)}.feature-card h3{font-size:1.5rem;margin-bottom:1rem;color:var(--text-primary);font-weight:600}.feature-card p{color:var(--text-secondary);line-height:1.6}.auth-container{display:flex;justify-content:center;align-items:top;padding-right:2rem;padding-left:2rem;padding-bottom:3rem;width:100%;margin:auto}.auth-card{background:#fff;padding:3rem;border-radius:16px;box-shadow:0 4px 6px #0000000d,0 10px 15px #0000000d;width:100%;max-width:440px;border:1px solid var(--border)}.auth-card h2{margin-top:0;margin-bottom:2rem;color:var(--text-primary);text-align:center;font-size:1.875rem;font-weight:700;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.form-group label{display:block;margin-bottom:.5rem;color:var(--text-primary);font-weight:600;font-size:.9rem;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.form-group input{width:100%;padding:.875rem;border:1.5px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text-primary);font-size:1rem;box-sizing:border-box;transition:all .2s ease}.form-group input:focus{outline:none;border-color:var(--primary-color);background:#fff;box-shadow:0 0 0 3px #2563eb1a}.form-group input:disabled{opacity:.6;cursor:not-allowed;background:var(--surface-hover)}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.error-message{background:#fef2f2;color:var(--error);padding:.875rem;border-radius:8px;margin-bottom:1rem;border-left:4px solid var(--error);font-weight:500}.success-message{background:#f0fdf4;color:var(--success);padding:.875rem;border-radius:8px;margin-bottom:1rem;border-left:4px solid var(--success);font-weight:500}.auth-link{text-align:center;margin-top:1.5rem;color:var(--text-secondary);font-size:.95rem}.auth-link a{color:#646cff;text-decoration:none}.auth-link a:hover{text-decoration:underline}.divider{display:flex;align-items:center;text-align:center;margin:1.5rem 0;color:var(--text-muted);font-size:.875rem}.divider:before,.divider:after{content:"";flex:1;border-bottom:1px solid var(--border)}.divider span{padding:0 1rem}.google-btn{width:100%;padding:.875rem;border:1px solid var(--border);background:#fff;color:var(--text-primary);font-size:.95rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:.75rem}.google-btn:hover:not(:disabled){background:var(--surface);border-color:var(--text-muted);box-shadow:0 2px 4px #00000014}.google-btn:disabled{opacity:.6;cursor:not-allowed}.google-icon{display:inline-block}.apple-btn{width:100%;padding:.875rem;border:1px solid #000;background:#000;color:#fff;font-size:.95rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:1.5rem}.apple-btn:hover:not(:disabled){background:#1a1a1a;border-color:#1a1a1a;box-shadow:0 2px 4px #0003}.apple-btn:disabled{opacity:.6;cursor:not-allowed}.apple-icon{display:inline-block}.modal-content{background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:90%;width:450px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 1.5rem 1rem;border-bottom:1px solid var(--border)}.modal-header h3{margin:0;font-size:1.25rem;font-weight:700;color:var(--text-primary)}.modal-close{background:none;border:none;font-size:2rem;color:var(--text-muted);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s ease;line-height:1}.modal-close:hover{background:var(--surface-hover);color:var(--text-primary)}.modal-body p{margin:0;color:var(--text-secondary);font-size:1rem;line-height:1.6}.modal-footer{display:flex;gap:.75rem;padding:1rem 1.5rem 1.5rem;justify-content:flex-end}.modal-btn{padding:.625rem 1.25rem;border-radius:8px;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s ease;border:none}.modal-btn-cancel{background:var(--surface);color:var(--text-secondary);border:1.5px solid var(--border)}.modal-btn-cancel:hover{background:var(--surface-hover);color:var(--text-primary)}.modal-btn-confirm{background:var(--error);color:#fff;box-shadow:0 2px 4px #ef444433}.modal-btn-confirm:hover{background:#dc2626;transform:translate3d(0,-1px,0);box-shadow:0 4px 8px #ef44444d}@media (max-width: 768px){.modal-content{width:calc(100% - 32px);max-width:calc(100% - 32px);margin:0 16px}}*{box-sizing:border-box}body,html{overflow-x:hidden!important;width:100vw;max-width:100vw;position:relative}.spotify-dashboard{display:flex;flex:1;background:#f9fafb;color:#111827;overflow:hidden;height:100vh;max-height:100vh;width:100vw;max-width:100vw}.sidebar{width:280px;background:#fff;padding:24px 16px;overflow-y:auto;border-right:1px solid #e5e7eb;display:flex;flex-direction:column;gap:24px;box-shadow:2px 0 8px #0000000d}.sidebar::-webkit-scrollbar{width:12px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:#e5e7eb;border-radius:6px}.sidebar::-webkit-scrollbar-thumb:hover{background:#d1d5db}.sidebar-section{display:flex;flex-direction:column;gap:8px}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;margin-bottom:4px}.sidebar-header h3{font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#6b7280;margin:0}.sidebar-btn{display:flex;align-items:center;gap:12px;padding:10px 12px;background:transparent;border:none;border-radius:8px;color:#4b5563;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;width:100%;text-align:left;min-height:40px}.sidebar-btn:hover{background:#f3f4f6;color:#111827}.sidebar-btn.active{background:#dbeafe;color:#2563eb}.sidebar-btn svg{flex-shrink:0}.icon-btn{background:transparent;border:none;color:#6b7280;cursor:pointer;padding:8px;border-radius:6px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:36px;min-height:36px}.icon-btn:hover{background:#f3f4f6;color:#111827}.sidebar-items{display:flex;flex-direction:column;gap:4px}.sidebar-item-wrapper{position:relative;display:flex;align-items:center;gap:4px;border-radius:6px;transition:all .2s ease}.sidebar-item-wrapper:hover .sidebar-item-actions{opacity:1;pointer-events:auto}.sidebar-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:transparent;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease;text-align:left;flex:1;min-width:0;min-height:40px}.sidebar-item:hover{background:#f3f4f6}.sidebar-item.active{background:#e0e7ff}.sidebar-item-actions{display:flex;gap:4px;padding:4px 8px;opacity:0;pointer-events:none;transition:opacity .2s ease;flex-shrink:0}@media (max-width: 768px){.sidebar-item-actions{opacity:1;pointer-events:auto}}.sidebar-action-btn{background:transparent;border:none;color:#6b7280;cursor:pointer;padding:6px;border-radius:6px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:32px;min-height:32px}.sidebar-action-btn:hover{background:#e5e7eb;color:#111827}.sidebar-action-btn:active{transform:scale(.95)}.album-mini-cover{width:40px;height:40px;border-radius:4px;flex-shrink:0}.playlist-mini-icon{width:40px;height:40px;border-radius:4px;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:#fffffff2}.sidebar-item-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.sidebar-item-name{font-size:.95rem;font-weight:600;color:#111827;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-item-meta{font-size:.8rem;color:#6b7280}.main-content{flex:1;background:#f9fafb;padding:24px 32px 32px;overflow-y:auto;overflow-x:hidden;width:100%;max-width:100%}.player-active .main-content{padding-bottom:0}.main-content.has-bulk-actions{padding-bottom:18rem}.main-content::-webkit-scrollbar{width:12px}.main-content::-webkit-scrollbar-track{background:transparent}.main-content::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:6px}.main-content::-webkit-scrollbar-thumb:hover{background:#9ca3af}.content-header{display:flex;align-items:flex-end;justify-content:space-between;gap:20px}.content-header h1{font-size:3rem;font-weight:900;margin:0;color:#111827;line-height:1.1}.content-subtitle{font-size:.95rem;color:#6b7280;margin:8px 0 0}.convert-fab{width:56px;height:56px;border-radius:50%;background:var(--primary-color);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 8px 24px #2563eb4d;flex-shrink:0;margin-right:1rem}.convert-fab:hover{transform:scale(1.06);box-shadow:0 12px 32px #2563eb66}.play-all-section{display:flex;align-items:center;gap:16px;margin-bottom:24px}.play-all-btn{display:flex;align-items:center;gap:12px;padding:12px 24px;background:#2563eb;color:#fff;border:none;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #2563eb33;min-height:44px}.play-all-btn:hover{background:#1d4ed8;box-shadow:0 4px 12px #2563eb4d}.play-all-btn svg{flex-shrink:0}.track-count-info{color:#6b7280;font-size:.95rem;font-weight:500}.global-player{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(180deg,#fffffff2,#fffffffa);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid #e5e7eb;z-index:1000;box-shadow:0 -4px 20px #00000014;animation:slideUpPlayer .3s ease}@keyframes slideUpPlayer{0%{transform:translateY(100%)}to{transform:translateY(0)}}.player-progress-bar{position:absolute;top:0;left:0;right:0;height:4px;background:#e5e7eb;cursor:pointer;transition:height .2s ease}.player-progress-bar:hover{height:6px}.player-progress-fill{height:100%;background:#2563eb;transition:width .1s linear;border-radius:0 2px 2px 0}.player-content{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:24px;padding:16px 24px}.player-track-info{display:flex;align-items:center;gap:12px;min-width:0}.player-track-details{min-width:0;flex:1}.player-track-name{font-size:.95rem;font-weight:600;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.player-track-meta{font-size:.8rem;color:#6b7280}.player-controls{display:flex;align-items:center;gap:12px;justify-content:center}.player-control-btn{background:transparent;border:none;color:#374151;cursor:pointer;padding:8px;border-radius:50%;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.player-control-btn:hover{background:#f3f4f6;color:#111827;transform:scale(1.1)}.player-play-btn{width:48px;height:48px;background:#2563eb;border:none;color:#fff;cursor:pointer;border-radius:50%;transition:all .2s ease;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #2563eb4d}.player-play-btn:hover{background:#1d4ed8;transform:scale(1.08);box-shadow:0 6px 16px #2563eb66}.player-time-volume{display:flex;align-items:center;gap:20px;justify-content:flex-end}.player-time{font-size:.85rem;color:#6b7280;font-variant-numeric:tabular-nums;white-space:nowrap}.player-volume{display:flex;align-items:center;gap:10px}.player-volume svg{color:#6b7280;flex-shrink:0}.volume-slider{width:100px;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#e5e7eb;border-radius:2px;outline:none;cursor:pointer}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;background:#2563eb;border-radius:50%;cursor:pointer;transition:all .2s ease}.volume-slider::-webkit-slider-thumb:hover{background:#1d4ed8;transform:scale(1.2)}.volume-slider::-moz-range-thumb{width:14px;height:14px;background:#2563eb;border:none;border-radius:50%;cursor:pointer;transition:all .2s ease}.volume-slider::-moz-range-thumb:hover{background:#1d4ed8;transform:scale(1.2)}.play-btn-track{background:transparent;border:2px solid #d1d5db;color:#6b7280;cursor:pointer;padding:8px;border-radius:50%;transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:36px;height:36px}.play-btn-track:hover{border-color:#2563eb;color:#2563eb;background:#2563eb0d;transform:scale(1.05)}.play-btn-track.active{border-color:#2563eb;background:#2563eb;color:#fff}.play-btn-track.active:hover{background:#1d4ed8;border-color:#1d4ed8}.bulk-actions-bar{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--primary-color);border-radius:10px;box-shadow:0 4px 20px #2563eb4d;z-index:1000;max-width:90%;min-width:min(600px,90vw)}.bulk-actions-info{display:flex;align-items:center;gap:12px;margin-right:16px}.bulk-count{color:#fff;font-size:.9rem;font-weight:600}.bulk-clear{background:#ffffff26;border:1px solid rgba(255,255,255,.3);color:#fff;padding:4px 12px;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500}.bulk-clear:hover{background:#ffffff40}.bulk-actions-buttons{display:flex;gap:8px}.bulk-action-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:#fffffff2;border:none;border-radius:6px;color:#2563eb;font-size:.875rem;font-weight:600;cursor:pointer;box-shadow:0 1px 4px #0000001a;transition:all .2s ease;min-height:36px}.bulk-action-btn:hover{background:#fff;box-shadow:0 2px 8px #00000026}.bulk-action-btn.danger{color:#ef4444}.bulk-action-btn.danger:hover{background:#fef2f2;color:#dc2626}.bulk-action-btn svg{flex-shrink:0}.tracks-table{margin-top:24px}.tracks-header{display:grid;grid-template-columns:48px 40px 3fr 1.5fr 100px 120px 220px;gap:16px;padding:8px 16px;border-bottom:2px solid #e5e7eb;margin-bottom:8px;font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:#6b7280;font-weight:600}.track-row{display:grid;grid-template-columns:56px 48px 3fr 1.5fr 100px 120px 220px;gap:20px;padding:8px 20px;border-radius:6px;transition:background .2s ease;align-items:center;min-height:56px;border-bottom:1px solid #f3f4f6}.track-row:hover{background:#f9fafb;box-shadow:0 1px 3px #0000000d}.track-checkbox{display:flex;align-items:center;justify-content:center}.track-checkbox-input{width:20px;height:20px;cursor:pointer;accent-color:#2563eb;border-radius:4px}.track-number{color:#9ca3af;font-size:.95rem;text-align:center;font-variant-numeric:tabular-nums}.track-title{display:flex;align-items:center;gap:12px;min-width:0}.track-info{display:flex;flex-direction:column;gap:4px;min-width:0}.track-name{color:#111827;font-size:.95rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-type{color:#6b7280;font-size:.8rem;text-transform:uppercase;letter-spacing:.3px}.track-voice{color:#374151;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-duration{color:#374151;font-size:.9rem;font-variant-numeric:tabular-nums}.track-date{color:#6b7280;font-size:.9rem}.track-actions{display:flex;align-items:center;gap:8px;justify-content:flex-end}.track-action-btn{background:transparent;border:none;color:#6b7280;cursor:pointer;padding:8px;border-radius:6px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:36px;min-height:36px}.track-action-btn:hover{background:#f3f4f6;color:#111827}.track-action-btn.delete:hover{background:#fee2e2;color:#ef4444}.play-btn-mini{background:#2563eb;border:none;color:#fff;cursor:pointer;padding:8px;border-radius:50%;transition:all .2s ease;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #2563eb4d}.play-btn-mini:hover{transform:scale(1.05);background:#1d4ed8;box-shadow:0 6px 16px #2563eb66}.audio-player-container{display:flex;align-items:center;gap:8px}.mini-audio-player{height:32px;width:100px;opacity:.9}.audio-loading-mini{color:#6b7280;font-size:.85rem}.audio-error{color:#ef4444;font-size:.8rem}.empty-state-spotify{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 40px;text-align:center}.empty-state-spotify svg{margin-bottom:24px}.empty-state-spotify h3{font-size:2rem;font-weight:700;margin:0 0 12px;color:#111827}.empty-state-spotify p{font-size:1rem;color:#6b7280;margin:0 0 32px}.empty-cta-btn{padding:12px 24px;background:var(--primary-color);color:#fff;border:none;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-block;box-shadow:0 2px 8px #2563eb33;min-height:44px}.empty-cta-btn:hover{background:#1d4ed8;box-shadow:0 4px 12px #2563eb4d}.loading-center{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:20px}.loading-center p{color:#6b7280;font-size:1rem}.spinner-large{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#2563eb;border-radius:50%;animation:spin .8s linear infinite}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content-custom{background:#fff;border-radius:12px;padding:32px;max-width:500px;width:90%;box-shadow:0 16px 48px #0003}.modal-content-custom h3{color:#111827;font-size:1.5rem;font-weight:700;margin:0 0 24px}.modal-input{width:100%;padding:14px 16px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;color:#111827;font-size:1rem;margin-bottom:24px;transition:border-color .2s ease}.modal-input:focus{outline:none;border-color:#2563eb;background:#fff}.modal-input::placeholder{color:#9ca3af}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.modal-btn-cancel{padding:10px 20px;background:transparent;border:1.5px solid #d1d5db;border-radius:8px;color:#374151;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;min-height:40px}.modal-btn-cancel:hover{border-color:#9ca3af;background:#f9fafb}.modal-btn-confirm{padding:10px 20px;background:#2563eb;border:none;border-radius:8px;color:#fff;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease;min-height:40px}.modal-btn-confirm:hover{background:#1d4ed8}.modal-btn-confirm:disabled{opacity:.5;cursor:not-allowed;transform:none}.modal-list{max-height:300px;overflow-y:auto;margin-bottom:24px;display:flex;flex-direction:column;gap:8px}.modal-list::-webkit-scrollbar{width:8px}.modal-list::-webkit-scrollbar-track{background:transparent}.modal-list::-webkit-scrollbar-thumb{background:#e5e7eb;border-radius:4px}.modal-list-item{display:flex;align-items:center;gap:12px;padding:12px;background:#f9fafb;border:none;border-radius:6px;color:#111827;font-size:.95rem;font-weight:500;cursor:pointer;text-align:left;width:100%}.modal-list-item:hover{background:#f3f4f6}.mobile-header{display:none;align-items:center;justify-content:space-between;padding:12px 16px;background:#fff;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:99;box-shadow:0 1px 3px #0000000d;flex-shrink:0;min-height:57px;max-height:57px;width:100vw;max-width:100vw;overflow:hidden}.hamburger-btn{background:transparent;border:none;color:#111827;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s ease;min-width:40px;min-height:40px}.hamburger-btn:hover{background:#f3f4f6}.mobile-title{font-size:1.125rem;font-weight:700;color:#111827;margin:0;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 12px}.mobile-add-btn,.mobile-play-all-btn{background:#2563eb;border:none;color:#fff;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s ease;min-width:40px;min-height:40px}.mobile-add-btn:hover{background:#1d4ed8}.sidebar-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:99998;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.track-mobile-info,.track-mobile-layout,.dropdown-overlay{display:none}@media (max-width: 1200px){.tracks-header,.track-row{grid-template-columns:48px 40px 2fr 1fr 80px 100px 180px}}@media (max-width: 900px){.sidebar{width:240px}.content-header h1{font-size:2rem}.tracks-header,.track-row{grid-template-columns:48px 40px 2fr 100px 160px}.track-voice,.track-date{display:none}}@media (max-width: 768px){*{box-sizing:border-box}body,html{overflow-x:hidden!important;max-width:100vw;width:100vw;position:relative}.mobile-header{display:flex}.spotify-dashboard{flex-direction:column;height:calc(100vh - 65px);min-height:calc(100vh - 65px);max-height:calc(100vh - 65px);overflow:hidden;display:grid;grid-template-rows:auto 1fr;width:100vw;max-width:100vw;padding-bottom:0}.sidebar{position:fixed;top:0;left:0;bottom:0;width:280px;max-height:100vh;border-right:1px solid #e5e7eb;border-bottom:none;transform:translate(-100%);transition:transform .3s ease;z-index:99999;box-shadow:2px 0 12px #00000026}.sidebar.sidebar-open{transform:translate(0);padding-top:4.5rem}.sidebar-overlay{display:block}.main-content{padding:16px 0;width:100vw;max-width:100vw;overflow-y:auto;overflow-x:hidden!important;flex:1;height:100%;max-height:100%;-webkit-overflow-scrolling:touch;position:relative}.player-active .main-content{padding-bottom:220px}.main-content::-webkit-scrollbar{display:none}.main-content{-ms-overflow-style:none;scrollbar-width:none}.content-header,.convert-fab,.tracks-header{display:none}.track-row{display:flex;flex-direction:row;align-items:center;gap:0;padding:8px 12px 8px 8px;background:transparent;border-radius:0;border:none;border-bottom:1px solid #f3f4f6;margin-bottom:0;box-shadow:none;position:relative;min-height:56px;width:100vw;max-width:100vw;overflow:visible}.track-row:hover{background:#fafafa;box-shadow:none}.track-row[data-playing=true]{background:#f0f0ff}.track-row[data-playing=true]:hover{background:#e8e8ff}.track-number,.track-title,.track-voice,.track-duration,.track-date,.track-actions{display:none}.track-mobile-layout{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.track-checkbox{position:relative;top:auto;left:auto;margin-right:4px}.track-checkbox-input{width:18px;height:18px}.play-btn-track{width:40px;height:40px;padding:8px;flex-shrink:0;border:none;background:transparent;color:#2563eb}.play-btn-track:hover{background:#2563eb1a;border:none}.play-btn-track.active{background:#2563eb;color:#fff;border:none}.play-btn-track svg{width:20px;height:20px}.track-mobile-info-inline{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.track-mobile-info-inline .track-name{font-size:.95rem;font-weight:500;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.track-mobile-info-inline .track-mobile-meta{display:flex;align-items:center;gap:6px;font-size:.8rem;color:#6b7280}.track-menu-btn{background:transparent;border:none;color:#6b7280;cursor:pointer;padding:8px;border-radius:50%;transition:all .2s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.track-menu-btn:hover{background:#f3f4f6;color:#111827}.dropdown-overlay{display:block;position:fixed;top:0;left:0;right:0;bottom:0;z-index:99}.track-dropdown-menu{position:absolute;right:12px;top:100%;margin-top:4px;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;z-index:100;min-width:200px;max-width:calc(100vw - 32px);overflow:hidden;animation:slideInDown .2s ease}@keyframes slideInDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.track-dropdown-menu button{width:100%;display:flex;align-items:center;gap:12px;padding:14px 16px;background:transparent;border:none;color:#374151;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;text-align:left}.track-dropdown-menu button:hover{background:#f9fafb}.track-dropdown-menu button.danger{color:#ef4444}.track-dropdown-menu button.danger:hover{background:#fef2f2}.track-dropdown-menu button svg{flex-shrink:0}.track-dropdown-menu button+button{border-top:1px solid #f3f4f6}.bulk-actions-bar{flex-direction:column;gap:10px;align-items:stretch;min-width:auto;width:calc(100% - 24px);max-width:calc(100% - 24px);bottom:12px;left:12px;transform:none;padding:12px;border-radius:12px}.bulk-actions-info{flex-direction:row;justify-content:space-between;width:100%;margin-right:0;margin-bottom:0}.bulk-count{font-size:.9rem}.bulk-clear{padding:6px 14px;font-size:.85rem}.bulk-actions-buttons{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;width:100%}.bulk-action-btn{flex:none;min-width:auto;padding:10px 12px;font-size:.85rem;justify-content:center;white-space:nowrap}.bulk-action-btn span{display:inline}.bulk-action-btn svg{width:16px;height:16px}.modal-content-custom{width:calc(100% - 32px);max-width:calc(100% - 32px);padding:24px;margin:0 16px}.modal-overlay{padding:16px}.modal-content-custom h3{font-size:1.25rem;margin-bottom:20px}.modal-input{padding:12px 14px;font-size:.95rem;margin-bottom:20px}.modal-actions{gap:10px}.modal-btn-cancel,.modal-btn-confirm{padding:12px 20px;font-size:.9rem;flex:1}.modal-list{max-height:250px;margin-bottom:20px}.modal-list-item{padding:14px;font-size:.9rem}.empty-state-spotify{padding:60px 24px}.empty-state-spotify svg{width:64px;height:64px;margin-bottom:20px}.empty-state-spotify h3{font-size:1.5rem;margin-bottom:10px}.empty-state-spotify p{font-size:.95rem;margin-bottom:24px}.empty-cta-btn{padding:12px 28px;font-size:.95rem}.sidebar-item-wrapper:hover .sidebar-item-actions,.sidebar-item-actions{opacity:1;pointer-events:auto}.play-all-section{flex-direction:column;align-items:flex-start;margin-bottom:8px}.play-all-btn{padding:12px 24px;font-size:.95rem}.track-count-info{font-size:.85rem}.global-player{padding-bottom:env(safe-area-inset-bottom);width:100vw;max-width:100vw;overflow:hidden!important;position:fixed;left:0;right:0;bottom:0}.player-content{grid-template-columns:1fr;grid-template-rows:auto auto auto;gap:12px;padding:12px 16px 16px}.player-track-info{order:1;justify-content:center}.player-controls{order:2;gap:16px}.player-control-btn{padding:10px}.player-play-btn{width:52px;height:52px}.player-time-volume{order:3;justify-content:space-between;width:100%}.player-time{font-size:.8rem}.volume-slider{width:80px}}@media (max-width: 480px){.mobile-header{padding:10px 12px}.mobile-title{font-size:1rem}.sidebar{width:260px}.main-content{padding:12px 0}.player-active .main-content{padding-bottom:120px}.main-content{min-height:100vh;height:100vh;display:flex;flex-direction:column}.tracks-table{margin-top:0;width:100vw;max-width:100vw;overflow-x:hidden;overflow-y:visible;padding-bottom:20px}.player-active .tracks-table{padding-bottom:120px}.track-row{padding:8px 16px 8px 12px}.track-mobile-layout{gap:10px}.play-btn-track{width:38px;height:38px}.track-mobile-info-inline .track-name{font-size:.9rem}.track-mobile-info-inline .track-mobile-meta{font-size:.75rem;gap:5px}.bulk-actions-buttons{grid-template-columns:1fr}.bulk-action-btn{width:100%}.sidebar-header h3{font-size:.8rem}.sidebar-item-name{font-size:.9rem}.sidebar-item-meta{font-size:.75rem}}@media (max-width: 900px) and (max-height: 500px){.sidebar{max-height:100vh;overflow-y:auto}}.queued-badge{display:inline-block;margin-left:8px;padding:2px 8px;background:#64748b;color:#fff;font-size:.7rem;font-weight:600;border-radius:4px;letter-spacing:.3px}.processing-badge{display:inline-block;margin-left:8px;padding:2px 8px;background:#f59e0b;color:#fff;font-size:.7rem;font-weight:600;border-radius:4px;letter-spacing:.3px;animation:pulse 2s ease-in-out infinite}.streaming-badge{display:inline-block;margin-left:8px;padding:2px 8px;background:#10b981;color:#fff;font-size:.7rem;font-weight:600;border-radius:4px;letter-spacing:.3px;animation:streamPulse 1.5s ease-in-out infinite}@keyframes streamPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.02)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.spinner-small{width:16px;height:16px;border:2px solid #e5e7eb;border-top-color:#2563eb;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.play-btn-track.disabled{opacity:.5;cursor:not-allowed}.track-action-btn:disabled,.track-dropdown-menu button:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.voice-selector-compact{margin:20px 0;padding:20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;transition:all .3s ease}.voice-selector-compact.expanded{padding-bottom:25px}.selector-header-compact{display:flex;justify-content:space-between;align-items:center;gap:15px}.header-left{flex:1}.header-left h3{margin:0 0 5px;color:#333;font-size:1.25rem;font-weight:600}.voice-info-compact{color:#666;font-size:.9rem}.expand-btn{padding:10px 20px;background:#2563eb;color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.expand-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #2563eb66}.selector-expanded-content{margin-top:20px;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.compact-filters{display:flex;gap:10px;margin-bottom:15px;flex-wrap:wrap;align-items:center}.search-bar-compact{position:relative;flex:1;min-width:200px}.search-input-compact{width:100%;padding:8px 35px;border:2px solid #e0e0e0;border-radius:8px;font-size:.9rem;transition:all .2s;background:#fafafa}.search-input-compact:focus{outline:none;border-color:#2563eb;background:#fff}.clear-search-compact{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:#ddd;border:none;width:20px;height:20px;border-radius:50%;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#666}.filter-select-compact{padding:8px 12px;border:2px solid #dee2e6;border-radius:8px;font-size:.9rem;background:#fff;cursor:pointer;transition:all .2s;font-weight:500}.filter-select-compact:focus{outline:none;border-color:#2563eb}.voice-count-compact{background:#2563eb;color:#fff;padding:6px 12px;border-radius:16px;font-size:.85rem;font-weight:600;white-space:nowrap}.horizontal-scroll-container{position:relative;display:flex;align-items:center;gap:10px}.scroll-btn{flex-shrink:0;width:40px;height:40px;border:2px solid #2563eb;background:#fff;color:#2563eb;border-radius:50%;font-size:1.8rem;font-weight:700;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;line-height:1;z-index:2}.scroll-btn:hover{background:#2563eb;color:#fff;transform:scale(1.1)}.scroll-btn:active{transform:scale(.95)}.voice-slider{display:flex;gap:15px;overflow-x:auto;scroll-behavior:smooth;padding:10px 0;scrollbar-width:thin;scrollbar-color:#2563eb #f1f1f1}.voice-slider::-webkit-scrollbar{height:8px}.voice-slider::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.voice-slider::-webkit-scrollbar-thumb{background:#2563eb;border-radius:4px}.voice-card-compact{flex:0 0 250px;padding:15px;border:2px solid #e9ecef;border-radius:10px;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);background:#fff;position:relative;min-height:140px}.voice-card-compact:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:#2563eb;opacity:0;transition:opacity .25s;border-radius:10px 10px 0 0}.voice-card-compact:hover{border-color:#2563eb;box-shadow:0 6px 12px #2563eb26;transform:translateY(-3px)}.voice-card-compact:hover:before{opacity:1}.voice-card-compact.selected{border-color:#2563eb;background:#dbeafe;box-shadow:0 4px 12px #2563eb40}.voice-card-compact.selected:before{opacity:1}.voice-card-compact.generating{border-color:#ff9800;background:#fff8f0}.voice-card-compact.playing{border-color:#4caf50;background:#f1f8f4}.voice-card-header-compact{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px;gap:8px}.voice-name-compact{font-weight:700;font-size:1.05rem;color:#2c3e50;flex:1}.voice-gender-compact{padding:4px 8px;border-radius:12px;font-size:.7rem;font-weight:700;text-transform:uppercase;flex-shrink:0}.voice-gender-compact.female{background:#fce4ec;color:#c2185b;border:1px solid #f8bbd0}.voice-gender-compact.male{background:#e3f2fd;color:#1976d2;border:1px solid #bbdefb}.voice-meta-compact{display:flex;gap:8px;margin-bottom:8px;font-size:.8rem;color:#666;flex-wrap:wrap}.voice-meta-compact span{padding:3px 8px;background:#f8f9fa;border-radius:4px;border:1px solid #e9ecef}.voice-description-compact{font-size:.85rem;color:#6c757d;margin:0 0 8px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.voice-status-compact{position:absolute;top:12px;right:12px;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center}.voice-status-compact.generating{background:#fff3e0;border:2px solid #ffcc80}.voice-status-compact.playing{background:#e8f5e9;border:2px solid #a5d6a7}.voice-status-compact.selected{background:#e3f2fd;border:2px solid #90caf9}.spinner-compact{animation:spin 1s linear infinite}.no-voices-compact{text-align:center;padding:40px 20px;color:#6c757d}.no-voices-compact p{font-size:1rem;margin:0 0 15px;font-weight:500}.reset-filters-compact{padding:8px 20px;background:#2563eb;color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.reset-filters-compact:hover{transform:translateY(-2px);box-shadow:0 4px 12px #2563eb66}@media (max-width: 768px){.selector-header-compact{flex-direction:column;align-items:flex-start}.expand-btn{width:100%;text-align:center}.compact-filters{flex-direction:column;align-items:stretch}.search-bar-compact,.filter-select-compact{width:100%;min-width:0}.voice-count-compact{align-self:flex-start}.voice-card-compact{flex:0 0 220px}.scroll-btn{width:35px;height:35px;font-size:1.5rem}}@media (max-width: 480px){.voice-selector-compact{padding:15px}.header-left h3{font-size:1.1rem}.voice-info-compact{font-size:.85rem}.voice-card-compact{flex:0 0 200px;padding:12px}.scroll-btn{width:30px;height:30px;font-size:1.3rem}}.voice-selector{margin:20px 0;padding:25px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014}.selector-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.voice-selector h3{margin:0;color:#333;font-size:1.5rem;font-weight:600}.voice-count{background:#2563eb;color:#fff;padding:6px 14px;border-radius:20px;font-size:.85rem;font-weight:600;box-shadow:0 2px 6px #2563eb4d}.search-bar{position:relative;margin-bottom:20px}.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#999;pointer-events:none}.search-input{width:100%;padding:12px 40px 12px 44px;border:2px solid #e0e0e0;border-radius:8px;font-size:.95rem;transition:all .2s;background:#fafafa}.search-input:focus{outline:none;border-color:#2563eb;background:#fff;box-shadow:0 0 0 3px #2563eb1a}.search-input::placeholder{color:#aaa}.clear-search{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:#ddd;border:none;width:24px;height:24px;border-radius:50%;font-size:1.3rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#666;transition:all .2s}.clear-search:hover{background:#ccc;color:#333}.voice-filters{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.filter-select{flex:1;min-width:180px;padding:10px 14px;border:2px solid #dee2e6;border-radius:8px;font-size:.95rem;background:#fff;cursor:pointer;transition:all .2s;font-weight:500}.filter-select:hover{border-color:#2563eb}.filter-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26}.voice-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;max-height:550px;overflow-y:auto;padding:4px}.voice-card{padding:18px;border:2px solid #e9ecef;border-radius:10px;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);background:#fff;position:relative;overflow:hidden}.voice-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:#2563eb;opacity:0;transition:opacity .25s}.voice-card:hover{border-color:#2563eb;box-shadow:0 8px 16px #2563eb26;transform:translateY(-3px)}.voice-card:hover:before{opacity:1}.voice-card.selected{border-color:#2563eb;background:#dbeafe;box-shadow:0 4px 16px #2563eb40}.voice-card.selected:before{opacity:1}.voice-card.generating{border-color:#ff9800;background:#fff8f0;animation:pulse 1.5s ease-in-out infinite}.voice-card.playing{border-color:#4caf50;background:#f1f8f4;animation:playing 2s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 4px 16px #ff98004d}50%{box-shadow:0 6px 24px #ff980073}}@keyframes playing{0%,to{box-shadow:0 4px 16px #4caf504d}50%{box-shadow:0 6px 24px #4caf5073}}.voice-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:10px}.voice-name{font-weight:700;font-size:1.15rem;color:#2c3e50;flex:1}.voice-gender{padding:5px 12px;border-radius:16px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;align-self:flex-start}.voice-gender.female{background:#fce4ec;color:#c2185b;border:1px solid #f8bbd0}.voice-gender.male{background:#e3f2fd;color:#1976d2;border:1px solid #bbdefb}.voice-details{display:flex;gap:10px;margin-bottom:10px;flex-wrap:wrap}.voice-language,.voice-style{display:flex;align-items:center;gap:5px;font-size:.85rem;padding:5px 10px;border-radius:6px;background:#f8f9fa;color:#495057;font-weight:500;border:1px solid #e9ecef}.detail-icon{opacity:.7}.voice-description{font-size:.9rem;color:#6c757d;margin:0 0 10px;line-height:1.5;min-height:42px}.voice-status{margin-top:12px;padding:8px 12px;border-radius:6px;font-size:.85rem;font-weight:600;text-align:center;display:flex;align-items:center;justify-content:center;gap:8px}.generating-status{background:#fff3e0;color:#e65100;border:1px solid #ffcc80}.playing-status{background:#e8f5e9;color:#2e7d32;border:1px solid #a5d6a7}.selected-status{background:#e3f2fd;color:#1565c0;border:1px solid #90caf9}.spinner{animation:spin 1s linear infinite}.audio-wave{flex-shrink:0}.no-voices{text-align:center;padding:60px 40px;color:#6c757d;display:flex;flex-direction:column;align-items:center;gap:16px}.no-voices svg{opacity:.4;margin-bottom:8px}.no-voices p{font-size:1.1rem;margin:0;font-weight:500}.reset-filters{margin-top:8px;padding:10px 24px;background:#2563eb;color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #2563eb4d}.reset-filters:hover{transform:translateY(-2px);box-shadow:0 4px 12px #2563eb66}.reset-filters:active{transform:translateY(0)}.voice-grid::-webkit-scrollbar{width:10px}.voice-grid::-webkit-scrollbar-track{background:#f1f1f1;border-radius:5px;margin:4px 0}.voice-grid::-webkit-scrollbar-thumb{background:#2563eb;border-radius:5px;border:2px solid #f1f1f1}.voice-grid::-webkit-scrollbar-thumb:hover{background:#1d4ed8}@media (max-width: 1024px){.voice-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.voice-selector{padding:20px}.selector-header{flex-direction:column;align-items:flex-start;gap:10px}.voice-count{align-self:flex-start}.voice-grid{grid-template-columns:1fr;max-height:450px}.voice-filters{flex-direction:column;gap:10px}.filter-select{width:100%;min-width:0}.voice-card{padding:16px}.voice-name{font-size:1.05rem}.no-voices{padding:40px 20px}}@media (max-width: 480px){.voice-selector h3{font-size:1.25rem}.search-input{font-size:.9rem;padding:10px 36px 10px 40px}.voice-filters{gap:8px}.filter-select{font-size:.9rem;padding:8px 12px;min-width:0}}.cloned-voices-section{margin:20px 0;padding:15px;background:linear-gradient(135deg,#f0f7ff,#e8f4ff);border-radius:10px;border:2px solid #d0e4ff}.section-title{margin:10px 0;color:#1a5cb8;font-size:1rem;font-weight:600}.cloned-slider{display:flex;gap:15px;overflow-x:auto;padding:10px 0}.voice-card-compact.cloned{background:linear-gradient(135deg,#fff,#f8fafc);border:2px solid #6366f1}.voice-card-compact.cloned:hover{border-color:#4f46e5;box-shadow:0 4px 12px #6366f133}.voice-card-compact.cloned.selected{background:linear-gradient(135deg,#eef2ff,#e0e7ff);border-color:#4f46e5}.voice-badge-cloned{display:inline-block;padding:2px 8px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-radius:12px;font-size:.7rem;font-weight:600;letter-spacing:.5px}.convert-container{max-width:50%;width:100%;margin:0 auto;padding:2rem 3rem 3rem}.player-active .convert-container{padding-bottom:0}.convert-container h1{text-align:center;margin-bottom:2rem;color:var(--text-primary);font-weight:700}.convert-tabs-container{background:#fff;border-radius:16px;border:1px solid var(--border);box-shadow:0 2px 4px #0000000a;margin-bottom:2rem;overflow:hidden}.tabs-header{display:flex;border-bottom:2px solid var(--border);background:#f8f9fa}.tab-btn{flex:1;padding:1rem 2rem;background:transparent;border:none;font-size:1rem;font-weight:600;color:#6c757d;cursor:pointer;transition:all .2s ease;position:relative}.tab-btn:hover{background:#4f46e50d;color:var(--primary-color)}.tab-btn.active{color:var(--primary-color);background:#fff}.tab-btn.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:3px;background:var(--primary-color)}.tab-content{padding:2rem}.tab-content form{display:flex;flex-direction:column}.input-group{margin-bottom:1rem}.input-label{display:block;margin-bottom:.5rem;font-size:.9rem;font-weight:600;color:var(--text-secondary)}.track-name-input{width:100%;padding:.875rem 1rem;border:1.5px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text-primary);font-size:1rem;font-family:inherit;box-sizing:border-box;transition:all .2s ease}.track-name-input:focus{outline:none;border-color:var(--primary-color);background:#fff;box-shadow:0 0 0 3px #4f46e51a}.track-name-input:disabled{opacity:.6;cursor:not-allowed}.text-input{width:100%;padding:1rem;border:1.5px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text-primary);font-size:1rem;font-family:inherit;resize:vertical;margin-bottom:1rem;box-sizing:border-box;transition:all .2s ease;user-select:text;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text}.text-input:focus{outline:none;border-color:var(--primary-color);background:#fff;box-shadow:0 0 0 3px #4f46e51a}.file-upload-area{display:flex;flex-direction:column;align-items:center;padding:3rem 2rem;border:2px dashed var(--border);border-radius:12px;background:var(--surface);margin-bottom:1rem;transition:all .2s ease}.file-upload-area:hover{border-color:var(--primary-color);background:var(--primary-light)}.upload-icon{margin-bottom:1rem;color:#adb5bd;transition:all .2s ease}.file-upload-area:hover .upload-icon{color:var(--primary-color);transform:translateY(-3px)}.file-input-wrapper{width:100%;max-width:400px;text-align:center}.file-input-wrapper input[type=file]{display:none}.file-input-label{display:block;padding:.75rem 1.5rem;background:#fff;border:2px solid var(--primary-color);border-radius:8px;color:var(--primary-color);font-weight:600;cursor:pointer;transition:all .2s ease}.file-input-label:hover{background:var(--primary-color);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #4f46e54d}.file-types{margin-top:1rem;font-size:.9rem;color:#6c757d}.convert-methods{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:2rem;margin-bottom:2rem}.method-card{background:#fff;padding:2rem;border-radius:16px;border:1px solid var(--border);box-shadow:0 2px 4px #0000000a;transition:all .2s ease}.method-card:hover{box-shadow:0 8px 16px #00000014}.method-card h2{margin-top:0;margin-bottom:1.5rem;font-size:1.5rem;color:var(--text-primary);font-weight:600}.method-card textarea{width:100%;padding:1rem;border:1.5px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text-primary);font-size:1rem;font-family:inherit;resize:vertical;margin-bottom:1rem;box-sizing:border-box;transition:all .2s ease;user-select:text;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text}.method-card textarea:focus{outline:none;border-color:var(--primary-color);background:#fff;box-shadow:0 0 0 3px #4f46e51a}.file-name{margin-top:.5rem;color:var(--primary-color);font-size:.9rem;font-weight:500}.submit-btn{width:100%;padding:.875rem;background:var(--primary-color);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #2563eb33}.submit-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 8px #2563eb4d}.submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.result-card{background:#fff;padding:2rem;border-radius:16px;margin-top:2rem;border:1px solid var(--border);box-shadow:0 2px 4px #0000000a}.result-card h2{margin-top:0;margin-bottom:1.5rem;color:var(--text-primary);font-weight:600}.result-info p{margin:.5rem 0;color:var(--text-secondary)}.audio-player{margin-top:1.5rem;display:flex;flex-direction:column;gap:1rem}.audio-player audio{width:100%;max-width:500px;border-radius:8px}.download-btn{display:inline-block;padding:.75rem 1.5rem;background:var(--primary-color);color:#fff;text-decoration:none;border-radius:8px;text-align:center;max-width:200px;transition:all .2s ease;font-weight:600;box-shadow:0 2px 4px #2563eb33}.download-btn:hover{transform:translateY(-1px);box-shadow:0 4px 8px #2563eb4d}.error-text{color:var(--error);font-weight:500}.info-text{color:var(--text-secondary);line-height:1.6;margin:.75rem 0}.processing-message{background:#f0f9ff;border-left:4px solid #3b82f6;padding:1rem 1.25rem;border-radius:8px;margin-top:1rem}.link-btn{background:none;border:none;color:var(--primary-color);cursor:pointer;text-decoration:underline;font-size:inherit;font-weight:600;padding:0;transition:color .2s ease}.link-btn:hover{color:var(--primary-hover)}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-weight:600;font-size:.875rem;text-transform:capitalize}.status-completed{background:#d1fae5;color:#065f46}.status-processing{background:#fef3c7;color:#92400e}.advanced-controls{background:#fff;padding:1.5rem;border-radius:16px;margin:2rem 0;border:1px solid var(--border);box-shadow:0 2px 4px #0000000a}.toggle-advanced-btn{background:none;border:none;color:var(--primary-color);font-size:1.1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem;padding:.5rem;transition:all .2s ease}.toggle-advanced-btn:hover{color:var(--primary-hover)}.advanced-options{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border)}.control-group{margin-bottom:2rem}.control-group label{display:block;font-weight:600;color:var(--text-primary);margin-bottom:.75rem;font-size:1rem}.control-value{color:var(--primary-color);font-weight:700;margin-left:.5rem}.slider{width:100%;height:6px;border-radius:3px;background:#e2e8f0;outline:none;-webkit-appearance:none;margin:.5rem 0}.slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--primary-color);cursor:pointer;box-shadow:0 2px 4px #4f46e54d;transition:all .2s ease}.slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 3px 8px #4f46e566}.slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--primary-color);cursor:pointer;border:none;box-shadow:0 2px 4px #4f46e54d;transition:all .2s ease}.slider::-moz-range-thumb:hover{transform:scale(1.2);box-shadow:0 3px 8px #4f46e566}.slider-labels{display:flex;justify-content:space-between;font-size:.85rem;color:var(--text-secondary);margin-top:.25rem}.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary-color)}.blend-controls{margin-top:1.5rem;padding:1.5rem;background:var(--surface);border-radius:8px;border:1px solid var(--border)}.blend-voice-select{margin-bottom:1.5rem}.blend-voice-select label{display:block;font-weight:600;margin-bottom:.5rem;color:var(--text-primary)}.voice-dropdown{width:100%;padding:.75rem;border:1.5px solid var(--border);border-radius:8px;background:#fff;color:var(--text-primary);font-size:.95rem;cursor:pointer;transition:all .2s ease}.voice-dropdown:hover{border-color:var(--primary-color)}.voice-dropdown:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4f46e51a}.blend-ratio label{font-size:.95rem}.usage-info-banner{background:#f0f9ff;border:2px solid #0ea5e9;border-radius:12px;padding:1.25rem;margin-bottom:1.5rem;box-shadow:0 2px 8px #0ea5e91a}.usage-info-banner.usage-depleted{background:#fef2f2;border-color:#ef4444;box-shadow:0 2px 8px #ef444426}.usage-content{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;flex-wrap:wrap;gap:1rem}.usage-text{font-size:1rem;color:#1e293b;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.usage-text strong{font-weight:600}.usage-depleted-text{color:#dc2626;font-weight:600}.usage-progress-bar{width:100%;height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden}.usage-progress-fill{height:100%;transition:width .3s ease,background-color .3s ease;border-radius:4px}.upgrade-btn-inline{padding:.5rem 1rem;background:var(--primary-color);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #2563eb33}.upgrade-btn-inline:hover{transform:translateY(-2px);box-shadow:0 4px 8px #2563eb4d}@media (max-width: 768px){.convert-container{padding:1.5rem;max-width:100%}.player-active .convert-container{padding-bottom:120px}.convert-methods{grid-template-columns:1fr}.tabs-header{flex-direction:row}.tab-btn{padding:.875rem 1rem;font-size:.95rem}.tab-content{padding:1.5rem}.file-upload-area{padding:2rem 1rem}.slider-labels{font-size:.75rem}.advanced-controls{padding:1rem}.usage-content{flex-direction:column;align-items:flex-start}.upgrade-btn-inline{width:100%}}@media (max-width: 480px){.convert-container h1{font-size:1.5rem}.tab-btn{padding:.75rem .5rem;font-size:.9rem}.tab-content{padding:1rem}.file-upload-area{padding:1.5rem .75rem}.upload-icon{width:36px;height:36px}}:root{--swiper-theme-color: #007aff}:host{position:relative;display:block;margin-left:auto;margin-right:auto;z-index:1}.swiper{margin-left:auto;margin-right:auto;position:relative;overflow:hidden;list-style:none;padding:0;z-index:1;display:block}.swiper-vertical>.swiper-wrapper{flex-direction:column}.swiper-wrapper{position:relative;width:100%;height:100%;z-index:1;display:flex;transition-property:transform;transition-timing-function:var(--swiper-wrapper-transition-timing-function, initial);box-sizing:content-box}.swiper-android .swiper-slide,.swiper-ios .swiper-slide,.swiper-wrapper{transform:translateZ(0)}.swiper-horizontal{touch-action:pan-y}.swiper-vertical{touch-action:pan-x}.swiper-slide{flex-shrink:0;width:100%;height:100%;position:relative;transition-property:transform;display:block}.swiper-slide-invisible-blank{visibility:hidden}.swiper-autoheight,.swiper-autoheight .swiper-slide{height:auto}.swiper-autoheight .swiper-wrapper{align-items:flex-start;transition-property:transform,height}.swiper-backface-hidden .swiper-slide{transform:translateZ(0);backface-visibility:hidden}.swiper-3d.swiper-css-mode .swiper-wrapper{perspective:1200px}.swiper-3d .swiper-wrapper{transform-style:preserve-3d}.swiper-3d{perspective:1200px}.swiper-3d .swiper-slide,.swiper-3d .swiper-cube-shadow{transform-style:preserve-3d}.swiper-css-mode>.swiper-wrapper{overflow:auto;scrollbar-width:none;-ms-overflow-style:none}.swiper-css-mode>.swiper-wrapper::-webkit-scrollbar{display:none}.swiper-css-mode>.swiper-wrapper>.swiper-slide{scroll-snap-align:start start}.swiper-css-mode.swiper-horizontal>.swiper-wrapper{scroll-snap-type:x mandatory}.swiper-css-mode.swiper-vertical>.swiper-wrapper{scroll-snap-type:y mandatory}.swiper-css-mode.swiper-free-mode>.swiper-wrapper{scroll-snap-type:none}.swiper-css-mode.swiper-free-mode>.swiper-wrapper>.swiper-slide{scroll-snap-align:none}.swiper-css-mode.swiper-centered>.swiper-wrapper:before{content:"";flex-shrink:0;order:9999}.swiper-css-mode.swiper-centered>.swiper-wrapper>.swiper-slide{scroll-snap-align:center center;scroll-snap-stop:always}.swiper-css-mode.swiper-centered.swiper-horizontal>.swiper-wrapper>.swiper-slide:first-child{margin-inline-start:var(--swiper-centered-offset-before)}.swiper-css-mode.swiper-centered.swiper-horizontal>.swiper-wrapper:before{height:100%;min-height:1px;width:var(--swiper-centered-offset-after)}.swiper-css-mode.swiper-centered.swiper-vertical>.swiper-wrapper>.swiper-slide:first-child{margin-block-start:var(--swiper-centered-offset-before)}.swiper-css-mode.swiper-centered.swiper-vertical>.swiper-wrapper:before{width:100%;min-width:1px;height:var(--swiper-centered-offset-after)}.swiper-3d .swiper-slide-shadow,.swiper-3d .swiper-slide-shadow-left,.swiper-3d .swiper-slide-shadow-right,.swiper-3d .swiper-slide-shadow-top,.swiper-3d .swiper-slide-shadow-bottom{position:absolute;left:0;top:0;width:100%;height:100%;pointer-events:none;z-index:10}.swiper-3d .swiper-slide-shadow{background:#00000026}.swiper-3d .swiper-slide-shadow-left{background-image:linear-gradient(to left,#00000080,#0000)}.swiper-3d .swiper-slide-shadow-right{background-image:linear-gradient(to right,#00000080,#0000)}.swiper-3d .swiper-slide-shadow-top{background-image:linear-gradient(to top,#00000080,#0000)}.swiper-3d .swiper-slide-shadow-bottom{background-image:linear-gradient(to bottom,#00000080,#0000)}.swiper-lazy-preloader{width:42px;height:42px;position:absolute;left:50%;top:50%;margin-left:-21px;margin-top:-21px;z-index:10;transform-origin:50%;box-sizing:border-box;border:4px solid var(--swiper-preloader-color, var(--swiper-theme-color));border-radius:50%;border-top-color:transparent}.swiper:not(.swiper-watch-progress) .swiper-lazy-preloader,.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader{animation:swiper-preloader-spin 1s infinite linear}.swiper-lazy-preloader-white{--swiper-preloader-color: #fff}.swiper-lazy-preloader-black{--swiper-preloader-color: #000}@keyframes swiper-preloader-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.swiper-pagination{position:absolute;text-align:center;transition:.3s opacity;transform:translateZ(0);z-index:10}.swiper-pagination.swiper-pagination-hidden{opacity:0}.swiper-pagination-disabled>.swiper-pagination,.swiper-pagination.swiper-pagination-disabled{display:none!important}.swiper-pagination-fraction,.swiper-pagination-custom,.swiper-horizontal>.swiper-pagination-bullets,.swiper-pagination-bullets.swiper-pagination-horizontal{bottom:var(--swiper-pagination-bottom, 8px);top:var(--swiper-pagination-top, auto);left:0;width:100%}.swiper-pagination-bullets-dynamic{overflow:hidden;font-size:0}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{transform:scale(.33);position:relative}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active,.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main{transform:scale(1)}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev{transform:scale(.66)}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev{transform:scale(.33)}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next{transform:scale(.66)}.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next{transform:scale(.33)}.swiper-pagination-bullet{width:var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));height:var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));display:inline-block;border-radius:var(--swiper-pagination-bullet-border-radius, 50%);background:var(--swiper-pagination-bullet-inactive-color, #000);opacity:var(--swiper-pagination-bullet-inactive-opacity, .2)}button.swiper-pagination-bullet{border:none;margin:0;padding:0;box-shadow:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.swiper-pagination-clickable .swiper-pagination-bullet{cursor:pointer}.swiper-pagination-bullet:only-child{display:none!important}.swiper-pagination-bullet-active{opacity:var(--swiper-pagination-bullet-opacity, 1);background:var(--swiper-pagination-color, var(--swiper-theme-color))}.swiper-vertical>.swiper-pagination-bullets,.swiper-pagination-vertical.swiper-pagination-bullets{right:var(--swiper-pagination-right, 8px);left:var(--swiper-pagination-left, auto);top:50%;transform:translate3d(0,-50%,0)}.swiper-vertical>.swiper-pagination-bullets .swiper-pagination-bullet,.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet{margin:var(--swiper-pagination-bullet-vertical-gap, 6px) 0;display:block}.swiper-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic{top:50%;transform:translateY(-50%);width:8px}.swiper-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{display:inline-block;transition:.2s transform,.2s top}.swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet,.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet{margin:0 var(--swiper-pagination-bullet-horizontal-gap, 4px)}.swiper-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic{left:50%;transform:translate(-50%);white-space:nowrap}.swiper-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{transition:.2s transform,.2s left}.swiper-horizontal.swiper-rtl>.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{transition:.2s transform,.2s right}.swiper-pagination-fraction{color:var(--swiper-pagination-fraction-color, inherit)}.swiper-pagination-progressbar{background:var(--swiper-pagination-progressbar-bg-color, rgba(0, 0, 0, .25));position:absolute}.swiper-pagination-progressbar .swiper-pagination-progressbar-fill{background:var(--swiper-pagination-color, var(--swiper-theme-color));position:absolute;left:0;top:0;width:100%;height:100%;transform:scale(0);transform-origin:left top}.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill{transform-origin:right top}.swiper-horizontal>.swiper-pagination-progressbar,.swiper-pagination-progressbar.swiper-pagination-horizontal,.swiper-vertical>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,.swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite{width:100%;height:var(--swiper-pagination-progressbar-size, 4px);left:0;top:0}.swiper-vertical>.swiper-pagination-progressbar,.swiper-pagination-progressbar.swiper-pagination-vertical,.swiper-horizontal>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,.swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite{width:var(--swiper-pagination-progressbar-size, 4px);height:100%;left:0;top:0}.swiper-pagination-lock{display:none}@media (max-width: 768px){.pricing-container{padding:1.5rem 0;min-height:100vh;max-width:100vw;display:flex;flex-direction:column;overflow:hidden}.player-active .pricing-container{padding-bottom:220px}.pricing-container h1{font-size:1.75rem;margin-bottom:.5rem;padding:0 1rem;color:var(--text-primary);font-weight:700}.pricing-subtitle{font-size:1rem;margin-bottom:1.5rem;padding:0 1rem;color:var(--text-secondary)}.pricing-swiper{width:100vw;max-width:100%;height:auto;padding:0 0 3.5rem!important;overflow:visible}.swiper-wrapper{padding:.5rem 0;max-width:100vw}.swiper-slide{display:flex!important;justify-content:center!important;align-items:center!important;height:auto!important;width:100vw!important;max-width:100%!important;padding:0 .75rem!important;box-sizing:border-box}.pricing-cards{display:none}.pricing-card{width:100%;max-width:100%;margin:0;border-radius:20px;box-shadow:0 4px 20px #0000001f;padding:2rem 1.25rem 1.5rem;background:#fff;position:relative;border:2px solid #e5e7eb;display:flex;flex-direction:column;box-sizing:border-box}.pricing-card.premium-tier{border:2px solid var(--primary-color)}.plan-header{padding-top:.5rem}.plan-header h2{font-size:1.75rem;margin-bottom:1rem;text-align:center;color:var(--text-primary);font-weight:700}.premium-tier .plan-header h2{color:var(--primary-color)}.price{margin-bottom:1.5rem;display:flex;align-items:baseline;justify-content:center;gap:.25rem}.currency{font-size:1.5rem;font-weight:600;color:var(--text-primary)}.amount{font-size:3rem;font-weight:800;color:var(--text-primary)}.period{font-size:1.1rem;color:var(--text-secondary);font-weight:500}.features-list{margin:1rem 0;font-size:.95rem;padding-left:0;list-style:none;text-align:left;flex:1}.features-list li{padding:.6rem 0;font-size:.95rem;line-height:1.5;color:var(--text-primary);border-bottom:1px solid #f3f4f6;display:flex;align-items:center}.features-list li:last-child{border-bottom:none}.features-list li:before{content:"✓";color:var(--success);font-weight:700;margin-right:.75rem;flex-shrink:0;font-size:1.1rem}.subscribe-btn{width:100%;padding:1rem;font-size:1.1rem;font-weight:600;border-radius:12px;margin-top:1.5rem;min-height:48px;letter-spacing:.02em;box-shadow:0 4px 12px #00000026;display:block;transition:transform .2s,box-shadow .2s;color:#fff;border:none;cursor:pointer}.free-btn{background:linear-gradient(135deg,#6b7280,#4b5563)}.premium-btn{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-hover) 100%)}.subscribe-btn:active{transform:scale(.98)}.popular-badge{font-size:.75rem;padding:.5rem 1rem;top:1rem;right:1rem;border-radius:20px;position:absolute;z-index:2;box-shadow:0 2px 8px #0003;background:var(--primary-color);color:#fff;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.pricing-note{font-size:.875rem;margin-top:.75rem;margin-bottom:0;text-align:center;color:var(--text-secondary);line-height:1.4}.features-list strong{font-size:1.05rem}.swiper-pagination{position:absolute!important;bottom:20px!important;left:0!important;width:100%!important;display:flex!important;justify-content:center!important;align-items:center!important;gap:10px!important;z-index:10!important}.swiper-pagination-bullet{width:12px!important;height:12px!important;background:var(--primary-color)!important;opacity:.5!important;margin:0!important;border-radius:50%!important;transition:all .3s ease!important;display:inline-block!important}.swiper-pagination-bullet-active{opacity:1!important;width:32px!important;height:12px!important;border-radius:6px!important;background:var(--primary-color)!important}}.pricing-container{max-width:1200px;margin:0 auto;padding:.5rem 2rem 3rem;text-align:center;min-height:100vh;display:flex;flex-direction:column;justify-content:center}.player-active .pricing-container{padding-bottom:calc(3rem + 140px)}.pricing-container h1{font-size:2rem;margin:0 0 .5rem;color:var(--text-primary);font-weight:700}.pricing-subtitle{font-size:1rem;color:var(--text-secondary);margin:0 0 1rem;line-height:1.4}.pricing-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem;max-width:900px;margin:0 auto}.pricing-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 4px 6px #0000000d,0 10px 15px #0000000d;border:2px solid #e5e7eb;position:relative;overflow:hidden;transition:all .3s ease;display:flex;flex-direction:column}.pricing-card:hover{transform:translateY(-5px);box-shadow:0 12px 24px #0000001a}.pricing-card.premium-tier{border:2px solid var(--primary-color)}.popular-badge{position:absolute;top:1rem;right:1rem;background:var(--primary-color);color:#fff;padding:.5rem 1rem;font-size:.85rem;font-weight:600;border-radius:20px;text-transform:uppercase;letter-spacing:.5px}.plan-header h2{margin:0 0 .75rem;font-size:1.5rem;color:var(--text-primary);font-weight:700}.premium-tier .plan-header h2{color:var(--primary-color)}.price{margin-bottom:1rem}.currency{font-size:1.5rem;vertical-align:top;color:var(--text-primary);font-weight:600;-webkit-user-select:none;user-select:none}.amount{font-size:3rem;font-weight:800;color:var(--text-primary);-webkit-user-select:none;user-select:none}.period{font-size:1.2rem;color:var(--text-secondary);font-weight:500;-webkit-user-select:none;user-select:none}.features-list{list-style:none;padding:0;margin:1rem 0;text-align:left;flex:1}.features-list li{padding:.5rem 0;font-size:.95rem;color:var(--text-primary);border-bottom:1px solid var(--border);display:flex;align-items:center}.features-list li:before{content:"✓";color:var(--success);font-weight:700;margin-right:.5rem;font-size:1rem}.features-list li:last-child{border-bottom:none}.subscribe-btn{width:100%;padding:.9rem;font-size:1rem;font-weight:600;color:#fff;border:none;border-radius:10px;cursor:pointer;transition:all .2s ease;margin-top:.75rem}.free-btn{background:#6b7280;box-shadow:0 4px 12px #6b728040}.free-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #6b728059}.premium-btn{background:var(--primary-color);box-shadow:0 4px 12px #2563eb40}.premium-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #2563eb59}.pricing-note{margin-top:.75rem;color:var(--text-secondary);font-size:.85rem}.mobile-pricing{background:#f9fafb;min-height:100vh;padding:0;max-width:100vw;overflow-x:hidden;display:flex;flex-direction:column;justify-content:center;align-items:center}.pricing-header-mobile{text-align:center;padding:0 1rem 1rem;max-width:100%;width:100%}.pricing-header-mobile h1{font-size:2rem;font-weight:800;color:#111827;margin:0 0 .5rem}.pricing-header-mobile .pricing-subtitle{font-size:1rem;color:#6b7280;margin:0}.pricing-swiper-mobile{width:100vw;max-width:100%;padding:0 0 2.5rem!important;margin:0;overflow:visible}.pricing-swiper-mobile .swiper-wrapper{padding:1rem 0;align-items:center}.pricing-swiper-mobile .swiper-slide{display:flex!important;justify-content:center!important;align-items:center!important;height:auto!important;padding:0 1rem!important;box-sizing:border-box}.mobile-card{background:#fff;border-radius:20px;padding:2rem 1.5rem;box-shadow:0 4px 12px #00000014;border:2px solid #e5e7eb;position:relative;max-width:340px;width:calc(100vw - 3rem);margin:0 auto;box-sizing:border-box}.mobile-card.premium-tier{border-color:var(--primary-color);box-shadow:0 8px 20px #2563eb26}.mobile-badge{position:absolute;top:1rem;right:1rem;background:var(--primary-color);color:#fff;padding:.4rem .9rem;border-radius:20px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.mobile-plan-header{text-align:center;margin-bottom:1.5rem}.mobile-plan-header h2{font-size:1.5rem;font-weight:700;color:#111827;margin:0 0 1rem}.premium-tier .mobile-plan-header h2{color:var(--primary-color)}.mobile-price{display:flex;align-items:baseline;justify-content:center;gap:.25rem}.mobile-amount{font-size:3rem;font-weight:800;color:#111827}.mobile-period{font-size:1rem;color:#6b7280;font-weight:500}.mobile-features{list-style:none;padding:0;margin:0 0 1.5rem}.mobile-features li{padding:.75rem 0;font-size:.95rem;color:#374151;border-bottom:1px solid #f3f4f6;display:flex;align-items:center;line-height:1.4}.mobile-features li:last-child{border-bottom:none}.mobile-features li:before{content:"✓";color:#10b981;font-weight:700;font-size:1.1rem;margin-right:.75rem;flex-shrink:0}.mobile-features li strong{font-weight:700;color:#111827}.mobile-btn{width:100%;padding:1rem;font-size:1rem;font-weight:700;border:none;border-radius:12px;cursor:pointer;transition:all .2s;color:#fff;text-align:center;box-shadow:0 4px 12px #00000026}.mobile-btn.free-btn{background:linear-gradient(135deg,#6b7280,#4b5563)}.mobile-btn.premium-btn{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-hover) 100%)}.mobile-btn:active{transform:scale(.98)}.mobile-note{text-align:center;font-size:.85rem;color:#6b7280;margin:.75rem 0 0}.pricing-swiper-mobile .swiper-pagination{bottom:.5rem!important}.pricing-swiper-mobile .swiper-pagination-bullet{width:8px!important;height:8px!important;background:#d1d5db!important;opacity:1!important}.pricing-swiper-mobile .swiper-pagination-bullet-active{background:var(--primary-color)!important;width:24px!important;border-radius:4px!important}.mobile-value-props,.value-item,.value-icon,.pricing-cards-mobile{display:none}@media (max-width: 480px){.pricing-container:not(.mobile-pricing){padding:.5rem 0rem 0rem}.pricing-container:not(.mobile-pricing) h1{font-size:1.4rem;margin-bottom:.7rem}.pricing-container:not(.mobile-pricing) .pricing-subtitle{font-size:1rem;margin-bottom:2rem}.pricing-cards{gap:1rem;max-width:100%;display:flex;flex-direction:column;align-items:stretch}.pricing-card{padding:1.5rem .7rem;font-size:.95rem;border-radius:10px;min-width:0;box-sizing:border-box;margin:0 0 1rem}.plan-header h2{font-size:1.2rem;margin-bottom:.7rem}.price{margin-bottom:1.2rem;display:flex;flex-wrap:wrap;align-items:baseline}.currency{font-size:1.2rem;margin-right:.2rem}.amount{font-size:2.2rem;margin-right:.2rem}.period{font-size:1rem}.features-list{margin:1rem 0;font-size:.95rem;padding-left:.2rem}.features-list li{padding:.5rem 0;font-size:.95rem;line-height:1.3;word-break:break-word}.subscribe-btn{padding:.8rem;font-size:1rem;border-radius:8px;margin-top:.7rem;min-height:48px;min-width:120px;letter-spacing:.02em;box-shadow:0 2px 8px #00000014}.popular-badge{font-size:.7rem;padding:.3rem .7rem;top:.7rem;right:.7rem;border-radius:16px}.pricing-note{font-size:.8rem;margin-top:1rem;margin-bottom:.5rem;text-align:center}.features-list strong{font-size:1.05rem}.pricing-card.free-tier{margin-bottom:1.5rem}.pricing-card.premium-tier{margin-bottom:.5rem}}.subscription-container{max-width:800px;margin:0 auto;padding:1rem 2rem 5rem}.player-active .subscription-container{padding-bottom:calc(5rem + 140px)}.subscription-container h1{margin-bottom:2rem;text-align:center;color:var(--text-primary);font-weight:700}.no-subscription{text-align:center;padding:4rem 2rem;background:#fff;border-radius:16px;border:1px solid var(--border);box-shadow:0 2px 4px #0000000a}.no-subscription p{font-size:1.2rem;color:var(--text-secondary);margin-bottom:1.5rem}.subscribe-link{display:inline-block;padding:1rem 2rem;background:var(--primary-color);color:#fff;text-decoration:none;border-radius:10px;font-weight:600;transition:all .2s ease;box-shadow:0 4px 12px #2563eb40}.subscribe-link:hover{transform:translateY(-2px);box-shadow:0 6px 16px #2563eb59}.subscription-card{background:#fff;padding:2rem;border-radius:16px;border:1px solid var(--border);box-shadow:0 2px 4px #0000000a}.subscription-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--border)}.subscription-header h2{margin:0;font-size:1.8rem;color:var(--text-primary);font-weight:700}.status-badge{padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:600;color:#fff;text-transform:capitalize}.subscription-details{margin-bottom:2rem}.detail-row{display:flex;justify-content:space-between;padding:1rem 0;border-bottom:1px solid var(--border)}.detail-row:last-child{border-bottom:none}.detail-label{color:var(--text-secondary);font-weight:600;-webkit-user-select:none;user-select:none}.detail-value{color:var(--text-primary);font-weight:600}.manage-btn{width:100%;padding:1rem;background:var(--primary-color);color:#fff;border:none;border-radius:10px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-bottom:1rem;box-shadow:0 2px 4px #2563eb33}.manage-btn:hover{transform:translateY(-1px);box-shadow:0 4px 8px #2563eb4d}.manage-note{text-align:center;color:#aaa;font-size:.9rem;margin-top:1rem}.sync-btn{display:inline-block;padding:1rem 2rem;background:#10b981;color:#fff;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #10b98140}.sync-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #10b98159}.sync-btn:disabled{background:#9ca3af;cursor:not-allowed;box-shadow:none}.container{max-width:100%;padding:1rem;min-height:100vh}.container.mobile{padding-bottom:5rem}.header{text-align:center;margin-bottom:1.5rem}.header h1{font-size:1.5rem;color:var(--text-primary);margin:0}.loading{text-align:center;padding:2rem;color:var(--text-secondary)}.noSubscription{text-align:center;padding:3rem 1.5rem;background:#fff;border-radius:12px;border:1px solid var(--border)}.noSubscription p{color:var(--text-secondary);margin-bottom:1.5rem}.card{background:#fff;padding:1.5rem;border-radius:12px;border:1px solid var(--border);margin-bottom:1rem;box-shadow:0 2px 4px #0000000a}.card h2{margin:0 0 1rem;font-size:1.3rem;color:var(--text-primary)}.planInfo{display:flex;flex-direction:column;gap:.5rem}.planName{font-size:1.2rem;font-weight:700;color:var(--text-primary);margin:0}.planStatus{color:var(--text-secondary);margin:0}.planStatus .status-active{color:#10b981;font-weight:600}.planStatus .status-past_due{color:#f59e0b;font-weight:600}.planStatus .status-canceled{color:#ef4444;font-weight:600}.planStatus .status-incomplete{color:#3b82f6;font-weight:600}.usageInfo{display:flex;flex-direction:column;gap:.75rem}.usageBar{width:100%;height:8px;background:var(--border);border-radius:4px;overflow:hidden}.usageProgress{height:100%;background:var(--primary-color);transition:width .3s ease}.actions{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.btnPrimary{width:100%;padding:1rem;background:var(--primary-color);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btnPrimary:hover{transform:translateY(-1px);box-shadow:0 4px 8px #2563eb4d}.btnSecondary{width:100%;padding:1rem;background:#fff;color:var(--primary-color);border:2px solid var(--primary-color);border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btnSecondary:hover:not(:disabled){background:var(--primary-color);color:#fff}.btnSecondary:disabled{opacity:.5;cursor:not-allowed}.success-container{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 80px);padding:2rem}.success-card{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;padding:3rem 2rem;max-width:500px;width:100%;text-align:center}.success-icon{display:flex;justify-content:center;margin-bottom:2rem;animation:scaleIn .5s ease-out}@keyframes scaleIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.success-card h1{color:#2c3e50;margin-bottom:1rem;font-size:2rem}.success-card p{color:#555;margin-bottom:1rem;font-size:1.1rem}.redirect-message{margin:2rem 0;padding:1rem;background:#f0f9ff;border-radius:8px;color:#0369a1;font-weight:500}.success-card .btn-primary{margin-top:1rem;padding:.75rem 2rem;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .3s ease}.success-card .btn-primary:hover{background:#2563eb}@media (max-width: 768px){.success-card{padding:2rem 1.5rem}.success-card h1{font-size:1.5rem}.success-card p{font-size:1rem}}.admin-container{max-width:1400px;margin:0 auto;padding:2rem}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.admin-header h1{font-size:2rem;color:#1f2937}.refresh-btn{padding:.5rem 1rem;background:#6366f1;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;transition:background .2s}.refresh-btn:hover{background:#4f46e5}.admin-tabs{display:flex;gap:1rem;margin-bottom:2rem;border-bottom:2px solid #e5e7eb}.admin-tabs button{padding:.75rem 1.5rem;background:none;border:none;color:#6b7280;font-size:1rem;cursor:pointer;border-bottom:3px solid transparent;transition:all .2s}.admin-tabs button:hover{color:#374151}.admin-tabs button.active{color:#6366f1;border-bottom-color:#6366f1}.admin-content{animation:fadeIn .3s}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:3rem}.stat-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.stat-card h3{font-size:.9rem;color:#6b7280;margin-bottom:.5rem;text-transform:uppercase;font-weight:600}.stat-value{font-size:2.5rem;font-weight:700;color:#1f2937;margin:.5rem 0}.stat-detail{font-size:.9rem;color:#6b7280;margin:0}.section{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.section h2{font-size:1.5rem;color:#1f2937;margin-bottom:1.5rem}.table-container{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-size:.9rem}.admin-table thead{background:#f9fafb}.admin-table th{padding:1rem;text-align:left;font-weight:600;color:#374151;border-bottom:2px solid #e5e7eb}.admin-table td{padding:1rem;border-bottom:1px solid #e5e7eb;color:#1f2937}.admin-table tr:hover{background:#f9fafb}.status{padding:.25rem .75rem;border-radius:9999px;font-size:.85rem;font-weight:600;display:inline-block}.status.active,.status.completed{background:#d1fae5;color:#065f46}.status.inactive,.status.failed,.status.canceled{background:#fee2e2;color:#991b1b}.status.processing,.status.pending{background:#fef3c7;color:#92400e}.status.free{background:#e5e7eb;color:#374151}.status.past_due{background:#fed7aa;color:#9a3412}.revenue-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.revenue-card{background:#f9fafb;padding:1.5rem;border-radius:8px;text-align:center}.revenue-card h4{font-size:.85rem;color:#6b7280;margin-bottom:.5rem;text-transform:uppercase;font-weight:600}.revenue-value{font-size:2rem;font-weight:700;color:#1f2937;margin:0}.health-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.health-card{background:#f9fafb;padding:1.5rem;border-radius:8px}.health-card h4{font-size:.9rem;color:#6b7280;margin-bottom:.5rem;text-transform:uppercase;font-weight:600}.health-value{font-size:2rem;font-weight:700;color:#1f2937;margin:.5rem 0}.health-value.healthy{color:#059669}.health-value.error{color:#dc2626}.health-detail{font-size:.85rem;color:#6b7280;margin:0}.loading,.error{text-align:center;padding:3rem;font-size:1.1rem;color:#6b7280}.error{color:#dc2626}@media (max-width: 768px){.admin-container{padding:1rem}.admin-header{flex-direction:column;align-items:flex-start;gap:1rem}.admin-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.stats-grid{grid-template-columns:1fr}.admin-table{font-size:.8rem}.admin-table th,.admin-table td{padding:.5rem}.stat-value{font-size:2rem}}.voice-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:1001;padding:20px;overflow-y:auto;-webkit-overflow-scrolling:touch}.voice-modal-content{background:#fff;border-radius:16px;width:100%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;margin:auto}.voice-modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 16px;border-bottom:2px solid #e5e7eb;position:sticky;top:0;background:#fff;z-index:10;border-radius:16px 16px 0 0}.voice-modal-header h2{font-size:1.5rem;font-weight:600;color:#1f2937;margin:0;flex-grow:1}.voice-modal-current{padding:16px 24px;background:#f9fafb;border-bottom:1px solid #e5e7eb}.current-selection{display:flex;align-items:center;gap:12px}.current-selection .label{font-size:.875rem;color:#6b7280;font-weight:500}.current-selection .value{font-size:.9375rem;color:#1f2937;font-weight:600}.voice-modal-filters{padding:20px 24px;display:flex;gap:12px;flex-wrap:wrap;border-bottom:1px solid #e5e7eb;background:#fff;position:sticky;top:73px;z-index:9}.search-wrapper{position:relative;flex:1;min-width:200px}.voice-search-input{width:100%;padding:12px 40px 12px 16px;border:2px solid #d1d5db;border-radius:8px;font-size:15px;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.voice-search-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 4px #6366f126}.clear-search{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:#e5e7eb;border:none;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:20px;color:#6b7280;transition:all .2s;-webkit-tap-highlight-color:transparent}.clear-search:hover{background:#d1d5db;color:#374151}.voice-filter-select{padding:12px 16px;border:2px solid #d1d5db;border-radius:8px;font-size:15px;font-weight:500;background:#fff;cursor:pointer;transition:border-color .2s,box-shadow .2s;min-width:150px}.voice-filter-select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 4px #6366f126}.voice-modal-body{padding:24px;overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch}.voice-section{margin-bottom:32px}.voice-section:last-child{margin-bottom:0}.section-title{font-size:1.125rem;font-weight:600;color:#1f2937;margin:0 0 16px;display:flex;align-items:center;gap:8px}.section-title.collapsible{cursor:pointer;padding:12px 16px;background:#f9fafb;border-radius:10px;transition:all .2s;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none}.section-title.collapsible:hover{background:#f3f4f6}.section-title.collapsible:active{background:#e5e7eb}.section-title-content{display:flex;align-items:center;gap:10px;flex:1}.expand-icon{font-size:.875rem;color:#6b7280;transition:transform .2s;display:inline-flex;width:16px;justify-content:center}.voice-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.voice-card{background:#fff;border:2px solid #e5e7eb;border-radius:12px;padding:16px;transition:all .2s;display:flex;flex-direction:column;gap:12px}.voice-card:hover{border-color:#d1d5db;box-shadow:0 4px 12px #00000014}.voice-card.selected{border-color:#6366f1;background:#fafbff;box-shadow:0 4px 12px #6366f126}.voice-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.voice-info{display:flex;gap:12px;flex:1;min-width:0}.voice-icon{font-size:1.75rem;flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#f3f4f6;border-radius:10px}.voice-details{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.voice-name{font-size:1rem;font-weight:600;color:#1f2937;margin:0;word-break:break-word}.voice-type{font-size:.8125rem;color:#6b7280;font-weight:500}.voice-style{font-size:.75rem;color:#9ca3af;font-weight:500}.play-btn{background:#6366f1;border:none;border-radius:8px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;color:#fff;transition:all .2s;flex-shrink:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none}.play-btn:hover:not(:disabled){background:#5856eb;transform:scale(1.05)}.play-btn:disabled{opacity:.6;cursor:not-allowed}.select-btn{width:100%;padding:10px 16px;background:#f3f4f6;border:2px solid #e5e7eb;border-radius:8px;font-size:15px;font-weight:600;color:#374151;cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none}.select-btn:hover{background:#e5e7eb;border-color:#d1d5db}.voice-card.selected .select-btn{background:#6366f1;border-color:#6366f1;color:#fff}.voice-card.selected .select-btn:hover{background:#5856eb;border-color:#5856eb}.empty-results{text-align:center;padding:60px 20px;color:#6b7280}.empty-results p{font-size:1rem;margin:0}@media (max-width: 768px){.voice-modal-overlay{padding:0;align-items:flex-start}.voice-modal-content{max-height:100vh;max-width:100%;border-radius:0;min-height:100vh}.voice-modal-header{padding:20px 16px 16px;border-radius:0}.voice-modal-header h2{font-size:1.375rem}.voice-modal-current{padding:14px 16px}.voice-modal-filters{padding:16px;gap:10px;top:73px}.search-wrapper{min-width:100%}.voice-filter-select{flex:1;min-width:0}.voice-modal-body{padding:16px}.voice-section{margin-bottom:24px}.section-title{font-size:1.0625rem;margin-bottom:14px}.section-title.collapsible{padding:14px}.expand-icon{width:18px}.voice-grid{grid-template-columns:1fr;gap:14px}.voice-card{padding:14px}.voice-icon{font-size:1.625rem;width:44px;height:44px}.voice-name{font-size:1.0625rem}.play-btn{width:44px;height:44px;font-size:18px}.select-btn{padding:12px 16px;font-size:16px}}@media (max-width: 400px){.voice-modal-header{padding:16px 12px 14px}.voice-modal-current{padding:12px}.voice-modal-filters{padding:12px;gap:8px}.voice-modal-body{padding:12px}.voice-grid{gap:12px}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;overflow-y:auto;-webkit-overflow-scrolling:touch}.modal-content{background:#fff;border-radius:16px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;-webkit-overflow-scrolling:touch;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;margin:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 16px;border-bottom:1px solid #e5e7eb;margin-bottom:24px;position:sticky;top:0;background:#fff;z-index:10}.modal-header h2{font-size:1.5rem;font-weight:600;color:#1f2937;margin:0;flex-grow:1;line-height:1.3}.close-btn{background:#f3f4f6;border:none;font-size:1.75rem;color:#6b7280;cursor:pointer;padding:8px 12px;border-radius:8px;transition:all .2s;line-height:1;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;flex-shrink:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none}.close-btn:hover{color:#374151;background-color:#f3f4f6}.source-form{padding:0 24px 24px}.form-group{margin-bottom:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.form-group label{display:block;font-weight:500;color:#374151;margin-bottom:6px}.form-group input:not([type=checkbox]):not([type=range]),.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:2px solid #d1d5db;border-radius:8px;font-size:16px;transition:border-color .2s,box-shadow .2s;box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-group input:not([type=checkbox]):not([type=range]):focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 4px #6366f126;background-color:#fafbff}.form-group input[type=range]{padding:0;height:6px;background:#e5e7eb;border-radius:3px}.form-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#6366f1;cursor:pointer;border:2px solid white;box-shadow:0 2px 4px #0003}.form-group input[type=range]::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#6366f1;cursor:pointer;border:2px solid white;box-shadow:0 2px 4px #0003}.speed-value{margin-left:10px;font-weight:500;color:#6366f1}.checkbox-label{display:flex;align-items:center;gap:12px;cursor:pointer;font-weight:500;color:#374151;padding:4px 0}.checkbox-label input[type=checkbox]{width:20px;height:20px;margin:0;cursor:pointer;flex-shrink:0;accent-color:#6366f1}.voice-selector-btn{width:100%;padding:12px 16px;border:2px solid #d1d5db;border-radius:8px;font-size:16px;background:#fff;cursor:pointer;transition:border-color .2s,box-shadow .2s;display:flex;align-items:center;justify-content:space-between;text-align:left;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none}.voice-selector-btn:hover{border-color:#9ca3af}.voice-selector-btn:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 4px #6366f126}.voice-selector-label{display:flex;align-items:center;gap:8px;font-weight:500;color:#1f2937;flex:1}.voice-meta{color:#6b7280;font-weight:400;font-size:.9375rem}.voice-selector-arrow{color:#6b7280;font-size:12px;flex-shrink:0}.help-text{display:block;margin-top:4px;font-size:12px;color:#6b7280}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:30px;padding-top:20px;border-top:1px solid #e5e7eb}.btn{padding:14px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;min-height:48px;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none}@media (max-width: 768px){.modal-overlay{padding:0;align-items:flex-start}.modal-content{max-height:100vh;max-width:100%;border-radius:0;min-height:100vh}.modal-header{padding:20px 16px 16px;border-radius:0}.modal-header h2{font-size:1.375rem}.source-form{padding:0 16px 24px}.form-group{margin-bottom:24px}.form-group label{font-size:15px;margin-bottom:8px}.form-row{grid-template-columns:1fr;gap:24px}.form-actions{flex-direction:column-reverse;gap:12px;position:sticky;bottom:0;background:#fff;padding:16px 0 0;margin-top:24px;box-shadow:0 -2px 10px #0000000d}.form-actions .btn{width:100%;min-height:52px;font-size:17px}.help-text{font-size:13px;line-height:1.4}.checkbox-label{gap:12px;padding:8px 0}.checkbox-label input[type=checkbox]{width:22px;height:22px;flex-shrink:0}}.source-card{background:#fff;border:2px solid #e5e7eb;border-radius:16px;padding:20px;transition:all .2s;position:relative}.source-card:hover{box-shadow:0 4px 16px #00000014;transform:translateY(-2px);border-color:#d1d5db}.source-card.inactive{opacity:.7;background-color:#f9fafb}.source-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.source-info{display:flex;align-items:flex-start;gap:12px;flex-grow:1}.source-icon{font-size:1.75rem;background:#f3f4f6;border-radius:12px;padding:10px;min-width:48px;min-height:48px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.source-details{flex-grow:1;min-width:0}.source-name{font-size:1.125rem;font-weight:600;color:#1f2937;margin:0 0 6px;word-break:break-word;line-height:1.3}.source-type{font-size:.8125rem;color:#6b7280;text-transform:uppercase;font-weight:600;letter-spacing:.05em}.source-actions{display:flex;align-items:flex-start;gap:8px}.action-btn{background:#f9fafb;border:2px solid #e5e7eb;border-radius:8px;padding:8px 12px;cursor:pointer;transition:all .2s;color:#6b7280;font-size:16px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none}.action-btn:hover:not(:disabled){background-color:#f3f4f6;border-color:#9ca3af}.action-btn:disabled{opacity:.5;cursor:not-allowed}.sync-btn:hover:not(:disabled){color:#059669;border-color:#059669}.dropdown{position:relative}.dropdown-menu{position:absolute;top:calc(100% + 4px);right:0;background:#fff;border:2px solid #e5e7eb;border-radius:12px;box-shadow:0 8px 20px #00000026;min-width:160px;z-index:10;overflow:hidden}.dropdown-menu button{width:100%;padding:14px 16px;background:none;border:none;text-align:left;cursor:pointer;transition:background-color .2s;font-size:15px;font-weight:500;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none}.dropdown-menu button:hover{background-color:#f3f4f6}.dropdown-menu .delete-btn{color:#dc2626}.dropdown-menu .delete-btn:hover{background-color:#fef2f2}.source-status{display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:wrap}.status-indicator{padding:6px 12px;border-radius:16px;font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.status-indicator.active{background-color:#d1fae5;color:#047857}.status-indicator.inactive{background-color:#fee2e2;color:#dc2626}.auto-convert-badge{padding:6px 12px;background-color:#ede9fe;color:#7c3aed;border-radius:16px;font-size:.8125rem;font-weight:600}.source-stats{margin-bottom:16px}.stat{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;padding:4px 0}.stat:last-child{margin-bottom:0}.stat-label{font-size:.9375rem;color:#6b7280;line-height:1.4}.stat-value{font-size:.9375rem;font-weight:600;color:#374151}.source-url{border-top:1px solid #f3f4f6;padding-top:12px;margin-top:16px}.url-link{color:#6366f1;text-decoration:none;font-size:.875rem;word-break:break-all}.url-link:hover{text-decoration:underline}@media (max-width: 768px){.source-card{padding:18px;border-radius:16px}.source-card:active{transform:scale(.99)}.source-header{margin-bottom:16px}.source-info{gap:14px}.source-icon{font-size:1.875rem;min-width:52px;min-height:52px;padding:12px}.source-name{font-size:1.1875rem}.source-type{font-size:.875rem}.source-actions{gap:10px}.action-btn{min-width:48px;min-height:48px;font-size:18px;padding:10px 14px}.source-status{gap:10px;margin-bottom:18px}.status-indicator,.auto-convert-badge{padding:7px 14px;font-size:.875rem}.source-stats{margin-bottom:18px}.stat{margin-bottom:10px;padding:6px 0}.stat-label,.stat-value{font-size:1rem}.url-link{font-size:.9375rem}.dropdown-menu button{padding:16px 18px;font-size:16px}}.content-items-list{width:100%}.items-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:16px}.items-header h2{font-size:1.5rem;font-weight:600;color:#1f2937;margin:0}.items-filters{display:flex;gap:12px;align-items:center}.filter-select{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;background:#fff;cursor:pointer;transition:border-color .2s}.filter-select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.empty-state p{color:#6b7280;margin-bottom:0;max-width:500px;margin-left:auto;margin-right:auto}.items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px;margin-bottom:30px}.item-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px;transition:all .2s}.item-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-1px)}.item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.item-status{display:flex;align-items:center;gap:6px}.status-icon{font-size:16px}.status-text{font-size:.75rem;font-weight:500;text-transform:capitalize;color:#6b7280}.item-date{font-size:.75rem;color:#9ca3af}.item-title{font-size:1.1rem;font-weight:600;color:#1f2937;margin:0 0 8px;line-height:1.4;word-break:break-word}.item-link{color:inherit;text-decoration:none}.item-link:hover{color:#6366f1;text-decoration:underline}.item-author{font-size:.875rem;color:#6b7280;margin-bottom:12px;font-style:italic}.item-meta{display:flex;gap:12px;margin-bottom:16px;font-size:.75rem;color:#9ca3af}.word-count,.reading-time{background:#f3f4f6;padding:2px 8px;border-radius:4px}.item-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.btn-sm{padding:6px 12px;font-size:.75rem;border-radius:4px}.btn{padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:4px}.btn-primary:hover{background-color:#5856eb}.btn-secondary:hover{background-color:#e5e7eb}.tts-badge{background:#ede9fe;color:#7c3aed;padding:4px 8px;border-radius:12px;font-size:.75rem;font-weight:500}.error-badge{background:#fee2e2;color:#dc2626;padding:4px 8px;border-radius:12px;font-size:.75rem;font-weight:500;cursor:help}.load-more{text-align:center;margin:30px 0}.loading{text-align:center;padding:40px 20px;color:#6b7280;font-size:1rem}@media (max-width: 768px){.items-header,.items-filters{flex-direction:column;align-items:stretch}.items-grid{grid-template-columns:1fr}.item-card{padding:16px}.item-header{flex-direction:column;align-items:flex-start;gap:8px}.item-meta{flex-direction:column;gap:4px}.item-actions{flex-direction:column;align-items:stretch}}.content-sources-page{max-width:1400px;margin:0 auto;padding:20px;width:90%;box-sizing:border-box}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;flex-wrap:wrap;gap:16px}.page-header h1{font-size:2.5rem;font-weight:700;color:#1f2937;margin:0;flex:1;min-width:200px}.page-header .btn{flex-shrink:0}.page-header p{font-size:1.1rem;color:#6b7280;max-width:600px;margin:0 auto;width:100%}.error-message{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:20px}.tabs{display:flex;border-bottom:2px solid #e5e7eb;margin-bottom:30px}.tab{padding:12px 24px;background:none;border:none;cursor:pointer;font-size:1rem;font-weight:500;color:#6b7280;border-bottom:3px solid transparent;transition:all .2s;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none}.tab:hover{color:#374151;background-color:#f9fafb}.tab.active{color:#6366f1;border-bottom-color:#6366f1}.sources-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.sources-actions{display:flex;gap:12px}.btn{padding:12px 24px;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none;white-space:nowrap}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:#6366f1;color:#fff}.btn-primary:hover:not(:disabled){background-color:#5856eb}.btn-secondary{background-color:#f3f4f6;color:#374151;border:1px solid #d1d5db}.btn-secondary:hover:not(:disabled){background-color:#e5e7eb}.empty-state{text-align:center;padding:60px 20px;background-color:#f9fafb;border-radius:12px;border:2px dashed #d1d5db}.empty-state h3{font-size:1.5rem;color:#374151;margin-bottom:10px}.empty-state p{color:#6b7280;margin-bottom:20px;max-width:400px;margin-left:auto;margin-right:auto}.sources-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}@media (max-width: 420px){.sources-grid{grid-template-columns:1fr}}.loading{text-align:center;padding:40px 20px;color:#6b7280;font-size:1.1rem}@media (max-width: 768px){.content-sources-page{padding:16px;max-width:100%;width:100%;box-sizing:border-box}.page-header{margin-bottom:24px;padding:0;flex-direction:column;align-items:stretch;gap:12px}.page-header h1{font-size:1.875rem;line-height:1.2;text-align:left}.page-header .btn{width:100%;font-size:16px;min-height:50px}.page-header p{font-size:.95rem;line-height:1.5;text-align:left}.tabs{margin-bottom:24px;gap:0;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:12px;background-color:#f9fafb;padding:4px}.tab{padding:16px 24px;font-size:16px;white-space:nowrap;flex:1;text-align:center;border-radius:8px;min-height:48px}.tab.active{background-color:#fff;box-shadow:0 1px 3px #0000001a;border-bottom-color:transparent}.sources-header{flex-direction:column;align-items:stretch;gap:12px;margin-bottom:24px}.sources-actions{flex-direction:column;gap:12px}.sources-actions .btn{width:100%;justify-content:center;padding:14px 24px;font-size:16px;min-height:50px}.sources-grid{grid-template-columns:1fr;gap:16px}.empty-state{padding:48px 20px;margin:0;border-radius:16px}.empty-state h3{font-size:1.375rem;line-height:1.3}.empty-state p{font-size:1rem;line-height:1.5}.empty-state .btn{width:100%;max-width:320px;min-height:50px}.error-message{padding:14px 16px;font-size:15px;margin:0 0 20px;border-radius:12px;line-height:1.4}}@media (max-width: 400px){.content-sources-page{padding:12px}.page-header h1{font-size:1.625rem}.page-header p{font-size:.9375rem}.tab,.btn{padding:14px 20px;font-size:15px}.sources-grid{gap:14px}}.voice-cloning-page{max-width:1200px;margin:0 auto;padding:2rem}.page-header{margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.page-header h1{margin:0;font-size:2rem;color:#1a1a1a}.page-header p{color:#666;margin:.5rem 0 0;flex-basis:100%}.error-banner{background:#fee;border:1px solid #fcc;color:#c33;padding:1rem;border-radius:8px;margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center}.error-banner button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#c33}.info-card{background:#f0f7ff;border:1px solid #d0e4ff;border-radius:12px;padding:1.5rem;margin-bottom:2rem}.info-card h3{margin:0 0 1rem;color:#1a5cb8}.info-card ol{margin:0 0 1rem;padding-left:1.5rem}.info-card li{margin-bottom:.5rem;line-height:1.6}.info-note{background:#fff;padding:1rem;border-radius:8px;margin:1rem 0 0;color:#666}.loading-state,.empty-state{text-align:center;padding:4rem 2rem}.spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #6366f1;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-state h3{color:#1a1a1a;margin-bottom:.5rem}.empty-state p{color:#666;margin-bottom:2rem}.voices-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-top:2rem}.voice-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:1.5rem;transition:all .2s;box-shadow:0 2px 4px #0000000d}.voice-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.voice-icon{font-size:3rem;text-align:center;margin-bottom:1rem}.voice-card h3{margin:0 0 .5rem;font-size:1.25rem;color:#1a1a1a}.voice-meta{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;font-size:.875rem}.status{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-weight:500;text-transform:capitalize;width:fit-content}.status-ready{background:#d1fae5;color:#065f46}.status-training{background:#fef3c7;color:#92400e}.status-failed{background:#fee2e2;color:#991b1b}.date{color:#666}.voice-error{background:#fee;color:#c33;padding:.5rem;border-radius:6px;font-size:.875rem;margin-bottom:1rem}.voice-actions{display:flex;gap:.5rem;margin-top:1rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary{background:#6366f1;color:#fff}.btn-primary:hover:not(:disabled){background:#4f46e5}.btn-secondary{background:#e5e7eb;color:#374151}.btn-secondary:hover:not(:disabled){background:#d1d5db}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.btn:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:16px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}.modal-header{padding:1.5rem;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;font-size:1.5rem}.modal-close{background:none;border:none;font-size:2rem;line-height:1;cursor:pointer;color:#9ca3af;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.modal-close:hover:not(:disabled){background:#f3f4f6;color:#374151}.modal-body{padding:1.5rem}.modal-footer{padding:1.5rem;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:1rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#374151}.form-group input[type=text]{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;box-sizing:border-box}.form-group input[type=text]:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.form-group input[type=text]:disabled{background:#f9fafb;color:#9ca3af;cursor:not-allowed}.file-input-wrapper{margin-bottom:.5rem}.form-group input[type=file]{width:100%;padding:.75rem;border:2px dashed #d1d5db;border-radius:8px;font-size:.875rem;cursor:pointer;background:#f9fafb}.form-group input[type=file]:hover:not(:disabled){border-color:#6366f1;background:#f0f7ff}.file-info{margin-top:.5rem;padding:.75rem;background:#f0fdf4;border:1px solid #d1fae5;border-radius:6px;font-size:.875rem;color:#065f46}.form-group small{display:block;color:#6b7280;font-size:.875rem}.progress-bar{width:100%;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden;margin:1rem 0}.progress-fill{height:100%;background:#6366f1;transition:width .3s ease}@media (max-width: 768px){.voice-cloning-page{padding:1rem}.page-header{flex-direction:column;align-items:flex-start}.voices-grid{grid-template-columns:1fr}.modal-content{margin:0;max-height:100vh;border-radius:0}}.mobile-player-page{position:fixed;top:0;left:0;right:0;bottom:0;background:linear-gradient(180deg,#1a1a2e,#0f0f1e);color:#fff;display:flex;flex-direction:column;z-index:1000}.mobile-player-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.back-button{background:none;border:none;color:#fff;padding:.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .2s}.back-button:hover{opacity:.7}.player-title{font-size:1.1rem;font-weight:600;margin:0}.header-spacer{width:40px}.mode-toggle-button{background:none;border:none;color:#fff;padding:.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .2s;border-radius:8px}.mode-toggle-button:hover{opacity:.7;background:#ffffff1a}.mode-toggle-button:active{transform:scale(.95)}.mobile-player-main{flex:1;display:flex;flex-direction:column;padding:2rem 1.5rem;justify-content:center;gap:2rem}.album-art{display:flex;justify-content:center;align-items:center;margin-bottom:1rem}.album-art-placeholder{width:280px;height:280px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;display:flex;align-items:center;justify-content:center;box-shadow:0 20px 60px #0006}.album-art-placeholder svg{opacity:.5}.track-info-section{text-align:center;padding:0 1rem}.track-title{font-size:1.5rem;font-weight:700;margin:0 0 .5rem;line-height:1.3;display:unset!important}.track-meta{font-size:1rem;color:#fff9;margin:0}.progress-section{padding:0 .5rem}.progress-bar-container{height:6px;background:#ffffff26;border-radius:3px;position:relative;cursor:pointer;margin-bottom:.5rem}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:3px;position:relative;transition:width .1s linear}.progress-handle{position:absolute;right:-6px;top:50%;transform:translateY(-50%);width:12px;height:12px;background:#fff;border-radius:50%;box-shadow:0 2px 8px #0000004d}.time-display{display:flex;justify-content:space-between;font-size:.875rem;color:#fff9;padding:0 .25rem}.controls-section{display:flex;align-items:center;justify-content:center;gap:2rem;padding:1rem 0}.control-button,.play-button{background:none;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s,opacity .2s}.control-button:active,.play-button:active{transform:scale(.95)}.control-button:hover,.play-button:hover{opacity:.8}.control-button{padding:.75rem}.play-button{padding:1.25rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;box-shadow:0 8px 24px #667eea66}.play-button:hover{opacity:1;box-shadow:0 8px 32px #667eea99}.read-along-container{display:flex;flex-direction:column;height:100%;overflow:hidden}.read-along-header{text-align:center;padding:1rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0;background:#0003}.read-along-title{font-size:1.3rem;font-weight:700;margin:0 0 .5rem;line-height:1.3}.read-along-meta{font-size:.95rem;color:#fff9;margin:0}.read-along-text{flex:1;overflow-y:auto;overflow-x:hidden;padding:1.5rem 1.5rem 2rem;font-size:1.2rem;line-height:1.8;text-align:left;-webkit-overflow-scrolling:touch;max-height:calc(100vh - 280px);min-height:200px}.read-along-word{display:inline;cursor:pointer;transition:all .2s ease;color:#ffffff80;padding:2px 1px;border-radius:3px}.read-along-word:hover{color:#fffc;background:#ffffff0d}.read-along-word.past{color:#fff6}.read-along-word.active{color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);padding:4px 6px;border-radius:4px;font-weight:600;box-shadow:0 2px 8px #667eea66;transform:scale(1.05)}.player-controls-bottom{flex-shrink:0;background:#0000004d;padding:1rem 1.5rem 1.5rem;border-top:1px solid rgba(255,255,255,.1)}.read-along-no-text{text-align:center;color:#fff6;font-style:italic;margin-top:3rem}.read-along-text::-webkit-scrollbar{width:6px}.read-along-text::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.read-along-text::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.read-along-text::-webkit-scrollbar-thumb:hover{background:#ffffff4d}@media (max-height: 700px){.mobile-player-main{gap:1.5rem}.album-art-placeholder{width:220px;height:220px}.album-art-placeholder svg{width:80px;height:80px}.track-title{font-size:1.3rem}}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column;background:var(--background);width:100%}.main-content{flex:1;width:100%;display:flex;flex-direction:column}.loading{display:flex;justify-content:center;align-items:center;min-height:50vh;font-size:1.5rem;color:var(--primary-color);font-weight:500}.error-message{background:#fef2f2;color:var(--error);padding:1rem;border-radius:8px;margin-bottom:1rem;border-left:4px solid var(--error);font-weight:500}.success-message{background:#f0fdf4;color:var(--success);padding:1rem;border-radius:8px;margin-bottom:1rem;border-left:4px solid var(--success);font-weight:500}button{font-family:inherit}a{font-weight:500;color:var(--primary-color);text-decoration:inherit;transition:color .2s ease}a:hover{color:var(--primary-hover)}h1{font-size:3.2em;line-height:1.1;color:var(--text-primary);user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}@media (max-width: 768px){.nav-menu{flex-wrap:wrap;gap:1rem}.convert-methods,.feature-grid{grid-template-columns:1fr}h1{font-size:2em}}.mobile-home .hero h1{font-size:28px;line-height:1.2}.mobile-home .hero .subtitle{font-size:16px}.mobile-home .cta-buttons{flex-direction:column;gap:12px}.mobile-home .cta-btn{width:100%;padding:14px 24px}.mobile-home .tts-demo{margin:20px 0}.mobile-home .mobile-feature-grid{grid-template-columns:1fr;gap:15px}.mobile-home .feature-card{padding:20px}.mobile-home .feature-card h3{font-size:18px}.mobile-home .feature-card p{font-size:14px}.mobile-convert{padding:15px}.mobile-convert .tabs-header{gap:10px}.mobile-convert .tab-btn{flex:1;padding:12px 16px;font-size:14px}.mobile-convert .text-input{font-size:16px;min-height:150px}.mobile-convert .file-upload-area{padding:30px 20px}.mobile-convert .submit-btn{width:100%;padding:14px 24px;font-size:16px}.mobile-dashboard,.mobile-dashboard .mobile-track-list{padding:0}.mobile-dashboard .mobile-track-item{touch-action:manipulation}.mobile-auth .auth-card{padding:24px;margin:20px 15px;box-shadow:0 2px 8px #0000001a}.mobile-auth .form-group{margin-bottom:16px}.mobile-auth .form-group label{font-size:14px;margin-bottom:6px}.mobile-auth .form-group input{padding:12px;font-size:16px!important}.mobile-auth .submit-btn{width:100%;padding:14px 24px;font-size:16px}.mobile-auth .google-btn,.mobile-auth .apple-btn{width:100%;padding:12px 24px;font-size:15px}.mobile-auth .auth-footer,.mobile-auth .auth-link{text-align:center;font-size:14px;margin-top:20px}.mobile-pricing{padding:20px 15px}.mobile-pricing h1{font-size:28px}.mobile-pricing .pricing-subtitle{font-size:16px}.mobile-pricing .pricing-cards-mobile{display:flex;flex-direction:column;gap:20px;margin-top:30px}.mobile-pricing .pricing-card{width:100%;padding:24px}.mobile-pricing .price{margin:15px 0}.mobile-pricing .features-list{font-size:14px;margin:20px 0}.mobile-pricing .features-list li{padding:10px 0}.mobile-pricing .subscribe-btn{width:100%;padding:14px 24px;font-size:16px}@media (max-width: 768px){input[type=text],input[type=email],input[type=password],input[type=number],textarea,select{font-size:16px!important}button,a.button,.btn{min-height:44px;min-width:44px}.container{padding-left:15px;padding-right:15px}body{overflow-x:hidden}.modal-content{width:95%;max-width:95%;margin:20px auto}}@media (min-width: 768px) and (max-width: 1024px){.mobile-home .mobile-feature-grid{grid-template-columns:repeat(2,1fr)}.mobile-pricing .pricing-cards-mobile{flex-direction:row}}@media screen and (orientation: landscape){html{-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}}:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.6;font-weight:400;--primary-color: #2563eb;--primary-hover: #1d4ed8;--primary-light: #dbeafe;--secondary-color: #2563eb;--background: #ffffff;--surface: #f9fafb;--surface-hover: #f3f4f6;--border: #e5e7eb;--text-primary: #111827;--text-secondary: #6b7280;--text-muted: #9ca3af;--success: #10b981;--error: #ef4444;--warning: #f59e0b;color-scheme:light;color:var(--text-primary);background-color:var(--background);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;min-width:320px;min-height:100vh;max-height:100vh;overflow:hidden;background:var(--background)}#root{width:100%;height:100vh;overflow:hidden;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6,label,button,a,.nav-logo,.subtitle{user-select:none!important;-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important}input,textarea{user-select:text!important;-webkit-user-select:text!important;-moz-user-select:text!important;-ms-user-select:text!important}
