/* ═══════════════════════════════════════════
   JÁ CALCULEI NET EMPRESAS — style.css
   Tema: Branco profissional + Verde esmeralda
   Fontes: Plus Jakarta Sans + Lora
═══════════════════════════════════════════ */

:root {
  --white:       #ffffff;
  --bg:          #f8faf9;
  --bg2:         #f1f5f2;
  --green:       #0f7a4a;
  --green-mid:   #1a9a60;
  --green-light: #22c979;
  --green-pale:  #e8f5ee;
  --green-glow:  rgba(15,122,74,.1);
  --dark:        #0d1f14;
  --dark2:       #1a2e20;
  --text:        #2d3f35;
  --text2:       #4a6358;
  --muted:       #7a9488;
  --border:      #dce8e1;
  --border2:     rgba(15,122,74,.2);
  --radius:      10px;
  --radius-lg:   18px;
  --radius-xl:   28px;
  --shadow-sm:   0 2px 12px rgba(15,122,74,.08);
  --shadow:      0 8px 32px rgba(15,122,74,.12);
  --shadow-lg:   0 20px 60px rgba(15,122,74,.15);
  --t:           .26s cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Plus Jakarta Sans',sans-serif;
  background:var(--white);color:var(--text);
  font-size:16px;line-height:1.65;overflow-x:hidden;
}
a{text-decoration:none;color:inherit;transition:opacity var(--t)}
img{max-width:100%;display:block}
.container{max-width:1140px;margin:0 auto;padding:0 28px}

/* ── TOPBAR ── */
.topbar{
  background:var(--dark);color:rgba(255,255,255,.65);
  padding:8px 0;font-size:.78rem;
}
.tb-inner{
  max-width:1140px;margin:0 auto;padding:0 28px;
  display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;
}
.tb-inner a{color:rgba(255,255,255,.65);transition:color var(--t)}
.tb-inner a:hover{color:var(--green-light);opacity:1}
.tb-sep{opacity:.3}

/* ── HEADER ── */
.header{
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:900;
  padding:16px 0;
  transition:padding var(--t),box-shadow var(--t);
}
.header.scrolled{padding:10px 0;box-shadow:var(--shadow-sm)}
.hd-wrap{
  max-width:1140px;margin:0 auto;padding:0 28px;
  display:flex;align-items:center;gap:28px;
}

/* Logo */
.logo{display:flex;align-items:center;gap:12px;flex-shrink:0;opacity:1}
.logo-mark{
  width:40px;height:40px;border-radius:10px;
  background:linear-gradient(135deg,var(--green),var(--green-mid));
  color:white;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.logo-mark svg{stroke:white}
.logo-mark-sm{width:34px;height:34px;border-radius:8px}
.logo-name{display:block;font-size:1.05rem;font-weight:800;color:var(--dark);line-height:1.1}
.logo-sub{
  display:block;font-size:.55rem;font-weight:700;
  letter-spacing:.14em;color:var(--green);text-transform:uppercase;margin-top:1px;
}

.nav{display:flex;gap:24px;margin-left:auto}
.nav-a{
  font-size:.88rem;font-weight:500;color:var(--text2);
  transition:color var(--t);position:relative;padding-bottom:2px;
}
.nav-a::after{
  content:'';position:absolute;bottom:0;left:0;right:0;
  height:2px;background:var(--green);transform:scaleX(0);
  transition:transform var(--t);border-radius:1px;
}
.nav-a:hover,.nav-a.active{color:var(--green);opacity:1}
.nav-a:hover::after,.nav-a.active::after{transform:scaleX(1)}

.hd-cta{flex-shrink:0}
.burger{
  display:none;flex-direction:column;gap:5px;
  background:none;border:none;cursor:pointer;padding:4px;margin-left:auto;
}
.burger span{width:22px;height:2px;background:var(--text);border-radius:2px;display:block;transition:var(--t)}
@media(max-width:900px){.nav,.hd-cta{display:none}.burger{display:flex}}

/* ── MOBILE ── */
.mob{
  position:fixed;inset:0;background:white;z-index:850;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0;
  opacity:0;pointer-events:none;transition:opacity .3s;
}
.mob.open{opacity:1;pointer-events:all}
.mob-x{
  position:absolute;top:20px;right:24px;
  background:none;border:none;font-size:1.4rem;cursor:pointer;color:var(--text);
}
.mob nav{display:flex;flex-direction:column;align-items:center;gap:22px}
.mob nav a{font-size:1.4rem;font-weight:600;color:var(--text)}
.mob nav a:hover{color:var(--green);opacity:1}
.mob nav .btn-primary{margin-top:8px}

/* ── BUTTONS ── */
.btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--green);color:white;
  font-weight:700;font-size:.9rem;
  padding:12px 24px;border-radius:100px;
  border:none;cursor:pointer;
  transition:var(--t);
}
.btn-primary:hover{background:var(--green-mid);transform:translateY(-2px);box-shadow:0 8px 24px rgba(15,122,74,.35);opacity:1}
.btn-primary.btn-full{width:100%;justify-content:center}
.btn-primary.btn-lg{padding:15px 32px;font-size:1rem}

