/* ============================================================
   NOICELA — Sistema de diseño (demo vanilla) · v2 "Norte"
   Editorial orgánico · montaña verde · Costa da Morte
   Mobile-first · animado · "Habita la calma"
   ============================================================ */

/* ---------- Tokens ---------- */
:root {
  /* Marca base */
  --crema:        #F3EDE0;
  --crema-2:      #E9E1CF;
  --papel:        #FBF8F0;
  --tinta:        #1F261B;   /* casi negro verdoso */
  --tinta-soft:   #4C5443;
  --bosque:       #2B3A2A;   /* verde corporativo */
  --bosque-2:     #18221A;   /* pino profundo */
  --musgo:        #5E6E43;
  --niebla:       #C9D2BE;   /* verde brumoso claro */
  --oro:          #C7A24B;   /* dorado del logo / acentos */
  --linea:        rgba(31,38,27,.13);

  /* Acentos por sección */
  --refuxio:      #7C5A38;   /* marrón */
  --vivencias:    #AF513A;   /* terracota */
  --expedicions:  #36586A;   /* azul atlántico */
  --retiros:      #6B7A45;   /* verde oliva */
  --somos:        #54683F;   /* verde */

  /* Acento activo (lo cambia cada página) */
  --acento:       var(--bosque);
  --acento-soft:  rgba(43,58,42,.08);

  /* Tipografía */
  --serif: "Fraunces", "Cormorant Garamond", Georgia, serif;
  --sans:  "Plus Jakarta Sans", system-ui, -apple-system, sans-serif;
  --mano:  "Caveat", cursive;

  /* Métricas */
  --container: 1280px;
  --pad-section: clamp(3.5rem, 9vw, 8rem);
  --radius: 6px;
  --radius-lg: 22px;
  --shadow: 0 26px 60px -28px rgba(24,34,26,.42);
  --shadow-soft: 0 14px 38px -22px rgba(24,34,26,.34);
  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-fluid: cubic-bezier(.32,.72,0,1);
  --safe-b: env(safe-area-inset-bottom, 0px);
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--sans);
  color: var(--tinta);
  background: var(--crema);
  line-height: 1.62;
  font-size: 1.02rem;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; -webkit-tap-highlight-color: transparent; }
button { font: inherit; cursor: pointer; border: none; background: none; color: inherit; -webkit-tap-highlight-color: transparent; }
ul { list-style: none; padding: 0; }
::selection { background: var(--oro); color: var(--bosque-2); }

/* Grano de papel editorial (fijo, sin coste de repintado al hacer scroll) */
.fx-grain {
  position: fixed; inset: 0; z-index: 70; pointer-events: none;
  opacity: .05; mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- Tipografía ---------- */
h1, h2, h3, h4 { font-family: var(--serif); font-weight: 400; line-height: 1.06; letter-spacing: -.018em; }
.display { font-size: clamp(2.7rem, 9vw, 5.6rem); font-weight: 380; }
h2 { font-size: clamp(2.05rem, 6vw, 3.3rem); }
h3 { font-size: clamp(1.3rem, 4.5vw, 1.75rem); }
p { max-width: 64ch; }
.lead { font-size: clamp(1.06rem, 2.6vw, 1.35rem); color: var(--tinta-soft); line-height: 1.6; }

.eyebrow {
  font-family: var(--sans); font-size: .72rem; font-weight: 600;
  letter-spacing: .26em; text-transform: uppercase; color: var(--acento);
  display: inline-flex; align-items: center; gap: .7rem;
}
.eyebrow::before { content: ""; width: 30px; height: 1px; background: currentColor; opacity: .55; }

.quote-hand { font-family: var(--mano); font-size: clamp(1.7rem, 6vw, 2.5rem); line-height: 1.22; color: var(--acento); }
.quote-hand span { display: block; font-family: var(--sans); font-size: .76rem; letter-spacing: .2em; text-transform: uppercase; color: var(--tinta-soft); margin-top: .5rem; }

/* ---------- Layout ---------- */
.container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: clamp(1.2rem, 5vw, 3rem); }
.section { padding-block: var(--pad-section); }
.section--tight { padding-block: clamp(2.5rem, 6vw, 4.5rem); }
.center { text-align: center; }
.measure { max-width: 56ch; }
.mx-auto { margin-inline: auto; }
.stack > * + * { margin-top: 1.1rem; }

