/* =====================
   VARIABLES CSS / RESET
===================== */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

:root {
  --primary:        #F27D0C;
  --primary-dark:   #D96C00;
  --secondary:      #1F3A8A;
  --bg-light:       #F9FAFB;
  --bg-dark:        #111827;
  --surface-light:  #FFFFFF;
  --surface-dark:   #1F2937;
  --text-light:     #374151;
  --text-dark:      #D1D5DB;
  --gray-50:        #F9FAFB;
  --gray-100:       #F3F4F6;
  --gray-200:       #E5E7EB;
  --gray-300:       #D1D5DB;
  --gray-400:       #9CA3AF;
  --gray-500:       #6B7280;
  --gray-600:       #4B5563;
  --gray-700:       #374151;
  --gray-800:       #1F2937;
  --gray-900:       #111827;
  --blue-50:        #EFF6FF;
  --blue-100:       #DBEAFE;
  --blue-400:       #60A5FA;
  --blue-800:       #1E40AF;
  --blue-900:       #1E3A8A;
  --orange-50:      #FFF7ED;
  --orange-900-20:  rgba(124,45,18,0.2);
  --blue-900-20:    rgba(30,58,138,0.2);
  --radius:         0.5rem;
  --font:           'Montserrat', sans-serif;
}

html { scroll-behavior: smooth; }

body {
  background-color: var(--bg-light);
  font-family: var(--font);
  color: var(--text-light);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  transition: background-color 0.3s, color 0.3s;
}

::selection {
  background-color: var(--primary);
  color: #fff;
}

a { text-decoration: none; }
img { display: block; max-width: 100%; }
ul { list-style: none; }
button, input, select, textarea { font-family: var(--font); }

/* =====================
   UTILIDADES
===================== */
.sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border-width: 0;
}

.gradient-text {
  background: linear-gradient(90deg, #F27D0C 0%, #1F3A8A 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.section-divider {
  height: 4px;
  background: linear-gradient(90deg, var(--primary) 0%, var(--secondary) 100%);
  width: 100%;
  display: block;
  border: none;
}

.container {
  max-width: 80rem;
  margin-left: auto;
  margin-right: auto;
  padding-left: 1rem;
  padding-right: 1rem;
}
@media (min-width: 640px) {
  .container { padding-left: 1.5rem; padding-right: 1.5rem; }
}
@media (min-width: 1024px) {
  .container { padding-left: 2rem; padding-right: 2rem; }
}

/* =====================
   ENCABEZADO
===================== */
header {
  background-color: var(--surface-light);
  box-shadow: 0 1px 3px rgba(0,0,0,0.07);
  position: sticky;
  top: 0;
  z-index: 50;
  transition: background-color 0.3s;
}

.interior-encabezado {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 5rem;
}

.area-logo { display: flex; align-items: center; gap: 0.75rem; flex-shrink: 0; }

.nav-principal { display: none; gap: 2rem; }
@media (min-width: 768px) { .nav-principal { display: flex; } }

.nav-principal a {
  color: var(--gray-600);
  font-weight: 500;
  transition: color 0.2s;
  font-size: 0.9375rem;
}
.nav-principal a:hover { color: var(--primary); }
.nav-principal a.activo { color: var(--primary); font-weight: 700; }

.btn-cta-encabezado {
  display: none;
  align-items: center;
}
@media (min-width: 768px) { .btn-cta-encabezado { display: flex; } }

.btn-cta-encabezado a {
  display: inline-flex;
  align-items: center;
  padding: 0.5rem 1.5rem;
  border-radius: 9999px;
  background-color: var(--secondary);
  color: #fff;
  font-size: 0.875rem;
  font-weight: 500;
  box-shadow: 0 1px 3px rgba(0,0,0,0.2);
  transition: background-color 0.2s;
}
.btn-cta-encabezado a:hover { background-color: var(--blue-800); }

.btn-menu-movil {
  display: flex;
  align-items: center;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--gray-500);
}
@media (min-width: 768px) { .btn-menu-movil { display: none; } }

/* =====================
   MENÚ MÓVIL
===================== */
.nav-movil {
  display: none;
  background-color: #fff;
  border-top: 1px solid var(--gray-200);
  box-shadow: 0 8px 24px rgba(0,0,0,0.1);
}

.nav-movil.abierto {
  display: block;
}

.nav-movil nav {
  display: flex;
  flex-direction: column;
  padding: 1rem 1.5rem 1.5rem;
  gap: 0;
}

.nav-movil nav a {
  color: var(--gray-700);
  font-weight: 500;
  font-size: 1rem;
  padding: 0.85rem 0;
  border-bottom: 1px solid var(--gray-100);
  transition: color 0.2s;
  text-decoration: none;
}

.nav-movil nav a:last-child {
  border-bottom: none;
}

.nav-movil nav a:hover {
  color: var(--primary);
}

.nav-movil nav a.cta-movil {
  margin-top: 1rem;
  background-color: var(--secondary);
  color: #fff !important;
  text-align: center;
  padding: 0.75rem 1rem;
  border-radius: 9999px;
  font-weight: 600;
  border-bottom: none;
}

.nav-movil nav a.cta-movil:hover {
  background-color: var(--primary);
  color: #fff !important;
}

@media (min-width: 768px) {
  .nav-movil {
    display: none !important;
  }
}

/* =====================
   CARRUSEL / HERO
   =====================*/ 
.seccion-carrusel {
  position: relative;
  width: 100%;
  height: calc(100vh - 5rem);
  min-height: 480px;
  max-height: 900px;
  overflow: hidden;
  background: #000;
}

.interior-carrusel { width: 100%; height: 100%; position: relative; }

.diapositiva-carrusel {
  display: none;
  opacity: 0;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0; left: 0;
  transition: opacity 0.6s ease-in-out;
}

.diapositiva-carrusel.activo {
  display: block;
  opacity: 1;
}

.diapositiva-carrusel img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

/* Indicadores */
.indicadores-carrusel {
  position: absolute;
  bottom: 1.5rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  gap: 0.5rem;
  z-index: 20;
}

.indicador {
  display: block;
  width: 0.65rem;
  height: 0.65rem;
  background-color: rgba(255,255,255,0.55);
  border-radius: 9999px;
  cursor: pointer;
  transition: background-color 0.3s, width 0.3s;
}
.indicador:hover {
  background-color: rgba(255,255,255,0.85);
}
.indicador.activo {
  background-color: var(--primary);
  width: 1.75rem;
}

/* Flechas */
.flechas-carrusel {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 1.25rem;
  pointer-events: none;
  z-index: 10;
}

.flechas-carrusel button {
  pointer-events: auto;
  width: 2.75rem;
  height: 2.75rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 9999px;
  background-color: rgba(255,255,255,0.9);
  color: var(--gray-700);
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(0,0,0,0.18);
  border: none;
  transition: background-color 0.2s, box-shadow 0.2s;
}
.flechas-carrusel button:hover {
  background-color: #fff;
  box-shadow: 0 4px 16px rgba(0,0,0,0.25);
}
.flechas-carrusel button .material-icons {
  font-size: 1.5rem;
  color: var(--gray-700);
}
/* =====================
   SECCIONES PRINCIPALES
===================== */

/* ---- Sección Nosotros ---- */
.seccion-nosotros {
  padding: 5rem 0;
  background-color: var(--surface-light);
}

.cuadricula-nosotros {
  display: grid;
  gap: 4rem;
  align-items: center;
}
@media (min-width: 1024px) {
  .cuadricula-nosotros { grid-template-columns: 1fr 1fr; gap: 4rem; }
}

.texto-nosotros { margin-bottom: 2.5rem; }
@media (min-width: 1024px) { .texto-nosotros { margin-bottom: 0; } }

.envoltura-titulo-nosotros { position: relative; }
.blob-titulo {
  position: absolute;
  top: -1rem; left: -1rem;
  width: 6rem; height: 6rem;
  background-color: rgba(242,125,12,0.2);
  border-radius: 9999px;
  z-index: -1;
}

.envoltura-titulo-nosotros h2 {
  font-size: clamp(1.75rem, 4vw, 2.25rem);
  font-weight: 700;
  color: var(--gray-900);
  margin-bottom: 1.5rem;
}

