/* ============================================================
   Rank It — Hoja de estilos principal
   Diseño: oscuro "tinta profunda" + acentos violeta/menta/oro.
   Firma visual: tarjetas ordenables con riel de podio a la
   izquierda (oro → plata → bronce) que codifica la posición.
   Mobile first. Sin frameworks.
   ============================================================ */
:root{
  --tinta:#0d1022;        /* fondo base */
  --tinta-2:#12162c;      /* fondo secciones */
  --carta:#181d38;        /* superficies */
  --carta-2:#1f2547;
  --borde:#2a3158;
  --texto:#edeffa;
  --texto-2:#9aa3c7;
  --violeta:#8b7cff;      /* acento principal */
  --violeta-2:#6d5cf0;
  --menta:#3ddc97;        /* éxito / exacto */
  --oro:#f5c84b;          /* muy cerca / podio */
  --naranja:#ff9d5c;      /* cerca */
  --rojo:#ff6b7a;         /* incorrecto */
  --radio:14px;
  --sombra:0 10px 30px rgba(5,8,24,.45);
  --f-display:"Bricolage Grotesque",system-ui,sans-serif;
  --f-texto:"Inter",system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--tinta);color:var(--texto);
  font:400 16px/1.55 var(--f-texto);
  background-image:radial-gradient(1100px 500px at 85% -10%,rgba(139,124,255,.14),transparent 60%),
                   radial-gradient(800px 420px at -10% 0%,rgba(61,220,151,.08),transparent 55%);
  background-attachment:fixed;
}
img{max-width:100%;display:block}
a{color:var(--violeta);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{width:min(1100px,100% - 2rem);margin-inline:auto}
.skip{position:absolute;left:-999px;top:0;background:var(--violeta);color:#fff;padding:.5rem 1rem;z-index:99}
.skip:focus{left:0}
:focus-visible{outline:3px solid var(--violeta);outline-offset:2px;border-radius:6px}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}

/* ---------- Barra superior ---------- */
.topbar{position:sticky;top:0;z-index:50;background:rgba(13,16,34,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--borde)}
.topbar__in{display:flex;align-items:center;gap:1rem;padding:.65rem 0;position:relative}
.logo{font:800 1.3rem/1 var(--f-display);color:var(--texto);display:flex;align-items:center;gap:.5rem;letter-spacing:-.02em}
.logo:hover{text-decoration:none}
.logo__img{width:32px;height:32px;border-radius:7px;display:block;object-fit:cover}
.logo__txt{font:800 1.3rem/1 var(--f-display);letter-spacing:-.02em}
@keyframes reordenar{0%,100%{transform:translateY(0)}10%{transform:translateY(7px)}20%{transform:translateY(0)}}
.nav{display:none;gap:1.1rem;margin-left:.5rem}
.nav a{color:var(--texto-2);font-weight:600;font-size:.92rem}
.nav a:hover{color:var(--texto);text-decoration:none}
/* Menú móvil: botón hamburguesa (checkbox-hack, sin JS) */
.navmenu__btn{cursor:pointer;display:flex;flex-direction:column;justify-content:center;gap:4px;width:40px;height:38px;padding:0 9px;border-radius:10px;border:1px solid var(--borde);background:var(--tinta-2)}
.navmenu__btn span{display:block;height:2.5px;border-radius:2px;background:var(--texto);transition:.2s}
.navtoggle:checked ~ .navmenu__btn span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.navtoggle:checked ~ .navmenu__btn span:nth-child(2){opacity:0}
.navtoggle:checked ~ .navmenu__btn span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.navtoggle:checked ~ .nav{display:flex;flex-direction:column;position:absolute;top:54px;left:0;min-width:230px;background:#10142b;border:1px solid var(--borde);border-radius:14px;padding:.6rem;gap:.2rem;box-shadow:0 18px 40px rgba(5,8,24,.7);z-index:60}
.navtoggle:checked ~ .nav a{padding:.6rem .7rem;border-radius:8px;font-size:1rem}
.navtoggle:checked ~ .nav a:hover{background:var(--tinta-2);color:var(--texto)}
.topbar__acts{margin-left:auto;display:flex;align-items:center;gap:.55rem}
.topbar__acts .racha,.topbar__acts .monedas-chip{display:inline-flex;align-items:center;gap:.25rem;white-space:nowrap;font-weight:700;font-size:.85rem;padding:.3rem .7rem;border-radius:999px;border:1px solid var(--borde);background:rgba(13,16,34,.5);line-height:1}
.topbar__acts .racha{color:var(--oro);border-color:rgba(245,200,75,.35)}
.topbar__acts .monedas-chip{color:var(--oro)}
.racha{font-weight:700;font-size:.9rem;color:var(--oro);white-space:nowrap}
.avatar-chip{display:flex;align-items:center;gap:.45rem;color:var(--texto);font-weight:600;font-size:.9rem;background:var(--carta);border:1px solid var(--borde);border-radius:99px;padding:.25rem .8rem .25rem .25rem}
.avatar-chip:hover{text-decoration:none;border-color:var(--violeta)}
.avatar{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-weight:800;color:#0d1022;font-size:.85rem}
.avatar--a1{background:var(--violeta)}.avatar--a2{background:var(--menta)}.avatar--a3{background:var(--oro)}.avatar--a4{background:var(--naranja)}
.avatar--a5{background:#6ec3ff}.avatar--a6{background:#ff8ad4}.avatar--a7{background:#b7f06b}.avatar--a8{background:#c9b3ff}
.lang{position:relative}
.lang summary{list-style:none;cursor:pointer;border:1px solid var(--borde);border-radius:8px;padding:.3rem .6rem;font-weight:700;font-size:.8rem;color:var(--texto-2)}
.lang summary::-webkit-details-marker{display:none}
.lang__menu{position:absolute;right:0;top:115%;background:var(--carta);border:1px solid var(--borde);border-radius:10px;padding:.35rem;display:grid;gap:2px;box-shadow:var(--sombra);min-width:70px}
.lang__menu a{padding:.35rem .7rem;border-radius:7px;color:var(--texto-2);font-weight:700;font-size:.85rem;text-align:center}
.lang__menu a:hover,.lang__menu a[aria-current]{background:var(--carta-2);color:var(--texto);text-decoration:none}
@media(min-width:760px){
  .navmenu__btn{display:none}
  .nav{display:flex !important;flex-direction:row;position:static;background:none;border:0;padding:0;box-shadow:none;min-width:0;gap:1.1rem;margin-left:.5rem}
  .nav a{padding:0;font-size:.92rem;border-radius:0}
}

/* ---------- Botones ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border:0;cursor:pointer;font:700 1rem var(--f-texto);border-radius:12px;padding:.8rem 1.5rem;transition:transform .12s,box-shadow .12s,background .12s;text-align:center}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn:active{transform:translateY(1px)}
.btn--primario{background:linear-gradient(135deg,var(--violeta),var(--violeta-2));color:#fff;box-shadow:0 6px 18px rgba(139,124,255,.35)}
.btn--menta{background:var(--menta);color:#0d1022}
.btn--ghost{background:transparent;color:var(--texto);border:1px solid var(--borde)}
.btn--ghost:hover{border-color:var(--violeta)}
.btn--sm{padding:.45rem .9rem;font-size:.88rem;border-radius:9px}
.btn--bloque{width:100%}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}

/* ---------- Héroe ---------- */
.heroe{padding:3rem 0 2rem;text-align:center}
.heroe h1{font:800 clamp(2rem,6vw,3.4rem)/1.08 var(--f-display);letter-spacing:-.03em;margin:0 0 .7rem}
.heroe h1 em{font-style:normal;background:linear-gradient(90deg,var(--oro),var(--violeta) 55%,var(--menta));-webkit-background-clip:text;background-clip:text;color:transparent}
.heroe p{color:var(--texto-2);max-width:46ch;margin:0 auto 1.6rem;font-size:1.05rem}
.heroe__acts{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:center}
.demo-rank{margin:1.6rem auto 1.8rem;max-width:420px;display:grid;gap:8px;text-align:left}

/* ---------- Tarjetas ordenables (firma del producto) ---------- */
.rk-lista{display:grid;gap:9px;margin:0;padding:0;list-style:none;counter-reset:pos}
.rk-item{
  counter-increment:pos;position:relative;display:flex;align-items:center;gap:.8rem;
  background:var(--carta);border:1px solid var(--borde);border-radius:var(--radio);
  padding:.85rem 1rem .85rem 3.4rem;font-weight:600;cursor:grab;user-select:none;
  transition:transform .15s,box-shadow .15s,border-color .15s,background .15s;
  touch-action:none;
}
.rk-item::before{ /* riel de podio: número de posición */
  content:counter(pos);position:absolute;left:0;top:0;bottom:0;width:2.6rem;
  display:grid;place-items:center;font:800 1.05rem var(--f-display);color:#0d1022;
  border-radius:var(--radio) 0 0 var(--radio);background:var(--texto-2);
}
.rk-item:nth-child(1)::before{background:var(--oro)}
.rk-item:nth-child(2)::before{background:#cdd5ee}
.rk-item:nth-child(3)::before{background:#d99a6c}
.rk-item:hover{border-color:var(--violeta)}
.rk-item.arrastrando{opacity:.92;cursor:grabbing;transform:scale(1.03) rotate(.6deg);box-shadow:0 14px 30px rgba(5,8,24,.6);border-color:var(--violeta);z-index:10}
.rk-item.hueco{background:var(--tinta-2);border-style:dashed;color:transparent}
.rk-item .asa{margin-left:auto;color:var(--texto-2);font-size:1.1rem;letter-spacing:2px}
.rk-item--exacto{border-color:var(--menta);background:rgba(61,220,151,.1)}
.rk-item--muy_cerca{border-color:var(--oro);background:rgba(245,200,75,.1)}
.rk-item--cerca{border-color:var(--naranja);background:rgba(255,157,92,.1)}
.rk-item--incorrecto{border-color:var(--rojo);background:rgba(255,107,122,.08)}
.rk-item .delta{margin-left:auto;font-weight:800;font-size:.85rem}
.rk-item--exacto .delta{color:var(--menta)}
.rk-item--muy_cerca .delta{color:var(--oro)}
.rk-item--cerca .delta{color:var(--naranja)}
.rk-item--incorrecto .delta{color:var(--rojo)}
.rk-item.flip{transition:transform .6s cubic-bezier(.22,.9,.3,1.2)}

/* ---------- Juego ---------- */
.juego{max-width:640px;margin-inline:auto;padding:1.4rem 0 3rem}
.juego__top{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.4rem;color:var(--texto-2);font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.06em}
.progreso{display:flex;gap:5px}
.progreso i{width:26px;height:6px;border-radius:3px;background:var(--carta-2)}
.progreso i.hecha{background:var(--menta)}
.progreso i.actual{background:var(--violeta)}
.juego h1{font:800 clamp(1.35rem,4.5vw,1.9rem)/1.15 var(--f-display);margin:.2rem 0 .35rem;letter-spacing:-.02em}
.juego .instruccion{color:var(--texto-2);margin:0 0 1.2rem}
.puntaje-flotante{position:fixed;left:50%;top:18%;transform:translateX(-50%);font:800 2rem var(--f-display);color:var(--menta);pointer-events:none;animation:flota 1.1s ease-out forwards;z-index:60;text-shadow:0 4px 18px rgba(0,0,0,.5)}
@keyframes flota{from{opacity:1;translate:0 0}to{opacity:0;translate:0 -60px}}

/* ---------- Resultado ---------- */
.resultado{max-width:640px;margin-inline:auto;text-align:center;padding:1.5rem 0 3rem}
.resultado h1{font:800 clamp(1.8rem,6vw,2.6rem) var(--f-display);margin:.4rem 0}
.marcador{color:var(--texto);font-variant-numeric:tabular-nums}
.medalla{font-size:3rem}
.stats-fila{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.7rem;margin:1.4rem 0}
.stat{background:var(--carta);border:1px solid var(--borde);border-radius:var(--radio);padding:.9rem .6rem}
.stat b{display:block;font:800 1.4rem var(--f-display);font-variant-numeric:tabular-nums}
.stat span{color:var(--texto-2);font-size:.8rem;font-weight:600}
.social-comp{background:linear-gradient(135deg,rgba(139,124,255,.15),rgba(61,220,151,.1));border:1px solid var(--borde);border-radius:var(--radio);padding:1.1rem;margin:1rem 0;display:grid;gap:.3rem;font-weight:600}
.compartir-fila{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin:1.2rem 0}
.btn-red{border:1px solid var(--borde);background:var(--carta);color:var(--texto);border-radius:10px;padding:.6rem 1rem;font-weight:700;font-size:.9rem;cursor:pointer;display:inline-flex;gap:.4rem;align-items:center}
.btn-red:hover{border-color:var(--violeta);text-decoration:none}
.tarjeta-share{background:var(--carta);border:2px solid var(--violeta);border-radius:var(--radio);padding:1.2rem;margin:1rem auto;max-width:380px;text-align:left;white-space:pre-line;font-weight:600;box-shadow:var(--sombra)}

/* ---------- Secciones / tarjetas generales ---------- */
.seccion{padding:2.2rem 0}
.seccion h2{font:800 1.5rem var(--f-display);letter-spacing:-.02em;margin:0 0 1rem}
.grid-modos{display:grid;gap:.9rem;grid-template-columns:repeat(auto-fit,minmax(230px,1fr))}
.modo{background:var(--carta);border:1px solid var(--borde);border-radius:var(--radio);padding:1.2rem;display:flex;flex-direction:column;gap:.4rem;color:var(--texto);transition:border-color .15s,transform .15s}
.modo:hover{border-color:var(--violeta);transform:translateY(-2px);text-decoration:none}
.modo .ico{font-size:1.6rem}
.modo b{font:700 1.05rem var(--f-display)}
.modo span{color:var(--texto-2);font-size:.88rem}
.grid-cats{display:grid;gap:.7rem;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
.cat{background:var(--carta);border:1px solid var(--borde);border-radius:12px;padding:1rem;text-align:center;color:var(--texto);font-weight:700}
.cat:hover{border-color:var(--menta);text-decoration:none}
.cat .ico{display:block;font-size:1.5rem;margin-bottom:.3rem}
.pasos{display:grid;gap:.8rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));counter-reset:paso}
.paso{background:var(--carta);border:1px solid var(--borde);border-radius:var(--radio);padding:1.1rem;counter-increment:paso;position:relative}
.paso::before{content:counter(paso,decimal-leading-zero);font:800 .85rem var(--f-display);color:var(--violeta)}
.paso p{margin:.3rem 0 0;font-weight:600}

/* ---------- Tablas de clasificación ---------- */
.tabla{width:100%;border-collapse:collapse;background:var(--carta);border:1px solid var(--borde);border-radius:var(--radio);overflow:hidden}
.tabla th,.tabla td{padding:.7rem .9rem;text-align:left;border-bottom:1px solid var(--borde);font-size:.93rem}
.tabla th{color:var(--texto-2);font-size:.75rem;text-transform:uppercase;letter-spacing:.07em}
.tabla tr:last-child td{border-bottom:0}
.tabla td.num{font-variant-numeric:tabular-nums;font-weight:700}
.tabla .yo{background:rgba(139,124,255,.12)}
.tabs{display:flex;gap:.4rem;margin-bottom:1rem;flex-wrap:wrap}
.tabs a{padding:.45rem 1rem;border-radius:99px;border:1px solid var(--borde);color:var(--texto-2);font-weight:700;font-size:.88rem}
.tabs a:hover{text-decoration:none;color:var(--texto)}
.tabs a.activa{background:var(--violeta);border-color:var(--violeta);color:#fff}

/* ---------- Formularios ---------- */
.form-caja{max-width:420px;margin:2.5rem auto;background:var(--carta);border:1px solid var(--borde);border-radius:var(--radio);padding:1.8rem;box-shadow:var(--sombra)}
.form-caja h1{font:800 1.6rem var(--f-display);margin:0 0 1.2rem}
.campo{display:grid;gap:.35rem;margin-bottom:1rem}
.campo label{font-weight:600;font-size:.9rem}
.campo input,.campo select,.campo textarea{background:var(--tinta-2);border:1px solid var(--borde);border-radius:10px;color:var(--texto);padding:.7rem .85rem;font:inherit;width:100%}
.campo input:focus,.campo textarea:focus,.campo select:focus{border-color:var(--violeta);outline:none}
.alerta{border-radius:10px;padding:.8rem 1rem;margin-bottom:1rem;font-weight:600;font-size:.92rem}
.alerta--error{background:rgba(255,107,122,.12);border:1px solid var(--rojo);color:#ffb4bd}
.alerta--ok{background:rgba(61,220,151,.12);border:1px solid var(--menta);color:#9af0cd}

/* ---------- Perfil ---------- */
.perfil-cab{display:flex;align-items:center;gap:1.1rem;padding:1.8rem 0 .6rem;flex-wrap:wrap}
.perfil-cab .avatar{width:72px;height:72px;font-size:2rem;border:3px solid var(--violeta)}
.perfil-cab h1{font:800 1.8rem var(--f-display);margin:0}
.nivel-pill{background:var(--carta);border:1px solid var(--oro);color:var(--oro);border-radius:99px;padding:.2rem .8rem;font-weight:800;font-size:.85rem}
.xp-barra{height:10px;background:var(--carta-2);border-radius:5px;overflow:hidden;margin:.4rem 0 1.2rem}
.xp-barra i{display:block;height:100%;background:linear-gradient(90deg,var(--violeta),var(--menta));border-radius:5px}
.insignia{display:inline-grid;place-items:center;gap:.2rem;background:var(--carta);border:1px solid var(--borde);border-radius:12px;padding:.8rem;text-align:center;font-size:.78rem;font-weight:700;width:108px}
.insignia .ico{font-size:1.6rem}
.insignias-grid{display:flex;gap:.7rem;flex-wrap:wrap}

/* ---------- Publicidad ---------- */
.ad{margin:1.2rem auto;text-align:center;position:relative;min-height:50px;max-width:100%;overflow:hidden}
.ad__tag{position:absolute;top:0;left:0;font-size:.6rem;text-transform:uppercase;letter-spacing:.1em;color:var(--texto-2);background:var(--tinta-2);padding:.1rem .4rem;border-radius:0 0 6px 0;z-index:2}
.ad--leaderboard_top{max-width:728px}
.ad--lateral{display:none}
.ad img{margin-inline:auto;border-radius:8px}
@media(min-width:1180px){
  .con-lateral{display:grid;grid-template-columns:1fr 300px;gap:1.5rem;align-items:start}
  .ad--lateral{display:block;position:sticky;top:80px}
}

/* ---------- Comentarios ---------- */
.comentario{background:var(--carta);border:1px solid var(--borde);border-radius:12px;padding:.9rem 1rem;margin-bottom:.7rem}
.comentario b{color:var(--violeta)}
.comentario time{color:var(--texto-2);font-size:.78rem;margin-left:.4rem}
.reacciones{display:flex;gap:.4rem;margin-top:.4rem}
.reaccion{background:var(--tinta-2);border:1px solid var(--borde);border-radius:99px;padding:.15rem .6rem;cursor:pointer;color:var(--texto);font-size:.85rem}
.reaccion:hover,.reaccion.activa{border-color:var(--violeta)}

/* ---------- Pie ---------- */
.pie{border-top:1px solid var(--borde);margin-top:2.5rem;padding:1.4rem 0;color:var(--texto-2);font-size:.88rem}
.pie__in{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.pie nav{display:flex;gap:1rem}
.pie a{color:var(--texto-2)}

/* ---------- Confeti ---------- */
.confeti{position:fixed;inset:0;pointer-events:none;z-index:70}
.confeti i{position:absolute;width:9px;height:14px;top:-20px;animation:cae 2.6s linear forwards}
@keyframes cae{to{transform:translateY(110vh) rotate(540deg)}}

/* ---------- Resultado: marcador, comparación, vs ---------- */
.resultado{display:flex;flex-direction:column;gap:1.1rem;max-width:560px;margin:0 auto}
.marcador__msg{font-family:var(--f-display);font-size:1.4rem;font-weight:700;margin:.2rem 0 .6rem}
.marcador__puntos{font-family:var(--f-display);font-size:3.2rem;font-weight:800;line-height:1;color:var(--violeta);font-variant-numeric:tabular-nums;margin:.2rem 0}
.marcador__sub{color:var(--texto-2);font-size:1rem;font-weight:600;line-height:1.4}
.marcador__msg{font-size:1.4rem}
.social-comp p{margin:.35rem 0}
.vs{margin-top:1rem;padding:.9rem;border-radius:12px;border:1px solid var(--borde);background:var(--tinta-2)}
.vs--gano{border-color:var(--menta);background:rgba(61,220,151,.12)}
.vs--perdio{border-color:var(--rojo);background:rgba(255,107,122,.1)}

/* ---------- Grilla de emojis (viral, estilo Wordle) ---------- */
.grilla-resultado__titulo{font-family:var(--f-display);font-size:1.1rem;margin:.2rem 0 .8rem}
.emoji-grilla{display:inline-flex;flex-direction:column;gap:.25rem;margin:.2rem auto}
.emoji-grilla__fila{font-size:1.7rem;line-height:1;letter-spacing:.15rem;opacity:0;transform:translateY(6px);animation:grilla-in .35s ease forwards}
.emoji-grilla__fila:nth-child(1){animation-delay:.05s}
.emoji-grilla__fila:nth-child(2){animation-delay:.18s}
.emoji-grilla__fila:nth-child(3){animation-delay:.31s}
.emoji-grilla__fila:nth-child(4){animation-delay:.44s}
.emoji-grilla__fila:nth-child(5){animation-delay:.57s}
@keyframes grilla-in{to{opacity:1;transform:translateY(0)}}
.emoji-leyenda{margin-top:.9rem;font-size:.8rem}

/* ---------- Compartir ---------- */
.compartir{display:flex;flex-direction:column;align-items:center;gap:.7rem}
.tarjeta{background:var(--tinta-2);border:1px dashed var(--borde);border-radius:12px;padding:1rem 1.2rem;margin:0;white-space:pre-wrap;text-align:center;font-family:var(--f-texto);font-size:.95rem;line-height:1.5;color:var(--texto);max-width:100%}
.compartir__botones{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}
.btn--red{color:#fff;font-weight:600}
.btn--fb{background:#1877f2}
.btn--x{background:#000}
.btn--wa{background:#25d366;color:#063}
.btn--tg{background:#27a7e7}
.resultado__acciones{display:flex;gap:.6rem;justify-content:center;flex-wrap:wrap;margin-top:.4rem}

@media (prefers-reduced-motion:reduce){
  .emoji-grilla__fila{animation:none;opacity:1;transform:none}
}

/* ---------- Retención: misiones, monedas, freeze, heatmap ---------- */
.monedas-chip{font-weight:700;font-size:.9rem;color:var(--oro);background:rgba(245,200,75,.12);border:1px solid rgba(245,200,75,.3);border-radius:99px;padding:.15rem .6rem}
.monedas-chip--sm{font-size:.82rem}

.misiones-pagina{max-width:620px;margin:0 auto;display:flex;flex-direction:column;gap:1rem}
.misiones-cab{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}
.misiones-cab h1{margin:0 0 .2rem}
.misiones-progreso{font-weight:700;margin:0}
.misiones-lista{display:flex;flex-direction:column;gap:.7rem}
.mision{display:flex;align-items:center;gap:.9rem;background:var(--carta);border:1px solid var(--borde);border-radius:14px;padding:.9rem 1rem;transition:border-color .2s}
.mision--ok{border-color:var(--menta);background:rgba(61,220,151,.08)}
.mision__icono{font-size:1.6rem;flex-shrink:0}
.mision__cuerpo{flex:1;min-width:0}
.mision__texto{margin:0 0 .4rem;font-weight:600}
.mision__barra{height:8px;background:var(--tinta-2);border-radius:99px;overflow:hidden}
.mision__barra span{display:block;height:100%;background:linear-gradient(90deg,var(--violeta),var(--menta));border-radius:99px;transition:width .4s ease}
.mision--ok .mision__barra span{background:var(--menta)}
.mision__meta{margin:.35rem 0 0;font-size:.82rem}
.mision__estado{font-size:1.2rem;flex-shrink:0}

.freeze{text-align:center}
.freeze h2{margin:.2rem 0 .4rem;font-size:1.15rem}
.freeze-aviso{margin-top:.6rem}

.heatmap{display:grid;grid-template-rows:repeat(7,1fr);grid-auto-flow:column;grid-auto-columns:1fr;gap:3px;max-width:100%;overflow-x:auto;padding:.2rem 0}
.hm{width:13px;height:13px;border-radius:3px;background:var(--tinta-2)}
.hm--0{background:var(--tinta-2)}
.hm--1{background:rgba(139,124,255,.35)}
.hm--2{background:rgba(139,124,255,.6)}
.hm--3{background:rgba(139,124,255,.8)}
.hm--4{background:var(--violeta)}
.heatmap-leyenda{margin-top:.6rem;font-size:.8rem}

/* ---------- Misiones mini (resultado) ---------- */
.misiones-mini__cab{display:flex;justify-content:space-between;align-items:center;margin-bottom:.6rem}
.misiones-mini__lista{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.5rem}
.mision-pill{background:var(--tinta-2);border:1px solid var(--borde);border-radius:99px;padding:.2rem .6rem;font-size:.82rem;font-variant-numeric:tabular-nums}
.mision-pill--ok{border-color:var(--menta);background:rgba(61,220,151,.12);color:var(--menta)}
.misiones-mini__link{font-size:.85rem;display:inline-block}

/* ---------- Liga ---------- */
.liga-pagina{max-width:640px;margin:0 auto;display:flex;flex-direction:column;gap:1rem}
.liga-cab{padding:1.6rem 1rem}
.liga-icono{font-size:3rem;display:block}
.liga-cab h1{font-family:var(--f-display);margin:.3rem 0}
.liga-cab--bronce{border-top:3px solid #cd7f32}
.liga-cab--plata{border-top:3px solid #c0c8d6}
.liga-cab--oro{border-top:3px solid var(--oro)}
.liga-cab--diamante{border-top:3px solid #7ee8ff}
.liga-intro{font-size:.88rem}
.tabla-liga .fila-promo td{background:rgba(61,220,151,.08)}
.tabla-liga .fila-descenso td{background:rgba(255,107,122,.08)}
.tabla .fila-yo td{background:rgba(139,124,255,.16);font-weight:700}
.tabla .sep td{text-align:center;font-size:.78rem;padding:.2rem;color:var(--texto-2);background:var(--tinta-2)}
.sep--promo td{color:var(--menta)}
.sep--descenso td{color:var(--rojo)}

/* ---------- Amigos ---------- */
.amigos-pagina{max-width:640px;margin:0 auto}
.amigo-buscar{display:flex;gap:.5rem;margin:.6rem 0}
.amigo-buscar input{flex:1;padding:.6rem .8rem;border-radius:10px;border:1px solid var(--borde);background:var(--tinta-2);color:var(--texto)}
.amigo-resultados,.amigo-lista{list-style:none;padding:0;margin:.4rem 0 1rem;display:flex;flex-direction:column;gap:.5rem}
.amigo-item{display:flex;align-items:center;gap:.7rem;background:var(--carta);border:1px solid var(--borde);border-radius:12px;padding:.6rem .8rem}
.amigo-nombre{flex:1;font-weight:600}
.amigo-acciones{display:flex;gap:.4rem}
.amigo-eliminar{padding:.2rem .5rem}

/* ---------- Destacados (portada) ---------- */
.grid-destacados{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.8rem}
.destacado-card{display:flex;flex-direction:column;gap:.3rem;background:var(--carta);border:1px solid var(--borde);border-radius:14px;padding:1rem;transition:border-color .2s,transform .2s}
.destacado-card:hover{border-color:var(--violeta);transform:translateY(-2px)}
.destacado-card__cat{font-size:.78rem;color:var(--texto-2)}
.destacado-card__titulo{font-family:var(--f-display);font-weight:700;font-size:1.05rem}
.destacado-card__desc{font-size:.85rem}

/* ---------- Tienda ---------- */
.tienda-pagina{max-width:680px;margin:0 auto}
.tienda-cab{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}
.tienda-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.8rem;margin-bottom:1rem}
.tienda-item{display:flex;flex-direction:column;align-items:center;gap:.5rem;background:var(--carta);border:1px solid var(--borde);border-radius:14px;padding:1rem .6rem;text-align:center}
.tienda-item__nombre{font-weight:600;font-size:.9rem;margin:0}
.avatar--xl{width:64px;height:64px;font-size:1.6rem;display:flex;align-items:center;justify-content:center;border-radius:50%;color:#0d1022;font-weight:800}
.chip--ok{background:rgba(61,220,151,.15);border:1px solid var(--menta);color:var(--menta);border-radius:99px;padding:.1rem .6rem;font-size:.8rem}

/* ---------- Pro ---------- */
.pro-banner{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;background:linear-gradient(135deg,rgba(245,200,75,.14),rgba(139,124,255,.14));border:1px solid rgba(245,200,75,.4);border-radius:14px;padding:1rem;margin:1rem 0}
.pro-banner--activo{justify-content:center;font-weight:700;color:var(--oro)}
.pro-beneficios{list-style:none;padding:0;margin:1rem 0;display:flex;flex-direction:column;gap:.5rem;text-align:left;max-width:340px;margin-inline:auto}
.pro-nota{font-size:.82rem;margin-top:.8rem}

/* ---------- CTA registro (resultado anónimo) ---------- */
.cta-registro{border:1px dashed var(--violeta);background:rgba(139,124,255,.08)}
.cta-registro h2{font-family:var(--f-display);margin:.2rem 0 .4rem}

/* ---------- Tutorial (primera partida) ---------- */
.tutorial{position:fixed;inset:0;background:rgba(5,8,24,.78);display:flex;align-items:center;justify-content:center;z-index:90;padding:1rem}
.tutorial[hidden]{display:none !important}
.tutorial__caja{background:var(--carta);border:1px solid var(--borde);border-radius:18px;padding:1.6rem;max-width:380px;box-shadow:var(--sombra)}
.tutorial__caja h2{font-family:var(--f-display);margin:0 0 1rem}
.tutorial__pasos{margin:0 0 1.2rem;padding-left:0;list-style:none;display:flex;flex-direction:column;gap:.7rem}
.tutorial__pasos li{background:var(--tinta-2);border-radius:10px;padding:.7rem .9rem;font-size:.92rem}

/* ---------- Modo Mayor o Menor ---------- */
.mm{max-width:640px;margin:0 auto;text-align:center}
.mm__cab{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}
.mm__racha{font-weight:700;color:var(--oro)}
.mm__titulo{font-family:var(--f-display);font-size:1.5rem;margin:.4rem 0}
.mm__pregunta{color:var(--texto-2);margin:0 0 1.2rem}
.mm__cartas{display:flex;align-items:center;justify-content:center;gap:1rem}
.mm-carta{position:relative;flex:1;min-height:170px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;
  background:var(--carta);border:2px solid var(--borde);border-radius:18px;padding:1.4rem 1rem;cursor:pointer;color:var(--texto);
  font-family:var(--f-texto);transition:transform .15s,border-color .15s}
.mm-carta:hover:not(:disabled){border-color:var(--violeta);transform:translateY(-3px)}
.mm-carta:disabled{cursor:default}
.mm-carta__nombre{font-size:1.2rem;font-weight:700;line-height:1.25}
.mm-carta__valor{font-family:var(--f-display);font-size:1.5rem;font-weight:800;color:var(--violeta);font-variant-numeric:tabular-nums;min-height:1.5rem}
.mm-carta--mayor{border-color:var(--menta)}
.mm-carta--mayor .mm-carta__valor{color:var(--menta)}
.mm-carta--ok{border-color:var(--menta);background:rgba(61,220,151,.12)}
.mm-carta--mal{border-color:var(--rojo);background:rgba(255,107,122,.12)}
.mm__vs{font-family:var(--f-display);font-weight:800;color:var(--texto-2);font-size:1.1rem}
.mm-flota{position:absolute;top:.4rem;right:.6rem;color:var(--menta);font-weight:800;animation:flota .9s ease forwards;pointer-events:none}
@keyframes flota{to{transform:translateY(-26px);opacity:0}}
.mm__fin{padding:1rem 0}
.mm__fin h2{font-family:var(--f-display);font-size:1.6rem;margin:.2rem 0 .6rem}
@media (max-width:480px){.mm-carta{min-height:140px;padding:1rem .6rem}.mm-carta__nombre{font-size:1.05rem}}

/* ---------- Logo en hero + tagline ---------- */
.heroe__logo{max-width:min(440px,82%);height:auto;margin:0 auto 1.2rem;display:block}
.heroe__sub{color:var(--texto-2);max-width:46ch;margin:0 auto 1.4rem;font-size:1.05rem}

/* ---------- Banderas de país ---------- */
.bandera{font-size:1.05em;line-height:1;vertical-align:-1px;margin-left:.15em}
.pais-bloque .form-inline{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}
.pais-bloque select{padding:.5rem .7rem;border-radius:10px;border:1px solid var(--borde);background:var(--tinta-2);color:var(--texto)}

/* ---------- Barra superior compacta en móvil ---------- */
@media (max-width:759px){
  .topbar__in{gap:.5rem}
  .logo__txt{font-size:1.1rem}
  .topbar__acts{gap:.4rem}
  .topbar__acts .btn--sm{padding:.45rem .7rem;font-size:.85rem;white-space:nowrap}
}
@media (max-width:420px){
  .logo__txt{display:none}        /* en pantallas muy chicas, solo el ícono */
}

/* ============================================================
   Perfil rediseñado + panel de administración
   ============================================================ */
.perfil{max-width:880px;margin:0 auto}
.perfil-hero{position:relative;background:
  radial-gradient(120% 140% at 0% 0%, rgba(139,124,255,.28), transparent 55%),
  radial-gradient(120% 140% at 100% 0%, rgba(61,220,151,.18), transparent 55%),
  var(--carta);
  border:1px solid var(--borde);border-radius:20px;padding:1.5rem 1.4rem;margin:1.4rem 0;overflow:hidden}
.perfil-hero__top{display:flex;align-items:center;gap:1.1rem;flex-wrap:wrap}
.perfil-hero__avatar{width:78px;height:78px;font-size:2.1rem;display:flex;align-items:center;justify-content:center;border-radius:50%;color:#0d1022;font-weight:800;border:3px solid rgba(255,255,255,.25);box-shadow:0 8px 24px rgba(5,8,24,.4);flex-shrink:0}
.perfil-hero__id{flex:1;min-width:0}
.perfil-hero__id h1{font:800 1.75rem var(--f-display);margin:0 0 .5rem;letter-spacing:-.02em;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.perfil-hero__chips{display:flex;gap:.45rem;flex-wrap:wrap}
.nivel-chip,.racha-chip,.freeze-chip,.monedas-chip,.rol-chip{font-weight:700;font-size:.82rem;padding:.32rem .6rem;border-radius:999px;border:1px solid var(--borde);background:rgba(13,16,34,.45);white-space:nowrap}
.nivel-chip{color:var(--violeta);border-color:rgba(139,124,255,.4)}
.racha-chip{color:var(--oro);border-color:rgba(245,200,75,.4)}
.monedas-chip{color:var(--oro)}
.freeze-chip{color:#7fd4ff}
.rol-chip--admin{color:var(--oro);background:rgba(245,200,75,.14);border-color:rgba(245,200,75,.5)}
.perfil-hero__salir{align-self:flex-start;margin-left:auto}
.perfil-hero__xp{margin-top:1.1rem}
.perfil-hero__xptxt{display:block;color:var(--texto-2);font-size:.82rem;margin-top:.4rem;font-weight:600}
.xp-barra{height:11px;background:rgba(13,16,34,.6);border-radius:6px;overflow:hidden}
.xp-barra i{display:block;height:100%;background:linear-gradient(90deg,var(--violeta),var(--menta));border-radius:6px;transition:width .6s ease}

/* Panel admin */
.admin-panel{background:linear-gradient(135deg,rgba(245,200,75,.1),rgba(139,124,255,.08));border:1px solid rgba(245,200,75,.35);border-radius:18px;padding:1.2rem 1.3rem;margin:0 0 1.4rem}
.admin-panel__cab{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}
.admin-panel__titulo{font:800 1.1rem var(--f-display)}
.admin-acc{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.6rem}
.admin-acc__item{display:flex;align-items:center;gap:.55rem;background:var(--carta);border:1px solid var(--borde);border-radius:12px;padding:.75rem .85rem;color:var(--texto);font-weight:600;font-size:.9rem;transition:border-color .15s,transform .15s}
.admin-acc__item span{font-size:1.2rem}
.admin-acc__item:hover{border-color:var(--oro);transform:translateY(-2px);text-decoration:none}

/* Stats con jerarquía */
.stats-fila{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.7rem;margin:0 0 1.4rem}
.stat{background:var(--carta);border:1px solid var(--borde);border-radius:14px;padding:1rem .7rem;text-align:center;transition:border-color .15s}
.stat:hover{border-color:var(--violeta)}
.stat b{display:block;font:800 1.55rem var(--f-display);font-variant-numeric:tabular-nums;line-height:1.1;margin-bottom:.2rem}
.stat span{color:var(--texto-2);font-size:.78rem;font-weight:600}

/* Categorías fuerte/débil */
.cat-destacadas{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.7rem;margin:0 0 1.4rem}
.cat-destacada{background:var(--carta);border:1px solid var(--borde);border-radius:14px;padding:.9rem 1rem}
.cat-destacada--mejor{border-left:4px solid var(--menta)}
.cat-destacada--peor{border-left:4px solid var(--oro)}
.cat-destacada__lbl{display:block;color:var(--texto-2);font-size:.8rem;font-weight:600;margin-bottom:.25rem}
.cat-destacada__val{font-weight:700}
.cat-destacada__val em{font-style:normal;color:var(--texto-2);font-weight:600}

.perfil-h2{font:800 1.2rem var(--f-display);margin:1.6rem 0 .8rem;letter-spacing:-.01em}
.panel-suave{background:var(--carta);border:1px solid var(--borde);border-radius:16px;padding:1.1rem 1.2rem;margin:0 0 1rem}
.insignias-grid{display:flex;gap:.7rem;flex-wrap:wrap}
.insignia{display:inline-grid;place-items:center;gap:.3rem;background:linear-gradient(160deg,var(--carta-2),var(--carta));border:1px solid var(--borde);border-radius:14px;padding:.9rem .7rem;text-align:center;font-size:.74rem;font-weight:700;width:104px}
.insignia .ico{font-size:1.7rem}

/* ============================================================
   Clases base usadas en varias páginas (faltaban en el CSS)
   ============================================================ */
.panel{background:var(--carta);border:1px solid var(--borde);border-radius:16px;padding:1.2rem 1.3rem;margin:0 0 1rem}
.centrado{text-align:center}
.centrado .form-inline,.centrado form{justify-content:center}
.liga-cab.centrado h1,.liga-cab.centrado p{margin-left:auto;margin-right:auto}
.liga-cab{border-radius:16px}
.liga-intro{text-align:center;max-width:52ch;margin:0 auto 1rem}
.alerta{background:rgba(255,107,122,.12);border:1px solid rgba(255,107,122,.4);color:#ffb3bc;border-radius:12px;padding:.9rem 1.1rem}
.alerta--error{background:rgba(255,107,122,.12);border-color:rgba(255,107,122,.4)}

/* ============================================================
   Pantalla de juego — cabecera, progreso, ítems (pulido UI)
   ============================================================ */
.juego__cab{display:flex;align-items:center;gap:.7rem;margin-bottom:1rem;flex-wrap:wrap}
.juego__modo{font-weight:700}
.juego__progreso{display:flex;gap:5px;flex:1;min-width:80px}
.juego__progreso i{flex:1;max-width:34px;height:6px;border-radius:3px;background:var(--carta-2)}
.juego__progreso i.hecha{background:var(--menta)}
.juego__progreso i.actual{background:var(--violeta);box-shadow:0 0 10px rgba(139,124,255,.6)}
.juego__puntos-caja{display:inline-flex;flex-direction:column;align-items:flex-end;line-height:1}
.juego__puntos-lbl{font-size:.62rem;text-transform:uppercase;letter-spacing:.08em;color:var(--texto-2);font-weight:700}
.juego__puntos-caja .puntos{font:800 1.4rem var(--f-display);color:var(--oro);font-variant-numeric:tabular-nums}
.juego__titulo{font:800 clamp(1.4rem,4.5vw,2rem)/1.15 var(--f-display);margin:.2rem 0 .35rem;letter-spacing:-.02em}
.juego__instr{color:var(--texto-2);margin:0 0 1.3rem;font-size:1.02rem}
/* Ítems arrastrables con más presencia */
.rk-item{cursor:grab}
.rk-item .asa{margin-left:auto;color:var(--texto-2);font-size:1.25rem;opacity:.5;cursor:grab;transition:opacity .15s}
.rk-item:hover .asa{opacity:.9}
.rk-item .nombre{font-weight:700}

/* Stats del admin (clases legacy .stats / .stat__v / .stat__k) */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.7rem;margin:1rem 0 1.6rem}
.stats .stat{text-align:center}
.stat__v{display:block;font:800 1.55rem var(--f-display);font-variant-numeric:tabular-nums;line-height:1.1;margin-bottom:.2rem}
.stat__k{color:var(--texto-2);font-size:.78rem;font-weight:600}

/* Botones pequeños no envuelven texto */
.btn--sm{white-space:nowrap}

/* ============================================================
   Formularios — estilo consistente para labels que envuelven inputs
   (crear.php, admin/*). Etiqueta arriba, control debajo a ancho completo.
   ============================================================ */
form label{display:block;font-weight:600;font-size:.88rem;color:var(--texto);margin-bottom:.85rem}
form label > input,
form label > select,
form label > textarea{
  display:block;width:100%;margin-top:.35rem;
  background:var(--tinta-2);border:1px solid var(--borde);border-radius:10px;
  color:var(--texto);padding:.65rem .8rem;font:inherit}
form label > input:focus,
form label > select:focus,
form label > textarea:focus{border-color:var(--violeta);outline:none;box-shadow:0 0 0 3px rgba(139,124,255,.18)}
form textarea{resize:vertical;min-height:2.6rem}
/* Filas de campos en paralelo */
.form-fila{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.9rem;margin-bottom:.85rem;align-items:end}
.form-fila label{margin-bottom:0}
/* checkbox/label inline (ej. Destacado) */
form label.check,form label.inline{display:inline-flex;align-items:center;gap:.45rem;margin-bottom:.85rem}
form label.check > input,form label.inline > input{width:auto;margin-top:0;display:inline-block}
/* Filas de elementos (nombre + valor + visible + imagen) */
.item-fila{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}
/* Botones de acción del form con separación */
form .btn{margin-top:.4rem}

/* Inputs sueltos (no envueltos en label) dentro de filas de formulario */
.form-fila > input,.form-fila > select,.form-fila > textarea,
.item-fila > input{
  width:100%;background:var(--tinta-2);border:1px solid var(--borde);border-radius:10px;
  color:var(--texto);padding:.65rem .8rem;font:inherit}
.form-fila > input:focus,.item-fila > input:focus{border-color:var(--violeta);outline:none;box-shadow:0 0 0 3px rgba(139,124,255,.18)}

/* ============================================================
   Barra de navegación del panel admin (muchos enlaces)
   ============================================================ */
.nav--admin{display:flex !important;flex-wrap:wrap;gap:.3rem .9rem;flex:1;margin-left:.8rem;align-items:center}
.nav--admin a{font-size:.86rem;color:var(--texto-2);font-weight:600;white-space:nowrap;padding:.2rem 0}
.nav--admin a:hover{color:var(--texto)}
.topbar__in .nav--admin + .topbar__acts{flex-shrink:0}
@media (max-width:900px){
  .nav--admin{gap:.2rem .7rem;margin-left:.5rem}
  .nav--admin a{font-size:.8rem}
}

/* ============================================================
   Página de categorías — cuadrícula de tarjetas
   ============================================================ */
.grilla-cats{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.8rem;margin:1.4rem 0}
.cat-card{position:relative;display:flex;flex-direction:column;align-items:center;gap:.4rem;background:var(--carta);border:1px solid var(--borde);border-radius:16px;padding:1.4rem 1rem;color:var(--texto);font-weight:700;text-align:center;transition:border-color .15s,transform .15s}
.cat-card:hover{border-color:var(--menta);transform:translateY(-3px);text-decoration:none}
.cat-card__icono{font-size:2rem;line-height:1}
.cat-card__nombre{font-size:1rem}
.cat-card__n{position:absolute;top:.6rem;right:.7rem;font-size:.72rem;font-weight:700;color:var(--texto-2);background:var(--tinta-2);border:1px solid var(--borde);border-radius:999px;padding:.1rem .5rem;min-width:1.4rem}
