/* ============================================================
   IMPORTACIÓN DE FUENTES
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,600;0,9..144,700;1,9..144,400&family=Montserrat:wght@300;400;500;600;700&display=swap');

/* ============================================================
   VARIABLES GLOBALES
   ============================================================ */
:root {
  /* ── Paleta original (azul institucional) ────────────────
  --color-fondo-principal: #FAF7F2;
  --color-seccion:         #1F3C88;
  --color-btn-secundario:  #2E4FA3;
  --color-btn-cta:         #F25C05;
  --color-hover:           #FF7A1A;
  --color-texto-azul:      #FFFFFF;
  --color-texto-titulo:    #1F3C88;
  --color-texto-cuerpo:    #555555;
  ──────────────────────────────────────────────────────── */

  /* ── Paleta tierra / natural ─────────────────────────── */
  --color-fondo-principal: #FAF3E8;   /* Crema cálida */
  --color-seccion:         #4A2C17;   /* Marrón oscuro — cacao tostado */
  --color-btn-secundario:  #7A4528;   /* Castaño medio */
  --color-btn-cta:         #C0622B;   /* Terracota */
  --color-hover:           #D4732E;   /* Terracota claro */

  /* Texto */
  --color-texto-azul:      #FFF8F0;   /* Blanco cálido (sobre fondos oscuros) */
  --color-texto-titulo:    #3B1F0D;   /* Marrón muy oscuro */
  --color-texto-cuerpo:    #6B5248;   /* Marrón medio cálido */
  --color-seccion-suave:   rgba(74, 44, 23, 0.12); /* Bordes y fondos tenues */

  /* Tipografía */
  --fuente-titulos:  'Fraunces', Georgia, serif;
  --fuente-cuerpo:   'Montserrat', Arial, sans-serif;

  /* Tamaños de fuente */
  --fs-xs:   0.75rem;   /* 12px */
  --fs-sm:   0.875rem;  /* 14px */
  --fs-base: 1rem;      /* 16px */
  --fs-md:   1.125rem;  /* 18px */
  --fs-lg:   1.5rem;    /* 24px */
  --fs-xl:   2rem;      /* 32px */
  --fs-2xl:  2.5rem;    /* 40px */
  --fs-3xl:  3rem;      /* 48px */

  /* Espaciado */
  --espaciado-xs:  0.5rem;
  --espaciado-sm:  1rem;
  --espaciado-md:  1.5rem;
  --espaciado-lg:  2rem;
  --espaciado-xl:  3rem;
  --espaciado-2xl: 5rem;

  /* Bordes */
  --radio-btn:    0.375rem;
  --radio-card:   0.75rem;
  --radio-circulo: 50%;

  /* Sombras */
  --sombra-sm: 0 1px 3px rgba(0, 0, 0, 0.08);
  --sombra-md: 0 4px 12px rgba(0, 0, 0, 0.10);
  --sombra-lg: 0 8px 24px rgba(0, 0, 0, 0.12);

  /* Transiciones */
  --transicion: 0.25s ease;
}

/* ============================================================
   RESET
   ============================================================ */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  font-size: 16px;
}

body {
  background-color: var(--color-fondo-principal);
  color: var(--color-texto-cuerpo);
  font-family: var(--fuente-cuerpo);
  font-size: var(--fs-base);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

img,
video {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  color: inherit;
  text-decoration: none;
}

ul,
ol {
  list-style: none;
}

button {
  cursor: pointer;
  border: none;
  background: none;
  font-family: inherit;
}

input,
textarea,
select {
  font-family: inherit;
  font-size: inherit;
}

/* ============================================================
   TIPOGRAFÍA BASE
   ============================================================ */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--fuente-titulos);
  color: var(--color-texto-titulo);
  line-height: 1.2;
  font-weight: 600;
}

h1 { font-size: var(--fs-3xl); }
h2 { font-size: var(--fs-2xl); }
h3 { font-size: var(--fs-xl);  }
h4 { font-size: var(--fs-lg);  }
h5 { font-size: var(--fs-md);  }
h6 { font-size: var(--fs-base);}

p {
  color: var(--color-texto-cuerpo);
  font-size: var(--fs-base);
  margin-bottom: var(--espaciado-sm);
}

/* Títulos sobre fondo azul */
.texto-blanco h1,
.texto-blanco h2,
.texto-blanco h3,
.texto-blanco h4,
.texto-blanco p {
  color: var(--color-texto-azul);
}

/* ============================================================
   BOTONES
   ============================================================ */
.btn-cta {
  display: inline-block;
  background-color: var(--color-btn-cta);
  color: var(--color-texto-azul);
  font-family: var(--fuente-cuerpo);
  font-weight: 600;
  font-size: var(--fs-base);
  padding: 0.75rem 1.75rem;
  border-radius: var(--radio-btn);
  transition: background-color var(--transicion), transform var(--transicion);
}

.btn-cta:hover {
  background-color: var(--color-hover);
  transform: translateY(-2px);
}

