/*
 * ═══════════════════════════════════════════════════════════════
 *  gameplay-ui.css  —  Shared duel gameplay component system
 *  Pure CSS. No PNGs for UI chrome. SVG only for match lines.
 *  Used by: geo-duel-questions, orbital-flags-duel,
 *           orbitalni-oblik-duel, zg-duel, slovons-duel,
 *           space-connection-duel
 * ═══════════════════════════════════════════════════════════════
 */

/* ─────────────────────────────────────────
   DESIGN TOKENS
───────────────────────────────────────── */
:root {
  --gp-bg:         #070b20;
  --gp-blue:       #68b7ff;
  --gp-purple:     #8b5cff;
  --gp-pink:       #ff4fb8;
  --gp-green:      #34ef8a;
  --gp-red:        #ff4f6d;
  --gp-gold:       #ffd447;
  --gp-text:       #ffffff;
  --gp-text-muted: rgba(255,255,255,0.45);

  /* player side colors */
  --gp-p1-color: #68b7ff;   /* blue  — left  player */
  --gp-p2-color: #ff4fb8;   /* pink  — right player */
}


/* ═══════════════════════════════════════════
   1. STRUCTURAL LAYOUT
═══════════════════════════════════════════ */

/* Page shell */
.gp-page {
  display: flex;
  flex-direction: column;
  min-height: 100dvh;
  background: var(--gp-bg);
  color: var(--gp-text);
  font-family: 'Segoe UI', system-ui, sans-serif;
  overflow-x: hidden;
  max-width: 430px;
  margin: 0 auto;
  padding: 0 0 24px;
}

/* ── Top bar ── */
.gp-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 16px 12px;
  position: sticky;
  top: 0;
  z-index: 50;
  background: linear-gradient(180deg, rgba(7,11,32,1) 0%, rgba(7,11,32,0) 100%);
}

.gp-back-btn {
  width: 46px;
  height: 46px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.12);
  color: #fff;
  font-size: 22px;
  font-weight: 700;
  cursor: pointer;
  text-decoration: none;
  flex-shrink: 0;
  transition: background .15s;
}
.gp-back-btn:hover { background: rgba(255,255,255,0.13); }

/* Mode pill — center of top bar */
.gp-mode-pill {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  border-radius: 999px;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.13);
  font-size: 15px;
  font-weight: 800;
  color: #fff;
  white-space: nowrap;
}
.gp-mode-pill img {
  width: 26px;
  height: 26px;
  object-fit: contain;
  border-radius: 6px;
}

