/* Crowd Hits – bereinigte konsolidierte Styles
   Generiert aus der bisherigen style.css.
   Ziel: gleiche Selektoren zusammenführen, Patch-Ballast reduzieren, finale Kaskade erhalten. */

:root {
  --bg: #050509;
  --panel: rgba(14, 14, 24, 0.86);
  --panel-strong: rgba(18, 18, 31, 0.96);
  --text: #f7f3ff;
  --muted: rgba(247, 243, 255, 0.68);
  --line: rgba(255, 255, 255, 0.14);
  --accent: #F98948;
  --accent-2: #ff3df2;
  --danger: #ff5468;
  --ok: #5dffb3;
  --shadow: 0 30px 90px rgba(0, 0, 0, 0.45);
  --radius-xl: 20px;
  --radius-lg: 20px;
  --radius-md: 20px;
  --content-max: 920px;
}

* {
  box-sizing: border-box;
}

html {
  min-height: 100%;
  background: var(--bg);
}

body {
  margin: 0;
  min-height: 100svh;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--text);
  background: radial-gradient(circle at 20% 10%, rgba(255, 61, 242, 0.24), transparent 34rem),
    radial-gradient(circle at 90% 85%, rgba(246, 255, 0, 0.16), transparent 32rem),
    linear-gradient(135deg, #050509 0%, #111122 48%, #090910 100%);
}

button, input, textarea {
  font: inherit;
}

button {
  cursor: pointer;
}

.hidden {
  display: none !important;
}

.home-separator {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 18px;
    margin: 22px 0;
    opacity: .5;
    font-size: 15px;
    font-weight: 600;
}

.home-separator::before,
.home-separator::after {
    content: "";
    flex: 1;
    max-width: 140px;
    height: 1px;
    background: rgba(255,255,255,.25);
}

.visitor-body {
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-tap-highlight-color: transparent;
  background: radial-gradient(circle at 20% 20%, rgba(255, 0, 160, 0.14), transparent 34%),
        radial-gradient(circle at 80% 80%, rgba(0, 210, 255, 0.12), transparent 36%),
        linear-gradient(135deg, #070711 0%, #160826 44%, #05050b 100%);
}

.visitor-body.form-mode:not(.success-mode) {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100dvh;
  min-height: 100dvh;
  overflow: hidden;
  overscroll-behavior: none;
}

.visitor-body.success-mode {
  height: auto;
  overflow-x: hidden;
  overflow-y: auto;
}

.visitor-shell {
  position: relative;
  min-height: 100svh;
  overflow: visible;
}

.ambient {
  position: fixed;
  width: 42vw;
  height: 42vw;
  max-width: 560px;
  max-height: 560px;
  border-radius: 999px;
  filter: blur(52px);
  opacity: 0.32;
  pointer-events: none;
  z-index: 0;
}

.ambient-a {
  top: -14vw;
  left: -10vw;
  background: var(--accent-2);
}

.ambient-b {
  right: -16vw;
  bottom: -14vw;
  background: var(--accent);
}

.home-screen,
.form-screen {
  position: relative;
  z-index: 1;
  min-height: 100svh;
  width: 100%;
}

.home-screen {
  display: grid;
  place-items: center;
  padding: clamp(22px, 4.2vw, 46px);
}

.home-card {
  width: min(100%, 760px);
  text-align: center;
  padding: clamp(46px, 5vw, 72px) clamp(34px, 4.8vw, 64px);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  background: linear-gradient(145deg, rgba(255,255,255,0.11), rgba(255,255,255,0.035));
  box-shadow: var(--shadow);
  backdrop-filter: blur(18px);
  display: flex;
  flex-direction: column;
  align-items: center;
  min-height: 0 !important;
  justify-content: center;
  gap: clamp(20px, 2.2vw, 26px);
}

.home-card h1 {
  margin: 12px 0 20px;
  font-size: clamp(4.1rem, 13vw, 9.6rem);
  line-height: 0.86;
  letter-spacing: -0.08em;
  font-weight: 900;
  text-transform: uppercase;
}

.home-card p {
  max-width: 680px;
  margin: 0 auto 34px;
  color: var(--muted);
  font-size: clamp(1.1rem, 2.1vw, 1.45rem);
  line-height: 1.45;
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--accent);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.form-screen {
  display: block;
  padding: clamp(12px, 2.4vw, 24px);
  padding-top: calc(env(safe-area-inset-top, 0px) + clamp(10px, 2vw, 20px));
}

.visitor-body.form-mode:not(.success-mode) .form-screen {
  position: fixed;
  inset: 0;
  min-height: 0;
  height: 100dvh;
  overflow: hidden;
  padding: 0;
}

.step-indicator {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  padding: 0;
}

.dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: rgba(255,255,255,0.22);
}

.dot.active {
  background: var(--accent);
  box-shadow: 0 0 18px rgba(246,255,0,0.55);
}

.flow-message {
  position: fixed;
  top: calc(env(safe-area-inset-top, 0px) + 0.8rem);
  left: 50%;
  transform: translateX(-50%);
  z-index: 99999;
  width: auto;
  max-width: min(390px, calc(100vw - 2rem));
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.65rem;
  padding: 0.65rem 0.75rem 0.65rem 1rem;
  border-radius: 999px;
  background: rgba(18, 8, 24, 0.92);
  border: 1px solid rgba(255, 95, 135, 0.55);
  color: #ff6b8a;
  font-size: 0.86rem;
  font-weight: 800;
  line-height: 1.15;
  text-align: center;
  box-shadow: 0 18px 45px rgba(0, 0, 0, 0.42);
  backdrop-filter: blur(18px);
}

.flow-message.success {
  border-color: rgba(145, 255, 100, 0.55);
  color: #9cff66;
}

.flow-message.info {
  border-color: rgba(255, 255, 255, 0.25);
  color: #ffffff;
}

.flow-message.hidden {
  display: none !important;
}

.flow-message-text {
  display: inline-block;
  max-width: 310px;
  white-space: normal;
}

.flow-message-close {
  width: 26px;
  height: 26px;
  min-width: 26px;
  border: 0;
  border-radius: 999px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
  font-size: 1.05rem;
  font-weight: 900;
  line-height: 1;
  cursor: pointer;
}

.flow-message-close:active {
  transform: scale(0.94);
}

.slide-form {
  width: min(100%, var(--content-max));
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.visitor-body.form-mode:not(.success-mode) .slide-form {
  width: 100%;
  max-width: none;
  height: 100dvh;
  margin: 0;
  display: block;
}

.nav-bar {
  position: fixed;
  top: calc(env(safe-area-inset-top, 0px) + clamp(10px, 2vw, 18px));
  left: 50%;
  transform: translate3d(-50%, 0, 0);
  z-index: 950;
  display: grid;
  grid-template-columns: minmax(104px, 1fr) auto minmax(130px, 1fr);
  align-items: center;
  gap: 14px;
  width: min(calc(100% - clamp(24px, 4.8vw, 48px)), var(--content-max));
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: linear-gradient(145deg, rgba(18,18,31,0.84), rgba(12,12,22,0.66));
  box-shadow: 0 18px 44px rgba(0,0,0,0.28);
  -webkit-backdrop-filter: blur(18px);
  backdrop-filter: blur(18px);
  isolation: isolate;
  will-change: transform;
  -webkit-transform: translate3d(-50%, 0, 0);
}

.nav-bar .step-indicator {
  justify-self: center;
}

.nav-bar .flow-actions-left {
  justify-self: start;
}

.nav-bar #nextBtn {
  justify-self: end;
}

.flow-actions {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.icon-nav-button {
  width: 46px;
  min-width: 46px;
  height: 46px;
  padding: 0 !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.45rem;
  line-height: 1;
}

.nav-button,
.primary-button,
.secondary-button,
.status-btn,
.copy-btn {
  appearance: none;
  border: 0;
  border-radius: 999px;
  font-weight: 900;
  text-decoration: none;
  transition: transform .12s ease, opacity .12s ease, background .12s ease;
}

.nav-button,
.primary-button {
  background: var(--accent);
  color: #07070a;
  padding: 16px 24px;
  box-shadow: 0 14px 34px rgba(246,255,0,0.18);
}

.nav-button.submit-nav {
  min-width: 190px;
  background: #97DB4F;
}

.nav-button.ghost,
.secondary-button,
.copy-btn {
  background: rgba(255,255,255,0.1);
  color: var(--text);
  border: 1px solid var(--line);
  padding: 14px 20px;
}

button:disabled {
  opacity: .36;
  cursor: default;
}

button:not(:disabled):active {
  transform: scale(0.98);
}

.home-cta {
  font-size: clamp(1.05rem, 2vw, 1.35rem);
  padding: 22px 34px;
}

.reset-btn {
  min-width: 0;
  height: 42px;
  padding: 0 0.95rem;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  font-size: 0.9rem;
  line-height: 1;
  white-space: nowrap;
  background: rgba(255, 255, 255, 0.1);
  color: var(--text);
  border: 1px solid var(--line);
}

.reset-icon {
  font-size: 1.15rem;
  line-height: 1;
}

.slides {
  display: block;
  margin-top: 92px;
}

.visitor-body.form-mode:not(.success-mode) .slides {
  width: 100%;
  height: 100dvh;
  margin-top: 0;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  padding: calc(env(safe-area-inset-top, 0px) + 104px) clamp(12px, 2.4vw, 24px) calc(34px + env(safe-area-inset-bottom, 0px));
  scroll-padding-top: calc(env(safe-area-inset-top, 0px) + 104px);
}

.slide {
  display: none;
}

.slide.active {
  display: block;
}

.single-input-step.active {
  align-items: start;
}

.card {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  background: var(--panel);
  box-shadow: var(--shadow);
  backdrop-filter: blur(18px);
  padding: clamp(40px, 3.2vw, 36px);
}

.card-center {
  text-align: center;
}

.card-scrollable {
  max-height: none;
  overflow: visible;
  padding-bottom: clamp(30px, 5vw, 58px);
}

.card h2 {
  margin: 8px 0 18px;
  font-size: clamp(2rem, 5vw, 3.8rem);
  line-height: .94;
  letter-spacing: -0.06em;
  font-weight: 900;
}

.microcopy {
  margin: -8px 0 22px;
  color: var(--muted);
  font-size: clamp(1rem, 1.8vw, 1.18rem);
  line-height: 1.45;
}

.field-hint {
  color: var(--muted);
  font-size: 0.78em;
  font-weight: 800;
  margin-left: 6px;
}

.field-label {
  display: block;
  margin: 18px 0 8px;
  color: rgba(255,255,255,0.78);
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.text-input {
  width: 100%;
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: var(--radius-lg);
  background: rgba(255,255,255,0.08);
  color: var(--text);
  outline: none;
  padding: 20px 22px;
  font-size: 1.15rem;
}

.text-input:focus {
  border-color: rgba(246,255,0,.65);
  box-shadow: 0 0 0 4px rgba(246,255,0,.1);
}

.giant-input {
  text-align: center;
  font-size: clamp(1.8rem, 5.2vw, 3.8rem);
  font-weight: 900;
  letter-spacing: -0.05em;
  padding: clamp(18px, 3vw, 28px);
}

.textarea-input {
  resize: vertical;
  min-height: 104px;
  line-height: 1.35;
}

.textarea-large {
  min-height: 132px;
}

.textarea-medium {
  min-height: 110px;
}

.tall-style-input {
  min-height: 118px;
}

.optional-stack {
  margin-top: 14px;
}

.optional-panel {
  margin-top: 12px;
}

.pill-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.compact-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 10px;
}

.choice-chip {
  min-height: 52px;
  border: 1px solid rgba(255,255,255,0.16);
  border-radius: 20px;
  background: rgba(255,255,255,0.08);
  color: var(--text);
  padding: 12px 14px;
  font-weight: 900;
  text-align: center;
}

.choice-chip.active {
  color: #08080a;
  background: var(--accent);
  border-color: var(--accent);
}

.options-grid-2 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin-top: 14px;
}

.compact-top {
  margin-top: 18px;
}

.submit-message {
  min-height: 24px;
  margin: 22px 0 12px;
  font-weight: 800;
}

.submit-message.error {
  color: var(--danger);
}

.submit-message.success {
  color: var(--ok);
}

.submit-inline {
  width: 100%;
  font-size: clamp(1.15rem, 2vw, 1.45rem);
  padding: 22px 26px;
}

.success-screen {
  min-height: 0;
  display: block;
  text-align: center;
  padding: clamp(18px, 4vw, 42px) 0;
}

.success-screen h2 {
  max-width: 780px;
  margin: 0 auto 18px;
}

.success-screen p {
  color: var(--muted);
  margin: 0 auto 22px;
  font-size: 1.1rem;
  max-width: 680px;
}

.visitor-body.success-mode .form-screen {
  position: relative;
  inset: auto;
  overflow: visible;
  min-height: 100svh;
  display: grid;
  place-items: center;
  padding: clamp(18px, 3vw, 34px);
}

.visitor-body.success-mode .flow-message {
  display: none;
}

.visitor-body.success-mode .slide-form {
  width: min(100%, var(--content-max));
  margin: 0 auto;
}

.visitor-body.success-mode .slides {
  margin-top: 0;
  width: 100%;
  height: auto;
  overflow: visible;
  padding-bottom: 0;
}

.visitor-body.success-mode .slide.active {
  display: grid;
  place-items: center;
  min-height: calc(100svh - clamp(36px, 6vw, 68px));
}

.visitor-body.success-mode .success-card {
  max-width: 920px;
  margin: 0 auto;
}

.visitor-body.success-mode .success-screen {
  padding: clamp(34px, 6vw, 78px) clamp(18px, 3vw, 36px);
}

.idle-prompt-overlay {
  position: fixed;
  inset: 0;
  z-index: 1100;
  display: grid;
  place-items: center;
  padding: 22px;
  background: rgba(0,0,0,.68);
  backdrop-filter: blur(12px);
}

.idle-prompt-card {
  width: min(100%, 520px);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  background: var(--panel-strong);
  box-shadow: var(--shadow);
  padding: clamp(28px, 5vw, 48px);
  text-align: center;
}

.idle-prompt-card h3 {
  margin: 0 0 12px;
  font-size: clamp(2.2rem, 7vw, 4.6rem);
  line-height: .9;
  letter-spacing: -0.06em;
  font-weight: 900;
  text-transform: uppercase;
}

.idle-prompt-card p {
  margin: 0 auto 24px;
  max-width: 420px;
  color: var(--muted);
  font-size: 1.08rem;
  line-height: 1.4;
}

.idle-prompt-actions {
  display: flex;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
}

.loading-overlay {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: grid;
  place-items: center;
  padding: 22px;
  background: rgba(0,0,0,.72);
  backdrop-filter: blur(10px);
}

.loading-card {
  width: min(100%, 420px);
  position: relative;
  overflow: hidden;
  padding: 36px;
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  background: var(--panel-strong);
  text-align: center;
  box-shadow: var(--shadow);
}

.loading-card h3 {
  margin: 16px 0 6px;
  font-size: 1.45rem;
}

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

.loading-spinner {
  width: 54px;
  height: 54px;
  margin: 0 auto;
  border: 5px solid rgba(255,255,255,.16);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: spin .8s linear infinite;
}

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

.admin-body {
  padding: 12px;
  overflow-x: hidden;
  padding-bottom: 92px !important;
}

.admin-shell {
  width: min(100%, 1600px);
  margin: 0 auto;
}

.admin-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
  margin-bottom: 12px;
}

.admin-header h1 {
  margin: 6px 0 0;
  font-size: clamp(1.8rem, 2.6vw, 3.1rem);
  letter-spacing: -0.06em;
}

.admin-link {
  color: var(--accent);
  font-weight: 900;
  text-decoration: none;
}

.admin-table-wrap {
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: 0 !important;
  background: rgba(255,255,255,0.04);
  overflow-x: hidden !important;
  width: 100% !important;
  display: block !important;
  max-width: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.admin-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 720px;
}

.admin-table th,
.admin-table td {
  padding: 8px 10px;
  border-bottom: 1px solid rgba(255,255,255,0.09);
  text-align: left;
  vertical-align: top;
}

.admin-table th {
  color: var(--muted);
  font-size: .62rem;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.admin-row {
  cursor: pointer;
  background: rgba(255,255,255,.02);
  --row-progress: 0%;
  height: 80px !important;
  max-height: 80px !important;
  position: relative;
}

.admin-row:hover,
.admin-row.expanded {
  background: rgba(246,255,0,.07);
}

.status-pill {
  display: inline-flex;
  border-radius: 999px;
  padding: 6px 10px;
  background: rgba(255,255,255,.1);
  font-weight: 900;
  font-size: .78rem;
}

.status-approved .status-pill {
  background: rgba(93,255,179,.18);
  color: var(--ok);
}

.status-rejected .status-pill {
  background: rgba(255,84,104,.18);
  color: var(--danger);
}

.status-played .status-pill {
  background: rgba(246,255,0,.18);
  color: var(--accent);
}

.admin-mini-meta {
  color: var(--muted);
  font-size: .85rem;
  margin-top: 4px;
}

.admin-details-row td {
  background: rgba(0,0,0,.23);
}

.admin-expand-card {
  padding: 10px;
}

.admin-expand-head {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 12px;
  align-items: center;
}

.admin-expand-head h3 {
  margin: 0;
  font-size: .95rem;
}

.admin-expand-head p {
  margin: 2px 0 0;
  color: var(--muted);
  font-size: .72rem;
  opacity: .7;
}

.admin-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  align-items: center;
}

.admin-actions-inline {
  justify-content: flex-end;
  gap: 5px;
  flex-wrap: wrap;
}

.admin-actions-spacing {
  margin: 8px 0 12px;
}

.status-btn {
  padding: 10px 14px;
  background: var(--accent);
  color: #07070a;
}

.status-btn.danger {
  background: var(--danger);
  color: #fff;
}

.cover-btn {
  background: var(--accent-2);
  color: #fff;
}

.admin-prompt {
  width: 100%;
  min-height: 260px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: rgba(0,0,0,.28);
  color: var(--text);
  padding: 16px;
  resize: vertical;
  line-height: 1.45;
}

.admin-prompt-small {
  min-height: 110px;
}

.admin-grid-meta {
  display: grid;
  gap: 8px;
  margin-bottom: 12px;
}

.admin-grid-meta-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.meta-box {
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 7px;
  background: rgba(255,255,255,.05);
}

.meta-box span {
  display: block;
  color: var(--muted);
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .12em;
}

.meta-box strong {
  display: block;
  margin-top: 5px;
}

.cover-card {
  display: grid;
  grid-template-columns: minmax(82px, 116px) minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  margin-bottom: 12px;
}

.cover-preview-wrap {
  aspect-ratio: 1;
  border: 1px solid var(--line);
  border-radius: 18px;
  overflow: hidden;
  background: rgba(255,255,255,.06);
  display: grid;
  place-items: center;
  width: 90px;
  min-width: 90px;
}

.cover-preview-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.cover-preview-placeholder {
  color: var(--muted);
  text-align: center;
  padding: 20px;
}

