/* ═══════════════════════════════════════════════════════════════
   CAWDAL WEDDINGS — CSS Editorial v=20260407h
   Referente estético: Vogue Weddings · Style Me Pretty · Junebug
   Paleta: crema cálida · carbón · dorado champán
   Tipografía: Cormorant Garamond (titulares) + Lato Light (cuerpo)
═══════════════════════════════════════════════════════════════ */

/* ─── GOOGLE FONTS ────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400;1,500&family=Lato:wght@300;400&family=Montserrat:wght@300;400;500&display=swap');

/* ─── RESET ───────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  background: #FAF8F5;
  color: #1C1C1C;
  font-family: 'Lato', 'Helvetica Neue', Arial, sans-serif;
  font-weight: 300;
  line-height: 1.8;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }
ul, ol { list-style: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }

/* ─── VARIABLES ───────────────────────────────────────────────── */
:root {
  /* Colores */
  --cream:     #FAF8F5;
  --cream2:    #F4EFE8;
  --cream3:    #EDE5DC;
  --parchment: #E6DDD2;
  --carbon:    #1C1C1C;
  --carbon2:   #3A3633;
  --muted:     #9B9390;
  --muted2:    #B8B2AC;
  --gold:      #C9A96E;
  --gold2:     #A8894E;
  --gold-pale: #E8D9C0;
  --gold-faint:#F5EDD8;
  --white:     #FFFFFF;
  /* Bordes */
  --border:    rgba(201,169,110,0.22);
  --border-s:  rgba(28,28,28,0.07);
  /* Tipografías */
  --font-serif: 'Cormorant Garamond', 'Garamond', Georgia, 'Times New Roman', serif;
  --font-sans:  'Lato', 'Helvetica Neue', Arial, sans-serif;
  --font-ui:    'Montserrat', 'Helvetica Neue', Arial, sans-serif;
  /* Layout */
  --nav-h:     80px;
  --topbar-h:  42px;
  /* Transiciones */
  --trans:      0.55s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --trans-fast: 0.28s ease;
}

/* ─── TIPOGRAFÍA BASE ────────────────────────────────────────── */
h1, h2, h3, h4 {
  font-family: var(--font-serif);
  font-weight: 300;
  line-height: 1.12;
  letter-spacing: 0.02em;
  color: var(--carbon);
}
h1 { font-size: clamp(2.8rem, 5.5vw, 5.2rem); }
h2 { font-size: clamp(2.2rem, 4vw, 3.8rem); }
h3 { font-size: clamp(1.5rem, 2.5vw, 2.4rem); }

/* Etiqueta de sección — estilo Vogue */
.label {
  font-family: var(--font-ui);
  font-size: 0.60rem;
  font-weight: 400;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: var(--gold);
  display: block;
}

/* ─── DIVISORES DORADOS ──────────────────────────────────────── */
/* Divisor centrado con líneas */
.divider {
  display: flex;
  align-items: center;
  gap: 18px;
  margin: 0 auto;
  width: fit-content;
}
.divider::before, .divider::after {
  content: '';
  display: block;
  width: 48px;
  height: 1px;
  background: var(--gold);
  opacity: 0.55;
}

/* Línea decorativa vertical */
.divider-v {
  width: 1px;
  height: 64px;
  background: linear-gradient(to bottom, transparent, var(--gold) 50%, transparent);
  display: block;
  margin: 0 auto;
  opacity: 0.7;
}

/* Línea decorativa horizontal */
.divider-h {
  width: 100%;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--border), transparent);
  display: block;
  margin: 0;
}

/* Separador de sección (línea gold horizontal larga) */
.section-sep {
  display: block;
  width: 72px;
  height: 1px;
  background: var(--gold);
  margin: 24px auto;
  opacity: 0.5;
}

/* ─── BOTONES ────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 15px 40px;
  font-family: var(--font-ui);
  font-size: 0.62rem;
  font-weight: 400;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  transition: var(--trans);
  cursor: pointer;
  position: relative;
}

.btn-dark {
  background: var(--carbon);
  color: var(--cream);
  border: 1px solid var(--carbon);
}
.btn-dark:hover {
  background: transparent;
  color: var(--carbon);
  transform: translateY(-2px);
}

.btn-outline {
  background: transparent;
  color: var(--carbon);
  border: 1px solid rgba(28,28,28,0.35);
}
.btn-outline:hover {
  background: var(--carbon);
  color: var(--cream);
  border-color: var(--carbon);
  transform: translateY(-2px);
}

.btn-outline-gold {
  background: transparent;
  color: var(--gold);
  border: 1px solid var(--gold);
}
.btn-outline-gold:hover {
  background: var(--gold);
  color: var(--white);
  transform: translateY(-2px);
}

/* Alias de compatibilidad */
.btn-gold {
  background: var(--carbon);
  color: var(--cream);
  border: 1px solid var(--carbon);
}
.btn-gold:hover {
  background: transparent;
  color: var(--carbon);
  transform: translateY(-2px);
}

/* ─── TOPBAR ─────────────────────────────────────────────────── */
#topbar {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 200;
  height: var(--topbar-h);
  background: var(--carbon2);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 52px 0 16px;
  transition: transform 0.35s, opacity 0.35s;
}
.topbar-text {
  font-family: var(--font-ui);
  font-size: 0.60rem;
  font-weight: 400;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: rgba(250,248,245,0.85);
}
#topbarClose {
  position: absolute;
  right: 20px; top: 50%;
  transform: translateY(-50%);
  color: rgba(255,255,255,0.45);
  font-size: 1.1rem;
  transition: color 0.2s;
  padding: 8px;
}
#topbarClose:hover { color: rgba(255,255,255,0.85); }

/* ─── NAVBAR ─────────────────────────────────────────────────── */
#mainNav {
  position: fixed;
  left: 0; right: 0;
  z-index: 100;
  top: var(--topbar-h);
  height: var(--nav-h);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 64px;
  transition: background var(--trans-fast), backdrop-filter var(--trans-fast),
              box-shadow var(--trans-fast), top 0.3s;
}
#mainNav.scrolled {
  background: rgba(250,248,245,0.97);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  box-shadow: 0 1px 0 var(--border-s);
}

.nav-logo {
  font-family: var(--font-serif);
  font-size: 1.55rem;
  font-weight: 300;
  letter-spacing: 0.42em;
  color: var(--carbon);
  text-transform: uppercase;
  transition: opacity var(--trans-fast);
}
.nav-logo:hover { opacity: 0.65; }

#navMenu {
  display: flex;
  align-items: center;
  gap: 48px;
}

.nav-link {
  font-family: var(--font-ui);
  font-size: 0.60rem;
  font-weight: 400;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--carbon2);
  position: relative;
  transition: color var(--trans-fast);
  padding-bottom: 3px;
}
.nav-link::after {
  content: '';
  position: absolute;
  bottom: -1px; left: 0;
  width: 0; height: 1px;
  background: var(--gold);
  transition: width 0.4s ease;
}
.nav-link:hover, .nav-link.active { color: var(--carbon); }
.nav-link:hover::after, .nav-link.active::after { width: 100%; }

