/* ══════════════════════════════════════
   VARIÁVEIS — PALETA VERDE/ESCURO
   ══════════════════════════════════════ */
:root {
  /* Verde */
  --g:  #7cb342;
  --gl: #9ccc65;
  --gd: #558b2f;

  /* Fundos escuros */
  --bg:      #080808;
  --bg2:     #111111;
  --surface: #111111;
  --s2:      #1a1a1a;

  /* Tipografia escura */
  --ink:   #ffffff;
  --ink2:  rgba(255, 255, 255, 0.55);
  --white: #ffffff;
  --muted: rgba(255, 255, 255, 0.45);

  /* Bordas */
  --border:   rgba(255, 255, 255, 0.07);
  --border-d: rgba(255, 255, 255, 0.07);

  /* Easing */
  --ease:   cubic-bezier(0.16, 1, 0.3, 1);
  --easing: cubic-bezier(0.32, 0.72, 0, 1);
  --spring: cubic-bezier(0.34, 1.56, 0.64, 1);

  /* Paleta pérola — seções claras */
  --pearl:      #f5f2eb;
  --pearl2:     #edeae1;
  --pearl3:     #d8d4c8;
  --pearl-ink:  #1c1c18;
  --pearl-ink2: #5c5c50;
  --pearl-g:    #4e7a14;

  /* Accent remap → verde */
  --accent:       #7cb342;
  --accent-light: rgba(124, 179, 66, 0.12);
  --accent-glow:  rgba(124, 179, 66, 0.28);

  /* Navy remap → fundo escuro */
  --navy:      #080808;
  --steel:     #2a3a1a;

  /* Textos body */
  --text-body: rgba(255, 255, 255, 0.85);
  --text-muted: rgba(255, 255, 255, 0.42);

  /* Glass — versão escura */
  --glass-bg:       rgba(17, 17, 17, 0.82);
  --glass-bg-strong: rgba(8, 8, 8, 0.94);
  --glass-border:   rgba(124, 179, 66, 0.18);
  --glass-shadow:
    0 8px 48px rgba(0, 0, 0, 0.55),
    0 2px 8px rgba(0, 0, 0, 0.35);
  --glass-blur: blur(28px) saturate(160%);

  /* Dropdown */
  --drop-bg:     rgba(17, 17, 17, 0.96);
  --drop-border: rgba(124, 179, 66, 0.2);

  /* Surface hover */
  --surface-hover: rgba(124, 179, 66, 0.09);

  --nav-h: 68px;
}

/* ══════════════════════════════════════
   RESET BASE
   ══════════════════════════════════════ */
*,
*::before,
*::after { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
  font-family: "DM Sans", sans-serif;
  background: var(--bg);
  color: var(--ink);
}

/* ══════════════════════════════════════
   NAVBAR — .nav
   ══════════════════════════════════════ */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  padding: 0 2rem;
  height: var(--nav-h);
  display: flex;
  align-items: center;
  transition:
    background 0.5s var(--easing),
    backdrop-filter 0.5s,
    box-shadow 0.5s,
    border-bottom 0.5s;
  background: transparent;
  border-bottom: 1px solid transparent;
  opacity: 0;
  transform: translateY(-12px);
  animation: navIn 0.6s var(--spring) 0.1s forwards;
}
@keyframes navIn { to { opacity: 1; transform: translateY(0); } }

/* Scrollado → glass escuro */
.nav.nav--scrolled {
  background: var(--glass-bg);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  box-shadow: var(--glass-shadow);
  border-bottom: 1px solid var(--glass-border);
}

/* Linha gradiente verde no topo */
.nav::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    var(--g) 40%,
    var(--gl) 60%,
    transparent 100%
  );
  opacity: 0;
  transition: opacity 0.5s;
  background-size: 200% 100%;
  animation: shimmerLine 3s linear infinite;
}
.nav.nav--scrolled::before { opacity: 1; }
@keyframes shimmerLine {
  0%   { background-position: -100% 0; }
  100% { background-position:  200% 0; }
}

.nav__inner {
  max-width: 1280px;
  width: 100%;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 1.5rem;
}

/* ── Logo ── */
.nav__logo {
  flex-shrink: 0;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 0.6rem;
  transition: transform 0.3s var(--spring);
}
.nav__logo:hover { transform: scale(1.03); }

.nav__logo-mark {
  width: 38px; height: 38px;
  background: var(--g);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 16px var(--accent-glow);
  transition: box-shadow 0.3s, transform 0.3s var(--spring);
  flex-shrink: 0;
}
.nav__logo:hover .nav__logo-mark {
  box-shadow: 0 6px 24px rgba(124, 179, 66, 0.5);
  transform: rotate(-6deg) scale(1.08);
}
.nav__logo-mark svg { width: 20px; height: 20px; }

.nav__logo-text {
  font-family: "League Spartan", sans-serif;
  font-size: 1.25rem;
  font-weight: 900;
  letter-spacing: -0.02em;
  color: #fff;
  line-height: 1;
  transition: color 0.3s;
}
/* No scroll, logo permanece branca (fundo escuro) */
.nav--scrolled .nav__logo-text { color: var(--ink); }
.nav__logo-text em { color: var(--g); font-style: normal; }

/* Logo fill SVG */
.logo-fill { transition: fill 0.3s ease; }
.nav--scrolled .logo-fill { fill: var(--gl) !important; }

/* ── Links ── */
.nav__links {
  display: flex;
  align-items: center;
  gap: 0.15rem;
  list-style: none;
  margin-left: auto;
}
.nav__links li {
  position: relative;
  padding-bottom: 8px;
  margin-bottom: -8px;
}
.nav__links a {
  display: flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.5rem 0.9rem;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.88);
  text-decoration: none;
  border-radius: 10px;
  transition:
    color 0.3s,
    background 0.3s,
    transform 0.2s var(--spring);
  white-space: nowrap;
}
.nav--scrolled .nav__links a { color: var(--ink2); }

.nav__links a:hover {
  color: var(--g);
  background: var(--surface-hover);
  transform: translateY(-1px);
}
.nav--scrolled .nav__links a:hover { color: var(--g); background: var(--surface-hover); }
.nav__links a.active         { color: var(--g); }
.nav--scrolled .nav__links a.active { color: var(--g); }

/* Chevron */
.nav__chevron {
  width: 13px; height: 13px;
  stroke: currentColor; fill: none;
  stroke-width: 2.5; stroke-linecap: round;
  transition: transform 0.3s var(--easing);
  flex-shrink: 0;
}
.nav__links li.drop-open > a .nav__chevron { transform: rotate(180deg); }

/* ── Dropdown base ── */
.nav__dropdown {
  position: absolute;
  top: calc(100% + 4px);
  left: 50%;
  transform: translateX(-50%) translateY(10px) scale(0.97);
  opacity: 0;
  pointer-events: none;
  transition:
    opacity 0.28s var(--easing),
    transform 0.3s var(--spring);
  z-index: 300;
  padding-top: 8px;
  transform-origin: top center;
}
.nav__links li.drop-open > .nav__dropdown {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0) scale(1);
}

/* ── Social Dropdown ── */
.nav__social-drop {
  width: 270px;
  background: var(--drop-bg);
  backdrop-filter: blur(32px) saturate(160%);
  -webkit-backdrop-filter: blur(32px) saturate(160%);
  border: 1px solid var(--drop-border);
  border-radius: 20px;
  padding: 1.1rem 1rem;
  box-shadow:
    0 20px 60px rgba(0, 0, 0, 0.5),
    0 4px 12px rgba(0, 0, 0, 0.3);
  position: relative;
}
.nav__social-drop::before,
.nav__mega::before {
  content: "";
  position: absolute;
  top: -6px; left: 50%;
  transform: translateX(-50%) rotate(45deg);
  width: 11px; height: 11px;
  background: var(--drop-bg);
  border-left: 1px solid var(--drop-border);
  border-top:  1px solid var(--drop-border);
}

.nav__drop-title {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--g);
  padding: 0 0.5rem 0.8rem;
  display: block;
}

/* Social link rows */
@keyframes rowIn {
  from { opacity: 0; transform: translateX(-12px); }
  to   { opacity: 1; transform: translateX(0); }
}
.nav__links li:hover .nav__social-link                 { animation: rowIn 0.35s var(--spring) both; }
.nav__links li:hover .nav__social-link:nth-child(2)    { animation-delay: 0.03s; }
.nav__links li:hover .nav__social-link:nth-child(4)    { animation-delay: 0.09s; }
.nav__links li:hover .nav__social-link:nth-child(6)    { animation-delay: 0.15s; }
.nav__links li:hover .nav__social-link:nth-child(8)    { animation-delay: 0.21s; }

.nav__social-link {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  padding: 0.7rem;
  border-radius: 14px;
  text-decoration: none;
  position: relative;
  overflow: hidden;
  transition:
    background 0.2s,
    transform 0.25s var(--spring),
    box-shadow 0.2s;
  border: 1px solid transparent;
}
.nav__social-link::before {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(110deg, transparent 30%, rgba(255,255,255,0.08) 50%, transparent 70%);
  transform: translateX(-120%);
  transition: transform 0.55s var(--easing);
  pointer-events: none;
  border-radius: inherit;
}
.nav__social-link:hover::before { transform: translateX(120%); }
.nav__social-link:hover {
  background: rgba(124, 179, 66, 0.1);
  border-color: rgba(124, 179, 66, 0.22);
  transform: translateX(4px);
  box-shadow: 0 2px 12px rgba(124, 179, 66, 0.12);
}

/* Social icons — mantém cores de marca */
.nav__social-icon {
  width: 40px; height: 40px;
  border-radius: 11px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: transform 0.3s var(--spring), box-shadow 0.3s;
  position: relative; overflow: hidden;
}
.nav__social-icon svg { width: 18px; height: 18px; position: relative; z-index: 1; }

