/* ==========================================================================
   Pronova Constructora — hoja de estilos principal
   Dirección «editorial material»: titulares serif (Fraunces), neutros
   minerales cálidos, verde de marca como único acento.

   Fuentes autoalojadas (RGPD + rendimiento): woff2 variables en assets/fonts/.

   Contraste WCAG AA verificado por script (luminancia relativa WCAG 2.x):
     #424341 sobre #FDFCFA  9.70:1 · sobre #F3F1EA  8.80:1  (cuerpo)
     #26261F sobre #FDFCFA 14.85:1 · sobre #F3F1EA 13.47:1  (titulares)
     #63625C sobre #FDFCFA  5.97:1 · sobre #F3F1EA  5.41:1  (texto secundario)
     #2E5A22 sobre #FDFCFA  7.87:1 · #F3F1EA 7.14:1 · #DFECC8 6.52:1 (enlaces/btn borde)
     #1F3E15 sobre #F3F1EA >9:1                              (hover de enlaces)
     #FFFFFF sobre #44832F  4.63:1 · sobre #2E5A22 8.07:1    (botones y su hover)
     #FFFFFF sobre #262B24 14.45:1 · blanco 82% 10.21:1 · 60% 6.17:1 (secciones oscuras)
     #82AE37 sobre #262B24  5.54:1                           (eyebrows en oscuro)
     #589F3F sobre #FDFCFA  3.18:1 (solo texto grande ≥24px / ≥18.66px bold)
     anillo de foco #44832F: 4.52 / 4.10 / 3.74 / 3.12:1 sobre blanco, hueso,
     crema y carbón — ≥3:1 no-texto en todos los fondos.
   ========================================================================== */

@font-face {
  font-family: 'Fraunces';
  src: url('../fonts/fraunces-var.woff2') format('woff2');
  font-weight: 600 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Fraunces';
  src: url('../fonts/fraunces-italic-var.woff2') format('woff2');
  font-weight: 600;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'Inter';
  src: url('../fonts/inter-var.woff2') format('woff2');
  font-weight: 400 700;
  font-style: normal;
  font-display: swap;
}

:root {
  --verde: #589F3F;
  --verde-osc: #2E5A22;     /* texto pequeño sobre blanco (7.87:1, AA) */
  --verde-boton: #44832F;   /* fondo de botones: más claro, 4.63:1 con blanco (AA) */
  --verde-hover: #1F3E15;   /* hover de enlaces: oscurece (AA en todos los fondos claros) */
  --verde-claro: #82AE37;   /* decorativo; como texto solo sobre carbón (5.54:1) */
  --crema: #DFECC8;
  --tinta: #26261F;         /* titulares serif: tinta cálida casi negra */
  --antracita: #424341;     /* cuerpo de texto (del logo) */
  --gris-texto: #63625C;    /* secundario cálido, 5.41:1 sobre hueso (AA) */
  --gris-borde: #E5E2D8;    /* hairlines arena */
  --blanco: #FDFCFA;        /* papel cálido */
  --hueso: #F3F1EA;         /* piedra/arena clara para secciones alternas */
  --carbon: #262B24;        /* secciones oscuras: carbón con matiz verde */

  --f-serif: 'Fraunces', Georgia, 'Times New Roman', serif;
  --f-display: 'Inter', system-ui, sans-serif;
  --f-body: 'Inter', system-ui, sans-serif;

  --ancho: 1200px;
  --radio: 6px;
  --sombra: 0 1px 2px rgba(38,38,31,.06), 0 8px 24px rgba(38,38,31,.07);
}

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

html { scroll-behavior: smooth; }

body {
  font-family: var(--f-body);
  font-size: 16px;
  line-height: 1.65;
  color: var(--antracita);
  background: var(--blanco);
  -webkit-font-smoothing: antialiased;
}

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

/* titulares serif editoriales (Fraunces); h3/h4 de componentes siguen en Inter */
h1, h2, h3, h4 { line-height: 1.12; text-wrap: balance; }
h1, h2 {
  font-family: var(--f-serif);
  font-weight: 600;
  letter-spacing: -0.008em;
  color: var(--tinta);
}
h3, h4 {
  font-family: var(--f-display);
  font-weight: 700;
  letter-spacing: -0.01em;
}

h1 { font-size: clamp(2.4rem, 5.5vw, 4.2rem); line-height: 1.05; }
h2 { font-size: clamp(1.7rem, 3.6vw, 2.6rem); line-height: 1.08; }
h3 { font-size: 1.25rem; }

