:root {
  --bg: #040404;
  --panel: rgba(10, 10, 11, 0.9);
  --panel-strong: rgba(14, 14, 15, 0.96);
  --panel-soft: rgba(255, 255, 255, 0.02);
  --panel-atmospheric: rgba(10, 10, 11, 0.22);
  --border: rgba(255, 255, 255, 0.12);
  --border-strong: rgba(255, 255, 255, 0.28);
  --text: #f2f2ee;
  --muted: rgba(242, 242, 238, 0.62);
  --shadow: 0 26px 70px rgba(0, 0, 0, 0.42);
  --font-display: "Bahnschrift SemiCondensed", "Arial Narrow", "Agency FB", sans-serif;
  --font-body: "Segoe UI", "Helvetica Neue", sans-serif;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  min-height: 100vh;
  background:
    radial-gradient(circle at top, rgba(255, 255, 255, 0.08), transparent 24%),
    linear-gradient(rgba(255, 255, 255, 0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.025) 1px, transparent 1px),
    linear-gradient(180deg, #0f1012 0%, #050505 28%, #020202 100%);
  background-size: auto, 100% 32px, 32px 100%, auto;
  color: var(--text);
  font-family: var(--font-body);
  letter-spacing: 0.02em;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -3;
  background:
    radial-gradient(circle at 18% 20%, rgba(168, 38, 52, 0.1), transparent 34%),
    radial-gradient(circle at 82% 16%, rgba(78, 18, 24, 0.08), transparent 28%),
    radial-gradient(circle at 50% 120%, rgba(198, 108, 66, 0.06), transparent 38%);
  pointer-events: none;
}

button,
a {
  color: inherit;
  font: inherit;
}

button {
  background: transparent;
  border: 0;
  cursor: pointer;
}

a {
  text-decoration: none;
}

img {
  display: block;
  max-width: 100%;
}

.site-shell {
  position: relative;
  z-index: 1;
  width: min(1360px, calc(100% - 32px));
  margin: 0 auto;
  padding: 20px 0 40px;
}

.site-frame {
  position: relative;
  min-height: 100vh;
  isolation: isolate;
}

.site-frame-has-backdrop .topbar {
  background:
    linear-gradient(180deg, rgba(11, 8, 9, 0.64), rgba(6, 6, 7, 0.8)),
    rgba(0, 0, 0, 0.18);
  border-color: rgba(255, 245, 232, 0.18);
}

.site-frame-has-backdrop .panel,
.site-frame-has-backdrop .feature-panel,
.site-frame-has-backdrop .summary-card,
.site-frame-has-backdrop .info-columns article {
  background:
    linear-gradient(180deg, rgba(18, 14, 15, 0.02), rgba(8, 8, 9, 0.08)),
    var(--panel-atmospheric);
  border-color: rgba(255, 242, 234, 0.16);
}

.club-backdrop {
  position: fixed;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
}

.club-backdrop-base,
.club-backdrop-vignette,
.club-backdrop-bloom,
.club-backdrop-noise,
.club-backdrop-layer {
  position: absolute;
  inset: 0;
  display: block;
}

.club-backdrop-base {
  background:
    radial-gradient(circle at 50% 0%, rgba(154, 34, 42, 0.24), transparent 36%),
    radial-gradient(circle at 50% 100%, rgba(92, 18, 28, 0.22), transparent 48%),
    linear-gradient(180deg, rgba(11, 8, 10, 0.82) 0%, rgba(6, 5, 6, 0.88) 54%, rgba(3, 3, 3, 0.94) 100%);
}

.club-backdrop-vignette {
  background:
    radial-gradient(circle at center, transparent 20%, rgba(0, 0, 0, 0.18) 58%, rgba(0, 0, 0, 0.54) 100%),
    linear-gradient(180deg, rgba(0, 0, 0, 0.1), rgba(0, 0, 0, 0.22));
}

.club-backdrop-bloom {
  background:
    radial-gradient(circle at 22% 24%, rgba(196, 64, 74, 0.26), transparent 25%),
    radial-gradient(circle at 78% 32%, rgba(140, 36, 44, 0.24), transparent 29%),
    radial-gradient(circle at 48% 72%, rgba(182, 106, 62, 0.16), transparent 28%);
  mix-blend-mode: screen;
  opacity: 0.9;
}

.club-backdrop-soft .club-backdrop-bloom {
  opacity: 0.82;
}

.club-backdrop-immersive .club-backdrop-bloom {
  opacity: 1;
}

.club-backdrop-noise {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.024) 0, rgba(255, 255, 255, 0.024) 1px, transparent 1px, transparent 4px),
    linear-gradient(90deg, rgba(255, 241, 232, 0.012), rgba(255, 241, 232, 0.03) 48%, rgba(0, 0, 0, 0.02));
  background-size: 100% 4px, 100% 100%;
  opacity: 0.28;
  mix-blend-mode: soft-light;
  animation: clubBackdropNoiseDrift 12s linear infinite;
}

.club-backdrop-layers {
  position: absolute;
  inset: 0;
}

.club-backdrop-layer {
  opacity: 0;
  background-position: var(--club-backdrop-focus-x, 50%) var(--club-backdrop-focus-y, 50%);
  background-repeat: no-repeat;
  background-size: cover;
  filter: grayscale(1) sepia(0.92) saturate(0.68) hue-rotate(-18deg) brightness(0.44) contrast(1.1);
  mix-blend-mode: screen;
  transform: translate3d(0, 0, 0) scale(1.04);
  animation:
    clubBackdropCrossfade var(--club-backdrop-duration, 42s) ease-in-out infinite,
    clubBackdropDrift calc(var(--club-backdrop-duration, 42s) + 10s) ease-in-out infinite;
  animation-delay: var(--club-backdrop-delay, 0s), var(--club-backdrop-delay, 0s);
  will-change: opacity, transform, filter;
}

.club-backdrop-soft .club-backdrop-layer {
  opacity: 0;
}

.club-backdrop-soft .club-backdrop-layer,
.club-backdrop-immersive .club-backdrop-layer {
  box-shadow: inset 0 0 140px rgba(0, 0, 0, 0.16);
}

.club-backdrop-ember .club-backdrop-layer {
  filter: grayscale(1) sepia(0.86) saturate(0.72) hue-rotate(-14deg) brightness(0.46) contrast(1.08);
}

.club-backdrop-ember-deep .club-backdrop-layer {
  filter: grayscale(1) sepia(0.98) saturate(0.82) hue-rotate(-22deg) brightness(0.4) contrast(1.14);
}

.club-backdrop-soft .club-backdrop-layer {
  filter: grayscale(1) sepia(0.84) saturate(0.68) hue-rotate(-14deg) brightness(0.42) contrast(1.08);
}

.club-backdrop-immersive .club-backdrop-layer {
  filter: grayscale(1) sepia(0.98) saturate(0.86) hue-rotate(-22deg) brightness(0.46) contrast(1.12);
}

.club-backdrop-soft .club-backdrop-layer-1,
.club-backdrop-soft .club-backdrop-layer-2,
.club-backdrop-soft .club-backdrop-layer-3,
.club-backdrop-soft .club-backdrop-layer-4 {
  opacity: 0.01;
}

.club-backdrop-immersive .club-backdrop-layer-1,
.club-backdrop-immersive .club-backdrop-layer-2,
.club-backdrop-immersive .club-backdrop-layer-3,
.club-backdrop-immersive .club-backdrop-layer-4,
.club-backdrop-immersive .club-backdrop-layer-5 {
  opacity: 0.01;
}

.ambient-audio-control {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 46;
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  min-width: 188px;
  padding: 12px 14px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(20, 20, 22, 0.94), rgba(8, 8, 9, 0.96)),
    rgba(0, 0, 0, 0.82);
  box-shadow: 0 22px 48px rgba(0, 0, 0, 0.42);
  backdrop-filter: blur(14px);
  transition: transform 180ms ease, border-color 180ms ease, background-color 180ms ease;
}

.ambient-audio-control:hover,
.ambient-audio-control:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(255, 255, 255, 0.34);
}

.ambient-audio-control.is-playing {
  border-color: rgba(210, 196, 156, 0.42);
  background:
    linear-gradient(180deg, rgba(26, 24, 20, 0.96), rgba(10, 10, 9, 0.98)),
    rgba(0, 0, 0, 0.84);
}

.ambient-audio-control.is-busy {
  opacity: 0.88;
}

.ambient-audio-control.has-error {
  border-color: rgba(255, 128, 128, 0.38);
}

.ambient-audio-control-icon {
  position: relative;
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background:
    radial-gradient(circle at center, rgba(255, 255, 255, 0.12), transparent 62%),
    rgba(255, 255, 255, 0.02);
  overflow: hidden;
}

.ambient-audio-control-ring,
.ambient-audio-control-wave {
  position: absolute;
  display: block;
}

.ambient-audio-control-ring {
  inset: 11px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.65);
}

.ambient-audio-control-wave {
  width: 2px;
  height: 16px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.84);
  transform-origin: center bottom;
  animation: ambientAudioWaveIdle 1.9s ease-in-out infinite;
}

.ambient-audio-control-wave-a {
  left: 16px;
}

.ambient-audio-control-wave-b {
  right: 16px;
  animation-delay: 0.28s;
}

.ambient-audio-control.is-playing .ambient-audio-control-wave {
  animation: ambientAudioWaveActive 0.72s ease-in-out infinite;
}

.ambient-audio-control-copy {
  display: grid;
  gap: 4px;
  text-align: left;
}

.ambient-audio-control-copy strong,
.ambient-audio-control-status {
  display: block;
  font-family: var(--font-display);
  text-transform: uppercase;
}

.ambient-audio-control-copy strong {
  letter-spacing: 0.16em;
}

.ambient-audio-control-status {
  color: var(--muted);
  font-size: 0.68rem;
  letter-spacing: 0.18em;
}

.topbar {
  position: sticky;
  top: 14px;
  z-index: 10;
  display: grid;
  gap: 18px;
  margin-bottom: 20px;
  padding: 18px 22px;
  border: 1px solid var(--border);
  background: rgba(4, 4, 4, 0.78);
  backdrop-filter: blur(14px);
}

.brand-row,
.shell-tools,
.preview-switch,
.area-nav,
.section-links,
.admin-subnav,
.hero-actions,
.club-tags,
.guest-grid {
  display: flex;
  gap: 12px;
}

.admin-grid {
  display: grid;
  gap: 20px;
}

.brand-row,
.shell-tools {
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
}

.session-meta {
  display: grid;
  gap: 6px;
  justify-items: end;
}

.brand-mark,
.shell-kicker,
.nav-pill,
.preview-button,
.section-link,
.eyebrow,
.section-kicker,
.hero-data span,
.event-head span,
.event-row-label,
.event-row-meta,
.archive-shot figcaption,
.archive-slate p,
.archive-slate span,
.module-card-label,
.summary-card span,
.info-columns h3 {
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: 0.2em;
}

.brand-mark {
  padding: 0;
  font-size: 1rem;
}

.shell-kicker {
  margin: 6px 0 0;
  color: var(--muted);
  font-size: 0.72rem;
}

.panel,
.section-shell,
.feature-panel,
.summary-card,
.info-columns article {
  border: 1px solid var(--border);
  background: var(--panel);
  box-shadow: var(--shadow);
}

.nav-pill,
.preview-button,
.section-link,
.button-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 10px 14px;
  border: 1px solid var(--border);
  color: var(--muted);
  font-size: 0.78rem;
  transition: background-color 160ms ease, border-color 160ms ease, color 160ms ease, transform 160ms ease;
}

