/* ============================================================
   LUMINA — Estilos
   Consultora de asesoría para clínicas estéticas.
   Estética: luminosa, sofisticada, cálida.
   Todo el branding vive en las variables de :root.
   ============================================================ */

:root {
  /* Colores */
  --fondo:        #f9f4ee;  /* marfil cálido */
  --fondo-alt:    #f1e6dc;  /* arena suave */
  --tinta:        #33282a;  /* texto principal (ciruela oscuro) */
  --tinta-suave:  #8a7670;  /* texto secundario (topo) */
  --oro:          #c4a160;  /* dorado champagne (acento principal) */
  --rosa:         #c79b94;  /* rosa empolvado */
  --borde:        #e6d7cb;
  --blanco:       #fffdfb;

  /* Tipografías */
  --display: 'Cormorant Garamond', Georgia, serif;  /* títulos elegantes */
  --texto:   'Jost', system-ui, sans-serif;          /* cuerpo y navegación */

  /* Medidas */
  --ancho-max: 1080px;
  --radio: 4px;
}

/* ---------- Reset ---------- */
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
  font-family: var(--texto);
  font-weight: 300;
  color: var(--tinta);
  background: var(--fondo);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3 { font-family: var(--display); font-weight: 500; line-height: 1.1; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }

.contenedor {
  width: 100%;
  max-width: var(--ancho-max);
  margin-inline: auto;
  padding-inline: 28px;
}

/* ---------- Elementos reutilizables ---------- */

/* Etiqueta pequeña sobre los títulos */
.eyebrow {
  font-family: var(--texto);
  font-size: 0.72rem;
  font-weight: 400;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--oro);
  margin-bottom: 1.1rem;
}

/* Botón principal */
.boton {
  display: inline-block;
  font-family: var(--texto);
  font-size: 0.82rem;
  font-weight: 400;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--tinta);
  background: transparent;
  border: 1px solid var(--oro);
  padding: 1rem 2.4rem;
  border-radius: var(--radio);
  cursor: pointer;
  transition: background 0.4s ease, color 0.4s ease;
}
.boton:hover { background: var(--oro); color: var(--blanco); }

/* Foco visible (accesibilidad por teclado) */
a:focus-visible, button:focus-visible,
input:focus-visible, textarea:focus-visible {
  outline: 2px solid var(--oro);
  outline-offset: 3px;
}

/* ============================================================
   ENCABEZADO
   ============================================================ */
.encabezado {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 40;
  background: rgba(249, 244, 238, 0.8);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--borde);
}
.encabezado__interior {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 76px;
}
.marca {
  font-family: var(--display);
  font-size: 1.7rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  color: var(--tinta);
}
/* Mantiene la marca centrada compensando el ancho de la hamburguesa */
.encabezado__espaciador { width: 28px; }

/* Botón hamburguesa */
.hamburguesa {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 28px; height: 28px;
  background: none; border: none;
  cursor: pointer; padding: 0;
}
.hamburguesa span {
  display: block;
  width: 100%; height: 1.5px;
  background: var(--tinta);
  transition: 0.3s;
}

/* ============================================================
   MENÚ OVERLAY
   ============================================================ */
.menu-overlay {
  position: fixed;
  inset: 0;
  z-index: 60;
  background: var(--fondo);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.4s ease, visibility 0.4s ease;
}
.menu-overlay.abierto { opacity: 1; visibility: visible; }

.menu-overlay__cerrar {
  position: absolute;
  top: 24px; right: 32px;
  font-size: 2.4rem;
  line-height: 1;
  background: none; border: none;
  color: var(--tinta);
  cursor: pointer;
}
.menu-overlay ul { text-align: center; }
.menu-overlay li { margin: 1.2rem 0; }
.menu-overlay a {
  font-family: var(--display);
  font-size: clamp(2rem, 7vw, 3.4rem);
  color: var(--tinta);
  transition: color 0.3s ease;
}
.menu-overlay a:hover { color: var(--oro); }