.cover-side {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.cover-help {
  color: var(--muted);
  line-height: 1.45;
  max-width: 680px;
  margin: 0 0 6px;
  font-size: .86rem;
}

.cover-state {
  margin: 6px 0 0;
  padding: 8px 10px;
  border-radius: 14px;
  background: rgba(255,255,255,.07);
  color: var(--muted);
  font-size: .84rem;
}

.cover-state.failed {
  background: rgba(255,84,104,.14);
  color: #ffd5db;
}

.cover-state.generated {
  background: rgba(93,255,179,.12);
  color: #c9ffe5;
}

.admin-raw-details {
  border-top: 1px solid var(--line);
  padding-top: 10px;
  margin-top: 10px;
}

.admin-raw-details summary {
  cursor: pointer;
  color: var(--accent);
  font-weight: 900;
  font-size: .74rem;
}

.snippet {
  margin: 12px 0;
  color: var(--muted);
  line-height: 1.5;
}

@media (max-width: 820px) {
  .home-card {
    padding: 32px 22px;
  }

  .form-screen {
    padding: 12px;
    padding-top: calc(env(safe-area-inset-top, 0px) + 10px);
  }

  .nav-bar {
    grid-template-columns: minmax(96px, 1fr) auto minmax(96px, 1fr);
    gap: 8px;
    padding: 10px;
    border-radius: 20px;
  }

  .nav-button {
    padding: 14px 16px;
  }

  .icon-nav-button {
    width: 42px;
    min-width: 42px;
    height: 42px;
    font-size: 1.32rem;
  }

  .flow-actions {
    gap: 6px;
  }

  .slides {
    margin-top: 84px;
  }

  .visitor-body.form-mode:not(.success-mode) .slides {
    height: 100dvh;
    margin-top: 0;
    padding-top: calc(env(safe-area-inset-top, 0px) + 96px);
    scroll-padding-top: calc(env(safe-area-inset-top, 0px) + 96px);
  }

  .card-scrollable {
    max-height: none;
    overflow: visible;
  }

  .card-center {
    min-height: 0;
  }

  .options-grid-2,
  .admin-grid-meta-4,
  .cover-card,
  .admin-expand-head {
    grid-template-columns: 1fr;
    display: grid;
  }

  .giant-input {
    font-size: clamp(1.7rem, 10vw, 3.4rem);
  }

  .compact-grid {
    grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  }

  .admin-body {
    padding: 14px;
  }
}

.live-body {
  min-height: 100dvh;
  overflow: hidden;
  background: #040407;
}

.live-screen {
  position: relative;
  width: 100vw;
  height: 100dvh;
  overflow: hidden;
  display: grid;
  place-items: center;
  padding: clamp(28px, 5vw, 76px);
  isolation: isolate;
  background: radial-gradient(circle at 20% 20%, rgba(255, 0, 160, 0.20), transparent 32%),
        radial-gradient(circle at 80% 80%, rgba(0, 210, 255, 0.18), transparent 34%),
        linear-gradient(135deg, #070711 0%, #160826 44%, #05050b 100%);
  background-size: 140% 140%;
  animation: aiClubBgBreath 11s ease-in-out infinite alternate;
  overflow-x: hidden;
}

.live-orb {
  position: fixed;
  width: 44vw;
  height: 44vw;
  border-radius: 999px;
  filter: blur(68px);
  opacity: .42;
  z-index: -2;
  animation: liveFloat 13s ease-in-out infinite alternate;
}

.live-orb-a {
  left: -12vw;
  top: -14vw;
  background: var(--accent-2);
}

.live-orb-b {
  right: -12vw;
  bottom: -14vw;
  background: var(--accent);
  animation-delay: -4s;
}

.live-noise {
  position: fixed;
  inset: 0;
  opacity: .11;
  pointer-events: none;
  z-index: -1;
  background-image: linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size: 42px 42px;
  animation: liveGrid 12s linear infinite;
}

.live-idle,
.live-active {
  width: min(100%, 1500px);
  min-height: min(74vh, 820px);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: clamp(24px, 3vw, 44px);
  background: linear-gradient(145deg, rgba(255,255,255,.12), rgba(255,255,255,.035));
  box-shadow: 0 38px 110px rgba(0,0,0,.55);
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
}

.live-idle {
  display: grid;
  place-items: center;
  text-align: center;
  padding: clamp(34px, 7vw, 110px);
}

.live-brand {
  color: var(--accent);
  font-weight: 950;
  letter-spacing: .28em;
  text-transform: uppercase;
  margin-bottom: clamp(20px, 3vw, 42px);
}

.live-idle h1 {
  margin: 0;
  max-width: 1100px;
  font-size: clamp(3.6rem, 9vw, 9.4rem);
  line-height: .88;
  letter-spacing: -.08em;
  text-transform: uppercase;
}

.live-idle p {
  margin: clamp(24px, 3vw, 40px) 0 0;
  color: var(--muted);
  font-size: clamp(1.2rem, 2vw, 2rem);
}

.live-pulse {
  display: flex;
  gap: 12px;
  justify-content: center;
  margin-top: clamp(32px, 4vw, 56px);
}

.live-pulse span {
  width: 14px;
  height: 14px;
  border-radius: 999px;
  background: var(--accent);
  animation: livePulse 1.2s ease-in-out infinite;
}

.live-pulse span:nth-child(2) {
  animation-delay: .16s;
}

.live-pulse span:nth-child(3) {
  animation-delay: .32s;
}

.live-active {
  display: grid;
  grid-template-columns: minmax(320px, 44%) 1fr;
  gap: clamp(28px, 5vw, 84px);
  align-items: center;
  padding: clamp(26px, 4vw, 68px);
}

.live-cover-frame {
  aspect-ratio: 1;
  width: 100%;
  border-radius: clamp(22px, 3vw, 40px);
  border: 1px solid rgba(255,255,255,.18);
  overflow: hidden;
  background: rgba(255,255,255,.07);
  box-shadow: 0 28px 80px rgba(0,0,0,.45);
  transform: rotate(-1.2deg);
  animation: liveCoverDrift 8s ease-in-out infinite alternate;
}

.live-cover-img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.live-cover-placeholder {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  padding: 28px;
  text-align: center;
  color: var(--muted);
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: clamp(1.6rem, 3vw, 3rem);
  background: radial-gradient(circle at 30% 25%, rgba(255,61,242,.36), transparent 45%),
    radial-gradient(circle at 70% 75%, rgba(249,137,72,.34), transparent 42%),
    #0b0b14;
}

.live-track-info {
  min-width: 0;
}

.live-kicker {
  display: inline-flex;
  margin-bottom: clamp(18px, 3vw, 36px);
  padding: 12px 18px;
  border-radius: 999px;
  background: var(--accent);
  color: #07070a;
  font-weight: 950;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.live-track-info h1 {
  margin: 0;
  font-size: clamp(4rem, 8vw, 10rem);
  line-height: .86;
  letter-spacing: -.08em;
  text-transform: uppercase;
  overflow-wrap: anywhere;
}

.live-track-info h2 {
  margin: clamp(18px, 2vw, 32px) 0 0;
  font-size: clamp(1.8rem, 3.4vw, 4.4rem);
  line-height: 1;
  color: var(--accent-2);
  overflow-wrap: anywhere;
}

.live-track-info p {
  margin: clamp(22px, 2.4vw, 34px) 0 0;
  color: var(--muted);
  font-size: clamp(1.1rem, 1.8vw, 1.7rem);
  font-weight: 800;
}

.admin-header-actions {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 8px !important;
}

.admin-live-state {
  margin: 0 0 12px;
  padding: 9px 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: rgba(255,255,255,.05);
  color: var(--muted);
  font-size: .78rem;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
}

.admin-live-state strong {
  color: var(--text);
}

.live-btn {
  appearance: none;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px;
  padding: 8px 10px;
  background: rgba(255,255,255,.08);
  color: #fff;
  font-weight: 900;
  cursor: pointer;
  white-space: nowrap;
  font-size: .72rem;
}

.live-btn-large {
  padding: 10px 16px;
}

.live-btn.is-live {
  box-shadow: 0 0 0 3px rgba(151,219,79,.24), 0 0 28px rgba(151,219,79,.24);
}

.live-clear-btn {
  cursor: pointer;
}

@keyframes liveFloat {
  from { transform: translate3d(0,0,0) scale(1); }
  to { transform: translate3d(4vw, -2vw, 0) scale(1.14); }
}

@keyframes liveGrid {
  from { transform: translate3d(0,0,0); }
  to { transform: translate3d(42px, 42px, 0); }
}

@keyframes livePulse {
  0%, 100% { transform: translateY(0); opacity: .35; }
  50% { transform: translateY(-12px); opacity: 1; }
}

@keyframes liveCoverDrift {
  from { transform: rotate(-1.2deg) translate3d(0,0,0); }
  to { transform: rotate(.8deg) translate3d(0,-10px,0); }
}

@media (max-width: 900px), (orientation: portrait) {
  .live-active {
    grid-template-columns: 1fr;
    min-height: 88vh;
    text-align: center;
  }

  .live-cover-frame {
    width: min(72vw, 520px);
    margin: 0 auto;
  }

  .live-track-info h1 {
    font-size: clamp(3rem, 12vw, 7rem);
  }
}

.visitor-body::before,
.visitor-body::after {
  content: none !important;
  display: none !important;
}

.live-screen::before,
.live-screen::after {
  content: "";
  position: fixed;
  inset: -35%;
  z-index: 0;
  pointer-events: none;
  opacity: 1;
  filter: blur(18px);
  transform: translateZ(0);
  will-change: transform, opacity;
}

.live-screen::before {
  background: radial-gradient(circle at 16% 26%, rgba(255, 255, 255, 0.28), transparent 20%),
        radial-gradient(circle at 68% 34%, rgba(255, 0, 160, 0.48), transparent 28%),
        radial-gradient(circle at 38% 78%, rgba(0, 210, 255, 0.42), transparent 26%),
        radial-gradient(circle at 84% 78%, rgba(255, 230, 0, 0.26), transparent 22%);
  animation: aiClubWaveOne 7s ease-in-out infinite alternate;
}

.live-screen::after {
  background: radial-gradient(circle at 82% 18%, rgba(255, 230, 0, 0.34), transparent 24%),
        radial-gradient(circle at 24% 72%, rgba(140, 80, 255, 0.48), transparent 30%),
        radial-gradient(circle at 62% 88%, rgba(255, 255, 255, 0.18), transparent 22%),
        radial-gradient(circle at 10% 86%, rgba(0, 255, 190, 0.34), transparent 26%);
  animation: aiClubWaveTwo 10s ease-in-out infinite alternate;
  mix-blend-mode: screen;
}

@keyframes aiClubBgBreath {
    0% {
        background-position: 0% 45%;
        filter: saturate(1);
    }

    100% {
        background-position: 100% 55%;
        filter: saturate(1.18);
    }
}

@keyframes aiClubWaveOne {
    0% {
        transform: translate3d(-8%, -5%, 0) scale(1) rotate(0deg);
        opacity: 0.78;
    }

    45% {
        transform: translate3d(7%, 4%, 0) scale(1.16) rotate(8deg);
        opacity: 1;
    }

    100% {
        transform: translate3d(-4%, 9%, 0) scale(1.28) rotate(-7deg);
        opacity: 0.88;
    }
}

@keyframes aiClubWaveTwo {
    0% {
        transform: translate3d(6%, 7%, 0) scale(1.06) rotate(4deg);
        opacity: 0.72;
    }

    50% {
        transform: translate3d(-10%, -5%, 0) scale(1.22) rotate(-9deg);
        opacity: 1;
    }

    100% {
        transform: translate3d(7%, -8%, 0) scale(1.10) rotate(7deg);
        opacity: 0.84;
    }
}

.visitor-shell,
.home-screen,
.form-screen,
.success-screen,
.idle-modal,
.live-screen .live-wrap,
.live-screen .live-stage,
.live-screen .live-idle,
.live-screen .live-active {
  position: relative;
  z-index: 2;
}

.card,
.nav-card,
.live-panel,
.live-cover-wrap {
  position: relative;
  z-index: 3;
}

@media (prefers-reduced-motion: reduce) {
  .live-screen,
    .live-screen::before,
    .live-screen::after,
    .live-vinyl-view.is-revealing .live-kicker,
    .live-vinyl-view.is-revealing .live-track-info h1,
    .live-vinyl-view.is-revealing .live-track-info h2,
    .live-vinyl-view.is-revealing .live-track-info p {
    animation: none !important;
  }
}

.live-active.live-vinyl-view {
  position: fixed;
  inset: 0;
  width: 100vw;
  height: 100dvh;
  min-height: 100dvh;
  max-width: none;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  display: grid;
  grid-template-columns: minmax(0, 58vw) minmax(360px, 42vw);
  align-items: stretch;
  gap: 0;
  padding: 0;
  overflow: hidden;
  z-index: 5;
}

.live-record-area {
  position: relative;
  min-width: 0;
  height: 100dvh;
  overflow: visible;
  z-index: 3;
}

.live-record {
  position: absolute;
  width: min(150vw, 180vh);
  aspect-ratio: 1 / 1;
  left: clamp(-500px, -500vw, -500px);
  top: 50%;
  border-radius: 50%;
  transform: translateY(-50%);
  --record-base-transform: translateY(-50%);
  animation: liveVinylSpin 18s linear infinite;
  background: radial-gradient(circle at 50% 50%, rgba(255,255,255,.16) 0 2.8%, transparent 3.2%),
        radial-gradient(circle at 50% 50%, rgba(255,255,255,.05) 0 18%, transparent 18.4%),
        repeating-radial-gradient(circle at 50% 50%,
            rgba(255,255,255,.09) 0px,
            rgba(255,255,255,.09) 1px,
            rgba(0,0,0,0) 2px,
            rgba(0,0,0,0) 7px),
        radial-gradient(circle at 33% 24%, rgba(255,255,255,.18), transparent 23%),
        radial-gradient(circle at 70% 82%, rgba(255,0,160,.14), transparent 24%),
        linear-gradient(135deg, #050508 0%, #141421 44%, #020203 100%);
  box-shadow: 0 0 0 1px rgba(255,255,255,.10),
        0 34px 120px rgba(0,0,0,.72),
        inset 0 0 0 18px rgba(255,255,255,.025),
        inset 0 0 110px rgba(255,255,255,.08);
}

.live-record.is-starting {
  animation: liveVinylStart 3.4s cubic-bezier(.10, .72, .18, 1) 1 both,
        liveVinylSpin 18s linear 3.4s infinite;
}

.live-record::before {
  content: "";
  position: absolute;
  inset: 6%;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.035),
        inset 0 0 0 8px rgba(0,0,0,.14),
        inset 0 0 0 16px rgba(255,255,255,.025),
        inset 0 0 0 26px rgba(0,0,0,.16);
  pointer-events: none;
}

.live-record::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: conic-gradient(from 18deg,
            rgba(255,255,255,.00),
            rgba(255,255,255,.16),
            rgba(255,255,255,.00) 14%,
            rgba(255,255,255,.00) 52%,
            rgba(255,255,255,.10),
            rgba(255,255,255,.00) 64%,
            rgba(255,255,255,.00));
  mix-blend-mode: screen;
  opacity: .38;
  pointer-events: none;
}

.live-record-rings {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: repeating-radial-gradient(circle at center,
            transparent 0,
            transparent 12px,
            rgba(255,255,255,.045) 13px,
            transparent 15px);
  opacity: .58;
  pointer-events: none;
}

.live-record .live-cover-frame,
.live-record .live-record-label {
  position: absolute;
  width: 43%;
  aspect-ratio: 1 / 1;
  left: 50%;
  top: 50%;
  margin: 0;
  border-radius: 50%;
  overflow: hidden;
  border: 8px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.08);
  box-shadow: 0 0 0 1px rgba(0,0,0,.72),
        0 20px 60px rgba(0,0,0,.42),
        inset 0 0 24px rgba(255,255,255,.10);
  transform: translate(-50%, -50%);
  animation: none;
  z-index: 4;
}

.live-record .live-cover-img,
.live-record .live-cover-placeholder {
  width: 100%;
  height: 100%;
  display: block;
  border-radius: 50%;
  object-fit: cover;
}

.live-record .live-cover-placeholder {
  display: grid;
  place-items: center;
  padding: 8%;
  font-size: clamp(1.1rem, 2.8vw, 2.8rem);
  line-height: 1;
}

.live-vinyl-view .live-track-info {
  position: relative;
  z-index: 9;
  min-width: 0;
  height: 100dvh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  padding: clamp(54px, 6vw, 120px)
        clamp(58px, 6vw, 128px)
        clamp(54px, 6vw, 120px)
        0;
  margin-left: -9vw;
  width: calc(100% + 9vw);
  text-shadow: 0 8px 40px rgba(0,0,0,.78);
  pointer-events: none;
}

.live-vinyl-view .live-kicker,
.live-vinyl-view .live-track-info h1,
.live-vinyl-view .live-track-info h2,
.live-vinyl-view .live-track-info p {
  pointer-events: auto;
}

.live-vinyl-view .live-kicker {
  margin-bottom: clamp(18px, 3vw, 38px);
  box-shadow: 0 12px 38px rgba(151,219,79,.18);
}

.live-vinyl-view .live-track-info h1 {
  font-size: clamp(4.4rem, 8.8vw, 12rem);
  line-height: .82;
  letter-spacing: -.085em;
  max-width: 8.2em;
}

.live-vinyl-view .live-track-info h2 {
  font-size: clamp(1.8rem, 3.8vw, 5rem);
  max-width: 13em;
}

.live-vinyl-view .live-track-info p {
  max-width: 44rem;
}

.live-vinyl-view.is-revealing .live-kicker,
.live-vinyl-view.is-revealing .live-track-info h1,
.live-vinyl-view.is-revealing .live-track-info h2,
.live-vinyl-view.is-revealing .live-track-info p {
  animation: liveTextReveal .76s cubic-bezier(.16, .82, .22, 1) both;
}

.live-vinyl-view.is-revealing .live-kicker {
  animation-delay: .10s;
}

.live-vinyl-view.is-revealing .live-track-info h1 {
  animation-delay: .24s;
}

.live-vinyl-view.is-revealing .live-track-info h2 {
  animation-delay: .42s;
}

.live-vinyl-view.is-revealing .live-track-info p {
  animation-delay: .58s;
}

@keyframes liveTextReveal {
    0% {
        opacity: 0;
        transform: translate3d(0, 26px, 0) scale(.985);
        filter: blur(10px);
    }

    70% {
        opacity: 1;
        filter: blur(0);
    }

    100% {
        opacity: 1;
        transform: translate3d(0, 0, 0) scale(1);
        filter: blur(0);
    }
}

@keyframes liveVinylStart {
    from {
        transform: var(--record-base-transform) rotate(0deg);
    }

    to {
        transform: var(--record-base-transform) rotate(-1080deg);
    }
}

@keyframes liveVinylSpin {
    from {
        transform: var(--record-base-transform) rotate(0deg);
    }

    to {
        transform: var(--record-base-transform) rotate(360deg);
    }
}

@media (max-width: 900px), (orientation: portrait) {
  .live-active.live-vinyl-view {
    position: fixed;
    inset: 0;
    grid-template-columns: 1fr;
    grid-template-rows: 58dvh 42dvh;
    text-align: center;
  }

  .live-record-area {
    height: 58dvh;
  }

  .live-record {
    width: min(122vw, 82vh);
    left: 50%;
    top: 52%;
    transform: translate(-50%, -50%);
    --record-base-transform: translate(-50%, -50%);
  }

  .live-vinyl-view .live-track-info {
    height: auto;
    width: 100%;
    margin-left: 0;
    align-items: center;
    justify-content: flex-start;
    padding: 0 clamp(28px, 7vw, 64px) clamp(34px, 6vw, 60px);
    text-align: center;
  }

  .live-vinyl-view .live-track-info h1 {
    font-size: clamp(2.8rem, 12vw, 7rem);
  }
}

.admin-session-panel {
  margin: -2px 0 12px;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 22px;
  background: linear-gradient(145deg, rgba(255,255,255,.095), rgba(255,255,255,.035));
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: center;
}

.admin-session-main h2 {
  margin: 6px 0 4px;
  font-size: clamp(1.05rem, 1.5vw, 1.55rem);
  letter-spacing: -.04em;
}

.admin-session-main p {
  margin: 0;
  color: var(--muted);
  font-weight: 800;
}

.admin-session-controls {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.admin-session-controls label {
  color: var(--muted);
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.session-select {
  min-width: min(280px, 32vw);
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(0,0,0,.32);
  color: var(--text);
  padding: 6px 10px;
  font-weight: 800;
  min-height: 32px;
  font-size: .78rem;
}

.admin-live-session {
  display: block !important;
  margin-left: 0 !important;
  color: var(--muted);
  font-size: .76rem !important;
  opacity: .78 !important;
}

.vote-count-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 30px;
  padding: 4px 7px;
  border-radius: 999px;
  background: rgba(255,255,255,.1);
  font-weight: 950;
  font-size: .72rem;
}

.admin-empty-state {
  padding: 24px !important;
  text-align: center;
  color: var(--muted);
  font-weight: 800;
}

.admin-grid-meta-5 {
  grid-template-columns: repeat(5, minmax(0,1fr));
}

.live-vote-box {
  margin-top: clamp(24px, 3vw, 44px);
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 12px;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.22) !important;
  background: rgba(0,0,0,.32);
  box-shadow: 0 18px 50px rgba(0,0,0,.25);
  overflow: hidden !important;
}

.live-vote-copy {
  display: grid;
  gap: 3px;
  text-align: right;
}

.live-vote-copy span {
  color: var(--muted);
  font-size: clamp(.72rem, .9vw, .9rem);
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.live-vote-copy strong {
  color: var(--text);
  font-size: clamp(.96rem, 1.15vw, 1.25rem);
  line-height: 1;
  text-transform: uppercase;
}

.live-vote-qr {
  width: clamp(148px, 12vw, 220px);
  height: clamp(148px, 12vw, 220px);
  border-radius: 20px;
  background: #fff;
  padding: 10px;
}

.vote-body {
  min-height: 100dvh;
  background: radial-gradient(circle at 20% 10%, rgba(255,61,242,.28), transparent 32rem),
    radial-gradient(circle at 80% 90%, rgba(249,137,72,.24), transparent 30rem),
    #050509;
}

.vote-shell {
  min-height: 100dvh;
  display: grid;
  place-items: center;
  padding: clamp(18px, 5vw, 54px);
}

.vote-card {
  width: min(100%, 560px);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  background: linear-gradient(145deg, rgba(255,255,255,.12), rgba(255,255,255,.04));
  box-shadow: var(--shadow);
  backdrop-filter: blur(20px);
  padding: clamp(28px, 7vw, 56px);
  text-align: center;
}

.vote-cover-wrap {
  width: min(58vw, 240px);
  aspect-ratio: 1 / 1;
  margin: 4px auto 22px;
  border-radius: 28px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.18);
  box-shadow: 0 24px 70px rgba(0,0,0,.35);
  background: rgba(255,255,255,.06);
}

.vote-cover-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.vote-card h1 {
  margin: 14px 0 8px;
  font-size: clamp(2.6rem, 12vw, 5.3rem);
  line-height: .88;
  letter-spacing: -.08em;
  text-transform: uppercase;
  overflow-wrap: anywhere;
}

.vote-card h2 {
  margin: 0;
  color: var(--accent-2);
  font-size: clamp(1.4rem, 6vw, 2.35rem);
  line-height: 1;
  overflow-wrap: anywhere;
}

.vote-copy {
  margin: 24px auto 0;
  color: var(--muted);
  line-height: 1.5;
  font-size: 1.05rem;
}

.vote-message {
  margin: 24px 0 0;
  padding: 14px 16px;
  border-radius: 18px;
  font-weight: 900;
  background: rgba(255,255,255,.08);
}

.vote-message.success {
  color: #c9ffe5;
  background: rgba(93,255,179,.14);
}

.vote-message.error {
  color: #ffd5db;
  background: rgba(255,84,104,.14);
}

.vote-message.info {
  color: var(--text);
  background: rgba(255,255,255,.08);
}

.vote-form {
  margin-top: 26px;
}

.vote-submit {
  width: 100%;
  justify-content: center;
}

.vote-thanks {
  margin: 18px 0 0;
  color: var(--muted);
  font-size: .95rem;
}

@media (max-width: 820px) {
  .admin-session-panel {
    display: grid;
  }

  .admin-session-controls {
    justify-content: stretch;
  }

  .session-select {
    min-width: 0;
    width: 100%;
  }

  .admin-grid-meta-5 {
    grid-template-columns: 1fr;
  }

  .live-vote-box {
    align-self: flex-start;
  }
}

@media (max-width: 980px) {
  .live-vote-box {
    margin-top: 18px;
  }

  .live-vote-copy {
    text-align: left;
  }
}

.admin-refresh-indicator {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: 10px;
  padding: 3px 8px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  color: rgba(255, 255, 255, 0.62);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transition: color 180ms ease, border-color 180ms ease, background 180ms ease;
}

.admin-refresh-indicator.is-fresh {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.55);
  background: rgba(255, 255, 255, 0.12);
}