.nav-pill:hover,
.preview-button:hover,
.section-link:hover,
.button-link:hover,
.nav-pill:focus-visible,
.preview-button:focus-visible,
.section-link:focus-visible,
.button-link:focus-visible {
  color: var(--text);
  border-color: rgba(255, 255, 255, 0.42);
  background: rgba(255, 255, 255, 0.06);
  transform: translateY(-1px);
}

.is-active {
  color: var(--text);
  border-color: var(--border-strong);
  background: rgba(255, 255, 255, 0.08);
}

.is-locked {
  opacity: 0.48;
}

.app-main {
  display: grid;
  gap: 20px;
}

.section-links {
  flex-wrap: wrap;
}

.admin-subnav {
  flex-wrap: wrap;
}

.hero {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
  overflow: hidden;
}

.hero-copy,
.hero-visuals,
.section,
.area-heading,
.feature-panel,
.summary-card,
.info-columns article {
  padding: clamp(20px, 3vw, 40px);
}

.hero-copy {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 28px;
  min-height: 720px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), transparent 26%),
    linear-gradient(180deg, rgba(10, 10, 11, 0.98), rgba(4, 4, 4, 0.96));
}

.eyebrow,
.section-kicker {
  margin: 0;
  color: var(--muted);
  font-size: 0.78rem;
}

.hero-logo,
.archive-slate img {
  width: min(320px, 72%);
}

.hero-text,
.section-head h2,
.area-heading h1,
.feature-panel h2,
.summary-card h3 {
  margin: 0;
  font-family: var(--font-display);
  line-height: 0.96;
  text-transform: uppercase;
}

.hero-text {
  max-width: 17ch;
  font-size: clamp(1.85rem, 4vw, 4rem);
  letter-spacing: 0.08em;
  text-wrap: balance;
}

.hero-subline {
  max-width: 34ch;
}

.hero-data,
.summary-grid,
.info-columns {
  display: grid;
  gap: 12px;
}

.hero-data {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.hero-data div,
.archive-slate,
.summary-card,
.info-columns article {
  padding: 16px;
  border: 1px solid var(--border);
  background: var(--panel-soft);
}

.hero-data span,
.event-head span,
.event-row-label,
.event-row-meta,
.archive-shot figcaption,
.archive-slate p,
.archive-slate span,
.module-card-label,
.summary-card span {
  color: var(--muted);
  font-size: 0.74rem;
}

.hero-data strong {
  display: block;
  margin-top: 8px;
  font-family: var(--font-display);
  font-size: 0.95rem;
  line-height: 1.25;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.hero-visuals {
  display: grid;
  gap: 18px;
  background:
    radial-gradient(circle at top right, rgba(255, 255, 255, 0.08), transparent 22%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.02), transparent),
    var(--panel-strong);
}

.hero-visual,
.archive-shot {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--border);
  background: #020202;
}

.hero-visual-primary {
  min-height: 520px;
}

.hero-visual-secondary {
  min-height: 164px;
}

.hero-visual img,
.archive-shot img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hero-visual-primary img {
  filter: grayscale(0.2) contrast(1.08) brightness(0.86);
}

.hero-visual-secondary img,
.archive-shot-room img {
  filter: grayscale(1) contrast(1.12) brightness(0.58);
}

.hero-visual::after,
.archive-shot::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 42%, rgba(0, 0, 0, 0.82) 100%);
}

.hero-visual figcaption,
.archive-shot figcaption {
  position: absolute;
  left: 14px;
  bottom: 14px;
  z-index: 1;
}

.section-grid {
  display: grid;
  grid-template-columns: 1.18fr 0.82fr;
  gap: 20px;
}

.split-section,
.footer-grid,
.artist-grid,
.media-grid {
  display: grid;
  gap: 18px;
}

.split-section,
.footer-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

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

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

.section-shell,
.area-heading,
.feature-panel {
  display: grid;
  gap: 22px;
}

.section-head,
.area-heading {
  display: grid;
  gap: 10px;
}

.section-head h2,
.area-heading h1,
.feature-panel h2 {
  font-size: clamp(1.9rem, 3vw, 3rem);
  letter-spacing: 0.08em;
}

.area-copy,
.feature-copy,
.club-copy p,
.module-card-copy,
.summary-card p,
.info-columns p {
  margin: 0;
  line-height: 1.6;
  color: #d7d7d3;
}

.event-board {
  display: grid;
  gap: 10px;
}

.event-head,
.event-row {
  display: grid;
  grid-template-columns: 72px 176px minmax(0, 1fr) 136px;
  gap: 16px;
  align-items: center;
}

.event-head {
  padding: 0 16px 8px;
}

.event-row {
  padding: 18px 16px;
  border: 1px solid var(--border);
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.05), transparent 22%),
    rgba(255, 255, 255, 0.02);
}

.event-row-label,
.event-title,
.module-card-title {
  margin: 0;
  font-family: var(--font-display);
  text-transform: uppercase;
}

.event-row-label {
  font-size: 2rem;
  line-height: 1;
}

.event-title {
  font-size: 1.08rem;
  letter-spacing: 0.14em;
}

.event-row-media {
  margin-bottom: 12px;
}

.event-row-flyer {
  width: min(220px, 100%);
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.02);
}

.event-row-meta {
  display: block;
  margin-top: 8px;
}

.button-link {
  min-width: 132px;
  color: var(--text);
}

.action-button {
  min-height: 48px;
  padding: 12px 16px;
  border-radius: 14px;
  font-family: var(--font-display);
  font-size: 0.78rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  box-shadow: 0 16px 28px rgba(0, 0, 0, 0.18);
}

.action-button-full {
  width: 100%;
}

.action-button-compact {
  min-height: 40px;
  padding: 9px 12px;
}

.action-button-primary {
  border-color: rgba(245, 229, 185, 0.68);
  background:
    linear-gradient(180deg, rgba(248, 236, 198, 0.96), rgba(220, 197, 133, 0.92)),
    rgba(255, 255, 255, 0.08);
  color: #12100a;
}

.action-button-primary:hover,
.action-button-primary:focus-visible {
  border-color: rgba(255, 241, 213, 0.84);
  background:
    linear-gradient(180deg, rgba(255, 244, 220, 0.98), rgba(230, 208, 148, 0.96)),
    rgba(255, 255, 255, 0.08);
  color: #060606;
}

.action-button-secondary {
  border-color: rgba(255, 255, 255, 0.34);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.04)),
    rgba(255, 255, 255, 0.03);
  color: var(--text);
}

.action-button-secondary:hover,
.action-button-secondary:focus-visible {
  border-color: rgba(255, 255, 255, 0.5);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0.06)),
    rgba(255, 255, 255, 0.04);
}

.action-button-utility {
  border-color: rgba(255, 255, 255, 0.18);
  background: rgba(255, 255, 255, 0.02);
  color: var(--muted);
  box-shadow: none;
}

.action-button-utility:hover,
.action-button-utility:focus-visible {
  color: var(--text);
  border-color: rgba(255, 255, 255, 0.34);
  background: rgba(255, 255, 255, 0.05);
}

.action-button-danger {
  border-color: rgba(255, 120, 120, 0.42);
  background:
    linear-gradient(180deg, rgba(114, 20, 20, 0.42), rgba(82, 16, 16, 0.28)),
    rgba(255, 80, 80, 0.05);
  color: #ffd1d1;
}

.action-button-danger:hover,
.action-button-danger:focus-visible {
  border-color: rgba(255, 154, 154, 0.58);
  background:
    linear-gradient(180deg, rgba(138, 24, 24, 0.48), rgba(94, 19, 19, 0.34)),
    rgba(255, 80, 80, 0.08);
  color: #fff2f2;
}

.button-link-danger {
  border-color: rgba(255, 120, 120, 0.34);
  color: #ffd1d1;
}

.button-link-danger:hover,
.button-link-danger:focus-visible {
  border-color: rgba(255, 150, 150, 0.52);
  background: rgba(255, 80, 80, 0.08);
  color: #fff1f1;
}

.section-club {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), transparent),
    linear-gradient(180deg, rgba(7, 7, 8, 0.98), rgba(4, 4, 4, 0.96));
}

.club-copy {
  display: grid;
  gap: 18px;
  max-width: 34ch;
}

.club-tags {
  flex-wrap: wrap;
  margin: 0;
  padding: 0;
  list-style: none;
}

.club-tags li {
  padding: 10px 12px;
  border: 1px solid var(--border);
  color: var(--muted);
  font-family: var(--font-display);
  font-size: 0.78rem;
  letter-spacing: 0.14em;
}

.archive-grid {
  display: grid;
  grid-template-columns: 1.25fr 0.75fr;
  gap: 18px;
}

.artist-card,
.media-card,
.highlight-item,
.admin-field-card,
.admin-quick-card {
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.02);
}

.artist-card,
.media-card,
.admin-quick-card {
  overflow: hidden;
}

.artist-image-wrap,
.media-card-image-wrap {
  min-height: 240px;
  background: #060606;
}

.artist-image,
.media-card-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.artist-image-placeholder,
.module-card-thumb-placeholder,
.admin-artist-thumb-placeholder {
  display: grid;
  place-items: center;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.04), transparent),
    rgba(255, 255, 255, 0.02);
  color: var(--muted);
}

.artist-image {
  filter: grayscale(1) contrast(1.08) brightness(0.56);
}

.media-card-image {
  filter: grayscale(0.7) contrast(1.08) brightness(0.62);
}

.artist-copy,
.media-card-copy,
.highlight-item,
.admin-field-card,
.admin-quick-card {
  display: grid;
  gap: 10px;
  padding: 18px;
}

.stack-copy,
.highlight-list,
.admin-form-grid,
.admin-quick-grid,
.flyer-intake-grid,
.admin-selection-grid,
.guest-event-list,
.guest-event-detail,
.guest-event-timetable,
.guest-event-stream-grid {
  display: grid;
  gap: 14px;
}

.admin-panel-header {
  display: grid;
  gap: 8px;
}

.admin-form-section {
  gap: 18px;
}

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

.flyer-intake-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

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

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

.admin-overview-panel {
  gap: 20px;
}

.admin-overview-card {
  min-height: 220px;
  align-content: start;
  justify-items: start;
  gap: 14px;
  text-align: left;
  transition: transform 160ms ease, border-color 160ms ease, background-color 160ms ease;
}

.admin-overview-icon-wrap {
  display: grid;
  place-items: center;
  width: 112px;
  height: 80px;
  padding: 4px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background:
    radial-gradient(circle at center, rgba(255, 255, 255, 0.1), transparent 62%),
    rgba(255, 255, 255, 0.02);
  overflow: hidden;
}

.admin-overview-icon {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  filter: contrast(1.04) brightness(0.98);
}

.admin-overview-card:hover,
.admin-overview-card:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(255, 255, 255, 0.34);
  background: rgba(255, 255, 255, 0.05);
}

.organizer-scope-card {
  display: grid;
  gap: 8px;
  padding: 18px 20px;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.03);
}

.organizer-stats-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.admin-tab-row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 18px;
}

.organizer-stat-card {
  min-height: 112px;
  align-content: end;
}

.organizer-onboarding-panel {
  display: grid;
  gap: 20px;
}

.admin-artist-access-panel {
  display: grid;
  gap: 12px;
  margin-top: 8px;
  padding-top: 14px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.admin-artist-access-head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.artist-portal-shell {
  gap: 18px;
}

.artist-portal-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: start;
}

