@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;1,300;1,400&family=Space+Mono&display=swap');

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --night:   #04050f;
  --deep:    #070b1a;
  --navy:    #0a1128;
  --blue:    #1a2a5e;
  --indigo:  #2d3a8c;
  --violet:  #4a3f9f;
  --teal:    #1a5c7a;
  --accent:  #4a8fd4;
  --glow:    #6baed6;
  --warm:    #c8a882;
  --rose:    #c06b8a;
  --cream:   #e8e2d8;
  --muted:   rgba(180,190,220,0.55);
  --dim:     rgba(180,190,220,0.28);
}

html{ scroll-behavior:smooth }
body{
  width:100%;min-height:100vh;
  background:var(--night);
  color:var(--cream);
  font-family:'Cormorant Garamond',serif;
  overflow-x:hidden;
}
body.has-mini-player{padding-bottom:104px}

/* ── SCROLLBAR ──────────────────────────────────── */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--night)}
::-webkit-scrollbar-thumb{background:rgba(74,143,212,.25);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:rgba(74,143,212,.45)}

/* ── CURSOR ──────────────────────────────────────── */
@media(hover:hover)and(pointer:fine){
  body{cursor:none}
  .cur,.cur-ring{display:block}
}
@media(hover:none),(pointer:coarse){
  .cur,.cur-ring{display:none!important}
}
.cur{
  display:none;position:fixed;
  width:7px;height:7px;
  border-radius:50%;
  background:var(--glow);
  pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
  box-shadow:0 0 10px rgba(107,174,214,0.7);
}
.cur-ring{
  display:none;position:fixed;
  width:34px;height:34px;
  border:1px solid rgba(107,174,214,0.3);
  border-radius:50%;
  pointer-events:none;z-index:9998;
  transform:translate(-50%,-50%);
  transition:width .35s cubic-bezier(.16,1,.3,1),
             height .35s cubic-bezier(.16,1,.3,1),
             border-color .35s ease;
}

/* ── CANVAS BG ───────────────────────────────────── */
#bgCanvas{
  position:fixed;inset:0;
  width:100%;height:100%;
  z-index:0;pointer-events:none;
  filter:blur(80px);
  -webkit-filter:blur(80px);
  opacity:.85;
}
@media(prefers-reduced-motion:reduce){
  #bgCanvas{ animation:none!important; }
}

/* ── GRAIN ───────────────────────────────────────── */
.grain{
  position:fixed;inset:-50%;width:200%;height:200%;
  z-index:60;pointer-events:none;opacity:.025;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-repeat:repeat;background-size:200px 200px;
}
@media(prefers-reduced-motion:no-preference){
  .grain{animation:grain .2s steps(1) infinite}
  @keyframes grain{
    0%{transform:translate(0,0)}20%{transform:translate(-4%,2%)}
    40%{transform:translate(3%,-3%)}60%{transform:translate(-2%,4%)}
    80%{transform:translate(5%,-1%)}100%{transform:translate(-3%,2%)}
  }
}

/* ── SEAM ────────────────────────────────────────── */
.seam{
  position:fixed;
  left:50%;top:0;bottom:0;width:1px;
  transform:translateX(-50%);
  background:linear-gradient(to bottom,
    transparent 0%,
    rgba(74,143,212,.08) 15%,
    rgba(74,143,212,.3) 50%,
    rgba(74,143,212,.08) 85%,
    transparent 100%);
  z-index:4;
  animation:seamPulse 5s ease-in-out infinite;
}
@keyframes seamPulse{0%,100%{opacity:.4}50%{opacity:1}}

/* ── CURTAIN ─────────────────────────────────────── */
.curtain{
  position:fixed;inset:0;
  background:var(--night);z-index:100;
  pointer-events:none;transform-origin:top;
  animation:curtainLift .9s cubic-bezier(.76,0,.24,1) both;
  animation-delay:.05s;
}
@keyframes curtainLift{from{transform:scaleY(1)}to{transform:scaleY(0)}}

