/* ============================================================
   ConJuanjugator · Identidad visual SILABOS
   Restyling — la lógica y los nombres de clase se conservan.
   Paleta neón "arcade" + tipografías Orbitron / DM Sans.
   ============================================================ */

:root{
  /* superficies */
  --bg:#0A0A12;
  --bg-soft:#0E0E1A;
  --surface:rgba(255,255,255,0.045);
  --surface-2:rgba(255,255,255,0.07);
  --surface-3:rgba(255,255,255,0.10);
  --border:rgba(255,255,255,0.11);
  --border-strong:rgba(255,255,255,0.18);

  /* texto (alto contraste, legible a pleno sol) */
  --text:#EDEDF5;
  --text-soft:#C4C4D6;
  --text-dim:#9A9AB0;
  --on-accent:#0A0A12;

  /* acentos neón */
  --fuxia:#FF2DA6;
  --morado:#A855F7;
  --cian:#00C8FF;
  --amarillo:#FACC15;
  --verde:#39FF14;
  --color-primary:#39FF14;
  --rojo:#FF4D6D;
  --naranja:#FF8A3D;
  --blanco:#F4F4FF;

  /* tipografía */
  --font-display:'Orbitron',sans-serif;
  --font-body:'DM Sans','Inter',sans-serif;

  /* formas */
  --radius:14px;
  --radius-sm:11px;
  --radius-lg:18px;

  /* glows */
  --glow-cian:0 0 18px rgba(0,200,255,.35);
  --glow-fuxia:0 0 18px rgba(255,45,166,.35);
  --glow-morado:0 0 18px rgba(168,85,247,.35);
  --glow-verde:0 0 18px rgba(57,255,20,.30);
}

*{box-sizing:border-box;}

body{
  margin:0;
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  padding-bottom:74px; /* hueco para el dock */
  min-height:100vh;
  position:relative;
}

/* Rejilla synthwave sutil — solo cuando el body lleva .grid-on (zonas de juego) */
body.grid-on::before{
  content:"";
  position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background-image:
    linear-gradient(rgba(0,200,255,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(168,85,247,.06) 1px,transparent 1px);
  background-size:44px 44px;
  -webkit-mask-image:linear-gradient(to bottom,transparent,#000 26%,#000 74%,transparent);
          mask-image:linear-gradient(to bottom,transparent,#000 26%,#000 74%,transparent);
}

#app-container{
  position:relative;
  z-index:1;
  max-width:820px;
  margin:0 auto;
  padding:26px 18px 12px;
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
}

@media (min-width:768px){
  #app-container{padding:34px 24px 16px;}
}

.app-logo{
  width:120px;height:auto;display:block;margin:6px auto 18px;
  filter:drop-shadow(0 0 18px rgba(168,85,247,.35));
}

/* ===== Tipografía ===== */
h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:700;
  letter-spacing:.02em;
  color:var(--text);
  line-height:1.2;
}
h1{font-size:1.9rem;margin:.2em 0 .4em;}
h2{
  font-size:1.5rem;margin:.2em 0 .3em;
  background:linear-gradient(92deg,var(--cian),var(--fuxia) 70%,var(--morado));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 14px rgba(255,45,166,.25));
}
h3{font-size:1.2rem;color:var(--cian);margin:.2em 0 .3em;}
h4{font-size:1rem;font-weight:500;color:var(--text);margin:.2em 0 .3em;}

p{
  font-family:var(--font-body);
  color:var(--text-soft);
  line-height:1.65;
  font-size:1rem;
  margin:.4em 0;
  max-width:64ch;
}

/* ===== Botones genéricos (menús) ===== */
button{
  font-family:var(--font-body);
  background:var(--surface);
  color:var(--text);
  padding:15px 22px;
  margin:7px 0;
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  cursor:pointer;
  font-size:1.02rem;
  font-weight:600;
  transition:transform .2s ease, border-color .2s ease, background .2s ease, box-shadow .2s ease, color .2s ease;
  flex-grow:1;
  max-width:430px;
  width:100%;
  position:relative;
}
button:hover{
  background:var(--surface-2);
  border-color:var(--cian);
  color:var(--text);
  transform:translateY(-2px);
  box-shadow:0 0 0 1px var(--cian), 0 6px 22px rgba(0,0,0,.35);
}
button:active{
  transform:translateY(0);
  box-shadow:0 0 0 1px var(--cian);
}
button:focus-visible{
  outline:2px solid var(--cian);
  outline-offset:2px;
}

/* Botón "Volver" — discreto, neutro */
#app-container .back-button{
  background:transparent !important;
  color:var(--text-soft) !important;
  border:1px solid var(--border) !important;
  font-weight:500 !important;
  width:auto !important;
  max-width:100% !important;
  min-width:240px !important;
  display:block !important;
  margin:22px auto 4px !important;
  text-align:center !important;
}
#app-container .back-button:hover{
  background:var(--surface) !important;
  color:var(--text) !important;
  border-color:var(--cian) !important;
  box-shadow:none !important;
}
#app-container .back-button:active{
  background:var(--surface-2) !important;
}

