:root{
  --navy:#0f2c4a;
  --navy-dark:#0a1f36;
  --green:#2d6b3f;
  --green-dark:#1f4d2c;
  --green-light:#e8f1ea;
  --bg:#f6f8fa;
  --text:#1f2937;
  --muted:#5b6b7a;
  --line:#e3e8ee;
  --white:#ffffff;
  --shadow:0 10px 30px rgba(15,44,74,.08);
  --radius:14px;
  --maxw:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter','Segoe UI',system-ui,-apple-system,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--navy);text-decoration:none}
a:hover{color:var(--green)}

/* ---------- HEADER ---------- */
.topbar{
  background:var(--navy-dark);
  color:#cfe0f2;
  font-size:.85rem;
}
.topbar .wrap{max-width:var(--maxw);margin:0 auto;padding:.5rem 1.25rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem}
.topbar a{color:#cfe0f2}
.topbar a:hover{color:#fff}

.header{
  background:#fff;
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:50;
}
.header .wrap{
  max-width:var(--maxw);margin:0 auto;padding:.9rem 1.25rem;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
}
.brand{display:flex;align-items:center;gap:.75rem;text-decoration:none}
.brand-logo{
  height:96px;width:auto;display:block;
}
@media (max-width:580px){ .brand-logo{height:72px} }

/* Logo no rodapé */
.footer-logo{
  width:160px;margin-bottom:.75rem;display:block;
  background:#fff;padding:.5rem .75rem;border-radius:8px;
}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-text .name{font-family:'Playfair Display',Georgia,serif;font-size:1.25rem;color:var(--navy);font-weight:700}
.brand-text .sub{font-size:.78rem;color:var(--muted);letter-spacing:.04em}

.nav{display:flex;gap:.25rem;align-items:center;flex-wrap:wrap}
.nav a{
  padding:.55rem .85rem;border-radius:8px;font-weight:500;color:var(--navy);font-size:.95rem;
}
.nav a:hover{background:var(--green-light);color:var(--green-dark)}
.nav a.active{background:var(--navy);color:#fff}

.nav-cta{
  background:var(--green);color:#fff !important;padding:.6rem 1rem;border-radius:8px;font-weight:600;
}
.nav-cta:hover{background:var(--green-dark);color:#fff !important}

.nav-toggle{display:none;background:none;border:0;font-size:1.6rem;color:var(--navy);cursor:pointer}

/* ---------- HERO ---------- */
.hero{
  position:relative;
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-dark) 100%);
  color:#fff;
  overflow:hidden;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 85% 30%, rgba(45,107,63,.35), transparent 55%);
  pointer-events:none;
}

/* Hero com imagem de fundo (página principal) — mantém paleta navy/verde */
.hero.hero-bg{
  background:
    linear-gradient(100deg, rgba(15,44,74,.94) 0%, rgba(15,44,74,.82) 40%, rgba(15,44,74,.55) 70%, rgba(15,44,74,.75) 100%),
    url('https://images.unsplash.com/photo-1571008887538-b36bb32f4571?auto=format&fit=crop&w=1920&q=80') center/cover no-repeat;
}
.hero.hero-bg::before{
  background:
    radial-gradient(circle at 90% 30%, rgba(45,107,63,.28), transparent 55%),
    linear-gradient(180deg, transparent 65%, rgba(10,31,54,.5) 100%);
}
@media (max-width: 900px){
  .hero.hero-bg{
    background:
      linear-gradient(180deg, rgba(15,44,74,.88) 0%, rgba(15,44,74,.8) 60%, rgba(15,44,74,.92) 100%),
      url('https://images.unsplash.com/photo-1571008887538-b36bb32f4571?auto=format&fit=crop&w=1200&q=80') center/cover no-repeat;
  }
}
.hero .wrap{
  max-width:var(--maxw);margin:0 auto;padding:5rem 1.25rem 5.5rem;
  display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:center;position:relative;
}
.hero h1{
  font-family:'Playfair Display',Georgia,serif;
  font-size:clamp(2rem,4vw,3.4rem);line-height:1.1;margin:0 0 1rem;
  font-weight:700;
}
.hero h1 .accent{color:#7fb98a;font-style:italic}
.hero p.lead{font-size:1.15rem;color:#dbe6f2;max-width:560px;margin:0 0 1.75rem}
.hero-ctas{display:flex;gap:.75rem;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.85rem 1.4rem;border-radius:10px;font-weight:600;font-size:1rem;
  border:0;cursor:pointer;transition:transform .15s ease, background .2s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--green);color:#fff}
.btn-primary:hover{background:var(--green-dark);color:#fff}
.btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.4)}
.btn-ghost:hover{background:rgba(255,255,255,.1);color:#fff}

.hero-card{
  background:rgba(255,255,255,.08);
  backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.18);
  border-radius:var(--radius);
  padding:1.75rem;
}
.hero-card h3{margin:0 0 1rem;font-size:1.05rem;letter-spacing:.05em;text-transform:uppercase;color:#a8d3b3}
.hero-card ul{list-style:none;padding:0;margin:0;display:grid;gap:.65rem}
.hero-card li{display:flex;gap:.7rem;align-items:flex-start;color:#e6eef8;font-size:.98rem}
.hero-card li::before{
  content:"";flex:0 0 18px;height:18px;border-radius:50%;
  background:var(--green);margin-top:.25rem;
  box-shadow:0 0 0 4px rgba(45,107,63,.25);
}

/* ---------- SECTIONS ---------- */
section{padding:4.5rem 1.25rem}
.section-wrap{max-width:var(--maxw);margin:0 auto}
.eyebrow{
  display:inline-block;font-size:.8rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--green);background:var(--green-light);
  padding:.35rem .8rem;border-radius:99px;margin-bottom:1rem;
}
h2{
  font-family:'Playfair Display',Georgia,serif;
  font-size:clamp(1.7rem,3vw,2.5rem);line-height:1.15;margin:0 0 .75rem;color:var(--navy);font-weight:700;
}
h2 .accent{color:var(--green);font-style:italic}
.section-lead{color:var(--muted);max-width:680px;font-size:1.05rem;margin:0 0 2.5rem}
.center{text-align:center}
.center .section-lead{margin:0 auto 2.5rem}

/* ---------- BENEFITS GRID ---------- */
.benefits{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.benefit{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.6rem;transition:transform .2s ease, box-shadow .2s ease;
}
.benefit:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.benefit .icon{
  width:52px;height:52px;border-radius:50%;
  background:var(--green);color:#fff;display:grid;place-items:center;
  font-size:1.4rem;margin-bottom:1rem;
}
.benefit h3{margin:0 0 .4rem;color:var(--navy);font-size:1.1rem}
.benefit p{margin:0;color:var(--muted);font-size:.95rem}

/* ---------- INDICATIONS PILLS ---------- */
.pills{display:flex;flex-wrap:wrap;gap:.6rem;margin:1rem 0 0}
.pill{
  background:#fff;border:1px solid var(--line);border-radius:99px;
  padding:.55rem 1rem;font-size:.92rem;color:var(--navy);font-weight:500;
}
.pill .dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--green);margin-right:.5rem;vertical-align:middle}

/* ---------- CTA BAND ---------- */
.cta-band{
  background:linear-gradient(120deg,var(--green) 0%,var(--green-dark) 100%);
  color:#fff;border-radius:var(--radius);
  padding:2.5rem;display:flex;justify-content:space-between;align-items:center;gap:1.5rem;flex-wrap:wrap;
  box-shadow:var(--shadow);
}
.cta-band h3{margin:0;font-family:'Playfair Display',serif;font-size:1.6rem}
.cta-band p{margin:.3rem 0 0;color:#dfeee3}
.cta-band .btn-primary{background:#fff;color:var(--green-dark)}
.cta-band .btn-primary:hover{background:#eaf3ec}

/* ---------- SERVICE CARDS ---------- */
.services{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.service{
  background:#fff;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line);display:flex;flex-direction:column;
  transition:transform .2s ease, box-shadow .2s ease;
}
.service:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.service-head{
  padding:1.75rem;background:linear-gradient(135deg,var(--navy),var(--navy-dark));color:#fff;
}
.service-head .tag{font-size:.78rem;letter-spacing:.15em;text-transform:uppercase;color:#a8d3b3}
.service-head h3{margin:.4rem 0 0;font-family:'Playfair Display',serif;font-size:1.45rem}
.service-body{padding:1.5rem 1.75rem;flex:1;display:flex;flex-direction:column;gap:1rem}
.service-body p{margin:0;color:var(--muted)}
.service-body ul{list-style:none;padding:0;margin:0;display:grid;gap:.5rem}
.service-body li{padding-left:1.4rem;position:relative;font-size:.95rem}
.service-body li::before{
  content:"";position:absolute;left:0;top:.55rem;width:8px;height:8px;border-radius:50%;background:var(--green)
}
.service-foot{padding:0 1.75rem 1.75rem}
.service-foot a{font-weight:600;color:var(--green-dark)}

/* ---------- AREAS ---------- */
.areas{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.area{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.75rem;text-align:center;
}
.area .city{
  font-family:'Playfair Display',serif;font-size:1.5rem;color:var(--navy);margin:0 0 .25rem
}
.area .state{color:var(--muted);font-size:.92rem;margin:0 0 1rem}
.area .marker{
  width:54px;height:54px;border-radius:50%;background:var(--green-light);color:var(--green-dark);
  display:grid;place-items:center;margin:0 auto 1rem;font-size:1.4rem
}

/* ---------- ABOUT ---------- */
.about{display:grid;grid-template-columns:.9fr 1.1fr;gap:3rem;align-items:center}
.about-photo{
  background:linear-gradient(135deg,var(--green-light),#fff);
  border-radius:var(--radius);min-height:380px;display:grid;place-items:center;
  border:1px solid var(--line);
  color:var(--green-dark);font-family:'Playfair Display',serif;font-size:1.2rem;
  padding:2rem;text-align:center;
}
.about p{color:var(--muted);font-size:1.02rem}
.about ul{padding-left:1.1rem;color:var(--muted)}
.about ul li{margin-bottom:.4rem}

/* ---------- FAQ ---------- */
.faq{max-width:780px;margin:0 auto;display:grid;gap:.75rem}
.faq details{
  background:#fff;border:1px solid var(--line);border-radius:12px;padding:1rem 1.25rem;
}
.faq summary{
  font-weight:600;color:var(--navy);cursor:pointer;list-style:none;
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
}
.faq summary::after{content:"+";font-size:1.4rem;color:var(--green);font-weight:400}
.faq details[open] summary::after{content:"−"}
.faq details[open]{box-shadow:var(--shadow)}
.faq p{margin:.75rem 0 0;color:var(--muted)}

/* ---------- CONTACT ---------- */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem}
.contact-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:2rem;
}
.contact-card h3{margin:0 0 1.25rem;font-family:'Playfair Display',serif;color:var(--navy);font-size:1.4rem}
.contact-item{display:flex;gap:1rem;align-items:flex-start;padding:.9rem 0;border-top:1px solid var(--line)}
.contact-item:first-of-type{border-top:0}
.contact-item .ico{
  width:42px;height:42px;border-radius:50%;background:var(--green-light);color:var(--green-dark);
  display:grid;place-items:center;flex:0 0 42px;font-size:1.1rem
}
.contact-item strong{display:block;color:var(--navy)}
.contact-item span{color:var(--muted);font-size:.95rem}

/* ---------- FOOTER ---------- */
footer{
  background:var(--navy-dark);color:#cfe0f2;padding:3rem 1.25rem 1.5rem;margin-top:2rem;
}
footer .wrap{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem}
footer h4{color:#fff;margin:0 0 .8rem;font-size:1rem;letter-spacing:.05em}
footer p, footer a{color:#cfe0f2;font-size:.92rem;margin:.25rem 0}
footer a:hover{color:#fff}
footer ul{list-style:none;padding:0;margin:0}
footer ul li{margin:.3rem 0}
.copy{
  border-top:1px solid rgba(255,255,255,.1);max-width:var(--maxw);margin:2rem auto 0;
  padding-top:1rem;font-size:.82rem;color:#8aa0b8;text-align:center;
}

/* ---------- WHATSAPP FLOAT ---------- */
.wa-float{
  position:fixed;right:1.25rem;bottom:1.25rem;z-index:100;
  background:#25d366;color:#fff;width:60px;height:60px;border-radius:50%;
  display:grid;place-items:center;box-shadow:0 12px 30px rgba(37,211,102,.45);
  font-size:1.8rem;transition:transform .2s ease;
}
.wa-float:hover{transform:scale(1.08);color:#fff}
.wa-float::before{
  content:"";position:absolute;inset:-6px;border-radius:50%;
  background:rgba(37,211,102,.35);z-index:-1;animation:pulse 2s infinite;
}
@keyframes pulse{
  0%{transform:scale(1);opacity:.6}
  100%{transform:scale(1.5);opacity:0}
}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 900px){
  .hero .wrap{grid-template-columns:1fr;padding:3rem 1.25rem}
  .benefits, .services, .areas{grid-template-columns:1fr 1fr}
  .about, .contact{grid-template-columns:1fr;gap:2rem}
  .nav-toggle{display:block}
  .nav{
    display:none;position:absolute;top:100%;left:0;right:0;background:#fff;
    flex-direction:column;align-items:stretch;padding:1rem;border-bottom:1px solid var(--line);
    box-shadow:var(--shadow);
  }
  .nav.open{display:flex}
  .nav a{padding:.8rem 1rem}
}
@media (max-width: 580px){
  .benefits, .services, .areas{grid-template-columns:1fr}
  .cta-band{padding:1.75rem;text-align:center;justify-content:center}
  section{padding:3rem 1.25rem}
}
