:root { font-family: system-ui, sans-serif; color-scheme: light dark; }
body { max-width: 640px; margin: 2rem auto; padding: 0 1rem; line-height: 1.5; }
h1 { margin-bottom: 0.25rem; }
ol { list-style: none; padding: 0; }
.cover { width: 100%; max-width: 320px; aspect-ratio: 1 / 1; object-fit: cover; border-radius: 12px; display: block; margin-bottom: 1rem; background: #8882; }
.cover-placeholder { display: flex; align-items: center; justify-content: center; font-size: 3rem; color: #8888; }
.track { display: flex; align-items: center; gap: 0.75rem; padding: 0.6rem 0; border-bottom: 1px solid #8884; }
.track.playing { font-weight: 600; }
.track .title { flex: 1; }
.votes button { font-size: 1rem; border: 1px solid #8886; background: transparent; border-radius: 6px; padding: 0.2rem 0.5rem; cursor: pointer; }
.votes button[disabled] { opacity: 0.5; cursor: default; }
audio { width: 100%; margin-top: 1rem; }
.muted { opacity: 0.6; font-size: 0.9rem; }
.cover-thumb { width: 120px; height: 120px; object-fit: cover; border-radius: 8px; display: block; margin: 0.5rem 0; }
button.danger { color: #c0392b; border-color: #c0392b88; }
#edit-view input[type="text"], #edit-view input:not([type]) { margin: 0.2rem 0.4rem 0.2rem 0; }
#list-view li, #edit-view li { padding: 0.3rem 0; }
