/* Metta Gestão Financeira — Improved CSS */

.yeseva-one-regular {
  font-family: "Yeseva One", serif;
  font-weight: 400;
  font-style: normal;
}


*,*::before,*::after{box-sizing:border-box }
:root{
  --bg:#ffffff;
  --fg:#111111;
  --muted:#666666;
  --muted-2:#8a8a8a;
  --border:#e5e5e5;
  --card:#fafafa;
  --gray:#f3f3f3;
  --primary:#111111;
  --primary-fg:#ffffff;
  --branco: #f5f4f0;
  --cinza-100: #e8e7e3;
  --cinza-300: #c2c1bc;
  --cinza-500: #888783;
  --cinza-700: #3d3d3a;
  --fonte-titulo: 'DM Serif Display','Yeseva', Georgia, serif;
  --fonte-corpo: 'DM Sans', sans-serif;
  --radius:14px;
  --shadow-card:0 4px 24px -6px rgba(0,0,0,.12);
  --shadow-elegant:0 20px 50px -20px rgba(0,0,0,.35);
  --grad-hero:linear-gradient(135deg,#0a0a0a 0%,#2a2a2a 100%);
  --grad-dark:linear-gradient(180deg,#1a1a1a 0%,#000 100%);
}
html,body{margin:0;padding:0;font-size: 1rem;}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;color:var(--fg);background:var(--bg);line-height:1.5;-webkit-font-smoothing:antialiased; font-size: 1rem;}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:"Yeseva";margin:0;font-weight:700;letter-spacing:-0.02em;line-height:1.15}
p{margin:0}
ul{margin:0;padding:0;list-style:none}

