/* ============================================================
   VILA NOVA AGROINDUSTRIAL — Sistema visual compartilhado
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  /* Marca */
  --ink:        #0a2c1f;   /* verde-tinta profundo (header/fundos escuros) */
  --ink-2:      #0e3a29;
  --forest:     #1e5c3a;   /* verde Puripalma */
  --leaf:       #3a9b50;   /* verde folha */
  --lime:       #86c53c;   /* lima / broto */
  --orange:     #e8551f;   /* laranja Vila Nova */
  --orange-d:   #c8430f;
  --amber:      #e2a02c;   /* dourado do óleo de palma */

  /* Neutros */
  --cream:      #f4f1e8;   /* off-white de seções claras */
  --paper:      #fcfbf7;
  --text:       #14211a;
  --muted:      #5d6b61;
  --line:       #e3ddcf;

  /* Tipografia */
  --display: "Schibsted Grotesk", system-ui, sans-serif;
  --body: "Hanken Grotesk", system-ui, sans-serif;

  /* Métrica */
  --maxw: 1240px;
  --gutter: clamp(20px, 5vw, 72px);
  --radius: 18px;
  --radius-lg: 30px;
  --ease: cubic-bezier(.22,.61,.36,1);
  --shadow: 0 24px 60px -28px rgba(10,44,31,.45);
  --shadow-sm: 0 10px 30px -16px rgba(10,44,31,.4);
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--body);
  color:var(--text);
  background:var(--paper);
  font-size:clamp(16px,1.05vw,18px);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
h1,h2,h3,h4{ font-family:var(--display); font-weight:700; line-height:1.02; letter-spacing:-.02em; margin:0; text-wrap:balance; }
p{ margin:0; text-wrap:pretty; }
::selection{ background:var(--lime); color:var(--ink); }

