*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bl:#FFFFFF;--cr:#F8F4EC;--crd:#EEE6D4;--crdd:#E0D5BE;
  --ve:#7A8C3A;--vel:#95A54A;--ved:#5E6B2C;
  --tx:#2A2620;--txm:#4A4540;--txl:#888078;
  --ln:rgba(90,80,50,.10);--or:#C4A030;
  --sd:'Cormorant Garamond',Georgia,serif;
  --sb:'Libre Baskerville',Georgia,serif;
  --ss:'Lato',sans-serif;
  --mx:1080px;--pd:clamp(24px,5vw,72px);
}
html{scroll-behavior:smooth}
body{font-family:var(--sb);background:var(--bl);color:var(--tx);font-size:18px;line-height:1.8;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--mx);margin:0 auto;padding:0 var(--pd)}
.lbl{font-family:var(--ss);font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--ved)}
.sep{width:36px;height:1px;background:var(--ve);display:block;margin-bottom:20px}
.sep-c{margin:0 auto 20px}
.fu{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s ease}
.fu.in{opacity:1;transform:none}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:200;height:68px;display:flex;align-items:center;justify-content:space-between;padding:0 var(--pd);background:rgba(248,244,236,.97);border-bottom:1px solid var(--ln);box-shadow:0 1px 12px rgba(42,38,32,.05)}
.nav-logo{font-family:var(--sd);font-size:22px;font-weight:400;color:var(--tx);letter-spacing:.5px;display:flex;align-items:center;gap:9px}
.nav-logo svg{width:20px;height:20px;flex-shrink:0}
.nav-menu{display:flex;align-items:center;gap:0;list-style:none}
.nav-menu a{font-family:var(--ss);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--txm);transition:color .2s;padding:8px 14px}
.nav-menu a:hover{color:var(--ve)}
.nav-cta{background:var(--ve)!important;color:white!important;border-radius:2px;padding:9px 18px!important;margin-left:8px;font-size:11px!important}
.nav-cta:hover{background:var(--ved)!important}

/* HEADER — foto olivo con texto superpuesto */
.site-header{
  position:relative;
  height:clamp(320px, 50vw, 560px);
  overflow:hidden;
  margin-top:68px;
}
.site-header-img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 35%;
  display:block;
  filter:brightness(.88);
}
.site-header-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(to right, rgba(42,38,32,.5) 0%, rgba(42,38,32,.1) 60%, rgba(42,38,32,0) 100%);
  display:flex;
  align-items:center;
}
.site-header-text{
  padding:0 var(--pd);
  max-width:var(--mx);
  margin:0 auto;
  width:100%;
}
.site-header-text .lbl{color:rgba(255,255,255,.65);margin-bottom:14px;display:block}
.site-header-text h1{
  font-family:var(--sd);
  font-size:clamp(40px,5.5vw,68px);
  font-weight:300;
  color:white;
  line-height:1.05;
  max-width:580px;
  margin-bottom:16px;
}
.site-header-text h1 em{font-style:italic;color:rgba(255,255,255,.8)}
.site-header-text p{
  font-family:var(--sb);
  font-size:clamp(15px,1.6vw,17px);
  color:rgba(255,255,255,.72);
  max-width:440px;
  line-height:1.6;
  margin-bottom:28px;
}
.hdr-btns{display:flex;gap:10px;flex-wrap:wrap}
.btn{display:inline-block;font-family:var(--ss);font-size:11px;letter-spacing:2px;text-transform:uppercase;padding:12px 26px;border-radius:2px;transition:all .22s}
.btn-v{background:var(--ve);color:white}
.btn-v:hover{background:var(--ved);transform:translateY(-1px)}
.btn-o{background:transparent;color:rgba(255,255,255,.85);border:1px solid rgba(255,255,255,.4)}
.btn-o:hover{border-color:rgba(255,255,255,.8);color:white}

/* FRANJA */
.franja{background:var(--ve)}
.franja-in{display:flex;overflow-x:auto;max-width:var(--mx);margin:0 auto}
.fi{flex:1;min-width:148px;padding:20px 22px;border-right:1px solid rgba(255,255,255,.15);text-align:center}
.fi:last-child{border-right:none}
.fi-v{font-family:var(--sd);font-size:22px;font-weight:300;color:white;line-height:1;margin-bottom:3px}
.fi-d{font-family:var(--ss);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.6)}