.section-subtitle {
  font-size: 1.125rem;
  font-weight: 500;
  color: var(--secondary);
  margin-bottom: 1.5rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.texto-nosotros p {
  color: var(--gray-600);
  font-size: 1.125rem;
  line-height: 1.75;
  margin-bottom: 1.5rem;
}

.texto-nosotros p span { font-weight: 700; color: var(--secondary); }

.link-arrow {
  display: inline-flex;
  align-items: center;
  color: var(--primary);
  font-weight: 700;
  transition: color 0.2s;
}
.link-arrow:hover { color: var(--primary-dark); }
.link-arrow .material-icons {
  margin-left: 0.5rem;
  transition: transform 0.2s;
  font-size: 1.25rem;
}
.link-arrow:hover .material-icons { transform: translateX(4px); }

.envoltura-imagen-nosotros { position: relative; }

.tarjeta-imagen-nosotros {
  position: relative;
  border-radius: 1rem;
  overflow: hidden;
  box-shadow: 0 25px 50px rgba(0,0,0,0.2);
}

.tarjeta-imagen-nosotros img {
  width: 100%;
  height: auto;
  object-fit: cover;
  transition: transform 0.7s ease;
}
.tarjeta-imagen-nosotros:hover img { transform: scale(1.05); }

.superposicion-imagen {
  position: absolute;
  inset: 0;
  background-color: rgba(31,58,138,0.1);
  transition: background-color 0.3s;
}
.tarjeta-imagen-nosotros:hover .superposicion-imagen { background-color: transparent; }

.insignia-nosotros {
  position: absolute;
  bottom: -1.5rem;
  right: -1.5rem;
  width: 8rem;
  height: 8rem;
  background-color: var(--secondary);
  border-radius: 9999px;
  display: none;
  align-items: center;
  justify-content: center;
  box-shadow: 0 10px 25px rgba(0,0,0,0.2);
  flex-direction: column;
  text-align: center;
  color: #fff;
}
@media (min-width: 768px) { .insignia-nosotros { display: flex; } }

.insignia-nosotros span:first-child { font-size: 1.875rem; font-weight: 700; display: block; }
.insignia-nosotros span:last-child  { font-size: 0.65rem; text-transform: uppercase; display: block; }

/* ---- Sección Servicios ---- */
.seccion-servicios {
  padding: 5rem 0;
  background-color: var(--bg-light);
}

.section-header { text-align: center; margin-bottom: 4rem; }
.section-label {
  color: var(--primary);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-size: 0.875rem;
}
.section-title {
  font-size: clamp(1.75rem, 4vw, 2.25rem);
  font-weight: 700;
  color: var(--gray-900);
  margin-top: 0.5rem;
  margin-bottom: 1rem;
}
.section-desc {
  color: var(--gray-400);
  max-width: 40rem;
  margin: 0 auto;
}

.cuadricula-servicios {
  display: grid;
  gap: 2rem;
}
@media (min-width: 768px)  { .cuadricula-servicios { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .cuadricula-servicios { grid-template-columns: 1fr 1fr 1fr; } }

.tarjeta-servicio {
  background-color: #fff;
  border-radius: 0.75rem;
  padding: 2rem;
  box-shadow: 0 4px 12px rgba(0,0,0,0.07);
  border-top: 4px solid transparent;
  transition: box-shadow 0.3s;
}
.tarjeta-servicio:hover { box-shadow: 0 20px 40px rgba(0,0,0,0.12); }
.tarjeta-servicio.borde-primario { border-top-color: var(--primary); }
.tarjeta-servicio.borde-secundario { border-top-color: var(--secondary); }

.icono-servicio {
  width: 3.5rem; height: 3.5rem;
  border-radius: 0.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.5rem;
  transition: background-color 0.3s;
}
.icono-servicio.naranja-bg { background-color: var(--orange-50); }
.icono-servicio.azul-bg   { background-color: var(--blue-50); }

.icono-servicio .material-symbols-outlined { font-size: 1.875rem; transition: color 0.3s; }
.icono-servicio.naranja-bg .material-symbols-outlined { color: var(--primary); }
.icono-servicio.azul-bg .material-symbols-outlined   { color: var(--secondary); }

.tarjeta-servicio:hover .icono-servicio.naranja-bg { background-color: var(--primary); }
.tarjeta-servicio:hover .icono-servicio.naranja-bg .material-symbols-outlined { color: #fff; }
.tarjeta-servicio:hover .icono-servicio.azul-bg { background-color: var(--secondary); }
.tarjeta-servicio:hover .icono-servicio.azul-bg .material-symbols-outlined { color: #fff; }

.tarjeta-servicio h3 {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--gray-900);
  margin-bottom: 0.75rem;
}
.tarjeta-servicio p {
  color: var(--gray-400);
  font-size: 0.875rem;
  line-height: 1.6;
  margin-bottom: 1.5rem;
}
.tarjeta-servicio a {
  color: var(--secondary);
  font-weight: 600;
  font-size: 0.875rem;
  transition: text-decoration 0.2s;
}
.tarjeta-servicio a:hover { text-decoration: underline; }

/* ---- Sección Contacto ---- */
.seccion-contacto {
  padding: 5rem 0;
  background-color: var(--surface-light);
  position: relative;
  overflow: hidden;
}

.blob-contacto-dr {
  position: absolute;
  top: -5rem; right: -5rem;
  width: 20rem; height: 20rem;
  border-radius: 9999px;
  background-color: rgba(31,58,138,0.05);
  filter: blur(3rem);
}
.blob-contacto-ii {
  position: absolute;
  bottom: -5rem; left: -5rem;
  width: 20rem; height: 20rem;
  border-radius: 9999px;
  background-color: rgba(242,125,12,0.05);
  filter: blur(3rem);
}

.cuadricula-contacto {
  display: grid;
  gap: 3rem;
  position: relative;
  z-index: 1;
}
@media (min-width: 1024px) {
  .cuadricula-contacto { grid-template-columns: 1fr 1fr; gap: 6rem; }
}

.info-contacto .section-label { display: block; margin-bottom: 0.5rem; }
.info-contacto h2 {
  font-size: clamp(1.75rem, 4vw, 2.25rem);
  font-weight: 700;
  color: var(--gray-900);
  margin-bottom: 1.5rem;
}
.info-contacto > p {
  color: var(--gray-600);
  margin-bottom: 2.5rem;
  font-size: 1.125rem;
}

.elementos-contacto { display: flex; flex-direction: column; gap: 2rem; }

.elemento-contacto { display: flex; align-items: flex-start; gap: 1rem; }

.icono-contacto {
  flex-shrink: 0;
  width: 3rem; height: 3rem;
  border-radius: 0.375rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
}
.icono-contacto.fondo-secundario { background-color: var(--secondary); }
.icono-contacto.fondo-primario   { background-color: var(--primary); }
.icono-contacto .material-icons { font-size: 1.25rem; }

.elemento-contacto h5 {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--gray-900);
  margin-bottom: 0.25rem;
}
.elemento-contacto p { color: var(--gray-500); font-size: 0.9375rem; line-height: 1.6; }

.tarjeta-formulario-contacto {
  background-color: #fff;
  border-radius: 1rem;
  box-shadow: 0 20px 40px rgba(0,0,0,0.1);
  padding: 2rem;
  border: 1px solid var(--gray-100);
}

.form-group { margin-bottom: 0; }
.form-stack { display: flex; flex-direction: column; gap: 1.5rem; }

.form-group label {
  display: block;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--gray-700);
  margin-bottom: 0.25rem;
}

.form-group input,
.form-group select,
.form-group textarea {
  display: block;
  width: 100%;
  font-size: 0.875rem;
  padding: 0.5rem 0.75rem;
  border: 1px solid var(--gray-300);
  border-radius: var(--radius);
  background-color: #fff;
  color: var(--gray-900);
  transition: border-color 0.2s, box-shadow 0.2s;
  outline: none;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(242,125,12,0.15);
}

.form-group textarea { resize: vertical; }

.btn-submit {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1rem;
  border: none;
  border-radius: var(--radius);
  background-color: var(--primary);
  color: #fff;
  font-size: 0.875rem;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 1px 3px rgba(0,0,0,0.15);
  transition: background-color 0.2s, transform 0.2s, box-shadow 0.2s;
}
.btn-submit:hover {
  background-color: var(--primary-dark);
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(242,125,12,.38);
}
.btn-submit:focus { outline: none; box-shadow: 0 0 0 3px rgba(242,125,12,0.3); }
.btn-submit .material-icons { font-size: 1.1rem; }

.btn-submit.btn-blue { background-color: var(--secondary); box-shadow: 0 6px 20px rgba(31,58,138,.25); }
.btn-submit.btn-blue:hover { background-color: #1a3278; box-shadow: 0 10px 28px rgba(31,58,138,.35); }
.btn-submit.btn-blue:focus { box-shadow: 0 0 0 3px rgba(31,58,138,.3); }

/* =====================
   PIE DE PÁGINA
===================== */
footer {
  background-color: var(--surface-light);
  border-top: 1px solid var(--gray-200);
  padding-top: 4rem;
  padding-bottom: 2rem;
  transition: background-color 0.3s;
}

.cuadricula-footer {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  margin-bottom: 3rem;
}
@media (min-width: 768px) {
  .cuadricula-footer { grid-template-columns: repeat(4, 1fr); }
}

.marca-footer { display: flex; justify-content: center;  }

.logo-footer {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.logo-footer img { height: 4rem; width: 4rem; object-fit: contain;  text-align: center; }

.marca-footer p { color: var(--gray-500); font-size: 0.875rem; line-height: 1.7; }

.columna-footer h4 {
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--gray-900);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 1rem;
}

.columna-footer ul { display: flex; flex-direction: column; gap: 0.75rem; }
.columna-footer ul li a {
  font-size: 0.875rem;
  color: var(--gray-600);
  transition: color 0.2s;
}
.columna-footer ul li a:hover { color: var(--primary); }

.elemento-contacto-footer {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  color: var(--gray-600);
}
.elemento-contacto-footer .material-icons {
  color: var(--primary);
  font-size: 0.75rem;
}

.pie-footer {
  border-top: 1px solid var(--gray-200);
  padding-top: 2rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
}
@media (min-width: 768px) {
  .pie-footer { flex-direction: row; justify-content:  center; gap: 0; }
}

.pie-footer p { font-size: 0.875rem; color: var(--gray-500); }

.social-links,
.f-social { display: flex; gap: 1.5rem; }
.social-links a,
.f-social a { color: var(--gray-400); transition: color 0.2s; }
.social-links a:hover,
.f-social a:hover { color: var(--secondary); }
.social-links a svg,
.f-social a svg { width: 1.5rem; height: 1.5rem; }

/* =====================
   SECCIÓN ¿POR QUÉ NOSOTROS?
===================== */
.seccion-por-que {
  padding: 5rem 0;
  background-color: var(--surface-light);
  position: relative;
  overflow: hidden;
}

.seccion-por-que::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--primary) 0%, var(--secondary) 100%);
}

.interior-por-que { position: relative; z-index: 1; }

.encabezado-por-que { text-align: center; margin-bottom: 4rem; }
.encabezado-por-que .section-label { color: var(--primary); }
.encabezado-por-que h2 {
  font-size: clamp(1.75rem, 4vw, 2.25rem);
  font-weight: 700;
  color: var(--gray-900);
  margin-top: 0.5rem;
  margin-bottom: 1rem;
}
.encabezado-por-que p {
  color: var(--gray-500);
  max-width: 40rem;
  margin: 0 auto;
  font-size: 1rem;
  line-height: 1.7;
}

