:root {
  --bg: #050505;
  --panel: #111111;
  --panel2: #1a1a1a;
  --line: #2d2d2d;
  --text: #f5f5f5;
  --muted: #b8b8b8;
  --primary: #f0f0f0;
  --primary-2: #cfcfcf;
  --good: #e0e0e0;
  --warn: #ffffff;
  --nameplate-tilt: -1.5deg;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: "Segoe UI", "Inter", sans-serif;
  background: radial-gradient(circle at 20% 0%, #1a1a1a 0%, var(--bg) 55%);
  color: var(--text);
  min-height: 100vh;
}

a {
  color: inherit;
}

.app {
  padding: 16px;
  max-width: 1600px;
  margin: 0 auto;
}

.simple-shell {
  max-width: 1200px;
}

.hub-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 12px;
  margin-top: 12px;
}

.hub-card {
  display: block;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #121212;
  padding: 14px;
  text-decoration: none;
}

.hub-card h2 {
  margin: 0 0 6px;
  font-size: 1.15rem;
}

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

.dashboard-topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 14px;
}

.nav {
  display: flex;
  gap: 10px;
  background: #101010;
  border: 1px solid #272727;
  border-radius: 999px;
  padding: 10px;
  margin-bottom: 16px;
}

.nav button,
.nav a {
  border: none;
  border-radius: 999px;
  background: transparent;
  color: #eceff2;
  font-size: 1rem;
  padding: 10px 18px;
  cursor: pointer;
  text-decoration: none;
}

.nav .active {
  background: linear-gradient(120deg, var(--primary), var(--primary-2));
  color: #111111;
}

.dashboard-kpis {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}

.kpi-card {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #101010;
  padding: 10px 12px;
  display: grid;
  gap: 5px;
}

.kpi-card strong {
  font-size: 1.15rem;
}

.kpi-wide {
  grid-column: span 1;
}

.dashboard-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(340px, 1fr);
  gap: 14px;
  align-items: start;
}

.dashboard-main {
  display: grid;
  gap: 14px;
}

.dashboard-side {
  display: grid;
  gap: 14px;
  position: sticky;
  top: 10px;
}

.panel-tight {
  padding: 12px;
}

.section-head {
  margin-bottom: 10px;
}

.section-head p {
  margin: 0;
}