.admin-shell.admin-shell-wide {
  width: 100%;
  max-width: none;
  padding: 10px;
  margin-left: 0;
  margin-right: 0;
}

.status-btn,
.live-btn,
.copy-btn {
  padding: 8px 11px;
  font-size: .88rem;
}

.admin-collapse-block {
  margin: 0 0 10px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(255,255,255,.035);
  overflow: hidden;
}

.admin-collapse-block summary {
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 8px 11px;
  color: var(--text);
  font-weight: 950;
  min-height: 38px;
}

.admin-collapse-block summary::-webkit-details-marker {
  display: none;
}

.admin-collapse-block summary::before {
  content: "â–¸";
  color: var(--accent);
  margin-right: 2px;
}

.admin-collapse-block[open] summary::before {
  content: "â–¾";
}

.admin-collapse-block summary span {
  margin-right: auto;
}

.copy-btn-compact {
  flex: 0 0 auto;
}

.admin-prompt-compact {
  min-height: 170px;
  border-width: 1px 0 0;
  border-radius: 0;
  background: rgba(0,0,0,.22);
}

.admin-prompt-small.admin-prompt-compact {
  min-height: 68px;
}

.admin-grid-meta-3 {
  grid-template-columns: repeat(3, minmax(0,1fr));
}

.live-vinyl-view .live-vote-box,
.live-vote-box {
  position: fixed;
  right: max(20px, env(safe-area-inset-right));
  bottom: max(20px, env(safe-area-inset-bottom));
  z-index: 40;
  margin: 0;
  padding: 14px;
  gap: 14px;
  border-radius: 26px;
  pointer-events: auto;
}

@media (max-width: 900px), (orientation: portrait) {
  .admin-grid-meta-3 {
    grid-template-columns: 1fr;
  }

  .live-vote-box {
    right: 14px;
    bottom: 14px;
    padding: 10px;
  }

  .live-vote-copy {
    display: none;
  }

  .live-vote-qr {
    width: clamp(118px, 34vw, 168px);
    height: clamp(118px, 34vw, 168px);
  }
}

.copy-drag-source {
  cursor: grab;
  user-select: none;
}

.copy-drag-source:active,
.copy-drag-source.is-dragging-copy {
  cursor: grabbing;
  opacity: .78;
  transform: scale(.98);
}

.copy-drag-source::after {
  content: " â†—";
  opacity: .55;
  font-weight: 900;
}

.suno-transfer-bar {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 5px;
  margin: -2px 0 10px;
  padding: 6px;
  border: 1px solid var(--line);
  border-radius: 15px;
  background: rgba(255,255,255,.045);
}

.suno-transfer-label {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 6px 0 2px;
  color: var(--muted);
  font-size: .72rem;
  font-weight: 950;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.suno-transfer-btn.copy-btn {
  min-height: 30px;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: .82rem;
  line-height: 1;
}

.suno-transfer-step {
  display: inline-grid;
  place-items: center;
  width: 18px;
  height: 18px;
  margin-right: 5px;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
  font-size: .68rem;
  font-weight: 950;
  line-height: 1;
}

.admin-subtle-label {
  margin-top: 10px;
  color: var(--muted);
}

.suno-transfer-hint {
  margin-left: auto;
  color: var(--muted);
  font-size: .76rem;
  white-space: nowrap;
  opacity: .82;
}

@media (max-width: 1100px) {
  .suno-transfer-hint {
    width: 100%;
    margin-left: 0;
  }

  .admin-grid-meta-4 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.admin-audio-player {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin: 10px 0 12px;
  padding: 12px 14px 13px;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: rgba(255,255,255,.045);
  box-shadow: none;
}

.admin-audio-player.is-active {
  border-color: rgba(255,255,255,.24);
  background: rgba(255,255,255,.065);
}

.admin-audio-player-main {
  min-width: 0;
  display: flex;
  align-items: baseline;
  gap: 8px;
}

.admin-audio-player-main strong {
  display: block;
  margin-top: 2px;
  font-size: .88rem;
  line-height: 1.15;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin: 0;
  max-width: 34vw;
}

.admin-audio-player-main span {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: .72rem;
  line-height: 1.25;
  margin: 0;
}

#adminAudioElement {
  width: 100% !important;
  height: 32px;
  display: block !important;
  max-width: none !important;
  min-width: 0 !important;
  grid-column: 1 / -1 !important;
}

.admin-audio-status-line {
  display: grid;
  grid-template-columns: 44px minmax(140px, 1fr) 76px 48px;
  align-items: center;
  gap: 10px;
  padding-top: 4px;
  font-size: .7rem;
  font-weight: 950;
  color: rgba(255,255,255,.82);
  font-variant-numeric: tabular-nums;
  padding: 5px 7px;
}

.admin-audio-progress {
  height: 7px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(255,255,255,.13);
}

.admin-audio-progress span {
  display: block;
  width: 0%;
  height: 100%;
  margin: 0;
  border-radius: inherit;
  background: rgba(255,255,255,.86);
  transition: width .15s linear;
}

#adminAudioTimeRemaining,
.admin-audio-duration {
  color: var(--muted);
  text-align: right;
}

@media (max-width: 980px) {
  .admin-audio-status-line {
    grid-template-columns: 48px minmax(110px, 1fr) 86px 52px;
    gap: 7px;
  }
}

.audio-cell {
  min-width: 96px;
  padding: 0 !important;
  height: 48px;
}

.audio-status-pill {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 4px 8px;
  border-radius: 999px;
  font-size: .72rem;
  font-weight: 900;
  white-space: nowrap;
  border: 1px solid var(--line);
}

.audio-status-pill.has-audio {
  color: #d7ffe3;
  background: rgba(65, 210, 119, .14);
  border-color: rgba(65, 210, 119, .35);
}

.audio-status-pill.missing-audio {
  color: rgba(255,255,255,.74);
  background: rgba(255,255,255,.055);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 48px;
  border-radius: 0;
  font-size: .62rem;
  opacity: .62;
}

.audio-play-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  margin-left: 0;
  padding: 6px 12px;
  border: 0;
  border-radius: 999px;
  background: #39d778;
  color: #031108;
  font-weight: 950;
  font-size: .78rem;
  cursor: pointer;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.18);
}

.audio-play-btn:hover,
.audio-play-btn.is-loaded {
  transform: translateY(-1px);
  background: #58ef93;
  filter: brightness(1.08);
}

.audio-play-btn.is-live {
  outline: 2px solid rgba(65, 210, 119, .75);
  outline-offset: 2px;
}

.audio-play-btn-large {
  min-height: 34px;
  padding: 8px 13px;
  width: auto;
  min-width: 92px;
  height: 34px;
  border-radius: 999px;
}

.admin-row[data-upload-id] {
  position: relative;
}

.admin-row[data-upload-id]::after {
  content: "";
  position: absolute;
  inset: 2px;
  border: 2px dashed transparent;
  border-radius: 12px;
  pointer-events: none;
}

.admin-row.is-audio-drop-target::after {
  border-color: rgba(255,255,255,.75);
  background: rgba(255,255,255,.06);
}

.admin-row.missing-audio .audio-cell {
  color: var(--muted);
}

.audio-drop-hint,
.audio-file-note {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 6px 10px;
  border: 1px dashed rgba(255,255,255,.24);
  border-radius: 999px;
  color: var(--muted);
  font-size: .78rem;
  font-weight: 800;
}

.audio-file-note {
  margin: -2px 0 10px;
  border-style: solid;
  background: rgba(255,255,255,.04);
}

@media (max-width: 900px) {
  .admin-audio-player {
    grid-template-columns: 1fr;
  }

  .admin-audio-status-line {
    grid-template-columns: 42px minmax(90px, 1fr) 48px;
  }

  .admin-audio-duration {
    display: none;
  }
}

#adminAudioPlayer.admin-audio-player {
  display: grid !important;
  flex-direction: column !important;
  grid-template-columns: 60px minmax(180px, .8fr) minmax(420px, 1.8fr) !important;
  align-items: center !important;
  gap: 14px !important;
  position: fixed !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  z-index: 1000 !important;
  grid-template-rows: auto 14px;
  column-gap: 10px;
  row-gap: 7px;
  padding: 12px 18px 14px !important;
  border-radius: 0 !important;
  background: rgba(3,7,13,.97) !important;
  border: 1px solid rgba(255,255,255,.13) !important;
  box-shadow: 0 -20px 56px rgba(0,0,0,.48) !important;
  backdrop-filter: blur(18px) saturate(1.25) !important;
  min-height: 96px !important;
  height: auto !important;
  overflow: visible !important;
  width: 100vw !important;
  max-width: 100vw !important;
  margin: 0 !important;
  border-top: 1px solid rgba(255,255,255,.14) !important;
  padding-top: 11px !important;
  padding-bottom: max(14px, env(safe-area-inset-bottom)) !important;
  box-sizing: border-box !important;
}

#adminAudioPlayer .admin-audio-player-main {
  width: 100% !important;
  min-width: 0 !important;
  display: flex;
  flex-direction: column;
  overflow: hidden !important;
}

#adminAudioStatusLine.admin-audio-status-line {
  width: 100% !important;
  display: grid !important;
  grid-template-columns: 58px minmax(0, 1fr) 76px 54px !important;
  align-items: center !important;
  gap: 10px !important;
  grid-column: 1 / -1 !important;
  font-size: .72rem !important;
  opacity: 1 !important;
  height: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  color: rgba(255,255,255,.82) !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  min-width: 0 !important;
  max-width: 100% !important;
  overflow: visible !important;
  min-height: 34px !important;
}

@media (max-width: 900px) {
  #adminAudioStatusLine.admin-audio-status-line {
    grid-template-columns: 46px minmax(90px, 1fr) 80px !important;
  }

  #adminAudioDuration.admin-audio-duration {
    display: none !important;
  }
}

.audio-cell-actions {
  display: flex;
  align-items: center;
  gap: 5px;
  flex-wrap: nowrap;
}

.hide-submission-btn {
  min-height: 26px;
  padding: 5px 9px;
  font-size: .7rem;
  border-radius: 999px;
}

.admin-gate-panel {
  margin: -6px 0 14px;
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: linear-gradient(145deg, rgba(255,255,255,.085), rgba(255,255,255,.028));
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
}

.admin-gate-panel.is-open {
  border-color: rgba(151, 219, 79, .35);
}

.admin-gate-panel.is-closed {
  border-color: rgba(255, 90, 90, .38);
  background: linear-gradient(145deg, rgba(255,90,90,.12), rgba(255,255,255,.025));
}

.admin-gate-main {
  display: grid;
  gap: 3px;
}

.admin-gate-main strong {
  font-size: clamp(1.05rem, 1.35vw, 1.35rem);
  letter-spacing: -.02em;
}

.admin-gate-main span {
  color: var(--muted);
  font-weight: 800;
  font-size: .9rem;
}

.admin-gate-controls {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}

.admin-gate-controls label {
  color: var(--muted);
  font-size: .74rem;
  font-weight: 950;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.admin-gate-input {
  width: min(340px, 30vw);
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(0,0,0,.32);
  color: var(--text);
  padding: 6px 10px;
  font-weight: 800;
  outline: none;
  min-height: 30px !important;
  font-size: .78rem;
  min-width: 170px;
  max-width: 100% !important;
}

.admin-gate-input:focus {
  border-color: rgba(246,255,0,.45);
}

.home-card-closed {
  max-width: min(900px, 92vw);
}

.closed-kicker {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 18px;
  padding: 9px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.1);
  border: 1px solid var(--line);
  font-weight: 950;
  letter-spacing: .18em;
  color: var(--accent);
}

.home-card-closed p {
  font-size: clamp(1.15rem, 2.4vw, 1.8rem);
  font-weight: 850;
}

@media (max-width: 900px) {
  .admin-gate-panel {
    display: grid;
  }

  .admin-gate-controls {
    justify-content: stretch;
  }

  .admin-gate-input {
    width: 100%;
  }
}

.admin-shell-wide {
  width: min(100%, 1760px);
}

.admin-header.admin-header-compact {
  align-items: center !important;
  margin-bottom: 8px;
  gap: 14px !important;
  padding: 14px 16px !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  width: 100% !important;
  border-radius: 0 !important;
}

.admin-header.admin-header-compact h1 {
  margin: 0 !important;
  font-size: clamp(1.65rem, 5vw, 4.2rem) !important;
  letter-spacing: -.07em !important;
  line-height: .9 !important;
}

.admin-header-actions .admin-link,
.admin-header-actions .copy-btn,
.admin-session-controls .copy-btn,
.admin-gate-controls .copy-btn {
  min-height: 30px;
  padding: 7px 10px;
  font-size: .72rem;
  line-height: 1;
}

.admin-session-panel,
.admin-gate-panel,
.admin-live-state,
.admin-audio-player {
  margin: 0 0 8px;
  padding: 8px 10px;
  border-radius: 14px;
}

.admin-session-panel,
.admin-gate-panel {
  gap: 10px;
}

.admin-session-main {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.admin-session-main strong,
.admin-gate-main strong {
  font-size: .82rem;
  white-space: nowrap;
}

.admin-session-main span {
  min-width: 0;
  max-width: 34vw;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: 950;
}

.admin-session-main em {
  color: var(--muted);
  font-style: normal;
  font-size: .78rem;
  white-space: nowrap;
}

.admin-session-controls,
.admin-gate-controls {
  gap: 6px;
}

.admin-audio-player-main .eyebrow {
  font-size: .62rem;
}

.status-btn.danger.hide-submission-btn,
.hide-submission-btn {
  min-width: 28px;
  min-height: 28px;
  padding: 0 9px;
  border: 1px solid rgba(255, 118, 132, .32);
  background: rgba(255, 86, 110, .12);
  color: rgba(255, 205, 212, .88);
  font-size: 1rem;
  line-height: 1;
  font-weight: 950;
}

.status-btn.danger.hide-submission-btn:hover,
.hide-submission-btn:hover {
  background: rgba(255, 86, 110, .2);
  color: #fff;
}

@media (max-width: 900px) {
  .admin-session-panel,
  .admin-gate-panel,
  .admin-header.admin-header-compact,
  .admin-audio-player-main {
    align-items: stretch;
    flex-direction: column;
  }

  .admin-session-main,
  .admin-gate-controls,
  .admin-session-controls {
    width: 100%;
  }

  .session-select,
  .admin-gate-input,
  .admin-session-main span,
  .admin-audio-player-main strong {
    max-width: none;
    width: 100%;
  }
}

.admin-top-btn,
.admin-header-actions .admin-top-btn,
.admin-header-actions .live-clear-btn {
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.08);
  color: #fff;
  border-radius: 999px;
  padding: 7px 10px;
  min-height: 32px;
  font-size: .78rem;
  font-weight: 800;
  text-decoration: none;
  line-height: 1;
  cursor: pointer;
  white-space: nowrap;
}

.admin-top-btn:hover,
.admin-header-actions .live-clear-btn:hover {
  background: rgba(255,255,255,.15);
}

.admin-session-panel,
.admin-gate-panel,
.admin-live-state {
  padding: 7px 10px;
  margin-bottom: 6px;
  gap: 8px;
  align-items: center !important;
}

.admin-session-main,
.admin-gate-main {
  gap: 7px;
  min-width: 0;
}

.admin-session-main em,
.admin-live-session {
  font-size: .72rem;
  opacity: .7;
}

.session-select,
.admin-gate-input {
  min-height: 32px;
  padding: 6px 9px;
  font-size: .78rem;
}

.admin-table.admin-table-compact {
  min-width: 0 !important;
  width: 100% !important;
  table-layout: fixed !important;
  border-radius: 0 !important;
}

.admin-table.admin-table-compact th,
.admin-table.admin-table-compact td {
  padding: 0;
  vertical-align: middle;
  font-size: .86rem !important;
}

.admin-table.admin-table-compact th {
  padding: 6px 6px;
  font-size: .68rem !important;
  line-height: 1.05 !important;
  padding-top: 6px !important;
  padding-bottom: 6px !important;
}

.admin-table.admin-table-compact th:nth-child(1),
.admin-table.admin-table-compact td:nth-child(1) {
  width: 44px !important;
  background-color: rgba(255,255,255,.018);
  min-width: 44px !important;
  max-width: 44px !important;
}

.admin-table.admin-table-compact th:nth-child(3),
.admin-table.admin-table-compact td:nth-child(3) {
  width: 58px !important;
  text-align: center;
  background-color: rgba(255,255,255,.025);
  min-width: 58px !important;
  max-width: 58px !important;
}

