/* ====== Ipê Agro Ambiental Landing ====== */
:root{--green-light:#73c26d;--green-dark:#00342e;--yellow:#f2d96d;--white:#ffffff;--text:#0f2a22}
*{box-sizing:border-box}html,body{margin:0;padding:0}
body{font-family:'Open Sans',Arial,Helvetica,sans-serif;color:var(--text);line-height:1.6;background:#f8fbf7}
img{max-width:100%;display:block}
.container{width:min(1120px,92%);margin-inline:auto}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:var(--green-dark);color:var(--white);box-shadow:0 6px 18px rgba(0,0,0,.15)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:10px 0}
.logo{height:48px}.logo.small{height:38px}
.nav{display:flex;gap:20px;align-items:center}
.nav a{color:#eaf7f0;text-decoration:none;font-weight:600}
.nav .btn-cta{color:var(--green-dark);background:var(--yellow);padding:.6rem .9rem;border-radius:12px}
.menu-toggle{display:none;background:none;border:none;color:#fff;font-size:28px}
@media (max-width:880px){
  .nav{position:fixed;inset:64px 0 auto 0;background:var(--green-dark);padding:16px;flex-direction:column;transform:translateY(-120%);transition:.25s}
  .nav.open{transform:translateY(0)}.menu-toggle{display:block}
}

/* Buttons */
.btn{display:inline-block;padding:.9rem 1.2rem;border-radius:14px;text-decoration:none;font-weight:700}
.btn-cta{background:var(--yellow);color:var(--green-dark);box-shadow:0 8px 24px rgba(0,0,0,.15)}
.btn-ghost{border:2px solid var(--white);color:var(--white)}
.btn-outline{border-color:var(--yellow);color:var(--white)}
.btn-sm{padding:.5rem .8rem;font-size:.9rem}.btn-lg{padding:1rem 1.4rem;font-size:1.05rem}

/* Hero */
.hero{background:linear-gradient(120deg, rgba(0,52,46,.92), rgba(0,52,46,.78)), var(--green-light);color:var(--white);padding:90px 0 64px}
.hero-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:28px;align-items:center}
.hero h1{font-family:'Montserrat',sans-serif;font-weight:800;line-height:1.15;margin:0 0 12px;font-size:clamp(28px,4vw,44px)}
.hero p{font-size:clamp(16px,1.4vw,18px);opacity:.95;margin:0 0 18px}
.cta-row{display:flex;gap:14px;flex-wrap:wrap}
.hero-card{background:#12463f;border:1px solid rgba(255,255,255,.15);border-radius:16px;padding:14px;box-shadow:0 20px 40px rgba(0,0,0,.25)}
.hero-visual{display:flex;justify-content:center}

/* Value cards */
.value{padding:36px 0;background:#eef7f0}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{background:#fff;border-radius:16px;padding:20px;border:1px solid #e6efe8;box-shadow:0 10px 24px rgba(0,0,0,.06)}
.card h3{font-family:'Montserrat',sans-serif;margin:0 0 6px}

/* Sections */
.section{padding:64px 0}.section.alt{background:#f2f8f3}
.section h2{font-family:'Montserrat',sans-serif;font-size:clamp(22px,3.2vw,32px);margin:0 0 18px}
.section-lead{margin-top:-8px;margin-bottom:16px;color:#45695f;font-size:.98rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}

/* Service cards + icons (centered) */
.svc-card{background:#fff;border:1px solid #e6efe8;padding:18px;border-radius:14px;box-shadow:0 8px 16px rgba(0,0,0,.05);display:flex;flex-direction:column;gap:10px;text-align:center}
.svc-card h4{margin:0 0 6px;font-family:'Montserrat',sans-serif}
.svc-ico{width:54px;height:54px;border-radius:14px;background:var(--green-light);display:grid;place-items:center;margin-inline:auto}
.svc-ico svg{width:30px;height:30px;fill:none;stroke:#053429;stroke-width:1.6}
#servicos .grid-3{justify-items:center;text-align:center}

/* Steps */
.steps{counter-reset:step;display:grid;grid-template-columns:repeat(4,1fr);gap:16px;padding-left:0;margin:0;list-style:none}
.steps li{background:#fff;border:1px solid #e6efe8;border-radius:12px;padding:16px;position:relative}
.steps li::before{counter-increment:step;content:counter(step);position:absolute;top:-12px;left:-12px;background:var(--yellow);color:var(--green-dark);font-weight:800;border-radius:50%;width:34px;height:34px;display:grid;place-items:center;box-shadow:0 8px 18px rgba(0,0,0,.15)}

/* About */
.about{display:grid;grid-template-columns:1.2fr .8fr;gap:24px;align-items:center}
.badge{display:inline-block;background:var(--green-light);color:#053429;padding:.35rem .6rem;border-radius:999px;margin:.25rem .35rem 0 0;font-weight:700}
.muted{color:#567d72;font-size:.92rem}
.list-check{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.list-check li{position:relative;padding-left:28px}
.list-check li::before{content:'✓';position:absolute;left:0;top:0;color:#1e614f;font-weight:800}
.sub{font-family:'Montserrat',sans-serif;margin:12px 0 6px}

/* Form */
.form{max-width:720px}
.form-row{display:flex;flex-direction:column;margin:10px 0}
.form-row input,.form-row select,.form-row textarea{padding:.8rem .9rem;border-radius:12px;border:1px solid #cfe4d7;background:#fff;outline-color:var(--green-light)}
.help{color:#567d72;font-size:.84rem;margin-top:6px}
.form-row.checkbox{flex-direction:row;gap:10px;align-items:center}

/* Footer 3 colunas (sem mapa) */
.site-footer{background:var(--green-dark);color:#d7efe5;padding:36px 0 10px}
.footer-cols{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:28px;align-items:flex-start}
.foot-brand .brand-line{display:flex;gap:12px;align-items:center}
.brand-mark{width:48px;height:48px;border-radius:50%;background:var(--yellow);display:grid;place-items:center;overflow:hidden}
.brand-mark img{width:40px;height:auto;object-fit:contain;filter:brightness(0) invert(1)}
.brand-texts h4{color:var(--yellow);margin:0 0 2px;font-family:'Montserrat',sans-serif}
.tagline{color:#bfe9cf;font-weight:600}
.brand-desc{margin-top:10px;max-width:340px}
.foot-contact h4,.foot-services h4{color:var(--yellow);margin:0 0 10px;font-family:'Montserrat',sans-serif}
.foot-list{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.row{display:flex;align-items:center;gap:10px}
.row .ico{width:20px;height:20px;display:grid;place-items:center}
.row .ico svg{width:18px;height:18px;fill:none;stroke:var(--green-light);stroke-width:1.8}
.foot-list a{color:var(--yellow);text-decoration:none}
.foot-list a:hover{text-decoration:underline}
.foot-divider{height:1px;background:rgba(255,255,255,.2);margin:18px auto}
.foot-bottom{display:flex;flex-direction:column;align-items:center;gap:6px;color:#cfe9dc;text-align:center;padding-bottom:10px}
.foot-bottom .address a{color:#bfe9cf;text-decoration:underline}

/* Responsive */
@media (max-width:980px){
  .hero-grid,.about{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr}
  .footer-cols{grid-template-columns:1fr;gap:20px}
  .brand-desc{max-width:unset}
}
@media (max-width:640px){
  .cards{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
}

/* ===== Location Section ===== */
.location{background:#f7fbf8;padding-top:48px;padding-bottom:60px}
.loc-title{font-family:'Montserrat',sans-serif;text-align:center;color:#0a3a31;margin:0 0 6px}
.loc-sub{color:#45695f;text-align:center;margin:0 0 24px}
.loc-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:28px;align-items:start}
.loc-info{display:flex;flex-direction:column;gap:16px}
.loc-item{display:flex;gap:12px;align-items:flex-start;color:#0f2a22}
.loc-ico{width:28px;height:28px;border-radius:999px;background:#e9f6ee;display:grid;place-items:center;border:1px solid #cfe4d7}
.loc-ico svg{width:18px;height:18px;fill:none;stroke:#1e614f;stroke-width:1.8}
.btn-map{background:#73c26d;color:#fff;border-radius:12px}
.btn-map .ico-open svg{width:18px;height:18px;fill:none;stroke:#fff;stroke-width:1.8;margin-right:6px}
.loc-map-card{background:#e9ecef;border-radius:14px;border:1px solid #dfe6e0;min-height:320px;overflow:hidden}
.loc-map-card iframe{width:100%;height:100%;display:block}
@media (max-width:980px){
  .loc-grid{grid-template-columns:1fr}
  .loc-map-card{min-height:280px}
}

/* ===== Team Section ===== */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:28px}
.team-card{text-align:center;background:#fff;border:1px solid #e6efe8;padding:18px;border-radius:14px;box-shadow:0 6px 14px rgba(0,0,0,.06)}
.team-photo{width:100%;max-width:240px;height:260px;object-fit:cover;border-radius:12px;margin-inline:auto;box-shadow:0 4px 12px rgba(0,0,0,.1)}
.team-card h4{margin:12px 0 4px;font-family:'Montserrat',sans-serif;font-size:1.1rem;color:#0a3a31}
.team-card p{margin:0;color:#45695f}
.team-text{margin-top:28px;text-align:center;color:#234036;max-width:900px;margin-inline:auto;font-size:1rem}
@media (max-width:880px){
  .team-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:640px){
  .team-grid{grid-template-columns:1fr}
}
