html, body {
  width: 100%; height: 100%;
  background: var(--black);
  overflow: hidden;
  touch-action: none;
  -webkit-tap-highlight-color: transparent;
  user-select: none;
}
body {
  position: relative;
  font-family: 'DM Mono', monospace;
  color: var(--cream);
}

#back-link {
  position: fixed;
  top: calc(8px + var(--safe-top));
  left: calc(10px + var(--safe-left));
  z-index: 120;
  color: var(--amber);
  font-family: 'DM Mono', monospace;
  font-size: 0.72rem;
  text-decoration: none;
  letter-spacing: 0.05em;
  opacity: 0.7;
}
#back-link:hover { opacity: 1; }
/* In-game: back-link shrinks to icon-only pill so it doesn't collide with SCORE */
body.game-active #back-link {
  font-size: 0;
  width: 30px;
  height: 30px;
  line-height: 30px;
  text-align: center;
  border-radius: 50%;
  background: rgba(10,7,0,0.72);
  border: 1px solid rgba(245,176,48,0.35);
}
body.game-active #back-link::before {
  content: '←';
  font-family: 'DM Mono', monospace;
  font-size: 0.95rem;
  color: var(--amber);
}

/* ── Screens ───────────────────────────────────────────────────────────── */
.screen {
  position: fixed; inset: 0;
  display: none;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: calc(20px + var(--safe-top)) 1rem calc(20px + var(--safe-bottom));
  z-index: 10;
}
.screen.active { display: flex; }

/* ── Intro ─────────────────────────────────────────────────────────────── */
#screen-intro {
  text-align: center;
  gap: 1.2rem;
}
.intro-logo {
  font-family: 'Anton', sans-serif;
  font-size: clamp(2.2rem, 10vw, 3.4rem);
  letter-spacing: 0.04em;
  color: var(--amber-hi);
  line-height: 0.95;
  text-shadow: 0 0 24px rgba(212,146,10,0.45);
}
.intro-sub {
  font-family: 'DM Mono', monospace;
  font-size: 0.85rem;
  color: var(--cream);
  opacity: 0.9;
  letter-spacing: 0.03em;
  max-width: 320px;
  line-height: 1.45;
}
.intro-hero {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  padding: 0.5rem 1rem 0.5rem 0.5rem;
  background: rgba(212,146,10,0.08);
  border: 1px solid rgba(245,176,48,0.4);
  border-radius: 999px;
}
.intro-hero-photo {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: #1a0f00 center / cover;
  border: 2px solid var(--amber);
  flex-shrink: 0;
}
.intro-hero-text { text-align: left; }
.intro-hero-label {
  font-size: 0.55rem;
  color: var(--amber-hi);
  letter-spacing: 0.12em;
  opacity: 0.85;
}
.intro-hero-name {
  font-family: 'Anton', sans-serif;
  font-size: 1.1rem;
  letter-spacing: 0.04em;
}

.intro-best {
  display: inline-flex;
  align-items: baseline;
  gap: 0.45rem;
  padding: 0.35rem 0.9rem;
  background: rgba(245,176,48,0.12);
  border: 1px solid rgba(245,176,48,0.45);
  border-radius: 999px;
}
.intro-best-label {
  font-family: 'DM Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.18em;
  color: var(--amber);
  opacity: 0.9;
}
.intro-best-num {
  font-family: 'Anton', sans-serif;
  font-size: 1.3rem;
  color: var(--amber-hi);
  letter-spacing: 0.02em;
  text-shadow: 0 0 10px rgba(245,176,48,0.5);
}
.intro-best-fire { font-size: 1rem; }

.intro-hints {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  max-width: 320px;
  width: 100%;
}
.intro-hints .hint {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  padding: 0.55rem 0.9rem;
  background: rgba(10,7,0,0.55);
  border: 1px solid rgba(245,176,48,0.22);
  border-radius: 10px;
  font-size: 0.82rem;
  color: var(--cream);
  letter-spacing: 0.02em;
}
.intro-hints .hint-icon {
  font-size: 1.15rem;
  width: 1.5rem;
  text-align: center;
  flex-shrink: 0;
}