.admin-table.admin-table-compact th:nth-child(4),
.admin-table.admin-table-compact td:nth-child(4) {
  width: 64px !important;
  text-align: center;
  min-width: 64px !important;
  max-width: 64px !important;
}

.admin-row td {
  height: 48px;
  max-height: 48px;
  overflow: hidden;
  background-image: none !important;
  transition: background-color .18s ease, background-image .18s ease;
}

.admin-row.is-live-row td,
.admin-row.is-playing td {
  background-color: rgba(34, 197, 94, .10);
}

.admin-row.is-audio-playing-now td {
  background-color: rgba(34, 197, 94, .18);
}

.admin-row.is-archived td {
  opacity: .48;
  filter: grayscale(.35);
}

.admin-cell-x {
  text-align: center;
  padding-left: 8px !important;
  padding-right: 8px !important;
  padding: 0 !important;
  background: rgba(185,70,70,.055) !important;
}

.hide-submission-btn,
.restore-submission-btn {
  width: 26px;
  height: 34px;
  border-radius: 10px;
  border: 1px solid rgba(255,110,110,.18);
  background: rgba(120,50,50,.18);
  color: rgba(255,210,210,.68);
  font-size: 1rem;
  font-weight: 900;
  line-height: 1;
  cursor: pointer;
}

.restore-submission-btn {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.12);
  color: rgba(255,255,255,.7);
  font-size: .9rem;
  width: auto;
  padding: 0 8px;
}

.hide-submission-btn:hover {
  background: rgba(185,70,70,.28);
  color: #fff;
}

.admin-track-cell {
  min-width: 0;
  padding: 0 6px !important;
}

.admin-track-lines {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  min-width: 0;
  height: auto !important;
  line-height: 1.2 !important;
  padding: 8px 12px !important;
  align-items: flex-start !important;
  min-height: 72px !important;
  gap: 3px !important;
}

.admin-track-lines strong,
.admin-track-lines span {
  display: block !important;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
  width: 100% !important;
  text-align: left !important;
}

.admin-track-lines strong {
  font-size: 1.2rem !important;
  color: #fff !important;
  font-weight: 850 !important;
  letter-spacing: -.025em !important;
  line-height: 1.22 !important;
  padding-bottom: 0 !important;
}

.admin-track-lines span {
  font-size: 1.03rem !important;
  color: rgba(255,255,255,.82) !important;
  margin-top: 4px !important;
  font-weight: 650 !important;
  line-height: 1.18 !important;
}

.admin-sort-votes-btn {
  all: unset;
  cursor: pointer;
  font-weight: 900;
  color: inherit;
  font-size: .68rem !important;
  line-height: 1.05 !important;
  border-radius: 10px !important;
}

.audio-play-btn,
.chart-play-btn {
  width: 100%;
  min-width: 0;
  height: 48px;
  border: 0;
  border-radius: 0;
  background: linear-gradient(135deg, #22c55e, #16a34a);
  color: #06160b;
  font-size: .82rem;
  font-weight: 950;
  cursor: pointer;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.18);
}

.audio-play-btn.is-live,
.audio-play-btn.is-playing {
  background: linear-gradient(135deg, #7cff9d, #22c55e);
}

.suno-transfer-btn {
  padding: 6px 8px;
  font-size: .72rem;
}

.admin-collapse-block summary,
.admin-raw-details summary {
  padding: 7px 8px;
  font-size: .75rem;
}

.admin-grid-tight {
  gap: 6px;
}

.admin-archive-section {
  margin-top: 10px;
  margin-bottom: 110px;
}

.admin-archive-section > details > summary {
  cursor: pointer;
  padding: 8px 10px;
  border-radius: 12px;
  background: rgba(255,255,255,.05);
  color: rgba(255,255,255,.74);
  font-size: .8rem;
  font-weight: 800;
}

.admin-archive-section summary span {
  opacity: .6;
}

.admin-table-wrap-archive {
  margin-top: 6px;
  opacity: .9;
}

.admin-player-toggle {
  grid-row: 1 / 3;
  width: 54px;
  height: 54px;
  border: 0;
  border-radius: 50%;
  background: linear-gradient(135deg, #22c55e, #a3ff63);
  color: #06160b;
  font-size: 1.35rem;
  font-weight: 950;
  cursor: pointer;
  box-shadow: 0 8px 24px rgba(34,197,94,.25);
  font-variant-ligatures: none;
  line-height: 1;
}

#adminAudioPlayer .admin-audio-player-main strong {
  font-size: 1.06rem !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  line-height: 1.08 !important;
}

#adminAudioPlayer .admin-audio-player-main span {
  font-size: .8rem !important;
  opacity: .64;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  line-height: 1.12 !important;
}

#adminAudioStatusLine .admin-audio-progress {
  height: 14px !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.13) !important;
  overflow: hidden !important;
  cursor: pointer !important;
  position: relative !important;
  left: auto !important;
  right: auto !important;
  top: auto !important;
  transform: none !important;
  box-shadow: inset 0 1px 2px rgba(0,0,0,.45) !important;
  width: 100% !important;
}

#adminAudioStatusLine .admin-audio-progress span {
  display: block !important;
  height: 100% !important;
  width: 0%;
  border-radius: inherit !important;
  background: linear-gradient(90deg, #22c55e, #facc15) !important;
  box-shadow: 0 0 18px rgba(250,204,21,.22) !important;
}

.admin-chart-modal.hidden {
  display: none;
}

.admin-chart-modal {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
}

.admin-chart-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.72);
  backdrop-filter: blur(8px);
}

.admin-chart-panel {
  position: relative;
  width: min(520px, 100%);
  max-height: min(760px, 90vh);
  overflow: auto;
  border-radius: 22px;
  padding: 14px;
  background: #111827;
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 26px 80px rgba(0,0,0,.5);
}

.admin-chart-panel header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}

.admin-chart-panel header strong {
  font-size: 1.05rem;
}

.admin-chart-list {
  display: grid;
  gap: 7px;
}

.admin-chart-item {
  display: grid;
  grid-template-columns: 42px 1fr 46px 46px;
  gap: 8px;
  align-items: center;
  padding: 8px;
  border-radius: 14px;
  background: rgba(255,255,255,.055);
}

.admin-chart-rank {
  font-weight: 950;
  opacity: .65;
}

.admin-chart-title {
  min-width: 0;
  display: flex;
  flex-direction: column;
}

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

.admin-chart-title span {
  font-size: .72rem;
  opacity: .66;
}

.chart-play-btn {
  height: 36px;
  border-radius: 12px;
}

.live-style-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 18px;
  max-width: min(720px, 46vw);
}

.live-style-chips.hidden {
  display: none;
}

.live-style-chips span {
  max-width: 170px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.16);
  color: rgba(255,255,255,.86);
  font-size: clamp(.68rem, 1vw, .9rem);
  font-weight: 800;
}

@media (max-width: 720px) {
  .admin-shell.admin-shell-wide {
    padding: 6px;
  }

  .admin-header.admin-header-compact {
    align-items: flex-start;
  }

  .admin-header-actions {
    justify-content: flex-start;
    width: 100%;
  }

  .admin-session-panel,
  .admin-gate-panel {
    flex-direction: column;
    align-items: stretch;
  }

  .admin-session-controls,
  .admin-gate-controls {
    width: 100%;
  }

  .session-select,
  .admin-gate-input {
    flex: 1 1 auto;
    min-width: 0;
  }

  .admin-table.admin-table-compact th:nth-child(1),
  .admin-table.admin-table-compact td:nth-child(1) {
    width: 30px;
  }

  .admin-table.admin-table-compact th:nth-child(3),
  .admin-table.admin-table-compact td:nth-child(3) {
    width: 48px;
  }

  .admin-table.admin-table-compact th:nth-child(4),
  .admin-table.admin-table-compact td:nth-child(4) {
    width: 56px;
  }

  .admin-track-lines strong {
    font-size: .76rem;
  }

  .admin-track-lines span {
    font-size: .68rem;
  }

  #adminAudioStatusLine.admin-audio-status-line {
    grid-template-columns: 38px 1fr 62px;
  }

  #adminAudioDuration.admin-audio-duration {
    display: none;
  }

  .live-style-chips {
    max-width: 80vw;
    gap: 6px;
  }

  .live-style-chips span {
    max-width: 140px;
  }
}

.admin-row .admin-track-cell {
  background-image: linear-gradient(90deg, rgba(43,255,128,.26) var(--row-progress), transparent var(--row-progress)) !important;
  transition: background-color .18s ease, background-image .18s ease;
}

.admin-row.is-audio-playing-now td,
.admin-row.is-live-row td {
  background-color: rgba(34, 197, 94, .20) !important;
}

.admin-row.is-audio-playing-now .admin-track-cell,
.admin-row.is-live-row .admin-track-cell {
  background-color: rgba(34,197,94,.24) !important;
}

#adminAudioStatusLine .admin-audio-progress:hover {
  filter: brightness(1.18);
}

@media (max-width: 720px) {
  .admin-body {
    padding-left: 6px;
    padding-right: 6px;
  }

  .admin-shell.admin-shell-wide {
    padding-left: 0;
    padding-right: 0;
  }

  .admin-table.admin-table-compact th:nth-child(1),
  .admin-table.admin-table-compact td:nth-child(1) {
    width: 30px;
  }

  .admin-table.admin-table-compact th:nth-child(3),
  .admin-table.admin-table-compact td:nth-child(3) {
    width: 46px;
  }

  .admin-table.admin-table-compact th:nth-child(4),
  .admin-table.admin-table-compact td:nth-child(4) {
    width: 54px;
  }
}

.admin-table.admin-table-compact col.admin-col-archive {
  width: 44px !important;
}

.admin-table.admin-table-compact col.admin-col-track {
  width: calc(100% - 172px) !important;
}

.admin-table.admin-table-compact col.admin-col-votes {
  width: 58px !important;
}

.admin-table.admin-table-compact col.admin-col-play {
  width: 64px !important;
}

.admin-table.admin-table-compact th:nth-child(2),
.admin-table.admin-table-compact td:nth-child(2) {
  width: calc(100% - 172px) !important;
  min-width: 0 !important;
  max-width: none !important;
}

.admin-row.is-audio-playing-now .admin-cell-x,
.admin-row.is-live-row .admin-cell-x {
  background-color: rgba(34,197,94,.12) !important;
  background: rgba(35,120,70,.14) !important;
}

.admin-row.is-audio-playing-now .admin-vote-cell,
.admin-row.is-live-row .admin-vote-cell {
  background-color: rgba(34,197,94,.15) !important;
}

@media (max-width: 720px) {
  .admin-table.admin-table-compact col.admin-col-archive {
    width: 30px;
  }

  .admin-table.admin-table-compact col.admin-col-votes {
    width: 48px;
  }

  .admin-table.admin-table-compact col.admin-col-play {
    width: 56px;
  }

  .admin-table.admin-table-compact th:nth-child(1),
  .admin-table.admin-table-compact td:nth-child(1) {
    width: 30px !important;
  }

  .admin-table.admin-table-compact th:nth-child(3),
  .admin-table.admin-table-compact td:nth-child(3) {
    width: 48px !important;
  }

  .admin-table.admin-table-compact th:nth-child(4),
  .admin-table.admin-table-compact td:nth-child(4) {
    width: 56px !important;
  }
}

.admin-table-wrap > table.admin-table.admin-table-compact,
table.admin-table.admin-table-compact {
  display: table !important;
  width: 100% !important;
  min-width: 100% !important;
  max-width: none !important;
  table-layout: fixed !important;
  border-spacing: 0 !important;
}

.admin-cell-x .hide-submission-btn,
.admin-cell-x .restore-submission-btn {
  margin-left: 6px !important;
  margin-right: 6px !important;
  width: 100% !important;
  height: 56px !important;
  min-height: 56px !important;
  margin: 0 !important;
  border-radius: 0 !important;
  border: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 1.15rem !important;
  font-weight: 950 !important;
  line-height: 1 !important;
  box-shadow: none !important;
}

@media (max-width: 720px) {
  .admin-table.admin-table-compact col.admin-col-archive {
    width: 42px !important;
  }

  .admin-table.admin-table-compact col.admin-col-votes {
    width: 48px !important;
  }

  .admin-table.admin-table-compact col.admin-col-play {
    width: 56px !important;
  }

  .admin-table.admin-table-compact col.admin-col-track {
    width: calc(100% - 146px) !important;
  }

  .admin-table.admin-table-compact th:nth-child(1),
  .admin-table.admin-table-compact td:nth-child(1) {
    width: 42px !important;
    min-width: 42px !important;
    max-width: 42px !important;
  }

  .admin-table.admin-table-compact th:nth-child(2),
  .admin-table.admin-table-compact td:nth-child(2) {
    width: calc(100% - 146px) !important;
  }

  .admin-table.admin-table-compact th:nth-child(3),
  .admin-table.admin-table-compact td:nth-child(3) {
    width: 48px !important;
    min-width: 48px !important;
    max-width: 48px !important;
  }

  .admin-table.admin-table-compact th:nth-child(4),
  .admin-table.admin-table-compact td:nth-child(4) {
    width: 56px !important;
    min-width: 56px !important;
    max-width: 56px !important;
  }

  .admin-cell-x {
    padding-left: 5px !important;
    padding-right: 5px !important;
  }

  .admin-cell-x .hide-submission-btn,
  .admin-cell-x .restore-submission-btn {
    margin-left: 4px;
    margin-right: 4px;
  }
}

.admin-table.admin-table-compact .admin-row[data-upload-id]::after {
  content: none !important;
  display: none !important;
}

.admin-table.admin-table-compact .admin-row.is-audio-drop-target > td {
  box-shadow: inset 0 0 0 2px rgba(255,255,255,.72) !important;
  background-image: linear-gradient(rgba(255,255,255,.055), rgba(255,255,255,.055)) !important;
}

.admin-table.admin-table-compact .admin-row.is-audio-drop-target > td:first-child {
  border-top-left-radius: 12px;
  border-bottom-left-radius: 12px;
}

.admin-table.admin-table-compact .admin-row.is-audio-drop-target > td:last-child {
  border-top-right-radius: 12px;
  border-bottom-right-radius: 12px;
}

.admin-table.admin-table-compact th:nth-child(1),
.admin-table.admin-table-compact td:nth-child(1),
.admin-table.admin-table-compact col.admin-col-archive {
  width: 50px !important;
  min-width: 50px !important;
  max-width: 50px !important;
}

.admin-header-actions .live-clear-btn {
  display: none !important;
}

.admin-live-state-main {
  display: flex !important;
  align-items: flex-start !important;
  gap: 2px !important;
  min-width: 0;
  flex: 1 1 auto;
  overflow: hidden;
  flex-direction: column !important;
  line-height: 1.15 !important;
  text-align: left !important;
}

.admin-live-state-main strong,
.admin-live-state-main .admin-live-session {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.admin-live-state .live-clear-btn {
  flex: 0 0 auto;
  margin-left: 0 !important;
}

.audio-play-btn.is-playing,
.admin-player-toggle.is-playing {
  background: linear-gradient(135deg, #63ff61, #b7ff3d) !important;
  color: #07120a !important;
}

.audio-play-btn.is-playing {
  font-weight: 900 !important;
}

@media (max-width: 720px) {
  .admin-track-lines {
    height: 50px !important;
  }

  .admin-track-lines strong {
    font-size: .86rem !important;
  }

  .admin-track-lines span {
    font-size: .74rem !important;
  }

  .admin-live-state {
    align-items: stretch !important;
  }

  .admin-live-state-main {
    gap: 6px;
  }
}

.admin-live-chip {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 38px !important;
  padding: 0 13px !important;
  border: 1px solid rgba(124,255,157,.28) !important;
  border-radius: 999px !important;
  background: rgba(124,255,157,.12) !important;
  color: #7cff9d !important;
  font-size: .74rem;
  font-weight: 950 !important;
  letter-spacing: .01em;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
  cursor: default !important;
}

.admin-live-chip.is-fresh {
  background: rgba(124,255,157,.18);
  border-color: rgba(124,255,157,.45);
  color: #b7ff3d;
}

.admin-top-btn,
.admin-header-actions .admin-top-btn,
.admin-live-actions .admin-top-btn,
.admin-gate-controls .admin-top-btn,
.admin-session-controls .admin-top-btn {
  min-height: 30px !important;
  padding: 0 13px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255,255,255,.20) !important;
  background: rgba(255,255,255,.08) !important;
  color: #fff !important;
  font-size: .74rem !important;
  font-weight: 900 !important;
  letter-spacing: .01em !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  white-space: nowrap !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08) !important;
}

.admin-top-btn:hover,
.admin-header-actions .admin-top-btn:hover,
.admin-live-actions .admin-top-btn:hover,
.admin-gate-controls .admin-top-btn:hover,
.admin-session-controls .admin-top-btn:hover {
  background: rgba(255,255,255,.15) !important;
  border-color: rgba(255,255,255,.30) !important;
}

.admin-top-btn-charts,
.chart-open-btn {
  background: linear-gradient(135deg, rgba(255,139,75,.94), rgba(255,221,69,.88)) !important;
  color: #19090a !important;
  border-color: rgba(255,221,69,.55) !important;
}

.admin-top-btn-charts:hover,
.chart-open-btn:hover {
  filter: brightness(1.06);
  background: linear-gradient(135deg, rgba(255,154,85,.98), rgba(255,229,80,.95)) !important;
}

.admin-panel-title {
  flex: 0 0 auto;
  color: rgba(255,255,255,.48);
  font-size: .62rem;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .16em;
  white-space: nowrap;
}

.admin-gate-panel,
.admin-live-state {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px 12px !important;
}

.admin-gate-main,
.admin-live-state-main {
  flex: 1 1 auto !important;
  min-width: 160px !important;
}

.admin-gate-controls,
.admin-live-actions {
  margin-left: auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 7px !important;
  flex: 0 1 auto !important;
  min-width: 0 !important;
  max-width: 100% !important;
}

.admin-header-actions .live-clear-btn,
.admin-header-actions a[href="index.php"],
.admin-header-actions a[href="live.php"] {
  display: none !important;
}

.admin-cell-x .hide-submission-btn {
  background: rgba(160, 56, 68, .46) !important;
  color: rgba(255, 220, 224, .96) !important;
}

.admin-cell-x .restore-submission-btn {
  background: rgba(120, 120, 135, .38) !important;
  color: rgba(255,255,255,.9) !important;
}

.admin-cell-x .hide-submission-btn:hover {
  background: rgba(205, 75, 84, .70) !important;
  color: #fff !important;
}

.admin-cell-x .restore-submission-btn:hover {
  background: rgba(155,155,175,.52) !important;
}

.admin-row.is-audio-playing-now .admin-cell-x .hide-submission-btn,
.admin-row.is-live-row .admin-cell-x .hide-submission-btn {
  background: rgba(160, 56, 68, .34) !important;
}

.audio-cell .audio-play-btn {
  height: 56px !important;
  min-height: 56px !important;
}

.admin-player-toggle.is-playing,
.audio-play-btn.is-playing {
  font-family: Inter, Arial, sans-serif !important;
  font-variant-ligatures: none !important;
}

@media (max-width: 720px) {
  .admin-header.admin-header-compact {
    align-items: center !important;
  }

  .admin-header-actions {
    justify-content: flex-end !important;
    width: auto !important;
  }

  .admin-gate-controls,
  .admin-live-actions {
    width: 100%;
    justify-content: flex-start !important;
    margin-left: 0 !important;
  }

  .admin-gate-input {
    max-width: 100% !important;
    flex: 1 1 180px;
  }

  .admin-track-lines {
    height: 54px !important;
    padding: 7px 9px !important;
  }

  .admin-track-lines strong {
    font-size: .92rem !important;
  }

  .admin-track-lines span {
    font-size: .76rem !important;
  }

  .audio-cell .audio-play-btn,
  .admin-cell-x .hide-submission-btn,
  .admin-cell-x .restore-submission-btn {
    height: 54px !important;
    min-height: 54px !important;
  }
}

.admin-table.admin-table-compact col.admin-col-cover,
.admin-table.admin-table-compact th:nth-child(1),
.admin-table.admin-table-compact td:nth-child(1) {
  width: 80px !important;
  min-width: 80px !important;
  max-width: 80px !important;
}