/* ===== Inputs ===== */
input[type="text"],
input[type="number"]{
  background:var(--surface-2);
  color:var(--text);
  border:1px solid var(--border-strong);
  border-radius:10px;
  padding:11px 14px;
  font-family:var(--font-body);
  font-size:1.05rem;
  text-align:center;
  transition:border-color .2s ease, box-shadow .2s ease;
}
input[type="text"]:focus,
input[type="number"]:focus{
  outline:none;
  border-color:var(--cian);
  box-shadow:var(--glow-cian);
}
input[type="number"]{
  width:90px;
}

/* ============================================================
   DOCK inferior  (estructura conservada, look SILABOS)
   ============================================================ */
.dock-button:hover,
.dock-button:focus-visible{
  color:var(--cian);
  background:rgba(0,200,255,.10);
  transform:translateY(-2px);
  box-shadow:none;
  outline:none;
}
.dock-button:hover img,
.dock-button:focus-visible img{
  transform:scale(1.12);
  /* cian */
  filter:invert(64%) sepia(86%) saturate(2519%) hue-rotate(155deg) brightness(101%) contrast(101%);
}
/* el tercer botón (Jugar) en fuxia al activarse */

body{padding-bottom:74px;}
/* ============================================================
   PARTE 2 — Componentes
   ============================================================ */

/* ===== Menús / submenús (botones agrupados) ===== */
.sub-menu-container,
.activity-wrapper,
.opciones-container{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:4px;
  width:100%;
  max-width:460px;
  margin:0 auto;
}

/* Etiqueta de grupo (Indicativo / Subjuntivo) si el JS la usa con .time-row-group title */
.group-label,
.tiempo-titulo{
  font-family:var(--font-display);
  font-weight:500;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:.82rem;
  color:var(--cian);
}

/* ===== Área de juego (drag & drop) ===== */
.game-area{
  display:flex;
  flex-direction:column;
  gap:26px;
  width:100%;
  margin-top:16px;
}

.drag-container{
  background:var(--surface);
  border:1.5px dashed var(--fuxia);
  border-radius:var(--radius);
  min-height:96px;
  padding:18px;
  display:flex;
  flex-wrap:wrap;
  gap:13px;
  justify-content:center;
  align-items:center;
  box-shadow:inset 0 0 24px rgba(255,45,166,.10);
  position:sticky;
  top:0;
  z-index:100;
  /* fondo sólido para tapar el scroll detrás */
  background-color:#0E0E1A;
}

.draggable-verb{
  background:linear-gradient(135deg,var(--fuxia),var(--morado));
  color:#fff;
  padding:11px 18px;
  border-radius:10px;
  cursor:grab;
  font-family:var(--font-display);
  font-weight:700;
  font-size:.95rem;
  border:none;
  width:auto;
  max-width:none;
  margin:0;
  box-shadow:0 0 16px rgba(168,85,247,.45);
  transition:transform .18s ease, box-shadow .25s ease, filter .25s ease;
}
.draggable-verb:hover{
  transform:translateY(-2px);
  box-shadow:0 0 22px rgba(255,45,166,.6);
  filter:brightness(1.08);
}
.draggable-verb:active{cursor:grabbing;transform:scale(.96);}

.draggable-verb.correct{
  background:rgba(57,255,20,.14);
  color:var(--verde);
  border:1px solid var(--verde);
  cursor:default;
  box-shadow:0 0 14px rgba(57,255,20,.3);
  opacity:1;
}
.draggable-verb.dragging{opacity:.5;}

.drop-zones-container{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
  gap:16px;
  width:100%;
}

.drop-zone{
  background:var(--surface);
  border:1.5px dashed var(--border-strong);
  border-radius:var(--radius);
  min-height:140px;
  padding:16px 14px;
  text-align:center;
  box-shadow:0 4px 18px rgba(0,0,0,.25);
  transition:border-color .25s ease, box-shadow .25s ease, background .25s ease;
  display:flex;
  flex-direction:column;
  align-items:center;
}
.drop-zone.drag-over{
  border-color:var(--verde);
  border-style:solid;
  background:rgba(57,255,20,.07);
  box-shadow:0 0 24px rgba(57,255,20,.3) inset;
}
.drop-zone h4{
  margin-top:0;
  font-family:var(--font-display);
  font-weight:500;
  font-size:.85rem;
  letter-spacing:.02em;
  color:var(--cian);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}
.drop-zone h4 .icon-circle{
  background:var(--surface-3);
  border:1px solid var(--border);
  border-radius:50%;
  padding:4px;
  display:inline-flex;
  justify-content:center;
  align-items:center;
  width:1.9em;height:1.9em;
  font-size:1.05em;
  line-height:1;
  vertical-align:middle;
}
.drop-zone .dropped-verbs{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:12px;
  justify-content:center;
  width:100%;
  min-height:48px;
  border-top:1px dashed var(--border);
  padding-top:12px;
}

/* etiqueta de tipo de irregularidad sobre el verbo soltado */
.verb-irregularity-label{
  font-size:.72rem;
  color:var(--text-dim);
  display:block;
}

/* ===== Tipos de verbo (colores por categoría) ===== */
.verb-regular .icon-circle,
.verb-regular{ }
.verb-bota{color:var(--cian);}
.verb-sombrero{color:var(--amarillo);}
.verb-botasombrero{color:var(--fuxia);}
.verb-yogo{color:var(--morado);}