/* ── Round counter ── */
.gp-round {
  text-align: center;
  padding: 4px 0 12px;
}
.gp-round-label {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(180,160,255,0.6);
  margin-bottom: 2px;
}
.gp-round-value {
  font-size: 36px;
  font-weight: 900;
  background: linear-gradient(135deg, #c8b8ff 0%, #fff 55%, #c8b8ff 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1.1;
}

/* ── Scoreboard wrapper ── */
.gp-scoreboard {
  display: flex;
  align-items: stretch;
  gap: 0;
  padding: 0 14px;
}

/* Player card */
.gp-player-card {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 12px 10px;
  min-width: 0;
  border-radius: 22px;
}
/* left player — blue card */
.gp-player-card.left {
  background:
    linear-gradient(180deg, rgba(22,36,82,0.9), rgba(13,20,52,0.94)) padding-box,
    linear-gradient(135deg, #68b7ff, #7d54ff) border-box;
  border: 1px solid transparent;
  box-shadow: 0 0 28px rgba(100,180,255,0.18);
}
/* right player — pink card, mirrored layout */
.gp-player-card.right {
  flex-direction: row-reverse;
  background:
    linear-gradient(180deg, rgba(54,22,67,0.9), rgba(22,13,42,0.94)) padding-box,
    linear-gradient(135deg, #ff4fb8, #8a5cff) border-box;
  border: 1px solid transparent;
  box-shadow: 0 0 28px rgba(255,79,184,0.18);
}

/* Player info block */
.gp-player-info {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.gp-player-card.right .gp-player-info {
  align-items: flex-end;
}

.gp-player-name {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 800;
  color: rgba(255,255,255,0.9);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.gp-player-card.right .gp-player-name {
  flex-direction: row-reverse;
}

.gp-online-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #32e982;
  box-shadow: 0 0 8px rgba(50,233,130,0.8);
  flex-shrink: 0;
}

.gp-player-score {
  font-size: 32px;
  font-weight: 900;
  line-height: 1;
  color: var(--gp-p1-color);
}
.gp-player-card.right .gp-player-score {
  color: var(--gp-p2-color);
}

/* Progress bar inside player card */
.gp-player-card .progress-track {
  width: 100%;
  height: 6px;
  margin-top: 2px;
}
.gp-player-card.left .progress-track::before {
  background: linear-gradient(90deg, #5fa8ff, #7d54ff);
}
.gp-player-card.right .progress-track::before {
  background: linear-gradient(90deg, #ff4fb8, #8a5cff);
}

/* ── Between scoreboard and content ── */
.gp-scoreboard-gap {
  padding: 10px 14px 0;
}

/* ── Content card ── */
.gp-content-card {
  margin: 12px 14px 0;
  border-radius: 28px;
  padding: 16px;
  background:
    linear-gradient(180deg, rgba(18,24,60,0.92), rgba(10,15,38,0.96)) padding-box,
    linear-gradient(135deg, rgba(100,160,255,0.35), rgba(150,75,255,0.28), rgba(255,65,175,0.22)) border-box;
  border: 1px solid transparent;
  box-shadow:
    0 0 32px rgba(100,80,255,0.14),
    inset 0 0 32px rgba(100,120,255,0.05);
  backdrop-filter: blur(14px);
}

/* ── Rival bar (bottom) ── */
.gp-rival-bar {
  margin: 12px 14px 0;
  border-radius: 22px;
  padding: 12px 16px;
  display: flex;
  align-items: center;
  gap: 12px;
  background: rgba(12,16,40,0.88);
  border: 1px solid rgba(255,255,255,0.07);
}
.gp-rival-bar .avatar-wrap {
  width: 46px;
  height: 46px;
  flex-shrink: 0;
}
.gp-rival-bar .avatar-wrap img {
  border-color: var(--gp-p2-color);
  box-shadow: 0 0 14px rgba(255,79,184,0.45);
}
.gp-rival-text {
  flex: 1;
  font-size: 15px;
  font-weight: 800;
  color: var(--gp-p2-color);
}
.gp-rival-dots {
  display: flex;
  gap: 5px;
  align-items: center;
}
.gp-rival-dots span {
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: var(--gp-p2-color);
  opacity: 0.5;
  animation: gpDotPulse 1.4s ease-in-out infinite;
}
.gp-rival-dots span:nth-child(2) { animation-delay: .2s; }
.gp-rival-dots span:nth-child(3) { animation-delay: .4s; }
@keyframes gpDotPulse {
  0%,80%,100% { opacity: 0.25; transform: scale(0.7); }
  40%          { opacity: 1;    transform: scale(1.2); }
}


/* ═══════════════════════════════════════════
   2. NEON CARD
═══════════════════════════════════════════ */
.neon-card {
  position: relative;
  border-radius: 28px;
  border: 1px solid transparent;
  background:
    linear-gradient(180deg, rgba(22,28,70,0.88), rgba(12,16,42,0.92)) padding-box,
    linear-gradient(135deg, rgba(100,180,255,0.85), rgba(150,75,255,0.75), rgba(255,65,175,0.75)) border-box;
  box-shadow:
    0 0 24px rgba(120,80,255,0.22),
    inset 0 0 28px rgba(120,140,255,0.08);
  backdrop-filter: blur(14px);
}
.neon-card.blue {
  background:
    linear-gradient(180deg, rgba(22,36,82,0.9), rgba(13,20,52,0.94)) padding-box,
    linear-gradient(135deg, #68b7ff, #7d54ff) border-box;
}
.neon-card.pink {
  background:
    linear-gradient(180deg, rgba(54,22,67,0.9), rgba(22,13,42,0.94)) padding-box,
    linear-gradient(135deg, #ff4fb8, #8a5cff) border-box;
}


/* ═══════════════════════════════════════════
   3. CONIC-GRADIENT TIMER RING (top-right)
═══════════════════════════════════════════ */
.timer-ring {
  --value: 72%;
  --size: 66px;
  width: var(--size);
  height: var(--size);
  border-radius: 999px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  background:
    radial-gradient(circle at center, #090d24 58%, transparent 60%),
    conic-gradient(#a855f7 0 var(--value), rgba(100,80,255,0.22) var(--value) 100%);
  box-shadow:
    0 0 22px rgba(160,80,255,0.55),
    inset 0 0 14px rgba(255,255,255,0.07);
  color: #fff;
  font-weight: 900;
  font-size: 22px;
}
.timer-ring.warn {
  background:
    radial-gradient(circle at center, #090d24 58%, transparent 60%),
    conic-gradient(#ffb020 0 var(--value), rgba(255,255,255,0.12) var(--value) 100%);
  box-shadow: 0 0 22px rgba(255,176,32,0.5);
}
.timer-ring.danger {
  background:
    radial-gradient(circle at center, #090d24 58%, transparent 60%),
    conic-gradient(#ff4f6d 0 var(--value), rgba(255,255,255,0.12) var(--value) 100%);
  box-shadow: 0 0 22px rgba(255,79,109,0.55);
}

/* Reveal-hold phase: the same ring animates the per-mode reveal countdown in a
   distinct green/cyan accent so it reads as "showing the answer" rather than a
   frozen gameplay timer. Driven by DuelTimerRing.reveal(). */
.timer-ring.reveal {
  background:
    radial-gradient(circle at center, #090d24 58%, transparent 60%),
    conic-gradient(#22c55e 0 var(--value), rgba(0,245,255,0.18) var(--value) 100%);
  box-shadow: 0 0 22px rgba(34,197,94,0.5), inset 0 0 14px rgba(255,255,255,0.07);
}


/* ═══════════════════════════════════════════
   4. PROGRESS TRACK WITH DOT
═══════════════════════════════════════════ */
.progress-track {
  --value: 55%;
  position: relative;
  height: 10px;
  border-radius: 999px;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(170,150,255,0.25);
  overflow: visible;
}
.progress-track::before {
  content: "";
  position: absolute;
  inset: 1px auto 1px 1px;
  width: calc(var(--value) - 2px);
  border-radius: inherit;
  background: linear-gradient(90deg, #5fa8ff, #8b5cff, #ff4fd8);
  box-shadow: 0 0 16px rgba(150,90,255,0.7);
}
.progress-track::after {
  content: "";
  position: absolute;
  top: 50%;
  left: var(--value);
  transform: translate(-50%, -50%);
  width: 16px;
  height: 16px;
  border-radius: 999px;
  background: #fff;
  box-shadow:
    0 0 14px rgba(180,90,255,1),
    0 0 28px rgba(120,90,255,0.7);
}

.mcq-player-card .progress-track {
  background: rgba(255,255,255,.08) !important;
  border: 1px solid rgba(74,222,128,.14) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.06),
    0 0 10px rgba(34,197,94,.10) !important;
}

.mcq-player-card .progress-track::before {
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  background: linear-gradient(90deg,#22c55e 0%,#86efac 55%,#22d3ee 100%) !important;
  box-shadow:
    0 0 12px rgba(34,197,94,.42),
    inset 0 1px 0 rgba(255,255,255,.24) !important;
}

.mcq-player-card .progress-track::after {
  display: none !important;
  content: none !important;
}


/* ═══════════════════════════════════════════
   5. VS PILL
═══════════════════════════════════════════ */
.vs-pill {
  width: 60px;
  height: 60px;
  border-radius: 20px;
  display: grid;
  place-items: center;
  color: #d9c2ff;
  font-size: 22px;
  font-weight: 900;
  flex-shrink: 0;
  align-self: center;
  background: linear-gradient(180deg, rgba(76,38,130,0.85), rgba(27,18,64,0.95));
  border: 1px solid rgba(177,112,255,0.6);
  box-shadow:
    0 0 22px rgba(150,70,255,0.5),
    inset 0 0 16px rgba(255,255,255,0.07);
  margin: 0 -2px;
  position: relative;
  z-index: 2;
}


/* ═══════════════════════════════════════════
   6. AVATAR WRAP + BADGE
═══════════════════════════════════════════ */
.avatar-wrap {
  position: relative;
  width: 72px;
  height: 72px;
  flex-shrink: 0;
}
.avatar-wrap img {
  width: 100%;
  height: 100%;
  border-radius: 999px;
  object-fit: cover;
  object-position: top center;
  border: 3px solid #7b5cff;
  box-shadow: 0 0 20px rgba(125,92,255,0.6);
  display: block;
}
.gp-player-card.left .avatar-wrap img {
  border-color: var(--gp-p1-color);
  box-shadow: 0 0 20px rgba(100,180,255,0.5);
}
.gp-player-card.right .avatar-wrap img {
  border-color: var(--gp-p2-color);
  box-shadow: 0 0 20px rgba(255,79,184,0.5);
}

.avatar-badge {
  position: absolute;
  right: -3px;
  bottom: -3px;
  width: 26px;
  height: 26px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  font-size: 13px;
  font-weight: 900;
  color: #fff;
  background: linear-gradient(180deg, #9b5cff, #651cff);
  border: 3px solid #070b20;
  box-shadow: 0 0 12px rgba(145,80,255,0.7);
}


/* ═══════════════════════════════════════════
   7. THREE STAT PILLS
═══════════════════════════════════════════ */
.stat-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.stat-pill {
  min-height: 68px;
  border-radius: 18px;
  padding: 10px 12px;
  display: flex;
  align-items: center;
  gap: 10px;
  background: rgba(15,22,55,0.82);
  border: 1px solid var(--stat-color, #8b5cff);
  box-shadow: 0 0 16px color-mix(in srgb, var(--stat-color, #8b5cff), transparent 65%);
}
.stat-pill .stat-icon {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  font-size: 17px;
  flex-shrink: 0;
  background: color-mix(in srgb, var(--stat-color, #8b5cff), transparent 78%);
}
.stat-pill .stat-body {
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.stat-pill .stat-label {
  font-size: 11px;
  font-weight: 800;
  color: var(--stat-color, #8b5cff);
  letter-spacing: 0.03em;
}
.stat-pill .stat-value {
  font-size: 22px;
  font-weight: 900;
  color: #fff;
  line-height: 1;
}
.stat-pill.points { --stat-color: #ffd447; }
.stat-pill.correct { --stat-color: #32e982; }
.stat-pill.rival   { --stat-color: #ff4fb8; }


/* ═══════════════════════════════════════════
   8. GLOWING LETTER ORB
═══════════════════════════════════════════ */
.letter-orb {
  --size: 165px;
  width: var(--size);
  height: var(--size);
  border-radius: 999px;
  display: grid;
  place-items: center;
  margin: 0 auto;
  color: #fff;
  font-size: 90px;
  font-weight: 900;
  line-height: 1;
  background:
    radial-gradient(circle, rgba(56,75,160,0.22), rgba(8,12,32,0.78) 64%),
    linear-gradient(180deg, rgba(32,44,95,0.8), rgba(12,17,45,0.88));
  border: 2px solid rgba(100,170,255,0.92);
  box-shadow:
    0 0 32px rgba(85,145,255,0.85),
    0 0 72px rgba(122,80,255,0.4),
    inset 0 0 32px rgba(130,100,255,0.16);
}


/* ═══════════════════════════════════════════
   9. TIMER PILL (inside content card)
═══════════════════════════════════════════ */
.timer-pill {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  min-width: 120px;
  padding: 12px 16px;
  border-radius: 18px;
  background: rgba(13,20,52,0.78);
  border: 1px solid rgba(92,152,255,0.5);
  box-shadow: inset 0 0 16px rgba(90,145,255,0.1);
}
.timer-pill .tp-time {
  color: #57b8ff;
  font-size: 24px;
  font-weight: 900;
  line-height: 1;
}
.timer-pill .tp-sub {
  color: #dfe8ff;
  font-size: 13px;
  font-weight: 800;
}
.timer-pill .tp-sub strong {
  color: #37a7ff;
}


/* ═══════════════════════════════════════════
   10. TAČNI ODGOVORI — 2-COLUMN LIST
═══════════════════════════════════════════ */
.correct-list {
  border-radius: 22px;
  padding: 16px;
  background: rgba(12,18,48,0.82);
  border: 1px solid rgba(151,114,255,0.5);
}
.correct-list-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: #b58cff;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 10px;
}
.correct-list-count {
  color: var(--gp-purple);
  font-weight: 900;
}
.correct-list-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border-radius: 16px;
  overflow: hidden;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.07);
}
.correct-item {
  display: flex;
  align-items: center;
  gap: 9px;
  min-height: 42px;
  padding: 9px 12px;
  color: #fff;
  font-size: 14px;
  font-weight: 800;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.correct-item:nth-child(odd) {
  border-right: 1px solid rgba(255,255,255,0.08);
}
.correct-check {
  width: 22px;
  height: 22px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  font-size: 12px;
  color: #37f08f;
  border: 2px solid rgba(55,240,143,0.5);
  flex-shrink: 0;
  line-height: 1;
}


/* ═══════════════════════════════════════════
   11. SCAN FRAME (shape duel country silhouette)
═══════════════════════════════════════════ */
.scan-frame {
  position: relative;
  border-radius: 24px;
  min-height: 210px;
  display: flex;
  align-items: center;
  justify-content: center;
  background:
    linear-gradient(rgba(100,90,255,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(100,90,255,0.05) 1px, transparent 1px),
    rgba(8,13,36,0.55);
  background-size: 22px 22px;
  border: 1px solid rgba(145,95,255,0.22);
  overflow: hidden;
}
.scan-frame .corner {
  position: absolute;
  width: 40px;
  height: 40px;
  border-color: #a45cff;
  filter: drop-shadow(0 0 8px rgba(164,92,255,0.85));
  pointer-events: none;
}
.scan-frame .corner.tl {
  top: 16px; left: 16px;
  border-top: 4px solid; border-left: 4px solid;
  border-radius: 10px 0 0 0;
}
.scan-frame .corner.tr {
  top: 16px; right: 16px;
  border-top: 4px solid; border-right: 4px solid;
  border-radius: 0 10px 0 0;
}
.scan-frame .corner.bl {
  bottom: 16px; left: 16px;
  border-bottom: 4px solid; border-left: 4px solid;
  border-radius: 0 0 0 10px;
}
.scan-frame .corner.br {
  bottom: 16px; right: 16px;
  border-bottom: 4px solid; border-right: 4px solid;
  border-radius: 0 0 10px 0;
}


/* ═══════════════════════════════════════════
   12. ANSWER OPTIONS  (MCQ / Flags / Shape)
═══════════════════════════════════════════ */
.answers-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 12px;
}
.answers-grid > * {
  min-width: 0;
}

.answer-option {
  position: relative;
  box-sizing: border-box;
  min-height: 88px;
  border-radius: 22px;
  padding: 14px 14px 14px 14px;
  display: flex;
  align-items: center;
  gap: 14px;
  background: rgba(15,22,55,0.86);
  border: 1px solid rgba(137,110,255,0.45);
  color: #fff;
  font-size: 15px;
  font-weight: 800;
  cursor: pointer;
  text-align: left;
  transition: border-color .15s, box-shadow .15s, background .15s;
  font-family: inherit;
  -webkit-tap-highlight-color: transparent;
  min-width: 0;
  overflow: hidden;
}
.answer-option:active {
  transform: scale(0.97);
}

.answer-letter {
  width: 50px;
  height: 50px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  font-size: 20px;
  font-weight: 900;
  flex-shrink: 0;
  background: linear-gradient(180deg, #a47cff, #7039e8);
  box-shadow: 0 0 16px rgba(130,80,255,0.6);
  transition: background .15s;
}

.answer-text {
  flex: 1;
  line-height: 1.3;
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: normal;
}

/* State: selected (pending — waiting for server) */
.answer-option.selected {
  padding-right: clamp(52px, 14vw, 66px);
  min-height: clamp(88px, 20vw, 104px);
  border-color: var(--gp-pink);
  background: linear-gradient(180deg, rgba(83,17,76,0.84), rgba(20,13,42,0.9));
  box-shadow:
    0 0 22px rgba(255,79,184,0.5),
    inset 0 0 22px rgba(255,79,184,0.1);
}
.answer-option.selected .answer-letter {
  background: linear-gradient(180deg, #ff4fb8, #b22cff);
  box-shadow: 0 0 16px rgba(255,79,184,0.6);
}

/* State: correct (green) */
.answer-option.correct {
  padding-right: clamp(52px, 14vw, 66px);
  min-height: clamp(88px, 20vw, 104px);
  border-color: var(--gp-green);
  background: linear-gradient(180deg, rgba(10,50,32,0.9), rgba(8,28,20,0.95));
  box-shadow:
    0 0 22px rgba(52,239,138,0.4),
    inset 0 0 22px rgba(52,239,138,0.08);
}
.answer-option.correct .answer-letter {
  background: linear-gradient(180deg, #32e982, #1aaa58);
  box-shadow: 0 0 16px rgba(52,239,138,0.55);
}
.answer-option.correct::after {
  content: "✓";
  position: absolute;
  right: clamp(10px, 3vw, 14px);
  top: 50%;
  transform: translateY(-50%);
  width: clamp(28px, 8vw, 38px);
  height: clamp(28px, 8vw, 38px);
  border-radius: 999px;
  display: grid;
  place-items: center;
  font-size: 20px;
  color: var(--gp-green);
  border: 2px solid rgba(52,239,138,0.6);
  box-shadow: 0 0 14px rgba(52,239,138,0.7);
}

/* State: wrong (red) */
.answer-option.wrong {
  padding-right: clamp(52px, 14vw, 66px);
  min-height: clamp(88px, 20vw, 104px);
  border-color: var(--gp-red);
  background: linear-gradient(180deg, rgba(50,10,16,0.9), rgba(28,8,12,0.95));
  box-shadow:
    0 0 22px rgba(255,79,109,0.4),
    inset 0 0 22px rgba(255,79,109,0.08);
}
.answer-option.wrong .answer-letter {
  background: linear-gradient(180deg, #ff4f6d, #b2203a);
  box-shadow: 0 0 16px rgba(255,79,109,0.55);
}
.answer-option.wrong::after {
  content: "×";
  position: absolute;
  right: clamp(10px, 3vw, 14px);
  top: 50%;
  transform: translateY(-50%);
  width: clamp(28px, 8vw, 38px);
  height: clamp(28px, 8vw, 38px);
  border-radius: 999px;
  display: grid;
  place-items: center;
  font-size: 20px;
  color: var(--gp-red);
  border: 2px solid rgba(255,79,109,0.6);
  box-shadow: 0 0 14px rgba(255,79,109,0.7);
}

@keyframes answerWrongShake {
  0%,100% { transform: translateX(0); }
  20% { transform: translateX(-5px); }
  40% { transform: translateX(5px); }
  60% { transform: translateX(-3px); }
  80% { transform: translateX(3px); }
}

.answer-option.wrong {
  animation: answerWrongShake .45s ease;
}

/* Flags keeps its answer CSS inline in the page; these important rules only
   enforce the shared result-state layout contract without touching JS. */
.ans-btn {
  position: relative !important;
  box-sizing: border-box !important;
  min-width: 0 !important;
  overflow: hidden !important;
}
.ans-text,
.ans-txt {
  min-width: 0 !important;
  overflow-wrap: anywhere !important;
  word-break: normal !important;
  line-height: 1.3;
}
.ans-btn.correct,
.ans-btn.wrong,
.ans-btn.selected:not(.correct):not(.wrong) {
  padding-right: clamp(52px, 14vw, 66px) !important;
  min-height: clamp(82px, 20vw, 104px) !important;
}
.ans-btn.correct::after,
.ans-btn.wrong::after {
  position: absolute !important;
  right: clamp(10px, 3vw, 14px) !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  margin-left: 0 !important;
  width: clamp(28px, 8vw, 38px) !important;
  height: clamp(28px, 8vw, 38px) !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 999px !important;
  pointer-events: none !important;
}
.ans-btn.wrong {
  animation: answerWrongShake .45s ease !important;
}

@media (max-width: 430px) {
  .answers-grid:has(> .answer-option.correct),
  .answers-grid:has(> .answer-option.wrong),
  .answers-grid:has(> .answer-option.selected),
  .answers-grid:has(> .ans-btn.correct),
  .answers-grid:has(> .ans-btn.wrong),
  .answers-grid:has(> .ans-btn.selected),
  .answers:has(> .ans-btn.correct),
  .answers:has(> .ans-btn.wrong),
  .answers:has(> .ans-btn.selected) {
    grid-template-columns: 1fr !important;
    gap: 6px;
  }

  .answers-grid:has(> .answer-option.correct) > *,
  .answers-grid:has(> .answer-option.wrong) > *,
  .answers-grid:has(> .answer-option.selected) > *,
  .answers-grid:has(> .ans-btn.correct) > *,
  .answers-grid:has(> .ans-btn.wrong) > *,
  .answers-grid:has(> .ans-btn.selected) > *,
  .answers:has(> .ans-btn.correct) > *,
  .answers:has(> .ans-btn.wrong) > *,
  .answers:has(> .ans-btn.selected) > * {
    grid-column: 1 / -1 !important;
  }

  .answers-grid:has(> .answer-option.correct) > .answer-option:not(.correct):not(.wrong):not(.selected),
  .answers-grid:has(> .answer-option.wrong) > .answer-option:not(.correct):not(.wrong):not(.selected),
  .answers-grid:has(> .answer-option.selected) > .answer-option:not(.correct):not(.wrong):not(.selected) {
    min-height: clamp(45px, 12vw, 50px);
    padding: 6px 10px;
    gap: 6px;
  }

  .answers-grid:has(> .ans-btn.correct) > .ans-btn:not(.correct):not(.wrong):not(.selected),
  .answers-grid:has(> .ans-btn.wrong) > .ans-btn:not(.correct):not(.wrong):not(.selected),
  .answers-grid:has(> .ans-btn.selected) > .ans-btn:not(.correct):not(.wrong):not(.selected),
  .answers:has(> .ans-btn.correct) > .ans-btn:not(.correct):not(.wrong):not(.selected),
  .answers:has(> .ans-btn.wrong) > .ans-btn:not(.correct):not(.wrong):not(.selected),
  .answers:has(> .ans-btn.selected) > .ans-btn:not(.correct):not(.wrong):not(.selected) {
    min-height: clamp(45px, 12vw, 50px) !important;
    padding: 6px 10px !important;
    gap: 6px !important;
  }

  .answer-option.wrong,
  .answer-option.selected:not(.correct):not(.wrong) {
    min-height: clamp(52px, 14vw, 60px);
    padding: 7px clamp(42px, 11vw, 50px) 7px 10px;
    gap: 7px;
  }

  .ans-btn.wrong,
  .ans-btn.selected:not(.correct):not(.wrong) {
    min-height: clamp(52px, 14vw, 60px) !important;
    padding: 7px clamp(42px, 11vw, 50px) 7px 10px !important;
    gap: 7px !important;
  }

  .answer-option.correct {
    min-height: clamp(60px, 16vw, 68px);
    padding: 9px clamp(42px, 11vw, 50px) 9px 10px;
    gap: 8px;
  }

  .ans-btn.correct {
    min-height: clamp(60px, 16vw, 68px) !important;
    padding: 9px clamp(42px, 11vw, 50px) 9px 10px !important;
    gap: 8px !important;
  }

  .answer-option.correct::after,
  .answer-option.wrong::after,
  .ans-btn.correct::after,
  .ans-btn.wrong::after {
    right: clamp(8px, 2.6vw, 10px) !important;
    width: clamp(30px, 7.6vw, 32px) !important;
    height: clamp(30px, 7.6vw, 32px) !important;
    font-size: 17px !important;
  }

  .answer-option.wrong {
    box-shadow:
      0 0 20px rgba(255,79,109,0.36),
      inset 0 0 20px rgba(255,79,109,0.07);
  }

  .answer-option.wrong .answer-letter {
    box-shadow: 0 0 15px rgba(255,79,109,0.5);
  }

  .answer-option.wrong::after,
  .ans-btn.wrong::after {
    box-shadow: 0 0 13px rgba(255,79,109,0.62) !important;
  }

  .answer-letter,
  .ans-letter {
    width: clamp(38px, 9.6vw, 42px) !important;
    height: clamp(38px, 9.6vw, 42px) !important;
    border-radius: 12px !important;
    font-size: 16px !important;
  }

  .answer-option.correct .answer-text,
  .answer-option.wrong .answer-text,
  .answer-option.selected .answer-text,
  .answers-grid:has(> .answer-option.correct) > .answer-option:not(.correct):not(.wrong):not(.selected) .answer-text,
  .answers-grid:has(> .answer-option.wrong) > .answer-option:not(.correct):not(.wrong):not(.selected) .answer-text,
  .answers-grid:has(> .answer-option.selected) > .answer-option:not(.correct):not(.wrong):not(.selected) .answer-text,
  .ans-btn.correct .ans-txt,
  .ans-btn.wrong .ans-txt,
  .ans-btn.selected .ans-txt,
  .ans-btn.correct .ans-text,
  .ans-btn.wrong .ans-text,
  .ans-btn.selected .ans-text,
  .answers-grid:has(> .ans-btn.correct) > .ans-btn:not(.correct):not(.wrong):not(.selected) .ans-text,
  .answers-grid:has(> .ans-btn.wrong) > .ans-btn:not(.correct):not(.wrong):not(.selected) .ans-text,
  .answers-grid:has(> .ans-btn.selected) > .ans-btn:not(.correct):not(.wrong):not(.selected) .ans-text,
  .answers:has(> .ans-btn.correct) > .ans-btn:not(.correct):not(.wrong):not(.selected) .ans-txt,
  .answers:has(> .ans-btn.wrong) > .ans-btn:not(.correct):not(.wrong):not(.selected) .ans-txt,
  .answers:has(> .ans-btn.selected) > .ans-btn:not(.correct):not(.wrong):not(.selected) .ans-txt {
    overflow-wrap: break-word !important;
    word-break: normal !important;
    line-height: 1.24;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }

  .gp-page:has(.answers-grid > .ans-btn.correct) .flag-card,
  .gp-page:has(.answers-grid > .ans-btn.wrong) .flag-card,
  .gp-page:has(.answers-grid > .ans-btn.selected) .flag-card {
    padding: 10px 12px 8px;
    border-radius: 22px;
  }

  .gp-page:has(.answers-grid > .ans-btn.correct) .flag-display,
  .gp-page:has(.answers-grid > .ans-btn.wrong) .flag-display,
  .gp-page:has(.answers-grid > .ans-btn.selected) .flag-display {
    max-height: 108px;
  }

  .gp-page:has(.answers-grid > .ans-btn.correct) .gp-rival-bar,
  .gp-page:has(.answers-grid > .ans-btn.wrong) .gp-rival-bar,
  .gp-page:has(.answers-grid > .ans-btn.selected) .gp-rival-bar,
  .gp-page:has(.answers > .ans-btn.correct) .gp-rival-bar,
  .gp-page:has(.answers > .ans-btn.wrong) .gp-rival-bar,
  .gp-page:has(.answers > .ans-btn.selected) .gp-rival-bar {
    min-height: 50px;
    padding: 7px 10px;
    margin-top: 6px;
  }

  .gp-page:has(.answers-grid > .ans-btn.correct) .gp-rival-bar .mcq-avatar,
  .gp-page:has(.answers-grid > .ans-btn.wrong) .gp-rival-bar .mcq-avatar,
  .gp-page:has(.answers-grid > .ans-btn.selected) .gp-rival-bar .mcq-avatar,
  .gp-page:has(.answers > .ans-btn.correct) .gp-rival-bar .mcq-avatar,
  .gp-page:has(.answers > .ans-btn.wrong) .gp-rival-bar .mcq-avatar,
  .gp-page:has(.answers > .ans-btn.selected) .gp-rival-bar .mcq-avatar {
    width: 36px !important;
    height: 36px !important;
  }

  .mcq-player-card {
    height: 84px !important;
    padding: 7px !important;
  }

  .mcq-player-inner {
    grid-template-columns: 58px minmax(0, 1fr) !important;
    gap: 7px !important;
  }

  .mcq-player-card.is-rival .mcq-player-inner {
    grid-template-columns: minmax(0, 1fr) 58px !important;
  }

  .mcq-avatar {
    width: 58px !important;
    height: 58px !important;
  }

  .mcq-avatar-ring {
    border-width: 2.5px !important;
  }

  .mcq-avatar-badge {
    width: 22px !important;
    height: 22px !important;
    right: -4px !important;
    bottom: -4px !important;
    font-size: 10px !important;
  }

  .mcq-player-score {
    font-size: 34px !important;
  }

  .mcq-vs-pill {
    width: 44px !important;
    height: 44px !important;
    border-radius: 15px !important;
    font-size: 18px !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  .answer-option.wrong,
  .answer-btn.wrong,
  .ans-btn.wrong {
    animation: none !important;
  }
}

/* Disabled (post-answer, non-selected non-correct) */
.answer-option:disabled,
.answer-option.locked {
  opacity: 0.45;
  cursor: not-allowed;
  pointer-events: none;
}


/* ═══════════════════════════════════════════
   13. MCQ QUESTION CARD
═══════════════════════════════════════════ */
.gp-category-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 5px 13px;
  border-radius: 999px;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.1);
  font-size: 13px;
  font-weight: 800;
  color: rgba(255,255,255,0.75);
  margin-bottom: 14px;
}

.gp-question-text {
  font-size: 22px;
  font-weight: 800;
  line-height: 1.35;
  color: #fff;
  margin-bottom: 4px;
}


/* ═══════════════════════════════════════════
   14. FLAG CARD (Flags Duel)
═══════════════════════════════════════════ */
.gp-flag-timer {
  /* small conic timer badge inside the flags card */
  width: 52px;
  height: 52px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  font-size: 18px;
  font-weight: 900;
  color: #fff;
  margin-bottom: 10px;
  background:
    radial-gradient(circle at center, #090d24 55%, transparent 57%),
    conic-gradient(#a855f7 0 var(--value, 70%), rgba(100,80,255,0.22) var(--value, 70%) 100%);
  box-shadow: 0 0 16px rgba(160,80,255,0.5);
}

.gp-flag-label {
  font-size: 19px;
  font-weight: 800;
  color: #fff;
  text-align: center;
  margin-bottom: 14px;
}

.gp-flag-image {
  width: 100%;
  border-radius: 16px;
  overflow: hidden;
  margin-bottom: 4px;
  box-shadow: 0 4px 24px rgba(0,0,0,0.5);
}
.gp-flag-image img {
  width: 100%;
  display: block;
  border-radius: 16px;
}


/* ═══════════════════════════════════════════
   15. GLAVNI GRADOVI — MATCH BOARD + SVG LINES
═══════════════════════════════════════════ */
.match-title {
  font-size: 20px;
  font-weight: 900;
  color: #fff;
  text-align: center;
  margin-bottom: 16px;
}

.match-col-labels {
  display: flex;
  justify-content: space-between;
  padding: 0 4px;
  margin-bottom: 8px;
}
.match-col-label {
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.match-col-label.left  { color: var(--gp-p1-color); }
.match-col-label.right { color: var(--gp-p2-color); }

.match-board {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
}
.match-lines {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  overflow: visible;
  z-index: 1;
}
.match-col {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.match-card {
  position: relative;
  z-index: 2;
  min-height: 70px;
  border-radius: 18px;
  padding: 12px 16px;
  display: flex;
  align-items: center;
  gap: 10px;
  background: rgba(15,22,55,0.9);
  border: 1.5px solid rgba(92,152,255,0.6);
  color: #fff;
  font-size: 15px;
  font-weight: 800;
  cursor: pointer;
  text-align: left;
  font-family: inherit;
  transition: border-color .15s, box-shadow .15s;
  -webkit-tap-highlight-color: transparent;
}
.match-col.right .match-card {
  border-color: rgba(255,79,184,0.65);
}
.match-card.selected {
  border-color: #fff;
  box-shadow: 0 0 18px rgba(255,255,255,0.3);
}
.match-card.matched {
  border-color: var(--gp-green);
  box-shadow: 0 0 14px rgba(52,239,138,0.35);
  opacity: 0.7;
  cursor: default;
}
.match-card.wrong-match {
  border-color: var(--gp-red);
  box-shadow: 0 0 14px rgba(255,79,109,0.35);
}
.match-flag {
  font-size: 22px;
  flex-shrink: 0;
}

.anchor {
  position: absolute;
  top: 50%;
  width: 16px;
  height: 16px;
  border-radius: 999px;
  transform: translateY(-50%);
  background: #0e1330;
  border: 3px solid currentColor;
  box-shadow: 0 0 12px currentColor;
  pointer-events: none;
}
.anchor-right {
  right: -9px;
  color: var(--gp-p1-color);
}
.anchor-left {
  left: -9px;
  color: var(--gp-p2-color);
}


/* ═══════════════════════════════════════════
   16. ZG CATEGORY INPUTS
═══════════════════════════════════════════ */
.zg-categories {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 14px;
}
.zg-categories > * {
  min-width: 0;
}

.zg-category-row {
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(15,22,55,0.82);
  border: 1px solid rgba(100,140,255,0.3);
  border-radius: 14px;
  padding: 0 12px 0 10px;
  height: 52px;
  transition: border-color .15s;
}
.zg-category-row:focus-within {
  border-color: rgba(140,100,255,0.7);
  box-shadow: 0 0 12px rgba(130,90,255,0.2);
}
.zg-cat-icon {
  font-size: 20px;
  flex-shrink: 0;
}
.zg-cat-label {
  font-size: 12px;
  font-weight: 800;
  color: rgba(200,185,255,0.7);
  flex-shrink: 0;
}
.zg-cat-input {
  flex: 1;
  background: none;
  border: none;
  outline: none;
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  font-family: inherit;
  min-width: 0;
}
.zg-cat-input::placeholder {
  color: rgba(255,255,255,0.2);
  font-weight: 500;
}


/* ═══════════════════════════════════════════
   17. SNS INPUT ROW
═══════════════════════════════════════════ */
.sns-input-row {
  display: flex;
  gap: 10px;
  margin-top: 10px;
}
.sns-input {
  flex: 1;
  height: 54px;
  border-radius: 16px;
  background: rgba(15,22,55,0.82);
  border: 1.5px solid rgba(137,110,255,0.4);
  padding: 0 16px;
  color: #fff;
  font-size: 16px;
  font-weight: 700;
  font-family: inherit;
  outline: none;
  transition: border-color .15s;
}
.sns-input:focus {
  border-color: rgba(140,100,255,0.75);
  box-shadow: 0 0 14px rgba(130,90,255,0.2);
}
.sns-input::placeholder {
  color: rgba(255,255,255,0.22);
  font-weight: 500;
}


/* ═══════════════════════════════════════════
   18. PRIMARY ACTION BUTTON (Submit / Pošalji)
═══════════════════════════════════════════ */
.gp-submit-btn {
  width: 100%;
  height: 60px;
  border-radius: 18px;
  border: none;
  background: linear-gradient(135deg, #7c3aed, #a855f7, #c026d3);
  background-size: 200%;
  color: #fff;
  font-size: 17px;
  font-weight: 900;
  font-family: inherit;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  box-shadow:
    0 0 28px rgba(168,85,247,0.45),
    0 4px 20px rgba(0,0,0,0.3);
  animation: gpBtnShimmer 3s ease-in-out infinite;
  transition: transform .15s, box-shadow .15s;
  margin-top: 12px;
}
.gp-submit-btn:active { transform: scale(0.97); }
.gp-submit-btn:hover  { box-shadow: 0 0 40px rgba(168,85,247,0.6); }
@keyframes gpBtnShimmer {
  0%,100% { background-position: 0%   }
  50%      { background-position: 100% }
}


/* ═══════════════════════════════════════════
   19. LETTER + ZG LAYOUT ROW (orb + timer-pill)
═══════════════════════════════════════════ */
.gp-orb-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 16px;
}
.gp-orb-row .letter-orb {
  margin: 0; /* override auto margin when inside flex */
}


/* ═══════════════════════════════════════════
   20. UTILITY / MISC
═══════════════════════════════════════════ */
.gp-mode-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 5px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.1);
  font-size: 13px;
  font-weight: 800;
  color: rgba(255,255,255,0.75);
  margin-bottom: 12px;
}
.gp-mode-badge img {
  width: 22px;
  height: 22px;
  object-fit: contain;
}

/* Full-width progress track (between scoreboard + content) */
.gp-match-progress {
  padding: 10px 14px 0;
}

/* Stars / nebula background passthrough */
.gp-page .stars,
.gp-page .nebula { z-index: 0; }
.gp-page > *:not(.stars):not(.nebula) { position: relative; z-index: 1; }

/* ═══════════════════════════════════════════
   21. SHARED DUEL HUD/HEADER
   Phase A/B: MCQ + Flags + Orbital + Connection + Slovons + ZG.
═══════════════════════════════════════════ */
:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)).gp-page {
  position: relative;
  z-index: 5;
  max-width: 430px;
  margin: 0 auto;
  padding: max(18px, env(safe-area-inset-top)) 18px 28px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-height: 100dvh;
  background: transparent;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .gp-topbar {
  position: relative !important;
  background: transparent !important;
  padding: 0 0 4px !important;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .gp-back-btn {
  width: 46px;
  height: 46px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.12);
  color: #fff;
  font-size: 22px;
  font-weight: 700;
  cursor: pointer;
  text-decoration: none;
  flex-shrink: 0;
  transition: background .15s;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .gp-mode-pill {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  border-radius: 999px;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.13);
  font-size: 15px;
  font-weight: 800;
  color: #fff;
  white-space: nowrap;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .gp-mode-pill img {
  width: 20px;
  height: 20px;
  object-fit: contain;
  border-radius: 4px;
  flex-shrink: 0;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .gp-round {
  padding: 0;
  text-align: center;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .gp-round-label {
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #fff;
  text-align: center;
  padding: 0;
  margin: 0;
  line-height: 1.2;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .gp-round-value {
  display: none;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-battle-header {
  width: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 52px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-player-card {
  height: 92px;
  min-width: 0;
  padding: 9px;
  border-radius: 24px;
  overflow: visible;
  background:
    linear-gradient(180deg, rgba(22,36,82,0.9), rgba(13,20,52,0.94)) padding-box,
    linear-gradient(135deg, #68b7ff 0%, #7d54ff 100%) border-box;
  border: 1.5px solid transparent;
  box-shadow: 0 0 28px rgba(100,183,255,0.15), 0 4px 24px rgba(0,0,0,.3);
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-player-card.is-rival {
  background:
    linear-gradient(180deg, rgba(54,22,67,0.9), rgba(22,13,42,0.94)) padding-box,
    linear-gradient(135deg, #ff4fb8 0%, #8a5cff 100%) border-box;
  border: 1.5px solid transparent;
  box-shadow: 0 0 28px rgba(255,79,184,0.15), 0 4px 24px rgba(0,0,0,.3);
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-player-inner {
  height: 100%;
  display: grid;
  grid-template-columns: 68px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  min-width: 0;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-player-card.is-rival .mcq-player-inner {
  grid-template-columns: minmax(0, 1fr) 68px;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-avatar {
  width: 68px;
  height: 68px;
  position: relative;
  overflow: visible;
  flex-shrink: 0;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-avatar-ring {
  position: absolute;
  inset: 0;
  border-radius: 999px;
  overflow: hidden;
  border: 3px solid var(--avatar-ring, rgba(104,183,255,0.7));
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-avatar-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transform: scale(1.23) translateY(1px);
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-player-card:not(.is-rival) .mcq-avatar-img {
  transform: scale(1.50) translateY(2px);
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-avatar-badge {
  position: absolute;
  right: -5px;
  bottom: -5px;
  width: 26px;
  height: 26px;
  border-radius: 999px;
  z-index: 5;
  display: grid;
  place-items: center;
  font-size: 12px;
  font-weight: 900;
  color: #fff;
  background: linear-gradient(180deg, #9b5cff, #651cff);
  border: 2.5px solid #070b20;
  box-shadow: 0 0 10px rgba(145,80,255,0.7);
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-player-info {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 3px;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-player-card.is-rival .mcq-player-info {
  align-items: flex-end;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-player-name {
  font-size: 14px;
  font-weight: 900;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: rgba(255,255,255,0.88);
  min-width: 0;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-player-score {
  font-size: 42px;
  line-height: 0.95;
  font-weight: 950;
  letter-spacing: -0.02em;
  color: #68b7ff;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-player-card.is-rival .mcq-player-score {
  color: #ff4fb8;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-vs-pill {
  width: 52px;
  height: 52px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  justify-self: center;
  font-size: 22px;
  font-weight: 900;
  color: #d9c2ff;
  background: linear-gradient(180deg, rgba(76,38,130,0.85), rgba(27,18,64,0.95));
  border: 1px solid rgba(177,112,255,0.55);
  box-shadow: 0 0 20px rgba(150,70,255,0.45), inset 0 0 14px rgba(255,255,255,0.07);
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .gp-match-progress {
  padding: 2px 0;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .progress-track,
:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-player-card .progress-track {
  width: 100%;
  height: 5px;
  border-radius: 999px;
  background: rgba(255,255,255,0.08);
  border: none;
  overflow: hidden;
  margin-top: 1px;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-player-card .progress-track::before {
  content: "";
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border-radius: inherit;
  box-shadow: none;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-player-card:not(.is-rival) .progress-track::before {
  background: linear-gradient(90deg, #5fa8ff, #7d54ff);
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-player-card.is-rival .progress-track::before {
  background: linear-gradient(90deg, #ff4fb8, #8a5cff);
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-player-card .progress-track::after {
  display: none;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .gp-match-progress .progress-track,
:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .gp-match-progress .track-bar {
  height: 8px;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .gp-match-progress .progress-track::after {
  width: 13px;
  height: 13px;
  box-shadow: 0 0 12px rgba(180,90,255,1), 0 0 24px rgba(120,90,255,0.65);
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .gp-rival-bar {
  border-radius: 18px;
  padding: 10px 14px;
  display: flex;
  align-items: center;
  gap: 12px;
  background: rgba(10,14,36,0.85);
  border: 1px solid rgba(255,255,255,0.07);
  box-shadow: 0 2px 12px rgba(0,0,0,.25);
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .gp-rival-bar .avatar-wrap,
:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .gp-rival-bar .mcq-avatar {
  width: 40px !important;
  height: 40px !important;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .gp-rival-text {
  flex: 1;
  font-size: 14px;
  font-weight: 800;
  color: #ff4fb8;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .gp-rival-dots {
  display: flex;
  gap: 5px;
  align-items: center;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .gp-rival-dots span {
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: rgba(255,79,184,0.6);
  animation: gpDotPulse 1.4s ease-in-out infinite;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .gp-rival-check {
  display: none;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  flex-shrink: 0;
  place-items: center;
  font-size: 16px;
  font-weight: 900;
  color: #34ef8a;
  background: rgba(52,239,138,0.12);
  border: 1.5px solid rgba(52,239,138,0.4);
  box-shadow: 0 0 12px rgba(52,239,138,0.35);
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .gp-rival-bar.rival-answered .gp-rival-dots {
  display: none;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .gp-rival-bar.rival-answered .gp-rival-check {
  display: grid;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .gp-rival-bar.rival-answered .gp-rival-text {
  color: #34ef8a;
}

:is(.gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .gp-topbar .timer-ring-wrap {
  width: 48px;
  height: 48px;
  flex-shrink: 0;
}

:is(.gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .gp-topbar .timer-ring-wrap svg {
  width: 100%;
  height: 100%;
}

:is(.gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .gp-topbar .timer-num {
  font-size: 15px;
}

:is(.gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .timer-ring-wrap {
  width: 72px;
  height: 72px;
  display: grid;
  place-items: center;
  position: relative;
  align-self: center;
  flex-shrink: 0;
}

:is(.gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .timer-ring-wrap svg {
  position: absolute;
  inset: 0;
  transform: rotate(-90deg);
}

:is(.gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .timer-bg {
  fill: none;
  stroke: rgba(255,255,255,0.08);
  stroke-width: 5;
}

:is(.gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .timer-arc {
  fill: none;
  stroke: url(#obTimerGrad);
  stroke-width: 5;
  stroke-linecap: round;
  stroke-dasharray: 194.78;
  stroke-dashoffset: 194.78;
  transition: stroke-dashoffset 0.18s linear, stroke .2s;
}

.gp-page:has(.flag-card) .timer-arc {
  stroke: url(#timerGrad);
}

.gp-page:has(.sc-match-board) .timer-arc {
  stroke: url(#scTimerGrad);
  stroke-dashoffset: 0;
  transition: stroke-dashoffset .15s linear, stroke .2s;
}

.gp-page:has(.sv-question-card) .timer-arc {
  stroke: url(#svTimerGrad);
  stroke-dashoffset: 0;
  transition: stroke-dashoffset .15s linear, stroke .2s;
}

.gp-page:has(.zg-timer-chip) .timer-arc {
  stroke: url(#zgTimerGrad);
  stroke-dashoffset: 0;
  transition: stroke-dashoffset .15s linear, stroke .2s;
}

:is(.gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .timer-ring-wrap .timer-num {
  font-size: 20px;
  font-weight: 900;
  color: #fff;
  position: relative;
  z-index: 2;
  line-height: 1;
  min-width: unset;
  background: none;
  border: none;
  padding: 0;
  border-radius: 0;
  text-align: center;
}

:is(.gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .timer-ring-wrap.warn .timer-arc {
  stroke: #f59e0b;
}

:is(.gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .timer-ring-wrap.danger .timer-arc {
  stroke: #ff4f6d;
}

:is(.gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .timer-ring-wrap.danger .timer-num {
  color: #ff4f6d;
}

.gp-page:has(.q-cat-pill) .timer-ring {
  --value: 100%;
  width: 66px;
  height: 66px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
}

@media (max-width: 380px) {
  :is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-player-card {
    height: 84px;
    padding: 7px;
  }

  :is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-player-inner {
    grid-template-columns: 58px minmax(0, 1fr);
    gap: 7px;
  }

  :is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-player-card.is-rival .mcq-player-inner {
    grid-template-columns: minmax(0, 1fr) 58px;
  }

  :is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-avatar {
    width: 58px;
    height: 58px;
  }

  :is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-avatar-ring {
    border-width: 2.5px;
  }

  :is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-avatar-badge {
    width: 22px;
    height: 22px;
    right: -4px;
    bottom: -4px;
    font-size: 10px;
  }

  :is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-player-score {
    font-size: 34px;
  }

  :is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-vs-pill {
    width: 44px;
    height: 44px;
    border-radius: 15px;
    font-size: 18px;
  }
}

/* Mirrored player cards: keep the right-side avatar badge inside the card. */
:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-player-card:not(.is-rival) .mcq-avatar {
  justify-self: start;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-player-card.is-rival .mcq-avatar {
  justify-self: end;
}

:is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-player-card.is-rival .mcq-avatar-badge {
  left: -5px !important;
  right: auto !important;
}

@media (max-width: 380px) {
  :is(.gp-page:has(.q-cat-pill), .gp-page:has(.flag-card), body.orbital-server .gp-page, .gp-page:has(.sc-match-board), .gp-page:has(.sv-question-card), .gp-page:has(.zg-timer-chip)) .mcq-player-card.is-rival .mcq-avatar-badge {
    left: -4px !important;
    right: auto !important;
  }
}