.btn-primary {
  background: var(--amber);
  color: var(--black);
  border: 2px solid var(--cream);
  padding: 0.9rem 2.2rem;
  min-height: 44px;
  min-width: 44px;
  font-family: 'Anton', sans-serif;
  font-size: 1.15rem;
  letter-spacing: 0.06em;
  border-radius: 8px;
  cursor: pointer;
  box-shadow: 0 0 18px rgba(212,146,10,0.4);
  transition: transform 0.1s ease-out, box-shadow 0.12s ease-out;
}
.btn-primary:active { transform: translateY(2px); box-shadow: 0 0 8px rgba(212,146,10,0.5); }
.btn-ghost {
  background: none;
  color: var(--amber);
  border: 1px solid var(--amber);
  padding: 0.7rem 1.8rem;
  font-family: 'Anton', sans-serif;
  font-size: 0.95rem;
  letter-spacing: 0.06em;
  border-radius: 6px;
  cursor: pointer;
}

/* ── Game screen ────────────────────────────────────────────────────────── */
#screen-game {
  display: none;
  padding: 0;
  z-index: 5;
}
#screen-game.active { display: block; }

canvas {
  display: block;
  position: absolute;
  inset: 0;
  width: 100vw; height: 100vh;
  z-index: 1;
}

/* HUD */
#hud {
  position: fixed;
  top: calc(10px + var(--safe-top));
  left: 0; right: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 1rem 0 54px;
  z-index: 20;
  pointer-events: none;
}
.hud-left { display: flex; flex-direction: column; }
.hud-mid  { display: flex; flex-direction: column; align-items: center; gap: 0.15rem; }
.hud-score {
  font-family: 'Anton', sans-serif;
  font-size: 1.3rem;
  color: var(--amber-hi);
  letter-spacing: 0.04em;
  text-shadow: 0 1px 6px rgba(0,0,0,0.8);
}
.hud-score-label {
  display: block;
  font-family: 'DM Mono', monospace;
  font-size: 0.55rem;
  color: var(--cream);
  opacity: 0.6;
  letter-spacing: 0.1em;
}
.hud-level {
  font-family: 'Anton', sans-serif;
  font-size: 1rem;
  color: var(--amber-hi);
  letter-spacing: 0.06em;
  padding: 0.15rem 0.55rem;
  background: rgba(245,176,48,0.14);
  border: 1px solid rgba(245,176,48,0.4);
  border-radius: 999px;
  text-shadow: 0 1px 4px rgba(0,0,0,0.6);
}
.hud-combo {
  font-family: 'Anton', sans-serif;
  font-size: 0.85rem;
  color: var(--amber);
  opacity: 0.9;
}
.hud-combo.hot { color: var(--amber-hi); text-shadow: 0 0 10px rgba(245,176,48,0.8); }
.hud-combo.pop { animation: comboPop 0.5s cubic-bezier(.2,1.6,.4,1); transform-origin: center; }
@keyframes comboPop {
  0%   { transform: scale(1);   }
  40%  { transform: scale(1.75); color: var(--cream); text-shadow: 0 0 18px rgba(245,176,48,1), 0 0 30px rgba(255,243,208,0.7); }
  100% { transform: scale(1);   }
}

/* Perfect-Streak badge (5/10/15 in Folge) */
#streak-badge {
  position: fixed;
  top: 28%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0);
  font-family: 'Anton', sans-serif;
  font-size: clamp(1.6rem, 7vw, 2.4rem);
  letter-spacing: 0.04em;
  color: var(--cream);
  text-shadow: 0 0 18px rgba(245,176,48,1), 0 0 30px rgba(255,243,208,0.7);
  background: linear-gradient(90deg, var(--amber), var(--amber-hi));
  padding: 0.7rem 1.5rem;
  border-radius: 14px;
  box-shadow: 0 0 30px rgba(245,176,48,0.55);
  z-index: 90;
  opacity: 0;
  pointer-events: none;
  white-space: nowrap;
}
#streak-badge.visible {
  opacity: 1;
  animation: streakPop 1.1s cubic-bezier(.2,1.8,.4,1);
}
@keyframes streakPop {
  0%   { transform: translate(-50%, -50%) scale(0) rotate(-10deg); opacity: 0; }
  25%  { transform: translate(-50%, -50%) scale(1.25) rotate(4deg); opacity: 1; }
  45%  { transform: translate(-50%, -50%) scale(1) rotate(-1deg); }
  80%  { transform: translate(-50%, -50%) scale(1) rotate(0); opacity: 1; }
  100% { transform: translate(-50%, -50%) scale(0.9) rotate(0); opacity: 0; }
}