.artist-portal-head h1 {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.9rem, 4vw, 3.2rem);
  line-height: 0.98;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.artist-portal-badge {
  display: grid;
  gap: 8px;
  min-width: 220px;
  padding: 16px 18px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.04), transparent 28%),
    rgba(255, 255, 255, 0.025);
}

.artist-portal-badge strong {
  font-family: var(--font-display);
  font-size: 1rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.admin-window-backdrop {
  position: fixed;
  inset: 0;
  z-index: 30;
  display: grid;
  place-items: center;
  padding: 24px;
  background: rgba(0, 0, 0, 0.72);
  backdrop-filter: blur(12px);
}

.admin-window-panel {
  width: min(1240px, 100%);
  max-height: calc(100vh - 48px);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  border: 1px solid var(--border-strong);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), transparent 18%),
    rgba(8, 8, 9, 0.98);
  box-shadow: 0 32px 90px rgba(0, 0, 0, 0.52);
}

.admin-window-header {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 18px;
  padding: 22px 24px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.admin-window-header h2 {
  margin: 6px 0 0;
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.workspace-editor-mask-backdrop {
  z-index: 44;
  padding: 18px;
  background: rgba(3, 3, 4, 0.82);
}

.workspace-editor-mask-panel {
  width: min(1380px, 100%);
  min-height: calc(100vh - 36px);
  grid-template-rows: auto minmax(0, 1fr) auto;
  border-color: rgba(255, 255, 255, 0.18);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.04), transparent 18%),
    rgba(5, 5, 6, 0.98);
}

.workspace-editor-mask-header {
  position: sticky;
  top: 0;
  z-index: 2;
  align-items: center;
  background:
    linear-gradient(180deg, rgba(11, 11, 12, 0.98), rgba(8, 8, 9, 0.94)),
    rgba(8, 8, 9, 0.96);
  backdrop-filter: blur(14px);
}

.workspace-editor-mask-copy {
  display: grid;
  gap: 8px;
}

.workspace-editor-mask-body {
  padding-top: 20px;
  padding-bottom: 20px;
  scroll-padding-bottom: 104px;
}

.workspace-editor-mask-footer {
  position: relative;
  z-index: 2;
  padding: 0 24px 24px;
  background:
    linear-gradient(180deg, rgba(5, 5, 6, 0), rgba(5, 5, 6, 0.94) 18%, rgba(5, 5, 6, 0.98) 100%);
}

.workspace-editor-footer-bar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: center;
  padding: 14px 16px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.02)),
    rgba(8, 8, 9, 0.96);
}

.workspace-editor-footer-status,
.editor-status-strip {
  display: grid;
  gap: 10px;
}

.workspace-editor-footer-actions {
  grid-template-columns: repeat(2, minmax(160px, auto));
  justify-content: end;
}

.editor-status-strip {
  padding-top: 10px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.admin-window-body {
  overflow: auto;
  display: grid;
  gap: 20px;
  padding: 24px;
  scroll-padding-top: 112px;
}

.flyer-dropzone,
.flyer-preview-card {
  min-height: 220px;
}

.flyer-dropzone {
  display: grid;
  align-content: start;
  gap: 12px;
  padding: 18px;
  border: 1px dashed rgba(255, 255, 255, 0.28);
  background: rgba(255, 255, 255, 0.02);
}

.flyer-file-input {
  display: none;
}

.file-picker-control,
.file-picker-actions,
.flyer-preview-card,
.flyer-preview-file {
  display: grid;
  gap: 12px;
}

.file-picker-button {
  width: 100%;
  min-height: 52px;
}

.admin-text-input {
  width: 100%;
  min-height: 44px;
  padding: 12px 14px;
  border: 1px solid var(--border);
  background: rgba(0, 0, 0, 0.28);
  color: var(--text);
}

.admin-text-input-email {
  direction: ltr;
  unicode-bidi: plaintext;
  text-align: left;
}

.admin-textarea-input,
.admin-select-input {
  font: inherit;
}

.admin-textarea-input {
  min-height: 120px;
  resize: vertical;
}

.admin-form-field,
.admin-selection-card {
  align-content: start;
}

.admin-form-grid-wide {
  grid-template-columns: 1fr;
}

.flyer-preview-frame {
  display: grid;
  place-items: center;
  min-height: 120px;
  padding: 12px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(0, 0, 0, 0.24);
}

.flyer-preview-image {
  max-height: 180px;
  object-fit: contain;
}

.flyer-preview-file {
  justify-items: center;
  text-align: center;
}

.admin-checkbox-input {
  width: 18px;
  height: 18px;
  margin: 0;
  accent-color: #d7d7d3;
}

.admin-media-dj-grid,
.admin-media-entry-list {
  display: grid;
  gap: 16px;
}

.admin-media-subnav,
.admin-media-dj-list,
.admin-media-dj-panel,
.admin-media-inline-editor,
.admin-actions-cluster-media-inline,
.admin-media-window-grid,
.media-window-actions {
  display: grid;
  gap: 16px;
}

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

.admin-media-window-card,
.media-window-shell {
  align-content: start;
}

.admin-media-window-copy,
.admin-media-window-meta,
.media-window-copy {
  display: grid;
  gap: 8px;
}

.media-window-shell {
  margin-bottom: 20px;
}

.media-window-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: start;
}

.media-window-actions {
  grid-template-columns: repeat(2, minmax(180px, auto));
  justify-content: end;
}

.media-window-header h1 {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.9rem, 3vw, 3rem);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.admin-media-dj-card,
.admin-media-entry-card {
  align-content: start;
}

.admin-media-dj-head,
.admin-media-entry-card {
  display: grid;
  gap: 14px;
}

.admin-media-dj-head {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
}

.admin-media-dj-copy,
.admin-media-dj-meta,
.admin-media-entry-copy,
.admin-media-entry-meta {
  display: grid;
  gap: 8px;
}

.admin-media-dj-meta,
.admin-media-entry-meta {
  justify-items: start;
  align-content: start;
}

.admin-actions-cluster-media {
  grid-template-columns: minmax(220px, 280px);
}

.admin-media-subnav {
  grid-template-columns: repeat(3, minmax(0, auto));
  justify-content: start;
}

.admin-media-dj-list-card {
  gap: 18px;
}

.admin-media-dj-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 18px;
  align-items: center;
}

.admin-media-dj-row-main,
.admin-media-dj-row-meta {
  display: grid;
  gap: 8px;
}

.admin-media-dj-row-meta {
  justify-items: start;
}

.admin-media-dj-panel {
  padding-top: 18px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.admin-media-dj-panel-head {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
}

.admin-media-entry-card-compact {
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 18px;
  align-items: start;
}

.admin-media-inline-editor {
  padding: 18px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.02)),
    rgba(8, 8, 9, 0.92);
}

.admin-actions-cluster-media-inline {
  grid-template-columns: repeat(2, minmax(180px, auto));
  justify-content: end;
}

.admin-media-placeholder-panel {
  min-height: 220px;
  align-content: start;
}

.admin-image-folder-list,
.admin-image-folder-meta,
.admin-image-upload-list,
.admin-image-asset-grid,
.admin-video-asset-grid,
.admin-image-upload-actions,
.admin-image-asset-actions,
.admin-image-assignment-actions,
.admin-image-folder-meta-grid,
.admin-image-folder-head,
.admin-image-asset-badges,
.admin-image-upload-copy,
.admin-image-asset-copy,
.admin-image-editor-panel,
.admin-image-upload-panel,
.admin-image-assets-panel,
.admin-image-selected-asset-panel {
  display: grid;
  gap: 16px;
}

.admin-image-folder-list,
.admin-image-upload-list,
.admin-image-asset-grid,
.admin-video-asset-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.admin-image-folder-head {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
}

.admin-image-folder-head-side {
  display: grid;
  justify-items: end;
  gap: 8px;
}

.admin-image-folder-preview-grid {
  display: grid;
  grid-template-columns: repeat(2, 30px);
  grid-template-rows: repeat(2, 30px);
  gap: 4px;
  width: 64px;
  height: 64px;
  overflow: hidden;
}

.admin-image-folder-preview-tile {
  width: 30px;
  height: 30px;
  display: block;
  object-fit: cover;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.04);
}

.admin-image-folder-card,
.admin-image-search-card,
.admin-image-reference-card,
.admin-image-upload-panel,
.admin-image-assets-panel,
.admin-image-selected-asset-panel {
  align-content: start;
}

.admin-image-assignment-card {
  gap: 14px;
}

.admin-image-assignment-actions,
.admin-image-upload-actions,
.admin-image-asset-actions {
  grid-template-columns: repeat(3, minmax(0, auto));
  justify-content: start;
}

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

.admin-image-meta-wide {
  grid-column: span 3;
}

.admin-image-dropzone {
  padding: 18px;
  border: 1px dashed rgba(255, 255, 255, 0.16);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.02);
}

.admin-image-upload-item {
  grid-template-columns: 96px minmax(0, 1fr);
  align-items: center;
}

.admin-video-upload-item {
  align-items: center;
}

.admin-image-upload-preview,
.admin-image-asset-preview,
.admin-image-selected-preview {
  width: 100%;
  border-radius: 16px;
  object-fit: cover;
  background: rgba(255, 255, 255, 0.04);
}

.admin-image-upload-preview {
  height: 96px;
}

.admin-image-asset-preview {
  aspect-ratio: 4 / 3;
}

.admin-image-selected-preview {
  max-height: 360px;
}

.admin-image-asset-card.is-selected {
  border-color: rgba(245, 229, 185, 0.42);
  box-shadow: 0 0 0 1px rgba(245, 229, 185, 0.18);
}

.admin-image-asset-actions {
  align-content: start;
}

.admin-image-reference-card {
  gap: 10px;
}

.admin-image-upload-copy,
.admin-image-asset-copy {
  align-content: start;
}

.admin-video-folder-card,
.admin-video-asset-card {
  align-content: start;
}

.admin-video-player-shell {
  border-radius: 18px;
  overflow: hidden;
  background:
    radial-gradient(circle at top left, rgba(245, 229, 185, 0.12), transparent 52%),
    rgba(6, 8, 14, 0.82);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.admin-video-player {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #05070d;
}

.admin-video-fallback {
  min-height: 220px;
  display: grid;
  align-content: center;
  gap: 10px;
  padding: 24px;
}

.admin-video-link {
  color: rgba(245, 229, 185, 0.92);
  text-decoration: none;
  font-family: var(--font-display);
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.admin-video-link:hover,
.admin-video-link:focus-visible {
  text-decoration: underline;
}

.admin-linked-video-list,
.admin-linked-video-browser-grid,
.admin-linked-video-folder-list,
.admin-linked-video-selection-list,
.admin-linked-dj-list {
  display: grid;
  gap: 14px;
}

.admin-linked-video-browser {
  display: grid;
  gap: 18px;
  margin-top: 22px;
}

.admin-linked-video-browser-grid {
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.35fr);
  align-items: start;
}

.admin-linked-video-browser-column,
.admin-linked-video-card,
.admin-video-dj-assignment-panel {
  align-content: start;
  gap: 14px;
}

.admin-linked-video-preview-shell {
  border-radius: 16px;
  overflow: hidden;
  background:
    radial-gradient(circle at top left, rgba(245, 229, 185, 0.12), transparent 52%),
    rgba(6, 8, 14, 0.82);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.admin-linked-video-preview {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #05070d;
}

.admin-linked-video-preview-fallback {
  display: grid;
  gap: 10px;
  padding: 14px;
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.03);
}

.admin-linked-video-folder-card,
.admin-linked-video-selection-card {
  display: grid;
  gap: 10px;
  text-align: left;
  cursor: pointer;
}

.admin-linked-video-folder-card.is-selected,
.admin-linked-video-selection-card.is-selected {
  border-color: rgba(245, 229, 185, 0.34);
  background: rgba(245, 229, 185, 0.08);
}

.admin-linked-video-selection-head {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 12px;
  align-items: start;
}

.admin-linked-video-copy {
  display: grid;
  gap: 8px;
}

.admin-linked-dj-chip {
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  padding: 10px 12px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.03);
}