.nav-cta {
  font-family: var(--font-ui);
  font-size: 0.60rem;
  font-weight: 400;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--carbon);
  border-bottom: 1px solid var(--gold);
  padding-bottom: 2px;
  transition: color var(--trans-fast), border-color var(--trans-fast);
}
.nav-cta:hover { color: var(--gold); }

/* Hamburger */
#navBurger {
  display: none;
  flex-direction: column;
  gap: 6px;
  padding: 8px;
}
#navBurger span {
  display: block;
  width: 22px;
  height: 1px;
  background: var(--carbon);
  transition: var(--trans);
}
#navBurger.active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
#navBurger.active span:nth-child(2) { opacity: 0; }
#navBurger.active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ─── HERO — FULL SCREEN ─────────────────────────────────────── */
#hero {
  position: relative;
  height: 100vh;
  min-height: 680px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  /* Fallback oscuro mientras carga; JS inyecta hero_thumb encima */
  background-color: var(--carbon);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.hero-video-wrap {
  position: absolute;
  inset: 0;
  overflow: hidden;
}

/* ── iframe YouTube ── */
.hero-video-wrap iframe {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 100vw;
  height: 56.25vw;
  min-height: 100vh;
  min-width: 177.78vh;
  pointer-events: none;
  border: none;
}

/* ── <video> nativo (MP4/WebM alojado en servidor) ──
   display:block por defecto — el <source> está en el HTML directamente
   (igual que camdalcrea.com). content-loader sólo lo actualiza si cambia. */
.hero-video-wrap video {
  display: block;
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  /* Cubre todo el hero manteniendo ratio */
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
  object-fit: cover;
  pointer-events: none;
}

/* Overlay cinematográfico suave */
.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(28,28,28,0.18) 0%,
    rgba(28,28,28,0.10) 30%,
    rgba(28,28,28,0.45) 70%,
    rgba(28,28,28,0.82) 100%
  );
}

#heroContent {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 0 40px;
  max-width: 900px;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 2s ease, transform 2s ease;
}
#heroContent.hero-content-visible {
  opacity: 1;
  transform: translateY(0);
}

.hero-en-text {
  font-family: var(--font-serif);
  font-size: 0.85rem;
  letter-spacing: 0.42em;
  text-transform: uppercase;
  color: var(--gold-pale);
  margin-bottom: 28px;
  display: block;
  opacity: 0.9;
}

#heroH1 {
  font-family: var(--font-serif);
  font-size: clamp(2.8rem, 5.5vw, 5rem);
  font-weight: 300;
  color: #FDFAF5;
  margin-bottom: 24px;
  line-height: 1.12;
  letter-spacing: 0.03em;
}

#heroSub {
  font-family: var(--font-serif);
  font-size: clamp(1.05rem, 1.7vw, 1.25rem);
  color: rgba(253,250,245,0.75);
  margin-bottom: 52px;
  font-style: italic;
  font-weight: 300;
  line-height: 1.7;
}

.hero-ctas {
  display: flex;
  gap: 20px;
  justify-content: center;
  flex-wrap: wrap;
}

/* CTAs sobre fondo oscuro del hero */
#hero .btn-dark {
  background: rgba(253,250,245,0.92);
  color: var(--carbon);
  border-color: rgba(253,250,245,0.92);
}
#hero .btn-dark:hover {
  background: var(--white);
  border-color: var(--white);
  color: var(--carbon);
  transform: translateY(-3px);
}
#hero .btn-outline {
  background: transparent;
  border: 1px solid rgba(253,250,245,0.45);
  color: rgba(253,250,245,0.9);
}
#hero .btn-outline:hover {
  background: rgba(253,250,245,0.10);
  border-color: rgba(253,250,245,0.8);
  color: #FDFAF5;
  transform: translateY(-3px);
}

/* Indicador de scroll */
.hero-scroll {
  position: absolute;
  bottom: 40px; left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  color: rgba(253,250,245,0.45);
  font-family: var(--font-ui);
  font-size: 0.50rem;
  letter-spacing: 0.38em;
  text-transform: uppercase;
}
.hero-scroll-line {
  width: 1px;
  height: 52px;
  background: linear-gradient(to bottom, rgba(201,169,110,0.85), transparent);
  animation: scrollLine 2.8s ease-in-out infinite;
}
@keyframes scrollLine {
  0%   { transform: scaleY(0); transform-origin: top; }
  50%  { transform: scaleY(1); transform-origin: top; opacity: 1; }
  51%  { transform: scaleY(1); transform-origin: bottom; }
  100% { transform: scaleY(0); transform-origin: bottom; opacity: 0.3; }
}

/* ─── PAGE HERO — páginas interiores ─────────────────────────── */
.page-hero {
  padding-top: calc(var(--topbar-h) + var(--nav-h) + 88px);
  padding-bottom: 88px;
  text-align: center;
  background: var(--cream2);
  position: relative;
  overflow: hidden;
}

/* Imagen de fondo opcional en page-hero */
.page-hero.has-bg {
  background-size: cover;
  background-position: center;
}
.page-hero.has-bg::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(250,248,245,0.88);
}
.page-hero.has-bg .container { position: relative; z-index: 1; }

/* Línea decorativa inferior */
.page-hero::after {
  content: '';
  position: absolute;
  bottom: 0; left: 50%;
  transform: translateX(-50%);
  width: 1px;
  height: 56px;
  background: linear-gradient(to bottom, var(--gold) 0%, transparent 100%);
  opacity: 0.55;
}

#pageHeroLabel {
  font-family: var(--font-ui);
  font-size: 0.60rem;
  letter-spacing: 0.38em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 22px;
  display: block;
}

#pageHeroH1 {
  font-family: var(--font-serif);
  font-size: clamp(2.4rem, 4.5vw, 4.4rem);
  font-weight: 300;
  color: var(--carbon);
  margin-bottom: 22px;
  max-width: 720px;
  margin-left: auto; margin-right: auto;
  line-height: 1.1;
}

#pageHeroDesc {
  font-family: var(--font-serif);
  font-size: 1.05rem;
  color: var(--muted);
  max-width: 500px;
  margin: 0 auto;
  font-style: italic;
  line-height: 1.75;
}

/* ─── SECCIONES GENERALES ────────────────────────────────────── */
.section {
  padding: 120px 0;
}
.section-sm { padding: 72px 0; }
.section-cream  { background: var(--cream); }
.section-cream2 { background: var(--cream2); }
.section-cream3 { background: var(--cream3); }
.section-white  { background: var(--white); }
.section-parchment { background: var(--parchment); }

/* Línea dorada separadora entre secciones */
.section + .section::before,
section + section.section-sep-top::before {
  display: none; /* usamos divider-h como elemento HTML en su lugar */
}

.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 64px;
}
.container-wide {
  max-width: 1480px;
  margin: 0 auto;
  padding: 0 64px;
}
.container-narrow {
  max-width: 800px;
  margin: 0 auto;
  padding: 0 64px;
}

