/* =====================================================================
   MAPA NEAE · Hoja de estilos principal
   Sistema de diseño propio · responsive · modo claro y oscuro
   ===================================================================== */

/* ---------- Tipografías locales (sin depender de internet) ---------- */
@font-face {
  font-family: 'Inter';
  src: url('../lib/fonts/inter-latin-400-normal.woff2') format('woff2');
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Inter';
  src: url('../lib/fonts/inter-latin-500-normal.woff2') format('woff2');
  font-weight: 500; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Inter';
  src: url('../lib/fonts/inter-latin-600-normal.woff2') format('woff2');
  font-weight: 600; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Inter';
  src: url('../lib/fonts/inter-latin-700-normal.woff2') format('woff2');
  font-weight: 700; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Fraunces';
  src: url('../lib/fonts/fraunces-latin-400-normal.woff2') format('woff2');
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Fraunces';
  src: url('../lib/fonts/fraunces-latin-500-normal.woff2') format('woff2');
  font-weight: 500; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Fraunces';
  src: url('../lib/fonts/fraunces-latin-600-normal.woff2') format('woff2');
  font-weight: 600; font-style: normal; font-display: swap;
}

/* ---------------------------- Tokens --------------------------------- */
:root {
  /* Color — paleta "mapa": tonos de tierra, musgo y contorno */
  --paper: #F5F6F2;
  --superficie: #FFFFFF;
  --superficie-hundida: #ECEEE8;
  --tinta: #1F2A24;
  --niebla: #5C6B62;
  --niebla-suave: #8B968E;
  --linea: #DDE3DA;
  --linea-fuerte: #C7D0C3;
  --musgo: #3D6B58;
  --musgo-hover: #2F5444;
  --musgo-suave: #E3ECE5;
  --arcilla: #B9892F;
  --arcilla-suave: #F3E8D2;
  --peligro: #B3473D;
  --peligro-suave: #F6E3E1;
  --exito: #3D7A52;
  --exito-suave: #E1EFE5;

  /* Tipografía */
  --f-cuerpo: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --f-display: 'Fraunces', Georgia, serif;

  --texto-xs: 0.75rem;
  --texto-sm: 0.8125rem;
  --texto-base: 0.9375rem;
  --texto-md: 1.0625rem;
  --texto-lg: 1.25rem;
  --texto-xl: 1.6rem;
  --texto-2xl: 2rem;
  --texto-3xl: 2.6rem;

  /* Espaciado */
  --e1: 4px; --e2: 8px; --e3: 12px; --e4: 16px; --e5: 20px;
  --e6: 24px; --e8: 32px; --e10: 40px; --e12: 48px; --e16: 64px;

  --radio-sm: 6px;
  --radio: 10px;
  --radio-lg: 16px;
  --radio-full: 999px;

  --sombra-sm: 0 1px 2px rgba(31, 42, 36, .06);
  --sombra: 0 1px 2px rgba(31,42,36,.05), 0 6px 16px rgba(31,42,36,.06);
  --sombra-lg: 0 8px 28px rgba(31,42,36,.14);

  --ancho-sidebar: 256px;
  --alto-cabecera: 64px;
  --alto-nav-movil: 64px;
  --transicion: 160ms ease;
}

[data-tema="oscuro"] {
  --paper: #11151A;
  --superficie: #1A2025;
  --superficie-hundida: #0E1216;
  --tinta: #E9ECE7;
  --niebla: #9CA8A0;
  --niebla-suave: #6E7A72;
  --linea: #2A332D;
  --linea-fuerte: #394238;
  --musgo: #74B597;
  --musgo-hover: #8AC4A8;
  --musgo-suave: #1C2C24;
  --arcilla: #D9A75C;
  --arcilla-suave: #2E2615;
  --peligro: #E08178;
  --peligro-suave: #2E1A18;
  --exito: #6FC18A;
  --exito-suave: #16261B;

  --sombra-sm: 0 1px 2px rgba(0,0,0,.3);
  --sombra: 0 1px 2px rgba(0,0,0,.3), 0 6px 20px rgba(0,0,0,.35);
  --sombra-lg: 0 12px 32px rgba(0,0,0,.5);
}

