.btn-delete{background:linear-gradient(135deg,var(--error-color),var(--error-color-dark));color:var(--white)}.btn-delete:hover:not(:disabled){background:linear-gradient(135deg,var(--error-color-dark),var(--error-color));box-shadow:var(--shadow-md);transform:translateY(-2px)}:root{--primary-color: #ff6b35;--primary-dark: #e55a2b;--primary-light: #ff8557;--secondary-color: #4a90e2;--secondary-dark: #357abd;--secondary-light: #6fa8e8;--accent-color: #ffd23f;--accent-dark: #f4c430;--white: #ffffff;--gray-50: #fafafa;--gray-100: #f5f5f5;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--success-color: #10b981;--success-color-dark: #059669;--success-bg: #d1fae5;--warning-color: #f59e0b;--warning-bg: #fef3c7;--error-color: #ef4444;--error-color-dark: #dc2626;--error-bg: #fee2e2;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px -1px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--transition-fast: .15s ease;--transition-base: .3s ease;--transition-slow: .5s ease}*{box-sizing:border-box}body{margin:0;font-family:var(--font-family);background:linear-gradient(135deg,var(--gray-50),var(--gray-100));color:var(--gray-800);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}#root{min-height:100vh;width:100%}.app{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,var(--gray-50),var(--gray-100))}.app-main{flex:1;padding:var(--space-6);max-width:1400px;margin:0 auto;width:100%}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-decoration:none;min-height:44px;box-shadow:var(--shadow-sm)}.btn-primary{background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));color:var(--white)}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--primary-dark),var(--primary-color));box-shadow:var(--shadow-md);transform:translateY(-2px)}.btn-secondary{background-color:var(--white);color:var(--gray-700);border:2px solid var(--gray-200)}.btn-secondary:hover:not(:disabled){background-color:var(--gray-50);border-color:var(--gray-300);box-shadow:var(--shadow-md)}.btn-success{background:linear-gradient(135deg,var(--success-color),var(--success-color-dark));color:var(--white)}.btn-success:hover:not(:disabled){background:linear-gradient(135deg,var(--success-color-dark),var(--success-color));box-shadow:var(--shadow-md);transform:translateY(-2px)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:var(--shadow-xs)}.btn-large{padding:var(--space-4) var(--space-8);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-group label{font-weight:var(--font-weight-medium);color:var(--gray-700);font-size:var(--font-size-sm)}.form-input{padding:var(--space-3) var(--space-4);font-size:var(--font-size-base);border:2px solid var(--gray-200);border-radius:var(--radius-lg);transition:all var(--transition-fast);background-color:var(--white);box-shadow:var(--shadow-xs)}.form-input:disabled{background-color:var(--gray-100);cursor:not-allowed}.alert{padding:var(--space-4);border-radius:var(--radius-lg);display:flex;align-items:center;gap:var(--space-3);margin:var(--space-4) 0;box-shadow:var(--shadow-sm)}.alert-error{background-color:var(--error-bg);color:var(--error-color);border:1px solid #fecaca}.alert-warning{background-color:var(--warning-bg);color:var(--warning-color);border:1px solid #fed7aa}.alert-success{background-color:var(--success-bg);color:var(--success-color);border:1px solid #bbf7d0}.card{background:var(--white);border-radius:var(--radius-2xl);box-shadow:var(--shadow-md);border:1px solid var(--gray-200);overflow:hidden;transition:all var(--transition-fast)}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card-body{padding:var(--space-6)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.text-3xl{font-size:var(--font-size-3xl)}.text-gray-500{color:var(--gray-500)}.text-gray-600{color:var(--gray-600)}.text-gray-700{color:var(--gray-700)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.gap-2{gap:var(--space-2)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.error-message{background-color:var(--error-bg);color:var(--error-color);border:1px solid #fecaca;padding:var(--space-4);border-radius:var(--radius-lg);display:flex;align-items:center;gap:var(--space-3);margin:var(--space-4) 0;font-weight:var(--font-weight-medium);box-shadow:var(--shadow-sm)}.error-message:before{content:"⚠️";font-size:var(--font-size-lg)}.success-message{background-color:var(--success-bg);color:var(--success-color-dark);border:1px solid var(--success-color);padding:var(--space-4);border-radius:var(--radius-lg);display:flex;align-items:center;gap:var(--space-3);margin:var(--space-4) 0;font-weight:var(--font-weight-medium);box-shadow:var(--shadow-sm)}.success-message:before{content:"✅";font-size:var(--font-size-lg)}.navbar{background:linear-gradient(135deg,var(--white),var(--gray-50));border-bottom:1px solid var(--gray-200);box-shadow:var(--shadow-sm);padding:var(--space-4) var(--space-6);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}.navbar-brand{display:flex;align-items:center;gap:var(--space-3)}.navbar-brand h1{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--primary-color);margin:0;display:flex;align-items:center;gap:var(--space-2);background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.navbar-brand h1:before{content:"🎵";font-size:var(--font-size-3xl)}.navbar-links{display:flex;gap:var(--space-2);align-items:center}.nav-link{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);text-decoration:none;color:var(--gray-600);background-color:transparent;border-radius:var(--radius-xl);transition:all var(--transition-fast);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);border:2px solid rgba(10,10,10,10%);position:relative;box-shadow:var(--shadow-xs)}.nav-link:hover{background-color:var(--gray-100);color:var(--gray-800);transform:translateY(-2px);box-shadow:var(--shadow-md)}.nav-link.active{background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));color:var(--white);box-shadow:var(--shadow-md);border:2px solid var(--primary-color)}.nav-link.active:hover{background:linear-gradient(135deg,var(--primary-dark),var(--primary-color));transform:translateY(-3px);box-shadow:var(--shadow-lg)}.nav-icon{font-size:var(--font-size-base);opacity:.8}.nav-link.active .nav-icon{opacity:1}@media (max-width: 768px){.navbar{padding:var(--space-3) var(--space-4);flex-direction:column;gap:var(--space-4);position:static}.navbar-brand h1{font-size:var(--font-size-xl)}.navbar-links{width:100%;justify-content:center;flex-wrap:wrap}.nav-link{flex:1;justify-content:center;font-size:var(--font-size-xs);min-width:100px}}.page-hero:before{content:"";position:absolute;inset:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1000 1000"><defs><radialGradient id="grad"><stop offset="0%" stop-color="rgba(255,255,255,0.1)"/><stop offset="100%" stop-color="rgba(255,255,255,0)"/></radialGradient></defs><circle cx="200" cy="300" r="100" fill="url(%23grad)"/><circle cx="800" cy="700" r="150" fill="url(%23grad)"/><circle cx="500" cy="150" r="80" fill="url(%23grad)"/></svg>') no-repeat center/cover;pointer-events:none}@media (max-width: 768px){.page-hero{padding:var(--space-8) var(--space-4);margin-bottom:var(--space-8)}.hero-content h1{font-size:var(--font-size-3xl)}.hero-content p{font-size:var(--font-size-lg)}.hero-actions{flex-direction:column;gap:var(--space-3)}.hero-actions button{width:100%;max-width:300px}}.settings-section{background:var(--white);border-radius:var(--radius-2xl);padding:var(--space-8);margin-bottom:var(--space-8);border:1px solid var(--gray-200);box-shadow:var(--shadow-sm)}.section-header{margin-bottom:var(--space-8)}.section-description{color:var(--gray-600);font-size:var(--font-size-base);line-height:1.5}.settings-section.summary-section{background:linear-gradient(135deg,var(--blue-50),var(--purple-50));border:1px solid var(--blue-200)}.advanced-section{margin-top:var(--space-8);padding-top:var(--space-8);border-top:2px dashed var(--gray-200)}.advanced-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6)}.advanced-badge{padding:var(--space-1) var(--space-2);background:#9333ea1a;color:var(--purple-700);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);border-radius:var(--radius-md);text-transform:uppercase;letter-spacing:.025em}.form-group{margin-bottom:var(--space-6)}.form-group label{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2);font-weight:var(--font-weight-medium);color:var(--gray-800);font-size:var(--font-size-sm)}.label-badge{padding:var(--space-1) var(--space-2);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.025em}.label-badge.required{background:#ef44441a;color:var(--red-700)}.label-badge.optional{background:#6b72801a;color:var(--gray-600)}.label-badge.advanced{background:#9333ea1a;color:var(--purple-700)}.form-input{width:100%;padding:var(--space-3) var(--space-4);border:2px solid var(--gray-300);border-radius:var(--radius-lg);font-size:var(--font-size-sm);transition:all var(--transition-fast);background:var(--white)}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #ff6b351a}.form-input:disabled{background:var(--gray-50);color:var(--gray-500);cursor:not-allowed}.token-input-wrapper{position:relative}.help-text{color:var(--gray-600);font-size:var(--font-size-xs);line-height:1.4}.loading-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);border:none;border-radius:var(--radius-lg);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast);text-decoration:none;position:relative;white-space:nowrap}.loading-btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary-color);color:var(--white);box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background:var(--primary-600);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--gray-200);color:var(--gray-800);border:1px solid var(--gray-300)}.btn-secondary:hover:not(:disabled){background:var(--gray-300);border-color:var(--gray-400)}.btn-danger{background:var(--red-600);color:var(--white)}.btn-danger:hover:not(:disabled){background:var(--red-700)}.btn-md{padding:var(--space-3) var(--space-6);font-size:var(--font-size-base);min-height:40px}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--font-size-lg);min-height:48px}.btn-content{display:flex;align-items:center;gap:var(--space-2)}.spinner{width:16px;height:16px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn-loading{pointer-events:none}.settings-page{max-width:800px;margin:0 auto;padding-bottom:var(--space-10)}.settings-header{text-align:center;margin-bottom:var(--space-12)}.settings-header h1{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);color:var(--gray-900);margin-bottom:var(--space-4);background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.settings-header p{font-size:var(--font-size-lg);color:var(--gray-600);margin:0}.settings-content{display:flex;flex-direction:column;gap:var(--space-8)}.settings-section{background:var(--white);border-radius:var(--radius-2xl);padding:var(--space-8);box-shadow:var(--shadow-md);border:1px solid var(--gray-200)}.section-header{margin-bottom:var(--space-8);padding-bottom:var(--space-4);border-bottom:2px solid var(--gray-100)}.section-title{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-2)}.section-icon{font-size:var(--font-size-2xl)}.section-title h2{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--gray-900);margin:0}.section-description{font-size:var(--font-size-base);color:var(--gray-600);margin-left:calc(var(--font-size-2xl) + var(--space-3))}.form-group{margin-bottom:var(--space-8)}.form-group label{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3);font-weight:var(--font-weight-semibold);color:var(--gray-800);font-size:var(--font-size-base)}.label-text{flex:1}.label-badge{padding:var(--space-1) var(--space-2);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em}.label-badge.required{background:var(--error-bg);color:var(--error-color)}.label-badge.optional{background:var(--gray-100);color:var(--gray-600)}.input-wrapper{position:relative}.form-input{width:100%;padding:var(--space-4);border:2px solid var(--gray-300);border-radius:var(--radius-lg);font-size:var(--font-size-base);transition:all var(--transition-fast);background:var(--white);font-family:var(--font-family)}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 4px #ff6b351a}.form-input::placeholder{color:var(--gray-400)}.input-help{margin-top:var(--space-2)}.help-text{font-size:var(--font-size-sm);color:var(--gray-500);font-style:italic}.advanced-section{margin-top:var(--space-8);padding:var(--space-6);background:var(--gray-50);border-radius:var(--radius-xl);border:1px solid var(--gray-200)}.advanced-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6);padding-bottom:var(--space-3);border-bottom:1px solid var(--gray-300)}.advanced-header h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--gray-800);margin:0}.advanced-badge{padding:var(--space-1) var(--space-3);background:var(--secondary-color);color:var(--white);border-radius:var(--radius-xl);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em}.summary-section{background:linear-gradient(135deg,var(--gray-50),var(--white));border:2px dashed var(--gray-300)}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-6)}.summary-item{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4);background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--gray-200)}.summary-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--gray-600);text-transform:uppercase;letter-spacing:.05em}.summary-value{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);display:flex;align-items:center;gap:var(--space-2);max-width:70vw}.token-masked{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:var(--font-size-sm);color:var(--gray-700);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-indicator{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-indicator.connected,.status-indicator.enabled{background:var(--success-color);box-shadow:0 0 4px var(--success-color)}.status-indicator.disabled{background:var(--gray-400)}.status-not-set,.status-disabled{color:var(--gray-500)}.status-enabled{color:var(--success-color)}.settings-actions{margin-top:var(--space-10);text-align:center}.save-button{font-size:var(--font-size-xl);padding:var(--space-5) var(--space-10);font-weight:var(--font-weight-bold);min-width:200px}@media (max-width: 768px){.settings-page{padding-left:var(--space-4);padding-right:var(--space-4)}.settings-header h1{font-size:var(--font-size-3xl)}.settings-header p{font-size:var(--font-size-base)}.settings-section{padding:var(--space-6)}.section-description{margin-left:0;margin-top:var(--space-2)}.form-group label{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.summary-grid{grid-template-columns:1fr}.advanced-section{padding:var(--space-4)}.advanced-header{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.save-button{width:100%;max-width:300px}.token-input-wrapper{width:100%;max-width:100%}}@media (max-width: 480px){.section-title{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.section-title h2{font-size:var(--font-size-xl)}}@media (max-width: 768px){.empty-state,.setup-required{padding:var(--space-12) var(--space-4)}}.delete-button{position:absolute;top:var(--space-2);right:var(--space-2);background:#ef4444e6;border:none;border-radius:var(--radius-full);width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);z-index:10;color:#fff;font-size:var(--font-size-sm)}.delete-button:hover{background:#dc2626;transform:scale(1.1)}.playlist-cover{position:relative;overflow:hidden;background:var(--gray-100)}.playlist-info{padding:var(--space-4);height:80px;display:flex;flex-direction:column;justify-content:center}.playlist-card.grid-mode{display:flex;flex-direction:column}.playlist-card.grid-mode .playlist-cover{aspect-ratio:1}.playlist-card.list-mode{display:flex;flex-direction:row;align-items:center;padding:var(--space-4);gap:var(--space-4)}.playlist-card.list-mode .playlist-cover{width:80px;height:80px;flex-shrink:0;aspect-ratio:1}.playlist-card.list-mode .playlist-overlay{display:none}.playlist-card.list-mode .play-button{width:32px;height:32px;font-size:var(--font-size-base);position:static;transform:none;opacity:1;margin-left:auto}.playlist-card.list-mode .playlist-info{padding:0;flex:1;height:auto}.playlist-card.list-mode .playlist-info h3{font-size:var(--font-size-lg);margin-bottom:var(--space-1)}@media (max-width: 480px){.playlist-card.list-mode{flex-direction:column;text-align:center;gap:var(--space-3)}.playlist-card.list-mode .play-button{margin:0}}.playlists-page{max-width:1200px;margin:0 auto}.page-hero{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));border-radius:var(--radius-2xl);padding:var(--space-12) var(--space-8);margin-bottom:var(--space-10);color:var(--white);text-align:center;position:relative;overflow:hidden}.page-hero:before{content:"";position:absolute;inset:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1000 1000"><defs><radialGradient id="grad"><stop offset="0%" stop-color="rgba(255,255,255,0.1)"/><stop offset="100%" stop-color="rgba(255,255,255,0)"/></radialGradient></defs><circle cx="200" cy="300" r="100" fill="url(%23grad)"/><circle cx="800" cy="700" r="150" fill="url(%23grad)"/><circle cx="500" cy="150" r="80" fill="url(%23grad)"/></svg>') no-repeat center/cover;pointer-events:none}.hero-content{position:relative;z-index:1}.hero-content h1{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-4);text-shadow:0 2px 4px rgba(0,0,0,.1)}.hero-content p{font-size:var(--font-size-xl);margin-bottom:var(--space-8);opacity:.95;max-width:600px;margin-left:auto;margin-right:auto}.hero-actions{display:flex;gap:var(--space-4);justify-content:center;align-items:center;flex-wrap:wrap}.create-playlist-btn{background:var(--white)!important;color:var(--primary-color)!important;font-weight:var(--font-weight-bold);box-shadow:var(--shadow-xl)}.create-playlist-btn:hover{background:var(--gray-50)!important;transform:translateY(-3px);box-shadow:var(--shadow-xl)}.refresh-btn{background:#fff3!important;color:var(--white)!important;border:2px solid rgba(255,255,255,.3)!important;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.refresh-btn:hover:not(:disabled){background:#ffffff4d!important;border-color:#ffffff80!important}.btn-icon{font-size:var(--font-size-lg)}.playlists-section{margin-top:var(--space-8)}.view-controls{display:flex;gap:var(--space-1);background:var(--gray-100);padding:var(--space-1);border-radius:var(--radius-lg)}.view-toggle{padding:var(--space-2) var(--space-3);background:transparent;border:none;border-radius:var(--radius-md);color:var(--gray-600);cursor:pointer;transition:all var(--transition-fast);font-size:var(--font-size-lg)}.view-toggle:hover{color:var(--gray-800)}.view-toggle.active{background:var(--white);color:var(--primary-color);box-shadow:var(--shadow-sm)}.playlists-container{margin-top:var(--space-6)}.playlists-container.grid-view{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-6)}.playlists-container.list-view{display:flex;flex-direction:column;gap:var(--space-4)}.playlist-card{background:var(--white);border-radius:var(--radius-2xl);overflow:hidden;cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);border:1px solid var(--gray-200);position:relative}.playlist-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.playlist-cover{position:relative;overflow:hidden;aspect-ratio:1;background:var(--gray-100)}.playlist-cover img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-base)}.playlist-card:hover .playlist-cover img{transform:scale(1.05)}.playlist-overlay{position:absolute;inset:0;background:linear-gradient(135deg,#ff6b35cc,#4a90e2cc);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-fast)}.playlist-card:hover .playlist-overlay{opacity:1}.play-button{width:64px;height:64px;border-radius:50%;background:var(--white);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-2xl);color:var(--primary-color);box-shadow:var(--shadow-lg);transform:scale(.8);transition:transform var(--transition-fast)}.playlist-card:hover .play-button{transform:scale(1)}.grid-view .playlist-card{display:flex;flex-direction:column}.grid-view .playlist-info{padding:var(--space-4);height:80px;display:flex;flex-direction:column;justify-content:center}.list-view .playlist-card{display:flex;flex-direction:row;align-items:center;padding:var(--space-4);gap:var(--space-4)}.list-view .playlist-cover{width:80px;height:80px;flex-shrink:0;aspect-ratio:1}.list-view .playlist-overlay{display:none}.list-view .play-button{width:32px;height:32px;font-size:var(--font-size-base);position:static;transform:none;opacity:1;margin-left:auto}.list-view .playlist-info{padding:0;flex:1}.list-view .playlist-info h3{font-size:var(--font-size-lg);margin-bottom:var(--space-1)}.list-view .playlist-meta{font-size:var(--font-size-sm)}.playlist-info{padding:var(--space-6)}.playlist-info h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--gray-900);margin:0 0 var(--space-2) 0;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;position:relative}.playlist-card:hover .playlist-info h3{white-space:normal;word-wrap:break-word;overflow:visible}.playlist-meta{display:flex;align-items:center;gap:var(--space-2);color:var(--gray-600);font-size:var(--font-size-sm)}.playlist-type{display:flex;align-items:center;gap:var(--space-1);font-weight:var(--font-weight-medium)}.empty-state,.setup-required{text-align:center;padding:var(--space-16) var(--space-8);background:var(--white);border-radius:var(--radius-2xl);box-shadow:var(--shadow-sm);border:2px dashed var(--gray-300)}.empty-state-icon,.setup-icon{font-size:4rem;margin-bottom:var(--space-6);opacity:.8}.empty-state h2,.setup-required h2{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--gray-800);margin-bottom:var(--space-4)}.empty-state p,.setup-required p{font-size:var(--font-size-lg);color:var(--gray-600);margin-bottom:var(--space-8);max-width:400px;margin-left:auto;margin-right:auto}.playlist-controls{display:flex;gap:var(--space-6);align-items:center;margin-bottom:var(--space-6);padding:var(--space-4);background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--gray-200);flex-wrap:wrap}.search-control{position:relative;flex:1;min-width:200px}.search-input{width:100%;padding:var(--space-3) var(--space-4);padding-right:var(--space-10);border:2px solid var(--gray-300);border-radius:var(--radius-md);font-size:var(--font-size-base);background:var(--white);transition:border-color var(--transition-fast)}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4a90e21a}.clear-search-btn{position:absolute;right:var(--space-3);top:50%;transform:translateY(-50%);background:none;border:none;color:var(--gray-400);cursor:pointer;font-size:var(--font-size-sm);width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all var(--transition-fast)}.clear-search-btn:hover{color:var(--gray-600);background:var(--gray-100)}.sort-control{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.sort-control label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--gray-700)}.sort-select{padding:var(--space-2) var(--space-3);border:2px solid var(--gray-300);border-radius:var(--radius-md);font-size:var(--font-size-sm);background:var(--white);cursor:pointer;transition:border-color var(--transition-fast)}.sort-select:focus{outline:none;border-color:var(--primary-color)}.sort-direction-btn{padding:var(--space-2);background:var(--gray-100);border:2px solid var(--gray-300);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-lg);color:var(--gray-600);width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.sort-direction-btn:hover{background:var(--gray-200);color:var(--gray-800)}.no-results{text-align:center;padding:var(--space-12);background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:2px dashed var(--gray-300)}.no-results p{font-size:var(--font-size-lg);color:var(--gray-600);margin-bottom:var(--space-4)}.clear-search-link{background:none;border:none;color:var(--primary-color);font-size:var(--font-size-base);cursor:pointer;text-decoration:underline;transition:color var(--transition-fast)}.clear-search-link:hover{color:var(--primary-color-dark)}.btn-sm{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);min-height:32px}.ml-auto{margin-left:auto}@media (max-width: 768px){.page-hero{padding:var(--space-8) var(--space-4);margin-bottom:var(--space-8)}.hero-content h1{font-size:var(--font-size-3xl)}.hero-content p{font-size:var(--font-size-lg)}.hero-actions{flex-direction:column;gap:var(--space-3)}.hero-actions button{width:100%;max-width:300px}.playlists-container.grid-view{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--space-4)}.section-header{flex-direction:column;gap:var(--space-4);align-items:flex-start}.view-controls{align-self:flex-end}.playlist-controls{flex-direction:column;gap:var(--space-4);align-items:stretch}.search-control{min-width:unset}.sort-control{justify-content:end}.empty-state,.setup-required{padding:var(--space-12) var(--space-4)}}@media (max-width: 480px){.playlists-container.grid-view{grid-template-columns:1fr}.list-view .playlist-card{flex-direction:column;text-align:center;gap:var(--space-3)}.list-view .play-button{margin:0}}.alert{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);margin-bottom:var(--space-4)}.alert-content{flex:1}.alert-action{margin-left:auto}.alert-icon{font-size:var(--font-size-lg);flex-shrink:0}.alert-error{background:#ef44441a;color:var(--red-700);border:1px solid rgba(239,68,68,.2)}.alert-success{background:#22c55e1a;color:var(--green-700);border:1px solid rgba(34,197,94,.2)}.alert-warning{background:#f59e0b1a;color:var(--yellow-700);border:1px solid rgba(245,158,11,.2)}.alert-info{background:#3b82f61a;color:var(--blue-700);border:1px solid rgba(59,130,246,.2)}.back-button{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:transparent;font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all .2s ease;border:0}.back-button:hover{-webkit-transition:all .5s;-moz-transition:all .5s;-o-transition:all .5s;transition:all .5s;color:gray}.back-button:active{transform:translate(-1px) translateY(1px)}.back-button:hover .back-arrow{transform:translate(-3px)}.back-arrow{font-size:1.1em;transition:transform .2s ease}.back-button.btn-secondary{background:var(--bg-secondary);color:var(--text-primary)}.back-button.page-back-button{position:absolute;top:1rem;left:1rem;z-index:10}.icon-display{display:flex;flex-direction:column;align-items:center;position:relative;transition:all .2s ease}.icon-display--clickable{cursor:pointer}.icon-display--small .icon-display__image-container{width:24px;height:24px}.icon-display--medium .icon-display__image-container{width:32px;height:32px}.icon-display--large .icon-display__image-container{width:48px;height:48px}.icon-display--grid{padding:12px;border:2px solid #e9ecef;border-radius:8px;background:#fff}.icon-display--grid.icon-display--clickable:hover{border-color:#007bff;box-shadow:0 2px 8px #007bff26;transform:translateY(-2px)}.icon-display--grid.icon-display--clickable:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff33}.icon-display--grid.icon-display--selected{border-color:#28a745;background:#f8fff9;box-shadow:0 2px 8px #28a74533}.icon-display--grid.icon-display--highlighted{border-color:#ffc107;background:#fffdf5}.icon-display--card{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:#f8f9fa;border-radius:8px;padding:16px}.icon-display--selector{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.icon-display__image-container{position:relative;display:flex;align-items:center;justify-content:center;border-radius:4px;overflow:hidden;margin-bottom:8px}.icon-display--card .icon-display__image-container{margin-bottom:0;width:32px;height:32px}.icon-display--selector .icon-display__image-container{margin-bottom:0;width:100%;height:100%}.icon-display__image{width:100%;height:100%;object-fit:cover;border-radius:4px}.icon-display--selector .icon-display__image{object-fit:contain}.icon-display__loading{font-size:20px;color:#666}.icon-display__error{font-size:20px;color:#dc3545}.icon-display--small .icon-display__loading,.icon-display--small .icon-display__error{font-size:12px}.icon-display--large .icon-display__loading,.icon-display--large .icon-display__error{font-size:24px}.icon-display__selected-overlay{position:absolute;inset:0;background:#28a745cc;display:flex;align-items:center;justify-content:center;border-radius:4px}.icon-display__checkmark{color:#fff;font-size:20px;font-weight:700}.icon-display--small .icon-display__checkmark{font-size:12px}.icon-display--large .icon-display__checkmark{font-size:24px}.icon-display__custom-badge{position:absolute;top:-4px;right:-4px;background:#ffc107;border-radius:50%;width:16px;height:16px;display:flex;align-items:center;justify-content:center;font-size:10px;border:2px solid white;box-shadow:0 1px 3px #0003}.icon-display--small .icon-display__custom-badge{width:12px;height:12px;font-size:8px;top:-2px;right:-2px}.icon-display--large .icon-display__custom-badge{width:20px;height:20px;font-size:12px;top:-6px;right:-6px}.icon-display__info{text-align:center;width:100%}.icon-display__title{font-size:12px;font-weight:500;color:#333;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.icon-display--large .icon-display__title{font-size:14px}.icon-display--small .icon-display__title{font-size:10px}.icon-display__tags{display:flex;flex-wrap:wrap;gap:2px;justify-content:center;align-items:center}.icon-display__tag{font-size:10px;background:#e9ecef;color:#495057;padding:1px 4px;border-radius:3px;white-space:nowrap}.icon-display--small .icon-display__tag{font-size:8px;padding:1px 2px}.icon-display--large .icon-display__tag{font-size:12px;padding:2px 6px}.icon-display__tag-more{font-size:10px;color:#6c757d;font-style:italic}.icon-display--small .icon-display__tag-more{font-size:8px}.icon-display--large .icon-display__tag-more{font-size:12px}@media (max-width: 768px){.icon-display--grid{padding:8px}.icon-display--grid .icon-display__title{font-size:11px}.icon-display--grid .icon-display__tag{font-size:9px}}@media (max-width: 480px){.icon-display--grid{padding:6px}}.icon-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:16px;padding:8px}.icon-grid-empty{display:flex;align-items:center;justify-content:center;height:200px;color:#666;font-style:italic}@media (max-width: 768px){.icon-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px}}@media (max-width: 480px){.icon-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px}}.icon-picker-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.icon-picker-modal{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000004d;max-width:800px;width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.icon-picker-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #eee;background:#f8f9fa}.icon-picker-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#333}.close-button{background:none;border:none;font-size:20px;cursor:pointer;color:#666;padding:4px;border-radius:4px;transition:all .2s ease}.close-button:hover{background:#e9ecef;color:#333}.icon-picker-controls{display:flex;gap:16px;padding:16px 24px;border-bottom:1px solid #eee;background:#fff}.search-container{flex:1}.search-input{width:100%;padding:8px 12px;border:2px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .2s ease}.search-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.category-container{min-width:200px}.category-select{width:100%;padding:8px 12px;border:2px solid #ddd;border-radius:6px;font-size:14px;background:#fff;cursor:pointer;transition:border-color .2s ease}.category-select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.icon-picker-content{flex:1;padding:16px 24px;overflow-y:auto;min-height:400px}.loading-state,.error-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;text-align:center}.loading-spinner,.error-icon,.empty-icon{font-size:48px;margin-bottom:16px}.loading-state p,.error-state p,.empty-state p{color:#666;font-size:16px;margin:0 0 16px}.retry-button,.clear-search-button{background:#007bff;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;transition:background-color .2s ease}.retry-button:hover,.clear-search-button:hover{background:#0056b3}.icon-picker-footer{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-top:1px solid #eee;background:#f8f9fa}.icon-count{font-size:14px;color:#666}.cancel-button{background:#6c757d;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;transition:background-color .2s ease}.cancel-button:hover{background:#545b62}@media (max-width: 768px){.icon-picker-overlay{padding:10px}.icon-picker-modal{max-height:95vh}.icon-picker-controls{flex-direction:column;gap:12px}.category-container{min-width:unset}.icon-picker-header h3{font-size:1.1rem}}.track-icon-selector{position:relative;display:inline-block}.track-icon-selector.small .icon-selector-button{width:24px;height:24px}.track-icon-selector.medium .icon-selector-button{width:32px;height:32px}.track-icon-selector.large .icon-selector-button{width:48px;height:48px}.icon-selector-button{border:2px solid #ddd;border-radius:6px;background:#fff;cursor:pointer;padding:0;position:relative;transition:all .2s ease;overflow:hidden}.icon-selector-button:hover:not(:disabled){border-color:#007bff;box-shadow:0 2px 4px #007bff33;transform:translateY(-1px)}.icon-selector-button:disabled{cursor:not-allowed;opacity:.6;border-color:#ccc}.current-icon{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.current-icon .track-icon{width:100%;height:100%}.current-icon .track-icon img,.current-icon .track-icon .default-icon,.current-icon .track-icon .loading-icon{width:100%;height:100%;object-fit:cover;display:flex;align-items:center;justify-content:center;font-size:.8em}.change-icon-overlay{position:absolute;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease;pointer-events:none}.icon-selector-button:hover:not(:disabled) .change-icon-overlay{opacity:1}.change-icon-text{color:#fff;font-size:12px}.track-icon-selector.disabled{opacity:.7}.track-icon-selector.disabled .icon-selector-button{cursor:default;border-color:#eee}.track-icon-selector.disabled .change-icon-overlay{display:none}.progress-bar-wrapper{display:flex;align-items:center;gap:var(--space-3);width:100%}.progress-bar-track{flex:1;height:8px;background-color:var(--gray-200);border-radius:var(--radius-full);overflow:hidden;box-shadow:inset 0 1px 2px #0000001a}.progress-bar-fill{height:100%;border-radius:var(--radius-full);transition:width .3s ease-in-out}.progress-bar-fill.primary{background:linear-gradient(90deg,var(--primary-color),var(--primary-light));box-shadow:0 1px 2px #ff6b354d}.progress-bar-fill.success{background:linear-gradient(90deg,var(--success-color),var(--success-color-light));box-shadow:0 1px 2px #10b9814d}.progress-bar-fill.warning{background:linear-gradient(90deg,var(--warning-color),var(--warning-color-light));box-shadow:0 1px 2px #f59e0b4d}.progress-bar-fill.error{background:linear-gradient(90deg,var(--error-color),var(--error-color-light));box-shadow:0 1px 2px #ef44444d}.progress-bar-wrapper.small .progress-bar-track{height:4px}.progress-bar-wrapper.medium .progress-bar-track{height:8px}.progress-bar-wrapper.large .progress-bar-track{height:12px}.progress-bar-text{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--gray-600);min-width:35px;text-align:right}.progress-bar-wrapper.small .progress-bar-text{font-size:var(--font-size-xs);min-width:30px}.progress-bar-wrapper.large .progress-bar-text{font-size:var(--font-size-base);min-width:40px}.progress-bar-error{font-size:var(--font-size-sm);color:var(--error-color);font-weight:var(--font-weight-medium)}.progress-bar-wrapper.job-progress{margin:var(--space-4) 0}.progress-bar-wrapper.job-progress .progress-bar-track{height:12px}.progress-bar-wrapper.upload-progress{margin-top:var(--space-2)}.tracks-list{display:flex;flex-direction:column;gap:var(--space-4)}.track-item{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-5);background:var(--gray-50);border-radius:var(--radius-xl);transition:all var(--transition-fast);border:1px solid var(--gray-200);cursor:default}body:not(.icon-modal-open) .track-item:hover{background:var(--white);box-shadow:var(--shadow-md);transform:translate(4px)}body.icon-modal-open .track-item:hover{background:var(--gray-50);box-shadow:none;transform:none}.track-item.modal-open{pointer-events:auto}.track-item.dragging{opacity:.5;transform:rotate(2deg);box-shadow:var(--shadow-lg);z-index:1000}.track-item:not(.modal-open).dragging{z-index:1000}.track-item.modal-open.dragging{z-index:5000}.track-item.drag-over{border-color:var(--primary-color);background:var(--primary-50);transform:translateY(-2px);box-shadow:0 8px 25px rgba(var(--primary-color-rgb),.15)}.track-drag-handle{flex-shrink:0;color:var(--gray-400);font-size:var(--font-size-lg);cursor:grab;padding:var(--space-2);margin-left:-var(--space-2);border-radius:var(--radius-md);transition:all var(--transition-fast);-webkit-user-select:none;user-select:none}.track-drag-handle:hover{color:var(--gray-600);background:var(--gray-100)}.track-drag-handle:active{cursor:grabbing}.track-icon{flex-shrink:0;width:48px;height:48px;border-radius:var(--radius-lg);overflow:hidden;background:var(--gray-200);display:flex;align-items:center;justify-content:center;transition:transform .3s ease,opacity .3s ease,box-shadow .3s ease}.track-icon.processing{animation:aiProcessing 1.5s infinite;box-shadow:0 0 15px #8b45134d}.track-icon.updating{animation:iconUpdating .8s ease-in-out}.track-icon.icon-changed{animation:iconChange .5s ease-out}.processing-icon{animation:sparkle 1.5s infinite;font-size:1.5rem}.loading-icon{animation:spin 1s infinite linear;font-size:1.2rem}.track-title-container{margin-bottom:var(--space-2)}.track-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--gray-900);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3}.track-artist{font-size:var(--font-size-xs);font-weight:var(--font-weight-normal);color:var(--gray-500);font-style:italic;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.2}.upload-status{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);padding:var(--space-1) var(--space-2);border-radius:var(--radius-md);display:inline-flex;align-items:center;gap:var(--space-1)}.status-uploading{background-color:#3b82f61a;color:var(--blue-600)}.status-transcoding{background-color:#f59e0b1a;color:var(--amber-600)}.status-completed{background-color:#10b9811a;color:var(--green-600)}.status-failed{background-color:#ef44441a;color:var(--red-600)}.upload-error{font-size:var(--font-size-sm);color:var(--red-600);font-weight:var(--font-weight-medium)}.track-title-display{display:flex;align-items:center;gap:var(--space-2);group:hover}.track-title-edit-btn{opacity:.6;font-size:var(--font-size-sm);transition:all var(--transition-fast);padding:var(--space-1) var(--space-2);border-radius:var(--radius-md);margin-left:var(--space-2)}.track-title-display:hover .track-title-edit-btn,.track-title-edit-btn:focus{opacity:1;background:#0000000d;transform:scale(1.1)}.track-title-edit{display:flex;flex-direction:column;gap:var(--space-2)}.track-title-input{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--gray-900);margin:0;line-height:1.3;background:var(--white);border:2px solid var(--gray-300);border-radius:var(--radius-lg);padding:var(--space-2) var(--space-3);padding-right:var(--space-8);width:100%;transition:all var(--transition-fast);box-shadow:var(--shadow-xs)}.track-title-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #ff6b351a;background:var(--white)}.track-title-input::placeholder{color:var(--gray-500);opacity:.7}.title-edit-actions{display:flex;gap:var(--space-2);align-items:center;margin-top:var(--space-1)}.title-edit-actions .btn{min-width:32px;padding:var(--space-1) var(--space-2);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.track-title-edit .input-with-icon{position:relative;display:flex;align-items:center}.track-title-edit .edit-icon{position:absolute;right:var(--space-3);top:50%;transform:translateY(-50%);font-size:var(--font-size-sm);color:var(--gray-400);pointer-events:none;opacity:.6;transition:opacity var(--transition-fast)}.track-title-edit .input-with-icon:hover .edit-icon,.track-title-edit .input-with-icon:focus-within .edit-icon{opacity:1}.playback-option-selector{margin-top:var(--space-2);display:flex;flex-direction:column;gap:var(--space-1)}.playback-option-label{font-size:var(--font-size-sm);color:var(--gray-600);font-weight:var(--font-weight-medium);margin:0}.playback-option-select{font-size:var(--font-size-sm);padding:var(--space-2) var(--space-3);border:1px solid var(--gray-300);border-radius:var(--radius-md);background:var(--white);color:var(--gray-700);font-weight:var(--font-weight-medium);transition:all var(--transition-fast);cursor:pointer;max-width:240px}.playback-option-select:hover:not(:disabled){border-color:var(--gray-400);box-shadow:var(--shadow-sm)}.playback-option-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #ff6b351a}.playback-option-select:disabled{opacity:.5;cursor:not-allowed;background:var(--gray-100)}.ai-status{display:inline-flex;align-items:center;gap:4px;padding:var(--space-1) var(--space-2);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.ai-status.ai-processing{background-color:#8b45131a;color:#8b4513;animation:processingGlow 2s infinite}.ai-status.ai-updating{background-color:#007bff1a;color:#007bff}@keyframes aiProcessing{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}}@keyframes iconUpdating{0%{transform:scale(1) rotate(0);opacity:1}50%{transform:scale(1.1) rotate(5deg);opacity:.7}to{transform:scale(1) rotate(0);opacity:1}}@keyframes iconChange{0%{transform:scale(1);opacity:1}25%{transform:scale(.9);opacity:.7}50%{transform:scale(1.1);opacity:.9}to{transform:scale(1);opacity:1}}@keyframes sparkle{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.2)}}@keyframes processingGlow{0%,to{box-shadow:0 0 5px #8b45134d;transform:scale(1)}50%{box-shadow:0 0 15px #8b451380;transform:scale(1.02)}}.playlist-edit-page{max-width:1000px;margin:0 auto;padding-bottom:var(--space-10);position:relative;padding-top:4rem}.playlist-content{background:var(--white);border-radius:var(--radius-2xl);padding:var(--space-10);margin-bottom:var(--space-10);box-shadow:var(--shadow-lg);border:1px solid var(--gray-200);display:flex;gap:var(--space-10);align-items:flex-start}.playlist-cover-section{flex-shrink:0}.cover-container{position:relative;width:250px;height:250px;border-radius:var(--radius-2xl);overflow:hidden;box-shadow:var(--shadow-xl);background:var(--gray-100)}.playlist-cover{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-base)}.cover-container:hover .playlist-cover{transform:scale(1.05)}.cover-upload-overlay{position:absolute;bottom:var(--space-4);right:var(--space-4);width:48px;height:48px;border-radius:50%;background:var(--primary-color);color:var(--white);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);box-shadow:var(--shadow-md);font-size:var(--font-size-lg)}.cover-upload-overlay:hover:not(:disabled){background:var(--primary-dark);transform:scale(1.1);box-shadow:var(--shadow-lg)}.cover-upload-overlay:disabled{opacity:.7;cursor:not-allowed;transform:none}.upload-spinner{display:flex;align-items:center;justify-content:center}.upload-icon{font-size:var(--font-size-lg)}.playlist-info-section{flex:1;display:flex;flex-direction:column;gap:var(--space-6)}.playlist-title{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);color:var(--gray-900);margin:0;line-height:1.2;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.playlist-title-input{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);color:var(--gray-900);margin:0;line-height:1.2;background:transparent;border:2px solid transparent;border-radius:var(--radius-lg);padding:var(--space-2) var(--space-4);padding-right:var(--space-10);width:100%;transition:all var(--transition-fast)}.playlist-title-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 4px #ff6b351a;background:#fffc}.playlist-title-input::placeholder{color:var(--gray-500);opacity:.7}.playlist-description-input{font-size:var(--font-size-base);color:var(--gray-700);margin:0;line-height:1.5;background:transparent;border:2px solid transparent;border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);padding-right:var(--space-10);width:100%;transition:all var(--transition-fast);resize:vertical;min-height:80px;font-family:inherit}.playlist-description-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 4px #ff6b351a;background:#fffc}.playlist-description-input::placeholder{color:var(--gray-500);opacity:.7}.description-display-container{margin-top:var(--space-2)}.playlist-description{font-size:var(--font-size-base);color:var(--gray-700);margin:0;line-height:1.6;font-style:italic}.title-edit-container,.description-edit-container{display:flex;flex-direction:column;gap:var(--space-3)}.input-with-icon{position:relative;display:flex;align-items:center}.edit-icon{position:absolute;right:var(--space-4);top:50%;transform:translateY(-50%);font-size:var(--font-size-base);color:var(--gray-400);pointer-events:none;opacity:.6;transition:opacity var(--transition-fast)}.input-with-icon:hover .edit-icon,.input-with-icon:focus-within .edit-icon{opacity:1}.title-edit-actions{display:flex;gap:var(--space-3);align-items:center}.title-display-container{display:flex;align-items:center;gap:var(--space-3)}.title-edit-btn{opacity:.6;font-size:var(--font-size-lg);transition:all var(--transition-fast);padding:var(--space-2);border-radius:var(--radius-lg)}.title-edit-btn:hover{opacity:1;background:#0000001a;transform:scale(1.1)}.btn-sm{font-size:var(--font-size-sm);padding:var(--space-2) var(--space-3)}.btn-ghost{background:transparent;border:1px solid transparent;color:var(--gray-600)}.btn-ghost:hover{background:var(--gray-100);border-color:var(--gray-300)}.toggle-section-btn{display:flex;align-items:center;gap:var(--space-2);background:var(--primary-color);color:var(--white);border:none;padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.toggle-section-btn:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.toggle-icon{font-size:var(--font-size-sm);transition:transform var(--transition-base);display:inline-block}.collapsible-section{overflow:hidden;transition:max-height var(--transition-base) ease-in-out}.collapsible-section.collapsed{max-height:0}.collapsible-section.expanded{max-height:1000px}.collapsible-content{padding-top:var(--space-4);opacity:1;transition:opacity var(--transition-base) ease-in-out}.collapsible-section.collapsed .collapsible-content{opacity:0;transition:opacity var(--transition-fast) ease-in-out}.playlist-stats{display:flex;gap:var(--space-8);flex-wrap:wrap}.stat{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-2)}.stat-icon{font-size:var(--font-size-2xl);opacity:.8}.stat-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--gray-900)}.stat-label{font-size:var(--font-size-sm);color:var(--gray-500);text-transform:uppercase;font-weight:var(--font-weight-medium);letter-spacing:.05em}.playlist-actions{display:flex;gap:var(--space-4);flex-wrap:wrap;flex-direction:column;margin-top:var(--space-4)}.action-group.primary-actions{display:flex;gap:var(--space-4);justify-content:flex-end;align-items:center}.action-btn{font-size:var(--font-size-lg);padding:var(--space-4) var(--space-6);font-weight:var(--font-weight-semibold)}.tracks-section{margin-bottom:var(--space-8);margin-top:var(--space-4)}.tracks-section.minimized{padding:var(--space-4) var(--space-6)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-8);padding-bottom:var(--space-4);border-bottom:2px solid var(--gray-200)}.section-header.no-border{border-bottom:none;padding-bottom:0;margin-bottom:var(--space-4)}.section-description{font-size:var(--font-size-base);color:var(--gray-600);margin:var(--space-2) 0 0 0;font-style:italic}.section-actions{display:flex;gap:var(--space-4);align-items:center}.track-count-badge{background:var(--primary-color);color:var(--white);padding:var(--space-2) var(--space-4);border-radius:var(--radius-xl);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.tracks-list{display:flex;flex-direction:column;gap:var(--space-4);margin-top:var(--space-4)}.track-item{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-5);background:var(--gray-50);border-radius:var(--radius-xl);transition:all var(--transition-fast);border:1px solid var(--gray-200)}.track-item:hover{background:var(--white);box-shadow:var(--shadow-md);transform:translate(4px)}.track-number{flex-shrink:0;width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));color:var(--white);display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-bold);font-size:var(--font-size-base);box-shadow:var(--shadow-sm)}.track-icon{flex-shrink:0;width:48px;height:48px;border-radius:var(--radius-lg);overflow:hidden;background:var(--gray-200);display:flex;align-items:center;justify-content:center}.track-icon img{width:100%;height:100%;object-fit:cover}.default-icon{font-size:var(--font-size-xl);color:var(--gray-500)}.track-info{flex:1;min-width:0}.track-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--gray-900);margin:0 0 var(--space-2) 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.track-meta{display:flex;gap:var(--space-4);font-size:var(--font-size-sm);color:var(--gray-600)}.track-duration,.track-size{display:flex;align-items:center;gap:var(--space-1)}.track-actions{flex-shrink:0}.remove-track-btn{background:var(--error-color)!important;color:var(--white)!important;font-size:var(--font-size-sm);padding:var(--space-2) var(--space-3)}.remove-track-btn:hover:not(:disabled){background:#dc2626!important;transform:translateY(-1px)}.empty-tracks{text-align:center;padding:var(--space-16) var(--space-8);color:var(--gray-500)}.empty-tracks h3{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--gray-600);margin-bottom:var(--space-2)}.empty-tracks p{font-size:var(--font-size-lg);color:var(--gray-500);margin:0}.loading{text-align:center;padding:var(--space-16);font-size:var(--font-size-lg);color:var(--gray-600)}.error-section{text-align:center;padding:var(--space-16);background:var(--white);border-radius:var(--radius-2xl);box-shadow:var(--shadow-sm)}.error-section h2{color:var(--error-color);margin-bottom:var(--space-4);font-size:var(--font-size-3xl)}.error-container{margin-top:var(--space-8);text-align:center}.error-container .alert{margin-bottom:var(--space-6)}@media (max-width: 768px){.playlist-edit-page{padding-left:var(--space-4);padding-right:var(--space-4)}.playlist-edit-page{padding-top:5rem}.playlist-content{flex-direction:column;align-items:center;text-align:center;gap:var(--space-6);padding:var(--space-6)}.cover-container{width:200px;height:200px}.playlist-title{font-size:var(--font-size-3xl)}.playlist-stats{justify-content:center;gap:var(--space-6)}.playlist-actions{justify-content:center}.tracks-section{padding:var(--space-6)}.section-header{flex-direction:column;gap:var(--space-4);align-items:flex-start}.track-item{flex-wrap:wrap;gap:var(--space-3);padding:var(--space-4)}.track-meta{flex-direction:column;gap:var(--space-1)}.track-actions{width:100%;display:flex;justify-content:flex-end}}@media (max-width: 480px){.cover-container{width:150px;height:150px}.playlist-title{font-size:var(--font-size-2xl)}.track-title{white-space:normal;overflow:visible}}.create-playlist-page{max-width:800px;margin:0 auto;padding:var(--space-6)}.page-header{text-align:center;margin-bottom:var(--space-12);padding:var(--space-8) var(--space-4);background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));border-radius:var(--radius-2xl);color:var(--white);position:relative;overflow:hidden;box-shadow:var(--shadow-lg)}.page-header:before{content:"";position:absolute;inset:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1000 1000"><defs><radialGradient id="grad"><stop offset="0%" stop-color="rgba(255,255,255,0.1)"/><stop offset="100%" stop-color="rgba(255,255,255,0)"/></radialGradient></defs><circle cx="200" cy="300" r="100" fill="url(%23grad)"/><circle cx="800" cy="700" r="150" fill="url(%23grad)"/><circle cx="500" cy="150" r="80" fill="url(%23grad)"/></svg>') no-repeat center/cover;pointer-events:none}.page-header h1{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);color:var(--white);margin-bottom:var(--space-4);text-shadow:0 2px 4px rgba(0,0,0,.1)}.page-header p{font-size:var(--font-size-xl);color:#fffffff2;max-width:600px;margin:0 auto}.create-steps{display:flex;flex-direction:column;gap:var(--space-8)}.step{display:flex;gap:var(--space-6);align-items:flex-start;opacity:.5;transition:all var(--transition-base);background:var(--white);border-radius:var(--radius-2xl);padding:var(--space-6);box-shadow:var(--shadow-md);border:1px solid var(--gray-200)}.step.active{opacity:1;box-shadow:var(--shadow-lg);border-color:var(--primary-color);transform:translateY(-2px)}.step.completed{opacity:.8;background:linear-gradient(135deg,var(--gray-50),var(--white))}.step-number{flex-shrink:0;width:48px;height:48px;border-radius:50%;background-color:var(--gray-200);color:var(--gray-500);display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-bold);font-size:var(--font-size-xl);transition:all var(--transition-fast);border:3px solid transparent;box-shadow:var(--shadow-sm)}.step.active .step-number{background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));color:var(--white);box-shadow:var(--shadow-lg);transform:scale(1.1)}.step.completed .step-number{background:linear-gradient(135deg,var(--success-color),var(--success-color-dark));color:var(--white);border-color:var(--success-color)}.step.completed .step-number:before{content:"✓";font-size:var(--font-size-lg)}.step-content{flex:1;padding-top:var(--space-2)}.step-content h3{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);color:var(--gray-800);margin:0 0 var(--space-2) 0}.step-description{color:var(--gray-600);font-size:var(--font-size-base);margin:0 0 var(--space-4) 0}.creation-form{background:var(--white);border-radius:var(--radius-2xl);padding:var(--space-8);box-shadow:var(--shadow-lg);border:1px solid var(--gray-200)}.creation-form .form-group{margin-bottom:var(--space-6)}.creation-form label{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--gray-800);margin-bottom:var(--space-3)}.creation-form input{padding:var(--space-4);font-size:var(--font-size-lg);border:2px solid var(--gray-300);border-radius:var(--radius-xl);transition:all var(--transition-fast);box-shadow:var(--shadow-xs)}.creation-form input:focus{border-color:var(--primary-color);box-shadow:0 0 0 4px #ff6b351a}.create-button{background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));color:var(--white);border:none;padding:var(--space-5) var(--space-10);border-radius:var(--radius-xl);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;gap:var(--space-3);box-shadow:var(--shadow-lg);width:100%;min-height:64px}.create-button:hover:not(:disabled){transform:translateY(-3px);box-shadow:var(--shadow-xl);background:linear-gradient(135deg,var(--primary-dark),var(--primary-color))}.create-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.add-music-section{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);padding:var(--space-6);background:var(--gray-50);border-radius:var(--radius-xl);border:2px dashed var(--gray-300);transition:all var(--transition-fast)}.add-music-section:hover{border-color:var(--primary-color);background:#ff6b350d}.add-music-btn{background:var(--primary-color);color:var(--white);border:none;padding:var(--space-4) var(--space-6);border-radius:var(--radius-lg);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;gap:var(--space-2);box-shadow:var(--shadow-md)}.add-music-btn:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.add-music-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.add-music-description{margin:0;color:var(--gray-600);font-size:var(--font-size-base);text-align:center}.job-queue-page{padding:var(--space-6);max-width:1200px;margin:0 auto}.job-queue-page .page-header{margin-bottom:var(--space-6);text-align:center}.job-queue-page .page-header h1{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--gray-900);margin-bottom:var(--space-2);background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.job-queue-page .page-header p{font-size:var(--font-size-base);color:var(--gray-600);margin:0}.tabs{display:flex;gap:var(--space-2);margin-bottom:var(--space-6);border-bottom:2px solid var(--gray-200)}.tab{background:none;border:none;padding:var(--space-3) var(--space-6);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--gray-600);cursor:pointer;border-bottom:3px solid transparent;transition:all var(--transition-fast)}.tab:hover{color:var(--gray-800)}.tab.active{color:var(--primary-color);border-bottom:3px solid var(--primary-color)}.tab-content{min-height:300px}.job-history-controls{display:flex;justify-content:flex-end;margin-bottom:var(--space-4)}.clear-history-button{background:linear-gradient(135deg,var(--error-color),var(--error-color-dark));color:#fff;border:none;border-radius:var(--radius-xl);padding:var(--space-3) var(--space-6);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-md);display:flex;align-items:center;gap:var(--space-2)}.clear-history-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg)}.clear-history-button:disabled{background:var(--gray-300);cursor:not-allowed;transform:none;box-shadow:none}.job-queue-list,.job-history-list{display:flex;flex-direction:column;gap:var(--space-4)}.job-queue-item,.job-history-item{background:var(--white);border-radius:var(--radius-2xl);border:1px solid var(--gray-200);padding:var(--space-5);transition:all var(--transition-base);box-shadow:var(--shadow-md)}.job-queue-item:hover,.job-history-item:hover{box-shadow:var(--shadow-lg);border-color:var(--gray-300);transform:translateY(-2px)}.job-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3);padding-bottom:var(--space-3);border-bottom:1px solid var(--gray-100)}.job-title{display:flex;align-items:center;gap:var(--space-3);font-weight:var(--font-weight-semibold);font-size:var(--font-size-lg);color:var(--gray-800)}.job-status-icon{font-size:var(--font-size-xl)}.job-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:300px}.job-position{font-size:var(--font-size-sm);color:var(--gray-500);background:var(--gray-50);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full)}.job-actions{display:flex;align-items:center}.cancel-job-button{background:linear-gradient(135deg,var(--error-color),var(--error-color-dark));color:#fff;border:none;border-radius:var(--radius-xl);padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.cancel-job-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md)}.cancel-job-button:disabled{background:var(--gray-300);cursor:not-allowed;transform:none;box-shadow:none}.current-job-section{margin-bottom:var(--space-6)}.current-job-section h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--gray-800);margin-bottom:var(--space-3)}.current-job{border:2px solid var(--primary-color);background:var(--primary-bg)}.job-progress{margin:var(--space-4) 0}.progress-bar-container.job-item-progress-text{font-size:var(--font-size-sm);color:var(--gray-700);margin-bottom:var(--space-2)}.job-timestamp{font-size:var(--font-size-sm);color:var(--gray-500);background:var(--gray-50);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full)}.job-details{display:flex;flex-direction:column;gap:var(--space-3)}.job-status,.job-error{display:flex;flex-direction:column;gap:var(--space-1)}.status-label,.error-label{font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);color:var(--gray-600)}.status-value{font-weight:var(--font-weight-semibold);font-size:var(--font-size-base);text-transform:capitalize;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);display:inline-block;width:fit-content}.status-completed .status-value{color:var(--success-color-dark);background:var(--success-bg);border:1px solid var(--success-color)}.status-failed .status-value,.status-cancelled .status-value{color:var(--error-color-dark);background:var(--error-bg);border:1px solid var(--error-color)}.error-message{font-size:var(--font-size-sm);color:var(--error-color);word-break:break-word;background:var(--error-bg);padding:var(--space-3);border-radius:var(--radius-lg);border:1px solid var(--error-color)}.empty-state{text-align:center;padding:var(--space-12) var(--space-6);background:var(--white);border-radius:var(--radius-2xl);border:1px dashed var(--gray-300);box-shadow:var(--shadow-md);display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.empty-icon{font-size:var(--font-size-4xl);margin-bottom:var(--space-4);color:var(--gray-400)}.empty-state h3{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--gray-800);margin-bottom:var(--space-2)}.empty-state p{font-size:var(--font-size-base);color:var(--gray-600);margin:0}.loading{text-align:center;padding:var(--space-12);font-size:var(--font-size-base);color:var(--gray-600)}.loading:after{content:"";display:inline-block;width:20px;height:20px;border:3px solid var(--gray-300);border-top:3px solid var(--primary-color);border-radius:50%;margin-left:var(--space-3);animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.job-type-badge{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);background:var(--primary-bg);color:var(--primary-color-dark);border:1px solid var(--primary-color);white-space:nowrap}.login-page{position:fixed;inset:60px 0 0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;z-index:100}.login-page.authenticated{background:linear-gradient(135deg,#56ab2f,#a8e6cf)}.login-container{background:#fff;border-radius:12px;padding:40px;box-shadow:0 10px 30px #0003;width:100%;max-width:500px;text-align:center}.login-header h1{color:#333;margin-bottom:8px;font-size:28px;font-weight:600}.login-header p{color:#666;margin-bottom:20px;font-size:16px;line-height:1.5}.login-subtitle{margin-top:20px!important;margin-bottom:30px!important;font-weight:500;color:#555}.app-features{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:20px 0;text-align:left}.feature{display:flex;align-items:center;gap:8px;font-size:14px;color:#555}.feature-icon{font-size:16px;width:20px;text-align:center}.login-form{margin-bottom:30px}.error-message{background:#fee;border:1px solid #fcc;border-radius:6px;padding:15px;margin-bottom:20px;color:#c33;font-size:14px;text-align:left}.login-actions{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.btn{padding:12px 24px;border:none;border-radius:6px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;min-height:48px}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover:not(:disabled){background:#5a67d8;transform:translateY(-1px)}.btn-secondary{background:#e2e8f0;color:#4a5568}.btn-secondary:hover:not(:disabled){background:#cbd5e0}.btn-outline{background:transparent;color:#667eea;border:2px solid #667eea}.btn-outline:hover:not(:disabled){background:#667eea;color:#fff}.btn-large{font-size:18px;padding:16px 32px;min-height:56px}.auth-flow-instructions{text-align:left}.instruction-step h3{color:#333;margin-bottom:12px;font-size:20px}.instruction-step p{color:#666;margin-bottom:12px;line-height:1.6}.instruction-step ol{color:#666;margin-bottom:20px;padding-left:20px;line-height:1.6}.instruction-step li{margin-bottom:8px}.loading-message{margin-top:20px;padding:15px;background:#f7fafc;border-radius:6px;color:#4a5568;font-style:italic}.login-footer{border-top:1px solid #e2e8f0;padding-top:20px;color:#666;font-size:14px}.login-footer a{color:#667eea;text-decoration:none}.login-footer a:hover{text-decoration:underline}.protected-route-loading,.protected-route-unauthorized{display:flex;align-items:center;justify-content:center;min-height:60vh;text-align:center}.loading-container,.unauthorized-container{background:#fff;border-radius:8px;padding:40px;box-shadow:0 4px 20px #0000001a;max-width:400px;margin:0 20px}.unauthorized-container h2{color:#333;margin-bottom:12px;font-size:24px}.unauthorized-container p{color:#666;margin-bottom:24px;line-height:1.5}.unauthorized-actions{display:flex;justify-content:center}.logout-btn{background:transparent!important;border:1px solid currentColor!important;padding:8px 16px!important;font-size:14px!important;min-height:auto!important}.logout-btn:hover{background:currentColor!important;color:#fff!important}.icon-card{background:var(--card-bg);border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000001a;transition:box-shadow .2s ease,transform .2s ease;display:flex;flex-direction:column;align-items:center;justify-content:space-between}.icon-card:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.icon-details{padding:1rem}.icon-title{margin:0 0 .5rem;font-size:1rem;font-weight:500;color:var(--text-primary);word-break:break-word}.icon-tags{margin:0 0 .5rem;display:flex;flex-wrap:wrap;gap:.25rem}.tag{background:var(--tag-bg, #e9ecef);color:var(--tag-color, #495057);padding:.125rem .5rem;border-radius:12px;font-size:.75rem;font-weight:500}.icon-meta{font-size:.875rem;color:var(--text-secondary);margin-bottom:1rem}.icon-actions{display:flex;gap:.5rem}.edit-form{display:flex;flex-direction:column;gap:.75rem}.edit-title-input,.edit-tags-input{width:100%;padding:.5rem;border:1px solid var(--border-color);border-radius:4px;font-size:1rem}.edit-actions{display:flex;gap:.5rem}.custom-icons-page{max-width:1200px;margin:0 auto;padding-bottom:var(--space-10)}.hero-inner{display:flex;gap:var(--space-4);margin-top:var(--space-6);flex-wrap:wrap;flex-direction:column}.storage-stats{padding:var(--space-6);max-width:50%;margin-left:auto;margin-right:auto;display:flex;flex-direction:column;align-items:center}.storage-stats h3{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--gray-900);margin:0 0 var(--space-4) 0}.stats-grid{display:flex;gap:var(--space-6);flex-wrap:wrap}.stat{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-1)}.stat-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--primary-color)}.stat-label{font-size:var(--font-size-sm);color:var(--gray-600);text-transform:uppercase;font-weight:var(--font-weight-medium);letter-spacing:.05em}.usage-bar{height:8px;background:var(--gray-200);border-radius:var(--radius-full);overflow:hidden}.usage-fill{height:100%;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));border-radius:var(--radius-full);transition:width var(--transition-base)}.empty-state{text-align:center;padding:var(--space-16) var(--space-8);background:var(--white);border-radius:var(--radius-2xl);box-shadow:var(--shadow-md);border:1px solid var(--gray-200)}.empty-icon{font-size:4rem;margin-bottom:var(--space-6);opacity:.6}.empty-state h3{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--gray-600);margin-bottom:var(--space-2)}.empty-state p{font-size:var(--font-size-lg);color:var(--gray-500);margin:0 0 var(--space-2) 0}.empty-subtitle{font-size:var(--font-size-base)!important;color:var(--gray-400)!important;font-style:italic}.icons-section{background:var(--white);border-radius:var(--radius-2xl);padding:var(--space-8);box-shadow:var(--shadow-md);border:1px solid var(--gray-200);margin-bottom:var(--space-8)}.section-header{margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:2px solid var(--gray-200)}.section-header-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-4)}.section-header h2{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--gray-900);margin:0}.sort-controls{display:flex;align-items:center;gap:var(--space-2)}.sort-controls label{font-weight:var(--font-weight-medium);color:var(--gray-700)}.sort-dropdown{padding:var(--space-2) var(--space-3);border:1px solid var(--gray-300);border-radius:var(--radius-md);background-color:var(--white);font-size:var(--font-size-base);color:var(--gray-700);cursor:pointer;transition:border-color var(--transition-fast)}.sort-dropdown:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #ff6b351a}.icons-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--space-6)}.icon-details{display:flex;flex-direction:column;gap:var(--space-3)}.icon-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--gray-900);margin:0;word-break:break-word}.icon-tags{display:flex;flex-wrap:wrap;gap:var(--space-2)}.tag{background:var(--primary-color);color:var(--white);padding:var(--space-1) var(--space-2);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.icon-meta{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--gray-600)}.icon-actions{display:flex;gap:var(--space-2);margin-top:var(--space-2)}.delete-btn:hover{background:var(--error-color)!important;color:var(--white)!important}.edit-form{display:flex;flex-direction:column;gap:var(--space-3)}.edit-title-input,.edit-tags-input{padding:var(--space-2) var(--space-3);border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:var(--font-size-base);transition:border-color var(--transition-fast)}.edit-title-input:focus,.edit-tags-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #ff6b351a}.edit-actions{display:flex;gap:var(--space-2)}.parent-info{width:100%;display:flex;justify-content:space-around}.info-section{width:50%}.info-section li{margin-bottom:var(--space-1);color:var(--gray-600)}.btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);border-radius:var(--radius-md)}.btn-ghost{background:transparent;border:1px solid var(--gray-300);color:var(--gray-600);transition:all var(--transition-fast)}.btn-ghost:hover:not(.delete-btn){background:var(--gray-100);border-color:var(--gray-400)}.btn-primary{background:var(--primary-color);color:var(--white);border:1px solid var(--primary-color)}.btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark)}@media (max-width: 768px){.custom-icons-page{padding-left:var(--space-4);padding-right:var(--space-4)}.stats-grid{justify-content:center;gap:var(--space-4)}.icons-grid{grid-template-columns:1fr;gap:var(--space-4)}.icons-section{padding:var(--space-6)}.icon-actions{flex-wrap:wrap}}@media (max-width: 480px){.hero-actions{flex-direction:column;gap:var(--space-3)}.icon-card{padding:var(--space-4)}.icon-image{height:100px}}.help-page{padding:2rem;max-width:800px;margin:0 auto}.help-page h1,.help-page h2{color:var(--primary-color)}.help-page section{margin-bottom:2rem}.help-page ul{list-style-type:disc;padding-left:2rem}.help-page a{color:var(--accent-dark);text-decoration:none}.help-page a:hover{text-decoration:underline;color:var(--accent-color)}.creation-status-toast{position:fixed;bottom:var(--space-6);right:var(--space-6);width:350px;background:var(--white);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);border:1px solid var(--gray-200);z-index:1000;overflow:hidden;transition:all var(--transition-base);animation:slide-in .5s ease-out forwards}.creation-status-toast.minimized{height:auto}@keyframes slide-in{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.creation-status-toast.error{border-color:var(--error-color);box-shadow:0 4px 12px #ef444433}.toast-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4);background:linear-gradient(135deg,var(--gray-50),var(--gray-100));border-bottom:1px solid var(--gray-200)}.toast-header h4{margin:0;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--gray-800);display:flex;align-items:center;gap:var(--space-2)}.toast-header h4:before{content:"🎵"}.creation-status-toast.error .toast-header h4:before{content:"⚠️"}.toast-controls{display:flex;gap:var(--space-2)}.minimize-btn,.dismiss-btn{background:none;border:none;font-size:var(--font-size-base);cursor:pointer;color:var(--gray-500);padding:var(--space-1);border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.minimize-btn:hover,.dismiss-btn:hover{background:var(--gray-200);color:var(--gray-700)}.toast-body{padding:var(--space-4)}.current-job-status{display:flex;flex-direction:column;gap:var(--space-3)}.job-title{display:flex;align-items:center;gap:var(--space-3);font-weight:var(--font-weight-medium)}.job-icon{font-size:var(--font-size-lg)}.job-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:var(--font-weight-semibold)}.job-progress-status{margin:0;font-size:var(--font-size-sm);color:var(--gray-600);min-height:20px}.detailed-progress{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-2)}.current-file{margin:0;font-size:var(--font-size-xs);color:var(--gray-500);font-family:monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;background:var(--gray-50);padding:var(--space-1) var(--space-2);border-radius:var(--radius-md)}.progress-info{display:flex;justify-content:space-between;align-items:center}.progress-bar-container{position:relative;background:var(--gray-200);border-radius:var(--radius-lg);height:16px;overflow:hidden;box-shadow:inset 0 1px 2px #0000001a}.progress-bar{height:100%;background:linear-gradient(90deg,var(--primary-color),var(--accent-color));border-radius:var(--radius-lg);transition:width var(--transition-base);box-shadow:0 1px 2px #ff6b354d}.queue-info{margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--gray-200)}.queue-info p{margin:0;font-size:var(--font-size-sm);color:var(--gray-500);text-align:center}.toast-footer{margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--gray-200)}.toast-footer .info-text{margin:0;font-size:var(--font-size-xs);color:var(--gray-500);text-align:center;font-style:italic}@keyframes progress-pulse{0%{opacity:.8}50%{opacity:1}to{opacity:.8}}.progress-bar:not(.completed){animation:progress-pulse 2s infinite}