.admin-submit-row {
  display: flex;
  gap: 14px;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
}

.action-status {
  display: inline-flex;
  align-items: center;
  min-height: 48px;
  padding: 12px 16px;
  border: 1px solid var(--border);
  border-radius: 14px;
  font-family: var(--font-display);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  background: rgba(255, 255, 255, 0.04);
}

.action-status-idle,
.action-status-empty {
  color: var(--muted);
}

.action-status-saving {
  border-color: rgba(248, 191, 73, 0.34);
  background: rgba(248, 191, 73, 0.12);
  color: #ffe19f;
}

.action-status-success {
  border-color: rgba(72, 220, 138, 0.46);
  background: rgba(72, 220, 138, 0.14);
  color: #d1ffe0;
}

.action-status-error {
  border-color: rgba(255, 108, 108, 0.52);
  background: rgba(255, 108, 108, 0.14);
  color: #ffd0d0;
}

.admin-actions-cluster,
.admin-card-actions,
.admin-list-grid,
.admin-timetable-grid {
  display: grid;
  gap: 14px;
}

.admin-timeslot-action-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 14px;
  margin-top: 16px;
}

.admin-timeslot-action-row .module-card-copy {
  margin: 0;
}

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

.editor-action-bar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, auto);
  gap: 18px;
  padding: 16px 18px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.02)),
    rgba(8, 8, 9, 0.96);
}

.editor-action-bar-sticky {
  position: sticky;
  top: 12px;
  z-index: 3;
  border-color: rgba(255, 255, 255, 0.24);
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.22);
  backdrop-filter: blur(12px);
}

.editor-action-bar-compact {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
}

.editor-action-bar-copy,
.editor-action-buttons {
  display: grid;
  gap: 14px;
}

.editor-action-status-row {
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
}

.editor-action-buttons {
  align-content: start;
  justify-items: stretch;
  grid-template-columns: repeat(2, minmax(180px, 1fr));
}

.editor-action-bar-compact .admin-panel-header {
  gap: 4px;
}

.editor-action-bar-compact .feature-copy {
  font-size: 0.94rem;
}

.editor-action-bar-compact .editor-action-status-row {
  gap: 10px;
}

.editor-action-bar-compact .editor-action-buttons {
  grid-template-columns: repeat(2, minmax(160px, auto));
  justify-content: end;
}

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

.admin-card-actions-stack {
  grid-template-columns: 1fr;
}

.admin-status-sections,
.admin-status-row {
  display: grid;
  gap: 14px;
}

.admin-planner-shell {
  gap: 20px;
}

.admin-planner-header {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

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

.admin-planner-workspace {
  display: grid;
  grid-template-columns: 320px minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}

.admin-planner-calendar {
  position: sticky;
  top: 0;
  gap: 18px;
  padding: 22px;
  align-content: start;
}

.admin-planner-calendar-head {
  gap: 12px;
}

.admin-calendar-nav {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 10px;
  align-items: center;
}

.admin-calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 8px;
}

.admin-calendar-weekday {
  color: var(--muted);
  font-family: var(--font-display);
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  text-align: center;
}

.admin-calendar-day {
  display: grid;
  gap: 8px;
  min-height: 74px;
  padding: 10px 8px;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.02);
  text-align: left;
  align-content: start;
  overflow: hidden;
}

.admin-calendar-day:hover,
.admin-calendar-day:focus-visible {
  border-color: rgba(255, 255, 255, 0.34);
  background: rgba(255, 255, 255, 0.05);
}

.admin-calendar-day.is-outside {
  opacity: 0.38;
}

.admin-calendar-day.is-selected {
  border-color: var(--border-strong);
  background: rgba(255, 255, 255, 0.08);
}

.admin-calendar-day.has-events {
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.admin-calendar-day.holiday-national {
  background:
    linear-gradient(180deg, rgba(245, 201, 53, 0.14), rgba(255, 255, 255, 0.02)),
    rgba(255, 255, 255, 0.02);
}

.admin-calendar-day.holiday-regional {
  background:
    linear-gradient(180deg, rgba(88, 146, 255, 0.16), rgba(255, 255, 255, 0.02)),
    rgba(255, 255, 255, 0.02);
}

.admin-calendar-day-number {
  font-family: var(--font-display);
  font-size: 0.96rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.admin-calendar-day-markers {
  display: grid;
  gap: 6px;
  min-width: 0;
}

.admin-calendar-marker {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  min-height: 22px;
  padding: 3px 7px;
  border: 1px solid var(--border);
  border-radius: 999px;
  font-family: var(--font-display);
  font-size: 0.58rem;
  letter-spacing: 0.14em;
  line-height: 1.1;
  text-transform: uppercase;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.marker-event {
  border-color: rgba(255, 255, 255, 0.26);
  background: rgba(255, 255, 255, 0.08);
  color: var(--text);
}

.marker-national {
  border-color: rgba(245, 201, 53, 0.5);
  background: rgba(245, 201, 53, 0.18);
  color: #ffe88b;
}

.marker-regional {
  border-color: rgba(88, 146, 255, 0.5);
  background: rgba(88, 146, 255, 0.18);
  color: #b7d1ff;
}

.admin-planner-content {
  display: grid;
  gap: 18px;
}

.admin-planner-list-panel,
.admin-planner-detail-panel {
  gap: 16px;
}

.admin-planner-list-tools {
  display: flex;
  gap: 12px;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
}

.admin-planner-subtitle {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.admin-compact-event-list {
  display: grid;
  gap: 10px;
}

.admin-event-row-shell {
  display: grid;
  gap: 0;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.02);
  overflow: hidden;
}

.admin-event-row-shell.is-expanded {
  border-color: rgba(255, 255, 255, 0.26);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.02)),
    rgba(255, 255, 255, 0.02);
}

.admin-compact-event {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(220px, 0.95fr) auto;
  gap: 16px;
  align-items: center;
  padding: 14px 16px;
  width: 100%;
  text-align: left;
}

.admin-compact-event:hover,
.admin-compact-event:focus-visible {
  background: rgba(255, 255, 255, 0.05);
}

.admin-compact-event-main,
.admin-compact-event-meta {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.admin-compact-event-main .module-card-title,
.admin-compact-event-meta .module-card-copy {
  overflow-wrap: anywhere;
}

.admin-compact-event-side {
  display: grid;
  gap: 8px;
  justify-items: end;
  align-content: center;
  min-width: 140px;
}

.admin-event-inline-detail {
  padding: 0 16px 16px;
}

.admin-event-detail-body {
  display: grid;
  gap: 14px;
  padding: 16px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), transparent),
    rgba(0, 0, 0, 0.18);
}

.admin-event-detail-head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.admin-planner-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.event-status-badge {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 28px;
  padding: 6px 11px;
  border: 1px solid var(--border);
  border-radius: 999px;
  font-family: var(--font-display);
  font-size: 0.68rem;
  letter-spacing: 0.16em;
  line-height: 1;
  text-transform: uppercase;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02);
}

.status-draft {
  border-color: rgba(201, 201, 201, 0.32);
  background: rgba(255, 255, 255, 0.09);
  color: #f0f0eb;
}

.status-submitted {
  border-color: rgba(248, 191, 73, 0.52);
  background: rgba(248, 191, 73, 0.16);
  color: #ffe19f;
}

.status-published {
  border-color: rgba(72, 220, 138, 0.54);
  background: rgba(72, 220, 138, 0.18);
  color: #c2ffd9;
}

.status-rejected {
  border-color: rgba(255, 108, 108, 0.56);
  background: rgba(255, 108, 108, 0.14);
  color: #ffc0c0;
}

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

.admin-planner-description,
.admin-planner-lineup {
  align-content: start;
}

.admin-detail-slot-list {
  display: grid;
  gap: 10px;
}

.admin-detail-slot-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 10px 0;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.admin-detail-slot-row:first-child {
  border-top: 0;
  padding-top: 0;
}

.admin-artist-list {
  display: grid;
  gap: 14px;
}

.admin-artist-list-card {
  display: grid;
  grid-template-columns: 120px minmax(0, 1fr) 220px;
  gap: 16px;
  align-items: start;
}

.admin-artist-thumb-wrap {
  width: 120px;
  min-height: 120px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: #060606;
}

.admin-artist-thumb {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(0.2) contrast(1.04) brightness(0.82);
}

.admin-artist-card-copy {
  display: grid;
  gap: 8px;
  align-content: start;
}

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

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

.admin-timeslot-grid {
  grid-template-columns: repeat(2, minmax(136px, 180px));
}

.admin-account-card {
  align-content: start;
}

.admin-timeslot-card,
.admin-image-card {
  align-content: start;
}

.admin-time-input {
  min-height: 50px;
  min-width: 136px;
  padding: 13px 16px;
  font-size: 1rem;
  letter-spacing: 0.08em;
  font-variant-numeric: tabular-nums;
}

.admin-event-date-input {
  min-height: 50px;
  padding: 13px 16px;
  font-size: 1rem;
}