/* ----------------------------- Reset ---------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  font-family: var(--f-cuerpo);
  font-size: var(--texto-base);
  line-height: 1.55;
  color: var(--tinta);
  background: var(--paper);
  -webkit-font-smoothing: antialiased;
  transition: background var(--transicion), color var(--transicion);
}
h1, h2, h3, h4 { margin: 0; font-family: var(--f-display); font-weight: 600; line-height: 1.18; letter-spacing: -0.01em; }
p { margin: 0; }
ul, ol { margin: 0; padding: 0; list-style: none; }
button, input, textarea, select { font-family: inherit; font-size: inherit; color: inherit; }
button { cursor: pointer; }
a { color: inherit; }
img { max-width: 100%; display: block; }
svg { display: block; }

:focus-visible {
  outline: 2.5px solid var(--musgo);
  outline-offset: 2px;
  border-radius: var(--radio-sm);
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.001ms !important; transition-duration: 0.001ms !important; }
}

::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-thumb { background: var(--linea-fuerte); border-radius: var(--radio-full); }
::-webkit-scrollbar-track { background: transparent; }

.icono { width: 18px; height: 18px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; flex-shrink: 0; }
.icono-grande { width: 28px; height: 28px; }
.icono-peq { width: 14px; height: 14px; }

.oculto { display: none !important; }
.solo-lectura-pantalla { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); }

/* ============================ PANTALLA DE ACCESO ====================== */
.pantalla-acceso {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--e6);
  background:
    radial-gradient(circle at 18% 22%, var(--musgo-suave) 0%, transparent 45%),
    radial-gradient(circle at 84% 78%, var(--arcilla-suave) 0%, transparent 40%),
    var(--paper);
}
.tarjeta-acceso {
  width: 100%;
  max-width: 392px;
  background: var(--superficie);
  border: 1px solid var(--linea);
  border-radius: var(--radio-lg);
  box-shadow: var(--sombra-lg);
  padding: var(--e8) var(--e6);
}
.marca {
  display: flex;
  align-items: center;
  gap: var(--e3);
  margin-bottom: var(--e6);
}
.marca-icono {
  width: 40px; height: 40px;
  border-radius: var(--radio);
  background: var(--musgo);
  color: white;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.marca-texto { display: flex; flex-direction: column; }
.marca-nombre { font-family: var(--f-display); font-size: var(--texto-lg); font-weight: 600; }
.marca-lema { font-size: var(--texto-xs); color: var(--niebla); }

.tarjeta-acceso h1 { font-size: var(--texto-xl); margin-bottom: var(--e1); }
.acceso-subtitulo { color: var(--niebla); font-size: var(--texto-sm); margin-bottom: var(--e6); }

.campo { margin-bottom: var(--e4); }
.campo label { display: block; font-size: var(--texto-sm); font-weight: 600; margin-bottom: var(--e2); color: var(--tinta); }
.campo .ayuda-campo { font-size: var(--texto-xs); color: var(--niebla); margin-top: var(--e1); }

.input, .select, textarea.input {
  width: 100%;
  padding: 11px var(--e3);
  border: 1.5px solid var(--linea);
  border-radius: var(--radio);
  background: var(--superficie);
  color: var(--tinta);
  transition: border-color var(--transicion), background var(--transicion);
  min-height: 44px;
}
.input:hover, .select:hover { border-color: var(--linea-fuerte); }
.input:focus, .select:focus, textarea.input:focus { border-color: var(--musgo); outline: none; box-shadow: 0 0 0 3px var(--musgo-suave); }
textarea.input { min-height: 96px; resize: vertical; line-height: 1.5; }
.select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%235C6B62' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 12px center; padding-right: 36px; }

.campo-password-envoltorio { position: relative; }
.boton-ver-password { position: absolute; right: 8px; top: 50%; transform: translateY(-50%); background: none; border: none; padding: 6px; color: var(--niebla); border-radius: var(--radio-sm); display: flex; }
.boton-ver-password:hover { background: var(--superficie-hundida); }

.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--e2);
  border: 1.5px solid transparent;
  border-radius: var(--radio);
  padding: 11px var(--e5);
  font-weight: 600;
  font-size: var(--texto-sm);
  min-height: 44px;
  transition: background var(--transicion), border-color var(--transicion), transform 80ms ease, color var(--transicion);
  white-space: nowrap;
}
.btn:active { transform: translateY(1px); }
.btn-primario { background: var(--musgo); border-color: var(--musgo); color: white; }
.btn-primario:hover { background: var(--musgo-hover); border-color: var(--musgo-hover); }
.btn-secundario { background: var(--superficie); border-color: var(--linea); color: var(--tinta); }
.btn-secundario:hover { border-color: var(--linea-fuerte); background: var(--superficie-hundida); }
.btn-fantasma { background: transparent; border-color: transparent; color: var(--niebla); }
.btn-fantasma:hover { background: var(--superficie-hundida); color: var(--tinta); }
.btn-peligro { background: var(--superficie); border-color: var(--peligro); color: var(--peligro); }
.btn-peligro:hover { background: var(--peligro-suave); }
.btn-peligro-lleno { background: var(--peligro); border-color: var(--peligro); color: white; }
.btn-peligro-lleno:hover { filter: brightness(0.92); }
.btn-ancho { width: 100%; }
.btn-peq { padding: 7px var(--e3); min-height: 34px; font-size: var(--texto-xs); }
.btn-icono { padding: 9px; min-height: 38px; min-width: 38px; }
.btn:disabled { opacity: .55; cursor: not-allowed; }