.cuadricula-por-que {
  display: grid;
  gap: 1.5rem;
}
@media (min-width: 640px)  { .cuadricula-por-que { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .cuadricula-por-que { grid-template-columns: repeat(3, 1fr); } }

.tarjeta-razon {
  background-color: #fff;
  border: 1px solid var(--gray-100);
  border-left: 4px solid var(--primary);
  border-radius: 0.75rem;
  padding: 1.75rem 1.75rem 1.75rem 1.5rem;
  box-shadow: 0 2px 12px rgba(0,0,0,0.05);
  transition: box-shadow 0.3s, transform 0.3s, border-left-color 0.3s;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.tarjeta-razon:hover {
  box-shadow: 0 12px 32px rgba(242,125,12,0.12);
  transform: translateY(-4px);
  border-left-color: var(--primary-dark);
}

.icono-razon {
  width: 3rem; height: 3rem;
  border-radius: 0.625rem;
  background-color: var(--orange-50);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.1rem;
  transition: background-color 0.3s;
  flex-shrink: 0;
}
.tarjeta-razon:hover .icono-razon { background-color: var(--primary); }
.icono-razon .material-symbols-outlined {
  font-size: 1.6rem;
  color: var(--primary);
  transition: color 0.3s;
}
.tarjeta-razon:hover .icono-razon .material-symbols-outlined { color: #fff; }

.tarjeta-razon h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--gray-900);
  margin-bottom: 0.5rem;
  line-height: 1.3;
}
.tarjeta-razon p {
  color: var(--gray-500);
  font-size: 0.875rem;
  line-height: 1.65;
}

.estadisticas-por-que {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0;
  margin-bottom: 3rem;
  border: 1px solid var(--gray-100);
  border-radius: 1rem;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 2px 12px rgba(0,0,0,0.05);
}

.estadistica {
  flex: 1;
  min-width: 10rem;
  padding: 1.5rem 1rem;
  text-align: center;
  border-right: 1px solid var(--gray-100);
  position: relative;
}
.estadistica:last-child { border-right: none; }

.estadistica .numero-estadistica {
  font-size: 2rem;
  font-weight: 700;
  color: var(--primary);
  line-height: 1;
  display: block;
  margin-bottom: 0.3rem;
}
.estadistica .etiqueta-estadistica {
  font-size: 0.8rem;
  color: var(--gray-56);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.cta-por-que {
  margin-top: 3rem;
  text-align: center;
}
.cta-por-que a {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background-color: var(--primary);
  color: #fff;
  font-size: 0.9375rem;
  font-weight: 700;
  padding: 0.85rem 2.25rem;
  border-radius: 9999px;
  box-shadow: 0 8px 24px rgba(242,125,12,0.25);
  transition: background-color 0.2s, transform 0.2s;
}
.cta-por-que a:hover { background-color: var(--primary-dark); transform: translateY(-2px); }
.cta-por-que a .material-icons { font-size: 1.1rem; }

.cta-por-que-alt {
  margin-top: 3rem;
  text-align: center;
}
.cta-por-que-alt a {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background-color: var(--secondary);
  color: #fff;
  font-size: 0.9375rem;
  font-weight: 700;
  padding: 0.85rem 2.25rem;
  border-radius: 9999px;
  box-shadow: 0 8px 24px rgba(27, 12, 242, 0.25);
  transition: background-color 0.2s, transform 0.2s;
}
.cta-por-que-alt a:hover { background-color: var(--secondary); transform: translateY(-2px); }
.cta-por-que-alt a .material-icons { font-size: 1.1rem; }





.tarjeta-razon-alt {
  background-color: #fff;
  border: 1px solid var(--gray-100);
  border-left: 4px solid var(--secondary);
  border-radius: 0.75rem;
  padding: 1.75rem 1.75rem 1.75rem 1.5rem;
  box-shadow: 0 2px 12px rgba(0,0,0,0.05);
  transition: box-shadow 0.3s, transform 0.3s, border-left-color 0.3s;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.tarjeta-razon-alt:hover {
  box-shadow: 0 12px 32px rgba(242,125,12,0.12);
  transform: translateY(-4px);
  border-left-color: var(--primary-dark);
}

.icono-razon-alt {
  width: 3rem; height: 3rem;
  border-radius: 0.625rem;
  background-color: var(--blue-50);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.1rem;
  transition: background-color 0.3s;
  flex-shrink: 0;
}
.tarjeta-razon-alt:hover .icono-razon-alt { background-color: var(--secondary); }
.icono-razon-alt .material-symbols-outlined1 {
  font-size: 1.6rem;
  color: var(--secondary);
  transition: color 0.3s;
}
.tarjeta-razon-alt:hover .icono-razon-alt .material-symbols-outlined1 { color: #fff; }

.tarjeta-razon-alt h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--gray-900);
  margin-bottom: 0.5rem;
  line-height: 1.3;
}
.tarjeta-razon-alt p {
  color: var(--gray-500);
  font-size: 0.875rem;
  line-height: 1.65;
}

/* =====================
   SECCIÓN CERTIFICACIONES
===================== */
.seccion-certificaciones {
  padding: 5rem 0;
  background-color: var(--bg-light);
}

.cuadricula-certs {
  display: grid;
  gap: 1.5rem;
  margin-top: 3rem;
  justify-content: center;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

@media (min-width: 640px)  { .cuadricula-certs { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .cuadricula-certs { grid-template-columns: 1fr 1fr; } }

.tarjeta-cert {
  background-color: #fff;
  border-radius: 1rem;
  padding: 2rem 1.5rem;
  box-shadow: 0 4px 16px rgba(0,0,0,0.07);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  transition: box-shadow 0.3s, transform 0.3s;
  border-bottom: 3px solid transparent;
  max-width: 400px;   /* <-- agrega esto */
  width: 100%;        /* <-- y esto */
  margin: 0 auto;     /* <-- y esto */
}

.tarjeta-cert:hover {
  box-shadow: 0 16px 40px rgba(0,0,0,0.12);
  transform: translateY(-4px);
}
.tarjeta-cert.acento-primario  { border-bottom-color: var(--primary); }
.tarjeta-cert.accent-secondary { border-bottom-color: var(--secondary); }

.envoltura-logo-cert {
  width: 4.5rem; height: 4.5rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.25rem;
  flex-shrink: 0;
}
.envoltura-logo-cert.fondo-naranja { background-color: var(--orange-50); }
.envoltura-logo-cert.fondo-azul   { background-color: var(--blue-50); }

.envoltura-logo-cert .material-symbols-outlined { font-size: 2rem; }
.envoltura-logo-cert.fondo-naranja .material-symbols-outlined { color: var(--primary); }
.envoltura-logo-cert.fondo-azul   .material-symbols-outlined { color: var(--secondary); }

.tarjeta-cert h3 {
  font-size: 0.975rem;
  font-weight: 700;
  color: var(--gray-900);
  margin-bottom: 0.4rem;
  line-height: 1.35;
}
.cert-issuer {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--primary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 0.6rem;
}
.tarjeta-cert p {
  font-size: 0.8125rem;
  color: var(--gray-500);
  line-height: 1.6;
}

.confianza-certs {
  margin-top: 4rem;
  padding: 2rem;
  background-color: #fff;
  border-radius: 1rem;
  box-shadow: 0 2px 12px rgba(0,0,0,0.06);
  text-align: center;
}
.confianza-certs p {
  font-size: 0.8125rem;
  color: var(--gray-400);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight: 600;
  margin-bottom: 1.5rem;
}
.logos-confianza {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 2.5rem;
}
.elemento-logo-confianza {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--gray-400);
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  transition: color 0.2s;
}
.elemento-logo-confianza:hover { color: var(--secondary); }
.elemento-logo-confianza .material-symbols-outlined { font-size: 1.5rem; }

/* =====================
   HERO BANNER (Servicios)
===================== */
.hero-servicios {
  background-color: var(--secondary);
  position: relative;
  overflow: hidden;
  padding: 4rem 0 4.5rem;
}

.hero-servicios::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--primary) 0%, #f5a623 100%);
}

.hero-circle-1 {
  position: absolute;
  top: -4rem; right: -4rem;
  width: 22rem; height: 22rem;
  border-radius: 9999px;
  background-color: rgba(255,255,255,0.04);
  pointer-events: none;
}
.hero-circle-2 {
  position: absolute;
  bottom: -6rem; left: -3rem;
  width: 18rem; height: 18rem;
  border-radius: 9999px;
  background-color: rgba(242,125,12,0.07);
  pointer-events: none;
}

/* decorative circles reutilizables */
.hero-dec-1 {
  position: absolute; top: -5rem; right: -5rem;
  width: 24rem; height: 24rem; border-radius: 9999px;
  background: rgba(255,255,255,.04); pointer-events: none;
}
.hero-dec-2 {
  position: absolute; bottom: -6rem; left: -4rem;
  width: 20rem; height: 20rem; border-radius: 9999px;
  background: rgba(242,125,12,.07); pointer-events: none;
}

.hero-content {
  position: relative;
  z-index: 1;
  max-width: 48rem;
}

.breadcrumb {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  margin-bottom: 1.25rem;
  font-size: 0.8125rem;
  color: rgba(255,255,255,0.55);
}
.breadcrumb a { color: rgba(255,255,255,0.55); transition: color 0.2s; }
.breadcrumb a:hover { color: #fff; }
.breadcrumb .material-icons { font-size: 0.9rem; }
.breadcrumb span:last-child { color: var(--primary); font-weight: 600; }

.hero-label {
  display: inline-block;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--primary);
  margin-bottom: 1rem;
}

.hero-servicios h1 {
  font-size: clamp(2rem, 5vw, 3rem);
  font-weight: 700;
  color: #fff;
  line-height: 1.15;
  margin-bottom: 1.25rem;
}

.hero-servicios p {
  font-size: 1.0625rem;
  color: rgba(255,255,255,0.65);
  line-height: 1.75;
  max-width: 38rem;
  margin-bottom: 2rem;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  align-items: center;
}

.btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  background-color: var(--primary);
  color: #fff;
  font-size: 0.9375rem;
  font-weight: 700;
  padding: 0.8rem 2rem;
  border-radius: 9999px;
  box-shadow: 0 6px 20px rgba(242,125,12,0.35);
  transition: background-color 0.2s, transform 0.2s;
}
.btn-primary:hover { background-color: var(--primary-dark); transform: translateY(-2px); }
.btn-primary .material-icons { font-size: 1.1rem; }

.btn-ghost {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  background-color: transparent;
  border: 1.5px solid rgba(255,255,255,0.35);
  color: #fff;
  font-size: 0.9375rem;
  font-weight: 600;
  padding: 0.8rem 2rem;
  border-radius: 9999px;
  transition: background-color 0.2s, border-color 0.2s;
}
.btn-ghost:hover { background-color: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.6); }

/* =====================
   STICKY FILTER NAV
===================== */
.envoltura-nav-filtro {
  background-color: var(--surface-light);
  border-bottom: 1px solid var(--gray-200);
  position: sticky;
  top: 5rem;
  z-index: 40;
}

.nav-filtro {
  display: flex;
  align-items: center;
  gap: 0;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding: 0;
}
.nav-filtro::-webkit-scrollbar { display: none; }

.btn-filtro {
  flex-shrink: 0;
  padding: 1rem 1.5rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--gray-500);
  background: none;
  border: none;
  border-bottom: 3px solid transparent;
  cursor: pointer;
  transition: color 0.2s, border-color 0.2s, background-color 0.2s;
  white-space: nowrap;
  font-family: var(--font);
}
.btn-filtro:hover { color: var(--gray-900); }
.btn-filtro.activo {
  color: var(--primary);
  border-bottom-color: var(--primary);
}

.hide { display: none; }

/* =====================
   SERVICES MAIN CONTENT
===================== */
.principal-servicios { padding: 4rem 0 5rem; }

