:root{
  --bg:#090b10;
  --panel:#121722;
  --panel2:#18202e;
  --text:#edf4ff;
  --muted:#8f9db3;
  --accent:#35d3ff;
  --now-color:#35d3ff;
  --danger:#ff6078;
  --warn:#ffbd6b;
  --radius:22px;
  --shadow:0 18px 50px rgba(0,0,0,.28);
  --safe-bottom:env(safe-area-inset-bottom,0px);
  --topbar-h:68px;
  --player-h:96px;
}

[data-theme="warm"]{
  --bg:#120c08;
  --panel:#1e1711;
  --panel2:#2a1f16;
  --accent:#f59e0b;
}

[data-theme="green"]{
  --bg:#06110b;
  --panel:#0f1f17;
  --panel2:#142a1f;
  --accent:#34d399;
}

[data-theme="minimal"]{
  --bg:#f3f5f7;
  --panel:#fff;
  --panel2:#e9edf2;
  --text:#10141b;
  --muted:#5f6877;
  --accent:#246bfe;
  --shadow:0 12px 32px rgba(20,24,32,.12);
}

*{
  box-sizing:border-box;
}

html{
  height:100%;
  scrollbar-color:color-mix(in srgb,var(--accent),transparent 30%) transparent;
  scrollbar-width:thin;
}

body{
  height:100%;
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:
    radial-gradient(circle at top left,color-mix(in srgb,var(--accent),transparent 76%),transparent 38rem),
    var(--bg);
  color:var(--text);
  overflow:hidden;
  -webkit-font-smoothing:antialiased;
  user-select:none;
}

input,
textarea,
[contenteditable],
pre{
  user-select:text;
}

a{
  color:inherit;
  text-decoration:none;
}

.hidden{
  display:none!important;
}

.muted{
  color:var(--muted);
}

hr{
  border:0;
  border-top:1px solid rgba(255,255,255,.08);
  margin:18px 0;
}

svg{
  width:1.15em;
  height:1.15em;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}

/* Scrollbars */
::-webkit-scrollbar{
  width:10px;
  height:10px;
}

::-webkit-scrollbar-track{
  background:rgba(255,255,255,.025);
  border-radius:999px;
}

::-webkit-scrollbar-thumb{
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb,var(--accent),transparent 15%),
      rgba(255,255,255,.18)
    );
  border:2px solid transparent;
  background-clip:content-box;
  border-radius:999px;
}

::-webkit-scrollbar-thumb:hover{
  background-color:var(--accent);
}

/* Background ambiance */
body::before{
  content:"";
  position:fixed;
  inset:-12%;
  z-index:-2;
  background:var(--now-cover) center/cover no-repeat;
  opacity:.10;
  filter:blur(38px) saturate(1.1);
  transition:.35s;
}

body::after{
  content:"";
  position:fixed;
  inset:0;
  z-index:-1;
  background:
    radial-gradient(circle at 72% 18%,color-mix(in srgb,var(--now-color),transparent 72%),transparent 28rem),
    linear-gradient(180deg,transparent,rgba(0,0,0,.26));
  pointer-events:none;
}

/* Topbar */
.topbar{
  height:var(--topbar-h);
  padding:12px 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  background:rgba(9,11,16,.78);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(255,255,255,.08);
  z-index:30;
}

.topbar strong{
  display:block;
  font-size:1.12rem;
}

.topbar span{
  display:block;
  color:var(--muted);
  font-size:.82rem;
}

.topbar nav{
  display:flex;
  gap:10px;
}

.topbar a,
.hamb{
  border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.06);
  padding:9px 12px;
  border-radius:999px;
  color:var(--text);
}

.hamb{
  display:none;
  font-size:1.1rem;
  cursor:pointer;
}

/* Main layout */
.app-shell{
  height:100dvh;
  display:grid;
  grid-template-columns:280px 1fr;
  grid-template-rows:var(--topbar-h) 1fr var(--player-h);
}

.app-shell .topbar{
  grid-column:1/3;
  grid-row:1;
}

.sidebar{
  grid-column:1;
  grid-row:2/4;
  padding:22px;
  border-right:1px solid rgba(255,255,255,.08);
  background:rgba(14,18,26,.78);
  overflow:auto;
}

.sidebar h2{
  margin-top:0;
}

.sidebar label{
  display:block;
  color:var(--muted);
  margin:18px 0 8px;
}