.mensaje-error-acceso {
  background: var(--peligro-suave); color: var(--peligro);
  border-radius: var(--radio); padding: var(--e3); font-size: var(--texto-sm);
  margin-bottom: var(--e4); display: flex; gap: var(--e2); align-items: flex-start;
}

.acceso-pie { text-align: center; margin-top: var(--e6); font-size: var(--texto-xs); color: var(--niebla-suave); }

/* ============================ ESTRUCTURA APP =========================== */
.shell {
  display: grid;
  grid-template-columns: var(--ancho-sidebar) 1fr;
  min-height: 100vh;
}

/* ---- Barra lateral ---- */
.barra-lateral {
  background: var(--superficie);
  border-right: 1px solid var(--linea);
  display: flex;
  flex-direction: column;
  padding: var(--e5) var(--e3);
  position: sticky;
  top: 0;
  height: 100vh;
  overflow-y: auto;
}
.barra-lateral .marca { padding: 0 var(--e2); margin-bottom: var(--e6); }
.nav-grupo { margin-bottom: var(--e5); }
.nav-grupo-titulo { font-size: var(--texto-xs); text-transform: uppercase; letter-spacing: .06em; color: var(--niebla-suave); padding: 0 var(--e3); margin-bottom: var(--e2); font-weight: 700; }
.item-nav {
  display: flex; align-items: center; gap: var(--e3);
  padding: 10px var(--e3);
  border-radius: var(--radio);
  color: var(--niebla);
  font-weight: 500;
  font-size: var(--texto-sm);
  margin-bottom: 2px;
  border: none; background: none; width: 100%; text-align: left;
}
.item-nav:hover { background: var(--superficie-hundida); color: var(--tinta); }
.item-nav.activo { background: var(--musgo-suave); color: var(--musgo-hover); font-weight: 600; }
[data-tema="oscuro"] .item-nav.activo { color: var(--musgo); }
.item-nav .icono { color: inherit; }
.etiqueta-nav-contador {
  margin-left: auto; background: var(--arcilla); color: white;
  font-size: 10.5px; font-weight: 700; border-radius: var(--radio-full);
  min-width: 18px; height: 18px; display: flex; align-items: center; justify-content: center; padding: 0 5px;
}
.sidebar-relleno { flex: 1; }
.pie-sidebar { padding: var(--e3); border-top: 1px solid var(--linea); font-size: var(--texto-xs); color: var(--niebla-suave); }

/* ---- Columna principal ---- */
.columna-principal { display: flex; flex-direction: column; min-width: 0; }
.cabecera {
  height: var(--alto-cabecera);
  border-bottom: 1px solid var(--linea);
  background: var(--superficie);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 var(--e5);
  position: sticky; top: 0; z-index: 20;
  gap: var(--e3);
}
.cabecera-titulo { font-family: var(--f-display); font-size: var(--texto-lg); font-weight: 600; }
.cabecera-acciones { display: flex; align-items: center; gap: var(--e2); }
.boton-menu-movil { display: none; }

.boton-tema {
  width: 38px; height: 38px; border-radius: var(--radio-full);
  background: var(--superficie-hundida); border: 1px solid var(--linea);
  display: flex; align-items: center; justify-content: center; color: var(--niebla);
}
.boton-tema:hover { color: var(--tinta); }

.menu-usuario { position: relative; }
.boton-usuario { display: flex; align-items: center; gap: var(--e2); border: 1px solid var(--linea); background: var(--superficie); border-radius: var(--radio-full); padding: 4px 12px 4px 4px; }
.boton-usuario:hover { background: var(--superficie-hundida); }
.avatar {
  width: 30px; height: 30px; border-radius: var(--radio-full);
  display: flex; align-items: center; justify-content: center;
  color: white; font-weight: 700; font-size: 12.5px; flex-shrink: 0;
}
.avatar-grande { width: 56px; height: 56px; font-size: 20px; }
.avatar-md { width: 40px; height: 40px; font-size: 15px; }