.seccion-contenido { margin-bottom: 5rem; }
.seccion-contenido:last-child { margin-bottom: 0; }

.seccion-contenido-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
  margin-bottom: 2.5rem;
  padding-bottom: 1.25rem;
  border-bottom: 2px solid var(--gray-100);
}

.etiqueta-grupo {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin-bottom: 0.5rem;
}

.etiqueta-grupo .indicador {
  width: 0.75rem;
  height: 0.75rem;
  border-radius: 9999px;
  flex-shrink: 0;
}
.indicador-primary  { background-color: var(--primary); }
.indicador-secondary { background-color: var(--secondary); }

.etiqueta-grupo h2 {
  font-size: 1.375rem;
  font-weight: 700;
  color: var(--gray-900);
}

.encabezado-seccion p {
  margin-bottom: 2rem;
}

/* --- Featured card (large) --- */
.servicio-destacado {
  display: grid;
  gap: 0;
  border-radius: 1.25rem;
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(0,0,0,0.1);
  margin-bottom: 1.5rem;
  background: #fff;
}
@media (min-width: 768px) {
  .servicio-destacado { grid-template-columns: 1fr 1fr; }
}

.imagen-destacada {
  position: relative;
  min-height: 280px;
  overflow: hidden;
  background-color: var(--gray-200);
}
.imagen-destacada img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s ease;
}
.servicio-destacado:hover .imagen-destacada img { transform: scale(1.04); }

.imagen-destacada .insignia-imagen {
  position: absolute;
  top: 1.25rem;
  left: 1.25rem;
  background-color: var(--primary);
  color: #fff;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 0.3rem 0.75rem;
  border-radius: 9999px;
}
.imagen-destacada .insignia-imagen.azul { background-color: var(--secondary); }