.btn-ghost{
  display:inline-flex;align-items:center;gap:6px;
  color:var(--text);font-size:.9rem;font-weight:500;
  padding:12px 22px;border-radius:100px;
  border:1.5px solid var(--border);
  transition:var(--t);
}
.btn-ghost:hover{border-color:var(--green);color:var(--green);opacity:1}
.btn-ghost.btn-lg{padding:15px 30px;font-size:1rem}

/* ── LABELS / HEADINGS ── */
.s-label{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--green);margin-bottom:12px;
}
.s-label::before{content:'';display:block;width:16px;height:2px;background:var(--green);border-radius:1px}
.s-label-light{color:rgba(255,255,255,.85)}
.s-label-light::before{background:rgba(255,255,255,.85)}
.s-h2{
  font-family:'Lora',serif;
  font-size:clamp(1.75rem,3.5vw,2.6rem);
  font-weight:700;line-height:1.2;
  color:var(--dark);margin-bottom:18px;
}
.s-h2 em{font-style:italic;color:var(--green)}
.s-h2-white{color:white}
.s-sub{color:var(--text2);font-size:.95rem;max-width:540px;margin:0 auto;margin-bottom:52px}
.sec-head{text-align:center;margin-bottom:56px}

/* ── HERO ── */
.hero{
  padding:96px 0 80px;position:relative;overflow:hidden;
  background:linear-gradient(160deg,var(--white) 50%,var(--green-pale) 100%);
}
.hero-bg{position:absolute;inset:0;pointer-events:none}
.hero-pattern{
  position:absolute;inset:0;opacity:.4;
  background-image:radial-gradient(circle,var(--border) 1px,transparent 1px);
  background-size:32px 32px;
}
.hero-shape{position:absolute;border-radius:50%;pointer-events:none}
.s1{
  width:500px;height:500px;
  background:radial-gradient(circle,rgba(15,122,74,.06),transparent);
  top:-100px;right:-100px;
}
.s2{
  width:300px;height:300px;
  background:radial-gradient(circle,rgba(34,201,121,.08),transparent);
  bottom:-80px;left:10%;
}

.hero-wrap{
  position:relative;z-index:2;
  max-width:1140px;margin:0 auto;padding:0 28px;
  display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:center;
}
@media(max-width:900px){.hero-wrap{grid-template-columns:1fr}.hero-right{display:none}}

.hero-pill{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.75rem;font-weight:600;letter-spacing:.1em;
  color:var(--green);background:var(--green-pale);
  border:1px solid var(--border2);
  padding:6px 16px;border-radius:100px;margin-bottom:24px;
  animation:fadeUp .5s ease both;
}
.pill-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--green-light);box-shadow:0 0 6px var(--green-light);
  animation:blink 2s ease infinite;flex-shrink:0;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}