.sidebar select,
.search,
input,
select{
  width:100%;
  background:#0d1119;
  border:1px solid rgba(255,255,255,.1);
  border-radius:14px;
  padding:12px 14px;
  color:var(--text);
  outline:none;
}

.nav-pill{
  width:100%;
  text-align:left;
  border:0;
  margin:4px 0;
  padding:12px 14px;
  border-radius:14px;
  background:transparent;
  color:var(--muted);
  cursor:pointer;
}

.nav-pill.active,
.nav-pill:hover{
  background:linear-gradient(90deg,color-mix(in srgb,var(--accent),transparent 78%),transparent);
  color:var(--text);
}

/* Library */
.library{
  grid-column:2;
  grid-row:2/3;
  overflow:auto;
  padding:0 28px calc(var(--player-h) + 28px);
}

.hero{
  position:sticky;
  top:0;
  z-index:18;
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:20px;
  margin:0 -28px 24px;
  padding:26px 28px 20px;
  background:linear-gradient(180deg,rgba(9,11,16,.96),rgba(9,11,16,.82));
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(255,255,255,.06);
}

.hero h1{
  font-size:clamp(2rem,4vw,4.6rem);
  line-height:.95;
  margin:0;
}

.hero p{
  margin:10px 0 0;
  color:var(--muted);
}

.hero .search{
  max-width:420px;
}

.mobile-stage{
  display:none;
}

/* Songs */
.song-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:16px;
}

.song-card{
  --song-color:var(--accent);
  position:relative;
  display:grid;
  grid-template-columns:76px 1fr;
  gap:14px;
  align-items:center;
  text-align:left;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(145deg,color-mix(in srgb,var(--song-color),transparent 88%),rgba(255,255,255,.025));
  border-radius:var(--radius);
  padding:12px;
  color:var(--text);
  box-shadow:var(--shadow);
  cursor:pointer;
  min-height:104px;
  transition:.16s;
  overflow:hidden;
}

.song-card::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:radial-gradient(circle at 0% 0%,color-mix(in srgb,var(--song-color),transparent 70%),transparent 48%);
  opacity:.45;
  pointer-events:none;
}

.song-card:hover{
  border-color:color-mix(in srgb,var(--song-color),white 10%);
  transform:translateY(-1px);
}

.song-card.playing{
  outline:2px solid var(--now-color);
  box-shadow:0 0 0 6px color-mix(in srgb,var(--now-color),transparent 84%);
}

.song-card img,
.song-card div{
  position:relative;
  z-index:1;
}

.song-card img{
  width:76px;
  height:76px;
  object-fit:cover;
  border-radius:16px;
  background:#0b0d12;
}

.song-card strong{
  display:block;
  line-height:1.14;
  padding-right:30px;
}

.song-card span,
.song-card small{
  display:block;
  color:var(--muted);
  margin-top:4px;
}

.song-card em{
  display:inline-block;
  margin-top:6px;
  color:var(--warn);
  font-style:normal;
  font-size:.78rem;
}

.song-card.missing{
  opacity:.68;
}

.song-card.missing strong{
  text-decoration:line-through;
}

/* Like button */
.song-card .like{
  position:absolute;
  right:9px;
  top:9px;
  z-index:3;
  border:0;
  background:rgba(0,0,0,.34);
  color:#fff;
  border-radius:999px;
  width:28px;
  height:28px;
  display:grid;
  place-items:center;
  padding:0;
  line-height:1;
  font-size:.92rem;
  cursor:pointer;
  opacity:.78;
  transition:.16s;
}

.song-card .like:hover{
  opacity:1;
  transform:scale(1.06);
}

.song-card .like.on{
  background:var(--accent);
  color:#041016;
  opacity:1;
}

/* Player */
.player{
  grid-column:2;
  grid-row:3;
  position:fixed;
  left:280px;
  right:0;
  bottom:0;
  height:var(--player-h);
  display:grid;
  grid-template-columns:64px minmax(170px,1fr) minmax(260px,540px) auto;
  grid-template-rows:1fr;
  gap:16px;
  align-items:center;
  padding:12px 18px calc(12px + var(--safe-bottom));
  background:rgba(9,11,16,.9);
  backdrop-filter:blur(16px);
  border-top:1px solid rgba(255,255,255,.1);
  z-index:28;
}