/* Overflow canvas tilt */
#c.overflow { animation: canvasTilt 0.55s ease-out; transform-origin: center center; }
@keyframes canvasTilt {
  0%   { transform: rotate(0) translateX(0); }
  18%  { transform: rotate(1.8deg) translateX(-8px); }
  36%  { transform: rotate(-1.4deg) translateX(5px); }
  55%  { transform: rotate(0.9deg) translateX(-3px); }
  75%  { transform: rotate(-0.4deg) translateX(1px); }
  100% { transform: rotate(0) translateX(0); }
}

/* Combo ≥5 celebration shake — upbeat vertical bounce, distinct from overflow */
#c.combo-rush { animation: canvasComboRush 0.55s cubic-bezier(.2,1.4,.4,1); transform-origin: center center; }
@keyframes canvasComboRush {
  0%   { transform: translateY(0) scale(1); }
  25%  { transform: translateY(-10px) scale(1.015); }
  50%  { transform: translateY(4px)  scale(0.995); }
  75%  { transform: translateY(-3px) scale(1.005); }
  100% { transform: translateY(0) scale(1); }
}

/* Drink-Typ-switch cue — 0.7s banner when drink type changes mid-order */
#drink-cue {
  position: fixed;
  top: 38%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  align-items: center;
  gap: 0.6rem;
  font-family: 'Anton', sans-serif;
  font-size: clamp(1.3rem, 6vw, 1.9rem);
  letter-spacing: 0.04em;
  color: var(--cream);
  background: rgba(6,4,0,0.9);
  border: 2px solid var(--amber-hi);
  border-radius: 10px;
  padding: 0.55rem 1.15rem;
  box-shadow: 0 0 26px rgba(245,176,48,0.55);
  z-index: 85;
  opacity: 0;
  pointer-events: none;
  white-space: nowrap;
}
#drink-cue.visible { animation: drinkCueIn 0.75s cubic-bezier(.2,1.6,.4,1); }
@keyframes drinkCueIn {
  0%   { transform: translate(-50%, -50%) scale(0.2) rotate(-6deg); opacity: 0; }
  22%  { transform: translate(-50%, -50%) scale(1.1) rotate(2deg);  opacity: 1; }
  45%  { transform: translate(-50%, -50%) scale(1)   rotate(0);     opacity: 1; }
  85%  { transform: translate(-50%, -50%) scale(1)   rotate(0);     opacity: 1; }
  100% { transform: translate(-50%, -50%) scale(0.92) rotate(0);    opacity: 0; }
}
#drink-cue .dc-icon  { font-size: 1.35em; }
#drink-cue .dc-hint  { color: var(--amber-hi); font-size: 0.75em; letter-spacing: 0.08em; }
.hud-strikes {
  display: flex;
  gap: 0.35rem;
  font-size: 1.1rem;
}
.hud-strike { opacity: 0.3; filter: grayscale(1); transition: opacity 0.2s ease-out, filter 0.2s ease-out; }
.hud-strike.lost { opacity: 1; filter: none; animation: strikeFlash 0.4s ease-out; }
@keyframes strikeFlash {
  0%  { transform: scale(1.5); }
  50% { transform: scale(0.9) rotate(-8deg); }
  100%{ transform: scale(1); }
}

