
/* ═══ RESET ═══ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:Helvetica,Arial,sans-serif;
  background:#1d1a4b;
  color:#ffffff;
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}

/* ═══ TOKENS ═══ */
:root{
  --bg:    #1d1a4b;
  --bg2:   #252262;
  --bg3:   #2c2972;
  --bg4:   #16143a;
  --bg5:   #0e0c2a;

  --g400:  #f8dc22;
  --g500:  #e6ca10;
  --g600:  #c9af0a;
  --g700:  #a88f05;

  --w100:  rgba(255,255,255,.08);
  --w200:  rgba(255,255,255,.14);
  --w300:  rgba(255,255,255,.28);
  --w400:  rgba(255,255,255,.50);
  --w500:  rgba(255,255,255,.70);
  --w600:  rgba(255,255,255,.85);
  --white: #ffffff;

  --r-sm:6px; --r-md:12px; --r-lg:20px; --r-xl:32px;
  --sh-md:0 4px 24px rgba(0,0,0,.4);
  --sh-lg:0 12px 48px rgba(0,0,0,.5);
  --sh-g: 0 8px 32px rgba(15,122,90,.35);
}

/* ═══ TIPOGRAFIA ═══ */
h1,h2,h3,h4{font-family:Helvetica,Arial,sans-serif;line-height:1.1;color:#ffffff}
h1{font-size:clamp(2.2rem,6vw,4.8rem);font-weight:700}
h2{font-size:clamp(1.7rem,4vw,3rem);font-weight:700}
h3{font-size:clamp(1rem,2vw,1.3rem);font-weight:700}
p{color:var(--w500);line-height:1.78}

/* ═══ LAYOUT ═══ */
.wrap{max-width:1160px;margin:0 auto;padding:0 20px}
@media(min-width:768px){.wrap{padding:0 32px}}
section{padding:80px 0}
@media(min-width:768px){section{padding:108px 0}}

/* ═══ UTILITÁRIOS ═══ */
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.7rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;
  color:var(--g400);margin-bottom:16px;
}
.eyebrow::before{display:none}
.eyebrow.center{justify-content:center}
.eyebrow.center::before{display:none}
.eyebrow.center::after{display:none}
.eyebrow.light{color:var(--w400)}
.eyebrow.light::before,.eyebrow.light::after{display:none}
.subtitle{font-size:1rem;color:var(--w400);max-width:540px;line-height:1.8;margin-top:14px}
.center-text{text-align:center}
.center-text .subtitle{margin:14px auto 0}

