/* Redesign v2 — /play + /leaderboard shared tokens */
:root {
  --play-fg: #00d5dc;
  --play-bg: #000058;
  --play-secondary: #f7f7f9;
}

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

html,
body {
  width: 100%;
  height: 100%;
  margin: 0;
}

body.play-screen {
  --play-pad-screen: 3vh 3vw;
  width: 100%;
  font-family: "Orbitron", system-ui, sans-serif;
  background:
    radial-gradient(circle at top center, rgba(0, 213, 220, 0.18), transparent 35%),
    radial-gradient(circle at bottom left, rgba(0, 213, 220, 0.08), transparent 30%),
    linear-gradient(180deg, color-mix(in srgb, var(--play-bg) 78%, #0a0a7a), var(--play-bg));
  color: var(--play-secondary);
  min-height: 100dvh;
  overflow: hidden;
  -webkit-tap-highlight-color: transparent;
  margin: 0;
  display: flex;
}

/* —— example.html layout; Farben nur über --play-* / rgba(0,213,220) —— */
body.play-screen .screen {
  position: relative;
  width: 100vw;
  height: 100vh;
  min-height: 100dvh;
  padding: var(--play-pad-screen);
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--play-bg) 70%, transparent),
    color-mix(in srgb, var(--play-bg) 92%, #000020)
  );
  overflow: hidden;
}

body.play-screen .screen::before {
  content: "";
  position: absolute;
  inset: 1.2vw;
  border: 1px solid rgba(0, 213, 220, 0.12);
  border-radius: 1.2vw;
  pointer-events: none;
}

body.play-screen .screen::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 80% 20%, rgba(0, 213, 220, 0.08), transparent 20%),
    radial-gradient(circle at 15% 80%, rgba(0, 213, 220, 0.05), transparent 25%);
  pointer-events: none;
}

body.play-screen .corners span {
  position: absolute;
  width: 2vw;
  height: 2vw;
  min-width: 18px;
  min-height: 18px;
  border-color: rgba(0, 213, 220, 0.45);
  border-style: solid;
  pointer-events: none;
}

body.play-screen .corners .tl {
  top: 1vw;
  left: 1vw;
  border-width: 2px 0 0 2px;
}

body.play-screen .corners .tr {
  top: 1vw;
  right: 1vw;
  border-width: 2px 2px 0 0;
}

body.play-screen .corners .bl {
  bottom: 1vw;
  left: 1vw;
  border-width: 0 0 2px 2px;
}

body.play-screen .corners .br {
  bottom: 1vw;
  right: 1vw;
  border-width: 0 2px 2px 0;
}

body.play-screen .layout {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  display: grid;
  grid-template-rows: auto 1fr auto;
  align-items: center;
}

body.play-screen .header {
  text-align: center;
  font-size: clamp(18px, 1.2vw, 28px);
  font-weight: 700;
  letter-spacing: 0.35em;
  color: rgba(247, 247, 249, 0.92);
  text-transform: uppercase;
  padding-top: 1vh;
}

body.play-screen .center {
  display: grid;
  grid-template-rows: auto auto auto 1fr;
  align-items: start;
  justify-items: center;
  text-align: center;
  min-width: 0;
}

body.play-screen .center.is-playing .delta {
  visibility: hidden;
}

body.play-screen .time {
  margin: 0;
  font-family: "Share Tech Mono", ui-monospace, monospace;
  font-size: clamp(120px, 13vw, 280px);
  line-height: 0.9;
  font-weight: 800;
  color: var(--play-fg);
  text-shadow:
    0 0 10px rgba(0, 213, 220, 0.45),
    0 0 30px rgba(0, 213, 220, 0.3),
    0 0 80px rgba(0, 213, 220, 0.12);
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1;
  display: inline-block;
  min-width: 8.5ch;
  text-align: center;
}