/* ---------- Botones (pill + button-in-button) ---------- */
.btn {
  position: relative; display: inline-flex; align-items: center; gap: .7rem;
  padding: 1rem 1.4rem 1rem 1.6rem; border-radius: 100px;
  font-family: var(--sans); font-weight: 600; font-size: .92rem; letter-spacing: .01em;
  min-height: 52px;
  transition: transform .5s var(--ease-fluid), background .4s var(--ease), color .4s var(--ease), box-shadow .4s var(--ease);
  will-change: transform;
}
.btn__ico {
  display: grid; place-items: center; width: 30px; height: 30px; border-radius: 50%;
  background: rgba(255,255,255,.16); flex: none;
  transition: transform .5s var(--ease-fluid);
}
.btn__ico svg { width: 15px; height: 15px; }
.btn:active { transform: scale(.97); }
.btn:hover .btn__ico { transform: translate(3px,-2px); }
.btn--solid { background: var(--acento); color: var(--crema); box-shadow: var(--shadow-soft); }
.btn--solid:hover { background: var(--bosque-2); transform: translateY(-3px); }
.btn--ghost { border: 1px solid var(--linea); color: var(--tinta); }
.btn--ghost .btn__ico { background: var(--acento-soft); }
.btn--ghost:hover { border-color: var(--acento); color: var(--acento); transform: translateY(-3px); }
.btn--light { background: rgba(251,248,240,.94); color: var(--tinta); backdrop-filter: blur(6px); }
.btn--light .btn__ico { background: rgba(31,38,27,.08); }
.btn--light:hover { background: #fff; transform: translateY(-3px); }

/* ============================================================
   HEADER — isla flotante de cristal
   ============================================================ */
.site-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  padding: max(.9rem, env(safe-area-inset-top)) 0 .9rem;
  transition: padding .5s var(--ease-fluid);
}
.site-header .container { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.site-header .nav-shell {
  display: flex; align-items: center; justify-content: space-between; gap: 1.2rem; width: 100%;
  padding: .55rem .7rem .55rem 1.1rem; border-radius: 100px;
  transition: background .5s var(--ease), box-shadow .5s var(--ease), border-color .5s var(--ease), padding .5s var(--ease);
  border: 1px solid transparent;
}
.site-header.is-scrolled .nav-shell {
  background: rgba(243,237,224,.82); backdrop-filter: blur(16px) saturate(120%);
  border-color: rgba(31,38,27,.08);
  box-shadow: 0 10px 34px -20px rgba(24,34,26,.4);
}

.brand { display: flex; align-items: center; gap: .7rem; line-height: 1; }
.brand__mark { width: 40px; height: 40px; flex: none; transition: transform .6s var(--ease-fluid); }
.brand:hover .brand__mark { transform: rotate(-8deg) scale(1.05); }
.brand__name { font-family: var(--serif); font-size: 1.5rem; letter-spacing: .01em; }
.brand__tag { display: block; font-family: var(--sans); font-size: .55rem; letter-spacing: .32em; text-transform: uppercase; color: var(--tinta-soft); margin-top: .15rem; }

.site-header:not(.is-scrolled) { color: var(--crema); }
.site-header:not(.is-scrolled) .brand__tag { color: rgba(243,237,224,.72); }

.nav { display: flex; align-items: center; gap: 1.25rem; }
.nav > a, .nav-parent { font-size: .82rem; font-weight: 500; letter-spacing: .02em; position: relative; padding-block: .35rem; }
.nav > a::after, .nav-parent::after { content: ""; position: absolute; left: 0; bottom: 0; width: 0; height: 1.5px; background: currentColor; transition: width .4s var(--ease-fluid); }
.nav > a:hover::after, .nav > a.is-active::after,
.nav-item:hover .nav-parent::after, .nav-item.is-active .nav-parent::after { width: 100%; }
.nav > a.is-active, .nav-item.is-active .nav-parent { font-weight: 700; }

/* Desplegables (desktop) */
.nav-item { position: relative; display: inline-flex; align-items: center; gap: .12rem; padding-bottom: .4rem; margin-bottom: -.4rem; }
.nav-caret { display: inline-grid; place-items: center; width: 18px; height: 18px; opacity: .6; }
.nav-caret svg { width: 11px; height: 11px; transition: transform .4s var(--ease-fluid); }
.nav-item:hover .nav-caret svg, .nav-item:focus-within .nav-caret svg { transform: rotate(180deg); }
.subnav {
  position: absolute; top: 100%; left: -.9rem; min-width: 258px;
  display: flex; flex-direction: column; gap: 2px; padding: .5rem;
  background: var(--papel); border: 1px solid rgba(31,38,27,.08); border-radius: 16px; box-shadow: var(--shadow);
  opacity: 0; visibility: hidden; transform: translateY(10px); transform-origin: top center;
  transition: opacity .35s var(--ease-fluid), transform .35s var(--ease-fluid), visibility .35s; z-index: 50;
}
.nav-item:hover .subnav, .nav-item:focus-within .subnav { opacity: 1; visibility: visible; transform: none; }
.subnav a { padding: .62rem .8rem; border-radius: 10px; font-size: .82rem; font-weight: 500; color: var(--tinta); white-space: nowrap; transition: background .25s, color .25s; }
.subnav a:hover { background: var(--acento-soft); color: var(--acento); }

.header-actions { display: flex; align-items: center; gap: 1rem; }
.lang { display: flex; gap: .55rem; font-size: .7rem; font-weight: 700; letter-spacing: .08em; }
.lang button { opacity: .5; transition: opacity .3s; padding: .4rem .15rem; }
.lang button.is-active, .lang button:hover { opacity: 1; }
.lang button.is-active { color: var(--oro); }

.nav-toggle { display: none; width: 48px; height: 48px; position: relative; border-radius: 50%; }
.nav-toggle span { position: absolute; left: 14px; width: 20px; height: 2px; border-radius: 2px; background: currentColor; transition: .45s var(--ease-fluid); }
.nav-toggle span:nth-child(1) { top: 19px; }
.nav-toggle span:nth-child(2) { top: 27px; }
body.nav-open .nav-toggle span:nth-child(1) { top: 23px; transform: rotate(45deg); }
body.nav-open .nav-toggle span:nth-child(2) { top: 23px; transform: rotate(-45deg); }

/* ============================================================
   HERO — con colina + hierba animada
   ============================================================ */
.hero { position: relative; min-height: 100svh; display: flex; align-items: flex-end; color: var(--crema); overflow: hidden; }
.hero--compact { min-height: 86svh; }
.hero__media { position: absolute; inset: 0; z-index: -2; will-change: transform; }
.hero__media img { width: 100%; height: 116%; object-fit: cover; }
.hero::after { content: ""; position: absolute; inset: 0; z-index: -1; background: linear-gradient(180deg, rgba(18,26,18,.42) 0%, rgba(18,26,18,.12) 38%, rgba(18,26,18,.62) 78%, var(--crema) 100%); }
.hero__inner { position: relative; z-index: 2; padding-bottom: clamp(5rem, 14vw, 8rem); padding-top: 9rem; width: 100%; }
.hero .eyebrow { color: var(--crema); }
.hero h1 { margin-top: 1.1rem; max-width: 16ch; text-shadow: 0 2px 30px rgba(18,26,18,.35); }
.hero .lead { color: rgba(243,237,224,.9); margin-top: 1.3rem; }
.hero__cta { display: flex; flex-wrap: wrap; gap: .8rem; margin-top: 2rem; }
.hero__quote { position: absolute; right: clamp(1.5rem,5vw,4rem); top: 34%; max-width: 22ch; text-align: right; z-index: 2; }
.hero__quote .quote-hand { color: var(--crema); }
.hero__quote .quote-hand span { color: rgba(243,237,224,.78); }
@media (max-width: 900px){ .hero__quote { display: none; } }

/* Pie de hero: colina de crema + hierba */
.hero__foot { position: absolute; left: 0; right: 0; bottom: -1px; z-index: 1; pointer-events: none; line-height: 0; }
.hero__foot .hill { display: block; width: 100%; height: clamp(60px, 9vw, 120px); }
.grass-field { position: absolute; left: 0; right: 0; bottom: 0; height: clamp(46px, 7vw, 82px); display: flex; align-items: flex-end; justify-content: stretch; gap: 1px; padding-inline: 0; overflow: hidden; }
.blade {
  flex: 1 1 auto; min-width: 3px; max-width: 11px;
  border-radius: 60% 60% 2px 2px / 90% 90% 2px 2px;
  transform-origin: bottom center;
  animation: sway var(--dur,4s) var(--ease) calc(var(--d,0s)) infinite alternate;
  will-change: transform;
}
@keyframes sway {
  0%   { transform: rotate(var(--a1,-6deg)) scaleY(1); }
  100% { transform: rotate(var(--a2,7deg)) scaleY(1.04); }
}

/* ============================================================
   Divisor orgánico reutilizable
   ============================================================ */
.divider { line-height: 0; color: var(--crema); }
.divider svg { display: block; width: 100%; height: clamp(40px, 6vw, 80px); }

/* ============================================================
   Marquesina cinética
   ============================================================ */
.marquee { overflow: hidden; white-space: nowrap; }
.marquee__track { display: inline-flex; align-items: center; gap: 2.5rem; padding-right: 2.5rem; animation: marquee 26s linear infinite; }
.marquee__track span { font-family: var(--serif); font-size: clamp(1.4rem, 4vw, 2.4rem); display: inline-flex; align-items: center; gap: 2.5rem; }
.marquee__track span::after { content: "✦"; font-size: .6em; color: var(--oro); }
@keyframes marquee { to { transform: translateX(-50%); } }
.marquee--band { background: var(--bosque); color: var(--crema); padding-block: 1.4rem; }
.marquee:hover .marquee__track { animation-play-state: paused; }

/* ============================================================
   Bloques reutilizables
   ============================================================ */
.section-head { max-width: 60ch; margin-bottom: clamp(2.5rem, 6vw, 4rem); }
.section-head.center { margin-inline: auto; }
.section-head h2 { margin-top: 1rem; }
.section-head p { margin-top: 1rem; }

/* Tarjetas de camino (home) — doble bisel */
.path-grid { display: grid; grid-template-columns: 1fr; gap: 1.2rem; }
@media (min-width: 640px){ .path-grid { grid-template-columns: repeat(2,1fr); } }
@media (min-width: 1040px){ .path-grid { grid-template-columns: repeat(4,1fr); } }
.path-card {
  position: relative; min-height: 400px; border-radius: var(--radius-lg); overflow: hidden;
  display: flex; flex-direction: column; justify-content: flex-end; padding: 1.7rem;
  color: var(--crema); isolation: isolate;
  transition: transform .6s var(--ease-fluid), box-shadow .6s var(--ease);
}
.path-card img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: -2; transition: transform 1.1s var(--ease-fluid); }
.path-card::after { content: ""; position: absolute; inset: 0; z-index: -1; background: linear-gradient(180deg, rgba(18,26,18,.05), rgba(18,26,18,.86)); }
.path-card:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.path-card:hover img { transform: scale(1.08); }
.path-card__tag { font-size: .66rem; letter-spacing: .24em; text-transform: uppercase; opacity: .85; }
.path-card h3 { margin: .45rem 0 .55rem; font-size: 1.7rem; }
.path-card p { font-size: .92rem; color: rgba(243,237,224,.86); }
.path-card .more { margin-top: 1.1rem; font-size: .74rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; display: inline-flex; gap: .5rem; }
.path-card .more::after { content: "→"; transition: transform .4s var(--ease-fluid); }
.path-card:hover .more::after { transform: translateX(6px); }