.player img{
  width:64px;
  height:64px;
  object-fit:cover;
  border-radius:14px;
  cursor:pointer;
}

.now strong,
.now span{
  display:block;
}

.now span{
  color:var(--muted);
  font-size:.9rem;
}

.transport{
  grid-column:4;
  grid-row:1;
  display:flex;
  gap:8px;
  align-items:center;
  justify-content:flex-end;
}

.round{
  width:46px;
  height:46px;
  border-radius:999px;
  border:0;
  background:var(--accent);
  color:#041016;
  font-weight:800;
  cursor:pointer;
  font-size:1.7rem;
  line-height:1;
}

.round:disabled{
  opacity:.4;
  cursor:not-allowed;
}

.round.ghost,
.chip{
  background:rgba(255,255,255,.08);
  color:var(--text);
  border:1px solid rgba(255,255,255,.1);
}

.chip{
  height:36px;
  min-width:38px;
  border-radius:999px;
  padding:0 10px;
  display:inline-grid;
  place-items:center;
  text-decoration:none;
  cursor:pointer;
}

.icon-chip svg{
  width:18px;
  height:18px;
}

.chip.active,
.chip.ready{
  background:var(--accent);
  color:#031015;
}

.chip:disabled,
.chip.disabled{
  opacity:.38;
  pointer-events:none;
}

.progress-wrap{
  grid-column:3;
  grid-row:1;
  display:grid;
  grid-template-columns:42px minmax(0,1fr) 42px;
  gap:10px;
  align-items:center;
  align-self:center;
  color:var(--muted);
  font-size:.82rem;
  min-width:0;
}

/* Progress bar */
.progress-wrap input[type=range]{
  appearance:none;
  -webkit-appearance:none;
  width:100%;
  height:22px;
  padding:0;
  border:0;
  background:transparent;
  cursor:pointer;
  accent-color:var(--accent);
}

.progress-wrap input[type=range]::-webkit-slider-runnable-track{
  height:11px;
  border-radius:999px;
  background:
    linear-gradient(
      90deg,
      color-mix(in srgb,var(--accent),white 12%),
      color-mix(in srgb,var(--accent),transparent 5%)
    );
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.30),
    0 0 20px color-mix(in srgb,var(--accent),transparent 58%);
}

.progress-wrap input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;
  width:22px;
  height:22px;
  border-radius:999px;
  background:#fff;
  border:4px solid var(--accent);
  margin-top:-5.5px;
  box-shadow:
    0 4px 14px rgba(0,0,0,.55),
    0 0 0 5px color-mix(in srgb,var(--accent),transparent 78%);
}

.progress-wrap input[type=range]::-moz-range-track{
  height:11px;
  border-radius:999px;
  background:
    linear-gradient(
      90deg,
      color-mix(in srgb,var(--accent),white 12%),
      color-mix(in srgb,var(--accent),transparent 5%)
    );
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.30),
    0 0 20px color-mix(in srgb,var(--accent),transparent 58%);
}

.progress-wrap input[type=range]::-moz-range-thumb{
  width:22px;
  height:22px;
  border-radius:999px;
  background:#fff;
  border:4px solid var(--accent);
  box-shadow:
    0 4px 14px rgba(0,0,0,.55),
    0 0 0 5px color-mix(in srgb,var(--accent),transparent 78%);
}

.player audio{
  display:none;
}

/* Dialogs */
.lyrics-dialog,
.tag-dialog{
  width:min(720px,calc(100vw - 22px));
  max-height:min(82dvh,760px);
  border:1px solid rgba(255,255,255,.12);
  border-radius:24px;
  background:#101620;
  color:var(--text);
  box-shadow:var(--shadow);
  padding:22px;
}

.lyrics-dialog::backdrop,
.tag-dialog::backdrop{
  background:rgba(0,0,0,.6);
  backdrop-filter:blur(3px);
}

.dialog-close{
  position:absolute;
  right:14px;
  top:12px;
  border:0;
  background:rgba(255,255,255,.08);
  color:#fff;
  border-radius:999px;
  width:34px;
  height:34px;
  font-size:1.2rem;
}

.lyrics-dialog pre{
  white-space:pre-wrap;
  line-height:1.5;
  color:#f4f8ff;
  background:rgba(255,255,255,.045);
  border-radius:16px;
  padding:14px;
  max-height:58dvh;
  overflow:auto;
}