p { max-width: 68ch; }

a { color: var(--verde-osc); text-decoration-thickness: 1px; text-underline-offset: 3px; }
a:hover { color: var(--verde-hover); }

:focus-visible { outline: 3px solid var(--verde-boton); outline-offset: 2px; border-radius: 2px; }

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

.seccion { padding-block: clamp(56px, 9vw, 104px); }
.seccion--hueso { background: var(--hueso); }
.seccion--crema { background: var(--crema); }
.seccion--oscura { background: var(--carbon); color: var(--blanco); }
.seccion--oscura p { color: rgba(255,255,255,.82); }
.seccion--oscura h1, .seccion--oscura h2 { color: var(--blanco); }

.eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: .78rem; font-weight: 600; letter-spacing: .16em;
  text-transform: uppercase; color: var(--verde-osc);
  margin-bottom: 14px;
}
.eyebrow::before { content: ""; width: 26px; height: 2px; background: var(--verde); }
.seccion--oscura .eyebrow { color: var(--verde-claro); }
.seccion--oscura .eyebrow::before { background: var(--verde-claro); }

.intro-seccion { color: var(--gris-texto); margin-top: 12px; font-size: 1.05rem; }
.seccion--oscura .intro-seccion { color: rgba(255,255,255,.75); }

/* ---------- header ---------- */

/* especificidad ".header .header__tel" a propósito: el botón vive dentro de
   <nav>, y así gana siempre a las reglas genéricas ".nav a" */
.header .header__tel {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--f-display); font-weight: 700; font-size: .95rem;
  color: var(--verde-osc); text-decoration: none;
  padding: 9px 16px; border: 1.5px solid var(--gris-borde);
  border-radius: 999px; white-space: nowrap;
  transition: border-color .15s, background .15s;
}
.header .header__tel:hover { border-color: var(--verde); background: var(--hueso); color: var(--verde-osc); }
.header__tel svg { width: 16px; height: 16px; fill: currentColor; flex-shrink: 0; }
.header__tel::after { display: none; }

.header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(253,252,250,.94);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--gris-borde);
}
.header .contenedor {
  display: flex; align-items: center;
  min-height: 72px; gap: 14px;
  transition: min-height .3s ease;
}
.header__logo {
  display: flex; align-items: center; gap: 13px;
  text-decoration: none; flex-shrink: 0;
}
.header__logo img {
  height: 66px; width: 66px;
  transition: height .3s ease, width .3s ease;
}
.header__marca {
  display: flex; flex-direction: column; line-height: 1.02;
  font-family: var(--f-display); font-weight: 700; font-size: 1.55rem;
  letter-spacing: .015em; color: var(--antracita);
  transition: font-size .3s ease;
}
.header__marca small {
  font-size: .68rem; font-weight: 700; letter-spacing: .345em;
  transition: font-size .3s ease;
  color: var(--verde-osc); margin-top: 4px;
}

/* al cargar la página (arriba del todo) el header arranca más grande en
   escritorio; al hacer scroll, JS añade .header--compacta y encoge al
   tamaño "normal" de arriba. En móvil/tablet estrecha no se toca. */
@media (min-width: 601px) {
  .header .contenedor { min-height: 104px; }
  .header__logo img { height: 88px; width: 88px; }
  .header__marca { font-size: 1.95rem; }
  .header__marca small { font-size: .8rem; letter-spacing: .38em; }

  .header--compacta .contenedor { min-height: 72px; }
  .header--compacta .header__logo img { height: 66px; width: 66px; }
  .header--compacta .header__marca { font-size: 1.55rem; }
  .header--compacta .header__marca small { font-size: .68rem; letter-spacing: .345em; }
}

.nav { display: flex; align-items: center; gap: 4px; margin-left: auto; }
.nav a {
  position: relative;
  font-family: var(--f-display); font-size: .92rem; font-weight: 600;
  color: var(--antracita); text-decoration: none;
  padding: 10px 13px; border-radius: var(--radio);
  transition: color .18s ease, background .18s ease;
}
.nav a:hover { background: var(--hueso); color: var(--verde-osc); }
.nav a[aria-current="page"] { color: var(--verde-osc); }
/* subrayado animado (crece de izquierda a derecha) */
.nav a::after {
  content: ""; position: absolute; left: 13px; right: 13px; bottom: 5px;
  height: 2px; background: var(--verde); border-radius: 2px;
  transform: scaleX(0); transform-origin: left;
  transition: transform .22s ease;
}
.nav a:hover::after,
.nav a[aria-current="page"]::after { transform: scaleX(1); }
.nav__cta::after, .nav__idioma::after { display: none; }
.nav__cta {
  background: var(--verde-boton); color: #FFFFFF !important;
  margin-left: 8px;
}
.nav__cta:hover { background: var(--verde-osc) !important; }

