/* Brass Hour design system — shared across /me/, /u/, community pages */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0a0807; --panel:#13100c; --panel-2:#1a150f; --panel-3:#221b13;
  --ink:#f5f1e8; --ink-dim:#a99e8b; --ink-faint:#7a7263;
  --brass:#b8954c; --gold:#d4af37; --rust:#a04e2a;
  --teal:#14b8a6;
  --line:rgba(255,255,255,.10); --line-strong:rgba(212,175,55,.32);
  --success:#7da95c; --danger:#cc4f48;
}
html,body{color:var(--ink);font-family:'Inter',sans-serif;min-height:100vh;-webkit-font-smoothing:antialiased}
html,body{
  background:
    radial-gradient(ellipse 1400px 700px at 50% -6%, rgba(212,175,55,.18), transparent 62%),
    radial-gradient(ellipse 900px 500px at 50% 110%, rgba(160,78,42,.10), transparent 70%),
    repeating-linear-gradient(91deg, rgba(120,80,40,.05) 0 2px, transparent 2px 8px),
    repeating-linear-gradient(0deg, rgba(0,0,0,.32) 0 1px, transparent 1px 72px),
    linear-gradient(180deg,#0e0a06 0%,#0a0807 60%,#070504 100%);
  background-attachment: fixed;
}
body{padding:0;position:relative}
body::before{content:'';position:fixed;inset:0;background:radial-gradient(ellipse at center, transparent 38%, rgba(0,0,0,.55) 100%);pointer-events:none;z-index:0}
body > *{position:relative;z-index:1}
a{color:var(--gold);text-decoration:none}
a:hover{color:var(--brass)}

.topnav{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;border-bottom:1px solid var(--line);backdrop-filter:blur(8px);background:rgba(10,8,7,.6);position:sticky;top:0;z-index:50}
.topnav .brand{display:flex;align-items:center;gap:0;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.4rem;color:var(--gold);text-decoration:none;flex-shrink:0}
.topnav .brand img{height:42px;width:auto;display:block;margin-right:-6px}
.topnav .brand .wordmark{display:inline-block}
.topnav .navlinks{display:flex;gap:20px;font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim)}
.topnav .navlinks a{white-space:nowrap}
.topnav .navlinks a.active{color:var(--gold)}
.topnav .navtoggle{display:none;background:transparent;border:1px solid var(--line);border-radius:8px;padding:8px 10px;color:var(--gold);cursor:pointer}
.topnav .navtoggle svg{display:block;width:22px;height:22px}
@media (max-width:760px){
  .topnav{padding:12px 16px}
  .topnav .navtoggle{display:flex;align-items:center;justify-content:center}
  .topnav .navlinks{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:rgba(10,8,7,.97);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);padding:6px 0}
  .topnav .navlinks.open{display:flex}
  .topnav .navlinks a, .topnav .navlinks button.nav-action{padding:14px 20px;border-bottom:1px solid rgba(255,255,255,.04);font-size:.78rem;letter-spacing:.15em;font-family:'JetBrains Mono',monospace;text-transform:uppercase;color:var(--ink-dim);background:transparent;border-left:none;border-right:none;border-top:none;text-align:left;cursor:pointer;width:100%;display:block}
  .topnav .navlinks a:last-child, .topnav .navlinks button.nav-action:last-child{border-bottom:none}
  .hero-actions{display:none !important}
}

.wrap{max-width:1100px;margin:0 auto;padding:32px 22px 80px}
.wrap--narrow{max-width:680px}

h1{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(2.2rem,5vw,3.4rem);font-weight:600;letter-spacing:-.01em;line-height:1.1;margin-bottom:14px;color:var(--gold)}
h2{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.6rem;margin:28px 0 14px;color:var(--ink)}
h3{font-family:'Inter',sans-serif;font-weight:600;font-size:1.05rem;margin:14px 0 8px;letter-spacing:.01em}
.subhead{font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--brass);margin-bottom:8px}
p{color:var(--ink-dim);line-height:1.7}