.desplegable {
  position: absolute; top: calc(100% + 8px); right: 0;
  background: var(--superficie); border: 1px solid var(--linea);
  border-radius: var(--radio); box-shadow: var(--sombra-lg);
  min-width: 220px; padding: var(--e2); z-index: 60;
}
.desplegable-item {
  display: flex; align-items: center; gap: var(--e2);
  padding: 9px var(--e3); border-radius: var(--radio-sm);
  width: 100%; background: none; border: none; text-align: left; color: var(--tinta); font-size: var(--texto-sm);
}
.desplegable-item:hover { background: var(--superficie-hundida); }
.desplegable-item.peligro { color: var(--peligro); }
.desplegable-separador { height: 1px; background: var(--linea); margin: var(--e2) 4px; }

.contenido { flex: 1; padding: var(--e6); max-width: 1280px; width: 100%; margin: 0 auto; }

/* ---- Navegación móvil (barra inferior) ---- */
.nav-movil {
  display: none;
  position: fixed; bottom: 0; left: 0; right: 0; height: var(--alto-nav-movil);
  background: var(--superficie); border-top: 1px solid var(--linea);
  z-index: 50;
  padding-bottom: env(safe-area-inset-bottom, 0);
}
.nav-movil-lista { display: flex; height: 100%; }
.item-nav-movil {
  flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 3px;
  background: none; border: none; color: var(--niebla); font-size: 10.5px; font-weight: 600;
}
.item-nav-movil.activo { color: var(--musgo); }

/* ---- Cajón lateral móvil (overlay) ---- */
.fondo-cajon { display: none; position: fixed; inset: 0; background: rgba(20,24,20,.45); z-index: 70; }
.fondo-cajon.visible { display: block; }
.cajon-movil {
  position: fixed; top: 0; left: 0; bottom: 0; width: 280px; max-width: 84vw;
  background: var(--superficie); z-index: 80; transform: translateX(-100%);
  transition: transform 220ms ease; padding: var(--e5) var(--e3); overflow-y: auto;
}
.cajon-movil.visible { transform: translateX(0); }

/* ============================ COMPONENTES =============================== */
.tarjeta {
  background: var(--superficie);
  border: 1px solid var(--linea);
  border-radius: var(--radio-lg);
  padding: var(--e5);
}
.tarjeta-pad-grande { padding: var(--e6); }

.cabecera-seccion { display: flex; align-items: center; justify-content: space-between; gap: var(--e3); margin-bottom: var(--e5); flex-wrap: wrap; }
.cabecera-seccion h2 { font-size: var(--texto-xl); }
.cabecera-seccion h3 { font-size: var(--texto-lg); }
.subtitulo-seccion { color: var(--niebla); font-size: var(--texto-sm); margin-top: 2px; }

.rejilla-estadisticas { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: var(--e4); margin-bottom: var(--e6); }
.tarjeta-estadistica { background: var(--superficie); border: 1px solid var(--linea); border-radius: var(--radio-lg); padding: var(--e4) var(--e5); }
.tarjeta-estadistica .numero { font-family: var(--f-display); font-size: var(--texto-2xl); font-weight: 600; line-height: 1; }
.tarjeta-estadistica .etiqueta { color: var(--niebla); font-size: var(--texto-sm); margin-top: var(--e1); }

.rejilla-tarjetas { display: grid; grid-template-columns: repeat(auto-fill, minmax(230px, 1fr)); gap: var(--e4); }

.tarjeta-alumno {
  background: var(--superficie); border: 1px solid var(--linea); border-radius: var(--radio-lg);
  padding: var(--e4); text-align: left; display: flex; flex-direction: column; gap: var(--e3);
  transition: border-color var(--transicion), box-shadow var(--transicion), transform 120ms ease;
}
.tarjeta-alumno:hover { border-color: var(--linea-fuerte); box-shadow: var(--sombra); transform: translateY(-1px); }
.tarjeta-alumno-cabecera { display: flex; align-items: center; gap: var(--e3); }
.tarjeta-alumno-nombre { font-weight: 600; font-size: var(--texto-md); }
.tarjeta-alumno-curso { color: var(--niebla); font-size: var(--texto-xs); }
.tarjeta-alumno-pie { display: flex; align-items: center; justify-content: space-between; font-size: var(--texto-xs); color: var(--niebla); border-top: 1px solid var(--linea); padding-top: var(--e3); }

.distintivo {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 10px; border-radius: var(--radio-full);
  font-size: 11.5px; font-weight: 700;
  white-space: nowrap;
}
.distintivo-punto { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }

.pestanas {
  display: flex; gap: 4px; border-bottom: 1px solid var(--linea);
  margin-bottom: var(--e5); overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none;
}
.pestanas::-webkit-scrollbar { display: none; }
.pestana {
  flex: 0 0 auto; display: flex; align-items: center; gap: 7px;
  padding: var(--e3) var(--e4); font-weight: 600; font-size: var(--texto-sm); color: var(--niebla);
  border: none; background: none; border-bottom: 2.5px solid transparent; margin-bottom: -1px;
  white-space: nowrap;
}
.pestana:hover { color: var(--tinta); }
.pestana.activa { color: var(--musgo-hover); border-bottom-color: var(--musgo); }
[data-tema="oscuro"] .pestana.activa { color: var(--musgo); }

.envoltorio-tabla { overflow-x: auto; border: 1px solid var(--linea); border-radius: var(--radio-lg); }
table.tabla { width: 100%; border-collapse: collapse; font-size: var(--texto-sm); min-width: 480px; }
table.tabla th { text-align: left; font-size: var(--texto-xs); text-transform: uppercase; letter-spacing: .04em; color: var(--niebla); padding: var(--e3) var(--e4); border-bottom: 1px solid var(--linea); background: var(--superficie-hundida); white-space: nowrap; }
table.tabla td { padding: var(--e3) var(--e4); border-bottom: 1px solid var(--linea); vertical-align: middle; }
table.tabla tr:last-child td { border-bottom: none; }
table.tabla tr:hover td { background: var(--superficie-hundida); }

.estado-vacio { text-align: center; padding: var(--e12) var(--e5); color: var(--niebla); }
.estado-vacio .icono { width: 40px; height: 40px; margin: 0 auto var(--e3); color: var(--niebla-suave); }
.estado-vacio h3 { color: var(--tinta); font-size: var(--texto-md); margin-bottom: var(--e1); }
.estado-vacio p { font-size: var(--texto-sm); max-width: 360px; margin: 0 auto; }

.cargando { display: flex; align-items: center; justify-content: center; gap: var(--e3); padding: var(--e10); color: var(--niebla); font-size: var(--texto-sm); }
.giro { width: 20px; height: 20px; border: 2.5px solid var(--linea); border-top-color: var(--musgo); border-radius: 50%; animation: girar 700ms linear infinite; }
@keyframes girar { to { transform: rotate(360deg); } }

.indicador-guardado { display: inline-flex; align-items: center; gap: 6px; font-size: var(--texto-xs); color: var(--niebla); transition: opacity var(--transicion); }
.indicador-guardado .icono { width: 14px; height: 14px; color: var(--exito); }
.indicador-guardado.guardando .icono { color: var(--arcilla); }

/* ---- Modal ---- */
.fondo-modal { position: fixed; inset: 0; background: rgba(20,24,20,.5); display: flex; align-items: center; justify-content: center; padding: var(--e4); z-index: 100; }
.modal { background: var(--superficie); border-radius: var(--radio-lg); width: 100%; max-width: 480px; max-height: 88vh; display: flex; flex-direction: column; box-shadow: var(--sombra-lg); }
.modal-ancho { max-width: 640px; }
.modal-cabecera { display: flex; align-items: center; justify-content: space-between; padding: var(--e5) var(--e5) var(--e4); border-bottom: 1px solid var(--linea); }
.modal-cabecera h3 { font-size: var(--texto-lg); }
.modal-cuerpo { padding: var(--e5); overflow-y: auto; }
.modal-pie { padding: var(--e4) var(--e5); border-top: 1px solid var(--linea); display: flex; justify-content: flex-end; gap: var(--e2); }
.cerrar-modal { background: none; border: none; color: var(--niebla); padding: 6px; border-radius: var(--radio-sm); }
.cerrar-modal:hover { background: var(--superficie-hundida); color: var(--tinta); }

/* ---- Toasts ---- */
.contenedor-toasts { position: fixed; bottom: var(--e5); right: var(--e5); z-index: 200; display: flex; flex-direction: column; gap: var(--e2); max-width: calc(100vw - 32px); }
.toast {
  background: var(--tinta); color: var(--paper); padding: 13px var(--e4);
  border-radius: var(--radio); box-shadow: var(--sombra-lg); font-size: var(--texto-sm);
  display: flex; align-items: center; gap: var(--e2); animation: aparecer-toast 200ms ease;
  max-width: 360px;
}
.toast.exito { background: var(--exito); color: white; }
.toast.error { background: var(--peligro); color: white; }
@keyframes aparecer-toast { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }

/* ============================ FICHA DE ALUMNO ============================ */
.cabecera-alumno { display: flex; align-items: center; gap: var(--e4); margin-bottom: var(--e5); flex-wrap: wrap; }
.cabecera-alumno-info { flex: 1; min-width: 160px; }
.cabecera-alumno-info h1 { font-size: var(--texto-xl); }
.cabecera-alumno-meta { color: var(--niebla); font-size: var(--texto-sm); margin-top: 2px; }
.enlace-volver { display: inline-flex; align-items: center; gap: 6px; color: var(--niebla); font-size: var(--texto-sm); font-weight: 600; margin-bottom: var(--e4); background: none; border: none; }
.enlace-volver:hover { color: var(--tinta); }