.nav__idioma {
  font-size: .8rem !important; font-weight: 700 !important;
  border: 1.5px solid var(--gris-borde);
  color: var(--gris-texto) !important;
}

.nav-toggle {
  display: none; background: none; border: 1.5px solid var(--gris-borde);
  border-radius: var(--radio); padding: 9px 11px; cursor: pointer;
  font: inherit; color: var(--antracita); margin-left: auto;
  transition: border-color .18s ease;
}
.nav-toggle:hover { border-color: var(--verde); }
.nav-toggle__icono { display: inline-block; transition: transform .25s ease; }
.nav-toggle[aria-expanded="true"] .nav-toggle__icono { transform: rotate(90deg); }

@media (max-width: 900px) {
  .nav-toggle { display: block; }
  /* desplegable animado: siempre presente, se muestra con opacidad + desplazamiento */
  .nav {
    display: flex; position: absolute; top: 100%; left: 0; right: 0;
    flex-direction: column; align-items: stretch;
    background: var(--blanco); border-bottom: 1px solid var(--gris-borde);
    padding: 12px 24px 20px; gap: 2px;
    box-shadow: var(--sombra);
    opacity: 0; visibility: hidden; pointer-events: none;
    transform: translateY(-10px);
    transition: opacity .25s ease, transform .25s ease, visibility 0s linear .25s;
  }
  .nav.abierta {
    opacity: 1; visibility: visible; pointer-events: auto; transform: none;
    transition: opacity .25s ease, transform .25s ease;
  }
  /* entrada escalonada de los ítems */
  .nav a {
    padding: 12px 10px;
    opacity: 0; transform: translateY(-8px);
    transition: opacity .28s ease, transform .28s ease, color .18s ease, background .18s ease;
  }
  .nav.abierta a { opacity: 1; transform: none; }
  .nav.abierta a:nth-child(1) { transition-delay: .04s; }
  .nav.abierta a:nth-child(2) { transition-delay: .08s; }
  .nav.abierta a:nth-child(3) { transition-delay: .12s; }
  .nav.abierta a:nth-child(4) { transition-delay: .16s; }
  .nav.abierta a:nth-child(5) { transition-delay: .20s; }
  .nav.abierta a:nth-child(6) { transition-delay: .24s; }
  .nav.abierta a:nth-child(7) { transition-delay: .28s; }
  .nav.abierta a:nth-child(8) { transition-delay: .32s; }
  .nav__cta { margin-left: 0; text-align: center; justify-content: center; margin-top: 8px; }
  .header .header__tel { justify-content: center; margin-top: 4px; }
}

/* ---------- hero ---------- */

.hero { position: relative; isolation: isolate; color: var(--blanco); }
.hero__img {
  position: absolute; inset: 0; z-index: -2;
  overflow: hidden; pointer-events: none;
}
.hero__img img {
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover;
  opacity: 0;
  animation: heroSlideshow 25s infinite;
}
/* cada capa arranca desfasada 1/5 del ciclo: un único keyframe crea el pase de diapositivas */
.hero__img img:nth-child(1) { animation-delay: 0s; }
.hero__img img:nth-child(2) { animation-delay: -5s; }
.hero__img img:nth-child(3) { animation-delay: -10s; }
.hero__img img:nth-child(4) { animation-delay: -15s; }
.hero__img img:nth-child(5) { animation-delay: -20s; }

@keyframes heroSlideshow {
  0%    { opacity: 1; }
  15%   { opacity: 1; }
  20%   { opacity: 0; }
  95%   { opacity: 0; }
  100%  { opacity: 1; }
}

@media (prefers-reduced-motion: reduce) {
  .hero__img img { animation: none; opacity: 0; }
  .hero__img img:first-child { opacity: 1; }
}
/* degradado cinematográfico: más denso abajo-izquierda (donde vive el texto),
   la foto respira arriba-derecha */
