*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0B0F14;--bg-card: #121821;--bg-elevated: #1A1F2B;--accent: #FF8C1A;--accent-hover: #FFA726;--accent-active:#E65100;--text-primary: #FFFFFF;--text-secondary:#B0B7C3;--text-muted: #6B7280;--border: #2A2F3A;--border-subtle:#1F2530}body{font-family:Inter,system-ui,sans-serif;background:var(--bg);color:var(--text-primary);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}.nav{position:fixed;top:0;left:0;right:0;z-index:50;background:#0b0f14f2;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid var(--border-subtle)}.nav-inner{max-width:480px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;padding:0 1rem;height:56px}.nav-logo{text-decoration:none;display:inline-flex;align-items:center}.nav-logo-image{display:block;height:36px;width:auto}.nav-suggest-btn{background:var(--accent);color:#000;font-weight:700;font-family:inherit;border-radius:20px;padding:.4rem 1rem;font-size:.8rem;border:none;cursor:pointer;text-decoration:none;display:inline-block;transition:background .15s}.nav-suggest-btn:hover{background:var(--accent-hover)}.wizard-page{padding-top:56px;min-height:100vh;display:flex;flex-direction:column;align-items:center;max-width:480px;margin:0 auto;width:100%;padding-left:1.25rem;padding-right:1.25rem}.mascot-wrap{display:flex;justify-content:center;padding:1rem 0 0}.mascot-img{width:320px;height:320px;object-fit:contain}.mascot-img--result{width:320px;height:320px;object-fit:contain;margin-top:1.5rem;margin-bottom:.25rem}.progress-dots{display:flex;gap:6px;justify-content:center;padding:.2rem 0}.dot{width:6px;height:6px;border-radius:50%;background:var(--border);transition:all .2s}.dot.active{background:var(--accent);width:18px;border-radius:3px}.dot.done{background:var(--text-muted)}.step-container{flex:1;width:100%;display:flex;flex-direction:column;padding:0 0 2rem}.step-body{flex:1;display:flex;flex-direction:column;padding-top:1rem;transition:opacity .5s ease}.step-body--hidden{opacity:0;pointer-events:none}.step-question{font-size:1.3rem;font-weight:800;color:var(--text-primary);margin-bottom:1.5rem;line-height:1.3}.subtle{color:var(--text-muted);font-size:.82rem;font-weight:400}.genre-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.genre-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;color:var(--text-secondary);font-weight:600;font-family:inherit;font-size:.85rem;padding:1rem .5rem;cursor:pointer;transition:border-color .15s,color .15s,background .15s;line-height:1.2}.genre-btn:hover{border-color:var(--accent);color:var(--accent)}.genre-btn.active{background:var(--accent);border-color:var(--accent);color:#000;font-weight:800}.tag-group{display:flex;flex-wrap:wrap;gap:.4rem}.subgenre-examples{display:flex;flex-direction:column;gap:.3rem;margin-top:.6rem}.subgenre-example-row{display:flex;flex-direction:column;gap:.2rem;font-size:.8rem}.subgenre-example-name{color:var(--accent);font-weight:600}.subgenre-example-songs{display:flex;flex-direction:column;gap:.15rem;color:var(--text-muted);font-style:italic;padding-left:.75rem}.tag{padding:.45rem 1rem;border-radius:20px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;font-family:inherit;font-size:.82rem;transition:border-color .15s,color .15s,background .15s}.tag:hover:not(:disabled){border-color:var(--accent)}.tag.preferred{border-color:var(--accent);color:var(--accent);background:#ff8c1a1a}.tag.excluded{border-color:#f87171;color:#f87171;background:#f871711a;text-decoration:line-through}.tag:disabled{opacity:.3;cursor:not-allowed}.importance-chips{display:flex;gap:.4rem;margin-top:1.25rem;align-items:center;flex-wrap:wrap}.importance-label-text{font-size:.75rem;color:var(--text-muted);margin-right:.1rem}.importance-chip{border:1px solid var(--border);background:transparent;color:var(--text-muted);border-radius:20px;padding:.25rem .75rem;font-size:.75rem;font-family:inherit;cursor:pointer;transition:border-color .15s,color .15s}.importance-chip:hover{border-color:var(--text-muted)}.importance-chip.selected{border-color:var(--accent);color:var(--accent)}.energy-slider{width:100%;accent-color:var(--accent);cursor:pointer;height:4px;margin:.5rem 0}.energy-value{font-size:1.5rem;font-weight:900;color:var(--accent);margin-left:.5rem}.energy-description{font-size:.82rem;color:var(--text-muted);margin-top:.5rem;line-height:1.4}.decade-group{display:flex;flex-wrap:nowrap;gap:.35rem}.decade-btn{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;padding:.5rem .2rem;border-radius:10px;border:1px solid var(--border);background:var(--bg-card);cursor:pointer;font-family:inherit;transition:all .15s}.decade-label{font-size:.68rem;color:var(--text-muted);white-space:nowrap}.decade-rating{font-size:.9rem;font-weight:700}.decade-btn.rating-0 .decade-rating{color:var(--border)}.decade-btn.rating-1 .decade-rating{color:#86efac}.decade-btn.rating-2{border-color:var(--accent);background:#ff8c1a14}.decade-btn.rating-2 .decade-rating{color:var(--accent)}.decade-btn.rating--1 .decade-rating{color:#fca5a5}.decade-btn.rating--2{border-color:#f87171;background:#f8717114}.decade-btn.rating--2 .decade-rating{color:#f87171}.wizard-nav{display:flex;gap:.75rem;margin-top:auto;padding-top:2rem;width:100%}.back-btn{flex:1;padding:.9rem;border:1px solid var(--border);background:transparent;color:var(--text-secondary);border-radius:12px;font-weight:600;font-family:inherit;font-size:.95rem;cursor:pointer;transition:border-color .15s}.back-btn:hover{border-color:var(--text-muted)}.next-btn{flex:2;padding:.9rem;background:var(--accent);color:#000;border:none;border-radius:12px;font-weight:800;font-family:inherit;font-size:.95rem;cursor:pointer;letter-spacing:.02em;transition:background .15s}.next-btn:hover:not(:disabled){background:var(--accent-hover)}.next-btn:disabled{opacity:.4;cursor:not-allowed}.roll-btn{flex:2;padding:.9rem;background:var(--accent);color:#000;border:none;border-radius:12px;font-weight:900;font-family:inherit;font-size:1rem;cursor:pointer;letter-spacing:.05em;box-shadow:0 0 24px #ff8c1a66;transition:background .15s,box-shadow .15s}.roll-btn:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 0 32px #ff8c1a99}.roll-btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.loading-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:2rem 0;color:var(--text-muted);font-size:.9rem}.loading-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.error-message{margin:1rem 0;padding:.75rem 1rem;border:1px solid #f87171;border-radius:10px;color:#f87171;font-size:.88rem}@keyframes resultReveal{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes resultFadeIn{0%{opacity:0}to{opacity:1}}.result-screen{width:100%;padding-top:56px;padding-bottom:2rem;min-height:100vh;display:flex;flex-direction:column;align-items:center;max-width:480px;margin:0 auto;padding-left:1.25rem;padding-right:1.25rem;animation:resultFadeIn 2s ease forwards}.result-eyebrow{font-size:.7rem;font-weight:700;letter-spacing:.15em;color:var(--accent);text-transform:uppercase;margin-top:2rem;margin-bottom:.75rem;align-self:flex-start}.result-card{display:grid;grid-template-columns:minmax(0,1fr) 80px;column-gap:1rem;width:100%;background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:1.75rem;margin-bottom:1.25rem}.album-art-wrap{grid-column:2;grid-row:1 / span 4;width:80px;height:80px}.result-card>:not(.album-art-wrap):not(.song-actions){grid-column:1;min-width:0}.album-art{width:80px;height:80px;border-radius:8px;object-fit:cover;display:block}.album-art--placeholder{width:80px;height:80px;border-radius:8px;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.song-title{font-size:1.4rem;font-weight:900;line-height:1.1;color:var(--text-primary);margin-bottom:.25rem;text-transform:capitalize;overflow-wrap:anywhere}.song-artist{font-size:.8rem;color:var(--text-secondary);margin-bottom:1rem;text-transform:capitalize;overflow-wrap:anywhere}.song-meta{display:flex;gap:.75rem;flex-wrap:wrap;font-size:.75rem;color:var(--text-muted);margin-bottom:1rem}.meta-item{display:inline-block;font-size:.65rem}.song-moods{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1rem}.mood-tag{padding:.2rem .65rem;border-radius:20px;background:var(--bg-elevated);color:var(--text-muted);font-size:.65rem;text-transform:capitalize}.song-actions{display:flex;flex-direction:column;gap:.5rem;grid-column:1 / -1;margin-top:1.25rem}.preview-row{display:flex}.preview-row .preview-btn{width:100%;justify-content:center}.platform-row{display:flex;gap:.5rem;width:100%}.platform-row .platform-link{flex:1;display:flex;justify-content:center;text-align:center;min-width:0}.preview-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border:1px solid var(--border);border-radius:8px;background:transparent;color:var(--text-primary);cursor:pointer;font-family:inherit;font-size:.85rem;transition:border-color .15s,background .15s}.preview-btn:hover:not(:disabled){border-color:var(--text-muted);background:var(--bg-elevated)}.preview-btn--loading{opacity:.5;cursor:default}.preview-btn--unavailable{opacity:.3;cursor:default}.preview-spinner{display:inline-block;width:12px;height:12px;border:2px solid var(--border);border-top-color:var(--text-muted);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.platform-link{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem 1rem;border-radius:8px;font-size:.82rem;font-weight:500;text-decoration:none;transition:opacity .15s}.platform-link:hover{opacity:.8}.platform-link--apple{background:#fc3c44;color:#fff}.platform-link--spotify{background:#1db954;color:#fff}.platform-link--youtube{background:red;color:#fff}.loading-blank{min-height:100vh;background:var(--bg)}.boomstead-quote{font-size:.9rem;font-style:italic;color:var(--text-secondary);text-align:center;padding:.25rem 1rem .75rem}.result-actions{display:flex;flex-direction:column;gap:.75rem;width:100%}.reroll-btn{width:100%;padding:1rem;background:var(--accent);color:#000;border:none;border-radius:12px;font-weight:900;font-family:inherit;font-size:1rem;cursor:pointer;letter-spacing:.05em;box-shadow:0 0 24px #ff8c1a59;transition:background .15s,box-shadow .15s}.reroll-btn:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 0 32px #ff8c1a8c}.reroll-btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.back-to-form-btn{width:100%;padding:.9rem;background:transparent;border:1px solid var(--border);color:var(--text-secondary);border-radius:12px;font-weight:600;font-family:inherit;font-size:.95rem;cursor:pointer;transition:border-color .15s}.back-to-form-btn:hover{border-color:var(--text-muted)}.suggest-page{max-width:480px;margin:0 auto;padding:80px 1.25rem 2rem}.suggest-page .app-header{margin-bottom:1.75rem}.suggest-page .app-header h1{font-size:1.5rem;font-weight:900}.suggest-page .tagline{color:var(--text-muted);font-size:.88rem;margin-top:.25rem}.suggest-form{display:flex;flex-direction:column;gap:1.75rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-size:.9rem;color:var(--text-secondary);font-weight:600}.required{color:#f87171}.text-field{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border);border-radius:10px;padding:.6rem .85rem;font-size:.95rem;font-family:inherit;width:100%;outline:none;transition:border-color .15s}.text-field:focus{border-color:var(--accent)}.text-field--short{max-width:10rem}.genre-check-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.4rem}.check-label{display:flex;align-items:center;gap:.4rem;font-size:.82rem;color:var(--text-secondary);cursor:pointer}.check-label--disabled{opacity:.3;cursor:not-allowed}.check-input{accent-color:var(--accent);cursor:pointer}.suggest-btn{width:100%;padding:1rem;background:var(--accent);color:#000;border:none;border-radius:12px;font-weight:800;font-family:inherit;font-size:1rem;cursor:pointer;transition:background .15s}.suggest-btn:hover:not(:disabled){background:var(--accent-hover)}.suggest-btn:disabled{opacity:.4;cursor:not-allowed}.success-card{margin-top:3rem;padding:2rem;border:1px solid var(--border);border-radius:16px;background:var(--bg-card);text-align:center}.success-card h2{font-size:1.4rem;font-weight:800;margin-bottom:.5rem}.success-card p{color:var(--text-muted);font-size:.9rem}.admin-page{min-height:100vh}.app{max-width:900px;margin:0 auto;padding:80px 1.25rem 2rem}.app-header{margin-bottom:1.5rem}.app-header h1{font-size:1.5rem;font-weight:900}.admin-auth-gate{max-width:360px;margin:6rem auto;padding:2rem;border:1px solid var(--border);border-radius:16px;background:var(--bg-card);text-align:center}.admin-auth-gate h2{font-size:1.2rem;font-weight:800;margin-bottom:1.25rem}.admin-auth-form{display:flex;flex-direction:column;gap:.75rem}.admin-key-input{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border);border-radius:10px;padding:.65rem .85rem;font-size:.95rem;font-family:inherit;width:100%;outline:none;text-align:center;transition:border-color .15s}.admin-key-input:focus{border-color:var(--accent)}.admin-submit-btn{width:100%;padding:.9rem;background:var(--accent);color:#000;border:none;border-radius:10px;font-weight:800;font-family:inherit;font-size:.95rem;cursor:pointer;transition:background .15s}.admin-submit-btn:hover:not(:disabled){background:var(--accent-hover)}.admin-submit-btn:disabled{opacity:.4;cursor:not-allowed}.admin-tabs{display:flex;gap:.25rem;margin-bottom:1.25rem;border-bottom:1px solid var(--border-subtle)}.admin-tab{background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-family:inherit;font-size:.88rem;padding:.5rem 1rem;cursor:pointer;transition:color .15s,border-color .15s;margin-bottom:-1px}.admin-tab:hover{color:var(--text-secondary)}.admin-tab.active{color:var(--text-primary);border-bottom-color:var(--accent)}.admin-tab--logout{margin-left:auto;color:#555;font-size:.78rem}.admin-tab--logout:hover{color:#f87171}.bulk-bar{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;margin-bottom:.75rem;font-size:.84rem;color:var(--text-muted)}.admin-loading,.admin-empty{color:var(--text-muted);font-size:.9rem;padding:2rem 0}.admin-count-row{display:flex;align-items:center;justify-content:space-between;margin:.5rem 0}.admin-count{font-size:.8rem;color:var(--text-muted);margin:0}.export-btn{background:var(--bg-elevated);border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);font-size:.8rem;padding:.3rem .7rem;cursor:pointer}.export-btn:hover{border-color:var(--accent);color:var(--accent)}.song-filter-bar{display:flex;flex-wrap:wrap;gap:.5rem;padding:.75rem 0;align-items:center}.song-filter-bar .filter-input,.song-filter-bar .filter-select{background:var(--bg-elevated);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:.82rem;padding:.35rem .6rem;min-width:120px}.song-filter-bar .filter-input:focus,.song-filter-bar .filter-select:focus{outline:none;border-color:var(--accent)}.sort-chips{display:flex;gap:.35rem;align-items:center;margin-left:auto}.sort-chips--suggestions{margin-left:0;padding:.5rem 0 .25rem}.sort-chip{background:var(--bg-elevated);border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);font-size:.78rem;padding:.3rem .6rem;cursor:pointer;white-space:nowrap}.sort-chip.active{background:var(--accent);border-color:var(--accent);color:#fff}.admin-table-wrap{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-size:.82rem;color:var(--text-secondary)}.admin-table th{text-align:left;padding:.4rem .6rem;border-bottom:1px solid var(--border-subtle);color:var(--text-muted);font-weight:600;white-space:nowrap}.admin-table td{padding:.5rem .6rem;border-bottom:1px solid var(--border-subtle);vertical-align:top}.admin-table tr:last-child td{border-bottom:none}.editing-row td{background:var(--bg-card);vertical-align:top}.row-actions{display:flex;gap:.35rem;flex-wrap:wrap}.edit-field{background:var(--bg);color:var(--text-primary);border:1px solid var(--border);border-radius:4px;padding:.25rem .4rem;font-size:.8rem;font-family:inherit;width:100%;min-width:6rem;outline:none}.edit-field--short{max-width:5rem;min-width:4rem}.edit-select{background:var(--bg);color:var(--text-primary);border:1px solid var(--border);border-radius:4px;padding:.25rem .4rem;font-size:.8rem;font-family:inherit;outline:none;cursor:pointer}.edit-check-group{display:flex;flex-direction:column;gap:.2rem;min-width:8rem}.check-label--sm{font-size:.75rem;color:var(--text-secondary);gap:.3rem}.approve-btn,.delete-btn,.edit-btn,.save-btn,.cancel-btn{padding:.25rem .6rem;border-radius:6px;font-size:.78rem;font-family:inherit;cursor:pointer;border:1px solid transparent;transition:opacity .15s;white-space:nowrap}.approve-btn{background:#14532d;color:#86efac;border-color:#166534}.approve-btn:hover{opacity:.8}.delete-btn{background:#450a0a;color:#fca5a5;border-color:#7f1d1d}.delete-btn:hover{opacity:.8}.edit-btn{background:var(--bg-elevated);color:var(--text-muted);border-color:var(--border)}.edit-btn:hover{border-color:var(--text-muted)}.save-btn{background:#1e3a5f;color:#93c5fd;border-color:#1d4ed8}.save-btn:hover{opacity:.8}.cancel-btn{background:var(--bg-elevated);color:var(--text-muted);border-color:var(--border)}.cancel-btn:hover{border-color:var(--text-muted)}.status-badge{display:inline-block;padding:.15rem .5rem;border-radius:999px;font-size:.75rem;font-weight:600;text-transform:capitalize}.status-badge--approved{background:#0a2016;color:#4ade80}.status-badge--rejected{background:#200a0a;color:#f87171}.status-badge--pending{background:#1a1500;color:#fbbf24}