/* ============================================================
   HERO
   ============================================================ */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  text-align: center;
  overflow: hidden;
}
/* "Luz" de fondo: el guiño al nombre Lumina */
.hero__luz {
  position: absolute;
  top: 38%; left: 50%;
  transform: translate(-50%, -50%);
  width: 80vw; max-width: 760px;
  aspect-ratio: 1;
  background: radial-gradient(circle,
              rgba(196, 161, 96, 0.22) 0%,
              rgba(199, 155, 148, 0.12) 38%,
              transparent 68%);
  pointer-events: none;
}
.hero__interior { position: relative; max-width: 640px; }
.hero__titulo {
  font-size: clamp(4rem, 16vw, 8.5rem);
  font-weight: 500;
  letter-spacing: 0.04em;
  margin-bottom: 0.4rem;
}
.hero__bajada {
  font-size: 1.15rem;
  color: var(--tinta-suave);
  max-width: 460px;
  margin: 0 auto 2.5rem;
}

/* ============================================================
   SECCIONES
   ============================================================ */
.seccion { padding: clamp(4.5rem, 11vw, 8rem) 0; }
.seccion--alt { background: var(--fondo-alt); }
.seccion--angosta { max-width: 760px; }
.seccion--centrada { text-align: center; }
.seccion--centrada .formulario { text-align: left; }

.seccion__cabecera { text-align: center; margin-bottom: 3.5rem; }
.seccion__titulo {
  font-size: clamp(2.2rem, 5vw, 3.4rem);
  margin-bottom: 1.5rem;
}
.texto-grande {
  font-size: 1.2rem;
  color: var(--tinta);
  margin-bottom: 1.2rem;
}
.seccion p { color: var(--tinta-suave); }
.seccion .texto-grande { color: var(--tinta); }

/* ---------- Pilares (Quiénes somos) ---------- */
.pilares {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 2.5rem;
  margin-top: 3.5rem;
  padding-top: 3rem;
  border-top: 1px solid var(--borde);
}
.pilar__numero {
  font-family: var(--display);
  font-size: 1.4rem;
  font-style: italic;
  color: var(--oro);
}
.pilar h3 { font-size: 1.5rem; margin: 0.5rem 0; }
.pilar p { color: var(--tinta-suave); font-size: 0.98rem; }

/* ---------- Testimonios ---------- */
.grilla-testimonios {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 2rem;
}
.testimonio {
  background: var(--blanco);
  border: 1px solid var(--borde);
  border-radius: var(--radio);
  padding: 2.5rem 2rem;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
.testimonio blockquote {
  font-family: var(--display);
  font-size: 1.35rem;
  font-style: italic;
  line-height: 1.4;
  color: var(--tinta);
}
.testimonio figcaption { font-size: 0.92rem; }
.testimonio figcaption strong { display: block; font-weight: 500; color: var(--tinta); }
.testimonio figcaption span { color: var(--oro); letter-spacing: 0.04em; }

/* ---------- Formulario ---------- */
.formulario {
  display: grid;
  gap: 1.4rem;
  margin-top: 2.5rem;
  text-align: left;
}
.formulario label {
  display: grid;
  gap: 0.5rem;
  font-size: 0.78rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--tinta-suave);
}
.formulario input,
.formulario textarea {
  font-family: var(--texto);
  font-weight: 300;
  font-size: 1rem;
  color: var(--tinta);
  padding: 0.9rem 1rem;
  background: var(--blanco);
  border: 1px solid var(--borde);
  border-radius: var(--radio);
  resize: vertical;
  transition: border-color 0.3s ease;
}
.formulario input::placeholder,
.formulario textarea::placeholder { color: #bca99f; text-transform: none; letter-spacing: normal; }
.formulario input:focus,
.formulario textarea:focus { border-color: var(--oro); }
.formulario .boton { justify-self: start; margin-top: 0.5rem; }

/* ============================================================
   PIE DE PÁGINA
   ============================================================ */
.pie {
  background: var(--tinta);
  color: var(--fondo);
  padding: 3.5rem 0;
}
.pie__interior {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.75rem;
  text-align: center;
}
.pie__marca {
  font-family: var(--display);
  font-size: 1.8rem;
  letter-spacing: 0.12em;
}
.redes { display: flex; gap: 1.75rem; }
.redes a {
  color: var(--fondo);
  opacity: 0.75;
  transition: opacity 0.3s ease, color 0.3s ease;
}
.redes a:hover { opacity: 1; color: var(--oro); }
.pie__copy { font-size: 0.8rem; opacity: 0.55; letter-spacing: 0.04em; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 640px) {
  .encabezado__interior { height: 64px; }
  .marca { font-size: 1.4rem; }
}

/* Respeta "reducir movimiento" */
@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; scroll-behavior: auto; }
}