/* Customer bubble */
#customer {
  position: fixed;
  top: calc(62px + var(--safe-top));
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  background: rgba(10,7,0,0.94);
  border: 2px solid rgba(245,176,48,0.55);
  border-radius: 16px;
  padding: 0.7rem 1rem 0.75rem 0.7rem;
  max-width: min(96vw, 540px);
  z-index: 22;
  opacity: 0;
  transition: opacity 0.25s ease-out, transform 0.25s cubic-bezier(.2,.6,.35,1);
  pointer-events: none;
  box-shadow: 0 6px 24px rgba(0,0,0,0.55), 0 0 18px rgba(245,176,48,0.18);
}
#customer.visible { opacity: 1; transform: translateX(-50%) translateY(0); }
#customer.enter   { transform: translateX(-50%) translateY(-20px); }
.cust-photo {
  width: 58px; height: 58px;
  border-radius: 50%;
  background: #1a0f00 center / cover;
  border: 2px solid var(--amber);
  flex-shrink: 0;
}
.cust-text { flex: 1; min-width: 0; text-align: left; padding-top: 0.1rem; }
.cust-name {
  font-family: 'Anton', sans-serif;
  font-size: 0.92rem;
  color: var(--amber-hi);
  letter-spacing: 0.05em;
  line-height: 1;
}
.cust-line {
  font-family: 'DM Mono', monospace;
  font-size: 0.82rem;
  color: var(--cream);
  line-height: 1.25;
  margin-top: 0.2rem;
  opacity: 0.82;
}

/* Order chips — prominent, sprachlich gespiegelt */
.cust-order {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: 0.55rem;
}
.order-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.38rem 0.75rem;
  background: rgba(212,146,10,0.24);
  border: 1.5px solid rgba(245,176,48,0.5);
  border-radius: 999px;
  font-size: 0.95rem;
  color: var(--cream);
  letter-spacing: 0.03em;
}
.order-chip .order-n {
  font-family: 'Anton', sans-serif;
  font-size: 1.25rem;
  color: var(--amber-hi);
  letter-spacing: 0;
  line-height: 1;
}
.order-chip .order-icon { font-size: 1.45rem; line-height: 1; }
.order-chip .order-label {
  font-family: 'Anton', sans-serif;
  font-size: 0.95rem;
  letter-spacing: 0.08em;
  color: var(--amber-hi);
  opacity: 0.95;
}
.order-chip .order-dots {
  display: inline-flex;
  gap: 5px;
  margin-left: 0.3rem;
}
.order-chip .dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: rgba(255,243,208,0.22);
  transition: background 0.15s ease-out, transform 0.15s ease-out, box-shadow 0.15s ease-out;
}
.order-chip .dot.done {
  background: var(--amber-hi);
  animation: dotDoneBurst 0.45s ease-out;
}
@keyframes dotDoneBurst {
  0%   { transform: scale(1.8); box-shadow: 0 0 18px rgba(245,176,48,0.95), 0 0 28px rgba(255,243,208,0.8); }
  60%  { transform: scale(0.9); box-shadow: 0 0 6px rgba(245,176,48,0.4); }
  100% { transform: scale(1);   box-shadow: none; }
}
.order-big-badge {
  display: inline-block;
  margin-right: 0.35rem;
  padding: 0.15rem 0.5rem;
  font-family: 'Anton', sans-serif;
  font-size: 1.1rem;
  letter-spacing: 0.08em;
  color: #fff3d0;
  background: linear-gradient(90deg, var(--amber-hi), #ff6b3a);
  border-radius: 6px;
  text-shadow: 0 1px 2px rgba(0,0,0,0.5);
  box-shadow: 0 0 12px rgba(245,176,48,0.6);
  animation: orderBigBadgePulse 0.8s ease-in-out infinite alternate;
}
@keyframes orderBigBadgePulse {
  0%   { transform: scale(1);    box-shadow: 0 0 10px rgba(245,176,48,0.45); }
  100% { transform: scale(1.06); box-shadow: 0 0 18px rgba(255,107,58,0.85); }
}
.order-chip .dot.active {
  background: var(--cream);
  box-shadow: 0 0 10px rgba(255,243,208,1), 0 0 18px rgba(245,176,48,0.6);
  transform: scale(1.55);
  animation: dotActivePulse 0.9s ease-in-out infinite alternate;
}
@keyframes dotActivePulse {
  0%   { box-shadow: 0 0 8px rgba(255,243,208,0.7), 0 0 14px rgba(245,176,48,0.4); }
  100% { box-shadow: 0 0 14px rgba(255,243,208,1),   0 0 24px rgba(245,176,48,0.75); }
}

/* Timer bar */
#timer-bar-wrap {
  position: fixed;
  left: 50%; transform: translateX(-50%);
  top: calc(44px + var(--safe-top));
  width: min(92vw, 460px);
  height: 4px;
  background: rgba(212,146,10,0.12);
  border-radius: 2px;
  overflow: hidden;
  z-index: 21;
}
#timer-bar {
  height: 100%;
  width: 100%;
  background: linear-gradient(90deg, var(--amber-hi), var(--amber));
  transform-origin: left center;
  transition: transform 0.08s linear, background 0.15s ease-out;
}
#timer-bar.warn     { background: linear-gradient(90deg, #ff8a3a, #ff6b3a); }
#timer-bar.critical { background: linear-gradient(90deg, #ff3a3a, #c00); animation: timerPulse 0.35s infinite alternate; }
@keyframes timerPulse { to { filter: brightness(1.4); } }

