/**
 * main.css — GENERATED FILE. Do not edit by hand.
 * Source files in assets/css/ and assets/css/components/.
 * Regenerate with: ./scripts/build-css.sh
 * Last build: 2026-05-11T12:11:17Z
 */


/* ─── design-system.css ─────────────────────────────────────────── */
/**
 * design-system.css — Estudio González
 * Sistema de variables CSS: todos los tokens de diseño.
 * Este archivo es la única fuente de verdad para colores, tipografía, espaciado y transiciones.
 */

:root {

  /* ─── Colores ─────────────────────────────────────────────────────────── */

  --color-black:        #0A0A0A;
  --color-white:        #FAFAFA;
  --color-off-white:    #F5F4F2;

  /* Acento — carmesí del logo */
  --color-accent:       #C41E3A;
  --color-accent-dark:  #9E1830;
  --color-accent-light: #E8283F;

  /* Superficies oscuras */
  --color-surface:      #111111;
  --color-surface-mid:  #1A1A1A;

  /* Texto */
  --color-text:         #0A0A0A;
  --color-text-muted:   #6B6B6B;
  --color-text-white:   #FAFAFA;

  /* Bordes */
  --color-border:       #E4E2DE;
  --color-border-dark:  #2A2A2A;

  /* Alias semánticos */
  --bg-default:         var(--color-white);
  --bg-alt:             var(--color-off-white);
  --bg-dark:            var(--color-surface);


  /* ─── Tipografía ─────────────────────────────────────────────────────── */

  --font-serif:         'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --font-sans:          'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  /* Escala de tamaños */
  --text-xs:            0.625rem;   /* 10px — labels, overlines */
  --text-sm:            0.75rem;    /* 12px — captions, footer links */
  --text-base:          0.9375rem;  /* 15px — cuerpo */
  --text-md:            1.125rem;   /* 18px */
  --text-lg:            clamp(1.25rem, 2vw, 1.5rem);
  --text-xl:            clamp(1.5rem, 3vw, 2rem);
  --text-2xl:           clamp(2rem, 4vw, 3rem);
  --text-3xl:           clamp(2.5rem, 5vw, 4rem);
  --text-4xl:           clamp(3rem, 7vw, 5.5rem);
  --text-hero:          clamp(3.5rem, 9vw, 8rem);

  /* Pesos */
  --weight-light:       300;
  --weight-regular:     400;
  --weight-medium:      500;
  --weight-semibold:    600;
  --weight-bold:        700;

  /* Line heights */
  --leading-tight:      1.05;
  --leading-snug:       1.2;
  --leading-normal:     1.5;
  --leading-relaxed:    1.65;
  --leading-loose:      1.8;

  /* Letter spacing */
  --tracking-tight:     -0.02em;
  --tracking-normal:     0;
  --tracking-wide:       0.06em;
  --tracking-wider:      0.12em;
  --tracking-widest:     0.2em;   /* para overlines y etiquetas */
  --tracking-caps:       0.3em;   /* para letras capitales decorativas */


  /* ─── Espaciado ──────────────────────────────────────────────────────── */

  --space-1:            0.25rem;
  --space-2:            0.5rem;
  --space-3:            0.75rem;
  --space-4:            1rem;
  --space-5:            1.25rem;
  --space-6:            1.5rem;
  --space-8:            2rem;
  --space-10:           2.5rem;
  --space-12:           3rem;
  --space-16:           4rem;
  --space-20:           5rem;
  --space-24:           6rem;
  --space-32:           8rem;
  --space-section:      clamp(4rem, 8vw, 8rem);
  --space-section-sm:   clamp(2.5rem, 5vw, 5rem);


  /* ─── Layout ─────────────────────────────────────────────────────────── */

  --container:          1400px;
  --container-md:       1100px;
  --container-sm:       900px;
  --container-padding:  clamp(1.25rem, 4vw, 3rem);

  --header-height:      80px;
  --header-height-mobile: 64px;


  /* ─── Bordes ─────────────────────────────────────────────────────────── */

  --radius:             0;   /* esquinas afiladas — NUNCA modificar */
  --border-width:       1px;
  --border-width-thick: 2px;


  /* ─── Transiciones ───────────────────────────────────────────────────── */

  --ease-premium:       cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --ease-out-expo:      cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in-out:        cubic-bezier(0.4, 0, 0.2, 1);

  --transition-fast:    0.15s ease;
  --transition-base:    0.3s var(--ease-premium);
  --transition:         0.35s var(--ease-premium);
  --transition-slow:    0.6s var(--ease-premium);
  --transition-hero:    1s var(--ease-out-expo);


  /* ─── Z-index ────────────────────────────────────────────────────────── */

  --z-base:             1;
  --z-above:            10;
  --z-dropdown:         50;
  --z-header:           100;
  --z-whatsapp:         200;
  --z-overlay:          300;
  --z-loader:           400;
  --z-cursor:           500;


  /* ─── Sombras (uso mínimo — solo para overlays, no decorativas) ──────── */

  --shadow-subtle:      0 2px 24px rgba(0, 0, 0, 0.06);
  --shadow-overlay:     0 20px 60px rgba(0, 0, 0, 0.12);

}

/* ─── global.css ─────────────────────────────────────────── */
/**
 * global.css — Estudio González
 * Reset, tipografía base, utilidades y estilos de cuerpo.
 */

@import './design-system.css';

/* ─── Reset ──────────────────────────────────────────────────────────────── */

*, *::before, *::after {
  box-sizing: border-box;
  border-radius: var(--radius);
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

body {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  font-weight: var(--weight-regular);
  line-height: var(--leading-relaxed);
  color: var(--color-text);
  background-color: var(--color-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

/* ─── Tipografía ─────────────────────────────────────────────────────────── */

h1, h2, h3 {
  font-family: var(--font-serif);
  font-weight: var(--weight-light);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--color-text);
}

h4, h5, h6 {
  font-family: var(--font-sans);
  font-weight: var(--weight-medium);
  line-height: var(--leading-snug);
  color: var(--color-text);
}

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

p {
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: var(--color-text-muted);
  max-width: 65ch;
}

/* Párrafos dentro de secciones de texto (sin max-width en layouts de columna) */
.text-block p {
  max-width: none;
}

a {
  color: inherit;
  text-decoration: none;
  transition: color var(--transition-fast);
}

a:hover {
  color: var(--color-accent);
}

strong, b {
  font-weight: var(--weight-semibold);
  color: var(--color-text);
}

em, i {
  font-style: italic;
}

/* ─── Microelementos tipográficos ────────────────────────────────────────── */

/* Overline — etiqueta decorativa sobre títulos */
.overline {
  display: block;
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: var(--space-4);
}

/* Label pequeño para categorías, formularios */
.label-sm {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--color-text-muted);
}

/* Número estadístico */
.stat-number {
  font-family: var(--font-serif);
  font-size: var(--text-3xl);
  font-weight: var(--weight-light);
  line-height: 1;
  color: var(--color-text);
}

.stat-number--white {
  color: var(--color-white);
}

/* ─── Listas ─────────────────────────────────────────────────────────────── */

ul, ol {
  padding-left: var(--space-6);
}

li {
  margin-bottom: var(--space-2);
  line-height: var(--leading-normal);
  color: var(--color-text-muted);
}

/* Lista sin estilos (para nav, tarjetas, etc.) */
.list-none {
  list-style: none;
  padding-left: 0;
}

.list-none li {
  margin-bottom: 0;
}

/* ─── Imágenes ───────────────────────────────────────────────────────────── */

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

/* Imagen que llena su contenedor */
.img-fill {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

/* ─── Contenedor principal ───────────────────────────────────────────────── */

.container {
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--container-padding);
}

.container--md {
  max-width: var(--container-md);
}

.container--sm {
  max-width: var(--container-sm);
}

/* ─── Secciones ──────────────────────────────────────────────────────────── */

.section {
  padding-block: var(--space-section);
}

.section--sm {
  padding-block: var(--space-section-sm);
}

.section--dark {
  background-color: var(--color-surface);
  color: var(--color-white);
}

.section--dark h1,
.section--dark h2,
.section--dark h3,
.section--dark h4,
.section--dark h5 {
  color: var(--color-white);
}

.section--dark p,
.section--dark li {
  color: rgba(250, 250, 250, 0.75);
}

.section--dark .overline {
  color: var(--color-accent-light);
}

.section--off-white {
  background-color: var(--color-off-white);
}

/* ─── Divisores ──────────────────────────────────────────────────────────── */

hr {
  border: none;
  border-top: 1px solid var(--color-border);
  margin-block: var(--space-8);
}

.divider {
  width: 40px;
  height: 1px;
  background-color: var(--color-accent);
  margin-block: var(--space-6);
}

/* ─── Utilidades de espaciado ────────────────────────────────────────────── */

.mt-auto { margin-top: auto; }
.mb-auto { margin-bottom: auto; }
.ml-auto { margin-left: auto; }
.mr-auto { margin-right: auto; }
.mx-auto { margin-inline: auto; }

/* ─── Utilidades de texto ────────────────────────────────────────────────── */

.text-center    { text-align: center; }
.text-left      { text-align: left; }
.text-right     { text-align: right; }
.text-uppercase { text-transform: uppercase; }
.text-muted     { color: var(--color-text-muted); }
.text-accent    { color: var(--color-accent); }
.text-white     { color: var(--color-white); }

/* ─── Utilidades de visualización ────────────────────────────────────────── */

.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;
}