/* Franja de valores */
.values { display: grid; grid-template-columns: 1fr; gap: 1.6rem 2rem; }
@media (min-width: 560px){ .values { grid-template-columns: repeat(2,1fr); } }
@media (min-width: 940px){ .values { grid-template-columns: repeat(4,1fr); } }
.value { display: flex; flex-direction: column; gap: .45rem; }
.value .ico { width: 34px; height: 34px; color: var(--acento); }
.value h4 { font-family: var(--sans); font-size: .8rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.value p { font-size: .9rem; color: var(--tinta-soft); }

/* Tarjetas de experiencia */
.exp-grid { display: grid; grid-template-columns: 1fr; gap: 1.4rem; }
@media (min-width: 600px){ .exp-grid { grid-template-columns: repeat(2,1fr); } }
@media (min-width: 1000px){ .exp-grid { grid-template-columns: repeat(auto-fill, minmax(290px,1fr)); } }
.exp-card {
  position: relative; background: var(--papel); border-radius: var(--radius-lg); overflow: hidden;
  box-shadow: var(--shadow-soft); display: flex; flex-direction: column;
  border: 1px solid rgba(31,38,27,.05);
  transition: transform .55s var(--ease-fluid), box-shadow .55s var(--ease);
}
.exp-card:hover { transform: translateY(-7px); box-shadow: var(--shadow); }
.exp-card:active { transform: scale(.99); }
.exp-card__media { position: relative; aspect-ratio: 4/3; overflow: hidden; }
.exp-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 1s var(--ease-fluid); }
.exp-card:hover .exp-card__media img { transform: scale(1.07); }
.exp-card__date { position: absolute; top: .9rem; left: .9rem; background: var(--acento); color: var(--crema); font-size: .7rem; font-weight: 700; letter-spacing: .06em; padding: .42rem .8rem; border-radius: 100px; box-shadow: var(--shadow-soft); }
.exp-card__num { position: absolute; top: .6rem; right: 1.1rem; font-family: var(--serif); font-size: 2.4rem; color: var(--crema); opacity: .9; text-shadow: 0 2px 14px rgba(18,26,18,.4); }
.exp-card__body { padding: 1.5rem; display: flex; flex-direction: column; flex: 1; }
.exp-card__place { font-size: .7rem; letter-spacing: .2em; text-transform: uppercase; color: var(--acento); }
.exp-card__body h3 { margin: .35rem 0 .6rem; }
.exp-card__body p { font-size: .9rem; color: var(--tinta-soft); flex: 1; }
.exp-card__foot { display: flex; align-items: center; justify-content: space-between; gap: .8rem; margin-top: 1.2rem; padding-top: 1rem; border-top: 1px solid var(--linea); font-size: .8rem; }
.exp-card__tag { color: var(--tinta-soft); }
.exp-card__link { font-weight: 700; color: var(--acento); display: inline-flex; gap: .4rem; }
.exp-card__link::after { content: "→"; transition: transform .4s var(--ease-fluid); }
.exp-card:hover .exp-card__link::after { transform: translateX(5px); }