/* ---- Registro diario ---- */
.caja-entrada-hoy { margin-bottom: var(--e6); }
.caja-entrada-hoy .selector-fecha-fila { display: flex; align-items: center; gap: var(--e3); margin-bottom: var(--e3); flex-wrap: wrap; }
.lista-registros { display: flex; flex-direction: column; gap: var(--e3); }
.tarjeta-registro { border: 1px solid var(--linea); border-radius: var(--radio-lg); padding: var(--e4); background: var(--superficie); }
.tarjeta-registro-cabecera { display: flex; align-items: flex-start; gap: var(--e3); margin-bottom: var(--e3); }
.tarjeta-registro-autor { flex: 1; min-width: 0; }
.tarjeta-registro-autor .nombre { font-weight: 600; font-size: var(--texto-sm); }
.tarjeta-registro-autor .meta { font-size: var(--texto-xs); color: var(--niebla); display: flex; gap: 6px; align-items: center; flex-wrap: wrap; margin-top: 2px; }
.tarjeta-registro-contenido { font-size: var(--texto-sm); white-space: pre-wrap; line-height: 1.6; }
.tarjeta-registro-acciones { display: flex; gap: 4px; }
.chips-materiales { display: flex; flex-wrap: wrap; gap: var(--e2); margin-top: var(--e3); }
.chip-material {
  display: inline-flex; align-items: center; gap: 6px; padding: 6px 10px;
  background: var(--superficie-hundida); border: 1px solid var(--linea); border-radius: var(--radio-full);
  font-size: var(--texto-xs); font-weight: 500; max-width: 220px;
}
.chip-material span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.chip-material:hover { border-color: var(--linea-fuerte); }

.barra-filtro-equipo { display: flex; align-items: center; gap: var(--e2); margin-bottom: var(--e4); flex-wrap: wrap; }

/* ---- Materiales ---- */
.rejilla-materiales { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: var(--e3); }
.tarjeta-material { border: 1px solid var(--linea); border-radius: var(--radio-lg); padding: var(--e4); background: var(--superficie); display: flex; flex-direction: column; gap: var(--e2); }
.tarjeta-material-icono { width: 38px; height: 38px; border-radius: var(--radio); background: var(--musgo-suave); color: var(--musgo-hover); display: flex; align-items: center; justify-content: center; }
.tarjeta-material-nombre { font-weight: 600; font-size: var(--texto-sm); word-break: break-word; }
.tarjeta-material-meta { font-size: var(--texto-xs); color: var(--niebla); }
.zona-soltar {
  border: 2px dashed var(--linea-fuerte); border-radius: var(--radio-lg);
  padding: var(--e8) var(--e5); text-align: center; color: var(--niebla); margin-bottom: var(--e5);
  transition: border-color var(--transicion), background var(--transicion);
}
.zona-soltar.sobre { border-color: var(--musgo); background: var(--musgo-suave); }

/* ---- Evaluación / radar "mapa de evolución" ---- */
.disposicion-evaluacion { display: grid; grid-template-columns: 1fr; gap: var(--e6); }
@media (min-width: 1080px) {
  .disposicion-evaluacion { grid-template-columns: minmax(320px, 440px) 1fr; align-items: start; }
}
.panel-radar { background: var(--superficie); border: 1px solid var(--linea); border-radius: var(--radio-lg); padding: var(--e5); }
.contenedor-radar { position: relative; width: 100%; height: 360px; }
@media (max-width: 639px) { .contenedor-radar { height: 300px; } }
.leyenda-trimestres { display: flex; gap: var(--e4); justify-content: center; margin-top: var(--e4); flex-wrap: wrap; }
.leyenda-item { display: flex; align-items: center; gap: 7px; font-size: var(--texto-xs); font-weight: 600; color: var(--niebla); }
.leyenda-linea { width: 18px; height: 3px; border-radius: var(--radio-full); }

.tabla-puntuaciones input.input { padding: 8px; text-align: center; min-height: 38px; width: 64px; }
.celda-area { display: flex; align-items: center; gap: var(--e2); font-weight: 500; }
.boton-comentario { background: none; border: none; color: var(--niebla-suave); padding: 4px; }
.boton-comentario.tiene-comentario { color: var(--arcilla); }