@keyframes waBounce {
  0%, 100% { transform: scale(1) rotate(0deg); }
  30%       { transform: scale(1.2) rotate(-8deg); }
  60%       { transform: scale(0.92) rotate(5deg); }
}
.nav__social-icon--wa { background: linear-gradient(135deg,#25d366,#128c7e); box-shadow:0 3px 12px rgba(37,211,102,.2); }
.nav__social-link:hover .nav__social-icon--wa { box-shadow:0 6px 20px rgba(37,211,102,.4); transform:scale(1.1); }
.nav__social-link:hover .nav__social-icon--wa svg { animation: waBounce 0.5s var(--spring); }

@keyframes igSpin {
  0%   { transform: rotate(0) scale(1); }
  50%  { transform: rotate(18deg) scale(1.15); }
  100% { transform: rotate(0) scale(1); }
}
.nav__social-icon--ig { background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888); box-shadow:0 3px 12px rgba(225,48,108,.2); }
.nav__social-link:hover .nav__social-icon--ig { box-shadow:0 6px 20px rgba(225,48,108,.4); transform:scale(1.1); }
.nav__social-link:hover .nav__social-icon--ig svg { animation: igSpin 0.45s var(--spring); }

@keyframes fbShake {
  0%, 100% { transform: translateX(0); }
  25%       { transform: translateX(-3px); }
  75%       { transform: translateX(3px); }
}
.nav__social-icon--fb { background:#1877f2; box-shadow:0 3px 12px rgba(24,119,242,.2); }
.nav__social-link:hover .nav__social-icon--fb { box-shadow:0 6px 20px rgba(24,119,242,.4); transform:scale(1.1); }
.nav__social-link:hover .nav__social-icon--fb svg { animation: fbShake 0.35s var(--easing); }

@keyframes tkGlitch {
  0%, 100% { transform:translate(0); filter:none; }
  20%  { transform:translate(-2px,1px);  filter:drop-shadow(2px 0 #ff0050); }
  40%  { transform:translate(2px,-1px);  filter:drop-shadow(-2px 0 #00f2ea); }
  60%  { transform:translate(-1px,2px); }
  80%  { transform:translate(1px,-1px);  filter:drop-shadow(1px 0 #ff0050); }
}
.nav__social-icon--tk { background:#010101; border:1px solid rgba(255,255,255,.12); box-shadow:0 3px 12px rgba(0,0,0,.15); }
.nav__social-link:hover .nav__social-icon--tk { box-shadow:0 6px 20px rgba(255,0,80,.35); transform:scale(1.1); }
.nav__social-link:hover .nav__social-icon--tk svg { animation: tkGlitch 0.45s steps(1); }

.nav__social-info { display:flex; flex-direction:column; flex:1; min-width:0; }
.nav__social-name   { font-size:.82rem; font-weight:700; color:var(--ink);  line-height:1.2; transition:color .2s; }
.nav__social-handle { font-size:.71rem; color:var(--text-muted); transition:color .2s; }
.nav__social-link:hover .nav__social-name   { color: var(--g); }
.nav__social-link:hover .nav__social-handle { color: var(--gl); }

.nav__social-arrow {
  margin-left:auto; flex-shrink:0;
  width:18px; height:18px;
  opacity:0; transform:translateX(-5px);
  transition: opacity .2s, transform .3s var(--spring);
  color: var(--g);
}
.nav__social-arrow svg { width:100%; height:100%; stroke:currentColor; fill:none; stroke-width:2.2; stroke-linecap:round; }
.nav__social-link:hover .nav__social-arrow { opacity:1; transform:translateX(0); }

.nav__drop-divider {
  height:1px;
  background:linear-gradient(90deg, transparent, var(--drop-border), transparent);
  margin:.25rem .5rem;
}

/* ── Mega Menu ── */
.nav__mega {
  width:580px;
  background: var(--drop-bg);
  backdrop-filter:blur(32px) saturate(160%);
  -webkit-backdrop-filter:blur(32px) saturate(160%);
  border:1px solid var(--drop-border);
  border-radius:22px;
  padding:1.4rem;
  box-shadow:
    0 24px 64px rgba(0,0,0,.5),
    0 4px 16px rgba(0,0,0,.3);
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:.8rem;
  position:relative;
}
.nav__mega::before { background:var(--drop-bg); }

.nav__mega-col       { display:flex; flex-direction:column; gap:.2rem; }
.nav__mega-col-title {
  font-size:.63rem; font-weight:700; letter-spacing:.14em;
  text-transform:uppercase; color:var(--g);
  padding:0 .5rem .55rem;
}

@keyframes megaItemIn {
  from { opacity:0; transform:translateY(8px); }
  to   { opacity:1; transform:translateY(0); }
}
.nav__links li:hover .nav__mega-item                 { animation:megaItemIn .35s var(--spring) both; }
.nav__links li:hover .nav__mega-item:nth-child(2)    { animation-delay:.04s; }
.nav__links li:hover .nav__mega-item:nth-child(3)    { animation-delay:.08s; }
.nav__links li:hover .nav__mega-item:nth-child(4)    { animation-delay:.12s; }
.nav__links li:hover .nav__mega-item:nth-child(5)    { animation-delay:.16s; }
.nav__links li:hover .nav__mega-item:nth-child(6)    { animation-delay:.20s; }

.nav__mega-item {
  display:flex; align-items:center; gap:.65rem;
  padding:.55rem .65rem;
  border-radius:11px;
  text-decoration:none;
  color:var(--ink2);
  font-size:.83rem; font-weight:500;
  transition:
    background .2s, color .2s,
    transform .2s var(--spring), box-shadow .2s;
  border:1px solid transparent;
  position:relative; overflow:hidden;
}
.nav__mega-item::before {
  content:""; position:absolute; inset:0;
  background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.06) 50%,transparent 70%);
  transform:translateX(-120%);
  transition:transform .45s var(--easing);
  pointer-events:none;
}
.nav__mega-item:hover::before { transform:translateX(120%); }
.nav__mega-item:hover {
  background: rgba(124,179,66,.1);
  color: var(--g);
  transform:translateX(3px);
  border-color:rgba(124,179,66,.22);
  box-shadow:0 2px 10px rgba(124,179,66,.1);
}

.nav__mega-dot {
  width:30px; height:30px;
  border-radius:8px;
  background:rgba(124,179,66,.12);
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
  font-size:.62rem; font-weight:900;
  font-family:"League Spartan",sans-serif;
  color:var(--g);
  transition:background .2s, transform .25s var(--spring), color .2s;
}
.nav__mega-item:hover .nav__mega-dot {
  background:var(--g);
  color:#000;
  transform:scale(1.12) rotate(-5deg);
}

/* Footer banner mega */
.nav__mega-footer {
  grid-column:1 / -1;
  margin-top:.2rem;
  padding:.85rem 1.1rem;
  border-radius:14px;
  background:linear-gradient(110deg, rgba(124,179,66,.12), rgba(85,139,47,.08));
  border:1px solid rgba(124,179,66,.22);
  display:flex; align-items:center; justify-content:space-between;
  text-decoration:none;
  transition:
    background .25s, border-color .25s,
    transform .25s var(--spring), box-shadow .25s;
  position:relative; overflow:hidden;
}
.nav__mega-footer::before {
  content:""; position:absolute; inset:0;
  background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.05) 50%,transparent 70%);
  transform:translateX(-120%);
  transition:transform .6s var(--easing);
  pointer-events:none;
}
.nav__mega-footer:hover::before { transform:translateX(120%); }
.nav__mega-footer:hover {
  background:linear-gradient(110deg, rgba(124,179,66,.2), rgba(85,139,47,.15));
  border-color:rgba(124,179,66,.4);
  transform:translateY(-1px);
  box-shadow:0 6px 20px rgba(124,179,66,.15);
}
.nav__mega-footer-text { font-size:.82rem; font-weight:700; color:var(--ink); }
.nav__mega-footer-sub  { font-size:.71rem; color:var(--text-muted); }
.nav__mega-footer-arrow {
  width:30px; height:30px; border-radius:50%;
  background:var(--g);
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
  transition:transform .3s var(--spring), box-shadow .3s;
  box-shadow:0 3px 10px var(--accent-glow);
}
.nav__mega-footer:hover .nav__mega-footer-arrow {
  transform:translateX(4px);
  box-shadow:0 4px 16px rgba(124,179,66,.45);
}
.nav__mega-footer-arrow svg { width:13px; height:13px; stroke:#000; fill:none; stroke-width:2.5; stroke-linecap:round; }

/* ── CTA ── */
.nav__cta {
  flex-shrink:0;
  padding:.52rem 1.15rem;
  border-radius:30px;
  background:var(--g);
  color:#000 !important;
  font-size:.79rem !important; font-weight:700 !important;
  text-transform:uppercase !important; letter-spacing:.08em !important;
  text-decoration:none;
  display:flex; align-items:center; gap:.4rem;
  box-shadow:0 4px 18px var(--accent-glow);
  transition:box-shadow .3s, transform .25s var(--spring), background .25s;
  position:relative; overflow:hidden; border:none;
}
.nav__cta::before {
  content:""; position:absolute; inset:0;
  background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.18) 50%,transparent 70%);
  transform:translateX(-120%);
  transition:transform .45s var(--easing);
  pointer-events:none;
}
.nav__cta:hover::before { transform:translateX(120%); }
.nav__cta:hover {
  transform:scale(1.05) translateY(-1px);
  box-shadow:0 8px 28px rgba(124,179,66,.5);
  background:var(--gl);
}
.nav__cta svg { width:13px; height:13px; flex-shrink:0; }

/* ── Hamburger ── */
.nav__hamburger {
  display:none; flex-direction:column; justify-content:center;
  gap:5px; width:40px; height:40px;
  background:none; border:none; cursor:pointer; padding:6px;
  margin-left:auto; border-radius:10px;
  transition:background .2s;
}
.nav__hamburger:hover { background:var(--surface-hover); }
.nav__hamburger span {
  display:block; height:2px; border-radius:2px; background:#fff;
  transition:transform .35s var(--easing), opacity .25s, width .25s;
  transform-origin:center;
}
.nav__hamburger span:nth-child(1) { width:22px; }
.nav__hamburger span:nth-child(2) { width:16px; }
.nav__hamburger span:nth-child(3) { width:20px; }
.nav__hamburger.open span:nth-child(1) { width:22px; transform:translateY(7px) rotate(45deg); }
.nav__hamburger.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.nav__hamburger.open span:nth-child(3) { width:22px; transform:translateY(-7px) rotate(-45deg); }

/* ── Mobile Drawer ── */
.nav__drawer {
  position:fixed; top:var(--nav-h); left:0; right:0; z-index:999;
  background:rgba(8,8,8,.97);
  backdrop-filter:blur(28px) saturate(160%);
  border-bottom:1px solid var(--drop-border);
  padding:1.5rem;
  display:flex; flex-direction:column; gap:.25rem;
  transform:translateY(-16px); opacity:0; pointer-events:none;
  transition:transform .4s var(--easing), opacity .3s;
  max-height:calc(100vh - var(--nav-h));
  overflow-y:auto;
  box-shadow:0 20px 60px rgba(0,0,0,.6);
}
.nav__drawer.open { transform:translateY(0); opacity:1; pointer-events:auto; }
.nav__drawer a {
  padding:.8rem 1rem; border-radius:12px;
  color:var(--ink2); text-decoration:none;
  font-size:.88rem; font-weight:600;
  letter-spacing:.04em; text-transform:uppercase;
  transition:background .2s, color .2s, transform .2s var(--spring);
  border:1px solid transparent;
}
.nav__drawer a:hover {
  background:rgba(124,179,66,.1);
  color:var(--g);
  border-color:rgba(124,179,66,.2);
  transform:translateX(4px);
}
.nav__drawer-section {
  font-size:.63rem; font-weight:700; letter-spacing:.14em;
  text-transform:uppercase; color:var(--g);
  padding:1rem 1rem .35rem;
}
.nav__drawer-grid { display:grid; grid-template-columns:1fr 1fr; gap:.45rem; }
.nav__drawer-grid a { font-size:.78rem; padding:.6rem .8rem; text-transform:none; letter-spacing:0; }
.nav__drawer-socials { display:flex; gap:.65rem; padding:.75rem 0 .5rem; flex-wrap:wrap; }
.nav__drawer-social {
  display:flex; align-items:center; gap:.5rem;
  padding:.5rem .9rem; border-radius:10px;
  background:rgba(124,179,66,.08); text-decoration:none;
  color:var(--ink2); font-size:.77rem; font-weight:600;
  transition:background .2s, transform .2s var(--spring);
  border:1px solid var(--drop-border);
}
.nav__drawer-social:hover { background:rgba(124,179,66,.16); transform:translateY(-2px); color:var(--g); }
.nav__drawer-social svg { width:15px; height:15px; flex-shrink:0; }

@media (max-width: 860px) {
  .nav__links, .nav__cta { display:none; }
  .nav__hamburger { display:flex; }
}

/* ══════════════════════════════════════
   HERO — .newhero30
   ══════════════════════════════════════ */
.newhero30 {
  position:relative; width:100%; height:100vh; min-height:560px;
  overflow:hidden; display:flex; align-items:flex-end;
}
.newhero30__bg {
  position:absolute; inset:0;
  background:url("/images/img-section-hero/2.jpg") center top / cover no-repeat;
  transform:scale(1.06);
  animation:newhero30-zoom 2.8s cubic-bezier(.32,.72,0,1) forwards;
}
@keyframes newhero30-zoom {
  from { transform:scale(1.06); }
  to   { transform:scale(1); }
}
.newhero30__overlay {
  position:absolute; inset:0;
  background:
    linear-gradient(to bottom, rgba(0,0,0,.92) 0%, rgba(0,0,0,.4) 18%, transparent 35%),
    linear-gradient(to top,    rgba(0,0,0,.96) 0%, rgba(0,0,0,.55) 22%, transparent 42%);
}

/* Tint verde sutil no gradient inferior */
.newhero30__overlay::after {
  content:""; position:absolute; inset:0;
  background:linear-gradient(to top, rgba(78,122,20,.18) 0%, transparent 40%);
  pointer-events:none;
}

.newhero30__content {
  position:relative; z-index:2;
  max-width:1280px; width:100%; margin:0 auto;
  padding:0 2.5rem 8vh;
  display:flex; flex-direction:column; align-items:flex-start;
}

/* Eyebrow */
.newhero30__eyebrow {
  display:flex; align-items:center; gap:.5rem;
  margin-bottom:.75rem; opacity:0; transform:translateY(14px);
  animation:newhero30-up .65s cubic-bezier(.34,1.56,.64,1) .4s forwards;
}
.newhero30__eyebrow-line {
  width:22px; height:1.5px;
  background:var(--g); border-radius:2px; flex-shrink:0;
}
.newhero30__eyebrow-text {
  font-size:.62rem; font-weight:700; letter-spacing:.2em;
  text-transform:uppercase; color:var(--gl);
  font-family:"DM Sans",sans-serif;
}

/* Título */
.newhero30__title {
  font-family:"League Spartan",sans-serif;
  font-size:clamp(1.9rem,3.8vw,3rem);
  font-weight:900; color:#fff;
  line-height:.95; letter-spacing:-.03em;
  margin:0 0 .85rem; max-width:520px;
  opacity:0; transform:translateY(20px);
  animation:newhero30-up .8s cubic-bezier(.34,1.56,.64,1) .55s forwards;
}
.newhero30__title em { font-style:normal; color:var(--gl); }

/* Descrição */
.newhero30__desc {
  font-family:"DM Sans",sans-serif;
  font-size:.82rem; font-weight:400; line-height:1.65;
  color:rgba(200,230,170,.75); max-width:420px; margin:0 0 1.6rem;
  opacity:0; transform:translateY(16px);
  animation:newhero30-up .7s cubic-bezier(.32,.72,0,1) .7s forwards;
}

/* Actions */
.newhero30__actions {
  display:flex; align-items:center; gap:.75rem; flex-wrap:wrap;
  opacity:0; transform:translateY(12px);
  animation:newhero30-up .65s cubic-bezier(.32,.72,0,1) .84s forwards;
}

/* Botão primário hero */
.newhero30__btn-primary {
  display:inline-flex; align-items:center; gap:.4rem;
  padding:.6rem 1.25rem; border-radius:50px;
  background:var(--g); color:#000;
  font-family:"DM Sans",sans-serif; font-size:.75rem; font-weight:700;
  letter-spacing:.06em; text-decoration:none; text-transform:uppercase;
  box-shadow:0 4px 20px var(--accent-glow);
  transition:transform .28s var(--spring), box-shadow .3s, background .25s;
  position:relative; overflow:hidden; border:none; cursor:pointer;
}
.newhero30__btn-primary::before {
  content:""; position:absolute; inset:0;
  background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.18) 50%,transparent 70%);
  transform:translateX(-120%);
  transition:transform .5s var(--easing); pointer-events:none;
}
.newhero30__btn-primary:hover::before { transform:translateX(120%); }
.newhero30__btn-primary:hover {
  transform:translateY(-2px) scale(1.04);
  box-shadow:0 8px 28px rgba(124,179,66,.55);
  background:var(--gl);
}
.newhero30__btn-primary svg { width:13px; height:13px; flex-shrink:0; transition:transform .25s var(--spring); }
.newhero30__btn-primary:hover svg { transform:translateX(3px); }

/* Botão secundário hero */
.newhero30__btn-secondary {
  display:inline-flex; align-items:center; gap:.4rem;
  padding:.58rem 1.15rem; border-radius:50px;
  background:rgba(124,179,66,.1);
  border:1.5px solid rgba(124,179,66,.4);
  color:#fff;
  font-family:"DM Sans",sans-serif; font-size:.75rem; font-weight:600;
  letter-spacing:.06em; text-decoration:none; text-transform:uppercase;
  backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
  transition:transform .28s var(--spring), background .25s, border-color .25s, box-shadow .3s;
  position:relative; overflow:hidden; cursor:pointer;
}
.newhero30__btn-secondary::before {
  content:""; position:absolute; inset:0;
  background:linear-gradient(110deg,transparent 30%,rgba(124,179,66,.12) 50%,transparent 70%);
  transform:translateX(-120%);
  transition:transform .5s var(--easing); pointer-events:none;
}
.newhero30__btn-secondary:hover::before { transform:translateX(120%); }
.newhero30__btn-secondary:hover {
  transform:translateY(-2px);
  background:rgba(124,179,66,.18);
  border-color:rgba(124,179,66,.65);
  box-shadow:0 6px 22px rgba(124,179,66,.2);
}
.newhero30__btn-secondary svg { width:13px; height:13px; flex-shrink:0; }

/* Scroll indicator */
.newhero30__scroll {
  position:absolute; bottom:2rem; right:2.4rem; z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:.4rem;
  text-decoration:none; opacity:0;
  animation:newhero30-up .55s cubic-bezier(.32,.72,0,1) 1.1s forwards;
}
.newhero30__scroll-label {
  font-size:.56rem; letter-spacing:.18em; text-transform:uppercase;
  color:rgba(124,179,66,.45); writing-mode:vertical-rl;
  transform:rotate(180deg); font-family:"DM Sans",sans-serif;
}
.newhero30__scroll-track {
  width:1.5px; height:44px;
  background:rgba(124,179,66,.15); border-radius:2px;
  position:relative; overflow:hidden;
}
.newhero30__scroll-track::after {
  content:""; position:absolute; top:-100%; left:0; right:0; height:100%;
  background:var(--g);
  animation:newhero30-bar 2s cubic-bezier(.32,.72,0,1) 1.3s infinite;
}
@keyframes newhero30-bar { 0%{top:-100%} 50%{top:0%} 100%{top:100%} }
@keyframes newhero30-up  { to { opacity:1; transform:translateY(0); } }

@media (max-width: 600px) {
  .newhero30__content { padding:0 1.4rem 10vh; }
  .newhero30__actions { flex-direction:column; align-items:stretch; }
  .newhero30__btn-primary, .newhero30__btn-secondary { justify-content:center; }
  .newhero30__scroll { display:none; }
}

/* ══════════════════════════════════════
   BOTÕES — .newherosection31
   ══════════════════════════════════════ */
.newherosection31__actions {
  display:flex; align-items:center; gap:16px; flex-wrap:wrap;
}

.newherosection31__btn-primary,
.newherosection31__btn-secondary {
  display:inline-flex; align-items:center; gap:12px;
  padding:14px 28px; border-radius:4px;
  font-family:inherit; font-size:.95rem; font-weight:600;
  letter-spacing:.04em; text-decoration:none; cursor:pointer;
  position:relative; overflow:hidden;
  transition:color .35s ease, border-color .35s ease;
}
.newherosection31__btn-primary::before,
.newherosection31__btn-secondary::before {
  content:""; position:absolute; inset:0;
  transform:translateY(100%);
  transition:transform .35s cubic-bezier(.4,0,.2,1);
  z-index:0;
}
.newherosection31__btn-primary:hover::before,
.newherosection31__btn-secondary:hover::before { transform:translateY(0); }

.newherosection31__btn-text,
.newherosection31__btn-arrow { position:relative; z-index:1; }
.newherosection31__btn-arrow { display:flex; align-items:center; transition:transform .3s ease; }
.newherosection31__btn-primary:hover .newherosection31__btn-arrow,
.newherosection31__btn-secondary:hover .newherosection31__btn-arrow { transform:translateX(4px); }

/* Primário — verde sólido */
.newherosection31__btn-primary {
  background:var(--g);
  border:1.5px solid var(--g);
  color:#000;
}
.newherosection31__btn-primary::before { background:var(--gd); }
.newherosection31__btn-primary:hover   { color:#fff; }

/* Secundário — contorno verde */
.newherosection31__btn-secondary {
  background:transparent;
  border:1.5px solid var(--g);
  color:var(--g);
}
.newherosection31__btn-secondary::before { background:var(--g); }
.newherosection31__btn-secondary:hover   { color:#000; }

@keyframes newherosection31-rise {
  from { opacity:0; transform:translateY(24px); }
  to   { opacity:1; transform:translateY(0); }
}
.newherosection31__btn-primary,
.newherosection31__btn-secondary { opacity:0; animation:newherosection31-rise .6s cubic-bezier(.22,1,.36,1) forwards; }
.newherosection31__btn-primary   { animation-delay:.2s; }
.newherosection31__btn-secondary { animation-delay:.4s; }

/* ── btn-sobre (botão outline simples) ── */
.btn-sobre {
  display:inline-flex; align-items:center; gap:12px;
  padding:14px 28px; background:transparent;
  border:1.5px solid var(--g); border-radius:4px;
  color:var(--g); font-family:inherit; font-size:.95rem; font-weight:600;
  letter-spacing:.04em; text-decoration:none; cursor:pointer;
  position:relative; overflow:hidden;
  transition:color .35s ease, border-color .35s ease;
  margin-top:32px;
}
.btn-sobre::before {
  content:""; position:absolute; inset:0;
  background:var(--g); transform:translateY(100%);
  transition:transform .35s cubic-bezier(.4,0,.2,1); z-index:0;
}
.btn-sobre:hover { color:#000; border-color:var(--g); }
.btn-sobre:hover::before { transform:translateY(0); }
.btn-sobre-text, .btn-sobre-arrow { position:relative; z-index:1; }
.btn-sobre-arrow { display:flex; align-items:center; transition:transform .3s ease; }
.btn-sobre:hover .btn-sobre-arrow { transform:translateX(4px); }

/* ══════════════════════════════════════
   SEÇÕES CLARAS — pearl
   ══════════════════════════════════════ */
.section--pearl {
  background:var(--pearl);
  color:var(--pearl-ink);
}
.section--pearl .nav__links a        { color:var(--pearl-ink2); }
.section--pearl .nav__links a:hover  { color:var(--pearl-g); }
.section--pearl .nav__links a.active { color:var(--pearl-g); }

/* Accent verde escuro para seções claras */
.section--pearl .nav__drop-title,
.section--pearl .nav__mega-col-title  { color:var(--pearl-g); }
.section--pearl .nav__mega-item:hover { color:var(--pearl-g); background:rgba(78,122,20,.08); }
.section--pearl .nav__mega-dot        { color:var(--pearl-g); background:rgba(78,122,20,.1); }
.section--pearl .nav__mega-item:hover .nav__mega-dot { background:var(--pearl-g); color:#fff; }

/* Footer */
.footer__link   { color:var(--ink); }
.footer-links a { color:var(--ink); }

.nav__logo-img {
  transition: transform 0.35s var(--spring), filter 0.35s ease;
}

.nav__logo:hover .nav__logo-img {
  transform: translateY(-5px);
  filter: drop-shadow(0 6px 18px rgba(124, 179, 66, 0.55))
          drop-shadow(0 2px 6px rgba(124, 179, 66, 0.3));
}




.ss{
  background: #060606 ;
  font-family:"DM Sans",sans-serif;
  padding:6rem 2rem 7rem;
  position:relative;
  overflow:hidden;
}

.ss::after{
  content:"";
  position:absolute;
  bottom:-120px;right:-80px;
  width:480px;height:480px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(124,179,66,.055) 0%,transparent 70%);
  pointer-events:none;
}

.ss__wrap{max-width:1100px;margin:0 auto;position:relative;z-index:1;}

.ss__top{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:2rem;
  margin-bottom:3.5rem;
  flex-wrap:wrap;
}

.ss__left{opacity:0;transform:translateY(18px);transition:opacity .65s var(--ease),transform .7s var(--spring);}
.ss__left.vis{opacity:1;transform:translateY(0);}

.ss__ey{
  display:flex;align-items:center;gap:.45rem;
  margin-bottom:.7rem;
}
.ss__ey-dash{width:18px;height:1.5px;background:var(--g);border-radius:2px;}
.ss__ey-txt{font-size:.6rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gl);}

.ss__title{
  font-family:"League Spartan",sans-serif;
  font-size:clamp(2rem,3.6vw,3rem);
  font-weight:900;line-height:.95;letter-spacing:-.03em;color:#fff;
}
.ss__title em{font-style:normal;color:var(--gl);}

.ss__right{
  opacity:0;transform:translateY(14px);
  transition:opacity .6s var(--ease) .15s,transform .6s var(--ease) .15s;
  max-width:320px;
}
.ss__right.vis{opacity:1;transform:translateY(0);}
.ss__desc{font-size:.82rem;line-height:1.7;color:rgba(200,230,170,.55);}

.ss__list{
  border-top:1px solid var(--border);
}

.ss__item{
  display:grid;
  grid-template-columns:3rem 1fr auto;
  align-items:center;
  gap:0 2rem;
  padding:1.6rem 0;
  border-bottom:1px solid var(--border);
  position:relative;
  cursor:default;
  opacity:0;transform:translateX(-20px);
  transition:
    opacity .55s var(--ease),
    transform .6s var(--spring),
    border-color .3s;
}
.ss__item.vis{opacity:1;transform:translateX(0);}

.ss__item::after{
  content:"";
  position:absolute;
  bottom:-1px;left:0;
  height:1px;width:0;
  background:linear-gradient(90deg,var(--g),var(--gl),transparent);
  transition:width .5s var(--ease);
}
.ss__item:hover::after{width:100%;}

.ss__item:hover .ss__item-title{color:#fff;}
.ss__item:hover .ss__item-num{color:var(--g);}
.ss__item:hover .ss__item-arrow{opacity:1;transform:translateX(0);}
.ss__item:hover .ss__item-icon{background:rgba(124,179,66,.15);border-color:rgba(124,179,66,.3);}
.ss__item:hover .ss__item-icon svg{stroke:var(--gl);}

.ss__item-num{
  font-family:"League Spartan",sans-serif;
  font-size:.7rem;font-weight:900;
  letter-spacing:.08em;
  color:rgba(255,255,255,.18);
  transition:color .3s;
  text-align:right;
  line-height:1;
  padding-top:2px;
}

.ss__item-body{display:flex;align-items:center;gap:1.2rem;}

.ss__item-icon{
  width:44px;height:44px;flex-shrink:0;
  border-radius:11px;
  background:rgba(124,179,66,.07);
  border:1px solid rgba(124,179,66,.12);
  display:flex;align-items:center;justify-content:center;
  transition:background .25s,border-color .25s,transform .3s var(--spring);
}
.ss__item:hover .ss__item-icon{transform:rotate(-6deg) scale(1.07);}
.ss__item-icon svg{width:18px;height:18px;stroke:rgba(124,179,66,.7);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;transition:stroke .25s;}

.ss__item-text{}
.ss__item-title{
  font-family:"League Spartan",sans-serif;
  font-size:1.05rem;font-weight:900;letter-spacing:-.01em;
  color:rgba(255,255,255,.85);
  transition:color .25s;
  margin-bottom:.2rem;
}
.ss__item-sub{font-size:.78rem;color:var(--muted);line-height:1.5;}

.ss__item-tags{
  display:flex;gap:.4rem;align-items:center;
  flex-shrink:0;
}
.ss__tag{
  font-size:.58rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--g);
  background:rgba(124,179,66,.08);
  border:1px solid rgba(124,179,66,.15);
  padding:.22rem .6rem;border-radius:20px;
  white-space:nowrap;
}

.ss__item-arrow{
  width:28px;height:28px;border-radius:50%;
  background:rgba(124,179,66,.12);
  border:1px solid rgba(124,179,66,.2);
  display:flex;align-items:center;justify-content:center;
  opacity:0;transform:translateX(-8px);
  transition:opacity .25s,transform .3s var(--spring),background .25s;
  flex-shrink:0;
  margin-left:.5rem;
}
.ss__item:hover .ss__item-arrow{background:rgba(124,179,66,.2);}
.ss__item-arrow svg{width:11px;height:11px;stroke:var(--g);fill:none;stroke-width:2.3;stroke-linecap:round;}

.ss__foot{
  display:flex;align-items:center;justify-content:space-between;
  gap:1.5rem;flex-wrap:wrap;
  padding-top:2.5rem;
  opacity:0;transform:translateY(12px);
  transition:opacity .6s var(--ease) .55s,transform .6s var(--ease) .55s;
}
.ss__foot.vis{opacity:1;transform:translateY(0);}
.ss__foot-note{font-size:.78rem;color:var(--muted);line-height:1.6;}
.ss__foot-note strong{color:var(--gl);font-weight:600;}

.ss__cta{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.58rem 1.3rem;border-radius:50px;
  background:var(--g);color:#000;
  font-size:.76rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  text-decoration:none;white-space:nowrap;
  box-shadow:0 4px 20px var(--glow);
  transition:transform .28s var(--spring),box-shadow .3s,background .25s;
  position:relative;overflow:hidden;
}
.ss__cta::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.18) 50%,transparent 70%);
  transform:translateX(-120%);transition:transform .45s var(--easing);pointer-events:none;
}
.ss__cta:hover::before{transform:translateX(120%);}
.ss__cta:hover{transform:scale(1.05) translateY(-2px);box-shadow:0 8px 28px rgba(124,179,66,.5);background:var(--gl);}
.ss__cta svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round;flex-shrink:0;}