.hidden { display: none !important; }

/* ─── Scroll suave personalizado ─────────────────────────────────────────── */

@media (prefers-reduced-motion: no-preference) {
  html {
    scroll-behavior: smooth;
  }
}

/* ─── Focus visible ──────────────────────────────────────────────────────── */

:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 3px;
}

/* ─── Selección de texto ─────────────────────────────────────────────────── */

::selection {
  background-color: var(--color-accent);
  color: var(--color-white);
}

/* ─── Scrollbar personalizada (webkit) ───────────────────────────────────── */

::-webkit-scrollbar {
  width: 6px;
}

::-webkit-scrollbar-track {
  background: var(--color-off-white);
}

::-webkit-scrollbar-thumb {
  background-color: var(--color-accent);
}

/* ─── Wordpress: eliminar margen superior del admin bar en header sticky ─── */

.admin-bar .site-header {
  top: 32px;
}

@media (max-width: 782px) {
  .admin-bar .site-header {
    top: 46px;
  }
}

/* ─── Wordpress: alineaciones de bloque ──────────────────────────────────── */

.wp-block-group.alignfull,
.wp-block-cover.alignfull {
  max-width: none;
  width: 100%;
}

/* ─── animations.css ─────────────────────────────────────────── */
/**
 * animations.css — Estudio González
 * Animaciones: scroll reveal (IntersectionObserver), page loader, keyframes.
 * Todas las animaciones respetan prefers-reduced-motion.
 */

/* ─── Page Loader ────────────────────────────────────────────────────────── */

.page-loader {
  position: fixed;
  inset: 0;
  background-color: var(--color-white);
  z-index: var(--z-loader);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity var(--transition-slow), visibility var(--transition-slow);
}

.page-loader.is-loaded {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.page-loader__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
}

.page-loader__logo {
  font-family: var(--font-serif);
  font-size: 1.25rem;
  font-weight: var(--weight-regular);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-text);
  animation: loaderPulse 1.6s ease-in-out infinite;
}

.page-loader__line {
  width: 40px;
  height: 1px;
  background-color: var(--color-accent);
  transform-origin: left;
  animation: loaderExpand 1.6s ease-in-out infinite;
}

@keyframes loaderPulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.25; }
}

@keyframes loaderExpand {
  0%   { transform: scaleX(0); opacity: 0; }
  50%  { transform: scaleX(1); opacity: 1; }
  100% { transform: scaleX(0); opacity: 0; transform-origin: right; }
}


/* ─── Scroll Reveal ──────────────────────────────────────────────────────── */

/* Estado inicial — elementos ocultos antes de entrar en viewport */
[data-reveal] {
  opacity: 0;
  transform: translateY(28px);
  transition:
    opacity 0.75s var(--ease-premium),
    transform 0.75s var(--ease-premium);
}

[data-reveal="left"] {
  transform: translateX(-28px);
}

[data-reveal="right"] {
  transform: translateX(28px);
}

[data-reveal="scale"] {
  transform: scale(0.96);
}

[data-reveal="fade"] {
  transform: none;
}

/* Estado revelado */
[data-reveal].is-revealed {
  opacity: 1;
  transform: none;
}

/* Stagger — hijos con retardos escalonados */
[data-reveal-stagger] > * {
  opacity: 0;
  transform: translateY(20px);
  transition:
    opacity 0.6s var(--ease-premium),
    transform 0.6s var(--ease-premium);
}

[data-reveal-stagger].is-revealed > *:nth-child(1) { transition-delay: 0.05s; }
[data-reveal-stagger].is-revealed > *:nth-child(2) { transition-delay: 0.15s; }
[data-reveal-stagger].is-revealed > *:nth-child(3) { transition-delay: 0.25s; }
[data-reveal-stagger].is-revealed > *:nth-child(4) { transition-delay: 0.35s; }
[data-reveal-stagger].is-revealed > *:nth-child(5) { transition-delay: 0.45s; }
[data-reveal-stagger].is-revealed > *:nth-child(6) { transition-delay: 0.55s; }
[data-reveal-stagger].is-revealed > *:nth-child(7) { transition-delay: 0.65s; }
[data-reveal-stagger].is-revealed > *:nth-child(8) { transition-delay: 0.75s; }

[data-reveal-stagger].is-revealed > * {
  opacity: 1;
  transform: none;
}


/* ─── Animación de entrada del hero ─────────────────────────────────────── */

.hero-content > * {
  opacity: 0;
  transform: translateY(20px);
}

.hero-content.is-ready > *:nth-child(1) {
  animation: heroFadeUp 0.9s var(--ease-out-expo) 0.3s forwards;
}
.hero-content.is-ready > *:nth-child(2) {
  animation: heroFadeUp 0.9s var(--ease-out-expo) 0.5s forwards;
}
.hero-content.is-ready > *:nth-child(3) {
  animation: heroFadeUp 0.9s var(--ease-out-expo) 0.7s forwards;
}
.hero-content.is-ready > *:nth-child(4) {
  animation: heroFadeUp 0.9s var(--ease-out-expo) 0.9s forwards;
}
.hero-content.is-ready > *:nth-child(5) {
  animation: heroFadeUp 0.9s var(--ease-out-expo) 1.1s forwards;
}

@keyframes heroFadeUp {
  to {
    opacity: 1;
    transform: none;
  }
}


/* ─── Animación de conteo de estadísticas ────────────────────────────────── */

[data-count] {
  font-variant-numeric: tabular-nums;
}


/* ─── Indicador de scroll en el hero ────────────────────────────────────── */

.scroll-indicator {
  position: absolute;
  bottom: var(--space-8);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  color: rgba(250, 250, 250, 0.5);
  animation: scrollBounce 2s ease-in-out infinite;
}

.scroll-indicator__line {
  width: 1px;
  height: 48px;
  background: linear-gradient(to bottom, transparent, rgba(250, 250, 250, 0.5));
}

.scroll-indicator__label {
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  writing-mode: vertical-lr;
  transform: rotate(180deg);
}

@keyframes scrollBounce {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%       { transform: translateX(-50%) translateY(6px); }
}


/* ─── Cursor personalizado ───────────────────────────────────────────────── */

.cursor-dot,
.cursor-ring {
  position: fixed;
  top: 0;
  left: 0;
  pointer-events: none;
  z-index: var(--z-cursor);
  border-radius: 0;
  transform: translate(-50%, -50%);
  will-change: transform;
}

.cursor-dot {
  width: 6px;
  height: 6px;
  background-color: var(--color-accent);
  transition: width 0.2s ease, height 0.2s ease, background-color 0.2s ease;
}

.cursor-ring {
  width: 32px;
  height: 32px;
  border: 1px solid rgba(10, 10, 10, 0.35);
  transition: width 0.25s ease, height 0.25s ease, border-color 0.25s ease;
}

/* Estado hover sobre elementos interactivos */
body.cursor-hover .cursor-dot {
  width: 40px;
  height: 40px;
  background-color: var(--color-accent);
  opacity: 0.15;
}

body.cursor-hover .cursor-ring {
  opacity: 0;
}


/* ─── Respetar prefers-reduced-motion ────────────────────────────────────── */

@media (prefers-reduced-motion: reduce) {

  [data-reveal],
  [data-reveal-stagger] > *,
  .hero-content > * {
    opacity: 1;
    transform: none;
    transition: none;
    animation: none;
  }

  .page-loader {
    display: none;
  }

  .scroll-indicator {
    animation: none;
  }

  .cursor-dot,
  .cursor-ring {
    display: none;
  }

}