.admin-table.admin-table-compact col.admin-col-archive,
.admin-table.admin-table-compact th:nth-child(2),
.admin-table.admin-table-compact td:nth-child(2) {
  width: 50px !important;
  min-width: 50px !important;
  max-width: 50px !important;
}

.admin-table.admin-table-compact col.admin-col-votes,
.admin-table.admin-table-compact th:nth-child(4),
.admin-table.admin-table-compact td:nth-child(4) {
  width: 58px !important;
  min-width: 58px !important;
  max-width: 58px !important;
  text-align: center !important;
}

.admin-table.admin-table-compact col.admin-col-play,
.admin-table.admin-table-compact th:nth-child(5),
.admin-table.admin-table-compact td:nth-child(5) {
  width: 64px !important;
  min-width: 64px !important;
  max-width: 64px !important;
  text-align: center !important;
}

.admin-table.admin-table-compact col.admin-col-track,
.admin-table.admin-table-compact th:nth-child(3),
.admin-table.admin-table-compact td:nth-child(3) {
  width: calc(100% - 252px) !important;
  min-width: 0 !important;
}

.admin-table.admin-table-compact th.admin-col-cover-head {
  text-align: center !important;
}

.admin-row > td {
  height: 80px !important;
  max-height: 80px !important;
}

.admin-cover-cell {
  padding: 0 !important;
  width: 80px !important;
  height: 80px !important;
  min-width: 80px !important;
  max-width: 80px !important;
  background: rgba(0,0,0,.18) !important;
  overflow: hidden !important;
}

.admin-cover-cell img {
  display: block;
  width: 80px;
  height: 80px;
  object-fit: cover;
  object-position: center;
}

.admin-cover-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 80px;
  height: 80px;
  color: rgba(255,255,255,.30);
  font-weight: 900;
  background: radial-gradient(circle at center, rgba(255,255,255,.08), rgba(255,255,255,.02));
}

.admin-cell-x .hide-submission-btn,
.admin-cell-x .restore-submission-btn,
.audio-cell .audio-play-btn,
.audio-status-pill.missing-audio {
  height: 80px !important;
  min-height: 80px !important;
}

.admin-row .admin-cover-cell,
.admin-row .admin-cell-x,
.admin-row .admin-vote-cell,
.admin-row .audio-cell {
  background-image: none !important;
}

.admin-row.is-audio-playing-now .admin-cover-cell,
.admin-row.is-live-row .admin-cover-cell {
  background-color: rgba(34,197,94,.12) !important;
}

@media (max-width: 720px) {
  .admin-table.admin-table-compact col.admin-col-cover,
  .admin-table.admin-table-compact th:nth-child(1),
  .admin-table.admin-table-compact td:nth-child(1) {
    width: 64px !important;
    min-width: 64px !important;
    max-width: 64px !important;
  }

  .admin-table.admin-table-compact col.admin-col-archive,
  .admin-table.admin-table-compact th:nth-child(2),
  .admin-table.admin-table-compact td:nth-child(2) {
    width: 44px !important;
    min-width: 44px !important;
    max-width: 44px !important;
  }

  .admin-table.admin-table-compact col.admin-col-votes,
  .admin-table.admin-table-compact th:nth-child(4),
  .admin-table.admin-table-compact td:nth-child(4) {
    width: 48px !important;
    min-width: 48px !important;
    max-width: 48px !important;
  }

  .admin-table.admin-table-compact col.admin-col-play,
  .admin-table.admin-table-compact th:nth-child(5),
  .admin-table.admin-table-compact td:nth-child(5) {
    width: 54px !important;
    min-width: 54px !important;
    max-width: 54px !important;
  }

  .admin-table.admin-table-compact col.admin-col-track,
  .admin-table.admin-table-compact th:nth-child(3),
  .admin-table.admin-table-compact td:nth-child(3) {
    width: calc(100% - 210px) !important;
  }

  .admin-row,
  .admin-row > td,
  .admin-cover-cell,
  .admin-cover-cell img,
  .admin-cover-placeholder,
  .admin-cell-x .hide-submission-btn,
  .admin-cell-x .restore-submission-btn,
  .audio-cell .audio-play-btn,
  .audio-status-pill.missing-audio,
  .admin-track-lines {

  }

  .admin-cover-cell,
  .admin-cover-cell img,
  .admin-cover-placeholder {
    width: 64px !important;
  }

  .admin-track-lines {
    padding: 9px 9px !important;
  }

  .admin-track-lines strong {
    font-size: .94rem !important;
  }

  .admin-track-lines span {
    font-size: .76rem !important;
  }
}

.admin-track-cell,
.admin-track-lines {
  text-align: left !important;
  overflow: visible !important;
}

#adminAudioPlayer .admin-audio-player-main,
#adminAudioPlayer .admin-audio-player-main strong,
#adminAudioPlayer .admin-audio-player-main span,
#adminAudioTimeElapsed,
#adminAudioTimeRemaining,
#adminAudioDuration {
  display: none !important;
}

#adminAudioToggle.admin-player-toggle {
  position: static !important;
  left: 50% !important;
  top: 50% !important;
  transform: none !important;
  width: 56px !important;
  height: 56px !important;
  min-width: 56px !important;
  min-height: 56px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255,255,255,.22) !important;
  background: linear-gradient(135deg, rgba(99,255,97,.97), rgba(183,255,61,.95)) !important;
  color: #07120a !important;
  box-shadow: 0 16px 36px rgba(74,255,101,.25), inset 0 1px 0 rgba(255,255,255,.42) !important;
  font-size: 1rem !important;
  font-weight: 1000 !important;
  line-height: 1 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  font-family: Inter, Arial, sans-serif !important;
  z-index: 3 !important;
  letter-spacing: 0 !important;
  text-align: center !important;
}

#adminAudioToggle.admin-player-toggle.is-playing {
  background: linear-gradient(135deg, rgba(105,255,90,.98), rgba(255,225,61,.98)) !important;
}

@media (max-width: 720px) {
  .admin-track-lines strong {
    font-size: 1rem !important;
  }

  .admin-track-lines span {
    font-size: .80rem !important;
  }

  #adminAudioPlayer.admin-audio-player {
    left: 6px !important;
    right: 6px !important;
    bottom: 6px !important;
    height: 48px !important;
    min-height: 48px !important;
    padding-left: 56px !important;
    padding-right: 56px !important;
    border-radius: 18px !important;
  }

  #adminAudioToggle.admin-player-toggle {
    width: 52px !important;
    height: 52px !important;
    min-width: 52px !important;
    min-height: 52px !important;
  }

  #adminAudioStatusLine .admin-audio-progress {
    left: 56px !important;
    right: 56px !important;
    height: 12px !important;
  }

  .admin-body {
    padding-bottom: 72px !important;
  }
}

.admin-track-lines em {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  margin-top: 4px !important;
  font-style: normal !important;
  font-size: .72rem !important;
  line-height: 1.15 !important;
  font-weight: 850 !important;
  letter-spacing: .055em !important;
  text-transform: uppercase !important;
  color: rgba(124,255,157,.82) !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  opacity: .86 !important;
}

#adminAudioPlayer .admin-audio-player-main,
#adminAudioPlayer .admin-audio-player-main strong,
#adminAudioPlayer .admin-audio-player-main span {
  display: block !important;
}

#adminAudioTimeElapsed,
#adminAudioTimeRemaining,
#adminAudioDuration {
  display: inline-flex !important;
  align-items: center !important;
  white-space: nowrap !important;
  opacity: .92 !important;
  font-variant-numeric: tabular-nums !important;
}

#adminAudioTimeElapsed {
  justify-content: flex-start !important;
}

#adminAudioTimeRemaining,
#adminAudioDuration {
  justify-content: flex-end !important;
}

@media (max-width: 720px) {
  #adminAudioPlayer.admin-audio-player {
    padding-left: 64px !important;
    padding-right: 64px !important;
  }

  #adminAudioStatusLine.admin-audio-status-line {
    grid-template-columns: 42px minmax(0, 1fr) 56px !important;
    gap: 7px !important;
    font-size: .64rem !important;
  }

  #adminAudioDuration {
    display: none !important;
  }

  #adminAudioToggle.admin-player-toggle {
    width: 52px !important;
    height: 52px !important;
    min-width: 52px !important;
    min-height: 52px !important;
  }
}

.admin-user-input-card {
  margin: 10px 0 12px !important;
  padding: 12px !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  border-radius: 16px !important;
  background: linear-gradient(135deg, rgba(255,139,75,.08), rgba(116,255,91,.035)),
    rgba(5,6,16,.44) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}

.admin-user-input-title {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}

.admin-user-input-title span,
.admin-detail-section-title {
  color: rgba(255,255,255,.52);
  font-size: .62rem;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .16em;
  white-space: nowrap;
}

.admin-user-input-title strong {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: #fff;
  font-size: .98rem;
  letter-spacing: -.02em;
}

.admin-user-meta-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 6px;
  margin-bottom: 10px;
}

.admin-user-meta-grid > div,
.admin-user-lyric-box {
  min-width: 0;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 12px;
  background: rgba(0,0,0,.18);
  padding: 8px 9px;
}

.admin-user-meta-grid span,
.admin-user-lyric-box span,
.admin-user-input-label {
  display: block;
  color: rgba(255,255,255,.48);
  font-size: .58rem;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .13em;
  margin-bottom: 4px;
}

.admin-user-meta-grid strong {
  display: block;
  color: rgba(255,255,255,.92);
  font-size: .78rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.admin-user-input-row {
  display: grid;
  grid-template-columns: 116px minmax(0, 1fr);
  gap: 8px;
  align-items: start;
  margin-top: 8px;
}

.admin-user-input-row p {
  margin: 0;
  color: rgba(255,255,255,.78);
  font-size: .78rem;
  line-height: 1.35;
}

.admin-user-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  min-width: 0;
}

.admin-user-chip {
  display: inline-flex;
  align-items: center;
  max-width: 190px;
  min-height: 24px;
  padding: 4px 8px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.13);
  background: rgba(255,139,75,.13);
  color: rgba(255,255,255,.9);
  font-size: .68rem;
  font-weight: 900;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.admin-user-lyrics-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
  margin-top: 10px;
}

.admin-user-lyric-box p {
  margin: 0;
  color: rgba(255,255,255,.84);
  font-size: .78rem;
  line-height: 1.35;
}

.admin-cover-direct {
  margin: 10px 0 10px;
  padding: 12px;
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 16px;
  background: rgba(0,0,0,.12);
}

.admin-cover-direct .admin-detail-section-title {
  margin-bottom: 9px;
}

.admin-cover-direct .cover-card {
  margin-bottom: 0 !important;
}

@media (max-width: 920px) {
  .admin-user-meta-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .admin-user-lyrics-grid {
    grid-template-columns: 1fr;
  }

  .admin-user-input-row {
    grid-template-columns: 1fr;
    gap: 4px;
  }
}

@media (max-width: 620px) {
  .admin-user-input-card,
  .admin-cover-direct {
    padding: 10px;
    border-radius: 14px;
  }

  .admin-user-input-title {
    display: block;
  }

  .admin-user-input-title strong {
    display: block;
    margin-top: 3px;
  }

  .admin-user-meta-grid {
    grid-template-columns: 1fr;
  }
}

.admin-user-input-card .admin-user-input-title {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  margin: 0 0 10px !important;
  padding-bottom: 8px !important;
  border-bottom: 1px solid rgba(255,255,255,.08) !important;
}

.admin-user-input-card .admin-user-input-title span {
  color: rgba(255,255,255,.58) !important;
  font-size: .62rem !important;
  font-weight: 950 !important;
  letter-spacing: .16em !important;
  text-transform: uppercase !important;
}

.admin-user-input-card .admin-user-input-title strong {
  min-width: 0 !important;
  color: #fff !important;
  font-size: .95rem !important;
  line-height: 1.05 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.admin-user-input-table {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 6px !important;
}

.admin-user-input-tr {
  min-width: 0 !important;
  display: grid !important;
  grid-template-columns: 92px minmax(0, 1fr) !important;
  align-items: center !important;
  column-gap: 8px !important;
  min-height: 34px !important;
  padding: 7px 9px !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  border-radius: 12px !important;
  background: rgba(0,0,0,.18) !important;
}

.admin-user-input-tr-wide {
  grid-column: 1 / -1 !important;
  align-items: start !important;
}

.admin-user-input-th {
  min-width: 0 !important;
  color: rgba(255,255,255,.48) !important;
  font-size: .56rem !important;
  font-weight: 950 !important;
  text-transform: uppercase !important;
  letter-spacing: .11em !important;
  white-space: nowrap !important;
}

.admin-user-input-td {
  min-width: 0 !important;
  color: rgba(255,255,255,.92) !important;
  font-size: .81rem !important;
  font-weight: 850 !important;
  line-height: 1.22 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.admin-user-input-text {
  white-space: normal !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}

.admin-user-input-card .admin-user-chip-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 5px !important;
  min-width: 0 !important;
}

.admin-user-input-card .admin-user-chip {
  min-height: 22px !important;
  max-width: 180px !important;
  padding: 3px 8px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255,139,75,.34) !important;
  background: rgba(255,139,75,.13) !important;
  color: rgba(255,255,255,.92) !important;
  font-size: .66rem !important;
  font-weight: 950 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.admin-user-input-card .admin-user-lyrics-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 6px !important;
  margin-top: 8px !important;
}

.admin-user-input-card .admin-user-lyric-box {
  min-width: 0 !important;
  border: 1px solid rgba(116,255,91,.10) !important;
  border-radius: 12px !important;
  background: rgba(116,255,91,.045) !important;
  padding: 8px 9px !important;
}

.admin-user-input-card .admin-user-lyric-box span {
  display: block !important;
  color: rgba(116,255,91,.62) !important;
  font-size: .56rem !important;
  font-weight: 950 !important;
  text-transform: uppercase !important;
  letter-spacing: .12em !important;
  margin-bottom: 5px !important;
}

.admin-user-input-card .admin-user-lyric-box p {
  margin: 0 !important;
  color: rgba(255,255,255,.86) !important;
  font-size: .78rem !important;
  line-height: 1.28 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 3 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}

@media (max-width: 980px) {
  .admin-user-input-table {
    grid-template-columns: 1fr !important;
  }

  .admin-user-input-card .admin-user-lyrics-grid {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 640px) {
  .admin-user-input-tr {
    grid-template-columns: 78px minmax(0, 1fr) !important;
    padding: 7px 8px !important;
  }

  .admin-user-input-card .admin-user-input-title {
    align-items: flex-start !important;
    flex-direction: column !important;
    gap: 4px !important;
  }
}

.admin-expand-head-actions-only {
  display: flex !important;
  justify-content: flex-end !important;
  align-items: center !important;
  margin: 0 0 8px !important;
  padding: 0 !important;
  gap: 0 !important;
}

.admin-detail-actionbar {
  width: auto !important;
  margin-left: auto !important;
  padding: 5px !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.045) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 5px !important;
}

.admin-detail-actionbar .audio-play-btn-large,
.admin-detail-actionbar .live-btn,
.admin-detail-actionbar .audio-delete-btn,
.admin-detail-actionbar .hide-submission-btn,
.admin-detail-actionbar .restore-submission-btn {
  height: 34px !important;
  min-height: 34px !important;
  border-radius: 999px !important;
  padding: 0 12px !important;
  font-size: .72rem !important;
  line-height: 1 !important;
  font-weight: 950 !important;
  white-space: nowrap !important;
}

.admin-detail-actionbar .audio-play-btn-large {
  min-width: 92px !important;
  width: auto !important;
}

.admin-detail-actionbar .hide-submission-btn {
  width: 34px !important;
  min-width: 34px !important;
  padding: 0 !important;
  border-color: rgba(255,110,120,.22) !important;
  background: rgba(120,50,60,.38) !important;
  color: rgba(255,220,225,.92) !important;
}

.audio-delete-btn {
  border: 1px solid rgba(255,255,255,.12) !important;
  background: rgba(255,255,255,.07) !important;
  color: rgba(255,255,255,.82) !important;
  cursor: pointer !important;
}

.audio-delete-btn:hover {
  border-color: rgba(255,145,145,.34) !important;
  background: rgba(170,60,70,.22) !important;
  color: #fff !important;
}

.admin-expand-card > .suno-transfer-bar {
  position: relative !important;
  margin: 0 0 12px !important;
  padding: 10px !important;
  border: 1px solid rgba(124,255,157,.28) !important;
  border-radius: 18px !important;
  background: linear-gradient(135deg, rgba(124,255,157,.15), rgba(255,139,75,.075)),
    rgba(2,6,15,.42) !important;
  box-shadow: 0 12px 32px rgba(0,0,0,.20), inset 0 1px 0 rgba(255,255,255,.08) !important;
}

.admin-expand-card > .suno-transfer-bar::before {
  content: "Transfer" !important;
  position: absolute !important;
  top: -9px !important;
  left: 14px !important;
  padding: 2px 8px !important;
  border-radius: 999px !important;
  background: #1e102d !important;
  color: rgba(255,255,255,.62) !important;
  border: 1px solid rgba(124,255,157,.20) !important;
  font-size: .58rem !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  font-weight: 950 !important;
}

.admin-expand-card > .suno-transfer-bar .suno-transfer-label {
  color: #7cff9d !important;
  padding-left: 4px !important;
}

.admin-expand-card > .suno-transfer-bar .suno-transfer-btn.copy-btn {
  border-color: rgba(255,255,255,.16) !important;
  background: rgba(255,255,255,.10) !important;
  color: #fff !important;
}

.admin-expand-card > .suno-transfer-bar .suno-transfer-btn.copy-btn:hover {
  background: rgba(124,255,157,.18) !important;
}

@media (max-width: 720px) {
  .admin-expand-head-actions-only {
    justify-content: stretch !important;
  }

  .admin-detail-actionbar {
    width: 100% !important;
    border-radius: 16px !important;
    flex-wrap: wrap !important;
    justify-content: flex-start !important;
  }

  .admin-detail-actionbar .audio-play-btn-large,
  .admin-detail-actionbar .live-btn,
  .admin-detail-actionbar .audio-delete-btn {
    flex: 1 1 auto !important;
  }
}

.admin-top-btn.admin-top-btn-charts {
  min-height: 46px !important;
  padding: 0 20px !important;
  font-size: .95rem !important;
  font-weight: 1000 !important;
  border-color: rgba(255,139,75,.42) !important;
  background: linear-gradient(135deg, rgba(255,139,75,.34), rgba(124,255,157,.16)) !important;
}

.admin-session-panel.admin-top-panel,
.admin-gate-panel.admin-top-panel,
.admin-live-state.admin-top-panel {
  width: 100% !important;
  border-radius: 0 !important;
  margin: 0 0 1px 0 !important;
  padding: 10px 12px !important;
  border-left: 0 !important;
  border-right: 0 !important;
  display: grid !important;
  grid-template-columns: minmax(0, .9fr) minmax(0, 1.5fr) !important;
  align-items: center !important;
  gap: 10px !important;
  border: 0 !important;
  box-shadow: none !important;
}

.admin-session-controls,
.admin-gate-controls,
.admin-live-actions {
  min-width: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 7px !important;
  flex-wrap: nowrap !important;
}

.admin-session-controls .session-select,
.admin-gate-input {
  min-width: 0 !important;
  width: auto !important;
  flex: 1 1 auto !important;
  height: 38px !important;
  border-radius: 0 !important;
}

.admin-session-controls .new-session-btn,
.admin-gate-controls .submission-gate-toggle,
.admin-gate-controls .submission-gate-save,
.admin-live-actions .live-clear-btn,
.admin-external-link {
  flex: 0 0 auto !important;
  min-height: 38px !important;
  height: 38px !important;
  border-radius: 0 !important;
  padding: 0 11px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.admin-external-link {
  width: 42px !important;
  min-width: 42px !important;
  padding: 0 !important;
  color: #07100b !important;
  background: #7cff9d !important;
  border-color: rgba(124,255,157,.8) !important;
  font-size: 1.05rem !important;
  font-weight: 1000 !important;
  margin-left: auto !important;
}

.admin-live-actions .live-clear-btn {
  width: 42px !important;
  min-width: 42px !important;
  padding: 0 !important;
  font-size: 1.25rem !important;
  height: 38px !important;
  min-height: 38px !important;
  line-height: 1 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  font-family: Arial, Helvetica, sans-serif !important;
}

.admin-live-state.is-live-active {
  border-color: rgba(124,255,157,.48) !important;
  background: linear-gradient(135deg, rgba(124,255,157,.20), rgba(255,139,75,.13)), rgba(4,10,18,.72) !important;
  box-shadow: inset 0 0 0 1px rgba(124,255,157,.18), 0 14px 36px rgba(0,0,0,.22) !important;
}

#adminAudioStatusLine {
  font-size: 1.42rem !important;
  font-weight: 1000 !important;
  gap: 12px !important;
  line-height: 1 !important;
  display: grid !important;
  grid-template-columns: 126px minmax(170px, 1fr) 140px 88px !important;
  align-items: center !important;
}

