*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,-apple-system,Segoe UI,sans-serif;background:#0f0f0f;color:#e0e0e0;line-height:1.6;min-height:100vh}.container{max-width:800px;margin:0 auto;padding:2rem 1rem}h1{font-size:1.8rem;margin-bottom:.5rem;color:#fff}h2{font-size:1.3rem;margin-bottom:1rem;color:#ccc}.steps{display:flex;gap:.5rem;margin-bottom:2rem}.steps button{flex:1;padding:.6rem 1rem;background:#1a1a1a;border:1px solid #333;color:#666;border-radius:6px;font-size:.85rem;cursor:default;transition:all .2s}.steps button.active{background:#2a2a2a;border-color:#c084fc;color:#e0e0e0}.steps button.completed{background:#1a2a1a;border-color:#4ade80;color:#4ade80}button{cursor:pointer;border:none;border-radius:6px;padding:.5rem 1rem;font-size:.9rem;transition:all .15s}.btn-primary{background:#c084fc;color:#0f0f0f;font-weight:600}.btn-primary:hover{background:#d4a5ff}.btn-primary:disabled{background:#444;color:#888;cursor:not-allowed}.btn-secondary{background:#2a2a2a;color:#e0e0e0;border:1px solid #444}.btn-secondary:hover{background:#333}.btn-spotify{background:#1db954;color:#fff;font-weight:600}.btn-spotify:hover{background:#1ed760}.presets{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.presets button{background:#1a1a2e;border:1px solid #333;color:#c084fc;padding:.75rem 1.25rem;font-size:.95rem}.presets button:hover{background:#252540;border-color:#c084fc}input[type=text],input[type=number],textarea{background:#1a1a1a;border:1px solid #333;border-radius:6px;color:#e0e0e0;padding:.5rem .75rem;font-size:.9rem;font-family:inherit;width:100%}input[type=text]:focus,input[type=number]:focus,textarea:focus{outline:none;border-color:#c084fc}input[type=number]{width:3.5rem;text-align:center}textarea{resize:vertical;min-height:150px}label{font-size:.85rem;color:#aaa;display:block;margin-bottom:.3rem}.day-tabs{display:flex;gap:.25rem;margin-bottom:1rem;overflow-x:auto}.day-tabs button{background:#1a1a1a;border:1px solid #333;color:#888;padding:.4rem .8rem;font-size:.8rem;white-space:nowrap}.day-tabs button.active{background:#2a2a2a;border-color:#c084fc;color:#e0e0e0}.tier-buttons{display:flex;gap:.25rem}.tier-buttons button{width:2.2rem;height:2rem;font-size:.75rem;font-weight:600;border:1px solid #333;background:#1a1a1a;color:#666;padding:0}.tier-buttons button.active{border-width:2px}.tier-buttons button[data-tier=S].active{background:#422006;border-color:#f59e0b;color:#f59e0b}.tier-buttons button[data-tier=A].active{background:#052e16;border-color:#4ade80;color:#4ade80}.tier-buttons button[data-tier=B].active{background:#0c1a3a;border-color:#60a5fa;color:#60a5fa}.tier-buttons button[data-tier=C].active{background:#1a1a1a;border-color:#888;color:#888}.tier-buttons button[data-tier=skip].active{background:#1a1a1a;border-color:#555;color:#555}.artist-row{display:flex;align-items:center;gap:.75rem;padding:.4rem 0;border-bottom:1px solid #1a1a1a}.artist-row .artist-name{flex:1;font-size:.9rem}.tier-config{display:flex;gap:1rem;align-items:center;margin-bottom:1rem;padding:.75rem;background:#1a1a1a;border-radius:6px}.tier-config .tier-item{display:flex;align-items:center;gap:.3rem;font-size:.85rem}.tier-config .tier-label{font-weight:600}.tier-config .tier-label-S{color:#f59e0b}.tier-config .tier-label-A{color:#4ade80}.tier-config .tier-label-B{color:#60a5fa}.tier-config .tier-label-C{color:#888}.summary{margin-top:.75rem;font-size:.85rem;color:#888}.log-area{background:#111;border:1px solid #222;border-radius:6px;padding:.75rem;max-height:400px;overflow-y:auto;font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:.8rem;line-height:1.5;margin-top:1rem}.log-entry{padding:.1rem 0}.log-entry.info{color:#e0e0e0}.log-entry.warn{color:#fbbf24}.log-entry.error{color:#f87171}.log-entry.success{color:#4ade80}.playlist-links{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}.playlist-link{display:flex;align-items:center;justify-content:space-between;background:#1a1a1a;border:1px solid #333;border-radius:6px;padding:.75rem 1rem}.playlist-link a{color:#1db954;text-decoration:none;font-weight:600}.playlist-link a:hover{text-decoration:underline}.section{margin-bottom:1.5rem}.section-title{font-size:1rem;color:#aaa;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.instructions{background:#1a1a1a;border:1px solid #333;border-radius:6px;padding:1rem;margin-bottom:1rem}.instructions ol{padding-left:1.25rem}.instructions li{margin-bottom:.5rem;font-size:.9rem}.instructions code{background:#0f0f0f;padding:.15rem .4rem;border-radius:3px;font-size:.85rem;color:#c084fc;word-break:break-all}.connected-user{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#0a2a0a;border:1px solid #1db954;border-radius:6px;margin-bottom:1rem}.connected-user .dot{width:8px;height:8px;background:#1db954;border-radius:50%}.nav-row{display:flex;justify-content:space-between;margin-top:1.5rem}.error-msg{color:#f87171;font-size:.85rem;margin-top:.5rem}@media(max-width:600px){.container{padding:1rem .75rem}h1{font-size:1.4rem}.tier-config{flex-wrap:wrap;gap:.5rem}.artist-row{flex-wrap:wrap;gap:.4rem}.steps{flex-direction:column}}