/* ─── header.css ─────────────────────────────────────────── */
/**
 * header.css — Estudio González
 * Header sticky: grid 3 columnas, barra promo, hamburger mobile.
 */

/* ─── Barra promocional ──────────────────────────────────────────────────── */

.promo-bar {
  background-color: var(--color-surface);
  color: var(--color-white);
  text-align: center;
  padding: 0.625rem var(--container-padding);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  overflow: hidden;
  max-height: 42px;
  transition: max-height var(--transition), opacity var(--transition), padding var(--transition);
}

.promo-bar.is-hidden {
  max-height: 0;
  opacity: 0;
  padding-block: 0;
}

.promo-bar strong {
  color: var(--color-accent-light);
}

.promo-bar__dismiss {
  position: absolute;
  right: calc(var(--container-padding) - var(--space-3));
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: rgba(250, 250, 250, 0.7);
  cursor: pointer;
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  transition: color var(--transition-fast);
}

.promo-bar__dismiss:hover {
  color: var(--color-white);
}

.promo-bar-wrap {
  position: relative;
}

/* ─── Header principal ────────────────────────────────────────────────────── */

.site-header {
  position: sticky;
  top: 0;
  z-index: var(--z-header);
  background-color: var(--color-white);
  height: var(--header-height);
  width: 100%;
  transition: box-shadow var(--transition-fast);
  border-bottom: 1px solid transparent;
  transition: box-shadow var(--transition-fast), border-color var(--transition-fast);
}

.site-header.is-scrolled {
  box-shadow: var(--shadow-subtle);
  border-bottom-color: var(--color-border);
}

.site-header__inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  height: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--container-padding);
  gap: var(--space-8);
}

/* ─── Logo ───────────────────────────────────────────────────────────────── */

.site-logo {
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

.site-logo img,
.site-logo svg {
  height: 68px;
  width: auto;
  display: block;
  transition: transform var(--transition-fast);
}

.site-logo:hover img {
  transform: scale(1.03);
}

@media (max-width: 768px) {
  .site-logo img,
  .site-logo svg {
    height: 52px;
  }
}

/* ─── Navegación principal ───────────────────────────────────────────────── */

.site-nav {
  display: flex;
  align-items: center;
}

.site-nav__list {
  display: flex;
  align-items: center;
  gap: var(--space-8);
  list-style: none;
  padding: 0;
  margin: 0;
}

.site-nav__link {
  position: relative;
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-text);
  padding-block: var(--space-2);
  white-space: nowrap;
  transition: color var(--transition-fast);
}

/* Underline animado */
.site-nav__link::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 1px;
  background-color: var(--color-black);
  transition: width var(--transition);
}

.site-nav__link:hover,
.site-nav__link.is-active {
  color: var(--color-text);
}

.site-nav__link:hover::after,
.site-nav__link.is-active::after {
  width: 100%;
}

/* ─── Dropdown (Servicios) ──────────────────────────────────────────────── */

.site-nav__item {
  position: relative;
}

.site-nav__item--has-dropdown > .site-nav__link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.site-nav__item--has-dropdown > .site-nav__link svg {
  transition: transform var(--transition-fast);
}

.site-nav__item--has-dropdown:hover > .site-nav__link svg {
  transform: rotate(180deg);
}

.site-nav__dropdown {
  position: absolute;
  top: calc(100% + var(--space-2));
  left: 50%;
  transform: translateX(-50%) translateY(-8px);
  min-width: 240px;
  background: var(--color-white);
  border-top: 2px solid var(--color-accent);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.08);
  padding: var(--space-4) 0;
  list-style: none;
  margin: 0;
  opacity: 0;
  visibility: hidden;
  transition: all var(--transition);
  z-index: 50;
}

.site-nav__item--has-dropdown:hover > .site-nav__dropdown,
.site-nav__item--has-dropdown:focus-within > .site-nav__dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}

.site-nav__dropdown li a {
  display: block;
  padding: var(--space-3) var(--space-6);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text);
  text-decoration: none;
  transition: color var(--transition-fast), background var(--transition-fast);
  white-space: nowrap;
}

.site-nav__dropdown li a:hover {
  color: var(--color-accent);
  background: var(--color-off-white, #F8F7F5);
}

/* ─── Acciones del header (derecha) ──────────────────────────────────────── */

.site-header__actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-6);
}

.header-social {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.header-social__link {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-muted);
  transition: color var(--transition-fast);
}

.header-social__link:hover {
  color: var(--color-accent);
}

.header-social__link svg {
  width: 18px;
  height: 18px;
  stroke-width: 1.5;
}

/* CTA WhatsApp en header */
.header-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-sans);
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-white);
  background: var(--color-black);
  padding: 0.85rem 1.5rem;
  transition: background var(--transition), transform var(--transition-fast);
  white-space: nowrap;
  text-decoration: none;
  border: none;
}

.header-cta:hover {
  background: var(--color-accent);
  color: var(--color-white);
  transform: translateY(-1px);
}

/* ─── Hamburger (mobile) ─────────────────────────────────────────────────── */

.hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 6px;
  width: 44px;
  height: 44px;
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--space-2);
}

.hamburger__line {
  display: block;
  width: 22px;
  height: 1.5px;
  background-color: var(--color-text);
  transform-origin: center;
  transition: transform 0.3s ease, opacity 0.3s ease;
}

.hamburger.is-open .hamburger__line:nth-child(1) {
  transform: rotate(45deg) translate(5px, 5px);
}
.hamburger.is-open .hamburger__line:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}
.hamburger.is-open .hamburger__line:nth-child(3) {
  transform: rotate(-45deg) translate(5px, -5px);
}

/* ─── Menú mobile ────────────────────────────────────────────────────────── */

.mobile-nav {
  position: fixed;
  inset: 0;
  top: var(--header-height-mobile);
  background-color: var(--color-white);
  z-index: calc(var(--z-header) - 1);
  display: flex;
  flex-direction: column;
  padding: var(--space-8) var(--container-padding) var(--space-12);
  overflow-y: auto;
  transform: translateX(100%);
  opacity: 0;
  visibility: hidden;
  transition: transform var(--transition), opacity var(--transition), visibility var(--transition);
}

.mobile-nav.is-open {
  transform: translateX(0);
  opacity: 1;
  visibility: visible;
}

.mobile-nav__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.mobile-nav__item {
  border-bottom: 1px solid var(--color-border);
}

.mobile-nav__link {
  display: block;
  font-family: var(--font-sans);
  font-size: 0.8125rem;
  font-weight: var(--weight-medium);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-text);
  padding: var(--space-4) 0;
  transition: color var(--transition-fast);
}

.mobile-nav__link:hover {
  color: var(--color-accent);
}

.mobile-nav__footer {
  margin-top: auto;
  padding-top: var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

/* ─── Breakpoints ────────────────────────────────────────────────────────── */

@media (max-width: 1024px) {
  .site-nav,
  .header-social,
  .header-cta {
    display: none;
  }

  .hamburger {
    display: flex;
  }

  .site-header {
    height: var(--header-height-mobile);
  }

  .site-header__inner {
    grid-template-columns: 1fr auto;
    gap: 0;
  }

  .site-logo img,
  .site-logo svg {
    height: 36px;
  }
}

/* ─── footer.css ─────────────────────────────────────────── */
/**
 * footer.css — Estudio González
 * Footer oscuro: 4 columnas, redes sociales, legal.
 */

.site-footer {
  background-color: var(--color-surface);
  color: var(--color-white);
}

/* ─── Parte superior ─────────────────────────────────────────────────────── */

.site-footer__top {
  padding-top: var(--space-16);
  padding-bottom: var(--space-12);
  padding-inline: var(--container-padding);
  max-width: var(--container);
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: var(--space-12) var(--space-8);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

/* ─── Columna de marca ───────────────────────────────────────────────────── */

.footer-brand__logo {
  margin-bottom: var(--space-6);
  display: block;
}

.footer-brand__logo img,
.footer-brand__logo svg {
  height: 72px;
  width: auto;
  display: block;
}

.footer-brand__tagline {
  font-family: var(--font-serif);
  font-size: var(--text-md);
  font-weight: var(--weight-light);
  font-style: italic;
  color: rgba(250, 250, 250, 0.6);
  margin-bottom: var(--space-6);
  line-height: var(--leading-normal);
}

.footer-brand__desc {
  font-size: 0.875rem;
  line-height: 1.65;
  color: rgba(250, 250, 250, 0.65);
  max-width: 32ch;
}

/* Redes sociales */
.footer-social {
  display: flex;
  gap: var(--space-3);
  margin-top: var(--space-8);
}

.footer-social__link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border: 1px solid rgba(255, 255, 255, 0.25);
  color: rgba(250, 250, 250, 0.7);
  transition: border-color var(--transition-fast), color var(--transition-fast);
}

.footer-social__link:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
}