.hero-h1{
  font-family:'Lora',serif;
  font-size:clamp(2.2rem,5vw,3.8rem);
  font-weight:700;line-height:1.12;
  color:var(--dark);margin-bottom:22px;
  animation:fadeUp .5s .1s ease both;
}
.hero-h1 em{font-style:italic;color:var(--green)}

.hero-desc{
  font-size:1rem;color:var(--text2);max-width:480px;
  margin-bottom:36px;line-height:1.75;
  animation:fadeUp .5s .2s ease both;
}

.hero-btns{
  display:flex;gap:12px;flex-wrap:wrap;margin-bottom:48px;
  animation:fadeUp .5s .3s ease both;
}

.hero-selos{
  display:flex;align-items:center;gap:0;flex-wrap:wrap;row-gap:14px;
  padding-top:28px;border-top:1.5px solid var(--border);
  animation:fadeUp .5s .4s ease both;
}
.selo{display:flex;flex-direction:column;padding:0 28px 0 0}
.selo:first-child{padding-left:0}
.selo-num{
  font-family:'Lora',serif;font-size:1.8rem;font-weight:700;color:var(--dark);line-height:1;
}
.selo>span:nth-child(2){font-size:1.1rem;color:var(--green);font-weight:700}
.selo-label{font-size:.72rem;color:var(--muted);margin-top:3px}
.selo-div{width:1px;height:38px;background:var(--border);margin-right:28px}

/* Hero cards */
.hero-card-stack{position:relative;height:300px}
.hcs-card{
  position:absolute;background:white;
  border-radius:var(--radius-lg);box-shadow:var(--shadow);
  border:1.5px solid var(--border);padding:22px 20px;
}
.hcs-back{
  width:220px;right:-10px;top:0;
  transform:rotate(4deg);
  background:var(--green-pale);border-color:var(--border2);
}
.hcs-front{width:300px;left:0;top:40px;z-index:2}
.hcs-icon{font-size:1.6rem;margin-bottom:10px}
.hcs-label{font-size:.82rem;font-weight:600;color:var(--text);margin-bottom:10px}
.hcs-bar-wrap{height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin-bottom:6px}
.hcs-bar{height:100%;border-radius:3px}
.hcs-val{font-size:.72rem;color:var(--green);font-weight:700}
.hcs-row{display:flex;gap:0;justify-content:space-around;margin-bottom:14px}
.hcs-stat{text-align:center}
.hcss-val{display:block;font-family:'Lora',serif;font-size:1.4rem;font-weight:700;color:var(--dark);line-height:1}
.hcss-label{display:block;font-size:.68rem;color:var(--muted);margin-top:2px}
.hcs-divider{height:1px;background:var(--border);margin-bottom:14px}
.hcs-icon-row{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;margin-bottom:14px}
.hcs-icon-item{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:.62rem;color:var(--muted)}
.hcs-icon-item span:first-child{font-size:1rem}
.hcs-badge{
  background:var(--green-pale);border:1px solid var(--border2);
  border-radius:6px;padding:6px 10px;font-size:.72rem;font-weight:600;color:var(--green);
  text-align:center;
}

/* ── TRUST BAR ── */
.trust-bar{
  background:var(--dark);padding:16px 0;overflow:hidden;
}
.tb-items{
  max-width:1140px;margin:0 auto;padding:0 28px;
  display:flex;align-items:center;justify-content:center;gap:20px;
  flex-wrap:wrap;
}
.tbi{display:flex;align-items:center;gap:7px;font-size:.82rem;color:rgba(255,255,255,.65)}
.tbi span:first-child{font-size:1rem}
.tbi-sep{color:rgba(255,255,255,.2);font-size:.6rem}