.flyer-state-badge {
  width: fit-content;
  padding: 8px 10px;
  border: 1px solid var(--border);
  font-family: var(--font-display);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.flyer-state-success {
  border-color: rgba(255, 255, 255, 0.4);
  color: var(--text);
}

.flyer-state-error {
  border-color: rgba(255, 160, 160, 0.42);
  color: #ffd0d0;
}

.flyer-state-empty {
  color: var(--muted);
}

.flyer-state-idle,
.flyer-state-saving {
  color: var(--muted);
}

.archive-shot-room {
  min-height: 420px;
}

.archive-shot-crowd {
  grid-row: span 2;
  min-height: 620px;
}

.archive-shot-crowd img {
  filter: contrast(1.06) brightness(0.9);
}

.archive-slate {
  display: grid;
  align-content: start;
  gap: 14px;
}

.module-list {
  display: grid;
  gap: 14px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.stream-preview,
.event-streams {
  display: grid;
  gap: 10px;
}

.stream-preview {
  padding-top: 12px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.stream-preview-inline {
  padding: 16px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 18px;
  background:
    radial-gradient(circle at top left, rgba(165, 181, 228, 0.08), transparent 28%),
    rgba(8, 10, 16, 0.78);
}

.stream-preview-head {
  display: grid;
  gap: 4px;
}

.stream-preview-details {
  display: grid;
  gap: 10px;
}

.stream-preview-details[open] {
  padding-top: 2px;
}

.stream-preview-details-inline {
  gap: 12px;
}

.stream-preview-details-inline[open] {
  padding-top: 0;
}

.stream-preview-toggle {
  list-style: none;
  cursor: pointer;
}

.stream-preview-toggle::-webkit-details-marker {
  display: none;
}

.stream-preview-body {
  display: grid;
  gap: 10px;
}

.stream-preview-title {
  margin: 0;
  font-family: var(--font-display);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.stream-preview-player-frame {
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(0, 0, 0, 0.28);
}

.stream-preview-player {
  display: block;
  width: 100%;
  min-height: 166px;
  border: 0;
}

.guest-artist-stream-grid .stream-preview {
  padding-top: 0;
  border-top: 0;
}

.guest-artist-stream-grid .stream-preview-player {
  min-height: 176px;
}

.stream-link,
.event-stream-chip {
  width: fit-content;
}

.event-streams .stream-preview {
  padding-top: 0;
  border-top: 0;
}

.event-stream-chip {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 8px 12px;
  border: 1px solid var(--border);
  color: var(--muted);
  font-family: var(--font-display);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  transition: background-color 160ms ease, border-color 160ms ease, color 160ms ease;
}

.event-stream-chip:hover,
.event-stream-chip:focus-visible {
  color: var(--text);
  border-color: rgba(255, 255, 255, 0.42);
  background: rgba(255, 255, 255, 0.06);
}

.module-card {
  display: grid;
  gap: 10px;
  padding: 18px;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.02);
}

.module-card-artist {
  grid-template-columns: 92px minmax(0, 1fr);
  align-items: start;
  gap: 16px;
}

.module-card-thumb-wrap {
  width: 92px;
  min-height: 92px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: #060606;
}

.module-card-thumb {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(0.45) contrast(1.04) brightness(0.72);
}

.module-card-stack {
  display: grid;
  gap: 8px;
}

.module-card-title {
  font-size: 1.08rem;
  letter-spacing: 0.14em;
}

.guest-grid {
  align-items: stretch;
  flex-wrap: wrap;
}

.guest-events-panel {
  gap: 18px;
}

.guest-event-row,
.guest-event-detail-panel,
.guest-event-detail-empty {
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.03);
}

.guest-event-row {
  display: grid;
  grid-template-columns: 120px minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  padding: 16px;
}

.guest-event-row.is-active {
  border-color: rgba(255, 255, 255, 0.28);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.02)),
    rgba(255, 255, 255, 0.03);
}

.guest-event-row-empty,
.guest-event-detail-empty {
  padding: 18px;
}

.guest-event-thumb-wrap {
  width: 120px;
  min-height: 120px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: #060606;
}

.guest-event-thumb-empty {
  display: grid;
  place-items: center;
}

.guest-event-thumb {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.guest-event-main,
.guest-event-side,
.guest-event-slot-copy {
  display: grid;
  gap: 8px;
}

.guest-event-side {
  align-content: center;
  justify-items: end;
}

.guest-event-lineup,
.guest-event-slot-time {
  color: var(--muted);
  font-family: var(--font-display);
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.guest-event-detail {
  margin-top: 4px;
}

.guest-event-detail-header {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.guest-event-detail-grid,
.guest-event-dj-grid {
  display: grid;
  gap: 14px;
}

.guest-event-detail-grid {
  grid-template-columns: minmax(260px, 0.7fr) minmax(0, 1fr);
}

.guest-event-detail-panel {
  padding: 18px;
}

.guest-event-detail-flyer-frame {
  min-height: 280px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(0, 0, 0, 0.24);
  overflow: hidden;
}

.guest-event-detail-flyer-image {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.guest-event-timetable-row {
  display: grid;
  grid-template-columns: 128px minmax(0, 1fr);
  gap: 14px;
  padding-top: 14px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.guest-event-timetable-row:first-child {
  padding-top: 0;
  border-top: 0;
}

.guest-event-dj-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.guest-grid > * {
  flex: 1 1 320px;
}

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

.module-list li {
  padding-top: 12px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  color: #d7d7d3;
}

.guest-area-shell,
.guest-modules-grid,
.guest-modules-stack,
.guest-entry-grid,
.guest-entry-nav,
.guest-entry-atlas,
.guest-events-head,
.guest-artists-grid,
.guest-module-list {
  display: grid;
  gap: 18px;
}

.guest-area-shell {
  gap: 22px;
}

.guest-entry-stage,
.guest-events-panel,
.guest-module-panel,
.guest-access-gate {
  position: relative;
  overflow: hidden;
  border-color: rgba(255, 255, 255, 0.14);
  background:
    radial-gradient(circle at top right, rgba(89, 129, 255, 0.045), transparent 20%),
    radial-gradient(circle at bottom left, rgba(210, 194, 150, 0.05), transparent 24%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.014), transparent 16%),
    rgba(6, 7, 9, 0.075);
}

.guest-entry-stage::before,
.guest-events-panel::before,
.guest-module-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, transparent 0 8%, rgba(255, 255, 255, 0.022) 8% 9%, transparent 9% 100%),
    linear-gradient(180deg, transparent 0 22%, rgba(255, 255, 255, 0.018) 22% 23%, transparent 23% 100%);
  mix-blend-mode: screen;
  opacity: 0.32;
}

.guest-entry-stage {
  padding: clamp(26px, 4vw, 42px);
}

.guest-entry-grid {
  grid-template-columns: minmax(0, 1.08fr) minmax(280px, 0.92fr);
  align-items: stretch;
}

.guest-entry-copy,
.guest-entry-atlas,
.guest-events-spotlight,
.guest-entry-signal {
  position: relative;
  z-index: 1;
}

.guest-entry-copy {
  display: grid;
  gap: 18px;
  align-content: start;
}

.guest-entry-copy h1,
.guest-section-head h2,
.guest-events-head h2 {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(2.2rem, 4vw, 4.1rem);
  line-height: 0.94;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-wrap: balance;
}

.guest-entry-nav {
  grid-auto-flow: column;
  grid-auto-columns: max-content;
  align-items: center;
}

.guest-entry-atlas {
  grid-template-columns: 1fr;
  align-content: end;
}

.guest-entry-stat,
.guest-events-spotlight,
.guest-artist-card,
.guest-ticket-panel,
.guest-vip-panel {
  border: 1px solid rgba(255, 255, 255, 0.12);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.014), transparent 30%),
    rgba(8, 8, 9, 0.075);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.18);
}

.guest-entry-stat {
  padding: 18px 20px;
  min-height: 128px;
  align-content: end;
}

.guest-entry-signal {
  min-height: 100%;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background:
    radial-gradient(circle at 24% 28%, rgba(255, 255, 255, 0.1), transparent 18%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.06), transparent 16%),
    rgba(255, 255, 255, 0.02);
  overflow: hidden;
}

.guest-entry-signal-line {
  position: absolute;
  inset: auto 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.22), transparent);
  opacity: 0.7;
}

.guest-entry-signal-line-a {
  top: 18%;
}

.guest-entry-signal-line-b {
  top: 48%;
}

.guest-entry-signal-line-c {
  top: 74%;
}

.guest-stage-band {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.guest-stage-band span {
  display: block;
  min-height: 6px;
  border-radius: 999px;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.05), rgba(210, 194, 150, 0.32), rgba(255, 255, 255, 0.05));
  opacity: 0.76;
}

.guest-events-panel {
  padding: clamp(24px, 3vw, 34px);
}

.guest-events-head {
  grid-template-columns: minmax(0, 1fr) minmax(280px, 0.52fr);
  align-items: start;
}

.guest-events-spotlight {
  padding: 18px 20px;
  align-content: start;
}

.guest-event-list {
  gap: 16px;
}

.guest-event-row,
.guest-event-detail-panel,
.guest-event-detail-empty {
  border-color: rgba(255, 255, 255, 0.12);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.013), transparent 28%),
    rgba(8, 8, 9, 0.075);
}

.guest-event-row {
  grid-template-columns: minmax(180px, 220px) minmax(0, 1fr) auto;
  gap: 22px;
  align-items: stretch;
  padding: 20px;
}

.guest-event-row.is-active {
  border-color: rgba(210, 194, 150, 0.42);
  box-shadow: 0 24px 44px rgba(0, 0, 0, 0.26);
}

.guest-event-poster {
  position: relative;
  display: grid;
}

.guest-event-thumb-wrap,
.guest-event-thumb {
  width: 100%;
  min-height: 100%;
}

.guest-event-thumb-wrap {
  min-height: 220px;
}

.guest-event-thumb {
  min-height: 220px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  filter: contrast(1.05) brightness(0.88);
}

.guest-event-accent {
  position: absolute;
  left: 12px;
  bottom: 12px;
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 6px 10px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(0, 0, 0, 0.56);
  font-family: var(--font-display);
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.guest-event-main {
  align-content: start;
  gap: 10px;
}

.guest-event-side {
  align-content: end;
}

.guest-event-detail {
  margin-top: 10px;
  gap: 18px;
}

.has-guest-event-overlay {
  overflow: hidden;
}

.guest-event-overlay {
  position: fixed;
  inset: 0;
  z-index: 48;
  display: grid;
  place-items: center;
  padding: 24px;
}

.guest-event-overlay-backdrop {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at top, rgba(38, 48, 79, 0.22), transparent 26%),
    rgba(2, 2, 3, 0.82);
  backdrop-filter: blur(16px);
}

.guest-event-overlay-panel {
  position: relative;
  z-index: 1;
  width: min(1220px, 100%);
  max-height: calc(100vh - 48px);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  border: 1px solid rgba(255, 255, 255, 0.16);
  background:
    radial-gradient(circle at top right, rgba(76, 112, 216, 0.08), transparent 20%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.04), transparent 14%),
    rgba(6, 7, 9, 0.98);
  box-shadow: 0 34px 90px rgba(0, 0, 0, 0.48);
  overflow: hidden;
}

.guest-event-overlay-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  padding: 22px 24px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  background:
    linear-gradient(180deg, rgba(18, 19, 22, 0.96), rgba(8, 8, 10, 0.92)),
    rgba(8, 8, 10, 0.94);
}

.guest-event-overlay-body {
  display: grid;
  gap: 18px;
  padding: 22px 24px 24px;
  overflow: auto;
}

.guest-event-overlay-grid {
  display: grid;
  grid-template-columns: minmax(320px, 0.68fr) minmax(0, 1fr);
  gap: 18px;
}

.guest-event-detail-panel {
  padding: 22px;
}

.guest-event-detail-facts {
  align-content: start;
}

.guest-event-detail-flyer-frame {
  min-height: 360px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), transparent),
    rgba(0, 0, 0, 0.28);
}

.guest-event-detail-flyer-image {
  object-fit: cover;
}

.guest-event-timetable-row {
  padding-top: 16px;
}

.guest-modules-grid {
  grid-template-columns: minmax(0, 1.08fr) minmax(300px, 0.92fr);
  align-items: start;
}

.guest-modules-main,
.guest-modules-stack {
  display: grid;
  gap: 20px;
}

.guest-module-panel {
  padding: clamp(22px, 3vw, 30px);
}

.guest-section-head {
  display: grid;
  gap: 10px;
}

.guest-artists-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.guest-artist-card {
  display: grid;
  grid-template-columns: minmax(120px, 160px) minmax(0, 1fr);
  gap: 18px;
  overflow: hidden;
  padding: 18px;
}

.guest-artist-card.is-active {
  border-color: rgba(220, 198, 142, 0.36);
  background:
    radial-gradient(circle at top right, rgba(210, 194, 151, 0.08), transparent 30%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.035), transparent 30%),
    rgba(8, 8, 9, 0.085);
}

.guest-artist-card-trigger {
  display: grid;
  grid-template-columns: inherit;
  gap: inherit;
  width: 100%;
  padding: 0;
  color: inherit;
  text-align: left;
}

