/* Masia Moliner — Static styles */
:root{
  --bg:#f6f1e6; --fg:#3a322a; --muted:#7a6f60; --muted-bg:#ece4d3;
  --primary:#3d4a32; --primary-fg:#f6f1e6;
  --gold:#c9a35a; --gold-fg:#2c2418;
  --cream:#f1ead8; --border:#dcd2bd; --card:#fbf6ea;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;color:var(--fg);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:'Cormorant Garamond',Georgia,serif;font-weight:500;letter-spacing:-0.01em;line-height:1.1}
em{font-style:italic;color:var(--gold)}
.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}
.narrow{max-width:780px;margin:0 auto;padding:0 1.5rem}
.eyebrow{font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold)}
.btn{display:inline-block;padding:.85rem 1.6rem;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;border:1px solid transparent;border-radius:3px;cursor:pointer;transition:.25s;font-weight:500}
.btn-gold{background:var(--gold);color:var(--gold-fg)}
.btn-gold:hover{filter:brightness(1.08)}
.btn-primary{background:var(--primary);color:var(--primary-fg)}
.btn-primary:hover{background:#4a5a3e}
.btn-outline-light{border-color:#fff;color:#fff}
.btn-outline-light:hover{background:#fff;color:var(--fg)}
.btn-outline{border-color:var(--border);color:var(--fg)}
section{padding:6rem 0}
.bg-cream{background:var(--cream)}
.bg-primary{background:var(--primary);color:var(--primary-fg)}
.bg-primary .muted{color:rgba(246,241,230,.7)}

/* Header */
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;transition:.4s;background:rgba(246,241,230,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}
.site-header.transparent{background:transparent;border-color:transparent}
.site-header.transparent a,.site-header.transparent .logo{color:#f6f1e6}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.5rem;max-width:1280px;margin:0 auto}
.logo{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.6rem;letter-spacing:.05em}
.logo small{display:block;font-family:'Inter',sans-serif;font-style:normal;font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-top:2px}
.main-nav{display:none;gap:2.2rem}
.main-nav a{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;transition:.2s}
.main-nav a:hover,.main-nav a.active{color:var(--gold)}
.nav-cta{display:none}
.menu-btn{background:none;border:0;color:inherit;cursor:pointer;font-size:1.5rem;display:block}
.mobile-nav{display:none;background:var(--bg);border-top:1px solid var(--border);padding:1rem 1.5rem}
.mobile-nav.open{display:flex;flex-direction:column;gap:.5rem}
.mobile-nav a{padding:.7rem 0;font-size:.8rem;letter-spacing:.18em;text-transform:uppercase}
@media(min-width:880px){.main-nav,.nav-cta{display:flex}.menu-btn{display:none}.mobile-nav{display:none!important}}

/* Hero */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;color:#f6f1e6;overflow:hidden}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(40,33,26,.55),rgba(40,33,26,.35) 40%,rgba(40,33,26,.75));z-index:1}
.hero-content{position:relative;z-index:2;max-width:900px;padding:0 1.5rem}
.hero h1{font-size:clamp(2.6rem,6vw,5.5rem);margin:1.5rem 0}
.hero p{font-size:1.15rem;max-width:640px;margin:0 auto 2.5rem;color:rgba(246,241,230,.88)}
.hero .btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

.page-hero{position:relative;min-height:55vh;display:flex;align-items:center;color:#f6f1e6;padding-top:6rem}
.page-hero .hero-bg{filter:brightness(.65)}
.page-hero h1{font-size:clamp(2.2rem,5vw,4.5rem);margin:1rem 0}
.page-hero p{font-size:1.1rem;max-width:640px;color:rgba(246,241,230,.85)}

/* Section title */
.section-title{text-align:center;max-width:720px;margin:0 auto 3.5rem}
.section-title h2{font-size:clamp(2.2rem,4.5vw,3.6rem);margin-top:.6rem}
.section-title p{margin-top:1rem;color:var(--muted);font-size:1.05rem}
.bg-primary .section-title p{color:rgba(246,241,230,.75)}

/* Pillars */
.pillar{display:grid;gap:3rem;grid-template-columns:1fr;align-items:center;margin-bottom:6rem}
@media(min-width:780px){.pillar{grid-template-columns:1fr 1fr;gap:4rem}.pillar.reverse > div:first-child{order:2}}
.pillar-img{position:relative;aspect-ratio:4/5;overflow:hidden;border-radius:3px;box-shadow:0 20px 50px -20px rgba(0,0,0,.25)}
.pillar-img img{width:100%;height:100%;object-fit:cover;transition:1s}
.pillar-img:hover img{transform:scale(1.05)}
.badge{position:absolute;top:1.4rem;left:1.4rem;background:var(--gold);color:var(--gold-fg);padding:.5rem 1rem;font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;border-radius:3px}
.pillar h3{font-size:clamp(2rem,3.5vw,3rem);margin:.8rem 0 1.2rem}
.pillar-text p{color:var(--muted);font-size:1.08rem}
.pillar-text .link-arrow{display:inline-block;margin-top:1.5rem;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--primary)}
.pillar-text .link-arrow:hover{color:var(--gold)}

/* Gold divider */
.gold-divider{display:flex;align-items:center;gap:1rem;color:var(--gold);justify-content:center}
.gold-divider::before,.gold-divider::after{content:"";flex:1;max-width:160px;height:1px;background:linear-gradient(to right,transparent,var(--gold),transparent)}
.gold-divider span{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.6rem}

/* Experiences cards */
.exp-grid{display:grid;gap:2rem;grid-template-columns:1fr}
@media(min-width:780px){.exp-grid{grid-template-columns:1fr 1fr}}
.exp-card{background:var(--card);color:var(--fg);border-radius:3px;overflow:hidden}
.exp-card .exp-img{aspect-ratio:4/3;overflow:hidden}
.exp-card .exp-img img{width:100%;height:100%;object-fit:cover;transition:.7s}
.exp-card:hover .exp-img img{transform:scale(1.05)}
.exp-card .pad{padding:2rem}
.exp-card h3{font-size:1.8rem;margin:.5rem 0 1rem}
.exp-card p{color:var(--muted)}

/* CTA section */
.cta-section{position:relative;color:#f6f1e6;text-align:center;overflow:hidden}
.cta-section .hero-bg{filter:brightness(.55)}
.cta-section .hero-overlay{background:linear-gradient(135deg,rgba(40,33,26,.75),rgba(40,33,26,.55))}
.cta-section h2{font-size:clamp(2.2rem,5vw,4rem)}
.cta-section p{margin:1.5rem auto 2.5rem;max-width:600px;color:rgba(246,241,230,.85)}

/* Two col content */
.two-col{display:grid;gap:3rem;grid-template-columns:1fr;align-items:center}
@media(min-width:780px){.two-col{grid-template-columns:1fr 1fr;gap:4rem}.two-col.reverse > div:first-child{order:2}}
.two-col img{aspect-ratio:1/1;width:100%;height:100%;object-fit:cover;border-radius:3px;box-shadow:0 20px 50px -20px rgba(0,0,0,.25)}
.two-col h2{font-size:clamp(2rem,4vw,3rem);margin:1rem 0 1.2rem}
.two-col p{color:var(--muted);font-size:1.08rem;margin-bottom:1rem}
.two-col ul{list-style:none;margin-top:1.5rem}
.two-col ul li{display:flex;gap:.7rem;margin-bottom:.7rem}
.two-col ul li::before{content:"·";color:var(--gold);font-family:serif;font-size:1.4rem;line-height:1}

/* Cards (huerto, aceite) */
.card-grid{display:grid;gap:2rem;grid-template-columns:1fr}
@media(min-width:780px){.card-grid{grid-template-columns:1fr 1fr}}
.info-card{background:var(--card);border-radius:3px;overflow:hidden;box-shadow:0 6px 24px -12px rgba(0,0,0,.1)}
.info-card .info-img{aspect-ratio:4/3;overflow:hidden}
.info-card .info-img img{width:100%;height:100%;object-fit:cover}
.info-card .pad{padding:2rem}
.info-card h3{font-size:1.8rem;margin:.5rem 0 1rem}
.info-card p{color:var(--muted)}

/* Forms */
.form-grid{display:grid;gap:1.2rem;grid-template-columns:1fr}
@media(min-width:600px){.form-grid.two{grid-template-columns:1fr 1fr}}
label{display:block;font-size:.85rem;margin-bottom:.4rem;color:var(--fg);font-weight:500}
input,textarea,select{width:100%;padding:.75rem 1rem;border:1px solid var(--border);border-radius:3px;font:inherit;background:#fff;color:var(--fg)}
input:focus,textarea:focus,select:focus{outline:0;border-color:var(--gold)}
textarea{resize:vertical;min-height:120px}

/* Contact info */
.contact-grid{display:grid;gap:3.5rem;grid-template-columns:1fr}
@media(min-width:780px){.contact-grid{grid-template-columns:1fr 1fr;gap:4rem}}
.contact-info li{display:flex;gap:1rem;margin-bottom:1.6rem;list-style:none;align-items:flex-start}
.contact-info .ico{color:var(--gold);font-size:1.3rem;flex-shrink:0;margin-top:.2rem}
.contact-info p.title{font-family:'Cormorant Garamond',serif;font-size:1.2rem;color:var(--fg);margin-bottom:.2rem}
.contact-info p.val{color:var(--muted)}
.map-wrap{margin-top:2rem;aspect-ratio:4/3;border:1px solid var(--border);border-radius:3px;overflow:hidden}
.map-wrap iframe{width:100%;height:100%;border:0}

/* Reservas */
.reserva-step{margin-bottom:2.5rem}
.tipo-grid{display:grid;gap:1rem;grid-template-columns:1fr}
@media(min-width:600px){.tipo-grid{grid-template-columns:1fr 1fr}}
.tipo-opt{display:block;padding:1.5rem;border:2px solid var(--border);border-radius:3px;cursor:pointer;transition:.25s;background:#fff}
.tipo-opt:hover{border-color:var(--gold)}
.tipo-opt input{position:absolute;opacity:0}
.tipo-opt input:checked + .tipo-content{color:var(--fg)}
.tipo-opt:has(input:checked){border-color:var(--gold);background:rgba(201,163,90,.08);box-shadow:0 6px 18px -10px rgba(201,163,90,.4)}
.tipo-opt .t1{font-family:'Cormorant Garamond',serif;font-size:1.5rem}
.tipo-opt .t2{font-size:.88rem;color:var(--muted);margin-top:.2rem}

/* Footer */
.site-footer{background:var(--primary);color:var(--primary-fg);padding:4rem 0 0}
.footer-grid{display:grid;gap:3rem;grid-template-columns:1fr}
@media(min-width:780px){.footer-grid{grid-template-columns:2fr 1fr 1fr}}
.site-footer h4{font-size:1.1rem;color:var(--gold);margin-bottom:1rem}
.site-footer ul{list-style:none}
.site-footer ul li{margin-bottom:.5rem}
.site-footer a{color:rgba(246,241,230,.78);font-size:.92rem;transition:.2s}
.site-footer a:hover{color:var(--gold)}
.site-footer .desc{color:rgba(246,241,230,.7);font-size:.92rem;max-width:380px;margin-top:1rem}
.footer-bottom{border-top:1px solid rgba(246,241,230,.1);text-align:center;padding:1.5rem 1rem;margin-top:3rem;font-size:.78rem;color:rgba(246,241,230,.55)}