/* ─── CABECERA DE SECCIÓN — Estilo editorial ─────────────────── */
.section-header {
  text-align: center;
  margin-bottom: 80px;
}
.section-header .label { margin-bottom: 22px; }
.section-header h2 {
  margin-bottom: 0;
  margin-top: 6px;
}
.section-header .section-sep { margin-top: 28px; margin-bottom: 28px; }
.section-header p {
  font-size: 1.02rem;
  color: var(--muted);
  max-width: 500px;
  margin: 0 auto;
  font-style: italic;
  line-height: 1.85;
}

/* ─── MÉTRICAS ───────────────────────────────────────────────── */
#metricsGrid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  background: var(--cream2);
  border-top: 1px solid var(--border-s);
  border-bottom: 1px solid var(--border-s);
}
.metric-item {
  padding: 60px 32px;
  text-align: center;
  border-right: 1px solid var(--border-s);
}
.metric-item:last-child { border-right: none; }
.metric-value {
  display: block;
  font-family: var(--font-serif);
  font-size: clamp(3rem, 5vw, 4.8rem);
  font-weight: 300;
  color: var(--carbon);
  line-height: 1;
  margin-bottom: 12px;
  letter-spacing: -0.01em;
}
.metric-label {
  display: block;
  font-family: var(--font-ui);
  font-size: 0.58rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--muted);
}

/* ─── MANIFIESTO ─────────────────────────────────────────────── */
.manifiesto-wrap {
  max-width: 760px;
  margin: 0 auto;
  text-align: center;
  padding: 112px 64px;
}
#manifiestoTitulo {
  font-family: var(--font-serif);
  font-size: clamp(3rem, 5.5vw, 5.4rem);
  font-weight: 300;
  color: var(--carbon);
  line-height: 1.08;
  margin-bottom: 6px;
  letter-spacing: 0.01em;
}
#manifiestoSub {
  font-family: var(--font-serif);
  font-size: clamp(2.4rem, 4.5vw, 4.4rem);
  font-weight: 300;
  color: var(--gold);
  margin-bottom: 0;
  font-style: italic;
  letter-spacing: 0.01em;
}
.manifiesto-divider {
  width: 1px;
  height: 72px;
  background: linear-gradient(to bottom, transparent, var(--gold) 50%, transparent);
  display: block;
  margin: 52px auto;
  opacity: 0.65;
}
#manifiestoTexto p {
  font-size: 1.05rem;
  color: var(--carbon2);
  margin-bottom: 22px;
  line-height: 1.95;
  font-weight: 300;
}
#manifiestoTexto p:last-child { margin-bottom: 0; }

/* ─── MOSAICO GALERÍA — HOME ─────────────────────────────────── */
#trabajosHomeGrid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: 200px;
  gap: 8px;
}

/* Mosaico asimétrico editorial */
.mosaic-item {
  position: relative;
  background-size: cover;
  background-position: center;
  cursor: pointer;
  overflow: hidden;
}
/* Variantes */
.mosaic-large  { grid-column: span 8; grid-row: span 2; } /* 2/3 ancho, doble alto */
.mosaic-tall   { grid-column: span 4; grid-row: span 3; } /* 1/3 ancho, triple alto */
.mosaic-normal { grid-column: span 4; grid-row: span 2; }
.mosaic-wide   { grid-column: span 8; grid-row: span 2; }

/* Hover overlay con info */
.mosaic-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(28,28,28,0.86) 0%, rgba(28,28,28,0) 52%);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-start;
  padding: 28px 28px 24px;
  opacity: 0;
  transition: opacity 0.55s ease;
}
.mosaic-item:hover .mosaic-overlay { opacity: 1; }

.mosaic-play {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%) scale(0.8);
  width: 60px; height: 60px;
  border-radius: 50%;
  background: rgba(250,248,245,0.88);
  display: flex; align-items: center; justify-content: center;
  color: var(--carbon);
  transition: transform 0.55s ease, opacity 0.55s ease;
  opacity: 0;
}
.mosaic-play svg { width: 20px; height: 20px; margin-left: 3px; }
.mosaic-item:hover .mosaic-play {
  transform: translate(-50%, -50%) scale(1);
  opacity: 1;
}

.mosaic-info h3 {
  font-family: var(--font-serif);
  font-size: 1.3rem;
  font-weight: 300;
  color: #FDFAF5;
  margin-bottom: 4px;
  letter-spacing: 0.02em;
}
.mosaic-info p {
  font-family: var(--font-ui);
  font-size: 0.58rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold-pale);
}

/* ─── GRID TRABAJOS — página trabajos.html ───────────────────── */
#trabajosGrid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
  gap: 48px;
}
.trabajo-card {
  cursor: pointer;
  transition: transform 0.55s cubic-bezier(0.25,0.46,0.45,0.94);
  background: transparent;
}
.trabajo-card:hover { transform: translateY(-8px); }

.trabajo-thumb {
  position: relative;
  aspect-ratio: 4/3;
  background-size: cover;
  background-position: center;
  overflow: hidden;
  margin-bottom: 24px;
}
.trabajo-overlay {
  position: absolute;
  inset: 0;
  background: rgba(28,28,28,0.35);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.4s ease;
}
.trabajo-card:hover .trabajo-overlay { opacity: 1; }
.trabajo-play {
  width: 64px; height: 64px;
  border-radius: 50%;
  background: rgba(250,248,245,0.9);
  display: flex; align-items: center; justify-content: center;
  color: var(--carbon);
}
.trabajo-play svg { width: 22px; height: 22px; margin-left: 3px; }

.trabajo-badge {
  position: absolute;
  top: 16px; left: 16px;
  background: var(--cream);
  color: var(--carbon);
  font-family: var(--font-ui);
  font-size: 0.52rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  font-weight: 500;
  padding: 6px 14px;
}

.trabajo-info { text-align: center; padding: 0 8px; }
.trabajo-title {
  font-family: var(--font-serif);
  font-size: 1.7rem;
  font-weight: 300;
  color: var(--carbon);
  margin-bottom: 8px;
  letter-spacing: 0.01em;
}
.trabajo-meta {
  font-family: var(--font-ui);
  font-size: 0.58rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 12px;
}
.trabajo-desc {
  font-size: 0.88rem;
  color: var(--muted);
  line-height: 1.75;
  font-style: italic;
}

/* ─── MODAL ──────────────────────────────────────────────────── */
.modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 1000;
  background: rgba(28,28,28,0.90);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 40px;
  opacity: 0;
  transition: opacity 0.45s ease;
  overflow-y: auto;
}
.modal-overlay.modal-visible { opacity: 1; }
.modal-inner {
  position: relative;
  width: 100%;
  max-width: 900px;
  background: var(--cream);
}
.modal-close {
  position: absolute;
  top: 16px; right: 16px;
  z-index: 10;
  width: 40px; height: 40px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(28,28,28,0.55);
  color: var(--cream);
  font-size: 1.4rem;
  border-radius: 50%;
  transition: background var(--trans-fast);
}
.modal-close:hover { background: var(--carbon); }
.modal-video-wrap {
  position: relative;
  aspect-ratio: 16/9;
  background: var(--carbon);
}
.modal-video-wrap iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: none; }
.modal-body { padding: 52px 56px; text-align: center; }
.modal-title {
  font-family: var(--font-serif);
  font-size: 2.6rem;
  font-weight: 300;
  color: var(--carbon);
  margin-bottom: 10px;
}
.modal-meta {
  font-family: var(--font-ui);
  font-size: 0.60rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 24px;
}
.modal-desc {
  font-size: 0.95rem;
  color: var(--carbon2);
  line-height: 1.9;
  margin-bottom: 28px;
  font-style: italic;
}
.modal-result {
  font-family: var(--font-serif);
  font-size: 1.25rem;
  font-style: italic;
  color: var(--carbon2);
  margin-bottom: 40px;
  padding: 0 40px;
  line-height: 1.65;
}
.modal-result::before { content: '\201C'; color: var(--gold); margin-right: 2px; }
.modal-result::after  { content: '\201D'; color: var(--gold); margin-left: 2px; }