/* ===== Display del verbo actual (móvil) ===== */
.current-verb-display-container{
  background:rgba(255,45,166,.06);
  border:1px solid var(--fuxia);
  border-radius:var(--radius);
  padding:16px;
  box-shadow:var(--glow-fuxia);
  margin:0 auto 18px;
  max-width:320px;
}
.mobile-verb-to-classify{
  display:inline-block;
  font-family:var(--font-display);
  font-weight:700;
  font-size:1.2rem;
  padding:8px 18px;
  border-radius:10px;
  background:linear-gradient(135deg,var(--fuxia),var(--morado));
  color:#fff;
  box-shadow:0 0 16px rgba(168,85,247,.5);
  cursor:pointer;
  transition:transform .18s ease, box-shadow .25s ease;
  border:none;width:auto;max-width:none;
}
.mobile-verb-to-classify:hover{transform:translateY(-2px);box-shadow:0 0 22px rgba(255,45,166,.6);}
.mobile-verb-to-classify:active{transform:scale(.96);}
.mobile-verb-to-classify.selected{
  outline:2px solid var(--amarillo);
  box-shadow:0 0 22px rgba(250,204,21,.6);
}
.mobile-category-button{
  background:var(--surface);
  color:var(--text);
  border:1px solid var(--border-strong);
  border-radius:var(--radius-sm);
  padding:14px;
  font-family:var(--font-body);
  font-weight:600;
  transition:.2s ease;
}
.mobile-category-button:hover{
  border-color:var(--cian);
  background:var(--surface-2);
  box-shadow:0 0 0 1px var(--cian);
}
.mobile-category-button:active{transform:scale(.98);}
.dropped-verbs .mobile-verb-to-classify,
.mobile-verb-to-classify-classified{
  background:rgba(57,255,20,.14);
  color:var(--verde);
  border:1px solid var(--verde);
  box-shadow:0 0 12px rgba(57,255,20,.25);
  font-size:.95rem;
}

/* ===== Mensajes de resultado ===== */
.result-message{
  padding:12px 16px;
  border-radius:10px;
  margin-top:18px;
  font-family:var(--font-body);
  font-weight:600;
  max-width:430px;
}
.result-message.correct{
  background:rgba(57,255,20,.1);
  color:var(--verde);
  border:1px solid var(--verde);
}
.result-message.incorrect{
  background:rgba(255,77,109,.1);
  color:var(--rojo);
  border:1px solid var(--rojo);
}

/* ===== Inputs de conjugación ===== */
.conjugation-group{margin:14px 0;width:100%;max-width:430px;}
.conjugation-group label{color:var(--text-soft);font-size:.95rem;}
.conjugation-group input{margin-top:6px;}

/* ===== Radios / checkboxes ===== */
.radio-group{display:flex;flex-direction:column;gap:10px;align-items:center;width:100%;max-width:430px;}
.radio-group input[type="radio"]{display:none;}
.radio-group label{
  background:var(--surface);
  color:var(--text);
  padding:12px 20px;
  border-radius:var(--radius-sm);
  border:1px solid var(--border);
  cursor:pointer;
  width:100%;
  text-align:center;
  transition:.2s ease;
}
.radio-group label:hover{border-color:var(--cian);background:var(--surface-2);}
.radio-group input[type="radio"]:checked + label{
  border-color:var(--cian);
  background:rgba(0,200,255,.12);
  color:var(--cian);
  box-shadow:0 0 0 1px var(--cian);
}
.checkboxes-container{
  display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:14px 0;
}
.checkboxes-container div{display:flex;align-items:center;gap:6px;}
.checkboxes-container label{color:var(--text-soft);font-size:.92rem;}

/* ===== Info boxes / explicaciones (zona Aprender, sobria) ===== */
.info-section,
.explanation-main-container{
  width:100%;
  display:flex;
  flex-direction:column;
  gap:18px;
  align-items:stretch;
}
.info-box,
.explanation-box,
.detalle-verbo-container{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:22px 24px;
  text-align:left;
  box-shadow:0 2px 14px rgba(0,0,0,.2);
}
.info-box-icon{
  font-size:1.6rem;
  margin-bottom:6px;
}
.info-box h3,
.detalle-verbo-container h3{
  color:var(--cian);
  margin-top:0;margin-bottom:8px;
  font-size:1.2rem;
}
.info-box h4,
.detalle-verbo-container h4{color:var(--text);}
.info-box p,
.detalle-verbo-container p{color:var(--text);}
.info-box p.description{color:var(--text-soft);}
.info-box p.example{
  background:rgba(0,200,255,.05);
  border-left:2px solid var(--cian);
  border-radius:6px;
  padding:10px 14px;
  color:var(--text);
}
.info-box strong,
.detalle-verbo-container strong,
.bold-text{color:var(--verde);font-weight:700;}

.formacion-title,
.irregular-list-title,
.sub-list-title{
  font-family:var(--font-display);
  color:var(--amarillo);
  font-weight:500;
  font-size:.95rem;
  letter-spacing:.02em;
  margin-top:6px;
}