/* INTRO */
.intro{padding:96px 0;background:var(--bl)}
.intro-g{display:grid;grid-template-columns:55fr 45fr;gap:72px;align-items:center}
.intro-t h2{font-family:var(--sd);font-size:clamp(32px,3.8vw,50px);font-weight:300;line-height:1.1;color:var(--tx);margin:14px 0 24px}
.intro-t h2 em{font-style:italic;color:var(--ved)}
.intro-t p{font-size:17px;color:var(--txm);line-height:1.9;margin-bottom:16px}
.iw{position:relative}
.iw img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:2px;box-shadow:16px 20px 48px rgba(42,38,32,.12)}
.iw::after{content:'';position:absolute;bottom:-12px;left:-12px;width:48%;height:48%;background:var(--crd);z-index:-1;border-radius:2px}
.ic{margin-top:10px;font-family:var(--ss);font-size:11px;color:var(--txl);font-style:italic;text-align:center;letter-spacing:.3px}

/* DIFS */
.difs{padding:96px 0;background:var(--cr)}
.dif-hdr{display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-bottom:60px;align-items:end}
.dif-hdr h2{font-family:var(--sd);font-size:clamp(32px,3.8vw,50px);font-weight:300;color:var(--tx);line-height:1.1;margin-top:14px}
.dif-hdr p{font-family:var(--sb);font-size:16px;color:var(--txm);line-height:1.85}
.dif-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--crdd);border:1px solid var(--crdd);overflow:hidden;border-radius:2px}
.dif{background:var(--bl);padding:38px 34px;transition:background .3s}
.dif:hover{background:var(--cr)}
.dn{font-family:var(--sd);font-size:52px;font-weight:300;color:var(--crdd);line-height:1;display:block;margin-bottom:12px;transition:color .3s}
.dif:hover .dn{color:var(--vel);opacity:.38}
.dt{font-family:var(--sd);font-size:20px;font-weight:400;color:var(--tx);line-height:1.25;margin-bottom:9px}
.dp{font-family:var(--sb);font-size:16px;color:var(--txm);line-height:1.75}
.dtag{display:block;margin-top:14px;font-family:var(--ss);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--ve);padding-top:12px;border-top:1px solid var(--crdd)}

/* PAUSA */
.pausa{display:block;width:100%;height:clamp(240px,36vw,480px);object-fit:cover;object-position:center 40%}
.pausa-cap{background:var(--crd);text-align:center;padding:13px 24px;font-family:var(--sd);font-size:16px;font-style:italic;font-weight:300;color:var(--txm);letter-spacing:.3px}

/* ══ GALERÍA UNIFICADA ══ */
.gal{padding:96px 0;background:var(--bl)}
.gal-hdr{text-align:center;margin-bottom:52px}
.gal-hdr h2{font-family:var(--sd);font-size:clamp(30px,3.8vw,48px);font-weight:300;color:var(--tx);line-height:1.15;margin-top:14px}

.gal-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:3px;
}
/* Todos los items con altura fija para evitar distorsión */
.gi{
  overflow:hidden;cursor:pointer;
  background:var(--crd);
  position:relative;
  aspect-ratio:1/1;
}
.gi img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center center;
  transition:transform .55s ease;
  display:block;
  image-rendering:auto;
}
.gi:hover img{transform:scale(1.04)}
/* wide: 2 columnas, altura simple */
.g-wide{grid-column:span 2;aspect-ratio:16/9}
.g-lbl{
  position:absolute;bottom:0;left:0;right:0;
  padding:20px 14px 10px;
  background:linear-gradient(to top,rgba(42,38,32,.6),transparent);
  font-family:var(--ss);font-size:10px;letter-spacing:2px;
  text-transform:uppercase;color:rgba(255,255,255,.9);
  opacity:0;transition:opacity .3s;
}
.gi:hover .g-lbl{opacity:1}

/* LIGHTBOX */
.lb{display:none;position:fixed;inset:0;z-index:500;background:rgba(30,26,20,.96);align-items:center;justify-content:center;padding:16px}
.lb.open{display:flex}
.lb-img{max-width:94vw;max-height:90vh;object-fit:contain;border-radius:1px;image-rendering:auto}
.lbc{position:absolute;top:16px;right:20px;color:rgba(255,255,255,.55);font-size:22px;cursor:pointer;background:none;border:none;font-family:var(--ss);line-height:1;transition:color .2s;padding:4px}
.lbc:hover{color:white}
.lbp,.lbn{position:absolute;top:50%;transform:translateY(-50%);color:rgba(255,255,255,.4);background:none;border:none;font-size:44px;cursor:pointer;padding:16px;transition:color .2s;font-weight:300;font-family:var(--ss);line-height:1}
.lbp{left:4px}.lbn{right:4px}
.lbp:hover,.lbn:hover{color:white}
.lb-cap{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);font-family:var(--sd);font-size:15px;font-style:italic;color:rgba(255,255,255,.5);white-space:nowrap}
.lb-cnt{position:absolute;top:18px;left:50%;transform:translateX(-50%);font-family:var(--ss);font-size:10px;letter-spacing:2px;color:rgba(255,255,255,.35)}