.container{max-width:1200px;margin:0 auto;padding:0 24px}
.container.narrow{max-width:820px}
.center{text-align:center}
.muted{color:var(--muted)}
.rounded{border-radius:var(--radius)}
.label{font-size:1.1rem;font-weight:800;text-transform:uppercase;letter-spacing:.15em;color:var(--muted)}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:999px;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;transition:transform .2s,box-shadow .2s;cursor:pointer;border:0}
.btn:hover{transform:scale(1.03);box-shadow:0 8px 30px -8px rgba(0,0,0,.45)}
.btn-primary{background:var(--primary);color:var(--primary-fg)}
.btn-white{background:#fff;color:var(--primary)}S
.btn-sm{padding:10px 18px;font-size:11px}
.ic{ width: 24px; height: 24px; }

/* Nav */
.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 24px}
.brand{display:flex;align-items:center;gap:10px}
.brand-logo{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;background:var(--primary);color:#fff;font-weight:800}
.brand-logo.light{background:#fff;color:var(--primary)}
.brand-text strong{display:block;font-size:13px;letter-spacing:.15em,.yeseva-one-regular {
  font-family: "Yeseva One", serif;font-weight: 400;font-style: normal;}
}.wa-float
.brand-text small{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.2em;color:var(--muted)}
.brand-light .brand-text small{color:rgba(255,255,255,.6)}
.nav-links{display:none;gap:32px;font-size:14px;fonts-weight:500}
.nav-links a:hover{color:var(--muted)}
/* Mobile nav toggle */
.nav-toggle{display:flex;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--fg);border-radius:2px;transition:transform .3s,opacity .3s}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{display:none;flex-direction:column;gap:0;background:#fff;border-bottom:1px solid var(--border)}
.mobile-menu.open{display:flex}
.mobile-menu a{padding:14px 24px;font-size:15px;font-weight:500;border-bottom:1px solid var(--border)}
.mobile-menu-cta{padding:16px 24px}
@media(min-width:768px){
  .nav-links{display:flex}
  .nav-toggle{display:none}
  .mobile-menu{display:none !important}
}

/* ============================
   HERO — altura padrão 760px
   ============================ */
.hero{
  position:relative;
  overflow:hidden;
  color:#fff;
  height: 100vh;          
  min-height: 90vh;
  height:auto;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
}
.hero-bg      { z-index: 1; }
.hero-overlay { z-index: 2; }
.hero-grid    { position: relative; z-index: 3; } 
.hero-bg{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center top;
  opacity:.15; 
  z-index: 1;               /* bem mais visível */
  transform:scale(1.04);
  animation:hero-bg-drift 22s ease-in-out infinite alternate;
}
@keyframes hero-bg-drift{
  0%{transform:scale(1.04) translateX(0)}
  100%{transform:scale(1.10) translateX(-16px)}
}
/* overlay mais leve para o fundo aparecer mais */
.hero-overlay{
  position:absolute;
  z-index: 2;
  inset:0;background:linear-gradient(135deg,rgba(8,8,8,.82) 0%,rgba(20,20,20,.70) 100%)
}

.hero-grid{
  position: relative;
  z-index: 3;
  display: grid;
  gap: 48px;
  box-sizing: border-box;
  padding: 120px 28px 80px;     /* ← aumenta padding lateral */
  align-items: center;
  width: 100%;
  height: auto;
  max-width: max-content;    /* ← limita largura máxima */
  margin: 0 auto; 
  grid-template-columns: 1fr;


}

@media (min-width: 768px) {
  .hero-grid {
    grid-template-columns: 1.3fr 1fr;   /* ← texto ocupa mais espaço (era 1.1fr) */
    padding: 80px 64px;
  }
}

@media (min-width: 1024px) {
  .hero-grid {
    grid-template-columns: 1.4fr 1fr;
    padding: 100px 80px 80px;
    max-width: 100%;  
    
    margin: 0 auto;
    align-items: end;
    padding-bottom: 80px;   
  }
}

@media (min-width: 1280px) {
  .hero-grid {
    padding: 80px 120px;               /* ← telas grandes: margem ainda maior */
  }
}

/* Mobile */
@media (max-width: 767px) {
  .hero {
    height: auto;
    min-height: 100svh;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;   /* ← era flex-end, texto sumia */
    overflow-y: visible;
  }
  
  .hero-grid {
    grid-template-columns: 1fr;
    align-items: start;            /* ← era end/center, itens saíam da tela */
    padding: 100px 24px 48px;
    gap: 0;                        /* cada seção controla seu próprio espaço */
    width: 100%;
    max-width: 100%;
    height: auto;
  }
    /* 3. Texto: fluxo normal */
  .hero-text {
    order: 1;
    padding-bottom: 32px;
  }

  /* 4. Visual (coluna da imagem): tamanho natural, sem forçar flex-end */
  .hero-visual {
    order: 2;
    height: auto;
    justify-content: center;
    align-items: center;           /* ← era flex-end, cortava imagem */
    padding-bottom: 24px;
    overflow: visible;
  }

  .hero-image-col {
    height: auto;
    align-items: center;           /* ← era flex-end */
    justify-content: center;
  }

  /* 5. Imagem: contida, sem vazar pelo topo */
  .hero-img {
    max-width: 100%;
    width: auto;
    height: auto;
    max-height: 55vh;              /* ← era 110%, vazava para fora */
    margin-top: 0;
    object-position: center center;
  }

  /* 6. Cards flutuantes: saem do absolute, entram no fluxo */
  .hero-anims {
    order: 3;
    position: relative;            /* ← era absolute, ficava sobreposto */
    right: auto;
    bottom: auto;
    width: 100%;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: center;
    padding-bottom: 40px;
  }

  .anim-card {
    max-width: calc(50% - 6px);   /* dois cards lado a lado no mobile */
    flex: 1 1 140px;
  }
}
/* ============================================================
   EXTRA — max-width: 480px (telas bem pequenas)
   ============================================================ */

@media (max-width: 480px) {

  .hero-grid {
    padding: 88px 20px 40px;
  }

  .hero-text h1 {
    font-size: clamp(1.75rem, 8vw, 2.25rem);
  }

  .hero-img {
    max-height: 45vh;
  }

  .anim-card {
    max-width: 100%;               /* cards em coluna única nas telas menores */
    flex: 1 1 100%;
  }
}

.chip{
  display:inline-block;
  border:1px solid rgba(255,255,255,.3);
  border-radius:999px;
  padding:6px 16px;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.2em;
  animation:fade-up .7s ease both;
}
.hero-text h1{
  position: relative;
  margin-top:10px;
  margin-left:0px ;
  
  font-size:clamp(2rem, 4vw, 56px);
  line-height:1.08;
  animation:fade-up .7s .15s ease both;
}
.hero-text .accent{color:rgba(255,255,255,.7)}
.hero-text p{
  margin-top:16px;
  max-width:520px;
  font-size:15px;
  color:rgba(255,255,255,.8);
  line-height:1.65;
  animation:fade-up .7s .3s ease both;
}
.hero-cta{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:14px;
  margin-top:24px;
  animation:fade-up .7s .45s ease both;
}
.link-arrow{font-size:14px;color:rgba(255,255,255,.8);text-decoration:underline;text-underline-offset:4px}
.hero-stats{
  display:flex;
  flex-wrap:wrap;
  gap:24px;
  border-top:1px solid rgba(255,255,255,.15);
  padding-top:20px;
  margin-top:24px;
  font-size:13px;
  color:rgba(255,255,255,.7);
  animation:fade-up .7s .6s ease both;
}
.hero-stats strong{display:block;font-size:22px;color:#fff;font-weight:800}

@keyframes fade-up{
  from{opacity:0;transform:translateY(24px)}
  to{opacity:1;transform:translateY(0)}
}

/* ============================
   HERO VISUAL — bigger image
   ============================ */
.hero-visual {
    height: 100%;               /* ocupa toda a altura da coluna */
    display: flex;
    flex-direction: column;
    justify-content: flex-end;  /* empurra para baixo */
    align-items: center;
  }
@media(min-width:768px){
  .hero-visual{
    grid-template-columns:1fr auto;
    height:100%;
    align-items:flex-end;
    overflow:visible;
  }
}

.hero-image-col{
    height: 100%;
    display: flex;
    align-items: flex-end;      /* gruda na base */
    justify-content: center;
}
.hero{overflow:hidden}
.hero-glow{
  position:absolute;
  left:50%;
  bottom:10%;
  width:500px;
  height:500px;
  transform:translateX(-50%);
  border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.25),transparent 65%);
  filter:blur(50px);
  animation:pulse-glow 4s ease-in-out infinite alternate;
}
@keyframes pulse-glow{
  0%{opacity:.3;transform:translateX(-50%) scale(1)}
  100%{opacity:.55;transform:translateX(-50%) scale(1.12)}
}

/* ---- HERO IMAGE — maior e saindo pelo topo ---- */
.hero-img{
    display: block;
    margin: 0 auto;
    align-self: flex-end;       /* gruda na base */
    object-fit: contain;
    object-position: bottom center;
    max-height: 90vh;           /* nunca ultrapassa a tela */
    width: auto;
    margin-top: 0;
    margin-bottom: 0;    
}
@media(min-width:480px){.hero-img{max-width:460px}}
@media(min-width:768px){
  .hero-img{
    max-width:none;
    height:110%;          /* ultrapassa levemente o hero para subir */
    width:auto;
    max-height:820px;
    object-fit:contain;
    object-position:bottom center;
    margin-top:-60px;     /* puxa a imagem para cima */
  }
}
@media (min-width: 1024px) {
  .hero-grid {
    grid-template-columns: 1.4fr 1fr;
    width: 100%;
    max-width: 100%;
    margin: 0;
    padding: 0px 80px 0px;
    align-items: end;           /* ancora tudo na base */
  }

}

/* Animation cards column */
.hero-anims{
  position:relative;
  display:flex;
  flex-direction:column;
  gap:16px;
  color:#fff;
  z-index:20;
}
@media(min-width:768px){
  .hero-anims{
    position:absolute;
    right:-12px;
    bottom:200px;
    width:220px;
  }
}
@media(min-width:1024px){
  .hero-anims{
    right:0;
    width:240px;
    bottom:240px;
  }
}

/* Anim cards — improved */
.anim-card{
  width:100%;
  max-width:220px;
  border-radius:20px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(15,15,20,.75);
  padding:14px 16px;
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  box-shadow:0 8px 32px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.12);
  color:#fff;
  transition:border-color .3s;
}
.anim-card:hover{border-color:rgba(255,255,255,.35)}
.anim-card-head{
  display:flex;
  justify-content:space-between;
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:rgba(255,255,255,.55);
  font-weight:600;
}
.anim-value{margin-top:6px;font-size:22px;font-weight:800;letter-spacing:-.02em}
.bars{
  display:flex;
  align-items:flex-end;
  gap:5px;
  height:44px;
  margin-top:10px;
}
.bars span{
  flex:1;
  background:linear-gradient(180deg,rgba(255,255,255,.9),rgba(255,255,255,.4));
  border-radius:3px 3px 2px 2px;
  height:var(--h);
  transform-origin:bottom;
  animation:bar-grow 2.8s cubic-bezier(.34,1.56,.64,1) infinite;
  animation-delay:var(--d);
}