@media(max-width:640px){
  .ss__top{flex-direction:column;align-items:flex-start;}
  .ss__item{grid-template-columns:2.2rem 1fr;gap:0 1rem;}
  .ss__item-tags,.ss__item-arrow{display:none;}
  .ss__item-body{gap:.8rem;}
}


.sv{
  background: #0e0e0e;
  font-family:"DM Sans",sans-serif;
  padding:7rem 2rem 8rem;
  position:relative;
  overflow:hidden;
}
.sv::before{
  content:"";position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:900px;height:900px;
  background:radial-gradient(ellipse,rgba(124,179,66,.04) 0%,transparent 65%);
  pointer-events:none;
}

.sv__wrap{max-width:1120px;margin:0 auto;position:relative;z-index:1;}

/* ── HEADER ── */
.sv__header{
  display:grid;grid-template-columns:1fr 1fr;
  gap:2rem 4rem;align-items:end;
  margin-bottom:5rem;
}
@media(max-width:700px){.sv__header{grid-template-columns:1fr;}}

.sv__hl{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .75s var(--spring);}
.sv__hl.vis{opacity:1;transform:translateY(0);}
.sv__hr{opacity:0;transform:translateY(16px);transition:opacity .65s var(--ease) .12s,transform .65s var(--ease) .12s;}
.sv__hr.vis{opacity:1;transform:translateY(0);}

.sv__ey{display:flex;align-items:center;gap:.45rem;margin-bottom:.8rem;}
.sv__ey-dash{width:20px;height:1.5px;background:var(--g);border-radius:2px;}
.sv__ey-txt{font-size:.6rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gl);}

.sv__title{
  font-family:"League Spartan",sans-serif;
  font-size:clamp(2.4rem,4vw,3.5rem);
  font-weight:900;line-height:.92;letter-spacing:-.035em;color:#fff;
}
.sv__title em{font-style:normal;color:var(--gl);}

.sv__hr-desc{font-size:.85rem;line-height:1.72;color:rgba(200,230,170,.5);margin-bottom:1.4rem;}

.sv__hr-stat{
  display:flex;gap:2rem;flex-wrap:wrap;
}
.sv__stat{}
.sv__stat-num{
  font-family:"League Spartan",sans-serif;
  font-size:1.9rem;font-weight:900;letter-spacing:-.03em;
  color:var(--g);line-height:1;
}
.sv__stat-lbl{font-size:.68rem;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;margin-top:.2rem;}

/* ── GRID ── */
.sv__grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  border:1px solid var(--border);
  border-radius:20px;
  overflow:hidden;
  background:var(--border);
}
@media(max-width:860px){.sv__grid{grid-template-columns:1fr 1fr;}}
@media(max-width:500px){.sv__grid{grid-template-columns:1fr;}}

.sv__item{
  background: #141414;
  padding:2.2rem 2rem 2rem;
  position:relative;
  overflow:hidden;
  opacity:0;transform:translateY(24px) scale(.98);
  transition:opacity .6s var(--ease),transform .65s var(--spring),background .3s;
}
.sv__item.vis{opacity:1;transform:translateY(0) scale(1);}
.sv__item:hover{background:#181818;}

.sv__item::before{
  content:"";position:absolute;
  top:0;left:0;right:0;height:1.5px;
  background:linear-gradient(90deg,transparent,var(--g),var(--gl),transparent);
  transform:scaleX(0);transform-origin:left;
  transition:transform .45s var(--ease);
}
.sv__item:hover::before{transform:scaleX(1);}

.sv__item-shine{
  position:absolute;inset:0;
  background:linear-gradient(130deg,transparent 35%,rgba(124,179,66,.04) 50%,transparent 65%);
  transform:translateX(-100%);
  transition:transform .6s var(--easing);pointer-events:none;
}
.sv__item:hover .sv__item-shine{transform:translateX(100%);}

.sv__item-idx{
  font-family:"League Spartan",sans-serif;
  font-size:.6rem;font-weight:900;letter-spacing:.14em;
  color:rgba(124,179,66,.25);
  margin-bottom:1.4rem;
  display:flex;align-items:center;gap:.5rem;
  transition:color .3s;
}
.sv__item:hover .sv__item-idx{color:rgba(124,179,66,.5);}
.sv__item-idx::after{content:"";flex:1;height:1px;background:rgba(124,179,66,.1);}

.sv__item-icon{
  width:46px;height:46px;border-radius:12px;
  background:rgba(124,179,66,.07);
  border:1px solid rgba(124,179,66,.12);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:1.1rem;
  transition:background .3s,border-color .3s,transform .35s var(--spring);
}
.sv__item:hover .sv__item-icon{
  background:rgba(124,179,66,.14);
  border-color:rgba(124,179,66,.28);
  transform:rotate(-5deg) scale(1.08);
}
.sv__item-icon svg{width:20px;height:20px;stroke:rgba(124,179,66,.75);fill:none;stroke-width:1.65;stroke-linecap:round;stroke-linejoin:round;transition:stroke .3s;}
.sv__item:hover .sv__item-icon svg{stroke:var(--gl);}

.sv__item-name{
  font-family:"League Spartan",sans-serif;
  font-size:1.05rem;font-weight:900;letter-spacing:-.015em;
  color:rgba(255,255,255,.82);margin-bottom:.6rem;
  transition:color .25s;
}
.sv__item:hover .sv__item-name{color:#fff;}

.sv__item-desc{
  font-size:.79rem;line-height:1.68;
  color:rgba(255,255,255,.38);
  transition:color .25s;
}
.sv__item:hover .sv__item-desc{color:rgba(255,255,255,.58);}

.sv__item-link{
  display:inline-flex;align-items:center;gap:.3rem;
  margin-top:1.3rem;
  font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--g);text-decoration:none;
  opacity:0;transform:translateY(6px);
  transition:opacity .25s,transform .3s var(--spring),color .2s,gap .25s var(--spring);
}
.sv__item:hover .sv__item-link{opacity:1;transform:translateY(0);}
.sv__item-link:hover{color:var(--gl);gap:.5rem;}
.sv__item-link svg{width:10px;height:10px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round;flex-shrink:0;}

/* ── RODAPÉ ── */
.sv__foot{
  display:flex;align-items:center;justify-content:space-between;
  gap:1.5rem;flex-wrap:wrap;
  margin-top:3.5rem;padding-top:2rem;
  border-top:1px solid var(--border);
  opacity:0;transform:translateY(14px);
  transition:opacity .6s var(--ease) .5s,transform .6s var(--ease) .5s;
}
.sv__foot.vis{opacity:1;transform:translateY(0);}
.sv__foot-txt{font-size:.8rem;color:var(--muted);line-height:1.6;max-width:340px;}
.sv__foot-txt strong{color:rgba(156,204,101,.75);font-weight:600;}

.sv__cta{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.62rem 1.35rem;border-radius:50px;
  background:var(--g);color:#000;
  font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  text-decoration:none;white-space:nowrap;
  box-shadow:0 4px 22px var(--glow);
  transition:transform .28s var(--spring),box-shadow .3s,background .25s;
  position:relative;overflow:hidden;
}
.sv__cta::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.18) 50%,transparent 70%);
  transform:translateX(-120%);transition:transform .45s var(--easing);pointer-events:none;
}
.sv__cta:hover::before{transform:translateX(120%);}
.sv__cta:hover{transform:scale(1.05) translateY(-2px);box-shadow:0 8px 28px rgba(124,179,66,.48);background:var(--gl);}
.sv__cta svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round;flex-shrink:0;}


.pj{
  background: #060606 ;
  font-family:"DM Sans",sans-serif;
  padding:7rem 2rem 8rem;
  position:relative;overflow:hidden;
}
.pj::before{
  content:"";position:absolute;
  top:-100px;left:-100px;
  width:600px;height:600px;
  background:radial-gradient(circle,rgba(124,179,66,.05) 0%,transparent 65%);
  pointer-events:none;
}
.pj::after{
  content:"";position:absolute;
  bottom:-80px;right:-60px;
  width:500px;height:500px;
  background:radial-gradient(circle,rgba(124,179,66,.04) 0%,transparent 65%);
  pointer-events:none;
}

.pj__wrap{max-width:1120px;margin:0 auto;position:relative;z-index:1;}

/* HEADER */
.pj__header {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;   /* muda de end para center */
  gap: 2rem 5rem;
  margin-bottom: 4rem;
}

.pj__hl{opacity:0;transform:translateY(20px);transition:opacity .7s var(--ease),transform .75s var(--spring);}
.pj__hl.vis{opacity:1;transform:translateY(0);}

.pj__ey{display:flex;align-items:center;gap:.45rem;margin-bottom:.8rem;}
.pj__ey-dash{width:20px;height:1.5px;background:var(--g);border-radius:2px;}
.pj__ey-txt{font-size:.6rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gl);}

.pj__title{
  font-family:"League Spartan",sans-serif;
  font-size:clamp(2.2rem,4vw,3.4rem);
  font-weight:900;line-height:.93;letter-spacing:-.035em;color:#fff;
}
.pj__title em{font-style:normal;color:var(--gl);}

.pj__hr{
  opacity:0;transform:translateY(14px);
  transition:opacity .6s var(--ease) .15s,transform .6s var(--ease) .15s;
  display:flex;flex-direction:column;align-items:flex-end;gap:1rem;
}
.pj__hr.vis{opacity:1;transform:translateY(0);}
.pj__hr-desc {
  text-align: left;
  max-width: 380px;
}
/* GRID */
.pj__grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.2rem;
}
@media(max-width:860px){.pj__grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:520px){.pj__grid{grid-template-columns:1fr;}}

.pj__card{
  position:relative;border-radius:18px;overflow:hidden;
  background:#141414;
  border:1px solid var(--border);
  cursor:pointer;
  opacity:0;transform:translateY(30px) scale(.97);
  transition:
    opacity .65s var(--ease),
    transform .7s var(--spring),
    border-color .35s,
    box-shadow .35s;
  text-decoration:none;display:block;
}
.pj__card.vis{opacity:1;transform:translateY(0) scale(1);}
.pj__card:hover{
  border-color:rgba(124,179,66,.3);
  box-shadow:0 16px 52px rgba(0,0,0,.6), 0 0 0 1px rgba(124,179,66,.08);
  transform:translateY(-6px) scale(1.01) !important;
   background: #181818;
}

/* Imagem placeholder */
.pj__card-img {
  width: 100%;
  aspect-ratio: 16 / 10;
  position: relative;
  overflow: hidden;
}
.pj__card-slides {
  display: flex;
  width: 100%;
  height: 100%;
  transition: transform .1s cubic-bezier(.32,.72,0,1);
}
.pj__card-slide {
  min-width: 100%;
  height: 100%;
  object-fit: cover;
  flex-shrink: 0;
  filter: brightness(.85) saturate(.9);
  transition: filter .4s;
}.pj__card:hover .pj__card-slide {
  filter: brightness(.7) saturate(.7);
}

.pj__card-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s var(--ease),filter .4s;
  filter:brightness(.85) saturate(.9);
}
.pj__card:hover .pj__card-img img{
  transform:scale(1.07);
  filter:brightness(.7) saturate(.7);
}

/* placeholder quando não tem imagem */
.pj__card-ph{
  display:flex;align-items:center;justify-content:center;
  width:100%;height:100%;
}
.pj__card-ph svg{width:36px;height:36px;stroke:rgba(124,179,66,.2);fill:none;stroke-width:1.2;}

/* overlay escuro no hover */
.pj__card-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.92) 0%,rgba(0,0,0,.2) 50%,transparent 100%);
  opacity:.7;
  transition:opacity .35s;
}
.pj__card:hover .pj__card-overlay{opacity:1;}

/* botão de ver projeto — aparece no hover */
.pj__card-btn{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%) scale(.7);
  opacity:0;
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.5rem 1.1rem;border-radius:50px;
  background:var(--g);color:#000;
  font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  white-space:nowrap;
  transition:opacity .3s,transform .35s var(--spring);
  z-index:3;pointer-events:none;
}
.pj__card:hover .pj__card-btn{opacity:1;transform:translate(-50%,-50%) scale(1);}
.pj__card-btn svg{width:11px;height:11px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round;}

/* tag no topo */
.pj__card-tag{
  position:absolute;top:1rem;left:1rem;z-index:3;
  font-size:.58rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--g);
  background:rgba(8,8,8,.82);
  border:1px solid rgba(124,179,66,.22);
  padding:.22rem .65rem;border-radius:20px;
  backdrop-filter:blur(8px);
  transition:background .25s,border-color .25s;
}
.pj__card:hover .pj__card-tag{background:rgba(8,8,8,.9);border-color:rgba(124,179,66,.45);}

/* barra verde topo */
.pj__card-topline{
  position:absolute;top:0;left:0;right:0;height:2px;z-index:4;
  background:linear-gradient(90deg,transparent,var(--g),var(--gl),transparent);
  transform:scaleX(0);transform-origin:left;
  transition:transform .45s var(--ease);
}
.pj__card:hover .pj__card-topline{transform:scaleX(1);}

/* info */
.pj__card-info{
  padding:1.2rem 1.3rem 1.4rem;
  position:relative;z-index:2;
}
.pj__card-name{
  font-family:"League Spartan",sans-serif;
  font-size:1rem;font-weight:900;letter-spacing:-.015em;
  color:rgba(255,255,255,.85);margin-bottom:.3rem;
  transition:color .25s;
}
.pj__card:hover .pj__card-name{color:#fff;}
.pj__card-sub{font-size:.75rem;color:var(--muted);line-height:1.5;transition:color .25s;}
.pj__card:hover .pj__card-sub{color:rgba(255,255,255,.5);}

/* número decorativo */
.pj__card-num{
  position:absolute;bottom:1.1rem;right:1.3rem;
  font-family:"League Spartan",sans-serif;
  font-size:2.4rem;font-weight:900;letter-spacing:-.04em;
  color:rgba(124,179,66,.05);line-height:1;
  transition:color .3s;pointer-events:none;
}
.pj__card:hover .pj__card-num{color:rgba(124,179,66,.1);}

/* RODAPÉ CTA */
.pj__foot{
  display:flex;align-items:center;justify-content:center;
  margin-top:3.5rem;
  opacity:0;transform:translateY(14px);
  transition:opacity .6s var(--ease) .55s,transform .6s var(--ease) .55s;
}
.pj__foot.vis{opacity:1;transform:translateY(0);}

.pj__cta-wrap{display:flex;flex-direction:column;align-items:center;gap:.75rem;}
.pj__cta-label{font-size:.65rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);}

.pj__cta{
  display:inline-flex;align-items:center;gap:.55rem;
  padding:.72rem 1.8rem;border-radius:50px;
  background:transparent;
  border:1.5px solid rgba(124,179,66,.45);
  color:#fff;
  font-size:.8rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  text-decoration:none;white-space:nowrap;
  position:relative;overflow:hidden;
  transition:color .35s,border-color .35s,transform .3s var(--spring),box-shadow .3s;
}
.pj__cta::before{
  content:"";position:absolute;inset:0;
  background:var(--g);
  transform:translateY(100%);
  transition:transform .35s var(--easing);
  z-index:0;
}
.pj__cta:hover{color:#000;border-color:var(--g);transform:translateY(-2px);box-shadow:0 8px 28px rgba(124,179,66,.35);}
.pj__cta:hover::before{transform:translateY(0);}
.pj__cta-txt,.pj__cta-arrow{position:relative;z-index:1;}
.pj__cta-arrow{display:flex;align-items:center;transition:transform .3s var(--spring);}
.pj__cta:hover .pj__cta-arrow{transform:translateX(4px);}
.pj__cta-arrow svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2.3;stroke-linecap:round;}

.pj__card-slides {
  display: flex;
  width: 100%;
  height: 100%;
  will-change: transform;
}

.pj__card-img {
  -webkit-mask-image: linear-gradient(
    to right,
    transparent 0%,
    black 4%,
    black 96%,
    transparent 100%
  );
  mask-image: linear-gradient(
    to right,
    transparent 0%,
    black 4%,
    black 96%,
    transparent 100%
  );
}

.ab{
  width:100%;
  background:var(--bg2);
  position:relative;
  overflow:hidden;
  padding:8rem 0 9rem;
}
 
/* BG */
.ab-bg{position:absolute;inset:0;pointer-events:none;overflow:hidden;}
.ab-orb{position:absolute;border-radius:50%;filter:blur(90px);}
.ab-orb-a{
  width:500px;height:500px;top:-180px;right:-100px;
  background:radial-gradient(circle,rgba(124,179,66,.06) 0%,transparent 70%);
  animation:floatA 14s ease-in-out infinite;
}
.ab-orb-b{
  width:420px;height:420px;bottom:-140px;left:-80px;
  background:radial-gradient(circle,rgba(85,139,47,.045) 0%,transparent 70%);
  animation:floatB 11s ease-in-out infinite;
}
@keyframes floatA{0%,100%{transform:translate(0,0);}50%{transform:translate(20px,-25px);}}
@keyframes floatB{0%,100%{transform:translate(0,0);}50%{transform:translate(-18px,20px);}}
 
.ab-dots{
  position:absolute;inset:0;
  background-image:radial-gradient(rgba(124,179,66,.07) 1px,transparent 1px);
  background-size:34px 34px;
  -webkit-mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,#000 0%,transparent 100%);
  mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,#000 0%,transparent 100%);
}
.ab-topline{
  position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(124,179,66,.4) 30%,rgba(156,204,101,.55) 50%,rgba(124,179,66,.4) 70%,transparent);
}
 
/* Wrap */
.ab-wrap{max-width:1100px;margin:0 auto;padding:0 2rem;position:relative;z-index:2;}
@media(max-width:480px){.ab-wrap{padding:0 1.1rem;}}
 
/* ── LABEL ── */
.ab-lbl{display:flex;align-items:center;gap:.55rem;margin-bottom:3rem;}
.ab-lbl__bar{width:26px;height:1.5px;background:var(--g);border-radius:2px;flex-shrink:0;}
.ab-lbl__txt{font-size:.6rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gl);}
 
/* ── INTRO ── */
.ab-intro{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:3.5rem;
  align-items:center;
  margin-bottom:5rem;
}
@media(max-width:780px){.ab-intro{grid-template-columns:1fr;gap:2rem;}}
 
.ab-intro__h{
  font-family:"League Spartan",sans-serif;
  font-size:clamp(2.2rem,3.8vw,3.5rem);
  font-weight:900;line-height:.93;letter-spacing:-.04em;color:#fff;
  margin-bottom:1.3rem;
}
.ab-intro__h em{font-style:normal;color:var(--gl);}
.ab-intro__p{font-size:.87rem;line-height:1.75;color:rgba(200,230,170,.5);max-width:390px;}
 