.hero::after {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background:
    linear-gradient(80deg, rgba(20,23,17,.84) 0%, rgba(20,23,17,.5) 44%, rgba(20,23,17,.12) 76%, rgba(20,23,17,0) 100%),
    linear-gradient(0deg, rgba(20,23,17,.42) 0%, rgba(20,23,17,0) 45%);
}
.hero .contenedor {
  min-height: min(78vh, 680px);
  display: flex; flex-direction: column; justify-content: center;
  padding-block: 96px;
}
.hero h1 { max-width: 19ch; color: var(--blanco); text-shadow: 0 2px 18px rgba(0,0,0,.35); }
.hero__sub {
  margin-top: 20px; font-size: clamp(1.05rem, 2vw, 1.3rem);
  max-width: 46ch; color: rgba(255,255,255,.92);
}
.hero__acciones { display: flex; gap: 14px; margin-top: 34px; flex-wrap: wrap; }
/* kicker en blanco con barra verde: el verde claro sobre foto no garantiza AA */
.hero__kicker {
  display: inline-flex; align-items: center; gap: 12px;
  color: var(--blanco); font-weight: 600; letter-spacing: .18em;
  text-transform: uppercase; font-size: .82rem; margin-bottom: 18px;
  font-family: var(--f-display);
  text-shadow: 0 1px 10px rgba(0,0,0,.4);
}
.hero__kicker::before {
  content: ""; width: 30px; height: 3px; flex-shrink: 0;
  background: var(--verde-claro);
}

/* ---------- botones ---------- */