/* Badge circle */
.anim-row{display:flex;align-items:center;gap:12px}
.badge-circle{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  width:88px;
  height:88px;
  flex-shrink:0;
  border-radius:50%;
  border:1.5px solid rgba(255,255,255,.25);
  background:rgba(15,15,20,.75);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  box-shadow:0 8px 32px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.1);
  text-align:center;
  transition:border-color .3s, transform .3s;
}
.badge-circle:hover{border-color:rgba(255,255,255,.5);transform:scale(1.05) !important}
.badge-circle strong{font-size:24px;font-weight:800;line-height:1}
.badge-circle small{font-size:9px;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.6);margin-top:2px}

.anim-icons{display:flex;flex-direction:column;gap:10px}
.anim-icons svg{width:28px;height:28px;color:rgba(255,255,255,.75);filter:drop-shadow(0 2px 6px rgba(255,255,255,.15))}

/* Type animation lines */
.type-lines{display:flex;flex-direction:column;gap:7px;margin-top:10px}
.type-lines>div{
  height:7px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  overflow:hidden;
}
.type-line{
  display:block;
  height:100%;
  background:linear-gradient(90deg,rgba(255,255,255,.5),rgba(255,255,255,.9));
  border-radius:999px;
  width:0;
  animation:type-line 2.6s cubic-bezier(.4,0,.2,1) infinite;
}
.anim-foot{
  margin-top:10px;
  font-size:10px;
  color:rgba(255,255,255,.7);
  font-weight:500;
}

