: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: rgba(34, 197, 94, .2);--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-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 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .5);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .6);--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: #ffffff;--color-surface-elevated: #ffffff;--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 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .15)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-primary);font-size:var(--text-base);color:var(--color-text-primary);background-color:var(--color-background);line-height:1.5;min-height:100vh}#root{width:100%;min-height:100vh}a{color:var(--color-brand-500);text-decoration:none;transition:color var(--transition-fast) var(--ease-out)}a:hover{color:var(--color-brand-400)}button{cursor:pointer;font-family:inherit;font-size:inherit;border:none;background:none}img{max-width:100%;height:auto}.container{max-width:1200px;margin:0 auto;padding:0 var(--space-md)}.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{display:inline-flex;align-items:center;justify-content: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)}.btn-primary{background:var(--color-brand-500);color:#fff}.btn-primary:hover{background:var(--color-brand-600)}.btn-primary:disabled{opacity:.7;cursor:not-allowed}.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{outline:none;border-color:var(--color-brand-500);box-shadow:0 0 0 3px rgba(var(--color-brand-500-rgb),.15)}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%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}.animate-pulse{animation:pulse 1.5s infinite}.animate-spin{animation:spin 1s linear infinite}.track-list-container{padding:var(--space-xl);color:var(--color-text-primary);max-width:1600px;margin:0 auto;height:100vh;display:flex;flex-direction:column;overflow:hidden;box-sizing:border-box}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xl);flex-shrink:0}.title{font-size:var(--text-3xl);font-weight:var(--font-bold);display:flex;align-items:center;gap:var(--space-lg);background:linear-gradient(to right,var(--color-brand-400),var(--color-brand-300));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.controls{display:flex;gap:var(--space-md)}.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);outline:none;transition:border-color var(--transition-base) var(--ease-out)}.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{position:absolute;left:var(--space-lg);top:50%;transform:translateY(-50%);color:var(--color-text-muted);width:1rem;height:1rem}.tracks-table-container{background:var(--color-background);border:1px solid var(--color-surface);border-radius:var(--radius-lg);flex:1;overflow-y:auto;min-height:0}.tracks-table{width:100%;border-collapse:collapse;text-align:left}.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;position:sticky;top:0;z-index:10}.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{width:40px;text-align:center}.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{display:flex;gap:var(--space-sm)}.status-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:#6b728026;color:#6b7280;border:1px solid rgba(107,114,128,.3);font-size:var(--text-xs);cursor:help}.status-icon.error{background:#ef444433;color:var(--color-error);border:1px solid rgba(239,68,68,.4)}.status-icon.done{background:#22c55e33;color:var(--color-success);border:1px solid rgba(34,197,94,.4)}.status-icon.queued{background:#f59e0b33;color:var(--color-warning);border:1px solid rgba(245,158,11,.4)}.status-icon.generating{background:#3b82f633;color:#3b82f6;border:1px solid rgba(59,130,246,.4);animation:pulse 1.5s infinite}.batch-toolbar{background:var(--color-brand-700);color:var(--color-text-primary);padding:var(--space-md) var(--space-xl);display:flex;justify-content:space-between;align-items:center;border-radius:var(--radius-md);margin-bottom:var(--space-md);animation:slideDown var(--transition-base) var(--ease-out);flex-shrink:0}.batch-actions{display:flex;gap:var(--space-md)}.btn-batch{background:var(--color-text-primary);color:var(--color-brand-700);border:none;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-weight:var(--font-semibold);cursor:pointer;display:flex;align-items:center;gap:var(--space-sm);transition:background var(--transition-fast) var(--ease-out)}.btn-batch:hover{background:var(--color-brand-100)}.status-filter-box{display:flex;gap:var(--space-xs);padding:4px;background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);align-items:center}.filter-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);border:1px solid transparent;background:var(--color-surface-elevated);color:var(--color-text-muted);cursor:pointer;transition:all .2s ease}.filter-btn:hover{background:var(--color-border)}.filter-btn.has{background:#22c55e33;color:var(--color-success);border-color:#22c55e66}.filter-btn.missing{background:#6b728033;color:#6b7280;border-color:#6b728066}.filter-btn.queued{background:#3b82f633;color:#3b82f6;border-color:#3b82f666}.filter-btn.error{background:#ef444433;color:var(--color-error);border-color:#ef444466}.loading{text-align:center;padding:var(--space-2xl);color:var(--color-text-muted)}.notifications-container{position:fixed;top:1rem;right:1rem;z-index:1000;display:flex;flex-direction:column;gap:.5rem;max-width:400px}.notification{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 1rem;border-radius:var(--radius-md);background:#dc2626;color:#fff;box-shadow:0 4px 12px #0000004d;animation:slideIn .3s ease-out}.notification.error{background:#dc2626}.notification span{flex:1;font-size:var(--text-sm);line-height:1.4}.notification .dismiss-btn{background:none;border:none;color:#ffffffb3;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center}.notification .dismiss-btn:hover{color:#fff}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.status-icon.error{background:#dc262633;color:#ef4444;border:1px solid rgba(220,38,38,.4)}.tracks-table tbody tr.has-error{background:#dc26260d}.tracks-table tbody tr.has-error:hover{background:#dc26261a}.error-badge{display:inline-flex;align-items:center;justify-content:center;margin-left:.5rem;width:16px;height:16px;border-radius:50%;background:#dc2626;color:#fff;font-size:10px;font-weight:700}.track-detail-container{padding:var(--space-xl);color:var(--color-text-primary);max-width:1200px;margin:0 auto}.track-nav-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xl)}.back-button{display:inline-flex;align-items:center;gap:var(--space-sm);color:var(--color-text-muted);background:transparent;border:none;font-size:var(--text-sm);cursor:pointer;padding:0;transition:color var(--transition-fast) var(--ease-out)}.back-button:hover{color:var(--color-text-primary)}.track-nav-arrows{display:flex;gap:var(--space-sm)}.nav-arrow-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-md);background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast) var(--ease-out)}.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);display:block;margin-bottom:var(--space-sm)}.track-title-large{font-size:var(--text-4xl);font-weight:800;margin:0;background:linear-gradient(to right,var(--color-text-primary),var(--color-text-muted));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1.1}.detail-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:var(--space-2xl)}.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{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg);margin-bottom:var(--space-xl)}.meta-item label{display:block;color:var(--color-text-muted);font-size:var(--text-xs);margin-bottom:var(--space-xs);text-transform:uppercase;letter-spacing:.05em}.meta-item p{margin:0;font-weight:var(--font-medium)}.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);line-height:1.6;margin:0;font-style:italic}.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);line-height:1.6;margin-bottom:var(--space-xl);min-height:300px}.empty-lyrics{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;background:var(--color-surface);border:2px dashed var(--color-border-light);border-radius:var(--radius-lg);color:var(--color-text-muted);gap:var(--space-md)}.generate-btn{background:var(--color-brand-500);color:#fff;border:none;padding:var(--space-lg) var(--space-lg);border-radius:var(--radius-md);font-weight:var(--font-semibold);cursor:pointer;display:flex;align-items:center;gap:var(--space-sm);transition:background var(--transition-base) var(--ease-out)}.generate-btn:hover:not(:disabled){background:var(--color-brand-600)}.generate-btn:disabled{opacity:.7;cursor:not-allowed}.art-display{margin-bottom:var(--space-md)}.art-display img{width:100%;border-radius:var(--radius-md);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)}@media(max-width:768px){.detail-grid{grid-template-columns:1fr}}.track-generator{min-height:100vh;background:var(--color-background);color:var(--color-text-primary);padding:var(--space-lg)}.generator-header{display:flex;align-items:center;gap:var(--space-lg);margin-bottom:var(--space-xl)}.generator-header h1{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--text-2xl);color:var(--color-brand-400);margin:0}.generator-header .icon{color:var(--color-brand-500)}.back-btn{display:flex;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)}.back-btn:hover{background:var(--color-surface-elevated);color:var(--color-text-primary)}.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{display:flex;gap:var(--space-lg);margin-bottom:var(--space-lg)}.control-group{margin-bottom:var(--space-lg)}.control-group label{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm);color:var(--color-text-secondary);font-weight:var(--font-medium)}.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{display:flex;align-items:center;gap:var(--space-sm);margin:0;color:var(--color-text-primary);font-size:var(--text-lg)}.advanced-content{padding:0 var(--space-lg) var(--space-lg) var(--space-lg);animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.slider-group{margin-bottom:var(--space-lg)}.slider-group:last-child{margin-bottom:0}.slider-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.slider-header label{color:var(--color-text-secondary);font-weight:var(--font-medium);font-size:var(--text-base)}.toggle-container{display:flex;align-items:center;gap:var(--space-md)}.slider-value{color:var(--color-brand-400);font-weight:var(--font-semibold);font-size:var(--text-sm);min-width:50px;text-align:right}.toggle-switch{position:relative;width:48px;height:24px;background:var(--color-surface-elevated);border:2px solid var(--color-border);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-base);padding:0}.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{position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform var(--transition-base);box-shadow:0 2px 4px #0003}.toggle-switch.enabled .toggle-slider{transform:translate(24px)}.slider-group input[type=range]{width:100%;height:6px;background:var(--color-surface-elevated);border-radius:var(--radius-full);outline:none;-webkit-appearance:none;appearance:none}.slider-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;background:var(--color-brand-500);border-radius:50%;cursor:pointer;transition:all var(--transition-fast)}.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{width:18px;height:18px;background:var(--color-brand-500);border-radius:50%;cursor:pointer;border:none;transition:all var(--transition-fast)}.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{display:flex;justify-content:space-between;margin-top:var(--space-xs);font-size:var(--text-xs);color:var(--color-text-muted)}.genre-accordion{max-height:500px;overflow-y:auto;border:1px solid var(--color-border);border-radius:var(--radius-md)}.genre-section{border-bottom:1px solid var(--color-border)}.genre-section:last-child{border-bottom:none}.genre-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);background:var(--color-surface-muted);cursor:pointer;transition:background var(--transition-fast)}.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;padding:2px 8px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium)}.select-all-btn{padding:4px 10px;background:transparent;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)}.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{display:flex;flex-wrap:wrap;gap:var(--space-xs);padding:var(--space-md);background:var(--color-background)}.subgenre-chip{display:flex;align-items:center;gap:4px;padding:4px 10px;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)}.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{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.subgenre-chip .track-count{background:#0003;padding:1px 5px;border-radius:var(--radius-full);font-size:10px;min-width:18px;text-align:center}.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);font-style:italic;padding:var(--space-lg)}.generate-btn{display:flex;align-items:center;justify-content: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:none;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)}.generate-btn:hover:not(:disabled){background:linear-gradient(135deg,var(--color-brand-500),var(--color-brand-400));transform:translateY(-2px);box-shadow:var(--shadow-lg)}.generate-btn:disabled{opacity:.6;cursor:not-allowed}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-message{display:flex;align-items:center;gap:var(--space-sm);margin-top:var(--space-md);padding:var(--space-md);background:#ef44441a;border:1px solid var(--color-error);border-radius:var(--radius-md);color:var(--color-error)}.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{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:var(--space-md);margin-bottom:var(--space-lg)}.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{display:block;font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text-primary)}.result-card .track-artist{color:var(--color-text-muted);font-style:italic}.track-meta{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-bottom:var(--space-sm)}.genre-badge,.subgenre-badge,.type-badge{padding:2px 8px;border-radius:var(--radius-sm);font-size:var(--text-xs)}.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{background:#3b82f6;color:#fff}.type-badge.instrumental{background:#8b5cf6}.track-vibe{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.5;margin:var(--space-sm) 0}.track-params{display:flex;gap:var(--space-md);font-size:var(--text-xs);color:var(--color-text-muted)}.negative-tags{margin-top:var(--space-sm);padding:var(--space-xs) var(--space-sm);background:#ef44441a;border-radius:var(--radius-sm);font-size:var(--text-xs);color:var(--color-error)}.view-tracks-btn{display:block;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)}.view-tracks-btn:hover{background:var(--color-brand-800);border-color:var(--color-brand-600)}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-background);padding:var(--space-md)}.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);display:flex;align-items:center;justify-content:center;color:#fff}.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{display:flex;flex-direction:column;gap:var(--space-md)}.input-group{position:relative}.input-icon{position:absolute;left:var(--space-md);top:50%;transform:translateY(-50%);color:var(--color-text-muted)}.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{outline:none;border-color:var(--color-brand-500);box-shadow:0 0 0 3px rgba(var(--color-brand-500-rgb),.15)}.input-group input::placeholder{color:var(--color-text-muted)}.error-message{display:flex;align-items:center;gap:var(--space-sm);color:var(--color-error);font-size:var(--text-sm);background:#ef44441a;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md)}.login-btn{padding:var(--space-md);background:var(--color-brand-500);color:#fff;border:none;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)}.login-btn:hover:not(:disabled){background:var(--color-brand-600)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.app{min-height:100vh;width:100%;background-color:var(--color-background)}