/* ═══ BOTÕES ═══ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:9px;font-family:Helvetica,Arial,sans-serif;font-weight:700;
  font-size:.85rem;letter-spacing:.03em;padding:14px 28px;
  border-radius:var(--r-sm);transition:all .22s ease;
  white-space:nowrap;line-height:1;border:none;cursor:pointer;
}
.btn svg{width:17px;height:17px;flex-shrink:0}
.btn-primary{background:var(--g500);color:#ffffff;box-shadow:var(--sh-g)}
.btn-primary:hover{background:var(--g600);transform:translateY(-2px);box-shadow:0 12px 40px rgba(15,122,90,.4)}
.btn-wa{background:#01c501;color:#ffffff;box-shadow:0 8px 28px rgba(1,197,1,.28)}
.btn-wa:hover{background:#00a800;transform:translateY(-2px);box-shadow:0 12px 40px rgba(1,197,1,.4)}
.btn-outline{background:transparent;color:var(--g400);border:1.5px solid var(--g400)}
.btn-outline:hover{background:rgba(61,184,138,.1);transform:translateY(-2px)}
.btn-white{background:#ffffff;color:var(--bg);box-shadow:var(--sh-md)}
.btn-white:hover{transform:translateY(-2px);box-shadow:var(--sh-lg)}
.btn-ghost{background:var(--w100);color:#ffffff;border:1.5px solid var(--w300)}
.btn-ghost:hover{background:var(--w200);transform:translateY(-2px)}
.btn-full{width:100%}

/* ═══ NAV ═══ */
.nav{position:fixed;top:0;left:0;right:0;z-index:900;padding:22px 0;transition:all .35s}
.nav.scrolled{
  background:rgba(22,20,58,.97);
  backdrop-filter:blur(20px);
  box-shadow:0 1px 0 var(--w200);
  padding:13px 0;
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  max-width:1160px;margin:0 auto;padding:0 20px;
}
@media(min-width:768px){.nav-inner{padding:0 32px}}
.logo{display:flex;align-items:center;line-height:1}
.logo span{color:var(--g400)}
.nav-links{display:none;align-items:center;gap:30px}
@media(min-width:900px){.nav-links{display:flex}}
.nav-links a{font-size:.84rem;font-weight:500;color:var(--w500);transition:color .2s}
.nav-links a:hover{color:#ffffff}
.nav-cta{display:none;align-items:center;gap:10px}
@media(min-width:900px){.nav-cta{display:flex}}
.nav-cta .btn{padding:10px 20px;font-size:.82rem}
.hamburger{display:flex;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
@media(min-width:900px){.hamburger{display:none}}
.hamburger span{display:block;width:22px;height:1.5px;background:#ffffff;border-radius:2px;transition:all .3s}

/* Menu Mobile */
.mob{display:none;position:fixed;inset:0;background:var(--bg5);z-index:980;flex-direction:column;align-items:center;justify-content:center;gap:28px}
.mob.open{display:flex}
.mob a{font-size:1.9rem;font-weight:700;color:#ffffff;transition:color .2s}
.mob a:hover{color:var(--g400)}
.mob-close{position:absolute;top:22px;right:20px;background:none;border:none;font-size:1.3rem;color:var(--w400);cursor:pointer;padding:6px}

/* ═══ HERO ═══ */
.hero{
  min-height:100svh;display:flex;flex-direction:column;
  justify-content:flex-end;position:relative;overflow:hidden;
  background:linear-gradient(155deg,var(--bg5) 0%,var(--bg) 45%,var(--bg2) 100%);
  padding-bottom:72px;
}
.hero-pattern{
  position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(circle,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:32px 32px;
}
.hero-vline{
  position:absolute;top:0;right:clamp(60px,12vw,140px);width:1px;height:100%;
  background:linear-gradient(to bottom,transparent 0%,var(--w200) 20%,var(--w200) 80%,transparent 100%);
}
.hero-cred{
  position:absolute;top:clamp(100px,16vh,150px);right:clamp(64px,12vw,144px);
  display:flex;flex-direction:column;align-items:flex-end;gap:4px;
}
@media(max-width:767px){.hero-cred{display:none}}
.hero-cred span{font-size:.6rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--w300)}

.hero-inner{
  position:relative;z-index:1;padding-top:clamp(48px,8vh,72px);
  display:flex;flex-direction:column;align-items:center;gap:44px;
  text-align:center;
}
@media(min-width:900px){.hero-inner{gap:56px;padding-top:80px}}

.hero-badge{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-size:.7rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--w400);margin-bottom:22px;
}
.hero-badge::before{display:none}
.hero h1{color:#ffffff;max-width:820px;margin:0 auto}
.hero h1 em{font-style:italic;color:var(--g400)}
.hero-desc{font-size:clamp(.93rem,1.4vw,1.05rem);color:var(--w400);max-width:580px;line-height:1.85;margin-top:20px;margin-bottom:36px;margin-left:auto;margin-right:auto}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;align-items:center;justify-content:center}

/* Stats */
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;width:100%;max-width:600px;margin:0 auto}
@media(max-width:540px){.hero-stats{grid-template-columns:repeat(2,1fr)}}
.hstat{
  background:var(--w100);border:1px solid var(--w200);
  border-radius:var(--r-md);padding:20px 16px;backdrop-filter:blur(8px);transition:background .25s;
}
.hstat:hover{background:var(--w200)}
.hstat-n{font-size:clamp(1.7rem,3.5vw,2.3rem);font-weight:700;color:#ffffff;line-height:1}
.hstat-l{font-size:.7rem;font-weight:500;letter-spacing:.05em;color:var(--w400);margin-top:5px;line-height:1.3}

/* Scroll hint */
.scroll-hint{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:6px}
.scroll-hint-line{width:1px;height:34px;background:linear-gradient(to bottom,var(--w300),transparent);animation:sh 2.2s ease-in-out infinite}
.scroll-hint-txt{font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--w300)}
@keyframes sh{0%,100%{opacity:.4}50%{opacity:1}}

/* Hero animações */
@keyframes fadeUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:none}}
.hero-badge{animation:fadeUp .8s cubic-bezier(.16,1,.3,1) .1s both}
.hero h1{animation:fadeUp .8s cubic-bezier(.16,1,.3,1) .24s both}
.hero-desc{animation:fadeUp .8s cubic-bezier(.16,1,.3,1) .38s both}
.hero-btns{animation:fadeUp .8s cubic-bezier(.16,1,.3,1) .5s both}
.hero-stats{animation:fadeUp .8s cubic-bezier(.16,1,.3,1) .6s both}