/* ============================
   Improved animations
   ============================ */
@keyframes float-person{
  0%,100%{transform:translateY(0) rotate(0deg)}
  30%{transform:translateY(-14px) rotate(.4deg)}
  70%{transform:translateY(-8px) rotate(-.3deg)}
}
@keyframes float-slow{
  0%,100%{transform:translateY(0) rotate(0)}
  40%{transform:translateY(-18px) rotate(-1.5deg)}
  80%{transform:translateY(-10px) rotate(1deg)}
}
@keyframes float-mid{
  0%,100%{transform:translateY(0) rotate(0)}
  50%{transform:translateY(-14px) rotate(2deg)}
}
@keyframes float-fast{
  0%,100%{transform:translateY(0) scale(1)}
  50%{transform:translateY(-10px) scale(1.02)}
}
@keyframes bar-grow{
  0%{transform:scaleY(.15);opacity:.6}
  60%{transform:scaleY(1.08);opacity:1}
  80%{transform:scaleY(.95)}
  100%{transform:scaleY(1);opacity:1}
}
@keyframes type-line{
  0%{width:0;opacity:.6}
  70%{width:100%;opacity:1}
  90%{width:100%;opacity:.8}
  100%{width:0;opacity:.6}
}
.float-person{animation:float-person 6s ease-in-out infinite}
.float-slow{animation:float-slow 7s ease-in-out infinite}
.float-mid{animation:float-mid 5s ease-in-out infinite}
.float-fast{animation:float-fast 4s ease-in-out infinite}