body.play-screen .time-label {
  margin-top: 1vh;
  font-size: clamp(18px, 1.4vw, 32px);
  font-weight: 700;
  letter-spacing: 0.25em;
  color: var(--play-fg);
  text-transform: uppercase;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1vw;
  max-width: 96vw;
  text-align: center;
}

body.play-screen .time-label::before,
body.play-screen .time-label::after {
  content: "";
  width: 5vw;
  max-width: 90px;
  height: 1px;
  flex-shrink: 0;
  background: linear-gradient(90deg, transparent, rgba(0, 213, 220, 0.9), transparent);
}

body.play-screen .delta {
  margin-top: 2vh;
  font-size: clamp(42px, 4vw, 88px);
  font-weight: 800;
  color: #ffffff;
}

body.play-screen .sub {
  margin-top: 0.5vh;
  font-size: clamp(16px, 1.1vw, 28px);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--play-secondary) 45%, var(--play-fg));
}

body.play-screen section.bottom {
  width: 100%;
  margin: 0;
  padding: 0;
}

body.play-screen .bottom-inner {
  display: grid;
  grid-template-columns: 18vw 1fr;
  gap: 3vw;
  align-items: center;
  width: 100%;
  padding: 0 8vw 5vh;
}

body.play-screen .qr-wrap {
  display: flex;
  justify-content: center;
}

body.play-screen .qr-box {
  width: 14vw;
  height: 14vw;
  min-width: 170px;
  min-height: 170px;
  max-width: 280px;
  max-height: 280px;
  padding: 0.8vw;
  border: 4px solid #e1fdff;
  /* border: 2px solid rgba(0, 213, 220, 0.6); */
  border-radius: 0.6vw;
  background: rgba(0, 0, 88, 0.92);
  box-shadow:
    0 0 20px rgba(0, 213, 220, 0.78),
    inset 0 0 18px rgba(0, 213, 220, 0.08);
}