@keyframes fadeUp{
  from{opacity:0;transform:translateY(16px)}
  to{opacity:1;transform:translateY(0)}
}

/* ── NAV ─────────────────────────────────────────── */
.nav-bar{
  position:fixed;top:0;left:0;right:0;
  z-index:50;padding:28px 44px;
  display:flex;justify-content:space-between;align-items:center;
  background:linear-gradient(to bottom, var(--night) 0%, transparent 100%);
  animation:fadeUp 1s cubic-bezier(.16,1,.3,1) both;
  animation-delay:.3s;
}
.nav-logo{
  font-family:'Space Mono',monospace;
  font-size:10px;letter-spacing:.22em;
  color:var(--dim);text-transform:uppercase;
  text-decoration:none;
  transition:color .25s ease;
}
.nav-logo:hover{color:var(--cream)}

.nav-links{display:flex;gap:16px;align-items:center}

.nav-link{
  font-family:'Space Mono',monospace;
  font-size:10px;letter-spacing:.2em;
  color:rgba(107,174,214,.8);
  text-transform:uppercase;text-decoration:none;
  border:1px solid rgba(74,143,212,.25);
  padding:5px 13px 4px;
  transition:border-color .3s ease,color .3s ease,background .3s ease;
  position:relative;overflow:hidden;
}
.nav-link::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(74,143,212,.12),rgba(74,63,159,.08));
  opacity:0;transition:opacity .3s ease;
}
.nav-link:hover::before{opacity:1}
.nav-link:hover{
  border-color:rgba(107,174,214,.6);
  color:var(--glow);
}
.nav-link.active{
  border-color:rgba(107,174,214,.5);
  color:var(--glow);
  background:rgba(74,143,212,.08);
}

/* ── PAGE HEADER ─────────────────────────────────── */
.page-header{
  text-align:center;
  padding:140px 30px 50px;
  position:relative;z-index:10;
  animation:fadeUp 1.2s cubic-bezier(.16,1,.3,1) both;
  animation-delay:.5s;
}
.page-title{
  font-family:'Cormorant Garamond',serif;
  font-weight:300;
  font-size:clamp(48px,7vw,84px);
  letter-spacing:.15em;
  color:var(--cream);
  text-transform:lowercase;
  line-height:1;
}
.page-sub{
  font-family:'Space Mono',monospace;
  font-size:clamp(8px,.8vw,10px);
  letter-spacing:.3em;
  text-transform:uppercase;
  margin-top:14px;
  background:linear-gradient(90deg,var(--muted),rgba(107,174,214,.7),var(--muted));
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}

/* ── TAG FILTER ──────────────────────────────────── */
.filter-bar{
  position:relative;z-index:10;
  display:flex;flex-wrap:wrap;justify-content:center;
  gap:8px;padding:0 30px 40px;
  animation:fadeUp 1s cubic-bezier(.16,1,.3,1) both;
  animation-delay:.7s;
}
.tag-pill{
  font-family:'Space Mono',monospace;
  font-size:9px;letter-spacing:.15em;
  text-transform:uppercase;
  padding:5px 14px 4px;
  border:1px solid rgba(74,143,212,.2);
  border-radius:20px;
  color:var(--muted);
  background:transparent;
  cursor:pointer;
  transition:all .3s ease;
}
.tag-pill:hover{
  border-color:rgba(107,174,214,.5);
  color:var(--glow);
  background:rgba(74,143,212,.06);
}
.tag-pill.active{
  border-color:rgba(107,174,214,.6);
  color:var(--glow);
  background:rgba(26,42,94,.5);
  box-shadow:0 0 12px rgba(74,143,212,.15);
}

/* ── LOOP GRID ───────────────────────────────────── */
.loop-grid{
  position:relative;z-index:10;
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(340px,1fr));
  gap:20px;
  padding:0 44px 80px;
  max-width:1200px;
  margin:0 auto;
}
@media(max-width:440px){
  .loop-grid{grid-template-columns:1fr;padding:0 20px 60px}
}