/* Quote + stats */
.ab-quote{
  background:var(--s2);
  border:1px solid var(--border2);
  border-radius:18px;
  padding:1.8rem 1.8rem 1.8rem 2.2rem;
  position:relative;overflow:hidden;
}
.ab-quote::before{
  content:"";position:absolute;left:0;top:0;bottom:0;
  width:3px;background:linear-gradient(to bottom,var(--g),var(--gl));
  border-radius:2px 0 0 2px;
}
.ab-quote__txt{
  font-size:.87rem;line-height:1.78;
  color:rgba(255,255,255,.68);
  font-style:italic;font-weight:300;
  margin-bottom:1.4rem;
}
.ab-quote__txt strong{color:var(--gl);font-weight:500;font-style:normal;}
 
.ab-stats{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:var(--border);
  border:1px solid var(--border);border-radius:12px;overflow:hidden;
}
.ab-st{
  background:var(--s2);padding:1rem .8rem;text-align:center;
  cursor:default;position:relative;transition:background .3s;
}
.ab-st::after{
  content:"";position:absolute;top:0;left:0;right:0;height:1.5px;
  background:linear-gradient(90deg,transparent,var(--g),transparent);
  transform:scaleX(0);transform-origin:center;transition:transform .4s var(--ease);
}
.ab-st:hover{background:var(--s3);}
.ab-st:hover::after{transform:scaleX(1);}
.ab-st__n{
  font-family:"League Spartan",sans-serif;
  font-size:1.85rem;font-weight:900;letter-spacing:-.04em;
  color:var(--g);line-height:1;margin-bottom:.2rem;
}
.ab-st__l{font-size:.62rem;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;}
 
/* ── VALORES ── */
.ab-vals{margin-bottom:5rem;}
.ab-cards{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;border:1px solid var(--border);
  border-radius:18px;overflow:hidden;background:var(--border);
}
@media(max-width:860px){.ab-cards{grid-template-columns:repeat(2,1fr);}}
@media(max-width:460px){.ab-cards{grid-template-columns:1fr;}}
 
.ab-card{
  background:var(--bg2);padding:1.7rem 1.5rem;
  position:relative;overflow:hidden;cursor:default;transition:background .3s;
}
.ab-card:hover{background:var(--s2);}
.ab-card__bar{
  position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--g),var(--gl),transparent);
  transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease);
}
.ab-card:hover .ab-card__bar{transform:scaleX(1);}
.ab-card__n{
  font-family:"League Spartan",sans-serif;
  font-size:.6rem;font-weight:900;letter-spacing:.15em;
  color:rgba(124,179,66,.2);margin-bottom:1rem;transition:color .3s;
}
.ab-card:hover .ab-card__n{color:rgba(124,179,66,.45);}
.ab-card__ico{
  width:42px;height:42px;border-radius:11px;
  background:rgba(124,179,66,.07);
  border:1px solid rgba(124,179,66,.13);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:1rem;
  transition:background .3s,border-color .3s,transform .35s var(--spring);
}
.ab-card:hover .ab-card__ico{background:rgba(124,179,66,.15);border-color:rgba(124,179,66,.3);transform:rotate(-7deg) scale(1.1);}
.ab-card__ico svg{width:18px;height:18px;stroke:rgba(124,179,66,.7);fill:none;stroke-width:1.65;stroke-linecap:round;stroke-linejoin:round;transition:stroke .3s;}
.ab-card:hover .ab-card__ico svg{stroke:var(--gl);}
.ab-card__t{font-family:"League Spartan",sans-serif;font-size:.98rem;font-weight:900;letter-spacing:-.01em;color:rgba(255,255,255,.8);margin-bottom:.5rem;transition:color .25s;}
.ab-card:hover .ab-card__t{color:#fff;}
.ab-card__d{font-size:.77rem;line-height:1.68;color:rgba(255,255,255,.35);transition:color .25s;}
.ab-card:hover .ab-card__d{color:rgba(255,255,255,.55);}
 
/* ── TIMELINE ── */
.ab-tl{margin-bottom:5rem;position:relative;}
.ab-tl__spine{
  position:absolute;left:50%;top:0;bottom:0;
  width:1px;transform:translateX(-50%);
  background:linear-gradient(to bottom,transparent,var(--border2) 8%,var(--border2) 92%,transparent);
  pointer-events:none;
}
@media(max-width:640px){
  .ab-tl__spine{left:16px;top:0;}
}
 
.ab-tl__row{
  display:grid;
  grid-template-columns:1fr 48px 1fr;
  align-items:start;
  padding:1.2rem 0;
}
@media(max-width:640px){
  .ab-tl__row{
    display:flex;
    flex-direction:row;
    align-items:flex-start;
    gap:1rem;
    padding:.9rem 0;
  }
}
 
.ab-tl__col{padding:0 2rem;}
.ab-tl__col--blank{}
@media(max-width:640px){
  .ab-tl__col--left,.ab-tl__col--right{padding:0;flex:1;min-width:0;}
  .ab-tl__col--blank{display:none;}
  .ab-tl__col--right{order:2;}
  .ab-tl__mid{order:1;}
}
 
.ab-tl__mid{display:flex;align-items:flex-start;justify-content:center;padding-top:1.5rem;}
@media(max-width:640px){
  .ab-tl__mid{padding-top:1.4rem;flex-shrink:0;width:32px;justify-content:center;}
}
 
.ab-tl__dot{
  width:13px;height:13px;border-radius:50%;flex-shrink:0;
  background:var(--s2);border:2px solid var(--g);
  box-shadow:0 0 0 4px rgba(124,179,66,.1);
  transition:transform .35s var(--spring),box-shadow .3s,background .3s;
  cursor:default;
}
.ab-tl__row:hover .ab-tl__dot{
  transform:scale(1.5);background:var(--g);
  box-shadow:0 0 0 8px rgba(124,179,66,.14),0 0 22px rgba(124,179,66,.35);
}
 
.ab-tl__card{
  background:var(--s2);border:1px solid var(--border);
  border-radius:14px;padding:1.2rem 1.4rem;
  position:relative;overflow:hidden;
  transition:background .3s,border-color .3s,box-shadow .3s;
}
.ab-tl__row:hover .ab-tl__card{
  background:var(--s3);border-color:rgba(124,179,66,.22);
  box-shadow:0 8px 30px rgba(0,0,0,.5);
}
.ab-tl__card::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(110deg,transparent 35%,rgba(124,179,66,.04) 50%,transparent 65%);
  transform:translateX(-100%);transition:transform .55s var(--ev);pointer-events:none;
}
.ab-tl__row:hover .ab-tl__card::before{transform:translateX(100%);}
.ab-tl__yr{font-family:"League Spartan",sans-serif;font-size:.63rem;font-weight:900;letter-spacing:.12em;color:var(--g);margin-bottom:.3rem;}
.ab-tl__t{font-family:"League Spartan",sans-serif;font-size:.96rem;font-weight:900;letter-spacing:-.01em;color:rgba(255,255,255,.85);margin-bottom:.38rem;transition:color .25s;}
.ab-tl__row:hover .ab-tl__t{color:#fff;}
.ab-tl__p{font-size:.76rem;line-height:1.68;color:rgba(255,255,255,.37);transition:color .25s;}
.ab-tl__row:hover .ab-tl__p{color:rgba(255,255,255,.55);}
 
/* ── BOTTOM ── */
.ab-bot{
  display:grid;grid-template-columns:1fr 1fr;
  gap:1.5rem;align-items:stretch;
}
@media(max-width:680px){.ab-bot{grid-template-columns:1fr;}}
 
.ab-mani{
  background:var(--s2);border:1px solid var(--border2);
  border-radius:20px;padding:2.4rem;
  display:flex;flex-direction:column;gap:1.3rem;
  position:relative;overflow:hidden;
}
.ab-mani::after{
  content:"";position:absolute;top:-70px;right:-70px;
  width:260px;height:260px;border-radius:50%;
  background:radial-gradient(circle,rgba(124,179,66,.06) 0%,transparent 65%);
  pointer-events:none;
}
.ab-mani__h{
  font-family:"League Spartan",sans-serif;
  font-size:clamp(1.4rem,2.3vw,1.8rem);
  font-weight:900;line-height:1.05;letter-spacing:-.035em;color:#fff;
}
.ab-mani__h em{font-style:normal;color:var(--gl);}
.ab-mani__p{font-size:.81rem;line-height:1.75;color:rgba(200,230,170,.45);}
.ab-mani__btn{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.55rem 1.2rem;border-radius:50px;
  background:var(--g);color:#000;
  font-size:.72rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  text-decoration:none;width:fit-content;
  box-shadow:0 4px 18px var(--glow);
  position:relative;overflow:hidden;
  transition:transform .28s var(--spring),box-shadow .3s,background .25s;
}
.ab-mani__btn::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.18) 50%,transparent 70%);
  transform:translateX(-120%);transition:transform .45s var(--ev);pointer-events:none;
}
.ab-mani__btn:hover::before{transform:translateX(120%);}
.ab-mani__btn:hover{transform:scale(1.06) translateY(-2px);box-shadow:0 8px 28px rgba(124,179,66,.5);background:var(--gl);}
.ab-mani__btn svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round;}
 
.ab-svcs{
  display:flex;flex-direction:column;
  border:1px solid var(--border);border-radius:20px;
  overflow:hidden;background:var(--border);gap:1px;
}
.ab-svc{
  background:var(--bg2);
  padding:1rem 1.4rem;
  display:flex;align-items:center;gap:1rem;
  cursor:default;position:relative;overflow:hidden;
  transition:background .25s;
}
.ab-svc:hover{background:var(--s2);}
.ab-svc::after{
  content:"";position:absolute;bottom:-1px;left:0;
  height:1px;width:0;
  background:linear-gradient(90deg,var(--g),transparent);
  transition:width .4s var(--ease);
}
.ab-svc:hover::after{width:55%;}
.ab-svc__ico{
  width:36px;height:36px;border-radius:9px;flex-shrink:0;
  background:rgba(124,179,66,.07);border:1px solid rgba(124,179,66,.12);
  display:flex;align-items:center;justify-content:center;
  transition:background .25s,transform .3s var(--spring),border-color .25s;
}
.ab-svc:hover .ab-svc__ico{background:rgba(124,179,66,.16);border-color:rgba(124,179,66,.28);transform:rotate(-5deg) scale(1.08);}
.ab-svc__ico svg{width:15px;height:15px;stroke:rgba(124,179,66,.7);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;transition:stroke .25s;}
.ab-svc:hover .ab-svc__ico svg{stroke:var(--gl);}
.ab-svc__info{flex:1;min-width:0;}
.ab-svc__name{font-family:"League Spartan",sans-serif;font-size:.87rem;font-weight:900;letter-spacing:-.01em;color:rgba(255,255,255,.75);transition:color .25s;}
.ab-svc:hover .ab-svc__name{color:#fff;}
.ab-svc__tag{font-size:.62rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:rgba(124,179,66,.6);}
.ab-svc__arr{
  width:22px;height:22px;border-radius:50%;
  background:rgba(124,179,66,.1);
  display:flex;align-items:center;justify-content:center;
  opacity:0;transform:translateX(-6px);flex-shrink:0;
  transition:opacity .2s,transform .3s var(--spring);
}
.ab-svc:hover .ab-svc__arr{opacity:1;transform:translateX(0);}
.ab-svc__arr svg{width:9px;height:9px;stroke:var(--g);fill:none;stroke-width:2.5;stroke-linecap:round;}
 
/* ── REVEAL ── */
.sr{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .75s var(--spring);}
.sr.vis{opacity:1;transform:none;}
.srl{opacity:0;transform:translateX(-24px);transition:opacity .7s var(--ease),transform .75s var(--spring);}
.srl.vis{opacity:1;transform:none;}
.srr{opacity:0;transform:translateX(24px);transition:opacity .7s var(--ease),transform .75s var(--spring);}
.srr.vis{opacity:1;transform:none;}
.srs{opacity:0;transform:scale(.95);transition:opacity .68s var(--ease),transform .72s var(--spring);}
.srs.vis{opacity:1;transform:none;}
 
.d1{transition-delay:.04s}.d2{transition-delay:.11s}.d3{transition-delay:.18s}
.d4{transition-delay:.25s}.d5{transition-delay:.32s}

:root{
  --g:#7cb342;
  --gl:#9ccc65;
  --gd:#558b2f;
  --bg:#060606;
  --bg2:#0e0e0e;
  --s2:#141414;
  --s3:#1c1c1c;
  --ink:#fff;
  --muted:rgba(255,255,255,.38);
  --border:rgba(255,255,255,.07);
  --border2:rgba(255,255,255,.12);
  --ease:cubic-bezier(0.16,1,0.3,1);
  --spring:cubic-bezier(0.34,1.56,0.64,1);
  --ev:cubic-bezier(0.32,0.72,0,1);
  --glow:rgba(124,179,66,.28);
}


.cvd{
  background:#060606;font-family:'DM Sans',sans-serif;
  padding:8rem 2rem 9rem;position:relative;overflow:hidden;
  min-height:100vh;
}
.cvd-particles{position:absolute;inset:0;pointer-events:none;overflow:hidden;}
.cvd-particle{
  position:absolute;border-radius:50%;
  background:var(--g);opacity:0;
  animation:particleFloat linear infinite;
}
@keyframes particleFloat{
  0%{opacity:0;transform:translateY(100vh) scale(0);}
  10%{opacity:.4;}
  90%{opacity:.1;}
  100%{opacity:0;transform:translateY(-20vh) scale(1.2);}
}
.cvd-orb{
  position:absolute;border-radius:50%;
  pointer-events:none;filter:blur(80px);
}
.cvd-orb-a{
  width:700px;height:700px;top:-200px;right:-200px;
  background:radial-gradient(circle,rgba(124,179,66,.07) 0%,transparent 65%);
  animation:orbA 16s ease-in-out infinite;
}
.cvd-orb-b{
  width:500px;height:500px;bottom:-150px;left:-100px;
  background:radial-gradient(circle,rgba(85,139,47,.055) 0%,transparent 65%);
  animation:orbB 12s ease-in-out infinite;
}
@keyframes orbA{0%,100%{transform:translate(0,0);}50%{transform:translate(-30px,20px);}}
@keyframes orbB{0%,100%{transform:translate(0,0);}50%{transform:translate(25px,-30px);}}
.cvd-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(124,179,66,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(124,179,66,.04) 1px,transparent 1px);
  background-size:60px 60px;
  -webkit-mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,#000 0%,transparent 100%);
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,#000 0%,transparent 100%);
}
.cvd-topline{
  position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(124,179,66,.5) 30%,rgba(156,204,101,.7) 50%,rgba(124,179,66,.5) 70%,transparent);
}
.cvd-wrap{max-width:1160px;margin:0 auto;position:relative;z-index:2;}

.cvd-eyebrow{
  display:flex;align-items:center;gap:.5rem;
  justify-content:center;margin-bottom:1.2rem;
  opacity:0;transform:translateY(16px);
  animation:slideUp .6s var(--spring) .2s forwards;
}
.cvd-eyebrow-pill{
  display:flex;align-items:center;gap:.5rem;
  padding:.25rem .85rem;border-radius:30px;
  background:rgba(124,179,66,.1);
  border:1px solid rgba(124,179,66,.25);
}
.cvd-eyebrow-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--g);
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(124,179,66,.4);}50%{box-shadow:0 0 0 5px rgba(124,179,66,0);}}
.cvd-eyebrow-txt{
  font-size:.6rem;font-weight:700;letter-spacing:.2em;
  text-transform:uppercase;color:var(--gl);
}

.cvd-heading{
  font-family:'League Spartan',sans-serif;
  font-size:clamp(2.6rem,5.5vw,5rem);
  font-weight:900;line-height:.93;letter-spacing:-.04em;
  color:#fff;text-align:center;margin-bottom:1.2rem;
  opacity:0;transform:translateY(20px);
  animation:slideUp .75s var(--spring) .35s forwards;
}
.cvd-heading em{font-style:normal;color:var(--gl);}
.cvd-heading .cvd-h-line2{
  display:block;
  background:linear-gradient(90deg,var(--g),var(--gl),#c5e1a5);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}

.cvd-sub{
  font-size:.9rem;line-height:1.7;
  color:rgba(200,230,170,.5);
  text-align:center;max-width:480px;margin:0 auto 4rem;
  opacity:0;transform:translateY(14px);
  animation:slideUp .65s var(--ease) .5s forwards;
}

@keyframes slideUp{to{opacity:1;transform:translateY(0);}}

.cvd-main{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  gap:0 3.5rem;align-items:center;
  opacity:0;transform:translateY(24px);
  animation:slideUp .8s var(--ease) .65s forwards;
}
@media(max-width:900px){
  .cvd-main{grid-template-columns:1fr;grid-template-rows:auto auto auto;gap:3rem 0;}
  .cvd-phone-col{order:-1;}
  .cvd-left,.cvd-right{max-width:480px;margin:0 auto;width:100%;}
}

/* ── FEATURES LEFT ── */
.cvd-features{display:flex;flex-direction:column;gap:.85rem;}
.cvd-feat{
  display:flex;align-items:center;gap:1rem;
  padding:1rem 1.2rem;border-radius:16px;
  background:rgba(124,179,66,.04);
  border:1px solid rgba(124,179,66,.1);
  cursor:default;
  transition:background .3s,border-color .3s,transform .35s var(--spring),box-shadow .3s;
  position:relative;overflow:hidden;
}
.cvd-feat::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(110deg,transparent 30%,rgba(124,179,66,.05) 50%,transparent 70%);
  transform:translateX(-100%);
  transition:transform .6s var(--ev);pointer-events:none;
}
.cvd-feat:hover::before{transform:translateX(100%);}
.cvd-feat:hover{
  background:rgba(124,179,66,.09);
  border-color:rgba(124,179,66,.25);
  transform:translateX(5px);
  box-shadow:0 4px 20px rgba(124,179,66,.08);
}
.cvd-feat-left{display:flex;align-items:center;gap:1rem;flex:1;}
.cvd-feat-ico{
  width:42px;height:42px;border-radius:11px;flex-shrink:0;
  background:rgba(124,179,66,.1);
  border:1px solid rgba(124,179,66,.18);
  display:flex;align-items:center;justify-content:center;font-size:18px;
  transition:transform .35s var(--spring),background .3s;
}
.cvd-feat:hover .cvd-feat-ico{transform:rotate(-8deg) scale(1.1);background:rgba(124,179,66,.2);}
.cvd-feat-info{}
.cvd-feat-title{
  font-family:'League Spartan',sans-serif;
  font-size:.95rem;font-weight:900;
  color:rgba(255,255,255,.8);
  transition:color .25s;margin-bottom:.15rem;
}
.cvd-feat:hover .cvd-feat-title{color:#fff;}
.cvd-feat-sub{font-size:.72rem;color:var(--muted);line-height:1.4;}
.cvd-feat-badge{
  font-size:.55rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--g);background:rgba(124,179,66,.1);
  border:1px solid rgba(124,179,66,.2);
  padding:.2rem .55rem;border-radius:20px;white-space:nowrap;flex-shrink:0;
}

/* ── RIGHT STATS ── */
.cvd-stats{display:flex;flex-direction:column;gap:.85rem;}
.cvd-stat-card{
  padding:1.2rem 1.4rem;border-radius:16px;
  background:rgba(20,20,20,.9);
  border:1px solid var(--border);
  position:relative;overflow:hidden;
  transition:background .3s,border-color .3s,transform .3s var(--spring);
  cursor:default;
}
.cvd-stat-card::after{
  content:"";position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--g),var(--gl),transparent);
  transform:scaleX(0);transform-origin:left;
  transition:transform .45s var(--ease);
}
.cvd-stat-card:hover{background:rgba(24,24,24,.95);border-color:rgba(124,179,66,.2);transform:translateX(-5px);}
.cvd-stat-card:hover::after{transform:scaleX(1);}
.cvd-stat-num{
  font-family:'League Spartan',sans-serif;
  font-size:2rem;font-weight:900;letter-spacing:-.04em;
  color:var(--g);line-height:1;margin-bottom:.25rem;
}
.cvd-stat-lbl{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;}