/* ---- Hitos (línea de tiempo tipo "puntos en el mapa") ---- */
.linea-tiempo { position: relative; padding-left: var(--e8); }
.linea-tiempo::before { content: ''; position: absolute; left: 15px; top: 6px; bottom: 6px; width: 2px; background: var(--linea); }
.hito { position: relative; padding-bottom: var(--e6); }
.hito:last-child { padding-bottom: 0; }
.hito-marca {
  position: absolute; left: -33px; top: 0; width: 32px; height: 32px; border-radius: 50%;
  background: var(--arcilla-suave); color: var(--arcilla); display: flex; align-items: center; justify-content: center;
  border: 3px solid var(--paper);
}
.hito-tarjeta { background: var(--superficie); border: 1px solid var(--linea); border-radius: var(--radio-lg); padding: var(--e4); }
.hito-fecha { font-size: var(--texto-xs); color: var(--niebla); font-weight: 600; margin-bottom: 2px; }
.hito-titulo { font-weight: 600; font-size: var(--texto-md); margin-bottom: 2px; }
.hito-descripcion { font-size: var(--texto-sm); color: var(--niebla); white-space: pre-wrap; }
.hito-pie { display: flex; align-items: center; justify-content: space-between; margin-top: var(--e3); }

/* ---- Equipo y traspasos ---- */
.lista-equipo { display: flex; flex-direction: column; gap: var(--e2); }
.fila-equipo { display: flex; align-items: center; gap: var(--e3); padding: var(--e3); border: 1px solid var(--linea); border-radius: var(--radio-lg); }
.fila-equipo-info { flex: 1; min-width: 0; }
.fila-equipo-nombre { font-weight: 600; font-size: var(--texto-sm); display: flex; align-items: center; gap: 6px; }
.estrella-principal { color: var(--arcilla); }
.fila-equipo-acciones { display: flex; gap: 4px; }

/* ============================ ADMINISTRACIÓN ============================ */
.subnav-admin { display: flex; gap: var(--e2); margin-bottom: var(--e5); flex-wrap: wrap; }
.matriz-asignacion { display: flex; flex-direction: column; gap: var(--e2); }
.fila-matriz { display: flex; align-items: center; gap: var(--e3); padding: var(--e3); border: 1px solid var(--linea); border-radius: var(--radio); }
.fila-matriz:hover { border-color: var(--linea-fuerte); }
.casilla { width: 22px; height: 22px; border-radius: 6px; border: 2px solid var(--linea-fuerte); flex-shrink: 0; display: flex; align-items: center; justify-content: center; background: var(--superficie); }
.casilla.marcada { background: var(--musgo); border-color: var(--musgo); color: white; }

/* ============================ MENSAJERÍA ============================ */
.disposicion-mensajes { display: grid; grid-template-columns: 300px 1fr; border: 1px solid var(--linea); border-radius: var(--radio-lg); overflow: hidden; height: calc(100vh - var(--alto-cabecera) - var(--e6) * 2 - 8px); background: var(--superficie); }
@media (max-width: 899px) { .disposicion-mensajes { grid-template-columns: 1fr; height: calc(100vh - var(--alto-cabecera) - var(--alto-nav-movil) - var(--e6)); } }

.panel-conversaciones { border-right: 1px solid var(--linea); display: flex; flex-direction: column; min-height: 0; }
@media (max-width: 899px) { .panel-conversaciones.con-chat-abierto { display: none; } }
.panel-conversaciones-cabecera { padding: var(--e4); border-bottom: 1px solid var(--linea); display: flex; gap: var(--e2); }
.lista-conversaciones { flex: 1; overflow-y: auto; }
.item-conversacion { display: flex; align-items: center; gap: var(--e3); padding: var(--e3) var(--e4); width: 100%; background: none; border: none; border-bottom: 1px solid var(--linea); text-align: left; }
.item-conversacion:hover, .item-conversacion.activa { background: var(--superficie-hundida); }
.item-conversacion-info { flex: 1; min-width: 0; }
.item-conversacion-nombre { font-weight: 600; font-size: var(--texto-sm); display: flex; justify-content: space-between; gap: 6px; }
.item-conversacion-previa { font-size: var(--texto-xs); color: var(--niebla); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; margin-top: 2px; }
.badge-no-leidos { background: var(--musgo); color: white; font-size: 10.5px; font-weight: 700; border-radius: var(--radio-full); min-width: 18px; height: 18px; display: flex; align-items: center; justify-content: center; padding: 0 5px; flex-shrink: 0; }