/* ── LOOP CARD ───────────────────────────────────── */
.loop-card{
  background:linear-gradient(135deg,rgba(7,11,26,.9),rgba(10,17,40,.85));
  border:1px solid rgba(74,143,212,.1);
  border-radius:8px;
  padding:24px;
  transition:border-color .4s ease, box-shadow .4s ease, transform .3s ease;
  animation:fadeUp .6s cubic-bezier(.16,1,.3,1) both;
}
.loop-card:hover{
  border-color:rgba(107,174,214,.25);
  box-shadow:0 8px 32px rgba(0,0,0,.3),0 0 20px rgba(74,143,212,.05);
  transform:translateY(-2px);
}
.loop-card.is-active{
  border-color:rgba(107,174,214,.38);
  background:linear-gradient(135deg,rgba(8,18,34,.94),rgba(10,17,40,.9));
  box-shadow:0 0 0 1px rgba(107,174,214,.08),0 12px 34px rgba(0,0,0,.28);
}
.loop-card.is-playing{
  border-color:rgba(107,174,214,.55);
}
.loop-card.is-paused,
.loop-card.is-ended{
  border-color:rgba(200,168,130,.35);
}
.loop-card.is-loading{
  border-color:rgba(74,143,212,.45);
}
.loop-card.is-error{
  border-color:rgba(192,107,138,.55);
}
.loop-card.is-active .loop-title::after{
  content:'now playing';
  display:inline-block;
  margin-left:10px;
  transform:translateY(-2px);
  font-family:'Space Mono',monospace;
  font-size:7px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--glow);
}
.loop-card.is-paused .loop-title::after{content:'paused';color:var(--warm)}
.loop-card.is-ended .loop-title::after{content:'ended';color:var(--warm)}
.loop-card.is-loading .loop-title::after{content:'loading';color:var(--accent)}
.loop-card.is-error .loop-title::after{content:'error';color:var(--rose)}
.loop-card.exclaim-level-1{
  border-color:rgba(192,107,138,.22);
  background:linear-gradient(135deg,rgba(18,12,28,.91),rgba(10,17,40,.86));
}
.loop-card.exclaim-level-1:hover{
  border-color:rgba(192,107,138,.36);
}
.loop-card.exclaim-level-2{
  border-color:rgba(107,174,214,.25);
  background:linear-gradient(135deg,rgba(8,18,34,.92),rgba(10,17,40,.86));
}
.loop-card.exclaim-level-2:hover{
  border-color:rgba(107,174,214,.42);
}

.loop-card-header{
  display:flex;justify-content:space-between;align-items:flex-start;
  gap:16px;
  margin-bottom:16px;
}
.loop-title-group{
  display:flex;align-items:flex-start;gap:8px;
  flex:1;
  min-width:0;
}
.loop-title{
  font-family:'Cormorant Garamond',serif;
  font-weight:400;font-size:22px;
  letter-spacing:.06em;
  color:var(--cream);
  line-height:1.2;
  min-width:0;
  overflow-wrap:anywhere;
}
.exclaim-badge{
  width:18px;height:18px;
  display:inline-flex;align-items:center;justify-content:center;
  flex:0 0 auto;
  margin-top:3px;
  font-family:'Space Mono',monospace;
  font-size:12px;line-height:1;
  color:var(--rose);
  border:1px solid rgba(192,107,138,.28);
  border-radius:50%;
  background:rgba(192,107,138,.08);
}
.exclaim-badge.level-2{
  width:auto;
  min-width:24px;
  padding:0 5px;
  color:var(--glow);
  border-color:rgba(107,174,214,.34);
  background:rgba(74,143,212,.1);
  border-radius:10px;
}
.loop-meta{
  font-family:'Space Mono',monospace;
  font-size:9px;letter-spacing:.15em;
  color:var(--muted);
  text-transform:uppercase;
  text-align:right;
  white-space:nowrap;
  flex:0 0 auto;
}
.loop-bpm{color:var(--accent)}
.loop-key{color:var(--warm);margin-top:2px}

