/* ══════════════════════════════════════════════════════
   TSSR QCM · Duel 2026
   Cinématique pixel-art (gant) + Mode Tennis + gestion défis
   ══════════════════════════════════════════════════════ */

.duel-shell {
  position: relative;
  z-index: 1;
  width: min(1080px, calc(100% - 40px));
  margin: 0 auto;
  padding: 28px 0 80px;
}

/* ─── Hero ─── */
.duel-hero {
  text-align: center;
  margin-bottom: 28px;
}
.duel-hero .eyebrow { justify-content: center; }
.duel-hero h1 {
  margin: 6px 0 0;
  padding: 0.06em 0 0.12em;
  font-size: clamp(2.2rem, 5vw, 3.6rem);
  font-weight: 800;
  letter-spacing: -.045em;
  line-height: 1.15;
  background: linear-gradient(135deg, var(--ink) 30%, var(--accent) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.duel-hero p {
  margin: 14px auto 0;
  max-width: 52ch;
  color: var(--muted);
  font-size: 1rem;
  line-height: 1.7;
}

/* ─── Not logged ─── */
.duel-locked {
  max-width: 460px;
  margin: 40px auto;
  text-align: center;
  padding: 40px 32px;
}
.duel-locked .lock-emoji { font-size: 3rem; margin-bottom: 12px; }

/* ─── Tabs ─── */
.duel-tabs {
  display: flex;
  gap: 4px;
  padding: 5px;
  margin: 0 auto 22px;
  width: fit-content;
  border-radius: 999px;
  background: var(--surf-3);
  border: 1px solid var(--line);
}
.duel-tab {
  padding: 9px 22px;
  border-radius: 999px;
  border: 0;
  background: transparent;
  color: var(--muted);
  font-weight: 600;
  font-size: .88rem;
  cursor: pointer;
  transition: all var(--t-sm) ease;
  white-space: nowrap;
}
.duel-tab:hover { color: var(--ink); }
.duel-tab.active {
  background: linear-gradient(135deg, var(--accent), var(--accent-strong));
  color: #fff;
  box-shadow: 0 6px 18px var(--accent-soft);
}

.tab-content { animation: fadeUp 320ms var(--ease-spring) both; }

/* ─── Duel cards list ─── */
.duels-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 14px;
}
.duel-card {
  position: relative;
  padding: 18px 20px;
  border-radius: var(--r-lg);
  background: var(--surf-grad);
  border: 1px solid var(--line);
  box-shadow: var(--sh);
  overflow: hidden;
  transition: all var(--t-md) var(--ease-spring);
}
.duel-card:hover { transform: translateY(-3px); border-color: var(--line-2); box-shadow: var(--sh-lg); }
.duel-card::before {
  content: "";
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, var(--accent), transparent 70%);
}
.duel-card.status-active::before { background: linear-gradient(90deg, #34d399, transparent 70%); }
.duel-card.status-completed { opacity: .82; }
.duel-card.status-completed::before { background: linear-gradient(90deg, var(--muted), transparent 70%); }

.dc-title { font-size: 1rem; font-weight: 700; color: var(--ink); margin-bottom: 6px; }
.dc-meta { font-size: .78rem; color: var(--muted); margin-bottom: 10px; }
.dc-stake {
  display: inline-flex;
  font-size: .82rem;
  font-weight: 600;
  color: var(--accent);
  font-family: 'JetBrains Mono', monospace;
  padding: 5px 11px;
  border-radius: 999px;
  background: var(--accent-soft);
  margin-bottom: 10px;
}
.dc-result {
  padding: 9px 13px;
  border-radius: var(--r-sm);
  font-size: .84rem;
  font-weight: 600;
  margin: 8px 0;
}
.dc-result.win  { background: var(--fb-ok); color: var(--success); }
.dc-result.loss { background: var(--fb-err); color: var(--danger); }
.dc-result.draw { background: var(--surf-3); color: var(--muted); }

.dc-actions { display: flex; flex-direction: column; gap: 6px; margin-top: 8px; }

.duel-btn {
  padding: 9px 16px;
  border-radius: 999px;
  border: 0;
  font: inherit;
  font-weight: 700;
  font-size: .85rem;
  cursor: pointer;
  transition: all var(--t-sm) var(--ease-spring);
}
.duel-btn:hover { transform: translateY(-2px); }
.duel-btn-accept, .duel-btn-play {
  background: linear-gradient(135deg, var(--accent), var(--accent-strong));
  color: #fff;
  box-shadow: 0 6px 16px var(--accent-soft);
}
.duel-btn-cancel {
  background: var(--surf-3);
  border: 1px solid var(--line);
  color: var(--muted);
}
.duel-btn-cancel:hover { color: var(--danger); border-color: rgba(248,113,113,.3); }
.duel-waiting { font-size: .82rem; color: var(--muted); font-style: italic; }

.empty-duels {
  grid-column: 1 / -1;
  text-align: center;
  padding: 36px 20px;
  color: var(--muted);
  font-size: .92rem;
  border: 1.5px dashed var(--line-2);
  border-radius: var(--r-lg);
}

/* ─── Create duel form ─── */
.dc-form { max-width: 540px; }
.dc-field { margin-bottom: 16px; }
.dc-field label {
  display: block;
  margin-bottom: 7px;
  font-size: .83rem;
  font-weight: 700;
  color: var(--ink-2);
}
.dc-field select,
.dc-field input {
  width: 100%;
  padding: 11px 14px;
  border-radius: var(--r-md);
  border: 1.5px solid var(--line);
  background: var(--surf-2);
  color: var(--ink);
  font-size: .92rem;
  outline: none;
  transition: all var(--t-sm) ease;
}
.dc-field select:focus,
.dc-field input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
.dc-balance-hint { font-size: .8rem; color: var(--muted); margin: 8px 0 0; }
.dc-feedback {
  margin: 14px 0 0;
  padding: 11px 14px;
  border-radius: var(--r-md);
  font-size: .86rem;
  font-weight: 500;
  display: none;
}
.dc-feedback.visible { display: block; }
.dc-feedback.success { background: var(--fb-ok); color: var(--success); }
.dc-feedback.error { background: var(--fb-err); color: var(--danger); }

/* ─── Stake quick chips ─── */
.stake-chips { display: flex; gap: 7px; flex-wrap: wrap; margin-top: 8px; }
.stake-chip {
  padding: 6px 13px;
  border-radius: 999px;
  border: 1.5px solid var(--line);
  background: var(--surf-3);
  color: var(--ink-2);
  font: inherit; font-size: .8rem; font-weight: 700;
  font-family: 'JetBrains Mono', monospace;
  cursor: pointer;
  transition: all var(--t-sm) ease;
}
.stake-chip:hover { border-color: var(--accent); color: var(--accent); }
.stake-chip.is-active { background: var(--accent-soft); border-color: var(--accent); color: var(--accent); }

/* ════════════════════════════════════════════
   CINÉMATIQUE PIXEL-ART — le défieur jette un gant
   ════════════════════════════════════════════ */
#duel-vs-screen {
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: none;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background:
    radial-gradient(ellipse 70% 60% at 50% 45%, rgba(40,12,30,.7), rgba(8,4,12,.96)),
    #07040a;
}
#duel-vs-screen.show { display: flex; }

/* CRT scanlines */
#duel-vs-screen::before {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    to bottom,
    rgba(0,0,0,0) 0,
    rgba(0,0,0,0) 2px,
    rgba(0,0,0,.18) 3px,
    rgba(0,0,0,0) 4px
  );
  pointer-events: none;
  z-index: 30;
  opacity: .5;
}
/* Vignette */
#duel-vs-screen::after {
  content: "";
  position: absolute;
  inset: 0;
  box-shadow: inset 0 0 200px rgba(0,0,0,.85);
  pointer-events: none;
  z-index: 29;
}

