/* ============================================================
   LAZ · Café de Montaña — sistema visual
   Paleta cálida: café, madera, naturaleza, montaña
   Tipografía serif refinada (Cormorant Garamond) + sans tranquilo (Mulish)
   ============================================================ */

:root {
  /* superficies */
  --paper:    #f4efe5;   /* fondo más claro */
  --cream:    #efe7da;   /* fondo base */
  --sand:     #e6dccb;   /* fondo seccional alterno */
  --card:     #faf6ef;   /* tarjetas */
  /* tinta */
  --espresso: #2e2620;   /* texto principal */
  --bark:     #463a30;   /* texto secundario */
  --muted:    #8c8073;   /* texto terciario */
  --line:     rgba(46,38,32,.12);
  --line-soft:rgba(46,38,32,.07);
  /* acentos cálidos */
  --caramel:  #d08a52;
  --caramel-d:#b8703a;
  --sage:     #7a8b6f;
  --sage-d:   #5f6e56;
  --latte:    #b89b76;
  /* oscuro */
  --night:    #221b15;
  --night-2:  #2a221b;

  --shadow-sm: 0 1px 3px rgba(46,38,32,.06), 0 6px 18px rgba(46,38,32,.05);
  --shadow-md: 0 4px 14px rgba(46,38,32,.08), 0 18px 50px rgba(46,38,32,.10);
  --shadow-lg: 0 10px 30px rgba(46,38,32,.12), 0 40px 90px rgba(46,38,32,.16);

  --serif: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans:  "Mulish", "Helvetica Neue", Arial, sans-serif;
  --mono:  ui-monospace, "SFMono-Regular", "Menlo", monospace;

  --r-sm: 8px;
  --r-md: 16px;
  --r-lg: 26px;
  --r-xl: 36px;

  --ease: cubic-bezier(.22,.61,.36,1);
  --pad: clamp(20px, 5.5vw, 96px);
  --maxw: 1280px;
}

/* ---------- reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--sans);
  color: var(--espresso);
  background: var(--cream);
  line-height: 1.65;
  font-size: 17px;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
ul { list-style: none; }
::selection { background: var(--caramel); color: #fff; }

/* ---------- tipografía ---------- */
h1, h2, h3, h4 { font-family: var(--serif); font-weight: 500; line-height: 1.04; letter-spacing: -0.01em; color: var(--espresso); }
.serif-italic { font-family: var(--serif); font-style: italic; font-weight: 400; }

.eyebrow {
  font-family: var(--sans);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--caramel-d);
}
.eyebrow.on-dark { color: var(--latte); }

.lead { font-size: clamp(1.05rem, 1.6vw, 1.3rem); color: var(--bark); line-height: 1.7; }
.muted { color: var(--muted); }
.en {  /* subtítulos secundarios en inglés */
  font-family: var(--sans);
  font-style: italic;
  font-weight: 400;
  color: var(--muted);
  letter-spacing: .01em;
}