/* ─── SERVICIOS — página ─────────────────────────────────────── */
#serviciosGrid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
}
.servicio-card {
  background: var(--cream);
  padding: 72px 56px;
  border: 1px solid var(--border-s);
  position: relative;
  transition: background var(--trans-fast);
}
.servicio-card:hover { background: var(--white); }

/* Línea dorada top al hacer hover */
.servicio-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(to right, transparent, var(--gold), transparent);
  opacity: 0;
  transition: opacity 0.55s ease;
}
.servicio-card:hover::before { opacity: 1; }

.servicio-subtitle {
  display: block;
  font-family: var(--font-ui);
  font-size: 0.58rem;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 16px;
}
.servicio-title {
  font-family: var(--font-serif);
  font-size: clamp(2rem, 3vw, 3rem);
  font-weight: 300;
  color: var(--carbon);
  margin-bottom: 8px;
  line-height: 1.1;
}
.servicio-price {
  font-family: var(--font-ui);
  font-size: 0.70rem;
  color: var(--muted);
  letter-spacing: 0.08em;
  margin-bottom: 44px;
  padding-bottom: 36px;
  border-bottom: 1px solid var(--border-s);
}
.servicio-desc p {
  font-size: 0.92rem;
  color: var(--carbon2);
  margin-bottom: 18px;
  line-height: 1.95;
}
.servicio-deliverables { margin: 32px 0 40px; }
.servicio-deliverables li {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  font-size: 0.88rem;
  color: var(--carbon2);
  padding: 10px 0;
  border-bottom: 1px solid var(--border-s);
  font-weight: 300;
  line-height: 1.55;
}
.servicio-deliverables .check { color: var(--gold); font-size: 0.68rem; flex-shrink: 0; margin-top: 4px; }
.servicio-ref {
  font-family: var(--font-serif);
  font-size: 1.02rem;
  font-style: italic;
  color: var(--gold2);
  margin-bottom: 40px;
  line-height: 1.55;
}

/* Servicios HOME — lista editorial */
#serviciosHomeGrid { display: flex; flex-direction: column; }
.servicio-home-item {
  display: grid;
  grid-template-columns: 80px 1fr auto;
  align-items: center;
  gap: 44px;
  padding: 44px 0;
  border-bottom: 1px solid var(--border-s);
  transition: padding-left var(--trans-fast);
  cursor: default;
}
.servicio-home-item:first-child { border-top: 1px solid var(--border-s); }
.servicio-home-item:hover { padding-left: 8px; }

.servicio-home-num {
  font-family: var(--font-serif);
  font-size: 4rem;
  font-weight: 300;
  color: var(--parchment);
  line-height: 1;
  user-select: none;
}
.servicio-home-title {
  font-family: var(--font-serif);
  font-size: 2rem;
  font-weight: 300;
  color: var(--carbon);
  margin-bottom: 5px;
  letter-spacing: 0.01em;
}
.servicio-home-sub {
  font-size: 0.82rem;
  color: var(--muted);
  font-style: italic;
  line-height: 1.55;
}
.servicio-home-price {
  font-family: var(--font-ui);
  font-size: 0.63rem;
  color: var(--gold);
  margin-top: 8px;
  letter-spacing: 0.10em;
}
.servicio-home-arrow {
  font-family: var(--font-serif);
  font-size: 1.8rem;
  color: var(--muted2);
  transition: color var(--trans-fast), transform var(--trans-fast);
  flex-shrink: 0;
}
.servicio-home-item:hover .servicio-home-arrow {
  color: var(--gold);
  transform: translateX(8px);
}

/* ─── EXTRAS ─────────────────────────────────────────────────── */
#extrasGrid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
  gap: 0;
  border-top: 1px solid var(--border-s);
  border-left: 1px solid var(--border-s);
  margin-top: 64px;
}
.extra-item {
  background: var(--cream);
  padding: 36px 32px;
  border-right: 1px solid var(--border-s);
  border-bottom: 1px solid var(--border-s);
  text-align: center;
  transition: background var(--trans-fast);
}
.extra-item:hover { background: var(--white); }
.extra-title {
  font-family: var(--font-serif);
  font-size: 1.25rem;
  font-weight: 300;
  color: var(--carbon);
  margin-bottom: 8px;
}
.extra-desc { font-size: 0.82rem; color: var(--muted); margin-bottom: 16px; font-style: italic; line-height: 1.65; }
.extra-price { font-family: var(--font-ui); font-size: 0.70rem; color: var(--gold); font-weight: 500; letter-spacing: 0.12em; }

/* ─── TESTIMONIOS — EDITORIAL ────────────────────────────────── */
#testimoniosGrid {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
  max-width: 680px;
  margin: 0 auto;
}

.testimonio-item {
  text-align: center;
  padding: 72px 40px;
  border-bottom: 1px solid var(--border-s);
  width: 100%;
  position: relative;
}
.testimonio-item:last-child { border-bottom: none; }

/* Comillas decorativas grandes */
.testimonio-item::before {
  content: '\201C';
  position: absolute;
  top: 40px; left: 50%;
  transform: translateX(-50%);
  font-family: var(--font-serif);
  font-size: 5rem;
  font-weight: 300;
  color: var(--gold-faint);
  line-height: 1;
  pointer-events: none;
  user-select: none;
}

.testimonio-stars {
  font-size: 0.70rem;
  letter-spacing: 0.3em;
  color: var(--gold);
  margin-bottom: 32px;
  display: block;
  padding-top: 32px; /* espacio para la comilla decorativa */
}

.testimonio-text {
  font-family: var(--font-serif);
  font-size: clamp(1.35rem, 2.2vw, 1.9rem);
  font-style: italic;
  font-weight: 300;
  color: var(--carbon);
  line-height: 1.6;
  margin-bottom: 32px;
}

.testimonio-footer {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
}
.testimonio-author {
  font-family: var(--font-ui);
  font-size: 0.62rem;
  font-weight: 500;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--carbon);
}
.testimonio-role {
  font-family: var(--font-ui);
  font-size: 0.60rem;
  letter-spacing: 0.16em;
  color: var(--gold);
  text-transform: uppercase;
}