.card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:22px;margin-bottom:18px}
.card.elevated{box-shadow:0 18px 50px -22px rgba(0,0,0,.7)}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 22px;
  background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:10px;
  color:var(--ink);font-family:'Inter',sans-serif;font-weight:500;font-size:.9rem;letter-spacing:.04em;
  cursor:pointer;text-decoration:none;transition:all .2s ease;
}
.btn:hover{background:rgba(255,255,255,.12);border-color:var(--line-strong)}
.btn.primary{background:linear-gradient(180deg,rgba(212,175,55,.22),rgba(184,149,76,.16));border-color:rgba(212,175,55,.45);color:var(--gold)}
.btn.primary:hover{background:linear-gradient(180deg,rgba(212,175,55,.32),rgba(184,149,76,.22));color:#fff}
.btn.danger{color:var(--danger);border-color:rgba(204,79,72,.4)}
.btn.tiny{padding:6px 12px;font-size:.75rem}
.btn.full{width:100%}

input,select,textarea{
  width:100%;padding:11px 14px;
  background:rgba(0,0,0,.32);border:1px solid var(--line);border-radius:8px;
  color:var(--ink);font-family:'Inter',sans-serif;font-size:.95rem;
}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--gold)}
label{display:block;color:var(--ink-dim);font-size:.8rem;letter-spacing:.04em;margin-bottom:6px}

.field{margin-bottom:14px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}