/* ===== Tablas de conjugación (legibles sobre fondo oscuro) ===== */
.conjugation-tables-wrapper{
  display:flex;
  justify-content:center;
  gap:20px;
  flex-wrap:wrap;
  margin:20px 0 30px;
  width:100%;
}
.conjugation-table-box{
  flex:1;
  min-width:260px;
  max-width:340px;
  background:var(--surface);
  border:1px solid var(--border);
  padding:16px;
  border-radius:var(--radius);
  box-shadow:0 4px 18px rgba(0,0,0,.25);
  box-sizing:border-box;
  color:var(--text);
  text-align:center;
}
.conjugation-table-box h4{
  color:var(--cian);
  margin-bottom:14px;
  font-size:1rem;
  font-weight:700;
}
.conjugation-table{
  width:100%;
  border-collapse:collapse;
  margin-top:8px;
  table-layout:fixed;
}
.conjugation-table th,
.conjugation-table td{
  padding:11px 12px;
  border:1px solid var(--border);
  line-height:1.4;
  text-align:left;
  font-size:.9rem;
  color:var(--text);
  word-wrap:break-word;
}
.conjugation-table th{
  font-family:var(--font-display);
  font-weight:500;
  font-size:.78rem;
  color:var(--amarillo);
  letter-spacing:.02em;
}
.conjugation-table tr:nth-child(odd){background:rgba(255,255,255,0.03);}
.conjugation-table tr:nth-child(even){background:transparent;}

/* ===== Listas de verbos ===== */
.verbos-list-container,
.irregular-verbs-list{
  width:100%;
  max-width:760px;
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(140px,1fr));
  gap:8px;
}
.boton-verbo-lista{
  background:var(--surface);
  color:var(--text);
  border:1px solid var(--border);
  border-radius:10px;
  padding:9px 10px;
  font-family:var(--font-body);
  font-weight:600;
  font-size:.92rem;
  width:100%;
  max-width:none;
  margin:0;
  text-align:center;
  transition:.18s ease;
  transition:.2s ease;
}
.boton-verbo-lista:hover{
  border-color:var(--cian);
  background:var(--surface-2);
  transform:translateY(-2px);
  box-shadow:0 0 0 1px var(--cian),0 4px 14px rgba(0,0,0,.3);
}
.irregular-verbs-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
  gap:12px;
  list-style:none;
  padding:0;
  width:100%;
}
.irregular-verbs-grid li{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:10px;
  padding:12px;
  text-align:left;
}
.irregular-verbs-grid li ul{margin:6px 0 0;padding-left:16px;}
.irregular-verbs-grid li ul li{background:none;border:none;padding:2px 0;color:var(--text-soft);font-size:.88rem;}

/* ===== Modal ===== */
.modal-overlay{
  position:fixed;inset:0;
  background:rgba(5,5,12,.78);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  display:none;
  justify-content:center;
  align-items:center;
  z-index:2000;
  padding:20px;
}
.modal-overlay.active,
.modal-overlay[style*="flex"]{display:flex;}
.modal-content{
  background:#12121E;
  border:1px solid var(--morado);
  border-radius:16px;
  padding:26px;
  max-width:560px;
  width:100%;
  position:relative;
  box-shadow:0 0 50px rgba(168,85,247,.4);
  max-height:88vh;
  overflow-y:auto;
}
.modal-close-btn{
  position:absolute;
  top:14px;right:16px;
  width:34px;height:34px;
  border-radius:8px;
  background:var(--surface);
  border:1px solid var(--border);
  color:var(--text);
  font-size:1.4rem;
  line-height:1;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
}
.modal-close-btn:hover{border-color:var(--fuxia);color:var(--fuxia);}
.modal-title{
  font-family:var(--font-display);
  color:var(--morado);
  font-size:1.15rem;
  margin:0 0 16px;
  padding-right:36px;
}
.modal-content img{
  max-width:100%;
  height:auto;
  border-radius:10px;
  display:block;
}

/* ===== Animaciones (respetando reduced-motion) ===== */
@keyframes fadeInScale{from{opacity:0;transform:scale(.92);}to{opacity:1;transform:scale(1);}}
@keyframes fadeOut{from{opacity:1;}to{opacity:0;}}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
  }
  body.grid-on::before{display:none;}
}
/* ============================================================
   PARTE 3 — Responsive (breakpoints y comportamientos conservados)
   ============================================================ */

@media (max-width:768px){
  body{display:block;}
  #app-container{
    width:100%;
    max-width:none;
    border-radius:0;
    padding:22px 14px 12px;
    display:flex;
    flex-direction:column;
    align-items:center;
  }
  .app-logo{max-width:200px;width:70%;}

  h2{font-size:1.7rem;}
  h3{font-size:1.25rem;}
  p{font-size:1rem;}

  button{
    font-size:1.05rem;
    width:90%;
    max-width:380px;
  }
  #app-container .back-button{
    font-size:1rem;
    width:90% !important;
    max-width:100% !important;
  }

  .drop-zones-container{
    grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  }
  .drop-zone{margin:0 4px;}

  .conjugation-tables-wrapper{flex-direction:column;align-items:center;}
  .conjugation-table-box{
    max-width:100%;
    min-width:unset;
    width:100%;
  }
  .conjugation-table th,
  .conjugation-table td{font-size:.85rem;padding:9px 10px;}

  .irregular-verbs-grid{grid-template-columns:1fr 1fr;}
}