.placeholder-imagen {
  width: 100%;
  height: 100%;
  min-height: 280px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.placeholder-imagen.gradiente-naranja {
  background: linear-gradient(135deg, #FFF7ED 0%, #FDBA74 100%);
}
.placeholder-imagen.gradiente-azul {
  background: linear-gradient(135deg, #EFF6FF 0%, #93C5FD 100%);
}
.placeholder-imagen .material-symbols-outlined {
  font-size: 5rem;
  opacity: 0.3;
}
.placeholder-imagen.gradiente-naranja .material-symbols-outlined { color: var(--primary-dark); }
.placeholder-imagen.gradiente-azul   .material-symbols-outlined { color: var(--secondary); }

.cuerpo-destacado {
  padding: 2.5rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: #fff;
}

.etiqueta-servicio {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.09em;
  color: var(--primary);
  margin-bottom: 0.85rem;
}
.etiqueta-servicio.azul { color: var(--secondary); }
.etiqueta-servicio .material-symbols-outlined { font-size: 1rem; }

.cuerpo-destacado h3 {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--gray-900);
  margin-bottom: 1rem;
  line-height: 1.25;
}

.cuerpo-destacado > p {
  color: var(--gray-600);
  font-size: 0.9375rem;
  line-height: 1.75;
  margin-bottom: 1.5rem;
}

.lista-servicio {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-bottom: 2rem;
}
.elemento-lista {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  font-size: 0.875rem;
  color: var(--gray-600);
  line-height: 1.5;
}
.elemento-lista .material-icons {
  color: var(--primary);
  font-size: 1rem;
  margin-top: 0.15rem;
  flex-shrink: 0;
}

.elemento-lista .material-icons.azul { color: var(--secondary); }

.btn-servicio {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.875rem;
  font-weight: 700;
  padding: 0.65rem 1.5rem;
  border-radius: 9999px;
  border: 2px solid var(--primary);
  color: var(--primary);
  transition: background-color 0.2s, color 0.2s;
  width: max-content;
}
.btn-servicio:hover { background-color: var(--primary); color: #fff; }
.btn-servicio.azul { border-color: var(--secondary); color: var(--secondary); }
.btn-servicio.azul:hover { background-color: var(--secondary); color: #fff; }
.btn-servicio .material-icons { font-size: 1rem; }

.service-cards-grid {
  display: grid;
  gap: 1.25rem;
}
@media (min-width: 640px)  { .service-cards-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .service-cards-grid { grid-template-columns: repeat(3, 1fr); } }

.tarjeta-servicio-sm {
  background: #fff;
  border-radius: 1rem;
  overflow: hidden;
  box-shadow: 0 4px 16px rgba(0,0,0,0.07);
  border-top: 4px solid var(--primary);
  transition: box-shadow 0.3s, transform 0.3s;
  display: flex;
  flex-direction: column;
}
.tarjeta-servicio-sm.azul-top { border-top-color: var(--secondary); }
.tarjeta-servicio-sm:hover {
  box-shadow: 0 16px 40px rgba(0,0,0,0.12);
  transform: translateY(-4px);
}

.card-sm-thumb {
  width: 100%;
  height: 10rem;
  overflow: hidden;
  position: relative;
}
.card-sm-thumb img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.5s;
}
.tarjeta-servicio-sm:hover .card-sm-thumb img { transform: scale(1.06); }

.thumb-placeholder {
  width: 100%; height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.thumb-placeholder.naranja { background: linear-gradient(135deg, #FFF7ED, #FDBA74); }
.thumb-placeholder.azul   { background: linear-gradient(135deg, #EFF6FF, #93C5FD); }
.thumb-placeholder .material-symbols-outlined { font-size: 3rem; opacity: 0.3; }
.thumb-placeholder.naranja .material-symbols-outlined { color: var(--primary-dark); }
.thumb-placeholder.azul   .material-symbols-outlined { color: var(--secondary); }

.card-sm-body {
  padding: 1.5rem;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.card-sm-body h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--gray-900);
  margin-bottom: 0.6rem;
  line-height: 1.3;
}
.card-sm-body p {
  color: var(--gray-500);
  font-size: 0.8125rem;
  line-height: 1.65;
  flex: 1;
  margin-bottom: 1.25rem;
}
.card-sm-link {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  font-size: 0.8125rem;
  font-weight: 700;
  color: var(--primary);
  transition: gap 0.2s, color 0.2s;
}
.card-sm-link.azul { color: var(--secondary); }
.card-sm-link:hover { gap: 0.55rem; }
.card-sm-link .material-icons { font-size: 0.9rem; }

/* =====================
   CTA BAND
===================== */
.franja-llamada-accion {
  background-color: var(--secondary);
  padding: 4rem 0;
  position: relative;
  overflow: hidden;
}
.franja-llamada-accion::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--primary) 0%, #f5a623 100%);
}
.interior-franja,
.interior-llamada-accion {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 1.5rem;
}
@media (min-width: 768px) {
  .interior-franja,
  .interior-llamada-accion {
    flex-direction: row;
    text-align: center;
    justify-content: center;
    gap: 2rem;
  }
}
.franja-llamada-accion h2,
.interior-llamada-accion h2 {
  font-size: clamp(1.4rem, 3vw, 1.875rem);
  font-weight: 700;
  color: #fff;
  margin-bottom: 0.5rem;
}
.franja-llamada-accion p,
.interior-llamada-accion p { color: rgba(255,255,255,0.65); font-size: 1rem; }
.acciones-franja,
.acciones-llamada {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  flex-shrink: 0;
  justify-content: center; /* Centra horizontalmente */
}

/* =====================
   HERO (Nosotros)
===================== */
.hero-nosotros {
  background-color: var(--secondary);
  position: relative;
  overflow: hidden;
  padding: 4.5rem 0 5rem;
}
.hero-nosotros::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--primary) 0%, #f5a623 100%);
}

.cuadricula-hero {
  position: relative; z-index: 1;
  display: grid;
  gap: 3rem;
  align-items: center;
}
@media (min-width: 1024px) { .cuadricula-hero { grid-template-columns: 1fr 1fr; gap: 5rem; } }

.hero-nosotros h1 {
  font-size: clamp(2rem, 5vw, 3rem);
  font-weight: 700; color: #fff;
  line-height: 1.15; margin-bottom: 1.25rem;
}
.hero-nosotros h1 span {
  background: linear-gradient(90deg, var(--primary) 0%, #f5a623 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.hero-nosotros > .container > .cuadricula-hero > div > p {
  font-size: 1.0625rem; color: rgba(255,255,255,.65);
  line-height: 1.75; margin-bottom: 2rem;
}

.estadisticas-hero {
  display: flex; flex-wrap: wrap; gap: 1.5rem;
}
.estadistica-hero-num {
  font-size: 1.875rem; font-weight: 700;
  color: var(--primary); display: block; line-height: 1;
}
.estadistica-hero-lbl {
  font-size: .8rem; color: rgba(255,255,255,.55);
  font-weight: 500; text-transform: uppercase; letter-spacing: .05em;
  display: block; margin-top: .2rem;
}

.envoltura-imagen-hero { position: relative; }
.tarjeta-imagen-hero {
  border-radius: 1.25rem; overflow: hidden;
  box-shadow: 0 30px 60px rgba(0,0,0,.3);
  aspect-ratio: 4/3;
  background: linear-gradient(135deg, #2d4fa3 0%, #1a2f72 100%);
  display: flex; align-items: center; justify-content: center;
}
.tarjeta-imagen-hero img { width: 100%; height: 100%; object-fit: cover; }

.placeholder-imagen-hero {
  display: flex; flex-direction: column; align-items: center;
  gap: .75rem; color: rgba(255,255,255,.25);
}
.placeholder-imagen-hero .material-symbols-outlined { font-size: 5rem; }
.placeholder-imagen-hero span { font-size: .875rem; font-weight: 500; }

.insignia-imagen-hero {
  position: absolute;
  bottom: -1.25rem; left: -1.25rem;
  background: var(--primary);
  color: #fff; border-radius: 1rem;
  padding: 1rem 1.5rem;
  box-shadow: 0 8px 24px rgba(242,125,12,.4);
  display: none;
}
@media (min-width: 768px) { .insignia-imagen-hero { display: block; } }
.insignia-imagen-hero strong { font-size: 1.5rem; font-weight: 700; display: block; line-height: 1; }
.insignia-imagen-hero span   { font-size: .75rem; opacity: .85; }

/* =====================
   MISSION / VISION / VALUES
===================== */
.seccion-mvv {
  padding: 5rem 0;
  background-color: var(--surface-light);
  position: relative;
  overflow: hidden;
}
.seccion-mvv::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--primary) 0%, var(--secondary) 100%);
}

.encabezado-mvv { text-align: center; margin-bottom: 3.5rem; }

.cuadricula-mvv {
  display: grid; gap: 1.5rem;
}
@media (min-width: 768px)  { .cuadricula-mvv { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .cuadricula-mvv { grid-template-columns: 1fr 1fr 1fr; } }

.tarjeta-mvv {
  border-radius: 1.25rem;
  padding: 2.25rem 2rem;
  position: relative;
  overflow: hidden;
  transition: transform .3s, box-shadow .3s;
}
.tarjeta-mvv:hover { transform: translateY(-4px); box-shadow: 0 20px 48px rgba(0,0,0,.1); }

.tarjeta-mvv.mision  { background-color: var(--secondary); color: #fff; }
.tarjeta-mvv.vision   { background-color: var(--surface-light); border: 2px solid var(--gray-100); box-shadow: 0 4px 16px rgba(0,0,0,.06); }
.tarjeta-mvv.valores   { background-color: var(--bg-light); border: 2px solid var(--gray-100); box-shadow: 0 4px 16px rgba(0,0,0,.06); }

.tarjeta-mvv::after {
  content: '';
  position: absolute;
  bottom: -3rem; right: -3rem;
  width: 10rem; height: 10rem;
  border-radius: 9999px;
  pointer-events: none;
}
.tarjeta-mvv.mision::after  { background: rgba(255,255,255,.05); }
.tarjeta-mvv.vision::after   { background: rgba(242,125,12,.06); }
.tarjeta-mvv.valores::after   { background: rgba(31,58,138,.05); }

.icono-mvv {
  width: 3.25rem; height: 3.25rem;
  border-radius: .75rem;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 1.25rem;
}
.tarjeta-mvv.mision  .icono-mvv { background: rgba(255,255,255,.12); }
.tarjeta-mvv.vision   .icono-mvv { background: var(--orange-50); }
.tarjeta-mvv.valores   .icono-mvv { background: var(--blue-50); }

.icono-mvv .material-symbols-outlined { font-size: 1.75rem; }
.tarjeta-mvv.mision  .icono-mvv .material-symbols-outlined { color: var(--primary); }
.tarjeta-mvv.vision   .icono-mvv .material-symbols-outlined { color: var(--primary); }
.tarjeta-mvv.valores   .icono-mvv .material-symbols-outlined { color: var(--secondary); }

.tarjeta-mvv-label {
  font-size: .7rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .12em; margin-bottom: .6rem;
}
.tarjeta-mvv.mision  .tarjeta-mvv-label { color: rgba(255,255,255,.55); }
.tarjeta-mvv.vision   .tarjeta-mvv-label { color: var(--primary); }
.tarjeta-mvv.valores   .tarjeta-mvv-label { color: var(--secondary); }

.tarjeta-mvv h3 {
  font-size: 1.25rem; font-weight: 700; margin-bottom: .75rem; line-height: 1.3;
}
.tarjeta-mvv.mision  h3 { color: #fff; }
.tarjeta-mvv.vision   h3,
.tarjeta-mvv.valores   h3 { color: var(--gray-900); }

.tarjeta-mvv p { font-size: .9rem; line-height: 1.75; }
.tarjeta-mvv.mision p { color: rgba(255,255,255,.7); }
.tarjeta-mvv.vision  p,
.tarjeta-mvv.valores  p { color: var(--gray-600); }

.lista-valores {
  display: flex; flex-direction: column; gap: .55rem; margin-top: 1rem;
}
.elemento-valor {
  display: flex; align-items: center; gap: .5rem;
  font-size: .875rem; font-weight: 600; color: var(--gray-700);
}
.punto-valor {
  width: .5rem; height: .5rem;
  border-radius: 9999px; flex-shrink: 0;
  background-color: var(--secondary);
}

/* =====================
   HISTORY TIMELINE
===================== */
.section-history {
  padding: 5rem 0;
  background-color: var(--bg-light);
}
.history-header { text-align: center; margin-bottom: 4rem; }

.timeline {
  position: relative;
  max-width: 52rem;
  margin: 0 auto;
}
.timeline::before {
  content: '';
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: 0; bottom: 0;
  width: 2px;
  background: linear-gradient(to bottom, var(--primary), var(--secondary));
  border-radius: 9999px;
}
@media (max-width: 767px) {
  .timeline::before { left: 1.25rem; transform: none; }
}

.timeline-item {
  display: grid;
  gap: 1rem;
  margin-bottom: 3rem;
  position: relative;
}
@media (min-width: 768px) {
  .timeline-item { grid-template-columns: 1fr 2.5rem 1fr; align-items: start; }
  .timeline-item:nth-child(even) .tl-content { grid-column: 1; grid-row: 1; text-align: right; }
  .timeline-item:nth-child(even) .tl-dot-col  { grid-column: 2; grid-row: 1; }
  .timeline-item:nth-child(even) .tl-spacer   { grid-column: 3; grid-row: 1; }
  .timeline-item:nth-child(odd)  .tl-spacer   { grid-column: 1; grid-row: 1; }
  .timeline-item:nth-child(odd)  .tl-dot-col  { grid-column: 2; grid-row: 1; }
  .timeline-item:nth-child(odd)  .tl-content  { grid-column: 3; grid-row: 1; }
}
@media (max-width: 767px) {
  .timeline-item { grid-template-columns: 2.5rem 1fr; }
  .tl-spacer { display: none; }
  .tl-dot-col { grid-column: 1; }
  .tl-content { grid-column: 2; }
}

.tl-dot-col { display: flex; justify-content: center; padding-top: .25rem; }
.tl-dot {
  width: 2.5rem; height: 2.5rem; border-radius: 9999px;
  background-color: var(--surface-light);
  border: 3px solid var(--primary);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 0 0 4px rgba(242,125,12,.15);
  z-index: 1; position: relative;
}
.tl-dot .material-icons { font-size: .9rem; color: var(--primary); }

.tl-content {
  background: var(--surface-light);
  border-radius: 1rem;
  padding: 1.5rem;
  box-shadow: 0 4px 16px rgba(0,0,0,.06);
  border-left: 4px solid var(--primary);
  transition: box-shadow .3s, transform .3s;
}
.tl-content:hover { box-shadow: 0 10px 32px rgba(0,0,0,.1); transform: translateY(-2px); }

@media (min-width: 768px) {
  .timeline-item:nth-child(even) .tl-content {
    border-left: none;
    border-right: 4px solid var(--secondary);
  }
  .timeline-item:nth-child(even) .tl-dot { border-color: var(--secondary); box-shadow: 0 0 0 4px rgba(31,58,138,.15); }
  .timeline-item:nth-child(even) .tl-dot .material-icons { color: var(--secondary); }
}

.tl-year {
  font-size: .75rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em;
  color: var(--primary); margin-bottom: .4rem;
}
@media (min-width: 768px) {
  .timeline-item:nth-child(even) .tl-year { color: var(--secondary); }
}
.tl-content h3 { font-size: 1rem; font-weight: 700; color: var(--gray-900); margin-bottom: .4rem; }
.tl-content p  { font-size: .875rem; color: var(--gray-500); line-height: 1.65; }

/* =====================
   TEAM
===================== */
.seccion-equipo {
  padding: 5rem 0;
  background-color: var(--surface-light);
}
.encabezado-equipo { text-align: center; margin-bottom: 1rem; }
.subencabezado-equipo {
  text-align: center;
  color: var(--gray-500); font-size: .9375rem;
  max-width: 36rem; margin: 0 auto 3.5rem;
  line-height: 1.7;
}

.cuadricula-equipo {
  display: grid; gap: 1.5rem;
}
@media (min-width: 640px)  { .cuadricula-equipo { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .cuadricula-equipo { grid-template-columns: repeat(3, 1fr); } }

.tarjeta-miembro {
  background: var(--surface-light);
  border-radius: 1.25rem;
  overflow: hidden;
  box-shadow: 0 4px 16px rgba(0,0,0,.07);
  transition: box-shadow .3s, transform .3s;
  border: 1px solid var(--gray-100);
}
.tarjeta-miembro:hover { box-shadow: 0 16px 40px rgba(0,0,0,.12); transform: translateY(-6px); }

.tarjeta-miembro-photo {
  width: 100%; aspect-ratio: 3/4;
  overflow: hidden; position: relative;
  background: linear-gradient(135deg, #EFF6FF 0%, #BFDBFE 100%);
}
.tarjeta-miembro-photo img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .6s ease;
}
.tarjeta-miembro:hover .tarjeta-miembro-photo img { transform: scale(1.05); }

.placeholder-foto {
  width: 100%; height: 100%;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: .5rem;
}
.placeholder-foto.naranja { background: linear-gradient(135deg, #FFF7ED, #FDBA74 80%); }
.placeholder-foto.azul   { background: linear-gradient(135deg, #EFF6FF, #93C5FD 80%); }
.placeholder-foto .material-symbols-outlined { font-size: 4.5rem; opacity: .3; }
.placeholder-foto.naranja .material-symbols-outlined { color: var(--primary-dark); }
.placeholder-foto.azul   .material-symbols-outlined { color: var(--secondary); }

.tarjeta-miembro-ribbon { height: 4px; }
.tarjeta-miembro-ribbon.naranja { background: var(--primary); }
.tarjeta-miembro-ribbon.azul   { background: var(--secondary); }

.tarjeta-miembro-body { padding: 1.25rem; }
.tarjeta-miembro-body h3 { font-size: .9375rem; font-weight: 700; color: var(--gray-900); margin-bottom: .2rem; }
.tarjeta-miembro-role {
  font-size: .8rem; font-weight: 600; color: var(--primary);
  text-transform: uppercase; letter-spacing: .07em; margin-bottom: .75rem; display: block;
}
.tarjeta-miembro-role.azul { color: var(--secondary); }
.tarjeta-miembro-body p { font-size: .8125rem; color: var(--gray-500); line-height: 1.6; margin-bottom: 1rem; }

.team-social { display: flex; gap: .5rem; }
.team-social a {
  width: 2rem; height: 2rem; border-radius: .5rem;
  background-color: var(--gray-100);
  display: flex; align-items: center; justify-content: center;
  color: var(--gray-500); transition: background-color .2s, color .2s;
}
.team-social a:hover { background-color: var(--primary); color: #fff; }
.team-social a.azul:hover { background-color: var(--secondary); }
.team-social a svg { width: .9rem; height: .9rem; fill: currentColor; }

/* =====================
   HERO (Bolsa de Trabajo)
===================== */
.bolsa-hero {
  background-color: var(--secondary);
  position: relative; overflow: hidden; padding: 4rem 0 4.5rem;
}
.bolsa-hero::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px;
  background: linear-gradient(90deg, var(--primary) 0%, #f5a623 100%);
}

.bolsa-hero h1 { font-size: clamp(2rem, 5vw, 3rem); font-weight: 700; color: #fff; line-height: 1.15; margin-bottom: 1.25rem; }
.bolsa-hero p  { font-size: 1.0625rem; color: rgba(255,255,255,.65); line-height: 1.75; max-width: 38rem; }

/* =====================
   TYPE SELECTOR
===================== */
.seccion-selector-tipo {
  background-color: var(--surface-light);
  border-bottom: 1px solid var(--gray-200);
  padding: 2.5rem 0;
  position: sticky;
  top: 5rem;
  z-index: 40;
}

.selector-tipo {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  justify-content: center;
}

/* ================= BOTÓN BASE ================= */

.btn-tipo {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding: .85rem 2rem;
  border-radius: 9999px;
  border: 2px solid var(--gray-200);
  background: var(--surface-light);
  font-size: .9375rem;
  font-weight: 600;
  color: var(--gray-500);
  cursor: pointer;
  transition: all .25s;
  font-family: var(--font);
}

.btn-tipo .material-symbols-outlined {
  font-size: 1.375rem;
  transition: color .25s;
}

/* ================= HOVER BASE ================= */

.btn-tipo:hover {
  border-color: var(--primary);
  color: var(--primary);
}

/* ================= ACTIVO BASE (NARANJA) ================= */

.btn-tipo.activo {
  border-color: var(--primary);
  background-color: var(--primary);
  color: #fff;
  box-shadow: 0 6px 20px rgba(242,125,12,.3);
}

.btn-tipo.activo .material-symbols-outlined {
  color: #fff;
}

/* ================= VARIANTE AZUL ================= */

/* Azul normal (NO activo) */
.btn-tipo.azul {
  border-color: var(--secondary);
  color: var(--secondary);
}

/* Hover azul */
.btn-tipo.azul:hover {
  background-color: var(--secondary);
  color: #fff;
}

/* Azul activo */
.btn-tipo.azul.activo {
  background-color: var(--secondary);
  border-color: var(--secondary);
  color: #fff;
  box-shadow: 0 6px 20px rgba(24, 50, 165, 0.3);
}

.btn-tipo.azul.activo .material-symbols-outlined {
  color: #fff;
}


/* =====================
   FORMS SECTION
===================== */
.seccion-formularios { padding: 4.5rem 0 5rem; }

.panel-formulario { display: none; }
.panel-formulario.activo { display: block; }

.encabezado-panel { text-align: center; margin-bottom: 3.5rem; }
.encabezado-panel .section-label { display: block; margin-bottom: .5rem; }
.encabezado-panel h2 { font-size: clamp(1.6rem, 4vw, 2.1rem); font-weight: 700; color: var(--gray-900); margin-bottom: .75rem; }
.encabezado-panel p  { color: var(--gray-500); font-size: .9375rem; max-width: 38rem; margin: 0 auto; line-height: 1.7; }

.tarjeta-formulario {
  background: var(--surface-light);
  border-radius: 1.25rem;
  box-shadow: 0 8px 40px rgba(0,0,0,.09);
  border: 1px solid var(--gray-100);
  overflow: hidden;
  max-width: 56rem; margin: 0 auto;
}
.tarjeta-formulario::before {
  content: ''; display: block; height: 4px;
  background: linear-gradient(90deg, var(--primary) 0%, #f5a623 100%);
}
.tarjeta-formulario.azul::before {
  background: linear-gradient(90deg, var(--secondary) 0%, #4f6ec4 100%);
}

.interior-tarjeta { padding: 2.5rem; }

.form-row    { display: grid; gap: 1.5rem; }
@media (min-width: 640px) { .form-row { grid-template-columns: 1fr 1fr; } }
.form-row-3 { display: grid; gap: 1.5rem; }
@media (min-width: 640px) { .form-row-3 { grid-template-columns: 1fr 1fr 1fr; } }

.form-group label .req { color: var(--primary); }

.azul-accent .form-group input:focus,
.azul-accent .form-group select:focus,
.azul-accent .form-group textarea:focus {
  border-color: var(--secondary);
  box-shadow: 0 0 0 3px rgba(31,58,138,.12);
}

/* CV Upload zone */
.zona-carga {
  border: 2px dashed var(--gray-300);
  border-radius: .875rem; padding: 2.5rem 1.5rem;
  background-color: var(--bg-light);
  text-align: center; cursor: pointer;
  transition: border-color .25s, background-color .25s;
  position: relative;
}
.zona-carga:hover, .zona-carga.dragover {
  border-color: var(--primary); background-color: var(--orange-50);
}
.zona-carga input[type="file"] {
  position: absolute; inset: 0; opacity: 0; cursor: pointer; width: 100%; height: 100%;
}
.upload-icon {
  width: 3.5rem; height: 3.5rem; border-radius: 9999px;
  background-color: var(--orange-50); display: flex; align-items: center;
  justify-content: center; margin: 0 auto 1rem; transition: background-color .25s;
}
.zona-carga:hover .upload-icon, .zona-carga.dragover .upload-icon { background-color: var(--primary); }
.upload-icon .material-symbols-outlined { font-size: 1.75rem; color: var(--primary); transition: color .25s; }


.zona-carga.azul {
  border: 2px dashed var(--gray-300);
  border-radius: .875rem; padding: 2.5rem 1.5rem;
  background-color: var(--bg-light);
  text-align: center; cursor: pointer;
  transition: border-color .25s, background-color .25s;
  position: relative;
}
.zona-carga.azul:hover, .zona-carga.azul.dragover {
  border-color: var(--secondary); background-color: var(--blue-390);
}

.upload-icon.azul {
  width: 3.5rem; height: 3.5rem; border-radius: 9999px;
  background-color: var(--bg-light); display: flex; align-items: center;
  justify-content: center; margin: 0 auto 1rem; transition: background-color .25s;
}
.zona-carga.azul:hover .upload-icon.azul, .zona-carga.azul .upload-icon.azul { background-color: var(--secondary); }
.upload-icon.azul .material-symbols-outlined.azul { font-size: 1.75rem; color: var(--bg-light); transition: color .25s; }


.zona-carga:hover .upload-icon .material-symbols-outlined,
.zona-carga.dragover .upload-icon .material-symbols-outlined { color: #fff; }

.upload-title { font-size: .9375rem; font-weight: 700; color: var(--gray-900); margin-bottom: .35rem; }
.upload-subtitle { font-size: .8125rem; color: var(--gray-400); line-height: 1.6; }
.upload-subtitle span { color: var(--primary); font-weight: 600; }

.upload-title.azul { font-size: .9375rem; font-weight: 700; color: var(--gray-900); margin-bottom: .35rem; }
.upload-subtitle.azul { font-size: .8125rem; color: var(--gray-400); line-height: 1.6; }
.upload-subtitle.azul span { color: var(--secondary); font-weight: 600; }


.archivo-seleccionado {
  display: none; align-items: center; gap: .75rem;
  background: var(--orange-50); border: 1.5px solid var(--primary);
  border-radius: .625rem; padding: .75rem 1rem; margin-top: .75rem;
}
.archivo-seleccionado.visible { display: flex; }
.archivo-seleccionado .material-icons { color: var(--primary); font-size: 1.25rem; }
.archivo-seleccionado span { font-size: .8125rem; font-weight: 600; color: var(--gray-800); flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.archivo-seleccionado button { background: none; border: none; cursor: pointer; color: var(--gray-400); transition: color .2s; line-height: 0; }
.archivo-seleccionado button:hover { color: var(--primary); }


.archivo-seleccionado.azul {
  display: none; align-items: center; gap: .75rem;
  background: var(--orange-50); border: 1.5px solid var(--secondary);
  border-radius: .625rem; padding: .75rem 1rem; margin-top: .75rem;
}
.archivo-seleccionado.azul .visible { display: flex; }
.archivo-seleccionado.azul  .material-icons.azul  { color: var(--secondary); font-size: 1.25rem; }
.archivo-seleccionado.azul  span { font-size: .8125rem; font-weight: 600; color: var(--gray-800); flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.archivo-seleccionado.azul  button { background: none; border: none; cursor: pointer; color: var(--gray-400); transition: color .2s; line-height: 0; }
.archivo-seleccionado.azul  button:hover { color: var(--secondary); }





/* Pills */
.pills-label { font-size: .8125rem; font-weight: 600; color: var(--gray-700); margin-bottom: .5rem; display: block; }
.pills-wrap  { display: flex; flex-wrap: wrap; gap: .5rem; }
.pill {
  padding: .38rem .9rem; border-radius: 9999px;
  border: 1.5px solid var(--gray-200); font-size: .78rem; font-weight: 600;
  color: var(--gray-500); cursor: pointer; transition: all .2s;
  background: var(--surface-light); user-select: none;
}
.pill:hover  { border-color: var(--primary); color: var(--primary); }
.pill.activo { border-color: var(--primary); background-color: var(--primary); color: #fff; }


.pill.blue {
  padding: .38rem .9rem; border-radius: 9999px;
  border: 1.5px solid var(--gray-200); font-size: .78rem; font-weight: 600;
  color: var(--gray-500); cursor: pointer; transition: all .2s;
  background: var(--surface-light); user-select: none;
}
.pill.blue:hover  { border-color: #1565c0; color: #1565c0; }
.pill.blue.activo { border-color: #1565c0;  background-color: #1565c0;  color: #fff;}


/* service pills alias */
.pastillas-servicio { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: .5rem; }

/* Radio group */
.radio-group { display: flex; flex-wrap: wrap; gap: .75rem; }
.radio-item  { display: flex; align-items: center; gap: .4rem; cursor: pointer; font-size: .875rem; font-weight: 500; color: var(--gray-600); }
.radio-item input[type="radio"] { accent-color: var(--primary); width: 1rem; height: 1rem; cursor: pointer; }

.radio-item.azul  { display: flex; align-items: center; gap: .4rem; cursor: pointer; font-size: .875rem; font-weight: 500; color: var(--gray-600); }
.radio-item.azul input[type="radio"] { accent-color: var(--secondary); width: 1rem; height: 1rem; cursor: pointer; }

.azul-accent .radio-item input[type="radio"] { accent-color: var(--secondary); }

/* Form divider */
.form-divider { display: flex; align-items: center; gap: 1rem; margin: .5rem 0; }
.form-divider span { font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--gray-400); white-space: nowrap; }
.form-divider::before, .form-divider::after { content: ''; flex: 1; height: 1px; background: var(--gray-200); }

/* Privacy check */
.privacy-check {
  display: flex; align-items: flex-start; gap: .65rem;
  font-size: .8rem; color: var(--gray-500); line-height: 1.6;
}
.privacy-check input[type="checkbox"] { width: 1rem; height: 1rem; margin-top: .1rem; accent-color: var(--primary); flex-shrink: 0; cursor: pointer; }
.privacy-check.azul input[type="checkbox"] { width: 1rem; height: 1rem; margin-top: .1rem; accent-color: var(--secondary); flex-shrink: 0; cursor: pointer; }
.privacy-check a { color: var(--primary); font-weight: 600; }
.privacy-check.azul a { color: var(--secondary); font-weight: 600; }

/* Form success */
.exito-formulario {
  display: none; flex-direction: column; align-items: center;
  text-align: center; gap: 1rem; padding: 3rem 1.5rem;
}
.exito-formulario.visible { display: flex; }
.icono-exito { width: 4.5rem; height: 4.5rem; border-radius: 9999px; background-color: #D1FAE5; display: flex; align-items: center; justify-content: center; }
.icono-exito .material-icons { font-size: 2.25rem; color: #059669; }
.exito-formulario h4 { font-size: 1.25rem; font-weight: 700; color: var(--gray-900); }
.exito-formulario p  { font-size: .875rem; color: var(--gray-500); max-width: 24rem; line-height: 1.7; }
.exito-formulario .btn-back {
  display: inline-flex; align-items: center; gap: .4rem;
  font-size: .875rem; font-weight: 700; color: var(--primary);
  border: 2px solid var(--primary); padding: .6rem 1.5rem;
  border-radius: 9999px; transition: background-color .2s, color .2s; margin-top: .5rem;
}
.exito-formulario .btn-back:hover { background-color: var(--primary); color: #fff; }

/* =====================
   SUCESS
===================== */

.form-success {
  display: none; flex-direction: column; align-items: center;
  text-align: center; gap: 1rem; padding: 3rem 1.5rem;
}
.form-success.visible { display: flex; }
.success-icon { width: 4.5rem; height: 4.5rem; border-radius: 9999px; background-color: #D1FAE5; display: flex; align-items: center; justify-content: center; }
.success-icon .material-icons { font-size: 2.25rem; color: #059669; }
.form-success h4 { font-size: 1.25rem; font-weight: 700; color: var(--gray-900); }
.form-success p  { font-size: .875rem; color: var(--gray-500); max-width: 24rem; line-height: 1.7; }
.form-success .btn-back {
  display: inline-flex; align-items: center; gap: .4rem;
  font-size: .875rem; font-weight: 700; color: var(--primary);
  border: 2px solid var(--primary); padding: .6rem 1.5rem;
  border-radius: 9999px; transition: background-color .2s, color .2s; margin-top: .5rem;
}
.form-success .btn-back:hover { background-color: var(--primary); color: #fff; }



/* =====================
   INFO STRIP
===================== */
.franja-info {
  background-color: var(--surface-light);
  border-top: 1px solid var(--gray-100);
  padding: 4rem 0;
}
.franja-info-header { text-align: center; margin-bottom: 3rem; }
.franja-info-header .section-label { display: block; margin-bottom: .5rem; }
.franja-info-header h2 { font-size: clamp(1.5rem, 3.5vw, 2rem); font-weight: 700; color: var(--gray-900); }

.cuadricula-info { display: grid; gap: 1.25rem; }
@media (min-width: 640px)  { .cuadricula-info { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .cuadricula-info { grid-template-columns: repeat(4, 1fr); } }

.tarjeta-info {
  background: var(--bg-light); border-radius: 1rem; padding: 1.75rem 1.5rem;
  border: 1px solid var(--gray-200); text-align: center;
  transition: box-shadow .3s, transform .3s;
}
.tarjeta-info:hover { box-shadow: 0 12px 32px rgba(0,0,0,.08); transform: translateY(-3px); }

.tarjeta-info-icon {
  width: 3.25rem; height: 3.25rem; border-radius: 9999px;
  display: flex; align-items: center; justify-content: center; margin: 0 auto 1rem;
}
.tarjeta-info-icon.naranja { background-color: var(--orange-50); }
.tarjeta-info-icon.azul   { background-color: var(--blue-50); }
.tarjeta-info-icon .material-symbols-outlined { font-size: 1.6rem; }
.tarjeta-info-icon.naranja .material-symbols-outlined { color: var(--primary); }
.tarjeta-info-icon.azul   .material-symbols-outlined { color: var(--secondary); }

.tarjeta-info h3 { font-size: .9375rem; font-weight: 700; color: var(--gray-900); margin-bottom: .4rem; }
.tarjeta-info p  { font-size: .8125rem; color: var(--gray-500); line-height: 1.65; }

/* =====================
   HERO (Contacto)
===================== */
.hero-contacto {
  background-color: var(--secondary);
  position: relative; overflow: hidden; padding: 4rem 0 4.5rem;
}
.hero-contacto::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px;
  background: linear-gradient(90deg, var(--primary) 0%, #f5a623 100%);
}

.hero-contacto h1 {
  font-size: clamp(2rem, 5vw, 3rem);
  font-weight: 700; color: #fff; line-height: 1.15; margin-bottom: 1.25rem;
}
.hero-contacto p {
  font-size: 1.0625rem; color: rgba(255,255,255,.65); line-height: 1.75; max-width: 36rem;
}

/* =====================
   QUICK CONTACT CARDS
===================== */
.seccion-tarjetas-rapidas {
  background-color: var(--surface-light);
  padding: 3.5rem 0;
  border-bottom: 1px solid var(--gray-100);
}
.cuadricula-tarjetas-rapidas { display: grid; gap: 1.25rem; }
@media (min-width: 640px)  { .cuadricula-tarjetas-rapidas { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .cuadricula-tarjetas-rapidas { grid-template-columns: repeat(4, 1fr); } }

.tarjeta-rapida {
  background: var(--surface-light); border: 1px solid var(--gray-200);
  border-radius: 1rem; padding: 1.75rem 1.5rem;
  display: flex; flex-direction: column; align-items: flex-start; gap: 1rem;
  box-shadow: 0 2px 10px rgba(0,0,0,.05);
  transition: box-shadow .3s, transform .3s, border-color .3s; text-decoration: none;
}
.tarjeta-rapida:hover { box-shadow: 0 12px 32px rgba(0,0,0,.1); transform: translateY(-4px); border-color: transparent; }
.tarjeta-rapida:hover .icono-tr.naranja { background-color: var(--primary); }
.tarjeta-rapida:hover .icono-tr.naranja .material-icons { color: #fff; }
.tarjeta-rapida:hover .icono-tr.azul   { background-color: var(--secondary); }
.tarjeta-rapida:hover .icono-tr.azul   .material-icons { color: #fff; }

.icono-tr {
  width: 3rem; height: 3rem; border-radius: .75rem;
  display: flex; align-items: center; justify-content: center;
  transition: background-color .3s; flex-shrink: 0;
}
.icono-tr.naranja { background-color: var(--orange-50); }
.icono-tr.azul   { background-color: var(--blue-50); }
.icono-tr .material-icons { font-size: 1.375rem; transition: color .3s; }
.icono-tr.naranja .material-icons { color: var(--primary); }
.icono-tr.azul   .material-icons { color: var(--secondary); }

.etiqueta-tr { font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--gray-400); margin-bottom: .25rem; }
.valor-tr { font-size: .9375rem; font-weight: 600; color: var(--gray-900); line-height: 1.4; }
.sub-tr   { font-size: .8rem; color: var(--gray-400); margin-top: .15rem; }

/* =====================
   MAIN CONTACT SECTION
===================== */
.contacto-principal { padding: 5rem 0; background-color: var(--bg-light); }
.cuadricula-contacto-principal { display: grid; gap: 3rem; align-items: start; }
@media (min-width: 1024px) { .cuadricula-contacto-principal { grid-template-columns: 1fr 1.5fr; gap: 4rem; } }

.columna-info-contacto .col-label {
  font-size: .75rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .12em; color: var(--primary); display: block; margin-bottom: .75rem;
}
.columna-info-contacto h2 {
  font-size: clamp(1.6rem, 4vw, 2.1rem); font-weight: 700; color: var(--gray-900); margin-bottom: 1rem; line-height: 1.2;
}
.columna-info-contacto > p { color: var(--gray-500); font-size: .9375rem; line-height: 1.75; margin-bottom: 2.5rem; }

.ci-icon {
  width: 2.75rem; height: 2.75rem; border-radius: .625rem;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; color: #fff;
}
.ci-icon.orange { background-color: var(--primary); box-shadow: 0 4px 12px rgba(242,125,12,.3); }
.ci-icon.blue   { background-color: var(--secondary); box-shadow: 0 4px 12px rgba(31,58,138,.25); }
.ci-icon .material-icons { font-size: 1.1rem; }

.ci-body h5 { font-size: .875rem; font-weight: 700; color: var(--gray-900); margin-bottom: .2rem; }
.ci-body p  { font-size: .8125rem; color: var(--gray-500); line-height: 1.6; }
.ci-body a  { color: var(--gray-500); transition: color .2s; }
.ci-body a:hover { color: var(--primary); }

.bloque-horario {
  background: var(--surface-light); border-radius: .875rem;
  border: 1px solid var(--gray-100); box-shadow: 0 2px 8px rgba(0,0,0,.04);
  padding: 1.25rem; margin-bottom: 2.5rem;
}
.bloque-horario h5 {
  font-size: .875rem; font-weight: 700; color: var(--gray-900);
  margin-bottom: 1rem; display: flex; align-items: center; gap: .5rem;
}
.bloque-horario h5 .material-icons { color: var(--primary); font-size: 1.1rem; }

.fila-horario {
  display: flex; justify-content: space-between; align-items: center;
  padding: .45rem 0; border-bottom: 1px solid var(--gray-100); font-size: .8125rem;
}
.fila-horario:last-child { border-bottom: none; }
.fila-horario span:first-child { color: var(--gray-600); font-weight: 500; }
.fila-horario span:last-child  { color: var(--gray-900); font-weight: 600; }
.fila-horario .closed { color: var(--gray-400); }

.fila-social { display: flex; gap: .75rem; flex-wrap: wrap; }
.btn-social {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .55rem 1.1rem; border-radius: 9999px;
  border: 1.5px solid var(--gray-200);
  font-size: .8125rem; font-weight: 600; color: var(--gray-600);
  transition: background-color .2s, border-color .2s, color .2s;
}
.btn-social:hover { border-color: var(--primary); color: var(--primary); background-color: var(--orange-50); }
.btn-social svg { width: 1rem; height: 1rem; fill: currentColor; }

.tarjeta-formulario-contacto {
  background: var(--surface-light); border-radius: 1.25rem;
  box-shadow: 0 8px 40px rgba(0,0,0,.1); padding: 2.5rem;
  border: 1px solid var(--gray-100); position: relative; overflow: hidden;
}
.tarjeta-formulario-contacto::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px;
  background: linear-gradient(90deg, var(--primary) 0%, #f5a623 100%);
}

.encabezado-tarjeta { margin-bottom: 2rem; }
.encabezado-tarjeta h3 { font-size: 1.25rem; font-weight: 700; color: var(--gray-900); margin-bottom: .35rem; }
.encabezado-tarjeta p  { font-size: .875rem; color: var(--gray-400); }

/* =====================
   MAP SECTION
===================== */
.marco-mapa {
  width: 100%;
  height: 32rem; /* Más grande en desktop */
  border-radius: 1.5rem;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(0,0,0,.15);
  border: 1px solid var(--gray-200);
  background-color: var(--gray-100);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  transition: all .3s ease;
}
.encabezado-mapa h2 .material-icons { color: var(--primary); font-size: 1.5rem; margin-bottom: 0.5rem;}
.encabezado-mapa p  { font-size: .875rem; color: var(--gray-400); margin-top: .3rem; margin-bottom: 1rem;}

.marco-mapa iframe {
  width: 100%;
  height: 100%;
  border: none;
  display: block;
}

/* Tablets */
@media (max-width: 1024px) {
  .marco-mapa {
    height: 26rem;
    border-radius: 1.25rem;
  }
}

/* Móviles */
@media (max-width: 640px) {
  .marco-mapa {
    height: 22rem;
    border-radius: 1rem;
  }
}


/* =====================
   FAQ STRIP
===================== */
.seccion-preguntas { padding: 5rem 0; background-color: var(--surface-light); border-top: 1px solid var(--gray-100); }
.encabezado-preguntas { text-align: center; margin-bottom: 3rem; }
.encabezado-preguntas .section-label { display: block; margin-bottom: .5rem; }
.encabezado-preguntas h2 { font-size: clamp(1.6rem, 4vw, 2rem); font-weight: 700; color: var(--gray-900); }

.cuadricula-preguntas { display: grid; gap: 1rem; max-width: 52rem; margin: 0 auto; }

.elemento-pregunta {
  background: var(--bg-light); border: 1px solid var(--gray-200);
  border-radius: .875rem; overflow: hidden; transition: box-shadow .2s;
}
.elemento-pregunta:hover { box-shadow: 0 4px 16px rgba(0,0,0,.07); }

.boton-pregunta {
  width: 100%; display: flex; align-items: center; justify-content: space-between;
  padding: 1.1rem 1.5rem; gap: 1rem;
  background: none; border: none; cursor: pointer; text-align: left; font-family: var(--font);
}
.boton-pregunta span:first-child { font-size: .9375rem; font-weight: 600; color: var(--gray-900); }
.chevron-pregunta { color: var(--gray-400); flex-shrink: 0; transition: transform .3s, color .3s; }
.elemento-pregunta.abierto .chevron-pregunta { transform: rotate(180deg); color: var(--primary); }
.elemento-pregunta.abierto .boton-pregunta span:first-child { color: var(--primary); }

.respuesta-pregunta { max-height: 0; overflow: hidden; transition: max-height .35s ease, padding .35s ease; padding: 0 1.5rem; }
.elemento-pregunta.abierto .respuesta-pregunta { max-height: 10rem; padding: 0 1.5rem 1.25rem; }
.respuesta-pregunta p { font-size: .875rem; color: var(--gray-500); line-height: 1.7; }


.area-logo a {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  text-decoration: none;
}

.area-logo img {
  height: 90px;
  width: auto;
}

.logo-eslogan {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.75rem;
  font-weight: 500;
  color: #555;
  letter-spacing: 0.05em;
}

.logo-footer img {
  height: 100px;
  width: auto;
}
/* =====================
   ALIASES DE CORRECCIÓN - Selectores que quedaron desalineados
===================== */

/* contacto.php - layout grid */
.cuadricula-contacto-principal {
  display: grid;
  gap: 3rem;
  align-items: start;
}
@media (min-width: 1024px) {
  .cuadricula-contacto-principal {
    grid-template-columns: 1fr 1.5fr;
    gap: 4rem;
  }
}

/* contacto.php - columna info */
.columna-info-contacto .col-label {
  display: block;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--primary);
  margin-bottom: .75rem;
}
.columna-info-contacto h2 {
  font-size: clamp(1.75rem, 3vw, 2.25rem);
  font-weight: 800;
  color: var(--gray-900);
  margin-bottom: 1rem;
}
.columna-info-contacto > p {
  color: var(--gray-500);
  font-size: .9375rem;
  line-height: 1.75;
  margin-bottom: 2.5rem;
}

/* servicios.php - puntos de sección (distintos del carrusel) */
.dot-primary { background-color: var(--primary); }
.dot-secondary { background-color: var(--secondary); }

/* bolsa.php - pastillas azules */
.blue-pill {
  background-color: var(--blue-50, #eff2fc);
  color: var(--secondary);
  border-color: var(--secondary);
}
.blue-pill.activo,
.blue-pill:hover {
  background-color: var(--secondary);
  color: #fff;
  border-color: var(--secondary);
}

/* index.php - tarjeta única certificaciones */
.tarjeta-unica {
  max-width: 36rem;
  margin: 0 auto;
  grid-template-columns: 1fr !important;
}

/* servicios.php - punto decorativo de sección (circulito antes del título) */
.etiqueta-grupo .dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}

/* contacto.php - pill active (no renombrado en HTML) */
.pill.active {
  border-color: var(--primary);
  background-color: var(--primary);
  color: #fff;
}

/* contacto.php - faq-chevron (no renombrado en HTML) */
.faq-chevron {
  color: var(--gray-400);
  flex-shrink: 0;
  transition: transform .3s, color .3s;
}
.elemento-pregunta.abierto .faq-chevron {
  transform: rotate(180deg);
  color: var(--primary);
}

.estadisticas-hero {
  display: flex; flex-wrap: wrap; gap: 1.5rem;
}
.numero-estadistica {
  font-size: 1.875rem; font-weight: 700;
  color: var(--primary); display: block; line-height: 1;
}
.etiqueta-estadistica {
  font-size: .8rem; color: rgba(255,255,255,.55);
  font-weight: 500; text-transform: uppercase; letter-spacing: .05em;
  display: block; margin-top: .2rem;
}


.cinta-miembro { height: 4px; }
.cinta-miembro.naranja { background: var(--primary); }
.cinta-miembro.azul  { background: var(--secondary); }


.cuerpo-miembro { padding: 1.25rem; }
.cuerpo-miembro h3 { font-size: .9375rem; font-weight: 700; color: var(--gray-900); margin-bottom: .2rem; }
.rol-miembro {
  font-size: .8rem; font-weight: 600; color: var(--primary);
  text-transform: uppercase; letter-spacing: .07em; margin-bottom: .75rem; display: block;
}
.rol-miembro.azul { color: var(--secondary); }
.cuerpo-miembro p { font-size: .8125rem; color: var(--gray-500); line-height: 1.6; margin-bottom: 1rem; }



.cta-band {
  background-color: var(--secondary);
  padding: 4rem 0;
  position: relative;
  overflow: hidden;
}
.cta-band::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--primary) 0%, #f5a623 100%);
}
.cta-band-inner,
.cta-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 1.5rem;
}
@media (min-width: 768px) {
  .cta-band-inner,
  .cta-inner {
    flex-direction: row;
    text-align: left;
    justify-content: space-between;
    gap: 2rem;
  }
}
.cta-band h2,
.cta-inner h2 {
  font-size: clamp(1.4rem, 3vw, 1.875rem);
  font-weight: 700;
  color: #fff;
  margin-bottom: 0.5rem;
}
.cta-band p,
.cta-inner p { color: rgba(255,255,255,0.65); font-size: 1rem; }
.cta-band-actions,
.cta-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;      /* centrado vertical */
  justify-content: center;  /* centrado horizontal */
  gap: 0.75rem;
  flex-shrink: 0;
}


.franja-info {
  background-color: var(--surface-light);
  border-top: 1px solid var(--gray-100);
  padding: 4rem 0;
}
.encabezado-franja { text-align: center; margin-bottom: 3rem; }
.encabezado-franja .section-label { display: block; margin-bottom: .5rem; }
.encabezado-franja h2 { font-size: clamp(1.5rem, 3.5vw, 2rem); font-weight: 700; color: var(--gray-900); }

.cuadricula-info { display: grid; gap: 1.25rem; }
@media (min-width: 640px)  { .cuadricula-info { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .cuadricula-info { grid-template-columns: repeat(4, 1fr); } }

.tarjeta-info {
  background: var(--bg-light); border-radius: 1rem; padding: 1.75rem 1.5rem;
  border: 1px solid var(--gray-200); text-align: center;
  transition: box-shadow .3s, transform .3s;
}
.tarjeta-info:hover { box-shadow: 0 12px 32px rgba(0,0,0,.08); transform: translateY(-3px); }

.icono-tarjeta {
  width: 3.25rem; height: 3.25rem; border-radius: 9999px;
  display: flex; align-items: center; justify-content: center; margin: 0 auto 1rem;
}
.icono-tarjeta.naranja { background-color: var(--orange-50); }
.icono-tarjeta.azul   { background-color: var(--blue-50); }
.icono-tarjeta .material-symbols-outlined { font-size: 1.6rem; }
.icono-tarjeta.naranja .material-symbols-outlined { color: var(--primary); }
.icono-tarjeta.azul   .material-symbols-outlined { color: var(--secondary); }

.tarjeta-info h3 { font-size: .9375rem; font-weight: 700; color: var(--gray-900); margin-bottom: .4rem; }
.tarjeta-info p  { font-size: .8125rem; color: var(--gray-500); line-height: 1.65; }


.float {
    position: fixed;
    width: 60px;
    height: 60px;
    bottom: 40px;
    right: 40px;
    background-color: #25d366;
    color: #FFF;
    border-radius: 50px;
    text-align: center;
    font-size: 30px;
    box-shadow: 2px 2px 3px #999;
    z-index: 100;
}

.my-float {
    margin-top: 16px;
}
