/* =====================================================================
   Crisdart Construções Metálicas — Estilos do site (novo, 2026)
   Visual industrial moderno: grafite + vermelho da marca + azul aço.
   Fonte Inter. Mobile-first, sem CSS inline.
   ===================================================================== */

/* ---------- Tokens ---------- */
:root{
  --ink:#12161d;
  --ink-2:#181d27;
  --ink-3:#212a37;
  --steel:#2b3442;

  --red:#e01f26;        /* vermelho da marca — CTA/destaque */
  --red-600:#c2161c;
  --red-soft:rgba(224,31,38,.12);

  --blue:#1573c4;       /* azul aço — secundário/ícones */
  --blue-600:#0f5ea3;
  --blue-soft:rgba(21,115,196,.12);

  --bg:#ffffff;
  --bg-soft:#f4f6f9;
  --bg-mute:#eaeef4;
  --line:#e3e8ef;

  --text:#1c2430;
  --text-soft:#5a6676;
  --text-mute:#8a94a3;

  --wa:#25d366;
  --wa-600:#1ebe57;

  --radius:16px;
  --radius-sm:12px;
  --shadow-sm:0 2px 10px rgba(17,22,29,.06);
  --shadow:0 14px 40px rgba(17,22,29,.10);
  --shadow-lg:0 30px 70px rgba(17,22,29,.16);
  --container:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  background:var(--bg);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{margin:0;line-height:1.15;font-weight:800;letter-spacing:-.02em;color:var(--ink)}
p{margin:0}
ul{margin:0;padding:0;list-style:none}
button{font-family:inherit}

.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 22px}
.section{padding:88px 0}
.text-accent{color:var(--red)}
.text-blue{color:var(--blue)}

/* ---------- Eyebrow / heads ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-size:.78rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--red);margin-bottom:14px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--red);border-radius:2px}
.section-head{max-width:800px;margin:0 auto 52px;text-align:center}
.section-head .eyebrow{justify-content:center}
.section-head h2{font-size:clamp(1.7rem,3.4vw,2.5rem)}
.section-head p{margin-top:14px;color:var(--text-soft);font-size:1.06rem}

/* =====================================================================
   BOTÕES
   ===================================================================== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 26px;border-radius:12px;font-weight:700;font-size:.98rem;
  border:1.5px solid transparent;cursor:pointer;transition:.22s var(--ease);
  white-space:nowrap;
}
.btn svg{width:18px;height:18px}
.btn--primary{background:var(--red);color:#fff;box-shadow:0 10px 26px rgba(224,31,38,.30)}
.btn--primary:hover{background:var(--red-600);transform:translateY(-2px);box-shadow:0 16px 34px rgba(224,31,38,.38)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
.btn--outline{background:transparent;border-color:rgba(255,255,255,.4);color:#fff}
.btn--outline:hover{background:rgba(255,255,255,.12);transform:translateY(-2px)}
.btn--lg{padding:16px 32px;font-size:1.04rem}
.btn--block{width:100%}

/* Botão WhatsApp brilhante */
.btn-wa{
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:15px 28px;border-radius:12px;font-weight:700;font-size:1rem;color:#fff;
  background:linear-gradient(135deg,var(--wa),var(--wa-600));
  box-shadow:0 12px 30px rgba(37,211,102,.32);overflow:hidden;
  transition:.22s var(--ease);
}
.btn-wa svg{width:20px;height:20px}
.btn-wa:hover{transform:translateY(-2px);box-shadow:0 18px 40px rgba(37,211,102,.42)}
.btn-wa::after{
  content:"";position:absolute;top:0;left:-130%;width:60%;height:100%;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,.55),transparent);
  transform:skewX(-20deg);animation:shine 3.4s var(--ease) infinite;
}
.btn-wa--block{width:100%}
.btn-wa--sm{padding:11px 18px;font-size:.9rem}
@keyframes shine{0%{left:-130%}55%{left:130%}100%{left:130%}}

/* =====================================================================
   HEADER
   ===================================================================== */
.header{position:sticky;top:0;z-index:200}
.header-top{
  background:#fff;border-bottom:1px solid var(--line);transition:.25s var(--ease);
}
.header-top__inner{display:flex;align-items:center;gap:26px;padding:12px 22px;max-width:var(--container);margin:0 auto}
.brand img{height:54px;width:auto}
.header-feats{display:flex;gap:26px;margin-left:auto}
.header-feat{display:flex;align-items:center;gap:11px}
.header-feat__icon{
  display:grid;place-items:center;width:42px;height:42px;border-radius:11px;
  background:var(--blue-soft);color:var(--blue);flex:none;
}
.header-feat__icon svg{width:20px;height:20px}
.header-feat__txt{display:flex;flex-direction:column;line-height:1.25}
.header-feat__txt strong{font-size:.96rem;color:var(--ink)}
.header-feat__txt span{font-size:.78rem;color:var(--text-soft)}