@media (max-width:768px) and (orientation:portrait){
  #app-container{width:100%;border-radius:0;}
  .app-logo{max-width:240px;}
  h2{font-size:1.85rem;}
  button{
    font-size:1.1rem;
    width:95%;
    max-width:450px;
  }
  p{font-size:1.05rem;}
}

@media (max-width:480px){
  h2{font-size:1.5rem;}
  button{width:95%;font-size:1rem;}
  .conjugation-table th,
  .conjugation-table td{font-size:.8rem;padding:8px;}
  .drop-zones-container{grid-template-columns:1fr;}
  .irregular-verbs-grid{grid-template-columns:1fr;}
  .modal-content{padding:20px;}
  .modal-title{font-size:1.05rem;}
}

@media (max-height:600px){
  body{padding-bottom:64px;}
}

/* La insignia del dock conserva sus colores (sin el filtro invert de los iconos) */
.dock-home:hover .dock-insignia,
.dock-home:focus-visible .dock-insignia{
  filter:drop-shadow(0 0 10px rgba(0,200,255,.7)) !important;
  transform:scale(1.12);
}
.dock-home:hover,
.dock-home:focus-visible{color:var(--morado);background:rgba(168,85,247,.10);}

/* ===== Tarjetas del menú de inicio (.text/.subtitle/.button-icon) ===== */
.button-icon{display:flex;justify-content:center;margin-bottom:2px;}
.button-icon svg{transition:transform .25s ease;}
.text{
  font-family:var(--font-display);
  font-weight:700;
  font-size:1.12rem;
  letter-spacing:.01em;
}
.subtitle{
  font-family:var(--font-body);
  font-weight:400;
  font-size:.86rem;
  opacity:.92;
}

/* ===== Logo de cabecera en cápsula SILABOS ===== */
@media (max-width:480px){
}

/* Título de instrucción de menús (sobrio, sin degradado fuerte) */
.menu-instruccion{
  font-family:var(--font-display) !important;
  font-weight:500 !important;
  font-size:1.3rem !important;
  color:var(--text-soft) !important;
  background:none !important;
  -webkit-text-fill-color:var(--text-soft) !important;
  filter:none !important;
  letter-spacing:.06em;
}
.ico{width:30px;height:30px;flex:none;stroke-width:1.7;fill:none;stroke-linecap:round;stroke-linejoin:round}
/* marca */
.ins-big{width:118px;height:auto;display:block;margin:0 auto;filter:drop-shadow(0 0 22px rgba(168,85,247,.35))}
.logo-foot{width:160px;height:auto;display:block;margin:30px auto 6px;opacity:.85}
.ins-dock{width:30px;height:30px;display:block}
.ins-watermark{position:fixed;right:14px;bottom:108px;width:80px;height:auto;opacity:.13;z-index:1;pointer-events:none}
/* INICIO */
.logo-zone{text-align:center;margin:14px 0 26px}
.logo-zone .mark{font-family:var(--font-display);font-weight:900;font-size:2.1rem;letter-spacing:.02em;margin-top:14px;
  background:linear-gradient(92deg,var(--cian),var(--fuxia) 60%,var(--morado));-webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 0 16px rgba(255,45,166,.3))}
