.login-page{background:var(--gradient-hero);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-hero{z-index:1;padding:var(--spacing-2xl);position:relative}.login-content{text-align:center;max-width:480px}.login-logo{justify-content:center;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);display:flex}.logo-icon{width:64px;height:64px;color:var(--color-primary);filter:drop-shadow(0 0 20px #1db95480)}.logo-icon svg{width:100%;height:100%}.login-title{font-size:var(--font-size-4xl);background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:700}.login-description{font-size:var(--font-size-xl);color:var(--color-text-secondary);margin-bottom:var(--spacing-2xl);line-height:1.6}.login-description .highlight{color:var(--color-primary);font-weight:600}.login-features{gap:var(--spacing-md);margin-bottom:var(--spacing-2xl);flex-direction:column;display:flex}.feature{justify-content:center;align-items:center;gap:var(--spacing-sm);color:var(--color-text-secondary);font-size:var(--font-size-base);display:flex}.feature-icon{font-size:var(--font-size-xl)}.login-btn{min-width:280px}.login-visual{pointer-events:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.visual-ring{border:1px solid #1db9541a;border-radius:50%;animation:4s ease-in-out infinite pulse;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.ring-1{width:300px;height:300px;animation-delay:0s}.ring-2{width:500px;height:500px;animation-delay:1s}.ring-3{width:700px;height:700px;animation-delay:2s}@keyframes pulse{0%,to{opacity:.1;transform:translate(-50%,-50%)scale(1)}50%{opacity:.3;transform:translate(-50%,-50%)scale(1.05)}}@media (width<=768px){.login-title{font-size:var(--font-size-3xl)}.login-description{font-size:var(--font-size-lg)}.login-btn{width:100%}}.dashboard{background:var(--color-background);min-height:100vh}.dashboard-loading{justify-content:center;align-items:center;min-height:100vh;display:flex}.dashboard-header{background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:var(--spacing-md) 0;z-index:100;position:sticky;top:0}.header-content{justify-content:space-between;align-items:center;display:flex}.header-logo{align-items:center;gap:var(--spacing-sm);display:flex}.logo-icon-small{color:var(--color-primary)}.header-title{font-size:var(--font-size-xl);color:var(--color-text-primary);font-weight:700}.header-user{align-items:center;gap:var(--spacing-md);display:flex}.user-name{color:var(--color-text-secondary);font-weight:500}.dashboard-main{padding:var(--spacing-2xl) 0}.dashboard-section{margin-bottom:var(--spacing-2xl)}.section-header{margin-bottom:var(--spacing-lg);justify-content:space-between;align-items:center;display:flex}.section-header .section-title{margin-bottom:0}.invitation-list{gap:var(--spacing-md);flex-direction:column;display:flex}.invitation-card{padding:var(--spacing-lg);background:linear-gradient(135deg, var(--color-surface) 0%, #1db9540d 100%);border-color:#1db9544d;justify-content:space-between;align-items:center;display:flex}.invitation-playlist{font-size:var(--font-size-lg);margin-bottom:var(--spacing-xs);font-weight:600}.invitation-inviter{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.invitation-actions{gap:var(--spacing-sm);display:flex}.playlist-grid{gap:var(--spacing-lg);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));display:grid}.playlist-card{gap:var(--spacing-md);color:inherit;flex-direction:column;text-decoration:none;display:flex}.playlist-card:hover{transform:translateY(-2px)}.playlist-card-header{justify-content:space-between;align-items:flex-start;gap:var(--spacing-sm);display:flex}.playlist-name{font-size:var(--font-size-lg);font-weight:600}.playlist-description{color:var(--color-text-secondary);font-size:var(--font-size-sm);-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.playlist-meta{align-items:center;gap:var(--spacing-sm);margin-top:auto;display:flex}.empty-state{text-align:center;padding:var(--spacing-2xl)}.empty-icon{margin-bottom:var(--spacing-lg);font-size:4rem}.empty-state h3{font-size:var(--font-size-xl);margin-bottom:var(--spacing-sm)}.empty-state p{margin-bottom:var(--spacing-xl)}@media (width<=768px){.header-content{gap:var(--spacing-md);flex-direction:column}.section-header,.invitation-card{align-items:stretch;gap:var(--spacing-md);flex-direction:column}.invitation-actions{justify-content:stretch}.invitation-actions .btn{flex:1}.playlist-grid{grid-template-columns:1fr}}.create-playlist-page{min-height:100vh;padding:var(--spacing-2xl) 0;background:var(--color-background)}.create-playlist-content{max-width:600px;margin:0 auto}.back-link{align-items:center;gap:var(--spacing-sm);color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--spacing-md);transition:color var(--transition-fast);display:inline-flex}.page-title{font-size:var(--font-size-3xl);font-weight:700}.create-form{margin-bottom:var(--spacing-xl)}.form-group{margin-bottom:var(--spacing-lg)}.form-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-sm);font-weight:500;display:block}.textarea{resize:vertical;min-height:80px}.form-error{padding:var(--spacing-md);border:1px solid var(--color-error);border-radius:var(--radius-md);color:var(--color-error);font-size:var(--font-size-sm);margin-bottom:var(--spacing-lg);background:#e914291a}.form-actions{justify-content:flex-end;gap:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border);display:flex}.create-info{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--spacing-lg);border:1px solid var(--color-border)}.create-info h3{font-size:var(--font-size-lg);margin-bottom:var(--spacing-md)}.create-info ol{counter-reset:step;list-style:none}.create-info li{counter-increment:step;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) 0;color:var(--color-text-secondary);display:flex}.create-info li:before{content:counter(step);background:var(--color-primary);width:24px;height:24px;color:var(--color-background);font-size:var(--font-size-xs);border-radius:50%;justify-content:center;align-items:center;font-weight:600;display:flex}@media (width<=768px){.form-actions{flex-direction:column-reverse}.form-actions .btn{width:100%}}.playlist-detail-page{min-height:100vh;padding:var(--spacing-2xl) 0;background:var(--color-background)}.detail-loading,.detail-error{justify-content:center;align-items:center;gap:var(--spacing-lg);flex-direction:column;min-height:100vh;display:flex}.detail-content{max-width:800px;margin:0 auto}.page-header{margin-bottom:var(--spacing-xl)}.back-link{align-items:center;gap:var(--spacing-sm);color:var(--color-text-secondary);font-size:var(--font-size-sm);transition:color var(--transition-fast);display:inline-flex}.back-link:hover{color:var(--color-text-primary)}.detail-header{margin-bottom:var(--spacing-xl)}.detail-title-row{justify-content:space-between;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-sm);display:flex}.detail-title{font-size:var(--font-size-3xl);font-weight:700}.detail-description{color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.detail-meta{gap:var(--spacing-lg);color:var(--color-text-muted);font-size:var(--font-size-sm);display:flex}.detail-section{margin-bottom:var(--spacing-xl)}.section-title{align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-xl);margin-bottom:var(--spacing-lg);font-weight:600;display:flex}.section-icon{font-size:var(--font-size-2xl)}.subsection-title{font-size:var(--font-size-base);color:var(--color-text-secondary);margin:var(--spacing-lg) 0 var(--spacing-md)}.member-list{gap:var(--spacing-sm);flex-direction:column;display:flex}.member-item{align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);display:flex}.member-item.pending{opacity:.7}.member-avatar{background:var(--gradient-primary);width:40px;height:40px;color:var(--color-background);font-weight:600;font-size:var(--font-size-lg);border-radius:50%;justify-content:center;align-items:center;display:flex}.member-avatar.pending{background:var(--color-surface-hover);color:var(--color-text-secondary)}.member-info{align-items:center;gap:var(--spacing-sm);display:flex}.member-name{font-weight:500}.invite-form{padding:var(--spacing-lg)}.search-input-wrapper{position:relative}.search-spinner{right:var(--spacing-md);border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin;position:absolute;top:50%;transform:translateY(-50%)}.search-results{margin-top:var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.search-result-item{padding:var(--spacing-md);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.search-result-item:last-child{border-bottom:none}.result-info{flex-direction:column;display:flex}.result-name{font-weight:500}.result-email{font-size:var(--font-size-sm);color:var(--color-text-muted)}.no-results{text-align:center;color:var(--color-text-muted);padding:var(--spacing-lg)}.form-error{padding:var(--spacing-md);border:1px solid var(--color-error);border-radius:var(--radius-md);color:var(--color-error);font-size:var(--font-size-sm);margin-top:var(--spacing-md);background:#e914291a}.generate-card{text-align:center;padding:var(--spacing-2xl)}.generate-info{color:var(--color-text-secondary);margin-bottom:var(--spacing-xl)}.generate-hint{margin-top:var(--spacing-md);font-size:var(--font-size-sm)}.button-spinner{border:2px solid #0000004d;border-top-color:currentColor;border-radius:50%;width:18px;height:18px;animation:.8s linear infinite spin}.success-card{text-align:center;padding:var(--spacing-2xl);background:linear-gradient(135deg, var(--color-surface) 0%, #1db9541a 100%);border-color:var(--color-primary);margin-bottom:var(--spacing-xl)}.success-icon{margin-bottom:var(--spacing-md);font-size:4rem}.success-card h2{font-size:var(--font-size-2xl);margin-bottom:var(--spacing-sm)}.success-card p{color:var(--color-text-secondary);margin-bottom:var(--spacing-xl)}.generated-card{text-align:center;padding:var(--spacing-2xl)}.generated-icon{margin-bottom:var(--spacing-md);font-size:3rem}.generated-card h3{margin-bottom:var(--spacing-lg)}.tracks-loading{padding:var(--spacing-xl);justify-content:center;display:flex}.track-list{gap:var(--spacing-xs);max-height:500px;padding:var(--spacing-xs);flex-direction:column;display:flex;overflow-y:auto}.track-list::-webkit-scrollbar{width:8px}.track-list::-webkit-scrollbar-track{background:var(--color-surface);border-radius:var(--radius-sm)}.track-list::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-sm)}.track-list::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.track-item{align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);transition:background var(--transition-fast);display:flex}.track-item:hover{background:var(--color-surface-hover)}.track-image{border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;width:48px;height:48px}.track-info{flex-direction:column;flex:1;min-width:0;display:flex}.track-name{white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.track-artists{font-size:var(--font-size-sm);color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.track-album{font-size:var(--font-size-sm);color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;text-align:right;max-width:200px;overflow:hidden}.no-tracks{text-align:center;color:var(--color-text-muted);padding:var(--spacing-xl)}.delete-confirm{gap:var(--spacing-md);flex-direction:column;display:flex}.delete-actions{gap:var(--spacing-sm);flex-wrap:wrap;display:flex}.btn-danger:hover{background:#c53030}@media (width<=768px){.detail-title-row{flex-direction:column;align-items:flex-start}.detail-meta{gap:var(--spacing-sm);flex-direction:column}.search-result-item{align-items:stretch;gap:var(--spacing-md);flex-direction:column}.search-result-item .btn{width:100%}.track-album{display:none}.track-list{max-height:400px}.delete-actions{flex-direction:column}.delete-actions .btn{width:100%}.sort-mode-options{flex-direction:column}}.sort-mode-selector{margin-bottom:var(--spacing-lg)}.sort-mode-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin-bottom:var(--spacing-sm);display:block}.sort-mode-options{gap:var(--spacing-md);display:flex}.sort-mode-option{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);flex:1;display:flex}.sort-mode-option:hover{border-color:var(--color-primary);background:var(--color-surface-hover)}.sort-mode-option.selected{border-color:var(--color-primary);background:#1db9541a}.sort-mode-option input[type=radio]{display:none}.sort-mode-icon{font-size:1.5rem}.sort-mode-text{flex-direction:column;gap:2px;display:flex}.sort-mode-title{font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.sort-mode-desc{font-size:var(--font-size-xs);color:var(--color-text-secondary)}:root{--color-primary:#1db954;--color-primary-hover:#1ed760;--color-primary-dark:#169c46;--color-background:#0a0a0a;--color-surface:#121212;--color-surface-elevated:#1a1a1a;--color-surface-hover:#282828;--color-text-primary:#fff;--color-text-secondary:#b3b3b3;--color-text-muted:#6a6a6a;--color-border:#282828;--color-error:#e91429;--color-warning:#f59b23;--color-success:#1db954;--gradient-primary:linear-gradient(135deg, #1db954 0%, #1ed760 100%);--gradient-surface:linear-gradient(180deg, #1a1a1a 0%, #121212 100%);--gradient-hero:linear-gradient(135deg, #1a1a1a 0%, #0a2818 50%, #121212 100%);--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 24px #00000080;--shadow-glow:0 0 40px #1db9544d;--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, 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:2rem;--font-size-4xl:2.5rem;--spacing-xs:.25rem;--spacing-sm:.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.35s ease}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--font-family);background-color:var(--color-background);color:var(--color-text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;line-height:1.6}#root{flex-direction:column;min-height:100vh;display:flex}a{color:var(--color-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-primary-hover)}button{cursor:pointer;border:none;outline:none;font-family:inherit}.btn{justify-content:center;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-base);border-radius:var(--radius-full);transition:all var(--transition-base);font-weight:600;display:inline-flex}.btn-primary{background:var(--gradient-primary);color:var(--color-background);box-shadow:var(--shadow-md)}.btn-primary:hover{box-shadow:var(--shadow-glow);transform:scale(1.02)}.btn-primary:active{transform:scale(.98)}.btn-secondary{background:var(--color-surface-elevated);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-surface-hover);border-color:var(--color-text-muted)}.btn-ghost{color:var(--color-text-secondary);background:0 0}.btn-ghost:hover{color:var(--color-text-primary);background:var(--color-surface-hover)}.btn-danger{background:var(--color-error);color:#fff}.btn-danger:hover{opacity:.9}.btn-sm{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm)}.btn-lg{padding:var(--spacing-lg) var(--spacing-2xl);font-size:var(--font-size-lg)}.card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--spacing-xl);border:1px solid var(--color-border);transition:all var(--transition-base)}.card:hover{border-color:var(--color-text-muted);box-shadow:var(--shadow-md)}.card-elevated{background:var(--color-surface-elevated)}.input{width:100%;padding:var(--spacing-md);font-size:var(--font-size-base);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);transition:all var(--transition-fast);font-family:inherit}.input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #1db95433}.input::placeholder{color:var(--color-text-muted)}.container{width:100%;max-width:1200px;padding:0 var(--spacing-lg);margin:0 auto}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.gap-xl{gap:var(--spacing-xl)}.text-center{text-align:center}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-text-muted)}.badge{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs);border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.5px;align-items:center;font-weight:600;display:inline-flex}.badge-pending{color:var(--color-warning);background:#f59b2333}.badge-success{color:var(--color-success);background:#1db95433}.badge-owner{color:var(--color-primary);background:#1db95433}.badge-member{color:var(--color-text-secondary);background:#b3b3b333}.spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.page-enter{opacity:0;transform:translateY(10px)}.page-enter-active{opacity:1;transition:all var(--transition-base);transform:translateY(0)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-fadeIn{animation:fadeIn var(--transition-base) ease-out}.animate-slideUp{animation:slideUp var(--transition-base) ease-out}@media (width<=768px){.container{padding:0 var(--spacing-md)}.btn-lg{width:100%}}