/* RESEÑAS */
.res{padding:96px 0;background:var(--cr)}
.res-hdr{text-align:center;margin-bottom:52px}
.res-hdr h2{font-family:var(--sd);font-size:clamp(30px,3.8vw,48px);font-weight:300;color:var(--tx);margin-top:14px}
.res-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.rc{padding:30px 26px;border:1px solid var(--crdd);border-radius:2px;background:var(--bl);transition:border-color .3s,transform .3s}
.rc:hover{border-color:var(--ve);transform:translateY(-3px)}
.rc-stars{color:var(--or);font-size:13px;letter-spacing:2px;margin-bottom:14px}
.rc-txt{font-family:var(--sd);font-size:17px;font-weight:300;font-style:italic;line-height:1.65;color:var(--tx);margin-bottom:20px}
.rc-txt::before{content:'\201C';font-size:38px;color:var(--ve);opacity:.2;line-height:0;vertical-align:-13px;margin-right:2px;font-style:normal}
.rc-firma{padding-top:14px;border-top:1px solid var(--crdd)}
.rc-n{font-family:var(--ss);font-size:13px;color:var(--tx);margin-bottom:2px}
.rc-f{font-family:var(--ss);font-size:11px;color:var(--txl);font-weight:300}
.res-cta{text-align:center;margin-top:36px}
.res-cta a{font-family:var(--ss);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--ved);border-bottom:1px solid var(--ve);padding-bottom:3px;transition:opacity .2s}
.res-cta a:hover{opacity:.6}

/* PARA QUIÉN */
.pq{padding:96px 0;background:var(--bl)}
.pq-hdr{margin-bottom:52px}
.pq-hdr h2{font-family:var(--sd);font-size:clamp(30px,3.8vw,48px);font-weight:300;color:var(--tx);line-height:1.1;max-width:380px;margin-top:14px}
.pq-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.pq-card{padding:34px 30px;background:var(--bl);border:1px solid var(--crdd);border-radius:2px;transition:border-color .3s,box-shadow .3s}
.pq-card:hover{border-color:var(--vel);box-shadow:0 4px 20px rgba(90,80,50,.06)}
.pq-lbl{font-family:var(--ss);font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--ve);margin-bottom:8px;display:block}
.pq-tit{font-family:var(--sd);font-size:21px;font-weight:400;color:var(--tx);margin-bottom:9px;line-height:1.2}
.pq-txt{font-family:var(--sb);font-size:16px;color:var(--txm);line-height:1.75}