/* ── SOBRE ── */
.sobre{padding:100px 0;background:var(--white)}
.sobre-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
@media(max-width:860px){.sobre-grid{grid-template-columns:1fr}}
.sobre-img{position:relative;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-lg)}
.sobre-img img{width:100%;aspect-ratio:5/6;object-fit:cover}
.sobre-float{
  position:absolute;bottom:20px;left:20px;right:20px;
  background:rgba(255,255,255,.95);backdrop-filter:blur(10px);
  border:1.5px solid var(--border);border-radius:var(--radius);
  padding:14px 18px;display:flex;align-items:center;gap:12px;
}
.sf-icon{font-size:1.4rem}
.sobre-float strong{display:block;font-size:.88rem;font-weight:700;color:var(--dark)}
.sobre-float span{font-size:.78rem;color:var(--muted)}
.sobre-text .s-h2{margin-top:6px}
.sobre-text>p{color:var(--text2);font-size:.95rem;margin-bottom:14px;line-height:1.75}
.sobre-items{display:flex;flex-direction:column;gap:16px;margin:24px 0 32px}
.si{display:flex;align-items:flex-start;gap:12px}
.si-icon{
  width:28px;height:28px;flex-shrink:0;border-radius:6px;
  background:var(--green-pale);
  display:flex;align-items:center;justify-content:center;font-size:.9rem;
  margin-top:1px;
}
.si strong{display:block;font-size:.9rem;color:var(--dark);margin-bottom:2px}
.si span{font-size:.83rem;color:var(--muted)}

/* ── SERVIÇOS ── */
.servicos{padding:100px 0;background:var(--bg)}
.servicos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:900px){.servicos-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.servicos-grid{grid-template-columns:1fr}}

.serv-card{
  background:white;border:1.5px solid var(--border);border-radius:var(--radius-lg);
  padding:30px 24px;transition:var(--t);position:relative;overflow:hidden;
}
.serv-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--green),var(--green-light));
  transform:scaleX(0);transition:transform .3s;transform-origin:left;
}
.serv-card:hover{border-color:var(--border2);box-shadow:var(--shadow);transform:translateY(-4px)}
.serv-card:hover::before{transform:scaleX(1)}
.serv-featured{border-color:var(--border2);background:linear-gradient(160deg,var(--green-pale),white)}
.serv-featured::before{transform:scaleX(1)}

.sc-number{
  font-size:.68rem;font-weight:700;letter-spacing:.12em;color:var(--muted);
  margin-bottom:14px;
}
.sc-icon{font-size:1.8rem;margin-bottom:14px}
.serv-card h3{font-family:'Lora',serif;font-size:1.1rem;font-weight:700;color:var(--dark);margin-bottom:10px}
.serv-card p{font-size:.87rem;color:var(--text2);line-height:1.65;margin-bottom:16px}
.serv-card ul{list-style:none;margin-bottom:20px;display:flex;flex-direction:column;gap:7px}
.serv-card ul li{font-size:.83rem;color:var(--muted);padding-left:14px;position:relative}
.serv-card ul li::before{content:'—';position:absolute;left:0;color:var(--green);font-size:.7rem}
.sc-link{font-size:.85rem;font-weight:700;color:var(--green)}
.sc-link:hover{opacity:.75}

