:root{
  --verde:#0b6b3a; --verde2:#0f8a4c; --verde-suave:#eef6f1; --verde-borde:#cfe6da;
  --tinta:#0c1424; --fondo:#f4f6f5; --card:#fff; --linea:#e3e8e5;
  --muted:#6b7a72; --oro:#e8b923; --oro-suave:#fff8e1; --rojo:#d23b3b;
  --sombra:0 2px 14px rgba(12,20,36,.08); --radio:14px;
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;background:var(--fondo);color:var(--tinta);line-height:1.45}
.wrap{max-width:760px;margin:0 auto;padding:0 16px}

/* Encabezado */
.topbar{background:linear-gradient(135deg,var(--verde),var(--verde2));color:#fff;box-shadow:var(--sombra)}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;padding-top:14px;padding-bottom:14px}
.topbar h1{font-size:1.15rem;margin:0}
.topbar nav{display:flex;gap:6px}
.topbar nav a{color:#eafff2;text-decoration:none;padding:6px 12px;border-radius:999px;font-size:.9rem}
.topbar nav a.active,.topbar nav a:hover{background:rgba(255,255,255,.18)}
.link-salir{opacity:.85}
main.wrap{padding-top:18px;padding-bottom:40px}

/* Tarjetas y avisos */
.card{background:var(--card);border:1px solid var(--linea);border-radius:var(--radio);box-shadow:var(--sombra);padding:18px;margin-bottom:18px}
.card h2{margin:0 0 10px;font-size:1.1rem}
.destacado{border-top:4px solid var(--verde)}
.muted{color:var(--muted);font-size:.9rem}
.aviso{background:#fff7e0;border:1px solid #f0d98a;color:#7a5c00;padding:10px 14px;border-radius:10px;margin-bottom:14px}
.ok-aviso{background:var(--verde-suave);border-color:#a9dfbd;color:#1c6b3a}
.aviso-inline{margin-top:14px;background:var(--verde-suave);border:1px dashed var(--verde-borde);padding:12px 14px;border-radius:10px;color:var(--verde)}
.hola{margin:0 0 14px;font-size:.95rem}
.hola a{color:var(--verde2)}

/* Entrada de nombre */
.form-nombre{display:flex;gap:8px;flex-wrap:wrap}
.form-nombre input{flex:1;min-width:160px;padding:12px;border:1px solid var(--linea);border-radius:10px;font-size:1rem}
.form-nombre button{background:var(--verde2);color:#fff;border:0;padding:12px 18px;border-radius:10px;font-size:1rem;cursor:pointer}
.form-nombre button:hover{background:var(--verde)}

/* Cómo se juega */
.howto{background:#fff;border:1px solid var(--linea);border-left:4px solid var(--verde2);border-radius:12px;
  padding:12px 16px;margin-bottom:16px;font-size:.92rem;color:#33433b;box-shadow:var(--sombra);line-height:1.7}
.howto-ico{display:inline-block;color:var(--verde2);font-weight:700;margin-right:2px}
.howto strong{color:var(--verde)}

/* Lista de reglas (página de condiciones) */
.reglas{margin:0;padding-left:0;list-style:none;counter-reset:regla}
.reglas li{position:relative;padding:8px 0 8px 38px;border-bottom:1px solid #f0f3f1;line-height:1.5}
.reglas li:last-child{border-bottom:0}
.reglas li::before{counter-increment:regla;content:counter(regla);position:absolute;left:0;top:8px;
  width:24px;height:24px;border-radius:50%;background:var(--verde-suave);color:var(--verde);
  border:1px solid var(--verde-borde);display:flex;align-items:center;justify-content:center;
  font-size:.8rem;font-weight:700}
.reglas strong{color:var(--verde)}

/* Selector de día */
.selector{margin-bottom:14px}
.selector select{padding:11px 12px;border:1px solid var(--linea);border-radius:10px;font-size:1rem;background:#fff;max-width:100%;width:100%}
.selector label{display:block;font-size:.82rem;color:var(--muted);margin-bottom:6px;font-weight:600;text-transform:uppercase;letter-spacing:.03em}

/* Cabecera de jornada + pozo */
.cab-jornada{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:8px}
.cab-jornada h2{text-transform:capitalize}
.pozo-chip{background:var(--oro-suave);border:1px solid #f0e2a6;border-radius:999px;padding:7px 14px;font-size:.9rem}
.pozo-chip strong{color:#9a7a00}

/* Estado abierto/cerrado */
.estado{margin:12px 0;padding:12px 14px;border-radius:10px;font-weight:600;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.estado.abierto{background:var(--verde-suave);color:var(--verde)}
.estado.cerrado{background:#fbeaea;color:var(--rojo)}
.estado-label{font-weight:600}
#cuenta{font-variant-numeric:tabular-nums;font-size:1.15rem;font-weight:700;background:#fff;border:1px solid var(--verde-borde);border-radius:8px;padding:2px 10px;color:var(--verde)}

/* Progreso */
.progress{margin:0 0 14px;padding:10px 14px;background:#f3f8f5;border:1px solid var(--verde-borde);border-radius:10px;font-size:.92rem;color:#33433b}
.progress strong{color:var(--verde)}

/* Lista de partidos (tarjeta tipo marcador) */
.matches{display:flex;flex-direction:column;gap:12px;margin-top:8px}
.match{border:1px solid var(--linea);border-radius:14px;padding:14px;background:#fff;transition:border-color .15s}
.match:focus-within{border-color:var(--verde2);box-shadow:0 0 0 3px rgba(15,138,76,.12)}
.match.fin{background:#fafbfa}
.match-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.match-meta{font-size:.8rem;color:var(--muted);font-weight:600}
.mark-badge{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:#9aa8a0;background:#f0f3f1;border-radius:999px;padding:3px 9px}
.mark-badge.on{color:#fff;background:var(--verde2)}

/* Duelo: equipo - marcador - equipo */
.fixture{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:10px}
.team{display:flex;align-items:center;gap:8px;min-width:0}
.team .flag{font-size:1.5rem;line-height:1;flex:none;display:inline-flex;align-items:center}
.flagimg{height:22px;width:auto;border-radius:3px;box-shadow:0 0 0 1px rgba(12,20,36,.12);display:block}
.team .name{font-weight:600;font-size:1rem;overflow-wrap:anywhere}
.team.local{justify-content:flex-end;text-align:right}
.team.local .flag{order:2}
.team.local .name{order:1}
.team.visitante{justify-content:flex-start;text-align:left}

/* Marcador */
.score{display:flex;align-items:center;gap:6px;flex:none}
.score input{width:50px;height:50px;text-align:center;border:1.5px solid var(--linea);border-radius:10px;font-size:1.3rem;font-weight:700;color:var(--tinta);padding:0;font-variant-numeric:tabular-nums}
.score input:focus{outline:none;border-color:var(--verde2)}
.score input:disabled{background:#f1f3f2;color:#90a098;border-color:var(--linea)}
.score .dash{color:var(--muted);font-weight:700}

/* Traductor de pronóstico en vivo */
.outcome{min-height:0;overflow:hidden;font-size:.86rem;font-weight:600;color:var(--verde);text-align:center;
  margin-top:0;opacity:0;transition:opacity .15s}
.outcome.show{margin-top:10px;opacity:1}
.outcome.draw{color:#9a7a00}

/* Resultado final */
.match-result{margin-top:10px;padding-top:10px;border-top:1px dashed var(--linea);font-size:.9rem;color:var(--muted)}
.match-result strong{color:var(--tinta);font-size:1rem}
.ok{color:var(--verde);font-weight:700;margin-left:6px}
.no{color:var(--rojo);font-weight:700;margin-left:6px}

/* Botón guardar */
.btn-guardar{margin-top:16px;background:var(--verde2);color:#fff;border:0;padding:15px 22px;border-radius:12px;font-size:1.05rem;font-weight:600;cursor:pointer;width:100%}
.btn-guardar:hover{background:var(--verde)}

/* Tablas (ranking y admin) */
.ranking,.admin-tabla{width:100%;border-collapse:collapse;margin-top:6px}
.ranking th,.ranking td,.admin-tabla th,.admin-tabla td{padding:10px 8px;border-bottom:1px solid var(--linea);text-align:left;font-size:.95rem}
.ranking th,.admin-tabla th{color:var(--muted);font-weight:600;font-size:.82rem;text-transform:uppercase;letter-spacing:.03em}
.num{text-align:right;font-variant-numeric:tabular-nums}
.ranking tr.ganador,.ranking tr.lider{background:var(--oro-suave)}
.ranking tr.ganador td,.ranking tr.lider td{font-weight:600}

/* Panel admin */
.grid-add{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.grid-add label{display:flex;flex-direction:column;font-size:.82rem;color:var(--muted);gap:4px}
.grid-add input{padding:9px 10px;border:1px solid var(--linea);border-radius:8px;font-size:.95rem}
.grid-add .btn-guardar{grid-column:1 / -1}
.del{text-decoration:none;font-size:1.05rem}

/* Pronósticos por partido (vista mobile-friendly) */
.picks{display:grid;gap:12px;margin-top:8px}
.pick-match{border:1px solid var(--linea);border-radius:12px;overflow:hidden}
.pick-head{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:10px 12px;background:#f3f8f5;border-bottom:1px solid var(--linea)}
.pm-teams{display:flex;align-items:center;gap:6px;font-weight:600;font-size:.92rem;flex-wrap:wrap}
.pm-teams .flagimg{height:16px}
.pm-name{overflow-wrap:anywhere}
.pm-vs{color:var(--muted);font-weight:400;font-size:.82rem}
.pm-res{flex:none;font-size:.95rem}
.pm-res strong{color:var(--tinta);font-variant-numeric:tabular-nums}
.pick-list{list-style:none;margin:0;padding:4px 0}
.pick-list li{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:7px 12px;border-bottom:1px solid #f0f3f1}
.pick-list li:last-child{border-bottom:0}
.pl-name{font-size:.92rem;overflow-wrap:anywhere}
.pl-pick{font-weight:700;font-variant-numeric:tabular-nums;font-size:.92rem;padding:2px 10px;border-radius:999px;background:#f0f3f1;color:#33433b;white-space:nowrap}
.pl-pick.ok{background:var(--verde-suave);color:#1c6b3a}
.pl-pick.no{background:#fbeaea;color:#b23b3b}
.pl-pick.none{background:transparent;color:#b9c4be;font-weight:400}
@media (min-width:560px){.picks{grid-template-columns:1fr 1fr}}

/* Insignias del panel admin */
.badge-on{color:#fff;background:var(--verde2);border-radius:999px;padding:2px 9px;font-size:.78rem;font-weight:700}
.badge-off{color:#9aa8a0;background:#f0f3f1;border-radius:999px;padding:2px 9px;font-size:.78rem;font-weight:600}
.chk{display:inline-flex;align-items:center;gap:5px;font-size:.85rem;color:#33433b;cursor:pointer}
.chk input{width:17px;height:17px}

.pie{text-align:center;color:var(--muted);font-size:.82rem;padding:18px}

/* Responsive */
@media (max-width:520px){
  .grid-add{grid-template-columns:1fr}
  .topbar h1{font-size:1rem}
  .team .name{font-size:.9rem}
  .team .flag{font-size:1.25rem}
  .flagimg{height:18px}
  .score input{width:46px;height:46px;font-size:1.15rem}
  .fixture{gap:7px}
  .howto{font-size:.88rem}
}
@media (prefers-reduced-motion:reduce){
  .outcome,.match{transition:none}
}