.grid{display:grid;gap:16px}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}
.grid--5{grid-template-columns:repeat(5,1fr)}
@media (max-width:780px){.grid--2,.grid--3,.grid--4,.grid--5{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.grid--2,.grid--3,.grid--4,.grid--5{grid-template-columns:1fr}}

.stamp-card{aspect-ratio:16/9;border-radius:14px;overflow:hidden;position:relative;border:2px solid var(--line);transition:all .2s;cursor:pointer;background:#0a0807}
.stamp-card:hover{transform:translateY(-2px);box-shadow:0 14px 30px -10px rgba(212,175,55,.45);border-color:var(--gold)}
.stamp-card img{width:100%;height:100%;object-fit:contain;background:#0a0807}
.stamp-card .meta{position:absolute;inset:auto 0 0 0;padding:8px 12px;background:linear-gradient(180deg,transparent,rgba(0,0,0,.94));font-family:'JetBrains Mono',monospace;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;display:flex;align-items:flex-end;justify-content:space-between;gap:10px}
.stamp-card .meta .meta-text{flex:1;min-width:0}
.stamp-card .meta .meta-num{font-family:'JetBrains Mono',monospace;font-size:.78rem;letter-spacing:.06em;text-transform:none;color:var(--ink-dim);font-weight:600;flex-shrink:0;align-self:flex-end}
.stamp-card .meta .meta-num.first{color:#e8a73a}

.attendee-pill{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--panel-2);border:1px solid var(--line);border-radius:60px;cursor:pointer;transition:all .15s}
.attendee-pill:hover{border-color:var(--gold)}
.attendee-pill img{width:34px;height:34px;border-radius:50%;object-fit:cover;background:#222}
.attendee-pill .name{font-size:.85rem;color:var(--ink)}
.attendee-pill .stat{font-family:'JetBrains Mono',monospace;font-size:.65rem;color:var(--ink-faint);letter-spacing:.1em}

.photo-card{position:relative;border-radius:10px;overflow:hidden;border:1px solid var(--line);aspect-ratio:1}
.photo-card img{width:100%;height:100%;object-fit:cover;cursor:pointer}
.photo-card .caption{position:absolute;inset:auto 0 0 0;padding:10px;background:linear-gradient(180deg,transparent,rgba(0,0,0,.8));font-size:.78rem;color:var(--ink-dim)}

.tag{display:inline-block;padding:3px 8px;background:rgba(212,175,55,.12);border:1px solid rgba(212,175,55,.3);border-radius:50px;font-family:'JetBrains Mono',monospace;font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
.tag.muted{background:rgba(255,255,255,.04);border-color:var(--line);color:var(--ink-faint)}

.empty{padding:50px 20px;text-align:center;color:var(--ink-faint);border:1px dashed var(--line);border-radius:14px}
.empty .ico{font-size:2.5rem;margin-bottom:8px;opacity:.4}

.hero-row{display:flex;align-items:center;gap:20px;margin-bottom:24px}
.hero-row .avatar{width:88px;height:88px;border-radius:50%;background:#222;border:2px solid var(--gold);object-fit:cover}
.avatar-wrap{position:relative;width:88px;height:88px;flex-shrink:0}
.avatar-wrap .avatar-edit{
  position:absolute;bottom:-2px;right:-2px;width:30px;height:30px;border-radius:50%;
  background:var(--gold);color:#0a0807;display:flex;align-items:center;justify-content:center;
  border:2px solid var(--bg);cursor:pointer;font-size:.85rem;font-weight:700;
  transition:transform .15s;
}
.avatar-wrap .avatar-edit:hover{transform:scale(1.08);background:#ffd56a}
.avatar-wrap.empty .avatar{border-style:dashed;opacity:.7}
.avatar-wrap.empty::after{
  content:'+';position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  color:var(--gold);font-size:2.4rem;font-weight:300;pointer-events:none;
}
.avatar-wrap.empty .avatar{background:rgba(212,175,55,.06)}
.hero-row .meta .h{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:2rem;color:var(--gold);margin-bottom:2px}
.hero-row .meta .sub{font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint)}
.hero-row .stats{display:flex;gap:18px;margin-top:6px}
.hero-row .stats .s{display:flex;flex-direction:column;align-items:flex-start}
.hero-row .stats .s .n{font-family:'JetBrains Mono',monospace;font-size:1.2rem;color:var(--ink)}
.hero-row .stats .s .l{font-family:'JetBrains Mono',monospace;font-size:.55rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint)}

.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:18px;overflow-x:auto}
.tabs .tab{padding:10px 16px;font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);background:transparent;border:none;cursor:pointer;border-bottom:2px solid transparent}
.tabs .tab.active{color:var(--gold);border-bottom-color:var(--gold)}

.toast{position:fixed;bottom:30px;left:50%;transform:translateX(-50%);padding:14px 22px;background:rgba(212,175,55,.92);color:#0a0807;border-radius:10px;font-weight:600;z-index:100;animation:fadein .3s}
@keyframes fadein{from{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%,0)}}

.fab{position:fixed;bottom:24px;right:24px;width:60px;height:60px;border-radius:50%;background:linear-gradient(180deg,#e8a73a,#b8954c);border:none;color:#0a0807;font-size:1.6rem;cursor:pointer;box-shadow:0 14px 30px -10px rgba(232,167,58,.6);z-index:40}

.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;z-index:200;padding:20px}
.modal-overlay.show{display:flex}
.modal{background:var(--panel);border:1px solid var(--line-strong);border-radius:16px;padding:28px;max-width:520px;width:100%;max-height:90vh;overflow-y:auto}
.modal h2{margin-top:0}
.modal .close{float:right;background:none;border:none;color:var(--ink-faint);font-size:1.4rem;cursor:pointer}

.spinner{display:inline-block;width:18px;height:18px;border:2px solid var(--line);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Photo lightbox */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.94);backdrop-filter:blur(10px);display:none;flex-direction:column;align-items:center;justify-content:flex-start;z-index:9999;padding:80px 30px 40px;cursor:pointer;overflow-y:auto}
.lightbox.show{display:flex}
.lightbox img{max-width:100%;max-height:90vh;object-fit:contain;border-radius:8px;cursor:default}
.lightbox .lb-close{position:fixed;top:20px;left:24px;display:flex;align-items:center;gap:6px;padding:10px 16px;border-radius:50px;background:rgba(0,0,0,.85);border:1px solid rgba(212,175,55,.45);color:var(--gold);font-size:.85rem;font-family:'Inter',sans-serif;font-weight:500;cursor:pointer;z-index:10000;transition:all .15s}
.lightbox .lb-close:hover{background:rgba(212,175,55,.18);color:#fff}
.lightbox .lb-close::before{content:'←';font-size:1.1rem;line-height:1}
.lightbox .lb-caption{position:fixed;left:0;right:0;bottom:30px;text-align:center;color:var(--ink-dim);font-family:'Inter',sans-serif;font-size:.9rem;padding:0 30px}
/* Hide the topnav while the lightbox is open so the close button + content aren't covered */
body.lightbox-open .topnav{display:none}

/* Record-sleeve stamp lightbox: poster as the album sleeve in front, vinyl peeking out behind */
.vinyl-stage{position:relative;width:min(58vmin,460px);aspect-ratio:1;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}

/* The vinyl record sits BEHIND the sleeve, fills the full stage */
.vinyl{
  position:absolute;inset:0;border-radius:50%;
  background:
    radial-gradient(circle at center, #1a1a1a 0%, #0c0c0c 28%, #1c1c1c 30%, #0c0c0c 32%, #1c1c1c 34%, #0c0c0c 36%, #1c1c1c 38%, #0c0c0c 40%, #1c1c1c 42%, #0c0c0c 44%, #1c1c1c 46%, #0c0c0c 48%, #1c1c1c 50%, #0c0c0c 52%, #1c1c1c 54%, #0c0c0c 56%, #1c1c1c 58%, #0c0c0c 60%, #1c1c1c 62%, #0c0c0c 64%, #1c1c1c 66%, #0c0c0c 68%, #1c1c1c 70%, #0c0c0c 72%, #1c1c1c 74%, #0c0c0c 76%, #1c1c1c 78%, #0c0c0c 80%, #1c1c1c 82%, #0c0c0c 84%, #0a0a0a 100%);
  box-shadow:
    0 30px 80px -20px rgba(0,0,0,.9),
    inset 0 0 0 4px rgba(212,175,55,.45),
    inset 0 0 0 6px rgba(0,0,0,.6),
    inset 0 0 0 8px rgba(212,175,55,.18);
  z-index:1;
  animation: vinyl-spin-in 2.4s cubic-bezier(.18,.7,.18,1) forwards;
}
.vinyl::before{
  /* light reflection sheen */
  content:'';position:absolute;inset:0;border-radius:50%;
  background:linear-gradient(125deg,transparent 35%,rgba(212,175,55,.10) 50%,transparent 65%);
  pointer-events:none;mix-blend-mode:screen;
}
.vinyl-spindle{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:14px;height:14px;border-radius:50%;
  background:radial-gradient(circle, #2a2a2a 0%, #050505 60%, #1a1a1a 100%);
  box-shadow:0 0 0 1px rgba(0,0,0,.8), inset 0 1px 1px rgba(255,255,255,.15);
  z-index:2;pointer-events:none;
}
/* Album sleeve: landscape rectangle inscribed in the circular vinyl, sits IN FRONT, does not spin */
.album-sleeve{
  position:absolute;
  left:50%;top:50%;transform:translate(-50%,-50%);
  width:78%;aspect-ratio:16/9;
  background:#0a0807;
  border:1px solid rgba(212,175,55,.45);
  border-radius:6px;
  box-shadow:0 22px 56px -10px rgba(0,0,0,.85), 0 0 0 1px rgba(0,0,0,.5), 0 4px 14px rgba(0,0,0,.4);
  z-index:3;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  animation: sleeve-in 1s ease-out 0.4s backwards;
}
.album-sleeve img{width:100%;height:100%;object-fit:contain;display:block;background:#0a0807}
@keyframes sleeve-in{
  0%   { opacity:0; transform: translate(-42%,-50%) rotate(-3deg); }
  100% { opacity:1; transform: translate(-50%,-50%) rotate(0deg); }
}
@keyframes vinyl-spin-in{
  0%   { transform:rotate(-720deg) scale(.7); opacity:0; }
  60%  { transform:rotate(60deg) scale(1.02); opacity:1; }
  100% { transform:rotate(0deg) scale(1); opacity:1; }
}
@keyframes vinyl-spin-loop{
  to { transform:rotate(360deg); }
}
.vinyl.spinning{ animation: vinyl-spin-loop 2.4s linear; }

/* First-claim sparkle effect */
.sparkles{position:absolute;inset:-20px;pointer-events:none;z-index:10}
.sparkle{position:absolute;width:6px;height:6px;background:radial-gradient(circle,#fff 0%,rgba(212,175,55,.9) 40%,transparent 70%);border-radius:50%;opacity:0;
  animation:sparkle-pop 1.4s ease-out forwards;}
@keyframes sparkle-pop{
  0%{transform:scale(0) translate(0,0);opacity:0}
  20%{transform:scale(1.3) translate(var(--dx,0),var(--dy,0));opacity:1}
  100%{transform:scale(0) translate(calc(var(--dx,0)*1.6),calc(var(--dy,0)*1.6));opacity:0}
}

.vinyl-meta{
  margin-top:24px;text-align:center;color:var(--ink);
  font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.6rem;
}
.vinyl-meta-sub{
  font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold);margin-top:6px;
}
.vinyl-meta-desc{font-family:'Inter',sans-serif;font-style:normal;color:var(--ink-dim);margin-top:10px;font-size:.92rem;max-width:480px}

/* First-mint card glow (mint ≤10 only) */
.stamp-card.first-ed{box-shadow:0 0 0 2px rgba(232,167,58,.55), 0 0 22px rgba(232,167,58,.18)}
.stamp-card.first-ed:hover{box-shadow:0 0 0 2px rgba(232,167,58,.75), 0 16px 32px -10px rgba(232,167,58,.45)}

/* Unclaimed stamp (grayscale until purchased) */
.stamp-card.unclaimed{cursor:pointer;border-style:dashed;opacity:.55;position:relative}
.stamp-card.unclaimed img{filter:grayscale(1) brightness(.7) contrast(.85)}
.stamp-card.unclaimed:hover{opacity:.85}
.stamp-card.unclaimed .unclaimed-overlay{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:linear-gradient(180deg,transparent 30%,rgba(0,0,0,.7) 100%);text-align:center;padding:14px
}
.stamp-card.unclaimed .unclaimed-overlay .lock{font-size:1.6rem;color:rgba(212,175,55,.7);margin-bottom:6px}
.stamp-card.unclaimed .unclaimed-overlay .cta{font-family:'JetBrains Mono',monospace;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);background:rgba(212,175,55,.16);padding:4px 10px;border-radius:50px;border:1px solid rgba(212,175,55,.4)}

/* Vinyl detail actions — modern button row with Lucide icons */
.vinyl-actions{display:flex;gap:8px;margin-top:22px;flex-wrap:wrap;justify-content:center;max-width:680px}
.vinyl-action{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 14px;
  background:rgba(255,255,255,.05);
  border:1px solid var(--line);
  border-radius:50px;
  color:var(--ink);
  font-family:'Inter',sans-serif;font-weight:500;font-size:.82rem;letter-spacing:.01em;
  cursor:pointer;text-decoration:none;
  transition:all .18s ease;
  white-space:nowrap;
}
.vinyl-action svg{width:16px;height:16px;flex-shrink:0;color:var(--gold);transition:transform .2s}
.vinyl-action:hover{background:rgba(212,175,55,.10);border-color:rgba(212,175,55,.45);color:#fff}
.vinyl-action:hover svg{transform:scale(1.15)}
.vinyl-action.active{background:rgba(212,175,55,.18);border-color:rgba(212,175,55,.6);color:#fff}
.vinyl-action.primary{background:linear-gradient(180deg,rgba(232,167,58,.22),rgba(184,149,76,.16));border-color:rgba(212,175,55,.55);color:var(--gold);font-weight:600}
.vinyl-action.primary:hover{background:linear-gradient(180deg,rgba(232,167,58,.32),rgba(184,149,76,.22));color:#fff}

/* Slow continuous spin (when music is playing) */
@keyframes vinyl-slow-spin{ to { transform: rotate(360deg); } }
.vinyl.playing{ animation: vinyl-slow-spin 2.4s linear infinite !important; }

/* Full Spotify player */
.sp-player{margin:14px auto 0;width:100%;max-width:680px;background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.sp-now{display:flex;gap:14px;align-items:center;padding:14px 16px;border-bottom:1px solid var(--line)}
.sp-now .sp-art{width:64px;height:64px;border-radius:6px;object-fit:cover;background:#222;flex-shrink:0}
.sp-now .sp-text{flex:1;min-width:0}
.sp-now .sp-title{font-weight:600;font-size:.98rem;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sp-now .sp-sub{font-size:.78rem;color:var(--ink-faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sp-progress{display:flex;align-items:center;gap:10px;padding:6px 16px 14px}
.sp-progress .sp-time{font-family:'JetBrains Mono',monospace;font-size:.72rem;color:var(--ink-faint);min-width:36px;text-align:center}
.sp-bar{flex:1;height:4px;background:rgba(255,255,255,.10);border-radius:2px;cursor:pointer;position:relative;overflow:hidden}
.sp-bar .sp-bar-fill{height:100%;background:var(--gold);width:0%;transition:width .15s linear;border-radius:2px}
.sp-bar:hover .sp-bar-fill{background:#ffd56a}
.sp-controls{display:flex;align-items:center;justify-content:center;gap:18px;padding:8px 16px 16px}
.sp-btn{background:transparent;border:none;color:var(--ink-dim);cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .15s}
.sp-btn:hover{color:var(--gold);background:rgba(212,175,55,.08)}
.sp-btn.active{color:var(--gold)}
.sp-btn svg{width:22px;height:22px}
.sp-btn.play{background:var(--gold);color:#0a0807;width:50px;height:50px}
.sp-btn.play:hover{background:#ffd56a;color:#0a0807;transform:scale(1.05)}
.sp-btn.play svg{width:24px;height:24px}
.sp-volume{display:flex;align-items:center;gap:8px;padding:0 16px 14px;justify-content:flex-end}
.sp-volume svg{color:var(--ink-faint);width:18px;height:18px}
.sp-volume input[type=range]{width:120px;height:4px;-webkit-appearance:none;background:rgba(255,255,255,.12);border-radius:2px;cursor:pointer}
.sp-volume input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:var(--gold);cursor:pointer}
.tracklist{max-height:280px;overflow-y:auto;border-top:1px solid var(--line)}
.tracklist .track{display:flex;align-items:center;gap:12px;padding:8px 14px;border-bottom:1px solid rgba(255,255,255,.04);cursor:pointer;transition:background .15s}
.tracklist .track:hover{background:rgba(255,255,255,.04)}
.tracklist .track.playing{background:rgba(212,175,55,.10);color:var(--gold)}
.tracklist .track .num{font-family:'JetBrains Mono',monospace;font-size:.72rem;color:var(--ink-faint);width:22px;text-align:center;flex-shrink:0;display:flex;justify-content:center;align-items:center}
.tracklist .track.playing .num{color:var(--gold)}
.tracklist .track .art{width:34px;height:34px;border-radius:4px;object-fit:cover;background:#222;flex-shrink:0}
.tracklist .track .info{flex:1;min-width:0}
.tracklist .track .title{font-size:.88rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tracklist .track .album{font-size:.7rem;color:var(--ink-faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tracklist .track .dur{font-family:'JetBrains Mono',monospace;font-size:.72rem;color:var(--ink-faint);flex-shrink:0}
.tracklist .track .pip{width:8px;height:8px;border-radius:50%;background:var(--gold);animation:pulse 1.4s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.4}50%{opacity:1}}

.player-container{margin:14px auto 0;width:100%;max-width:640px;background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.tracklist{max-height:360px;overflow-y:auto;border-top:1px solid var(--line)}
.tracklist .track{display:flex;align-items:center;gap:12px;padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.04);cursor:pointer;transition:background .15s}
.tracklist .track:hover{background:rgba(255,255,255,.04)}
.tracklist .track.playing{background:rgba(212,175,55,.10);color:var(--gold)}
.tracklist .track .num{font-family:'JetBrains Mono',monospace;font-size:.75rem;color:var(--ink-faint);width:22px;text-align:right;flex-shrink:0}
.tracklist .track.playing .num{color:var(--gold)}
.tracklist .track .art{width:36px;height:36px;border-radius:4px;object-fit:cover;background:#222;flex-shrink:0}
.tracklist .track .info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.tracklist .track .title{font-size:.92rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tracklist .track .album{font-size:.74rem;color:var(--ink-faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tracklist .track .dur{font-family:'JetBrains Mono',monospace;font-size:.74rem;color:var(--ink-faint);flex-shrink:0}
.tracklist .track .pip{width:8px;height:8px;border-radius:50%;background:var(--gold);flex-shrink:0;animation:pulse 1.4s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.4}50%{opacity:1}}
.player-container iframe{width:100%;border:none;display:block}
.player-container audio{width:100%;display:block}
.player-container .player-header{padding:10px 14px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--line);font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-dim)}
.player-container .player-close{background:none;border:none;color:var(--ink-faint);cursor:pointer;font-size:1rem;padding:0}
.player-container .player-close:hover{color:var(--gold)}

/* Vote button "voted" state */
.btn.voted{background:rgba(125,169,92,.18);border-color:rgba(125,169,92,.45);color:#7da95c}

/* DM preflight banner */
.dm-preflight{padding:12px 14px;border-radius:10px;margin-bottom:12px;font-size:.85rem}
.dm-preflight.ok{background:rgba(125,169,92,.10);border:1px solid rgba(125,169,92,.30);color:#a3c984}
.dm-preflight.blocked{background:rgba(204,79,72,.10);border:1px solid rgba(204,79,72,.30);color:#e08885}