/* ── DIFERENCIAIS ── */
.diferenciais{padding:100px 0;position:relative;overflow:hidden}
.diff-bg{
  position:absolute;inset:0;
  background:linear-gradient(135deg,var(--dark),var(--dark2));
}
.diff-wrap{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;
}
@media(max-width:860px){.diff-wrap{grid-template-columns:1fr}}
.diff-desc{color:rgba(255,255,255,.65);margin-bottom:28px;font-size:.95rem;line-height:1.75}
.diff-lista{display:flex;flex-direction:column;gap:18px;margin-bottom:32px}
.dl-item{display:flex;align-items:flex-start;gap:14px}
.dl-icon{
  width:40px;height:40px;flex-shrink:0;border-radius:10px;
  background:rgba(34,201,121,.12);border:1px solid rgba(34,201,121,.2);
  display:flex;align-items:center;justify-content:center;font-size:1.1rem;
}
.dl-item strong{display:block;font-size:.9rem;color:white;margin-bottom:3px}
.dl-item span{font-size:.83rem;color:rgba(255,255,255,.55)}
.diff-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.dc-card{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius-lg);padding:22px 20px;
  transition:var(--t);
}
.dc-card:hover{background:rgba(255,255,255,.08);border-color:rgba(34,201,121,.2)}
.dc-accent{background:rgba(34,201,121,.08);border-color:rgba(34,201,121,.2)}
.dcc-top{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.dcc-icon{font-size:1.2rem}
.dcc-tag{font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.45)}
.dcc-val{font-family:'Lora',serif;font-size:1.8rem;font-weight:700;color:white;line-height:1;margin-bottom:6px}
.dcc-label{font-size:.78rem;color:rgba(255,255,255,.5);line-height:1.5}