/* Release hint floating above zapf button */
#release-hint {
  position: fixed;
  bottom: calc(108px + var(--safe-bottom));
  left: 50%;
  transform: translateX(-50%);
  font-family: 'Anton', sans-serif;
  font-size: 0.85rem;
  letter-spacing: 0.12em;
  color: var(--cream);
  opacity: 0;
  background: rgba(10,7,0,0.7);
  border: 1px solid rgba(245,176,48,0.35);
  border-radius: 999px;
  padding: 0.3rem 0.9rem;
  z-index: 24;
  pointer-events: none;
  transition: opacity 0.2s;
}
#release-hint.visible { opacity: 0.85; animation: hintBob 1.6s infinite ease-in-out; }
@keyframes hintBob {
  0%,100% { transform: translateX(-50%) translateY(0); }
  50%     { transform: translateX(-50%) translateY(-3px); }
}

/* Action button — full width, no serve button */
#action-bar {
  position: fixed;
  bottom: calc(20px + var(--safe-bottom));
  left: 0; right: 0;
  display: flex;
  justify-content: center;
  padding: 0 1rem;
  z-index: 25;
}
#btn-zapf {
  flex: 1;
  max-width: 340px;
  height: 72px;
  background: radial-gradient(circle at 30% 30%, var(--amber-hi), var(--amber) 60%, #8B5A06);
  color: var(--black);
  border: 2px solid var(--amber-hi);
  border-radius: 16px;
  font-family: 'Anton', sans-serif;
  font-size: 1.5rem;
  letter-spacing: 0.08em;
  cursor: pointer;
  box-shadow: 0 4px 14px rgba(212,146,10,0.5);
  transition: transform 0.08s ease-out, box-shadow 0.1s ease-out;
  user-select: none; -webkit-user-select: none;
  touch-action: manipulation;
}
#btn-zapf:active,
#btn-zapf.holding {
  transform: translateY(3px) scale(0.98);
  box-shadow: 0 1px 4px rgba(212,146,10,0.3), inset 0 0 18px rgba(0,0,0,0.25);
  background: radial-gradient(circle at 30% 30%, var(--amber), #A36A08 60%, #5f3e04);
}
#btn-zapf .zapf-icon { font-size: 1.3rem; margin-right: 0.4rem; }
#btn-zapf.disabled { opacity: 0.35; pointer-events: none; }