/* Split / zig-zag */
.split { display: grid; grid-template-columns: 1fr; gap: clamp(1.8rem,5vw,4.5rem); align-items: center; }
@media (min-width: 860px){
  .split { grid-template-columns: 1fr 1fr; }
  .split--media-right .split__media { order: 2; }
}
.split__media { border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow); aspect-ratio: 4/3; }
.split__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.2s var(--ease-fluid); }
.split__media:hover img { transform: scale(1.05); }

/* Specs */
.specs { display: grid; grid-template-columns: repeat(2,1fr); gap: 1.6rem 1rem; text-align: center; }
@media (min-width: 760px){ .specs { grid-template-columns: repeat(auto-fit,minmax(140px,1fr)); } }
.spec { display: flex; flex-direction: column; align-items: center; gap: .5rem; }
.spec .ico { width: 30px; height: 30px; color: var(--acento); }
.spec strong { font-family: var(--sans); font-size: .8rem; letter-spacing: .06em; text-transform: uppercase; }
.spec span { font-size: .85rem; color: var(--tinta-soft); }

/* Banda */
.band { background: var(--bosque); color: var(--crema); text-align: center; position: relative; overflow: hidden; }
.band h2 { font-size: clamp(1.9rem,5vw,3rem); }
.band--accent { background: var(--acento); }

