/* === Orbitalni oblik duel aesthetic — zg variant === */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#0a0e27; --bg2:#111936; --card:rgba(30,41,79,.7); --card-2:rgba(22,32,66,.85);
  --stroke:rgba(167,139,250,.25); --stroke-strong:rgba(167,139,250,.45);
  --purple:#7c3aed; --violet:#a78bfa; --violet-2:#c4b5fd; --blue:#60a5fa; --blue-2:#38bdf8;
  --pink:#ec4899; --green:#22c55e; --red:#ef4444; --gold:#fbbf24; --amber:#f59e0b;
  --text:#f8fafc; --muted:#94a3b8; --dim:#64748b;
  --grad-hero:linear-gradient(135deg,#7c3aed 0%,#a78bfa 55%,#60a5fa 100%);
  --grad-you:linear-gradient(135deg,#60a5fa 0%,#3b82f6 100%);
  --grad-opp:linear-gradient(135deg,#a78bfa 0%,#7c3aed 100%);
  --grad-gold:linear-gradient(135deg,#fbbf24 0%,#f59e0b 55%,#fbbf24 100%);
  --shadow-1:0 10px 40px -12px rgba(124,58,237,.35);
  --shadow-2:0 14px 50px -10px rgba(96,165,250,.4);
  --shadow-gold:0 0 28px rgba(251,191,36,.55);
}
html,body{height:100%}
body{
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
  background:radial-gradient(ellipse at 50% 0%,#1a1f3d 0%,#0a0e27 55%,#050816 100%);
  color:var(--text); min-height:100vh; overflow-x:hidden; position:relative;
  -webkit-tap-highlight-color:transparent;
}
.stars{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.stars .star,.star{position:absolute;background:#fff;border-radius:50%;opacity:.85;
  animation:tw var(--d,3s) ease-in-out infinite}
@keyframes tw{0%,100%{opacity:.2;transform:scale(.7)}50%{opacity:1;transform:scale(1.1)}}
.neb{position:fixed;border-radius:50%;filter:blur(70px);opacity:.42;pointer-events:none;z-index:0;animation:nbDrift 18s ease-in-out infinite}
.neb1{width:340px;height:340px;background:radial-gradient(circle,rgba(124,58,237,.6),transparent 68%);top:-80px;left:-80px}
.neb2{width:280px;height:280px;background:radial-gradient(circle,rgba(96,165,250,.55),transparent 68%);top:38%;right:-80px;animation-delay:-6s}
.neb3{width:300px;height:300px;background:radial-gradient(circle,rgba(236,72,153,.45),transparent 68%);bottom:-60px;left:30%;animation-delay:-12s}
@keyframes nbDrift{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(22px,-18px) scale(1.08)}}
#cvs{position:fixed;inset:0;pointer-events:none;z-index:1}
.flash{position:fixed;inset:0;pointer-events:none;z-index:2;opacity:0;transition:opacity .18s;mix-blend-mode:screen}
.flash.green{background:radial-gradient(circle at 50% 40%,rgba(34,197,94,.4),transparent 60%);opacity:1;animation:sflashAnim .55s ease-out}
.flash.red{background:radial-gradient(circle at 50% 40%,rgba(239,68,68,.42),transparent 60%);opacity:1;animation:sflashAnim .55s ease-out}
.flash.gold{background:radial-gradient(circle at 50% 40%,rgba(251,191,36,.45),transparent 60%);opacity:1;animation:sflashAnim .65s ease-out}
@keyframes sflashAnim{0%{opacity:1}100%{opacity:0}}
.toast{position:fixed;top:64px;left:50%;transform:translateX(-50%) translateY(-12px);padding:10px 18px;border-radius:999px;background:var(--card);backdrop-filter:blur(12px);border:1px solid var(--stroke-strong);color:var(--text);font-weight:800;font-size:.82rem;letter-spacing:.02em;z-index:50;opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;box-shadow:var(--shadow-1)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.good{border-color:rgba(34,197,94,.5);color:#86efac;background:rgba(34,197,94,.15)}
.toast.bad{border-color:rgba(239,68,68,.5);color:#fca5a5;background:rgba(239,68,68,.15)}

.app{position:relative;z-index:5;max-width:480px;margin:0 auto;padding:14px 12px 24px;display:flex;flex-direction:column;gap:12px}
.zg-banner{font-size:.62rem;color:var(--dim);line-height:1.45;background:rgba(15,23,42,.5);border:1px solid var(--stroke);padding:8px 10px;border-radius:10px}
.zg-banner code{font-size:.6rem;background:rgba(124,58,237,.14);padding:1px 5px;border-radius:4px;color:var(--violet-2)}

/* duel header */
.duel-header{display:grid;grid-template-columns:1fr 68px 1fr;gap:8px;align-items:stretch;padding:10px 8px;border-radius:18px;background:var(--card);backdrop-filter:blur(14px);border:1px solid var(--stroke);box-shadow:var(--shadow-1)}
.player-card{display:flex;flex-direction:column;align-items:center;gap:5px;padding:10px 8px;border-radius:14px;position:relative;overflow:hidden;border:1px solid transparent}
.player-card::before{content:"";position:absolute;inset:0;opacity:.16;z-index:0;pointer-events:none}
.player-card.you::before{background:var(--grad-you)}
.player-card.opp::before{background:var(--grad-opp)}
.player-card.you{border-color:rgba(96,165,250,.4)}
.player-card.opp{border-color:rgba(167,139,250,.4)}
.player-card>*{position:relative;z-index:1}
.pc-avatar{font-size:1.4rem;line-height:1;filter:drop-shadow(0 0 6px rgba(167,139,250,.35))}
.pc-name{font-size:.7rem;font-weight:800;color:var(--text);max-width:118px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pc-score{font-size:1.35rem;font-weight:900;line-height:1;background:var(--grad-hero);-webkit-background-clip:text;background-clip:text;color:transparent}
.hp-bar{width:100%;height:5px;border-radius:999px;background:rgba(148,163,184,.18);overflow:hidden;border:1px solid rgba(167,139,250,.2)}
.hp-fill{height:100%;width:100%;background:linear-gradient(90deg,#22c55e,#4ade80);border-radius:999px;transition:width .5s ease}
.hp-fill.opp{background:linear-gradient(90deg,#f43f5e,#ec4899)}
.vs-center{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;position:relative}
.vs-center::before{content:"";position:absolute;inset:10% 50%;width:1px;background:linear-gradient(180deg,transparent,rgba(167,139,250,.4),transparent)}
.vs-badge{font-weight:900;font-size:.78rem;color:var(--violet-2);background:rgba(167,139,250,.15);border:1px solid rgba(167,139,250,.4);border-radius:999px;padding:4px 10px;letter-spacing:.06em;box-shadow:0 0 10px rgba(167,139,250,.35)}
.round-badge{font-size:.6rem;font-weight:800;color:var(--gold);background:rgba(251,191,36,.15);border:1px solid rgba(251,191,36,.35);padding:3px 9px;border-radius:999px;letter-spacing:.04em;text-transform:uppercase}

/* letter section */
.letter-section{padding:14px 10px 12px;border-radius:20px;background:var(--card);backdrop-filter:blur(14px);border:1px solid var(--stroke);box-shadow:var(--shadow-2);display:flex;flex-direction:column;align-items:center;gap:10px;position:relative;overflow:hidden}
.letter-section::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,rgba(124,58,237,.18),transparent 60%);pointer-events:none}
.letter-section>*{position:relative;z-index:1}
.letter-wrap{position:relative;width:132px;height:132px;display:flex;align-items:center;justify-content:center}
.letter-ring,.letter-ring2{position:absolute;inset:0;border-radius:50%;pointer-events:none}
.letter-ring{border:2px solid transparent;border-top-color:var(--violet);border-right-color:rgba(124,58,237,.6);animation:ringRot 5s linear infinite}
.letter-ring2{inset:9px;border:2px dashed rgba(96,165,250,.35);animation:ringRot 8s linear infinite reverse}
@keyframes ringRot{to{transform:rotate(360deg)}}
.letter-core{font-size:4.6rem;font-weight:900;background:var(--grad-hero);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1;letter-spacing:.01em;filter:drop-shadow(0 0 18px rgba(167,139,250,.45));font-family:'Georgia',serif}
.letter-label{font-size:.72rem;font-weight:700;color:var(--muted);letter-spacing:.04em;text-align:center}

.timer-num{font-size:1.15rem;font-weight:900;min-width:54px;text-align:center;line-height:1;padding:6px 6px;border-radius:10px;background:rgba(15,23,42,.6);border:1px solid var(--stroke)}
.timer-num.ok{color:var(--violet-2)}
.timer-num.warn{color:var(--amber)}
.timer-num.danger{color:var(--red);animation:pulseRed 1s ease-in-out infinite}
@keyframes pulseRed{0%,100%{transform:scale(1)}50%{transform:scale(1.07)}}
.typing-dots{display:inline-flex;gap:3px;margin-left:4px}
.typing-dots span{width:5px;height:5px;border-radius:50%;background:var(--violet);animation:dotBounce 1.2s ease-in-out infinite}
.typing-dots span:nth-child(2){animation-delay:.15s}
.typing-dots span:nth-child(3){animation-delay:.3s}
@keyframes dotBounce{0%,100%{transform:translateY(0);opacity:.45}50%{transform:translateY(-4px);opacity:1}}

/* categories */
.cats-card{padding:14px 12px 14px;border-radius:20px;background:var(--card);backdrop-filter:blur(14px);border:1px solid var(--stroke);box-shadow:var(--shadow-1);display:flex;flex-direction:column;gap:8px}
.cat-section-title{font-size:.7rem;font-weight:800;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:2px}
.cat-row{position:relative;display:grid;grid-template-columns:32px 78px minmax(0,1fr) 40px;gap:8px;align-items:center;padding:7px 8px;border-radius:12px;background:rgba(15,23,42,.55);border:1px solid var(--stroke);transition:border-color .18s,background .18s,box-shadow .18s;box-sizing:border-box;min-width:0;overflow:hidden}
.cat-row.filled{border-color:rgba(34,197,94,.45);background:rgba(34,197,94,.1)}
.cat-row.active{border-color:rgba(167,139,250,.5);box-shadow:0 0 0 3px rgba(167,139,250,.12)}
/* Unified correct/wrong row styling — mirrors MCQ `.answer-btn.correct/.wrong`
   (gradient bg + #34ef8a / #ff4f6d border + matching glow). */
.cat-row.valid{
  min-height: clamp(58px, 16vw, 74px);
  border-color:#34ef8a;
  background:linear-gradient(160deg,rgba(8,44,26,0.95),rgba(5,24,15,0.98));
  box-shadow:0 0 26px rgba(52,239,138,.38),inset 0 0 24px rgba(52,239,138,.07);
}
.cat-row.invalid{
  min-height: clamp(58px, 16vw, 74px);
  border-color:#ff4f6d;
  background:linear-gradient(160deg,rgba(44,8,16,0.95),rgba(24,5,10,0.98));
  box-shadow:0 0 26px rgba(255,79,109,.38),inset 0 0 24px rgba(255,79,109,.07);
}
.cat-emoji{font-size:1.1rem;text-align:center;line-height:1}
.cat-name{font-size:.72rem;font-weight:800;color:var(--violet-2);letter-spacing:.02em;min-width:0;overflow-wrap:anywhere;word-break:normal}
.cat-input{background:rgba(10,14,39,.75);border:1px solid rgba(167,139,250,.22);border-radius:10px;padding:8px 10px;font-family:inherit;font-size:.8rem;font-weight:700;color:var(--text);outline:none;transition:border-color .18s,box-shadow .18s;width:100%;letter-spacing:.01em}
.cat-input:focus{border-color:var(--violet);box-shadow:0 0 0 3px rgba(167,139,250,.18)}
.cat-input::placeholder{color:var(--dim);font-weight:500}
.cat-check{font-size:.95rem;text-align:center;line-height:1;opacity:0;transition:opacity .2s,transform .2s;color:var(--muted);font-weight:900}
.cat-row.filled .cat-check{opacity:.75;transform:scale(1)}
/* Unified correct/wrong marker badge — copied 1:1 from Orbital `.ans-btn.correct::after`
   / `.wrong::after` (also matches MCQ `.answer-btn.correct::after` at 36x36/18px).
   Positioned absolutely so the badge center sits cleanly on the right edge of the
   category card, vertically centered with the row regardless of input height. */
.cat-row.valid .cat-check,
.cat-row.invalid .cat-check{
  opacity:1;
  position:static;
  transform:none;
  margin:0;
  display:grid;
  place-items:center;
  width:clamp(28px,8vw,36px);height:clamp(28px,8vw,36px);
  border-radius:999px;
  font-size:17px;
  font-weight:900;
  line-height:1;
  text-shadow:none;
  flex-shrink:0;
  pointer-events:none;
  z-index:2;
  justify-self:center;
  align-self:center;
}
.cat-row.valid .cat-check{
  color:#34ef8a;
  border:2px solid rgba(52,239,138,.55);
  box-shadow:0 0 14px rgba(52,239,138,.65);
}
.cat-row.invalid .cat-check{
  color:#ff4f6d;
  border:2px solid rgba(255,79,109,.55);
  box-shadow:0 0 14px rgba(255,79,109,.65);
}
.cat-row.pending .cat-check{opacity:.75;color:var(--violet-2)}

.submit-btn{padding:14px 16px;border:1px solid transparent;border-radius:16px;font-family:inherit;font-size:.95rem;font-weight:900;letter-spacing:.02em;color:#fff;background:var(--grad-hero);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 10px 28px -6px rgba(124,58,237,.55);transition:transform .15s,filter .15s,opacity .15s,background .25s,border-color .25s,box-shadow .25s}
.submit-btn:active:not(:disabled){transform:scale(.97)}
.submit-btn:disabled{opacity:.45;cursor:not-allowed;filter:grayscale(.3)}
.submit-btn.duel-submit-ack-fade{opacity:0;filter:none;transition:opacity .45s ease,filter .45s ease}
.submit-btn.duel-submit-ack-fade.duel-submit-ack-in{opacity:1}
.submit-btn.duel-submit-ack-fade.duel-submit-ack-in:disabled{opacity:1;filter:none}
/* Submitted (success) state — bright green gradient + unified MCQ/Orbital correct marker.
   Override base .submit-btn purple gradient + box-shadow at higher specificity. */
.submit-btn.submitted,
.submit-btn.submitted:disabled{
  background:linear-gradient(160deg,#22c55e 0%,#16a34a 60%,#15803d 100%) !important;
  border-color:#34ef8a !important;
  color:#fff !important;
  filter:none !important;
  opacity:1 !important;
  cursor:default !important;
  box-shadow:0 12px 32px -6px rgba(34,197,94,.55),0 0 28px rgba(52,239,138,.5),inset 0 0 24px rgba(52,239,138,.18) !important;
  text-shadow:0 1px 0 rgba(0,0,0,.18);
}
.submit-btn .submit-check{
  display:inline-grid;
  place-items:center;
  width:30px;height:30px;
  border-radius:999px;
  font-size:16px;
  font-weight:900;
  color:#0a3b1f;
  background:#fff;
  border:2px solid rgba(255,255,255,.85);
  box-shadow:0 0 12px rgba(255,255,255,.55);
  margin-left:4px;
}

/* overlays */
.overlay,.final-overlay{position:fixed;inset:0;background:rgba(5,8,22,.92);backdrop-filter:blur(16px);z-index:70;display:none;flex-direction:column;align-items:center;justify-content:center;padding:16px 14px 22px;animation:fadeIn .28s}
.overlay.show,.final-overlay.show{display:flex}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes roEmojiPop{from{transform:scale(.3) rotate(-20deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}
/* inter-round: fokus na poene ove runde + odgovori po kategorijama */
.ro-inter{width:100%;max-width:400px;margin:0 auto;display:flex;flex-direction:column;align-items:stretch;gap:12px;text-align:left}
.ro-kick{font-size:.65rem;font-weight:800;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;text-align:center}
.ro-hero{display:grid;grid-template-columns:1fr 26px 1fr;gap:8px;align-items:center;padding:16px 12px;border-radius:20px;background:var(--card);border:1px solid var(--stroke-strong);box-shadow:var(--shadow-1)}
.ro-hero-vs{font-size:1.35rem;font-weight:900;color:var(--violet-2);text-align:center;line-height:1}
.ro-hero-col{display:flex;flex-direction:column;align-items:center;gap:5px;text-align:center}
.ro-hero-pts{font-size:2.4rem;font-weight:900;line-height:1;letter-spacing:-.03em}
.ro-hero-pts.you{color:var(--blue)}
.ro-hero-pts.opp{color:var(--pink)}
.ro-hero-name{font-size:.74rem;font-weight:800;color:var(--text);max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ro-hero-cum{font-size:.6rem;font-weight:700;color:var(--dim)}
/* Inter-round breakdown — compact single-row blocks so all 6 categories
   fit on mobile without an inner scrollbar. */
.ro-bd{width:100%;display:flex;flex-direction:column;gap:6px;padding:2px 0;max-height:none;overflow:visible}
.ro-bd-block{display:grid;grid-template-columns:26px minmax(58px,72px) 1fr 1fr;align-items:center;gap:8px;padding:7px 9px;border-radius:12px;background:rgba(15,23,42,.5);border:1px solid var(--stroke)}
.ro-bd-ico{width:24px;height:24px;display:grid;place-items:center;color:var(--violet-2);flex-shrink:0}
.ro-bd-ico svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.ro-bd-cat{font-size:.7rem;font-weight:800;color:var(--violet-2);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:.02em}
.ro-bd-pair{display:flex;align-items:center;gap:5px;font-size:.7rem;font-weight:700;min-width:0;border-radius:8px;padding:3px 6px;background:rgba(10,14,39,.6);border:1px solid var(--stroke)}
.ro-bd-pair.ok{border-color:rgba(52,239,138,.45);background:rgba(8,44,26,.55)}
.ro-bd-pair.bad{border-color:rgba(255,79,109,.45);background:rgba(44,8,16,.55)}
.ro-bd-pair-lbl{font-size:.54rem;font-weight:800;color:var(--dim);letter-spacing:.06em;text-transform:uppercase;flex-shrink:0}
.ro-bd-pair-word{flex:1;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.ro-bd-pair.ok .ro-bd-pair-word{color:#bdf7d4}
.ro-bd-pair.bad .ro-bd-pair-word{color:#fecaca}
.ro-bd-pair-pt{font-size:.66rem;font-weight:900;color:var(--gold);white-space:nowrap;flex-shrink:0}
@media (max-width:380px){
  .ro-bd-block{grid-template-columns:22px 54px 1fr 1fr;gap:6px;padding:6px 7px}
  .ro-bd-ico{width:22px;height:22px}
  .ro-bd-ico svg{width:18px;height:18px}
  .ro-bd-cat{font-size:.66rem}
  .ro-bd-pair{padding:3px 5px;font-size:.66rem;gap:4px}
}
.ro-meta{text-align:center;font-size:.62rem;font-weight:700;color:var(--dim);line-height:1.45;padding:0 4px}

.final-trophy{font-size:3.8rem;line-height:1;filter:drop-shadow(0 0 22px rgba(251,191,36,.65));animation:roEmojiPop .55s cubic-bezier(.2,1.6,.4,1)}
.final-title{font-size:1.55rem;font-weight:900;background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:.01em}
.final-score-box{display:grid;grid-template-columns:1fr 34px 1fr;gap:10px;align-items:center;margin-top:6px;padding:14px 14px;border-radius:18px;background:var(--card);backdrop-filter:blur(12px);border:1px solid var(--stroke-strong);width:100%;max-width:320px;box-shadow:var(--shadow-1)}
.fs{display:flex;flex-direction:column;align-items:center;gap:3px}
.fs-num{font-size:2rem;font-weight:900;line-height:1}
.fs-num.win-num{color:var(--blue)}
.fs-num.lose-num{color:var(--pink)}
.fs-lbl{font-size:.62rem;color:var(--muted);font-weight:700;letter-spacing:.04em;max-width:110px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.final-letters{font-size:.72rem;color:var(--muted);font-weight:700;letter-spacing:.04em;margin-top:4px}
.xp-chip{font-size:.78rem;font-weight:900;padding:6px 14px;border-radius:999px;background:rgba(251,191,36,.14);color:var(--gold);border:1px solid rgba(251,191,36,.4);letter-spacing:.04em;box-shadow:var(--shadow-gold)}
.final-btns{display:flex;gap:10px;margin-top:14px;width:100%;max-width:320px}
.btn-home,.btn-rematch{flex:1;padding:12px 14px;border-radius:14px;font-family:inherit;font-weight:800;font-size:.85rem;letter-spacing:.02em;cursor:pointer;border:none;color:#fff;text-align:center;text-decoration:none;transition:transform .15s,filter .15s}
.btn-home{background:rgba(167,139,250,.14);color:var(--violet);border:1px solid rgba(167,139,250,.35)}
.btn-rematch{background:var(--grad-hero);box-shadow:0 10px 28px -6px rgba(124,58,237,.55)}
.btn-home:active,.btn-rematch:active{transform:scale(.97)}

@media (max-width:430px){
  .cat-row.invalid{box-shadow:0 0 23px rgba(255,79,109,.34),inset 0 0 22px rgba(255,79,109,.063)}
  .cat-row.invalid .cat-check{box-shadow:0 0 13px rgba(255,79,109,.59)}
}

@media (max-width:380px){
  .duel-header{grid-template-columns:1fr 56px 1fr}
  .letter-wrap{width:118px;height:118px}
  .letter-core{font-size:3.9rem}
  .cat-row{grid-template-columns:28px 64px minmax(0,1fr) 36px;gap:6px}
  .cat-row.valid .cat-check,
  .cat-row.invalid .cat-check{width:30px;height:30px;font-size:15px;transform:none}
  .cat-input{font-size:.74rem;padding:7px 9px}
}
.zg-nav-row{display:flex;justify-content:flex-start;margin:0 0 10px}
.zg-back-btn{
  font-size:.78rem;font-weight:800;color:var(--muted);text-decoration:none;
  padding:7px 14px;border:1px solid var(--stroke);border-radius:999px;
  transition:background .2s,color .2s;
}
.zg-back-btn:hover{color:var(--text);background:rgba(167,139,250,.1)}

/* ═══════════════════════════════════════════
   PREMIUM SKIN — Zanimljiva Geografija
════════════════════════════════════════════ */
.app { display: none !important; }
/* ── match progress ── */
.gp-track-bar {
  height: 6px; border-radius: 999px;
  background: rgba(255,255,255,.08); overflow: hidden;
}
.gp-track-fill {
  height: 100%; width: 100%;
  background: linear-gradient(90deg,#7c3aed,#a78bfa,#06b6d4);
  border-radius: 999px; transition: width .5s ease;
}

/* ── question card ── */
.zg-question-card {
  border-radius: 22px;
  background: rgba(255,255,255,.04);
  border: 1.5px solid rgba(255,255,255,.1);
  padding: 14px 12px 16px;
  display: flex; flex-direction: column; gap: 12px;
  position: relative; overflow: hidden;
}
.zg-question-card::before {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(circle at 50% 0%, rgba(124,58,237,.14), transparent 55%);
  pointer-events: none;
}
.zg-question-card > * { position: relative; z-index: 1; }

.zg-card-pill {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(124,58,237,.18); border: 1px solid rgba(167,139,250,.35);
  border-radius: 999px; padding: 5px 12px;
  font-size: .7rem; font-weight: 800; color: #c4b5fd;
  align-self: flex-start;
}
.zg-card-pill img { width: 18px; height: 18px; object-fit: contain; border-radius: 5px; }
.gp-topbar .timer-ring .timer-num{
  min-width:auto;
  padding:0;
  border:0;
  border-radius:0;
  background:none;
  color:#fff;
  font-size:15px;
}

/* ── letter area ── */
.zg-letter-area {
  display: flex; align-items: center; gap: 14px; justify-content: center;
}
.zg-timer-chip {
  display: flex; flex-direction: column; gap: 5px;
  padding: 10px 14px; border-radius: 14px;
  background: rgba(15,23,42,.6);
  border: 1px solid rgba(167,139,250,.25);
  --zg-icon-color: #3a95ff;
}
.zg-timer-val {
  display: flex; align-items: center; gap: 6px;
  font-size: 1.1rem; font-weight: 900; color: #a78bfa; line-height: 1;
}
.zg-timer-icon {
  width: 18px; height: 18px; color: var(--zg-icon-color); flex: 0 0 auto;
}
.zg-timer-icon svg {
  width: 100%; height: 100%; stroke: currentColor; fill: none;
  stroke-width: 2.35; stroke-linecap: round; stroke-linejoin: round;
}
.zg-timer-sub {
  font-size: .72rem; color: rgba(148,163,184,.8); font-weight: 600;
}
.zg-timer-sub strong { color: #c4b5fd; }

.zg-letter-orb {
  width: clamp(88px, 14.25vw, 132px);
  height: clamp(88px, 14.25vw, 132px);
  border-radius: 999px;
  position: relative;
  display: grid;
  place-items: center;
  margin-inline: auto;
  background:
    radial-gradient(circle at 50% 42%, rgba(100, 145, 255, 0.22), rgba(5, 9, 31, 0.98) 64%),
    rgba(8, 12, 36, 0.92);
  border: 2px solid rgba(76, 147, 255, 0.95);
  box-shadow:
    0 0 16px rgba(61, 132, 255, 0.85),
    0 0 40px rgba(94, 84, 255, 0.42),
    inset 0 0 24px rgba(94, 84, 255, 0.32);
}
.zg-letter-orb::before {
  content: "";
  position: absolute;
  inset: -8px;
  border-radius: inherit;
  background: radial-gradient(circle, rgba(84, 139, 255, 0.22), transparent 68%);
  filter: blur(8px);
  z-index: -1;
}
.zg-letter-orb::after {
  content: "";
  position: absolute;
  inset: 8px;
  border-radius: inherit;
  border: 1px solid rgba(255,255,255,0.08);
  pointer-events: none;
}
.zg-letter-orb span {
  font-size: clamp(46px, 7.5vw, 78px);
  line-height: 1;
  font-weight: 950;
  color: white;
  text-shadow:
    0 0 12px rgba(255,255,255,0.45),
    0 0 28px rgba(120, 90, 255, 0.55);
}

/* ── category grid — 2 columns ── */
.zg-cats-grid {
  display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 6px;
}
.zg-cats-grid > * {
  min-width: 0;
}
/* override cat-row to 2-line layout: icon+name on top, input full-width below */
.zg-cats-grid .cat-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) clamp(30px, 8vw, 38px);
  grid-template-rows: auto auto;
  gap: 8px 8px;
  padding: 8px 8px 10px;
}
.zg-cats-grid .zg-icon-badge { grid-row: 1; grid-column: 1; align-self: center; }
.zg-cats-grid .cat-name  { grid-row: 1; grid-column: 2; font-size: .68rem; align-self: center; }
.zg-cats-grid .cat-check { grid-row: 1; grid-column: 3; align-self: center; font-size: .85rem; }
.zg-cats-grid .cat-input {
  grid-row: 2; grid-column: 1 / -1;
  font-size: .82rem; padding: 8px 10px;
  width: 100%; min-width: 0;
}

@media (max-width:430px){
  .zg-cats-grid{gap:5px}
  .zg-cats-grid .cat-row{gap:6px 6px;padding:7px 7px 9px}
  .zg-cats-grid .cat-check{width:clamp(28px,7vw,34px);height:clamp(28px,7vw,34px)}
  .zg-cats-grid .cat-row.valid .cat-name,
  .zg-cats-grid .cat-row.invalid .cat-name,
  .zg-cats-grid .cat-row.pending .cat-name{
    overflow-wrap:break-word;
    word-break:normal;
    line-height:1.3;
  }
}
.zg-icon-badge {
  width: clamp(30px, 5vw, 42px);
  height: clamp(30px, 5vw, 42px);
  border-radius: 999px;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  color: var(--zg-icon-color);
  background:
    radial-gradient(circle at 40% 25%, rgba(255,255,255,0.12), transparent 42%),
    rgba(9, 14, 42, 0.76);
  border: 2px solid color-mix(in srgb, var(--zg-icon-color) 68%, transparent);
  box-shadow:
    0 0 18px color-mix(in srgb, var(--zg-icon-color) 38%, transparent),
    inset 0 0 16px rgba(255,255,255,0.05);
}
.zg-icon-badge svg {
  width: 56%;
  height: 56%;
  stroke: currentColor;
  fill: none;
  stroke-width: 2.35;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.zg-category-card[data-type="country"] { --zg-icon-color: #3a95ff; }
.zg-category-card[data-type="mountain"] { --zg-icon-color: #9a6bff; }
.zg-category-card[data-type="city"] { --zg-icon-color: #7d77ff; }
.zg-category-card[data-type="plant"] { --zg-icon-color: #38e878; }
.zg-category-card[data-type="river"] { --zg-icon-color: #2f8dff; }
.zg-category-card[data-type="animal"] { --zg-icon-color: #ff4fb3; }

/* ── rival bar ── */
.zg-rival-bar {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px; border-radius: 16px;
  background: rgba(167,139,250,.08);
  border: 1.5px solid rgba(167,139,250,.2);
}
.zg-rival-avatar {
  width: 36px; height: 36px; border-radius: 50%;
  border: 2px solid rgba(236,72,153,.5); object-fit: cover; flex-shrink: 0;
}
.zg-rival-info { flex: 1; display: flex; flex-direction: column; gap: 2px; }
.zg-rival-name { font-size: .72rem; font-weight: 800; color: #ec4899; }
.zg-rival-status { font-size: .68rem; color: rgba(148,163,184,.7); font-weight: 600; }

@media (prefers-reduced-motion: reduce) {
  .stars .star,
  .star,
  .neb,
  .letter-ring,
  .letter-ring2,
  .timer-num.danger,
  .typing-dots span {
    animation: none !important;
  }

  .flash,
  .toast,
  .hp-fill,
  .cat-row,
  .cat-input,
  .cat-check,
  .submit-btn,
  .duel-submit-ack-fade,
  .timer-arc,
  .zg-back-link,
  .progress-track,
  .btn-home,
  .btn-rematch {
    transition-duration: .01ms !important;
  }
}
