:root{--brand:#0d3b2e;--brand-accent:#21c27a;--brand-accent-2:#1aa066;--surface:rgba(255,255,255,.04);--text:#fff;}
/* Styles */
:root{--bg:#0f3d2e;--bg-soft:#0f3d2e;--surface:#0b2f24;--text:#f0f7f4;--muted:#cfe6dd;--accent:#2ad49f;--shadow:0 10px 30px rgba(0,0,0,.25)}
*{box-sizing:border-box}html,body{margin:0;padding:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);background:var(--bg-soft)}
a{color:var(--accent)}.container{width:min(1120px,92%);margin-inline:auto}
.site-header{position:sticky;top:0;backdrop-filter:saturate(1.2) blur(8px);background:rgba(11,47,36,.7);border-bottom:1px solid rgba(255,255,255,.08);z-index:20}
.site-header .container{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{display:flex;align-items:center;gap:10px;color:var(--text);text-decoration:none;font-weight:700}
.brand.small span{font-size:.95rem}
.btn{display:inline-block;background:var(--accent);color:#043526;text-decoration:none;padding:.85rem 1.15rem;border-radius:12px;font-weight:700;box-shadow:var(--shadow)}
.btn:hover{transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--text)}
.hero{padding:92px 0 60px;background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,0))}
.grid-1{display:grid;grid-template-columns:1fr;gap:24px}
.hero h1{font-size:clamp(28px,3.2vw,46px);line-height:1.1;margin:0 0 12px;text-wrap:balance}
.highlight{color:var(--accent)}
.hero p{color:var(--muted);font-size:1.05rem}
.cta-group{display:flex;gap:12px;margin-top:18px;flex-wrap:wrap;justify-content:center}
.badges{display:flex;justify-content:center;align-items:center;gap:16px;list-style:none;padding:0;margin:18px 0 0;color:var(--muted);text-align:center}
.badges li{text-align:center;flex:0 0 auto}
.steps{padding:64px 0;background:#0c3529}
.steps h2,.contact h2{font-size:clamp(24px,2.4vw,34px);margin:0 0 22px}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{background:#0b3126;border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:20px;box-shadow:var(--shadow)}
.card .icon{width:34px;height:34px;opacity:.9}
.card h3{margin:10px 0 6px}.card p{color:var(--muted)}
.contact{padding:90px 0 80px;background:#0c3529}
.form{margin-top:10px}.grid-form{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.grid-form .full{grid-column:1/-1}label{display:grid;gap:8px;font-weight:600}
input,textarea{background:#0b2f24;border:1px solid rgba(255,255,255,.12);color:var(--text);padding:.85rem;border-radius:10px;outline:none}
input::placeholder,textarea::placeholder{color:#9fcbb9}
.form-actions{display:flex;gap:12px;margin-top:12px;justify-content:flex-start}
.site-footer{border-top:1px solid rgba(255,255,255,.08);padding:26px 0;background:#0b2f24}
.footer-grid{display:flex;align-items:center;justify-content:space-between;gap:16px}
.socials{display:flex;gap:14px}
.tiny{opacity:.7;font-size:.9rem}
@media (max-width:900px){.cards{grid-template-columns:1fr}}

.cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: var(--surface);
  color: var(--text);
  padding: 14px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 10px;
  border-top: 1px solid rgba(255,255,255,.1);
  z-index: 9999;
  text-align: center;
}
.cookie-banner p { margin: 0; font-size: 0.9rem; max-width:600px; }
.cookie-banner .btn { padding: 6px 14px; font-size: 0.9rem; }

/* Theme toggle */
:root.light{--bg:#f6fbf9;--bg-soft:#f6fbf9;--surface:#ffffff;--text:#09241b;--muted:#2c4e40;--accent:#0e8f66}
body.light{background:var(--bg-soft);color:var(--text)}
.toggles{display:flex;gap:10px;align-items:center}
.chip{background:#0b2f24;border:1px solid rgba(255,255,255,.18);color:#f0f7f4;border-radius:999px;padding:6px 10px;cursor:pointer}
.light .chip{background:#ffffff;color:#09241b;border-color:#cfd8d5}

/* Timeline styling */
.steps .cards{position:relative}

.steps .card{position:relative}



/* Testimonials */
.testimonials-cards .card{min-height:140px}
.quote{font-style:italic}
.author{opacity:.8;margin-top:6px}

/* Partners */
.partners{background:#0b2f24;padding:56px 0}
.partners-logos{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.partner{background:#0b3126;border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:18px;text-align:center}

/* FAQ */
.faq details{background:#0b3126;border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:12px;margin:10px 0}
.faq summary{cursor:pointer;font-weight:700}

/* Floating WhatsApp */
.fab-whatsapp{position:fixed;right:18px;bottom:18px;background:#25d366;color:#081b13;padding:12px 14px;border-radius:999px;text-decoration:none;font-weight:800;box-shadow:var(--shadow);z-index:9999}

/* Modal (lead capture) */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.45);display:none;align-items:center;justify-content:center;z-index:9998}
.modal.open{display:flex}
.modal-card{background:var(--surface);color:var(--text);border-radius:14px;padding:22px;width:min(420px,92%);box-shadow:var(--shadow)}
.modal-card .mini-form{display:grid;gap:10px;margin-top:10px}
.modal-close{position:absolute;top:10px;right:12px;background:none;border:0;color:inherit;font-size:18px;cursor:pointer}

/* Reveal animation */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease, transform .6s ease}
.reveal.in-view{opacity:1;transform:none}

@media (max-width:900px){
  .partners-logos{grid-template-columns:1fr}
}


/* v23: Equal-height cards ("balões") and section spacing */
.cards{align-items:stretch}
.card{display:flex;flex-direction:column;min-height:180px}
.card h3{margin-top:0}
.card p:last-child{margin-bottom:0}
section{padding-bottom:72px}
.testimonials{padding-top:56px}
.faq{padding-top:40px}

/* v24: FAB placement and spacing */
.fab-whatsapp{ right:18px; bottom:22px; }
body.with-cookies .fab-whatsapp{ bottom:92px; } /* lifts above cookie banner */
@media (max-width: 600px){
  .fab-whatsapp{ right:14px; bottom:18px; }
  body.with-cookies .fab-whatsapp{ bottom:88px; }
}
/* ensure testimonials/faq cards consistent spacing */
.testimonials, .faq{ padding-bottom: 84px; }


/* ===== v30 Mobile Fixes ===== */

/* Prevent horizontal scroll and ensure media scales */
html, body { overflow-x: hidden; }
img, svg, video, canvas { max-width: 100%; height: auto; display: block; }

/* Header: allow wrapping and spacing on small screens */
.site-header .container { flex-wrap: wrap; gap: 10px; }
.toggles { display: flex; gap: 8px; align-items: center; }
@media (max-width: 700px){
  .toggles { margin-left: auto; }
  .brand span { font-size: 1rem; }
}

/* Hero: spacing so content não fique colado ao header no mobile */
@media (max-width: 700px){
  .hero { padding-top: 110px; padding-bottom: 60px; }
}

/* Cards/“balões”: uma coluna no mobile e alturas consistentes */
@media (max-width: 900px){
  .cards { grid-template-columns: 1fr; }
}
.card { display: flex; flex-direction: column; }
.card .icon { width: 34px; height: 34px; margin-bottom: 8px; }

/* Badges e CTA: permitir quebra em mobile e centralização */
.badges { flex-wrap: wrap; row-gap: 6px; }
.cta-group { flex-wrap: wrap; justify-content: center; }

/* Formulário: 1 coluna no mobile e labels legíveis */
@media (max-width: 900px){
  .grid-form { grid-template-columns: 1fr; }
}
label { gap: 6px; }
.form-actions { justify-content: flex-start; }

/* Cookie banner: evitar sobreposição e centralização */
.cookie-banner { text-align: center; }
body.with-cookies .fab-whatsapp { bottom: 96px; }

/* Modal: garantir largura correcta em mobile */
.modal-card { width: min(460px, 92%); }


/* v42: Calculator page tweaks */
.calc-result.highlight{margin-top:14px;padding:14px 16px;border:1px solid rgba(255,255,255,.12);border-radius:12px;font-size:1.1rem;font-weight:800;background:rgba(255,255,255,.04)}
.calc .calc-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;align-items:end}
@media(max-width:900px){ .calc .calc-grid{grid-template-columns:1fr} }


/* v45: Fancy retention popup */
.pop-fancy{
  background: radial-gradient(120% 120% at 20% 0%, rgba(255,255,255,.06), rgba(255,255,255,.02) 60%) var(--surface);
  border:1px solid rgba(255,255,255,.12);
}
.pop-badge{
  font-size:44px; width:64px; height:64px; border-radius:16px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.08); margin:2px auto 10px auto;
}
.pop-benefits{display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:8px; margin:4px 0 10px 0; padding:0; list-style:none; text-align:center; font-size:.95rem}
@media(max-width:640px){ .pop-benefits{grid-template-columns:1fr; text-align:left} }
.modal-close{position:absolute; top:10px; right:10px; background:rgba(0,0,0,.08); border:0; border-radius:10px; width:32px; height:32px; line-height:32px; text-align:center; cursor:pointer; font-size:18px}
.modal-card.pop-elevated.pop-fancy{padding-top:32px}

/* v45: CTA row for hero buttons */
.cta-row{display:flex; gap:12px; flex-wrap:wrap; align-items:center; margin-top:10px}
@media(max-width:560px){ .cta-row{flex-direction:column; align-items:stretch} .cta-row .btn{width:100%; justify-content:center} }

/* v46: popup brand accents */
.pop-fancy{background:
  radial-gradient(130% 120% at 10% -10%, rgba(33,194,122,.18), transparent 40%),
  radial-gradient(120% 120% at 110% 20%, rgba(26,160,102,.16), transparent 50%),
  var(--surface);
  border:1px solid rgba(255,255,255,.12);
}
.pop-badge{background:linear-gradient(135deg, rgba(33,194,122,.25), rgba(26,160,102,.18)); box-shadow:0 6px 18px rgba(33,194,122,.18)}
.btn.btn-full{background:var(--brand-accent);border:none}
.btn.btn-full:hover{filter:brightness(.95)}


/* v48: CTA row ensured */
.cta-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-top:10px}
@media (max-width:560px){.cta-row{flex-direction:row}.cta-row .btn{flex:1 1 auto}}

/* v48: Calculator layout */
.calc .calc-extras{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:8px}
@media(max-width:900px){.calc .calc-extras{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.calc .calc-extras{grid-template-columns:1fr}}
.calc .calc-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-top:10px}
.calc .calc-actions .btn{min-width:160px}
.calc-result.highlight{margin-top:14px}

/* v48: Pretty checkboxes */
.chk{display:flex;align-items:center;gap:8px;font-weight:600}
.chk input[type="checkbox"]{appearance:none;width:22px;height:22px;border-radius:6px;border:2px solid rgba(255,255,255,.5);display:inline-block;position:relative;background:transparent}
.chk input[type="checkbox"]:checked{background:var(--brand-accent);border-color:var(--brand-accent)}
.chk input[type="checkbox"]::after{content:'';position:absolute;inset:0;transform:scale(0.6);background:rgba(0,0,0,.25);border-radius:4px;opacity:0;transition:.12s}
.chk input[type="checkbox"]:checked::after{opacity:1}


/* v49: Calculator layout tidy */
.calc .calc-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:16px;align-items:end}
@media(max-width:1100px){.calc .calc-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:720px){.calc .calc-grid{grid-template-columns:1fr}}

.calc .calc-extras{grid-column:1/-1;display:flex;gap:18px;flex-wrap:wrap;align-items:center;margin-top:6px}
.calc .calc-actions{grid-column:1/-1;display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-top:10px}

.calc .calc-actions .btn{min-width:180px;height:48px;display:inline-flex;align-items:center;justify-content:center;font-weight:700}
@media(max-width:560px){.calc .calc-actions .btn{flex:1 1 auto;min-width:140px}}

/* Checkbox styling & text no-wrap */
.chk{display:inline-flex;align-items:center;gap:8px;font-weight:600;white-space:nowrap}
.chk input[type="checkbox"]{appearance:none;width:20px;height:20px;border-radius:6px;border:2px solid rgba(255,255,255,.55);display:inline-block;position:relative;background:transparent;outline:none}
.chk input[type="checkbox"]:checked{background:var(--brand-accent);border-color:var(--brand-accent)}
.chk input[type="checkbox"]::after{content:'';position:absolute;inset:0;transform:scale(.55);background:rgba(0,0,0,.25);border-radius:4px;opacity:0;transition:.12s}
.chk input[type="checkbox"]:checked::after{opacity:1}


/* v49: enforce CTA row */
.cta-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-top:10px}
@media(max-width:560px){.cta-row{flex-direction:row}.cta-row .btn{flex:1 1 auto}}


/* v50: Calculator controls row */
.calc .calc-controls{display:flex;gap:24px;align-items:flex-start;flex-wrap:wrap;margin-top:10px}
.calc .calc-extras{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.calc .calc-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.calc .calc-actions .btn{min-width:180px;height:48px;display:inline-flex;align-items:center;justify-content:center;font-weight:700}
@media(max-width:800px){.calc .calc-controls{flex-direction:column;align-items:flex-start} .calc .calc-actions .btn{min-width:160px}}
/* Checkbox tidy */
.chk{display:inline-flex;align-items:center;gap:8px;font-weight:600;white-space:nowrap}
.chk input[type="checkbox"]{appearance:none;width:22px;height:22px;border-radius:6px;border:2px solid rgba(255,255,255,.55);display:inline-block;position:relative;background:transparent;outline:none}
.chk input[type="checkbox"]:checked{background:var(--brand-accent);border-color:var(--brand-accent)}
.chk input[type="checkbox"]::after{content:'';position:absolute;inset:0;transform:scale(.55);background:rgba(0,0,0,.25);border-radius:4px;opacity:0;transition:.12s}
.chk input[type="checkbox"]:checked::after{opacity:1}


/* v51: Hero CTA row fix */
.hero .cta-row{display:flex;gap:14px;justify-content:center;align-items:center;flex-wrap:wrap;margin-top:14px}
.hero .cta-row .btn{display:inline-flex;min-width:220px;height:48px;align-items:center;justify-content:center}
@media(max-width:560px){ .hero .cta-row{justify-content:center} .hero .cta-row .btn{min-width:180px} }


/* v51: Calculator desktop layout */
.calc .calc-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:16px;align-items:end}
@media(max-width:1100px){.calc .calc-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:720px){.calc .calc-grid{grid-template-columns:1fr}}

.calc .calc-controls{display:flex;justify-content:space-between;gap:24px;align-items:center;flex-wrap:wrap;margin-top:12px}
.calc .calc-extras{display:flex;gap:18px;flex-wrap:wrap;align-items:center}
.calc .calc-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.calc .calc-actions .btn{min-width:180px;height:48px;display:inline-flex;align-items:center;justify-content:center;font-weight:700}

.chk{display:inline-flex;align-items:center;gap:8px;font-weight:600;white-space:nowrap}
.chk input[type="checkbox"]{appearance:none;width:22px;height:22px;border-radius:6px;border:2px solid rgba(255,255,255,.55);display:inline-block;position:relative;background:transparent;outline:none}
.chk input[type="checkbox"]:checked{background:var(--brand-accent);border-color:var(--brand-accent)}
.chk input[type="checkbox"]::after{content:'';position:absolute;inset:0;transform:scale(.55);background:rgba(0,0,0,.25);border-radius:4px;opacity:0;transition:.12s}
.chk input[type="checkbox"]:checked::after{opacity:1}

@media(max-width:900px){
  .calc .calc-controls{flex-direction:column;align-items:flex-start}
  .calc .calc-actions .btn{min-width:160px}
}


/* v52: Calculator controls grid for desktop */
.calc .calc-controls{display:grid;grid-template-columns:1fr auto;align-items:center;gap:24px;margin-top:12px}
.calc .calc-extras{display:flex;gap:18px;flex-wrap:wrap;align-items:center}
.calc .calc-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center;justify-content:flex-end}
.calc .calc-actions .btn{min-width:180px;height:48px;display:inline-flex;align-items:center;justify-content:center;font-weight:700}
@media(max-width:900px){.calc .calc-controls{grid-template-columns:1fr}.calc .calc-actions{justify-content:flex-start}.calc .calc-actions .btn{min-width:160px}}

/* v52: Center hero CTA row */
.hero .cta-row{display:flex;gap:14px;justify-content:center;align-items:center;flex-wrap:wrap;margin-top:14px}
.hero .cta-row .btn{display:inline-flex;min-width:220px;height:48px;align-items:center;justify-content:center}
@media(max-width:560px){ .hero .cta-row .btn{min-width:180px} }


/* v53: Minimal footer bar */
.site-footer.minimal{padding:18px 0;border-top:1px solid rgba(255,255,255,.08);background:transparent}
.footer-bar{display:flex;align-items:center;justify-content:space-between;gap:16px}
.footer-right a{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid rgba(255,255,255,.15);text-decoration:none;opacity:.9}
.footer-right a:hover{opacity:1}
.brand-mark{font-weight:700}

/* v53: Force hero CTAs center */
.hero .cta-row{display:flex!important;gap:14px;justify-content:center!important;align-items:center;flex-wrap:wrap;margin-top:14px}
.hero .cta-row .btn{display:inline-flex;min-width:220px;height:48px;align-items:center;justify-content:center}
@media(max-width:560px){ .hero .cta-row .btn{min-width:180px} }

/* v53: Popup mini badges row */
.pop-minis{display:flex;gap:12px;flex-wrap:wrap;align-items:center;justify-content:center;margin:8px 0 6px 0;opacity:.95}
.pop-minis .mini{display:inline-flex;gap:6px;align-items:center;font-size:.9rem;white-space:nowrap}


/* v54: Footer only icons left */
.site-footer.minimal{padding:18px 0;border-top:1px solid rgba(255,255,255,.08);background:transparent}
.footer-bar{display:flex;justify-content:flex-start;gap:14px}
.footer-left a{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;border:1px solid rgba(255,255,255,.15);color:#fff;text-decoration:none;opacity:.85;transition:opacity .2s}
.footer-left a:hover{opacity:1}


/* v55: Footer with brand left, icons right */
.site-footer.minimal{padding:18px 0;border-top:1px solid rgba(255,255,255,.08);background:transparent}
.footer-bar{display:flex;justify-content:space-between;align-items:center}
.brand-mark{font-weight:700}
.footer-right{display:flex;gap:14px}
.footer-right a{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;border:1px solid rgba(255,255,255,.15);color:#fff;text-decoration:none;opacity:.85;transition:opacity .2s}
.footer-right a:hover{opacity:1}


/* v56: Footer right-aligned brand + icons */
.site-footer.minimal{padding:18px 0;border-top:1px solid rgba(255,255,255,.08);background:transparent}
.footer-bar{display:flex;justify-content:flex-end;align-items:center}
.footer-right{display:flex;gap:16px;align-items:center}
.brand-mark{font-weight:700}
.footer-right a{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;border:1px solid rgba(255,255,255,.15);color:#fff;text-decoration:none;opacity:.85;transition:opacity .2s}
.footer-right a:hover{opacity:1}


/* v57: Ensure hero CTAs are centered on all breakpoints */
.hero .cta-row{display:flex;gap:14px;justify-content:center;align-items:center;flex-wrap:wrap;margin-top:14px}
.hero .cta-row .btn{display:inline-flex;min-width:200px;height:48px;align-items:center;justify-content:center}
@media(max-width:480px){
  .hero .cta-row{flex-direction:column}
  .hero .cta-row .btn{width:100%;max-width:320px}
}


/* v59: Force footer right alignment */
.site-footer.minimal{padding:18px 0;border-top:1px solid rgba(255,255,255,.08);background:transparent}
.site-footer.minimal .footer-bar{display:flex;justify-content:flex-end !important;align-items:center}
.site-footer.minimal .footer-right{display:flex;gap:16px;align-items:center}
.site-footer.minimal .brand-mark{font-weight:700}
.site-footer.minimal .footer-right a{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;border:1px solid rgba(255,255,255,.15);color:#fff;text-decoration:none;opacity:.85;transition:opacity .2s}
.site-footer.minimal .footer-right a:hover{opacity:1}


/* v60: Footer brand left, icons right + layout fix */
.site-footer.minimal{padding:18px 0;border-top:1px solid rgba(255,255,255,.08);background:transparent;margin-top:auto}
.footer-bar{display:flex;justify-content:space-between;align-items:center;gap:16px}
.footer-left{font-weight:700}
.footer-right{display:flex;gap:16px;align-items:center}
.footer-right a{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;border:1px solid rgba(255,255,255,.15);color:#fff;text-decoration:none;opacity:.85;transition:opacity .2s}
.footer-right a:hover{opacity:1}

/* Push footer to bottom without big gaps */
html,body{height:100%}
body{display:flex;flex-direction:column}
main{flex:1 0 auto}


/* v61: Footer icon placement fixes */
.container{padding-left:16px; padding-right:16px}
.site-footer.minimal{padding:16px 0; border-top:1px solid rgba(255,255,255,.08); margin-top:auto}
.footer-bar{display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:nowrap}
.footer-left{font-weight:700; display:flex; align-items:center}
.footer-right{display:flex; align-items:center; gap:12px; flex-wrap:nowrap; line-height:0}
.footer-right a{display:inline-flex; align-items:center; justify-content:center; width:36px; height:36px; line-height:0;
  border-radius:10px; border:1px solid rgba(255,255,255,.15); color:#fff; text-decoration:none; opacity:.9; transition:transform .12s, opacity .12s}
.footer-right a:hover{opacity:1; transform:translateY(-1px)}
.footer-right svg{display:block}
@media(max-width:420px){
  .footer-bar{gap:10px}
  .footer-right a{width:32px; height:32px}
}


/* v62: Footer compacto, alinhado à esquerda */
.site-footer.minimal{padding:10px 0;border-top:1px solid rgba(255,255,255,.08);background:transparent;margin-top:auto}
.footer-bar{display:flex;justify-content:flex-start;align-items:center}
.footer-left{display:flex;align-items:center;gap:12px}
.brand-mark{font-weight:700}
.footer-left a{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;border:1px solid rgba(255,255,255,.15);color:#fff;text-decoration:none;opacity:.9;transition:opacity .15s}
.footer-left a:hover{opacity:1}
/* Garantir que não sobra espaço verde no fundo */
html,body{height:100%}
body{display:flex;flex-direction:column}
main{flex:1 0 auto}