/* Toast */
.toast{
  position:fixed;
  z-index:80;
  left:50%;
  bottom:112px;
  transform:translateX(-50%) translateY(20px);
  background:#fff;
  color:#111;
  padding:10px 14px;
  border-radius:999px;
  opacity:0;
  pointer-events:none;
  transition:.18s;
}

.toast.show{
  opacity:1;
  transform:translateX(-50%) translateY(0);
}

/* Login */
.login-page{
  min-height:100dvh;
  display:grid;
  place-items:center;
}

.login-card{
  width:min(360px,calc(100vw - 28px));
  padding:28px;
  background:var(--panel);
  border:1px solid rgba(255,255,255,.09);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}

.login-card h1{
  font-size:3rem;
  margin:0;
}

.login-card p{
  color:var(--muted);
  margin-top:0;
}

.login-card label{
  display:block;
  margin:16px 0 8px;
}

/* Buttons */
.btn{
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px;
  background:rgba(255,255,255,.07);
  color:var(--text);
  padding:11px 14px;
  cursor:pointer;
}

.btn.primary{
  background:var(--accent);
  color:#031015;
  border-color:transparent;
  font-weight:700;
}

.btn.danger{
  background:color-mix(in srgb,var(--danger),transparent 78%);
  color:#fff;
}

.btn.tiny{
  padding:6px 8px;
  border-radius:10px;
  font-size:.78rem;
}

.notice{
  padding:12px 14px;
  border-radius:14px;
  background:rgba(255,255,255,.07);
  margin:12px 0;
}

.notice.error,
.warn{
  color:var(--warn);
}

.ok{
  color:#7ee787;
}

/* Admin */
.admin-shell{
  height:100dvh;
  display:grid;
  grid-template-columns:240px 1fr;
  grid-template-rows:var(--topbar-h) 1fr;
  overflow:hidden;
}

.admin-shell .topbar{
  grid-column:1/3;
  grid-row:1;
}

.admin-tabs{
  grid-column:1;
  grid-row:2;
  padding:18px;
  border-right:1px solid rgba(255,255,255,.08);
  background:rgba(14,18,26,.72);
  overflow:auto;
}

.admin-tabs a{
  display:block;
  padding:12px 14px;
  margin:5px 0;
  border-radius:14px;
  color:var(--muted);
}

.admin-tabs a.active,
.admin-tabs a:hover{
  background:color-mix(in srgb,var(--accent),transparent 82%);
  color:var(--text);
}

.admin-main{
  grid-column:2;
  grid-row:2;
  overflow:auto;
  padding:24px;
  display:grid;
  gap:18px;
  align-content:start;
}

.panel{
  background:rgba(18,23,34,.88);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:20px;
}

.panel h1,
.panel h2{
  margin-top:0;
}

.stat-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}

.stat-grid div{
  background:var(--panel2);
  border-radius:18px;
  padding:18px;
}

.stat-grid b{
  display:block;
  font-size:2rem;
}

.stat-grid span{
  color:var(--muted);
}

.table-wrap{
  overflow:auto;
}

table{
  width:100%;
  border-collapse:collapse;
  min-width:920px;
}

th,
td{
  text-align:left;
  border-bottom:1px solid rgba(255,255,255,.08);
  padding:10px;
  vertical-align:middle;
}

th{
  color:var(--muted);
  font-weight:600;
}

.mini-cover{
  width:42px;
  height:42px;
  object-fit:cover;
  border-radius:9px;
}

.formline{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
}

.formline input{
  width:auto;
}

.edit-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(190px,1fr));
  gap:12px;
}

.edit-grid label{
  display:grid;
  gap:7px;
  color:var(--muted);
}

.check{
  display:flex!important;
  align-items:center;
  gap:8px;
}

.check input{
  width:auto;
}

td[contenteditable]{
  background:rgba(255,255,255,.025);
  border-radius:8px;
}

.row-actions{
  white-space:nowrap;
}

/* Upload */
.upload-zone{
  display:flex;
  gap:14px;
  align-items:stretch;
  flex-wrap:wrap;
}

.upload-zone input[type=file]{
  position:absolute;
  opacity:0;
  pointer-events:none;
  width:1px;
  height:1px;
}

.drop-label{
  min-width:min(420px,100%);
  display:grid;
  gap:6px;
  border:1px dashed color-mix(in srgb,var(--accent),transparent 45%);
  background:rgba(255,255,255,.045);
  border-radius:20px;
  padding:18px;
  cursor:pointer;
}