/* ─── LOGOS / FINCAS ─────────────────────────────────────────── */
#logosGrid {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  justify-content: center;
  align-items: center;
  padding: 48px 0 16px;
}
.logo-item {
  padding: 16px 28px;
  border: 1px solid var(--border-s);
  transition: border-color var(--trans-fast), transform var(--trans-fast);
}
.logo-item:hover { border-color: var(--border); transform: translateY(-3px); }
.logo-item img { height: 32px; width: auto; filter: grayscale(1) opacity(0.55); transition: filter var(--trans-fast); }
.logo-item:hover img { filter: grayscale(0.5) opacity(0.75); }
.logo-text {
  font-family: var(--font-ui);
  font-size: 0.60rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--muted);
}
#fincasLista {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  margin-top: 40px;
}
.finca-tag {
  padding: 11px 24px;
  border: 1px solid var(--border-s);
  font-family: var(--font-ui);
  font-size: 0.60rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--muted);
  transition: border-color var(--trans-fast), color var(--trans-fast), background var(--trans-fast);
  cursor: default;
}
.finca-tag:hover {
  border-color: var(--border);
  color: var(--carbon);
  background: var(--gold-faint);
}

/* ─── NOSOTROS ───────────────────────────────────────────────── */
.nosotros-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 104px;
  align-items: start;
}
#nosotrosIntro {
  font-family: var(--font-serif);
  font-size: clamp(1.7rem, 2.8vw, 2.5rem);
  font-weight: 300;
  color: var(--carbon);
  line-height: 1.42;
  margin-bottom: 40px;
  font-style: italic;
}
#nosotrosTexto p {
  font-size: 1.02rem;
  color: var(--carbon2);
  margin-bottom: 24px;
  line-height: 1.95;
  font-weight: 300;
}
.nosotros-firma {
  margin-top: 48px;
  padding-top: 36px;
  border-top: 1px solid var(--border-s);
}
#nosotrosNombre {
  font-family: var(--font-serif);
  font-size: 2.2rem;
  font-weight: 300;
  color: var(--carbon);
  margin-bottom: 5px;
  letter-spacing: 0.02em;
}
#nosotrosRol {
  font-family: var(--font-ui);
  font-size: 0.60rem;
  color: var(--gold);
  letter-spacing: 0.26em;
  text-transform: uppercase;
}
.nosotros-equipo {
  background: var(--cream2);
  padding: 48px;
  border-top: 2px solid var(--gold);
}
#nosotrosEquipoTitulo {
  font-family: var(--font-serif);
  font-size: 1.5rem;
  font-weight: 300;
  color: var(--carbon);
  margin-bottom: 18px;
}
#nosotrosEquipoTexto {
  font-size: 0.88rem;
  color: var(--muted);
  line-height: 2;
  font-style: italic;
}

/* Valores */
.valores-list { display: flex; flex-direction: column; margin-top: 44px; }
.valor-item {
  display: flex;
  align-items: flex-start;
  gap: 22px;
  padding: 30px 0;
  border-bottom: 1px solid var(--border-s);
}
.valor-item:first-child { border-top: 1px solid var(--border-s); }
.valor-icon { font-size: 1.35rem; flex-shrink: 0; margin-top: 3px; opacity: 0.85; }
.valor-titulo {
  font-family: var(--font-serif);
  font-size: 1.25rem;
  font-weight: 300;
  color: var(--carbon);
  margin-bottom: 7px;
}
.valor-desc { font-size: 0.85rem; color: var(--muted); line-height: 1.85; font-style: italic; }

/* ─── CONTACTO ───────────────────────────────────────────────── */
.contacto-layout {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: 96px;
  align-items: start;
}
.contacto-info { padding-top: 8px; }

.contacto-escasez {
  font-family: var(--font-serif);
  font-size: 1.05rem;
  font-style: italic;
  color: var(--carbon2);
  border-left: 2px solid var(--gold);
  padding-left: 22px;
  margin: 40px 0;
  line-height: 1.75;
}
.contacto-detalle {
  display: flex;
  flex-direction: column;
  gap: 18px;
  margin-top: 36px;
}
.contacto-detalle a, .contacto-detalle span {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 0.88rem;
  color: var(--muted);
  transition: color var(--trans-fast);
}
.contacto-detalle a:hover { color: var(--carbon); }
.contacto-icon { font-size: 1rem; flex-shrink: 0; }

/* Formulario */
.form-wrap {
  background: var(--white);
  padding: 60px 56px;
  border-top: 2px solid var(--gold);
  box-shadow: 0 2px 40px rgba(28,28,28,0.04);
}
.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
}
.form-group { display: flex; flex-direction: column; gap: 10px; margin-bottom: 28px; }
.form-group label {
  font-family: var(--font-ui);
  font-size: 0.58rem;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 400;
}
.form-group input,
.form-group select,
.form-group textarea {
  background: transparent;
  border: none;
  border-bottom: 1px solid rgba(28,28,28,0.12);
  color: var(--carbon);
  font-family: var(--font-sans);
  font-size: 0.95rem;
  font-weight: 300;
  padding: 12px 0;
  transition: border-color var(--trans-fast);
  width: 100%;
  outline: none;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-bottom-color: var(--gold);
}
.form-group select { cursor: pointer; }
.form-group select option { background: var(--white); color: var(--carbon); }
.form-group textarea { resize: none; min-height: 110px; line-height: 1.7; }

.form-submit {
  width: 100%;
  padding: 18px;
  background: var(--carbon);
  color: var(--cream);
  font-family: var(--font-ui);
  font-size: 0.60rem;
  font-weight: 400;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  cursor: pointer;
  border: 1px solid var(--carbon);
  transition: var(--trans-fast);
  margin-top: 8px;
}
.form-submit:hover { background: transparent; color: var(--carbon); }
.form-submit:disabled { opacity: 0.45; cursor: not-allowed; }

#formSuccess { display: none; text-align: center; padding: 72px 40px; }
#formSuccess .success-icon { font-size: 2.4rem; margin-bottom: 24px; }
#formSuccess h3 {
  font-family: var(--font-serif);
  font-size: 2.4rem;
  font-weight: 300;
  color: var(--carbon);
  margin-bottom: 14px;
}
#formSuccess p { font-size: 0.92rem; color: var(--muted); font-style: italic; line-height: 1.8; }

/* Mini quotes contacto */
.mini-quote {
  border-left: 1px solid var(--gold);
  padding-left: 20px;
  margin-bottom: 24px;
}
.mini-quote p {
  font-family: var(--font-serif);
  font-size: 1.02rem;
  font-style: italic;
  color: var(--carbon2);
  margin-bottom: 5px;
  line-height: 1.62;
}
.mini-quote span {
  font-family: var(--font-ui);
  font-size: 0.58rem;
  color: var(--gold);
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

/* ─── CTA FINAL ──────────────────────────────────────────────── */
.cta-final {
  text-align: center;
  padding: 140px 64px;
  background: var(--cream2);
  position: relative;
}
.cta-final::before {
  content: '';
  position: absolute;
  top: 0; left: 50%;
  transform: translateX(-50%);
  width: 1px;
  height: 80px;
  background: linear-gradient(to bottom, transparent, var(--gold));
  opacity: 0.55;
}
#ctaFinalTitulo {
  font-family: var(--font-serif);
  font-size: clamp(2.4rem, 4.5vw, 4.2rem);
  font-weight: 300;
  color: var(--carbon);
  margin-bottom: 18px;
  line-height: 1.12;
}
#ctaFinalSub {
  font-family: var(--font-serif);
  font-size: 1.05rem;
  color: var(--muted);
  font-style: italic;
  margin-bottom: 52px;
  line-height: 1.7;
}