.section-head-inline {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.section-head-inline h2 {
  margin: 0;
}

.control-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.control-card {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #111111;
  padding: 10px;
  display: grid;
  gap: 10px;
}

.control-card h3 {
  margin: 0;
}

.grid {
  display: grid;
  gap: 16px;
}

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

.panel {
  background: linear-gradient(140deg, #141414 0%, #0f0f0f 100%);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 14px;
}

.panel h2,
.panel h3 {
  margin: 0 0 12px;
}

.row {
  display: flex;
  gap: 8px;
  align-items: center;
}

.wrap {
  flex-wrap: wrap;
}

input,
select,
button,
textarea {
  border: 1px solid var(--line);
  background: #121212;
  color: var(--text);
  border-radius: 10px;
  padding: 10px 12px;
  font-size: 1rem;
}

input,
select,
textarea {
  width: 100%;
}

button {
  width: auto;
  cursor: pointer;
}

button.primary {
  background: linear-gradient(120deg, var(--primary), var(--primary-2));
  color: #111111;
  border: none;
}

button.ghost {
  background: #1a1a1a;
}

button.danger {
  background: #222222;
  border-color: #3b3b3b;
}

.entity-list {
  display: grid;
  gap: 8px;
}

.entity-item {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 8px;
}

.qr-panel {
  border: 1px dashed #3a3a3a;
  border-radius: 10px;
  padding: 10px;
  background: #0e0e0e;
  place-items: center;
  gap: 8px;
}

.qr-code-preview {
  width: min(240px, 60vw);
  height: auto;
  border-radius: 8px;
  background: #fff;
  padding: 6px;
}

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

.team-card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 12px;
  display: grid;
  gap: 8px;
}

.team-members {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.dancers-editor {
  display: grid;
  gap: 10px;
}

.dancer-edit-card {
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 10px;
  background: #101010;
  display: grid;
  gap: 8px;
}

.upload-progress {
  width: 100%;
  height: 8px;
  border-radius: 999px;
}

.upload-status {
  font-size: 0.82rem;
}

.dancer-preview {
  min-height: 110px;
  border: 1px dashed #3a3a3a;
  border-radius: 10px;
  display: grid;
  place-items: center;
  background: #0e0e0e;
  overflow: hidden;
  padding: 6px;
}

.dancer-preview img {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
}

.dancer-preview video {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  object-fit: contain;
}

.muted {
  color: var(--muted);
  font-size: 0.9rem;
}

.screen-layout {
  min-height: 100vh;
  padding: 40px;
  display: grid;
  gap: 20px;
  align-content: start;
}

.screen-layout.is-battle {
  padding: 0;
  gap: 0;
  width: 100vw;
  height: 100vh;
  min-height: 100vh;
  overflow: hidden;
}

.fullscreen-media-view {
  width: 100vw;
  height: 100vh;
  min-height: 100vh;
  display: grid;
  place-items: center;
  background: #000;
  overflow: hidden;
}

.fullscreen-media-asset {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  background: #000;
}

.fullscreen-media-asset.is-video {
  object-fit: cover;
}

.team-mode-stage {
  width: 100%;
  height: 100%;
  padding: 36px;
  overflow: auto;
}

.team-mode-stage .score-box {
  margin-top: 0;
}

.screen-title {
  font-size: clamp(2rem, 5vw, 4rem);
  font-weight: 800;
}

.battle-box {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 14px;
  align-items: stretch;
}

.fighter {
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 20px;
  background: linear-gradient(150deg, #1b1d21, #13151a);
}

.fighter h2 {
  margin: 0 0 8px;
  font-size: clamp(1.8rem, 4vw, 3rem);
}

.battle-showcase {
  border: none;
  border-radius: 0;
  overflow: hidden;
  background: linear-gradient(140deg, #1a1a1a, #0f0f0f);
  background-size: 100% 100%;
  background-repeat: no-repeat;
  background-position: center center;
  width: 100vw;
  height: 100vh;
  min-height: 100vh;
}

.team-focus-showcase {
  border: none;
  border-radius: 0;
  overflow: hidden;
  background: linear-gradient(140deg, #1a1a1a, #0f0f0f);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  width: 100vw;
  height: 100vh;
  min-height: 100vh;
}

.team-focus-overlay {
  width: 100%;
  height: 100%;
  min-height: 100%;
  display: grid;
  align-content: end;
  justify-items: center;
  padding: 0 24px 36px;
  gap: 18px;
}

.team-focus-nameplate {
  position: relative;
  width: min(860px, 95vw);
  min-height: 98px;
  background: #0b0b0be5;
  color: #fff;
  border: 3px solid #1f1f1f;
  padding: 10px 14px;
  text-align: center;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.45);
  z-index: 40;
  opacity: 1;
  transform: translateY(0);
  transition:
    opacity 0.6s ease-out,
    transform 0.6s ease-out;
}

.team-focus-name {
  margin: 0;
  font-size: clamp(1.8rem, 4.8vw, 3.2rem);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.team-focus-members {
  margin: 4px 0 0;
  font-size: clamp(0.78rem, 1.2vw, 1rem);
  color: #d3d3d3;
}

.team-focus-dancer-strip {
  width: min(1600px, 98vw);
  display: flex;
  align-items: end;
  justify-content: center;
  gap: clamp(8px, 1.2vw, 22px);
}

.team-focus-dancer-strip.split {
  width: min(1850px, 99vw);
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: end;
  gap: clamp(14px, 2vw, 34px);
}

.team-focus-lane {
  min-width: 0;
  display: flex;
  align-items: end;
  justify-content: center;
  gap: clamp(8px, 1.2vw, 20px);
}

.team-focus-lane.left .team-focus-dancer-card {
  transform: translateX(0) translateY(0) scale(1);
}

.team-focus-lane.right .team-focus-dancer-card {
  transform: translateX(0) translateY(0) scale(1);
}

.team-focus-dancer-card {
  flex: 0 0 clamp(210px, 17vw, 320px);
  opacity: 1;
  transform: translateY(0) scale(1);
}

.team-focus-dancer-photo {
  width: 100%;
  height: clamp(320px, 56vh, 700px);
  object-fit: contain;
  object-position: center bottom;
  filter: drop-shadow(0 14px 18px rgba(0, 0, 0, 0.48));
}

.team-focus-dancer-empty {
  width: 100%;
  height: clamp(320px, 56vh, 700px);
  display: grid;
  place-items: end center;
  color: #bfbfbf;
  font-size: 0.85rem;
}

.team-focus-showcase.stage-bg .team-focus-nameplate,
.team-focus-showcase.stage-bg .team-focus-dancer-card {
  opacity: 0;
  transform: translateY(80px) scale(0.95);
}

.team-focus-showcase.reveal .team-focus-nameplate {
  animation: teamFocusPlateIn 0.68s cubic-bezier(0.22, 1, 0.36, 1) both;
  animation-delay: 0.08s;
}

.team-focus-showcase.reveal .team-focus-lane.left .team-focus-dancer-card {
  animation: teamFocusLeftIn 0.9s cubic-bezier(0.22, 1, 0.36, 1) both;
  animation-delay: calc(0.12s + (var(--i, 0) * 0.09s));
}

.team-focus-showcase.reveal .team-focus-lane.right .team-focus-dancer-card {
  animation: teamFocusRightIn 0.9s cubic-bezier(0.22, 1, 0.36, 1) both;
  animation-delay: calc(0.12s + (var(--i, 0) * 0.09s));
}

@keyframes teamFocusPlateIn {
  from {
    opacity: 0;
    transform: translateY(44px) scale(0.96);
    filter: blur(3px);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: blur(0);
  }
}

@keyframes teamFocusLeftIn {
  from {
    opacity: 0;
    transform: translateX(-280px) translateY(72px) scale(0.92);
    filter: blur(5px);
  }
  to {
    opacity: 1;
    transform: translateX(0) translateY(0) scale(1);
    filter: blur(0);
  }
}

@keyframes teamFocusRightIn {
  from {
    opacity: 0;
    transform: translateX(280px) translateY(72px) scale(0.92);
    filter: blur(5px);
  }
  to {
    opacity: 1;
    transform: translateX(0) translateY(0) scale(1);
    filter: blur(0);
  }
}

.battle-showcase-overlay {
  position: relative;
  padding: 0;
  width: 100%;
  height: 100%;
  min-height: 100%;
  display: grid;
  place-items: center;
}

.battle-fixed-stage {
  --stage-w-px: 1920px;
  --stage-h-px: 1080px;
  --battle-scale: min(calc(100vw / var(--stage-w-px)), calc(100vh / var(--stage-h-px)));
  width: var(--stage-w-px);
  height: var(--stage-h-px);
  transform: scale(var(--battle-scale));
  transform-origin: center center;
  position: relative;
  overflow: visible;
}

.battle-headline {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
}

.battle-faceoff-grid {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  padding: 0 0 12px;
  overflow: visible;
}

.battle-faceoff-grid.single-focus-grid {
  display: grid;
  grid-template-columns: 1fr;
  justify-items: center;
  transform: none;
}

.battle-side-slot {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 50%;
  height: 100%;
  display: flex;
  align-items: end;
  justify-content: center;
  padding: 0 12px;
  overflow: visible;
}

.battle-side-slot.right-slot {
  left: 50%;
}

.battle-team-side.single-focus-side {
  width: min(1080px, 100%);
  justify-content: center;
}

.battle-showcase.winner-focus .battle-team-side.single-focus-side {
  transform: translateX(var(--winner-center-shift-x, 0px)) translateY(var(--winner-center-shift-y, 0px)) scale(1);
}

.battle-showcase.reveal.winner-focus.winner-from-left .single-focus-side {
  animation: winnerToCenterFromLeft 0.55s cubic-bezier(0.2, 1, 0.3, 1) both;
}

.battle-showcase.reveal.winner-focus.winner-from-right .single-focus-side {
  animation: winnerToCenterFromRight 0.55s cubic-bezier(0.2, 1, 0.3, 1) both;
}

.winner-overlay-badge {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 90;
  pointer-events: none;
  user-select: none;
  filter: drop-shadow(0 14px 24px rgba(0, 0, 0, 0.5));
}

@keyframes winnerToCenterFromLeft {
  0% {
    opacity: 0;
    transform: translateX(calc(var(--winner-center-shift-x, 0px) - 560px)) translateY(var(--winner-center-shift-y, 0px))
      scale(0.96);
    filter: blur(6px);
  }
  100% {
    opacity: 1;
    transform: translateX(var(--winner-center-shift-x, 0px)) translateY(var(--winner-center-shift-y, 0px)) scale(1);
    filter: blur(0);
  }
}

@keyframes winnerToCenterFromRight {
  0% {
    opacity: 0;
    transform: translateX(calc(var(--winner-center-shift-x, 0px) + 560px)) translateY(var(--winner-center-shift-y, 0px))
      scale(0.96);
    filter: blur(6px);
  }
  100% {
    opacity: 1;
    transform: translateX(var(--winner-center-shift-x, 0px)) translateY(var(--winner-center-shift-y, 0px)) scale(1);
    filter: blur(0);
  }
}

.battle-team-side.cast-focus-side .battle-dancer-strip {
  max-width: 54%;
  transform: translateX(-50%) translateY(335px);
}

.battle-team-side {
  --nameplate-bottom: calc(20vh / var(--battle-scale, 1));
  --nameplate-height: 92px;
  --dancer-baseline: calc(var(--nameplate-bottom) + var(--nameplate-height) - 78px);
  position: relative;
  min-height: 1080px;
  height: 1080px;
  width: min(980px, calc(100% - 24px));
  min-width: 0;
  display: flex;
  align-items: end;
  justify-content: center;
  padding: 0 0;
  opacity: 1;
  transform: translateX(var(--half-center-shift, 0px)) scale(1);
  filter: blur(0);
  transition:
    transform 0.35s cubic-bezier(0.2, 0.9, 0.3, 1),
    opacity 0.35s cubic-bezier(0.2, 0.9, 0.3, 1),
    filter 0.35s cubic-bezier(0.2, 0.9, 0.3, 1);
}

.battle-team-side.left {
  animation: none;
  justify-content: center;
}

.battle-team-side.right {
  animation: none;
  justify-content: center;
}

.battle-nameplate {
  position: absolute;
  left: 50%;
  transform: translateX(-50%) rotate(var(--nameplate-tilt));
  width: 540px;
  height: 92px;
  bottom: var(--nameplate-bottom);
  z-index: 40;
  background: #0b0b0be5;
  color: #fff;
  border: 3px solid #1f1f1f;
  padding: 8px 12px;
  display: grid;
  align-content: center;
  gap: 2px;
  text-align: center;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.45);
  overflow: visible;
  opacity: 1;
  transition:
    opacity 0.34s ease-out,
    transform 0.34s ease-out,
    filter 0.34s ease-out;
}

.battle-nameplate-frame {
  position: absolute;
  left: 50%;
  bottom: calc(var(--nameplate-bottom) - 19px);
  width: 540px;
  height: auto;
  display: block;
  transform: translateX(-50%) rotate(var(--nameplate-tilt));
  z-index: 30;
  pointer-events: none;
  user-select: none;
}

.battle-team-name {
  margin: 0;
  font-size: 1.6rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.battle-team-members {
  margin: 0;
  font-size: 0.65rem;
  color: #d3d3d3;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.battle-dancer-strip {
  --lane-width: 924px;
  --overlap: 460px;
  position: absolute;
  left: 50%;
  bottom: var(--dancer-baseline);
  z-index: 20;
  transform: translateX(-50%);
  display: flex;
  align-items: end;
  justify-content: center;
  width: 100%;
  max-width: var(--lane-width);
  padding: 0;
  overflow: visible;
}

.battle-dancer-card {
  flex: 0 0 min(780px, calc((var(--lane-width) + ((var(--count, 1) - 1) * var(--overlap))) / var(--count, 1)));
  margin-left: calc(-1 * var(--overlap));
  text-align: center;
  position: relative;
  z-index: calc(20 + var(--i, 0));
  opacity: 1;
  transform: translateY(0) scale(1);
  transition:
    opacity 0.34s ease-out,
    transform 0.34s ease-out,
    filter 0.34s ease-out;
  transition-delay: calc(var(--i, 0) * 0.03s);
}

.battle-dancer-card:first-child {
  margin-left: 0;
}

.battle-dancer-photo {
  width: 100%;
  height: 1170px;
  object-fit: contain;
  object-position: center bottom;
  filter: drop-shadow(0 12px 18px rgba(0, 0, 0, 0.48));
  transform: translateY(0);
}

.battle-dancer-empty {
  width: 100%;
  height: 1170px;
  display: grid;
  place-items: end center;
  color: #bfbfbf;
  font-size: 0.85rem;
  transform: translateY(0);
}

.battle-showcase.stage-bg .battle-nameplate,
.battle-showcase.stage-bg .battle-nameplate-frame,
.battle-showcase.stage-bg .battle-dancer-card {
  opacity: 0;
}

.battle-showcase.stage-bg .battle-team-side.left .battle-nameplate,
.battle-showcase.stage-bg .battle-team-side.left .battle-nameplate-frame,
.battle-showcase.stage-bg .battle-team-side.left .battle-dancer-card {
  transform: translateX(-56px) translateY(4px) scale(1.04);
  filter: blur(9px) contrast(1.15) saturate(1.2);
}

.battle-showcase.stage-bg .battle-team-side.left .battle-nameplate {
  transform: translateX(calc(-50% - 56px)) translateY(4px) rotate(var(--nameplate-tilt)) scale(1.04);
}

.battle-showcase.stage-bg .battle-team-side.left .battle-nameplate-frame {
  transform: translateX(calc(-50% - 56px)) translateY(4px) rotate(var(--nameplate-tilt)) scale(1.04);
}

.battle-showcase.stage-bg .battle-team-side.right .battle-nameplate,
.battle-showcase.stage-bg .battle-team-side.right .battle-nameplate-frame,
.battle-showcase.stage-bg .battle-team-side.right .battle-dancer-card {
  transform: translateX(56px) translateY(4px) scale(1.04);
  filter: blur(9px) contrast(1.15) saturate(1.2);
}

.battle-showcase.stage-bg .battle-team-side.right .battle-nameplate {
  transform: translateX(calc(-50% + 56px)) translateY(4px) rotate(var(--nameplate-tilt)) scale(1.04);
}

.battle-showcase.stage-bg .battle-team-side.right .battle-nameplate-frame {
  transform: translateX(calc(-50% + 56px)) translateY(4px) rotate(var(--nameplate-tilt)) scale(1.04);
}

.battle-showcase.reveal .battle-team-side.left .battle-nameplate-frame {
  animation: battlePlateGlitchInLeft 0.56s cubic-bezier(0.2, 1, 0.3, 1) both;
}

.battle-showcase.reveal .battle-team-side.right .battle-nameplate-frame {
  animation: battlePlateGlitchInRight 0.56s cubic-bezier(0.2, 1, 0.3, 1) both;
}

.battle-showcase.reveal .battle-team-side.left .battle-nameplate {
  animation: battlePlateGlitchInLeftFixed 0.62s cubic-bezier(0.2, 1, 0.3, 1) both;
  animation-delay: 0.01s;
}

.battle-showcase.reveal .battle-team-side.right .battle-nameplate {
  animation: battlePlateGlitchInRightFixed 0.62s cubic-bezier(0.2, 1, 0.3, 1) both;
  animation-delay: 0.01s;
}

.battle-showcase.reveal .battle-team-side.left .battle-dancer-card {
  animation: battleCardGlitchInLeft 0.6s cubic-bezier(0.2, 1, 0.3, 1) both;
  animation-delay: calc(var(--i, 0) * 0.05s);
}

.battle-showcase.reveal .battle-team-side.right .battle-dancer-card {
  animation: battleCardGlitchInRight 0.6s cubic-bezier(0.2, 1, 0.3, 1) both;
  animation-delay: calc(var(--i, 0) * 0.05s);
}

@keyframes battleCardGlitchInLeft {
  0% {
    opacity: 0;
    transform: translateX(-56px) translateY(4px) scale(1.04);
    filter: blur(9px) contrast(1.2) saturate(1.22);
  }
  18% {
    opacity: 1;
    transform: translateX(16px) translateY(-2px) scale(1.01);
    filter: blur(1.6px) contrast(1.25) saturate(1.3);
  }
  23% {
    transform: translateX(-10px) translateY(1px) scale(1.01);
    filter: blur(1.2px) contrast(1.26) saturate(1.3);
  }
  29% {
    opacity: 1;
    transform: translateX(8px) translateY(0) scale(1);
    filter: blur(0.8px) contrast(1.22) saturate(1.24);
  }
  38% {
    transform: translateX(-4px) translateY(0) scale(1);
    filter: blur(0.4px) contrast(1.1) saturate(1.12);
  }
  100% {
    opacity: 1;
    transform: translateX(0) translateY(0) scale(1);
    filter: blur(0);
  }
}

@keyframes battleCardGlitchInRight {
  0% {
    opacity: 0;
    transform: translateX(56px) translateY(4px) scale(1.04);
    filter: blur(9px) contrast(1.2) saturate(1.22);
  }
  18% {
    opacity: 1;
    transform: translateX(-16px) translateY(-2px) scale(1.01);
    filter: blur(1.6px) contrast(1.25) saturate(1.3);
  }
  23% {
    transform: translateX(10px) translateY(1px) scale(1.01);
    filter: blur(1.2px) contrast(1.26) saturate(1.3);
  }
  29% {
    opacity: 1;
    transform: translateX(-8px) translateY(0) scale(1);
    filter: blur(0.8px) contrast(1.22) saturate(1.24);
  }
  38% {
    transform: translateX(4px) translateY(0) scale(1);
    filter: blur(0.4px) contrast(1.1) saturate(1.12);
  }
  100% {
    opacity: 1;
    transform: translateX(0) translateY(0) scale(1);
    filter: blur(0);
  }
}

@keyframes battlePlateGlitchInLeft {
  0% {
    opacity: 0;
    transform: translateX(calc(-50% - 56px)) translateY(4px) rotate(var(--nameplate-tilt)) scale(1.04);
    filter: blur(9px) contrast(1.2);
  }
  20% {
    opacity: 1;
    transform: translateX(calc(-50% + 14px)) translateY(-1px) rotate(var(--nameplate-tilt)) scale(1.01);
    filter: blur(1.4px) contrast(1.25);
  }
  30% {
    opacity: 1;
    transform: translateX(calc(-50% - 8px)) translateY(0) rotate(var(--nameplate-tilt)) scale(1);
    filter: blur(0.8px) contrast(1.2);
  }
  40% {
    transform: translateX(calc(-50% + 4px)) translateY(0) rotate(var(--nameplate-tilt)) scale(1);
    filter: blur(0.4px) contrast(1.12);
  }
  100% {
    opacity: 1;
    transform: translateX(-50%) translateY(0) rotate(var(--nameplate-tilt)) scale(1);
    filter: blur(0);
  }
}

@keyframes battlePlateGlitchInRight {
  0% {
    opacity: 0;
    transform: translateX(calc(-50% + 56px)) translateY(4px) rotate(var(--nameplate-tilt)) scale(1.04);
    filter: blur(9px) contrast(1.2);
  }
  20% {
    opacity: 1;
    transform: translateX(calc(-50% - 14px)) translateY(-1px) rotate(var(--nameplate-tilt)) scale(1.01);
    filter: blur(1.4px) contrast(1.25);
  }
  30% {
    opacity: 1;
    transform: translateX(calc(-50% + 8px)) translateY(0) rotate(var(--nameplate-tilt)) scale(1);
    filter: blur(0.8px) contrast(1.2);
  }
  40% {
    transform: translateX(calc(-50% - 4px)) translateY(0) rotate(var(--nameplate-tilt)) scale(1);
    filter: blur(0.4px) contrast(1.12);
  }
  100% {
    opacity: 1;
    transform: translateX(-50%) translateY(0) rotate(var(--nameplate-tilt)) scale(1);
    filter: blur(0);
  }
}

@keyframes battlePlateGlitchInLeftFixed {
  0% {
    opacity: 0;
    transform: translateX(calc(-50% - 56px)) translateY(4px) rotate(var(--nameplate-tilt)) scale(1.04);
    filter: blur(9px) contrast(1.2);
  }
  20% {
    opacity: 1;
    transform: translateX(calc(-50% + 14px)) translateY(-1px) rotate(var(--nameplate-tilt)) scale(1.01);
    filter: blur(1.4px) contrast(1.25);
  }
  24% {
    transform: translateX(calc(-50% - 12px)) translateY(0) rotate(var(--nameplate-tilt)) scale(1.01);
    filter: blur(1px) contrast(1.24);
  }
  30% {
    opacity: 1;
    transform: translateX(calc(-50% + 8px)) translateY(0) rotate(var(--nameplate-tilt)) scale(1);
    filter: blur(0.8px) contrast(1.2);
  }
  42% {
    transform: translateX(calc(-50% - 3px)) translateY(0) rotate(var(--nameplate-tilt)) scale(1);
    filter: blur(0.3px) contrast(1.08);
  }
  100% {
    opacity: 1;
    transform: translateX(-50%) translateY(0) rotate(var(--nameplate-tilt)) scale(1);
    filter: blur(0);
  }
}

@keyframes battlePlateGlitchInRightFixed {
  0% {
    opacity: 0;
    transform: translateX(calc(-50% + 56px)) translateY(4px) rotate(var(--nameplate-tilt)) scale(1.04);
    filter: blur(9px) contrast(1.2);
  }
  20% {
    opacity: 1;
    transform: translateX(calc(-50% - 14px)) translateY(-1px) rotate(var(--nameplate-tilt)) scale(1.01);
    filter: blur(1.4px) contrast(1.25);
  }
  24% {
    transform: translateX(calc(-50% + 12px)) translateY(0) rotate(var(--nameplate-tilt)) scale(1.01);
    filter: blur(1px) contrast(1.24);
  }
  30% {
    opacity: 1;
    transform: translateX(calc(-50% - 8px)) translateY(0) rotate(var(--nameplate-tilt)) scale(1);
    filter: blur(0.8px) contrast(1.2);
  }
  42% {
    transform: translateX(calc(-50% + 3px)) translateY(0) rotate(var(--nameplate-tilt)) scale(1);
    filter: blur(0.3px) contrast(1.08);
  }
  100% {
    opacity: 1;
    transform: translateX(-50%) translateY(0) rotate(var(--nameplate-tilt)) scale(1);
    filter: blur(0);
  }
}

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

.dancer-card {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #101010;
  padding: 8px;
  text-align: center;
}

.dancer-photo-wrap {
  height: 170px;
  display: grid;
  place-items: end center;
  overflow: hidden;
  border-radius: 8px;
  background: radial-gradient(circle at 50% 20%, #2a2a2a 0%, #141414 65%);
}

.dancer-photo {
  height: 165px;
  width: auto;
  object-fit: contain;
  filter: drop-shadow(0 8px 16px rgba(0, 0, 0, 0.5));
}

.dancer-photo-empty {
  font-size: 0.75rem;
  color: var(--muted);
}

.dancer-name {
  margin-top: 8px;
  font-weight: 800;
  font-size: 0.95rem;
  letter-spacing: 0.02em;
}

.vs {
  align-self: center;
  font-size: clamp(2rem, 5vw, 4rem);
  color: var(--warn);
  font-weight: 700;
}

.score-box {
  margin-top: 20px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 12px;
}

.team-grid-showcase {
  perspective: 1200px;
}

.team-grid-showcase .fighter {
  transform-origin: center bottom;
  will-change: transform, opacity, filter;
}

.team-grid-showcase .fighter h2 {
  position: relative;
  overflow: hidden;
}

.team-grid-showcase.animate-in .fighter {
  animation: teamCardBurst 0.9s cubic-bezier(0.2, 0.9, 0.2, 1) both;
  animation-delay: calc(var(--i, 0) * 0.09s);
}

.team-grid-showcase.animate-in .fighter h2::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(110deg, transparent 15%, rgba(255, 255, 255, 0.32) 48%, transparent 82%);
  transform: translateX(-130%);
  animation: teamTitleSweep 0.7s ease-out both;
  animation-delay: calc(0.2s + (var(--i, 0) * 0.09s));
}

@keyframes teamCardBurst {
  from {
    opacity: 0;
    transform: translateY(36px) scale(0.88) rotateX(10deg);
    filter: blur(5px);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1) rotateX(0deg);
    filter: blur(0);
  }
}

@keyframes teamTitleSweep {
  from {
    transform: translateX(-130%);
  }
  to {
    transform: translateX(130%);
  }
}

.score-chip {
  border: 1px solid var(--line);
  background: #171a20;
  border-radius: 12px;
  padding: 12px;
  text-align: center;
}

.big-score {
  font-size: clamp(2rem, 8vw, 5rem);
  font-weight: 800;
}

.judge-shell {
  max-width: 700px;
  margin: 0 auto;
  padding: 16px;
}

.judge-shell .panel {
  margin-top: 14px;
}

.vote-lock {
  padding: 8px 10px;
  border-radius: 8px;
  background: #1d1d1d;
  border: 1px solid #343434;
}

.judge-vote-shell {
  width: 100vw;
  height: 100vh;
  min-height: 100vh;
  background: #050608;
  display: grid;
  grid-template-rows: auto 1fr;
}

.judge-vote-head {
  display: grid;
  gap: 4px;
  padding: 14px 16px;
  border-bottom: 1px solid #232630;
  background: rgba(12, 14, 18, 0.92);
}

.judge-vote-judge {
  font-size: clamp(1.2rem, 2vw, 1.8rem);
  font-weight: 800;
}

.judge-vote-info {
  color: #c5c8d2;
}

.judge-vote-state {
  font-weight: 700;
  color: #f1f3f9;
}

.judge-vote-buttons {
  width: 100%;
  height: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.judge-vote-btn {
  border: none;
  border-radius: 0;
  font-size: clamp(2rem, 5vw, 4rem);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  color: #f6f7fb;
  background: linear-gradient(160deg, #11141b 0%, #0a0d14 100%);
}

.judge-vote-btn + .judge-vote-btn {
  border-left: 1px solid #252a34;
}

.judge-vote-btn.is-picked {
  background: linear-gradient(160deg, #25314f 0%, #12192a 100%);
  box-shadow: inset 0 0 0 2px rgba(161, 186, 255, 0.55);
}

.judge-vote-btn:disabled {
  opacity: 0.55;
}

.judge-vote-idle {
  grid-column: 1 / -1;
  display: grid;
  place-items: center;
  font-size: clamp(1.1rem, 2vw, 1.8rem);
  color: #c7cad4;
}

.regie-shell {
  max-width: 1600px;
  padding: 16px 22px 14px;
  display: grid;
  gap: 9px;
}

.regie-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.regie-nav {
  margin-bottom: 0;
  flex: 1;
  padding: 6px;
  border-radius: 999px;
  border: 1px solid #2a2a2d;
  background: linear-gradient(180deg, #090b0e 0%, #050608 100%);
}

.regie-nav .active {
  background: #e4e4e4;
  color: #111;
}

.regie-open-screen {
  border-radius: 16px;
  border: 1px solid #3f3f43;
  padding: 9px 14px;
  font-weight: 700;
  background: #ececec;
  color: #151515;
}

.regie-panel {
  border-radius: 18px;
  border: 1px solid #26272c;
  background:
    radial-gradient(120% 120% at 50% 14%, rgba(33, 36, 45, 0.32), transparent 65%),
    linear-gradient(180deg, #07090d 0%, #05070a 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
  padding: 11px 13px;
}

.regie-panel h2 {
  margin-bottom: 7px;
  font-size: clamp(1.22rem, 1.5vw, 1.5rem);
}

.regie-panel h3 {
  margin: 0 0 5px;
}

.regie-battle-panel {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(380px, 0.75fr);
  gap: 10px;
  align-items: start;
}

.regie-battle-main {
  min-height: 0;
  display: grid;
  align-content: start;
  gap: 7px;
}

.regie-round-tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 24px;
  padding: 0 8px;
  border-radius: 12px;
  border: 1px solid #333740;
  background: linear-gradient(180deg, #171a21 0%, #0f1218 100%);
  color: #ececf0;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  justify-self: start;
}

.regie-bracket-board {
  display: grid;
  grid-template-columns: minmax(250px, 1fr) minmax(250px, 1fr) minmax(250px, 1fr);
  gap: 12px;
  max-width: 1060px;
}

.regie-round-col {
  display: grid;
  align-content: start;
}

.regie-round-col-qf {
  gap: 8px;
}

.regie-round-col-sf {
  gap: 10px;
  padding-top: 158px;
}

.regie-round-col-final {
  padding-top: 220px;
}

.regie-match-card {
  border: 1px solid #2e323b;
  border-radius: 14px;
  background: linear-gradient(180deg, #0e1117 0%, #0a0d13 100%);
  padding: 7px;
  display: grid;
  gap: 5px;
}

.regie-match-card .primary {
  height: 31px;
  border-radius: 10px;
  font-size: 0.82rem;
  font-weight: 800;
  padding: 0 10px;
}

.regie-match-card select {
  min-height: 31px;
  font-size: 0.82rem;
  padding-top: 6px;
  padding-bottom: 6px;
}

.regie-battle-selects {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  max-width: 760px;
}

.regie-battle-actions {
  margin-top: 0;
  gap: 6px;
}

.regie-vote-console {
  border-radius: 36px;
  border: 1px solid #d2d2d6;
  background: #dddddf;
  padding: 8px;
  display: grid;
  align-content: start;
  gap: 6px;
  min-height: 0;
}

.regie-vote-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
}

.regie-vote-chip {
  border: 1px solid #32353d;
  border-radius: 14px;
  background: linear-gradient(180deg, #17191f 0%, #101218 100%);
  color: #f3f3f3;
  font-size: 0.86rem;
  font-weight: 700;
  padding: 10px 7px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.regie-vote-chip.is-voted {
  border-color: #5e6574;
  box-shadow:
    inset 0 0 0 1px rgba(167, 177, 194, 0.45),
    0 0 0 1px rgba(130, 158, 255, 0.25);
  background:
    linear-gradient(180deg, rgba(50, 63, 102, 0.34) 0%, rgba(30, 36, 55, 0.55) 100%),
    linear-gradient(180deg, #17191f 0%, #101218 100%);
}

.regie-team-chip {
  font-size: 0.74rem;
  padding: 10px 7px;
}

.regie-vote-button {
  justify-self: center;
  margin-top: 2px;
  border-radius: 10px;
  border: 2px solid #3b3d42;
  background: linear-gradient(180deg, #181b22, #0d1119);
  color: #f4f4f4;
  font-weight: 800;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  padding: 10px 12px;
  font-size: 0.82rem;
}

.regie-bottom-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.regie-public-live-panel {
  padding-top: 10px;
  padding-bottom: 10px;
}

.regie-bg-panel {
  padding-top: 12px;
}

.regie-bg-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.regie-shell #ctrlTeamButtons button,
.regie-shell #ctrlMediaButtons button,
.regie-shell #ctrlJudgeButtons button,
.regie-shell #ctrlMcButtons button,
.regie-shell #ctrlDjButtons button {
  border-radius: 14px;
  border-color: #2f3138;
  background: linear-gradient(180deg, #1a1d23 0%, #12151c 100%);
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  text-transform: uppercase;
  padding-top: 8px;
  padding-bottom: 8px;
}

.regie-shell #ctrlTeamButtons button.primary {
  background: #ececec;
  color: #151515;
  border-color: #ececec;
}

@media (max-width: 1100px) {
  .regie-topbar {
    flex-direction: column;
    align-items: stretch;
  }

  .regie-open-screen {
    align-self: flex-end;
  }

  .regie-battle-panel {
    grid-template-columns: 1fr;
  }

  .regie-vote-console {
    border-radius: 24px;
    min-height: 0;
  }

  .regie-bottom-grid,
  .regie-bg-grid,
  .regie-battle-selects {
    grid-template-columns: 1fr;
  }

  .regie-bracket-board {
    grid-template-columns: 1fr;
  }

  .regie-round-col-sf,
  .regie-round-col-final {
    padding-top: 0;
  }
}
