
:root{
  --bg:#f7f5f1;
  --surface:#ffffff;
  --ink:#1f2328;
  --muted:#636b74;
  --line:#e7e2da;
  --brand:#6b6258; /* inspired by favicon */
  --brand-2:#8d857a;
  --accent:#c0b39f;
  --shadow:0 12px 30px rgba(31,35,40,.08);
  --radius:18px;
  --radius-sm:12px;
  --container:min(1120px, calc(100% - 2rem));
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
}
img{max-width:100%; display:block}
a{color:var(--brand); text-decoration:none}
a:hover{text-decoration:underline}
.container{width:var(--container); margin-inline:auto}
.skip-link{
  position:absolute; left:-9999px; top:0; background:#000; color:#fff; padding:.5rem .75rem; z-index:9999;
}
.skip-link:focus{left:1rem; top:1rem}

.site-header{
  position:sticky; top:0; z-index:50;
  backdrop-filter:saturate(1.1) blur(8px);
  background:rgba(247,245,241,.85);
  border-bottom:1px solid rgba(231,226,218,.7);
}
.header-wrap{display:flex; align-items:center; justify-content:space-between; gap:1rem; min-height:72px}
.brand{display:flex; align-items:center; gap:.7rem; color:inherit; text-decoration:none}
.brand img{border-radius:8px; box-shadow:0 2px 8px rgba(0,0,0,.12)}
.brand span{display:flex; flex-direction:column; line-height:1.1}
.brand strong{font-size:.95rem}
.brand small{color:var(--muted); font-size:.74rem; letter-spacing:.02em}

.main-nav ul{display:flex; align-items:center; list-style:none; padding:0; margin:0; gap:.35rem}
.main-nav a{
  display:inline-flex; align-items:center; justify-content:center;
  padding:.6rem .85rem; border-radius:999px; color:inherit; text-decoration:none; font-weight:500;
}
.main-nav a:hover{background:rgba(107,98,88,.08)}
.menu-toggle{
  display:none; background:none; border:1px solid var(--line); border-radius:10px;
  padding:.45rem .65rem; font-size:1.15rem; cursor:pointer; color:var(--ink)
}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.4rem;
  border:none; border-radius:999px; padding:.85rem 1rem; font-weight:700; text-decoration:none; cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.btn:hover{text-decoration:none; transform:translateY(-1px)}