.vs-stage {
  position: relative;
  width: min(900px, 94vw);
  height: min(440px, 56vh);
  display: flex;
  align-items: center;
  justify-content: space-between;
  image-rendering: pixelated;
}

/* Pixel ground */
.vs-ground {
  position: absolute;
  left: 0; right: 0; bottom: 14%;
  height: 4px;
  background: repeating-linear-gradient(90deg, #2a1830 0 16px, #1a0f22 16px 32px);
  box-shadow: 0 8px 0 rgba(0,0,0,.4);
}

/* Fighters */
.vs-fighter {
  position: relative;
  width: 150px;
  display: flex;
  flex-direction: column;
  align-items: center;
  z-index: 10;
  opacity: 0;
}
.vs-fighter .vs-sprite { width: 132px; height: 132px; display: block; }
.vs-fighter .vs-sprite svg { width: 132px; height: 132px; display: block; }

/* Animations only fire once the screen is shown */
#duel-vs-screen.show .vs-fighter--left  { animation: fighterInLeft .55s var(--ease-spring) both, windUp 1.6s ease 0.6s; }
#duel-vs-screen.show .vs-fighter--right { animation: fighterInRight .55s var(--ease-spring) both, recoil 1s ease 2s both; }

@keyframes fighterInLeft  { from { transform: translateX(-160%); opacity: 0; } to { transform: translateX(0); opacity: 1; } }
@keyframes fighterInRight { from { transform: translateX( 160%); opacity: 0; } to { transform: translateX(0); opacity: 1; } }

@keyframes windUp {
  0%, 100% { transform: translateX(0) rotate(0); }
  30%      { transform: translateX(-10px) rotate(-4deg); }
  45%      { transform: translateX(8px) rotate(3deg); }
}

@keyframes recoil {
  0%   { transform: translateX(0) rotate(0); filter: none; }
  12%  { transform: translateX(34px) rotate(9deg); filter: brightness(2.4) saturate(.3); }
  26%  { transform: translateX(14px) rotate(4deg); filter: brightness(1.2); }
  40%  { transform: translateX(22px) rotate(6deg); }
  100% { transform: translateX(8px) rotate(2deg); }
}

.vs-fighter-name {
  margin-top: 10px;
  font-family: 'JetBrains Mono', monospace;
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .03em;
  padding: 4px 12px;
  border-radius: 4px;
  text-transform: uppercase;
  max-width: 170px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.vs-fighter--left  .vs-fighter-name { background: rgba(240,84,110,.2); color: #ff9bb0; border: 2px solid #f0546e; }
.vs-fighter--right .vs-fighter-name { background: rgba(96,165,250,.2); color: #a7c8ff; border: 2px solid #60a5fa; }

/* The flying glove */
.vs-glove {
  position: absolute;
  left: 130px;
  top: 38%;
  width: 56px;
  height: 56px;
  z-index: 20;
  opacity: 0;
}
.vs-glove svg { width: 100%; height: 100%; display: block; }
#duel-vs-screen.show .vs-glove { animation: gloveThrow 0.85s cubic-bezier(.45,.05,.55,.95) 1.15s both; }
@keyframes gloveThrow {
  0%   { opacity: 0; transform: translate(0, 0) rotate(0) scale(.7); }
  10%  { opacity: 1; transform: translate(0, -20px) rotate(40deg) scale(.9); }
  55%  { opacity: 1; transform: translate(min(46vw,560px), -54px) rotate(280deg) scale(1.05); }
  85%  { opacity: 1; transform: translate(min(54vw,640px), 6px) rotate(520deg) scale(1.15); }
  100% { opacity: 1; transform: translate(min(56vw,660px), 14px) rotate(560deg) scale(1); }
}

/* Impact burst */
.vs-impact {
  position: absolute;
  right: 110px;
  top: 30%;
  z-index: 25;
  font-family: 'JetBrains Mono', monospace;
  font-weight: 800;
  font-size: 2.2rem;
  color: #ffd23f;
  text-shadow: 3px 3px 0 #c93050, 6px 6px 0 rgba(0,0,0,.4);
  opacity: 0;
}
#duel-vs-screen.show .vs-impact { animation: impactPow .7s var(--ease-spring) 2s both; }
@keyframes impactPow {
  0%   { opacity: 0; transform: scale(.2) rotate(-12deg); }
  30%  { opacity: 1; transform: scale(1.3) rotate(8deg); }
  60%  { transform: scale(1) rotate(-4deg); }
  100% { opacity: 0; transform: scale(1.1) rotate(0); }
}

/* Impact stars */
.vs-stars {
  position: absolute;
  right: 90px;
  top: 18%;
  z-index: 24;
  opacity: 0;
}
#duel-vs-screen.show .vs-stars { animation: starsPop 1.2s ease 2.05s both; }
.vs-stars span {
  position: absolute;
  font-size: 1.3rem;
  animation: starOrbit 1.2s linear infinite;
}
.vs-stars span:nth-child(1) { --a: 0deg;   }
.vs-stars span:nth-child(2) { --a: 120deg; }
.vs-stars span:nth-child(3) { --a: 240deg; }
@keyframes starsPop { 0% { opacity: 0; } 20% { opacity: 1; } 80% { opacity: 1; } 100% { opacity: 0; } }
@keyframes starOrbit {
  from { transform: rotate(var(--a)) translateX(28px) rotate(calc(-1 * var(--a))); }
  to   { transform: rotate(calc(var(--a) + 360deg)) translateX(28px) rotate(calc(-1 * var(--a) - 360deg)); }
}

/* Screen shake on impact */
#duel-vs-screen.show .vs-stage { animation: stageShake .5s ease 2s; }
@keyframes stageShake {
  0%,100% { transform: translate(0,0); }
  20% { transform: translate(-6px, 3px); }
  40% { transform: translate(6px, -3px); }
  60% { transform: translate(-4px, 2px); }
  80% { transform: translate(4px, -1px); }
}

/* Impact flash */
.vs-flash {
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 78% 38%, rgba(255,255,255,.5), transparent 30%);
  z-index: 26;
  opacity: 0;
  pointer-events: none;
}
#duel-vs-screen.show .vs-flash { animation: flashHit .4s ease 2s; }
@keyframes flashHit { 0% { opacity: 0; } 30% { opacity: 1; } 100% { opacity: 0; } }

/* VS badge */
.vs-badge {
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  z-index: 28;
  font-family: 'JetBrains Mono', monospace;
  font-weight: 800;
  font-size: clamp(3rem, 9vw, 5.5rem);
  color: #fff;
  text-shadow:
    4px 4px 0 #c93050,
    -2px -2px 0 #60a5fa,
    0 0 24px rgba(240,84,110,.6);
  opacity: 0;
}
.vs-badge { letter-spacing: -.04em; }
#duel-vs-screen.show .vs-badge { animation: vsSlam .6s var(--ease-spring) 2.5s both; }
@keyframes vsSlam {
  0%   { opacity: 0; transform: translate(-50%,-50%) scale(3) rotate(-15deg); }
  60%  { opacity: 1; transform: translate(-50%,-50%) scale(.9) rotate(4deg); }
  100% { opacity: 1; transform: translate(-50%,-50%) scale(1) rotate(0); }
}

/* Meta info (module + stake) */
.vs-meta {
  position: absolute;
  left: 50%; bottom: 8%;
  transform: translateX(-50%);
  z-index: 28;
  text-align: center;
  opacity: 0;
}
#duel-vs-screen.show .vs-meta { animation: fadeUp .5s ease 2.9s both; }
.vs-meta #vs-module {
  display: block;
  font-family: 'JetBrains Mono', monospace;
  font-size: .9rem;
  color: #a7c8ff;
  letter-spacing: .1em;
  text-transform: uppercase;
}
.vs-meta #vs-stake {
  display: block;
  margin-top: 6px;
  font-weight: 700;
  color: #ffd23f;
  font-size: 1rem;
}

/* Countdown */
#vs-countdown {
  position: absolute;
  left: 50%; top: 74%;
  transform: translateX(-50%);
  z-index: 28;
  font-family: 'JetBrains Mono', monospace;
  font-weight: 800;
  font-size: clamp(2rem, 6vw, 3.4rem);
  color: #fff;
  text-shadow: 0 0 20px var(--accent-glow);
  animation: cdPulse .9s ease infinite;
}
@keyframes cdPulse { 0%,100% { transform: translateX(-50%) scale(1); } 50% { transform: translateX(-50%) scale(1.18); } }

