:root{
  --forest:#23402f;--forest-d:#162a1f;--pine:#36523f;--honey:#c58b3c;--honey-d:#a8722c;
  --cream:#f6f0e3;--sand:#ece2cd;--stone:#dccdb1;--line:#ddd0b6;--ink:#22251f;--muted:#7d7561;--white:#fffdf7;
  --shadow:0 26px 64px rgba(22,42,31,.20);--shadow-s:0 14px 34px rgba(22,42,31,.12)
}
*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;color:var(--ink);background:var(--cream);line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased}
h1,h2,h3,.serif{font-family:'Fraunces',serif;font-weight:500;line-height:1.08}
.it{font-style:italic}
img{display:block;max-width:100%}a{color:inherit;text-decoration:none}
.wrap{max-width:1200px;margin:0 auto;padding:0 26px}
.eyebrow{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:4px;text-transform:uppercase;color:var(--honey-d);font-weight:500;margin-bottom:16px}
.noise{position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.045;mix-blend-mode:overlay;
  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.8' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.btn{position:relative;display:inline-flex;align-items:center;gap:9px;overflow:hidden;background:var(--honey);color:#22251f;padding:14px 30px;border-radius:40px;font-weight:600;font-size:15px;transition:transform .3s cubic-bezier(.2,.8,.2,1),box-shadow .3s;border:none;cursor:pointer;z-index:0}
.btn .lbl{position:relative;z-index:2}
.btn:before{content:'';position:absolute;inset:0;background:var(--forest-d);transform:translateY(101%);transition:transform .4s cubic-bezier(.65,0,.35,1);z-index:1}
.btn:hover{transform:scale(1.03);box-shadow:0 14px 30px rgba(197,139,60,.4);color:var(--cream)}
.btn:hover:before{transform:translateY(0)}
.btn.ghost{background:transparent;border:1.4px solid rgba(255,255,255,.5);color:#fff}
.btn.ghost:before{background:rgba(255,255,255,.16)}.btn.ghost:hover{color:#fff}
.btn.dark{background:var(--forest)}.btn.dark{color:#fff}.btn.dark:before{background:var(--honey)}.btn.dark:hover{color:var(--ink)}
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:20px 0;transition:.4s}
nav.scr{background:rgba(246,240,227,.86);backdrop-filter:blur(14px);box-shadow:0 1px 0 rgba(0,0,0,.06);padding:12px 0}
nav.solid{background:rgba(246,240,227,.96);backdrop-filter:blur(14px);box-shadow:0 1px 0 rgba(0,0,0,.06)}
nav .row{display:flex;align-items:center;justify-content:space-between}
.logo{font-family:'Fraunces',serif;font-size:25px;font-weight:600;color:#fff;transition:.4s}
nav.scr .logo,nav.solid .logo{color:var(--forest)} .logo b{color:var(--honey);font-weight:600}
.navlinks{display:flex;gap:28px;align-items:center}
.navlinks a{color:rgba(255,255,255,.9);font-weight:500;font-size:14.5px}
nav.scr .navlinks a,nav.solid .navlinks a{color:var(--ink)} .navlinks a:hover{color:var(--honey-d)}
.navtoggle{display:none;background:none;border:0;cursor:pointer}
.hero{height:100vh;min-height:640px;display:flex;align-items:center;position:relative;overflow:hidden}
.hero.sub{height:80vh;min-height:560px}
.hero-bg{position:absolute;inset:0;background-position:center 40%;background-size:cover;z-index:-2;will-change:transform}
.hero:after{content:'';position:absolute;inset:0;background:linear-gradient(100deg,rgba(15,28,20,.84) 0%,rgba(22,42,31,.55) 48%,rgba(22,42,31,.28) 100%);z-index:-1}
.hero-content{color:#fff;max-width:780px}
.hero .chip{display:inline-flex;gap:9px;align-items:center;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.28);padding:7px 17px;border-radius:30px;font-size:13px;margin-bottom:24px;font-family:'IBM Plex Mono',monospace;letter-spacing:1px}
.hero h1{font-size:clamp(44px,7.6vw,86px);font-weight:500}.hero h1 .it{color:#e8c98a}
.hero.sub h1{font-size:clamp(40px,6.5vw,72px)}
.hero p{font-size:clamp(16px,2.1vw,20px);margin:24px 0 36px;max-width:580px;opacity:.93;font-weight:300}
.cta-row{display:flex;gap:14px;flex-wrap:wrap}
.scrollcue{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.7);font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:3px;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:8px}
.scrollcue i{width:1px;height:42px;background:linear-gradient(rgba(255,255,255,.7),transparent);animation:cue 2s infinite}
@keyframes cue{0%{opacity:0;transform:scaleY(.3)}50%{opacity:1}100%{opacity:0;transform:scaleY(1)}}
section{padding:104px 0}
.pitch{background:var(--forest);color:var(--cream);text-align:center;padding:58px 0}
.pitch .wrap{max-width:900px}.pitch .eyebrow{color:var(--honey)}
.pitch h2{font-size:clamp(26px,4vw,40px);font-weight:400}.pitch h2 .it{color:#e8c98a}
.pitch p{opacity:.82;font-size:16px;margin-top:14px}
.section-head{max-width:700px;margin:0 auto 56px;text-align:center}
.section-head h2{font-size:clamp(34px,5vw,56px)}.section-head p{color:var(--muted);margin-top:16px;font-size:17px}
.about-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.about-grid.rev{grid-template-columns:.95fr 1.05fr}
.about-figure{position:relative}
.about-figure img{border-radius:28px 28px 28px 4px;box-shadow:var(--shadow);width:100%;height:540px;object-fit:cover}
.about-txt h2{font-size:clamp(32px,4.4vw,50px);margin-bottom:20px}
.about-txt p{color:var(--muted);margin-bottom:16px;font-size:16.5px}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:30px}
.stat b{font-family:'Fraunces',serif;font-size:44px;color:var(--forest);display:block;line-height:1}
.stat small{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted)}
.specs{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.specs span{background:var(--white);border:1px solid var(--line);padding:9px 17px;border-radius:30px;font-size:14px;font-weight:500;box-shadow:var(--shadow-s)}
/* dos casas (home) */
.casas{background:var(--sand)}
.casa-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px}
.casa{display:block;background:var(--white);border:1px solid var(--line);border-radius:24px;overflow:hidden;box-shadow:var(--shadow-s);transition:.35s;cursor:pointer}
.casa:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.casa .ph{height:280px;overflow:hidden}
.casa .ph img{height:100%;width:100%;object-fit:cover;transition:.5s}
.casa:hover .ph img{transform:scale(1.05)}
.casa-body{padding:30px 32px 34px}
.casa h3{font-size:30px;margin-bottom:4px}
.casa .pax{font-family:'IBM Plex Mono',monospace;color:var(--honey-d);font-size:14px;letter-spacing:1px;margin-bottom:16px}
.casa ul{list-style:none}.casa li{display:flex;gap:10px;color:var(--muted);font-size:15px;padding:6px 0;border-top:1px solid var(--sand)}.casa li b{color:var(--ink);font-weight:600}
.casa .foot{display:flex;justify-content:space-between;align-items:center;margin-top:20px}
.casa .from{font-size:15px;color:var(--ink)}.casa .from b{font-family:'Fraunces',serif;font-size:26px;color:var(--forest)}
.casa .go{font-weight:600;color:var(--honey-d);display:inline-flex;align-items:center;gap:7px;transition:.3s}
.casa:hover .go{gap:12px}
.casa-note{text-align:center;color:var(--muted);font-size:14.5px;margin-top:30px}
/* family band */
.band{height:84vh;min-height:520px;position:relative;display:flex;align-items:center;overflow:hidden}
.band-bg{position:absolute;inset:0;background-position:center;background-size:cover;z-index:-2;will-change:transform}
.band:after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(15,28,20,.78),rgba(22,42,31,.2));z-index:-1}
.band-content{color:#fff;max-width:580px}.band .eyebrow{color:#e8c98a}
.band h2{font-size:clamp(36px,5.5vw,62px);font-weight:400}.band h2 .it{color:#e8c98a}
.band p{margin-top:18px;opacity:.92;font-weight:300;font-size:18px}
/* equipamiento */
.feats{background:var(--forest-d);color:var(--cream)}
.feats .section-head h2{color:#fff}.feats .section-head .eyebrow{color:var(--honey)}
.feat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08);border-radius:20px;overflow:hidden}
.feat{background:var(--forest-d);padding:34px 22px;text-align:center;transition:.35s}.feat:hover{background:var(--pine)}
.feat .ic{font-size:30px;margin-bottom:12px}.feat b{display:block;font-size:15px;font-weight:500}
/* room list (subpage) */
.rooms{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:6px}
.room{background:var(--white);border:1px solid var(--line);border-radius:18px;padding:24px 22px;box-shadow:var(--shadow-s)}
.room .ic{font-size:26px;margin-bottom:8px}
.room b{font-family:'Fraunces',serif;font-size:21px;display:block}
.room small{color:var(--muted);font-size:14px}
/* precios */
.precios{background:var(--cream)}
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;max-width:960px;margin:0 auto}
.pc{background:var(--white);border:1px solid var(--line);border-radius:22px;padding:32px 28px;box-shadow:var(--shadow-s);transition:.3s}
.pc:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.pc.feat-p{border:2px solid var(--honey)}
.pc h3{font-size:25px;margin-bottom:3px}.pc .cap{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:1px;color:var(--honey-d);margin-bottom:18px}
.pc .seasons{display:flex;flex-direction:column;gap:10px}
.pc .se{display:flex;justify-content:space-between;align-items:baseline;padding-bottom:9px;border-bottom:1px dashed var(--line)}
.pc .se span{color:var(--muted);font-size:14px}.pc .se b{font-family:'Fraunces',serif;font-size:26px;color:var(--forest)}.pc .se b small{font-size:13px;color:var(--muted);font-family:'Inter'}
.price-single{max-width:560px;margin:0 auto}
.price-note{text-align:center;color:var(--muted);font-size:14px;margin-top:24px}
/* galeria */
.gallery-sec{background:var(--sand)}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:210px;gap:14px}
.gallery img{width:100%;height:100%;object-fit:cover;border-radius:16px;cursor:pointer;transition:.4s}
.gallery img:hover{transform:scale(1.02);filter:brightness(1.05)}
.gallery .big{grid-column:span 2;grid-row:span 2}.gallery .wide{grid-column:span 2}
/* entorno */
.zona{background:var(--pine);color:var(--cream)}
.zona .section-head h2{color:#fff}.zona .section-head .eyebrow{color:#e8c98a}
.zona-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.zona-txt p{opacity:.9;margin-bottom:16px;font-weight:300;font-size:16.5px}
.acts{display:flex;flex-wrap:wrap;gap:9px;margin-top:6px}.acts span{background:rgba(255,255,255,.1);border-radius:24px;padding:7px 15px;font-size:14px}
.dist{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.dist .d{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:18px;padding:22px}
.dist .d b{font-family:'Fraunces',serif;font-size:30px;color:#e8c98a;display:block;line-height:1}
.dist .d small{font-size:12px;opacity:.85;letter-spacing:1px;font-family:'IBM Plex Mono',monospace}
/* cross-sell (subpage) */
.cross{background:var(--sand)}
.cross-card{display:grid;grid-template-columns:1fr 1.2fr;gap:0;background:var(--white);border:1px solid var(--line);border-radius:24px;overflow:hidden;box-shadow:var(--shadow-s);max-width:960px;margin:0 auto}
.cross-card img{width:100%;height:100%;min-height:260px;object-fit:cover}
.cross-body{padding:40px 42px}
.cross-body .eyebrow{margin-bottom:10px}
.cross-body h3{font-size:clamp(26px,3.5vw,36px);margin-bottom:10px}
.cross-body p{color:var(--muted);margin-bottom:22px}
/* reviews */
.reviews{background:var(--cream)}
.rev-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;max-width:960px;margin:0 auto}
.rev{background:var(--white);border:1px solid var(--line);border-radius:24px;padding:38px 36px;box-shadow:var(--shadow-s)}
.rev .stars{color:var(--honey);letter-spacing:3px;font-size:16px}
.rev p{font-family:'Fraunces',serif;font-style:italic;font-size:23px;line-height:1.42;margin:16px 0 18px;color:var(--ink)}
.rev .by{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:1px;color:var(--muted);text-transform:uppercase}
/* contacto */
.contacto{background:var(--sand)}
.cont-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:54px}
.cont-info .line{display:flex;gap:14px;align-items:center;margin-bottom:16px;font-size:16px}
.cont-info .line .ic{width:48px;height:48px;border-radius:50%;background:var(--forest);color:var(--honey);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:19px}
.cont-info small{color:var(--muted);display:block;font-size:13px}
form{background:var(--white);padding:34px;border-radius:26px;box-shadow:var(--shadow)}
form h3{font-family:'Fraunces',serif;font-size:28px;font-weight:600;margin-bottom:18px}
form label{display:block;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);margin:14px 0 6px}
form input,form select{width:100%;border:1.5px solid var(--line);border-radius:13px;padding:13px 15px;font-family:inherit;font-size:15px;background:var(--cream);transition:.2s}
form input:focus,form select:focus{outline:none;border-color:var(--honey)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:12px}form .btn{width:100%;justify-content:center;margin-top:20px;padding:16px}
.demo-note{background:#fbf3df;border:1px dashed var(--honey-d);color:#73561f;border-radius:12px;padding:12px 15px;font-size:13px;margin-top:16px}
footer{background:var(--forest-d);color:rgba(246,240,227,.75);padding:60px 0 34px}
.foot-grid{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px}
footer .logo{color:#fff;font-size:30px;margin-bottom:10px}
.status{display:inline-flex;align-items:center;gap:9px;font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:1px}
.status .dot{width:9px;height:9px;border-radius:50%;background:#5bd06a;animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(91,208,106,.6)}70%{box-shadow:0 0 0 10px rgba(91,208,106,0)}100%{box-shadow:0 0 0 0 rgba(91,208,106,0)}}
.foot-copy{font-size:12px;opacity:.55;margin-top:28px;text-align:center;font-family:'IBM Plex Mono',monospace;letter-spacing:.5px}
.sticky{position:fixed;bottom:0;left:0;right:0;z-index:90;display:none}.sticky a{flex:1;text-align:center;padding:16px;color:#fff;font-weight:700}.sticky .c{background:var(--forest)}.sticky .w{background:#25d366}
.lightbox{position:fixed;inset:0;background:rgba(14,20,15,.96);z-index:200;display:none;align-items:center;justify-content:center}.lightbox.on{display:flex}.lightbox img{max-width:90vw;max-height:86vh;border-radius:8px}
.lb-x{position:absolute;top:22px;right:30px;color:#fff;font-size:40px;cursor:pointer}.lb-a{position:absolute;top:50%;transform:translateY(-50%);color:#fff;font-size:46px;cursor:pointer;padding:18px;opacity:.75}.lb-a:hover{opacity:1}.lb-p{left:6px}.lb-n{right:6px}
.reveal{opacity:0;transform:translateY(40px);transition:.9s cubic-bezier(.2,.7,.2,1)}.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.12s}.reveal.d2{transition-delay:.24s}.reveal.d3{transition-delay:.36s}
@media(max-width:900px){
  .navlinks{position:fixed;top:0;right:-100%;height:100vh;width:78%;background:var(--forest-d);flex-direction:column;justify-content:center;transition:.45s;z-index:120}.navlinks.open{right:0}.navlinks a{color:#fff;font-size:21px}
  .navtoggle{display:block;z-index:130}.navtoggle span{display:block;width:27px;height:2px;background:#fff;margin:6px 0}nav.scr .navtoggle span,nav.solid .navtoggle span{background:var(--forest)}
  .about-grid,.about-grid.rev,.cont-grid,.zona-grid,.casa-grid,.rev-grid,.cross-card{grid-template-columns:1fr}.about-figure img{height:380px}.about-figure{margin-bottom:18px}
  .stats{grid-template-columns:repeat(2,1fr);gap:24px}
  .feat-grid,.price-grid,.rooms{grid-template-columns:repeat(2,1fr)}.price-grid{gap:16px}
  .gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px}.gallery .big,.gallery .wide{grid-column:span 2;grid-row:span 1}
  section{padding:74px 0}.band{height:74vh}.sticky{display:flex}body{padding-bottom:52px}
}