/* RESERVA */
.rsv{padding:96px 0;background:var(--cr)}
.rsv-in{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.rsv-l h2{font-family:var(--sd);font-size:clamp(30px,3.8vw,48px);font-weight:300;color:var(--tx);line-height:1.1;margin:14px 0 20px}
.rsv-p{font-family:var(--sb);font-size:16px;color:var(--txm);line-height:1.85;margin-bottom:22px}
.rsv-ul{list-style:none;margin-bottom:28px}
.rsv-ul li{font-family:var(--sb);font-size:16px;color:var(--txm);padding:10px 0;border-bottom:1px solid var(--ln);display:flex;gap:12px;align-items:baseline}
.rsv-ul li::before{content:'—';color:var(--ve);flex-shrink:0}
.rsv-ul li:last-child{border-bottom:none}
.rsv-btns{display:flex;flex-direction:column;gap:9px}
.btn-em{background:var(--ve);color:white;text-align:center;font-size:11px;letter-spacing:2px}
.btn-em:hover{background:var(--ved);transform:translateY(-1px)}
.btn-ws{background:var(--bl);color:var(--ved);border:1px solid var(--ve);text-align:center;font-size:11px;letter-spacing:2px}
.btn-ws:hover{background:var(--crd)}
.rsv-ab{font-family:var(--ss);font-size:11px;color:var(--txl);text-align:center;padding:7px 0;transition:color .2s}
.rsv-ab:hover{color:var(--ved)}
.tar-card{border:1px solid var(--crdd);border-radius:2px;overflow:hidden;box-shadow:0 2px 14px rgba(42,38,32,.06)}
.tar-row{display:flex;justify-content:space-between;align-items:center;padding:17px 20px;border-bottom:1px solid var(--crdd);gap:14px;transition:background .2s}
.tar-row:hover{background:var(--cr)}
.tar-row:last-of-type{border-bottom:none}
.tar-row.alta{background:var(--ve)}
.tar-row.alta:hover{background:var(--ved)}
.tar-nom{font-family:var(--sb);font-size:16px;color:var(--tx);margin-bottom:2px}
.tar-row.alta .tar-nom{color:white}
.tar-per{font-family:var(--ss);font-size:11px;color:var(--txl)}
.tar-row.alta .tar-per{color:rgba(255,255,255,.55)}
.tar-prec{text-align:right;flex-shrink:0}
.tar-prec strong{display:block;font-family:var(--sd);font-size:22px;font-weight:300;color:var(--ved);line-height:1}
.tar-row.alta .tar-prec strong{color:white}
.tar-prec span{font-family:var(--ss);font-size:10px;color:var(--txl)}
.tar-row.alta .tar-prec span{color:rgba(255,255,255,.5)}
.tar-nota{padding:11px 20px;background:var(--cr);font-family:var(--ss);font-size:11px;color:var(--txl);text-align:center;font-style:italic;border-top:1px solid var(--crdd);line-height:1.5}

/* UBICACIÓN */
.ub{padding:96px 0;background:var(--bl)}
.ub-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;margin-top:44px}
.ub-l h2{font-family:var(--sd);font-size:clamp(28px,3.5vw,44px);font-weight:300;color:var(--tx);margin:14px 0 16px;line-height:1.15}
.ub-l p{font-family:var(--sb);font-size:16px;color:var(--txm);line-height:1.85;margin-bottom:12px}
.dists{list-style:none;margin-top:22px}
.di{display:flex;justify-content:space-between;align-items:baseline;padding:11px 0;border-bottom:1px solid var(--ln);gap:14px}
.di:last-child{border-bottom:none}
.di-l{font-family:var(--sb);font-size:16px;color:var(--tx)}
.di-d{font-family:var(--sd);font-size:16px;font-style:italic;color:var(--ve);white-space:nowrap;font-weight:300}
.ub-nota{margin-top:18px;padding:15px 17px;border-left:3px solid var(--ve);background:var(--cr);font-family:var(--sb);font-size:16px;color:var(--txm);line-height:1.7;font-style:italic}
.mapas{display:flex;flex-direction:column;gap:12px}
.mapa-gmap{width:100%;aspect-ratio:4/3;border-radius:2px;overflow:hidden;box-shadow:0 4px 18px rgba(42,38,32,.08)}
.mapa-gmap iframe{width:100%;height:100%;border:none;display:block}
/* Placeholder mientras no haya API key de Google Maps */
.mapa-ph{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;width:100%;height:100%;text-align:center;padding:24px;background:var(--cr);color:var(--txm);transition:background .25s}
.mapa-ph:hover{background:var(--crd)}
.mapa-ph-pin{font-size:34px;line-height:1}
.mapa-ph-t{font-family:var(--sb);font-size:16px;color:var(--tx)}
.mapa-ph-s{font-family:var(--ss);font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--ved)}
.mapa-dl{display:block;overflow:hidden;border-radius:2px;position:relative}
.mapa-dl img{width:100%;display:block;transition:transform .4s}
.mapa-dl:hover img{transform:scale(1.02)}
.mapa-dl-lbl{position:absolute;bottom:0;left:0;right:0;background:rgba(42,38,32,.65);padding:10px 14px;font-family:var(--ss);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.85);text-align:center}

/* FOOTER */
footer{background:var(--cr);border-top:1px solid var(--crdd);padding:52px 0 30px}
.ft{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;margin-bottom:36px}
.ft-brand{font-family:var(--sd);font-size:24px;font-weight:300;color:var(--tx);margin-bottom:8px;display:flex;align-items:center;gap:8px}
.ft-brand svg{width:17px;height:17px}
.ft-tag{font-family:var(--sb);font-size:13px;font-style:italic;color:var(--txl);line-height:1.65;margin-bottom:16px}
.ft-cont a{display:block;font-family:var(--ss);font-size:13px;color:var(--txm);margin-bottom:6px;transition:color .2s;font-weight:300}
.ft-cont a:hover{color:var(--ved)}
.ft-col h4{font-family:var(--ss);font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--txl);margin-bottom:14px}
.ft-col ul{list-style:none}
.ft-col li{margin-bottom:8px}
.ft-col a{font-family:var(--ss);font-size:13px;color:var(--txm);transition:color .2s;font-weight:300}
.ft-col a:hover{color:var(--ved)}
.ft-b{border-top:1px solid var(--crdd);padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}
.ft-copy,.ft-lic{font-family:var(--ss);font-size:11px;color:var(--txl);font-weight:300}
.ft-lic{font-style:italic}

@media(max-width:860px){
  .nav-menu{display:none}
  .intro-g,.dif-hdr,.dif-grid,.rsv-in,.ub-grid,.ft{grid-template-columns:1fr;gap:32px}
  .res-grid,.pq-grid{grid-template-columns:1fr}
  .gal-grid{grid-template-columns:repeat(2,1fr)}
  .g-wide{grid-column:span 2}
  .franja-in{flex-wrap:wrap}
  .fi{flex:1 1 50%;border-right:none;border-bottom:1px solid rgba(255,255,255,.15)}
  .site-header{height:clamp(280px,70vw,400px)}
}