.logo-zone .tag{color:var(--text-soft);font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;margin-top:6px}
.home-cards{display:flex;flex-direction:column;gap:18px;max-width:430px;margin:0 auto}
.home-card{position:relative;overflow:hidden;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);padding:26px 22px;cursor:pointer;display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px;transition:transform .25s cubic-bezier(.4,0,.2,1),box-shadow .25s,border-color .25s}
.home-card .icwrap{width:58px;height:58px;border-radius:16px;display:grid;place-items:center;margin-bottom:6px;background:var(--surface-2);border:1px solid var(--border);transition:.25s}
.home-card h3{font-family:var(--font-display);font-weight:700;font-size:1.15rem}
.home-card p{color:var(--text-soft);font-size:.9rem;max-width:34ch}
.home-card:hover{transform:translateY(-3px)}
.home-card.learn:hover{border-color:var(--cian);box-shadow:0 0 0 1px var(--cian),0 8px 30px rgba(0,200,255,.18)}
.home-card.play:hover{border-color:var(--fuxia);box-shadow:0 0 0 1px var(--fuxia),0 8px 30px rgba(255,45,166,.22)}
.home-card.learn h3{color:var(--cian)}
.home-card.learn .ico{stroke:var(--cian)}
.home-card.play h3{color:var(--fuxia)}
.home-card.play .ico{stroke:var(--fuxia)}
.home-card.learn:hover .icwrap{border-color:var(--cian);box-shadow:0 0 16px rgba(0,200,255,.3)}
.home-card.play:hover .icwrap{border-color:var(--fuxia);box-shadow:0 0 16px rgba(255,45,166,.3)}
/* SUBMENÚ JUEGOS — formato a lo largo (filas anchas) */
.row-list{display:flex;flex-direction:column;gap:14px;max-width:640px;margin:0 auto}
.row-card{display:flex;align-items:center;gap:18px;text-align:center;width:100%;
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 22px;cursor:pointer;transition:.22s}
.row-card .icwrap{width:50px;height:50px;border-radius:13px;display:grid;place-items:center;background:var(--surface-2);border:1px solid var(--border);flex:none;transition:.22s}
.row-card .icwrap .ico{width:26px;height:26px;stroke:var(--accent,var(--cian))}
.row-card .txt{flex:1}
.row-card .txt h3{font-family:var(--font-display);font-weight:700;font-size:1.28rem;margin-bottom:4px;color:var(--text)}
.row-card .txt p{color:var(--text-soft);font-size:.88rem}
.row-card:hover{transform:translateX(5px);border-color:var(--accent,var(--cian));background:var(--surface-2);box-shadow:0 0 0 1px var(--accent,var(--cian)),0 6px 22px rgba(0,0,0,.3)}
.row-card:hover .icwrap{border-color:var(--accent,var(--cian));box-shadow:0 0 14px var(--accent,var(--cian))}
.back-link{display:flex;align-items:center;justify-content:center;gap:8px;max-width:640px;margin:16px auto 0;color:var(--text-soft);background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);padding:13px;cursor:pointer;font-family:var(--font-body);font-weight:500;font-size:.92rem;transition:.2s}
.back-link:hover{color:var(--text);border-color:var(--cian)}
.back-link .ico{width:18px;height:18px;stroke:currentColor}
/* tiempos columna (igual que v2) */
.menu-list{display:flex;flex-direction:column;gap:13px;max-width:430px;margin:0 auto}
.menu-btn{font-family:var(--font-body);font-weight:600;font-size:1.02rem;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px 20px;cursor:pointer;transition:.22s;display:flex;align-items:center;justify-content:center;gap:11px;text-align:center}
.menu-btn:hover{transform:translateY(-2px);border-color:var(--accent,var(--cian));background:var(--surface-2);box-shadow:0 0 0 1px var(--accent,var(--cian)),0 6px 22px rgba(0,0,0,.3)}
.group-label{display:flex;align-items:center;gap:10px;max-width:430px;margin:22px auto 12px;font-family:var(--font-display);font-weight:500;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase}
.group-label::after{content:"";flex:1;height:1px;background:var(--border)}
.group-label.ind{color:var(--cian)}
.group-label.ind::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--cian);box-shadow:0 0 10px var(--cian)}
.group-label.sub{color:var(--amarillo)}
.group-label.sub::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--amarillo);box-shadow:0 0 10px var(--amarillo)}
/* JUEGO */
.game-head{text-align:center;margin-bottom:14px}
.game-head .score{display:inline-flex;gap:20px;margin-top:10px;font-family:var(--font-display);font-size:.82rem;color:var(--text-soft)}
.game-head .score b{color:var(--amarillo);font-size:1.1rem;display:block}
.help-btn{display:inline-flex;align-items:center;gap:7px;margin:0 auto 18px;font-family:var(--font-body);font-weight:600;font-size:.85rem;color:var(--morado);background:rgba(168,85,247,.1);border:1px solid var(--morado);border-radius:999px;padding:8px 16px;cursor:pointer;transition:.2s}
.help-btn:hover{background:rgba(168,85,247,.2);box-shadow:0 0 16px rgba(168,85,247,.4)}
.help-btn .ico{width:18px;height:18px;stroke:var(--morado)}
.center-row{display:flex;justify-content:center}
.current-verb{margin:0 auto 20px;max-width:280px;text-align:center;padding:18px;border:1px solid var(--fuxia);border-radius:var(--radius);background:rgba(255,45,166,.06);box-shadow:0 0 24px rgba(255,45,166,.25)}
.current-verb .lbl{font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text-soft)}
.chip{display:inline-block;font-family:var(--font-display);font-weight:700;font-size:1.3rem;margin-top:6px;padding:8px 18px;border-radius:10px;cursor:grab;user-select:none;background:linear-gradient(135deg,var(--fuxia),var(--morado));color:#fff;box-shadow:0 0 18px rgba(168,85,247,.5);transition:transform .15s}
.chip:active{cursor:grabbing;transform:scale(.95)}
.drop-zones{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;max-width:620px;margin:0 auto}
.drop-zones{grid-template-columns:1fr}
.drop-zone{min-height:130px;border:1px dashed var(--border);border-radius:var(--radius);padding:14px 12px;background:var(--surface);transition:.2s;text-align:center}
.drop-zone .catico{width:44px;height:44px;margin:0 auto 8px;stroke-width:1.6;fill:none;stroke-linecap:round;stroke-linejoin:round}
.drop-zone h4{font-family:var(--font-display);font-weight:500;font-size:.82rem;margin-bottom:10px;color:var(--cian);letter-spacing:.03em}
.drop-zone.over{border-color:var(--verde);border-style:solid;background:rgba(57,255,20,.07);box-shadow:0 0 22px rgba(57,255,20,.3) inset}
.dropped{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}
.dropped .placed{font-family:var(--font-display);font-size:.82rem;padding:5px 12px;border-radius:8px;background:rgba(57,255,20,.12);color:var(--verde);border:1px solid var(--verde);box-shadow:0 0 12px rgba(57,255,20,.25);animation:pop .3s}
.hint{text-align:center;color:var(--text-soft);font-size:.85rem;margin-top:16px}
.modal-icons{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:8px}
.modal-icons .mi{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:10px}
.modal-icons .mi svg{width:34px;height:34px;flex:none;fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.modal-icons .mi span{font-size:.82rem;color:var(--text)}
/* NAV B abajo, con insignia = Inicio */
.botnav{position:fixed;left:0;right:0;bottom:0;z-index:50;background:rgba(10,10,18,.92);backdrop-filter:blur(14px);border-top:1px solid var(--border);padding:8px 12px}
.botnav .inner{max-width:640px;margin:0 auto;display:flex;align-items:center;gap:10px}
.botnav .home{display:flex;flex-direction:column;align-items:center;gap:2px;background:none;border:none;cursor:pointer;color:var(--text-soft);font-size:.58rem;font-family:var(--font-body);padding:2px 4px;border-radius:12px;transition:.2s}
.botnav .home .ins-dock{filter:drop-shadow(0 0 5px rgba(168,85,247,.5));transition:.2s}
.botnav .home:hover{color:var(--cian)}
.botnav .home:hover .ins-dock{filter:drop-shadow(0 0 10px rgba(0,200,255,.7))}
.botnav .sep{width:1px;height:34px;background:var(--border)}
.botnav .pri{display:flex;gap:7px;flex:1;justify-content:center}
.botnav .pri button{display:flex;flex-direction:column;align-items:center;gap:3px;font-family:var(--font-body);font-weight:600;font-size:.62rem;padding:7px 11px;border-radius:11px;border:1px solid transparent;background:transparent;color:var(--text-soft);cursor:pointer;transition:.2s}
.botnav .pri button .ico{width:22px;height:22px;stroke:var(--text-soft);transition:.2s}
.botnav .pri button:hover,.botnav .pri button.active{color:var(--cian);background:rgba(0,200,255,.1)}
.botnav .pri button:hover .ico,.botnav .pri button.active .ico{stroke:var(--cian)}
.botnav .pri button.play:hover,.botnav .pri button.play.active{color:var(--fuxia);background:rgba(255,45,166,.1)}
.botnav .pri button.play:hover .ico,.botnav .pri button.play.active .ico{stroke:var(--fuxia)}
.botnav .util{display:flex;gap:5px}
.botnav .util button{width:40px;height:40px;border-radius:10px;border:1px solid var(--border);background:transparent;cursor:pointer;transition:.2s;display:grid;place-items:center}
.botnav .util button .ico{width:19px;height:19px;stroke:var(--text-soft)}
.botnav .util button:hover{border-color:var(--cian)}
.botnav .util button:hover .ico{stroke:var(--cian)}

/* ===== Barra agrupada SILABOS (v5) sobre el nav real ===== */
#main-dock-menu.botnav{
  position:fixed;left:0;right:0;bottom:0;z-index:1000;
  background:rgba(10,10,18,.92);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-top:1px solid var(--border);padding:8px 12px;height:auto;display:block;
}
body{padding-bottom:84px;}

/* mapear iconos .ico de la v5 (stroke neón) */
.ico{stroke:currentColor;}

/* La insignia del Inicio en la barra conserva color (no filtros) */
#main-dock-menu .ins-dock{filter:drop-shadow(0 0 5px rgba(168,85,247,.5));}

/* ===== FIX barra agrupada: neutralizar button genérico dentro del nav ===== */
#main-dock-menu.botnav button{
  margin:0;
  width:auto;
  max-width:none;
  flex-grow:0;
  box-shadow:none;
}
#main-dock-menu.botnav button:hover{
  transform:none;
  box-shadow:none;
}
/* insignia del botón Inicio: tamaño fijo para que el botón no se estire */
#main-dock-menu .home .ins-dock{
  width:30px;height:30px;display:block;
}
/* asegurar centrado de los iconos guardar/cargar */
#main-dock-menu .util button{
  padding:0;
  display:grid;
  place-items:center;
}
#main-dock-menu .util button .ico{display:block;}
/* inner centrado y con aire correcto */
#main-dock-menu .inner{width:100%;}