/* Timeline */
.timeline { display: grid; gap: 1.6rem; }
.day { border-left: 2px solid var(--acento-soft); padding-left: 1.4rem; position: relative; }
.day::before { content: ""; position: absolute; left: -7px; top: .35rem; width: 12px; height: 12px; border-radius: 50%; background: var(--acento); box-shadow: 0 0 0 4px var(--acento-soft); }
.day__title { font-family: var(--sans); font-weight: 700; font-size: .78rem; letter-spacing: .1em; text-transform: uppercase; color: var(--acento); }
.day h3 { margin: .2rem 0 .8rem; font-size: 1.25rem; }
.day ul { display: grid; gap: .5rem; }
.day li { display: flex; gap: .9rem; font-size: .92rem; color: var(--tinta-soft); }
.day li time { font-variant-numeric: tabular-nums; font-weight: 700; color: var(--tinta); flex: none; width: 3.6rem; }

/* Factbox (doble bisel) */
.factbox { background: var(--papel); border-radius: var(--radius-lg); box-shadow: var(--shadow-soft); padding: 1.8rem; border: 1px solid rgba(31,38,27,.05); }
@media (min-width: 860px){ .factbox { position: sticky; top: 110px; } }
.factbox h4 { font-family: var(--sans); font-size: .76rem; letter-spacing: .12em; text-transform: uppercase; color: var(--acento); margin-bottom: 1rem; }
.factbox dl { display: grid; gap: .85rem; margin-bottom: 1.4rem; }
.factbox dl > div { display: flex; justify-content: space-between; gap: 1rem; font-size: .9rem; border-bottom: 1px dashed var(--linea); padding-bottom: .8rem; }
.factbox dt { color: var(--tinta-soft); }
.factbox dd { font-weight: 600; text-align: right; }
.price-row { display: flex; justify-content: space-between; align-items: baseline; padding: .7rem 0; }
.price-row .amount { font-family: var(--serif); font-size: 1.8rem; color: var(--acento); font-variant-numeric: tabular-nums; }
.price-row small { color: var(--tinta-soft); font-size: .76rem; }

/* Tablas */
.table-wrap { overflow-x: auto; border-radius: var(--radius-lg); box-shadow: var(--shadow-soft); background: var(--papel); -webkit-overflow-scrolling: touch; }
table.data { width: 100%; border-collapse: collapse; font-size: .9rem; min-width: 560px; }
table.data th, table.data td { padding: .95rem 1.1rem; text-align: left; border-bottom: 1px solid var(--linea); }
table.data thead th { background: var(--bosque); color: var(--crema); font-family: var(--sans); font-weight: 600; font-size: .72rem; letter-spacing: .1em; text-transform: uppercase; position: sticky; top: 0; }
table.data tbody tr { transition: background .25s; }
table.data tbody tr:hover { background: var(--acento-soft); }
table.data td:nth-child(3), table.data td:nth-child(4) { font-variant-numeric: tabular-nums; }
.pill { display: inline-block; padding: .22rem .7rem; border-radius: 100px; font-size: .68rem; font-weight: 700; letter-spacing: .05em; }
.pill--retiro { background: rgba(107,122,69,.18); color: var(--retiros); }
.pill--exped  { background: rgba(54,88,106,.18); color: var(--expedicions); }
.pill--viven  { background: rgba(175,81,58,.16); color: var(--vivencias); }
.pill--refux  { background: rgba(124,90,56,.18); color: var(--refuxio); }