.guest-artist-image-wrap {
  min-height: 180px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: #060606;
  overflow: hidden;
}

.guest-artist-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(0.35) contrast(1.08) brightness(0.72);
}

.guest-artist-copy {
  display: grid;
  gap: 10px;
  align-content: start;
}

.guest-artist-media-hint,
.guest-artist-open-label {
  font-family: var(--font-display);
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.guest-artist-media-hint {
  color: rgba(242, 242, 238, 0.58);
}

.guest-artist-open-label {
  color: rgba(220, 198, 142, 0.88);
}

.guest-artist-card-trigger:hover .guest-artist-open-label,
.guest-artist-card-trigger:focus-visible .guest-artist-open-label {
  color: rgba(244, 228, 188, 0.98);
}

.guest-artist-card-trigger:hover .guest-artist-image,
.guest-artist-card-trigger:focus-visible .guest-artist-image {
  filter: grayscale(0.18) contrast(1.12) brightness(0.78);
  transform: scale(1.015);
}

.guest-artist-image {
  transition: transform 220ms ease, filter 220ms ease;
}

.guest-artist-overlay-panel {
  width: min(1180px, 100%);
  background:
    radial-gradient(circle at top right, rgba(165, 181, 228, 0.1), transparent 24%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.04), transparent 14%),
    rgba(5, 6, 8, 0.985);
}

.guest-artist-overlay-grid {
  display: grid;
  grid-template-columns: minmax(320px, 0.88fr) minmax(0, 1.12fr);
  gap: 18px;
}

.guest-artist-overlay-title {
  margin: 6px 0 0;
  font-family: var(--font-display);
  font-size: clamp(1.7rem, 3vw, 2.6rem);
  letter-spacing: 0.08em;
  line-height: 0.98;
  text-transform: uppercase;
}

.guest-artist-detail-hero {
  min-height: 340px;
  align-content: end;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), transparent 32%),
    linear-gradient(180deg, rgba(11, 11, 13, 0.72), rgba(7, 7, 8, 0.92)),
    rgba(255, 255, 255, 0.02);
}

.guest-artist-detail-gallery {
  align-content: start;
}

.guest-artist-detail-image-grid,
.guest-artist-stream-grid,
.guest-artist-video-grid,
.guest-artist-related-events,
.guest-artist-detail-facts {
  display: grid;
  gap: 14px;
}

.guest-artist-detail-image-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.guest-artist-detail-image-card,
.guest-artist-related-event {
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), transparent 28%),
    rgba(255, 255, 255, 0.02);
}

.guest-artist-detail-image {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  filter: grayscale(0.22) contrast(1.08) brightness(0.76);
}

.guest-artist-detail-facts {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.guest-artist-detail-facts > div,
.guest-artist-related-event {
  padding: 16px;
}

.guest-artist-video-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.guest-artist-video-card {
  display: grid;
  gap: 14px;
  padding: 16px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background:
    radial-gradient(circle at top left, rgba(165, 181, 228, 0.08), transparent 28%),
    rgba(8, 10, 16, 0.78);
  border-radius: 18px;
}

.guest-artist-video-player-shell {
  border-radius: 16px;
  overflow: hidden;
  background:
    radial-gradient(circle at top left, rgba(245, 229, 185, 0.12), transparent 52%),
    rgba(6, 8, 14, 0.82);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.guest-artist-video-player {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #05070d;
}

.guest-artist-video-fallback,
.guest-artist-video-copy,
.guest-artist-video-badges {
  display: grid;
  gap: 10px;
}

.guest-artist-video-fallback {
  padding: 18px;
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.04);
}

.guest-artist-video-link {
  color: rgba(244, 228, 188, 0.96);
  text-decoration: none;
  font-family: var(--font-display);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.guest-artist-video-link:hover,
.guest-artist-video-link:focus-visible {
  text-decoration: underline;
}

.guest-module-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.guest-module-list li {
  padding: 14px 0 0;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  color: #d7d7d3;
}

.guest-ticket-panel,
.guest-vip-panel,
.guest-access-gate {
  align-content: start;
}

.guest-area-shell-locked .guest-entry-stage {
  min-height: 360px;
}

.guest-entry-stage-locked .guest-entry-grid {
  grid-template-columns: minmax(0, 1.2fr) minmax(220px, 0.8fr);
}

@media (max-width: 1120px) {
  .hero,
  .section-grid,
  .archive-grid,
  .split-section,
  .footer-grid,
  .artist-grid,
  .media-grid,
  .admin-form-grid,
  .flyer-intake-grid,
  .admin-quick-grid,
  .organizer-stats-grid,
  .admin-planner-summary,
  .admin-actions-cluster,
  .admin-card-actions,
  .admin-list-grid,
  .admin-planner-detail-grid,
  .editor-action-bar,
  .editor-action-buttons,
  .workspace-editor-footer-bar,
  .workspace-editor-footer-actions,
  .guest-event-detail-grid,
  .guest-event-dj-grid,
  .summary-grid,
  .info-columns {
    grid-template-columns: 1fr;
  }

  .admin-planner-workspace,
  .admin-compact-event,
  .guest-event-row {
    grid-template-columns: 1fr;
  }

  .admin-actions-cluster-detail {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .admin-media-window-grid,
  .media-window-header,
  .media-window-actions,
  .guest-entry-grid,
  .guest-events-head,
  .guest-modules-grid,
  .guest-artists-grid,
  .guest-entry-stage-locked .guest-entry-grid,
  .guest-artist-overlay-grid,
  .guest-artist-detail-facts,
  .guest-artist-video-grid {
    grid-template-columns: 1fr;
  }

  .hero-copy {
    min-height: unset;
  }

  .archive-shot-crowd {
    grid-row: auto;
    min-height: 420px;
  }

  .admin-window-panel {
    width: min(100%, 100%);
  }

  .admin-artist-list-card {
    grid-template-columns: 1fr;
  }

  .admin-planner-calendar {
    position: static;
  }

  .editor-action-bar-sticky {
    position: static;
    top: auto;
    box-shadow: none;
    backdrop-filter: none;
  }
}

@media (max-width: 760px) {
  .site-shell {
    width: min(100% - 16px, 100%);
    padding-top: 8px;
  }

  .topbar {
    top: 8px;
    padding: 16px;
  }

  .hero-copy,
  .hero-visuals,
  .section,
  .area-heading,
  .feature-panel,
  .summary-card,
  .info-columns article {
    padding: 20px 18px;
  }

  .hero-data,
  .event-head,
  .event-row {
    grid-template-columns: 1fr;
  }

  .hero-actions {
    flex-direction: column;
  }

  .event-head {
    display: none;
  }

  .event-row-label {
    font-size: 1.3rem;
  }

  .module-card-artist {
    grid-template-columns: 1fr;
  }

  .module-card-thumb-wrap,
  .admin-artist-thumb-wrap {
    width: 100%;
  }

  .admin-window-backdrop {
    padding: 0;
  }

  .admin-window-panel {
    max-height: 100vh;
    min-height: 100vh;
    border-left: 0;
    border-right: 0;
  }

  .workspace-editor-mask-backdrop {
    padding: 0;
  }

  .workspace-editor-mask-panel {
    min-height: 100vh;
    border-left: 0;
    border-right: 0;
  }

  .workspace-editor-mask-footer {
    padding: 0 18px 18px;
  }

  .admin-window-header,
  .admin-window-body {
    padding: 18px;
  }

  .admin-media-subnav,
  .admin-media-window-grid,
  .admin-timeslot-grid,
  .admin-timeslot-action-row,
  .admin-media-dj-row,
  .admin-media-dj-panel-head,
  .admin-media-entry-card-compact,
  .admin-image-folder-list,
  .admin-image-upload-list,
  .admin-image-asset-grid,
  .admin-video-asset-grid,
  .admin-linked-video-browser-grid,
  .admin-image-folder-meta-grid,
  .admin-image-folder-head,
  .admin-image-assignment-actions,
  .admin-image-upload-actions,
  .admin-image-asset-actions,
  .admin-actions-cluster-media-inline {
    grid-template-columns: 1fr;
  }

  .admin-image-meta-wide {
    grid-column: auto;
  }

  .admin-image-folder-head-side {
    justify-items: start;
  }

  .admin-calendar-nav {
    grid-template-columns: 1fr;
  }

  .guest-event-thumb-wrap {
    width: 100%;
  }

  .guest-event-side {
    justify-items: stretch;
  }

  .guest-event-timetable-row,
  .guest-event-detail-header {
    grid-template-columns: 1fr;
  }

  .editor-action-status-row {
    align-items: stretch;
  }

  .admin-event-detail-head {
    flex-direction: column;
    align-items: start;
  }

  .admin-actions-cluster-detail {
    grid-template-columns: 1fr;
  }

  .media-window-actions {
    grid-template-columns: 1fr;
    justify-content: stretch;
  }
}

.public-heading {
  gap: 10px;
}

.public-page-nav {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  padding: 16px 18px;
  align-items: center;
}

.public-hero,
.public-split-grid,
.public-impression-grid,
.public-location-grid,
.public-event-grid,
.public-hero-data,
.public-hero-actions,
.public-inline-actions,
 .public-access-actions,
 .public-location-actions {
  display: grid;
  gap: 16px;
}

.public-hero {
  grid-template-columns: minmax(0, 1.02fr) minmax(360px, 0.98fr);
  padding: clamp(22px, 3vw, 36px);
  overflow: hidden;
  background:
    radial-gradient(circle at top right, rgba(64, 110, 255, 0.11), transparent 22%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.02), transparent 20%),
    rgba(7, 7, 8, 0.075);
}

.public-hero-copy,
.public-hero-media,
.public-hero-image-card,
.public-hero-video-card,
.public-event-card,
.public-impression-card,
.public-impression-video-card,
.public-location-card,
 .public-conversion-inline,
 .public-location-address-card,
 .public-location-transit,
 .public-location-map-shell,
 .public-location-map-fallback {
  display: grid;
  gap: 14px;
}

.public-hero-copy {
  align-content: start;
}

.public-hero-brand {
  position: relative;
  display: inline-grid;
  grid-template-areas: "stack";
  width: fit-content;
  padding: 12px 16px 14px;
  overflow: hidden;
  isolation: isolate;
  animation: roofSignalBrandJolt 16.5s steps(6, end) infinite;
}

.public-hero-logo,
.public-hero-logo-slice,
.public-hero-brand-noise,
.public-hero-brand-scanline,
.public-hero-brand-sync,
.public-hero-brand-flare {
  grid-area: stack;
}

.public-hero-logo {
  position: relative;
  width: min(360px, 82%);
  filter: drop-shadow(0 0 32px rgba(255, 255, 255, 0.08));
}

.public-hero-logo-base {
  z-index: 2;
}

.public-hero-logo-ghost {
  position: relative;
  z-index: 1;
  opacity: 0.16;
  mix-blend-mode: screen;
  pointer-events: none;
}

.public-hero-logo-ghost-a {
  filter: blur(0.45px) contrast(1.1) brightness(1.06);
  animation: roofSignalGhostA 7.8s steps(6, end) infinite;
}

.public-hero-logo-ghost-b {
  opacity: 0.1;
  filter: blur(1.1px) contrast(1.12) brightness(0.94);
  animation: roofSignalGhostB 10.6s steps(7, end) infinite;
}

.public-hero-logo-slice {
  position: relative;
  z-index: 3;
  display: block;
  overflow: hidden;
  pointer-events: none;
  opacity: 0.24;
  mix-blend-mode: screen;
}

.public-hero-logo-slice-a {
  clip-path: inset(12% 0 64% 0);
  animation: roofSignalSliceA 7.2s steps(7, end) infinite;
}

.public-hero-logo-slice-b {
  clip-path: inset(40% 0 38% 0);
  animation: roofSignalSliceB 9.2s steps(8, end) infinite;
}

.public-hero-logo-slice-c {
  clip-path: inset(70% 0 8% 0);
  animation: roofSignalSliceC 8.1s steps(6, end) infinite;
}

.public-hero-logo-slice-image {
  display: block;
  width: min(360px, 82%);
  filter: blur(0.35px) contrast(1.08) brightness(1.02);
}

.public-hero-brand-noise,
.public-hero-brand-scanline,
.public-hero-brand-sync,
.public-hero-brand-flare {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.public-hero-brand-noise {
  background:
    repeating-linear-gradient(
      0deg,
      rgba(255, 255, 255, 0.035) 0 1px,
      transparent 1px 3px
    ),
    linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0.045) 18%, transparent 34%, rgba(255, 255, 255, 0.03) 54%, transparent 72%),
    radial-gradient(circle at 20% 18%, rgba(255, 255, 255, 0.08), transparent 24%),
    radial-gradient(circle at 78% 72%, rgba(255, 255, 255, 0.06), transparent 26%);
  mix-blend-mode: screen;
  opacity: 0.18;
  animation: roofSignalNoise 5.6s steps(8, end) infinite;
}

.public-hero-brand-scanline {
  background:
    repeating-linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.06) 0 1px,
      transparent 1px 4px,
      rgba(0, 0, 0, 0.12) 4px 5px
    );
  background-size: 100% 5px;
  opacity: 0.12;
  animation: roofSignalScan 8.1s linear infinite;
}