/* ---------- Utilidades ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding-block:clamp(72px,9vw,140px); position:relative; }
.eyebrow{
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--body); font-weight:700;
  font-size:.78rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--orange);
}
.eyebrow::before{ content:""; width:26px; height:2px; background:var(--orange); display:inline-block; }
.eyebrow.on-dark{ color:var(--lime); }
.eyebrow.on-dark::before{ background:var(--lime); }

.lead{ font-size:clamp(1.05rem,1.5vw,1.3rem); color:var(--muted); max-width:60ch; }
.on-dark .lead, .lead.on-dark{ color:rgba(255,255,255,.78); }

/* Botões */
.btn{
  --bg:var(--orange); --fg:#fff;
  display:inline-flex; align-items:center; gap:.7em; white-space:nowrap;
  padding:1.02em 1.7em; border-radius:999px;
  background:var(--bg); color:var(--fg);
  font-family:var(--body); font-weight:700; font-size:.98rem; letter-spacing:.01em;
  border:none; line-height:1;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .25s;
  box-shadow:0 14px 30px -14px color-mix(in srgb, var(--bg) 75%, transparent);
  will-change:transform;
}
.btn:hover{ transform:translateY(-3px); box-shadow:0 20px 38px -14px color-mix(in srgb, var(--bg) 70%, transparent); }
.btn:active{ transform:translateY(-1px); }
.btn .ico{ width:1.05em; height:1.05em; transition:transform .35s var(--ease); }
.btn:hover .ico{ transform:translateX(4px); }
.btn--forest{ --bg:var(--forest); }
.btn--ghost{ --bg:transparent; --fg:var(--ink); box-shadow:none; border:1.6px solid color-mix(in srgb,var(--ink) 22%,transparent); }
.btn--ghost:hover{ background:var(--ink); --fg:#fff; }
.btn--light{ --bg:#fff; --fg:var(--forest); }
.btn--whats{ --bg:#1fae54; }
.on-dark .btn--ghost{ --fg:#fff; border-color:rgba(255,255,255,.32); }
.on-dark .btn--ghost:hover{ background:#fff; --fg:var(--ink); }
/* ghost sobre imagem/header de vidro — preenchimento translúcido p/ legibilidade */
.site-header .btn--ghost,
.hero .btn--ghost,
.prod-hero .btn--ghost{
  --fg:#fff;
  background:rgba(255,255,255,.16);
  -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
  border-color:rgba(255,255,255,.55);
}
.site-header .btn--ghost:hover,
.hero .btn--ghost:hover,
.prod-hero .btn--ghost:hover{ background:#fff; --fg:var(--ink); border-color:#fff; }

/* link com seta */
.arrow-link{
  display:inline-flex; align-items:center; gap:.55em;
  font-weight:700; color:var(--forest);
  border-bottom:2px solid transparent; padding-bottom:2px;
  transition:gap .3s var(--ease), border-color .3s;
}
.arrow-link:hover{ gap:.9em; border-color:var(--orange); }
.arrow-link .ico{ width:1em; height:1em; color:var(--orange); }
.on-dark .arrow-link{ color:#fff; }

/* ---------- Gotas orgânicas (motivo da marca) ---------- */
.mosaic{ display:flex; flex-wrap:wrap; gap:7px; line-height:0; }
.mosaic i{ width:var(--cell,22px); height:var(--cell,22px); display:block; border-radius:50%; }
/* formas: círculo, gota, meia-lua e blob — atribuídas via JS */
.mosaic i.s-drop{ border-radius:50% 50% 50% 4px; }
.mosaic i.s-half{ border-radius:999px 999px 4px 4px; }
.mosaic i.s-blob{ border-radius:62% 38% 54% 46% / 52% 56% 44% 48%; }
.mosaic i.s-leaf{ border-radius:0 50% 50% 50%; }

/* ---------- Reveal ao rolar ---------- */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.08s; }
.reveal[data-d="2"]{ transition-delay:.16s; }
.reveal[data-d="3"]{ transition-delay:.24s; }
.reveal[data-d="4"]{ transition-delay:.32s; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  html{ scroll-behavior:auto; }
}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed; inset:14px 0 auto 0; z-index:90;
  transition:inset .45s var(--ease);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between; gap:18px;
  padding:9px 9px 9px 22px; border-radius:18px;
  background:rgba(7,26,18,.62);
  backdrop-filter:blur(16px) saturate(1.3);
  -webkit-backdrop-filter:blur(16px) saturate(1.3);
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 18px 44px -26px rgba(0,0,0,.85);
  transition:background .4s var(--ease), border-color .4s, box-shadow .4s;
}
.site-header.scrolled{ inset:8px 0 auto 0; }
.site-header.scrolled .header-inner{
  background:rgba(7,28,19,.92);
  border-color:rgba(255,255,255,.10);
  box-shadow:0 22px 50px -28px rgba(0,0,0,.9);
}
.header-inner{ display:flex; align-items:center; justify-content:space-between; gap:18px; }
.brand{ display:flex; align-items:center; gap:12px; flex-shrink:0; }
.brand img{ height:104px; width:auto; }
.header-nav{ display:flex; align-items:center; gap:2px; }
.nav-link{
  position:relative; padding:10px 14px; border-radius:11px;
  font-family:var(--body); font-weight:600; font-size:.95rem; color:rgba(255,255,255,.84);
  transition:color .25s, background .25s; white-space:nowrap;
}
.nav-link:hover{ color:#fff; background:rgba(255,255,255,.08); }
.nav-link.has-sub{ display:inline-flex; align-items:center; gap:.4em; }
.nav-link.has-sub svg{ width:12px; height:12px; opacity:.7; transition:transform .3s; }
.nav-item{ position:relative; }
.nav-item:hover .nav-link.has-sub svg{ transform:rotate(180deg); }
.submenu{
  position:absolute; top:calc(100% + 14px); left:0; transform:translateY(10px);
  background:#fff; border-radius:20px; padding:16px; width:620px; max-width:78vw;
  max-height:80vh; overflow:auto;
  box-shadow:var(--shadow); opacity:0; visibility:hidden; transition:.32s var(--ease);
  border:1px solid var(--line);
}
.submenu__grid{ display:grid; grid-template-columns:1fr 1fr; gap:2px 8px; }
.nav-item:hover .submenu{ opacity:1; visibility:visible; transform:translateY(0); }
.submenu__h{ font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; font-weight:700; color:var(--orange); padding:6px 12px 12px; }
.submenu a{ display:flex; align-items:center; gap:13px; padding:8px 12px; border-radius:14px; transition:background .2s; }
.submenu a:hover{ background:var(--cream); }
.submenu a > span:last-child{ display:flex; flex-direction:column; gap:1px; min-width:0; }
.submenu a .thumb{ width:46px; height:46px; border-radius:12px; display:flex; align-items:center; justify-content:center; overflow:hidden; flex-shrink:0; box-shadow:inset 0 0 0 1px rgba(255,255,255,.15); }
.submenu a .thumb img{ width:92%; height:92%; object-fit:contain; filter:drop-shadow(0 4px 6px rgba(0,0,0,.35)); }
.submenu a strong{ display:block; font-weight:700; font-size:.92rem; color:var(--text); line-height:1.18; letter-spacing:-.01em; white-space:nowrap; }
.submenu a small{ display:block; font-size:.77rem; color:var(--muted); line-height:1.1; white-space:nowrap; }
.submenu__foot{ margin-top:8px; padding-top:10px; border-top:1px solid var(--line); }
.submenu__foot a{ justify-content:space-between; color:var(--forest); font-weight:700; font-size:.9rem; }
.submenu__foot a .ico{ width:1em; height:1em; transition:transform .3s var(--ease); }
.submenu__foot a:hover .ico{ transform:translateX(4px); }
.header-cta{ display:flex; align-items:center; gap:10px; }
.header-cta .btn{ padding:.75em 1.25em; font-size:.9rem; }

.burger{ display:none; width:46px; height:46px; border-radius:12px; border:none; background:rgba(255,255,255,.1); position:relative; }
.burger span{ position:absolute; left:12px; right:12px; height:2px; background:#fff; border-radius:2px; transition:.3s var(--ease); }
.burger span:nth-child(1){ top:16px; }
.burger span:nth-child(2){ top:22px; }
.burger span:nth-child(3){ top:28px; }
body.menu-open .burger span:nth-child(1){ top:22px; transform:rotate(45deg); }
body.menu-open .burger span:nth-child(2){ opacity:0; }
body.menu-open .burger span:nth-child(3){ top:22px; transform:rotate(-45deg); }

/* Drawer mobile */
.drawer{
  position:fixed; inset:0; z-index:80; background:var(--ink);
  padding:104px var(--gutter) 40px; overflow-y:auto;
  transform:translateX(100%); transition:transform .45s var(--ease);
  display:flex; flex-direction:column;
}
body.menu-open .drawer{ transform:none; }
.drawer a{ color:#fff; }
.drawer-link{ font-family:var(--display); font-weight:600; font-size:1.7rem; padding:14px 0; border-bottom:1px solid rgba(255,255,255,.1); display:flex; justify-content:space-between; align-items:center; }
.drawer-sub{ display:flex; flex-direction:column; gap:2px; padding:6px 0 14px; }
.drawer-sub a{ color:rgba(255,255,255,.7); font-size:1.02rem; padding:9px 0 9px 16px; border-left:2px solid rgba(255,255,255,.14); display:flex; gap:10px; align-items:center; }
.drawer-sub a .dot{ width:9px;height:9px;border-radius:3px; }
.drawer-foot{ margin-top:auto; padding-top:28px; display:flex; flex-direction:column; gap:14px; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end; overflow:hidden; color:#fff; isolation:isolate; }
.hero__media{ position:absolute; inset:0; z-index:-2; }
.hero__media img, .hero__media video{ width:100%; height:100%; object-fit:cover; }
.hero__media::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(10,44,31,.55) 0%, rgba(10,44,31,.15) 30%, rgba(10,44,31,.55) 66%, rgba(8,34,24,.96) 100%),
    linear-gradient(75deg, rgba(10,44,31,.6), transparent 60%);
}
.hero__inner{ width:100%; padding-bottom:clamp(48px,7vw,96px); padding-top:140px; }
.hero h1{
  font-size:clamp(2.6rem, 7vw, 6.6rem); font-weight:800; line-height:.98;
  letter-spacing:-.03em; max-width:18ch;
}
.hero h1 .accent{ color:var(--lime); }
.hero h1 .accent-o{ color:var(--amber); }
.hero__sub{ margin-top:26px; max-width:54ch; font-size:clamp(1.05rem,1.6vw,1.35rem); color:rgba(255,255,255,.86); }
.hero__cta{ margin-top:38px; display:flex; flex-wrap:wrap; gap:14px; align-items:center; }
.hero__scroll{ position:absolute; bottom:26px; right:var(--gutter); display:flex; align-items:center; gap:10px; font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.7); }
.hero__scroll .line{ width:1px; height:46px; background:linear-gradient(rgba(255,255,255,.7), transparent); position:relative; overflow:hidden; }
.hero__scroll .line::after{ content:""; position:absolute; top:-50%; left:0; width:100%; height:50%; background:var(--lime); animation:scrolldot 1.9s var(--ease) infinite; }
@keyframes scrolldot{ to{ top:120%; } }

/* faixa marquee de atributos */
.marquee{ background:var(--orange); color:#fff; overflow:hidden; border-block:none; }
.marquee__track{ display:flex; gap:0; white-space:nowrap; animation:marquee 32s linear infinite; }
.marquee:hover .marquee__track{ animation-play-state:paused; }
.marquee__track span{ display:inline-flex; align-items:center; gap:26px; padding:16px 26px; font-family:var(--display); font-weight:600; font-size:clamp(1rem,1.6vw,1.4rem); letter-spacing:-.01em; }
.marquee__track span::after{ content:""; width:9px; height:9px; border-radius:3px; background:var(--ink); transform:rotate(45deg); }
@keyframes marquee{ to{ transform:translateX(-50%); } }

/* esteira cinética de duas linhas (kinetic belt) */
.belt{ overflow:hidden; padding-block:20px; position:relative; background:var(--ink); }
.belt__row{ display:flex; align-items:center; white-space:nowrap; width:max-content;
  -webkit-mask:linear-gradient(90deg, transparent 0, #000 9%, #000 91%, transparent 100%);
  mask:linear-gradient(90deg, transparent 0, #000 9%, #000 91%, transparent 100%); }
.belt__row + .belt__row{ margin-top:2px; }
.belt__row span{ display:inline-flex; align-items:center; font-family:var(--display); font-weight:600;
  font-size:clamp(1.1rem,2.2vw,1.85rem); letter-spacing:-.01em; line-height:1.15; text-transform:uppercase; padding-right:.1em; color:rgba(255,255,255,.9); }
.belt__row .sep{ width:9px; height:9px; border-radius:3px; transform:rotate(45deg); margin:0 .6em; flex-shrink:0; opacity:.9; }
.belt__row span:nth-child(odd) .sep{ background:var(--lime) !important; }
.belt__row span:nth-child(even) .sep{ background:var(--leaf) !important; }
.belt__row.out span:nth-child(even) .sep{ background:#cfeaa0 !important; }
.belt__a{ animation:beltL 40s linear infinite; }
.belt__b{ animation:beltR 40s linear infinite; }
.belt:hover .belt__a, .belt:hover .belt__b{ animation-play-state:paused; }
.belt__row.out span{ color:rgba(134,197,60,.92); -webkit-text-stroke:0; }
.belt .hl{ color:#fff; }
.belt .hlo{ color:var(--lime); }
@keyframes beltL{ from{ transform:translateX(0);} to{ transform:translateX(-50%);} }
@keyframes beltR{ from{ transform:translateX(-50%);} to{ transform:translateX(0);} }
@media (prefers-reduced-motion: reduce){ .belt__a,.belt__b{ animation:none; } }

/* ============================================================
   SEÇÕES GENÉRICAS
   ============================================================ */
.dark{ background:var(--ink); color:#fff; }
.dark h2,.dark h3{ color:#fff; }
.cream{ background:var(--cream); }

.sec-head{ display:grid; gap:22px; max-width:62ch; }
.sec-head h2{ font-size:clamp(2rem,4.4vw,3.7rem); }
.split-head{ display:grid; grid-template-columns:1fr; gap:30px; align-items:end; }
@media(min-width:900px){ .split-head{ grid-template-columns:1.3fr .9fr; } .split-head .sec-head{ max-width:none; } }

/* Stats */
.stats{ display:grid; grid-template-columns:repeat(2,1fr); gap:2px; margin-top:54px; background:rgba(255,255,255,.12); border-radius:var(--radius); overflow:hidden; }
@media(min-width:760px){ .stats{ grid-template-columns:repeat(4,1fr); } }
.stat{ background:var(--ink); padding:32px 26px; }
.cream .stat{ background:var(--cream); }
.stat__num{ font-family:var(--display); font-weight:700; font-size:clamp(2.4rem,4.6vw,3.6rem); line-height:1; letter-spacing:-.03em; color:var(--lime); }
.cream .stat__num{ color:var(--forest); }
.stat__num .u{ color:var(--orange); }
.stat__label{ margin-top:12px; font-size:.95rem; color:rgba(255,255,255,.72); }
.cream .stat__label{ color:var(--muted); }

/* ============================================================
   JORNADA (da palma ao produto)
   ============================================================ */
/* ---- Jornada interativa (Home) ---- */
.jx-panel{ position:relative; margin-top:50px; background:var(--ink); color:#fff; border-radius:var(--radius-lg); padding:clamp(30px,4.5vw,64px); overflow:hidden; }
.jx-panel__drops{ position:absolute; top:0; right:0; max-width:200px; opacity:.4; transform:translate(20%,-26%); }
.jx{ position:relative; }
.jx__steps{ list-style:none; margin:0; padding:0; display:grid; grid-template-columns:1fr; gap:34px; }
.jx__step{ position:relative; display:flex; gap:22px; align-items:flex-start; }
.jx__node{
  position:relative; flex-shrink:0; width:74px; height:74px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; z-index:1;
  background:rgba(255,255,255,.05); border:1.5px solid rgba(255,255,255,.16);
  color:rgba(255,255,255,.55);
  transition:transform .5s var(--ease), background .5s, border-color .5s, color .5s, box-shadow .5s;
}
.jx__node svg{ width:34px; height:34px; }
.jx__num{
  position:absolute; top:-8px; right:-8px; width:26px; height:26px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background:var(--ink); border:1.5px solid rgba(255,255,255,.2);
  font-family:var(--display); font-weight:700; font-size:.72rem; color:rgba(255,255,255,.6);
  transition:background .5s, color .5s, border-color .5s;
}
.jx__body{ padding-top:6px; }
.jx__body h3{ font-size:1.35rem; }
.jx__body p{ margin-top:9px; font-size:.96rem; color:rgba(255,255,255,.72); max-width:46ch; }
.jx__stage{ display:inline-flex; align-items:center; gap:.5em; font-size:.72rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--lime); margin-bottom:8px; }

/* trilho vertical (mobile-first) */
.jx__rail{ position:absolute; left:37px; top:30px; bottom:30px; width:3px; border-radius:3px; background:rgba(255,255,255,.12); overflow:hidden; z-index:0; }
.jx__rail-fill{ position:absolute; inset:0; background:linear-gradient(180deg, var(--orange), var(--amber) 40%, var(--lime)); transform:scaleY(0); transform-origin:top center; transition:transform 1.6s var(--ease); }
.jx-panel.in .jx__rail-fill{ transform:scaleY(1); }

/* ativa\u00e7\u00e3o sequencial dos n\u00f3s */
.jx__step.jx-active .jx__node{
  background:linear-gradient(150deg, var(--leaf), var(--forest));
  border-color:transparent; color:#fff;
  box-shadow:0 14px 30px -14px rgba(58,155,80,.7);
}
.jx__step.jx-active .jx__num{ background:var(--orange); border-color:transparent; color:#fff; }
.jx__step:hover .jx__node{ transform:scale(1.06); }

@media (prefers-reduced-motion: reduce){
  .jx__rail-fill{ transition:none; }
}

/* desktop: trilho horizontal em 4 colunas */
@media(min-width:880px){
  .jx__steps{ grid-template-columns:repeat(4,1fr); gap:26px; }
  .jx__step{ flex-direction:column; gap:20px; align-items:flex-start; }
  .jx__body{ padding-top:0; }
  .jx__rail{ left:37px; right:37px; top:37px; bottom:auto; width:auto; height:3px; }
  .jx__rail-fill{ background:linear-gradient(90deg, var(--orange), var(--amber) 40%, var(--lime)); transform:scaleX(0); transform-origin:left center; transition:transform 1.8s var(--ease); }
}

.journey{ display:grid; gap:18px; margin-top:56px; grid-template-columns:1fr; }
@media(min-width:720px){ .journey{ grid-template-columns:repeat(2,1fr); } }
@media(min-width:1040px){ .journey{ grid-template-columns:repeat(4,1fr); } }
.step{ position:relative; padding:30px 26px 34px; border-radius:var(--radius); background:#fff; border:1px solid var(--line); overflow:hidden; transition:transform .4s var(--ease), box-shadow .4s; }
.dark .step{ background:rgba(255,255,255,.04); border-color:rgba(255,255,255,.1); }
.step:hover{ transform:translateY(-6px); box-shadow:var(--shadow-sm); }
/* badge verde-pílula (assinatura da marca) */
.vn-badge, .step__n, .offer__tag, .prow__tag{
  display:inline-flex; align-items:center; align-self:flex-start; width:max-content;
  padding:.5em .95em; border-radius:999px; white-space:nowrap;
  background:var(--forest); color:#fff;
  font-family:var(--body); font-weight:700; font-size:.74rem;
  letter-spacing:.06em; text-transform:uppercase; line-height:1;
}
.step__n{ font-size:.72rem; }
.step__ico{ width:42px; height:42px; margin:18px 0 16px; color:var(--leaf); }
.dark .step__ico{ color:var(--lime); }
.step h3{ font-size:1.35rem; }
.step p{ margin-top:10px; font-size:.96rem; color:var(--muted); }
.dark .step p{ color:rgba(255,255,255,.72); }
.step__bar{ position:absolute; left:0; bottom:0; height:4px; width:0; background:var(--orange); transition:width .5s var(--ease); }
.step:hover .step__bar{ width:100%; }

/* variante "diretrizes" — cards mais limpos e interativos */
.journey--guide{ gap:20px; }
.journey--guide .step{ padding:34px 30px 38px; border-radius:var(--radius-lg); display:flex; flex-direction:column; align-items:flex-start; transition:transform .45s var(--ease), box-shadow .45s, border-color .45s; }
.journey--guide .step__ico{ box-sizing:content-box; width:26px; height:26px; padding:15px; border-radius:16px; margin:20px 0 20px; background:color-mix(in srgb, var(--leaf) 14%, #fff); color:var(--forest); transition:background .45s var(--ease), color .45s, transform .45s var(--ease); }
.journey--guide .step:hover{ transform:translateY(-8px); box-shadow:0 30px 60px -34px rgba(10,44,31,.5); border-color:transparent; }
.journey--guide .step:hover .step__ico{ background:var(--forest); color:#fff; transform:rotate(-5deg) scale(1.04); }
.journey--guide .step h3{ font-size:1.32rem; }
.journey--guide .step p{ margin-top:11px; }
.journey--guide .step__bar{ height:5px; background:linear-gradient(90deg, var(--orange), var(--amber)); border-radius:0 4px 0 0; }

/* ============================================================
   LINHA PURIPALMA — showcase
   ============================================================ */
.line-showcase{ position:relative; }
.pp-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:30px; flex-wrap:wrap; }
.pp-logo{ height:clamp(132px,14vw,184px); width:auto; }

.pp-grid{ display:grid; gap:18px; margin-top:50px; grid-template-columns:repeat(1,1fr); }
@media(min-width:560px){ .pp-grid{ grid-template-columns:repeat(2,1fr); } }
@media(min-width:980px){ .pp-grid{ grid-template-columns:repeat(3,1fr); } }

.pcard{
  position:relative; border-radius:var(--radius-lg); overflow:hidden;
  background:var(--card,#214); color:#fff; min-height:470px;
  display:flex; flex-direction:column;
  isolation:isolate;
  transition:transform .5s var(--ease), box-shadow .5s;
}
.pcard:hover{ transform:translateY(-8px); box-shadow:0 40px 70px -34px rgba(0,0,0,.55); }
.pcard__bg{ position:absolute; inset:0; z-index:-2; background:
  radial-gradient(120% 80% at 50% -8%, color-mix(in srgb, var(--card) 58%, #fff 18%), transparent 62%),
  var(--card); }
.pcard__leaf{ position:absolute; inset:0; z-index:-1; opacity:.16; background-repeat:no-repeat; background-position:120% -20%; background-size:65%; }
.pcard__img{
  position:relative; z-index:1; display:block;
  width:auto; max-width:72%; max-height:212px; height:auto;
  margin:34px auto 2px; object-fit:contain;
  filter:drop-shadow(0 20px 28px rgba(0,0,0,.4));
  transition:transform .55s var(--ease);
}
.pcard:hover .pcard__img{ transform:scale(1.05) translateY(-4px); }
.pcard__copy{ position:relative; z-index:1; margin-top:auto; padding:12px 28px 30px; }
.pcard__tag{ display:inline-flex; align-self:flex-start; width:max-content; padding:.5em .95em; border-radius:999px; background:rgba(255,255,255,.18); -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px); font-size:.72rem; letter-spacing:.06em; text-transform:uppercase; font-weight:700; line-height:1; }
.pcard h3{ font-size:1.6rem; margin-top:8px; max-width:16ch; }
.pcard p{ margin-top:10px; font-size:.92rem; color:rgba(255,255,255,.84); max-width:34ch; }
.pcard__cta{ margin-top:18px; display:inline-flex; align-items:center; gap:.5em; font-weight:700; font-size:.92rem; }
.pcard__cta .ico{ width:1em; height:1em; transition:transform .3s var(--ease); }
.pcard:hover .pcard__cta .ico{ transform:translateX(5px); }
.pcard--wide{ grid-column:1 / -1; min-height:0; }
.pcard--wide .pcard__copy{ margin-top:0; padding:clamp(30px,4vw,48px); max-width:62ch; }
.pcard--wide h3{ font-size:clamp(1.6rem,2.6vw,2.2rem); max-width:24ch; }

/* soluções */
.solutions{ display:grid; gap:18px; margin-top:50px; grid-template-columns:1fr; }
@media(min-width:820px){ .solutions{ grid-template-columns:repeat(3,1fr); } }
.sol{ padding:32px 28px; border-radius:var(--radius); background:#fff; border:1px solid var(--line); }
.dark .sol{ background:rgba(255,255,255,.04); border-color:rgba(255,255,255,.1); }
.sol__ico{ width:40px; height:40px; color:var(--orange); margin-bottom:18px; }
.sol h3{ font-size:1.3rem; }
.sol p{ margin-top:10px; color:var(--muted); font-size:.96rem; }
.dark .sol p{ color:rgba(255,255,255,.72); }

/* ============================================================
   CLIENTES / SETORES
   ============================================================ */
.sectors{ display:grid; gap:14px; margin-top:48px; grid-template-columns:repeat(2,1fr); }
@media(min-width:760px){ .sectors{ grid-template-columns:repeat(3,1fr); } }
@media(min-width:1040px){ .sectors{ grid-template-columns:repeat(6,1fr); } }
.sector{ position:relative; aspect-ratio:1; border-radius:var(--radius); border:1px solid var(--line); background:#fff; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px; text-align:center; padding:20px; overflow:hidden; transition:transform .45s var(--ease), color .4s, box-shadow .45s, border-color .4s; }
.sector::before{ content:""; position:absolute; inset:0; background:linear-gradient(155deg, var(--leaf), var(--forest)); opacity:0; transition:opacity .45s var(--ease); z-index:0; }
.sector > *{ position:relative; z-index:1; }
.sector svg{ width:40px; height:40px; color:var(--forest); transition:color .4s, transform .45s var(--ease); }
.sector:hover{ transform:translateY(-8px); color:#fff; border-color:transparent; box-shadow:0 26px 50px -28px rgba(10,44,31,.55); }
.sector:hover::before{ opacity:1; }
.sector:hover svg{ color:#fff; transform:translateY(-3px) scale(1.08); }
.sector span{ font-weight:700; font-size:.95rem; }
.sector__desc{ display:block; font-size:.8rem; font-weight:500; line-height:1.32; color:rgba(255,255,255,.9); max-height:0; opacity:0; overflow:hidden; transition:max-height .5s var(--ease), opacity .4s, margin-top .5s var(--ease); }
.sector:hover .sector__desc{ max-height:72px; opacity:1; margin-top:2px; }

.clients-note{ margin-top:30px; font-size:.86rem; color:var(--muted); display:flex; gap:10px; align-items:center; }

/* ===== Explorador de segmentos (interativo) ===== */
.segx{ display:grid; grid-template-columns:1fr; margin-top:50px; border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--line); background:#fff; box-shadow:var(--shadow-sm); }
@media(min-width:900px){ .segx{ grid-template-columns:312px 1fr; } }
.segx__tabs{ display:flex; gap:8px; padding:14px; overflow-x:auto; border-bottom:1px solid var(--line); scrollbar-width:none; }
.segx__tabs::-webkit-scrollbar{ display:none; }
@media(min-width:900px){ .segx__tabs{ flex-direction:column; overflow:visible; border-bottom:none; border-right:1px solid var(--line); padding:18px; gap:4px; } }
.segx__tab{ flex:0 0 auto; display:flex; align-items:center; gap:13px; padding:14px 16px; border-radius:14px; background:transparent; border:none; cursor:pointer; text-align:left; color:var(--muted); font-family:var(--body); font-weight:700; font-size:.96rem; transition:background .3s var(--ease), color .3s; white-space:nowrap; }
@media(min-width:900px){ .segx__tab{ width:100%; } }
.segx__tab svg{ width:24px; height:24px; flex-shrink:0; color:var(--forest); transition:color .3s; }
.segx__tab:hover{ background:var(--cream); color:var(--text); }
.segx__tab.is-active{ background:var(--forest); color:#fff; box-shadow:0 12px 26px -14px rgba(30,92,58,.6); }
.segx__tab.is-active svg{ color:var(--lime); }
.segx__panel{ position:relative; padding:clamp(28px,4vw,52px); color:#fff; min-height:360px; display:flex; flex-direction:column; justify-content:center; background:radial-gradient(120% 100% at 92% 0%, #2f7d44, var(--forest) 55%, var(--ink)); overflow:hidden; isolation:isolate; }
.segx__drops{ position:absolute; top:0; right:0; max-width:180px; opacity:.32; transform:translate(22%,-26%); z-index:0; }
.segx__content{ position:relative; z-index:1; }
.segx__content.is-anim{ animation:segxIn .5s var(--ease); }
@keyframes segxIn{ from{ opacity:0; transform:translateY(12px);} to{ opacity:1; transform:none; } }
.segx__ico{ width:62px; height:62px; border-radius:17px; background:rgba(255,255,255,.14); display:flex; align-items:center; justify-content:center; margin-bottom:22px; }
.segx__ico svg{ width:32px; height:32px; color:#fff; }
.segx__stage{ display:inline-flex; font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; font-weight:700; color:var(--lime); margin-bottom:10px; }
.segx__panel h3{ font-size:clamp(1.5rem,3vw,2.2rem); }
.segx__panel p{ margin-top:14px; color:rgba(255,255,255,.86); max-width:48ch; }
.segx__prods{ display:flex; flex-wrap:wrap; gap:8px; margin-top:24px; }
.segx__prod{ font-size:.84rem; font-weight:600; padding:8px 14px; border-radius:999px; background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.22); }
.segx__progress{ position:absolute; left:0; bottom:0; height:3px; width:100%; background:rgba(255,255,255,.14); z-index:1; }
.segx__progress i{ display:block; height:100%; width:0; background:var(--lime); }
.segx__progress.run i{ animation:segxBar 6s linear forwards; }
@keyframes segxBar{ from{ width:0; } to{ width:100%; } }
.clients-wall{ display:flex; flex-wrap:wrap; gap:14px; margin-top:24px; }
.client-chip{ height:64px; min-width:150px; flex:1 1 150px; max-width:200px; border-radius:14px; border:1px dashed var(--line); background:var(--paper); display:flex; align-items:center; justify-content:center; color:var(--muted); font-weight:700; letter-spacing:.04em; font-size:.82rem; }

/* ============================================================
   TEASERS (quem somos / sustentabilidade)
   ============================================================ */
.feature{ display:grid; gap:40px; align-items:center; grid-template-columns:1fr; }
@media(min-width:920px){ .feature{ grid-template-columns:1fr 1fr; gap:64px; } .feature.rev .feature__media{ order:2; } }
.feature__media{ position:relative; border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:4/3.2; box-shadow:var(--shadow); }
.feature__media img{ width:100%; height:100%; object-fit:cover; }
.feature__media .tint{ position:absolute; inset:0; background:linear-gradient(200deg, transparent 40%, color-mix(in srgb,var(--forest) 55%, transparent)); mix-blend-mode:multiply; }
.feature__media video{ width:100%; height:100%; object-fit:cover; display:block; }
/* tratamento para recorte de estúdio (fruto em fundo branco) */
.feature__media--float{ background:radial-gradient(120% 120% at 70% 10%, #2b7a44, var(--forest) 55%, var(--ink)); box-shadow:var(--shadow); }
.feature__media--float img{ object-fit:contain; padding:7% 9%; mix-blend-mode:normal; transform:scale(1.02); }
.feature__media--float .tint{ display:none; }
.feature__media--float .mosaic{ position:absolute; left:24px; bottom:20px; max-width:120px; opacity:.85; }
.feature__copy h2{ font-size:clamp(1.9rem,3.6vw,3rem); }
.feature__copy p{ margin-top:18px; color:var(--muted); }
.dark .feature__copy p{ color:rgba(255,255,255,.76); }
.feature__copy .btn, .feature__copy .arrow-link{ margin-top:26px; }
.mvv{ display:grid; gap:16px; grid-template-columns:1fr; margin-top:14px; }
@media(min-width:680px){ .mvv{ grid-template-columns:repeat(3,1fr); } }

/* ============================================================
   CONTATO
   ============================================================ */
.contact{ display:grid; gap:40px; grid-template-columns:1fr; }
@media(min-width:900px){ .contact{ grid-template-columns:1fr 1fr; gap:64px; } }
.contact-cards{ display:grid; gap:14px; }
.ccard{ display:flex; align-items:center; gap:18px; padding:22px 24px; border-radius:var(--radius); background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1); transition:transform .35s var(--ease), background .3s; }
.ccard:hover{ transform:translateX(6px); background:rgba(255,255,255,.09); }
.ccard__ico{ width:50px; height:50px; flex-shrink:0; border-radius:14px; background:var(--orange); display:flex; align-items:center; justify-content:center; color:#fff; }
.ccard__ico svg{ width:24px; height:24px; }
.ccard small{ display:block; color:rgba(255,255,255,.6); font-size:.82rem; letter-spacing:.04em; text-transform:uppercase; }
.ccard strong{ font-size:1.12rem; font-weight:700; }
.socials{ display:flex; gap:12px; margin-top:6px; }
.social{ width:48px; height:48px; border-radius:12px; background:rgba(255,255,255,.08); display:flex; align-items:center; justify-content:center; color:#fff; transition:.3s var(--ease); }
.social:hover{ background:var(--lime); color:var(--ink); transform:translateY(-3px); }
.social svg{ width:22px; height:22px; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{ background:#07241a; color:rgba(255,255,255,.74); padding-top:clamp(60px,7vw,96px); }
.footer-top{ display:grid; gap:44px; grid-template-columns:1fr; padding-bottom:54px; border-bottom:1px solid rgba(255,255,255,.1); }
@media(min-width:880px){ .footer-top{ grid-template-columns:1.4fr 1fr 1fr; } }
.footer-brand img{ height:40px; margin-bottom:20px; }
.footer-brand p{ max-width:38ch; font-size:.95rem; }
.footer-col h4{ font-family:var(--body); font-weight:700; font-size:.82rem; letter-spacing:.14em; text-transform:uppercase; color:var(--lime); margin-bottom:18px; }
.footer-col a{ display:block; padding:7px 0; font-size:.96rem; transition:color .25s, padding .25s; }
.footer-col a:hover{ color:#fff; padding-left:6px; }
.footer-bottom{ display:flex; flex-wrap:wrap; gap:16px; justify-content:space-between; align-items:center; padding-block:28px; font-size:.86rem; }
.footer-mosaic{ height:12px; display:flex; gap:8px; flex-wrap:wrap; overflow:hidden; }
.footer-mosaic i{ width:12px; height:12px; border-radius:50%; flex-shrink:0; }
.footer-mosaic i:nth-child(4n+2){ border-radius:50% 50% 50% 2px; }
.footer-mosaic i:nth-child(4n){ border-radius:999px 999px 2px 2px; }

/* float whatsapp */
.wa-float{ position:fixed; right:20px; bottom:20px; z-index:70; width:60px; height:60px; border-radius:50%; background:#1fae54; display:flex; align-items:center; justify-content:center; box-shadow:0 16px 34px -12px rgba(31,174,84,.7); transition:transform .35s var(--ease); }
.wa-float:hover{ transform:scale(1.08); }
.wa-float svg{ width:30px; height:30px; color:#fff; }

/* ============================================================
   PÁGINA PRODUTOS
   ============================================================ */
.prod-hero{ position:relative; background:var(--ink); color:#fff; padding-top:160px; overflow:hidden; }
/* variante com foto de fundo */
.prod-hero--photo .prod-hero__bg{ position:absolute; inset:0; z-index:0; }
.prod-hero--photo .prod-hero__bg img,
.prod-hero--photo .prod-hero__bg video{ width:100%; height:100%; object-fit:cover; }
.prod-hero--photo .prod-hero__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(7,30,21,.74) 0%, rgba(7,30,21,.5) 38%, rgba(7,28,19,.9) 100%); }
.prod-hero--photo::before{ background:radial-gradient(70% 60% at 88% 0%, rgba(134,197,60,.16), transparent 60%); z-index:0; }
.prod-hero--photo .wrap{ position:relative; z-index:1; }
.prod-hero::before{ content:""; position:absolute; inset:0; background:
  radial-gradient(80% 60% at 85% 0%, rgba(134,197,60,.18), transparent 60%),
  radial-gradient(60% 50% at 0% 100%, rgba(232,85,31,.16), transparent 60%); }
.prod-hero .wrap{ position:relative; padding-bottom:clamp(60px,8vw,110px); }
.prod-hero .pp-logo{ height:clamp(150px,20vw,216px); width:auto; margin-bottom:30px; }
.prod-hero h1{ font-size:clamp(2.4rem,5.6vw,5rem); max-width:18ch; }
.prod-hero p{ margin-top:24px; max-width:60ch; font-size:clamp(1.05rem,1.6vw,1.35rem); color:rgba(255,255,255,.82); }
.prod-hero .mosaic{ position:absolute; right:var(--gutter); bottom:30px; max-width:230px; opacity:.7; }

.product-list{ display:grid; gap:clamp(28px,5vw,72px); }
.prow{ display:grid; gap:34px; align-items:center; grid-template-columns:1fr; }
@media(min-width:940px){ .prow{ grid-template-columns:1fr 1.08fr; gap:60px; } .prow.rev .prow__media{ order:2; } }
.prow__media{
  position:relative; border-radius:var(--radius-lg); overflow:hidden;
  aspect-ratio:1/.86; background:var(--band,#214); display:flex; align-items:center; justify-content:center;
  box-shadow:var(--shadow);
}
.prow__media::after{ content:""; position:absolute; inset:0; background:radial-gradient(110% 80% at 80% -5%, rgba(255,255,255,.16), transparent 55%); }
.prow__media img{ position:relative; width:82%; height:auto; object-fit:contain; filter:drop-shadow(0 30px 40px rgba(0,0,0,.4)); transition:transform .6s var(--ease); z-index:1; }
.prow:hover .prow__media img{ transform:scale(1.05) rotate(-1.5deg); }
.prow__media .mosaic{ position:absolute; left:22px; bottom:18px; max-width:130px; z-index:1; opacity:.9; }
.prow__tag{ background:var(--accent,var(--forest)); }
.prow h2{ font-size:clamp(1.8rem,3.4vw,2.7rem); margin-top:10px; }
.prow__desc{ margin-top:16px; color:var(--muted); }
.selos{ display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-top:24px; }
@media(max-width:480px){ .selos{ grid-template-columns:1fr; } }
.selo{ display:flex; gap:10px; align-items:flex-start; font-size:.9rem; font-weight:600; line-height:1.3; padding:12px 14px; border-radius:12px; background:var(--cream); }
.selo svg{ width:18px; height:18px; flex-shrink:0; color:var(--leaf); margin-top:1px; }
.apps{ margin-top:24px; }
.apps__h{ font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; font-weight:700; color:var(--muted); margin-bottom:12px; }
.apps__list{ display:flex; flex-wrap:wrap; gap:8px; }
.app-chip{ font-size:.85rem; font-weight:600; padding:8px 14px; border-radius:999px; border:1.4px solid var(--line); color:var(--text); }
.prow__cta{ display:flex; flex-wrap:wrap; gap:12px; margin-top:28px; }
.prow__cta .btn{ font-size:.92rem; padding:.9em 1.4em; }

/* bloco final CTA produtos */
.cta-band{ background:linear-gradient(120deg, var(--forest), var(--ink)); color:#fff; border-radius:var(--radius-lg); padding:clamp(40px,6vw,80px); text-align:center; position:relative; overflow:hidden; }
.cta-band .mosaic{ position:absolute; opacity:.18; }
.cta-band h2{ font-size:clamp(2rem,4vw,3.2rem); max-width:20ch; margin-inline:auto; position:relative; }
.cta-band p{ margin:20px auto 0; max-width:54ch; color:rgba(255,255,255,.82); position:relative; }
.cta-band .btn{ margin-top:34px; position:relative; }

/* ============================================================
   SUSTENTABILIDADE
   ============================================================ */
/* faixa de pilares */
.pillars{ display:grid; gap:16px; grid-template-columns:repeat(2,1fr); margin-top:48px; }
@media(min-width:820px){ .pillars{ grid-template-columns:repeat(4,1fr); } }
.pillar{ padding:26px 24px; border-radius:var(--radius); background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1); }
.pillar svg{ width:38px; height:38px; color:var(--lime); margin-bottom:16px; }
.pillar h3{ font-size:1.15rem; }
.pillar p{ margin-top:8px; font-size:.92rem; color:rgba(255,255,255,.74); }

/* downloads ESG */
.docs-cats{ display:grid; gap:20px; grid-template-columns:1fr; margin-top:52px; }
@media(min-width:860px){ .docs-cats{ grid-template-columns:1fr 1fr; } }
.doc-cat{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:clamp(24px,3vw,34px); }
.doc-cat__head{ display:flex; align-items:center; gap:14px; margin-bottom:20px; }
.doc-cat__ico{ width:48px; height:48px; flex-shrink:0; border-radius:13px; background:var(--forest); color:#fff; display:flex; align-items:center; justify-content:center; }
.doc-cat__ico svg{ width:24px; height:24px; }
.doc-cat__head h3{ font-size:1.2rem; line-height:1.1; }
.doc-cat__head span{ display:block; font-size:.78rem; color:var(--muted); font-weight:600; margin-top:3px; }
.doc-list{ display:flex; flex-direction:column; gap:8px; }
.doc-link{ display:flex; align-items:center; gap:14px; padding:13px 14px; border-radius:14px; background:var(--cream); transition:background .25s var(--ease), transform .25s var(--ease), box-shadow .25s; }
.doc-link:hover{ background:#fff; box-shadow:var(--shadow-sm); transform:translateX(4px); }
.doc-link__pdf{ width:40px; height:40px; flex-shrink:0; border-radius:10px; background:var(--orange); color:#fff; display:flex; align-items:center; justify-content:center; font-family:var(--display); font-weight:800; font-size:.6rem; letter-spacing:.04em; }
.doc-link__t{ flex:1; min-width:0; font-weight:600; font-size:.93rem; line-height:1.25; color:var(--text); }
.doc-link__dl{ width:34px; height:34px; flex-shrink:0; border-radius:9px; background:rgba(30,92,58,.08); color:var(--forest); display:flex; align-items:center; justify-content:center; transition:background .25s, color .25s; }
.doc-link:hover .doc-link__dl{ background:var(--forest); color:#fff; }
.doc-link__dl svg{ width:17px; height:17px; }

/* ============================================================
   TRABALHE CONOSCO / CULTURA
   ============================================================ */
.culture-hero__logo{ height:clamp(120px,16vw,180px); width:auto; margin-bottom:30px; }
.gallery{ display:grid; gap:14px; grid-template-columns:repeat(2,1fr); margin-top:52px; }
@media(min-width:820px){ .gallery{ grid-template-columns:repeat(4,1fr); } }
.g-tile{ border-radius:var(--radius); overflow:hidden; position:relative; aspect-ratio:4/5; }
.g-tile--ph{ border:1.6px dashed var(--line); background:var(--cream); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px; color:var(--muted); text-align:center; padding:18px; }
.g-tile--ph svg{ width:34px; height:34px; opacity:.55; }
.g-tile--ph span{ font-size:.82rem; font-weight:600; }
.g-tile--c{ display:flex; align-items:flex-end; padding:22px; color:#fff; }
.g-tile--c span{ font-family:var(--display); font-weight:700; font-size:1.4rem; line-height:1.05; letter-spacing:-.01em; }
.g-tile--c .mosaic{ position:absolute; top:16px; left:16px; max-width:80px; opacity:.85; }

/* candidatura */
.apply{ display:grid; gap:18px; grid-template-columns:1fr; margin-top:50px; }
@media(min-width:820px){ .apply{ grid-template-columns:1fr 1fr; } }
.apply-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:clamp(28px,3.5vw,40px); display:flex; flex-direction:column; }
.apply-card.dark-card{ background:var(--ink); color:#fff; border-color:transparent; }
.apply-card__ico{ width:54px; height:54px; border-radius:14px; background:var(--orange); color:#fff; display:flex; align-items:center; justify-content:center; margin-bottom:22px; }
.dark-card .apply-card__ico{ background:var(--lime); color:var(--ink); }
.apply-card__ico svg{ width:26px; height:26px; }
.apply-card h3{ font-size:1.5rem; }
.apply-card p{ margin-top:12px; color:var(--muted); }
.dark-card p{ color:rgba(255,255,255,.78); }
.apply-card .btn, .apply-card .arrow-link{ margin-top:auto; align-self:flex-start; }
.apply-card .btn{ margin-top:26px; }

/* ===== Formulário de candidatura ===== */
.recruit{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:clamp(26px,4vw,48px); box-shadow:var(--shadow-sm); margin-top:50px; }
.recruit__head{ margin-bottom:28px; }
.recruit__head h3{ font-size:clamp(1.5rem,2.8vw,2.1rem); margin-top:10px; }
.recruit__head p{ margin-top:10px; color:var(--muted); max-width:54ch; }
.rf-grid{ display:grid; grid-template-columns:1fr; gap:18px; }
@media(min-width:680px){ .rf-grid{ grid-template-columns:1fr 1fr; } }
.rf-field{ display:flex; flex-direction:column; gap:9px; min-width:0; }
.rf-col-2{ grid-column:1 / -1; }
.rf-label{ font-weight:700; font-size:.9rem; color:var(--text); }
.rf-label .req{ color:var(--orange); }
.rf-input, .rf-select{ width:100%; font-family:var(--body); font-size:1rem; color:var(--text); background:var(--paper); border:1.6px solid var(--line); border-radius:12px; padding:13px 15px; transition:border-color .25s, box-shadow .25s; }
.rf-input::placeholder{ color:#9aa69d; }
.rf-input:focus, .rf-select:focus{ outline:none; border-color:var(--forest); box-shadow:0 0 0 4px color-mix(in srgb,var(--forest) 14%, transparent); }
.rf-select{ appearance:none; -webkit-appearance:none; background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%231e5c3a' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><path d='m6 9 6 6 6-6'/></svg>"); background-repeat:no-repeat; background-position:right 14px center; padding-right:42px; cursor:pointer; }
.rf-chips{ display:flex; flex-wrap:wrap; gap:10px; }
.rf-chip{ position:relative; }
.rf-chip input{ position:absolute; inset:0; opacity:0; cursor:pointer; margin:0; }
.rf-chip span{ display:block; padding:11px 20px; border-radius:999px; border:1.6px solid var(--line); font-weight:600; font-size:.92rem; color:var(--text); cursor:pointer; transition:background .25s, border-color .25s, color .25s; }
.rf-chip input:checked + span{ background:var(--forest); border-color:var(--forest); color:#fff; }
.rf-chip input:focus-visible + span{ box-shadow:0 0 0 4px color-mix(in srgb,var(--forest) 16%, transparent); }
.rf-file{ position:relative; display:block; border:1.8px dashed var(--line); border-radius:14px; padding:26px 22px; text-align:center; cursor:pointer; background:var(--paper); transition:border-color .25s, background .25s; }
.rf-file:hover, .rf-file.drag{ border-color:var(--forest); background:color-mix(in srgb,var(--forest) 5%, #fff); }
.rf-file input{ position:absolute; inset:0; opacity:0; cursor:pointer; }
.rf-file__ico{ width:38px; height:38px; margin:0 auto 12px; color:var(--forest); }
.rf-file__t{ display:block; font-weight:700; font-size:.96rem; color:var(--text); word-break:break-word; }
.rf-file__h{ display:block; font-size:.82rem; color:var(--muted); margin-top:5px; }
.rf-file.has-file{ border-style:solid; border-color:var(--forest); background:color-mix(in srgb,var(--forest) 6%, #fff); }
.rf-file.has-file .rf-file__t{ color:var(--forest); }
.rf-submit{ margin-top:28px; }
.rf-submit .btn{ width:100%; justify-content:center; font-size:1.04rem; padding:1.1em 1.5em; }
.rf-submit .btn[disabled]{ opacity:.6; pointer-events:none; }
.rf-note{ font-size:.8rem; color:var(--muted); margin-top:14px; text-align:center; }
.rf-msg{ margin-top:18px; padding:15px 18px; border-radius:12px; font-weight:600; font-size:.95rem; display:none; }
.rf-msg.show{ display:block; }
.rf-msg.ok{ background:color-mix(in srgb,var(--leaf) 15%,#fff); color:var(--forest); border:1px solid color-mix(in srgb,var(--leaf) 38%,#fff); }
.rf-msg.err{ background:#fdeae3; color:#a8431f; border:1px solid #f3c7b9; }

/* ============================================================
   B2B / VENDAS CORPORATIVAS
   ============================================================ */
/* duas ofertas principais */
.offers{ display:grid; gap:20px; grid-template-columns:1fr; margin-top:52px; }
@media(min-width:880px){ .offers{ grid-template-columns:1fr 1fr; } }
.offer{ position:relative; border-radius:var(--radius-lg); overflow:hidden; padding:clamp(30px,4vw,46px); color:#fff; min-height:440px; display:flex; flex-direction:column; isolation:isolate; transition:transform .5s var(--ease), box-shadow .5s; }
.offer:hover{ transform:translateY(-6px); box-shadow:0 40px 70px -34px rgba(0,0,0,.5); }
.offer__bg{ position:absolute; inset:0; z-index:-2; }
.offer--granel .offer__bg{ background:radial-gradient(120% 90% at 85% -10%, #2f7d44, var(--forest) 50%, var(--ink)); }
.offer--label .offer__bg{ background:radial-gradient(120% 90% at 85% -10%, #c8861a, #a8431f 55%, #6e2a12); }
.offer__img{ position:absolute; right:-8%; bottom:-6%; width:54%; z-index:-1; filter:drop-shadow(0 26px 40px rgba(0,0,0,.45)); transition:transform .6s var(--ease); }
.offer:hover .offer__img{ transform:scale(1.05) rotate(-2deg); }
.offer__tag{ background:rgba(255,255,255,.18); -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px); }
.offer--label .offer__tag{ background:var(--forest); }
.offer h3{ font-size:clamp(1.7rem,2.8vw,2.3rem); margin-top:12px; max-width:13ch; }
.offer p{ margin-top:14px; color:rgba(255,255,255,.84); max-width:34ch; }
.offer__list{ margin:22px 0 0; padding:0; list-style:none; display:flex; flex-direction:column; gap:10px; max-width:36ch; }
.offer__list li{ display:flex; gap:10px; align-items:flex-start; font-size:.94rem; font-weight:500; }
.offer__list svg{ width:18px; height:18px; flex-shrink:0; margin-top:3px; color:var(--lime); }
.offer .btn{ margin-top:28px; align-self:flex-start; }

/* formatos de fornecimento */
.formats{ display:grid; gap:14px; grid-template-columns:repeat(2,1fr); margin-top:48px; }
@media(min-width:900px){ .formats{ grid-template-columns:repeat(4,1fr); } }
.format{ padding:28px 24px; border-radius:var(--radius); background:#fff; border:1px solid var(--line); }
.format svg{ width:40px; height:40px; color:var(--forest); margin-bottom:16px; }
.format h3{ font-size:1.18rem; }
.format p{ margin-top:8px; font-size:.92rem; color:var(--muted); }

/* showcase personalização */
.brandbox{ position:relative; }
.brandbox .feature__media{ background:var(--ink); }
.brandbox .feature__media img{ width:100%; height:100%; object-fit:cover; }

/* ============================================================
   SOBRE NÓS
   ============================================================ */
/* missão / visão / valores */
.mvv-grid{ display:grid; gap:18px; grid-template-columns:1fr; margin-top:50px; }
@media(min-width:820px){ .mvv-grid{ grid-template-columns:repeat(3,1fr); } }
.mvv-card{ padding:34px 30px; border-radius:var(--radius-lg); background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1); }
.mvv-card__ico{ width:50px; height:50px; border-radius:13px; background:var(--lime); color:var(--ink); display:flex; align-items:center; justify-content:center; margin-bottom:22px; }
.mvv-card__ico svg{ width:26px; height:26px; }
.mvv-card h3{ font-size:1.4rem; }
.mvv-card p{ margin-top:12px; color:rgba(255,255,255,.78); }
.mvv-card ul{ margin:14px 0 0; padding:0; list-style:none; display:flex; flex-direction:column; gap:9px; }
.mvv-card li{ display:flex; gap:10px; align-items:flex-start; font-size:.95rem; color:rgba(255,255,255,.84); }
.mvv-card li svg{ width:17px; height:17px; flex-shrink:0; margin-top:3px; color:var(--lime); }

/* marcas do grupo */
.brands{ display:grid; gap:18px; grid-template-columns:1fr; margin-top:50px; }
@media(min-width:760px){ .brands{ grid-template-columns:repeat(3,1fr); } }
.brand-card{ border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--line); background:#fff; display:flex; flex-direction:column; transition:transform .45s var(--ease), box-shadow .45s; }
.brand-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-sm); }
.brand-card__top{ aspect-ratio:16/9; display:flex; align-items:center; justify-content:center; padding:34px; position:relative; overflow:hidden; }
.brand-card__top img{ max-height:84px; width:auto; position:relative; z-index:1; }
.brand-card__top .mosaic{ position:absolute; inset:auto auto 14px 14px; max-width:70px; opacity:.5; }
.brand-card__body{ padding:26px 28px 30px; }
.brand-card__body h3{ font-size:1.25rem; }
.brand-card__body p{ margin-top:10px; font-size:.94rem; color:var(--muted); }

/* ---------- responsivo header ---------- */
@media(max-width:1000px){
  .header-nav, .header-cta .btn--ghost{ display:none; }
  .burger{ display:block; }
}
@media(max-width:540px){
  .header-cta .btn:not(.burger){ display:none; }
  .header-inner{ padding-left:16px; }
  .brand img{ height:80px; }
}