/* Verdict popup */
#verdict {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(6,4,0,0.78);
  z-index: 80;
  padding: 1rem;
}
#verdict.visible { display: flex; }
.verdict-card {
  background: #0f0b02;
  border: 2px solid var(--amber);
  border-radius: 14px;
  padding: 1.2rem 1.3rem 1.1rem;
  max-width: 340px;
  width: 100%;
  text-align: center;
  animation: verdictIn 0.35s cubic-bezier(.2,1.3,.5,1);
}
.verdict-card.good    { border-color: var(--amber-hi); box-shadow: 0 0 22px rgba(245,176,48,0.35); }
.verdict-card.perfect { border-color: var(--amber-hi); box-shadow: 0 0 36px rgba(245,176,48,0.6); }
.verdict-card.bad {
  border-color: #ff6b6b;
  animation: verdictIn 0.35s cubic-bezier(.2,1.3,.5,1), verdictShake 0.6s ease-out 0.28s;
}
@keyframes verdictIn {
  0%   { transform: scale(0.7); opacity: 0; }
  100% { transform: scale(1);   opacity: 1; }
}
@keyframes verdictShake {
  0%,100% { transform: translate(0, 0) rotate(0); }
  15%     { transform: translate(-10px, 0) rotate(-1.8deg); }
  30%     { transform: translate(8px, 0)  rotate(1.6deg);  }
  45%     { transform: translate(-6px, 0) rotate(-1.2deg); }
  60%     { transform: translate(4px, 0)  rotate(0.8deg);  }
  75%     { transform: translate(-2px, 0) rotate(-0.3deg); }
}
.verdict-title {
  font-family: 'Anton', sans-serif;
  font-size: 1.8rem;
  letter-spacing: 0.05em;
  color: var(--amber-hi);
  line-height: 1;
  margin-bottom: 0.5rem;
}
.verdict-card.bad .verdict-title { color: #ff9b9b; }
.verdict-card.perfect .verdict-title { color: var(--cream); text-shadow: 0 0 18px rgba(245,176,48,0.7); }
.verdict-score {
  font-family: 'Anton', sans-serif;
  font-size: 2.4rem;
  color: var(--cream);
  margin: 0.3rem 0;
}
.verdict-quote {
  font-size: 0.78rem;
  color: var(--cream);
  opacity: 0.85;
  line-height: 1.4;
  font-style: italic;
  margin-top: 0.3rem;
  min-height: 1.1em;
}

/* Big-bang feedback overlay inside game */
#flash {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 15;
  opacity: 0;
}
#flash.red  { background: radial-gradient(circle, rgba(255,60,60,0.45), transparent 60%); animation: flashOut 0.5s ease-out; }
#flash.good { background: radial-gradient(circle, rgba(245,176,48,0.35), transparent 60%); animation: flashOut 0.6s ease-out; }
#flash.warn { background: radial-gradient(circle, rgba(255,210,60,0.42), transparent 60%); animation: flashOut 0.5s ease-out; }
@keyframes flashOut { 0% { opacity: 1; } 100% { opacity: 0; } }

/* Level-up overlay */
#level-up {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(6,4,0,0.85);
  z-index: 85;
}
#level-up.visible { display: flex; }
.lu-card {
  text-align: center;
  animation: luIn 0.5s cubic-bezier(.2,1.3,.5,1);
}
@keyframes luIn {
  0%   { transform: scale(0.5) rotate(-4deg); opacity: 0; }
  60%  { transform: scale(1.1) rotate(1deg);  opacity: 1; }
  100% { transform: scale(1)   rotate(0);     opacity: 1; }
}
.lu-label {
  font-family: 'DM Mono', monospace;
  font-size: 0.8rem;
  letter-spacing: 0.4em;
  color: var(--amber);
  margin-bottom: 0.4rem;
}
.lu-num {
  font-family: 'Anton', sans-serif;
  font-size: 7rem;
  line-height: 1;
  color: var(--amber-hi);
  text-shadow: 0 0 38px rgba(245,176,48,0.7);
}
.lu-sub {
  font-family: 'DM Mono', monospace;
  font-size: 0.85rem;
  color: var(--cream);
  margin-top: 0.6rem;
  letter-spacing: 0.04em;
  opacity: 0.9;
}

