/* =========================================================
   77petro · Soluções Ambientais
   Identidade: verde-floresta + amarelo solar sobre creme quente
   ========================================================= */

:root{
  /* Brand */
  --green-deep: #0E5A28;
  --green: #1F8A3D;
  --green-bright: #26A24B;
  --green-dim: #18421F;
  --yellow: #F4C81C;
  --yellow-deep: #C89A0A;

  /* Surfaces */
  --cream: #F7F4EC;
  --cream-2: #EFEBDD;
  --ink: #0B1A11;
  --ink-2: #1E2A20;
  --muted: #5C6B5E;
  --border: #D9D2BD;
  --border-strong: #C0B79D;

  /* Type */
  --display: 'Archivo', system-ui, sans-serif;
  --body: 'Manrope', system-ui, sans-serif;
  --mono: 'JetBrains Mono', ui-monospace, monospace;

  /* Radii */
  --r-sm: 4px;
  --r: 6px;
  --r-lg: 10px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  background:var(--cream);
  color:var(--ink);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.mono{font-family:var(--mono);font-feature-settings:'tnum' 1}
em{font-style:italic;font-family:'Archivo';font-weight:600}

.container{max-width:1280px;margin:0 auto;padding:0 28px}

/* =========================================================
   ANNOUNCEMENT
========================================================= */
.ann{
  background:var(--green-deep);
  color:#E8EFE2;
  font-size:13px;
  border-bottom:1px solid #082E13;
}
.ann__row{
  display:flex;align-items:center;gap:12px;
  padding:9px 28px;
  flex-wrap:wrap;
}
.ann__dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--yellow);
  box-shadow:0 0 0 3px rgba(244,200,28,.22);
  display:inline-block;
}
.ann__sep{opacity:.35}
.ann a{color:#fff;font-weight:500}
.ann a:hover{color:var(--yellow)}

/* =========================================================
   NAV
========================================================= */
.nav{
  background:var(--cream);
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(0);
}
.nav__row{
  display:flex;align-items:center;
  height:74px;gap:32px;
}
.brand{
  display:flex;align-items:center;gap:12px;
  flex-shrink:0;
}
.brand__mark{
  width:42px;height:42px;
  border-radius:var(--r);
  object-fit:cover;
}
.brand__type{display:flex;flex-direction:column;line-height:1}
.brand__type strong{
  font-family:var(--display);
  font-weight:800;
  font-size:21px;
  letter-spacing:-.02em;
  color:var(--green-deep);
}
.brand__type em{
  font-style:normal;
  font-family:var(--body);
  font-weight:500;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:var(--yellow-deep);
  margin-top:3px;
}
.brand--inv strong{color:#fff}
.brand--inv em{color:var(--yellow)}

.nav__menu{
  display:flex;gap:28px;margin-left:auto;
  font-size:14.5px;font-weight:500;color:var(--ink-2);
}
.nav__menu a{position:relative;padding:6px 0;transition:color .15s}
.nav__menu a:hover{color:var(--green)}
.nav__cta{display:flex;gap:10px;align-items:center}

/* Hamburger button — visible only on mobile */
.nav__burger{
  display:none;
  margin-left:auto;
  width:44px;height:44px;
  background:transparent;border:1px solid var(--border-strong);
  border-radius:var(--r);
  cursor:pointer;
  align-items:center;justify-content:center;
  flex-direction:column;gap:5px;
  padding:0;
  transition:border-color .15s, background .15s;
}
.nav__burger:hover{border-color:var(--ink);background:#fff}
.nav__burger span{
  display:block;width:20px;height:2px;
  background:var(--ink);border-radius:2px;
  transition:transform .25s ease, opacity .15s;
}
.nav__burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav__burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* =========================================================
   MOBILE DRAWER
========================================================= */
.drawer{
  position:fixed;inset:0;z-index:90;
  visibility:hidden;
  pointer-events:none;
}
.drawer.is-open{visibility:visible;pointer-events:auto}
.drawer__backdrop{
  position:absolute;inset:0;
  background:rgba(11,26,17,.5);
  opacity:0;
  transition:opacity .25s ease;
  backdrop-filter:blur(2px);
}
.drawer.is-open .drawer__backdrop{opacity:1}
.drawer__panel{
  position:absolute;top:0;right:0;bottom:0;
  width:min(360px, 86vw);
  background:var(--cream);
  display:flex;flex-direction:column;
  transform:translateX(100%);
  transition:transform .3s cubic-bezier(.4,0,.2,1);
  box-shadow:-20px 0 60px rgba(11,26,17,.18);
  overflow-y:auto;
}
.drawer.is-open .drawer__panel{transform:translateX(0)}
.drawer__head{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 22px;
  border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.drawer__close{
  width:40px;height:40px;
  background:transparent;border:1px solid var(--border-strong);
  border-radius:var(--r);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--ink);
  transition:border-color .15s, background .15s;
}
.drawer__close:hover{border-color:var(--ink);background:#fff}
.drawer__close svg{width:18px;height:18px}
.drawer__menu{
  display:flex;flex-direction:column;
  padding:14px 22px;gap:2px;
}
.drawer__menu a{
  font-family:var(--display);font-weight:700;
  font-size:22px;letter-spacing:-.015em;
  color:var(--ink);
  padding:14px 0;
  border-bottom:1px solid var(--border);
  transition:color .15s, padding-left .2s;
}
.drawer__menu a:hover,
.drawer__menu a:focus-visible{
  color:var(--green-deep);
  padding-left:8px;
}
.drawer__cta{
  display:flex;flex-direction:column;gap:10px;
  padding:18px 22px 0;
}
.drawer__foot{
  margin-top:auto;
  padding:22px;
  border-top:1px solid var(--border);
  background:var(--cream-2);
  display:flex;justify-content:space-between;align-items:center;
  font-size:12px;color:var(--muted);
  text-transform:uppercase;letter-spacing:.1em;
  flex-shrink:0;
}
.drawer__foot a{color:var(--green-deep);font-weight:600}
.drawer__foot a:hover{color:var(--green)}

/* Body lock when drawer open */
body.drawer-open{overflow:hidden}

/* =========================================================
   WHATSAPP · botões + floating
========================================================= */
.btn--wa{
  color:#128C7E;
  border-color:#128C7E;
  background:transparent;
}
.btn--wa:hover{
  background:#128C7E;color:#fff;border-color:#128C7E;
  transform:translateY(-1px);
}
.btn--wa svg{flex-shrink:0}

.btn--wa-solid{
  background:#25D366;color:#fff;border-color:#1FBA59;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--body);font-weight:700;font-size:14px;
  padding:12px 18px;border-radius:var(--r);
  transition:all .18s ease-out;
}
.btn--wa-solid:hover{background:#1DAE54;transform:translateY(-1px)}

.wa-float{
  position:fixed;
  right:22px;bottom:22px;
  z-index:60;
  display:inline-flex;align-items:center;gap:10px;
  background:#25D366;color:#fff;
  padding:14px 20px 14px 16px;
  border-radius:999px;
  box-shadow:0 10px 28px rgba(37,211,102,.4), 0 2px 6px rgba(0,0,0,.18);
  font-family:var(--body);font-weight:700;font-size:14.5px;
  letter-spacing:-.005em;
  text-decoration:none;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
  animation:wa-pulse 2.4s ease-out infinite;
}
.wa-float:hover{
  background:#1DAE54;
  transform:translateY(-2px) scale(1.02);
  box-shadow:0 14px 34px rgba(37,211,102,.5), 0 3px 8px rgba(0,0,0,.22);
  animation-play-state:paused;
}
.wa-float svg{flex-shrink:0}
.wa-float__lbl{white-space:nowrap}

@keyframes wa-pulse{
  0%   {box-shadow:0 10px 28px rgba(37,211,102,.4),  0 2px 6px rgba(0,0,0,.18), 0 0 0 0   rgba(37,211,102,.55)}
  60%  {box-shadow:0 10px 28px rgba(37,211,102,.4),  0 2px 6px rgba(0,0,0,.18), 0 0 0 18px rgba(37,211,102,0)}
  100% {box-shadow:0 10px 28px rgba(37,211,102,.4),  0 2px 6px rgba(0,0,0,.18), 0 0 0 0   rgba(37,211,102,0)}
}
@media (prefers-reduced-motion: reduce){
  .wa-float{animation:none}
}
@media (max-width: 720px){
  .wa-float{
    right:16px;bottom:16px;
    padding:14px;
    width:56px;height:56px;
    justify-content:center;
  }
  .wa-float__lbl{display:none}
}
@media print{
  .wa-float{display:none}
}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--body);font-weight:600;font-size:14px;
  padding:10px 18px;border-radius:var(--r);
  border:1px solid transparent;cursor:pointer;
  transition:all .18s ease-out;
  white-space:nowrap;
}
.btn--solid{background:var(--green-deep);color:#fff}
.btn--solid:hover{background:var(--green);transform:translateY(-1px)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--border-strong)}
.btn--ghost:hover{background:#fff;border-color:var(--ink)}
.btn--yellow{background:var(--yellow);color:var(--green-deep);font-weight:700}
.btn--yellow:hover{background:#FFD737;transform:translateY(-1px)}
.btn--link{
  background:transparent;color:var(--green-deep);
  font-weight:600;border-bottom:1px solid var(--green-deep);
  border-radius:0;padding:6px 0;
}
.btn--link:hover{color:var(--green-bright);border-color:var(--green-bright)}
.btn--lg{font-size:15.5px;padding:14px 22px}
.btn--block{width:100%;justify-content:center;margin-top:8px}
.btn .arrow{transition:transform .18s}
.btn:hover .arrow{transform:translateX(3px)}

/* =========================================================
   HERO
========================================================= */
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12px;font-weight:600;
  text-transform:uppercase;letter-spacing:.16em;
  color:var(--green-deep);
  margin:0 0 24px;
}
.eyebrow__dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--yellow);
  box-shadow:0 0 0 4px rgba(244,200,28,.18);
}
.eyebrow--inv{color:#F5E8B7}
.eyebrow--inv .eyebrow__dot{background:var(--yellow);box-shadow:0 0 0 4px rgba(244,200,28,.18)}

.display{
  font-family:var(--display);
  font-weight:800;
  font-size:clamp(40px, 5.6vw, 76px);
  line-height:1.02;
  letter-spacing:-.025em;
  margin:0 0 26px;
  color:var(--ink);
  text-wrap:balance;
}
.hl-yellow{color:var(--yellow-deep)}
.hl-green{color:var(--green-deep)}
.lede{
  font-size:18px;color:var(--ink-2);
  max-width:540px;line-height:1.55;
  margin:0 0 36px;
}

.hero{
  position:relative;overflow:hidden;
  padding:80px 0 0;
  border-bottom:1px solid var(--border);
}
.hero__grid{
  display:grid;grid-template-columns:1.05fr 1fr;
  gap:64px;align-items:start;
}
.hero__cta{display:flex;align-items:center;gap:24px;flex-wrap:wrap;margin-bottom:56px}
.hero__stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid var(--border);
  margin:0 0 80px;padding-top:28px;
}
.hero__stats > div{padding-right:24px}
.hero__stats > div + div{border-left:1px solid var(--border);padding-left:24px}
.hero__stats dt{
  font-family:var(--display);font-weight:800;
  font-size:34px;letter-spacing:-.02em;
  color:var(--green-deep);margin-bottom:8px;
}
.hero__stats dd{
  margin:0;font-size:13px;color:var(--muted);line-height:1.4;
}

/* Hero right — layered visual */
.hero__right{position:relative;height:620px;padding-top:8px}
.visual{position:relative;width:100%;height:100%}
.visual__grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(14,90,40,.07) 1px,transparent 1px),
    linear-gradient(90deg,rgba(14,90,40,.07) 1px,transparent 1px);
  background-size:38px 38px;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 45%,#000 30%,transparent 80%);
  z-index:0;
}
.visual__drop{
  position:absolute;
  left:50%;top:50px;
  transform:translateX(-48%);
  width:380px;height:auto;
  filter:drop-shadow(0 25px 50px rgba(14,90,40,.22));
  z-index:1;
}