.navbar{background:var(--ink);transition:.25s var(--ease)}
.navbar.is-stuck{box-shadow:0 10px 30px rgba(17,22,29,.22)}
.navbar__inner{display:flex;align-items:center;gap:20px;padding:0 22px;max-width:var(--container);margin:0 auto}
.nav{display:flex;gap:6px}
.nav__item{position:relative}
.nav__link{
  display:flex;align-items:center;gap:6px;padding:18px 16px;color:#cdd5e0;
  font-weight:600;font-size:.96rem;transition:.2s var(--ease);position:relative;
}
.nav__link::after{
  content:"";position:absolute;left:16px;right:16px;bottom:12px;height:2px;
  background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease);
}
.nav__link:hover,.nav__link.is-active{color:#fff}
.nav__link:hover::after,.nav__link.is-active::after{transform:scaleX(1)}
.nav__item--has:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown{
  position:absolute;top:100%;left:0;min-width:288px;background:#fff;border-radius:14px;
  box-shadow:var(--shadow-lg);padding:10px;opacity:0;visibility:hidden;transform:translateY(10px);
  transition:.22s var(--ease);border:1px solid var(--line);z-index:50;
}
.dropdown a{
  display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:9px;
  color:var(--text);font-weight:600;font-size:.93rem;transition:.16s;
}
.dropdown a::before{content:"";width:7px;height:7px;border-radius:2px;background:var(--red);flex:none;transform:rotate(45deg)}
.dropdown a:hover{background:var(--bg-soft);color:var(--red);padding-left:18px}
.nav-cta{margin-left:auto;padding:9px 0}

.burger{display:none;width:46px;height:46px;border:0;background:transparent;cursor:pointer;position:relative}
.burger span,.burger span::before,.burger span::after{
  content:"";position:absolute;left:11px;width:24px;height:2.5px;background:var(--ink);border-radius:3px;transition:.25s var(--ease)
}
.burger span{top:22px}
.burger span::before{top:-7px}
.burger span::after{top:7px}

/* Menu mobile */
.scrim{position:fixed;inset:0;background:rgba(10,14,20,.55);opacity:0;visibility:hidden;transition:.3s;z-index:300}
.mobile-nav{
  position:fixed;top:0;right:0;height:100dvh;width:min(86vw,340px);background:var(--ink);
  z-index:310;transform:translateX(100%);transition:transform .32s var(--ease);
  padding:24px 22px;overflow-y:auto;
}
.mobile-nav__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.mobile-nav__close{width:42px;height:42px;border:0;background:rgba(255,255,255,.08);color:#fff;font-size:1.7rem;border-radius:10px;cursor:pointer;line-height:1}
.mobile-nav a{display:block;padding:13px 6px;color:#d4dbe5;font-weight:600;border-bottom:1px solid rgba(255,255,255,.07)}
.mobile-nav a:hover{color:#fff}
.mobile-nav__sub a{padding-left:22px;font-size:.92rem;color:#9aa6b5}
body.menu-open .scrim{opacity:1;visibility:visible}
body.menu-open .mobile-nav{transform:translateX(0)}

/* =====================================================================
   HERO (AIDA — banner único)
   ===================================================================== */
.hero{position:relative;color:#fff;overflow:hidden;isolation:isolate}
.hero__bg{position:absolute;inset:0;z-index:-2}
.hero__bg img,.hero__bg video{width:100%;height:100%;object-fit:cover}
.hero::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(105deg,rgba(15,19,26,.96) 0%,rgba(16,21,30,.86) 42%,rgba(16,21,30,.50) 100%),
    linear-gradient(0deg,rgba(12,15,21,.7),transparent 60%);
}
.hero__inner{max-width:680px;padding:57px 0px 51px;}
.hero__badge{
  display:inline-flex;align-items:center;gap:9px;padding:8px 16px;border-radius:50px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);
  font-size:.82rem;font-weight:600;color:#e7ecf3;margin-bottom:22px;backdrop-filter:blur(6px);
}
.hero__badge svg{width:16px;height:16px;color:var(--red)}
.hero h1{color:#fff;font-size:clamp(2.1rem,3.2vw,3.5rem);line-height:1.06}
.hero h1 span{color:var(--red);position:relative;white-space:nowrap}
.hero__lead{margin-top:22px;font-size:clamp(1.04rem,1.6vw,1.2rem);color:#d3dae4;max-width:600px}
.hero__lead strong{color:#fff}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.hero__trust{display:flex;flex-wrap:wrap;gap:10px 26px;margin-top:38px;padding-top:30px;border-top:1px solid rgba(255,255,255,.13)}
.hero__trust li{display:flex;align-items:center;gap:10px;font-size:.92rem;color:#c6ceda;font-weight:500}
.hero__trust svg{width:20px;height:20px;color:var(--red);flex:none}

/* ---------- Faixa de números ---------- */
.stats{background:var(--ink-2);position:relative}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:42px 0}
.stats__item{text-align:center;padding:10px;position:relative}
.stats__item:not(:last-child)::after{content:"";position:absolute;right:-10px;top:14%;height:72%;width:1px;background:rgba(255,255,255,.1)}
.stats__num{font-size:clamp(1.7rem,3vw,2.4rem);font-weight:800;color:#fff;letter-spacing:-.02em}
.stats__num span{color:var(--red)}
.stats__label{margin-top:6px;color:#9aa6b5;font-size:.9rem}

/* =====================================================================
   SOBRE
   ===================================================================== */
.about__grid{display:grid;grid-template-columns:1.05fr 1fr;gap:60px;align-items:center}
.about__content h2{font-size:clamp(1.7rem,3.3vw,2.4rem)}
.about__content > p{margin-top:18px;color:var(--text-soft);font-size:1.05rem}
.about__list{margin:26px 0 30px;display:grid;gap:13px}
.about__list li{display:flex;gap:12px;align-items:flex-start;font-weight:500;color:var(--text)}
.about__list svg{width:24px;height:24px;color:#fff;background:var(--red);border-radius:7px;padding:4px;flex:none}
.about__media{position:relative}
.about__media-main{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg)}
.about__media-main img{width:100%;aspect-ratio:4/3.1;object-fit:cover}
.about__media-badge{
  position:absolute;left:-18px;bottom:-22px;background:var(--red);color:#fff;
  border-radius:14px;padding:16px 22px;box-shadow:0 16px 36px rgba(224,31,38,.36);text-align:center;
}
.about__media-badge strong{display:block;font-size:.78rem;font-weight:600;opacity:.9;letter-spacing:.06em;text-transform:uppercase}
.about__media-badge span{font-size:1.8rem;font-weight:800;line-height:1}
.about__media-deco{position:absolute;right:-16px;top:-16px;width:120px;height:120px;border:3px solid var(--blue);border-radius:16px;z-index:-1}

/* =====================================================================
   DEPOIMENTOS
   ===================================================================== */
.testimonials{margin-top:64px}
.testimonials__head{text-align:center;max-width:620px;margin:0 auto 36px}
.testimonials__head .eyebrow{justify-content:center}
.testimonials__head h3{font-size:clamp(1.4rem,2.6vw,1.9rem)}
.testimonials__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.testimonial{
  position:relative;display:flex;flex-direction:column;gap:16px;
  background:#fff;border-radius:18px;padding:30px 28px;
  transition:transform .26s var(--ease),box-shadow .26s var(--ease);
}
.testimonial:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
/* Borda com gradiente girando (Shine Border) */
@property --shine-angle{syntax:"<angle>";initial-value:0deg;inherits:false}
.testimonial::before{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:2px;pointer-events:none;
  background:conic-gradient(from var(--shine-angle,0deg),
    transparent 0deg, var(--blue) 55deg, var(--red) 150deg, var(--wa) 235deg, transparent 320deg);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask-composite:exclude;
  animation:shine-rotate 4s linear infinite;
}
.testimonial:hover::before{padding:2.5px}
@keyframes shine-rotate{to{--shine-angle:360deg}}
.testimonial__quote{position:absolute;right:22px;top:2px;font-family:Georgia,'Times New Roman',serif;font-size:5.2rem;line-height:1;color:var(--red-soft);pointer-events:none}
.testimonial__stars{display:flex;gap:3px;color:#f6b01e;position:relative;z-index:1}
.testimonial__stars svg{width:18px;height:18px;fill:currentColor}
.testimonial__text{color:var(--text-soft);font-size:1rem;line-height:1.75;position:relative;z-index:1}
.testimonial__name{display:flex;align-items:center;gap:10px;font-weight:700;color:var(--ink);margin-top:auto}
.testimonial__name::before{content:"";width:24px;height:2px;background:var(--red);border-radius:2px}
@media (max-width:900px){
  .testimonials__grid{grid-template-columns:1fr}
  .testimonials{margin-top:48px}
}

/* =====================================================================
   SERVIÇOS (cards)
   ===================================================================== */
.services{background:var(--bg-soft)}
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.service-card{
  position:relative;display:block;background:#fff;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);border:1px solid var(--line);transition:.28s var(--ease);
}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.service-card__media{position:relative;aspect-ratio:16/10;overflow:hidden}
.service-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.service-card:hover .service-card__media img{transform:scale(1.07)}
.service-card__media::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(15,19,26,.34),transparent 55%)}
.service-card__tag{
  position:absolute;left:14px;top:14px;z-index:2;background:var(--red);color:#fff;
  font-size:.74rem;font-weight:700;letter-spacing:.05em;padding:6px 12px;border-radius:50px;
}
.service-card__body{padding:22px 22px 24px}
.service-card__body h3{font-size:1.2rem}
.service-card__body p{margin-top:9px;color:var(--text-soft);font-size:.96rem}
.service-card__link{
  display:inline-flex;align-items:center;gap:8px;margin-top:16px;color:var(--red);
  font-weight:700;font-size:.92rem;transition:gap .2s var(--ease);
}
.service-card__link svg{width:17px;height:17px;transition:transform .2s var(--ease)}
.service-card:hover .service-card__link{gap:12px}
.service-card:hover .service-card__link svg{transform:translateX(3px)}

/* =====================================================================
   DIFERENCIAIS
   ===================================================================== */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.feature{
  position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 26px;transition:.26s var(--ease);overflow:hidden;
}
.feature:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:transparent}
.feature::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:var(--red);transition:width .3s var(--ease)}
.feature:hover::before{width:100%}
.feature__icon{
  display:grid;place-items:center;width:56px;height:56px;border-radius:14px;
  background:linear-gradient(135deg,var(--ink),var(--steel));color:#fff;margin-bottom:18px;
}
.feature__icon svg{width:26px;height:26px}
.feature h3{font-size:1.16rem}
.feature p{margin-top:10px;color:var(--text-soft);font-size:.96rem}

/* =====================================================================
   FAIXA CTA
   ===================================================================== */
.cta-band{position:relative;color:#fff;overflow:hidden;isolation:isolate}
.cta-band__bg{position:absolute;inset:0;z-index:-2}
.cta-band__bg img{width:100%;height:100%;object-fit:cover}
.cta-band::before{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(100deg,rgba(192,22,28,.95),rgba(16,21,30,.86))}
.cta-band__inner{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;padding:62px 0}
.cta-band__inner h2{color:#fff;font-size:clamp(1.6rem,3vw,2.2rem)}
.cta-band__inner p{margin-top:10px;color:#f1d8d9;font-size:1.06rem}

/* =====================================================================
   CONTATO / FORM
   ===================================================================== */
.contact{background:var(--ink);color:#fff;position:relative;overflow:hidden}
.contact::before{content:"";position:absolute;width:480px;height:480px;border-radius:50%;background:var(--red-soft);top:-160px;right:-120px;filter:blur(20px)}
.contact__grid{display:grid;grid-template-columns:1fr 1.05fr;gap:54px;align-items:start;position:relative}
.contact__info .eyebrow{color:#ff8086}
.contact__info .eyebrow::before{background:var(--red)}
.contact__info h2{color:#fff;font-size:clamp(1.7rem,3.2vw,2.4rem)}
.contact__info > p{margin-top:16px;color:#aeb8c6;font-size:1.05rem}
.contact-list{margin:30px 0 26px;display:grid;gap:6px}
.contact-list li{display:flex;gap:14px;align-items:flex-start;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.contact-list__icon{display:grid;place-items:center;width:44px;height:44px;border-radius:11px;background:rgba(255,255,255,.07);color:var(--red);flex:none}
.contact-list__icon svg{width:21px;height:21px}
.contact-list__txt{display:flex;flex-direction:column;gap:2px}
.contact-list__txt strong{color:#fff;font-size:.97rem}
.contact-list__txt a,.contact-list__txt span{color:#aeb8c6;font-size:.95rem}
.contact-list__txt a:hover{color:#fff}
.social-row{display:flex;gap:12px;margin-top:6px}
.social-row a{display:grid;place-items:center;width:44px;height:44px;border-radius:11px;background:rgba(255,255,255,.07);color:#fff;transition:.2s var(--ease)}
.social-row a:hover{background:var(--red);transform:translateY(-3px)}
.social-row svg{width:20px;height:20px}

/* Cartão do formulário */
.contact-card{background:#fff;border-radius:var(--radius);padding:34px;box-shadow:var(--shadow-lg);position:relative;color:var(--text)}
.contact-card__head h3{font-size:1.35rem}
.contact-card__head p{margin-top:7px;color:var(--text-soft);font-size:.95rem}
.form{margin-top:22px;display:grid;gap:16px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-size:.85rem;font-weight:600;color:var(--ink)}
.field .req{color:var(--red)}
.field input,.field textarea{
  width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:11px;
  font-family:inherit;font-size:.97rem;color:var(--text);background:var(--bg-soft);transition:.18s var(--ease);
}
.field input:focus,.field textarea:focus{
  outline:none;border-color:var(--red);background:#fff;box-shadow:0 0 0 4px var(--red-soft);
}
.field textarea{resize:vertical;min-height:120px}
.recaptcha-wrap{display:flex;justify-content:flex-start;min-height:78px}
.form .btn-submit{width:100%;margin-top:4px}
.form-error{
  display:none;background:#fdecec;border:1px solid #f6c4c6;color:#b81c22;
  padding:12px 15px;border-radius:11px;font-size:.9rem;font-weight:500;
}

/* Overlay de "carregando" */
.sending-overlay{
  position:absolute;inset:0;z-index:5;display:none;flex-direction:column;align-items:center;justify-content:center;
  gap:14px;background:rgba(255,255,255,.93);border-radius:var(--radius);backdrop-filter:blur(2px);text-align:center;padding:24px;
}
.sending-overlay.is-active{display:flex}
.sending-overlay__ring{width:56px;height:56px;border-radius:50%;border:4px solid var(--bg-mute);border-top-color:var(--red);animation:spin .8s linear infinite}
.sending-overlay strong{font-size:1.06rem;color:var(--ink)}
.sending-overlay span{font-size:.9rem;color:var(--text-soft)}
@keyframes spin{to{transform:rotate(360deg)}}
.btn-submit[data-loading]{opacity:.7;pointer-events:none}

/* =====================================================================
   FOOTER
   ===================================================================== */
.footer{background:var(--ink-2);color:#aeb8c6;padding:72px 0 0}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1.1fr;gap:44px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.08)}
.footer__brand img{height:56px;margin-bottom:18px;background:#fff;padding:8px 12px;border-radius:10px}
.footer__brand p{font-size:.95rem;line-height:1.7}
.footer h4{color:#fff;font-size:1.06rem;margin-bottom:18px}
.footer__list{display:grid;gap:11px}
.footer__list li{display:flex;gap:11px;align-items:flex-start;font-size:.94rem}
.footer__list svg{width:19px;height:19px;color:var(--red);flex:none;margin-top:2px}
.footer__list a:hover{color:#fff}
.footer__nav li a{display:flex;align-items:center;gap:8px;font-size:.94rem}
.footer__nav svg{width:16px;height:16px;color:var(--red)}
.footer__nav a:hover{color:#fff;padding-left:3px;transition:.18s}
.footer__map{margin-top:16px;border-radius:12px;overflow:hidden;display:block;border:1px solid rgba(255,255,255,.1)}
.footer__bottom{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;text-align:center;padding:22px 0}
.footer__bottom p{font-size:.88rem;color:var(--text-mute)}
.footer__bottom img{height:47px;opacity:1}

/* =====================================================================
   FLUTUANTES
   ===================================================================== */
.fab-whats{
  position:fixed;right:20px;bottom:20px;z-index:250;width:58px;height:58px;border-radius:50%;
  background:var(--wa);color:#fff;display:grid;place-items:center;box-shadow:0 12px 30px rgba(37,211,102,.45);
  animation:pulse 2.6s infinite;transition:.2s var(--ease);
}
.fab-whats:hover{transform:scale(1.07)}
.fab-whats svg{width:32px;height:32px}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 16px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}
.to-top{
  position:fixed;right:20px;bottom:86px;z-index:250;width:46px;height:46px;border-radius:12px;border:0;
  background:var(--ink);color:#fff;display:grid;place-items:center;cursor:pointer;opacity:0;visibility:hidden;
  transform:translateY(10px);transition:.25s var(--ease);
}
.to-top.is-visible{opacity:1;visibility:visible;transform:translateY(0)}
.to-top svg{width:22px;height:22px}

/* =====================================================================
   BANNER LGPD
   ===================================================================== */
.cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:400;max-width:760px;margin:0 auto;
  background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-lg);
  opacity:0;transform:translateY(18px);transition:.3s var(--ease)}
.cookie-banner.show{opacity:1;transform:translateY(0)}
.cookie-banner__inner{display:flex;align-items:center;gap:20px;padding:18px 20px;flex-wrap:wrap}
.cookie-banner__text{flex:1;min-width:240px}
.cookie-banner__text strong{display:block;color:var(--ink);font-size:.98rem;margin-bottom:3px}
.cookie-banner__text p{font-size:.86rem;color:var(--text-soft)}
.cookie-banner__text a{color:var(--red);font-weight:600}
.cookie-banner__actions{display:flex;gap:10px}
.cookie-btn{padding:11px 18px;border-radius:10px;font-weight:700;font-size:.88rem;cursor:pointer;border:1.5px solid transparent}
.cookie-btn--ghost{background:transparent;border-color:var(--line);color:var(--text)}
.cookie-btn--accept{background:var(--red);color:#fff}

/* =====================================================================
   PÁGINAS INTERNAS
   ===================================================================== */
.page-hero{position:relative;color:#fff;overflow:hidden;isolation:isolate;padding:32px 0 36px;}
.page-hero__bg{position:absolute;inset:0;z-index:-2}
.page-hero__bg img{width:100%;height:100%;object-fit:cover}
.page-hero::before{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(100deg,rgba(15,19,26,.96),rgba(16,21,30,.78) 60%,rgba(192,22,28,.45))}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:.86rem;color:#c6ceda;margin-bottom:16px;flex-wrap:wrap}
.breadcrumb a{color:#c6ceda}
.breadcrumb a:hover{color:#fff}
.breadcrumb svg{width:15px;height:15px;color:var(--red)}
.breadcrumb span{color:#fff;font-weight:600}
.page-hero h1{color:#fff;font-size:clamp(1.9rem,4.2vw,3rem);max-width:880px}
.page-hero__sub{margin-top:16px;font-size:clamp(1rem,1.5vw,1.15rem);color:#d3dae4;max-width:680px}

/* Conteúdo / prose */
.page-body{padding:80px 0}
.prose-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.prose-grid--reverse .prose-grid__media{order:-1}
.prose{color:var(--text)}
.prose .eyebrow{margin-bottom:12px}
.prose h2{font-size:clamp(1.5rem,2.8vw,2.1rem);margin-bottom:8px}
.prose h3{font-size:1.2rem;margin:24px 0 6px;color:var(--ink)}
.prose p{margin-top:14px;color:var(--text-soft);font-size:1.04rem;line-height:1.75}
.prose p strong{color:var(--ink)}
.prose .check-list{margin:20px 0 4px;display:grid;gap:12px}
.prose .check-list li{display:flex;gap:12px;align-items:flex-start;color:var(--text);font-weight:500}
.prose .check-list li::before{
  content:"";flex:none;width:19px;height:19px;border-radius:6px;margin-top:1px;
  background:var(--red) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/15px no-repeat;
}
.prose-grid__media{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg);position:relative}
.prose-grid__media img{width:100%;aspect-ratio:4/3.2;object-fit:cover}
.prose-actions{margin-top:30px;display:flex;flex-wrap:wrap;gap:14px}
.mt-block{margin-top:60px}

/* Cards de Missão/Visão/Valores */
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:8px}
.value-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;transition:.26s var(--ease)}
.value-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.value-card__icon{display:grid;place-items:center;width:54px;height:54px;border-radius:14px;background:linear-gradient(135deg,var(--ink),var(--steel));color:#fff;margin-bottom:16px}
.value-card__icon svg{width:25px;height:25px}
.value-card h3{font-size:1.18rem}
.value-card p{margin-top:9px;color:var(--text-soft);font-size:.97rem}

/* Galeria + Lightbox */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:2px}
.gallery--3{grid-template-columns:repeat(3,1fr)}
.gallery__item{
  position:relative;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;aspect-ratio:1/1;
  border:1px solid var(--line);background:var(--bg-mute);
}
.gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.gallery__item::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(15,19,26,.35),transparent 55%);opacity:0;transition:.25s var(--ease)}
.gallery__item::before{
  content:"";position:absolute;z-index:2;right:12px;bottom:12px;width:34px;height:34px;border-radius:9px;opacity:0;transform:scale(.7);
  background:var(--red) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M15 3h6v6M9 21H3v-6M21 3l-7 7M3 21l7-7'/%3E%3C/svg%3E") center/18px no-repeat;
  transition:.25s var(--ease);
}
.gallery__item:hover img{transform:scale(1.08)}
.gallery__item:hover::after{opacity:1}
.gallery__item:hover::before{opacity:1;transform:scale(1)}

.lightbox{
  position:fixed;inset:0;z-index:500;display:flex;align-items:center;justify-content:center;padding:24px;
  background:rgba(8,11,16,.92);opacity:0;visibility:hidden;transition:.28s var(--ease);backdrop-filter:blur(4px);
}
.lightbox.is-open{opacity:1;visibility:visible}
.lightbox__img{max-width:92vw;max-height:84vh;border-radius:12px;box-shadow:0 30px 80px rgba(0,0,0,.6);transform:scale(.94);transition:transform .28s var(--ease)}
.lightbox.is-open .lightbox__img{transform:scale(1)}
.lightbox__close,.lightbox__nav{
  position:absolute;width:52px;height:52px;border:0;border-radius:50%;background:rgba(255,255,255,.1);color:#fff;cursor:pointer;
  display:grid;place-items:center;transition:.2s var(--ease)
}
.lightbox__close:hover,.lightbox__nav:hover{background:var(--red)}
.lightbox__close{top:20px;right:20px;font-size:1.6rem}
.lightbox__close svg,.lightbox__nav svg{width:24px;height:24px}
.lightbox__nav{top:50%;transform:translateY(-50%)}
.lightbox__nav--prev{left:18px}
.lightbox__nav--next{right:18px}
.lightbox__counter{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);color:#cdd5e0;font-size:.9rem;font-weight:600}

@media (max-width:900px){
  .prose-grid{grid-template-columns:1fr;gap:34px}
  .prose-grid--reverse .prose-grid__media{order:0}
  .values-grid{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:680px){
  .page-hero{padding:54px 0 60px}
  .page-body{padding:56px 0}
  .gallery,.gallery--3{grid-template-columns:repeat(2,1fr);gap:2px}
  .lightbox__nav{width:44px;height:44px}
  .lightbox__nav--prev{left:8px}
  .lightbox__nav--next{right:8px}
}

/* =====================================================================
   GALERIA MARQUEE (scroll infinito automático)
   ===================================================================== */
.section-marquee{background:var(--ink);padding:74px 0 82px;position:relative;overflow:hidden}
.section-marquee::before{content:"";position:absolute;width:520px;height:520px;border-radius:50%;background:var(--red-soft);top:-220px;left:-160px;filter:blur(30px)}
.section-marquee .section-head{position:relative;z-index:1}
.section-marquee .section-head h2{color:#fff}
.section-marquee .section-head p{color:#aeb8c6}
.marquee{
  position:relative;width:100%;overflow:hidden;
  -webkit-mask:linear-gradient(90deg,transparent 0,#000 8%,#000 92%,transparent 100%);
  mask:linear-gradient(90deg,transparent 0,#000 8%,#000 92%,transparent 100%);
}
.marquee__track{display:flex;gap:6px;width:max-content;animation:marquee 48s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__item{
  position:relative;flex:0 0 auto;width:300px;height:220px;border-radius:14px;overflow:hidden;
  box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.08);
}
.marquee__item img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease),filter .4s var(--ease)}
.marquee__item::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(15,19,26,.55),transparent 55%);opacity:.7;transition:opacity .3s var(--ease)}
.marquee__item span{
  position:absolute;left:14px;bottom:12px;z-index:2;color:#fff;font-weight:700;font-size:.92rem;
  text-shadow:0 2px 8px rgba(0,0,0,.5);opacity:0;transform:translateY(6px);transition:.3s var(--ease);
}
.marquee__item:hover img{transform:scale(1.08);filter:brightness(1.08)}
.marquee__item:hover::after{opacity:1}
.marquee__item:hover span{opacity:1;transform:translateY(0)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* FAQ dentro da seção escura */
.faq{max-width:1060px;margin:58px auto 0;position:relative;z-index:1}
.faq__grid{display:grid;grid-template-columns:1fr 1fr;gap:0 26px;align-items:start}
.faq__col{display:flex;flex-direction:column}
.faq__item{
  border:1px solid rgba(255,255,255,.1);border-radius:14px;margin-bottom:12px;
  background:rgba(255,255,255,.03);overflow:hidden;transition:border-color .2s var(--ease),background .2s var(--ease);
}
.faq__item.is-open{border-color:rgba(224,31,38,.5);background:rgba(255,255,255,.05)}
.faq__q{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:19px 22px;background:none;border:0;color:#fff;font-weight:600;font-size:1.02rem;
  text-align:left;cursor:pointer;font-family:inherit;line-height:1.4;
}
.faq__icon{flex:none;width:26px;height:26px;border-radius:8px;background:var(--red);display:grid;place-items:center;position:relative}
.faq__icon::before,.faq__icon::after{content:"";position:absolute;background:#fff;border-radius:2px}
.faq__icon::before{width:12px;height:2px}
.faq__icon::after{width:2px;height:12px;transition:transform .25s var(--ease),opacity .25s var(--ease)}
.faq__item.is-open .faq__icon::after{transform:rotate(90deg);opacity:0}
.faq__a{max-height:0;overflow:hidden;transition:max-height .32s var(--ease)}
.faq__a-inner{padding:0 22px 20px;color:#aeb8c6;line-height:1.72;font-size:.98rem}
@media (max-width:760px){
  .faq__grid{grid-template-columns:1fr;gap:0}
}
@media (max-width:680px){
  .faq{margin-top:42px}
  .faq__q{font-size:.96rem;padding:16px 18px}
}
@media (max-width:680px){
  .marquee__track{gap:6px;animation-duration:36s}
  .marquee__item{width:220px;height:170px}
  .section-marquee{padding:56px 0 60px}
}
@media (prefers-reduced-motion:reduce){
  .marquee__track{animation:none;flex-wrap:wrap;justify-content:center;width:100%}
}

/* =====================================================================
   REVEAL (animações de entrada)
   ===================================================================== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.is-in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}

/* =====================================================================
   RESPONSIVO
   ===================================================================== */
@media (max-width:1024px){
  .header-feats{display:none}
  .about__grid{grid-template-columns:1fr;gap:46px}
  .about__media{max-width:520px;margin:0 auto}
  .contact__grid{grid-template-columns:1fr;gap:40px}
  .stats__grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .stats__item:nth-child(2)::after{display:none}
}
@media (max-width:900px){
  .nav,.nav-cta{display:none}
  .burger{display:block}
  .navbar__inner{justify-content:space-between;padding:10px 22px}
  .service-grid,.feature-grid{grid-template-columns:repeat(2,1fr)}
  .footer__grid{grid-template-columns:1fr 1fr}
}
@media (max-width:680px){
  .section{padding:62px 0}
  .header-top__inner{padding:10px 18px}
  .brand img{height:46px}
  .hero__inner{padding:78px 0 84px}
  .hero__actions{flex-direction:column;align-items:stretch}
  .hero__actions .btn-wa,.hero__actions .btn{width:100%}
  .service-grid,.feature-grid{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .contact-card{padding:24px}
  .footer__grid{grid-template-columns:1fr;gap:34px}
  .footer__bottom{justify-content:center;text-align:center}
  .cta-band__inner{flex-direction:column;align-items:flex-start}
  .stats__grid{grid-template-columns:1fr 1fr}
}

/* ---------- Utilitários / overrides sem inline ---------- */
.gtm-noscript{display:none;visibility:hidden}
.link-inherit{color:inherit}
.mobile-nav__brand{color:#fff;font-size:1.1rem;letter-spacing:.04em;font-weight:800}
.mobile-nav .btn-wa--block{margin-top:22px}

/* Página "obrigado" */
.navbar__inner--simple{justify-content:space-between;padding-top:10px;padding-bottom:10px}
.brand--chip{background:#fff;padding:6px 12px;border-radius:10px}
.brand--chip img{height:44px}
.hero--thanks{min-height:74vh;display:flex;align-items:center}
.hero__inner--center{max-width:680px;text-align:center;margin:0 auto;padding:80px 0}
.hero--thanks .hero__lead{margin-left:auto;margin-right:auto}
.hero--thanks .hero__actions{justify-content:center}
.success-badge{
  display:inline-flex;align-items:center;justify-content:center;width:92px;height:92px;border-radius:50%;
  background:rgba(37,211,102,.18);border:1px solid rgba(37,211,102,.5);margin:0 auto 26px;
}
.success-badge svg{width:46px;height:46px}
.footer--slim{padding-top:48px}
.footer--slim .footer__bottom{border-top:0}

/* Página 404 */
.error-badge{
  display:inline-flex;align-items:center;justify-content:center;width:92px;height:92px;border-radius:50%;
  background:rgba(224,31,38,.16);border:1px solid rgba(224,31,38,.5);margin:0 auto 26px;
  font-weight:800;font-size:1.6rem;letter-spacing:.03em;color:#ff7a7e;
}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}