.footer-social__link svg {
  width: 16px;
  height: 16px;
  stroke-width: 1.5;
}

/* ─── Columnas de navegación ─────────────────────────────────────────────── */

.footer-nav__title {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: var(--weight-semibold);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-white);
  color: var(--color-white);
  margin-bottom: var(--space-6);
}

.footer-nav__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.footer-nav__link {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  font-size: 0.8125rem;
  color: rgba(250, 250, 250, 0.7);
  transition: color var(--transition-fast);
  line-height: var(--leading-normal);
}

.footer-nav__link:hover {
  color: var(--color-white);
}

/* Dirección */
.footer-address {
  font-style: normal;
  font-size: 0.8125rem;
  color: rgba(250, 250, 250, 0.55);
  line-height: 1.55;
  margin: 0 0 var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.footer-address__line {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  margin: 0;
}

.footer-address__line svg {
  color: var(--color-accent-light);
  flex-shrink: 0;
  margin-top: 2px;
}

.footer-address__line span {
  display: block;
}

.footer-address a {
  color: rgba(250, 250, 250, 0.55);
  text-decoration: none;
  transition: color var(--transition-fast);
  border-bottom: 1px solid transparent;
}

.footer-address a:hover {
  color: var(--color-white);
  border-bottom-color: var(--color-accent);
}

/* CTA inline del footer (WhatsApp) */
.footer-cta {
  margin-top: var(--space-2);
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}

/* ─── Parte inferior ─────────────────────────────────────────────────────── */

.site-footer__bottom {
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--container-padding);
  padding-block: var(--space-6);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-4);
}

.footer-copyright {
  font-size: 0.75rem;
  color: rgba(250, 250, 250, 0.7);
  letter-spacing: 0.06em;
}

.footer-legal {
  display: flex;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.footer-legal__link {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  padding-inline: var(--space-2);
  font-size: 0.75rem;
  color: rgba(250, 250, 250, 0.7);
  letter-spacing: 0.06em;
  transition: color var(--transition-fast);
}

.footer-legal__link:hover {
  color: var(--color-white);
}

.footer-credits {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  color: rgba(250, 250, 250, 0.7);
  letter-spacing: 0.06em;
  margin: 0;
}

.footer-credits a {
  color: var(--color-accent-light);
  font-weight: var(--weight-semibold);
  transition: color var(--transition-fast);
  text-decoration: none;
}

.footer-credits a:hover,
.footer-credits a:focus-visible {
  color: var(--color-white);
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* ─── Breakpoints ────────────────────────────────────────────────────────── */

@media (max-width: 1024px) {
  .site-footer__top {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-10) var(--space-8);
  }

  .footer-brand {
    grid-column: 1 / -1;
  }

  .footer-brand__desc {
    max-width: 50ch;
  }
}

@media (max-width: 600px) {
  .site-footer__top {
    grid-template-columns: 1fr;
  }

  .footer-brand {
    grid-column: auto;
  }

  .site-footer__bottom {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* ─── Banner Kit Digital (Fondos Next Generation EU) ─────────────────────── */

.kit-digital {
  background-color: var(--color-white);
  color: var(--color-text);
  padding: var(--space-12) var(--container-padding);
  border-top: 1px solid var(--color-border);
  text-align: center;
}

.kit-digital__inner {
  max-width: 850px;
  margin-inline: auto;
}

.kit-digital__text {
  /* Resetear el max-width que WP global-styles aplica a todos los <p>
     vía --wp--style--global--content-size (~600px), que rompía el
     centrado dentro del .kit-digital__inner de 850px. */
  max-width: none;
  margin-inline: auto;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  font-weight: var(--weight-semibold);
  line-height: 1.5;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--color-text);
  margin-bottom: var(--space-8);
}

.kit-digital__logo img {
  display: block;
  width: 100%;
  height: auto;
  max-width: 850px;
  margin-inline: auto;
  border: 1px solid var(--color-border);
  padding: var(--space-3);
  background-color: var(--color-white);
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.06);
  box-sizing: border-box;
}

@media (max-width: 768px) {
  .kit-digital {
    padding-block: var(--space-10);
  }

  .kit-digital__text {
    font-size: 0.8125rem;
    letter-spacing: 0;
  }
}

/* ─── hero.css ─────────────────────────────────────────── */
/**
 * hero.css — Estudio González
 * Hero de página completa con overlay, contenido posicionado e indicador de scroll.
 */

.hero {
  position: relative;
  min-height: calc(100dvh - var(--header-height));
  display: flex;
  align-items: center;
  overflow: hidden;
  background-color: var(--color-surface);
}

/* ─── Imagen de fondo ────────────────────────────────────────────────────── */

.hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  /* Imagen 4:3 con sujeto en zona derecha-inferior (instructora + pelota).
   * En desktop, encuadrar para que el sujeto quede a la derecha sin
   * cortarse y el espacio negativo respire detrás del copy a la izquierda. */
  object-position: 70% 60%;
  background-color: var(--color-surface);
  will-change: transform;
}

/* ─── Overlay ────────────────────────────────────────────────────────────── */

.hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(
      90deg,
      rgba(20, 18, 16, 0.65) 0%,
      rgba(20, 18, 16, 0.45) 35%,
      rgba(20, 18, 16, 0.10) 70%,
      rgba(20, 18, 16, 0) 100%
    ),
    linear-gradient(
      180deg,
      rgba(20, 18, 16, 0.10) 0%,
      rgba(20, 18, 16, 0) 30%,
      rgba(20, 18, 16, 0.35) 100%
    );
}

/* ─── Contenido ──────────────────────────────────────────────────────────── */

.hero__content {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--container-padding);
  padding-block: var(--space-16);
}

.hero__inner {
  max-width: 680px;
}

.hero__overline {
  display: block;
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: var(--color-accent-light);
  margin-bottom: var(--space-6);
}

.hero__title {
  font-family: var(--font-serif);
  font-size: var(--text-hero);
  font-weight: var(--weight-light);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--color-white);
  margin-bottom: var(--space-6);
}

.hero__desc {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: rgba(250, 250, 250, 0.8);
  max-width: 44ch;
  margin-bottom: var(--space-10);
}

.hero__ctas {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.hero__trust {
  margin-top: var(--space-6);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2) var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(250, 250, 250, 0.6);
}

.hero__trust span[aria-hidden="true"] {
  color: rgba(250, 250, 250, 0.35);
}

/* ─── Indicador de scroll ────────────────────────────────────────────────── */

.hero__scroll {
  position: absolute;
  bottom: var(--space-8);
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
  color: rgba(250, 250, 250, 0.4);
  animation: scrollBounce 2s ease-in-out infinite;
}

.hero__scroll-label {
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  writing-mode: vertical-lr;
}

.hero__scroll-line {
  width: 1px;
  height: 48px;
  background: linear-gradient(to bottom, rgba(250, 250, 250, 0.4), transparent);
}

/* ─── Variante: hero interior de página ──────────────────────────────────── */

.page-hero {
  position: relative;
  min-height: 40vh;
  display: flex;
  align-items: flex-end;
  background-color: var(--color-surface);
  overflow: hidden;
}

.page-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.page-hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.35;
}

.page-hero__content {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--container-padding);
  padding-bottom: var(--space-12);
}

.page-hero__title {
  font-family: var(--font-serif);
  font-size: var(--text-4xl);
  font-weight: var(--weight-light);
  color: var(--color-white);
  letter-spacing: var(--tracking-tight);
}