/* Formularios */
.form { display: grid; gap: 1.1rem; }
.field { display: grid; gap: .4rem; }
.field label { font-size: .76rem; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; color: var(--tinta-soft); }
.field input, .field textarea, .field select {
  font: inherit; padding: .95rem 1rem; border: 1px solid var(--linea); border-radius: var(--radius);
  background: #fff; color: var(--tinta); transition: border .3s, box-shadow .3s; min-height: 50px;
}
.field input:focus, .field textarea:focus, .field select:focus { outline: none; border-color: var(--acento); box-shadow: 0 0 0 4px var(--acento-soft); }
.checkbox { display: flex; gap: .6rem; align-items: flex-start; font-size: .82rem; color: var(--tinta-soft); }
.checkbox input { margin-top: .15rem; width: 18px; height: 18px; flex: none; }
.contact-grid { display: grid; grid-template-columns: 1fr; gap: clamp(2rem,5vw,4rem); }
@media (min-width: 860px){ .contact-grid { grid-template-columns: 1fr 1.2fr; } }
.contact-item { display: flex; gap: 1rem; padding: 1.1rem 0; border-bottom: 1px solid var(--linea); }
.contact-item .ico { width: 26px; height: 26px; color: var(--acento); flex: none; margin-top: .2rem; }
.contact-item strong { display: block; font-family: var(--sans); font-size: .76rem; letter-spacing: .1em; text-transform: uppercase; }
.contact-item span { color: var(--tinta-soft); font-size: .92rem; }

/* Page header interior */
.page-hero { padding-top: 8.5rem; padding-bottom: 3rem; background: var(--acento-soft); position: relative; overflow: hidden; }
.page-hero .crumbs { font-size: .78rem; color: var(--tinta-soft); letter-spacing: .04em; margin-bottom: 1rem; }
.page-hero .crumbs a:hover { color: var(--acento); }
.page-hero h1 { font-size: clamp(2.4rem,7vw,4rem); max-width: 16ch; }

/* Legal */
.legal { display: grid; grid-template-columns: 1fr; gap: 1.6rem 3rem; }
@media (min-width: 760px){ .legal { grid-template-columns: 1fr 1fr; } }
.legal article h3 { font-family: var(--sans); font-weight: 700; font-size: .95rem; letter-spacing: .03em; margin-bottom: .5rem; color: var(--acento); }
.legal article p { font-size: .9rem; color: var(--tinta-soft); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer { background: var(--bosque-2); color: rgba(243,237,224,.82); padding-block: clamp(3.5rem,7vw,5.5rem) calc(2rem + var(--safe-b)); position: relative; }
.footer-grid { display: grid; grid-template-columns: 1fr; gap: 2.4rem; }
@media (min-width: 560px){ .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 920px){ .footer-grid { grid-template-columns: 1.4fr 1fr 1fr 1.2fr; } }
.site-footer h4 { font-family: var(--sans); font-size: .74rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--crema); margin-bottom: 1.2rem; }
.site-footer a { transition: color .3s; }
.site-footer a:hover { color: var(--oro); }
.site-footer li { margin-bottom: .6rem; font-size: .9rem; }
.footer-brand .brand__name { color: var(--crema); }
.footer-brand p { font-size: .9rem; margin-top: 1rem; max-width: 32ch; }
.footer-socials { display: flex; gap: .7rem; margin-top: 1.3rem; }
.footer-socials a { width: 46px; height: 46px; border: 1px solid rgba(243,237,224,.22); border-radius: 50%; display: grid; place-items: center; transition: .4s var(--ease-fluid); }
.footer-socials a:hover { background: var(--oro); border-color: var(--oro); color: var(--bosque-2); transform: translateY(-3px); }
.footer-bottom { margin-top: 2.8rem; padding-top: 1.5rem; border-top: 1px solid rgba(243,237,224,.14); display: flex; flex-wrap: wrap; gap: 1rem; justify-content: space-between; font-size: .78rem; color: rgba(243,237,224,.55); }
.footer-bottom .links { display: flex; gap: 1.4rem; flex-wrap: wrap; }

