*{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0a0a;--bg-card: #141414;--bg-input: #1a1a1a;--text: #e5e5e5;--text-muted: #737373;--accent: #3b82f6;--accent-hover: #2563eb;--border: #262626;--success: #22c55e;--warning: #eab308;--danger: #ef4444;--radius: 8px;--radius-sm: 4px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh}#app{max-width:800px;margin:0 auto;padding:2rem 1rem}.header{text-align:center;margin-bottom:2rem}.header h1{font-size:2rem;font-weight:600;letter-spacing:-.02em}.header__subtitle{color:var(--text-muted);font-size:.875rem}.add-section{margin-bottom:2rem}.add-form__row{display:flex;gap:.5rem}.add-form__details{margin-top:.75rem}.add-form__details summary{color:var(--text-muted);cursor:pointer;font-size:.875rem}.add-form__extra{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-top:.75rem}.add-form__extra select{grid-column:span 2}.input{flex:1;padding:.75rem 1rem;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:1rem}.input:focus{outline:none;border-color:var(--accent)}.input::placeholder{color:var(--text-muted)}.btn{padding:.75rem 1.5rem;border:none;border-radius:var(--radius);font-size:1rem;font-weight:500;cursor:pointer;transition:background .15s}.btn--primary{background:var(--accent);color:#fff}.btn--primary:hover{background:var(--accent-hover)}.btn--ghost{background:transparent;color:var(--text-muted);padding:.5rem}.btn--ghost:hover{color:var(--text)}.btn--danger:hover{color:var(--danger)}.filter-section{margin-bottom:1.5rem}.filter-bar{display:flex;gap:.5rem;flex-wrap:wrap}.filter-btn{padding:.5rem 1rem;background:var(--bg-input);border:1px solid var(--border);border-radius:9999px;color:var(--text-muted);font-size:.875rem;cursor:pointer;transition:all .15s}.filter-btn:hover{border-color:var(--text-muted)}.filter-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.stack-section{margin-bottom:1rem}.stack-bar{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.stack-tab{padding:.5rem 1rem;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);font-size:.875rem;cursor:pointer;transition:all .15s}.stack-tab:hover{border-color:var(--text-muted)}.stack-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}.stack-tab--manage{padding:.5rem;margin-left:auto}.music-list{display:flex;flex-direction:column;gap:.75rem}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.music-card{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.music-card__content{flex:1;min-width:0}.music-card__title{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.music-card__artist{color:var(--text-muted);font-size:.875rem}.music-card__meta{display:flex;gap:.5rem;margin-top:.5rem}.music-card__actions{display:flex;gap:.25rem}.badge{display:inline-block;padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;text-transform:capitalize}.badge--to-listen{background:#3b82f633;color:#60a5fa}.badge--listening{background:#eab30833;color:#facc15}.badge--listened{background:#22c55e33;color:#4ade80}.badge--to-revisit{background:#a855f733;color:#c084fc}.badge--done{background:#73737333;color:#a3a3a3}.badge--source{background:#ffffff1a;color:var(--text-muted)}.status-select{padding:.25rem .5rem;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.75rem;cursor:pointer}.status-select:focus{outline:none;border-color:var(--accent)}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.error-screen{text-align:center;padding:3rem 1rem}.error-screen h1{color:var(--danger);margin-bottom:1rem}.error-screen pre{background:var(--bg-card);padding:1rem;border-radius:var(--radius);overflow-x:auto;font-size:.875rem;margin-top:1rem}.stack-dropdown{position:absolute;top:100%;right:0;z-index:10;min-width:180px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:.5rem;display:flex;flex-direction:column;gap:.25rem}.stack-dropdown__item{display:flex;align-items:center;gap:.5rem;padding:.35rem .5rem;border-radius:var(--radius-sm);font-size:.875rem;cursor:pointer;color:var(--text)}.stack-dropdown__item:hover{background:var(--bg-input)}.stack-dropdown__new{border-top:1px solid var(--border);padding-top:.5rem;margin-top:.25rem}.stack-dropdown__new-input{width:100%;padding:.35rem .5rem;font-size:.875rem}.stack-picker{grid-column:span 2;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;position:relative}.stack-picker__chips{display:flex;gap:.25rem;flex-wrap:wrap}.stack-chip{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:#3b82f633;color:#60a5fa;border-radius:var(--radius-sm);font-size:.75rem}.stack-chip__remove{background:none;border:none;color:inherit;cursor:pointer;padding:0;font-size:1rem;line-height:1;opacity:.7}.stack-chip__remove:hover{opacity:1}.stack-picker__add{font-size:.875rem;padding:.25rem .5rem}.stack-manage{margin-top:.75rem;padding:1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.stack-manage__item{display:flex;align-items:center;gap:.5rem;padding:.5rem 0;border-bottom:1px solid var(--border)}.stack-manage__name{flex:1;font-size:.875rem}.stack-manage__count{color:var(--text-muted);font-size:.75rem}.stack-manage__rename-btn,.stack-manage__delete-btn,.stack-manage__rename-confirm{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.75rem;padding:.25rem .5rem}.stack-manage__rename-btn:hover,.stack-manage__rename-confirm:hover{color:var(--text)}.stack-manage__delete-btn:hover{color:var(--danger)}.stack-manage__rename-input{flex:1;padding:.25rem .5rem;font-size:.875rem}.stack-manage__create{display:flex;gap:.5rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border)}.stack-manage__create .input{flex:1;padding:.5rem;font-size:.875rem}.stack-manage__create .btn{padding:.5rem 1rem;font-size:.875rem}