.public-hero-brand-sync {
  background:
    linear-gradient(
      180deg,
      transparent 0 18%,
      rgba(255, 255, 255, 0.12) 18% 22%,
      transparent 22% 44%,
      rgba(255, 255, 255, 0.08) 44% 47%,
      transparent 47% 100%
    );
  mix-blend-mode: screen;
  opacity: 0;
  animation: roofSignalSyncBand 8.6s steps(7, end) infinite;
}

.public-hero-brand-flare {
  background:
    linear-gradient(90deg, transparent 0 14%, rgba(255, 255, 255, 0.08) 14% 18%, transparent 18% 100%);
  mix-blend-mode: screen;
  opacity: 0;
  animation: roofSignalFlare 9.4s steps(6, end) infinite;
}

.public-hero-signal {
  position: relative;
}

.public-hero-signal::before,
.public-hero-signal::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.public-hero-signal::before {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), transparent 16%, rgba(255, 255, 255, 0.02) 72%, transparent 100%);
  opacity: 0.15;
  animation: roofSignalFrameFlicker 7.2s steps(7, end) infinite;
}

.public-hero-signal::after {
  background:
    linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0.04) 24%, transparent 44%, rgba(255, 255, 255, 0.03) 68%, transparent 100%);
  opacity: 0.14;
  transform: translateX(-1%);
  animation: roofSignalInterference 9.8s steps(9, end) infinite;
}

.site-shell[data-audio-mode="active"] .public-hero-brand-noise,
.site-shell[data-audio-mode="active"] .public-hero-brand-sync,
.site-shell[data-audio-mode="active"] .public-hero-brand-flare,
.site-shell[data-audio-mode="active"] .public-hero-logo-slice,
.site-shell[data-audio-mode="active"] .public-hero-logo-ghost,
.site-shell[data-audio-mode="active"] .public-hero-signal::after {
  opacity: 0.3;
}

.site-shell[data-audio-mode="active"] .public-hero-brand-noise {
  animation-duration: 3.9s;
}

.site-shell[data-audio-mode="active"] .public-hero-brand {
  animation-duration: 10.8s;
}

.site-shell[data-audio-mode="active"] .public-hero-logo-slice-a {
  animation-duration: 4.1s;
}

.site-shell[data-audio-mode="active"] .public-hero-logo-slice-b {
  animation-duration: 4.4s;
}

.site-shell[data-audio-mode="active"] .public-hero-logo-slice-c {
  animation-duration: 3.9s;
}

.site-shell[data-audio-mode="active"] .public-hero-brand-sync,
.site-shell[data-audio-mode="active"] .public-hero-brand-flare,
.site-shell[data-audio-mode="active"] .public-hero-signal::after {
  animation-duration: 4.3s;
}

.site-shell[data-audio-pulse="boost"] .public-hero-brand {
  animation-duration: 1.2s;
}

.site-shell[data-audio-pulse="boost"] .public-hero-logo-slice,
.site-shell[data-audio-pulse="boost"] .public-hero-logo-ghost,
.site-shell[data-audio-pulse="boost"] .public-hero-brand-noise,
.site-shell[data-audio-pulse="boost"] .public-hero-brand-sync,
.site-shell[data-audio-pulse="boost"] .public-hero-brand-flare,
.site-shell[data-audio-pulse="boost"] .public-hero-signal::after {
  animation-duration: 0.5s;
}

.public-hero h1 {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(2.2rem, 5vw, 4.8rem);
  line-height: 0.94;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.public-hero-statement {
  margin: 0;
  max-width: 42ch;
  font-family: var(--font-display);
  font-size: clamp(1rem, 2vw, 1.35rem);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.public-hero-copy .feature-copy,
.public-section .feature-copy {
  max-width: 78ch;
}

.public-hero-actions,
.public-access-actions,
 .public-inline-actions,
 .public-location-actions {
  grid-auto-flow: column;
  grid-auto-columns: max-content;
  align-items: center;
}

.public-page-nav .preview-button,
.public-hero-actions .action-button,
.public-access-actions .action-button,
.public-inline-actions .action-button {
  min-height: 48px;
}

.public-hero-data {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.public-hero-data article,
.public-location-card,
 .public-conversion-inline,
 .public-location-address-card,
 .public-location-transit,
 .public-location-map-shell {
  padding: 16px;
  border: 1px solid var(--border);
  background: rgba(8, 8, 9, 0.075);
}

.public-location-map-frame {
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(0, 0, 0, 0.22);
}

.public-location-map-embed {
  display: block;
  width: 100%;
  min-height: 320px;
  border: 0;
}

.public-location-map-fallback {
  min-height: 220px;
  align-content: center;
  justify-items: start;
  padding: 20px;
  border: 1px dashed rgba(255, 255, 255, 0.22);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), transparent),
    rgba(255, 255, 255, 0.02);
}

.public-hero-media {
  align-content: start;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.public-hero-image-card,
.public-hero-video-card,
.public-impression-card,
.public-impression-video-card {
  overflow: hidden;
  border: 1px solid var(--border);
  background: rgba(0, 0, 0, 0.22);
}

.public-hero-image-card img,
.public-impression-card img,
.public-club-visual {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.public-hero-image-card {
  min-height: 260px;
}

.public-hero-image-secondary {
  min-height: 180px;
}

.public-hero-video-card {
  grid-column: span 2;
  min-height: 220px;
}

.public-hero-video,
.public-impression-video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  background: #050505;
}

.public-section {
  padding: clamp(22px, 3vw, 34px);
}

.public-split-grid {
  grid-template-columns: 1fr 1fr;
}

.public-event-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.public-event-card {
  overflow: hidden;
  border: 1px solid var(--border);
  background: rgba(8, 8, 9, 0.075);
}

.public-event-card-image {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

.public-event-card-copy,
.public-impression-copy,
.public-club-visual-copy {
  display: grid;
  gap: 10px;
  padding: 16px;
}

.public-event-card-meta {
  color: var(--muted);
}

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

.public-impression-grid-wide {
  align-items: start;
}

.public-impression-card img {
  aspect-ratio: 4 / 5;
}

.public-impression-video-card {
  padding: 18px;
}

.public-split-grid-club,
.public-split-grid-access {
  align-items: stretch;
}

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

.public-club-visual-panel {
  overflow: hidden;
}

.public-club-visual {
  min-height: 320px;
  filter: grayscale(0.2) contrast(1.06) brightness(0.82);
}

.public-conversion-band {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: center;
  padding: 22px 24px;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.022), transparent 35%),
    rgba(8, 8, 9, 0.075);
}

.public-house-rules-hero,
.public-house-rules-section,
.public-house-rules-grid,
.public-house-rule-card,
.public-house-rule-head,
.public-house-rule-copy,
.public-house-rules-closing,
.public-house-rules-hero-copy,
.public-house-rules-sidecar,
.public-house-rule-titles {
  display: grid;
  gap: 18px;
}

.public-house-rules-hero {
  grid-template-columns: minmax(0, 1.18fr) minmax(280px, 0.82fr);
  padding: clamp(24px, 3vw, 38px);
  overflow: hidden;
  background:
    radial-gradient(circle at top left, rgba(212, 178, 112, 0.1), transparent 24%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.03), transparent 26%),
    rgba(7, 7, 8, 0.075);
}

.public-house-rules-hero-copy {
  align-content: start;
}

.public-house-rules-sidecar,
.public-house-rule-card {
  padding: 16px;
  border: 1px solid var(--border);
}

.public-house-rules-sidecar {
  align-content: start;
  background:
    linear-gradient(180deg, rgba(240, 216, 164, 0.08), transparent 48%),
    rgba(8, 8, 9, 0.12);
}

.public-house-rules-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.public-house-rule-card {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), transparent 18%),
    rgba(8, 8, 9, 0.1);
}

.public-house-rule-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 3px;
  background: linear-gradient(180deg, rgba(241, 221, 178, 0.9), rgba(170, 62, 48, 0.42));
}

.public-house-rule-head {
  grid-template-columns: auto 1fr;
  align-items: start;
  gap: 14px;
}

.public-house-rule-number,
.public-house-rules-closing-german,
.public-house-rules-closing-english,
.public-house-rule-titles h2,
.public-house-rule-english-title {
  font-family: var(--font-display);
  text-transform: uppercase;
}

.public-house-rule-number {
  display: inline-grid;
  place-items: center;
  min-width: 54px;
  min-height: 54px;
  padding: 8px;
  border: 1px solid rgba(241, 221, 178, 0.28);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.03);
  color: rgba(241, 221, 178, 0.9);
  font-size: 1rem;
  letter-spacing: 0.18em;
}

.public-house-rule-titles {
  gap: 8px;
}

.public-house-rule-titles h2 {
  margin: 0;
  font-size: clamp(1.05rem, 2vw, 1.4rem);
  letter-spacing: 0.08em;
  line-height: 1.05;
}

.public-house-rule-english-title {
  margin: 0;
  color: rgba(241, 221, 178, 0.72);
  font-size: 0.82rem;
  letter-spacing: 0.16em;
}

.public-house-rule-english-copy {
  color: rgba(242, 242, 238, 0.74);
}

.public-house-rules-closing {
  padding: clamp(24px, 3vw, 34px);
  justify-items: start;
  background:
    radial-gradient(circle at top right, rgba(212, 178, 112, 0.08), transparent 26%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), transparent 22%),
    rgba(8, 8, 9, 0.12);
}

.public-house-rules-closing-german,
.public-house-rules-closing-english {
  margin: 0;
  max-width: 30ch;
  font-size: clamp(1.15rem, 2vw, 1.7rem);
  line-height: 1.08;
  letter-spacing: 0.08em;
}

