:root{--color-brand-900:#004a00;--color-brand-800:#0f350f;--color-brand-700:#1a5c1a;--color-brand-600:#3d8a3e;--color-brand-500:#5fbc60;--color-brand-400:#7ad27b;--color-brand-300:#9ee09f;--color-brand-200:#b8e5b9;--color-brand-100:#d9f0da;--color-brand-500-rgb:95, 188, 96;--color-success:#22c55e;--color-success-muted:#22c55e33;--color-warning:#f59e0b;--color-error:#ef4444;--color-info:#3b82f6;--color-background:#0b120c;--color-surface:#131d14;--color-surface-elevated:#1f4a1f;--color-surface-muted:#19281a;--color-text-primary:#e5f6e5;--color-text-secondary:#c5e8c5;--color-text-muted:#8ab58a;--color-text-disabled:#4a6b4a;--color-border:#2d5a2d;--color-border-light:#1f4a1f;--font-primary:"Inter", system-ui, sans-serif;--font-mono:"Fira Code", "Courier New", monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--font-normal:400;--font-medium:500;--font-semibold:600;--font-bold:700;--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--radius-sm:.25rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-full:9999px;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 6px #0006;--shadow-lg:0 10px 15px #00000080;--shadow-xl:0 20px 25px #0009;--transition-fast:.15s;--transition-base:.2s;--transition-slow:.3s;--ease-out:cubic-bezier(0, 0, .2, 1);--z-dropdown:100;--z-sticky:200;--z-modal:600;--z-tooltip:800}:root[data-theme=light]{--color-background:#f5f9f5;--color-surface:#fff;--color-surface-elevated:#fff;--color-surface-muted:#eef6ef;--color-text-primary:#123212;--color-text-secondary:#2f5b2f;--color-text-muted:#6b8a6b;--color-border:#d1e4d1;--color-border-light:#e8f3e8;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px #0000001a;--shadow-lg:0 10px 15px #0000001a;--shadow-xl:0 20px 25px #00000026}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-primary);font-size:var(--text-base);color:var(--color-text-primary);background-color:var(--color-background);min-height:100vh;line-height:1.5}#root{width:100%;min-height:100vh}a{color:var(--color-brand-500);transition:color var(--transition-fast) var(--ease-out);text-decoration:none}a:hover{color:var(--color-brand-400)}button{cursor:pointer;font-family:inherit;font-size:inherit;background:0 0;border:none}img{max-width:100%;height:auto}.container{max-width:1200px;padding:0 var(--space-md);margin:0 auto}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm)}.btn{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-weight:var(--font-medium);transition:all var(--transition-fast) var(--ease-out);display:inline-flex}.btn-primary:hover{background:var(--color-brand-600)}.btn-secondary{background:var(--color-surface-muted);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-border-light)}input,select,textarea{font-family:inherit;font-size:inherit;padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-primary);transition:border-color var(--transition-fast) var(--ease-out)}input:focus,select:focus,textarea:focus{border-color:var(--color-brand-500);box-shadow:0 0 0 3px rgba(var(--color-brand-500-rgb), .15);outline:none}input::placeholder{color:var(--color-text-muted)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-background)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--color-border-light)}@keyframes pulse{0%{opacity:.6}50%{opacity:1}to{opacity:.6}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.animate-pulse{animation:1.5s infinite pulse}.animate-spin{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.track-list-container{padding:var(--space-xl);color:var(--color-text-primary);box-sizing:border-box;flex-direction:column;max-width:1600px;height:100vh;margin:0 auto;display:flex;overflow:hidden}.header{margin-bottom:var(--space-xl);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.title{font-size:var(--text-3xl);font-weight:var(--font-bold);align-items:center;gap:var(--space-lg);background:linear-gradient(to right, var(--color-brand-400), var(--color-brand-300));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;display:flex}.controls{gap:var(--space-md);display:flex}.header-actions{gap:var(--space-md);align-items:center;display:flex}.btn-header-lg{align-items:center;gap:var(--space-sm);border-radius:var(--radius-lg);font-weight:var(--font-bold);font-size:var(--text-base);cursor:pointer;transition:all var(--transition-base) var(--ease-out);box-shadow:var(--shadow-md);text-transform:uppercase;letter-spacing:.025em;border:1px solid #0000;padding:.75rem 1.5rem;display:flex}.btn-header-lg:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn-header-lg:active{transform:translateY(0)}.btn-header-lg.generate{background:linear-gradient(135deg, var(--color-brand-600), var(--color-brand-500));color:#fff}.btn-header-lg.youtube-link{color:#ef4444;background:#ef44441a;border-color:#ef44444d}.btn-header-lg.youtube-link.linked{color:var(--color-success);background:#22c55e1a;border:1px solid #22c55e4d}.btn-header-lg.export{color:#3b82f6;background:#3b82f61a;border:1px solid #3b82f64d}.btn-header-lg.import{color:#f59e0b;background:#f59e0b1a;border:1px solid #f59e0b4d}.btn-header-sm{align-items:center;gap:var(--space-xs);border-radius:var(--radius-md);font-weight:var(--font-semibold);font-size:var(--text-sm);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);padding:.5rem 1rem;display:flex}.btn-header-sm:hover{background:var(--color-border);color:var(--color-text-primary)}.search-box,.filter-box{position:relative}.search-input,.genre-select{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-primary);padding:var(--space-sm) var(--space-md) var(--space-sm) 2.5rem;border-radius:var(--radius-md);font-size:var(--text-sm);transition:border-color var(--transition-base) var(--ease-out);outline:none}.search-input:focus,.genre-select:focus{border-color:var(--color-brand-500);box-shadow:0 0 0 3px rgba(var(--color-brand-500-rgb), .15)}.icon{left:var(--space-lg);color:var(--color-text-muted);width:1rem;height:1rem;position:absolute;top:50%;transform:translateY(-50%)}.tracks-table-container{background:var(--color-background);border:1px solid var(--color-surface);border-radius:var(--radius-lg);flex:1;min-height:0;overflow-y:auto}.tracks-table{border-collapse:collapse;text-align:left;width:100%}.tracks-table th,.tracks-table td{padding:var(--space-md);border-bottom:1px solid var(--color-surface)}.tracks-table th{background:var(--color-surface);color:var(--color-text-muted);font-weight:var(--font-semibold);text-transform:uppercase;font-size:var(--text-xs);letter-spacing:.05em;z-index:10;position:sticky;top:0}.tracks-table th[style*="cursor: pointer"]:hover{background:var(--color-surface-elevated);color:var(--color-text-primary)}.tracks-table tbody tr{transition:background-color var(--transition-fast) var(--ease-out)}.tracks-table tbody tr:hover{background:var(--color-surface)}.tracks-table tbody tr.selected{background:rgba(var(--color-brand-500-rgb), .1)}.col-checkbox{text-align:center;width:40px}.col-number{width:80px;font-family:var(--font-mono);color:var(--color-text-muted)}.col-title{font-weight:var(--font-semibold);color:var(--color-text-primary);cursor:pointer}.col-title:hover{color:var(--color-brand-500);text-decoration:underline}.col-genre{white-space:nowrap}.col-status{width:150px}.tag{font-size:var(--text-xs);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm)}.type-vocal{background:rgba(var(--color-brand-500-rgb), .2);color:var(--color-brand-300)}.type-inst{background:var(--color-surface-elevated);color:var(--color-text-secondary)}.status-indicators{gap:var(--space-sm);display:flex}.status-icon{border-radius:var(--radius-sm);color:#6b7280;width:24px;height:24px;font-size:var(--text-xs);cursor:help;background:#6b728026;border:1px solid #6b72804d;justify-content:center;align-items:center;display:flex}.status-icon.done{color:var(--color-success);background:#22c55e66;border:1px solid #22c55e66}.status-icon.queued{color:#3b82f6;background:#3b82f666;border:1px solid #3b82f666}.status-icon.unverified,.status-icon.partial{color:#a855f7;background:#a855f766;border:1px solid #a855f766}.status-icon.generating{color:var(--color-warning);background:#f59e0b66;border:1px solid #f59e0b66;animation:1.5s infinite pulse}.batch-toolbar{background:var(--color-brand-700);color:var(--color-text-primary);padding:var(--space-md) var(--space-xl);border-radius:var(--radius-md);margin-bottom:var(--space-md);animation:slideDown var(--transition-base) var(--ease-out);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.batch-actions{gap:var(--space-md);display:flex}.btn-batch{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-primary);border-radius:var(--radius-md);cursor:pointer;align-items:center;gap:6px;padding:6px 10px;font-size:12px;font-weight:600;transition:all .2s;display:flex;box-shadow:0 1px 2px #0000001a}.btn-batch:hover{background:var(--color-surface-elevated);border-color:var(--color-text-muted);transform:translateY(-1px);box-shadow:0 2px 5px #0003}.btn-batch:active{transform:translateY(0);box-shadow:0 1px 2px #0000001a}.status-filter-box{gap:var(--space-xs);background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);align-items:center;padding:4px;display:flex}.filter-btn{border-radius:var(--radius-sm);background:var(--color-surface-elevated);width:32px;height:32px;color:var(--color-text-muted);cursor:pointer;border:1px solid #0000;justify-content:center;align-items:center;transition:all .2s;display:flex}.filter-btn:hover{background:var(--color-border)}.filter-btn.has{color:var(--color-success);background:#22c55e66;border-color:#22c55e66}.filter-btn.missing{color:#6b7280;background:#6b728066;border-color:#6b728066}.filter-btn.queued{color:#3b82f6;background:#3b82f666;border-color:#3b82f666}.filter-btn.unverified,.filter-btn.partial{color:#a855f7;background:#a855f766;border-color:#a855f766}.filter-btn.error{color:var(--color-error);background:#ef444466;border-color:#ef444466}.loading{text-align:center;padding:var(--space-2xl);color:var(--color-text-muted)}.notifications-container{z-index:1000;flex-direction:column;gap:.5rem;max-width:400px;display:flex;position:fixed;top:1rem;right:1rem}.notification{border-radius:var(--radius-md);color:#fff;background:#dc2626;align-items:flex-start;gap:.75rem;padding:.75rem 1rem;animation:.3s ease-out slideIn;display:flex;box-shadow:0 4px 12px #0000004d}.notification.error{background:#dc2626}.notification span{font-size:var(--text-sm);flex:1;line-height:1.4}.notification .dismiss-btn{color:#ffffffb3;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:flex}.notification .dismiss-btn:hover{color:#fff}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.status-icon.error{color:#ef4444;background:#dc262666;border:1px solid #dc262666}.tracks-table tbody tr.has-error{background:#dc26260d}.tracks-table tbody tr.has-error:hover{background:#dc26261a}.error-badge{color:#fff;background:#dc2626;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;margin-left:.5rem;font-size:10px;font-weight:700;display:inline-flex}.track-detail-container{padding:var(--space-xl);color:var(--color-text-primary);max-width:1200px;margin:0 auto}.track-nav-bar{margin-bottom:var(--space-xl);justify-content:space-between;align-items:center;display:flex}.back-button{align-items:center;gap:var(--space-sm);color:var(--color-text-muted);font-size:var(--text-sm);cursor:pointer;transition:color var(--transition-fast) var(--ease-out);background:0 0;border:none;padding:0;display:inline-flex}.back-button:hover{color:var(--color-text-primary)}.track-nav-arrows{gap:var(--space-sm);display:flex}.nav-arrow-btn{background:var(--color-surface);border:1px solid var(--color-border);width:48px;height:48px;color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast) var(--ease-out);z-index:100;border-radius:50%;justify-content:center;align-items:center;display:flex;position:fixed;top:50%;transform:translateY(-50%);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.nav-arrow-btn.prev{left:2rem}.nav-arrow-btn.next{transition:all var(--transition-fast) var(--ease-out);right:2rem}.nav-arrow-btn:hover:not(:disabled){background:var(--color-brand-500);border-color:var(--color-brand-500);color:#fff}.nav-arrow-btn:disabled{opacity:.3;cursor:not-allowed}.track-header{margin-bottom:var(--space-2xl);border-bottom:1px solid var(--color-border);padding-bottom:var(--space-xl)}.track-number-large{font-family:var(--font-mono);color:var(--color-brand-500);font-size:var(--text-base);margin-bottom:var(--space-sm);display:block}.track-title-large{font-size:var(--text-4xl);background:linear-gradient(to right, var(--color-text-primary), var(--color-text-muted));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0;font-weight:800;line-height:1.1}.detail-grid{gap:var(--space-2xl);grid-template-columns:1fr 1.5fr;display:grid}.metadata-section h3,.lyrics-section h3{font-size:var(--text-xl);color:var(--color-text-primary);border-bottom:1px solid var(--color-border);padding-bottom:var(--space-lg);margin-bottom:var(--space-lg)}.meta-grid{gap:var(--space-lg);margin-bottom:var(--space-xl);grid-template-columns:1fr 1fr;display:grid}.meta-item label{color:var(--color-text-muted);font-size:var(--text-xs);margin-bottom:var(--space-xs);text-transform:uppercase;letter-spacing:.05em;display:block}.meta-item p{font-weight:var(--font-medium);margin:0}.style-box{background:var(--color-surface);border:1px solid var(--color-border);padding:var(--space-lg);border-radius:var(--radius-lg);margin-bottom:var(--space-xl)}.style-box p{color:var(--color-text-secondary);margin:0;font-style:italic;line-height:1.6}.lyrics-content{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-xl);white-space:pre-wrap;font-family:var(--font-mono);margin-bottom:var(--space-xl);min-height:300px;line-height:1.6}.empty-lyrics{background:var(--color-surface);border:2px dashed var(--color-border-light);border-radius:var(--radius-lg);height:300px;color:var(--color-text-muted);justify-content:center;align-items:center;gap:var(--space-md);flex-direction:column;display:flex}.generate-btn{background:var(--color-brand-500);color:#fff;padding:var(--space-lg) var(--space-lg);border-radius:var(--radius-md);font-weight:var(--font-semibold);cursor:pointer;align-items:center;gap:var(--space-sm);transition:background var(--transition-base) var(--ease-out);border:none;display:flex}.generate-btn:hover:not(:disabled){background:var(--color-brand-600)}.art-display{margin-bottom:var(--space-md)}.art-display img{border-radius:var(--radius-md);width:100%;margin-bottom:var(--space-md)}.songs-list h4{margin-bottom:var(--space-md);color:var(--color-text-secondary)}.song-item{background:var(--color-surface);padding:var(--space-sm);border-radius:var(--radius-sm);margin-bottom:var(--space-sm)}.song-item audio{width:100%;margin-top:var(--space-sm)}.pipeline-container{background:#0003;border-radius:8px;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:1.25rem;padding:12px;display:flex}.pipeline-stage{flex-direction:column;gap:4px;display:flex}.pipeline-stage label{opacity:.5;letter-spacing:.1em;text-transform:uppercase;margin:0;font-size:8px;font-weight:700}.status-badge{border-radius:4px;align-items:center;gap:4px;padding:2px 6px;font-size:9px;font-weight:700;display:inline-flex}.status-badge.processing{animation:1.5s infinite pulse}.mp3-chips{gap:4px;display:flex}.mp3-chip{border-radius:3px;padding:2px 4px;font-size:8px;font-weight:700}@media (width<=768px){.detail-grid{grid-template-columns:1fr}}.track-generator{background:var(--color-background);min-height:100vh;color:var(--color-text-primary);padding:var(--space-lg)}.generator-header{align-items:center;gap:var(--space-lg);margin-bottom:var(--space-xl);display:flex}.generator-header h1{align-items:center;gap:var(--space-sm);font-size:var(--text-2xl);color:var(--color-brand-400);margin:0;display:flex}.generator-header .icon{color:var(--color-brand-500)}.back-btn{align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast) var(--ease-out);display:flex}.generator-content{max-width:1400px;margin:0 auto}.generator-controls{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-xl);margin-bottom:var(--space-xl)}.control-row{gap:var(--space-lg);margin-bottom:var(--space-lg);display:flex}.selection-count{color:var(--color-brand-400);font-size:var(--text-sm)}.control-group input[type=number]{width:100px;padding:var(--space-sm) var(--space-md);background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--text-lg)}.search-group{flex:1}.search-group input[type=text]{width:100%;padding:var(--space-sm) var(--space-md);background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--text-base)}.advanced-settings{background:var(--color-surface-muted);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--space-lg);overflow:hidden}.advanced-header{padding:var(--space-md) var(--space-lg);cursor:pointer;transition:background var(--transition-fast)}.advanced-header:hover{background:var(--color-surface-elevated)}.advanced-settings h3{align-items:center;gap:var(--space-sm);color:var(--color-text-primary);font-size:var(--text-lg);margin:0;display:flex}.advanced-content{padding:0 var(--space-lg) var(--space-lg) var(--space-lg);animation:.2s ease-out slideDown}.slider-group{margin-bottom:var(--space-lg)}.slider-group:last-child{margin-bottom:0}.slider-header{margin-bottom:var(--space-sm);justify-content:space-between;align-items:center;display:flex}.slider-header label{color:var(--color-text-secondary);font-weight:var(--font-medium);font-size:var(--text-base)}.toggle-container{align-items:center;gap:var(--space-md);display:flex}.slider-value{color:var(--color-brand-400);font-weight:var(--font-semibold);font-size:var(--text-sm);text-align:right;min-width:50px}.toggle-switch{background:var(--color-surface-elevated);border:2px solid var(--color-border);border-radius:var(--radius-full);cursor:pointer;width:48px;height:24px;transition:all var(--transition-base);padding:0;position:relative}.toggle-switch:hover:not(:disabled){border-color:var(--color-brand-500)}.toggle-switch.enabled{background:var(--color-brand-600);border-color:var(--color-brand-600)}.toggle-switch:disabled{opacity:.5;cursor:not-allowed}.toggle-slider{width:16px;height:16px;transition:transform var(--transition-base);background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;box-shadow:0 2px 4px #0003}.toggle-switch.enabled .toggle-slider{transform:translate(24px)}.slider-group input[type=range]{background:var(--color-surface-elevated);border-radius:var(--radius-full);appearance:none;outline:none;width:100%;height:6px}.slider-group input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--color-brand-500);cursor:pointer;width:18px;height:18px;transition:all var(--transition-fast);border-radius:50%}.slider-group input[type=range]::-webkit-slider-thumb:hover{background:var(--color-brand-400);transform:scale(1.1)}.slider-group input[type=range]::-moz-range-thumb{background:var(--color-brand-500);cursor:pointer;width:18px;height:18px;transition:all var(--transition-fast);border:none;border-radius:50%}.slider-group input[type=range]::-moz-range-thumb:hover{background:var(--color-brand-400);transform:scale(1.1)}.slider-group input[type=range].disabled{opacity:.4;cursor:not-allowed}.slider-group input[type=range].disabled::-webkit-slider-thumb{cursor:not-allowed;background:var(--color-text-muted)}.slider-group input[type=range].disabled::-moz-range-thumb{cursor:not-allowed;background:var(--color-text-muted)}.slider-labels{margin-top:var(--space-xs);font-size:var(--text-xs);color:var(--color-text-muted);justify-content:space-between;display:flex}.genre-accordion{border:1px solid var(--color-border);border-radius:var(--radius-md);max-height:500px;overflow-y:auto}.genre-section{border-bottom:1px solid var(--color-border)}.genre-section:last-child{border-bottom:none}.genre-header{align-items:center;gap:var(--space-sm);padding:var(--space-md);background:var(--color-surface-muted);cursor:pointer;transition:background var(--transition-fast);display:flex}.genre-header:hover{background:var(--color-surface-elevated)}.genre-header.expanded{background:var(--color-surface-elevated);border-bottom:1px solid var(--color-border)}.genre-name{font-weight:var(--font-semibold);color:var(--color-text-primary)}.subgenre-total{color:var(--color-text-muted);font-size:var(--text-sm);margin-left:auto}.selected-badge{background:var(--color-brand-600);color:#fff;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium);padding:2px 8px}.select-all-btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);font-size:var(--text-xs);cursor:pointer;margin-left:var(--space-sm);transition:all var(--transition-fast);background:0 0;padding:4px 10px}.select-all-btn:hover{background:var(--color-brand-800);border-color:var(--color-brand-600);color:var(--color-text-primary)}.select-all-btn.all-selected{background:var(--color-brand-600);border-color:var(--color-brand-600);color:#fff}.subgenres-grid{gap:var(--space-xs);padding:var(--space-md);background:var(--color-background);flex-wrap:wrap;display:flex}.subgenre-chip{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-secondary);font-size:var(--text-xs);cursor:pointer;transition:all var(--transition-fast) var(--ease-out);align-items:center;gap:4px;padding:4px 10px;display:flex}.subgenre-chip:hover{background:var(--color-surface-elevated);border-color:var(--color-brand-500)}.subgenre-chip.selected{background:var(--color-brand-600);border-color:var(--color-brand-600);color:#fff}.subgenre-chip .sub-name{text-overflow:ellipsis;white-space:nowrap;max-width:200px;overflow:hidden}.subgenre-chip .track-count{border-radius:var(--radius-full);text-align:center;background:#0003;min-width:18px;padding:1px 5px;font-size:10px}.subgenre-chip .track-count.has-tracks{background:#22c55e4d}.subgenre-chip.selected .track-count{background:#fff3}.subgenre-chip.selected .track-count.has-tracks{background:#ffffff4d}.loading-genres{color:var(--color-text-muted);padding:var(--space-lg);font-style:italic}.generate-btn{justify-content:center;align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-md) var(--space-xl);background:linear-gradient(135deg, var(--color-brand-600), var(--color-brand-500));border-radius:var(--radius-lg);color:#fff;font-size:var(--text-lg);font-weight:var(--font-semibold);cursor:pointer;transition:all var(--transition-base) var(--ease-out);border:none;display:flex}.generate-btn:hover:not(:disabled){background:linear-gradient(135deg, var(--color-brand-500), var(--color-brand-400));box-shadow:var(--shadow-lg);transform:translateY(-2px)}.generate-btn:disabled{opacity:.6;cursor:not-allowed}.error-message{align-items:center;gap:var(--space-sm);margin-top:var(--space-md);padding:var(--space-md);border:1px solid var(--color-error);border-radius:var(--radius-md);color:var(--color-error);background:#ef44441a;display:flex}.generated-results{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-xl)}.generated-results h2{margin:0 0 var(--space-lg) 0;color:var(--color-brand-400)}.results-grid{gap:var(--space-md);margin-bottom:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(350px,1fr));display:grid}.result-card{background:var(--color-surface-muted);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md)}.result-card .track-header{margin-bottom:var(--space-sm)}.result-card .track-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text-primary);display:block}.result-card .track-artist{color:var(--color-text-muted);font-style:italic}.track-meta{gap:var(--space-xs);margin-bottom:var(--space-sm);flex-wrap:wrap;display:flex}.genre-badge,.subgenre-badge,.type-badge{border-radius:var(--radius-sm);font-size:var(--text-xs);padding:2px 8px}.genre-badge{background:var(--color-brand-800);color:var(--color-brand-200)}.subgenre-badge{background:var(--color-surface-elevated);color:var(--color-text-secondary)}.type-badge{color:#fff;background:#3b82f6}.type-badge.instrumental{background:#8b5cf6}.track-vibe{font-size:var(--text-sm);color:var(--color-text-secondary);margin:var(--space-sm) 0;line-height:1.5}.track-params{gap:var(--space-md);font-size:var(--text-xs);color:var(--color-text-muted);display:flex}.negative-tags{margin-top:var(--space-sm);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--text-xs);color:var(--color-error);background:#ef44441a}.view-tracks-btn{width:100%;padding:var(--space-md);background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--text-base);cursor:pointer;transition:all var(--transition-fast) var(--ease-out);display:block}.view-tracks-btn:hover{background:var(--color-brand-800);border-color:var(--color-brand-600)}.custom-add-track{background:var(--color-background);min-height:100vh;color:var(--color-text-primary);padding:var(--space-lg)}.custom-add-header{align-items:center;gap:var(--space-lg);margin-bottom:var(--space-xl);display:flex}.custom-add-header h1{align-items:center;gap:var(--space-sm);font-size:var(--text-2xl);color:var(--color-brand-400);margin:0;display:flex}.custom-add-header .icon{color:var(--color-brand-500)}.back-btn{align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;display:flex}.back-btn:hover{background:var(--color-surface-elevated);color:var(--color-text-primary)}.custom-add-content{max-width:1200px;margin:0 auto}.custom-add-controls{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-xl)}.custom-form-grid{gap:var(--space-lg);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.control-group{margin-bottom:var(--space-lg)}.control-group label{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm);color:var(--color-text-secondary);font-weight:var(--font-medium);display:flex}.control-group input,.control-group select,.control-group textarea{width:100%;padding:var(--space-sm) var(--space-md);background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--text-base)}.control-group small{color:var(--color-text-muted);font-size:var(--text-xs);margin-top:4px;display:block}.search-wrap{align-items:center;gap:var(--space-sm);padding:0 var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-background);display:flex}.search-wrap input{background:0 0;border:none;padding-left:0}.search-wrap input:focus{outline:none}.selected-subgenre{color:var(--color-brand-400);font-size:var(--text-sm)}.action-row{justify-content:flex-end;display:flex}.save-btn{align-items:center;gap:var(--space-sm);border-radius:var(--radius-md);cursor:pointer;background:var(--color-brand-600);color:#fff;font-weight:var(--font-semibold);border:1px solid #0000;padding:.75rem 1.25rem;display:inline-flex}.save-btn:disabled{opacity:.65;cursor:not-allowed}.spin{animation:1s linear infinite spin}@media (width<=900px){.custom-form-grid{grid-template-columns:1fr}.custom-add-header{flex-direction:column;align-items:flex-start}}.settings-container{max-width:1400px;margin:0 auto;padding:2rem}.settings-header{border-bottom:2px solid var(--color-border);align-items:center;gap:1rem;margin-bottom:2rem;padding-bottom:1rem;display:flex}.settings-header svg{color:var(--color-brand-500)}.settings-header h1{font-size:var(--text-4xl);color:var(--color-text-primary);margin:0}.settings-header p{color:var(--color-text-muted);font-size:var(--text-base);margin:.25rem 0 0}.btn-back{background:var(--color-surface-elevated);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-base) var(--ease-out);align-items:center;gap:.5rem;padding:.75rem 1.25rem;display:inline-flex}.btn-back:hover{background:var(--color-brand-500);border-color:var(--color-brand-500);box-shadow:0 4px 12px rgba(var(--color-brand-500-rgb), .2);transform:translateY(-1px)}.btn-back svg{color:inherit}.settings-grid{grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1.5rem;display:grid}.service-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);transition:all var(--transition-base) var(--ease-out);overflow:hidden}.service-panel:hover{border-color:var(--color-brand-500);box-shadow:0 4px 12px rgba(var(--color-brand-500-rgb), .15)}.panel-header{background:linear-gradient(135deg, rgba(var(--color-brand-500-rgb), .1) 0%, rgba(var(--color-brand-500-rgb), .05) 100%);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:flex-start;padding:1.5rem;display:flex}.panel-header h3{font-size:var(--text-xl);color:var(--color-text-primary);margin:0}.panel-header p{color:var(--color-text-muted);font-size:var(--text-sm);margin:.5rem 0 0}.default-badge{background:var(--color-success-muted);color:var(--color-success);border-radius:var(--radius-md);font-size:var(--text-xs);font-weight:var(--font-semibold);white-space:nowrap;align-items:center;gap:.375rem;padding:.375rem .75rem;display:inline-flex}.panel-content{padding:1.5rem}.form-group{margin-bottom:1.5rem}.form-group:last-of-type{margin-bottom:0}.form-group label{color:var(--color-text-primary);font-weight:var(--font-medium);font-size:var(--text-sm);margin-bottom:.5rem;display:block}.form-group select{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;color:var(--color-text-primary);font-size:var(--text-base);transition:all var(--transition-base) var(--ease-out);padding:.75rem}.form-group select:hover:not(:disabled){border-color:var(--color-brand-500)}.form-group select:focus{border-color:var(--color-brand-500);box-shadow:0 0 0 3px rgba(var(--color-brand-500-rgb), .1);outline:none}.form-group select:disabled{opacity:.5;cursor:not-allowed}.model-description{color:var(--color-text-muted);font-size:var(--text-sm);margin-top:.5rem;font-style:italic;display:block}.panel-actions{border-top:1px solid var(--color-border);gap:.75rem;margin-top:1.5rem;padding-top:1.5rem;display:flex}.panel-actions button{border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:var(--font-semibold);cursor:pointer;transition:all var(--transition-base) var(--ease-out);border:none;flex:1;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1rem;display:inline-flex}.btn-primary{background:var(--color-brand-500);color:var(--color-background)}.btn-primary:hover:not(:disabled){background:var(--color-brand-600);box-shadow:0 4px 12px rgba(var(--color-brand-500-rgb), .3);transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{color:var(--color-text-muted);border:1px solid var(--color-border);background:0 0}.btn-secondary:hover:not(:disabled){background:var(--color-surface-muted);border-color:var(--color-text-muted);color:var(--color-text-primary)}.btn-secondary:disabled{opacity:.3;cursor:not-allowed}.loading-message,.error-message{text-align:center;color:var(--color-text-muted);font-size:var(--text-lg);padding:3rem}.error-message{color:var(--color-error)}@media (width<=900px){.settings-grid{grid-template-columns:1fr}}@media (width<=640px){.settings-container{padding:1rem}.settings-header{flex-direction:column;align-items:flex-start}.panel-header{flex-direction:column;gap:1rem}.panel-actions{flex-direction:column}.panel-actions button{width:100%}}.login-container{background:var(--color-background);min-height:100vh;padding:var(--space-md);justify-content:center;align-items:center;display:flex}.login-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-2xl);width:100%;max-width:400px;box-shadow:var(--shadow-xl)}.login-header{text-align:center;margin-bottom:var(--space-xl)}.login-icon{width:64px;height:64px;margin:0 auto var(--space-md);background:var(--color-brand-500);border-radius:var(--radius-lg);color:#fff;justify-content:center;align-items:center;display:flex}.login-header h1{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text-primary);margin-bottom:var(--space-xs)}.login-header p{color:var(--color-text-muted);font-size:var(--text-sm)}.login-form{gap:var(--space-md);flex-direction:column;display:flex}.input-group{position:relative}.input-icon{left:var(--space-md);color:var(--color-text-muted);position:absolute;top:50%;transform:translateY(-50%)}.input-group input{width:100%;padding:var(--space-md) var(--space-md) var(--space-md) 2.75rem;background:var(--color-surface-muted);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--text-base);transition:all var(--transition-fast) var(--ease-out)}.input-group input:focus{border-color:var(--color-brand-500);box-shadow:0 0 0 3px rgba(var(--color-brand-500-rgb), .15);outline:none}.input-group input::placeholder{color:var(--color-text-muted)}.error-message{align-items:center;gap:var(--space-sm);color:var(--color-error);font-size:var(--text-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);background:#ef44441a;display:flex}.login-btn{padding:var(--space-md);background:var(--color-brand-500);color:#fff;border-radius:var(--radius-md);font-weight:var(--font-semibold);font-size:var(--text-base);cursor:pointer;transition:background var(--transition-fast) var(--ease-out);border:none}.login-btn:hover:not(:disabled){background:var(--color-brand-600)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.app{background-color:var(--color-background);width:100%;min-height:100vh}