/* ─── Breakpoints ────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
  /* Mobile: cambiamos la composición. En vez de superponer copy + CTAs
   * sobre la foto (los botones tapaban la cara de la instructora),
   * separamos el hero en dos bloques verticales: la foto arriba con
   * aspect-ratio fijo, y el copy/CTAs en un bloque oscuro debajo. */
  .hero {
    min-height: 0;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    background-color: var(--color-surface);
  }

  .hero__bg {
    position: relative;
    inset: auto;
    aspect-ratio: 4 / 5;
    width: 100%;
    flex: 0 0 auto;
  }

  .hero__bg img {
    /* Crop portrait ya viene encuadrado al sujeto. Center mantiene
     * pelota, cuerpo y cara visibles en el aspecto 4:5. */
    object-position: center;
  }

  .hero__overlay {
    /* Solo cubre la franja de la foto, con un sutil oscurecido en el
     * borde inferior para fundir con el bloque de copy de debajo. */
    background:
      linear-gradient(
        180deg,
        rgba(20, 18, 16, 0) 0%,
        rgba(20, 18, 16, 0) 70%,
        rgba(20, 18, 16, 0.55) 100%
      );
  }

  .hero__content {
    position: relative;
    inset: auto;
    padding-block: var(--space-10);
    padding-inline: var(--container-padding);
    background-color: var(--color-surface);
  }

  .hero__inner {
    max-width: 100%;
  }

  .hero__title {
    color: var(--color-white);
  }

  .hero__ctas {
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-3);
  }

  .hero__ctas .btn {
    justify-content: center;
  }

  .hero__trust {
    font-size: 10px;
    letter-spacing: 0.15em;
    gap: var(--space-1) var(--space-2);
  }

  .hero__scroll {
    display: none;
  }
}

/* ─── buttons.css ─────────────────────────────────────────── */
/**
 * buttons.css — Estudio González
 * Sistema de botones con efecto hover de fondo deslizante.
 */

/* ─── Base ────────────────────────────────────────────────────────────────── */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  padding: 1rem 2.5rem;
  border: none;
  cursor: pointer;
  text-decoration: none;
  position: relative;
  overflow: hidden;
  transition: color var(--transition);
  white-space: nowrap;
  border-radius: 0;
}

/* Fondo deslizante — efecto hover premium */
.btn::before {
  content: '';
  position: absolute;
  inset: 0;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--transition);
  z-index: 0;
}

.btn:hover::before {
  transform: scaleX(1);
}

/* El contenido queda por encima del pseudo-elemento */
.btn > * {
  position: relative;
  z-index: 1;
}

/* Texto envuelto en span para z-index */
.btn span {
  position: relative;
  z-index: 1;
}

/* Icono dentro del botón */
.btn svg {
  position: relative;
  z-index: 1;
  width: 16px;
  height: 16px;
  stroke-width: 1.5;
  flex-shrink: 0;
  transition: transform var(--transition-fast);
}

.btn:hover svg {
  transform: translateX(3px);
}

/* ─── Variante primaria (negro → rojo al hover) ──────────────────────────── */

.btn--primary {
  background-color: var(--color-black);
  color: var(--color-white);
}

.btn--primary::before {
  background-color: var(--color-accent);
}

/* ─── Variante secundaria / ghost (borde negro → fondo negro) ────────────── */

.btn--ghost {
  background-color: transparent;
  border: 1px solid var(--color-black);
  color: var(--color-black);
}

.btn--ghost::before {
  background-color: var(--color-black);
}

.btn--ghost:hover {
  color: var(--color-white);
}

/* ─── Variante blanca (fondo blanco → fondo negro en dark sections) ──────── */

.btn--white {
  background-color: var(--color-white);
  color: var(--color-black);
}

.btn--white::before {
  background-color: var(--color-black);
}

.btn--white:hover {
  color: var(--color-white);
}

/* ─── Variante ghost-white (para secciones oscuras) ─────────────────────── */

.btn--ghost-white {
  background-color: transparent;
  border: 1px solid rgba(250, 250, 250, 0.5);
  color: var(--color-white);
}

.btn--ghost-white::before {
  background-color: var(--color-white);
}

.btn--ghost-white:hover {
  color: var(--color-black);
}

/* ─── Variante acento (rojo) ─────────────────────────────────────────────── */

.btn--accent {
  background-color: var(--color-accent);
  color: var(--color-white);
}

.btn--accent::before {
  background-color: var(--color-accent-dark);
}

/* ─── Tamaños ─────────────────────────────────────────────────────────────── */

.btn--sm {
  font-size: 0.5625rem;
  padding: 0.75rem 1.75rem;
  letter-spacing: 0.16em;
}

.btn--lg {
  font-size: 0.75rem;
  padding: 1.25rem 3rem;
  letter-spacing: 0.22em;
}

/* ─── Botón de submit de formulario (ancho completo) ─────────────────────── */

.btn--submit {
  width: 100%;
  padding: 1.125rem 2rem;
  font-size: var(--text-xs);
  letter-spacing: 0.22em;
  background-color: var(--color-black);
  color: var(--color-white);
  border: none;
  justify-content: center;
  gap: 0.75rem;
  transition: background-color var(--transition-fast), gap var(--transition-fast);
}

.btn--submit::before {
  background-color: var(--color-accent);
}

/* ─── Botón de solo texto con flecha ─────────────────────────────────────── */

.btn--text {
  background-color: transparent;
  border: none;
  color: var(--color-text);
  padding: 0;
  gap: var(--space-3);
  font-size: var(--text-xs);
  letter-spacing: 0.16em;
  transition: gap var(--transition-fast), color var(--transition-fast);
}

.btn--text::before {
  display: none;
}

.btn--text:hover {
  color: var(--color-accent);
  gap: var(--space-5);
}

.btn--text svg {
  transition: transform var(--transition-fast);
}

.btn--text:hover svg {
  transform: translateX(4px);
}

.btn--text--white {
  color: rgba(250, 250, 250, 0.7);
}

.btn--text--white:hover {
  color: var(--color-white);
}

/* ─── cards.css ─────────────────────────────────────────── */
/**
 * cards.css — Estudio González
 * Tarjetas: servicios, equipo, máquinas, características.
 */

/* ─── Tarjeta de servicio ─────────────────────────────────────────────────── */

.service-card {
  position: relative;
  overflow: hidden;
  background-color: var(--color-white);
  border: 1px solid var(--color-border);
  display: flex;
  flex-direction: column;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.service-card:hover {
  border-color: var(--color-accent);
  box-shadow: var(--shadow-subtle);
}

/* Imagen del servicio */
.service-card__image {
  aspect-ratio: 3 / 4;
  overflow: hidden;
  flex-shrink: 0;
}

.service-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform 0.7s var(--ease-premium);
}

.service-card:hover .service-card__image img {
  transform: scale(1.05);
}

/* Contenido */
.service-card__body {
  padding: var(--space-6) var(--space-6) var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  flex-grow: 1;
}

.service-card__label {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--color-accent);
}

.service-card__title {
  font-family: var(--font-serif);
  font-size: var(--text-xl);
  font-weight: var(--weight-regular);
  line-height: var(--leading-snug);
  color: var(--color-text);
  letter-spacing: var(--tracking-tight);
}

.service-card__desc {
  font-size: 0.875rem;
  line-height: var(--leading-relaxed);
  color: var(--color-text-muted);
  flex-grow: 1;
}

.service-card__link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-text);
  margin-top: var(--space-2);
  transition: gap var(--transition-fast), color var(--transition-fast);
}

.service-card__link:hover {
  color: var(--color-accent);
  gap: var(--space-5);
}

.service-card__link svg {
  width: 14px;
  height: 14px;
  stroke-width: 1.5;
  flex-shrink: 0;
}

/* ─── Grid de servicios ───────────────────────────────────────────────────── */

.services-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-6) var(--space-4);
}

@media (max-width: 1024px) {
  .services-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 600px) {
  .services-grid {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }
}

/* ─── Tarjeta de categoría / máquina ─────────────────────────────────────── */

.machine-card {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4 / 5;
}

.machine-card__image {
  position: absolute;
  inset: 0;
}

.machine-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform 0.8s var(--ease-premium);
}

.machine-card:hover .machine-card__image img {
  transform: scale(1.04);
}

.machine-card__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(10, 10, 10, 0.75) 0%,
    rgba(10, 10, 10, 0.15) 55%,
    transparent 100%
  );
  transition: background var(--transition);
}

.machine-card:hover .machine-card__overlay {
  background: linear-gradient(
    to top,
    rgba(10, 10, 10, 0.85) 0%,
    rgba(10, 10, 10, 0.25) 55%,
    rgba(10, 10, 10, 0.05) 100%
  );
}

