*{margin:0;padding:0;box-sizing:border-box}:root{font-family:system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}.auth-status{background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:1.5rem;margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center}.auth-status.not-authenticated{border-color:#ffc107;background-color:#fff3cd}.auth-status.authenticated{border-color:#28a745;background-color:#d4edda}.loading-spinner{border:3px solid #f3f3f3;border-top:3px solid #007bff;border-radius:50%;width:30px;height:30px;animation:spin 1s linear infinite;margin-right:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.user-info{display:flex;align-items:center;gap:1rem}.user-icon{font-size:2rem}.user-details{display:flex;flex-direction:column}.user-details strong{color:#333;font-size:1.1rem}.user-details small{color:#666;font-size:.875rem}.btn-sm{padding:.4rem .8rem;font-size:.875rem}p{margin:0;color:#856404;font-weight:600}.auth-status.authenticated p{color:#155724}.layout{min-height:100vh;background-color:#f5f5f5}.navbar{background:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000001a}.nav-brand h2{margin:0;color:#333;font-size:1.5rem}.nav-links{display:flex;gap:1.5rem}.nav-links a{text-decoration:none;color:#666;font-weight:500;padding:.5rem 1rem;border-radius:8px;transition:all .3s ease}.nav-links a:hover{color:#007bff;background-color:#f0f7ff}.nav-links a.active{color:#007bff;background-color:#e7f3ff}.main-content{padding:2rem 0}.content-wrapper{max-width:1600px;margin:0 auto;padding:0 2rem}.toast{position:fixed;top:20px;right:20px;background:#fff;border-radius:8px;padding:1rem 1.5rem;box-shadow:0 4px 12px #00000026;z-index:9999;display:flex;align-items:center;gap:1rem;min-width:300px;max-width:500px;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.toast-success{border-left:4px solid #28a745}.toast-error{border-left:4px solid #dc3545}.toast-info{border-left:4px solid #007bff}.toast span{flex:1;font-size:.95rem;color:#333}.toast-close{background:none;border:none;font-size:1.5rem;color:#666;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.toast-close:hover{background:#f0f0f0;color:#333}.dashboard{max-width:1200px;margin:0 auto;padding:2rem}.dashboard h1{font-size:2.5rem;margin-bottom:2rem;color:#333}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.dashboard-card{background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:2rem;text-decoration:none;color:#333;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;text-align:center}.dashboard-card:hover{border-color:#007bff;transform:translateY(-4px);box-shadow:0 8px 16px #007bff33}.card-icon{font-size:4rem;margin-bottom:1rem}.dashboard-card h2{margin:.5rem 0;color:#333}.dashboard-card p{color:#666;margin:0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:1.5rem;display:flex;align-items:center;gap:1rem;transition:all .3s ease}.stat-card:hover{border-color:#007bff;transform:translateY(-2px);box-shadow:0 4px 12px #007bff33}.stat-icon{font-size:3rem}.stat-info h2{margin:0;font-size:2rem;color:#333}.stat-info p{margin:0;color:#666;font-size:.9rem}.songs-container{max-width:1400px;margin:0 auto;padding:2rem}.header{margin-bottom:2rem}.header h1{margin-bottom:1rem}.header-actions{display:flex;justify-content:space-between;align-items:center;gap:1rem}.search-input{flex:1;max-width:500px;padding:.75rem 1rem;font-size:1.1rem;border:2px solid #ddd;border-radius:8px;transition:border-color .3s}.search-input:focus{outline:none;border-color:#007bff}.song-form{background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:2rem;margin-bottom:2rem}.song-form h2{margin-top:0;margin-bottom:1.5rem;color:#333}.songs-list{background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:2rem}.songs-table{width:100%;border-collapse:collapse}.songs-table th,.songs-table td{padding:1rem;text-align:left;border-bottom:1px solid #eee}.songs-table th{background-color:#f8f9fa;font-weight:600;color:#333}.songs-table tr:hover{background-color:#f8f9fa}.albums-container{max-width:1400px;margin:0 auto;padding:2rem}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.header h1{font-size:2rem;color:#333}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:all .3s ease}.btn-primary{background-color:#007bff;color:#fff}.btn-primary:hover{background-color:#0056b3}.btn-success{background-color:#28a745;color:#fff}.btn-success:hover{background-color:#1e7e34}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:#545b62}.btn-sm{padding:.4rem .8rem;font-size:.875rem;margin:0 .25rem}.btn-edit{background-color:#ffc107;color:#333}.btn-edit:hover{background-color:#e0a800}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover{background-color:#c82333}.album-form{background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:2rem;margin-bottom:2rem}.album-form h2{margin-top:0;margin-bottom:1.5rem;color:#333}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#333}.form-group input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:8px;font-size:1rem;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#007bff}.form-help{display:block;margin-top:.5rem;color:#666;font-size:.875rem}.form-actions{display:flex;gap:1rem;margin-top:1.5rem}.empty-state{text-align:center;padding:3rem;color:#666;font-size:1.2rem}.albums-list{background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:2rem}.albums-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.album-card{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:12px;padding:1.5rem;transition:all .3s ease}.album-card:hover{border-color:#007bff;transform:translateY(-4px);box-shadow:0 4px 12px #007bff33}.album-card h3{margin-top:0;color:#333}.album-meta{color:#666;font-size:.9rem;margin:.5rem 0}.album-actions{margin-top:1rem}.album-songs-preview{margin-top:1rem;padding-top:1rem;border-top:1px solid #e0e0e0}.album-songs-list{list-style:none;padding:0;margin:.5rem 0 0}.album-song-item{padding:.5rem;margin-bottom:.25rem;background:#fff;border-radius:4px;font-size:.9rem}.album-song-item.more{color:#666;font-style:italic}.loading{text-align:center;padding:3rem;font-size:1.2rem;color:#666}.songs-selection{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:1.5rem}.available-songs h3,.selected-songs h3{margin-top:0;margin-bottom:1rem;color:#333}.song-list{list-style:none;padding:0;margin:0;max-height:400px;overflow-y:auto;border:1px solid #e0e0e0;border-radius:8px;padding:.5rem}.song-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;margin-bottom:.5rem;background:#f8f9fa;border-radius:6px;transition:background-color .3s;gap:.5rem}.song-controls{display:flex;flex-direction:column;gap:.25rem}.btn-move{padding:.2rem .4rem;font-size:.9rem;min-width:24px;line-height:1;background-color:#6c757d;color:#fff}.btn-move:hover:not(:disabled){background-color:#545b62}.btn-move:disabled{background-color:#ccc;cursor:not-allowed;opacity:.5}.song-item:hover{background-color:#e9ecef}.song-item.selected{background-color:#d4edda;border:1px solid #28a745}.song-item span{flex:1}.btn-add,.btn-remove{padding:.25rem .5rem;font-size:1.2rem;min-width:30px}.btn-add{background-color:#28a745;color:#fff}.btn-add:hover{background-color:#1e7e34}.btn-remove{background-color:#dc3545;color:#fff}.btn-remove:hover{background-color:#c82333}
