:root{
  --wine:#7b0f18;
  --wine-dark:#4f080e;
  --gold:#c8913d;
  --wood:#a66b35;
  --ink:#1d1b1a;
  --muted:#67615c;
  --cream:#f7f3ed;
  --white:#fff;
  --line:rgba(29,27,26,.12);
  --page-pad:clamp(20px,5vw,88px);
  --header-h:clamp(76px,8vw,92px);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:var(--header-h)}
body{font-family:Inter,system-ui,sans-serif;color:var(--ink);background:var(--cream);line-height:1.6;overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block;height:auto}

.header{
  position:fixed;
  top:0;
  left:0;
  width:100%;
  min-height:var(--header-h);
  z-index:50;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:clamp(12px,1.5vw,20px) var(--page-pad);
  background:rgba(247,243,237,.88);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--line);
}
.logo{display:flex;flex-direction:column;line-height:.9;color:var(--wine);font-weight:800;letter-spacing:.08em;cursor:pointer;flex:0 0 auto}
.logo span{font-size:clamp(28px,2.2vw,34px)}
.logo small{font-size:clamp(10px,.8vw,12px);letter-spacing:.42em;color:#3c2b2b;text-align:center;margin-top:4px}
.nav{display:flex;align-items:center;gap:clamp(14px,2vw,28px);font-size:clamp(12px,.9vw,14px);font-weight:700;text-transform:uppercase;letter-spacing:.06em;flex-wrap:wrap;justify-content:flex-end}
.nav a{color:#332b28;white-space:nowrap}
.nav a:hover{color:var(--wine)}
.nav-cta{padding:clamp(10px,1vw,12px) clamp(15px,1.5vw,18px);border:1px solid var(--wine);border-radius:999px;color:var(--wine)!important}
.menu-toggle{display:none;background:transparent;border:0;font-size:28px;color:var(--wine)}

.hero{
  min-height:clamp(620px,100svh,920px);
  padding:calc(var(--header-h) + clamp(34px,4vw,56px)) var(--page-pad) clamp(52px,7vw,86px);
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(360px,clamp(420px,42vw,760px));
  gap:clamp(28px,4vw,58px);
  align-items:center;
  position:relative;
  overflow:hidden;
}
.hero-bg{position:absolute;inset:0;background:radial-gradient(circle at 18% 20%,rgba(200,145,61,.22),transparent 33%),linear-gradient(135deg,#fff 0%,#f7f3ed 50%,#eadfce 100%);z-index:-2}
.hero-bg:after{content:"";position:absolute;right:-8vw;top:10%;width:clamp(420px,48vw,860px);height:min(78%,720px);background:var(--wine);border-radius:80px 0 0 80px;z-index:-1;opacity:.95}
.hero-content{max-width:clamp(520px,44vw,760px);min-width:0}
.eyebrow{font-size:clamp(12px,.9vw,13px);letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:800;margin-bottom:clamp(12px,1.4vw,16px)}
.hero h1,.section h2,.cta h2{font-family:'Playfair Display',serif;font-size:clamp(44px,5vw,78px);line-height:1.02;color:var(--wine-dark);max-width:100%}
.hero-text{font-size:clamp(17px,1.35vw,20px);color:var(--muted);max-width:620px;margin:clamp(18px,2vw,26px) 0 clamp(24px,2.6vw,34px)}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:clamp(13px,1.1vw,15px) clamp(20px,1.8vw,24px);border-radius:999px;font-weight:800;transition:.25s}
.btn.primary{background:var(--wine);color:#fff;box-shadow:0 16px 36px rgba(123,15,24,.22)}
.btn.primary:hover{transform:translateY(-2px);background:var(--wine-dark)}
.btn.secondary{border:1px solid var(--line);background:rgba(255,255,255,.55);color:var(--wine)}
.hero-card{width:100%;max-width:760px;justify-self:end;border-radius:clamp(28px,3vw,42px);overflow:hidden;box-shadow:0 24px 70px rgba(31,23,18,.24);transform:rotate(1deg)}
.hero-card img{width:100%;height:clamp(340px,43vw,620px);object-fit:cover;object-position:center}

.strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1px;background:var(--line);padding:1px}
.strip article{background:#fff;padding:clamp(26px,2.4vw,34px) var(--page-pad) clamp(26px,2.4vw,34px) clamp(24px,2.5vw,34px)}
.strip strong{display:block;color:var(--wine);font-size:clamp(17px,1.2vw,18px);margin-bottom:8px}
.strip span{color:var(--muted)}
.section{padding:clamp(76px,8vw,110px) var(--page-pad)}
.about{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:clamp(32px,4.5vw,60px);align-items:center}
.section-text h2,.section-head h2,.cta h2{font-size:clamp(34px,4vw,54px)}
.section-text p,.section-head p,.cta p{color:var(--muted);font-size:clamp(17px,1.25vw,18px);max-width:760px;margin-top:18px}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.about-grid img{height:clamp(320px,35vw,470px);width:100%;object-fit:cover;border-radius:34px}
.about-grid img:first-child{margin-top:clamp(0px,4vw,60px)}
.dark{background:#211817;color:#fff}
.dark h2,.dark h3{color:#fff}
.dark .eyebrow{color:#e3ad59}
.cards{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;margin-top:36px}
.cards article{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);padding:clamp(24px,2vw,28px);border-radius:28px}
.cards span{color:var(--gold);font-weight:800}
.cards h3{margin:18px 0 10px}
.cards p{color:rgba(255,255,255,.72)}
.section-head{text-align:center;max-width:820px;margin:0 auto 44px}
.section-head h2,.section-head p{margin-left:auto;margin-right:auto}
.gallery{columns:3 280px;column-gap:18px}
.gallery img{width:100%;margin:0 0 18px;border-radius:26px;break-inside:avoid;box-shadow:0 16px 42px rgba(31,23,18,.12);cursor:pointer;transition:.25s}
.gallery img:hover{transform:scale(1.015)}
.process{background:#fff}
.timeline{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;margin-top:34px}
.timeline div{padding:clamp(24px,2vw,28px);border:1px solid var(--line);border-radius:26px;background:var(--cream)}
.timeline strong{color:var(--wine);font-size:18px}
.timeline p{color:var(--muted);margin-top:10px}

.contact-section{background:#fff}
.contact-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.contact-card{background:var(--cream);border:1px solid var(--line);border-radius:28px;padding:clamp(24px,2.2vw,30px)}
.contact-card span{display:block;color:var(--gold);font-size:13px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;margin-bottom:12px}
.contact-card strong{display:block;color:var(--wine-dark);font-size:clamp(19px,1.5vw,21px);line-height:1.25}
.contact-card p{color:var(--muted);margin:14px 0 18px}
.text-link{display:inline-flex;color:var(--wine);font-weight:800;border-bottom:1px solid rgba(123,15,24,.35)}
.text-link:hover{color:var(--wine-dark);border-color:var(--wine-dark)}

.cta{text-align:center;padding:clamp(82px,8vw,110px) var(--page-pad);background:linear-gradient(rgba(79,8,14,.84),rgba(79,8,14,.86)),url('assets/projeto-02.jpg') center/cover;color:#fff}
.cta h2{color:#fff;margin:auto}
.cta p{color:rgba(255,255,255,.82);margin:20px auto 32px}
.center{justify-content:center}
.cta .btn.secondary{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.32)}
.footer{display:flex;justify-content:space-between;align-items:center;gap:24px;padding:32px calc(var(--page-pad) + 160px) 32px var(--page-pad);background:#fff;color:var(--muted);border-top:1px solid var(--line)}
.footer-info{text-align:right}
.footer-address{font-size:14px;margin-top:4px}
.whatsapp{position:fixed;right:22px;bottom:22px;z-index:60;background:#25d366;color:#fff;font-weight:800;padding:15px 20px;border-radius:999px;box-shadow:0 16px 40px rgba(0,0,0,.22)}
.reveal{opacity:0;transform:translateY(26px);transition:.75s ease}
.reveal.visible{opacity:1;transform:none}
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.86);z-index:100;display:flex;align-items:center;justify-content:center;padding:28px}
.lightbox img{max-height:90vh;max-width:92vw;border-radius:24px}
.lightbox button{position:absolute;right:24px;top:22px;background:#fff;border:0;border-radius:999px;padding:10px 14px;font-size:20px;cursor:pointer}

@media(max-width:1280px){
  .hero{grid-template-columns:minmax(0,1fr) minmax(330px,44vw);gap:30px}
  .hero h1{font-size:clamp(42px,5.1vw,66px)}
  .hero-card img{height:clamp(320px,40vw,520px)}
  .nav{gap:16px}
}

@media(max-width:1050px){
  .nav{gap:14px;font-size:12px}
  .contact-grid{grid-template-columns:1fr 1fr}
  .location-card{grid-column:1/-1}
  .cards,.timeline{grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media(max-width:920px){
  .menu-toggle{display:block}
  .nav{position:absolute;top:calc(var(--header-h) - 6px);right:var(--page-pad);left:var(--page-pad);background:#fff;border:1px solid var(--line);border-radius:24px;padding:22px;display:none;flex-direction:column;align-items:flex-start;font-size:14px}
  .nav.open{display:flex}
  .hero{min-height:auto;grid-template-columns:1fr;padding-top:calc(var(--header-h) + 34px)}
  .hero-bg:after{display:none}
  .hero-content{max-width:760px}
  .hero-card{justify-self:start;max-width:720px;transform:none}
  .hero-card img{height:clamp(300px,58vw,460px)}
  .strip{grid-template-columns:1fr 1fr}
  .about{grid-template-columns:1fr}
  .about-grid img:first-child{margin-top:0}
  .footer{flex-direction:column;gap:14px;text-align:center;padding:32px var(--page-pad) 104px}
  .footer-info{text-align:center}
}

@media(max-width:640px){
  :root{--page-pad:18px;--header-h:78px}
  .hero h1{font-size:clamp(40px,13vw,54px)}
  .section{padding:76px var(--page-pad)}
  .strip,.cards,.timeline,.contact-grid{grid-template-columns:1fr}
  .location-card{grid-column:auto}
  .about-grid{grid-template-columns:1fr}
  .about-grid img{height:340px}
  .gallery{columns:1}
  .whatsapp{left:18px;right:18px;bottom:16px;text-align:center}
  .strip article{padding:26px}
  .hero-actions .btn{width:100%}
  .footer{padding-bottom:104px}
}