.machine-card__content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 1;
  padding: var(--space-8);
}

.machine-card__label {
  display: block;
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--color-accent-light);
  margin-bottom: var(--space-3);
}

.machine-card__title {
  font-family: var(--font-serif);
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  font-weight: var(--weight-light);
  color: var(--color-white);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  margin-bottom: var(--space-4);
}

.machine-card__link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(250, 250, 250, 0.65);
  transition: gap var(--transition-fast), color var(--transition-fast);
}

.machine-card:hover .machine-card__link {
  color: var(--color-white);
  gap: var(--space-5);
}

/* ─── Tarjeta de equipo ───────────────────────────────────────────────────── */

.team-card {
  display: flex;
  flex-direction: column;
}

.team-card__image {
  aspect-ratio: 3 / 4;
  overflow: hidden;
  margin-bottom: var(--space-6);
  position: relative;
}

.team-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  transition: transform 0.7s var(--ease-premium);
}

.team-card:hover .team-card__image img {
  transform: scale(1.04);
}

.team-card__name {
  font-family: var(--font-serif);
  font-size: var(--text-xl);
  font-weight: var(--weight-regular);
  letter-spacing: var(--tracking-tight);
  color: var(--color-text);
  margin-bottom: var(--space-2);
}

.team-card__role {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: var(--space-4);
}

.team-card__bio {
  font-size: 0.875rem;
  line-height: var(--leading-relaxed);
  color: var(--color-text-muted);
}

/* ─── Trust badges / valores ──────────────────────────────────────────────── */

.trust-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-8);
  text-align: center;
}

.trust-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
}

.trust-item__icon {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-accent);
}

.trust-item__icon svg {
  width: 28px;
  height: 28px;
  stroke-width: 1.5;
}

.trust-item__title {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-text);
  line-height: var(--leading-snug);
}

.trust-item__desc {
  font-size: 0.8125rem;
  line-height: var(--leading-relaxed);
  color: var(--color-text-muted);
  max-width: 22ch;
  margin-inline: auto;
}

/* Versión oscura (sección dark) */
.section--dark .trust-item__title {
  color: rgba(250, 250, 250, 0.9);
}

.section--dark .trust-item__desc {
  color: rgba(250, 250, 250, 0.5);
}

/* ─── Breakpoints ─────────────────────────────────────────────────────────── */

@media (max-width: 1024px) {
  .trust-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 600px) {
  .trust-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-6);
  }

  .trust-item__desc {
    display: none;
  }
}

/* ─── Machines grid (3 cols: Reformer, Torre, Wunda Chair) ─────────────── */

.machines-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}

@media (max-width: 1024px) {
  .machines-grid {
    grid-template-columns: 1fr 1fr;
  }
  .machines-grid > .machine-card:nth-child(3) {
    grid-column: span 2;
    max-width: 60%;
    margin-inline: auto;
    width: 100%;
  }
}

@media (max-width: 720px) {
  .machines-grid {
    grid-template-columns: 1fr;
  }
  .machines-grid > .machine-card:nth-child(3) {
    grid-column: auto;
    max-width: none;
  }
}

/* ─── Machines benefits grid (3 cols: Reformer, Torre, Wunda Chair) ────── */

.machines-benefits-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-12) var(--space-10);
}

@media (max-width: 1024px) {
  .machines-benefits-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 720px) {
  .machines-benefits-grid {
    grid-template-columns: 1fr;
    gap: var(--space-10);
  }
}

/* ─── Tabla de Saltos (Jumpboard) destacado ───────────────────────────── */

.jumpboard-feature {
  margin-top: var(--space-16);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-12);
  align-items: center;
  padding: var(--space-10);
  background-color: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.07);
}

.jumpboard-feature__media {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background-color: rgba(255, 255, 255, 0.04);
}

.jumpboard-feature__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

@media (max-width: 900px) {
  .jumpboard-feature {
    grid-template-columns: 1fr;
    padding: var(--space-6);
  }
  .jumpboard-feature ul {
    grid-template-columns: 1fr !important;
  }
}

/* ─── whatsapp.css ─────────────────────────────────────────── */
/**
 * whatsapp.css — Estudio González
 * Botón flotante de WhatsApp (posición fija, derecha inferior).
 *
 * Convivencia con XCookies (plugin Subsana Cookies, instalado en
 * producción): el banner y su botón minimizado se posicionan en
 * bottom-left desde el override más abajo, dejando esta esquina
 * derecha libre para el WhatsApp.
 */

.whatsapp-float {
  position: fixed;
  bottom: var(--space-8);
  right: var(--space-8);
  z-index: var(--z-whatsapp);
  width: 56px;
  height: 56px;
  background-color: #25D366;
  color: var(--color-white);
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  border-radius: 0;
  box-shadow: 0 4px 16px rgba(37, 211, 102, 0.35);
  transition: transform var(--transition-fast), box-shadow var(--transition-fast), background-color var(--transition-fast);
  opacity: 0;
  transform: translateY(16px) scale(0.9);
  animation: whatsappAppear 0.6s var(--ease-out-expo) 2s forwards;
}

@keyframes whatsappAppear {
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.whatsapp-float:hover {
  background-color: #1da851;
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(37, 211, 102, 0.45);
}

.whatsapp-float svg {
  width: 28px;
  height: 28px;
  fill: currentColor;
  flex-shrink: 0;
}

/* Tooltip al hover */
.whatsapp-float::before {
  content: attr(data-tooltip);
  position: absolute;
  right: calc(100% + var(--space-3));
  top: 50%;
  transform: translateY(-50%);
  background-color: var(--color-surface);
  color: var(--color-white);
  font-family: var(--font-sans);
  font-size: 0.6875rem;
  font-weight: var(--weight-medium);
  letter-spacing: 0.08em;
  white-space: nowrap;
  padding: 0.5rem 0.875rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition-fast);
}

.whatsapp-float:hover::before {
  opacity: 1;
}

/* Pulsación de atención */
.whatsapp-float__pulse {
  position: absolute;
  inset: -4px;
  border-radius: 0;
  background-color: rgba(37, 211, 102, 0.3);
  animation: whatsappPulse 2.5s ease-out infinite;
  pointer-events: none;
}

@keyframes whatsappPulse {
  0%   { transform: scale(1); opacity: 0.6; }
  70%  { transform: scale(1.4); opacity: 0; }
  100% { transform: scale(1.4); opacity: 0; }
}

/* ─── Breakpoints ─────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
  .whatsapp-float {
    bottom: var(--space-6);
    right: var(--space-4);
    width: 50px;
    height: 50px;
  }

  .whatsapp-float svg {
    width: 24px;
    height: 24px;
  }

  .whatsapp-float::before {
    display: none;
  }
}

/* ─── Ocultar botón de Joinchat (plugin creame-whatsapp-me) ───────────────
 * En el servidor real (estudiovirginiagonzalez.es) está activo el plugin
 * `creame-whatsapp-me` (Joinchat) que también inyecta un botón flotante
 * de WhatsApp en bottom-right. Choca con nuestro `.whatsapp-float` que
 * el cliente prefiere mantener. Ocultamos visualmente el de Joinchat
 * sin desactivar el plugin (reversible — basta con eliminar este bloque
 * si en el futuro se prefiere usar el del plugin).
 */
.joinchat,
.joinchat__button,
#joinchat,
[class^="joinchat-"],
[class*=" joinchat-"] {
  display: none !important;
}

/* ─── Override XCookies (Subsana Cookies) — banner y botón a la izquierda ──
 * El plugin XCookies sirve banner y botón flotante minimizado en
 * bottom-right por defecto, lo que solapa el WhatsApp. Forzamos al
 * lado izquierdo desde aquí para no depender de la configuración del
 * plugin (admin del cliente).
 *
 * Specificity: body + #id + .class > #id + .class del plugin → ganamos
 * sin necesidad de !important.
 */
body #subsana-cookies-banner,
body #subsana-cookies-banner.sc-pos-right {
  right: auto;
  left: var(--space-4);
}

body #subsana-cookies-minimized,
body #subsana-cookies-minimized.sc-pos-right {
  right: auto;
  left: var(--space-4);
}

/* En móvil el banner XCookies ya pasa a full-width (left:0; right:0)
 * en su propio CSS — no necesitamos hacer nada extra ahí. El botón
 * minimizado sí se mantiene en la izquierda. */