body.play-screen .qr-box .qr {
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  background:
    linear-gradient(90deg, var(--play-fg) 10px, transparent 10px) 0 0 / 20px 20px,
    linear-gradient(var(--play-fg) 10px, transparent 10px) 0 0 / 20px 20px,
    linear-gradient(90deg, transparent 10px, var(--play-fg) 10px) 0 0 / 20px 20px,
    linear-gradient(transparent 10px, var(--play-fg) 10px) 0 0 / 20px 20px,
    color-mix(in srgb, var(--play-bg) 70%, #020824);
  position: relative;
  overflow: hidden;
}

body.play-screen .qr-box .qr::before,
body.play-screen .qr-box .qr::after {
  content: "";
  position: absolute;
  width: 22%;
  height: 22%;
  border: 0.35vw solid var(--play-fg);
  background: color-mix(in srgb, var(--play-bg) 70%, #020824);
}

body.play-screen .qr-box .qr::before {
  top: 6%;
  left: 6%;
  box-shadow:
    220% 0 0 0 color-mix(in srgb, var(--play-bg) 70%, #020824),
    220% 0 0 0.35vw var(--play-fg),
    0 220% 0 0 color-mix(in srgb, var(--play-bg) 70%, #020824),
    0 220% 0 0.35vw var(--play-fg);
}

body.play-screen .qr-box .qr::after {
  bottom: 6%;
  right: 6%;
}

body.play-screen .qr-box img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 4px;
}

body.play-screen .copy {
  text-transform: uppercase;
  min-width: 0;
}

body.play-screen .copy-top {
  font-size: clamp(20px, 1.6vw, 36px);
  letter-spacing: 0.15em;
  color: color-mix(in srgb, var(--play-secondary) 82%, var(--play-fg));
  margin-bottom: 0.8vh;
}

body.play-screen .headline {
  margin: 0;
  font-size: clamp(48px, 4.4vw, 110px);
  line-height: 0.95;
  font-weight: 800;
  color: var(--play-fg);
  text-shadow:
    0 0 10px rgba(0, 213, 220, 0.3),
    0 0 30px rgba(0, 213, 220, 0.12);
}

body.play-screen .fine {
  margin-top: 1.2vh;
  font-size: clamp(18px, 1.3vw, 30px);
  color: var(--play-secondary);
  opacity: 0.9;
  text-transform: none;
}

body.play-screen .play-survey-actions {
  margin: 1rem 0 0;
}

body.play-screen .footer {
  text-align: center;
  padding-bottom: 1vh;
  font-size: clamp(16px, 1vw, 24px);
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: rgba(0, 213, 220, 0.76);
}

@media (max-aspect-ratio: 4/3) {
  body.play-screen .bottom-inner {
    grid-template-columns: 1fr;
    justify-items: center;
    text-align: center;
    padding: 3vh 8vw 4vh;
  }

  body.play-screen .copy {
    text-align: center;
  }
}

.play-hit {
  position: fixed;
  inset: 0;
  z-index: 1;
  cursor: pointer;
  border: none;
  padding: 0;
  margin: 0;
  background: transparent;
  color: transparent;
}

.play-hit:disabled {
  cursor: default;
  pointer-events: none;
}

.play-hit:focus-visible {
  outline: 2px solid var(--play-fg);
  outline-offset: -4px;
}

.play-ui {
  position: relative;
  z-index: 2;
  flex: 1;
  min-width: 0;
  min-height: 100dvh;
  pointer-events: none;
}

.play-ui .play-interactive,
.play-ui a.play-interactive,
.play-ui button.play-interactive,
.play-ui details.play-interactive {
  pointer-events: auto;
}

.play-actions {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-top: 1rem;
}

.play-btn {
  font-family: inherit;
  font-size: clamp(1.1rem, 2.8vw, 1.35rem);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.85rem 1.25rem;
  border: 2px solid var(--play-fg);
  background: transparent;
  color: var(--play-fg);
  cursor: pointer;
  border-radius: 4px;
}

.play-btn:hover,
.play-btn:focus-visible {
  background: rgba(0, 213, 220, 0.15);
}

.play-survey-link {
  color: var(--play-secondary);
  font-size: clamp(1.05rem, 2.6vw, 1.25rem);
}

.play-error {
  color: #ffb4b4;
  font-size: clamp(0.95rem, 2.4vw, 1.1rem);
  margin-top: 0.5rem;
}

.play-survey-details {
  margin-top: 0.75rem;
  text-align: left;
  color: var(--play-secondary);
  font-size: clamp(0.95rem, 2.4vw, 1.1rem);
}

.play-survey-details summary {
  cursor: pointer;
  color: var(--play-fg);
}

.play-url-full {
  word-break: break-all;
  margin: 0.5rem 0 0;
  font-size: clamp(0.85rem, 2.2vw, 1rem);
}

/* Leaderboard kiosk — single column, one row per player */
body.leaderboard-screen {
  font-family: "Orbitron", system-ui, sans-serif;
  background: var(--play-bg);
  color: var(--play-fg);
  min-height: 100dvh;
  margin: 0;
}

.lb-shell {
  min-height: 100dvh;
  padding: clamp(1.25rem, 4vw, 2.5rem);
  max-width: 56rem;
  margin: 0 auto;
}

.lb-hero {
  text-align: center;
  margin-bottom: clamp(1.75rem, 5vw, 2.75rem);
}

.lb-brand {
  font-size: clamp(1.75rem, 5.5vw, 3.25rem);
  font-weight: 800;
  letter-spacing: 0.22em;
  margin: 0;
  text-shadow: 0 0 20px rgba(0, 213, 220, 0.35);
}

.lb-sub {
  margin: clamp(0.65rem, 2vw, 1rem) 0 0;
  font-size: clamp(0.85rem, 2.4vw, 1.2rem);
  font-weight: 600;
  letter-spacing: 0.28em;
  color: var(--play-secondary);
  text-transform: uppercase;
}

.lb-goal-line {
  margin: clamp(0.5rem, 1.5vw, 0.85rem) 0 0;
  font-size: clamp(0.95rem, 2.6vw, 1.35rem);
  font-weight: 500;
  letter-spacing: 0.12em;
  color: var(--play-secondary);
  opacity: 0.9;
  font-family: "Share Tech Mono", ui-monospace, monospace;
}

.lb-empty {
  text-align: center;
  color: var(--play-secondary);
  font-size: clamp(1rem, 2.5vw, 1.35rem);
}

.lb-table {
  width: 100%;
}

/* Column header — same grid as rows for alignment */
.lb-col-header {
  display: grid;
  grid-template-columns: minmax(4.25rem, 7rem) minmax(0, 1fr) minmax(5.5rem, 9rem);
  align-items: baseline;
  column-gap: clamp(1rem, 3.5vw, 2.25rem);
  padding: 0 0 clamp(0.65rem, 2vw, 0.85rem);
  margin-bottom: clamp(0.35rem, 1vw, 0.5rem);
  border-bottom: 1px solid rgba(0, 213, 220, 0.35);
  font-size: clamp(0.7rem, 2vw, 0.95rem);
  font-weight: 700;
  letter-spacing: 0.18em;
  color: var(--play-secondary);
  text-transform: uppercase;
}

.lb-h-rank {
  text-align: left;
}

.lb-h-name {
  text-align: left;
}

.lb-h-dev {
  text-align: right;
}

.lb-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: clamp(0.5rem, 1.5vw, 0.75rem);
}

.lb-row {
  display: grid;
  grid-template-columns: minmax(4.25rem, 7rem) minmax(0, 1fr) minmax(5.5rem, 9rem);
  align-items: center;
  column-gap: clamp(1rem, 3.5vw, 2.25rem);
  padding: clamp(0.55rem, 1.8vw, 0.85rem) clamp(0.35rem, 1.2vw, 0.5rem);
  background: rgba(0, 213, 220, 0.06);
  border: 1px solid rgba(0, 213, 220, 0.22);
  border-radius: 6px;
}

/* Top 3: stronger panel + cyan border glow */
.lb-list .lb-row:nth-child(-n + 3) {
  background: linear-gradient(
    135deg,
    rgba(0, 213, 220, 0.18) 0%,
    rgba(0, 213, 220, 0.08) 50%,
    rgba(0, 80, 120, 0.12) 100%
  );
  border: 1px solid rgba(0, 213, 220, 0.55);
  box-shadow:
    0 0 0 1px rgba(0, 213, 220, 0.15),
    0 0 20px rgba(0, 213, 220, 0.22),
    0 0 48px rgba(0, 213, 220, 0.1),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.lb-rank {
  font-family: "Share Tech Mono", ui-monospace, monospace;
  font-size: clamp(1.05rem, 3vw, 1.75rem);
  font-weight: 700;
  color: var(--play-secondary);
  font-variant-numeric: tabular-nums;
  text-align: left;
}

.lb-name {
  font-size: clamp(0.95rem, 2.6vw, 1.5rem);
  font-weight: 600;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-align: left;
  min-width: 0;
}

.lb-dev {
  font-family: "Share Tech Mono", ui-monospace, monospace;
  font-size: clamp(0.95rem, 2.6vw, 1.5rem);
  font-weight: 700;
  color: var(--play-secondary);
  font-variant-numeric: tabular-nums;
  text-align: right;
  white-space: nowrap;
}

.lb-list .lb-row:nth-child(-n + 3) .lb-rank {
  font-size: clamp(1.55rem, 4.5vw, 2.75rem);
}

.lb-list .lb-row:nth-child(-n + 3) .lb-name {
  font-size: clamp(1.35rem, 3.9vw, 2.25rem);
}

.lb-list .lb-row:nth-child(-n + 3) .lb-dev {
  font-size: clamp(1.35rem, 3.9vw, 2.25rem);
}