/* ═══ MARQUEE ═══ */
.marquee-bar{background:var(--bg5);border-top:1px solid var(--w200);border-bottom:1px solid var(--w200);padding:13px 0;overflow:hidden}
.marquee-track{display:flex;width:max-content;animation:marquee 26s linear infinite}
.marquee-track:hover{animation-play-state:paused}
.mi{display:flex;align-items:center;gap:24px;padding:0 24px;border-right:1px solid var(--w200)}
.mi-dot{width:4px;height:4px;border-radius:50%;background:var(--g400);flex-shrink:0}
.mi span{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--w400);white-space:nowrap}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ═══ NICHOS ═══ */
.nicho-section{background:var(--bg2)}
.nicho-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:52px}
@media(min-width:640px){.nicho-grid{grid-template-columns:repeat(4,1fr)}}
.nicho-card{
  background:var(--w100);border:1px solid var(--w200);border-radius:var(--r-lg);
  padding:clamp(20px,3vw,32px) clamp(16px,2.5vw,24px);
  text-align:center;transition:all .3s;position:relative;overflow:hidden;
}
.nicho-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--g500),var(--g400));
  transform:scaleX(0);transform-origin:left;transition:transform .35s ease;
}
.nicho-card:hover{background:#1d1a4b;border-color:rgba(248,220,34,.4);box-shadow:var(--sh-md);transform:translateY(-4px)}
.nicho-card:hover::before{transform:scaleX(1)}
.nicho-icon{
  width:56px;height:56px;border-radius:var(--r-md);
  background:var(--w100);display:flex;align-items:center;justify-content:center;
  margin:0 auto 16px;font-size:1.6rem;transition:background .3s;
}
.nicho-card:hover .nicho-icon{background:rgba(61,184,138,.15)}
.nicho-name{font-size:1rem;font-weight:700;color:#ffffff;margin-bottom:8px}
.nicho-desc{font-size:.8rem;color:var(--w400);line-height:1.65}

/* ═══ SERVIÇOS ═══ */
.services-section{background:var(--bg)}
.svc-wrap{display:grid;grid-template-columns:1fr;gap:56px}
@media(min-width:900px){.svc-wrap{grid-template-columns:1fr 1fr;align-items:start;gap:72px}}
.svc-intro{position:static}
@media(min-width:900px){.svc-intro{position:sticky;top:120px}}
.svc-intro h2{color:#ffffff;margin-bottom:18px}
.svc-intro p{color:var(--w400);margin-bottom:28px}

.svc-list{display:flex;flex-direction:column}
.svc-item{
  display:grid;grid-template-columns:44px 1fr 24px;
  align-items:start;gap:16px;padding:22px 0;
  border-top:1px solid var(--w200);transition:all .25s;position:relative;
}
@media(min-width:640px){.svc-item{grid-template-columns:60px 1fr 28px;gap:22px;padding:26px 0}}
.svc-item::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1.5px;background:var(--g400);transition:width .4s ease}
.svc-item:last-child{border-bottom:1px solid var(--w200)}
.svc-item:hover::after{width:100%}
.svc-item:hover .svc-title{color:var(--g400)}
.svc-item:hover .svc-arr{transform:translate(3px,-3px);color:var(--g400)}
.svc-num{font-size:.9rem;font-weight:400;color:var(--w300);padding-top:4px}
.svc-title{font-size:clamp(1.05rem,2.5vw,1.55rem);font-weight:700;color:#ffffff;margin-bottom:5px;transition:color .25s;line-height:1.2}
.svc-desc{font-size:.83rem;color:var(--w400);line-height:1.7;max-width:480px}
.svc-arr{font-size:1.1rem;color:var(--w300);transition:all .25s;padding-top:4px;text-align:right}
.svc-link-overlay{
  position:absolute;inset:0;z-index:1;
  text-decoration:none;
}

/* ═══ PLACEHOLDERS DE IMAGEM ═══ */
.img-placeholder{
  width:100%;border-radius:var(--r-lg);overflow:hidden;
  position:relative;background:var(--bg3);
  border:2px dashed rgba(248,220,34,.3);
  display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:10px;color:rgba(255,255,255,.35);
  font-size:.75rem;font-weight:600;letter-spacing:.08em;
  text-transform:uppercase;text-align:center;padding:20px;
}
.img-placeholder svg{opacity:.25}
.img-placeholder-label{
  font-size:.68rem;color:rgba(248,220,34,.5);
  letter-spacing:.1em;margin-top:4px;
}
/* Serviços: imagem abaixo do botão no intro */
.svc-img{aspect-ratio:4/3;margin-top:28px}
/* Sobre: substitui o card verde */
.about-img{aspect-ratio:3/4;min-height:380px}
/* CTA: imagem de fundo em meia largura */
.cta-img-wrap{
  max-width:680px;margin:32px auto 0;
}
.cta-img{aspect-ratio:16/6;border-radius:var(--r-lg)}
.about-section{background:var(--bg2)}
.about-grid{display:grid;grid-template-columns:1fr;gap:48px;align-items:center}
@media(min-width:900px){.about-grid{grid-template-columns:1fr 1fr;gap:80px}}
.about-visual{position:relative;padding:0 36px 36px 0}
.about-card{
  background:linear-gradient(145deg,var(--bg3),var(--bg5));
  border:1px solid var(--w200);
  border-radius:var(--r-xl);padding:clamp(32px,4vw,52px);
  position:relative;overflow:hidden;
}
.about-card::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:24px 24px;
}
.about-card-tag{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--w300);margin-bottom:22px;position:relative;
}
.about-card-tag::before{display:none}
.about-card h3{color:#ffffff;font-size:clamp(1.1rem,2.5vw,1.65rem);margin-bottom:14px;position:relative}
.about-card p{color:var(--w400);font-size:.9rem;line-height:1.85;position:relative}
.about-badge{
  position:absolute;bottom:0;right:0;
  background:var(--bg3);border:1px solid var(--w200);
  border-radius:var(--r-lg);padding:18px 24px;box-shadow:var(--sh-lg);
}
@media(max-width:480px){.about-badge{bottom:-10px;right:-8px;padding:14px 18px}}
.badge-n{font-size:1.9rem;font-weight:700;color:var(--g400);line-height:1}
.badge-l{font-size:.7rem;color:var(--w400);margin-top:4px}
.about-text .eyebrow{margin-bottom:14px}
.about-text h2{color:#ffffff;margin-bottom:20px}
.about-text>p{margin-bottom:16px;font-size:.95rem}
.pillars{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:26px 0 32px}
.pillar{
  display:flex;align-items:center;gap:9px;
  padding:12px 14px;background:var(--w100);
  border:1px solid var(--w200);border-radius:var(--r-sm);
  font-size:.82rem;font-weight:500;color:var(--w500);transition:all .2s;
}
.pillar:hover{border-color:var(--g400);color:#ffffff}
.pillar::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--g400);flex-shrink:0}
.about-btns{display:flex;gap:12px;flex-wrap:wrap}

/* ═══ PORTFÓLIO ═══ */
.portfolio-section{background:var(--bg5)}
.port-tabs{display:flex;gap:8px;margin-top:36px;flex-wrap:wrap;justify-content:center}
.port-tab{
  font-size:.78rem;font-weight:700;padding:8px 20px;border-radius:100px;
  border:1px solid var(--w200);color:var(--w400);background:transparent;cursor:pointer;transition:all .2s;
}
.port-tab.active,.port-tab:hover{background:#342f5c;border-color:#342f5c;color:#ffffff}
.pgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:32px}
@media(min-width:640px){.pgrid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:900px){.pgrid{grid-template-columns:repeat(4,1fr);gap:12px}}
.pitem{
  background:var(--w100);border:1px solid var(--w200);
  border-radius:var(--r-md);aspect-ratio:4/5;
  position:relative;overflow:hidden;transition:all .3s;
}
.pitem:hover{border-color:#f8dc22;border-width:2px;transform:translateY(-3px);box-shadow:0 0 0 1px #f8dc22}
.pitem:hover .povl{opacity:1}
.pitem:hover .pthumb{transform:scale(1.04)}
.pthumb{
  width:100%;height:100%;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:8px;
  background:linear-gradient(135deg,rgba(61,184,138,.1),rgba(61,184,138,.03));
  transition:transform .5s ease;
}
.pthumb-ico{font-size:1.8rem;opacity:.2}
.pthumb-txt{font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;color:var(--w300)}
.povl{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(14,12,42,.97) 0%,rgba(14,12,42,.2) 60%,transparent 100%);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:clamp(14px,2.5vw,22px);opacity:0;transition:opacity .3s;
}
.povl-nicho{font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--g400);margin-bottom:5px}
.povl-title{font-size:clamp(.88rem,1.8vw,1.1rem);font-weight:700;color:#ffffff;line-height:1.25}
.port-cta{text-align:center;margin-top:48px}

/* ═══ DIFERENCIAIS ═══ */
.diff-section{background:var(--bg4);contain:layout style paint}
.diff-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-top:52px}
@media(min-width:640px){.diff-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.diff-grid{grid-template-columns:repeat(3,1fr)}}
.diff-card{
  background:#342f5c;border:1px solid rgba(255,255,255,.12);border-radius:var(--r-lg);
  padding:clamp(24px,3vw,36px);transition:all .3s;
}
.diff-card:hover{border-color:rgba(248,220,34,.35);box-shadow:var(--sh-md);transform:translateY(-3px)}
.diff-ico{
  width:52px;height:52px;border-radius:var(--r-md);
  background:#1d1a4b;display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;margin-bottom:18px;transition:background .3s;
}
.diff-card:hover .diff-ico{background:rgba(248,220,34,.12)}
.diff-card h3{font-size:1rem;color:#ffffff;margin-bottom:10px}
.diff-card p{font-size:.84rem;line-height:1.7;color:var(--w400)}

/* ═══ PRICING ═══ */
.pricing-section{background:var(--bg2);contain:layout style paint}
.pgrid-price{display:grid;grid-template-columns:1fr;gap:16px;margin-top:52px}
@media(min-width:640px){.pgrid-price{grid-template-columns:repeat(3,1fr)}}
.price-card{
  border:1.5px solid var(--w200);border-radius:var(--r-lg);
  padding:clamp(26px,3.5vw,40px) clamp(22px,3vw,34px);
  display:flex;flex-direction:column;background:var(--bg);transition:all .3s;position:relative;
}
.price-card:hover{border-color:var(--g400);box-shadow:var(--sh-md);transform:translateY(-4px)}
.price-card.featured{background:#b81b44;border-color:#b81b44;box-shadow:0 8px 32px rgba(184,27,68,.35)}
.price-card.featured:hover{background:#9e1739;transform:translateY(-4px)}
.feat-pill{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  background:#f8dc22;color:#b71b44;border:none;
  font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  padding:4px 14px;border-radius:100px;white-space:nowrap;
}
.ptag{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-bottom:16px;color:var(--g400)}
.price-card.featured .ptag{color:rgba(255,255,255,.65)}
.pname{font-size:1.2rem;font-weight:700;color:#ffffff;margin-bottom:8px}
.pdesc{font-size:.83rem;line-height:1.65;margin-bottom:22px;color:var(--w400)}
.price-card.featured .pdesc{color:rgba(255,255,255,.75)}
.pamount{font-size:clamp(2rem,4vw,2.6rem);font-weight:700;line-height:1;margin-bottom:4px;color:#ffffff}
.price-card.featured .pamount{color:#ffffff}
.pperiod{font-size:.78rem;margin-bottom:28px;color:var(--w400)}
.price-card.featured .pperiod{color:rgba(255,255,255,.65)}
.pfeats{display:flex;flex-direction:column;gap:11px;margin-bottom:30px;flex:1}
.pfeats li{display:flex;align-items:flex-start;gap:10px;font-size:.84rem;line-height:1.5;color:var(--w500)}
.price-card.featured .pfeats li{color:rgba(255,255,255,.9)}
.pfeats li::before{
  content:'';width:16px;height:16px;border-radius:50%;flex-shrink:0;margin-top:1px;
  background:rgba(61,184,138,.15);border:1.5px solid var(--g400);
}
.price-card.featured .pfeats li::before{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.45)}

/* ═══ DEPOIMENTOS ═══ */
.testi-section{background:var(--bg4);contain:layout style paint}
.tgrid{display:grid;grid-template-columns:1fr;gap:14px;margin-top:48px}
@media(min-width:640px){.tgrid{grid-template-columns:repeat(2,1fr)}}
.tcard{
  background:var(--bg2);border:1px solid var(--w200);border-radius:var(--r-lg);
  padding:clamp(22px,3.5vw,34px) clamp(18px,3vw,30px);transition:all .3s;position:relative;overflow:hidden;
}
.tcard:hover{box-shadow:var(--sh-md);transform:translateY(-3px);border-color:rgba(61,184,138,.3)}
.tcard::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--g500);transform:scaleX(0);transform-origin:left;transition:transform .4s}
.tcard:hover::before{transform:scaleX(1)}
.tquote{font-size:3rem;color:rgba(61,184,138,.2);line-height:1;margin-bottom:4px}
.ttext{font-size:.9rem;color:var(--w400);line-height:1.8;margin-bottom:22px;font-style:italic}
.tauthor{display:flex;align-items:center;gap:12px}
.tavatar{
  width:42px;height:42px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--g500),var(--g700));
  display:flex;align-items:center;justify-content:center;
  font-size:.88rem;font-weight:700;color:#ffffff;
}
.tname{font-weight:700;font-size:.88rem;color:#ffffff}
.trole{font-size:.72rem;color:var(--w400);margin-top:2px}
.tstars{display:flex;gap:2px;margin-top:4px}
.tstars span{color:#D4A017;font-size:.82rem}

/* ═══ CTA ═══ */
.cta-section{background:var(--bg3);padding:96px 0;text-align:center;position:relative;overflow:hidden}
.cta-section::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:28px 28px;
}
.cta-word{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-size:clamp(5rem,16vw,16rem);font-weight:700;
  color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.04);
  white-space:nowrap;pointer-events:none;user-select:none;letter-spacing:-.04em;
}
.cta-section .wrap{position:relative;z-index:1}
.cta-section h2{color:#ffffff;margin-bottom:14px}
.cta-section>div>p{color:var(--w400);font-size:1.05rem;margin-bottom:36px;max-width:480px;margin-left:auto;margin-right:auto}
.cta-btns{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}

/* ═══ CONTATO ═══ */
.contact-section{background:var(--bg2)}
.cgrid{display:grid;grid-template-columns:1fr;gap:48px;align-items:start}
@media(min-width:900px){.cgrid{grid-template-columns:1fr 1.15fr;gap:72px}}
.contact-info .eyebrow{margin-bottom:14px}
.contact-info h2{color:#ffffff;margin-bottom:18px}
.contact-info>p{margin-bottom:32px;font-size:.95rem;color:var(--w400)}
.cmethods{display:flex;flex-direction:column;gap:2px}
.cmethod{
  display:flex;align-items:center;gap:14px;padding:16px 20px;
  background:var(--w100);border:1px solid var(--w200);text-decoration:none;transition:all .2s;
}
.cmethod:first-child{border-radius:var(--r-md) var(--r-md) 0 0}
.cmethod:last-child{border-radius:0 0 var(--r-md) var(--r-md)}
.cmethod:hover{background:rgba(61,184,138,.1);border-color:rgba(61,184,138,.4);padding-left:28px}
.cicon{
  width:40px;height:40px;border-radius:var(--r-sm);
  background:var(--w100);border:1px solid var(--w200);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.1rem;
}
.clbl{font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--w300)}
.cval{font-weight:500;color:#ffffff;font-size:.88rem;margin-top:1px}
.hours-card{margin-top:12px;padding:16px 20px;background:var(--w100);border:1px solid var(--w200);border-radius:var(--r-md)}
.hours-card p{font-size:.84rem;color:var(--w400);line-height:1.9}
.hours-card strong{color:#ffffff;font-weight:700}

/* Formulário */
.contact-form{background:var(--bg);border:1px solid var(--w200);border-radius:var(--r-xl);padding:clamp(28px,4vw,44px) clamp(22px,3.5vw,40px)}
.contact-form h3{font-size:1.65rem;color:#ffffff;margin-bottom:6px}
.contact-form>p{font-size:.85rem;color:var(--w400);margin-bottom:26px}
.frow{display:grid;grid-template-columns:1fr}
@media(min-width:480px){.frow{grid-template-columns:1fr 1fr;gap:12px}}
.fg{margin-bottom:12px}
label{display:block;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--w400);margin-bottom:6px}
input,textarea,select{
  width:100%;padding:12px 14px;
  background:var(--w100);border:1.5px solid var(--w200);
  border-radius:var(--r-sm);font-family:Helvetica,Arial,sans-serif;
  font-size:.9rem;color:#ffffff;outline:none;appearance:none;transition:all .2s;
}
input:focus,textarea:focus,select:focus{border-color:var(--g400);background:rgba(61,184,138,.06);box-shadow:0 0 0 3px rgba(61,184,138,.12)}
input::placeholder,textarea::placeholder{color:var(--w300)}
select option{background:var(--bg);color:#ffffff}
textarea{resize:vertical;min-height:108px}

/* ═══ FOOTER ═══ */
footer{background:var(--bg5);padding:clamp(48px,6vw,72px) 0 28px}
.fgrid{display:grid;grid-template-columns:1fr;gap:32px;margin-bottom:48px}
@media(min-width:640px){.fgrid{grid-template-columns:1fr 1fr}}
@media(min-width:900px){.fgrid{grid-template-columns:2fr 1fr 1fr 1fr;gap:44px}}
.fbrand-logo{display:block;margin-bottom:14px}
.fbrand p{font-size:.82rem;color:var(--w300);line-height:1.75;max-width:250px}
.fsocial{display:flex;gap:8px;margin-top:20px}
.fsoc{
  width:36px;height:36px;border-radius:var(--r-sm);
  background:var(--w100);border:1px solid var(--w200);
  display:flex;align-items:center;justify-content:center;text-decoration:none;transition:all .2s;
}
.fsoc:hover{background:var(--g600);border-color:var(--g600)}
.fsoc svg{width:15px;height:15px;color:var(--w400)}
.fsoc:hover svg{color:#ffffff}
.fcol h4{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--w300);margin-bottom:16px}
.fcol ul{display:flex;flex-direction:column;gap:9px}
.fcol ul li a{font-size:.82rem;color:var(--w400);text-decoration:none;transition:color .2s}
.fcol ul li a:hover{color:var(--g400)}
.fhours p{font-size:.82rem;color:var(--w300);line-height:2}
.fhours .fw{color:#ffffff;font-weight:500}
.fbot{border-top:1px solid var(--w200);padding-top:24px;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center}
@media(min-width:640px){.fbot{flex-direction:row;justify-content:space-between;text-align:left}}
.fbot p{font-size:.75rem;color:var(--w300)}
.fbot a{color:var(--g400)}

/* ═══ WA FLOAT ═══ */
.wa{
  position:fixed;bottom:22px;right:18px;z-index:800;
  width:52px;height:52px;border-radius:50%;
  background:#25D366;box-shadow:0 4px 18px rgba(37,211,102,.35);
  display:flex;align-items:center;justify-content:center;
  text-decoration:none;transition:all .25s;
}
.wa::before{
  content:'';
  position:absolute;width:100%;height:100%;border-radius:50%;
  background:#25D366;opacity:.6;
  animation:waPulse 2s ease-out infinite;
  z-index:-1;
}
.wa::after{
  content:'';
  position:absolute;width:100%;height:100%;border-radius:50%;
  background:#25D366;opacity:.3;
  animation:waPulse 2s ease-out infinite .5s;
  z-index:-1;
}
@media(min-width:640px){.wa{width:auto;height:auto;border-radius:100px;padding:13px 22px;gap:9px;bottom:26px;right:24px}.wa-txt{display:block}.wa::before,.wa::after{border-radius:100px}}
.wa:hover{transform:scale(1.05);box-shadow:0 6px 28px rgba(37,211,102,.5)}
.wa svg{width:25px;height:25px;color:#ffffff;flex-shrink:0}
.wa-txt{display:none;font-size:.83rem;font-weight:700;color:#ffffff;white-space:nowrap}
@keyframes waPulse{
  0%{transform:scale(1);opacity:.6}
  100%{transform:scale(1.7);opacity:0}
}

/* ═══ REVEAL: efeitos de entrada ═══ */
/* Base */
.reveal{
  opacity:0;
  transform:translateY(32px);
  transition:opacity .8s cubic-bezier(.16,1,.3,1),
             transform .8s cubic-bezier(.16,1,.3,1);
}
.reveal.on{opacity:1;transform:none}

/* Delays escalonados */
.d1{transition-delay:.1s}
.d2{transition-delay:.2s}
.d3{transition-delay:.3s}
.d4{transition-delay:.4s}
.d5{transition-delay:.5s}

/* Entrada da esquerda */
.reveal-left{
  opacity:0;transform:translateX(-36px);
  transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1);
}
.reveal-left.on{opacity:1;transform:none}

/* Entrada da direita */
.reveal-right{
  opacity:0;transform:translateX(36px);
  transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1);
}
.reveal-right.on{opacity:1;transform:none}

/* Fade puro (escala) */
.reveal-scale{
  opacity:0;transform:scale(.94);
  transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1);
}
.reveal-scale.on{opacity:1;transform:scale(1)}

/* SVG helper */
.ico{fill:none;stroke:currentColor;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}