.drop-label span{
  color:var(--muted);
  font-size:.9rem;
}

.cover-preview{
  display:grid;
  gap:8px;
  align-content:start;
  color:var(--muted);
}

.cover-preview img,
.proposal-cover{
  width:130px;
  height:130px;
  object-fit:cover;
  border-radius:18px;
  background:#0b0d12;
}

.proposal{
  display:grid;
  grid-template-columns:150px 1fr auto;
  gap:18px;
  align-items:center;
}

.proposal dl{
  display:grid;
  grid-template-columns:80px 1fr;
  gap:5px 10px;
  margin:0;
}

.proposal dt{
  color:var(--muted);
}

.mb-row{
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px 16px;
  align-items:center;
  padding:12px;
  border-bottom:1px solid rgba(255,255,255,.08);
}

.mb-row span{
  display:block;
  color:var(--muted);
}

.plugin-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:12px;
}

.plugin-grid div{
  background:var(--panel2);
  border-radius:18px;
  padding:16px;
}

.plugin-grid b,
.plugin-grid span{
  display:block;
}

.plugin-grid span{
  color:var(--muted);
  margin-top:8px;
}

.full{
  grid-column:1/-1;
}

.edit-grid textarea,
.tag-dialog textarea{
  width:100%;
  background:#0d1119;
  border:1px solid rgba(255,255,255,.1);
  border-radius:14px;
  padding:12px 14px;
  color:var(--text);
  outline:none;
  resize:vertical;
}

.admin-main input[data-field],
.admin-main select[data-field]{
  min-width:130px;
}

.admin-main input[data-field="genre_detail"]{
  margin-top:6px;
  display:block;
  width:100%;
}

/* Admin songs view */
.admin-main.songs-view{
  overflow:hidden;
  grid-template-rows:auto minmax(0,1fr);
  align-content:stretch;
}

.admin-main.songs-view .editor-panel{
  position:relative;
  z-index:3;
  max-height:42dvh;
  overflow:auto;
}

.admin-main.songs-view .panel:has(#songsTable){
  min-height:0;
  display:grid;
  grid-template-rows:auto auto minmax(0,1fr);
}

.admin-main.songs-view .table-wrap{
  min-height:0;
  overflow:auto;
  max-height:none;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.06);
}

.admin-main.songs-view #songsTable thead th{
  position:sticky;
  top:0;
  z-index:2;
  background:#101620;
  box-shadow:0 1px 0 rgba(255,255,255,.08);
}

.admin-main.songs-view tr[data-row="song"]{
  cursor:pointer;
}

.admin-main.songs-view tr[data-row="song"]:hover{
  background:rgba(255,255,255,.035);
}

.plugin-settings .plugin-grid div{
  display:grid;
  gap:10px;
}

.plugin-settings label{
  display:grid;
  gap:6px;
  color:var(--muted);
}

.plugin-settings input[type=number]{
  width:100%;
}

.web-proposal .proposal-cover{
  float:left;
  margin:0 12px 8px 0;
  width:82px;
  height:82px;
  border-radius:14px;
}

/* Equalizer visualizer */
.stage-eq i{
  transition:height .055s linear,opacity .055s linear;
  animation:none!important;
  will-change:height,opacity;
}

