:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;font-weight:400;color:#1e293b;background-color:#f8fafc;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background-color:#f8fafc}h1{font-size:2em;line-height:1.2;color:#1e293b;font-weight:700}h2{font-size:1.5em;color:#1e293b;font-weight:600}h3{font-size:1.2em;color:#334155;font-weight:600}.app-container{display:flex;min-height:100vh}.main-content{flex:1;margin-left:260px;padding:40px;background-color:#f8fafc;min-height:100vh}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.main-content{margin-left:0;margin-top:60px;padding:20px}}.sidebar{position:fixed;left:0;top:0;height:100vh;width:260px;background:linear-gradient(180deg,#1e293b,#0f172a);color:#fff;display:flex;flex-direction:column;box-shadow:2px 0 10px #0000001a;z-index:1000}.sidebar-header{padding:24px 20px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-header h2{margin:0;font-size:1.5rem;font-weight:600;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-nav{flex:1;padding:20px 0;overflow-y:auto}.sidebar-link{display:flex;align-items:center;padding:12px 20px;color:#cbd5e1;text-decoration:none;transition:all .2s ease;margin:4px 12px;border-radius:8px;font-weight:500}.sidebar-link:hover{background:#ffffff1a;color:#fff;transform:translate(4px)}.sidebar-link.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px #667eea66}.sidebar-icon{margin-right:12px;font-size:1.2rem}.sidebar-footer{padding:20px;border-top:1px solid rgba(255,255,255,.1)}.logout-btn{width:100%;display:flex;align-items:center;padding:12px 20px;background:#ef44441a;color:#fca5a5;border:1px solid rgba(239,68,68,.2);border-radius:8px;cursor:pointer;transition:all .2s ease;font-weight:500}.logout-btn:hover{background:#ef444433;color:#ef4444;border-color:#ef444466}.mobile-header,.burger-menu,.mobile-logout,.mobile-overlay{display:none}@media(max-width:768px){.sidebar{display:none}.mobile-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:linear-gradient(90deg,#1e293b,#0f172a);color:#fff;position:fixed;top:0;left:0;right:0;z-index:1000;box-shadow:0 2px 10px #0000001a}.mobile-header h1{font-size:1.2rem;margin:0;font-weight:600}.burger-menu{display:flex;flex-direction:column;gap:4px;background:none;border:none;padding:8px;cursor:pointer}.burger-menu span{display:block;width:24px;height:3px;background:#fff;border-radius:2px;transition:all .3s ease}.mobile-logout{display:block;background:none;border:none;font-size:1.5rem;cursor:pointer;padding:8px}.mobile-overlay{display:block;position:fixed;inset:0;background:#00000080;z-index:999;animation:fadeIn .2s ease}.mobile-nav{position:fixed;top:0;left:0;height:100vh;width:280px;background:linear-gradient(180deg,#1e293b,#0f172a);padding:80px 20px 20px;animation:slideIn .3s ease}.mobile-link{display:flex;align-items:center;padding:16px 20px;color:#cbd5e1;text-decoration:none;margin-bottom:8px;border-radius:8px;font-weight:500;transition:all .2s ease}.mobile-link:hover{background:#ffffff1a;color:#fff}.mobile-link.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}}.springboard-form .form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:20px}.springboard-form .full-width{grid-column:1 / -1}.springboard-form textarea{padding:10px 14px;border:1px solid #cbd5e1;border-radius:8px;font-size:.95rem;transition:all .2s ease;background:#fff;color:#1e293b;font-family:inherit;resize:vertical}.springboard-form textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.springboard-form textarea::placeholder{color:#94a3b8}.date-cell{padding:12px 20px!important}.date-badge{display:inline-flex;flex-direction:column;align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:8px 12px;border-radius:10px;min-width:60px;box-shadow:0 2px 8px #667eea4d}.date-day{font-size:1.5rem;font-weight:700;line-height:1}.date-month{font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;margin-top:2px;opacity:.9}.date-year{font-size:.7rem;opacity:.8;margin-top:2px}.location-cell{font-weight:500}.location-icon{margin-right:6px}.description-cell{max-width:400px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.participation-badge{display:inline-block;padding:6px 12px;background:linear-gradient(135deg,#dcfce7,#d1fae5);color:#166534;border-radius:12px;font-size:.85rem;font-weight:500}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#fff;border-radius:16px;padding:32px;max-width:440px;width:90%;box-shadow:0 20px 60px #0000004d}.modal-content h3{margin:0 0 12px;font-size:1.25rem;color:#1e293b}.modal-content p{color:#64748b;font-size:.95rem;margin:0 0 12px;line-height:1.5}.modal-content input{width:100%;padding:10px 14px;border:1px solid #cbd5e1;border-radius:8px;font-size:.95rem;margin-bottom:20px;box-sizing:border-box;transition:border-color .2s ease}.modal-content input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.btn-secondary{background:#f1f5f9;color:#475569;border:1px solid #cbd5e1;padding:8px 20px;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease}.btn-secondary:hover{background:#e2e8f0}@media(max-width:768px){.springboard-form .form-grid{grid-template-columns:1fr}.date-badge{min-width:50px;padding:6px 10px}.date-day{font-size:1.25rem}.date-month{font-size:.7rem}.description-cell{max-width:200px}}@media(max-width:640px){.description-cell{max-width:150px}}.page-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1rem}.sync-status{font-size:.8rem;color:#888;font-weight:400;display:flex;align-items:center;gap:.4rem}.sync-status-failed,.sync-status-failed .sync-reload-btn{color:#dc2626}.sync-reload-btn{background:none;border:none;cursor:pointer;color:#888;font-size:1.1rem;padding:.1rem .3rem;border-radius:4px;line-height:1;transition:color .15s,background .15s}.sync-reload-btn:hover{color:#6366f1;background:#eef2ff}.sync-reload-btn:disabled{cursor:not-allowed;opacity:.5}.sync-reload-btn.syncing{animation:spin 1s linear infinite;color:#6366f1}.filter-bar{display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-end;background:var(--card-bg, #fff);border-radius:8px;padding:1.25rem;margin-bottom:1.5rem;box-shadow:0 1px 4px #0000000f}.filter-group{display:flex;flex-direction:column;gap:.25rem}.filter-group label{font-size:.75rem;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.05em}.filter-select,.filter-input{padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.9rem;background:#fff;min-width:140px}.filter-select:focus,.filter-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.filter-tags .tag-checkboxes{display:flex;flex-wrap:wrap;gap:.5rem;max-width:300px}.tag-checkbox-label{display:flex;align-items:center;gap:.25rem;font-size:.85rem;cursor:pointer;padding:.25rem .5rem;border-radius:4px;border:1px solid #e2e8f0;background:#f8fafc}.tag-checkbox-label:hover{background:#eef2ff;border-color:#6366f1}.filter-actions{display:flex;gap:.75rem;align-items:flex-end;margin-left:auto}.error-banner{background:#fef2f2;border:1px solid #fca5a5;border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem;font-size:.9rem;color:#991b1b}.sync-banner{display:flex;align-items:center;gap:.75rem;background:#ecfdf5;border:1px solid #6ee7b7;border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem;font-size:.9rem;color:#065f46}.sync-errors{color:#dc2626;font-weight:600}.sync-banner-close{background:none;border:none;cursor:pointer;font-size:1rem;color:#6b7280;margin-left:auto;padding:0 .25rem}.sync-loading{text-align:center;padding:3rem 1rem;color:#6b7280}.sync-hint{font-size:.85rem;color:#9ca3af;margin-top:.25rem}.empty-state-releases{text-align:center;padding:3rem 1rem;color:#6b7280;background:var(--card-bg, #fff);border-radius:8px;box-shadow:0 1px 4px #0000000f}.month-sections{display:flex;flex-direction:column;gap:1rem}.month-section{background:var(--card-bg, #fff);border-radius:8px;box-shadow:0 1px 4px #0000000f;overflow:hidden}.month-header{display:flex;align-items:center;gap:.75rem;width:100%;padding:1rem 1.25rem;background:none;border:none;cursor:pointer;font-size:1rem;font-weight:600;color:#1e293b;text-align:left}.month-header:hover{background:#f8fafc}.month-chevron{font-size:.75rem;color:#94a3b8}.month-title{flex:1;text-transform:capitalize}.month-count{font-size:.8rem;font-weight:400;color:#64748b;background:#f1f5f9;padding:.2rem .6rem;border-radius:999px}.release-list{display:flex;flex-direction:column;gap:0}.release-card{display:flex;gap:1rem;padding:.875rem 1.25rem;border-top:1px solid #f1f5f9;transition:background .15s}.release-card:hover{background:#fafafa}.release-cover{width:56px;height:56px;border-radius:4px;object-fit:cover;flex-shrink:0}.release-info{display:flex;flex-direction:column;gap:.2rem;flex:1;min-width:0}.release-title-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.release-name{font-weight:600;font-size:.95rem;color:#1e293b}.release-name a{color:#1e293b;text-decoration:none}.release-name a:hover{color:#6366f1;text-decoration:underline}.release-artist{font-size:.85rem;color:#64748b}.release-date{font-size:.8rem;color:#94a3b8}.release-badge{font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:.15rem .5rem;border-radius:4px}.badge-single{background:#dbeafe;color:#1d4ed8}.badge-album{background:#ede9fe;color:#6d28d9}.badge-compilation{background:#f3f4f6;color:#374151}.badge-ep{background:#d1fae5;color:#065f46}.release-tags{display:flex;gap:.25rem;flex-wrap:wrap;margin-top:.1rem}.tracks-toggle{background:none;border:none;cursor:pointer;font-size:.8rem;color:#6366f1;padding:.25rem 0;text-align:left;margin-top:.25rem}.tracks-toggle:hover{text-decoration:underline}.tracks-not-loaded{font-size:.78rem;color:#94a3b8;font-style:italic;padding:.2rem 0;margin:0}.track-list{list-style:none;padding:.25rem 0 0;margin:0;border-top:1px solid #f1f5f9}.track-item{display:flex;align-items:center;gap:.5rem;padding:.2rem 0;font-size:.82rem;color:#475569}.track-number{width:1.5rem;text-align:right;color:#94a3b8;font-size:.75rem;flex-shrink:0}.track-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-duration{color:#94a3b8;font-size:.75rem;flex-shrink:0}.track-spotify-link{color:#22c55e;text-decoration:none;font-size:.7rem}.releases-content{margin-top:0}@media(max-width:768px){.filter-bar{flex-direction:column;align-items:stretch}.filter-actions{margin-left:0;flex-direction:column}.filter-actions .btn{width:100%}.release-cover{width:44px;height:44px}}.page-container{max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.page-header h1{margin:0;font-size:2rem;color:#1e293b}.btn{padding:10px 20px;border-radius:8px;border:none;font-weight:500;cursor:pointer;transition:all .2s ease;font-size:.95rem;display:inline-flex;align-items:center;gap:6px}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px #667eea4d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-secondary{background:#f1f5f9;color:#475569;box-shadow:none;border:1px solid #e2e8f0}.btn-secondary:hover{background:#e2e8f0;transform:translateY(-1px)}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ef44444d}.btn-sm{padding:6px 12px;font-size:.875rem}.form-card{background:#fff;border-radius:12px;padding:24px;margin-bottom:32px;box-shadow:0 2px 8px #00000014;border:1px solid #e2e8f0}.form-card h3{margin:0 0 20px;color:#1e293b;font-size:1.25rem}.artist-form{width:100%}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:20px}.form-group{display:flex;flex-direction:column}.form-group label{font-weight:500;margin-bottom:8px;color:#475569;font-size:.9rem}.form-group input{padding:10px 14px;border:1px solid #cbd5e1;border-radius:8px;font-size:.95rem;transition:all .2s ease;background:#fff;color:#1e293b}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input::placeholder{color:#94a3b8}.form-actions{display:flex;gap:12px}.table-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;border:1px solid #e2e8f0;overflow:hidden}.table-container{overflow-x:auto}.modern-table{width:100%;border-collapse:collapse;font-size:.95rem}.modern-table thead{background:linear-gradient(180deg,#f8fafc,#f1f5f9);border-bottom:2px solid #e2e8f0}.modern-table th{padding:16px 20px;text-align:left;font-weight:600;color:#475569;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.modern-table tbody tr{border-bottom:1px solid #f1f5f9;transition:all .2s ease}.modern-table tbody tr.artist-row-clickable{cursor:pointer}.modern-table tbody tr:hover{background:#f8fafc}.modern-table tbody tr:last-child{border-bottom:none}.modern-table td{padding:16px 20px;color:#334155}.artist-name{display:flex;align-items:center;gap:12px;font-weight:500}.avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.9rem}.tags{display:flex;flex-wrap:wrap;gap:6px}.tag{padding:4px 10px;background:linear-gradient(135deg,#e0e7ff,#ddd6fe);color:#5b21b6;border-radius:12px;font-size:.8rem;font-weight:500}.empty-state{text-align:center;padding:60px 20px!important;color:#94a3b8;font-style:italic}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px}.spinner{width:40px;height:40px;border:4px solid #f1f5f9;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}.loading-container p{color:#64748b;font-size:1rem}.spotify-input-valid{border-color:#22c55e!important;box-shadow:0 0 0 3px #22c55e26!important}.spotify-input-invalid{border-color:#ef4444!important;box-shadow:0 0 0 3px #ef444426!important}.spotify-validation-msg{font-size:.825rem;font-weight:500;margin-top:6px;padding:0 2px}.spotify-msg-valid{color:#16a34a}.spotify-msg-invalid{color:#ef4444}.spotify-preview{margin-top:8px}.spotify-loading{display:flex;align-items:center;gap:8px;color:#64748b;font-size:.85rem;padding:8px 12px}.spinner-small{width:16px;height:16px;border:2px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}.spotify-card{display:flex;align-items:center;gap:12px;padding:12px;background:linear-gradient(135deg,#f0f0ff,#f5f0ff);border:1px solid #ddd6fe;border-radius:10px}.spotify-card-image{width:56px;height:56px;border-radius:50%;object-fit:cover;box-shadow:0 2px 8px #667eea33}.spotify-card-info{display:flex;flex-direction:column;gap:4px;min-width:0}.spotify-card-name{font-weight:600;color:#1e293b;font-size:.95rem}.spotify-card-genres{display:flex;flex-wrap:wrap;gap:4px}.spotify-genre-badge{padding:2px 8px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:10px;font-size:.7rem;font-weight:500}.spotify-card-followers{color:#64748b;font-size:.8rem}@media(max-width:768px){.page-header{flex-direction:column;align-items:flex-start;gap:16px}.form-grid{grid-template-columns:1fr}.modern-table{font-size:.875rem}.modern-table th,.modern-table td{padding:12px 16px}.avatar{width:32px;height:32px;font-size:.8rem}}@media(max-width:640px){.table-container{overflow-x:scroll}.modern-table{min-width:600px}}.toggle-switch{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0;position:absolute}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:#cbd5e1;border-radius:24px;transition:.3s}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;border-radius:50%;transition:.3s;box-shadow:0 1px 3px #0003}.toggle-switch input:checked+.toggle-slider{background:linear-gradient(135deg,#667eea,#764ba2)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.toggle-switch input:disabled+.toggle-slider{opacity:.5;cursor:not-allowed}.user-status-badge{display:flex;align-items:center;gap:10px}.user-status-label{font-size:.8rem;font-weight:600;color:#475569;min-width:52px}.user-status-label.active{color:#22c55e}.user-status-label.inactive{color:#ef4444}.error-banner{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:.9rem}.form-section-title{font-size:.85rem;font-weight:600;color:#475569;text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid #e2e8f0}.form-section{margin-top:24px}