/* ── WAVEFORM ────────────────────────────────────── */
.waveform-wrap{
  position:relative;
  height:48px;
  margin-bottom:14px;
  cursor:pointer;
  display:flex;align-items:center;gap:2px;
  border-radius:4px;
  outline:none;
  transition:none;
}
.waveform-wrap:focus-visible{
  outline:1px solid rgba(107,174,214,.42);
  outline-offset:4px;
}
.waveform-bar{
  flex:1;
  border-radius:1px;
  background:var(--dim);
  transition:background .15s ease;
  min-width:2px;
}
.waveform-bar.played{
  background:linear-gradient(to top,rgba(74,143,212,.6),rgba(107,174,214,.85));
}
.waveform-bar.playing{
  background:var(--glow);
  box-shadow:0 0 4px rgba(107,174,214,.4);
}

/* ── CARD ACTIONS ────────────────────────────────── */
.loop-card-tags{
  display:flex;flex-wrap:wrap;gap:6px;
  margin-bottom:14px;
}
.loop-tag{
  font-family:'Space Mono',monospace;
  font-size:8px;letter-spacing:.12em;
  text-transform:uppercase;
  padding:2px 8px;
  border-radius:10px;
  background:rgba(26,42,94,.4);
  color:rgba(107,174,214,.7);
  border:1px solid rgba(74,143,212,.12);
}

.loop-card-actions{
  display:flex;justify-content:space-between;align-items:center;
}

.play-btn{
  display:flex;align-items:center;gap:8px;
  font-family:'Space Mono',monospace;
  font-size:9px;letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--accent);
  background:none;border:1px solid rgba(74,143,212,.25);
  padding:6px 16px 5px;
  border-radius:4px;
  cursor:pointer;
  transition:all .3s ease;
}
.play-btn:hover{
  border-color:rgba(107,174,214,.5);
  color:var(--glow);
  background:rgba(74,143,212,.06);
}
.play-btn:focus-visible,
.dl-btn:focus-visible,
.tag-pill:focus-visible,
.modal-close:focus-visible,
.modal-submit:focus-visible,
.modal-input:focus-visible,
.mini-btn:focus-visible,
.mini-toggle:focus-visible,
.mini-track:focus-visible{
  outline:1px solid rgba(107,174,214,.75);
  outline-offset:3px;
}
.play-btn.playing{
  border-color:rgba(192,107,138,.4);
  color:var(--rose);
}
.play-btn.loading{
  border-color:rgba(74,143,212,.45);
  color:var(--glow);
}
.play-btn.loading svg{
  animation:spin 1s linear infinite;
}
.play-btn.error{
  border-color:rgba(192,107,138,.55);
  color:var(--rose);
}
.play-btn svg{width:12px;height:12px;fill:currentColor}

@keyframes spin{to{transform:rotate(360deg)}}

.dl-btn{
  display:flex;align-items:center;gap:6px;
  font-family:'Space Mono',monospace;
  font-size:9px;letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--rose);
  background:none;border:1px solid rgba(192,107,138,.25);
  padding:6px 14px 5px;
  border-radius:4px;
  cursor:pointer;
  transition:all .3s ease;
}
.dl-btn:hover{
  border-color:rgba(192,107,138,.5);
  background:rgba(192,107,138,.06);
  color:#d88aa0;
}
.dl-btn svg{width:12px;height:12px;fill:currentColor}

/* ── PROGRESS BAR (below waveform) ───────────────── */
.loop-progress{
  width:100%;height:2px;
  background:rgba(74,143,212,.08);
  border-radius:1px;
  margin-top:-12px;margin-bottom:12px;
  overflow:hidden;
}
.loop-progress-fill{
  height:100%;width:0%;
  background:linear-gradient(90deg,var(--accent),var(--rose));
  transition:width .1s linear;
}