/* ---------- layout ---------- */
.wrap { max-width: var(--maxw); margin-inline: auto; padding-inline: var(--pad); }
.section { padding-block: clamp(72px, 11vw, 160px); position: relative; }
.section--sand { background: var(--sand); }
.section--paper { background: var(--paper); }
.section--dark { background: var(--night); color: #efe4d6; }
.section--dark h2, .section--dark h3 { color: #f6ede1; }

.section-head { max-width: 680px; margin-bottom: clamp(40px, 6vw, 72px); }
.section-head.center { margin-inline: auto; text-align: center; }
.section-head h2 { font-size: clamp(2.3rem, 4.6vw, 4rem); margin: 14px 0 0; }
.section-head .lead { margin-top: 20px; }

/* ---------- botones ---------- */
.btn {
  display: inline-flex; align-items: center; gap: .6em;
  font-family: var(--sans); font-weight: 600; font-size: .92rem;
  letter-spacing: .02em;
  padding: 15px 28px; border-radius: 100px;
  transition: transform .4s var(--ease), background .35s var(--ease), color .35s var(--ease), box-shadow .35s var(--ease);
  will-change: transform;
}
.btn .arw { transition: transform .4s var(--ease); }
.btn:hover .arw { transform: translateX(4px); }
.btn--primary { background: var(--espresso); color: var(--paper); box-shadow: var(--shadow-sm); }
.btn--primary:hover { background: var(--caramel-d); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.btn--ghost { background: transparent; color: var(--espresso); box-shadow: inset 0 0 0 1.5px var(--line); }
.btn--ghost:hover { box-shadow: inset 0 0 0 1.5px var(--espresso); transform: translateY(-2px); }
.btn--light { background: var(--paper); color: var(--espresso); }
.btn--light:hover { background: #fff; transform: translateY(-2px); box-shadow: var(--shadow-md); }
.btn--sm { padding: 11px 20px; font-size: .84rem; }

/* ---------- placeholders de imagen ---------- */
.ph {
  position: relative;
  background-color: #ddd0bb;
  background-image:
    repeating-linear-gradient(135deg, rgba(46,38,32,.05) 0 1px, transparent 1px 13px),
    linear-gradient(160deg, #e2d6c2, #cdbfa6);
  overflow: hidden;
  isolation: isolate;
}
.ph::after {
  content: attr(data-label);
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  text-align: center; padding: 14px;
  font-family: var(--mono); font-size: .68rem; letter-spacing: .12em;
  text-transform: uppercase; color: rgba(46,38,32,.46);
  line-height: 1.5;
}
.ph.dark { background-image: repeating-linear-gradient(135deg, rgba(255,255,255,.05) 0 1px, transparent 1px 13px), linear-gradient(160deg, #3a3026, #241d17); }
.ph.dark::after { color: rgba(255,255,255,.4); }

/* ============================================================
   NAV
   ============================================================ */
.nav {
  position: fixed; inset: 0 0 auto 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px var(--pad);
  transition: background .5s var(--ease), box-shadow .5s var(--ease), padding .5s var(--ease);
}
.nav.scrolled {
  background: rgba(244,239,229,.86);
  backdrop-filter: blur(14px) saturate(1.2);
  box-shadow: 0 1px 0 var(--line-soft);
  padding-block: 13px;
}
.brand { display: flex; align-items: baseline; gap: 10px; }
.brand .mark { font-family: var(--serif); font-weight: 600; font-size: 1.6rem; letter-spacing: .04em; color: var(--espresso); transition: color .5s var(--ease); }
.brand .sub { font-size: .62rem; font-weight: 700; letter-spacing: .24em; text-transform: uppercase; color: var(--caramel-d); transition: color .5s var(--ease); }
.nav.hero-mode:not(.scrolled) .mark { color: var(--paper); }
.nav.hero-mode:not(.scrolled) .sub { color: var(--latte); }
.nav.hero-mode:not(.scrolled) .nav-links a { color: rgba(255,255,255,.9); }
.nav.hero-mode:not(.scrolled) .nav-cta { color: var(--espresso); background: var(--paper); }
.nav.hero-mode:not(.scrolled) .burger span { background: #fff; }

.nav-links { display: flex; align-items: center; gap: 34px; }
.nav-links a { font-size: .9rem; font-weight: 500; color: var(--bark); position: relative; padding: 4px 0; transition: color .3s; }
.nav-links a::after { content:""; position:absolute; left:0; bottom:-2px; height:1.5px; width:0; background: var(--caramel); transition: width .35s var(--ease); }
.nav-links a:hover::after { width: 100%; }
.nav-cta { display:inline-flex; align-items:center; gap:.5em; font-size:.86rem; font-weight:600; padding:10px 20px; border-radius:100px; background: var(--espresso); color: var(--paper); transition: all .4s var(--ease); }
.nav-cta:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.burger { display:none; flex-direction:column; gap:5px; padding:8px; }
.burger span { width:24px; height:2px; background: var(--espresso); transition: all .35s var(--ease); border-radius:2px; }

/* mobile menu */
.mobile-menu { position: fixed; inset: 0; z-index: 99; background: var(--night); color: var(--paper); display: flex; flex-direction: column; justify-content: center; align-items: center; gap: 8px; opacity: 0; pointer-events: none; transform: translateY(-12px); transition: opacity .4s var(--ease), transform .4s var(--ease); }
.mobile-menu.open { opacity: 1; pointer-events: auto; transform: none; }
.mobile-menu a { font-family: var(--serif); font-size: 2rem; color: var(--paper); padding: 10px; }
.mobile-menu a:hover { color: var(--caramel); }

/* ============================================================
   HERO
   ============================================================ */
.hero { position: relative; min-height: 100svh; display: flex; align-items: flex-end; overflow: hidden; }
.hero__bg { position: absolute; inset: 0; z-index: 0; }
.hero__bg .ph { width: 100%; height: 100%; }
.hero__bg::after {
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(to top, rgba(20,15,11,.78) 0%, rgba(20,15,11,.28) 42%, rgba(20,15,11,.18) 70%, rgba(20,15,11,.42) 100%);
}
.hero__inner { position: relative; z-index: 2; width: 100%; padding: 0 var(--pad) clamp(56px, 8vw, 110px); }
.hero__grid { max-width: var(--maxw); margin-inline: auto; }
.hero .eyebrow { color: var(--latte); margin-bottom: 22px; display:flex; align-items:center; gap:14px; }
.hero .eyebrow::before { content:""; width: 40px; height:1px; background: var(--latte); display:inline-block; }
.hero h1 { color: var(--paper); font-size: clamp(3rem, 8.2vw, 7.2rem); font-weight: 500; max-width: 14ch; }
.hero h1 em { font-style: italic; font-weight: 400; color: var(--caramel); }
.hero__sub { color: rgba(255,255,255,.86); font-size: clamp(1.05rem, 1.7vw, 1.4rem); max-width: 46ch; margin-top: 26px; line-height: 1.55; }
.hero__sub .en { color: rgba(255,255,255,.6); display:block; font-size: .9em; margin-top:6px; }
.hero__actions { display: flex; flex-wrap: wrap; gap: 16px; margin-top: 40px; }
.hero__scroll { position: absolute; left: 50%; bottom: 26px; transform: translateX(-50%); z-index: 3; color: rgba(255,255,255,.7); font-family: var(--mono); font-size: .62rem; letter-spacing: .2em; text-transform: uppercase; display:flex; flex-direction:column; align-items:center; gap:10px; }
.hero__scroll .dot { width: 22px; height: 34px; border: 1.5px solid rgba(255,255,255,.5); border-radius: 14px; position: relative; }
.hero__scroll .dot::after { content:""; position:absolute; top:6px; left:50%; transform: translateX(-50%); width:3px; height:7px; border-radius:3px; background: #fff; animation: scrolldot 1.8s var(--ease) infinite; }
@keyframes scrolldot { 0%{opacity:0; transform: translate(-50%,0);} 30%{opacity:1;} 100%{opacity:0; transform: translate(-50%,12px);} }

/* ============================================================
   SOBRE NOSOTROS
   ============================================================ */
.about-grid { display: grid; grid-template-columns: 1.05fr 1fr; gap: clamp(36px, 5vw, 88px); align-items: center; }
.about-copy h2 { font-size: clamp(2.2rem, 4.2vw, 3.6rem); margin: 14px 0 0; }
.about-copy .lead { margin-top: 24px; }
.about-copy p + p { margin-top: 18px; }
.about-values { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; margin-top: 44px; }
.value { }
.value .n { font-family: var(--serif); font-size: 2.4rem; color: var(--caramel); line-height: 1; }
.value .t { font-weight: 700; font-size: .82rem; letter-spacing: .04em; margin-top: 10px; }
.value .d { font-size: .86rem; color: var(--muted); margin-top: 4px; }
.about-media { display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: 1.3fr 1fr; gap: 16px; height: clamp(420px, 52vw, 600px); }
.about-media .ph { border-radius: var(--r-md); }
.about-media .ph:nth-child(1) { grid-row: 1 / 3; border-radius: var(--r-lg); }
.about-media .ph:nth-child(3) { grid-column: 2; }

/* ============================================================
   MENÚ
   ============================================================ */
.menu-cats { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 26px; }
.menu-cat { font-size: .82rem; font-weight: 600; padding: 9px 18px; border-radius: 100px; background: transparent; box-shadow: inset 0 0 0 1.4px var(--line); color: var(--bark); transition: all .3s var(--ease); }
.menu-cat.active, .menu-cat:hover { background: var(--espresso); color: var(--paper); box-shadow: none; }
.menu-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(20px, 2.6vw, 34px); }
.menu-card { background: var(--card); border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--shadow-sm); transition: transform .5s var(--ease), box-shadow .5s var(--ease); display: flex; flex-direction: column; }
.menu-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); }
.menu-card__img { height: 230px; position: relative; }
.menu-card__img .ph { position: absolute; inset: 0; }
.menu-card__tag { position: absolute; top: 14px; left: 14px; z-index: 2; font-family: var(--sans); font-size: .64rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; background: rgba(244,239,229,.92); backdrop-filter: blur(6px); color: var(--bark); padding: 6px 12px; border-radius: 100px; }
.menu-card__body { padding: 24px 24px 26px; display: flex; flex-direction: column; flex: 1; }
.menu-card__head { display: flex; justify-content: space-between; align-items: baseline; gap: 14px; }
.menu-card__body h3 { font-size: 1.55rem; }
.menu-card__price { font-family: var(--serif); font-size: 1.35rem; color: var(--caramel-d); white-space: nowrap; }
.menu-card__body .en { display:block; font-size:.82rem; margin-top:2px; }
.menu-card__body p { font-size: .92rem; color: var(--muted); margin-top: 12px; flex: 1; }
.menu-note { margin-top: 40px; text-align: center; font-size: .92rem; color: var(--muted); }

/* ============================================================
   EXPLORAR LA ZONA  (mapa estilizado interactivo)
   ============================================================ */
.explore-grid { display: grid; grid-template-columns: 1.15fr .85fr; gap: clamp(28px, 3.4vw, 52px); align-items: stretch; }

.map-stage { position: relative; border-radius: var(--r-xl); overflow: hidden; background: linear-gradient(165deg, #e9e0cf, #ddd0b8); box-shadow: var(--shadow-md); min-height: 540px; }
.map-svg { position: absolute; inset: 0; width: 100%; height: 100%; }
.map-legend { position: absolute; left: 20px; bottom: 20px; z-index: 6; background: rgba(244,239,229,.9); backdrop-filter: blur(8px); border-radius: var(--r-md); padding: 14px 16px; font-size: .72rem; box-shadow: var(--shadow-sm); }
.map-legend .lg-title { font-family: var(--mono); font-size: .6rem; letter-spacing: .18em; text-transform: uppercase; color: var(--muted); margin-bottom: 8px; }
.map-legend ul { display:flex; flex-direction:column; gap:6px; }
.map-legend li { display:flex; align-items:center; gap:8px; color: var(--bark); }
.map-legend .swatch { width: 11px; height: 11px; border-radius: 50%; flex: none; }

/* marcadores */
.marker { position: absolute; transform: translate(-50%, -50%); z-index: 5; display: flex; flex-direction: column; align-items: center; gap: 5px; cursor: pointer; -webkit-tap-highlight-color: transparent; }
.marker__pin {
  width: 42px; height: 42px; border-radius: 50% 50% 50% 12px;
  transform: rotate(45deg);
  background: var(--card);
  box-shadow: var(--shadow-md);
  display: grid; place-items: center;
  transition: transform .4s var(--ease), background .4s var(--ease);
  position: relative;
}
.marker__pin svg { transform: rotate(-45deg); width: 19px; height: 19px; }
.marker__pin::after { content:""; position:absolute; inset:0; border-radius:inherit; box-shadow: 0 0 0 0 rgba(208,138,82,.5); transition: box-shadow .4s; }
.marker__label { transform: translateY(2px); font-family: var(--sans); font-size: .66rem; font-weight: 700; letter-spacing: .02em; color: var(--espresso); background: rgba(244,239,229,.85); padding: 3px 9px; border-radius: 100px; white-space: nowrap; box-shadow: var(--shadow-sm); opacity: 0; transition: opacity .35s var(--ease); }
.marker:hover .marker__pin { transform: rotate(45deg) scale(1.12); }
.marker:hover .marker__label { opacity: 1; }
.marker.active .marker__pin { background: var(--caramel); }
.marker.active .marker__pin svg { stroke: #fff; }
.marker.active .marker__label { opacity: 1; background: var(--espresso); color: var(--paper); }
.marker.active .marker__pin::after { animation: pulse 1.8s var(--ease) infinite; }
@keyframes pulse { 0%{ box-shadow: 0 0 0 0 rgba(208,138,82,.5);} 100%{ box-shadow: 0 0 0 18px rgba(208,138,82,0);} }
.marker--cafe .marker__pin { background: var(--espresso); width: 48px; height: 48px; }
.marker--cafe .marker__pin svg { stroke: var(--latte); width: 22px; height: 22px; }
.marker--cafe .marker__label { opacity: 1; background: var(--espresso); color: var(--paper); }

/* panel de detalle */
.detail { background: var(--card); border-radius: var(--r-xl); box-shadow: var(--shadow-md); overflow: hidden; display: flex; flex-direction: column; }
.detail__img { height: 230px; position: relative; }
.detail__img .ph { position: absolute; inset: 0; }
.detail__type { position: absolute; top: 16px; left: 16px; font-family: var(--sans); font-size: .64rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; background: rgba(244,239,229,.92); backdrop-filter: blur(6px); padding: 6px 12px; border-radius: 100px; color: var(--bark); }
.detail__body { padding: 26px clamp(22px,2.4vw,30px) 28px; display: flex; flex-direction: column; flex: 1; }
.detail__body h3 { font-size: 2rem; }
.detail__body .en { display:block; font-size:.84rem; margin-top:2px; }
.detail__desc { font-size: .94rem; color: var(--bark); margin-top: 14px; }
.detail__stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; margin-top: 22px; padding-block: 18px; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.stat { text-align: center; }
.stat .ico { color: var(--caramel-d); display:flex; justify-content:center; margin-bottom: 6px; }
.stat .v { font-family: var(--serif); font-size: 1.4rem; line-height: 1; color: var(--espresso); }
.stat .k { font-size: .64rem; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); margin-top: 5px; }
.diff { display:inline-flex; align-items:center; gap:6px; font-size:.78rem; font-weight:700; }
.diff .pip { width:8px; height:8px; border-radius:50%; }

/* combo card */
.combo { margin-top: 22px; border-radius: var(--r-lg); background: linear-gradient(150deg, #2f2720, #221b14); color: #efe4d6; padding: 22px 22px 24px; position: relative; overflow: hidden; }
.combo::before { content:""; position:absolute; right:-30px; top:-30px; width:140px; height:140px; border-radius:50%; background: radial-gradient(circle, rgba(208,138,82,.4), transparent 70%); }
.combo__eyebrow { font-family: var(--sans); font-size: .64rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--latte); display:flex; align-items:center; gap:8px; }
.combo h4 { font-family: var(--serif); font-size: 1.5rem; color: #fff; margin-top: 8px; line-height: 1.1; }
.combo__items { margin-top: 16px; display: flex; flex-direction: column; gap: 10px; }
.combo__item { display:flex; align-items:center; gap:12px; }
.combo__thumb { width: 44px; height: 44px; border-radius: 10px; flex:none; }
.combo__item .nm { font-weight: 600; font-size: .92rem; color: #f6ede1; }
.combo__item .ds { font-size: .76rem; color: rgba(239,228,214,.6); }
.combo__foot { display:flex; align-items:center; justify-content:space-between; margin-top: 20px; padding-top: 18px; border-top: 1px solid rgba(255,255,255,.12); }
.combo__price { font-family: var(--serif); font-size: 1.6rem; color: #fff; }
.combo__price small { font-size: .7rem; font-family: var(--sans); color: rgba(255,255,255,.55); letter-spacing:.06em; display:block; }

.detail__actions { margin-top: 22px; display:flex; gap: 12px; }
.detail__actions .btn { flex: 1; justify-content: center; }

/* ============================================================
   GALERÍA
   ============================================================ */
.gallery { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: 200px; gap: 16px; }
.gallery .ph { border-radius: var(--r-md); transition: transform .6s var(--ease); }
.gallery .g-item { overflow: hidden; border-radius: var(--r-md); position: relative; }
.gallery .g-item .ph { width:100%; height:100%; }
.gallery .g-item:hover .ph { transform: scale(1.06); }
.gallery .tall { grid-row: span 2; }
.gallery .wide { grid-column: span 2; }

/* ============================================================
   TESTIMONIOS
   ============================================================ */
.testi-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: clamp(18px,2.4vw,30px); }
.testi { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.1); border-radius: var(--r-lg); padding: 30px 28px; display:flex; flex-direction:column; }
.testi__stars { color: var(--caramel); letter-spacing: 3px; font-size: .9rem; }
.testi__quote { font-family: var(--serif); font-size: 1.35rem; line-height: 1.4; color: #f3e9dc; margin-top: 16px; flex:1; }
.testi__by { display:flex; align-items:center; gap:12px; margin-top: 22px; }
.testi__av { width: 44px; height: 44px; border-radius: 50%; flex:none; }
.testi__by .nm { font-weight: 700; font-size: .92rem; color:#f6ede1; }
.testi__by .loc { font-size: .78rem; color: rgba(239,228,214,.55); }

/* ============================================================
   CONTACTO
   ============================================================ */
.contact-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(32px,4vw,72px); align-items: center; }
.contact-info .row { display:flex; gap: 18px; padding-block: 22px; border-bottom: 1px solid var(--line); }
.contact-info .row:first-of-type { border-top: 1px solid var(--line); }
.contact-info .ico { color: var(--caramel-d); flex: none; margin-top: 3px; }
.contact-info .k { font-size: .68rem; letter-spacing: .18em; text-transform: uppercase; color: var(--muted); font-weight: 700; }
.contact-info .v { font-size: 1.05rem; color: var(--espresso); margin-top: 4px; }
.contact-info .v span { color: var(--muted); }
.socials { display:flex; gap: 12px; margin-top: 28px; }
.social { width: 46px; height: 46px; border-radius: 50%; display:grid; place-items:center; box-shadow: inset 0 0 0 1.4px var(--line); transition: all .35s var(--ease); }
.social:hover { background: var(--espresso); color: var(--paper); transform: translateY(-3px); }
.contact-map { position: relative; border-radius: var(--r-xl); overflow: hidden; min-height: 440px; box-shadow: var(--shadow-md); }
.contact-map .ph { position:absolute; inset:0; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { background: var(--night); color: rgba(239,228,214,.7); padding-block: clamp(56px,7vw,90px) 36px; }
.footer__top { display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 32px; }
.footer .mark { font-family: var(--serif); font-size: 1.9rem; color: #f6ede1; letter-spacing: .04em; }
.footer .sub { font-size: .62rem; font-weight: 700; letter-spacing: .24em; text-transform: uppercase; color: var(--latte); margin-top: 4px; }
.footer p { font-size: .9rem; margin-top: 18px; max-width: 32ch; }
.footer h5 { font-family: var(--sans); font-size: .7rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--latte); margin-bottom: 16px; }
.footer ul { display:flex; flex-direction:column; gap: 11px; }
.footer ul a { font-size: .92rem; transition: color .3s; }
.footer ul a:hover { color: #f6ede1; }
.footer__bottom { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px; margin-top: clamp(44px,6vw,72px); padding-top: 28px; border-top: 1px solid rgba(255,255,255,.1); font-size: .8rem; }

/* ============================================================
   WHATSAPP FLOTANTE
   ============================================================ */
.wa { position: fixed; right: 22px; bottom: 22px; z-index: 90; display:flex; align-items:center; gap:0; background: #25623f; color:#fff; border-radius: 100px; box-shadow: 0 8px 26px rgba(0,0,0,.28); padding: 14px; transition: transform .4s var(--ease), gap .4s var(--ease), padding .4s var(--ease); }
.wa svg { width: 26px; height: 26px; flex:none; }
.wa .wa-txt { max-width: 0; overflow: hidden; white-space: nowrap; font-size:.9rem; font-weight:600; transition: max-width .45s var(--ease), margin .45s var(--ease); }
.wa:hover { transform: translateY(-3px); gap: 10px; }
.wa:hover .wa-txt { max-width: 180px; }
.wa::before { content:""; position:absolute; inset:0; border-radius:inherit; box-shadow: 0 0 0 0 rgba(37,98,63,.5); animation: pulse-wa 2.4s var(--ease) infinite; z-index:-1; }
@keyframes pulse-wa { 0%{ box-shadow:0 0 0 0 rgba(37,98,63,.45);} 100%{ box-shadow:0 0 0 20px rgba(37,98,63,0);} }

/* ============================================================
   ANIMACIONES DE SCROLL
   ============================================================ */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
.reveal.d1 { transition-delay: .08s; }
.reveal.d2 { transition-delay: .16s; }
.reveal.d3 { transition-delay: .24s; }
.reveal.d4 { transition-delay: .32s; }
.reveal.d5 { transition-delay: .40s; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity:1 !important; transform:none !important; }
  html { scroll-behavior: auto; }
  .hero__scroll .dot::after, .wa::before, .marker.active .marker__pin::after { animation: none; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1080px) {
  .menu-grid { grid-template-columns: repeat(2,1fr); }
  .footer__top { grid-template-columns: 1fr 1fr; gap: 36px; }
}
@media (max-width: 920px) {
  .nav-links, .nav-cta { display: none; }
  .burger { display: flex; }
  .about-grid { grid-template-columns: 1fr; }
  .about-media { height: clamp(360px,80vw,520px); margin-top: 12px; }
  .explore-grid { grid-template-columns: 1fr; }
  .map-stage { min-height: 440px; }
  .contact-grid { grid-template-columns: 1fr; }
  .testi-grid { grid-template-columns: 1fr; }
  .gallery { grid-template-columns: repeat(2,1fr); grid-auto-rows: 170px; }
}
@media (max-width: 560px) {
  body { font-size: 16px; }
  .menu-grid { grid-template-columns: 1fr; }
  .about-values { grid-template-columns: 1fr; gap: 18px; }
  .hero__actions .btn { flex: 1; justify-content: center; }
  .gallery { grid-template-columns: 1fr 1fr; }
  .gallery .wide { grid-column: span 2; }
  .footer__top { grid-template-columns: 1fr; }
  .detail__actions { flex-direction: column; }
  .wa .wa-txt { display:none; }
}