#adminAudioStatusLine .admin-audio-progress,
.admin-audio-progress {
  height: 20px !important;
  cursor: pointer !important;
  touch-action: none !important;
  border-radius: 999px !important;
}

.home-live-now {
  display: block;
  margin-top: 2px;
  padding: 18px;
  border: 1px solid rgba(255,255,255,.16);
  background: linear-gradient(145deg, rgba(255,255,255,0.10), rgba(255,255,255,0.045));
  text-align: left;
  border-radius: 24px !important;
  overflow: hidden;
  width: 100%;
  max-width: 540px;
  min-height: 196px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}

.home-live-now.is-active {
  display: block;
}

.home-live-now h2 {
  margin: 0 0 10px;
  font-size: 0.78rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.62);
  margin-bottom: 14px;
}

.home-live-now-content {
  display: grid;
  grid-template-columns: 104px minmax(0, 1fr);
  gap: 16px;
  align-items: center;
  min-height: 128px;
}

.home-live-cover {
  width: 104px;
  height: 104px;
  background: linear-gradient(145deg, rgba(255,255,255,.12), rgba(255,255,255,.04));
  overflow: hidden;
  border-radius: 18px !important;
  border: 1px solid rgba(255,255,255,.10);
}

.home-live-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.home-live-placeholder {
  height: 100%;
  display: grid;
  place-items: center;
  font-size: .8rem;
  color: rgba(255,255,255,.56);
  width: 100%;
  padding: 10px;
  text-transform: uppercase;
  letter-spacing: .18em;
  font-weight: 900;
}

.home-live-text strong,
.home-live-text span {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.home-live-text strong {
  color: #fff;
  font-size: clamp(1.18rem, 2vw, 1.5rem);
  line-height: 1.08;
}

.home-live-text span {
  color: rgba(255,255,255,.68);
  font-size: 0.96rem;
  margin-top: 8px;
  line-height: 1.35;
  white-space: normal;
}

@media (max-width: 1024px) {
  .admin-shell.admin-shell-wide {
    width: 100% !important;
    max-width: none !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .admin-header.admin-header-compact,
  .admin-session-panel.admin-top-panel,
  .admin-gate-panel.admin-top-panel,
  .admin-live-state.admin-top-panel,
  .admin-table-wrap {
    border-radius: 0 !important;
  }

  .admin-session-panel.admin-top-panel,
  .admin-gate-panel.admin-top-panel,
  .admin-live-state.admin-top-panel {
    grid-template-columns: 1fr !important;
  }

  .admin-session-controls,
  .admin-gate-controls,
  .admin-live-actions {
    justify-content: stretch !important;
    width: 100% !important;
  }

  .admin-gate-controls .submission-gate-toggle,
  .admin-gate-controls .submission-gate-save {
    min-width: 44px !important;
  }

  #nextEventTextInput {
    max-width: none !important;
  }
}

@media (max-width: 620px) {
  .admin-header.admin-header-compact {
    grid-template-columns: minmax(0, 1fr) auto !important;
    padding: 12px 10px !important;
  }

  .admin-header.admin-header-compact h1 {
    font-size: 1.55rem !important;
  }

  .admin-live-chip {
    min-height: 34px !important;
    padding: 0 9px !important;
    font-size: .72rem !important;
  }

  .admin-top-btn.admin-top-btn-charts {
    min-height: 40px !important;
    padding: 0 13px !important;
    font-size: .84rem !important;
  }

  .admin-session-controls .session-select,
  .admin-gate-input {
    height: 36px !important;
    font-size: .8rem !important;
  }

  .admin-session-controls .new-session-btn,
  .admin-gate-controls .submission-gate-toggle,
  .admin-gate-controls .submission-gate-save,
  .admin-live-actions .live-clear-btn,
  .admin-external-link {
    height: 36px !important;
    min-height: 36px !important;
    font-size: .78rem !important;
  }

  .admin-external-link,
  .admin-live-actions .live-clear-btn {
    width: 38px !important;
    min-width: 38px !important;
  }

  .admin-table.admin-table-compact th,
  .admin-table.admin-table-compact td {
    font-size: .8rem !important;
  }

  .admin-track-lines strong {
    font-size: .9rem !important;
  }

  .admin-track-lines span {
    font-size: .78rem !important;
  }

  .admin-track-lines em {
    font-size: .72rem !important;
  }

  #adminAudioPlayer.admin-audio-player {
    grid-template-columns: auto minmax(0, 1fr) !important;
    gap: 8px !important;
  }

  #adminAudioStatusLine {
    grid-column: 1 / -1 !important;
    font-size: .95rem !important;
  }
}

@media (min-width: 1025px) {
  .admin-body {
    padding: 26px 18px calc(110px + env(safe-area-inset-bottom)) !important;
  }

  .admin-shell.admin-shell-wide {
    width: min(100%, 1020px) !important;
    max-width: 1020px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .admin-header.admin-header-compact {
    padding: 18px 0 14px !important;
  }

  .admin-session-panel.admin-top-panel,
  .admin-gate-panel.admin-top-panel,
  .admin-live-state.admin-top-panel,
  .admin-table-wrap {
    border-radius: 24px !important;
    border-left: 1px solid var(--line) !important;
    border-right: 1px solid var(--line) !important;
  }

  .admin-session-panel.admin-top-panel {
    grid-template-columns: minmax(0, .85fr) minmax(0, 1.15fr) !important;
  }

  .admin-gate-panel.admin-top-panel,
  .admin-live-state.admin-top-panel {
    grid-template-columns: auto minmax(140px, .75fr) minmax(0, 1.45fr) !important;
  }
}

.admin-gate-panel.admin-top-panel,
.admin-live-state.admin-top-panel {
  align-items: center !important;
}

.admin-gate-main,
.admin-live-state-main,
.admin-session-main {
  min-width: 0 !important;
}

.admin-live-status-line,
.admin-live-session {
  min-width: 0 !important;
  max-width: 100% !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.admin-audio-time-reset {
  appearance: none !important;
  border: 0 !important;
  background: transparent !important;
  color: #fff !important;
  padding: 0 !important;
  margin: 0 !important;
  font: inherit !important;
  font-weight: 1000 !important;
  text-align: left !important;
  cursor: pointer !important;
  text-decoration: underline !important;
  text-underline-offset: 3px !important;
}

.admin-audio-time-reset:hover {
  color: #7cff9d !important;
}

@media (max-width: 1024px) {
  html, body.admin-body {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
  }

  .admin-body {
    padding: 0 0 calc(112px + env(safe-area-inset-bottom)) !important;
  }

  .admin-shell.admin-shell-wide {
    width: 100vw !important;
    max-width: 100vw !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .admin-header.admin-header-compact,
  .admin-session-panel.admin-top-panel,
  .admin-gate-panel.admin-top-panel,
  .admin-live-state.admin-top-panel,
  .admin-table-wrap,
  .admin-archive-section {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    border-radius: 0 !important;
  }

  .admin-table-wrap {
    border-left: 0 !important;
    border-right: 0 !important;
  }

  .admin-session-panel.admin-top-panel,
  .admin-gate-panel.admin-top-panel,
  .admin-live-state.admin-top-panel {
    border-left: 0 !important;
    border-right: 0 !important;
    grid-template-columns: 1fr !important;
    gap: 7px !important;
    padding-left: max(10px, env(safe-area-inset-left)) !important;
    padding-right: max(10px, env(safe-area-inset-right)) !important;
  }

  .admin-session-controls,
  .admin-gate-controls,
  .admin-live-actions {
    width: 100% !important;
    justify-content: flex-start !important;
    flex-wrap: nowrap !important;
  }

  .admin-gate-controls .admin-external-link,
  .admin-live-actions .admin-external-link {
    margin-left: auto !important;
  }

  .admin-session-controls .session-select {
    flex: 1 1 auto !important;
    min-width: 0 !important;
  }

  .admin-gate-input {
    flex: 1 1 auto !important;
    min-width: 78px !important;
  }

  .admin-table.admin-table-compact {
    min-width: 0 !important;
    width: 100vw !important;
  }

  #adminAudioStatusLine {
    font-size: 1.14rem !important;
  }
}

@media (max-width: 620px) {
  .admin-gate-controls,
  .admin-live-actions {
    gap: 5px !important;
  }

  .admin-gate-controls .submission-gate-toggle,
  .admin-gate-controls .submission-gate-save {
    padding-left: 8px !important;
    padding-right: 8px !important;
  }

  .admin-gate-input {
    min-width: 58px !important;
    font-size: .76rem !important;
  }

  .admin-track-lines {
    min-height: 60px !important;
  }

  .admin-track-lines strong {
    font-size: 1.04rem !important;
  }

  .admin-track-lines span {
    font-size: .88rem !important;
  }

  .admin-track-lines em {
    font-size: .68rem !important;
  }

  #adminAudioStatusLine {
    font-size: 1.08rem !important;
  }
}

#adminAudioTimeElapsed,
#adminAudioTimeRemaining,
#adminAudioDuration,
#adminAudioTimeElapsed.admin-audio-time-reset {
  display: inline-block !important;
}

@media (max-width: 720px) {
  #adminAudioPlayer.admin-audio-player {
    grid-template-columns: 52px minmax(0, 1fr) !important;
    gap: 10px !important;
    min-height: 92px !important;
    padding-left: 10px !important;
    padding-right: 10px !important;
  }

  #adminAudioStatusLine {
    grid-column: 1 / -1 !important;
    grid-template-columns: 64px minmax(90px, 1fr) 96px !important;
    gap: 8px !important;
  }

  #adminAudioDuration {
    display: none !important;
  }
}

.admin-session-panel.admin-top-panel + .admin-gate-panel.admin-top-panel,
.admin-gate-panel.admin-top-panel + .admin-live-state.admin-top-panel {
  margin-top: 0 !important;
}

.admin-top-btn,
.admin-header-actions .admin-top-btn,
.admin-external-link,
.admin-session-controls .session-select,
.admin-gate-input,
#adminAudioToggle.admin-player-toggle,
.admin-audio-time-reset {
  border-radius: 10px !important;
}

.admin-table .admin-top-btn,
.admin-table button,
.admin-table .audio-play-btn,
.admin-table .status-btn,
.admin-cell-x .hide-submission-btn,
.admin-cell-x .restore-submission-btn {
  border-radius: 0 !important;
}

.admin-live-state.admin-top-panel {
  grid-template-columns: auto minmax(0, 1fr) auto !important;
}

.admin-live-status-line {
  display: block !important;
  text-align: left !important;
  white-space: nowrap !important;
}

.admin-live-status-line > span,
.admin-live-session {
  display: none !important;
}

.admin-live-status-line strong {
  display: block !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  max-width: 100% !important;
}

.admin-live-actions {
  justify-self: end !important;
  margin-left: 0 !important;
  width: auto !important;
}

#adminAudioTimeElapsed.admin-audio-time-reset {
  text-decoration: none !important;
  border: 1px solid rgba(124,255,157,.28) !important;
  background: rgba(124,255,157,.08) !important;
  padding: 8px 10px !important;
  text-align: center !important;
  min-height: 42px !important;
  min-width: 128px !important;
  justify-content: center !important;
  padding-left: 12px !important;
  padding-right: 12px !important;
  width: 128px !important;
  max-width: 128px !important;
  box-sizing: border-box !important;
  display: inline-flex !important;
  align-items: center !important;
  white-space: nowrap !important;
}

#adminAudioTimeElapsed.admin-audio-time-reset::before {
  content: "â†º ";
  font-size: .95em;
}

@media (min-width: 1025px) {
  .admin-session-panel.admin-top-panel,
  .admin-gate-panel.admin-top-panel,
  .admin-live-state.admin-top-panel {
    border-radius: 22px !important;
  }
}

@media (max-width: 1024px) {
  .admin-session-panel.admin-top-panel,
  .admin-gate-panel.admin-top-panel,
  .admin-live-state.admin-top-panel {
    border-radius: 0 !important;
    margin-bottom: 1px !important;
  }

  .admin-live-state.admin-top-panel {
    grid-template-columns: minmax(0, 1fr) auto !important;
    gap: 8px !important;
  }

  .admin-live-state .admin-panel-title {
    grid-column: 1 / -1 !important;
    margin-bottom: -3px !important;
  }

  .admin-live-state-main {
    grid-column: 1 !important;
    min-width: 0 !important;
  }

  .admin-live-actions {
    grid-column: 2 !important;
    grid-row: 2 !important;
    justify-content: flex-end !important;
    align-self: center !important;
    flex-wrap: nowrap !important;
  }

  .admin-live-status-line strong {
    font-size: .96rem !important;
    line-height: 1.12 !important;
  }

  #adminAudioPlayer.admin-audio-player {
    min-height: 104px !important;
    grid-template-columns: 54px minmax(0, 1fr) !important;
    gap: 9px 10px !important;
    padding: 10px 10px calc(10px + env(safe-area-inset-bottom)) !important;
  }

  #adminAudioStatusLine {
    grid-column: 1 / -1 !important;
    grid-template-columns: 78px minmax(90px, 1fr) 112px !important;
    gap: 9px !important;
    font-size: 1.2rem !important;
  }

  #adminAudioDuration {
    display: none !important;
  }
}

@media (max-width: 560px) {
  #adminAudioPlayer.admin-audio-player {
    min-height: 112px !important;
  }

  #adminAudioStatusLine {
    grid-template-columns: 72px minmax(72px, 1fr) 102px !important;
    font-size: 1.1rem !important;
    gap: 7px !important;
  }

  #adminAudioTimeElapsed.admin-audio-time-reset {
    padding-left: 6px !important;
    padding-right: 6px !important;
  }

  #adminAudioStatusLine .admin-audio-progress,
  .admin-audio-progress {
    height: 16px !important;
  }
}

.admin-top-btn,
.admin-header-actions .admin-top-btn,
.admin-external-link,
.admin-session-controls .session-select,
.admin-gate-input,
#adminAudioToggle.admin-player-toggle,
.admin-audio-time-reset,
.new-session-btn,
.submission-gate-toggle,
.submission-gate-save,
.live-clear-btn {
  border-radius: 10px !important;
}

@media (min-width: 1025px) {
  .admin-shell.admin-shell-wide {
    width: min(100%, 1020px) !important;
    max-width: 1020px !important;
  }

  .admin-session-panel.admin-top-panel,
  .admin-gate-panel.admin-top-panel,
  .admin-live-state.admin-top-panel {
    border-radius: 22px !important;
    margin-bottom: 1px !important;
  }

  .admin-gate-panel.admin-top-panel,
  .admin-live-state.admin-top-panel {
    grid-template-columns: auto minmax(0, 1fr) auto !important;
  }

  .admin-gate-controls,
  .admin-live-actions {
    justify-content: flex-end !important;
    justify-self: end !important;
  }
}

@media (max-width: 1024px) {
  .admin-body {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .admin-shell.admin-shell-wide,
  .admin-header.admin-header-compact,
  .admin-session-panel.admin-top-panel,
  .admin-gate-panel.admin-top-panel,
  .admin-live-state.admin-top-panel,
  .admin-table-wrap,
  .admin-archive-section {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    border-radius: 0 !important;
  }

  .admin-session-panel.admin-top-panel,
  .admin-gate-panel.admin-top-panel,
  .admin-live-state.admin-top-panel {
    border: 0 !important;
    margin-top: 0 !important;
    margin-bottom: 1px !important;
    padding: 10px 10px !important;
  }

  .admin-live-state.admin-top-panel {
    grid-template-columns: minmax(0, 1fr) auto !important;
    grid-template-areas: "title actions"
      "main actions" !important;
    align-items: center !important;
    gap: 3px 8px !important;
  }

  .admin-live-state .admin-panel-title {
    grid-area: title !important;
    margin: 0 !important;
    text-align: left !important;
  }

  .admin-live-state-main {
    grid-area: main !important;
    min-width: 0 !important;
    align-items: flex-start !important;
    text-align: left !important;
  }

  .admin-live-actions {
    grid-area: actions !important;
    justify-self: end !important;
    align-self: center !important;
    justify-content: flex-end !important;
    width: auto !important;
    min-width: max-content !important;
    gap: 6px !important;
  }

  .admin-live-status-line {
    display: block !important;
    max-width: 100% !important;
    white-space: nowrap !important;
  }

  .admin-live-status-line strong {
    display: block !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    font-size: 1rem !important;
    line-height: 1.15 !important;
  }

  #adminAudioPlayer.admin-audio-player {
    grid-template-columns: 58px minmax(0, 1fr) !important;
    min-height: 112px !important;
    gap: 8px 10px !important;
    padding: 10px 10px calc(10px + env(safe-area-inset-bottom)) !important;
  }

  #adminAudioStatusLine {
    grid-column: 1 / -1 !important;
    grid-template-columns: 92px minmax(80px, 1fr) 124px !important;
    gap: 9px !important;
    font-size: 1.34rem !important;
  }

  #adminAudioDuration {
    display: none !important;
  }
}

@media (max-width: 560px) {
  .admin-header.admin-header-compact {
    padding-left: 10px !important;
    padding-right: 10px !important;
  }

  .admin-live-actions .admin-top-btn,
  .admin-external-link {
    width: 40px !important;
    min-width: 40px !important;
  }

  #adminAudioPlayer.admin-audio-player {
    min-height: 116px !important;
  }

  #adminAudioStatusLine {
    grid-template-columns: 84px minmax(68px, 1fr) 112px !important;
    font-size: 1.22rem !important;
    gap: 7px !important;
  }

  #adminAudioStatusLine .admin-audio-progress,
  .admin-audio-progress {
    height: 18px !important;
  }
}

button,
input[type="button"],
input[type="submit"],
.nav-button,
.primary-button,
.secondary-button,
.status-btn,
.copy-btn,
.admin-top-btn,
.session-select,
.admin-gate-input,
.audio-play-btn,
.audio-play-btn-large,
.live-clear-btn,
.new-session-btn,
.submission-gate-toggle,
.submission-gate-save,
.admin-sort-votes-btn,
#adminAudioToggle.admin-player-toggle,
#adminAudioTimeElapsed.admin-audio-time-reset {
  border-radius: 10px !important;
}

.vote-count-pill,
.status-pill,
.audio-status-pill,
.live-vote-qr,
.live-vote-box,
.tag,
.pill,
.round-pill {
  border-radius: 999px !important;
}

#adminAudioToggle.admin-player-toggle,
.audio-play-btn,
.audio-play-btn-large {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  line-height: 1 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

@media (max-width: 1024px) {
  #adminAudioStatusLine {
    grid-template-columns: 112px minmax(80px, 1fr) 128px !important;
  }

  #adminAudioTimeElapsed.admin-audio-time-reset {
    min-width: 104px !important;
  }
}

@media (max-width: 560px) {
  #adminAudioStatusLine {
    grid-template-columns: 104px minmax(58px, 1fr) 112px !important;
    gap: 6px !important;
  }

  #adminAudioTimeElapsed.admin-audio-time-reset {
    min-width: 98px !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
  }
}

.admin-detail-actionbar .audio-play-btn-large,
.admin-detail-actionbar .live-btn,
.admin-detail-actionbar .audio-delete-btn,
.admin-detail-actionbar .hide-submission-btn,
.admin-detail-actionbar .restore-submission-btn,
.admin-expand-card > .suno-transfer-bar .suno-transfer-btn.copy-btn,
.suno-transfer-bar .suno-transfer-btn,
.submission-gate-toggle,
.submission-gate-save,
.new-session-btn,
.live-clear-btn,
button.admin-top-btn:not(.admin-external-link),
button.status-btn:not(.vote-count-pill) {
  border-radius: 10px !important;
}