/* ===== FIX final barra: util con tamaño correcto, logo pie legible ===== */
#main-dock-menu.botnav .util button{
  width:40px !important;
  height:40px !important;
  padding:0 !important;
}
#main-dock-menu.botnav .util{margin-right:2px;}
/* logo del pie legible */
.logo-foot{width:150px !important;max-width:60vw;opacity:.9;margin:26px auto 8px;}

/* subtítulo de sección (instrucción bajo el h2) */
.section-sub{text-align:center;color:var(--text-soft);font-size:.95rem;margin:-2px auto 18px;max-width:64ch;}

/* ===== Juego: título de zona con icono arriba (layout v5) ===== */
.drop-zone h4{
  flex-direction:column;
  gap:6px;
}
.drop-zone h4 .catico{margin:0 auto;}
.drop-zone h4 span{display:block;}
/* el icono fuera del h4 (por si acaso) y dentro, mismo tamaño */
.drop-zone .catico{width:42px;height:42px;}



/* ===== Colores por categoría de juego (únicos, sin repetir, distintos del verde de acierto) ===== */
.dz-bota .catico{stroke:var(--cian)}       .dz-bota h4{color:var(--cian)}        /* 👢 bota */
.dz-somb .catico{stroke:var(--amarillo)}   .dz-somb h4{color:var(--amarillo)}    /* 🎩 sombrero */
.dz-bs .catico{stroke:var(--fuxia)}        .dz-bs h4{color:var(--fuxia)}         /* 🎩👢 bota con sombrero */
.dz-radical .catico{stroke:var(--morado)}  .dz-radical h4{color:var(--morado)}   /* √ radical */
.dz-reg .catico{stroke:var(--blanco)}      .dz-reg h4{color:var(--blanco)}       /* ✓ regular = blanco */
.dz-total .catico{stroke:var(--naranja)}   .dz-total h4{color:var(--naranja)}    /* 👽 completo irregular = naranja */
.dz-participio .catico{stroke:var(--cian)} .dz-participio h4{color:var(--cian)}
.dz-participio h4,.dz-otro h4{}
.dz-otro h4{color:var(--text-soft)}        /* sin icono: emoji propio, color neutro */
.cat-emoji{font-family:var(--font-display);font-weight:500;font-size:.85rem;}

