/* ===========================
   ESTILO BASE (global)
   Paleta oscura, minimal
   =========================== */
:root {
  --FONDO: #0b0d10;
  --FONDO_CARDS: #12161e;
  --BORDE: #1b222c;
  --SOMBRA: 0 10px 30px rgba(0,0,0,.45);

  --TEXTO_PRINCIPAL: #e6e9ef;
  --TEXTO_SECUNDARIO: #a8b2c3;

  --PRIMARIO: #33b1ff;
  --PRIMARIO-ALFA: rgba(51,177,255,.12);
  --FOCUS: #7dd3fc;

  --OK: #22c55e;
  --ERROR: #ef4444;

  --RAD: 14px;
  --RAD-SM: 10px;
  --PAD: 18px;
  --TRANS: 220ms ease;
}

/* Reset mínimo & tipografía */
* { box-sizing: border-box }
html, body { height: 100% }
html { scroll-behavior: smooth }
body {
  margin: 0;
  background: radial-gradient(1200px 800px at 20% -10%, #0f141c 0%, var(--FONDO) 60%);
  color: var(--TEXTO_PRINCIPAL);
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Ubuntu, Arial, sans-serif;
  line-height: 1.6;
}

/* Contenedor secciones */
section {
  width: 100%;
  max-width: 1200px;
  margin-inline: auto;
  padding-inline: clamp(16px, 4vw, 28px);
}

/* Títulos */
.sub-titulos {
  font-size: clamp(20px, 2.2vw, 26px);
  font-weight: 700;
  margin: 28px 0 14px 0;
  color: var(--TEXTO_PRINCIPAL);
  border-bottom: 1px solid var(--BORDE);
  padding-bottom: 10px;
}

/* Texto */
p, li, .descripcion, .descripcion-p {
  color: var(--TEXTO_SECUNDARIO);
  font-size: clamp(15px, 1.6vw, 17px);
}
.descripcion-p { margin: 12px 0 18px }

/* ===========================
   Servicios (cards)
   =========================== */
.caracteristicas {
  margin: 8px auto 6px;
  max-width: 980px;
  display: grid;
  grid-template-columns: repeat( auto-fit, minmax(210px, 1fr) );
  gap: 12px;
}
.sub-caracteristicas {
  border: 1px solid var(--BORDE);
  border-radius: var(--RAD);
  background: var(--FONDO_CARDS);
  color: var(--TEXTO_PRINCIPAL);
  padding: 16px;
  display: grid;
  place-items: center;
  gap: 8px;
  box-shadow: var(--SOMBRA);
  transition: transform var(--TRANS), border-color var(--TRANS);
}
.sub-caracteristicas:hover { transform: translateY(-2px); border-color: var(--PRIMARIO) }

/* Override color iconos inline */
.caracteristicas .sub-caracteristicas i,
.subtitulo i,
.normas h5 i {
  color: var(--TEXTO_PRINCIPAL) !important;
}

/* ===========================
   Mapa
   =========================== */
.link-mapa { text-align: center; margin: 16px 0 6px }
.subtitulo { color: var(--TEXTO_PRINCIPAL); font-weight: 600; margin-bottom: 10px }
.mapa {
  width: 100%; height: 42vh; min-height: 320px;
  border: 1px solid var(--BORDE);
  border-radius: var(--RAD);
  overflow: hidden;
  box-shadow: var(--SOMBRA);
}

/* ===========================
   Descargas
   =========================== */
.descargas {
  background: linear-gradient(180deg, #0f141c 0%, var(--FONDO) 100%);
  border: 1px solid var(--BORDE);
  border-radius: var(--RAD);
  padding: 12px 16px 4px;
  margin-top: 18px;
  box-shadow: var(--SOMBRA);
}
.lista-descargas { padding: 0; margin: 6px 0 2px }
.lista-descargas li { margin-bottom: 8px }
.lista-descargas a.archivos-des,
.archivos-des {
  display: inline-block;
  color: var(--TEXTO_PRINCIPAL);
  text-decoration: none;
  padding: 10px 12px;
  border-radius: var(--RAD-SM);
  background: var(--FONDO_CARDS);
  border: 1px solid var(--BORDE);
  transition: border-color var(--TRANS), transform var(--TRANS), background var(--TRANS);
  margin-left: 0;
}
.lista-descargas a.archivos-des:hover,
.archivos-des:hover {
  transform: translateY(-1px);
  border-color: var(--PRIMARIO);
  background: #0f141c;
}

/* ===========================
   Footer
   =========================== */
footer {
  margin-top: 28px;
  background: #0a0d12;
  border-top: 1px solid var(--BORDE);
}
footer * { color: var(--TEXTO_SECUNDARIO) }
.contenido-footer {
  max-width: 1200px;
  margin-inline: auto;
  padding: 24px clamp(16px, 4vw, 28px);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
}
.enlaces-rapidos ul { padding: 0; margin: 6px 0 0 }
.enlaces-rapidos li { margin-bottom: 6px }
.enlaces-rapidos a {
  color: var(--TEXTO_PRINCIPAL);
  text-decoration: none;
  padding: 6px 8px;
  border-radius: 8px;
  transition: background var(--TRANS), color var(--TRANS);
}
.enlaces-rapidos a:hover {
  background: var(--PRIMARIO-ALFA);
  color: var(--PRIMARIO);
}
.derechos-reservados { text-align: center; padding: 12px 16px 20px }

/* ===========================
   WhatsApp FAB
   =========================== */
.whatsapp-button {
  position: fixed;
  bottom: 20px; right: 20px;
  z-index: 40;
  display: grid; place-items: center;
  width: 60px; height: 60px;
  border-radius: 999px;
  border: 1px solid var(--BORDE);
  background: radial-gradient(120px 80px at 50% 20%, #0f141c 0%, var(--FONDO_CARDS) 70%);
  box-shadow: var(--SOMBRA);
  transition: transform var(--TRANS), border-color var(--TRANS);
}
.whatsapp-button:hover { transform: translateY(-2px) scale(1.03); border-color: var(--PRIMARIO) }
.whatsapp-button img { width: 38px; height: 38px }

/* ===========================
   Utilidades
   =========================== */
li { margin-bottom: .8rem }
h5 { font-size: 1rem; margin-bottom: .8rem; text-align: center }
a { color: inherit }
:focus-visible { outline: 2px solid var(--FOCUS); outline-offset: 2px; border-radius: 8px }

/* Offset para anclajes (que el header no tape) */
[id] { scroll-margin-top: 90px; }

/* Responsivo leve del contenedor (compat) */
@media (max-width: 430px){
  section { max-width: 410px }
}

/* ===========================
   AJUSTES RESPONSIVE
   - Servicios: 2 columnas móvil
   - Adicionales: grid compacto
   =========================== */

/* Servicios: 2 columnas en ≤768px */
@media (max-width: 768px) {
  .caracteristicas {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 10px;
  }
  .sub-caracteristicas {
    padding: 12px;
    font-size: 14px;
    gap: 6px;
  }
  .sub-caracteristicas i { font-size: 20px }
}

/* Servicios: muy chico */
@media (max-width: 360px) {
  .caracteristicas { gap: 8px }
  .sub-caracteristicas {
    padding: 10px;
    font-size: 13px;
  }
  .sub-caracteristicas i { font-size: 18px }
}

/* Adicionales: grid responsive (compacto) */
.adicionales .lista-descargas {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr)); /* desktop compacto */
  gap: 10px 12px;
  align-items: stretch;
  padding: 0;
}
.adicionales .lista-descargas li { margin: 0 }
.adicionales .lista-descargas .archivos-des {
  display: block;
  text-align: center;
  padding: 12px;
  font-variant-numeric: tabular-nums; /* precios alineados */
}

/* Tablet y mobile: 2 por fila */
@media (max-width: 1024px) {
  .adicionales .lista-descargas {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Móviles muy chicos: más compacto */
@media (max-width: 380px) {
  .adicionales .lista-descargas { gap: 8px }
  .adicionales .lista-descargas .archivos-des {
    padding: 10px;
    font-size: 14px;
  }
}

/* Micro-UX: flechas galería más clicables */
.flecha-izquierda, .flecha-derecha { user-select: none; padding: 6px }