.admin-external-link,
.vote-count-pill,
.vote-pill,
.admin-vote-pill,
.status-pill,
.audio-status-pill,
.live-vote-qr,
.live-vote-box,
.tag,
.pill,
.round-pill {
  border-radius: 999px !important;
}

#adminAudioStatusLine .admin-audio-progress,
.admin-audio-status-line .admin-audio-progress {
  position: relative !important;
  left: auto !important;
  right: auto !important;
  top: auto !important;
  transform: none !important;
  display: block !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: 100% !important;
  margin: 0 !important;
  grid-column: auto !important;
  z-index: 1 !important;
  min-height: 16px !important;
  align-self: center !important;
}

#adminAudioTimeRemaining {
  justify-self: end !important;
  white-space: nowrap !important;
}

@media (min-width: 721px) {
  #adminAudioPlayer.admin-audio-player {
    grid-template-columns: 60px minmax(180px, .85fr) minmax(0, 1.65fr) !important;
  }

  #adminAudioStatusLine.admin-audio-status-line {
    grid-template-columns: 128px minmax(120px, 1fr) max-content max-content !important;
    column-gap: 14px !important;
  }
}

@media (max-width: 720px) {
  #adminAudioPlayer.admin-audio-player {
    grid-template-columns: 58px minmax(0, 1fr) !important;
    grid-template-areas: "toggle info"
      "status status" !important;
    gap: 9px 10px !important;
    min-height: 118px !important;
    padding: 10px 10px calc(10px + env(safe-area-inset-bottom)) !important;
  }

  #adminAudioToggle.admin-player-toggle {
    grid-area: toggle !important;
  }

  #adminAudioPlayer .admin-audio-player-main {
    grid-area: info !important;
  }

  #adminAudioStatusLine.admin-audio-status-line {
    grid-area: status !important;
    grid-template-columns: 116px minmax(0, 1fr) max-content !important;
    column-gap: 10px !important;
    font-size: 1.22rem !important;
  }

  #adminAudioTimeElapsed.admin-audio-time-reset {
    width: 116px !important;
    min-width: 116px !important;
    max-width: 116px !important;
  }

  #adminAudioDuration.admin-audio-duration {
    display: none !important;
  }
}

@media (max-width: 420px) {
  #adminAudioStatusLine.admin-audio-status-line {
    grid-template-columns: 106px minmax(0, 1fr) max-content !important;
    column-gap: 8px !important;
    font-size: 1.08rem !important;
  }

  #adminAudioTimeElapsed.admin-audio-time-reset {
    width: 106px !important;
    min-width: 106px !important;
    max-width: 106px !important;
  }
}

.live-vote-box,
.live-vote-qr {
  border-radius: 10px !important;
}

.admin-external-link,
.admin-top-panel .admin-external-link,
.admin-gate-controls .admin-external-link,
.admin-live-actions .admin-external-link,
.admin-header-actions .admin-top-btn,
.nav-button,
.primary-button,
.secondary-button,
.status-btn,
.copy-btn,
.admin-top-btn,
.audio-play-btn,
.audio-play-btn-large,
.live-btn,
.audio-delete-btn,
.new-session-btn,
.submission-gate-toggle,
.submission-gate-save,
.live-clear-btn,
.chart-close-btn,
#adminAudioToggle.admin-player-toggle,
#adminAudioTimeElapsed.admin-audio-time-reset {
  border-radius: 10px !important;
}

.vote-count-pill,
.vote-pill,
.admin-vote-pill,
.status-pill,
.audio-status-pill,
.pill,
.round-pill {
  border-radius: 999px !important;
}

.admin-gate-controls .submission-gate-toggle {
  background: rgba(185, 70, 70, .72) !important;
  border-color: rgba(255, 148, 148, .52) !important;
  color: #fff !important;
  order: 2 !important;
}

.admin-gate-controls .admin-gate-input {
  order: 1 !important;
  min-width: 0 !important;
  flex: 1 1 220px !important;
}

.admin-gate-controls .submission-gate-save {
  order: 3 !important;
}

.admin-gate-controls .admin-external-link {
  order: 4 !important;
}

.admin-gate-controls .submission-gate-toggle,
.admin-gate-controls .submission-gate-save,
.admin-gate-controls .admin-external-link {
  flex: 0 0 auto !important;
}

.admin-table.admin-table-compact th.admin-track-head,
.admin-table.admin-table-compact th:nth-child(3) {
  text-align: left !important;
}

.admin-table.admin-table-compact th.admin-col-cover-head,
.admin-table.admin-table-compact th.admin-play-head,
.admin-table.admin-table-compact th:nth-child(1),
.admin-table.admin-table-compact th:nth-child(5) {
  color: transparent !important;
  font-size: 0 !important;
}

.admin-table.admin-table-compact th.admin-col-cover-head::before,
.admin-table.admin-table-compact th.admin-play-head::before,
.admin-table.admin-table-compact th:nth-child(1)::before,
.admin-table.admin-table-compact th:nth-child(5)::before {
  content: "" !important;
}

.admin-cell-x .hide-submission-btn,
.admin-cell-x .restore-submission-btn,
.admin-table .hide-submission-btn,
.admin-table .restore-submission-btn {
  border-radius: 0 !important;
}

.admin-track-lines strong,
.admin-track-lines span,
.admin-track-lines em {
  display: block !important;
  max-width: 100% !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

#adminAudioTimeElapsed.admin-audio-time-reset,
#adminAudioTimeRemaining {
  align-self: center !important;
}

.home-gate-message {
  margin: -6px auto 0 !important;
  max-width: 520px;
  color: rgba(255,255,255,.72);
  font-weight: 800;
  line-height: 1.35;
  margin-top: 18px !important;
  font-size: 0.98rem;
}

#startFlowBtn:disabled {
  opacity: .62;
  cursor: not-allowed;
}

@media (max-width: 720px) {
  #adminAudioPlayer.admin-audio-player {
    grid-template-columns: 58px minmax(0, 1fr) !important;
    grid-template-areas: "toggle info"
      "status status" !important;
    gap: 8px 10px !important;
    min-height: 132px !important;
    padding: 10px 10px 14px !important;
    padding-bottom: max(14px, env(safe-area-inset-bottom)) !important;
  }

  #adminAudioStatusLine.admin-audio-status-line {
    grid-template-columns: 118px minmax(90px, 1fr) max-content !important;
    column-gap: 10px !important;
    min-height: 36px !important;
  }

  #adminAudioTimeElapsed.admin-audio-time-reset {
    width: 118px !important;
    min-width: 118px !important;
    max-width: 118px !important;
  }

  .admin-live-actions .live-clear-btn,
  .admin-live-actions .admin-external-link {
    width: 40px !important;
    min-width: 40px !important;
    height: 38px !important;
  }

  .admin-track-lines {
    min-height: 70px !important;
    padding: 7px 10px !important;
  }

  .admin-track-lines strong {
    font-size: 1.08rem !important;
  }

  .admin-track-lines span {
    font-size: .92rem !important;
  }

  .admin-track-lines em {
    font-size: .68rem !important;
  }
}

@media (max-width: 420px) {
  #adminAudioPlayer.admin-audio-player {
    min-height: 136px !important;
  }

  #adminAudioStatusLine.admin-audio-status-line {
    grid-template-columns: 112px minmax(74px, 1fr) max-content !important;
    column-gap: 8px !important;
  }

  #adminAudioTimeElapsed.admin-audio-time-reset {
    width: 112px !important;
    min-width: 112px !important;
    max-width: 112px !important;
  }
}

.admin-table.admin-table-compact tbody tr.admin-row > td {
  position: relative !important;
}

.admin-table.admin-table-compact tbody tr.admin-row > td.admin-cell-x,
.admin-table.admin-table-compact tbody tr.admin-row > td.audio-cell {
  padding: 0 !important;
  overflow: hidden !important;
}

.admin-table.admin-table-compact tbody tr.admin-row > td.admin-cell-x .hide-submission-btn,
.admin-table.admin-table-compact tbody tr.admin-row > td.admin-cell-x .restore-submission-btn,
.admin-table.admin-table-compact tbody tr.admin-row > td.audio-cell .audio-play-btn,
.admin-table.admin-table-compact tbody tr.admin-row > td.audio-cell .audio-status-pill {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  min-height: 100% !important;
  max-height: none !important;
  margin: 0 !important;
  padding: 0 !important;
  border-radius: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.admin-table.admin-table-compact tbody tr.admin-row > td.admin-cell-x .hide-submission-btn {
  background: rgba(160, 56, 68, .62) !important;
}

.admin-table.admin-table-compact tbody tr.admin-row > td.audio-cell .audio-play-btn {
  border-radius: 0 !important;
}

.admin-table.admin-table-compact tbody tr.admin-row > td.audio-cell .audio-play-btn::before,
.admin-table.admin-table-compact tbody tr.admin-row > td.audio-cell .audio-play-btn::after,
.admin-table.admin-table-compact tbody tr.admin-row > td.admin-cell-x .hide-submission-btn::before,
.admin-table.admin-table-compact tbody tr.admin-row > td.admin-cell-x .hide-submission-btn::after {
  border-radius: 0 !important;
}

.live-charts-view {
  position: fixed;
  inset: 0;
  width: 100vw;
  height: 100dvh;
  padding: clamp(34px, 3.8vw, 72px) clamp(58px, 6vw, 116px) !important;
  z-index: 6;
  display: grid;
  place-items: center;
  align-items: stretch !important;
  justify-items: stretch !important;
}

.live-charts-view.hidden {
  display: none !important;
}

.live-charts-shell {
  width: 100% !important;
  height: 100% !important;
  display: grid;
  grid-template-rows: 1fr !important;
  gap: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  overflow: visible !important;
  position: relative;
  max-width: none !important;
  max-height: none !important;
}

.live-charts-shell::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(90deg, rgba(255,255,255,.06) 0 1px, transparent 1px 100%),
    linear-gradient(rgba(255,255,255,.045) 0 1px, transparent 1px 100%);
  background-size: 86px 86px;
  mask-image: radial-gradient(circle at 50% 50%, #000 0 48%, transparent 76%);
  opacity: .38;
  display: none !important;
}

.live-charts-header {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: flex-end !important;
  justify-content: space-between;
  gap: 24px;
  padding: 0 clamp(6px, .5vw, 12px) !important;
}

.live-charts-header span {
  display: block;
  color: #7cff9d !important;
  font-size: clamp(.9rem, 1vw, 1.25rem);
  font-weight: 950;
  letter-spacing: .34em;
  text-transform: uppercase;
  margin: 0 0 10px;
}

.live-charts-header h1 {
  margin: 0;
  color: #fff;
  font-size: clamp(5.2rem, 8.8vw, 10.8rem) !important;
  line-height: .78 !important;
  letter-spacing: -.085em;
  text-transform: uppercase;
  text-shadow: 0 18px 70px rgba(0,0,0,.7);
}

.live-charts-header strong {
  flex: 0 0 auto;
  max-width: 40vw;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  padding: 14px 18px;
  border-radius: 10px !important;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.10) !important;
  color: rgba(255,255,255,.78);
  font-size: clamp(.9rem, 1.15vw, 1.35rem);
  font-weight: 950;
  border-color: rgba(255,255,255,.18) !important;
}

.live-charts-table {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-rows: repeat(5, minmax(0, 1fr)) !important;
  gap: clamp(10px, 1.15vw, 20px) !important;
  min-height: 0 !important;
  height: 100% !important;
  align-content: stretch !important;
}

.live-chart-row {
  min-height: 0 !important;
  display: grid;
  grid-template-columns: clamp(74px, 6vw, 118px) clamp(86px, 6.4vw, 124px) minmax(0, 1fr) clamp(82px, 6.2vw, 132px) clamp(124px, 9.4vw, 184px) !important;
  align-items: center;
  gap: clamp(16px, 1.55vw, 30px) !important;
  padding: clamp(9px, .95vw, 18px) clamp(16px, 1.75vw, 30px) !important;
  border: 1px solid rgba(255,255,255,.11);
  border-radius: 10px !important;
  background: linear-gradient(90deg, rgba(255,255,255,.13), rgba(255,255,255,.045)) !important;
  box-shadow: 0 12px 38px rgba(0,0,0,.22);
  overflow: hidden;
  position: relative;
}

.live-chart-rank-1,
.live-chart-rank-2,
.live-chart-rank-3 {
  background: linear-gradient(90deg, rgba(124,255,157,.18), rgba(255,255,255,.055));
  border-color: rgba(124,255,157,.22);
}

.live-chart-rank {
  color: rgba(255,255,255,.94);
  font-size: clamp(3.7rem, 5vw, 7rem) !important;
  font-weight: 1000;
  letter-spacing: -.08em;
  text-align: center;
  opacity: .96;
}

.live-chart-cover {
  width: clamp(86px, 6.4vw, 124px) !important;
  aspect-ratio: 1 / 1;
  border-radius: 10px !important;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.13);
  background: rgba(0,0,0,.26);
  box-shadow: 0 10px 28px rgba(0,0,0,.32);
}

.live-chart-cover img,
.live-chart-cover-placeholder {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  object-fit: cover;
  color: rgba(255,255,255,.54);
  font-weight: 1000;
  letter-spacing: -.08em;
  background: radial-gradient(circle at 30% 25%, rgba(255,0,160,.42), transparent 58%), #10101a;
}

.live-chart-track {
  min-width: 0;
  display: grid;
  gap: clamp(4px, .4vw, 8px) !important;
  align-content: center;
}

.live-chart-track strong,
.live-chart-track span,
.live-chart-track em {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.live-chart-track strong {
  color: #fff;
  font-size: clamp(2rem, 3vw, 4.35rem) !important;
  line-height: .98 !important;
  letter-spacing: -.04em;
  font-weight: 1000;
}

.live-chart-track span {
  color: rgba(255,255,255,.82);
  font-size: clamp(1.05rem, 1.42vw, 1.88rem) !important;
  font-weight: 850;
}

.live-chart-track em {
  color: #7cff9d;
  font-size: clamp(.82rem, 1vw, 1.18rem) !important;
  font-style: normal;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
  opacity: .82;
}

.live-chart-votes {
  justify-self: end;
  min-width: clamp(124px, 9.4vw, 184px) !important;
  display: grid;
  place-items: center;
  padding: clamp(10px, .9vw, 16px) clamp(12px, 1vw, 18px) !important;
  border-radius: 10px !important;
  background: rgba(0,0,0,.28);
  border: 1px solid rgba(255,255,255,.10);
}

.live-chart-votes strong {
  color: #7cff9d;
  font-size: clamp(2.65rem, 4vw, 5.4rem) !important;
  line-height: .9;
  font-weight: 1000;
}

.live-chart-votes span {
  margin-top: 5px;
  color: rgba(255,255,255,.60);
  font-size: clamp(.62rem, .78vw, .85rem);
  font-weight: 950;
  letter-spacing: .18em;
  text-transform: uppercase;
}

.live-chart-empty {
  height: 100%;
  display: grid;
  place-items: center;
  color: rgba(255,255,255,.70);
  font-size: clamp(2.6rem, 5vw, 6.8rem) !important;
  font-weight: 1000;
  letter-spacing: -.06em;
  min-height: 100% !important;
}

.admin-live-mode-switch {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 10px;
  background: rgba(0,0,0,.20);
}

.admin-live-mode-switch .live-mode-btn {
  min-width: 0 !important;
  width: auto !important;
  height: 32px !important;
  min-height: 32px !important;
  padding: 0 10px !important;
  border-radius: 8px !important;
  font-size: .68rem !important;
  letter-spacing: .02em !important;
  background: transparent !important;
  border-color: transparent !important;
}

.admin-live-mode-switch .live-mode-btn.is-active {
  color: #06110b !important;
  background: #7cff9d !important;
  border-color: rgba(124,255,157,.65) !important;
}

.admin-live-state.is-live-charts {
  border-color: rgba(255,139,75,.42) !important;
  background: linear-gradient(135deg, rgba(255,139,75,.18), rgba(124,255,157,.10)), rgba(4,10,18,.72) !important;
}

@media (max-width: 760px) {
  .admin-live-mode-switch .live-mode-btn {
    padding: 0 7px !important;
    font-size: .62rem !important;
  }

  .admin-live-mode-switch {
    gap: 2px;
  }
}

.live-charts-now {
  justify-self: end;
  max-width: min(760px, 58vw);
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  border-radius: 10px;
  border: 1px solid rgba(124,255,157,.24);
  background: linear-gradient(90deg, rgba(124,255,157,.16), rgba(255,255,255,.06));
  box-shadow: 0 18px 58px rgba(0,0,0,.26);
  color: #fff;
}

.live-charts-now.hidden {
  display: none !important;
}

.live-charts-now span {
  color: #7cff9d;
  font-size: clamp(.66rem, .78vw, .9rem);
  font-weight: 1000;
  letter-spacing: .18em;
  text-transform: uppercase;
  white-space: nowrap;
}

.live-charts-now strong,
.live-charts-now em {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.live-charts-now strong {
  font-size: clamp(1rem, 1.45vw, 1.85rem);
  line-height: 1;
  font-style: normal;
  font-weight: 1000;
}

.live-charts-now em {
  color: rgba(255,255,255,.72);
  font-size: clamp(.78rem, 1vw, 1.2rem);
  font-style: normal;
  font-weight: 850;
}

@media (max-width: 900px) {
  .live-charts-view {
    padding: 34px 22px !important;
  }

  .live-charts-header {
    align-items: flex-start !important;
    flex-direction: column !important;
  }

  .live-charts-header strong {
    max-width: 100% !important;
  }

  .live-charts-now {
    justify-self: stretch;
    max-width: none;
    grid-template-columns: 1fr;
    gap: 4px;
  }

  .live-chart-row {
    grid-template-columns: 42px 56px minmax(0, 1fr) 64px !important;
    gap: 10px !important;
    padding: 9px 10px !important;
  }

  .live-chart-cover {
    width: 56px !important;
  }

  .live-chart-rank {
    font-size: 2.25rem !important;
  }

  .live-chart-track strong {
    font-size: 1.3rem !important;
  }

  .live-chart-track span {
    font-size: .9rem !important;
  }

  .live-chart-votes {
    min-width: 58px !important;
    padding: 8px 6px !important;
  }

  .live-chart-votes strong {
    font-size: 1.7rem !important;
  }
}

.live-charts-header,
.live-charts-now {
  display: none !important;
}

.live-chart-row.is-now-playing {
  border-color: rgba(124,255,157,.48) !important;
  background: linear-gradient(90deg, rgba(124,255,157,.20), rgba(255,255,255,.055) 58%, rgba(124,255,157,.10)) !important;
  box-shadow: 0 0 0 1px rgba(124,255,157,.16), 0 24px 76px rgba(0,0,0,.32), 0 0 42px rgba(124,255,157,.10) !important;
  transform-origin: center center;
  animation: liveChartNowPulse 1.15s ease-in-out infinite;
  will-change: transform;
}

.live-chart-row.is-now-playing::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: clamp(5px, .45vw, 9px);
  background: #7cff9d;
  box-shadow: 0 0 24px rgba(124,255,157,.72);
}

.live-chart-playing-wave {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(5px, .45vw, 9px);
  min-width: 0;
  height: 100%;
  opacity: 0;
  transform: scaleX(.86);
  transition: opacity .2s ease, transform .2s ease;
}

.live-chart-row.is-now-playing .live-chart-playing-wave {
  opacity: 1;
  transform: scaleX(1);
}

.live-chart-playing-wave i {
  display: block;
  width: clamp(5px, .5vw, 9px);
  height: clamp(18px, 1.8vw, 34px);
  border-radius: 999px;
  background: linear-gradient(180deg, #7cff9d, #caff3d);
  box-shadow: 0 0 18px rgba(124,255,157,.42);
  animation: liveChartWave 1.05s ease-in-out infinite;
  transform-origin: center;
}

.live-chart-playing-wave i:nth-child(2) {
  animation-delay: .10s;
}

.live-chart-playing-wave i:nth-child(3) {
  animation-delay: .20s;
}

.live-chart-playing-wave i:nth-child(4) {
  animation-delay: .30s;
}

.live-chart-playing-wave i:nth-child(5) {
  animation-delay: .40s;
}

@keyframes liveChartWave {
  0%, 100% { transform: scaleY(.38); opacity: .55; }
  45% { transform: scaleY(1.55); opacity: 1; }
}

@keyframes liveChartNowPulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.018); }
}