/* ════════════════════════════════════════════
   MODE TENNIS — aperçu jouable
   ════════════════════════════════════════════ */
.tennis-intro {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 18px;
  align-items: center;
  margin-bottom: 18px;
  padding: 18px 22px;
  border-radius: var(--r-lg);
  background: linear-gradient(135deg, rgba(52,211,153,.08), rgba(34,211,238,.05));
  border: 1px solid rgba(52,211,153,.2);
}
.tennis-intro h3 { margin: 0 0 4px; font-size: 1.05rem; }
.tennis-intro p { margin: 0; color: var(--muted); font-size: .88rem; line-height: 1.5; }
.tennis-start-btn {
  padding: 12px 26px;
  border-radius: 999px;
  border: 0;
  background: linear-gradient(135deg, #34d399, #22d3ee);
  color: #06281f;
  font-weight: 800;
  font-size: .95rem;
  cursor: pointer;
  white-space: nowrap;
  box-shadow: 0 8px 24px rgba(52,211,153,.3);
  transition: all var(--t-sm) var(--ease-spring);
}
.tennis-start-btn:hover { transform: translateY(-2px) scale(1.03); box-shadow: 0 14px 32px rgba(52,211,153,.45); }

/* Tennis court */
.tennis-court {
  position: relative;
  height: 260px;
  border-radius: var(--r-lg);
  overflow: hidden;
  background:
    linear-gradient(180deg, #1a6b4a 0%, #14573c 100%);
  border: 3px solid #0c3a28;
  box-shadow: var(--sh), inset 0 0 60px rgba(0,0,0,.3);
  margin-bottom: 14px;
}
/* court lines */
.tennis-court::before {
  content: "";
  position: absolute;
  inset: 16px;
  border: 2px solid rgba(255,255,255,.55);
  border-radius: 2px;
}
/* net */
.tennis-net {
  position: absolute;
  left: 50%; top: 8px; bottom: 8px;
  width: 3px;
  transform: translateX(-50%);
  background: repeating-linear-gradient(to bottom, rgba(255,255,255,.8) 0 5px, transparent 5px 9px);
  z-index: 3;
}
.tennis-net::after {
  content: "";
  position: absolute;
  left: 50%; top: 0; bottom: 0;
  width: 10px; transform: translateX(-50%);
  background: rgba(255,255,255,.12);
}

/* paddles / players */
.tennis-player {
  position: absolute;
  top: 50%;
  width: 14px; height: 64px;
  border-radius: 7px;
  transform: translateY(-50%);
  z-index: 4;
  transition: top .25s var(--ease-out);
}
.tennis-player--you { left: 22px; background: linear-gradient(180deg, #ff9bb0, #f0546e); box-shadow: 0 0 16px rgba(240,84,110,.6); }
.tennis-player--cpu { right: 22px; background: linear-gradient(180deg, #a7c8ff, #60a5fa); box-shadow: 0 0 16px rgba(96,165,250,.6); }

/* ball */
.tennis-ball {
  position: absolute;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, #f5ff7a, #d4e02a);
  box-shadow: 0 0 14px rgba(212,224,42,.8);
  z-index: 5;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  transition: none;
}
.tennis-ball.hidden { opacity: 0; }

/* ball trail */
.tennis-trail {
  position: absolute;
  width: 10px; height: 10px;
  border-radius: 50%;
  background: rgba(245,255,122,.4);
  z-index: 4;
  pointer-events: none;
  animation: trailFade .5s ease forwards;
}
@keyframes trailFade { from { opacity: .6; transform: scale(1); } to { opacity: 0; transform: scale(.3); } }

/* Score banner over court */
.tennis-scoreboard {
  position: absolute;
  top: 10px; left: 50%;
  transform: translateX(-50%);
  z-index: 6;
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 5px 16px;
  border-radius: 999px;
  background: rgba(8,20,14,.7);
  backdrop-filter: blur(8px);
  font-family: 'JetBrains Mono', monospace;
  font-weight: 800;
  font-size: 1.1rem;
}
.tennis-score-you { color: #ff9bb0; }
.tennis-score-cpu { color: #a7c8ff; }
.tennis-score-sep { color: rgba(255,255,255,.4); font-size: .8rem; }

/* power flash on hit */
.tennis-power-flash {
  position: absolute;
  z-index: 5;
  font-family: 'JetBrains Mono', monospace;
  font-weight: 800;
  font-size: 1.1rem;
  color: #fff;
  text-shadow: 0 0 10px rgba(0,0,0,.6);
  pointer-events: none;
  animation: powerFlash .8s ease forwards;
}
@keyframes powerFlash {
  0% { opacity: 0; transform: translateY(0) scale(.6); }
  25% { opacity: 1; transform: translateY(-12px) scale(1.1); }
  100% { opacity: 0; transform: translateY(-30px) scale(1); }
}

/* Tennis question panel */
.tennis-q {
  padding: 20px 24px;
  border-radius: var(--r-lg);
  background: var(--surf-grad);
  border: 1px solid var(--line);
  box-shadow: var(--sh);
}
.tennis-q-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 4px;
}
.tennis-q-cat {
  font-size: .7rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--accent);
  font-weight: 700;
}
.tennis-q-num { font-size: .78rem; color: var(--muted); font-family: 'JetBrains Mono', monospace; }
.tennis-q h2 { margin: 8px 0 16px; font-size: 1.15rem; line-height: 1.4; font-weight: 700; }

/* Power meter */
.tennis-power {
  margin-bottom: 16px;
}
.tennis-power-label {
  display: flex;
  justify-content: space-between;
  font-size: .74rem;
  color: var(--muted);
  font-weight: 600;
  margin-bottom: 5px;
}
.tennis-power-track {
  height: 12px;
  border-radius: 999px;
  background: var(--surf);
  border: 1px solid var(--line);
  overflow: hidden;
  position: relative;
}
.tennis-power-fill {
  height: 100%;
  width: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, #34d399, #fbbf24 55%, #f0546e);
  transform-origin: left;
  transition: transform 50ms linear;
}

.tennis-choices { display: grid; gap: 9px; }
.tennis-choice {
  display: grid;
  grid-template-columns: 2.2rem 1fr;
  gap: 12px;
  align-items: center;
  padding: 12px 15px 12px 12px;
  border-radius: var(--r-md);
  background: var(--surf-3);
  border: 1.5px solid var(--line);
  cursor: pointer;
  text-align: left;
  font: inherit;
  color: var(--ink-2);
  transition: all var(--t-sm) var(--ease-out);
}
.tennis-choice:hover:not(:disabled) {
  border-color: color-mix(in srgb, #34d399 55%, transparent);
  background: rgba(52,211,153,.08);
  color: var(--ink);
}
.tennis-choice::before {
  content: attr(data-letter);
  display: flex; align-items: center; justify-content: center;
  width: 2.2rem; height: 2.2rem;
  border-radius: var(--r-sm);
  background: var(--surf);
  border: 1.5px solid var(--line-2);
  font-weight: 700; font-size: .8rem; color: var(--muted);
  font-family: 'JetBrains Mono', monospace;
}
.tennis-choice.is-correct { border-color: rgba(52,211,153,.6); background: rgba(52,211,153,.1); color: var(--ink); }
.tennis-choice.is-correct::before { background: rgba(52,211,153,.2); border-color: #34d399; color: #34d399; }
.tennis-choice.is-wrong { border-color: rgba(248,113,113,.5); background: rgba(248,113,113,.08); }
.tennis-choice.is-wrong::before { background: rgba(248,113,113,.16); border-color: #f87171; color: #f87171; }
.tennis-choice:disabled { cursor: default; }

/* Tennis result */
.tennis-result {
  text-align: center;
  padding: 36px 24px;
}
.tennis-result-emoji { font-size: 3.4rem; margin-bottom: 8px; }
.tennis-result h2 { margin: 0 0 6px; font-size: 1.6rem; }
.tennis-result .final-score {
  font-family: 'JetBrains Mono', monospace;
  font-size: 3rem; font-weight: 800;
  margin: 12px 0;
}
.tennis-result p { color: var(--muted); margin: 4px 0 20px; }

/* Responsive */
@media (max-width: 640px) {
  .duel-shell { width: min(100% - 24px, 100%); }
  .tennis-intro { grid-template-columns: 1fr; }
  .tennis-court { height: 200px; }
  .vs-fighter { width: 100px; }
  .vs-fighter svg { width: 92px; height: 92px; }
  .duels-list { grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  .vs-glove, .vs-fighter, .vs-badge, .vs-meta, .vs-impact, .vs-stars, .vs-flash { animation-duration: .01ms !important; }
}