.btn-secundario {
  display: inline-block;
  background-color: var(--color-btn-secundario);
  color: var(--color-texto-azul);
  font-family: var(--fuente-cuerpo);
  font-weight: 600;
  font-size: var(--fs-base);
  padding: 0.75rem 1.75rem;
  border-radius: var(--radio-btn);
  transition: background-color var(--transicion), transform var(--transicion);
}

.btn-secundario:hover {
  background-color: var(--color-seccion);
  transform: translateY(-2px);
}

/* ============================================================
   SECCIONES
   ============================================================ */
.seccion {
  padding: var(--espaciado-2xl) 0;
}

.seccion--azul {
  background-color: var(--color-seccion);
}

.seccion__titulo {
  text-align: center;
  margin-bottom: var(--espaciado-xl);
}

/* ============================================================
   UTILIDADES
   ============================================================ */
.contenedor {
  width: 100%;
  max-width: 1200px;
  margin-inline: auto;
  padding-inline: var(--espaciado-lg);
}

.texto-centro { text-align: center; }
.texto-izquierda { text-align: left; }
.texto-derecha { text-align: right; }

.oculto { display: none; }

/* ============================================================
   RESPONSIVE — Mobile first
   ============================================================ */
@media (max-width: 768px) {
  h1 { font-size: var(--fs-2xl); }
  h2 { font-size: var(--fs-xl);  }
  h3 { font-size: var(--fs-lg);  }

  .contenedor {
    padding-inline: var(--espaciado-sm);
  }

  .seccion {
    padding: var(--espaciado-xl) 0;
  }
}

@media (max-width: 480px) {
  h1 { font-size: var(--fs-xl);  }
  h2 { font-size: var(--fs-lg);  }
}

/* ============================================================
   NAVBAR
   ============================================================ */
.navbar--global {
  background-color: var(--color-seccion);
  padding-block: var(--espaciado-sm);
  position: sticky;
  top: 0;
  z-index: 1000;
  box-shadow: var(--sombra-md);
}

.navbar__contenedor {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* Logo */
.navbar__logo {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

.navbar__logo-img {
  height: 48px;
  width: auto;
}

/* Links */
.navbar__links {
  display: flex;
  align-items: center;
  gap: var(--espaciado-md);
}

.navbar__link {
  color: var(--color-texto-azul) !important;
  font-family: var(--fuente-cuerpo);
  font-weight: 500;
  font-size: var(--fs-sm);
  letter-spacing: 0.03em;
  text-transform: uppercase;
  padding: 0.25rem 0;
  position: relative;
  transition: color var(--transicion);
}

.navbar__link::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 2px;
  background-color: var(--color-btn-cta);
  transition: width var(--transicion);
}

.navbar__link:hover::after {
  width: 100%;
}

/* Botón hamburguesa */
.navbar__toggle {
  border: 2px solid var(--color-texto-azul);
  border-radius: var(--radio-btn);
  padding: 0.25rem 0.5rem;
}

.navbar__toggle-icon {
  filter: invert(1);
}

/* Menú colapsado en móvil */
@media (max-width: 991px) {
  .navbar__links {
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    padding: var(--espaciado-sm) 0;
  }

  .navbar__link {
    padding: 0.5rem 0;
    width: 100%;
  }
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer {
  background-color: var(--color-fondo-principal);
  color: var(--color-texto-cuerpo);
  padding-top: var(--espaciado-2xl);
}

.footer__contenedor {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--espaciado-xl);
  padding-bottom: var(--espaciado-xl);
  border-bottom: 1px solid var(--color-seccion-suave);
}

/* Título de columna */
.footer__titulo {
  font-family: var(--fuente-titulos);
  color: var(--color-texto-titulo);
  font-size: var(--fs-md);
  font-weight: 600;
  margin-bottom: var(--espaciado-sm);
}

/* Columna redes */
.footer__redes {
  display: flex;
  gap: var(--espaciado-sm);
}

.footer__red {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: var(--radio-circulo);
  background-color: var(--color-seccion-suave);
  color: var(--color-seccion);
  font-size: var(--fs-md);
  transition: background-color var(--transicion), color var(--transicion), transform var(--transicion);
}

.footer__red:hover {
  background-color: var(--color-btn-cta);
  color: #FFFFFF;
  transform: translateY(-3px);
}

/* Columna contacto */
.footer__lista {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

.footer__lista li {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: var(--fs-sm);
  color: var(--color-texto-cuerpo);
}

.footer__lista a {
  color: var(--color-texto-cuerpo);
  transition: color var(--transicion);
}

.footer__lista a:hover {
  color: var(--color-btn-cta);
}

/* Columna dirección */
.footer__direccion {
  font-style: normal;
  font-size: var(--fs-sm);
  color: var(--color-texto-cuerpo);
  line-height: 1.8;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.footer__direccion i {
  margin-right: 0.4rem;
  color: var(--color-btn-cta);
}

/* Franja inferior */
.footer__inferior {
  padding: var(--espaciado-sm) 0;
  text-align: center;
}

.footer__copy {
  font-size: var(--fs-xs);
  color: rgba(85, 85, 85, 0.6);
  margin-bottom: 0;
}

/* Footer responsive */
@media (max-width: 768px) {
  .footer__contenedor {
    grid-template-columns: 1fr;
    gap: var(--espaciado-lg);
  }
}