/* ─── FOOTER ─────────────────────────────────────────────────── */
#footer {
  background: var(--carbon);
  padding: 80px 0 40px;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.8fr 1fr 1fr 1fr;
  gap: 52px;
  margin-bottom: 60px;
}
.footer-brand .footer-logo-text {
  font-family: var(--font-serif);
  font-size: 1.85rem;
  letter-spacing: 0.38em;
  color: var(--cream);
  font-weight: 300;
  text-transform: uppercase;
}
#footerDesc {
  font-size: 0.82rem;
  color: rgba(250,248,245,0.38);
  line-height: 1.95;
  margin-top: 18px;
  font-style: italic;
}
.footer-col h4 {
  font-family: var(--font-ui);
  font-size: 0.55rem;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 28px;
  font-weight: 400;
}
.footer-col a, .footer-col span {
  display: block;
  font-size: 0.82rem;
  color: rgba(250,248,245,0.40);
  margin-bottom: 11px;
  transition: color var(--trans-fast);
  font-weight: 300;
}
.footer-col a:hover { color: rgba(250,248,245,0.85); }
.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 30px;
  border-top: 1px solid rgba(201,169,110,0.18);
}
#footerCopy { font-size: 0.65rem; color: rgba(250,248,245,0.25); letter-spacing: 0.08em; }
.footer-social { display: flex; gap: 28px; }
.footer-social a {
  font-family: var(--font-ui);
  font-size: 0.55rem;
  color: rgba(250,248,245,0.35);
  letter-spacing: 0.24em;
  text-transform: uppercase;
  transition: color var(--trans-fast);
}
.footer-social a:hover { color: var(--gold); }

/* ─── WHATSAPP FLOTANTE ──────────────────────────────────────── */
#whatsappFloat {
  position: fixed;
  bottom: 36px; right: 36px;
  z-index: 90;
  width: 54px; height: 54px;
  border-radius: 50%;
  background: #25D366;
  color: #fff;
  display: none;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 28px rgba(37,211,102,0.32);
  transition: transform var(--trans-fast), box-shadow var(--trans-fast);
}
#whatsappFloat:hover {
  transform: scale(1.1);
  box-shadow: 0 8px 36px rgba(37,211,102,0.42);
}
#whatsappFloat svg { width: 27px; height: 27px; fill: currentColor; }

/* ─── SPINNER ────────────────────────────────────────────────── */
.loading-spinner {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 96px;
}
.loading-spinner::after {
  content: '';
  width: 24px; height: 24px;
  border: 1px solid var(--border-s);
  border-top-color: var(--gold);
  border-radius: 50%;
  animation: spin 1s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ─── REVEAL — animación fade-in ────────────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity 1.0s ease, transform 1.0s ease;
}
.reveal.revealed {
  opacity: 1;
  transform: translateY(0);
}

/* Variante para stagger */
.reveal-slow {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 1.4s ease, transform 1.4s ease;
}
.reveal-slow.revealed { opacity: 1; transform: translateY(0); }

/* ─── FAQ ────────────────────────────────────────────────────── */
.faq-list { display: flex; flex-direction: column; }
.faq-item {
  padding: 40px 0;
  border-bottom: 1px solid var(--border-s);
}
.faq-item:first-child { border-top: 1px solid var(--border-s); }
.faq-q {
  font-family: var(--font-serif);
  font-size: 1.5rem;
  font-weight: 300;
  color: var(--carbon);
  margin-bottom: 14px;
}
.faq-a { font-size: 0.92rem; color: var(--muted); line-height: 1.9; font-weight: 300; }

/* ─── RESPONSIVE ─────────────────────────────────────────────── */
@media (max-width: 1200px) {
  .container, .container-wide, .container-narrow { padding: 0 44px; }
  #mainNav { padding: 0 44px; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .nosotros-layout { gap: 64px; }
  .contacto-layout { gap: 64px; }
  #serviciosGrid { grid-template-columns: 1fr; }
}

@media (max-width: 1024px) {
  .nosotros-layout { grid-template-columns: 1fr; gap: 56px; }
  .contacto-layout { grid-template-columns: 1fr; gap: 52px; }
  #trabajosHomeGrid {
    grid-template-columns: repeat(6, 1fr);
    grid-auto-rows: 180px;
  }
  .mosaic-large { grid-column: span 4; grid-row: span 2; }
  .mosaic-tall  { grid-column: span 2; grid-row: span 3; }
  .mosaic-normal { grid-column: span 2; grid-row: span 2; }
  .mosaic-wide  { grid-column: span 4; grid-row: span 2; }
}

@media (max-width: 768px) {
  :root { --topbar-h: 36px; --nav-h: 64px; }
  .container, .container-wide, .container-narrow { padding: 0 24px; }
  #mainNav { padding: 0 24px; }
  .section { padding: 80px 0; }

  /* Mobile nav */
  #navMenu {
    position: fixed;
    top: calc(var(--topbar-h) + var(--nav-h));
    left: 0; right: 0; bottom: 0;
    background: rgba(250,248,245,0.98);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    flex-direction: column;
    justify-content: center;
    gap: 40px;
    transform: translateX(100%);
    transition: transform 0.5s cubic-bezier(0.25,0.46,0.45,0.94);
    z-index: 99;
  }
  #navMenu.nav-open { transform: translateX(0); }
  .nav-link { font-size: 0.85rem; letter-spacing: 0.16em; }
  .nav-cta { display: none; }
  #navBurger { display: flex; }

  /* Métricas 2 col */
  #metricsGrid { grid-template-columns: repeat(2, 1fr); }
  .metric-item { border-right: none; border-bottom: 1px solid var(--border-s); }
  .metric-item:nth-child(odd) { border-right: 1px solid var(--border-s); }

  /* Mosaico 1 col en mobile */
  #trabajosHomeGrid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-auto-rows: 180px;
    gap: 6px;
  }
  .mosaic-large  { grid-column: span 2; grid-row: span 2; }
  .mosaic-tall   { grid-column: span 1; grid-row: span 2; }
  .mosaic-normal { grid-column: span 1; grid-row: span 2; }
  .mosaic-wide   { grid-column: span 2; grid-row: span 1; }

  #trabajosGrid { grid-template-columns: 1fr; }

  /* Servicios home */
  .servicio-home-item { grid-template-columns: 56px 1fr auto; gap: 20px; padding: 32px 0; }
  .servicio-home-num { font-size: 2.8rem; }

  .footer-grid { grid-template-columns: 1fr; gap: 36px; }
  .footer-bottom { flex-direction: column; gap: 16px; text-align: center; }
  .form-row { grid-template-columns: 1fr; gap: 0; }
  .form-wrap { padding: 44px 28px; }
  .modal-body { padding: 36px 28px; }
  .manifiesto-wrap { padding: 80px 28px; }
  .cta-final { padding: 100px 28px; }
  .nosotros-equipo { padding: 36px; }
  .contacto-layout { gap: 48px; }
}