/* ── MINI PLAYER ─────────────────────────────────── */
.mini-player{
  position:fixed;
  left:50%;bottom:18px;
  z-index:80;
  width:min(760px,calc(100vw - 32px));
  transform:translate(-50%,16px) scale(.985);
  opacity:0;
  display:grid;
  grid-template-columns:minmax(250px,1fr) auto;
  grid-template-areas:
    "track controls"
    "progress controls"
    "time controls";
  gap:8px 20px;
  padding:12px 16px 10px;
  border:1px solid rgba(74,143,212,.22);
  border-radius:8px;
  background:linear-gradient(135deg,rgba(7,11,26,.96),rgba(10,17,40,.93));
  box-shadow:0 16px 46px rgba(0,0,0,.46),0 0 24px rgba(74,143,212,.06),inset 0 1px 0 rgba(232,226,216,.045);
  transition:opacity .22s cubic-bezier(.23,1,.32,1),transform .22s cubic-bezier(.23,1,.32,1),border-color .22s ease;
}
.mini-player[hidden]{display:none}
.mini-player.visible{
  opacity:1;
  transform:translate(-50%,0) scale(1);
}
.mini-player.is-playing{border-color:rgba(107,174,214,.42)}
.mini-player.is-loading{border-color:rgba(74,143,212,.34)}
.mini-player.is-error{border-color:rgba(192,107,138,.48)}