/* ── Result screen ──────────────────────────────────────────────────────── */
#screen-result {
  text-align: center;
  gap: 0.9rem;
}
.res-title {
  font-family: 'Anton', sans-serif;
  font-size: 2.4rem;
  letter-spacing: 0.04em;
  color: var(--amber-hi);
  line-height: 1;
}
.res-score-box {
  background: #0f0b02;
  border: 2px solid var(--amber);
  border-radius: 12px;
  padding: 1.1rem 1.4rem;
  min-width: 240px;
}
.res-score-label {
  font-family: 'DM Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.15em;
  color: var(--amber);
  opacity: 0.8;
}
.res-score-num {
  font-family: 'Anton', sans-serif;
  font-size: 3.2rem;
  color: var(--cream);
  line-height: 1.1;
}
.res-best {
  font-family: 'DM Mono', monospace;
  font-size: 0.72rem;
  color: var(--amber);
  letter-spacing: 0.1em;
  margin-top: 0.4rem;
  opacity: 0.85;
  min-height: 1em;
}
.res-best:empty { display: none; }
.res-new-record {
  display: none;
  margin-top: 0.4rem;
  font-family: 'Anton', sans-serif;
  font-size: 1rem;
  letter-spacing: 0.18em;
  color: var(--amber-hi);
  text-shadow: 0 0 14px rgba(245,176,48,0.7);
  animation: recordPulse 1.2s ease-in-out infinite alternate;
}
.res-new-record.visible { display: block; }
@keyframes recordPulse {
  from { transform: scale(1);    text-shadow: 0 0 10px rgba(245,176,48,0.5); }
  to   { transform: scale(1.06); text-shadow: 0 0 22px rgba(245,176,48,1); }
}
.res-stats {
  display: flex;
  gap: 1rem;
  justify-content: center;
  font-size: 0.72rem;
  color: var(--cream);
  opacity: 0.8;
}
.res-stats b { display: block; font-family: 'Anton', sans-serif; font-size: 1rem; color: var(--amber-hi); font-weight: normal; }
.res-emmy {
  display: flex;
  align-items: flex-start;
  gap: 0.7rem;
  padding: 0.7rem 0.9rem;
  background: rgba(212,146,10,0.07);
  border: 1px solid rgba(245,176,48,0.25);
  border-radius: 12px;
  max-width: 360px;
  text-align: left;
}
.res-emmy-photo {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: #1a0f00 center / cover;
  border: 2px solid var(--amber-hi);
  flex-shrink: 0;
}
.res-emmy-name {
  font-family: 'Anton', sans-serif;
  font-size: 0.8rem;
  color: var(--amber-hi);
  letter-spacing: 0.05em;
}
.res-emmy-text {
  font-size: 0.82rem;
  color: var(--cream);
  line-height: 1.4;
  margin-top: 0.2rem;
}
.res-btns { display: flex; gap: 0.7rem; margin-top: 0.5rem; }

/* Countdown overlay */
#countdown {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(6,4,0,0.85);
  z-index: 90;
}
#countdown.visible { display: flex; }
.cd-num {
  font-family: 'Anton', sans-serif;
  font-size: 6rem;
  color: var(--amber-hi);
  letter-spacing: 0.04em;
  text-shadow: 0 0 32px rgba(245,176,48,0.6);
  animation: cdPulse 0.9s ease-out;
}
@keyframes cdPulse {
  0%   { transform: scale(0.5); opacity: 0; }
  30%  { transform: scale(1.1); opacity: 1; }
  100% { transform: scale(1); opacity: 1; }
}