@media (max-width: 520px) {
  :root { --topbar-h: 0px; }
  #topbar { display: none !important; }
  .hero-ctas { flex-direction: column; align-items: center; }
  .btn { width: 100%; max-width: 320px; justify-content: center; }
  .section { padding: 64px 0; }
  #trabajosHomeGrid {
    grid-template-columns: 1fr;
    grid-auto-rows: 220px;
  }
  .mosaic-large, .mosaic-tall, .mosaic-normal, .mosaic-wide {
    grid-column: span 1; grid-row: span 1;
  }
}

/* ════════════════════════════════════════════════════════════════
   PARCHES CROSS-BROWSER & MOBILE — v=20260407h
   Sin duplicar media queries existentes. Solo añade lo que falta.
   ════════════════════════════════════════════════════════════════ */

/* ── Header sección "Nuestras historias" ───────────────────────── */
.trabajos-home-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 64px;
}
.trabajos-home-header-text .label { display: block; }
.trabajos-home-header-text h2 {
  margin-top: 14px;
  line-height: 1.08;
}
.trabajos-ver-todas {
  flex-shrink: 0;
  font-size: 0.58rem;
  white-space: nowrap;
}

/* ── Anti-overflow global ──────────────────────────────────────── */
html {
  overflow-x: hidden;
  max-width: 100vw;
  -webkit-overflow-scrolling: touch;
}
html, body { overflow-x: hidden; }
body > * { max-width: 100%; }

/* ── Touch & tap ──────────────────────────────────────────────── */
* { -webkit-tap-highlight-color: transparent; }
a, button { touch-action: manipulation; }

/* ── Scrollbar (Chrome/Edge/Opera) ────────────────────────────── */
::-webkit-scrollbar       { width: 5px; }
::-webkit-scrollbar-track { background: var(--cream2); }
::-webkit-scrollbar-thumb { background: rgba(201,169,110,0.35); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--gold); }

/* ── Text rendering headings ──────────────────────────────────── */
h1, h2, h3, h4 { text-rendering: optimizeLegibility; }

/* ── Modal: sin salto de página ──────────────────────────────── */
html.modal-open { overflow: hidden; }
.modal-overlay  { overscroll-behavior: contain; }

/* ── Logos: colores reales ────────────────────────────────────── */
.logo-item img {
  max-height: 40px;
  max-width: 130px;
  object-fit: contain;
  filter: none;
  opacity: 0.78;
  transition: opacity 0.3s ease;
}
.logo-item:hover img { opacity: 1; }

/* ── Safari: backdrop-filter fallback ────────────────────────── */
@supports not (backdrop-filter: blur(1px)) {
  #mainNav.scrolled { background: rgba(250,248,245,0.98) !important; }
}

/* ── Safari: aspect-ratio fallback ───────────────────────────── */
@supports not (aspect-ratio: 16/9) {
  .trabajo-thumb {
    height: 0; padding-bottom: 62.5%;
    position: relative; overflow: hidden;
  }
  .trabajo-thumb > * { position: absolute; inset: 0; width: 100%; height: 100%; }
  .modal-video-wrap {
    height: 0; padding-bottom: 56.25%;
    position: relative;
  }
  .modal-video-wrap iframe { position: absolute; inset: 0; width: 100%; height: 100%; }
}

/* ── iOS: evitar zoom en inputs — CRÍTICO ─────────────────────── */
input, textarea, select { font-size: 16px !important; }
@media (min-width: 769px) {
  input, textarea, select { font-size: inherit !important; }
}

/* ── iOS safe-area (notch / home bar) ─────────────────────────── */
@supports (padding: env(safe-area-inset-bottom)) {
  body { padding-bottom: env(safe-area-inset-bottom); }
  #whatsappFloat {
    bottom: calc(1.4rem + env(safe-area-inset-bottom));
    right:  max(1.4rem, env(safe-area-inset-right));
  }
}

/* ── iOS: fix position:fixed parpadeo ────────────────────────── */
#topbar, #mainNav {
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
}

/* ── iOS hero height — SOLO añade 100dvh sin romper 100vh base ── */
@supports (height: 100dvh) {
  #hero { height: 100dvh; min-height: 100dvh; }
}

/* ── Tap targets mínimos 44px (Apple HIG) ─────────────────────── */
@media (max-width: 768px) {
  .btn           { min-height: 44px; }
  #navBurger     { min-width: 44px; min-height: 44px; }
  #whatsappFloat { min-width: 50px; min-height: 50px; }
}

/* ════════════════════════════════════════════════════════════════
   CORRECCIONES MÓVIL (sobreescriben reglas base donde hace falta)
   ════════════════════════════════════════════════════════════════ */