.btn-primary{background:var(--brand); color:#fff; box-shadow:0 8px 20px rgba(107,98,88,.25)}
.btn-primary:hover{background:#5d554d}
.btn-secondary{background:rgba(255,255,255,.96); color:var(--brand); border:1px solid rgba(255,255,255,.6)}
.btn-outline{border:1px solid var(--line); background:#fff; color:var(--ink)}
.btn-outline:hover{border-color:var(--brand); color:var(--brand)}
.btn-call{background:rgba(107,98,88,.1); color:var(--brand);}
.btn-block{width:100%}

.hero{
  position:relative;
  min-height:72svh;
  display:grid;
  align-items:center;
  overflow:hidden;
  border-bottom:1px solid var(--line);
}
.hero-bg{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
}
.hero-overlay{
  position:absolute; inset:0;
  background:
    linear-gradient(110deg, rgba(24,27,30,.72), rgba(24,27,30,.38) 45%, rgba(24,27,30,.12)),
    linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.36));
}
.hero-content{
  position:relative; z-index:2; color:#fff; padding:4.5rem 0 4.2rem;
  max-width:760px;
}
.eyebrow{
  text-transform:uppercase; letter-spacing:.14em; font-size:.74rem; font-weight:700;
  color:var(--accent); margin:0 0 .7rem;
}
.hero h1{
  margin:0;
  font-size:clamp(2rem, 4vw, 3.4rem);
  line-height:1.08;
  text-wrap:balance;
}
.hero h1 span{color:#f4ede1}
.hero-text{
  margin:1rem 0 1.35rem;
  max-width:58ch;
  color:rgba(255,255,255,.9);
  font-size:1.03rem;
}
.hero-actions{display:flex; flex-wrap:wrap; gap:.8rem}

.stats{
  display:grid; gap:1rem; grid-template-columns:repeat(3,1fr);
  margin-top:-2.1rem; position:relative; z-index:3;
}
.stat-card{
  background:rgba(255,255,255,.95); border:1px solid var(--line); border-radius:var(--radius);
  box-shadow:var(--shadow); padding:1rem 1rem;
}
.stat-number{
  display:block; color:var(--brand); font-weight:800; font-size:1.15rem; margin-bottom:.25rem;
}
.stat-card p{margin:0; color:var(--muted)}

.section{padding:4.3rem 0}
.section-soft{background:linear-gradient(180deg,#fbfaf8,#f5f2ed)}
.section-head{max-width:760px; margin-bottom:1.45rem}
.section-head h2{
  margin:.2rem 0 .35rem;
  font-size:clamp(1.5rem, 3vw, 2.15rem);
  line-height:1.15;
}
.section-head p:last-child{margin:0; color:var(--muted)}

.grid.cards{
  display:grid; gap:1rem; grid-template-columns:repeat(4,1fr);
}
.card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:1rem;
  box-shadow:0 8px 20px rgba(31,35,40,.04);
}
.card .icon{
  width:42px; height:42px; border-radius:12px; display:grid; place-items:center;
  background:rgba(107,98,88,.1); margin-bottom:.7rem; font-size:1.2rem;
}
.card h3{margin:0 0 .35rem; font-size:1rem}
.card p{margin:0; color:var(--muted); font-size:.96rem}

.gallery-grid{
  display:grid; gap:.8rem;
  grid-template-columns:repeat(4,1fr);
}
.gallery-item{
  border-radius:16px; overflow:hidden; border:1px solid var(--line); background:#fff;
  box-shadow:0 8px 20px rgba(31,35,40,.04);
  aspect-ratio:1 / .82;
}
.gallery-item img{
  width:100%; height:100%; object-fit:cover;
  transition:transform .45s ease;
}
.gallery-item:hover img{transform:scale(1.03)}
.gallery-item:focus-visible{outline:3px solid var(--brand); outline-offset:2px}

.social-grid{
  display:grid; gap:1rem; grid-template-columns:1fr 1fr;
}
.social-card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow);
  padding:1rem; display:grid; gap:1rem; align-content:start;
}
.social-head{display:flex; gap:.75rem; align-items:center}
.social-head h3{margin:0; font-size:1rem}
.social-head p{margin:0; color:var(--muted); font-size:.92rem}
.social-icon{
  width:40px; height:40px; border-radius:999px; display:grid; place-items:center;
  color:#1877f2; background:rgba(24,119,242,.08);
}
.social-icon.insta{
  color:#c13584; background:rgba(193,53,132,.09);
}
.fb-wrapper{
  border:1px solid var(--line); border-radius:12px; overflow:hidden;
  background:#f8f8f8; min-height:420px; display:grid; place-items:center;
}
.fb-wrapper iframe{width:100%; min-height:420px}
.social-placeholder{
  display:grid; gap:.8rem;
  border:1px solid var(--line); border-radius:12px; background:#fbfbfb; padding:.8rem;
}
.social-placeholder img{
  width:100%; border-radius:10px; aspect-ratio:16/10; object-fit:cover; border:1px solid var(--line)
}
.social-placeholder p{margin:0; color:var(--muted)}

.two-col{
  display:grid; gap:1rem; grid-template-columns:1fr 1.15fr; align-items:start;
}
.address{font-size:1.05rem; margin-top:.5rem}
.contact-quick{display:flex; flex-wrap:wrap; gap:.7rem; margin-top:1rem}
.map-wrap{
  border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; background:#fff; box-shadow:var(--shadow);
}
.map-wrap iframe{width:100%; min-height:340px; border:0; display:block}

.contact-layout{align-items:start}
.contact-list{
  margin:.8rem 0 0; padding:0; list-style:none; display:grid; gap:.4rem
}
.contact-list a{font-weight:600}
.contact-form{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  box-shadow:var(--shadow); padding:1rem;
}
.field{display:grid; gap:.35rem; margin-bottom:.8rem}
.field label{font-weight:600}
.field input, .field textarea{
  width:100%; border:1px solid #d7d1c7; border-radius:12px;
  padding:.8rem .9rem; background:#fff; color:var(--ink); font:inherit;
}
.field input:focus, .field textarea:focus{
  outline:2px solid rgba(107,98,88,.18); border-color:var(--brand);
}
.form-note{margin:.7rem 0 0; color:var(--muted); font-size:.9rem}

.site-footer{
  background:#1f2328; color:#eef0f3; margin-top:1rem;
}
.footer-grid{
  display:grid; grid-template-columns:1.2fr 1fr 1fr; gap:1rem;
  padding:2.2rem 0 1.3rem;
}
.site-footer h3,.site-footer h4{margin:0 0 .55rem}
.site-footer h3{font-size:1.05rem}
.site-footer p{margin:0; color:#c9d1d9}
.site-footer ul{list-style:none; padding:0; margin:0; display:grid; gap:.35rem}
.site-footer a{color:#f3f4f6}
.site-footer a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08)}
.footer-bottom-wrap{
  display:flex; flex-wrap:wrap; gap:.6rem 1rem; justify-content:space-between;
  padding:.8rem 0 1.1rem;
}
.footer-bottom small{color:#c7cbd1}

.whatsapp-float{
  position:fixed; right:16px; bottom:16px; z-index:70;
  background:#25D366; color:#fff; border-radius:999px; padding:.75rem .95rem;
  box-shadow:0 14px 30px rgba(37,211,102,.35);
  display:inline-flex; align-items:center; gap:.45rem; font-weight:700;
}
.whatsapp-float:hover{text-decoration:none; transform:translateY(-1px)}

.lightbox{
  position:fixed; inset:0; z-index:100; background:rgba(15,16,18,.92);
  display:none; align-items:center; justify-content:center; padding:1rem;
}
.lightbox.open{display:flex}
.lightbox-figure{
  margin:0; max-width:min(1100px, 92vw); max-height:88vh;
  display:grid; gap:.6rem; justify-items:center;
}
.lightbox img{
  max-width:100%; max-height:78vh; border-radius:14px; border:1px solid rgba(255,255,255,.15);
  box-shadow:0 20px 40px rgba(0,0,0,.35);
}
.lightbox figcaption{color:#e7eaef; text-align:center}
.lightbox-close, .lightbox-nav{
  position:absolute; border:none; color:#fff; background:rgba(255,255,255,.12);
  width:44px; height:44px; border-radius:999px; cursor:pointer; display:grid; place-items:center;
  font-size:1.4rem;
}
.lightbox-close{top:16px; right:16px}
.lightbox-nav{top:50%; transform:translateY(-50%); font-size:1.8rem}
.lightbox-nav.prev{left:12px}
.lightbox-nav.next{right:12px}

.reveal{
  opacity:0; transform:translateY(14px);
  transition:opacity .55s ease, transform .55s ease;
}
.reveal.is-visible{opacity:1; transform:none}

@media (max-width: 980px){
  .grid.cards{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
  .stats{grid-template-columns:1fr; margin-top:1rem}
  .hero{min-height:66svh}
  .social-grid{grid-template-columns:1fr}
  .two-col{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 720px){
  .menu-toggle{display:inline-flex; align-items:center; justify-content:center}
  .main-nav{position:relative}
  .main-nav ul{
    position:absolute; top:calc(100% + .5rem); right:0; min-width:240px;
    background:rgba(255,255,255,.98); border:1px solid var(--line); box-shadow:var(--shadow);
    border-radius:14px; padding:.45rem; display:none; flex-direction:column; align-items:stretch;
  }
  .main-nav ul.open{display:flex}
  .main-nav a{justify-content:flex-start; border-radius:10px}
  .main-nav a.btn-call{justify-content:center}
  .hero-content{padding:4rem 0 3rem}
  .hero-actions .btn{width:100%}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom-wrap{justify-content:center; text-align:center}
  .whatsapp-float span{display:none}
}
@media (max-width: 420px){
  .section{padding:3.4rem 0}
  .gallery-grid{grid-template-columns:1fr 1fr; gap:.55rem}
  .gallery-item{border-radius:12px}
  .grid.cards{grid-template-columns:1fr}
}