@media (prefers-reduced-motion: reduce) {
  .live-chart-row.is-now-playing {
    animation: none !important;
  }
}

@media (max-width: 900px) {
  .live-charts-view {
    padding: 24px 14px !important;
  }

  .live-chart-row {
    grid-template-columns: 36px 52px minmax(0, 1fr) 44px 58px !important;
    gap: 8px !important;
    padding: 8px 9px !important;
  }

  .live-chart-playing-wave {
    gap: 3px;
  }

  .live-chart-playing-wave i {
    width: 4px;
    height: 18px;
  }
}

.home-choice-actions {
  display: grid;
  gap: 14px;
  margin-top: 0;
  width: 100%;
  max-width: 540px;
}

.secondary-home-cta {
  width: 100%;
  justify-content: center;
  text-align: center;
  border-radius: 22px;
}

.request-screen.active {
  display: grid;
  place-items: center;
  min-height: 100dvh;
  padding: calc(env(safe-area-inset-top, 0px) + 72px) clamp(14px, 4vw, 24px) calc(env(safe-area-inset-bottom, 0px) + 24px);
}

.visitor-body.form-mode:not(.success-mode) .request-screen.active {
  display: grid;
  place-items: center;
  overflow: hidden;
}

.request-form-card {
  position: relative;
  width: min(92vw, 620px);
  margin: 0 auto;
}

.request-nav-bar {
  position: fixed;
  top: calc(env(safe-area-inset-top, 0px) + clamp(10px, 2vw, 18px));
  left: 50%;
  transform: translate3d(-50%, 0, 0);
  z-index: 950;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  width: min(calc(100% - clamp(24px, 4.8vw, 48px)), 620px);
  pointer-events: none;
}

.request-nav-bar > button {
  pointer-events: auto;
}

.request-back-btn {
  position: static;
  z-index: 2;
}

.request-home-btn {
  min-width: 112px;
}

.request-card {
  gap: 14px;
}

.request-submit-btn {
  width: 100%;
  margin-top: 6px;
}

.admin-content-tabs {
  display: flex;
  gap: 8px;
  margin: 18px 0 12px;
}

.admin-content-tab {
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: var(--text);
  border-radius: 999px;
  padding: 9px 14px;
  font-weight: 900;
  cursor: pointer;
}

.admin-content-tab.is-active {
  background: var(--accent);
  color: #06101f;
  border-color: transparent;
}

.admin-content-tab span {
  opacity: .78;
  margin-left: 4px;
}

.admin-tab-panel {
  display: none;
}

.admin-tab-panel.is-active {
  display: block;
}

.admin-request-table th,
.admin-request-table td {
  vertical-align: middle;
}

.admin-request-col-time {
  width: 80px;
}

.admin-request-col-name {
  width: 150px;
}

.admin-request-col-action {
  width: 130px;
}

.admin-request-time,
.admin-request-name {
  color: var(--muted);
  font-weight: 800;
}

.request-live-btn,
.request-archive-btn,
.request-restore-btn {
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: var(--text);
  border-radius: 10px;
  padding: 8px 10px;
  font-weight: 900;
  cursor: pointer;
}

.request-live-btn.is-live,
.admin-request-row.is-live-row .request-live-btn {
  background: #7cff9d !important;
  color: #07100b !important;
  border-color: transparent;
}

.admin-request-row.is-live-row {
  box-shadow: inset 3px 0 0 var(--accent);
}

.admin-live-status-line em {
  display: block;
  margin-top: 2px;
  color: var(--muted);
  font-size: .78rem;
  font-style: normal;
}

.live-screen.is-request .live-record {
  animation: none;
}

.live-request-placeholder {
  font-size: clamp(1.3rem, 3vw, 2.3rem);
  letter-spacing: .08em;
  text-transform: uppercase;
  position: relative;
  isolation: isolate;
  color: #fff !important;
  text-shadow: 0 3px 18px rgba(0,0,0,.34);
  background: radial-gradient(circle at 18% 18%, rgba(255,255,255,.72), transparent 0 10%, transparent 28%),
    radial-gradient(circle at 18% 22%, rgba(255,92,208,.88), transparent 0 26%, transparent 48%),
    radial-gradient(circle at 82% 18%, rgba(255,209,74,.92), transparent 0 24%, transparent 48%),
    radial-gradient(circle at 78% 82%, rgba(99,255,179,.86), transparent 0 26%, transparent 50%),
    linear-gradient(135deg, #6d5dfc 0%, #18c8ff 36%, #ff4fc3 68%, #ffd257 100%) !important;
}

.admin-request-table .admin-track-cell {
  width: auto;
}

.admin-request-lines em {
  color: rgba(124,255,157,.88) !important;
  letter-spacing: .055em !important;
  text-transform: uppercase !important;
  font-weight: 900 !important;
}

.request-live-btn,
.request-archive-btn,
.request-restore-btn,
.admin-table .request-live-btn,
.admin-table .request-archive-btn,
.admin-table .request-restore-btn {
  border-radius: 10px !important;
}

.live-mode-btn.is-disabled,
.live-mode-btn:disabled {
  opacity: .38 !important;
  filter: grayscale(1) !important;
  cursor: not-allowed !important;
  pointer-events: none !important;
}

.live-mode-btn.is-disabled:hover,
.live-mode-btn:disabled:hover {
  transform: none !important;
  box-shadow: none !important;
}

.live-screen.is-request .live-cover-frame {
  border-color: rgba(255,255,255,.28) !important;
  box-shadow: 0 34px 90px rgba(0,0,0,.46),
    0 0 90px rgba(86,190,255,.26) !important;
}

.live-request-placeholder::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: repeating-linear-gradient(45deg, rgba(255,255,255,.16) 0 2px, transparent 2px 13px),
    radial-gradient(circle at center, transparent 0 38%, rgba(0,0,0,.18) 72%);
  mix-blend-mode: soft-light;
}

.live-request-placeholder::after {
  content: "ðŸŽ§";
  display: block;
  position: absolute;
  left: 50%;
  top: 58%;
  transform: translate(-50%, -50%);
  font-size: clamp(3.8rem, 9vw, 8rem);
  opacity: .18;
  z-index: -1;
}

.home-live-cover,
.home-live-cover img,
.home-live-placeholder {
  border-radius: 16px !important;
}

.request-live-btn.is-disabled,
.request-live-btn:disabled {
  opacity: .38 !important;
  filter: grayscale(1) !important;
  cursor: not-allowed !important;
  pointer-events: none !important;
}

.admin-table.admin-table-compact:not(.admin-request-table) col.admin-col-cover,
.admin-table.admin-table-compact:not(.admin-request-table) th:nth-child(1),
.admin-table.admin-table-compact:not(.admin-request-table) td:nth-child(1) {
  width: 100px !important;
  min-width: 100px !important;
  max-width: 100px !important;
}

.admin-table.admin-table-compact:not(.admin-request-table) col.admin-col-track,
.admin-table.admin-table-compact:not(.admin-request-table) th:nth-child(3),
.admin-table.admin-table-compact:not(.admin-request-table) td:nth-child(3) {
  width: calc(100% - 272px) !important;
}

.admin-table.admin-table-compact:not(.admin-request-table) .admin-row {
  height: 100px !important;
  max-height: 100px !important;
}

.admin-table.admin-table-compact:not(.admin-request-table) .admin-row > td {
  height: 100px !important;
  max-height: 100px !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.admin-table.admin-table-compact:not(.admin-request-table) .admin-cover-cell,
.admin-table.admin-table-compact:not(.admin-request-table) .admin-cover-cell img,
.admin-table.admin-table-compact:not(.admin-request-table) .admin-cover-placeholder {
  width: 100px !important;
  height: 100px !important;
  min-width: 100px !important;
  max-width: 100px !important;
}

.admin-table.admin-table-compact:not(.admin-request-table) .admin-track-lines,
.admin-table.admin-table-compact:not(.admin-request-table) .audio-cell .audio-play-btn,
.admin-table.admin-table-compact:not(.admin-request-table) .admin-cell-x .hide-submission-btn,
.admin-table.admin-table-compact:not(.admin-request-table) .admin-cell-x .restore-submission-btn,
.admin-table.admin-table-compact:not(.admin-request-table) .audio-status-pill.missing-audio {
  height: 100px !important;
  min-height: 100px !important;
}

.admin-brand-wrap {
  display: flex;
  align-items: center;
  min-width: 0;
}

.admin-logo {
  display: block;
  width: clamp(190px, 24vw, 300px);
  max-width: 100%;
  height: auto;
}

.logo {margin-top: 40px; margin-bottom: 40px;}

@media (max-width: 760px) {
  .home-logo {
    width: min(100%, 360px);
    margin-bottom: 0px;
  }

  .admin-logo {
    width: clamp(160px, 42vw, 220px);
  }
}

.home-cta,
.home-choice-actions .primary-button,
.home-choice-actions .secondary-button {
  width: 100%;
  min-height: 68px;
  padding: 18px 28px;
  font-size: clamp(1rem, 1.55vw, 1.16rem);
  letter-spacing: -0.02em;
}

.home-live-now.is-idle {
  opacity: 0.96;
}

.home-live-cover img,
.home-live-placeholder {
  border-radius: 18px !important;
}

.home-live-text {
  align-self: center;
}

@media (max-width: 900px) {
  .home-card {
    width: min(100%, 700px);
    min-height: 0;
    padding: clamp(30px, 5.8vw, 48px) clamp(20px, 4.4vw, 34px);
  }
}

@media (max-width: 760px) {
  .home-screen {
    padding: 14px;
  }

  .home-card {
    width: 100%;
    min-height: 0;
    gap: 16px;
    padding: 28px 18px;
    justify-content: center;
  }

  .home-choice-actions,
  .home-live-now {
    max-width: none;
  }

  .home-live-now {
    min-height: 174px;
    padding: 16px;
  }

  .home-live-now-content {
    min-height: 112px;
    grid-template-columns: 88px minmax(0, 1fr);
    gap: 14px;
  }

  .home-live-cover {
    width: 88px;
    height: 88px;
  }

  .home-live-text strong {
    font-size: 1.1rem;
  }

  .home-live-text span {
    font-size: 0.9rem;
  }
}

.home-logo {
  width: min(100%, 360px);
  margin: 0;
}

@media (min-width: 761px) {
  .home-screen.active {
    min-height: 0;
    height: 100dvh;
    overflow: hidden;
  }
}

@media (max-width: 900px) {
  .home-card {
    padding: clamp(38px, 5.4vw, 58px) clamp(24px, 4.4vw, 42px);
  }

  .home-logo {
    width: min(100%, 360px);
    margin-bottom: 0;
  }
}

@media (max-width: 760px) {
  .home-card {
    padding: 32px 20px;
  }

  .home-logo {
    width: min(100%, 360px);
    margin-bottom: 0;
  }
}

.evolink-bar {
    margin: 10px 0 14px;
    padding: 10px 12px;
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 14px;
    background: rgba(255,255,255,0.045);
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.evolink-main {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.evolink-state {
    font-size: 12px;
    color: rgba(255,255,255,0.74);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 999px;
    padding: 4px 9px;
    background: rgba(0,0,0,0.18);
}

.evolink-state.is-done {
    color: #b8ffd5;
    border-color: rgba(100,255,170,0.28);
}

.evolink-state.is-error,
.evolink-error {
    color: #ffb8b8;
}

.evolink-error {
    font-size: 12px;
    line-height: 1.35;
}

.evolink-task {
    font-size: 11px;
    opacity: 0.55;
}

.evolink-disabled {
    opacity: 0.66;
}

.evolink-start-btn[disabled] {
    opacity: 0.55;
    pointer-events: none;
}

.audio-versions-box {
  margin-top: 12px;
  padding: 12px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 14px;
  background: rgba(255,255,255,.04);
}
.audio-version-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  padding: 10px 0;
  border-top: 1px solid rgba(255,255,255,.08);
}
.audio-version-row:first-of-type { border-top: 0; }
.audio-version-row.is-active { opacity: 1; }
.audio-version-info {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
}
.audio-version-info span {
  opacity: .75;
  font-size: .86rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 44vw;
}
.audio-version-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.audio-version-active-badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 5px 9px;
  background: rgba(34,197,94,.16);
  color: #86efac;
  font-size: .78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
}
@media (max-width: 720px) {
  .audio-version-row { align-items: flex-start; flex-direction: column; }
  .audio-version-info span { max-width: 100%; }
  .audio-version-actions { justify-content: flex-start; }
}

/* Generation Profile admin panel */
.admin-generation-panel {
    display: block;
}
.admin-generation-panel details {
    width: 100%;
}
.admin-generation-panel summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    cursor: pointer;
    list-style: none;
}
.admin-generation-panel summary::-webkit-details-marker {
    display: none;
}
.admin-generation-panel summary > span {
    display: flex;
    align-items: center;
    gap: .75rem;
    flex-wrap: wrap;
}
.admin-generation-panel summary em {
    font-style: normal;
    opacity: .72;
    font-size: .82rem;
}
.generation-profile-form {
    display: grid;
    gap: .9rem;
    margin-top: 1rem;
}
.generation-profile-form label {
    display: grid;
    gap: .38rem;
    font-size: .82rem;
    color: rgba(255,255,255,.76);
}
.generation-profile-form input[type="text"],
.generation-profile-form input[type="number"],
.generation-profile-form textarea {
    width: 100%;
    border: 1px solid rgba(255,255,255,.16);
    background: rgba(0,0,0,.22);
    color: #fff;
    border-radius: 14px;
    padding: .7rem .8rem;
    font: inherit;
    resize: vertical;
    outline: none;
}
.generation-profile-form textarea:focus,
.generation-profile-form input:focus {
    border-color: rgba(255,255,255,.36);
    background: rgba(0,0,0,.32);
}
.generation-profile-grid {
    display: grid;
    grid-template-columns: minmax(220px, 1.3fr) repeat(2, minmax(120px, .35fr));
    gap: .8rem;
    align-items: end;
}
.generation-profile-grid-wide {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: start;
}
.generation-profile-toggle {
    display: flex !important;
    grid-template-columns: auto 1fr;
    align-items: center;
    gap: .55rem !important;
    padding: .65rem .8rem;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 14px;
    background: rgba(255,255,255,.045);
}
.generation-profile-toggle input {
    width: auto;
}
.generation-profile-actions {
    display: flex;
    align-items: center;
    gap: .8rem;
}
.generation-profile-status {
    opacity: .75;
    font-size: .82rem;
}
@media (max-width: 920px) {
    .generation-profile-grid,
    .generation-profile-grid-wide {
        grid-template-columns: 1fr;
    }
}

/* Setup modal */
.admin-top-btn-setup {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.18);
}

.admin-setup-modal.hidden { display: none; }
.admin-setup-modal {
  position: fixed;
  inset: 0;
  z-index: 130;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px;
}
.admin-setup-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.76);
  backdrop-filter: blur(10px);
}
.admin-setup-panel {
  position: relative;
  width: min(1040px, 100%);
  height: min(840px, 92vh);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border-radius: 26px;
  background: linear-gradient(180deg, rgba(21,24,35,.98), rgba(13,16,26,.98));
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 30px 100px rgba(0,0,0,.58);
}
.admin-setup-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  padding: 18px 20px 14px;
  border-bottom: 1px solid rgba(255,255,255,.09);
}
.admin-setup-header div { display: grid; gap: .18rem; }
.admin-setup-header strong { font-size: 1.25rem; }
.admin-setup-header em {
  font-style: normal;
  color: rgba(255,255,255,.62);
  font-size: .88rem;
}
.admin-setup-tabs {
  display: flex;
  gap: 8px;
  padding: 12px 20px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  overflow-x: auto;
}
.admin-setup-tab {
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.055);
  color: rgba(255,255,255,.78);
  border-radius: 999px;
  padding: .62rem .9rem;
  font-weight: 800;
  cursor: pointer;
  white-space: nowrap;
}
.admin-setup-tab.is-active {
  color: #05070d;
  background: #86efac;
  border-color: rgba(134,239,172,.8);
}
.admin-setup-body {
  flex: 1;
  overflow: auto;
  padding: 18px 20px 0;
}
.admin-setup-tab-panel { display: none; }
.admin-setup-tab-panel.is-active { display: grid; gap: 14px; }
.setup-form { display: contents; }
.setup-form-narrow { display: grid; gap: 14px; }
.setup-card {
  display: grid;
  gap: 13px;
  padding: 16px;
  border-radius: 20px;
  background: rgba(255,255,255,.055);
  border: 1px solid rgba(255,255,255,.1);
}
.setup-card h3 {
  margin: 0;
  font-size: 1.02rem;
}
.setup-card p {
  margin: -5px 0 2px;
  color: rgba(255,255,255,.62);
  font-size: .88rem;
  line-height: 1.35;
}
.setup-card label,
.generation-profile-form label {
  display: grid;
  gap: .42rem;
  color: rgba(255,255,255,.78);
  font-size: .86rem;
  font-weight: 750;
}
.setup-card input[type="text"],
.setup-card input[type="number"],
.setup-card textarea,
.generation-profile-form input[type="text"],
.generation-profile-form input[type="number"],
.generation-profile-form textarea {
  width: 100%;
  border: 1px solid rgba(255,255,255,.15);
  background: rgba(0,0,0,.22);
  color: #fff;
  border-radius: 14px;
  padding: .72rem .82rem;
  font: inherit;
  font-weight: 550;
  resize: vertical;
  outline: none;
}
.setup-card textarea,
.generation-profile-form textarea {
  line-height: 1.35;
  min-height: 112px;
}
.setup-card input:focus,
.setup-card textarea:focus,
.generation-profile-form input:focus,
.generation-profile-form textarea:focus {
  border-color: rgba(134,239,172,.5);
  background: rgba(0,0,0,.32);
  box-shadow: 0 0 0 3px rgba(134,239,172,.08);
}
.setup-grid {
  display: grid;
  gap: 14px;
}
.setup-grid-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.setup-toggle-row {
  display: flex !important;
  align-items: center;
  gap: .8rem !important;
  padding: .85rem .9rem;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 16px;
  background: rgba(255,255,255,.045);
}
.setup-toggle-row input { width: auto !important; transform: scale(1.15); }
.setup-toggle-row span { display: grid; gap: .15rem; }
.setup-toggle-row strong { color: #fff; }
.setup-toggle-row em {
  font-style: normal;
  font-weight: 600;
  color: rgba(255,255,255,.58);
  font-size: .8rem;
}
.setup-toggle-row-compact { min-height: 100%; }
.admin-setup-footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  padding: 14px 0 18px;
}
.admin-setup-footer-sticky {
  position: sticky;
  bottom: 0;
  padding: 13px 0 18px;
  background: linear-gradient(180deg, rgba(13,16,26,0), rgba(13,16,26,.98) 28%);
  z-index: 2;
}
.setup-save-btn {
  background: #f97316;
  color: #100701;
  border-color: rgba(249,115,22,.8);
}
.setup-status {
  color: rgba(255,255,255,.72);
  font-size: .86rem;
  font-weight: 700;
}
@media (max-width: 780px) {
  .admin-setup-modal { padding: 8px; }
  .admin-setup-panel { height: 94vh; border-radius: 20px; }
  .setup-grid-2 { grid-template-columns: 1fr; }
  .admin-setup-header { padding: 14px; }
  .admin-setup-tabs { padding: 10px 14px; }
  .admin-setup-body { padding: 14px 14px 0; }
}


/* Crowd Hits patch: EvoLink progress inside the existing audio/status cell only */
.audio-status-pill.audio-generation-progress {
  position: relative;
  overflow: hidden;
  border-color: rgba(255, 148, 72, .50) !important;
  background: rgba(255, 148, 72, .12) !important;
  color: rgba(255, 242, 232, .98) !important;
  font-size: .70rem !important;
  font-weight: 950 !important;
  letter-spacing: .025em;
  text-transform: uppercase;
  isolation: isolate;
}

.audio-status-pill.audio-generation-progress::before {
  content: "";
  position: absolute;
  inset: 0;
  width: var(--generation-progress, 1%);
  background: rgba(255, 148, 72, .48);
  z-index: -1;
}

.audio-status-pill.audio-generation-progress > span {
  position: relative;
  z-index: 1;
  white-space: nowrap;
}