/* ── DEPOIMENTOS ── */
.depoimentos{padding:100px 0;background:var(--white)}
.dep-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:860px){.dep-grid{grid-template-columns:1fr}}
.dep-card{
  background:var(--bg);border:1.5px solid var(--border);
  border-radius:var(--radius-lg);padding:28px 24px;transition:var(--t);
}
.dep-card:hover{border-color:var(--border2);box-shadow:var(--shadow-sm);transform:translateY(-3px)}
.dep-mid{border-color:var(--border2);background:var(--green-pale)}
.dep-stars{color:#f59e0b;font-size:.9rem;letter-spacing:1.5px;margin-bottom:14px}
.dep-card p{font-size:.9rem;color:var(--text2);line-height:1.7;margin-bottom:20px;font-style:italic}
.dep-author{display:flex;align-items:center;gap:12px}
.dep-av{
  width:40px;height:40px;border-radius:50%;
  background:var(--green);color:white;
  font-size:.75rem;font-weight:700;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.dep-author strong{display:block;font-size:.88rem;color:var(--dark)}
.dep-author span{font-size:.78rem;color:var(--muted)}

/* ── CTA BAND ── */
.cta-band{
  padding:80px 0;
  background:linear-gradient(135deg,var(--green-pale),var(--bg2));
  border-top:1.5px solid var(--border2);border-bottom:1.5px solid var(--border2);
}
.ctab-wrap{display:flex;align-items:center;justify-content:space-between;gap:48px;flex-wrap:wrap}
.ctab-text h2{
  font-family:'Lora',serif;font-size:clamp(1.5rem,3vw,2.1rem);
  font-weight:700;color:var(--dark);margin-bottom:8px;
}
.ctab-text h2 em{font-style:italic;color:var(--green)}
.ctab-text p{color:var(--text2);font-size:.93rem}
.ctab-actions{display:flex;gap:12px;flex-shrink:0;flex-wrap:wrap}

/* ── CONTATO ── */
.contato{padding:100px 0;background:var(--white)}
.contato-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:72px;align-items:start}
@media(max-width:860px){.contato-grid{grid-template-columns:1fr}}
.ct-info>p{color:var(--text2);font-size:.93rem;margin-bottom:28px;line-height:1.75}
.ct-blocks{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}
.ctb-item{
  display:flex;align-items:flex-start;gap:14px;
  padding:14px 16px;background:var(--bg);
  border:1.5px solid var(--border);border-radius:var(--radius);
  transition:var(--t);color:inherit;
}
a.ctb-item:hover{border-color:var(--border2);background:var(--green-pale);opacity:1}
.ctb-icon{font-size:1.1rem;flex-shrink:0;margin-top:1px}
.ctb-item strong{display:block;font-size:.88rem;color:var(--dark);margin-bottom:2px}
.ctb-item span{font-size:.83rem;color:var(--muted)}
.ct-promise{
  display:flex;align-items:flex-start;gap:12px;
  background:var(--green-pale);border:1.5px solid var(--border2);
  border-radius:var(--radius);padding:14px 16px;
}
.ctp-icon{font-size:1.1rem;flex-shrink:0}
.ct-promise p{font-size:.85rem;color:var(--text2);line-height:1.55}
.ct-promise strong{color:var(--green)}

.ct-form{
  background:var(--bg);border:1.5px solid var(--border);
  border-radius:var(--radius-xl);padding:36px;box-shadow:var(--shadow-sm);
}
.ct-form h3{
  font-family:'Lora',serif;font-size:1.2rem;font-weight:700;
  color:var(--dark);margin-bottom:24px;padding-bottom:16px;
  border-bottom:1.5px solid var(--border);
}
.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:560px){.fg-row{grid-template-columns:1fr}}
.fg{margin-bottom:16px}
.fg label{
  display:block;font-size:.73rem;font-weight:700;color:var(--muted);
  margin-bottom:6px;letter-spacing:.06em;text-transform:uppercase;
}
.fg input,.fg select,.fg textarea{
  width:100%;background:white;
  border:1.5px solid var(--border);border-radius:var(--radius);
  color:var(--text);font-family:'Plus Jakarta Sans',sans-serif;font-size:.9rem;
  padding:11px 14px;outline:none;resize:vertical;
  transition:border-color .2s,box-shadow .2s;
}
.fg input::placeholder,.fg textarea::placeholder{color:#b0c0b8}
.fg input:focus,.fg select:focus,.fg textarea:focus{
  border-color:var(--green);box-shadow:0 0 0 3px rgba(15,122,74,.1);
}
.form-note{text-align:center;font-size:.76rem;color:var(--muted);margin-top:12px}

/* ── FOOTER ── */
.footer{background:var(--dark);padding:60px 0 0}
.ft-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:48px;
  padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.08);
}
@media(max-width:768px){.ft-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.ft-grid{grid-template-columns:1fr}}
.ft-brand .logo{margin-bottom:16px}
.ft-brand .logo-mark{background:rgba(255,255,255,.1)}
.ft-brand .logo-name{color:white}
.ft-brand p{font-size:.86rem;color:rgba(255,255,255,.45);line-height:1.7;max-width:260px}
.ft-col h4{
  font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.4);margin-bottom:16px;
}
.ft-col ul{list-style:none}
.ft-col ul li{margin-bottom:10px}
.ft-col ul a,.ft-col ul span{font-size:.86rem;color:rgba(255,255,255,.5);transition:color .2s}
.ft-col ul a:hover{color:var(--green-light);opacity:1}
.ft-bottom{padding:20px 0}
.ft-bottom-inner{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.ft-bottom p{font-size:.78rem;color:rgba(255,255,255,.3)}
.ft-bottom strong{color:rgba(255,255,255,.5)}
.ft-links{display:flex;gap:20px}
.ft-links a{font-size:.76rem;color:rgba(255,255,255,.3);transition:color .2s}
.ft-links a:hover{color:var(--green-light);opacity:1}

/* ── WHATSAPP FLOAT ── */
.waf{
  position:fixed;bottom:24px;right:24px;z-index:800;
  display:flex;align-items:center;gap:8px;
  background:#25d366;color:white;
  font-weight:700;font-size:.85rem;
  padding:13px 20px;border-radius:100px;
  box-shadow:0 4px 20px rgba(37,211,102,.45);
  transition:var(--t);
}
.waf:hover{transform:scale(1.05);box-shadow:0 6px 28px rgba(37,211,102,.6);opacity:1}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .65s ease,transform .65s ease}
.reveal.visible{opacity:1;transform:none}

/* ── ANIMATIONS ── */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(22px)}
  to{opacity:1;transform:none}
}