/* Kai-Zustimmungs-Chip — slides in top-right on perfect pour */
#kai-approval {
  position: fixed;
  top: clamp(0.6rem, 2vh, 1.2rem);
  right: clamp(0.6rem, 3vw, 1.2rem);
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.35rem 0.7rem 0.35rem 0.35rem;
  background: rgba(6,4,0,0.92);
  border: 2px solid var(--amber-hi);
  border-radius: 999px;
  box-shadow: 0 4px 18px rgba(245,176,48,0.45);
  font-family: 'Anton', sans-serif;
  color: var(--cream);
  letter-spacing: 0.03em;
  font-size: clamp(0.85rem, 3vw, 1.05rem);
  opacity: 0;
  transform: translateX(140%) scale(0.7);
  pointer-events: none;
  z-index: 86;
}
#kai-approval .ka-ava {
  width: 2.1rem;
  height: 2.1rem;
  border-radius: 50%;
  background-size: cover;
  background-position: center;
  border: 2px solid var(--amber-hi);
  flex: 0 0 auto;
}
#kai-approval .ka-bubble {
  white-space: nowrap;
  padding-right: 0.3rem;
}
#kai-approval.visible { animation: kaiApprovalPop 0.95s cubic-bezier(.2,1.6,.4,1); }
@keyframes kaiApprovalPop {
  0%   { transform: translateX(140%) scale(0.7); opacity: 0; }
  18%  { transform: translateX(-8%)  scale(1.06); opacity: 1; }
  35%  { transform: translateX(0)    scale(1);    opacity: 1; }
  80%  { transform: translateX(0)    scale(1);    opacity: 1; }
  100% { transform: translateX(130%) scale(0.85); opacity: 0; }
}

/* Kai-Taunt — slides up from bottom-left on strike/overflow/timeout */
#kai-taunt {
  position: fixed;
  bottom: clamp(6rem, 20vh, 9rem);
  left: clamp(0.6rem, 3vw, 1.2rem);
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.35rem 0.75rem 0.35rem 0.35rem;
  background: rgba(48,6,6,0.94);
  border: 2px solid #e85c3a;
  border-radius: 999px;
  box-shadow: 0 4px 18px rgba(232,92,58,0.5);
  font-family: 'Anton', sans-serif;
  color: #ffe7df;
  letter-spacing: 0.03em;
  font-size: clamp(0.85rem, 3vw, 1.05rem);
  opacity: 0;
  transform: translateX(-140%) scale(0.7);
  pointer-events: none;
  z-index: 86;
}
#kai-taunt .kt-ava {
  width: 2.1rem;
  height: 2.1rem;
  border-radius: 50%;
  background-size: cover;
  background-position: center;
  border: 2px solid #e85c3a;
  flex: 0 0 auto;
  filter: saturate(1.15) contrast(1.08);
}
#kai-taunt .kt-bubble {
  white-space: nowrap;
  padding-right: 0.3rem;
  max-width: 62vw;
  overflow: hidden;
  text-overflow: ellipsis;
}
#kai-taunt.visible { animation: kaiTauntPop 1.15s cubic-bezier(.2,1.6,.4,1); }
@keyframes kaiTauntPop {
  0%   { transform: translateX(-140%) scale(0.7) rotate(-4deg); opacity: 0; }
  18%  { transform: translateX(8%)    scale(1.08) rotate(2deg); opacity: 1; }
  32%  { transform: translateX(0)     scale(1)    rotate(-1deg); opacity: 1; }
  82%  { transform: translateX(0)     scale(1)    rotate(0); opacity: 1; }
  100% { transform: translateX(-130%) scale(0.85) rotate(0); opacity: 0; }
}

/* Intro hero perk chip — displays below name on intro screen */
.intro-hero-perk {
  margin-top: 0.5rem;
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.15rem;
  padding: 0.4rem 0.75rem;
  background: rgba(212,146,10,0.14);
  border: 1.5px solid var(--amber);
  border-radius: 8px;
  max-width: 100%;
}
.intro-hero-perk .hp-label {
  font-family: 'Anton', sans-serif;
  font-size: 1rem;
  letter-spacing: 0.04em;
  color: var(--amber-hi);
}
.intro-hero-perk .hp-desc {
  font-family: 'DM Mono', monospace;
  font-size: 0.78rem;
  letter-spacing: 0.02em;
  color: var(--cream);
  opacity: 0.88;
}

@media (prefers-reduced-motion: reduce) {
  * { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}