.chip{
  position:absolute;
  display:flex;gap:14px;align-items:center;
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:14px 16px;
  box-shadow:0 8px 24px rgba(11,26,17,.08);
  z-index:3;
  max-width:240px;
}
.chip__num{
  font-family:var(--display);font-weight:800;
  font-size:30px;letter-spacing:-.03em;
  color:var(--green-deep);line-height:1;
}
.chip__icon{
  width:38px;height:38px;flex-shrink:0;
  background:var(--green-deep);color:var(--yellow);
  border-radius:var(--r);
  display:flex;align-items:center;justify-content:center;
}
.chip__icon svg{width:22px;height:22px}
.chip__title{font-size:13px;font-weight:700;color:var(--ink)}
.chip__sub{font-size:11.5px;color:var(--muted);margin-top:2px;line-height:1.35}
.chip--a{top:30px;left:-10px}
.chip--b{top:240px;right:-20px}
.chip--c{bottom:60px;left:30px;border-left:3px solid var(--yellow)}
.status-dot{
  width:10px;height:10px;border-radius:50%;
  background:var(--green-bright);flex-shrink:0;
  box-shadow:0 0 0 4px rgba(38,162,75,.2);
  animation:pulse 1.8s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 4px rgba(38,162,75,.2)}
  50%{box-shadow:0 0 0 8px rgba(38,162,75,.05)}
}

