:root{--c1:#9d5c63;--c1d:#7a444a;--ac:#c2992f;--bg:#faf6f4;--soft:#f4eae8;--ink:#3a2c2e;--muted:#8c757a;--serif:'Playfair Display',serif;--sans:'Jost',sans-serif}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);line-height:1.7;font-size:16.5px;font-weight:300}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.15;letter-spacing:.2px}
.kicker{font-family:var(--sans);text-transform:uppercase;letter-spacing:3px;font-size:12.5px;font-weight:600;color:var(--ac)}
.sect{padding:96px 0}
.sect-head{text-align:center;max-width:680px;margin:0 auto 54px}
.sect-head h2{font-size:clamp(30px,4.4vw,46px);margin-top:12px;color:var(--ink)}
.sect-head p{margin-top:16px;color:var(--muted)}
.hl{color:var(--c1)}
/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:60;transition:.35s}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:78px}
.nav .brand{font-family:var(--serif);font-size:23px;font-weight:700;color:#fff;transition:.35s}
.nav .links{display:flex;gap:30px;align-items:center}
.nav .links a{font-size:14.5px;font-weight:400;color:#fff;letter-spacing:.4px;transition:.3s;opacity:.92}
.nav .links a:hover{color:var(--ac)}
.nav .wabtn{background:var(--c1);color:#fff!important;padding:11px 24px;border-radius:50px;font-weight:500;font-size:14px}
.nav .wabtn:hover{background:var(--c1d)}
.nav.solid{background:#fff;box-shadow:0 6px 30px rgba(0,0,0,.07)}
.nav.solid .brand{color:var(--c1)}
.nav.solid .links a{color:var(--ink)}
.nav.solid .links a:hover{color:var(--c1)}
.hamb{display:none}
/* HERO */
.hero{height:100vh;min-height:620px;background-size:cover;background-position:center;position:relative;display:flex;align-items:center;text-align:center;color:#fff}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.35),rgba(0,0,0,.55))}
.hero-c{position:relative;z-index:2;max-width:820px;margin:0 auto;padding:0 24px}
.hero h1{font-size:clamp(40px,7vw,76px);color:#fff;margin:16px 0 18px;text-shadow:0 2px 24px rgba(0,0,0,.3)}
.hero p{font-size:clamp(16px,2.2vw,21px);font-weight:300;max-width:600px;margin:0 auto 30px;opacity:.95}
.hero .kicker{color:#fff;opacity:.9}
.btn{display:inline-block;padding:15px 36px;border-radius:50px;font-weight:500;font-size:15.5px;letter-spacing:.4px;transition:.3s;font-family:var(--sans)}
.btn-main{background:var(--c1);color:#fff;box-shadow:0 10px 30px rgba(0,0,0,.2)}
.btn-main:hover{background:var(--c1d);transform:translateY(-3px)}
.btn-ghost{border:1.5px solid rgba(255,255,255,.7);color:#fff;margin-left:12px}
.btn-ghost:hover{background:#fff;color:var(--ink)}
/* ABOUT */
.about{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.about-img{height:480px;border-radius:14px;background-size:cover;background-position:center;box-shadow:0 30px 60px rgba(0,0,0,.14)}
.about h2{font-size:clamp(28px,3.6vw,42px)}
.about .lead{color:var(--muted);margin:20px 0 26px}
.feats{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:14px 24px}
.feats li{position:relative;padding-left:30px;font-size:15px}
.feats li::before{content:"";position:absolute;left:0;top:7px;width:16px;height:16px;border-radius:50%;background:var(--ac)}
.feats li::after{content:"";position:absolute;left:5px;top:11px;width:6px;height:6px;border-radius:50%;background:#fff}
/* SERVICIOS */
.serv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.scard{background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 8px 30px rgba(0,0,0,.06);transition:.35s}
.scard:hover{transform:translateY(-8px);box-shadow:0 24px 50px rgba(0,0,0,.13)}
.scard .si{height:210px;background-size:cover;background-position:center}
.scard .sb{padding:26px 26px 30px}
.scard h3{font-size:22px;color:var(--c1)}
.scard p{color:var(--muted);font-size:14.5px;margin-top:10px}
/* GALERIA */
.gal{columns:3;column-gap:16px}
.gal a{display:block;margin-bottom:16px;border-radius:12px;overflow:hidden}
.gal img{width:100%;transition:.5s}
.gal a:hover img{transform:scale(1.06)}
/* CONTACTO */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:stretch}
.cinfo h2{font-size:clamp(28px,3.6vw,42px)}
.crow{display:flex;gap:16px;margin-top:24px;align-items:flex-start}
.crow .ci{width:46px;height:46px;flex:none;border-radius:50%;background:var(--soft);display:flex;align-items:center;justify-content:center;font-size:20px}
.crow b{font-family:var(--serif);font-size:17px;display:block;margin-bottom:2px}
.crow span{color:var(--muted);font-size:15px}
.cmap{border-radius:14px;overflow:hidden;min-height:420px;box-shadow:0 20px 50px rgba(0,0,0,.12)}
.cmap iframe{width:100%;height:100%;border:0;min-height:420px}
.csoc{display:flex;gap:14px;margin-top:26px}
.csoc a{width:44px;height:44px;border-radius:50%;background:var(--c1);color:#fff;display:flex;align-items:center;justify-content:center;transition:.3s}
.csoc a:hover{background:var(--c1d);transform:translateY(-3px)}
/* FOOTER */
.foot{background:var(--ink);color:#fff;padding:60px 0 28px;text-align:center}
.foot .fbrand{font-family:var(--serif);font-size:26px;font-weight:700}
.foot p{opacity:.7;margin-top:12px;font-size:14.5px;max-width:520px;margin-left:auto;margin-right:auto}
.foot .copy{margin-top:34px;padding-top:22px;border-top:1px solid rgba(255,255,255,.12);opacity:.55;font-size:13px}
/* WA FLOAT */
.wafloat{position:fixed;bottom:26px;right:26px;width:60px;height:60px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px rgba(37,211,102,.5);z-index:80;transition:.3s}
.wafloat:hover{transform:scale(1.1)}
/* ANIM */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media(max-width:900px){
 .about,.contact{grid-template-columns:1fr;gap:36px}.about-img{height:340px}
 .serv-grid{grid-template-columns:1fr 1fr}.gal{columns:2}
 .nav .links{position:fixed;inset:0 0 0 auto;width:78%;max-width:320px;background:#fff;flex-direction:column;justify-content:center;transform:translateX(100%);transition:.4s;box-shadow:-10px 0 40px rgba(0,0,0,.1)}
 .nav .links a{color:var(--ink)!important;font-size:18px}
 .nav.open .links{transform:none}
 .hamb{display:flex;flex-direction:column;gap:5px;z-index:70;cursor:pointer}
 .hamb span{width:26px;height:2px;background:#fff;transition:.3s}
 .nav.solid .hamb span,.nav.open .hamb span{background:var(--ink)}
}
@media(max-width:560px){.serv-grid{grid-template-columns:1fr}.gal{columns:1}.feats{grid-template-columns:1fr}}
