/*
Theme Name: MH Cabañas
Theme URI: https://mhcabanas.cl
Description: Tema custom para MH Cabañas - Melipilla
Version: 1.0
*/

:root{--miel:#865128;--tostada:#b77b47;--negro:#17120d;--crema:#efe9e3;--arena:#d3bcac;--terra:#c06a44;--gris:#8d7662;--wa:#25d366;--serif:'Cormorant',Georgia,serif;--sans:'Jost',system-ui,sans-serif}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--negro);background:var(--crema);font-weight:300;line-height:1.65;-webkit-font-smoothing:antialiased}
img{display:block;width:100%;height:100%;object-fit:cover}
h1,h2,h3{font-family:var(--serif);font-weight:400;line-height:1.05;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
.wrap{max-width:1280px;margin:0 auto;padding:0 32px}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:22px 40px;color:#fff;transition:all .4s ease;background:linear-gradient(180deg,rgba(23,18,13,.5),rgba(23,18,13,0))}
nav.solid{background:var(--negro);padding:14px 40px;box-shadow:0 1px 20px rgba(0,0,0,.15)}
.logo{font-family:var(--serif);font-size:24px;letter-spacing:.02em;display:inline-flex;align-items:center;gap:12px}
.logo b{font-weight:500}
.logo-ico{width:38px;height:38px;object-fit:contain;display:block}
.nav-cta{border:1px solid currentColor;padding:10px 26px;border-radius:40px;font-size:12px;letter-spacing:.16em;text-transform:uppercase;transition:.3s}
.nav-cta:hover{background:#fff;color:var(--negro)}

/* HERO */
.hero{position:relative;height:100vh;min-height:620px;overflow:hidden}
.hero img{position:absolute;inset:0;filter:brightness(.82)}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(23,18,13,.35),rgba(23,18,13,0) 30%,rgba(23,18,13,.55))}
.hero-content{position:absolute;left:0;right:0;bottom:9vh;z-index:2;color:#fff;padding:0 40px}
.hero-tag{font-size:12px;letter-spacing:.4em;text-transform:uppercase;opacity:.9;margin-bottom:22px;display:flex;align-items:center;gap:14px}
.hero-tag::before{content:"";width:46px;height:1px;background:#fff;opacity:.7}
.hero h1{font-size:clamp(3rem,9vw,8.5rem);color:#fff;max-width:14ch}
.scroll-hint{position:absolute;bottom:34px;right:40px;z-index:2;color:#fff;font-size:11px;letter-spacing:.2em;text-transform:uppercase;writing-mode:vertical-rl;opacity:.75}

/* INTRO */
.intro{padding:130px 0 90px;display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:start}
.intro .eyebrow{font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--miel);margin-bottom:26px}
.intro h2{font-size:clamp(2rem,4.2vw,3.6rem)}
.intro p{font-size:17px;color:#3a3027;max-width:46ch;margin-top:8px}
.intro p+p{margin-top:20px}
.stats{display:flex;gap:54px;margin-top:46px}
.stat b{font-family:var(--serif);font-size:2.8rem;font-weight:500;display:block;color:var(--miel);line-height:1}
.stat span{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--gris)}

/* GALLERY */
.gal-head{padding:60px 0 40px;display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:20px}
.gal-head h2{font-size:clamp(2rem,5vw,4rem)}
.gal-head p{font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--gris)}
.gallery{display:grid;grid-template-columns:repeat(12,1fr);gap:14px;padding-bottom:40px}
.gallery figure{overflow:hidden;position:relative}
.gallery img{transition:transform 1.1s cubic-bezier(.2,.8,.2,1)}
.gallery figure:hover img{transform:scale(1.05)}
.g-tall{grid-column:span 5;height:660px}
.g-wide{grid-column:span 7;height:660px}
.g-third{grid-column:span 4;height:440px}
.cap{position:absolute;left:18px;bottom:16px;color:#fff;font-size:12px;letter-spacing:.16em;text-transform:uppercase;text-shadow:0 1px 8px rgba(0,0,0,.5);z-index:2}

/* EXPERIENCE */
.exp{background:var(--negro);color:var(--crema);margin-top:40px;padding:120px 0;overflow:hidden}
.exp .wrap{display:grid;grid-template-columns:1.2fr 1fr;gap:80px;align-items:center}
.exp .eyebrow{font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--tostada);margin-bottom:24px}
.exp h2{font-size:clamp(2.2rem,4.6vw,3.8rem);color:#fff}
.exp p{color:#c9bcae;margin-top:22px;max-width:42ch}
.exp-list{margin-top:40px;display:grid;gap:2px}
.exp-list div{display:flex;justify-content:space-between;padding:18px 0;border-top:1px solid rgba(255,255,255,.12);font-size:14px}
.exp-list div:last-child{border-bottom:1px solid rgba(255,255,255,.12)}
.exp-list span{color:var(--tostada)}
.exp-img{height:560px;overflow:hidden}

/* REVIEWS */
.reviews{padding:120px 0}
.reviews .eyebrow{text-align:center;font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--miel);margin-bottom:14px}
.reviews h2{text-align:center;font-size:clamp(2rem,4.5vw,3.6rem);margin-bottom:64px}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.rev{background:#fff;padding:38px 34px;border:1px solid var(--arena);border-radius:2px}
.rev .stars{color:var(--terra);letter-spacing:3px;font-size:14px;margin-bottom:18px}
.rev p{font-family:var(--serif);font-size:20px;font-style:italic;line-height:1.5;color:#3a3027}
.rev-grid{align-items:start}
.rev .who{margin-top:24px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--gris)}
.rev-grid{transition:opacity .35s ease}
.rev-dots{display:flex;gap:10px;justify-content:center;margin-top:44px}
.rev-dots .dot{width:9px;height:9px;border-radius:50%;border:0;background:var(--arena);cursor:pointer;padding:0;transition:all .3s}
.rev-dots .dot.active{background:var(--miel);transform:scale(1.3)}


/* LOCATION */
.loc{background:var(--arena);padding:120px 0}
.loc .wrap{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center}
.loc .eyebrow{font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--miel);margin-bottom:22px}
.loc h2{font-size:clamp(2.2rem,4.6vw,3.8rem)}
.loc p{margin-top:20px;max-width:40ch;color:#4a3d30}
.map{height:420px;border:1px solid #b9a48c}
.map iframe{width:100%;height:100%;border:0}
.btn{display:inline-flex;align-items:center;gap:12px;margin-top:34px;background:var(--negro);color:#fff;padding:17px 34px;border-radius:40px;font-size:13px;letter-spacing:.14em;text-transform:uppercase;transition:.3s}
.btn:hover{background:var(--miel)}

/* FINAL CTA */
.final{background:var(--negro);color:#fff;text-align:center;padding:130px 0}
.final h2{font-size:clamp(2.4rem,6vw,5rem);max-width:18ch;margin:0 auto}
.final .btn{margin-top:40px;background:var(--terra)}
.final .btn:hover{background:#fff;color:var(--negro)}

/* FOOTER */
footer{background:#0f0b07;color:#9a8b7a;padding:60px 0 40px;font-size:13px}
footer .wrap{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px}
footer .logo{color:#fff}

/* ===== RESERVAS ===== */
.res-head{text-align:center;padding:130px 0 20px}
.res-head .eyebrow{font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--miel);margin-bottom:18px}
.res-head h1{font-size:clamp(2.6rem,6vw,4.6rem)}
.res-head p{color:var(--gris);margin-top:18px;max-width:48ch;margin-inline:auto}
.updated{display:inline-flex;align-items:center;gap:8px;margin-top:22px;font-size:12px;letter-spacing:.06em;color:var(--gris);background:#fff;border:1px solid var(--arena);padding:7px 16px;border-radius:40px}
.updated .dot{width:7px;height:7px;border-radius:50%;background:var(--wa)}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;padding:50px 0 110px}
.card{background:#fff;border:1px solid var(--arena);border-radius:6px;overflow:hidden;display:flex;flex-direction:column;transition:transform .4s,box-shadow .4s}
.card:hover{transform:translateY(-6px);box-shadow:0 24px 50px -20px rgba(23,18,13,.25)}
.card .ph{height:240px;overflow:hidden;position:relative}
.card .ph img{transition:transform 1s cubic-bezier(.2,.8,.2,1)}
.card:hover .ph img{transform:scale(1.06)}
.card .badge{position:absolute;top:14px;left:14px;background:rgba(23,18,13,.8);color:#fff;font-size:11px;letter-spacing:.12em;text-transform:uppercase;padding:6px 12px;border-radius:20px}
.card .cbody{padding:30px 28px 32px;display:flex;flex-direction:column;flex:1}
.card h3{font-size:1.9rem;margin-bottom:6px}
.card .desc{font-size:14px;color:var(--gris);margin-bottom:24px}
.price{display:flex;align-items:baseline;gap:8px;padding:20px 0;border-top:1px solid var(--crema);border-bottom:1px solid var(--crema)}
.price .amt{font-family:var(--serif);font-size:2.5rem;font-weight:500;color:var(--miel);line-height:1}
.price .per{font-size:13px;color:var(--gris)}
.feats{display:flex;flex-wrap:wrap;gap:8px;margin:22px 0 26px}
.feats span{font-size:12px;background:var(--crema);color:#5a4d3f;padding:6px 12px;border-radius:20px}
.acts{margin-top:auto;display:grid;gap:10px}
.b-wa{display:flex;align-items:center;justify-content:center;gap:10px;background:var(--wa);color:#fff;padding:15px;border-radius:40px;font-size:13px;letter-spacing:.1em;text-transform:uppercase;transition:.3s}
.b-wa:hover{background:#1da851}
.b-air{display:flex;align-items:center;justify-content:center;gap:10px;background:#fff;color:var(--negro);border:1px solid var(--negro);padding:14px;border-radius:40px;font-size:13px;letter-spacing:.1em;text-transform:uppercase;transition:.3s}
.b-air:hover{background:var(--negro);color:#fff}
.res-note{text-align:center;padding:0 0 90px;color:var(--gris);font-size:14px}
.res-note b{color:var(--negro);font-weight:400}

@media(max-width:880px){
  .nav-cta{font-size:11px;padding:8px 18px}
  .intro,.exp .wrap,.loc .wrap{grid-template-columns:1fr;gap:40px}
  .rev-grid{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .g-tall,.g-wide,.g-third{grid-column:span 2;height:340px}
  .exp-img{height:360px}
  .cards{grid-template-columns:1fr;gap:24px}
  nav{padding:18px 24px}
  .hero-content{padding:0 24px}
  .wrap{padding:0 24px}
}