.public-house-rules-closing-english {
  color: rgba(241, 221, 178, 0.88);
}

@keyframes ambientAudioWaveIdle {
  0%,
  100% {
    transform: scaleY(0.42);
    opacity: 0.45;
  }

  50% {
    transform: scaleY(0.9);
    opacity: 0.86;
  }
}

@keyframes ambientAudioWaveActive {
  0%,
  100% {
    transform: scaleY(0.28);
    opacity: 0.42;
  }

  20% {
    transform: scaleY(1.08);
    opacity: 0.98;
  }

  55% {
    transform: scaleY(0.62);
    opacity: 0.7;
  }

  80% {
    transform: scaleY(1.24);
    opacity: 1;
  }
}

@keyframes roofSignalBrandJolt {
  0%,
  100% {
    transform: translate3d(0, 0, 0);
  }

  11% {
    transform: translate3d(0, 0, 0);
  }

  12% {
    transform: translate3d(-2px, 0, 0);
  }

  13% {
    transform: translate3d(3px, -1px, 0);
  }

  14% {
    transform: translate3d(-1px, 1px, 0);
  }

  15% {
    transform: translate3d(0, 0, 0);
  }

  57% {
    transform: translate3d(0, 0, 0);
  }

  58% {
    transform: translate3d(2px, 0, 0);
  }

  59% {
    transform: translate3d(-3px, 1px, 0);
  }

  60% {
    transform: translate3d(1px, 0, 0);
  }

  61% {
    transform: translate3d(0, 0, 0);
  }
}

@keyframes roofSignalGhostA {
  0%,
  100% {
    transform: translate3d(0, 0, 0);
    opacity: 0.13;
  }

  11% {
    transform: translate3d(2px, 0, 0);
    opacity: 0.24;
  }

  27% {
    transform: translate3d(-3px, 0, 0);
    opacity: 0.16;
  }

  53% {
    transform: translate3d(3px, -1px, 0);
    opacity: 0.26;
  }

  71% {
    transform: translate3d(-2px, 0, 0);
    opacity: 0.14;
  }
}

@keyframes roofSignalGhostB {
  0%,
  100% {
    transform: translate3d(0, 0, 0);
    opacity: 0.04;
  }

  17% {
    transform: translate3d(-4px, 1px, 0);
    opacity: 0.11;
  }

  36% {
    transform: translate3d(2px, -1px, 0);
    opacity: 0.16;
  }

  62% {
    transform: translate3d(4px, 0, 0);
    opacity: 0.1;
  }

  83% {
    transform: translate3d(-3px, 0, 0);
    opacity: 0.14;
  }
}

@keyframes roofSignalSliceA {
  0%,
  100% {
    transform: translate3d(0, 0, 0);
    opacity: 0.06;
  }

  8% {
    transform: translate3d(0, 0, 0);
  }

  9% {
    transform: translate3d(12px, 0, 0);
    opacity: 0.34;
  }

  11% {
    transform: translate3d(-8px, 0, 0);
    opacity: 0.22;
  }

  13% {
    transform: translate3d(0, 0, 0);
    opacity: 0.08;
  }

  64% {
    transform: translate3d(0, 0, 0);
  }

  66% {
    transform: translate3d(10px, 0, 0);
    opacity: 0.3;
  }

  68% {
    transform: translate3d(0, 0, 0);
    opacity: 0.08;
  }
}

@keyframes roofSignalSliceB {
  0%,
  100% {
    transform: translate3d(0, 0, 0);
    opacity: 0.05;
  }

  19% {
    transform: translate3d(0, 0, 0);
  }

  20% {
    transform: translate3d(-14px, 0, 0);
    opacity: 0.4;
  }

  22% {
    transform: translate3d(6px, 0, 0);
    opacity: 0.22;
  }

  24% {
    transform: translate3d(0, 0, 0);
    opacity: 0.05;
  }

  78% {
    transform: translate3d(0, 0, 0);
  }

  80% {
    transform: translate3d(-10px, 0, 0);
    opacity: 0.32;
  }

  82% {
    transform: translate3d(0, 0, 0);
    opacity: 0.05;
  }
}

@keyframes roofSignalSliceC {
  0%,
  100% {
    transform: translate3d(0, 0, 0);
    opacity: 0.04;
  }

  31% {
    transform: translate3d(0, 0, 0);
  }

  33% {
    transform: translate3d(8px, 0, 0);
    opacity: 0.28;
  }

  35% {
    transform: translate3d(-7px, 0, 0);
    opacity: 0.16;
  }

  37% {
    transform: translate3d(0, 0, 0);
    opacity: 0.04;
  }
}

@keyframes roofSignalNoise {
  0%,
  100% {
    transform: translate3d(0, 0, 0);
    opacity: 0.1;
  }

  9% {
    transform: translate3d(0, 1px, 0);
    opacity: 0.15;
  }

  26% {
    transform: translate3d(1px, 0, 0);
    opacity: 0.24;
  }

  51% {
    transform: translate3d(-1px, 0, 0);
    opacity: 0.12;
  }

  73% {
    transform: translate3d(0, -1px, 0);
    opacity: 0.22;
  }
}

@keyframes roofSignalScan {
  0% {
    transform: translateY(-2%);
  }

  100% {
    transform: translateY(2%);
  }
}

@keyframes roofSignalSyncBand {
  0%,
  100% {
    transform: translate3d(0, 0, 0);
    opacity: 0;
  }

  14% {
    opacity: 0;
  }

  15% {
    transform: translate3d(0, -3px, 0);
    opacity: 0.32;
  }

  17% {
    transform: translate3d(0, 3px, 0);
    opacity: 0.18;
  }

  19% {
    transform: translate3d(0, 0, 0);
    opacity: 0;
  }

  74% {
    opacity: 0;
  }

  75% {
    transform: translate3d(0, 1px, 0);
    opacity: 0.24;
  }

  77% {
    transform: translate3d(0, -1px, 0);
    opacity: 0.08;
  }

  79% {
    opacity: 0;
  }
}

@keyframes roofSignalFlare {
  0%,
  100% {
    transform: translateX(-8%);
    opacity: 0;
  }

  42% {
    opacity: 0;
  }

  44% {
    transform: translateX(6%);
    opacity: 0.22;
  }

  46% {
    transform: translateX(-2%);
    opacity: 0.04;
  }

  48% {
    opacity: 0;
  }
}

@keyframes roofSignalFrameFlicker {
  0%,
  100% {
    opacity: 0.1;
    transform: translate3d(0, 0, 0);
  }

  28% {
    opacity: 0.16;
  }

  29% {
    opacity: 0.05;
    transform: translate3d(0, -2px, 0);
  }

  31% {
    opacity: 0.18;
    transform: translate3d(0, 2px, 0);
  }

  33% {
    opacity: 0.1;
    transform: translate3d(0, 0, 0);
  }

  84% {
    opacity: 0.08;
  }

  85% {
    opacity: 0.2;
    transform: translate3d(0, 2px, 0);
  }

  87% {
    opacity: 0.1;
    transform: translate3d(0, 0, 0);
  }
}

@keyframes roofSignalInterference {
  0%,
  100% {
    transform: translateX(-1%);
    opacity: 0.08;
  }

  15% {
    transform: translateX(1%);
    opacity: 0.26;
  }

  39% {
    transform: translateX(-2%);
    opacity: 0.16;
  }

  63% {
    transform: translateX(2%);
    opacity: 0.28;
  }

  84% {
    transform: translateX(0%);
    opacity: 0.1;
  }
}

@keyframes clubBackdropCrossfade {
  0%,
  100% {
    opacity: 0;
  }

  12% {
    opacity: 0.22;
  }

  22% {
    opacity: 0.36;
  }

  54% {
    opacity: 0.34;
  }

  72% {
    opacity: 0.12;
  }
}

@keyframes clubBackdropDrift {
  0%,
  100% {
    transform: translate3d(calc(var(--club-backdrop-drift-x, 2%) * -0.4), calc(var(--club-backdrop-drift-y, 1%) * -0.4), 0) scale(1.02);
  }

  50% {
    transform: translate3d(var(--club-backdrop-drift-x, 2%), var(--club-backdrop-drift-y, 1%), 0) scale(var(--club-backdrop-scale, 1.06));
  }
}

@keyframes clubBackdropNoiseDrift {
  0%,
  100% {
    transform: translate3d(0, 0, 0);
    opacity: 0.24;
  }

  25% {
    transform: translate3d(0, -1.5%, 0);
    opacity: 0.3;
  }

  50% {
    transform: translate3d(0, 1.25%, 0);
    opacity: 0.26;
  }

  75% {
    transform: translate3d(0, -0.75%, 0);
    opacity: 0.34;
  }
}

@media (max-width: 1120px) {
  .public-hero,
  .public-split-grid,
  .public-impression-grid,
  .public-location-grid,
  .public-event-grid,
  .public-hero-data,
  .public-hero-media,
  .public-conversion-band,
  .public-house-rules-hero,
  .public-house-rules-grid {
    grid-template-columns: 1fr;
  }

  .public-hero-video-card {
    grid-column: auto;
  }
}

@media (max-width: 760px) {
  .club-backdrop-bloom {
    opacity: 0.58;
  }

  .club-backdrop-layer-4,
  .club-backdrop-layer-5 {
    display: none;
  }

  .club-backdrop-noise {
    opacity: 0.2;
  }

  .ambient-audio-control {
    right: 16px;
    bottom: 16px;
    min-width: 0;
    width: calc(100% - 32px);
    grid-template-columns: 40px minmax(0, 1fr);
  }

  .public-page-nav {
    gap: 10px;
    flex-wrap: nowrap;
    overflow-x: auto;
    scroll-snap-type: x proximity;
  }

  .public-page-nav .preview-button {
    flex: 0 0 auto;
    scroll-snap-align: start;
  }

  .public-hero-actions,
  .public-access-actions,
  .public-inline-actions,
  .public-location-actions {
    grid-auto-flow: row;
    grid-auto-columns: 1fr;
  }

  .public-location-map-embed {
    min-height: 240px;
  }

  .artist-portal-head {
    grid-template-columns: 1fr;
  }

  .guest-entry-stage,
  .guest-events-panel,
  .guest-module-panel,
  .guest-access-gate {
    padding: 20px 18px;
  }

  .guest-entry-nav {
    grid-auto-flow: row;
    grid-auto-columns: 1fr;
  }

  .guest-event-row,
  .guest-artist-card {
    grid-template-columns: 1fr;
  }

  .guest-event-thumb,
  .guest-event-thumb-wrap {
    min-height: 240px;
  }

  .guest-event-overlay {
    padding: 0;
  }

  .guest-event-overlay-panel {
    width: 100%;
    max-height: 100vh;
    min-height: 100vh;
    border-left: 0;
    border-right: 0;
  }

  .guest-event-overlay-head,
  .guest-event-overlay-body {
    padding: 18px;
  }

  .guest-event-overlay-grid {
    grid-template-columns: 1fr;
  }

  .guest-artist-detail-image-grid {
    grid-template-columns: 1fr;
  }

  .guest-event-side {
    justify-items: stretch;
  }

  .guest-entry-copy h1,
  .guest-section-head h2,
  .guest-events-head h2 {
    font-size: clamp(1.85rem, 9vw, 3rem);
  }

  .public-page-nav {
    padding: 14px 16px;
  }

  .public-section,
  .public-hero {
    padding: 20px 18px;
  }

  .public-hero-logo {
    width: min(300px, 88%);
  }
}