.cvd-cta-mini{
  margin-top:1.5rem;
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.6rem 1.4rem;border-radius:50px;
  background:var(--g);color:#000;
  font-size:.77rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  text-decoration:none;cursor:pointer;
  box-shadow:0 4px 22px var(--glow);
  position:relative;overflow:hidden;
  transition:transform .3s var(--spring),box-shadow .3s,background .25s;border:none;
}
.cvd-cta-mini::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.2) 50%,transparent 70%);
  transform:translateX(-120%);transition:transform .5s var(--ev);pointer-events:none;
}
.cvd-cta-mini:hover::before{transform:translateX(120%);}
.cvd-cta-mini:hover{transform:scale(1.06) translateY(-2px);box-shadow:0 8px 30px rgba(124,179,66,.55);background:var(--gl);}
.cvd-cta-arrow{transition:transform .3s var(--spring);}
.cvd-cta-mini:hover .cvd-cta-arrow{transform:translateX(4px);}

/* ── PHONE ── */
.cvd-phone-col{
  display:flex;align-items:center;justify-content:center;
  position:relative;
}
.cvd-phone-glow{
  position:absolute;
  width:280px;height:280px;border-radius:50%;
  background:radial-gradient(circle,rgba(124,179,66,.2) 0%,transparent 70%);
  filter:blur(40px);
  animation:glowPulse 3s ease-in-out infinite;
}
@keyframes glowPulse{0%,100%{transform:scale(1);opacity:.6;}50%{transform:scale(1.15);opacity:1;}}

.cvd-phone{
  position:relative;
  width:220px;
  animation:phoneFloat 4s ease-in-out infinite;
  filter:drop-shadow(0 30px 60px rgba(0,0,0,.7)) drop-shadow(0 0 40px rgba(124,179,66,.15));
}
@keyframes phoneFloat{
  0%,100%{transform:translateY(0) rotate(-1deg);}
  50%{transform:translateY(-14px) rotate(1deg);}
}
.cvd-phone-frame{
  width:220px;
  background:linear-gradient(145deg,#2a2a2a,#1a1a1a);
  border-radius:38px;
  padding:6px;
  border:1px solid rgba(255,255,255,.12);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.12),
    inset 0 -1px 0 rgba(0,0,0,.4),
    0 0 0 1px rgba(0,0,0,.5);
  position:relative;
}
.cvd-phone-notch{
  position:absolute;top:8px;left:50%;transform:translateX(-50%);
  width:70px;height:22px;
  background:#0a0a0a;
  border-radius:0 0 14px 14px;
  z-index:20;
  display:flex;align-items:center;justify-content:center;gap:6px;
}
.cvd-phone-notch-cam{
  width:8px;height:8px;border-radius:50%;
  background:radial-gradient(circle,#2a4a2a,#0f1f0f);
  border:1px solid rgba(124,179,66,.2);
}
.cvd-phone-notch-mic{
  width:20px;height:4px;border-radius:3px;
  background:#111;
}
.cvd-phone-screen{
  background:#7cb342;
  border-radius:32px;
  overflow:hidden;
  min-height:440px;
  position:relative;
}
.cvd-phone-screen::before{
  content:"";position:absolute;top:-30%;left:-20%;
  width:100%;height:80%;border-radius:50%;
  background:rgba(255,255,255,.07);
  pointer-events:none;
}
.cvd-ps-inner{
  padding:40px 14px 18px;
  display:flex;flex-direction:column;align-items:center;
}
.cvd-ps-avatar{
  width:62px;height:62px;border-radius:50%;
  background:rgba(255,255,255,.9);
  border:3px solid rgba(255,255,255,.5);
  box-shadow:0 4px 20px rgba(0,0,0,.25);
  margin-bottom:.7rem;
  display:flex;align-items:center;justify-content:center;
  font-size:22px;
  animation:avatarPop .6s var(--spring) 1.4s both;
  position:relative;
  overflow:hidden;
}
.cvd-ps-avatar::after{
  content:"";position:absolute;inset:0;border-radius:50%;
  background:linear-gradient(135deg,rgba(255,255,255,.3),transparent);
}
@keyframes avatarPop{from{transform:scale(.5);opacity:0;}to{transform:scale(1);opacity:1;}}
.cvd-ps-name{
  font-family:'League Spartan',sans-serif;
  font-size:1rem;font-weight:900;color:#fff;
  letter-spacing:-.01em;text-shadow:0 2px 8px rgba(0,0,0,.3);
  margin-bottom:.15rem;
}
.cvd-ps-role{font-size:.6rem;color:rgba(255,255,255,.7);text-align:center;margin-bottom:1rem;}
.cvd-ps-links{width:100%;display:flex;flex-direction:column;gap:.45rem;}
.cvd-ps-link{
  display:flex;align-items:center;gap:.5rem;
  padding:.55rem .8rem;border-radius:12px;
  background:rgba(255,255,255,.92);
  font-size:.72rem;font-weight:600;
  color:#1a1a1a;text-decoration:none;
  opacity:0;transform:translateX(-20px);
  transition:background .2s,transform .2s var(--spring);
  box-shadow:0 2px 8px rgba(0,0,0,.12);
}
.cvd-ps-link:hover{background:#fff;transform:translateX(3px)!important;}
.cvd-ps-link-ico{font-size:14px;width:20px;text-align:center;flex-shrink:0;}
.cvd-ps-link-txt{flex:1;font-weight:600;}
.cvd-ps-link-arr{margin-left:auto;font-size:10px;opacity:.4;}
.cvd-ps-socials{
  display:flex;gap:.5rem;margin-top:.9rem;
  justify-content:center;
}
.cvd-ps-soc{
  width:30px;height:30px;border-radius:8px;
  background:rgba(255,255,255,.2);
  border:1px solid rgba(255,255,255,.3);
  display:flex;align-items:center;justify-content:center;
  font-size:13px;
  transition:background .2s,transform .25s var(--spring);
  cursor:pointer;opacity:0;
}
.cvd-ps-soc:hover{background:rgba(255,255,255,.35);transform:translateY(-3px);}
.cvd-ps-link.anim{animation:linkIn .45s var(--spring) both;}
.cvd-ps-soc.anim{animation:socIn .5s var(--spring) both;}
@keyframes linkIn{to{opacity:1;transform:translateX(0);}}
@keyframes socIn{to{opacity:1;transform:none;}}

/* Reflection */
.cvd-phone::after{
  content:"";position:absolute;
  bottom:-30px;left:10%;right:10%;height:30px;
  background:radial-gradient(ellipse,rgba(124,179,66,.18) 0%,transparent 70%);
  filter:blur(8px);
  border-radius:50%;
}

/* ── BOTTOM SECTION ── */
.cvd-bottom{
  margin-top:5rem;
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--border);border:1px solid var(--border);
  border-radius:20px;overflow:hidden;
  opacity:0;transform:translateY(20px);
  animation:slideUp .7s var(--ease) 1s forwards;
}
@media(max-width:700px){.cvd-bottom{grid-template-columns:1fr;}}
.cvd-bottom-item{
  background:#0e0e0e;padding:1.8rem 2rem;
  position:relative;overflow:hidden;cursor:default;
  transition:background .3s;
}
.cvd-bottom-item:hover{background:#141414;}
.cvd-bottom-item::before{
  content:"";position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--g),transparent);
  transform:scaleX(0);transform-origin:center;transition:transform .4s var(--ease);
}
.cvd-bottom-item:hover::before{transform:scaleX(1);}
.cvd-bottom-ico{
  width:44px;height:44px;border-radius:12px;
  background:rgba(124,179,66,.08);border:1px solid rgba(124,179,66,.15);
  display:flex;align-items:center;justify-content:center;
  font-size:20px;margin-bottom:1rem;
  transition:transform .35s var(--spring),background .3s;
}
.cvd-bottom-item:hover .cvd-bottom-ico{transform:rotate(-8deg) scale(1.1);background:rgba(124,179,66,.18);}
.cvd-bottom-t{
  font-family:'League Spartan',sans-serif;
  font-size:.95rem;font-weight:900;color:rgba(255,255,255,.8);
  margin-bottom:.4rem;transition:color .25s;
}
.cvd-bottom-item:hover .cvd-bottom-t{color:#fff;}
.cvd-bottom-d{font-size:.75rem;color:var(--muted);line-height:1.6;}

/* ── TICKER ── */
.cvd-ticker{
  margin-top:3.5rem;
  display:flex;align-items:center;gap:1.5rem;
  padding:1rem 1.5rem;border-radius:14px;
  background:rgba(124,179,66,.05);
  border:1px solid rgba(124,179,66,.12);
  overflow:hidden;
  opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease;
}
.cvd-ticker-label{
  font-size:.6rem;font-weight:700;letter-spacing:.15em;
  text-transform:uppercase;color:var(--g);
  white-space:nowrap;flex-shrink:0;
}
.cvd-ticker-track{overflow:hidden;flex:1;}
.cvd-ticker-inner{
  display:flex;gap:2.5rem;
  animation:ticker 18s linear infinite;
  white-space:nowrap;
}
@keyframes ticker{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}
.cvd-ticker-item{
  font-size:.72rem;color:rgba(200,230,170,.45);
  display:flex;align-items:center;gap:.5rem;
  white-space:nowrap;
}
.cvd-ticker-item span{color:rgba(124,179,66,.6);}

.cvd-integrations{
  margin-top:3.5rem;
  display:flex;align-items:center;gap:1.5rem;
  padding:1.1rem 1.5rem;border-radius:14px;
  background:rgba(124,179,66,.05);
  border:1px solid rgba(124,179,66,.12);
  overflow:hidden;position:relative;
  opacity:0;transform:translateY(14px);
opacity:0;transform:translateY(20px);transition:opacity .7s var(--ease),transform .7s var(--spring);
}
.cvd-integrations::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(124,179,66,.5) 30%,rgba(156,204,101,.7) 50%,rgba(124,179,66,.5) 70%,transparent);
}
.cvd-int-label{display:flex;flex-direction:column;gap:3px;flex-shrink:0;}
.cvd-int-label-top{font-size:.55rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--g);}
.cvd-int-label-bot{font-size:.6rem;color:var(--muted);white-space:nowrap;}
.cvd-int-divider{width:1px;height:32px;background:rgba(124,179,66,.15);flex-shrink:0;}
.cvd-int-track-outer{overflow:hidden;flex:1;}
.cvd-int-track{display:flex;gap:10px;animation:ticker 22s linear infinite;}
.cvd-int-pill{
  display:flex;align-items:center;gap:7px;
  padding:.38rem .85rem;border-radius:40px;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  flex-shrink:0;cursor:default;
  transition:border-color .25s,background .25s;
}
.cvd-int-pill:hover{background:rgba(124,179,66,.08);border-color:rgba(124,179,66,.25);}
.cvd-int-pill-icon{width:18px;height:18px;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0;font-weight:700;}
.cvd-int-pill-name{font-size:.7rem;font-weight:600;color:rgba(255,255,255,.65);white-space:nowrap;}


/* ══════════════════════════════════════════
   MOBILE  ≤ 768px  →  CARROSSEL HORIZONTAL
══════════════════════════════════════════ */
@media (max-width: 768px) {

  .sv__hint { display: flex; }

  .sv__grid {
    display: flex;
    flex-direction: row;
    gap: 12px;
    padding: 0 24px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .sv__grid::-webkit-scrollbar { display: none; }

  .sv__item {
    flex: 0 0 78vw;
    max-width: 300px;
    scroll-snap-align: start;
    border-radius: 16px;
  }

  .sv__dots {
    display: flex;
    justify-content: center;
    gap: 6px;
    padding-top: 20px;
  }

  .sv__dot {
    width: 6px; height: 6px;
    border-radius: 50%;
    background: #333;
    border: none;
    cursor: pointer;
    transition: background .3s, width .3s;
  }

  .sv__dot.active {
    background: #7fff4f;
    width: 18px;
    border-radius: 3px;
  }

  .sv__foot {
    flex-direction: column;
    align-items: flex-start;
    padding-top: 32px;
  }
}

/* Esconde dots no desktop */
@media (min-width: 769px) {
  .sv__dots { display: none; }
}/* Esconde por padrão (desktop) */
.sv__hint {
  display: none;
}

/* Mostra só no mobile */
@media (max-width: 768px) {
  .sv__hint {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 0 24px 16px;
    font-size: 11px;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: #555;
  }

  .sv__hint span {
    display: inline-block;
    width: 14px;
    height: 1px;
    background: #555;
  }
}

/* ─── GALERIA ─── */
.gl {
  padding: 60px 0;
  overflow: hidden;
}

.gl__track-wrap {
  overflow: hidden;
  width: 100%;
}

.gl__track {
  display: flex;
  align-items: center;
  gap: 14px;
  width: max-content;
  animation: gl-scroll 30s linear infinite;
}

/* Pausa ao hover (desktop) */
@media (hover: hover) {
  .gl__track:hover { animation-play-state: paused; }
}

@keyframes gl-scroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* Cards */
.gl__item {
  flex-shrink: 0;
  height: 220px;
  width: 300px;
  border-radius: 16px;
  overflow: hidden;
  cursor: pointer;
  transition: transform .3s, opacity .3s;
}
.gl__item:hover { transform: scale(1.03); opacity: .9; }

/* Variação de altura para dar ritmo visual */
.gl__item--tall { height: 260px; }
.gl__item--short { height: 180px; }

.gl__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  pointer-events: none;
  user-select: none;
}

/* ─── LIGHTBOX ─── */
.gl__lb {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.92);
  z-index: 9999;
  align-items: center;
  justify-content: center;
}
.gl__lb.open { display: flex; }

.gl__lb-img {
  max-width: 92vw;
  max-height: 88vh;
  border-radius: 12px;
  object-fit: contain;
  box-shadow: 0 0 60px rgba(0,0,0,.6);
}

.gl__lb-close {
  position: absolute;
  top: 20px; right: 24px;
  background: none;
  border: none;
  color: #fff;
  font-size: 26px;
  cursor: pointer;
  opacity: .7;
  transition: opacity .2s;
}
.gl__lb-close:hover { opacity: 1; }