.btn {
  display: inline-flex; align-items: center; gap: 9px;
  font-family: var(--f-display); font-weight: 700; font-size: 1rem;
  padding: 14px 26px; border-radius: var(--radio);
  text-decoration: none; border: 2px solid transparent;
  cursor: pointer; transition: background .18s, color .18s, border-color .18s;
}
/* hover: siempre oscurecer (aclarar a --verde bajaba el contraste con el label) */
.btn--primario { background: var(--verde-boton); color: #FFFFFF; }
.btn--primario:hover { background: var(--verde-osc); color: #FFFFFF; }
.btn--claro { background: var(--blanco); color: var(--antracita); }
.btn--claro:hover { background: var(--crema); color: var(--antracita); }
/* verde-osc: 7.14:1 sobre hueso y 6.52:1 sobre crema (verde-boton fallaba AA ahí) */
.btn--borde { border-color: currentColor; color: var(--verde-osc); background: transparent; }
.btn--borde:hover { background: var(--verde-osc); color: #FFFFFF; border-color: var(--verde-osc); }
.hero .btn--borde,
.seccion--oscura .btn--borde { color: var(--blanco); }
.hero .btn--borde:hover,
.seccion--oscura .btn--borde:hover { background: var(--blanco); color: var(--antracita); border-color: var(--blanco); }

/* ---------- franja de confianza ---------- */

.confianza { border-bottom: 1px solid var(--gris-borde); background: var(--blanco); }
.confianza .contenedor {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 0; padding-block: 0;
}
.confianza__item {
  padding: 26px 20px; text-align: center;
  border-left: 1px solid var(--gris-borde);
  /* contenido anclado abajo: si una cifra ocupa dos líneas ("Lleida i
     Barcelona"), crece hacia arriba y la fila de etiquetas queda alineada */
  display: flex; flex-direction: column; justify-content: flex-end;
}
.confianza__item:first-child { border-left: 0; }
/* cifras en serif: el "masthead" del sitio */
.confianza__num {
  font-family: var(--f-serif); font-size: clamp(1.9rem, 2.6vw, 2.3rem); font-weight: 700;
  color: var(--verde-osc); line-height: 1.1;
}
.confianza__label { font-size: .88rem; color: var(--gris-texto); margin-top: 4px; }
@media (max-width: 700px) {
  .confianza .contenedor { grid-template-columns: 1fr 1fr; }
  .confianza__item { border-left: 0; padding: 20px 12px; }
  .confianza__item:nth-child(n+3) { border-top: 1px solid var(--gris-borde); }
  .confianza__item:nth-child(even) { border-left: 1px solid var(--gris-borde); }
  .confianza__num { font-size: 1.5rem; }
}

/* ---------- tarjetas de servicio ---------- */

.grid-servicios {
  display: grid; gap: 22px; margin-top: 44px;
  grid-template-columns: repeat(auto-fit, minmax(270px, 1fr));
}
.tarjeta-servicio {
  background: var(--blanco); border: 1px solid var(--gris-borde);
  border-radius: var(--radio); overflow: hidden;
  display: flex; flex-direction: column;
  transition: box-shadow .2s, transform .2s;
}
.tarjeta-servicio:hover { box-shadow: var(--sombra); transform: translateY(-3px); }
.tarjeta-servicio__foto { aspect-ratio: 4/3; overflow: hidden; }
.tarjeta-servicio__foto img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .45s ease;
}
.tarjeta-servicio:hover .tarjeta-servicio__foto img { transform: scale(1.045); }
.tarjeta-servicio__cuerpo { padding: 22px 22px 26px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.tarjeta-servicio__cuerpo p { font-size: .95rem; color: var(--gris-texto); flex: 1; }
.tarjeta-servicio__link {
  font-family: var(--f-display); font-weight: 700; font-size: .92rem;
  text-decoration: none;
}

/* lista editorial de servicios (página serveis) */
.lista-servicios { margin-top: 40px; display: grid; gap: 0; }
.servicio-fila {
  display: grid; grid-template-columns: 64px 1fr; gap: 20px;
  padding: 30px 0; border-top: 1px solid var(--gris-borde);
}
.servicio-fila:first-child { border-top: 2px solid var(--tinta); }
.servicio-fila:last-child { border-bottom: 1px solid var(--gris-borde); }
.servicio-fila__num {
  font-family: var(--f-serif); font-weight: 600; font-size: 1.6rem;
  color: var(--verde); /* 3.18:1, válido: texto grande decorativo */
}
.servicio-fila h3 { margin-bottom: 8px; }
.servicio-fila p { color: var(--gris-texto); }

/* ---------- galería de trabajos ---------- */

.filtros {
  display: flex; gap: 10px; flex-wrap: wrap; margin-top: 36px;
}
.filtros button {
  font-family: var(--f-display); font-weight: 600; font-size: .88rem;
  padding: 9px 18px; border-radius: 999px; cursor: pointer;
  background: var(--blanco); color: var(--antracita);
  border: 1.5px solid var(--gris-borde);
  transition: all .15s;
}
.filtros button:hover { border-color: var(--verde); color: var(--verde-osc); }
.filtros button[aria-pressed="true"] {
  background: var(--verde-boton); color: var(--blanco); border-color: var(--verde-boton);
}

.galeria {
  display: grid; gap: 14px; margin-top: 34px;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
}
.galeria__item {
  aspect-ratio: 4/3; overflow: hidden; border-radius: var(--radio);
  border: 0; padding: 0; cursor: zoom-in; background: var(--gris-borde);
  position: relative;
}
.galeria__item img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .4s ease;
}
.galeria__item:hover img { transform: scale(1.05); }
.galeria__item figcaption,
.galeria__item .etiqueta {
  position: absolute; left: 10px; bottom: 10px;
  background: rgba(20,23,17,.72); color: #FFFFFF;
  font-size: .74rem; font-weight: 600; letter-spacing: .04em;
  padding: 4px 10px; border-radius: 999px;
  opacity: 0; transition: opacity .2s;
}
.galeria__item:hover .etiqueta { opacity: 1; }
.galeria__item[hidden] { display: none; }

/* lightbox */
.lightbox {
  border: 0; padding: 0; background: rgba(20,21,19,.94);
  max-width: 100vw; max-height: 100vh; width: 100vw; height: 100vh;
}
.lightbox::backdrop { background: rgba(20,21,19,.94); }
.lightbox__inner {
  width: 100%; height: 100%; display: flex; align-items: center; justify-content: center;
  position: relative;
}
.lightbox img {
  max-width: min(92vw, 1400px); max-height: 88vh;
  width: auto; height: auto; object-fit: contain;
  border-radius: var(--radio);
}
.lightbox button {
  position: absolute; background: rgba(255,255,255,.12); color: #fff;
  border: 0; border-radius: 999px; width: 48px; height: 48px;
  font-size: 1.35rem; cursor: pointer; display: grid; place-items: center;
}
.lightbox button:hover { background: rgba(255,255,255,.28); }
.lightbox__cerrar { top: 18px; right: 18px; }
.lightbox__ant { left: 14px; top: 50%; transform: translateY(-50%); }
.lightbox__sig { right: 14px; top: 50%; transform: translateY(-50%); }

/* ---------- testimonios ---------- */

.testimonios {
  display: grid; gap: 22px; margin-top: 44px;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}
.testimonio {
  background: var(--blanco); border: 1px solid var(--gris-borde);
  border-radius: var(--radio); padding: 30px;
}
/* citas en serif itálica: voz editorial, no catálogo */
.testimonio blockquote {
  font-family: var(--f-serif); font-style: italic;
  font-size: 1.15rem; font-weight: 600;
  line-height: 1.48; color: var(--tinta);
}
.testimonio__pie { margin-top: 18px; display: flex; align-items: flex-start; gap: 12px; }
.testimonio__info { display: flex; flex-direction: column; gap: 5px; min-width: 0; }
.testimonio__estrellas { color: var(--verde); letter-spacing: 2px; font-size: .95rem; order: 2; }
.testimonio__autor {
  font-size: .9rem; color: var(--antracita); font-weight: 700;
  line-height: 1.3; order: 1;
}

/* resumen de nota media + carrusel de reseñas de Google */
.resenas-resumen {
  display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap;
  margin-top: 22px;
}
.resenas-nota {
  font-family: var(--f-serif); font-weight: 700; font-size: 2.8rem;
  color: var(--verde-osc); line-height: 1;
}
.resenas-estrellas { color: var(--verde); font-size: 1.3rem; letter-spacing: 3px; }
.resenas-basado { color: var(--gris-texto); font-size: .95rem; }

.carrusel-wrap { position: relative; margin-top: 34px; }
/* degradado en los bordes: la tarjeta que asoma se "desvanece" en vez de cortarse en seco */
.carrusel-wrap::before, .carrusel-wrap::after {
  content: ""; position: absolute; top: 0; bottom: 6px; width: 48px;
  z-index: 2; pointer-events: none;
}
.carrusel-wrap::before { left: 0; background: linear-gradient(90deg, var(--blanco), transparent); }
.carrusel-wrap::after { right: 0; background: linear-gradient(270deg, var(--blanco), transparent); }
.seccion--hueso .carrusel-wrap::before { background: linear-gradient(90deg, var(--hueso), transparent); }
.seccion--hueso .carrusel-wrap::after { background: linear-gradient(270deg, var(--hueso), transparent); }

.carrusel {
  display: flex; gap: 22px; margin: 0;
  overflow-x: auto; -webkit-overflow-scrolling: touch;
  scrollbar-width: none; cursor: grab;
  padding-bottom: 6px;
  scroll-snap-type: x proximity;
}
.carrusel::-webkit-scrollbar { display: none; }
.carrusel.arrastrando { cursor: grabbing; scroll-behavior: auto; scroll-snap-type: none; }
.carrusel .testimonio {
  flex: 0 0 min(360px, 84vw);
  display: flex; flex-direction: column;
  scroll-snap-align: start;
}
.carrusel .testimonio blockquote { flex: 1; }
.testimonio__sin-texto {
  flex: 1; font-style: italic; color: var(--gris-texto); font-size: .95rem;
}
.testimonio__foto {
  width: 40px; height: 40px; border-radius: 50%; object-fit: cover;
  flex-shrink: 0;
}
.resenas-cta { margin-top: 28px; text-align: center; }

/* ---------- CTA final ---------- */

.cta-final { text-align: center; }
.cta-final h2 { max-width: 22ch; margin-inline: auto; }
.cta-final p { margin: 16px auto 0; }
.cta-final .hero__acciones { justify-content: center; }

/* ---------- página interior / prosa ---------- */

.cabecera-pagina { background: var(--hueso); border-bottom: 1px solid var(--gris-borde); }
.cabecera-pagina .contenedor { padding-block: clamp(48px, 7vw, 84px); }
.cabecera-pagina h1 { font-size: clamp(2.2rem, 4.5vw, 3.4rem); } /* el drama máximo es del hero */
.cabecera-pagina p { color: var(--gris-texto); margin-top: 14px; font-size: 1.08rem; }

.prosa { max-width: 720px; }
.prosa p + p { margin-top: 1.1em; }
.prosa h2 { margin-top: 1.8em; margin-bottom: .5em; font-size: 1.45rem; }
.prosa ul { padding-left: 1.2em; margin-top: 1em; }
.prosa li + li { margin-top: .45em; }

.dos-columnas {
  display: grid; gap: 48px; align-items: start;
  grid-template-columns: 1.1fr .9fr;
}
@media (max-width: 860px) { .dos-columnas { grid-template-columns: 1fr; } }
.dos-columnas img { border-radius: var(--radio); }

/* valores en qui som */
.valores { display: grid; gap: 16px; margin-top: 24px; }
.valor { display: grid; grid-template-columns: 26px 1fr; gap: 12px; align-items: start; }
.valor__check {
  width: 22px; height: 22px; border-radius: 50%; margin-top: 3px;
  background: var(--crema); color: var(--verde-osc);
  display: grid; place-items: center; font-size: .8rem; font-weight: 700;
}
.valor strong { font-family: var(--f-display); }
.valor p { font-size: .93rem; color: var(--gris-texto); }

/* ---------- blog ---------- */

.grid-blog {
  display: grid; gap: 22px; margin-top: 44px;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}
.tarjeta-post {
  border: 1px solid var(--gris-borde); border-radius: var(--radio);
  overflow: hidden; background: var(--blanco);
  display: flex; flex-direction: column;
  transition: box-shadow .2s, transform .2s;
}
.tarjeta-post:hover { box-shadow: var(--sombra); transform: translateY(-3px); }
.tarjeta-post__foto { aspect-ratio: 16/9; overflow: hidden; }
.tarjeta-post__foto img { width: 100%; height: 100%; object-fit: cover; }
.tarjeta-post__cuerpo { padding: 22px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.tarjeta-post time { font-size: .8rem; color: var(--gris-texto); text-transform: uppercase; letter-spacing: .08em; }
.tarjeta-post h3 a { text-decoration: none; color: var(--antracita); }
.tarjeta-post h3 a:hover { color: var(--verde-osc); }
.tarjeta-post p { font-size: .93rem; color: var(--gris-texto); flex: 1; }

.articulo { max-width: 720px; margin-inline: auto; }
.articulo__meta { color: var(--gris-texto); font-size: .9rem; margin-top: 10px; }
.articulo__portada { border-radius: var(--radio); margin-block: 34px; }

/* ---------- contacto ---------- */

.contacto-grid {
  display: grid; gap: 48px; margin-top: 44px;
  grid-template-columns: .9fr 1.1fr;
}
@media (max-width: 860px) { .contacto-grid { grid-template-columns: 1fr; } }

.dato-contacto { display: grid; gap: 4px; padding: 18px 0; border-top: 1px solid var(--gris-borde); }
.dato-contacto:first-of-type { border-top: 2px solid var(--tinta); }
.dato-contacto:last-child { border-bottom: 1px solid var(--gris-borde); }
.dato-contacto span { font-size: .78rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--gris-texto); }
.dato-contacto a { font-family: var(--f-display); font-weight: 700; font-size: 1.08rem; text-decoration: none; }

.formulario { display: grid; gap: 18px; background: var(--hueso); border: 1px solid var(--gris-borde); border-radius: var(--radio); padding: 30px; }
.campo { display: grid; gap: 6px; }
.campo label { font-family: var(--f-display); font-weight: 600; font-size: .92rem; }
.campo input, .campo textarea {
  font: inherit; padding: 12px 14px; border-radius: var(--radio);
  border: 1.5px solid var(--gris-borde); background: var(--blanco);
  color: var(--antracita); width: 100%;
}
.campo input:focus, .campo textarea:focus { outline: 2px solid var(--verde); border-color: var(--verde); }
.campo--fila { display: flex; gap: 10px; align-items: flex-start; }
.campo--fila input { width: auto; margin-top: 5px; }
.campo--fila label { font-weight: 400; font-family: var(--f-body); font-size: .88rem; color: var(--gris-texto); }
.formulario button { justify-content: center; }
.form-nota { font-size: .8rem; color: var(--gris-texto); }
.trampa { position: absolute; left: -9999px; }

/* ---------- footer ---------- */

.footer { background: var(--carbon); color: rgba(255,255,255,.82); font-size: .93rem; }
.footer a { color: #FFFFFF; text-decoration: none; }
.footer a:hover { color: var(--verde-claro); text-decoration: underline; } /* 5.54:1 sobre carbón */
.footer__grid {
  display: grid; gap: 40px; padding-block: 64px;
  grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
}
@media (max-width: 900px) { .footer__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .footer__grid { grid-template-columns: 1fr; } }
.footer h4 {
  color: #FFFFFF; font-size: .82rem; letter-spacing: .14em;
  text-transform: uppercase; margin-bottom: 16px;
}
.footer ul { list-style: none; display: grid; gap: 9px; }
.footer__logo { height: 44px; width: auto; margin-bottom: 16px; background: #fff; padding: 5px 10px; border-radius: 4px; }
.footer__legal {
  border-top: 1px solid rgba(255,255,255,.14);
  padding-block: 22px; font-size: .8rem; color: rgba(255,255,255,.6);
  display: flex; justify-content: space-between; gap: 14px; flex-wrap: wrap;
}
.footer__legal a { color: rgba(255,255,255,.75); }

/* ---------- whatsapp flotante ---------- */

.whatsapp-flotante {
  position: fixed; right: 20px; bottom: 20px; z-index: 60;
  width: 56px; height: 56px; border-radius: 50%;
  background: #25D366; display: grid; place-items: center;
  box-shadow: 0 6px 20px rgba(0,0,0,.25);
  transition: transform .15s;
}
.whatsapp-flotante:hover { transform: scale(1.08); }
.whatsapp-flotante svg { width: 30px; height: 30px; fill: #fff; }

/* ---------- banner de cookies ---------- */

.cookie-banner {
  position: fixed; left: 20px; bottom: 20px; z-index: 70;
  max-width: 400px;
  background: var(--blanco); border: 1px solid var(--gris-borde);
  border-radius: var(--radio); box-shadow: var(--sombra);
  padding: 20px 22px;
  animation: cookieEntra .35s ease;
}
@keyframes cookieEntra { from { opacity: 0; transform: translateY(14px); } }
.cookie-banner__texto { font-size: .9rem; color: var(--antracita); }
.cookie-banner__acciones { display: flex; gap: 10px; margin-top: 14px; flex-wrap: wrap; }
.cookie-banner__btn { padding: 9px 20px; font-size: .92rem; }
@media (max-width: 600px) {
  .cookie-banner { left: 12px; right: 12px; bottom: 12px; max-width: none; }
  .cookie-banner__btn { flex: 1; justify-content: center; }
}
@media (prefers-reduced-motion: reduce) { .cookie-banner { animation: none; } }

/* ---------- animación reveal ---------- */

.reveal { opacity: 0; transform: translateY(18px); transition: opacity .6s ease, transform .6s ease; }
.reveal.visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
  html { scroll-behavior: auto; }
  .nav, .nav a, .nav a::after, .nav-toggle__icono { transition: none !important; }
}

/* ---------- utilidades ---------- */

.mt-0 { margin-top: 0; }
.mt-30 { margin-top: 30px; }
.centrado { text-align: center; }
.skip-link {
  position: absolute; left: -9999px; top: 0; z-index: 100;
  background: var(--verde-osc); color: #fff; padding: 12px 20px;
}
.skip-link:focus { left: 0; }

/* ---------- refinamiento responsive ---------- */

/* tablet */
@media (max-width: 1024px) {
  .contenedor { padding-inline: 20px; }
  .hero .contenedor { min-height: min(66vh, 560px); padding-block: 72px; }
  .dos-columnas { gap: 32px; }
}

/* móvil */
@media (max-width: 600px) {
  body { font-size: 15px; }
  .header .contenedor { min-height: 62px; }
  .header__logo { gap: 9px; }
  .header__logo img { height: 42px; width: 42px; }
  .header__marca { font-size: 1.05rem; }
  .header__marca small { font-size: .5rem; letter-spacing: .28em; margin-top: 2px; }
  .nav-toggle { padding: 8px 10px; }

  .hero .contenedor { min-height: auto; padding-block: 64px 56px; }
  .hero h1 { font-size: clamp(1.9rem, 8vw, 2.4rem); }
  .hero__sub { font-size: 1rem; }
  .hero__acciones { gap: 10px; }
  .hero__acciones .btn { width: 100%; justify-content: center; }

  .seccion { padding-block: 48px; }
  .galeria { grid-template-columns: 1fr 1fr; gap: 10px; }
  .galeria__item .etiqueta { opacity: 1; font-size: .68rem; }

  .filtros {
    flex-wrap: nowrap; overflow-x: auto; padding-bottom: 8px;
    margin-inline: -20px; padding-inline: 20px;
    scrollbar-width: none;
  }
  .filtros::-webkit-scrollbar { display: none; }
  .filtros button { flex-shrink: 0; }

  .formulario { padding: 22px 18px; }
  .cta-final .hero__acciones .btn { width: auto; }
}

/* rango tablet-escritorio estrecho: compactar para que el logo grande quepa */
@media (min-width: 901px) and (max-width: 1180px) {
  .header__tel span { display: none; }
  .header__logo img { height: 54px; width: 54px; }
  .header__marca { font-size: 1.25rem; }
  .header__marca small { font-size: .58rem; letter-spacing: .3em; }
  .nav a { padding: 10px 9px; font-size: .88rem; }
}