/* ─── gallery.css ─────────────────────────────────────────── */
/**
 * gallery.css — Estudio González
 * Galería: grid editorial asimétrico y lightbox nativo.
 */

/* ─── Grid editorial ──────────────────────────────────────────────────────── */

.gallery-grid {
  display: grid;
  grid-template-columns: 1.4fr 0.8fr 0.8fr 1.4fr;
  grid-auto-rows: 480px;
  gap: 3px;
}

/* Celdas altas (protruyen visualmente) */
.gallery-grid__item--tall {
  grid-row: span 1;
  margin-top: -30px;
}

.gallery-grid__item {
  position: relative;
  overflow: hidden;
  cursor: zoom-in;
}

.gallery-grid__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform 0.7s var(--ease-premium);
}

.gallery-grid__item:hover img {
  transform: scale(1.04);
}

/* Overlay hover */
.gallery-grid__item::after {
  content: '';
  position: absolute;
  inset: 0;
  background-color: rgba(10, 10, 10, 0);
  transition: background-color var(--transition);
}

.gallery-grid__item:hover::after {
  background-color: rgba(10, 10, 10, 0.2);
}

/* Icono de zoom */
.gallery-grid__zoom {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 1;
  transform: translate(-50%, -50%) scale(0.8);
  opacity: 0;
  color: var(--color-white);
  transition: transform var(--transition), opacity var(--transition);
}

.gallery-grid__item:hover .gallery-grid__zoom {
  transform: translate(-50%, -50%) scale(1);
  opacity: 1;
}

.gallery-grid__zoom svg {
  width: 32px;
  height: 32px;
  stroke-width: 1.5;
}

/* ─── Grid de galería simple (2x columnas) ───────────────────────────────── */

.gallery-simple {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
}

.gallery-simple__item {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  cursor: zoom-in;
  position: relative;
}

.gallery-simple__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s var(--ease-premium);
}

.gallery-simple__item:hover img {
  transform: scale(1.05);
}

/* ─── Lightbox nativo (dialog element) ───────────────────────────────────── */

.lightbox {
  position: fixed;
  inset: 0;
  z-index: calc(var(--z-overlay) + 50);
  background-color: rgba(10, 10, 10, 0.95);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-8);
  border: none;
  width: 100%;
  max-width: 100%;
  max-height: 100vh;
}

.lightbox::backdrop {
  background-color: rgba(10, 10, 10, 0.95);
}

.lightbox__img {
  max-width: 90vw;
  max-height: 85vh;
  object-fit: contain;
  display: block;
}

.lightbox__close {
  position: absolute;
  top: var(--space-6);
  right: var(--space-6);
  background: none;
  border: 1px solid rgba(250, 250, 250, 0.2);
  color: rgba(250, 250, 250, 0.6);
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: color var(--transition-fast), border-color var(--transition-fast);
}

.lightbox__close:hover {
  color: var(--color-white);
  border-color: var(--color-white);
}

.lightbox__close svg {
  width: 20px;
  height: 20px;
  stroke-width: 1.5;
}

/* ─── Breakpoints ─────────────────────────────────────────────────────────── */

@media (max-width: 1024px) {
  .gallery-grid {
    grid-template-columns: 1fr 1fr;
    grid-auto-rows: 320px;
  }

  .gallery-grid__item--tall {
    margin-top: 0;
  }

  .gallery-simple {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 600px) {
  .gallery-grid {
    grid-template-columns: 1fr 1fr;
    grid-auto-rows: 200px;
    gap: 2px;
  }

  .gallery-simple {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-2);
  }
}

/* ─── forms.css ─────────────────────────────────────────── */
/**
 * forms.css — Estudio González
 * Formularios: inputs con borde inferior en acento al focus.
 */

.form-card {
  background-color: var(--color-off-white);
  padding: var(--space-12) clamp(var(--space-8), 4vw, var(--space-16));
}

.form-header {
  margin-bottom: var(--space-10);
  padding-bottom: var(--space-6);
  border-bottom: 1px solid var(--color-border);
}

.form-header .overline {
  margin-bottom: var(--space-4);
}

.form-header h2,
.form-header h3 {
  font-family: var(--font-serif);
  font-size: var(--text-2xl);
  font-weight: var(--weight-light);
  letter-spacing: var(--tracking-tight);
  color: var(--color-text);
}

/* ─── Grupos y filas ─────────────────────────────────────────────────────── */

.form-row {
  display: grid;
  gap: var(--space-6);
  margin-bottom: var(--space-6);
}

.form-row--half {
  grid-template-columns: 1fr 1fr;
}

.form-row--single {
  grid-template-columns: 1fr;
}

/* ─── Campo individual ────────────────────────────────────────────────────── */

.form-field {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

/* ─── Labels ──────────────────────────────────────────────────────────────── */

label,
.form-field label {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--color-text-muted);
  transition: color var(--transition-fast);
}

.form-field:focus-within label {
  color: var(--color-text);
}

.form-field .req {
  color: var(--color-accent);
  margin-left: 0.2em;
}

/* ─── Inputs, Textarea, Select ───────────────────────────────────────────── */

input[type="text"],
input[type="email"],
input[type="tel"],
input[type="number"],
input[type="search"],
input[type="url"],
textarea,
select {
  width: 100%;
  padding: 0.875rem 1rem;
  background-color: var(--color-white);
  border: 1px solid var(--color-border);
  border-bottom: 2px solid var(--color-border);
  border-radius: 0;
  -webkit-appearance: none;
  appearance: none;
  font-family: var(--font-sans);
  font-size: var(--text-base);
  font-weight: var(--weight-regular);
  color: var(--color-text);
  outline: none;
  transition: border-color var(--transition-fast), background-color var(--transition-fast);
  line-height: var(--leading-normal);
}

input::placeholder,
textarea::placeholder {
  color: var(--color-text-muted);
  font-size: 0.875rem;
  opacity: 0.65;
}

input:focus,
textarea:focus,
select:focus {
  border-bottom-color: var(--color-accent);
  background-color: var(--color-white);
}

input:hover:not(:focus),
textarea:hover:not(:focus),
select:hover:not(:focus) {
  border-color: rgba(10, 10, 10, 0.3);
  border-bottom-color: rgba(10, 10, 10, 0.3);
}

textarea {
  min-height: 130px;
  resize: vertical;
  line-height: var(--leading-relaxed);
}

/* ─── Select personalizado ───────────────────────────────────────────────── */

.select-wrap {
  position: relative;
}

.select-wrap select {
  padding-right: 2.5rem;
  cursor: pointer;
}

.select-wrap__arrow {
  position: absolute;
  right: 1rem;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
  color: var(--color-text-muted);
}

.select-wrap__arrow svg {
  width: 16px;
  height: 16px;
  stroke-width: 1.5;
}

/* ─── Botón de submit ─────────────────────────────────────────────────────── */

.form-submit {
  width: 100%;
  padding: 1.125rem 2rem;
  background-color: var(--color-black);
  color: var(--color-white);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  border: none;
  border-radius: 0;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  margin-top: var(--space-8);
  transition: background-color var(--transition-fast), gap var(--transition-fast);
}

.form-submit:hover {
  background-color: var(--color-accent);
  gap: 1.25rem;
}

.form-submit svg {
  width: 16px;
  height: 16px;
  stroke-width: 1.5;
  flex-shrink: 0;
  transition: transform var(--transition-fast);
}

.form-submit:hover svg {
  transform: translateX(3px);
}

/* ─── Breakpoints ─────────────────────────────────────────────────────────── */

@media (max-width: 600px) {
  .form-row--half {
    grid-template-columns: 1fr;
  }

  .form-card {
    padding: var(--space-8) var(--space-6);
  }
}

/* ─── page-content.css ─────────────────────────────────────────── */
/* ═══════════════════════════════════════════════════════════════════════
   PAGE CONTENT — estilos para páginas interiores
   Hero compacto, bloques de texto, listas de beneficios, contacto, legal
   ═══════════════════════════════════════════════════════════════════════ */

/* ─── Hero de página interior ─────────────────────────────────────── */

.page-hero {
	position: relative;
	min-height: 45vh;
	display: flex;
	align-items: flex-end;
	padding: var(--space-24) 0 var(--space-12);
	overflow: hidden;
	background: var(--color-surface);
	color: var(--color-white);
}

.page-hero__bg {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.page-hero__bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: 0.35;
}

.page-hero::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(10,10,10,0.3) 0%, rgba(10,10,10,0.9) 100%);
	z-index: 1;
}