/* Mobile */
@media (max-width: 768px) {
  .gl__item        { height: 180px; width: 240px; }
  .gl__item--tall  { height: 210px; }
  .gl__item--short { height: 150px; }
  .gl__track { gap: 10px; animation-duration: 22s; }
}

  @import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600&family=League+Spartan:wght@700;900&display=swap');

  :root {
    --g:  #7cb342;
    --gl: #9ccc65;
    --gd: #558b2f;
    --bg:      #060606;
    --bg2:     #0e0e0e;
    --s2:      #141414;
    --s3:      #1c1c1c;
    --ink:     #fff;
    --muted:   rgba(255,255,255,.38);
    --border:  rgba(255,255,255,.07);
    --border2: rgba(255,255,255,.12);
    --ease:    cubic-bezier(0.16,1,0.3,1);
    --spring:  cubic-bezier(0.34,1.56,0.64,1);
    --ev:      cubic-bezier(0.32,0.72,0,1);
    --glow:    rgba(124,179,66,.28);
  }

  * , *::before , *::after { box-sizing:border-box; margin:0; padding:0; }

  body {
    font-family:"DM Sans", sans-serif;
    background: var(--bg);
    color: var(--ink);
  }

  /* ──────────────────────────
     SECTION WRAPPER
  ────────────────────────── */
  .fq {
    background: var(--bg2);
    font-family: "DM Sans", sans-serif;
    padding: 7rem 2rem 8rem;
    position: relative;
    overflow: hidden;
  }

  /* orb de fundo */
  .fq::before {
    content: "";
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    width: 800px; height: 800px;
    background: radial-gradient(ellipse, rgba(124,179,66,.045) 0%, transparent 65%);
    pointer-events: none;
  }

  /* linha verde no topo */
  .fq::after {
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0; height: 1px;
    background: linear-gradient(
      90deg,
      transparent,
      rgba(124,179,66,.4) 30%,
      rgba(156,204,101,.55) 50%,
      rgba(124,179,66,.4) 70%,
      transparent
    );
  }

  /* dots pattern */
  .fq__dots {
    position: absolute; inset: 0;
    background-image: radial-gradient(rgba(124,179,66,.06) 1px, transparent 1px);
    background-size: 36px 36px;
    -webkit-mask-image: radial-gradient(ellipse 65% 65% at 50% 50%, #000 0%, transparent 100%);
    mask-image:         radial-gradient(ellipse 65% 65% at 50% 50%, #000 0%, transparent 100%);
    pointer-events: none;
  }

  .fq__wrap {
    max-width: 1100px;
    margin: 0 auto;
    position: relative;
    z-index: 2;
  }

  /* ──────────────────────────
     HEADER
  ────────────────────────── */
  .fq__header {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem 5rem;
    align-items: end;
    margin-bottom: 4.5rem;
  }
  @media (max-width: 700px) {
    .fq__header { grid-template-columns: 1fr; gap: 1.5rem; }
  }

  .fq__hl {
    opacity: 0; transform: translateY(20px);
    transition: opacity .7s var(--ease), transform .75s var(--spring);
  }
  .fq__hl.vis { opacity: 1; transform: translateY(0); }

  .fq__ey {
    display: flex; align-items: center; gap: .45rem;
    margin-bottom: .8rem;
  }
  .fq__ey-dash { width: 20px; height: 1.5px; background: var(--g); border-radius: 2px; }
  .fq__ey-txt  {
    font-size: .6rem; font-weight: 700;
    letter-spacing: .22em; text-transform: uppercase;
    color: var(--gl);
  }

  .fq__title {
    font-family: "League Spartan", sans-serif;
    font-size: clamp(2.2rem, 4vw, 3.4rem);
    font-weight: 900; line-height: .93;
    letter-spacing: -.035em; color: #fff;
  }
  .fq__title em { font-style: normal; color: var(--gl); }

  .fq__hr {
    opacity: 0; transform: translateY(14px);
    transition: opacity .6s var(--ease) .15s, transform .6s var(--ease) .15s;
  }
  .fq__hr.vis { opacity: 1; transform: translateY(0); }

  .fq__desc {
    font-size: .85rem; line-height: 1.72;
    color: rgba(200,230,170,.5);
    margin-bottom: 1.5rem;
  }

  /* Tabs de categoria */
  .fq__tabs {
    display: flex; gap: .4rem; flex-wrap: wrap;
  }
  .fq__tab {
    font-size: .62rem; font-weight: 700;
    letter-spacing: .12em; text-transform: uppercase;
    color: var(--muted);
    background: rgba(255,255,255,.04);
    border: 1px solid var(--border);
    padding: .3rem .75rem; border-radius: 20px;
    cursor: pointer;
    transition: color .25s, background .25s, border-color .25s, transform .2s var(--spring);
  }
  .fq__tab:hover {
    color: var(--g);
    background: rgba(124,179,66,.08);
    border-color: rgba(124,179,66,.2);
  }
  .fq__tab.active {
    color: var(--g);
    background: rgba(124,179,66,.12);
    border-color: rgba(124,179,66,.3);
  }

  /* ──────────────────────────
     ACCORDION
  ────────────────────────── */
  .fq__list {
    border-top: 1px solid var(--border);
  }

  .fq__item {
    border-bottom: 1px solid var(--border);
    position: relative;
    opacity: 0; transform: translateY(16px);
    transition:
      opacity .55s var(--ease),
      transform .6s var(--spring),
      border-color .3s;
  }
  .fq__item.vis { opacity: 1; transform: translateY(0); }

  /* linha verde no hover na base */
  .fq__item::after {
    content: "";
    position: absolute;
    bottom: -1px; left: 0;
    height: 1px; width: 0;
    background: linear-gradient(90deg, var(--g), var(--gl), transparent);
    transition: width .45s var(--ease);
  }
  .fq__item:hover::after { width: 100%; }

  /* Linha verde lateral quando aberta */
  .fq__item.open { border-color: rgba(124,179,66,.15); }
  .fq__item.open::before {
    content: "";
    position: absolute;
    left: 0; top: 0; bottom: 0; width: 2px;
    background: linear-gradient(to bottom, var(--g), var(--gl));
    border-radius: 2px 0 0 2px;
  }

  .fq__trigger {
    width: 100%; display: flex;
    align-items: center; gap: 1.2rem;
    padding: 1.5rem 0 1.5rem 1rem;
    background: none; border: none;
    cursor: pointer; text-align: left;
    color: inherit;
  }

  .fq__trigger-num {
    font-family: "League Spartan", sans-serif;
    font-size: .62rem; font-weight: 900;
    letter-spacing: .1em;
    color: rgba(124,179,66,.25);
    flex-shrink: 0; width: 2rem;
    transition: color .3s;
  }
  .fq__item:hover .fq__trigger-num,
  .fq__item.open  .fq__trigger-num { color: var(--g); }

  .fq__trigger-icon {
    width: 42px; height: 42px; flex-shrink: 0;
    border-radius: 11px;
    background: rgba(124,179,66,.07);
    border: 1px solid rgba(124,179,66,.12);
    display: flex; align-items: center; justify-content: center;
    transition: background .25s, border-color .25s, transform .3s var(--spring);
  }
  .fq__trigger-icon svg {
    width: 18px; height: 18px;
    stroke: rgba(124,179,66,.7); fill: none;
    stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round;
    transition: stroke .25s;
  }
  .fq__item:hover .fq__trigger-icon,
  .fq__item.open  .fq__trigger-icon {
    background: rgba(124,179,66,.14);
    border-color: rgba(124,179,66,.28);
    transform: rotate(-6deg) scale(1.08);
  }
  .fq__item:hover .fq__trigger-icon svg,
  .fq__item.open  .fq__trigger-icon svg { stroke: var(--gl); }

  .fq__trigger-q {
    flex: 1;
    font-family: "League Spartan", sans-serif;
    font-size: 1.02rem; font-weight: 900;
    letter-spacing: -.01em;
    color: rgba(255,255,255,.8);
    transition: color .25s;
  }
  .fq__item:hover .fq__trigger-q,
  .fq__item.open  .fq__trigger-q { color: #fff; }

  /* Botão +/– */
  .fq__toggle {
    flex-shrink: 0;
    width: 30px; height: 30px; border-radius: 50%;
    background: rgba(124,179,66,.08);
    border: 1px solid rgba(124,179,66,.15);
    display: flex; align-items: center; justify-content: center;
    transition: background .25s, border-color .25s, transform .35s var(--spring);
  }
  .fq__toggle svg {
    width: 12px; height: 12px;
    stroke: var(--g); fill: none;
    stroke-width: 2.5; stroke-linecap: round;
    transition: transform .35s var(--spring);
  }
  .fq__item.open .fq__toggle {
    background: rgba(124,179,66,.18);
    border-color: rgba(124,179,66,.35);
    transform: rotate(45deg);
  }

  /* Resposta */
  .fq__body {
    display: grid;
    grid-template-rows: 0fr;
    transition: grid-template-rows .38s var(--ease);
    padding-left: 1rem;
  }
  .fq__item.open .fq__body {
    grid-template-rows: 1fr;
  }
  .fq__body-inner {
    overflow: hidden;
    padding: 0 0 0 calc(2rem + 42px + 1.2rem);
  }
  .fq__body-pad {
    padding-bottom: 1.6rem;
    font-size: .84rem; line-height: 1.78;
    color: rgba(200,230,170,.5);
  }

  /* tag inline na resposta */
  .fq__tag {
    display: inline-flex; align-items: center; gap: .3rem;
    font-size: .58rem; font-weight: 700;
    letter-spacing: .1em; text-transform: uppercase;
    color: var(--g);
    background: rgba(124,179,66,.08);
    border: 1px solid rgba(124,179,66,.15);
    padding: .18rem .55rem; border-radius: 20px;
    margin-left: .4rem; vertical-align: middle;
  }

  /* link interno na resposta */
  .fq__body-link {
    display: inline-flex; align-items: center; gap: .3rem;
    color: var(--gl); font-weight: 600;
    text-decoration: none;
    transition: color .2s, gap .25s var(--spring);
  }
  .fq__body-link:hover { color: #fff; gap: .5rem; }
  .fq__body-link svg {
    width: 11px; height: 11px;
    stroke: currentColor; fill: none;
    stroke-width: 2.4; stroke-linecap: round; flex-shrink: 0;
  }

  /* highlight verde em texto */
  .fq__body-pad strong { color: rgba(156,204,101,.8); font-weight: 600; }

  /* ──────────────────────────
     RODAPÉ
  ────────────────────────── */
  .fq__foot {
    display: flex; align-items: center;
    justify-content: space-between; gap: 1.5rem; flex-wrap: wrap;
    margin-top: 3.5rem; padding-top: 2rem;
    border-top: 1px solid var(--border);
    opacity: 0; transform: translateY(14px);
    transition: opacity .6s var(--ease) .55s, transform .6s var(--ease) .55s;
  }
  .fq__foot.vis { opacity: 1; transform: translateY(0); }

  .fq__foot-note {
    font-size: .8rem; color: var(--muted);
    line-height: 1.65; max-width: 360px;
  }
  .fq__foot-note strong { color: rgba(156,204,101,.75); font-weight: 600; }

  .fq__cta {
    display: inline-flex; align-items: center; gap: .5rem;
    padding: .62rem 1.4rem; border-radius: 50px;
    background: var(--g); color: #000;
    font-size: .76rem; font-weight: 700;
    letter-spacing: .08em; text-transform: uppercase;
    text-decoration: none; white-space: nowrap;
    box-shadow: 0 4px 20px var(--glow);
    position: relative; overflow: hidden;
    transition: transform .28s var(--spring), box-shadow .3s, background .25s;
  }
  .fq__cta::before {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(110deg, transparent 30%, rgba(255,255,255,.18) 50%, transparent 70%);
    transform: translateX(-120%);
    transition: transform .45s var(--ev);
    pointer-events: none;
  }
  .fq__cta:hover::before { transform: translateX(120%); }
  .fq__cta:hover {
    transform: scale(1.05) translateY(-2px);
    box-shadow: 0 8px 28px rgba(124,179,66,.48);
    background: var(--gl);
  }
  .fq__cta svg {
    width: 12px; height: 12px;
    stroke: currentColor; fill: none;
    stroke-width: 2.5; stroke-linecap: round; flex-shrink: 0;
  }

  /* ──────────────────────────
     REVEAL
  ────────────────────────── */
  .sr { opacity:0; transform:translateY(24px); transition:opacity .7s var(--ease), transform .75s var(--spring); }
  .sr.vis { opacity:1; transform:none; }

  /* Itens com stagger */
  .fq__item:nth-child(1) { transition-delay:.05s; }
  .fq__item:nth-child(2) { transition-delay:.10s; }
  .fq__item:nth-child(3) { transition-delay:.15s; }
  .fq__item:nth-child(4) { transition-delay:.20s; }
  .fq__item:nth-child(5) { transition-delay:.25s; }
  .fq__item:nth-child(6) { transition-delay:.30s; }
  .fq__item:nth-child(7) { transition-delay:.35s; }
  .fq__item:nth-child(8) { transition-delay:.40s; }

  @media (max-width: 640px) {
    .fq { padding: 5rem 1.4rem 6rem; }
    .fq__trigger { padding: 1.2rem 0 1.2rem .5rem; }
    .fq__body-inner { padding-left: .5rem; }
    .fq__foot { flex-direction: column; align-items: flex-start; }
    .fq__tabs { display: none; }
  }
    @import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600&family=League+Spartan:wght@700;900&display=swap');

  :root {
    --g:     #7cb342;
    --gl:    #9ccc65;
    --gd:    #558b2f;
    --bg:    #060606;
    --bg2:   #0e0e0e;
    --s2:    #141414;
    --ink:   #fff;
    --muted: rgba(255,255,255,.38);
    --border:rgba(255,255,255,.07);
    --ease:  cubic-bezier(0.16,1,0.3,1);
    --spring:cubic-bezier(0.34,1.56,0.64,1);
    --ev:    cubic-bezier(0.32,0.72,0,1);
    --glow:  rgba(124,179,66,.28);
  }

  *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

  body {
    font-family: "DM Sans", sans-serif;
    background: var(--bg);
    color: var(--ink);
  }

  /* ──────────────────────────
     SECTION
  ────────────────────────── */
  .gal {
    background: var(--bg);
    padding: 7rem 2rem 8rem;
    position: relative;
    overflow: hidden;
  }

  .gal::before {
    content: "";
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    width: 900px; height: 900px;
    background: radial-gradient(ellipse, rgba(124,179,66,.04) 0%, transparent 65%);
    pointer-events: none;
  }

  .gal::after {
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0; height: 1px;
    background: linear-gradient(
      90deg,
      transparent,
      rgba(124,179,66,.4) 30%,
      rgba(156,204,101,.55) 50%,
      rgba(124,179,66,.4) 70%,
      transparent
    );
  }

  .gal__dots {
    position: absolute; inset: 0;
    background-image: radial-gradient(rgba(124,179,66,.055) 1px, transparent 1px);
    background-size: 36px 36px;
    -webkit-mask-image: radial-gradient(ellipse 70% 70% at 50% 50%, #000 0%, transparent 100%);
    mask-image:         radial-gradient(ellipse 70% 70% at 50% 50%, #000 0%, transparent 100%);
    pointer-events: none;
  }

  .gal__wrap {
    max-width: 1200px;
    margin: 0 auto;
    position: relative;
    z-index: 2;
  }

  /* ──────────────────────────
     HEADER
  ────────────────────────── */
  .gal__header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 2rem;
    margin-bottom: 3.5rem;
    flex-wrap: wrap;
    opacity: 0; transform: translateY(18px);
    transition: opacity .7s var(--ease), transform .75s var(--spring);
  }
  .gal__header.vis { opacity: 1; transform: translateY(0); }

  .gal__ey {
    display: flex; align-items: center; gap: .45rem;
    margin-bottom: .75rem;
  }
  .gal__ey-dash { width: 20px; height: 1.5px; background: var(--g); border-radius: 2px; }
  .gal__ey-txt  {
    font-size: .6rem; font-weight: 700;
    letter-spacing: .22em; text-transform: uppercase;
    color: var(--gl);
  }

  .gal__title {
    font-family: "League Spartan", sans-serif;
    font-size: clamp(2rem, 3.6vw, 3rem);
    font-weight: 900; line-height: .93;
    letter-spacing: -.035em; color: #fff;
  }
  .gal__title em { font-style: normal; color: var(--gl); }

  .gal__desc {
    font-size: .83rem; line-height: 1.7;
    color: rgba(200,230,170,.5);
    max-width: 320px;
  }

  /* ──────────────────────────
     MASONRY GRID
  ────────────────────────── */
  .gal__grid {
    columns: 4;
    column-gap: 14px;
  }

  @media (max-width: 1024px) { .gal__grid { columns: 3; } }
  @media (max-width: 700px)  { .gal__grid { columns: 2; column-gap: 10px; } }
  @media (max-width: 420px)  { .gal__grid { columns: 1; } }

  /* ──────────────────────────
     CARD
  ────────────────────────── */
  .gal__card {
    break-inside: avoid;
    margin-bottom: 14px;
    border-radius: 16px;
    overflow: hidden;
    position: relative;
    cursor: pointer;
    transform-style: preserve-3d;
    will-change: transform;
    border: 1px solid var(--border);
    background: var(--s2);

    /* reveal inicial */
    opacity: 0; transform: translateY(30px) scale(.97);
    transition:
      opacity .65s var(--ease),
      transform .7s var(--spring),
      border-color .3s,
      box-shadow .3s;
  }
  .gal__card.vis {
    opacity: 1;
    transform: translateY(0) scale(1);
  }

  /* borda verde no topo — aparece no hover */
  .gal__card::before {
    content: "";
    position: absolute; top: 0; left: 0; right: 0; height: 2px;
    background: linear-gradient(90deg, transparent, var(--g), var(--gl), transparent);
    transform: scaleX(0); transform-origin: left;
    transition: transform .45s var(--ease);
    z-index: 4;
  }
  .gal__card:hover::before { transform: scaleX(1); }

  .gal__card:hover {
    border-color: rgba(124,179,66,.3);
    box-shadow:
      0 20px 60px rgba(0,0,0,.7),
      0 0 0 1px rgba(124,179,66,.08),
      0 0 40px rgba(124,179,66,.06);
  }

  /* imagem */
  .gal__card img {
    width: 100%;
    display: block;
    transition: transform .5s var(--ease), filter .4s;
    filter: brightness(.92) saturate(.95);
    transform-origin: center;
  }
  .gal__card:hover img {
    filter: brightness(.75) saturate(.8);
    transform: scale(1.04);
  }

  /* overlay escuro */
  .gal__overlay {
    position: absolute; inset: 0;
    background: linear-gradient(
      to top,
      rgba(0,0,0,.85) 0%,
      rgba(0,0,0,.2) 45%,
      transparent 100%
    );
    opacity: 0;
    transition: opacity .35s;
    z-index: 2;
  }
  .gal__card:hover .gal__overlay { opacity: 1; }

  /* botão "ver" */
  .gal__card-btn {
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%) scale(.65);
    opacity: 0;
    display: inline-flex; align-items: center; gap: .4rem;
    padding: .5rem 1.1rem; border-radius: 50px;
    background: var(--g); color: #000;
    font-family: "DM Sans", sans-serif;
    font-size: .68rem; font-weight: 700;
    letter-spacing: .08em; text-transform: uppercase;
    white-space: nowrap;
    transition: opacity .3s, transform .35s var(--spring);
    z-index: 3; pointer-events: none;
  }
  .gal__card:hover .gal__card-btn {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
  }
  .gal__card-btn svg {
    width: 11px; height: 11px;
    stroke: currentColor; fill: none;
    stroke-width: 2.5; stroke-linecap: round;
  }

  /* shine sweep */
  .gal__shine {
    position: absolute; inset: 0;
    background: linear-gradient(
      130deg,
      transparent 35%,
      rgba(255,255,255,.07) 50%,
      transparent 65%
    );
    transform: translateX(-100%);
    transition: transform .6s var(--ev);
    pointer-events: none;
    z-index: 3;
  }
  .gal__card:hover .gal__shine { transform: translateX(100%); }

  /* número decorativo */
  .gal__card-num {
    position: absolute;
    bottom: .8rem; right: 1rem;
    font-family: "League Spartan", sans-serif;
    font-size: 2rem; font-weight: 900;
    color: rgba(124,179,66,.07);
    line-height: 1; pointer-events: none;
    z-index: 2;
    transition: color .3s;
  }
  .gal__card:hover .gal__card-num { color: rgba(124,179,66,.14); }

  /* ──────────────────────────
     LIGHTBOX
  ────────────────────────── */
  .gal__lb {
    position: fixed; inset: 0;
    background: rgba(0,0,0,.93);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    z-index: 9999;
    display: flex; align-items: center; justify-content: center;
    opacity: 0; pointer-events: none;
    transition: opacity .35s var(--ease);
  }
  .gal__lb.open { opacity: 1; pointer-events: auto; }

  .gal__lb-inner {
    position: relative;
    max-width: 90vw; max-height: 90vh;
    transform: scale(.9);
    transition: transform .4s var(--spring);
  }
  .gal__lb.open .gal__lb-inner { transform: scale(1); }

  .gal__lb-img {
    max-width: 90vw; max-height: 86vh;
    border-radius: 16px;
    object-fit: contain;
    box-shadow: 0 0 80px rgba(0,0,0,.7), 0 0 0 1px rgba(124,179,66,.15);
    display: block;
  }

  /* barra verde topo lightbox */
  .gal__lb-inner::before {
    content: "";
    position: absolute; top: 0; left: 0; right: 0; height: 2px;
    background: linear-gradient(90deg, transparent, var(--g), var(--gl), transparent);
    border-radius: 16px 16px 0 0;
    z-index: 1;
  }

  .gal__lb-close {
    position: fixed; top: 1.5rem; right: 1.8rem;
    width: 40px; height: 40px; border-radius: 50%;
    background: rgba(124,179,66,.12);
    border: 1px solid rgba(124,179,66,.25);
    display: flex; align-items: center; justify-content: center;
    cursor: pointer;
    transition: background .25s, transform .3s var(--spring);
    color: #fff;
  }
  .gal__lb-close:hover {
    background: rgba(124,179,66,.25);
    transform: rotate(90deg) scale(1.1);
  }
  .gal__lb-close svg {
    width: 16px; height: 16px;
    stroke: currentColor; fill: none;
    stroke-width: 2.3; stroke-linecap: round;
  }

  /* nav prev/next */
  .gal__lb-nav {
    position: fixed; top: 50%; transform: translateY(-50%);
    width: 44px; height: 44px; border-radius: 50%;
    background: rgba(124,179,66,.1);
    border: 1px solid rgba(124,179,66,.2);
    display: flex; align-items: center; justify-content: center;
    cursor: pointer;
    transition: background .25s, transform .3s var(--spring), border-color .25s;
  }
  .gal__lb-nav:hover { background: rgba(124,179,66,.22); border-color: rgba(124,179,66,.4); }
  .gal__lb-nav--prev { left: 1.5rem; }
  .gal__lb-nav--prev:hover { transform: translateY(-50%) translateX(-3px); }
  .gal__lb-nav--next { right: 1.5rem; }
  .gal__lb-nav--next:hover { transform: translateY(-50%) translateX(3px); }
  .gal__lb-nav svg {
    width: 18px; height: 18px;
    stroke: var(--g); fill: none;
    stroke-width: 2.3; stroke-linecap: round;
  }

  /* contador */
  .gal__lb-count {
    position: fixed; bottom: 1.8rem; left: 50%; transform: translateX(-50%);
    font-size: .68rem; font-weight: 700;
    letter-spacing: .16em; text-transform: uppercase;
    color: rgba(124,179,66,.6);
    font-family: "League Spartan", sans-serif;
  }

  /* ──────────────────────────
     RODAPÉ
  ────────────────────────── */
  .gal__foot {
    display: flex; align-items: center; justify-content: center;
    margin-top: 3.5rem;
    opacity: 0; transform: translateY(14px);
    transition: opacity .6s var(--ease) .5s, transform .6s var(--ease) .5s;
  }
  .gal__foot.vis { opacity: 1; transform: translateY(0); }

  .gal__foot-inner {
    display: flex; flex-direction: column; align-items: center; gap: .6rem;
  }
  .gal__foot-label {
    font-size: .62rem; font-weight: 700;
    letter-spacing: .16em; text-transform: uppercase;
    color: var(--muted);
  }
  .gal__cta {
    display: inline-flex; align-items: center; gap: .5rem;
    padding: .68rem 1.6rem; border-radius: 50px;
    background: transparent;
    border: 1.5px solid rgba(124,179,66,.45);
    color: #fff;
    font-size: .78rem; font-weight: 700;
    letter-spacing: .07em; text-transform: uppercase;
    text-decoration: none; white-space: nowrap;
    position: relative; overflow: hidden;
    transition: color .35s, border-color .35s, transform .3s var(--spring), box-shadow .3s;
  }
  .gal__cta::before {
    content: ""; position: absolute; inset: 0;
    background: var(--g);
    transform: translateY(100%);
    transition: transform .35s var(--ev); z-index: 0;
  }
  .gal__cta:hover { color: #000; border-color: var(--g); transform: translateY(-2px); box-shadow: 0 8px 28px rgba(124,179,66,.35); }
  .gal__cta:hover::before { transform: translateY(0); }
  .gal__cta span, .gal__cta svg { position: relative; z-index: 1; }
  .gal__cta svg { width: 13px; height: 13px; stroke: currentColor; fill: none; stroke-width: 2.3; stroke-linecap: round; transition: transform .3s var(--spring); }
  .gal__cta:hover svg { transform: translateX(4px); }

  @media (max-width: 600px) {
    .gal { padding: 5rem 1.2rem 6rem; }
    .gal__card { margin-bottom: 10px; border-radius: 12px; }
    .gal__lb-nav { display: none; }
  }

  
.ct {
  background: #0a0a0a;
  padding: 8rem 2rem 9rem;
  position: relative;
  overflow: hidden;
  font-family: "DM Sans", sans-serif;
}
.ct::before {
  content: "";
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 900px; height: 900px;
  background: radial-gradient(ellipse, rgba(124,179,66,.045) 0%, transparent 65%);
  pointer-events: none;
}
.ct::after {
  content: "";
  position: absolute;
  bottom: -100px; right: -80px;
  width: 480px; height: 480px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(124,179,66,.055) 0%, transparent 70%);
  pointer-events: none;
}
.ct__topline {
  position: absolute;
  top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(124,179,66,.4) 30%, rgba(156,204,101,.55) 50%, rgba(124,179,66,.4) 70%, transparent);
}
.ct__dots {
  position: absolute; inset: 0;
  background-image: radial-gradient(rgba(124,179,66,.06) 1px, transparent 1px);
  background-size: 36px 36px;
  -webkit-mask-image: radial-gradient(ellipse 65% 65% at 50% 50%, #000 0%, transparent 100%);
  mask-image: radial-gradient(ellipse 65% 65% at 50% 50%, #000 0%, transparent 100%);
  pointer-events: none;
}
.ct__wrap {
  max-width: 1100px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  align-items: center;
}
@media (max-width: 860px) {
  .ct__wrap { grid-template-columns: 1fr; gap: 3.5rem; }
}
 
/* LEFT */
.ct__left {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .7s cubic-bezier(0.16,1,0.3,1), transform .75s cubic-bezier(0.34,1.56,0.64,1);
}
.ct__left.ct-vis { opacity: 1; transform: translateY(0); }
 
.ct__eyebrow {
  display: flex; align-items: center; gap: .5rem;
  margin-bottom: 1.4rem;
}
.ct__eyebrow-pill {
  display: flex; align-items: center; gap: .5rem;
  padding: .28rem .9rem; border-radius: 30px;
  background: rgba(124,179,66,.12);
  border: 1px solid rgba(124,179,66,.3);
}
.ct__eyebrow-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: #7cb342;
  animation: ctPulse 2s ease-in-out infinite;
}
@keyframes ctPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(124,179,66,.4); }
  50%       { box-shadow: 0 0 0 5px rgba(124,179,66,0); }
}
.ct__eyebrow-txt {
  font-size: .6rem; font-weight: 700;
  letter-spacing: .2em; text-transform: uppercase;
  color: #9ccc65;
}
.ct__title {
  font-family: "League Spartan", sans-serif;
  font-size: clamp(2.4rem, 4.5vw, 3.8rem);
  font-weight: 900; line-height: .93; letter-spacing: -.04em;
  color: #ffffff;
  margin-bottom: 1.1rem;
}
.ct__title em { font-style: normal; color: #9ccc65; }
.ct__desc {
  font-size: .85rem; line-height: 1.75;
  color: rgba(200,230,170,.55);
  max-width: 380px;
  margin-bottom: 2.5rem;
}
.ct__infos { display: flex; flex-direction: column; gap: .75rem; }
.ct__info {
  display: flex; align-items: center; gap: 1rem;
  padding: .85rem 1.1rem;
  border-radius: 14px;
  background: rgba(124,179,66,.05);
  border: 1px solid rgba(124,179,66,.12);
  cursor: default;
  transition: background .25s, border-color .25s, transform .3s cubic-bezier(0.34,1.56,0.64,1);
  position: relative; overflow: hidden;
}
.ct__info::before {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(110deg, transparent 30%, rgba(124,179,66,.05) 50%, transparent 70%);
  transform: translateX(-100%);
  transition: transform .55s cubic-bezier(0.32,0.72,0,1);
  pointer-events: none;
}
.ct__info:hover::before { transform: translateX(100%); }
.ct__info:hover {
  background: rgba(124,179,66,.1);
  border-color: rgba(124,179,66,.25);
  transform: translateX(5px);
}
.ct__info-ico {
  width: 42px; height: 42px; border-radius: 11px; flex-shrink: 0;
  background: rgba(124,179,66,.1);
  border: 1px solid rgba(124,179,66,.2);
  display: flex; align-items: center; justify-content: center;
  transition: background .25s, transform .3s cubic-bezier(0.34,1.56,0.64,1), border-color .25s;
}
.ct__info:hover .ct__info-ico {
  background: rgba(124,179,66,.2);
  border-color: rgba(124,179,66,.38);
  transform: rotate(-6deg) scale(1.08);
}
.ct__info-ico svg {
  width: 18px; height: 18px;
  stroke: rgba(124,179,66,.85); fill: none;
  stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round;
  transition: stroke .25s;
}
.ct__info:hover .ct__info-ico svg { stroke: #9ccc65; }
.ct__info-label {
  font-size: .6rem; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase;
  color: rgba(124,179,66,.65);
  margin-bottom: .1rem;
}
.ct__info-value {
  font-family: "League Spartan", sans-serif;
  font-size: .92rem; font-weight: 900;
  letter-spacing: -.01em; color: rgba(255,255,255,.85);
  transition: color .25s;
}
.ct__info:hover .ct__info-value { color: #fff; }
 
/* RIGHT */
.ct__right {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .7s cubic-bezier(0.16,1,0.3,1) .15s, transform .75s cubic-bezier(0.34,1.56,0.64,1) .15s;
}
.ct__right.ct-vis { opacity: 1; transform: translateY(0); }
 
.ct__card {
  background: #141414;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 22px;
  overflow: hidden;
  position: relative;
}
.ct__card::before {
  content: "";
  position: absolute; top: 0; left: 0; right: 0; height: 2.5px;
  background: linear-gradient(90deg, transparent, #7cb342, #9ccc65, transparent);
  background-size: 200% 100%;
  animation: ctShimmer 3s linear infinite;
}
@keyframes ctShimmer {
  0%   { background-position: -100% 0; }
  100% { background-position: 200% 0; }
}
.ct__card-inner { padding: 2rem; }
.ct__field { margin-bottom: 1.2rem; }
.ct__label {
  display: block;
  font-size: .62rem; font-weight: 700;
  letter-spacing: .16em; text-transform: uppercase;
  color: rgba(124,179,66,.75);
  margin-bottom: .55rem;
}
.ct__input-wrap { position: relative; }
.ct__input-ico {
  position: absolute;
  left: .9rem; top: 50%; transform: translateY(-50%);
  pointer-events: none;
}
.ct__input-ico svg {
  width: 16px; height: 16px;
  stroke: rgba(124,179,66,.4); fill: none;
  stroke-width: 1.6; stroke-linecap: round;
  transition: stroke .25s;
}
.ct__input-wrap:focus-within .ct__input-ico svg { stroke: rgba(124,179,66,.75); }
.ct__input {
  width: 100%;
  padding: .75rem 1rem .75rem 2.6rem;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 12px;
  color: #fff;
  font-family: "DM Sans", sans-serif;
  font-size: .85rem;
  outline: none;
  transition: border-color .25s, background .25s, box-shadow .25s;
}
.ct__input::placeholder { color: rgba(255,255,255,.25); }
.ct__input:focus {
  border-color: rgba(124,179,66,.5);
  background: rgba(124,179,66,.05);
  box-shadow: 0 0 0 3px rgba(124,179,66,.1);
}
.ct__textarea-wrap { position: relative; }
.ct__textarea-ico {
  position: absolute;
  left: .9rem; top: .9rem;
  pointer-events: none;
}
.ct__textarea-ico svg {
  width: 16px; height: 16px;
  stroke: rgba(124,179,66,.4); fill: none;
  stroke-width: 1.6; stroke-linecap: round;
  transition: stroke .25s;
}
.ct__textarea-wrap:focus-within .ct__textarea-ico svg { stroke: rgba(124,179,66,.75); }
.ct__textarea {
  width: 100%;
  padding: .75rem 1rem .75rem 2.6rem;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 12px;
  color: #fff;
  font-family: "DM Sans", sans-serif;
  font-size: .85rem;
  outline: none;
  resize: none;
  height: 130px;
  transition: border-color .25s, background .25s, box-shadow .25s;
}
.ct__textarea::placeholder { color: rgba(255,255,255,.25); }
.ct__textarea:focus {
  border-color: rgba(124,179,66,.5);
  background: rgba(124,179,66,.05);
  box-shadow: 0 0 0 3px rgba(124,179,66,.1);
}
.ct__counter {
  text-align: right; margin-top: .35rem;
  font-size: .62rem; color: rgba(255,255,255,.35);
  transition: color .25s;
}
.ct__counter.ct-warn { color: rgba(124,179,66,.7); }
.ct__divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.1), transparent);
  margin: 1.5rem 0;
}
.ct__btn {
  width: 100%;
  display: flex; align-items: center; justify-content: center; gap: .6rem;
  padding: .9rem 1.5rem;
  border-radius: 50px;
  background: #7cb342;
  color: #000;
  font-family: "DM Sans", sans-serif;
  font-size: .82rem; font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase;
  border: none; cursor: pointer;
  box-shadow: 0 4px 22px rgba(124,179,66,.3);
  position: relative; overflow: hidden;
  transition: transform .28s cubic-bezier(0.34,1.56,0.64,1), box-shadow .3s, background .25s;
}
.ct__btn::before {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(110deg, transparent 30%, rgba(255,255,255,.2) 50%, transparent 70%);
  transform: translateX(-120%);
  transition: transform .5s cubic-bezier(0.32,0.72,0,1);
  pointer-events: none;
}
.ct__btn:hover::before { transform: translateX(120%); }
.ct__btn:hover {
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 8px 30px rgba(124,179,66,.55);
  background: #9ccc65;
}
.ct__btn:active { transform: scale(.98); }
.ct__btn-arrow {
  width: 14px; height: 14px;
  stroke: currentColor; fill: none;
  stroke-width: 2.5; stroke-linecap: round; flex-shrink: 0;
  transition: transform .3s cubic-bezier(0.34,1.56,0.64,1);
}
.ct__btn:hover .ct__btn-arrow { transform: translateX(4px); }
.ct__card-note {
  padding: 1rem 2rem 1.5rem;
  text-align: center;
  font-size: .7rem;
  color: rgba(255,255,255,.35);
  line-height: 1.6;
  border-top: 1px solid rgba(255,255,255,.07);
}
.ct__card-note strong { color: rgba(156,204,101,.75); font-weight: 600; }
 
@media (max-width: 600px) {
  .ct { padding: 5rem 1.4rem 6rem; }
  .ct__title { font-size: 2.2rem; }
}

  
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600&family=League+Spartan:wght@700;900&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
body{font-family:"DM Sans",sans-serif;background:#000;}

.ft{background:#060606;font-family:"DM Sans",sans-serif;position:relative;overflow:hidden;padding:0;}
.ft__topline{position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(124,179,66,.4) 30%,rgba(156,204,101,.55) 50%,rgba(124,179,66,.4) 70%,transparent);}
.ft__orb{position:absolute;border-radius:50%;pointer-events:none;filter:blur(80px);}
.ft__orb-a{width:500px;height:500px;top:-150px;right:-80px;background:radial-gradient(circle,rgba(124,179,66,.06) 0%,transparent 65%);}
.ft__orb-b{width:400px;height:400px;bottom:-100px;left:-60px;background:radial-gradient(circle,rgba(85,139,47,.045) 0%,transparent 65%);}
.ft__dots{position:absolute;inset:0;background-image:radial-gradient(rgba(124,179,66,.055) 1px,transparent 1px);background-size:36px 36px;-webkit-mask-image:radial-gradient(ellipse 75% 75% at 50% 50%,#000 0%,transparent 100%);mask-image:radial-gradient(ellipse 75% 75% at 50% 50%,#000 0%,transparent 100%);pointer-events:none;}
.ft__wrap{max-width:1100px;margin:0 auto;padding:5rem 2rem 0;position:relative;z-index:2;}

.ft__top{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start;margin-bottom:3.5rem;}
@media(max-width:760px){.ft__top{grid-template-columns:1fr;gap:2.5rem;}}

.ft__logo{display:inline-block;margin-bottom:1rem;text-decoration:none;transition:transform .3s cubic-bezier(0.34,1.56,0.64,1),filter .3s;}
.ft__logo:hover{transform:translateY(-3px);filter:drop-shadow(0 6px 18px rgba(124,179,66,.45));}
.ft__logo-img{height:48px;width:auto;display:block;object-fit:contain;}

.ft__brand-desc{font-size:.82rem;line-height:1.7;color:rgba(200,230,170,.5);max-width:340px;margin-bottom:1.5rem;}
.ft__socials{display:flex;gap:.55rem;flex-wrap:wrap;}
.ft__soc{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;text-decoration:none;transition:transform .28s cubic-bezier(0.34,1.56,0.64,1),box-shadow .25s;flex-shrink:0;}
.ft__soc svg{width:17px;height:17px;}
.ft__soc--wa{background:linear-gradient(135deg,#25d366,#128c7e);color:#fff;box-shadow:0 3px 12px rgba(37,211,102,.2);}
.ft__soc--wa:hover{transform:scale(1.12) translateY(-2px);box-shadow:0 6px 20px rgba(37,211,102,.4);}
.ft__soc--ig{background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);color:#fff;box-shadow:0 3px 12px rgba(225,48,108,.2);}
.ft__soc--ig:hover{transform:scale(1.12) translateY(-2px);box-shadow:0 6px 20px rgba(225,48,108,.4);}
.ft__soc--fb{background:#1877f2;color:#fff;box-shadow:0 3px 12px rgba(24,119,242,.2);}
.ft__soc--fb:hover{transform:scale(1.12) translateY(-2px);box-shadow:0 6px 20px rgba(24,119,242,.4);}
.ft__soc--tk{background:#010101;border:1px solid rgba(255,255,255,.12);color:#fff;box-shadow:0 3px 12px rgba(0,0,0,.15);}
.ft__soc--tk:hover{transform:scale(1.12) translateY(-2px);box-shadow:0 6px 20px rgba(255,0,80,.35);}

/* ── NEWSLETTER ── */
.ft__newsletter{padding:2rem;border-radius:18px;background:#141414;border:1px solid rgba(255,255,255,.07);position:relative;overflow:hidden;min-height:220px;}
.ft__newsletter::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,#7cb342,#9ccc65,transparent);background-size:200% 100%;animation:ftShimmer 3s linear infinite;}
@keyframes ftShimmer{0%{background-position:-100% 0}100%{background-position:200% 0}}

.ft__nl-label{display:flex;align-items:center;gap:.4rem;margin-bottom:.7rem;}
.ft__nl-dot{width:6px;height:6px;border-radius:50%;background:#7cb342;animation:ftPulse 2s ease-in-out infinite;}
@keyframes ftPulse{0%,100%{box-shadow:0 0 0 0 rgba(124,179,66,.4);}50%{box-shadow:0 0 0 4px rgba(124,179,66,0);}}
.ft__nl-txt{font-size:.6rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:#9ccc65;}
.ft__nl-title{font-family:"League Spartan",sans-serif;font-size:1.45rem;font-weight:900;line-height:.97;letter-spacing:-.025em;color:#fff;margin-bottom:.6rem;}
.ft__nl-title em{font-style:normal;color:#9ccc65;}
.ft__nl-desc{font-size:.78rem;line-height:1.6;color:rgba(200,230,170,.45);margin-bottom:1.1rem;}

.ft__nl-form{display:flex;gap:.5rem;}
.ft__nl-input{flex:1;padding:.65rem 1rem;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:50px;color:#fff;font-family:"DM Sans",sans-serif;font-size:.82rem;outline:none;transition:border-color .25s,background .25s,box-shadow .25s;}
.ft__nl-input::placeholder{color:rgba(255,255,255,.25);}
.ft__nl-input:focus{border-color:rgba(124,179,66,.5);background:rgba(124,179,66,.05);box-shadow:0 0 0 3px rgba(124,179,66,.1);}
.ft__nl-input.ft-error{border-color:rgba(255,80,80,.5);box-shadow:0 0 0 3px rgba(255,80,80,.1);animation:ftShake .35s cubic-bezier(.36,.07,.19,.97);}
@keyframes ftShake{10%,90%{transform:translateX(-2px)}20%,80%{transform:translateX(3px)}30%,50%,70%{transform:translateX(-3px)}40%,60%{transform:translateX(3px)}}

.ft__nl-btn{width:42px;height:42px;border-radius:50%;flex-shrink:0;background:#7cb342;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(124,179,66,.3);transition:transform .28s cubic-bezier(0.34,1.56,0.64,1),box-shadow .25s,background .25s;position:relative;overflow:hidden;}
.ft__nl-btn:hover{transform:scale(1.12) translateY(-1px);box-shadow:0 6px 22px rgba(124,179,66,.5);background:#9ccc65;}
.ft__nl-btn:active{transform:scale(.95);}
.ft__nl-btn svg{width:14px;height:14px;stroke:#000;fill:none;stroke-width:2.3;stroke-linecap:round;transition:opacity .2s;}
.ft__nl-spin{position:absolute;width:18px;height:18px;border:2px solid rgba(0,0,0,.2);border-top-color:#000;border-radius:50%;animation:ftSpin .6s linear infinite;opacity:0;transition:opacity .2s;}
@keyframes ftSpin{to{transform:rotate(360deg)}}

.ft__nl-note{font-size:.65rem;color:rgba(255,255,255,.28);margin-top:.6rem;transition:opacity .3s;}

/* Loading state */
.ft__newsletter.ft-loading .ft__nl-spin{opacity:1;}
.ft__newsletter.ft-loading .ft__nl-btn svg{opacity:0;}
.ft__newsletter.ft-loading .ft__nl-btn{pointer-events:none;background:#558b2f;}
.ft__newsletter.ft-loading .ft__nl-input{pointer-events:none;opacity:.6;}

/* Success overlay */
.ft__nl-success{
  position:absolute;inset:0;border-radius:18px;
  background:#141414;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:.65rem;padding:2rem;text-align:center;
  opacity:0;pointer-events:none;
  transition:opacity .4s cubic-bezier(0.16,1,0.3,1);
}
.ft__newsletter.ft-done .ft__nl-success{opacity:1;pointer-events:auto;}
.ft__newsletter.ft-done .ft__nl-form-area{opacity:0;pointer-events:none;transition:opacity .3s;}

.ft__nl-ring{
  width:60px;height:60px;border-radius:50%;
  background:rgba(124,179,66,.12);border:1.5px solid rgba(124,179,66,.3);
  display:flex;align-items:center;justify-content:center;
  transform:scale(.5);opacity:0;
  transition:transform .5s cubic-bezier(0.34,1.56,0.64,1) .1s,opacity .4s .1s;
  position:relative;flex-shrink:0;
}
.ft__newsletter.ft-done .ft__nl-ring{transform:scale(1);opacity:1;}
.ft__nl-ring::after{content:"";position:absolute;inset:-6px;border-radius:50%;border:1px solid rgba(124,179,66,.15);animation:ftRingPulse 2s ease-in-out infinite;}
@keyframes ftRingPulse{0%,100%{transform:scale(1);opacity:1;}50%{transform:scale(1.12);opacity:0;}}

.ft__nl-check{width:26px;height:26px;stroke:#7cb342;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;}
.ft__nl-check-path{stroke-dasharray:30;stroke-dashoffset:30;transition:stroke-dashoffset .4s cubic-bezier(0.16,1,0.3,1) .45s;}
.ft__newsletter.ft-done .ft__nl-check-path{stroke-dashoffset:0;}

.ft__nl-ok-title{font-family:"League Spartan",sans-serif;font-size:1.15rem;font-weight:900;color:#fff;letter-spacing:-.02em;transform:translateY(10px);opacity:0;transition:transform .5s cubic-bezier(0.34,1.56,0.64,1) .3s,opacity .4s .3s;}
.ft__newsletter.ft-done .ft__nl-ok-title{transform:translateY(0);opacity:1;}
.ft__nl-ok-title em{font-style:normal;color:#9ccc65;}

.ft__nl-ok-txt{font-size:.75rem;line-height:1.6;color:rgba(200,230,170,.5);max-width:240px;transform:translateY(8px);opacity:0;transition:transform .5s cubic-bezier(0.34,1.56,0.64,1) .4s,opacity .4s .4s;}
.ft__newsletter.ft-done .ft__nl-ok-txt{transform:translateY(0);opacity:1;}

.ft__nl-ok-email{font-size:.7rem;font-weight:600;color:#7cb342;background:rgba(124,179,66,.1);border:1px solid rgba(124,179,66,.2);padding:.22rem .75rem;border-radius:20px;transform:translateY(6px);opacity:0;transition:transform .5s cubic-bezier(0.34,1.56,0.64,1) .5s,opacity .4s .5s;}
.ft__newsletter.ft-done .ft__nl-ok-email{transform:translateY(0);opacity:1;}

/* ── DIVISOR ── */
.ft__mid-div{height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.08) 30%,rgba(124,179,66,.15) 50%,rgba(255,255,255,.08) 70%,transparent);margin-bottom:3.5rem;}

/* ── LINKS ── */
.ft__links{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;margin-bottom:3.5rem;}
@media(max-width:860px){.ft__links{grid-template-columns:repeat(2,1fr);}}
@media(max-width:480px){.ft__links{grid-template-columns:1fr;gap:1.5rem;}}
.ft__col-title{font-family:"League Spartan",sans-serif;font-size:.62rem;font-weight:900;letter-spacing:.18em;text-transform:uppercase;color:#7cb342;margin-bottom:1rem;}
.ft__col-list{list-style:none;display:flex;flex-direction:column;gap:.35rem;}
.ft__col-list li a{font-size:.82rem;color:rgba(255,255,255,.45);text-decoration:none;display:inline-flex;align-items:center;gap:.3rem;transition:color .22s,transform .22s cubic-bezier(0.34,1.56,0.64,1);}
.ft__col-list li a:hover{color:#9ccc65;transform:translateX(3px);}
.ft__badge{font-size:.54rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#7cb342;background:rgba(124,179,66,.1);border:1px solid rgba(124,179,66,.2);padding:.15rem .5rem;border-radius:20px;}

.ft__col-list--contact{gap:.5rem;}
.ft__contact-item{display:flex!important;align-items:center;gap:.65rem;padding:.5rem .7rem;border-radius:10px;background:rgba(124,179,66,.04);border:1px solid rgba(124,179,66,.08);transition:background .22s,border-color .22s,transform .25s cubic-bezier(0.34,1.56,0.64,1)!important;}
.ft__contact-item:hover{background:rgba(124,179,66,.1)!important;border-color:rgba(124,179,66,.22)!important;transform:translateX(4px)!important;}
.ft__contact-ico{width:32px;height:32px;border-radius:8px;flex-shrink:0;background:rgba(124,179,66,.08);border:1px solid rgba(124,179,66,.12);display:flex;align-items:center;justify-content:center;transition:background .22s,transform .25s cubic-bezier(0.34,1.56,0.64,1);}
.ft__contact-item:hover .ft__contact-ico{background:rgba(124,179,66,.18);transform:rotate(-5deg) scale(1.08);}
.ft__contact-ico svg{width:14px;height:14px;stroke:rgba(124,179,66,.75);fill:none;stroke-width:1.6;stroke-linecap:round;}

/* ── BOTTOM ── */
.ft__bottom{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding:1.5rem 0 2rem;border-top:1px solid rgba(255,255,255,.07);}
.ft__copy{font-size:.74rem;color:rgba(255,255,255,.28);}
.ft__bottom-links{display:flex;align-items:center;gap:.75rem;}
.ft__bottom-links a{font-size:.72rem;color:rgba(255,255,255,.3);text-decoration:none;transition:color .2s;}
.ft__bottom-links a:hover{color:#9ccc65;}
.ft__bottom-sep{width:1px;height:10px;background:rgba(255,255,255,.12);}
.ft__made{display:flex;align-items:center;gap:.3rem;font-size:.72rem;color:rgba(255,255,255,.22);}
.ft__heart{color:#7cb342;font-size:.8rem;}
@media(max-width:600px){.ft__bottom{flex-direction:column;align-items:flex-start;gap:.75rem;}.ft__made{display:none;}}



*{box-sizing:border-box;margin:0;padding:0}
.about{background:#080808;padding:6rem 2rem;font-family:system-ui,sans-serif;overflow:hidden}
.about__wrap{max-width:960px;margin:0 auto}

.about__grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}

.about__visual{position:relative;opacity:0;transform:translateX(-32px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.about__visual.vis{opacity:1;transform:none}

.about__logo-frame{
  position:relative;width:100%;aspect-ratio:1;max-width:380px;
  border-radius:20px;overflow:hidden;
  border:1px solid rgba(124,179,66,.18);
  background:#111;
  display:flex;align-items:center;justify-content:center
}
.about__logo-frame::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 30% 30%,rgba(124,179,66,.12),transparent 65%);
  pointer-events:none
}
.about__logo-placeholder{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;
  width:100%;height:100%;padding:2.5rem;text-align:center
}
.about__logo-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  padding: 0;
  position: absolute;
  inset: 0;
}
.about__logo-label{
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(124,179,66,.5);margin-top:8px
}
.about__logo-icon{
  width:72px;height:72px;border-radius:16px;
  background:rgba(124,179,66,.1);border:1px solid rgba(124,179,66,.25);
  display:flex;align-items:center;justify-content:center
}
.about__logo-icon svg{width:32px;height:32px;stroke:#7cb342;fill:none;stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round}
.about__logo-name{font-size:1.5rem;font-weight:700;color:#fff;letter-spacing:.04em}
.about__logo-name span{color:#7cb342}

.about__corner{
  position:absolute;width:18px;height:18px;
  border-color:#7cb342;border-style:solid;opacity:.5
}
.about__corner--tl{top:-1px;left:-1px;border-width:2px 0 0 2px;border-radius:4px 0 0 0}
.about__corner--tr{top:-1px;right:-1px;border-width:2px 2px 0 0;border-radius:0 4px 0 0}
.about__corner--bl{bottom:-1px;left:-1px;border-width:0 0 2px 2px;border-radius:0 0 0 4px}
.about__corner--br{bottom:-1px;right:-1px;border-width:0 2px 2px 0;border-radius:0 0 4px 0}

.about__badge{
  position:absolute;bottom:-16px;right:-16px;
  background:#111;border:1px solid rgba(124,179,66,.2);
  border-radius:12px;padding:.85rem 1.1rem;
  display:flex;align-items:center;gap:10px;
  box-shadow:0 8px 32px rgba(0,0,0,.5)
}
.about__badge-dot{width:8px;height:8px;border-radius:50%;background:#7cb342;flex-shrink:0;animation:pulse 2s ease-in-out infinite}
.about__badge-txt{font-size:.78rem;color:rgba(255,255,255,.6);line-height:1.4}
.about__badge-txt strong{display:block;font-size:.88rem;color:#fff;font-weight:500}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.7)}}

.about__content{opacity:0;transform:translateX(32px);transition:opacity .9s .15s cubic-bezier(.16,1,.3,1),transform .9s .15s cubic-bezier(.16,1,.3,1)}
.about__content.vis{opacity:1;transform:none}

.about__ey{display:flex;align-items:center;gap:10px;margin-bottom:1.25rem}
.about__ey-line{display:block;width:24px;height:1px;background:#7cb342}
.about__ey-txt{font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:#7cb342}

.about__title{font-size:2.6rem;font-weight:600;line-height:1.1;color:#fff;margin-bottom:1.5rem}
.about__title em{font-style:normal;color:#7cb342}

.about__text{font-size:.95rem;color:rgba(255,255,255,.5);line-height:1.8;margin-bottom:1rem}
.about__text strong{color:rgba(255,255,255,.85);font-weight:500}

.about__divider{width:100%;height:1px;background:rgba(255,255,255,.06);margin:1.75rem 0}

.about__values{display:grid;grid-template-columns:1fr 1fr;gap:.85rem;margin-bottom:2rem}
.about__value{
  display:flex;align-items:flex-start;gap:10px;
  padding:.85rem 1rem;border-radius:10px;
  border:1px solid rgba(255,255,255,.06);
  background:rgba(255,255,255,.02);
  opacity:0;transform:translateY(14px);
  transition:opacity .5s cubic-bezier(.16,1,.3,1),transform .5s cubic-bezier(.16,1,.3,1),background .25s,border-color .25s
}
.about__value.vis{opacity:1;transform:none}
.about__value:hover{background:rgba(124,179,66,.06);border-color:rgba(124,179,66,.2)}
.about__value-dot{width:6px;height:6px;border-radius:50%;background:#7cb342;flex-shrink:0;margin-top:5px}
.about__value-txt{font-size:.84rem;color:rgba(255,255,255,.5);line-height:1.5}
.about__value-txt strong{display:block;font-size:.88rem;color:#fff;font-weight:500;margin-bottom:2px}

.about__cta{
  display:inline-flex;align-items:center;gap:8px;
  padding:.8rem 1.6rem;border-radius:100px;
  background:#7cb342;color:#080808;
  font-size:.875rem;font-weight:600;text-decoration:none;
  transition:background .25s,transform .3s cubic-bezier(.34,1.56,.64,1)
}
.about__cta svg{width:14px;height:14px;stroke:#080808;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:transform .35s cubic-bezier(.34,1.56,.64,1)}
.about__cta:hover{background:#9ccc65}
.about__cta:hover svg{transform:translateX(4px)}

@media(max-width:700px){
  .about__grid{grid-template-columns:1fr;gap:3rem}
  .about__visual{transform:translateY(-24px)}
  .about__content{transform:translateY(24px)}
  .about__logo-frame{max-width:100%}
  .about__title{font-size:2rem}
  .about__badge{right:0;bottom:-20px}
}
/* ══ CHAT WIDGET ══ */
:root {
  --chat-gm: #7cb342;
  --chat-gl: #9ccc65;
  --chat-gd: #558b2f;
}

.gchat__fab {
  position: fixed;
  bottom: 28px;
  right: 28px;
  z-index: 9990;
  width: 56px; height: 56px;
  border-radius: 50%;
  background: var(--chat-gm);
  border: none;
  cursor: pointer;
  display: grid;
  place-items: center;
  box-shadow: 0 4px 24px rgba(124,179,66,0.45);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.gchat__fab:hover { transform: scale(1.1); box-shadow: 0 6px 32px rgba(124,179,66,0.6); }
.gchat__fab svg { transition: opacity 0.2s, transform 0.2s; }
.gchat__fab .icon-open  { position: absolute; }
.gchat__fab .icon-close { position: absolute; opacity: 0; transform: rotate(-90deg); }
.gchat__fab.is-open .icon-open  { opacity: 0; transform: rotate(90deg); }
.gchat__fab.is-open .icon-close { opacity: 1; transform: rotate(0deg); }

.gchat__badge {
  position: absolute;
  top: -3px; right: -3px;
  width: 16px; height: 16px;
  background: #7cb342;
  border-radius: 50%;
  border: 2px solid #fff;
  animation: gchat-pulse 2s infinite;
}
@keyframes gchat-pulse {
  0%, 100% { transform: scale(1); }
  50%       { transform: scale(1.2); }
}
.gchat__fab.is-open .gchat__badge { display: none; }

.gchat__window {
  position: fixed;
  bottom: 96px;
  right: 28px;
  z-index: 9989;
  width: 360px;
  max-width: calc(100vw - 40px);
  height: 520px;
  max-height: calc(100vh - 120px);
  background: #0d110a;
  border: 1px solid rgba(124,179,66,0.2);
  border-radius: 18px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: 0 16px 48px rgba(0,0,0,0.5);
  transform: scale(0.92) translateY(16px);
  opacity: 0;
  pointer-events: none;
  transition: transform 0.3s cubic-bezier(0.34,1.56,0.64,1), opacity 0.25s ease;
  transform-origin: bottom right;
}
.gchat__window.is-open {
  transform: scale(1) translateY(0);
  opacity: 1;
  pointer-events: all;
}

.gchat__head {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  background: rgba(124,179,66,0.07);
  border-bottom: 1px solid rgba(124,179,66,0.12);
  flex-shrink: 0;
}
.gchat__avatar {
  width: 38px; height: 38px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--chat-gm), var(--chat-gd));
  display: grid;
  place-items: center;
  flex-shrink: 0;
}
.gchat__head-info { flex: 1; }
.gchat__head-name {
  font-family: 'DM Sans', sans-serif;
  font-size: 0.88rem;
  font-weight: 700;
  color: #f0f4ec;
  line-height: 1.2;
}
.gchat__head-status {
  font-size: 0.70rem;
  color: var(--chat-gl);
  display: flex;
  align-items: center;
  gap: 4px;
}
.gchat__head-status::before {
  content: '';
  width: 6px; height: 6px;
  background: var(--chat-gl);
  border-radius: 50%;
  display: inline-block;
  animation: gchat-pulse 2s infinite;
}

.gchat__msgs {
  flex: 1;
  overflow-y: auto;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  scrollbar-width: thin;
  scrollbar-color: rgba(124,179,66,0.3) transparent;
  /* impede que o scroll da lista propague para a página */
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
}
.gchat__msgs::-webkit-scrollbar { width: 3px; }
.gchat__msgs::-webkit-scrollbar-thumb { background: rgba(124,179,66,0.3); border-radius: 2px; }

.gchat__msg {
  display: flex;
  flex-direction: column;
  max-width: 82%;
  font-family: 'DM Sans', sans-serif;
  font-size: 0.84rem;
  line-height: 1.5;
  animation: gchat-in 0.25s ease;
}
@keyframes gchat-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.gchat__msg--bot  { align-self: flex-start; }
.gchat__msg--user { align-self: flex-end; }

.gchat__bubble {
  padding: 10px 14px;
  border-radius: 14px;
  word-break: break-word;
}
.gchat__msg--bot  .gchat__bubble {
  background: rgba(124,179,66,0.1);
  border: 1px solid rgba(124,179,66,0.15);
  color: #e8f0e0;
  border-bottom-left-radius: 4px;
}
.gchat__msg--user .gchat__bubble {
  background: var(--chat-gm);
  color: #fff;
  border-bottom-right-radius: 4px;
}

.gchat__typing {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 10px 14px;
  background: rgba(124,179,66,0.1);
  border: 1px solid rgba(124,179,66,0.15);
  border-radius: 14px;
  border-bottom-left-radius: 4px;
  width: fit-content;
}
.gchat__typing span {
  width: 6px; height: 6px;
  background: var(--chat-gl);
  border-radius: 50%;
  animation: gchat-dot 1.2s infinite;
}
.gchat__typing span:nth-child(2) { animation-delay: 0.2s; }
.gchat__typing span:nth-child(3) { animation-delay: 0.4s; }
@keyframes gchat-dot {
  0%, 80%, 100% { transform: scale(0.7); opacity: 0.4; }
  40%            { transform: scale(1);   opacity: 1; }
}

.gchat__footer {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 14px;
  border-top: 1px solid rgba(124,179,66,0.12);
  flex-shrink: 0;
  /* garante que o footer nunca some atrás do teclado */
  position: relative;
  z-index: 1;
}
.gchat__input {
  flex: 1;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(124,179,66,0.2);
  border-radius: 10px;
  padding: 9px 13px;
  font-family: 'DM Sans', sans-serif;
  font-size: 0.84rem;
  color: #f0f4ec;
  outline: none;
  resize: none;
  max-height: 90px;
  transition: border-color 0.2s;
}
.gchat__input::placeholder { color: rgba(240,244,236,0.35); }
.gchat__input:focus { border-color: var(--chat-gm); }

.gchat__send {
  width: 38px; height: 38px;
  border-radius: 10px;
  background: var(--chat-gm);
  border: none;
  cursor: pointer;
  display: grid;
  place-items: center;
  color: #fff;
  flex-shrink: 0;
  transition: background 0.2s, transform 0.15s;
}
.gchat__send:hover { background: var(--chat-gd); transform: scale(1.05); }
.gchat__send:disabled { opacity: 0.4; cursor: not-allowed; transform: none; }

.gchat__powered {
  text-align: center;
  font-size: 0.62rem;
  color: rgba(240,244,236,0.2);
  padding: 4px 0 8px;
  font-family: 'DM Sans', sans-serif;
  flex-shrink: 0;
}

/* ══ MOBILE ══════════════════════════════════════════════════
   Tela cheia + teclado virtual não estoura o layout.
   A chave é usar dvh (dynamic viewport height) + position fixed
   com top/bottom ancorados, deixando o flexbox resolver o espaço.
═══════════════════════════════════════════════════════════════ */
@media (max-width: 480px) {

  /* FAB some quando o chat está aberto */
  .gchat__fab {
    right: 16px;
    bottom: 20px;
    transition: opacity 0.2s, transform 0.2s, box-shadow 0.25s ease;
  }
  .gchat__fab.is-open {
    opacity: 0;
    pointer-events: none;
    transform: scale(0.8);
  }

  /* Janela ocupa 100% do viewport dinâmico */
  .gchat__window {
    position: fixed;
    inset: 0;                    /* top/right/bottom/left = 0 */
    width: 100%;
    max-width: 100%;
    height: 100dvh;              /* dvh respeita o teclado no iOS/Android */
    max-height: 100dvh;
    border-radius: 0;
    border: none;
    bottom: auto;                /* cancela o bottom: 96px do desktop */
    right: auto;                 /* cancela o right: 28px do desktop */
    transform: translateY(100%); /* entra de baixo */
    opacity: 0;
    transition: transform 0.38s cubic-bezier(0.22, 1, 0.36, 1),
                opacity   0.28s ease;
    transform-origin: bottom center;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    /* Evita que o body role por baixo */
    overscroll-behavior: none;
  }

  .gchat__window.is-open {
    transform: translateY(0);
    opacity: 1;
  }

  /* Header com safe-area para notch/ilha */
  .gchat__head {
    padding-top: max(14px, env(safe-area-inset-top));
    flex-shrink: 0;
  }

  /* Mensagens crescem e rolam — nunca saem da tela */
  .gchat__msgs {
    flex: 1;
    min-height: 0;               /* essencial: impede flex de estourar */
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
  }

  /* Footer fica sobre o teclado, respeitando safe-area */
  .gchat__footer {
    flex-shrink: 0;
    padding-bottom: max(12px, env(safe-area-inset-bottom));
  }

  .gchat__powered {
    flex-shrink: 0;
    padding-bottom: max(6px, env(safe-area-inset-bottom));
  }
}

@keyframes gchat-shake {
  0%, 100% { transform: translateX(0); }
  20%       { transform: translateX(-6px); }
  40%       { transform: translateX(6px); }
  60%       { transform: translateX(-4px); }
  80%       { transform: translateX(4px); }
}

/* ── Botão fechar mobile ── */
#gchat-close-mobile {
  display: none;
  background: rgba(124,179,66,0.15);
  border: 1px solid rgba(124,179,66,0.3);
  color: #7cb342;
  border-radius: 50%;
  width: 32px;
  height: 32px;
  font-size: 14px;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-left: auto;
  line-height: 1;
}

@media (max-width: 480px) {
  #gchat-close-mobile {
    display: flex;
  }
}