:root{
  --bg:#f6f7fb;
  --card:#ffffff;
  --ink:#0f172a;
  --muted:#475569;
  --line:#e2e8f0;
  --shadow: 0 10px 30px rgba(2,6,23,.08);
  --r:18px;

  /* Colores juego */
  --accent:#5b7cfa;
  --accentSoft: rgba(91,124,250,.14);
  --ok:#16a34a;
  --bad:#ef4444;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: var(--bg);
  color: var(--ink);
}

.container{max-width:1100px;margin:14px auto;padding:0 12px}
.header{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;padding:8px 0 2px}
.header h1{margin:0;font-size:20px;letter-spacing:-.2px}
.header p{margin:6px 0 0;color:var(--muted);font-size:13px}

.panel{
  background: rgba(255,255,255,.92);
  border:1px solid var(--line);
  border-radius: var(--r);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.controls{
  display:flex;justify-content:space-between;align-items:center;gap:10px;
  padding:12px;border-bottom:1px solid var(--line);
}
.group{display:flex;gap:8px;flex-wrap:wrap}

/* En tu /shared/ui.css ya hay .btn, pero reforzamos active */
.btn.active{
  background: var(--accentSoft) !important;
  border-color: rgba(91,124,250,.55) !important;
  box-shadow: 0 8px 20px rgba(91,124,250,.18) !important;
}
.btn.primary{
  background: var(--accent) !important;
  border-color: rgba(91,124,250,.75) !important;
  color: #fff !important;
}

.layout{
  display:grid;
  grid-template-columns: 1.3fr .7fr;
  gap:12px;
  padding:12px;
}
@media (max-width: 900px){ .layout{grid-template-columns:1fr} }

.mapWrap{
  position:relative;
  border:1px solid var(--line);
  border-radius: var(--r);
  background:#fff;
  overflow:hidden;
  min-height:360px;
}
.svgMap{width:100%;height:100%;min-height:360px}

.hud{
  position:absolute;left:10px;right:10px;top:10px;
  display:flex;justify-content:space-between;gap:10px;
  pointer-events:none;
}
.badge,.score{
  background: rgba(255,255,255,.92);
  border:1px solid var(--line);
  border-radius:999px;
  padding:8px 10px;
  font-size:12px;
  color:var(--muted);
  box-shadow: 0 10px 30px rgba(2,6,23,.06);
}
.hint{
  position:absolute;left:10px;bottom:10px;
  background: rgba(255,255,255,.92);
  border:1px solid var(--line);
  border-radius:999px;
  padding:8px 10px;
  font-size:12px;
  color:var(--muted);
  pointer-events:none;
}

.side{
  border:1px solid var(--line);
  border-radius: var(--r);
  background:#fff;
  overflow:hidden;
}
.side h2{margin:0;padding:12px;border-bottom:1px solid var(--line);font-size:16px}
.list{padding:10px;display:flex;flex-direction:column;gap:10px}
.item{
  display:flex;justify-content:space-between;gap:10px;
  padding:10px;border:1px solid var(--line);border-radius:14px;
}
.item small{color:var(--muted)}

.quiz{margin:0;padding:12px;border-top:1px solid var(--line);background: rgba(2,6,23,.02)}
.quiz .q{margin:0 0 8px;font-weight:600}
.quiz .row{display:flex;gap:8px;flex-wrap:wrap}
.notice{margin:10px 0 0;font-size:12px;color:var(--muted)}

/* ===== SVG ===== */

/* 1) QUITAR nombres de provincias: escondemos textos del SVG */
#svgHost svg text{ display:none !important; }

/* Mejor aún: que texto (si existiera) no bloquee clicks */
#svgHost svg text{ pointer-events:none !important; }

.regionShape{
  transition: filter .12s ease, opacity .12s ease, transform .12s ease, fill .12s ease;
}

.regionShape:hover{ filter:brightness(0.96); }

/* 2) COLORES como comunidades: marcadas en azul */
.revealed{
  opacity: 1 !important;
  fill: var(--accent) !important;
  stroke: rgba(255,255,255,.9) !important;
  stroke-width: 1.2px !important;
}

/* flashes */
.okFlash{ animation: okPulse .65s ease; }
.badFlash{ animation: badPulse .65s ease; }

@keyframes okPulse{
  0%{filter:none}
  40%{filter: drop-shadow(0 0 7px rgba(22,163,74,.55)) brightness(.92)}
  100%{filter:none}
}
@keyframes badPulse{
  0%{filter:none}
  40%{filter: drop-shadow(0 0 7px rgba(239,68,68,.55)) brightness(.92)}
  100%{filter:none}
}
/* ===== Persistencia de colores en QUIZ ===== */
.okPersist{
  fill: #16a34a !important;
  opacity: 1 !important;
  stroke: rgba(255,255,255,.95) !important;
  stroke-width: 1.2px !important;
}
.badPersist{
  fill: #ef4444 !important;
  opacity: 1 !important;
  stroke: rgba(255,255,255,.95) !important;
  stroke-width: 1.2px !important;
}

/* En QUIZ, el “marcado azul” no tiene sentido: gana el ok/bad */
.okPersist.revealed,
.badPersist.revealed{
  /* el fill persistente manda */
}