/* Mobile */
@media (max-width:780px){
  :root{
    --topbar-h:52px;
    --player-h:88px;
  }

  body{
    overflow:hidden;
    background:var(--bg);
  }

  .hamb{
    display:inline-flex;
  }

  .topbar{
    height:var(--topbar-h);
    min-height:var(--topbar-h);
    padding:7px 10px;
  }

  .topbar strong{
    font-size:1rem;
  }

  .topbar span{
    display:none;
  }

  .topbar nav{
    gap:6px;
  }

  .topbar nav a[href="admin.php"]{
    display:none;
  }

  .topbar nav a{
    padding:7px 9px;
    font-size:.82rem;
  }

  .app-shell{
    height:100svh;
    display:grid;
    grid-template-columns:1fr;
    grid-template-rows:var(--topbar-h) minmax(0,1fr) var(--player-h);
  }

  .app-shell .topbar{
    grid-column:1;
  }

  .sidebar{
    position:fixed;
    z-index:50;
    left:0;
    right:0;
    bottom:0;
    width:100%;
    max-height:58svh;
    overflow:auto;
    transform:translateY(110%);
    opacity:0;
    visibility:hidden;
    pointer-events:none;
    transition:
      transform .22s ease,
      opacity .18s ease,
      visibility .18s ease;
    border-right:0;
    border-top:1px solid rgba(255,255,255,.12);
    border-radius:24px 24px 0 0;
    box-shadow:var(--shadow);
    background:rgba(14,18,26,.96);
    padding-bottom:calc(var(--player-h) + 18px + var(--safe-bottom));
  }

  .sidebar.open{
    transform:translateY(0);
    opacity:1;
    visibility:visible;
    pointer-events:auto;
  }

  .sidebar h2{
    font-size:1.15rem;
  }

  .library{
    grid-column:1;
    grid-row:2;
    min-height:0;
    overflow:auto;
    padding:0 9px calc(var(--player-h) + 10px);
  }

  .hero{
    display:none;
  }

  .mobile-stage{
    display:grid;
    grid-template-rows:auto auto;
    gap:6px;
    position:sticky;
    top:0;
    z-index:12;
    margin:0 -9px 8px;
    padding:8px 10px 7px;
    background:
      linear-gradient(
        180deg,
        rgba(9,11,16,.98),
        rgba(9,11,16,.90)
      );
    backdrop-filter:blur(12px);
    border-bottom:1px solid rgba(255,255,255,.07);
  }

  .stage-visual{
    position:relative;
    display:grid;
    place-items:center;
    overflow:hidden;
    height:clamp(132px,25svh,205px);
    min-height:0;
    border-radius:22px;
    background:
      radial-gradient(
        circle at top,
        color-mix(in srgb,var(--now-color),transparent 58%),
        rgba(255,255,255,.045)
      );
    box-shadow:var(--shadow);
    cursor:pointer;
  }

  .stage-visual img{
    width:clamp(112px,40vw,185px);
    height:clamp(112px,40vw,185px);
    max-height:calc(25svh - 14px);
    object-fit:cover;
    border-radius:20px;
    box-shadow:0 18px 42px rgba(0,0,0,.35);
    transition:.25s;
  }

  .stage-video,
  .stage-visual iframe{
    display:none;
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    border:0;
  }

  .stage-eq{
    display:none;
    gap:8px;
    align-items:end;
    height:calc(100% - 24px);
    width:min(70vw,260px);
    padding:18px;
    border-radius:22px;
    background:
      linear-gradient(
        180deg,
        color-mix(in srgb,var(--now-color),transparent 82%),
        rgba(0,0,0,.2)
      );
  }

  .stage-eq i{
    display:block;
    flex:1;
    border-radius:999px;
    background:
      linear-gradient(
        180deg,
        var(--now-color),
        rgba(255,255,255,.18)
      );
    height:20%;
    transition:height .055s linear,opacity .055s linear;
    animation:none!important;
    will-change:height,opacity;
  }

  .stage-visual[data-mode="eq"] img{
    display:none;
  }

  .stage-visual[data-mode="eq"] .stage-eq{
    display:flex;
  }

  .stage-visual[data-mode="video"] img,
  .stage-visual[data-mode="video"] .stage-eq{
    display:none;
  }

  .stage-visual[data-mode="video"] iframe{
    display:block;
  }

  .stage-meta{
    text-align:center;
    display:grid;
    gap:1px;
    padding:0 6px;
  }

  .stage-meta strong{
    font-size:.98rem;
    line-height:1.15;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }

  .stage-meta span{
    color:var(--muted);
    font-size:.82rem;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }

  .stage-meta small{
    color:var(--muted);
    font-size:.72rem;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }

  .song-grid{
    display:grid;
    grid-template-columns:1fr;
    gap:7px;
  }

  .song-card{
    grid-template-columns:50px 1fr;
    min-height:68px;
    border-radius:16px;
    padding:8px;
    box-shadow:none;
  }

  .song-card img{
    width:50px;
    height:50px;
    border-radius:12px;
  }

  .song-card strong{
    font-size:.9rem;
    line-height:1.12;
    padding-right:28px;
  }

  .song-card span,
  .song-card small{
    font-size:.76rem;
    margin-top:2px;
  }

  .song-card .like{
    width:25px;
    height:25px;
    right:7px;
    top:7px;
    bottom:auto;
    font-size:.82rem;
  }

  .player{
    grid-column:1;
    grid-row:3;
    left:0;
    height:var(--player-h);
    grid-template-columns:42px minmax(0,1fr) auto;
    grid-template-rows:38px 30px;
    gap:4px;
    padding:7px 9px calc(5px + var(--safe-bottom));
    align-content:start;
  }

  .player img{
    width:42px;
    height:42px;
    border-radius:11px;
  }

  .now{
    min-width:0;
  }

  .now strong,
  .now span{
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }

  .now strong{
    font-size:.9rem;
  }

  .now span{
    font-size:.75rem;
  }

  .transport{
    grid-column:auto;
    grid-row:auto;
    gap:4px;
    justify-content:flex-end;
  }

  .round{
    width:34px;
    height:34px;
    font-size:1.25rem;
  }

  .chip{
    height:29px;
    min-width:30px;
    padding:0 6px;
  }

  .icon-chip svg{
    width:15px;
    height:15px;
  }

  .progress-wrap{
    grid-column:1/4;
    grid-row:2;
    grid-template-columns:34px 1fr 34px;
    gap:7px;
    font-size:.68rem;
    align-self:start;
    transform:translateY(-2px);
  }

  .progress-wrap input[type=range]{
    height:20px;
  }

  .progress-wrap input[type=range]::-webkit-slider-runnable-track{
    height:9px;
  }

  .progress-wrap input[type=range]::-webkit-slider-thumb{
    width:19px;
    height:19px;
    margin-top:-5px;
    border-width:3px;
  }

  .progress-wrap input[type=range]::-moz-range-track{
    height:9px;
  }

  .progress-wrap input[type=range]::-moz-range-thumb{
    width:19px;
    height:19px;
    border-width:3px;
  }

  .admin-shell{
    display:block;
    height:100svh;
    overflow:auto;
  }

  .admin-tabs{
    display:flex;
    overflow:auto;
    gap:8px;
    padding:10px;
    position:sticky;
    top:var(--topbar-h);
    z-index:15;
    border-right:0;
    border-bottom:1px solid rgba(255,255,255,.08);
  }

  .admin-tabs a{
    white-space:nowrap;
    margin:0;
  }

  .admin-main{
    padding:10px;
    display:grid;
  }

  .panel{
    padding:14px;
    border-radius:18px;
  }

  .stat-grid{
    grid-template-columns:1fr;
  }

  .formline,
  .upload-zone{
    display:grid;
  }

  .formline input,
  .upload-zone button{
    width:100%;
  }

  table{
    min-width:920px;
  }

  .proposal{
    grid-template-columns:1fr;
  }

  .cover-preview img,
  .proposal-cover{
    width:110px;
    height:110px;
  }

  .toast{
    bottom:112px;
    width:max-content;
    max-width:calc(100vw - 24px);
  }

  .admin-main.songs-view{
    overflow:auto;
  }

  .admin-main.songs-view .editor-panel{
    max-height:none;
  }

  .admin-main.songs-view .panel:has(#songsTable){
    display:block;
  }

  .admin-main.songs-view .table-wrap{
    max-height:58dvh;
  }
}

/* Smaller visible height: iPhone browser bars, smaller Android screens */
@media (max-width:780px) and (max-height:760px){
  :root{
    --topbar-h:48px;
    --player-h:86px;
  }

  .mobile-stage{
    padding-top:6px;
    padding-bottom:5px;
  }

  .stage-visual{
    height:clamp(118px,22svh,170px);
  }

  .stage-visual img{
    width:clamp(104px,36vw,155px);
    height:clamp(104px,36vw,155px);
    max-height:calc(22svh - 12px);
  }

  .stage-meta small{
    display:none;
  }

  .song-card{
    min-height:62px;
  }

  .song-card img{
    width:46px;
    height:46px;
  }

  .song-card .like{
    width:24px;
    height:24px;
    font-size:.78rem;
  }
}

@keyframes eq{
  0%,100%{
    height:18%;
  }

  25%{
    height:78%;
  }

  50%{
    height:38%;
  }

  75%{
    height:92%;
  }
}

[data-density="compact"] .song-card{
  min-height:84px;
  padding:9px;
}

.stage-visual { position: relative; }
.stage-visual::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 10; /* Passe par dessus l'iframe */
    background: transparent;
}