.mini-track{
  grid-area:track;
  min-width:0;
  text-align:left;
  border:0;
  background:transparent;
  color:var(--cream);
  cursor:pointer;
  padding:0;
  transition:opacity .18s ease,transform .16s cubic-bezier(.23,1,.32,1);
}
.mini-kicker{
  display:block;
  margin-bottom:4px;
  font-family:'Space Mono',monospace;
  font-size:7px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--muted);
}
.mini-title{
  display:block;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:21px;
  font-weight:400;
  line-height:1;
  letter-spacing:.06em;
}
.mini-progress{
  grid-area:progress;
  position:relative;
  width:100%;
  height:14px;
  padding:6px 0;
  border:0;
  border-radius:0;
  background:transparent;
  overflow:hidden;
  cursor:pointer;
  touch-action:none;
}
.mini-progress::before{
  content:'';
  position:absolute;
  left:0;right:0;top:6px;
  height:2px;
  border-radius:2px;
  background:rgba(74,143,212,.14);
}
.mini-progress-fill{
  position:absolute;
  left:0;
  top:6px;
  z-index:1;
  height:2px;
  width:0;
  border-radius:2px;
  background:linear-gradient(90deg,var(--accent),var(--glow),var(--rose));
  transition:width .1s linear;
}
.mini-time{
  grid-area:time;
  display:flex;
  justify-content:space-between;
  font-family:'Space Mono',monospace;
  font-size:8px;
  letter-spacing:.12em;
  color:var(--dim);
}
.mini-controls{
  grid-area:controls;
  display:flex;
  align-items:center;
  gap:7px;
}
.mini-btn,
.mini-toggle,
.mini-autoplay-switch{
  position:relative;
  font-family:'Space Mono',monospace;
  color:var(--accent);
  background:rgba(4,5,15,.28);
  border:1px solid rgba(74,143,212,.24);
  border-radius:4px;
  cursor:pointer;
  line-height:1;
  white-space:nowrap;
  transition:border-color .18s ease,color .18s ease,background .18s ease,transform .14s cubic-bezier(.23,1,.32,1);
}
.mini-btn{
  width:36px;height:36px;
  min-width:36px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0;
  overflow:hidden;
  font-size:0;
}
.mini-btn svg{
  width:14px;height:14px;
  fill:currentColor;
}
.mini-play{
  width:40px;height:40px;
  min-width:40px;
  color:var(--glow);
  border-color:rgba(107,174,214,.38);
}
.mini-mode svg{
  fill:none;
  width:15px;height:15px;
}
.mini-toggle{
  width:36px;
  min-width:36px;
  height:36px;
  padding:0;
  font-size:8px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--muted);
}
.mini-toggle.active{
  color:var(--glow);
  border-color:rgba(107,174,214,.42);
  background:rgba(74,143,212,.08);
}
.mini-mode.active{
  color:var(--glow);
  border-color:rgba(107,174,214,.68);
  background:linear-gradient(135deg,rgba(74,143,212,.22),rgba(26,42,94,.34));
  box-shadow:inset 0 0 0 1px rgba(107,174,214,.12),0 0 12px rgba(74,143,212,.12);
}
.mini-mode.active svg{
  filter:drop-shadow(0 0 4px rgba(107,174,214,.35));
}
.mini-mode.active::after{
  content:'';
  position:absolute;
  left:50%;
  bottom:5px;
  width:3px;height:3px;
  border-radius:50%;
  background:var(--glow);
  transform:translateX(-50%);
}
.mini-toggle:not(.mini-btn){
  width:auto;
  min-width:94px;
  padding:0 10px;
  font-size:8px;
}
.mini-autoplay-switch{
  width:68px;
  min-width:68px;
  height:36px;
  padding:0;
  border-radius:999px;
  overflow:hidden;
  background:rgba(4,5,15,.34);
}
.mini-switch-track{
  position:absolute;
  inset:4px;
  border-radius:999px;
  background:rgba(10,17,40,.54);
}
.mini-switch-thumb{
  position:absolute;
  top:50%;
  left:0;
  width:28px;
  height:28px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  color:var(--muted);
  background:rgba(7,11,26,.98);
  border:1px solid rgba(74,143,212,.28);
  box-shadow:0 6px 14px rgba(0,0,0,.3),inset 0 1px 0 rgba(232,226,216,.05);
  transform:translate(0,-50%);
  transition:transform .2s cubic-bezier(.23,1,.32,1),color .18s ease,border-color .18s ease,background .18s ease;
}
.mini-switch-thumb svg{
  width:13px;
  height:13px;
  fill:currentColor;
}
.mini-autoplay-switch.active{
  color:var(--glow);
  border-color:rgba(107,174,214,.58);
  background:rgba(74,143,212,.14);
  box-shadow:inset 0 0 0 1px rgba(107,174,214,.1),0 0 14px rgba(74,143,212,.1);
}
.mini-autoplay-switch.active .mini-switch-track{
  background:rgba(74,143,212,.18);
}
.mini-autoplay-switch.active .mini-switch-thumb{
  color:var(--cream);
  border-color:rgba(107,174,214,.66);
  background:rgba(26,42,94,.96);
  transform:translate(30px,-50%);
}
@media(hover:hover)and(pointer:fine){
  .mini-btn:hover,
  .mini-toggle:hover,
  .mini-autoplay-switch:hover{
    border-color:rgba(107,174,214,.5);
    color:var(--glow);
    background:rgba(74,143,212,.07);
  }
}
.mini-btn:active,
.mini-toggle:active,
.mini-autoplay-switch:active,
.mini-track:active{
  transform:scale(.97);
}

/* ── LOADING ─────────────────────────────────────── */
.loader{
  text-align:center;padding:40px;
  position:relative;z-index:10;
}
.is-hidden{display:none}
.loader-dot{
  display:inline-block;width:6px;height:6px;
  border-radius:50%;background:var(--accent);
  margin:0 4px;
  animation:loaderPulse 1.4s ease-in-out infinite;
}
.loader-dot:nth-child(2){animation-delay:.2s}
.loader-dot:nth-child(3){animation-delay:.4s}
@keyframes loaderPulse{
  0%,80%,100%{transform:scale(0);opacity:.4}
  40%{transform:scale(1);opacity:1}
}

.no-loops{
  text-align:center;padding:60px 20px;
  position:relative;z-index:10;
}
.no-loops p{
  font-family:'Space Mono',monospace;
  font-size:11px;letter-spacing:.15em;
  color:var(--muted);text-transform:uppercase;
}