/* WhatsApp flotante */
.wa-float { position: fixed; right: 1.1rem; bottom: calc(1.1rem + var(--safe-b)); z-index: 90; width: 58px; height: 58px; border-radius: 50%; background: #1FAE54; color: #fff; display: grid; place-items: center; box-shadow: 0 12px 30px -8px rgba(31,174,84,.6); transition: transform .5s var(--ease-fluid); }
.wa-float::before { content: ""; position: absolute; inset: 0; border-radius: 50%; border: 2px solid #1FAE54; animation: waPulse 2.6s var(--ease) infinite; }
@keyframes waPulse { 0% { transform: scale(1); opacity: .6; } 100% { transform: scale(1.7); opacity: 0; } }
.wa-float:hover { transform: scale(1.08) translateY(-2px); }
.wa-float svg { width: 30px; height: 30px; position: relative; }

/* Newsletter */
.newsletter { background: var(--papel); border: 1px solid rgba(31,38,27,.06); border-radius: var(--radius-lg); padding: clamp(1.6rem,5vw,3.2rem); display: grid; grid-template-columns: 1fr; gap: 1.6rem; align-items: center; box-shadow: var(--shadow-soft); }
@media (min-width: 720px){ .newsletter { grid-template-columns: 1fr auto; gap: 2rem; } }
.newsletter form { display: flex; gap: .7rem; flex-wrap: wrap; }
.newsletter input { flex: 1; min-width: 200px; padding: .95rem 1.1rem; border: 1px solid var(--linea); border-radius: 100px; background: #fff; font: inherit; min-height: 52px; }
.newsletter input:focus { outline: none; border-color: var(--acento); }

/* ============================================================
   Animaciones de revelado (fade-up + blur)
   ============================================================ */
[data-reveal] { opacity: 0; transform: translateY(34px); filter: blur(6px); transition: opacity .9s var(--ease-fluid), transform .9s var(--ease-fluid), filter .9s var(--ease-fluid); }
[data-reveal].is-in { opacity: 1; transform: none; filter: none; }
[data-reveal-delay="1"]{ transition-delay: .09s; }
[data-reveal-delay="2"]{ transition-delay: .18s; }
[data-reveal-delay="3"]{ transition-delay: .27s; }
[data-reveal-delay="4"]{ transition-delay: .36s; }

/* ============================================================
   Menú móvil — overlay de cristal a pantalla completa
   ============================================================ */
@media (max-width: 1080px){
  .nav-toggle { display: block; }
  /* El overlay fijo del menú no puede vivir dentro de un ancestro con
     backdrop-filter (crea bloque contenedor). En móvil quitamos el blur del pill. */
  .site-header .nav-shell { backdrop-filter: none !important; }
  .site-header.is-scrolled .nav-shell { background: rgba(243,237,224,.95); }
  .site-header:not(.is-scrolled) .nav-shell { background: rgba(24,34,26,.34); }
  .nav {
    position: fixed; inset: 0; z-index: 99;
    background: rgba(24,34,26,.95); backdrop-filter: blur(22px) saturate(120%);
    color: var(--crema);
    flex-direction: column; align-items: flex-start; justify-content: flex-start;
    gap: .35rem; padding: 5.4rem clamp(1.5rem,8vw,4rem) calc(3rem + var(--safe-b));
    overflow-y: auto; -webkit-overflow-scrolling: touch;
    clip-path: circle(0% at calc(100% - 44px) 44px);
    transition: clip-path .7s var(--ease-fluid);
    pointer-events: none;
  }
  body.nav-open .nav { clip-path: circle(150% at calc(100% - 44px) 44px); pointer-events: auto; }

  .nav > a, .nav-parent { font-family: var(--serif); font-size: clamp(1.7rem,7.5vw,2.6rem); padding-block: .08rem; line-height: 1.12; }
  .nav > a::after, .nav-parent::after { display: none; }
  .nav > a.is-active, .nav-item.is-active .nav-parent { color: var(--oro); }

  /* Entrada escalonada de cada bloque */
  .nav > a, .nav > .nav-item { opacity: 0; transform: translateY(26px); transition: opacity .5s var(--ease-fluid), transform .5s var(--ease-fluid); }
  body.nav-open .nav > a, body.nav-open .nav > .nav-item { opacity: 1; transform: none; }
  body.nav-open .nav > *:nth-child(1){ transition-delay:.16s; }
  body.nav-open .nav > *:nth-child(2){ transition-delay:.21s; }
  body.nav-open .nav > *:nth-child(3){ transition-delay:.26s; }
  body.nav-open .nav > *:nth-child(4){ transition-delay:.31s; }
  body.nav-open .nav > *:nth-child(5){ transition-delay:.36s; }
  body.nav-open .nav > *:nth-child(6){ transition-delay:.41s; }
  body.nav-open .nav > *:nth-child(7){ transition-delay:.46s; }

  /* Acordeón móvil */
  .nav-item { display: flex; flex-wrap: wrap; align-items: center; width: 100%; padding: 0; margin: 0; gap: 0; }
  .nav-parent { flex: 1; }
  .nav-caret { width: 48px; height: 48px; opacity: .85; margin-left: auto; }
  .nav-caret svg { width: 18px; height: 18px; }
  .nav-item.open .nav-caret svg { transform: rotate(180deg); }
  .subnav {
    position: static; flex-basis: 100%; width: 100%; min-width: 0;
    display: flex; flex-direction: column; gap: .1rem;
    background: none; border: none; box-shadow: none; border-radius: 0; transform: none;
    padding: 0 0 0 1rem; margin: 0;
    max-height: 0; overflow: hidden; opacity: 0; visibility: visible;
    transition: max-height .45s var(--ease-fluid), opacity .35s, padding .35s;
  }
  .nav-item.open .subnav { max-height: 80vh; opacity: 1; padding: .3rem 0 .9rem 1rem; }
  .subnav a { font-family: var(--sans); font-size: 1.02rem; font-weight: 500; color: rgba(243,237,224,.8); padding: .55rem 0; white-space: normal; }
  .subnav a:hover { background: none; color: var(--oro); }
  body.nav-open { overflow: hidden; }
  .header-actions .lang { position: fixed; bottom: calc(2.2rem + var(--safe-b)); left: clamp(1.5rem,8vw,4rem); z-index: 100; gap: 1.2rem; font-size: .9rem; opacity: 0; transition: opacity .5s .5s; pointer-events: none; }
  body.nav-open .header-actions .lang { opacity: 1; pointer-events: auto; }
  body.nav-open .site-header { color: var(--crema); }
}

@media (max-width: 560px){
  .hero__cta { flex-direction: column; align-items: stretch; }
  .hero__cta .btn { justify-content: center; }
}

/* ============================================================
   Sofisticación · micro-animaciones armónicas
   ============================================================ */

/* Barra de progreso de lectura */
.scroll-progress {
  position: fixed; top: 0; left: 0; height: 3px; width: 100%;
  transform: scaleX(0); transform-origin: 0 50%;
  background: linear-gradient(90deg, var(--oro), var(--musgo));
  z-index: 120; pointer-events: none;
}

/* Titular con revelado palabra a palabra (efecto cortina) */
h1.reveal-words .w { display: inline-block; overflow: hidden; vertical-align: top; padding-bottom: .12em; margin-bottom: -.12em; }
h1.reveal-words .w__i { display: inline-block; transform: translateY(115%); transition: transform 1s var(--ease-fluid); will-change: transform; }
h1.reveal-words.reveal-on .w__i { transform: none; }

/* Ken Burns: las fotos de hero respiran */
@media (prefers-reduced-motion: no-preference) {
  .hero__media img { animation: kenburns 32s ease-in-out infinite alternate; }
}
@keyframes kenburns { from { transform: scale(1.02); } to { transform: scale(1.085); } }

/* Luz que sigue al cursor sobre las tarjetas (desktop) */
.exp-card::before {
  content: ""; position: absolute; inset: 0; z-index: 3; pointer-events: none; border-radius: inherit;
  opacity: 0; transition: opacity .45s var(--ease-fluid);
  background: radial-gradient(360px circle at var(--mx,50%) var(--my,50%), rgba(255,255,255,.10), transparent 60%);
}
.exp-card:hover::before { opacity: 1; }

/* Niebla viva tras las bandas oscuras */
.band::before {
  content: ""; position: absolute; inset: -25%; z-index: 0; pointer-events: none; filter: blur(6px);
  background:
    radial-gradient(40% 50% at 20% 30%, rgba(255,255,255,.06), transparent 70%),
    radial-gradient(46% 56% at 80% 70%, rgba(199,162,75,.13), transparent 72%);
  animation: drift 22s ease-in-out infinite alternate;
}
.band > * { position: relative; z-index: 1; }
@keyframes drift {
  from { transform: translate3d(-2.5%, -1.5%, 0) scale(1); }
  to   { transform: translate3d(2.5%, 1.5%, 0) scale(1.08); }
}

/* La línea del eyebrow crece al entrar en pantalla */
[data-reveal] .eyebrow::before, [data-reveal].eyebrow::before { width: 0; transition: width .9s .25s var(--ease-fluid); }
[data-reveal].is-in .eyebrow::before, [data-reveal].is-in.eyebrow::before { width: 30px; }

/* ============================================================
   Reduced motion
   ============================================================ */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; }
  [data-reveal]{ opacity:1; transform:none; filter:none; }
  .blade { animation: none; }
  html{ scroll-behavior:auto; }
  .wa-float::before { display: none; }
}