@media (max-width: 768px) {

  /* ── Padding contenedores ─────────────────────────────────────── */
  .container,
  .container-wide,
  .container-narrow { padding-left: 20px !important; padding-right: 20px !important; }
  #mainNav           { padding-left: 20px !important; padding-right: 20px !important; }

  /* ── Secciones ────────────────────────────────────────────────── */
  .section           { padding-top: 72px; padding-bottom: 72px; }
  .section-header    { text-align: center; }

  /* ── Centrado global: TODOS los títulos y labels en móvil ──────── */
  .label             { text-align: center; }
  h2, h3             { text-align: center; }

  /* Excepciones: elementos donde NO centrar (listas, formularios) */
  .servicio-home-item h3,
  .trabajo-info h3,
  .testimonio-item h3,
  .footer-col h4,
  .nosotros-layout h2,
  .contacto-layout h2,
  .form-group label  { text-align: left; }

  /* ── Header "Nuestras historias" → columna centrada ───────────── */
  .trabajos-home-header {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 20px;
    margin-bottom: 36px;
  }
  .trabajos-home-header-text { text-align: center; }
  .trabajos-home-header-text h2 { text-align: center; }
  .trabajos-ver-todas {
    width: auto;
    white-space: nowrap;
    font-size: 0.60rem;
    padding: 12px 28px;
  }

  /* ── Tipografía ───────────────────────────────────────────────── */
  h1 { font-size: clamp(2rem, 8vw, 3rem); }
  h2 { font-size: clamp(1.7rem, 6.5vw, 2.6rem); }
  h3 { font-size: clamp(1.25rem, 4.5vw, 1.8rem); }
  p  { font-size: 0.95rem; }

  /* ── Hero ─────────────────────────────────────────────────────── */
  #hero {
    /* NO redefinir height: dejar el 100vh del CSS base
       Solo ajustamos padding y alineación del contenido */
    align-items: center;
    padding-top: 0;
    padding-bottom: 0;
  }
  #heroContent {
    padding-left: 24px;
    padding-right: 24px;
    text-align: center;
    max-width: 100%;
  }
  #heroH1 {
    font-size: clamp(2rem, 8vw, 3rem);
    line-height: 1.1;
    margin-bottom: 0.8rem;
  }
  #heroSub {
    font-size: 0.9rem;
    margin-bottom: 1.8rem;
  }
  .hero-en-text { font-size: 0.75rem; }
  .hero-ctas {
    flex-direction: column;
    align-items: center;
    gap: 12px;
  }
  .hero-ctas .btn {
    width: 100%;
    max-width: 300px;
    min-height: 48px;
    justify-content: center;
  }
  .hero-scroll { display: none; }

  /* ── Métricas ─────────────────────────────────────────────────── */
  #metricsGrid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  .metric-item {
    border-right: none !important;
    border-bottom: 1px solid var(--border-s);
    padding: 28px 16px;
  }
  .metric-item:nth-child(odd)  { border-right: 1px solid var(--border-s) !important; }
  .metric-item:nth-child(even) { border-right: none !important; }
  .metric-item:nth-last-child(-n+2) { border-bottom: none; }
  .metric-value { font-size: clamp(2rem, 9vw, 3rem); }
  .metric-label { font-size: 0.65rem; }

  /* ── Manifiesto ───────────────────────────────────────────────── */
  .manifiesto-wrap { padding: 72px 24px; }
  .manifiesto-wrap h2 { font-size: clamp(1.9rem, 7vw, 2.8rem); }

  /* ── Mosaico trabajos home ────────────────────────────────────── */
  #trabajosHomeGrid {
    grid-template-columns: 1fr 1fr !important;
    grid-auto-rows: 160px !important;
    gap: 4px !important;
  }
  .mosaic-large  { grid-column: span 2 !important; grid-row: span 2 !important; }
  .mosaic-tall   { grid-column: span 1 !important; grid-row: span 2 !important; }
  .mosaic-normal { grid-column: span 1 !important; grid-row: span 1 !important; }
  .mosaic-wide   { grid-column: span 2 !important; grid-row: span 1 !important; }

  /* ── Servicios home ───────────────────────────────────────────── */
  #serviciosHomeGrid { display: flex; flex-direction: column; gap: 0; }
  .servicio-home-item {
    grid-template-columns: 48px 1fr auto !important;
    gap: 16px !important;
    padding: 28px 0 !important;
    border-bottom: 1px solid var(--border-s);
  }
  .servicio-home-num  { font-size: 2.4rem; }
  .servicio-home-title { font-size: 1.05rem; }
  .servicio-home-sub  { font-size: 0.72rem; }

  /* ── Grid trabajos página ─────────────────────────────────────── */
  #trabajosGrid { grid-template-columns: 1fr 1fr !important; gap: 8px !important; }
  .trabajo-thumb { aspect-ratio: 3/4; }

  /* ── Servicios página ─────────────────────────────────────────── */
  #serviciosGrid { grid-template-columns: 1fr !important; }
  .servicio-card { padding: 32px 24px; }

  /* ── Testimonios ──────────────────────────────────────────────── */
  #testimoniosGrid { gap: 0; }
  .testimonio-item { padding: 48px 0; }
  .testimonio-text { font-size: 1.05rem; }

  /* ── Logos / fincas ───────────────────────────────────────────── */
  #logosGrid   { gap: 16px; }
  #fincasLista { gap: 8px; }
  .finca-tag   { font-size: 0.65rem; padding: 6px 14px; }

  /* ── CTA final ────────────────────────────────────────────────── */
  .cta-final { padding: 80px 24px; }
  .cta-final h2 { font-size: clamp(1.8rem, 7vw, 2.6rem); }
  #ctaFinalSub  { font-size: 0.9rem; }
  #ctaFinalBtn  { width: 100%; max-width: 300px; justify-content: center; }

  /* ── Footer ───────────────────────────────────────────────────── */
  .footer-grid   { grid-template-columns: 1fr !important; gap: 40px; }
  .footer-col    { padding-top: 0; }
  .footer-bottom { flex-direction: column; gap: 12px; text-align: center; font-size: 0.72rem; }

  /* ── Nosotros ─────────────────────────────────────────────────── */
  .nosotros-layout { grid-template-columns: 1fr !important; gap: 48px; }
  .nosotros-firma  { margin-top: 2rem; }
  .nosotros-equipo { padding: 28px 24px; }
  .values-list li  { gap: 16px; }

  /* ── Contacto ─────────────────────────────────────────────────── */
  .contacto-layout { grid-template-columns: 1fr !important; gap: 48px; }
  .form-wrap   { padding: 36px 24px; }
  .form-row    { grid-template-columns: 1fr !important; gap: 0; }

  /* ── Modal ────────────────────────────────────────────────────── */
  .modal-inner { max-width: 100%; border-radius: 0; margin: 0; max-height: 100vh; }
  .modal-body  { padding: 28px 20px; }

  /* ── WhatsApp ─────────────────────────────────────────────────── */
  #whatsappFloat { bottom: 16px; right: 16px; width: 52px; height: 52px; }

  /* ── Page hero (páginas interiores) ──────────────────────────── */
  .page-hero { padding: 60px 0 48px; }

  /* ── Botones ──────────────────────────────────────────────────── */
  .btn-dark, .btn-outline, .btn-gold, .btn-outline-gold {
    font-size: 0.62rem;
    padding: 14px 28px;
  }
}

/* ── Móvil pequeño: ≤480px ────────────────────────────────────── */
@media (max-width: 480px) {
  .container,
  .container-wide,
  .container-narrow { padding-left: 16px !important; padding-right: 16px !important; }

  h1 { font-size: clamp(1.9rem, 8.5vw, 2.6rem); }
  h2 { font-size: clamp(1.55rem, 7vw, 2.2rem); }

  #heroH1 { font-size: clamp(1.9rem, 9vw, 2.6rem); }

  #metricsGrid { grid-template-columns: 1fr !important; }
  .metric-item {
    border-right: none !important;
    border-bottom: 1px solid var(--border-s) !important;
    padding: 24px 0;
  }
  .metric-item:last-child { border-bottom: none !important; }

  #trabajosHomeGrid {
    grid-template-columns: 1fr !important;
    grid-auto-rows: 200px !important;
  }
  .mosaic-large, .mosaic-tall, .mosaic-normal, .mosaic-wide {
    grid-column: span 1 !important;
    grid-row:    span 1 !important;
  }

  #trabajosGrid { grid-template-columns: 1fr !important; }

  .servicio-card { padding: 28px 20px; }

  .footer-grid { gap: 32px; }
}

/* ── Landscape móvil ──────────────────────────────────────────── */
@media (max-height: 500px) and (orientation: landscape) {
  #hero { min-height: 100vw; }
  #heroH1 { font-size: 1.9rem; }
  #heroSub { font-size: 0.82rem; margin-bottom: 1rem; }
  .hero-ctas { flex-direction: row; justify-content: center; }
  .hero-ctas .btn { width: auto; min-width: 140px; }
}

/* ════════════════════════════════════════════════════════════════
   FIN PARCHES — v=20260407h
   ════════════════════════════════════════════════════════════════ */