/* ── EMAIL MODAL ─────────────────────────────────── */
.modal-overlay{
  position:fixed;inset:0;z-index:200;
  background:rgba(4,5,15,.75);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  display:none;align-items:center;justify-content:center;
  opacity:0;transition:opacity .3s ease;
}
.modal-overlay.visible{display:flex;opacity:1}

.modal{
  background:linear-gradient(135deg,rgba(10,17,40,.95),rgba(7,11,26,.98));
  border:1px solid rgba(74,143,212,.15);
  border-radius:12px;
  padding:40px;
  max-width:400px;width:90%;
  position:relative;
  box-shadow:0 20px 60px rgba(0,0,0,.5),0 0 40px rgba(74,143,212,.05);
}
.modal-close{
  position:absolute;top:16px;right:16px;
  background:none;border:none;
  color:var(--dim);cursor:pointer;
  font-size:20px;line-height:1;
  transition:color .2s ease;
}
.modal-close:hover{color:var(--cream)}

.modal-title{
  font-family:'Cormorant Garamond',serif;
  font-weight:300;font-size:28px;
  letter-spacing:.08em;
  color:var(--cream);
  margin-bottom:8px;
}
.modal-sub{
  font-family:'Space Mono',monospace;
  font-size:9px;letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:24px;
}
.modal-loop-name{
  font-family:'Space Mono',monospace;
  font-size:10px;color:var(--accent);
  margin-bottom:20px;letter-spacing:.1em;
}

.modal-input{
  width:100%;padding:12px 16px;
  font-family:'Space Mono',monospace;
  font-size:11px;letter-spacing:.08em;
  background:rgba(4,5,15,.6);
  border:1px solid rgba(74,143,212,.2);
  border-radius:6px;
  color:var(--cream);
  outline:none;
  transition:border-color .3s ease;
  margin-bottom:16px;
}
.modal-input::placeholder{color:var(--dim)}
.modal-input:focus{
  border-color:rgba(107,174,214,.5);
  box-shadow:0 0 12px rgba(74,143,212,.1);
}

.modal-submit{
  width:100%;padding:12px;
  font-family:'Space Mono',monospace;
  font-size:10px;letter-spacing:.2em;
  text-transform:uppercase;
  background:linear-gradient(135deg,var(--blue),var(--indigo));
  border:1px solid rgba(107,174,214,.3);
  border-radius:6px;
  color:var(--cream);
  cursor:pointer;
  transition:all .3s ease;
}
.modal-submit:hover{
  background:linear-gradient(135deg,var(--indigo),var(--violet));
  border-color:rgba(107,174,214,.5);
  box-shadow:0 4px 20px rgba(74,143,212,.15);
}
.modal-submit:disabled{opacity:.5;cursor:not-allowed}

.modal-error{
  font-family:'Space Mono',monospace;
  font-size:9px;color:var(--rose);
  margin-top:10px;text-align:center;
  min-height:14px;
}

/* ── FOOTER ──────────────────────────────────────── */
.page-footer{
  position:relative;z-index:10;
  text-align:center;padding:20px 30px 40px;
}
.page-footer p{
  font-family:'Space Mono',monospace;
  font-size:8px;letter-spacing:.2em;
  color:var(--dim);text-transform:uppercase;
}

@media(max-width:640px){
  body.has-mini-player{padding-bottom:142px}
  .mini-player{
    bottom:12px;
    width:calc(100vw - 24px);
    grid-template-columns:1fr;
    grid-template-areas:
      "track"
      "progress"
      "time"
      "controls";
    gap:8px;
    padding:13px;
  }
  .mini-controls{
    justify-content:center;
    gap:8px;
  }
  .mini-btn{
    width:42px;height:42px;
  }
  .mini-play{
    width:48px;height:48px;
  }
  .mini-title{font-size:20px}
  .mini-kicker{font-size:7px}
}

@media(prefers-reduced-motion:reduce){
  .mini-player,
  .loop-card,
  .play-btn,
  .dl-btn,
  .tag-pill,
  .waveform-wrap{
    transition:none!important;
  }
  .play-btn.loading svg{
    animation:none!important;
  }
}