/* Stats strip */
.stats{background:var(--primary);color:#fff;border-bottom:1px solid var(--border)}
.stats-grid{
  display:grid;
  gap:0;
  padding:0;
  text-align:center;
  grid-template-columns:repeat(2,1fr);
}
@media(min-width:768px){.stats-grid{grid-template-columns:repeat(4,1fr)}}
.stats-grid>div{
  padding:40px 24px;
  border-right:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
  transition:background .25s;
}
.stats-grid>div:hover{background:rgba(255,255,255,.04)}
@media(min-width:768px){.stats-grid>div{border-bottom:none}}
.stats-grid strong{display:block;font-size:32px;font-weight:800;letter-spacing:-.03em}
@media(min-width:768px){.stats-grid strong{font-size:38px}}
.stats-grid span{display:block;margin-top:4px;font-size:11px;text-transform:uppercase;letter-spacing:.2em;color:rgba(255,255,255,.6)}

/* Sections */
.section{padding:88px 0}
.section-gray{background:var(--gray)}
.section-head{max-width:640px;margin:0 auto;text-align:center}
.section-head h2{margin-top:12px;font-size:1rem}
@media(min-width:768px){.section-head h2{font-size:3rem}}
.section-head p{margin-top:16px;color:var(--muted)}
.two-col{display:grid;gap:48px;align-items:center}
@media(min-width:768px){.two-col{grid-template-columns:1fr 1fr}}
.two-col h2{margin-top:12px;font-size:28px}
@media(min-width:768px){.two-col h2{font-size:36px}}
.two-col img{
  border-radius:var(--radius);
  width:100%;
  height:auto;
  object-fit:cover;
  aspect-ratio:4/3;
}

.check-list{margin-top:32px;display:flex;flex-direction:column;gap:14px}
.check-list li{display:flex;gap:12px;font-size:15px;line-height:1.5}
.check-list i{
  display:flex;
  align-items:center;
  justify-content:center;
  width:24px;
  height:24px;
  flex-shrink:0;
  border-radius:50%;
  background:var(--primary);
  color:#fff;
  font-style:normal;
  font-size:11px;
  margin-top:1px;
}
.section .btn{margin-top:32px}

/* Grids */
.grid-3,.grid-4{display:grid;gap:20px;margin-top:56px}
.grid-3{grid-template-columns:1fr}
.grid-4{grid-template-columns:1fr}
@media(min-width:480px){.grid-3{grid-template-columns:repeat(2,1fr)}}
@media(min-width:640px){.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}}

/* Card */
.card{
  background:radial-gradient(circle,rgba(149, 139, 139, 0.337),rgba(248, 245, 245, 0.611));
  color: #1a1a1a;
  border:2px solid var(--border);
  border-radius:16px;
  padding:28px;
  transition:border-color .15s,transform .15s,box-shadow .15s;
}
.card:hover{
  border-color:var(--primary);
  transform:translateY(-3px);
  box-shadow:var(--shadow-card);
}
.card.center{text-align:center}
.card h3{margin-top:18px;font-size:17px}
.card p{margin-top:8px;font-size:14px;color:var(--muted);line-height:1.6}



.ic-box{
  display:flex;
  align-items:center;
  justify-content:center;
  width:80px;
  height:80px;
  border-radius:14px;
  background:#aaa;
  border:1px solid var(--border);
  font-size:50px;
  transition:transform .1s;
}
.card:hover .ic-box{transform:scale(1.1)}
.ic-box.dark{background:var(--muted-2);color:#fff;border-color:var(--primary)}
.ic-box.big{width:56px;height:56px;margin:0 auto}
.values-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* Service cards */
.service-card{
  background:#fff;
  border-radius:16px;
  overflow:hidden;
  box-shadow:var(--shadow-card);
  border:1px solid var(--border);
  transition:transform .15s cubic-bezier(.34,1.2,.64,1),box-shadow .15s;
}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-elegant)}
.img-wrap{aspect-ratio:4/3;overflow:hidden}
.img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.25,.46,.45,.94)}
.service-card:hover .img-wrap img{transform:scale(1.08)}
.pad{padding:28px}
.pad h3{font-size:20px}
.pad p{margin-top:8px;font-size:14px;color:var(--muted);line-height:1.6}

/* Testimonials */
.quote{font-size:52px;line-height:1;color:var(--primary);font-family:Georgia,serif;opacity:.6}
blockquote{margin:8px 0 0;font-size:14px;line-height:1.7;color:var(--fg)}
.stars{margin-top:16px;color:var(--primary);font-size:15px;letter-spacing:3px}
figcaption{margin-top:14px;font-size:14px}
figcaption strong{display:block;font-weight:700}
figcaption span{display:block;color:var(--muted);font-size:13px;margin-top:2px}