/* ===== Selector de tiempos: filas un poco más compactas (menos scroll) ===== */
.row-list--compact{gap:9px;}
.row-list--compact .row-card{padding:11px 18px;gap:14px;}
.row-list--compact .row-card .icwrap{width:40px;height:40px;border-radius:11px;}
.row-list--compact .row-card .icwrap .ico{width:21px;height:21px;}
.row-list--compact .row-card .txt h3{font-size:1.08rem;margin-bottom:1px;}
.row-list--compact .row-card .txt p{font-size:.82rem;}
.row-list--compact + .group-label{margin-top:16px;}

/* ===== Botón de ayuda redondo (esquina de actividades) ===== */
.help-icon-btn{
  background:rgba(168,85,247,.15) !important;
  border:1px solid var(--morado) !important;
  color:var(--morado) !important;
  display:grid !important;place-items:center !important;
  padding:0 !important;
}
.help-icon-btn .ico{width:20px;height:20px;stroke:var(--morado);}
.help-icon-btn:hover{background:rgba(168,85,247,.28) !important;box-shadow:0 0 14px rgba(168,85,247,.4) !important;}

/* ===== Mini botones seleccionar/deseleccionar todo (configuración) ===== */
.mini-toggle-btn{
  font-family:var(--font-body);font-weight:600;font-size:.82rem;
  color:var(--cian);background:rgba(0,200,255,.1);border:1px solid var(--cian);
  border-radius:999px;padding:7px 16px;cursor:pointer;width:auto;max-width:none;margin:0;
  transition:.2s;
}
.mini-toggle-btn:hover{background:rgba(0,200,255,.2);box-shadow:0 0 14px rgba(0,200,255,.35);transform:none;}

/* ===== Modal de tipos de verbos irregulares (único, estilo v5) ===== */
.sil-modal-overlay{z-index:2500;}
.modal-content.sil-modal{
  max-width:680px;
  background:#12121E;
  border:1px solid var(--morado);
  box-shadow:0 0 50px rgba(168,85,247,.4);
}
.sil-tipos-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-top:6px;
}
.sil-tipo{
  display:flex;
  align-items:flex-start;
  gap:12px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:12px;
  padding:13px 15px;
}
.sil-tipo-full{grid-column:1 / -1;}
.sil-tipo-ico{
  width:34px;height:34px;flex:none;
  fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;
}
.sil-tipo span{font-size:.92rem;line-height:1.5;color:var(--text);}
@media (max-width:560px){
  .sil-tipos-grid{grid-template-columns:1fr;}
  .sil-tipo-full{grid-column:auto;}
}

/* ===== FIX dock en móvil: que quepan todos los botones ===== */
@media (max-width: 560px){
  #main-dock-menu.botnav{padding:6px 8px;}
  .botnav .inner{gap:5px;}
  .botnav .home{font-size:.52rem;padding:2px;}
  .botnav .home .ins-dock{width:26px;height:26px;}
  .botnav .sep{display:none;}
  .botnav .pri{gap:3px;}
  .botnav .pri button{padding:5px 6px;font-size:.55rem;gap:2px;}
  .botnav .pri button .ico{width:19px;height:19px;}
  .botnav .util{gap:4px;}
  .botnav .util button{width:34px;height:34px;}
  .botnav .util button .ico{width:17px;height:17px;}
}
@media (max-width: 380px){
  .botnav .pri button span{display:none;}
  .botnav .pri button{padding:6px 7px;}
}

/* ===== FIX fila de conjugación en móvil (label + input no desbordan) ===== */
@media (max-width: 560px){
  .conj-row{
    flex-direction:column;
    align-items:stretch !important;
    gap:5px;
  }
  .conj-label{
    min-width:0 !important;
    text-align:left !important;
    margin-right:0 !important;
    font-weight:600;
  }
  .conj-input{
    max-width:100% !important;
    width:100% !important;
  }
}