/* Marquee */
.marquee{
  margin-top:0;
  border-top:1px solid var(--border);
  background:var(--cream-2);
  overflow:hidden;
}
.marquee__track{
  display:flex;gap:48px;
  padding:18px 0;
  white-space:nowrap;
  font-size:13px;font-weight:600;
  text-transform:uppercase;letter-spacing:.16em;
  color:var(--green-deep);
  animation:marquee 38s linear infinite;
}
.marquee__track span{display:inline-flex;align-items:center;gap:48px}
.marquee__track span::after{
  content:'';width:6px;height:6px;border-radius:50%;
  background:var(--yellow);display:inline-block;
}
@keyframes marquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* =========================================================
   SECTIONS
========================================================= */
.section{padding:120px 0;border-bottom:1px solid var(--border)}
.section--alt{background:var(--cream-2)}
.section--dark{
  background:var(--green-deep);
  color:#E6EEDF;
  border-bottom-color:#082E13;
  position:relative;
  overflow:hidden;
}
.section--dark::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:48px 48px;
  pointer-events:none;
}

.section__head{max-width:780px;margin-bottom:64px}
.section__head--center{text-align:center;margin-left:auto;margin-right:auto}
.section__head--center .eyebrow{justify-content:center;display:flex}
.h2{
  font-family:var(--display);font-weight:800;
  font-size:clamp(34px,4vw,54px);
  letter-spacing:-.022em;line-height:1.05;
  margin:0 0 22px;
  text-wrap:balance;
}
.h2 em{color:var(--green);font-style:italic;font-weight:700}
.h2--inv{color:#fff}
.h2--inv em{color:var(--yellow)}
.section__lede{
  font-size:17px;color:var(--muted);
  max-width:640px;line-height:1.6;margin:0;
}
.section__head--center .section__lede{margin-left:auto;margin-right:auto}
.section__lede--inv{color:#BFD3B6}

/* =========================================================
   SERVIÇOS GRID
========================================================= */
.svc-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:var(--border);
  border:1px solid var(--border);border-radius:var(--r-lg);
  overflow:hidden;
}
.svc{
  background:var(--cream);
  padding:36px 30px;
  display:flex;flex-direction:column;
  position:relative;
  transition:background .2s;
}
.svc:hover{background:#fff}
.svc__num{
  position:absolute;top:24px;right:28px;
  font-family:var(--mono);font-size:12px;font-weight:600;
  color:var(--green);opacity:.5;
}
.svc__icon{
  width:48px;height:48px;
  background:var(--green-deep);color:var(--yellow);
  border-radius:var(--r);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:24px;
}
.svc__icon svg{width:28px;height:28px}
.svc h3{
  font-family:var(--display);font-weight:700;
  font-size:21px;letter-spacing:-.015em;line-height:1.2;
  margin:0 0 14px;color:var(--ink);
  text-wrap:balance;
}
.svc p{
  font-size:14.5px;color:var(--muted);
  margin:0 0 20px;line-height:1.55;
}
.svc__list{
  list-style:none;padding:0;margin:auto 0 0;
  font-size:13px;
  border-top:1px dashed var(--border-strong);padding-top:14px;
}
.svc__list li{
  padding:5px 0;color:var(--ink-2);
  position:relative;padding-left:18px;
}
.svc__list li::before{
  content:'';position:absolute;left:0;top:13px;
  width:8px;height:2px;background:var(--yellow);
}
.svc--feat{background:var(--green-deep);color:#E8EFE2}
.svc--feat h3{color:#fff}
.svc--feat p{color:#C7D6BD}
.svc--feat .svc__num{color:var(--yellow);opacity:.7}
.svc--feat .svc__icon{background:var(--yellow);color:var(--green-deep)}
.svc--feat .svc__list{border-color:rgba(255,255,255,.18)}
.svc--feat .svc__list li{color:#E8EFE2}
.svc--feat:hover{background:var(--green-dim)}
.svc__badge{
  position:absolute;top:24px;left:30px;
  background:var(--yellow);color:var(--green-deep);
  font-size:10.5px;font-weight:700;
  text-transform:uppercase;letter-spacing:.12em;
  padding:4px 8px;border-radius:3px;
}

/* =========================================================
   SOBRE
========================================================= */
.sobre{
  display:grid;grid-template-columns:1.1fr 1fr;
  gap:72px;align-items:start;
}
.sobre__lede{font-size:17px;line-height:1.6;color:var(--ink-2);margin:0 0 18px}
.sobre__body{font-size:15.5px;line-height:1.65;color:var(--muted);margin:0 0 40px}

.sobre__values{
  display:grid;grid-template-columns:1fr 1fr;gap:28px 36px;
  border-top:1px solid var(--border);padding-top:36px;
}
.value strong{
  display:block;font-family:var(--display);
  font-weight:700;font-size:16px;
  color:var(--ink);margin:8px 0 6px;letter-spacing:-.01em;
}
.value p{font-size:13.5px;color:var(--muted);margin:0;line-height:1.5}
.value__k{
  font-family:var(--mono);font-size:11px;font-weight:600;
  color:var(--yellow-deep);
}

.sobre__right{display:flex;flex-direction:column;gap:24px}
.photo{
  background:#fff;border:1px solid var(--border);
  border-radius:var(--r-lg);overflow:hidden;
}
.photo__inner{aspect-ratio:16/10;overflow:hidden;position:relative}
.photo__inner svg{width:100%;height:100%;display:block}
.photo__cap{
  padding:14px 18px;
  font-size:13px;color:var(--muted);
  border-top:1px solid var(--border);
  display:flex;justify-content:space-between;
  background:var(--cream);
}

.kpi-stack{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1px;
  background:var(--border);
  border:1px solid var(--border);border-radius:var(--r-lg);
  overflow:hidden;
}
.kpi{
  background:#fff;padding:22px 22px;
}
.kpi__num{
  font-family:var(--display);font-weight:800;
  font-size:32px;letter-spacing:-.02em;
  color:var(--green-deep);line-height:1;
}
.kpi__lbl{
  font-size:12.5px;color:var(--muted);
  margin-top:8px;line-height:1.4;
}
.kpi--accent{background:var(--yellow)}
.kpi--accent .kpi__num{color:var(--green-deep)}
.kpi--accent .kpi__lbl{color:var(--green-dim);font-weight:500}

/* =========================================================
   PROCESSO (dark)
========================================================= */
.proc{
  list-style:none;padding:0;margin:0 0 64px;
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:32px;
  position:relative;z-index:1;
}
.proc__step{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--r-lg);
  padding:28px 24px 30px;
  position:relative;
}
.proc__head{
  display:flex;justify-content:space-between;align-items:baseline;
  margin-bottom:22px;
}
.proc__n{
  font-family:var(--display);font-weight:800;
  font-size:46px;letter-spacing:-.03em;line-height:1;
  color:var(--yellow);
}
.proc__t{font-size:11.5px;color:#9DBA92;letter-spacing:.08em}
.proc__step h3{
  font-family:var(--display);font-weight:700;
  font-size:19px;line-height:1.2;color:#fff;
  margin:0 0 12px;letter-spacing:-.01em;
}
.proc__step p{
  font-size:13.5px;color:#BFD3B6;line-height:1.55;margin:0;
}
.proc__line{
  position:absolute;right:-24px;top:54px;
  width:16px;height:2px;background:var(--yellow);
  display:none;
}

.proc__cta{
  background:var(--yellow);color:var(--green-deep);
  border-radius:var(--r-lg);
  padding:28px 36px;
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  position:relative;z-index:1;
}
.proc__cta__title{
  font-family:var(--display);font-weight:700;
  font-size:22px;margin:0 0 4px;letter-spacing:-.015em;
}
.proc__cta__sub{font-size:14px;margin:0;color:var(--green-dim)}
.proc__cta .btn--yellow{background:var(--green-deep);color:var(--yellow)}
.proc__cta .btn--yellow:hover{background:var(--green-dim)}

/* =========================================================
   IMPACTO
========================================================= */
.impact-grid{
  display:grid;
  grid-template-columns:1.6fr 1fr 1fr;
  grid-template-rows:auto auto;
  gap:18px;
}
.impact{
  background:#fff;border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:30px 28px;
  display:flex;flex-direction:column;
  min-height:200px;
}
.impact__tag{font-size:11px;color:var(--muted);margin:0 0 16px;letter-spacing:.1em}
.impact__num{
  font-family:var(--display);font-weight:800;
  font-size:64px;letter-spacing:-.035em;line-height:1;
  color:var(--green-deep);
}
.impact__num span{color:var(--yellow-deep);font-weight:700}
.impact__num--mid{font-size:44px}
.impact__lbl{
  font-size:13.5px;color:var(--muted);
  margin:14px 0 0;line-height:1.45;
}
.impact--big{
  grid-row:span 2;
  background:var(--green-deep);color:#E6EEDF;
  border-color:var(--green-dim);
}
.impact--big .impact__num{color:#fff}
.impact--big .impact__num span{color:var(--yellow)}
.impact--big .impact__lbl{color:#BFD3B6;font-size:15px}
.impact--big .impact__tag{color:#9DBA92}
.impact__bar{margin-top:auto;padding-top:28px}
.impact__bar__fill{
  height:6px;border-radius:3px;background:var(--yellow);
  width:var(--w);
  box-shadow:0 0 0 1px rgba(244,200,28,.4);
}
.impact__bar__meta{
  display:flex;justify-content:space-between;
  margin-top:10px;font-size:12px;color:#BFD3B6;
}
.impact--y{background:var(--yellow);border-color:var(--yellow-deep)}
.impact--y .impact__num,.impact--y .impact__num span{color:var(--green-deep)}
.impact--y .impact__lbl{color:var(--green-dim)}

.impact--quote{
  grid-column:span 2;
  background:var(--cream-2);border-color:var(--border-strong);
  position:relative;padding:32px 36px;
}
.quote-mark{position:absolute;top:24px;right:24px;width:42px;height:42px}
.impact--quote blockquote{
  font-family:var(--display);font-weight:500;font-style:italic;
  font-size:21px;line-height:1.35;color:var(--ink);
  margin:0 0 22px;max-width:560px;letter-spacing:-.01em;
  text-wrap:balance;
}
.quote__by{display:flex;gap:14px;align-items:center;font-size:13px;color:var(--muted)}
.quote__by strong{color:var(--ink);font-family:var(--body);font-weight:600;font-size:14px}
.quote__av{
  width:42px;height:42px;border-radius:50%;
  background:var(--green-deep);color:var(--yellow);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-weight:700;font-size:14px;
  letter-spacing:.04em;
}

/* =========================================================
   SETORES + DIFERENCIAIS
========================================================= */
.split{
  display:grid;grid-template-columns:.95fr 1.05fr;
  gap:72px;align-items:start;
}
.sectors{
  list-style:none;padding:0;margin:36px 0 0;
  border-top:1px solid var(--border-strong);
}
.sectors li{
  display:flex;gap:18px;align-items:center;
  padding:16px 0;
  border-bottom:1px solid var(--border-strong);
  font-size:15.5px;color:var(--ink-2);
}
.sectors li .mono{
  font-size:12px;color:var(--yellow-deep);
  flex-shrink:0;width:22px;
}

.diff-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:16px;
}
.diff{
  background:#fff;border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:24px 24px 22px;
}
.diff__ic{
  width:42px;height:42px;
  background:var(--green-deep);color:var(--yellow);
  border-radius:var(--r);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:18px;
}
.diff__ic svg{width:22px;height:22px}
.diff strong{
  font-family:var(--display);font-weight:700;
  font-size:16px;color:var(--ink);
  display:block;margin-bottom:6px;letter-spacing:-.01em;
}
.diff p{font-size:13.5px;color:var(--muted);margin:0;line-height:1.5}
.diff--y{background:var(--yellow);border-color:var(--yellow-deep)}
.diff--y .diff__ic{background:var(--green-deep);color:var(--yellow)}
.diff--y strong{color:var(--green-deep)}
.diff--y p{color:var(--green-dim)}

/* =========================================================
   CERTIFICAÇÕES
========================================================= */
.cert-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px;
}
.cert{
  background:#fff;border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:24px 22px 22px;
  position:relative;
}
.cert__lbl{
  position:absolute;top:14px;right:16px;
  font-family:var(--mono);font-size:10.5px;font-weight:600;
  color:var(--muted);
  background:var(--cream-2);padding:3px 7px;border-radius:3px;
  letter-spacing:.06em;
}
.cert strong{
  font-family:var(--display);font-weight:700;
  font-size:18px;color:var(--green-deep);
  display:block;margin:24px 0 8px;
  letter-spacing:-.012em;line-height:1.15;
}
.cert .mono{font-size:12px;color:var(--yellow-deep);margin:0 0 12px;font-weight:600}
.cert p{font-size:12.5px;color:var(--muted);margin:0;line-height:1.5}
.cert--y{background:var(--yellow);border-color:var(--yellow-deep)}
.cert--y .cert__lbl{background:var(--green-deep);color:var(--yellow)}
.cert--y strong{color:var(--green-deep)}
.cert--y p{color:var(--green-dim)}
.cert--y .mono{color:var(--green-deep)}

/* =========================================================
   CTA / CONTATO
========================================================= */
.section--cta{
  background:var(--green-deep);color:#E6EEDF;
  padding:120px 0;
  position:relative;overflow:hidden;
}
.section--cta::before{
  content:'';position:absolute;inset:0;
  background-image:
    radial-gradient(rgba(244,200,28,.07) 2px,transparent 3px);
  background-size:32px 32px;
  pointer-events:none;
}
.cta-wrap{
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:start;position:relative;
}
.contact-info{display:flex;flex-direction:column;gap:24px;margin-top:40px}
.info{display:flex;flex-direction:column;gap:4px}
.info__lbl{
  font-size:11px;text-transform:uppercase;letter-spacing:.14em;
  color:#9DBA92;font-weight:600;
}
.info__big{
  font-size:28px;font-weight:600;color:#fff;
  letter-spacing:-.02em;
}
.info__big:hover{color:var(--yellow)}
.info__med{font-size:15.5px;color:#E6EEDF;line-height:1.45}
.info__med:hover{color:var(--yellow)}
.info--row{flex-direction:row;gap:48px}
.info--row > div{display:flex;flex-direction:column;gap:4px}

/* Form */
.form{
  background:var(--cream);color:var(--ink);
  border-radius:var(--r-lg);
  padding:32px 32px 34px;
  border:1px solid var(--green-dim);
  box-shadow:0 30px 60px rgba(0,0,0,.25);
  position:relative;
}
.form__head{
  display:flex;justify-content:space-between;align-items:baseline;
  border-bottom:1px solid var(--border);padding-bottom:16px;margin-bottom:22px;
}
.form__head strong{
  font-family:var(--display);font-weight:700;font-size:18px;
  letter-spacing:-.01em;color:var(--green-deep);
}
.form__head .mono{font-size:11.5px;color:var(--muted);letter-spacing:.06em}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field span{
  font-size:12px;font-weight:600;
  text-transform:uppercase;letter-spacing:.1em;
  color:var(--muted);
}
.field input,.field select,.field textarea{
  font-family:var(--body);font-size:14.5px;color:var(--ink);
  background:#fff;
  border:1px solid var(--border-strong);
  border-radius:var(--r-sm);
  padding:11px 13px;
  transition:border-color .15s, box-shadow .15s;
}
.field input.mono{font-family:var(--mono)}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--green);
  box-shadow:0 0 0 3px rgba(31,138,61,.15);
}
.field textarea{resize:vertical;min-height:74px;font-family:var(--body)}
.check{
  display:flex;gap:10px;align-items:flex-start;
  font-size:12.5px;color:var(--muted);
  margin:6px 0 8px;line-height:1.45;
}
.check input{margin-top:3px;accent-color:var(--green-deep)}
.check a{color:var(--green-deep);text-decoration:underline}
.form__sent{
  display:none;font-size:13px;color:var(--green-deep);
  font-weight:600;text-align:center;margin:14px 0 0;
}
.form--sent .form__sent{display:block}
.form--sent button{opacity:.5;pointer-events:none}
.form__error{
  display:none;font-size:13px;color:#9a1c1c;
  font-weight:600;text-align:center;margin:14px 0 0;
  background:#fdecec;border:1px solid #f4caca;
  padding:10px 12px;border-radius:var(--r-sm);
}
.form--error .form__error{display:block}

/* =========================================================
   FOOTER
========================================================= */
.footer{background:var(--ink);color:#A8B5A9;padding:80px 0 0;font-size:14px}
.footer__row{
  display:grid;grid-template-columns:1.2fr 2.4fr;
  gap:64px;padding-bottom:60px;
}
.footer__claim{font-size:14.5px;color:#C8D0C5;max-width:340px;line-height:1.55;margin:18px 0 18px}
.footer__cnpj{font-size:12px;color:#7E8B7F}
.footer__cols{
  display:grid;grid-template-columns:repeat(4,1fr);gap:32px;
}
.footer__cols h4{
  font-family:var(--display);font-weight:700;font-size:13px;
  text-transform:uppercase;letter-spacing:.14em;
  color:#fff;margin:0 0 18px;
}
.footer__cols ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:9px}
.footer__cols a{color:#A8B5A9;font-size:13.5px;transition:color .15s}
.footer__cols a:hover{color:var(--yellow)}
.footer__bottom{
  border-top:1px solid rgba(255,255,255,.08);
  padding:22px 0;
}
.footer__bottom__row{
  display:flex;justify-content:space-between;align-items:center;
  font-size:12.5px;color:#7E8B7F;flex-wrap:wrap;gap:12px;
}

/* =========================================================
   RESPONSIVE
========================================================= */
@media (max-width: 1100px){
  .hero__grid{grid-template-columns:1fr;gap:48px}
  .hero__right{height:480px}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .proc{grid-template-columns:repeat(2,1fr)}
  .impact-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .impact--big{grid-row:auto;grid-column:span 2}
  .impact--quote{grid-column:span 2}
  .cert-grid{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1fr;gap:48px}
  .sobre{grid-template-columns:1fr;gap:48px}
  .cta-wrap{grid-template-columns:1fr;gap:48px}
  .footer__row{grid-template-columns:1fr;gap:40px}
  .footer__cols{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 720px){
  .nav__menu,.nav__cta{display:none}
  .nav__burger{display:flex}
  .ann__sep,.ann a{display:none}
  .svc-grid{grid-template-columns:1fr}
  .proc{grid-template-columns:1fr}
  .cert-grid{grid-template-columns:1fr}
  .hero__stats{grid-template-columns:1fr 1fr}
  .hero__stats > div{padding:18px 14px 0;border:none !important}
  .sobre__values{grid-template-columns:1fr}
  .diff-grid{grid-template-columns:1fr}
  .impact-grid{grid-template-columns:1fr}
  .impact--big,.impact--quote{grid-column:auto}
  .info--row{flex-direction:column;gap:18px}
  .footer__cols{grid-template-columns:1fr 1fr;gap:24px}
  .proc__cta{flex-direction:column;align-items:flex-start;gap:18px}
  .section{padding:80px 0}
}