/* FAQ */
.faq{margin-top:48px;display:flex;flex-direction:column;gap:12px}
.faq details{
  background:#fff;
  border:4px solid var(--border);
  border-radius:16px;
  padding:20px 24px;
  transition:border-color .2s,box-shadow .2s;
}
.faq details:hover{border-color:#aaa}
.faq details[open]{border-color:var(--primary);box-shadow:var(--shadow-card)}
.faq summary{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  list-style:none;
  cursor:pointer;
  font-weight:600;
  font-size:1.3rem;
  line-height:1.5;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary i{
  color:var(--primary);
  font-style:normal;
  font-size:35px;
  transition:transform .15s cubic-bezier(.34,1.56,.64,1);
  flex-shrink:0;
}
.faq details[open] summary i{transform:rotate(45deg)}
.faq p{margin-top:14px;font-size:1.1rem;color:var(--muted);line-height:1.7}

/* CTA */
.cta{position:relative;color:#fff;padding:100px 0;background:var(--grad-dark)}
.cta h2{font-size:30px;line-height:1.1}
@media(min-width:768px){.cta h2{font-size:50px}}
.cta p{margin:20px auto 0;max-width:640px;color:rgba(255,255,255,.75);font-size:16px}
.cta .btn{margin-top:36px}

/* Notice */
.notice-section{padding:56px 0;background-color: var(--fg);}
.notice-section h3{font-size:2rem; color: red;}
.notice-section p{margin-top:12px;font-size:1.2rem;line-height:1.7; color: rgb(139, 5, 5);}

/* Footer */
.footer{background:var(--primary);color:#fff}
.footer-grid{display:grid;gap:40px;padding:64px 24px;grid-template-columns:1fr}
@media(min-width:768px){.footer-grid{grid-template-columns:2fr 1fr 1fr}}
.footer-brand p{margin-top:20px;max-width:420px;font-size:14px;color:rgba(255,255,255,.65);line-height:1.65}
.footer h4{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.25em;color:rgba(255,255,255,.5)}
.footer ul{margin-top:20px;display:flex;flex-direction:column;gap:12px;font-size:14px;color:rgba(255,255,255,.8)}
.footer>div:not(.footer-bottom)>div>p{margin-top:20px;font-size:14px;color:rgba(255,255,255,.8)}
.footer .btn{margin-top:24px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08)}
.footer-bottom .container{display:flex;flex-direction:column;gap:8px;padding:24px;font-size:12px;color:rgba(255,255,255,.45)}
@media(min-width:768px){.footer-bottom .container{flex-direction:row;justify-content:space-between;align-items:center}}

.footer-dev a:hover{
  color: #fff000;
}

/* WhatsApp float */
.wa-float{
  position:fixed;
  bottom:28px;
  right:28px;
  z-index:100;
  display:flex;
  align-items:center;
  justify-content:center;
  width:60px;
  height:60px;
  border-radius:50%;
  background:#25D366;
  color:#fff;
  box-shadow:0 4px 20px rgba(37,211,102,.45);
  transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .25s;
}
.wa-float:hover{
  transform:scale(1.12);
  box-shadow:0 8px 30px rgba(37,211,102,.6);
}
.wa-float svg{width:26px;height:26px}

/* ============================
   MOBILE RESPONSIVE
   ============================ */
@media(max-width:767px){
  .hero-grid{
    grid-template-columns:1fr;
    padding:80px 20px 60px;
    gap:48px;
  }
  .hero-visual{
    grid-template-columns:1fr;
    min-height:unset;
  }
  .hero-anims{
    flex-direction:row;
    flex-wrap:wrap;
    gap:12px;
    justify-content:center;
  }
  .anim-card{max-width:180px}
  .badge-circle{width:76px;height:76px}
  .hero-stats{
    gap:20px;
  }
  .hero-stats>div{
    min-width:calc(33% - 14px);
  }
  .two-col{grid-template-columns:1fr;gap:32px}
  .section{padding:64px 0}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .values-grid{grid-template-columns:1fr 1fr}
  .grid-3,.grid-4{grid-template-columns:1fr}
  .container{padding:0 16px}
  .section-head h2{font-size:26px}
  .two-col h2{font-size:26px}
  .cta h2{font-size:26px}
  .faq summary{font-size:14px}
}

/* Tablet */
@media(min-width:480px) and (max-width:767px){
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .hero-img{max-width:480px}
}

/* Smooth scroll */
html{scroll-behavior:smooth}

/* Reduce motion */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important}
}