.page-hero__content {
	position: relative;
	z-index: 2;
	max-width: 720px;
}

.page-hero__content .overline {
	color: var(--color-accent-light);
	margin-bottom: var(--space-4);
	display: block;
}

.page-hero__title {
	font-family: var(--font-serif);
	font-size: clamp(2.25rem, 5vw, 3.75rem);
	font-weight: 300;
	letter-spacing: -0.02em;
	line-height: 1.05;
	color: var(--color-white);
	margin: 0 0 var(--space-6);
}

.page-hero__subtitle {
	font-family: var(--font-sans);
	font-size: var(--text-lg);
	font-weight: 300;
	line-height: 1.6;
	color: rgba(250, 250, 250, 0.75);
	max-width: 56ch;
	margin: 0;
}

/* ─── Bloque de texto a 2 columnas ───────────────────────────────── */

.two-col-text {
	display: grid;
	grid-template-columns: 1fr 1.5fr;
	gap: var(--space-16);
	align-items: start;
}

.two-col-text__heading h2 {
	font-family: var(--font-serif);
	font-size: var(--text-3xl);
	font-weight: 300;
	letter-spacing: -0.02em;
	line-height: 1.1;
	margin: 0;
	max-width: 14ch;
}

.two-col-text__body p {
	font-family: var(--font-sans);
	font-size: var(--text-lg);
	line-height: 1.75;
	color: var(--color-text);
	margin: 0 0 var(--space-6);
}

.two-col-text__body p:last-child {
	margin-bottom: 0;
}

.two-col-text__body p:first-of-type::first-letter {
	font-family: var(--font-serif);
	font-size: 3em;
	font-weight: 300;
	float: left;
	line-height: 0.9;
	margin: 0.1em 0.1em 0 0;
	color: var(--color-accent);
}

@media (max-width: 768px) {
	.two-col-text {
		grid-template-columns: 1fr;
		gap: var(--space-8);
	}
}

/* ─── Lista de beneficios ─────────────────────────────────────────── */

.benefits {
	max-width: 1000px;
	margin-inline: auto;
}

.benefits__header {
	text-align: center;
	margin-bottom: var(--space-12);
}

.benefits__header .overline {
	color: var(--color-accent);
	margin-bottom: var(--space-3);
	display: block;
}

.benefits__header h2 {
	font-family: var(--font-serif);
	font-size: var(--text-3xl);
	font-weight: 300;
	letter-spacing: -0.02em;
	line-height: 1.1;
	margin: 0;
}

.benefits__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-8) var(--space-12);
}

.benefit-item {
	display: flex;
	gap: var(--space-4);
	align-items: flex-start;
}

.benefit-item svg {
	color: var(--color-accent);
	flex-shrink: 0;
	margin-top: 4px;
}

.benefit-item h4 {
	font-family: var(--font-sans);
	font-size: var(--text-base);
	font-weight: 600;
	letter-spacing: 0;
	text-transform: none;
	margin: 0 0 var(--space-2);
	color: var(--color-text);
}

.benefit-item p {
	font-size: 0.9375rem;
	color: var(--color-muted);
	line-height: 1.65;
	margin: 0;
}

@media (max-width: 768px) {
	.benefits__list {
		grid-template-columns: 1fr;
		gap: var(--space-6);
	}
}

/* ─── Contacto (grid info + mapa) ─────────────────────────────────── */

.contact-grid {
	display: grid;
	grid-template-columns: 1fr 1.2fr;
	gap: var(--space-12);
	align-items: start;
}

.contact-info h2 {
	font-family: var(--font-serif);
	font-size: var(--text-2xl);
	font-weight: 300;
	letter-spacing: -0.01em;
	margin: var(--space-3) 0 var(--space-8);
}

.contact-list {
	list-style: none;
	padding: 0;
	margin: 0 0 var(--space-8);
	display: flex;
	flex-direction: column;
	gap: var(--space-6);
}

.contact-list li {
	display: flex;
	gap: var(--space-4);
	align-items: flex-start;
}

.contact-list svg {
	color: var(--color-accent);
	flex-shrink: 0;
	margin-top: 2px;
}

.contact-list strong {
	display: block;
	font-family: var(--font-sans);
	font-size: var(--text-xs);
	font-weight: 600;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--color-muted);
	margin-bottom: var(--space-1);
}

.contact-list p {
	font-size: var(--text-base);
	color: var(--color-text);
	line-height: 1.6;
	margin: 0;
}

.contact-list a {
	color: inherit;
	text-decoration: none;
	border-bottom: 1px solid transparent;
	transition: border-color var(--transition-fast), color var(--transition-fast);
}

.contact-list a:hover {
	color: var(--color-accent);
	border-bottom-color: var(--color-accent);
}

.contact-actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
	margin-top: var(--space-6);
}

.contact-map {
	position: relative;
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}

.contact-map iframe {
	width: 100%;
	display: block;
	filter: grayscale(0.3) contrast(1.05);
}

.contact-map__cta {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	font-size: 0.875rem;
	color: var(--color-text-muted);
	text-decoration: none;
	border-bottom: 1px solid transparent;
	align-self: flex-start;
	padding-block: var(--space-1);
	transition: color 0.2s, border-color 0.2s;
}

.contact-map__cta:hover {
	color: var(--color-accent);
	border-bottom-color: var(--color-accent);
}

/* ─── Sección fachada del estudio ─────────────────────────────────────── */

.contact-facade {
	padding-block: var(--space-section);
	background-color: var(--color-off-white);
}

.contact-facade__media {
	position: relative;
	margin: 0;
	overflow: hidden;
}

.contact-facade__media img {
	display: block;
	width: 100%;
	height: auto;
	aspect-ratio: 16 / 10;
	object-fit: cover;
}

.contact-facade__caption {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	padding: var(--space-8) var(--space-10);
	background: linear-gradient(180deg, rgba(10, 10, 10, 0) 0%, rgba(10, 10, 10, 0.55) 60%, rgba(10, 10, 10, 0.75) 100%);
	color: var(--color-white);
}

.contact-facade__caption .overline {
	color: var(--color-accent-light);
	display: block;
	margin-bottom: var(--space-2);
}

.contact-facade__address {
	font-family: var(--font-serif);
	font-size: var(--text-2xl);
	font-weight: var(--weight-light);
	letter-spacing: var(--tracking-tight);
	line-height: 1.1;
	color: var(--color-white);
	margin: 0;
}

@media (max-width: 768px) {
	.contact-facade__media img {
		aspect-ratio: 4 / 5;
	}
	.contact-facade__caption {
		padding: var(--space-6);
	}
	.contact-facade__address {
		font-size: var(--text-xl);
	}
}

@media (max-width: 900px) {
	.contact-grid {
		grid-template-columns: 1fr;
		gap: var(--space-8);
	}
	.contact-map iframe {
		height: 380px !important;
	}
}

/* ─── Galería completa (masonry) ──────────────────────────────────── */

.gallery-full {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: var(--space-2);
}

.gallery-full figure {
	margin: 0;
	overflow: hidden;
	position: relative;
	background: var(--color-surface);
}

.gallery-full figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	aspect-ratio: 4 / 3;
	transition: transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94),
	            filter var(--transition);
	filter: brightness(0.95);
}

.gallery-full figure:hover img {
	transform: scale(1.05);
	filter: brightness(1);
}

/* ─── Contenido legal (una sola columna, texto corrido) ───────────── */

.container--narrow {
	max-width: 760px;
	margin-inline: auto;
}

.section--legal {
	padding: var(--space-24) 0;
}

.page-title {
	font-family: var(--font-serif);
	font-size: clamp(2rem, 4vw, 3rem);
	font-weight: 300;
	letter-spacing: -0.02em;
	line-height: 1.1;
	margin: 0 0 var(--space-12);
	padding-bottom: var(--space-6);
	border-bottom: 1px solid var(--color-border);
}

.legal-content h2 {
	font-family: var(--font-serif);
	font-size: var(--text-xl);
	font-weight: 400;
	letter-spacing: -0.01em;
	margin: var(--space-10) 0 var(--space-4);
	color: var(--color-text);
}

.legal-content h2:first-child {
	margin-top: 0;
}

.legal-content p {
	font-family: var(--font-sans);
	font-size: var(--text-base);
	line-height: 1.8;
	color: var(--color-text);
	margin: 0 0 var(--space-4);
}