.panel-chat { display: flex; flex-direction: column; min-height: 0; min-width: 0; }
.chat-cabecera { padding: var(--e3) var(--e4); border-bottom: 1px solid var(--linea); display: flex; align-items: center; gap: var(--e3); }
.boton-volver-chat { display: none; }
@media (max-width: 899px) { .boton-volver-chat { display: flex; } }
.zona-mensajes { flex: 1; overflow-y: auto; padding: var(--e4); display: flex; flex-direction: column; gap: var(--e2); }
.burbuja-fila { display: flex; gap: var(--e2); max-width: 78%; }
.burbuja-fila.propia { align-self: flex-end; flex-direction: row-reverse; }
.burbuja { background: var(--superficie-hundida); border-radius: var(--radio-lg); padding: 9px 13px; font-size: var(--texto-sm); white-space: pre-wrap; word-break: break-word; }
.burbuja-fila.propia .burbuja { background: var(--musgo); color: white; border-bottom-right-radius: 4px; }
.burbuja-fila:not(.propia) .burbuja { border-bottom-left-radius: 4px; }
.burbuja-meta { font-size: 10.5px; color: var(--niebla-suave); margin-top: 3px; }
.burbuja-fila.propia .burbuja-meta { text-align: right; }
.burbuja-autor { font-size: 11px; font-weight: 700; color: var(--niebla); margin-bottom: 2px; }
.zona-escritura { display: flex; gap: var(--e2); padding: var(--e3); border-top: 1px solid var(--linea); }
.zona-escritura textarea { flex: 1; resize: none; max-height: 120px; }

/* ============================ AYUDA ============================ */
.lista-ayuda { display: flex; flex-direction: column; gap: var(--e2); }
.item-ayuda { border: 1px solid var(--linea); border-radius: var(--radio-lg); overflow: hidden; background: var(--superficie); }
.item-ayuda-pregunta { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: var(--e3); padding: var(--e4); background: none; border: none; text-align: left; font-weight: 600; font-size: var(--texto-sm); }
.item-ayuda-respuesta { padding: 0 var(--e4) var(--e4); color: var(--niebla); font-size: var(--texto-sm); line-height: 1.65; display: none; }
.item-ayuda.abierto .item-ayuda-respuesta { display: block; }
.item-ayuda.abierto .icono-chevron { transform: rotate(180deg); }
.icono-chevron { transition: transform var(--transicion); }

/* ============================ UTILIDADES ============================ */
.flex { display: flex; }
.flex-col { display: flex; flex-direction: column; }
.items-centro { align-items: center; }
.justifica-entre { justify-content: space-between; }
.gap-1 { gap: var(--e1); } .gap-2 { gap: var(--e2); } .gap-3 { gap: var(--e3); } .gap-4 { gap: var(--e4); }
.mt-2 { margin-top: var(--e2); } .mt-3 { margin-top: var(--e3); } .mt-4 { margin-top: var(--e4); } .mt-6 { margin-top: var(--e6); }
.mb-2 { margin-bottom: var(--e2); } .mb-3 { margin-bottom: var(--e3); } .mb-4 { margin-bottom: var(--e4); }
.texto-niebla { color: var(--niebla); }
.texto-sm { font-size: var(--texto-sm); }
.texto-xs { font-size: var(--texto-xs); }
.texto-centro { text-align: center; }
.flex-1 { flex: 1; }
.ancho-completo { width: 100%; }
.envoltorio-ancho { max-width: 560px; }
.separador { height: 1px; background: var(--linea); margin: var(--e5) 0; }

/* ============================ RESPONSIVE: app shell =================== */
@media (min-width: 640px) and (max-width: 899px) {
  .shell { grid-template-columns: 76px 1fr; }
  .barra-lateral { padding: var(--e4) var(--e2); align-items: center; }
  .barra-lateral .marca { justify-content: center; padding: 0; }
  .marca-texto, .nav-grupo-titulo, .etiqueta-nav, .pie-sidebar { display: none; }
  .item-nav { justify-content: center; padding: 12px; position: relative; }
  .item-nav .etiqueta-nav-contador { position: absolute; top: 4px; right: 4px; margin: 0; }
}

@media (max-width: 639px) {
  .shell { grid-template-columns: 1fr; }
  .barra-lateral { display: none; }
  .nav-movil { display: flex; }
  .columna-principal { padding-bottom: var(--alto-nav-movil); }
  .boton-menu-movil { display: flex; }
  .cabecera-titulo { font-size: var(--texto-md); }
  .contenido { padding: var(--e4); }
  .cabecera { padding: 0 var(--e4); }
  .rejilla-estadisticas { grid-template-columns: repeat(2, 1fr); }
  .modal { max-width: 100%; }
  .disposicion-evaluacion { gap: var(--e5); }
}

@media (min-width: 900px) {
  .boton-menu-movil { display: none; }
}
