*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Work Sans",Arial,sans-serif;
  background:#151515;
  color:#171717;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
.container{
  width:min(1100px, calc(100% - 34px));
  margin:0 auto;
}
.topbar{
  position:fixed;
  z-index:50;
  top:0;
  left:0;
  right:0;
  height:73px;
  background:rgba(19,19,19,.94);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.header-wrap{
  height:73px;
  display:flex;
  align-items:center;
  gap:24px;
}
.logo{
  flex:0 0 auto;
}
.logo img{
  width:79px;
  height:auto;
}
.menu{
  margin-left:auto;
  display:flex;
  align-items:center;
  gap:13px;
}
.menu a{
  color:#fff;
  font-size:10px;
  font-weight:700;
  text-transform:uppercase;
  line-height:1;
  opacity:.94;
  white-space:nowrap;
}
.menu a:hover{color:#a68f6d}
.menu .social{
  width:17px;
  height:17px;
  border-radius:50%;
  background:#a68f6d;
  color:#151515;
  display:grid;
  place-items:center;
  font-size:10px;
}
.whats-mini{
  border:1px solid #a68f6d;
  border-radius:10px;
  padding:6px 9px;
}
.menu-btn{
  display:none;
  width:38px;
  height:38px;
  margin-left:auto;
  border:0;
  background:transparent;
}
.menu-btn span{
  display:block;
  width:24px;
  height:2px;
  background:#fff;
  margin:5px auto;
}
.hero{
  position:relative;
  min-height:610px;
  padding-top:73px;
  background:
    linear-gradient(90deg, rgba(22,21,22,.88) 0%, rgba(22,21,22,.82) 48%, rgba(116,96,65,.65) 100%),
    url("https://acseg.com.br/wp-content/uploads/2022/10/banner-principal-fundo-1080.jpg") center/cover no-repeat;
  overflow:hidden;
}
.hero-inner{
  min-height:537px;
  display:grid;
  grid-template-columns:1fr 430px;
  align-items:center;
  gap:20px;
}
.hero-text{
  max-width:570px;
}
.hero h1{
  margin:0 0 16px;
  color:#fff;
  font-size:38px;
  line-height:1.03;
  letter-spacing:.025em;
  font-weight:900;
  text-transform:uppercase;
}
.hero p{
  width:430px;
  color:#fff;
  font-size:13px;
  line-height:1.55;
  margin:0 0 20px;
}
.btn{
  display:inline-flex;
  height:32px;
  align-items:center;
  justify-content:center;
  padding:0 17px;
  background:#a68f6d;
  color:#fff;
  font-size:10px;
  font-weight:800;
  text-transform:uppercase;
  border-radius:2px;
  border:0;
  cursor:pointer;
}
.btn-dark{background:#161516;margin-left:8px}
.hero-phone{
  position:relative;
  height:480px;
  display:flex;
  align-items:flex-end;
  justify-content:center;
}
.hero-phone > img{
  max-height:430px;
  object-fit:contain;
}
.recovery-badge{
  position:absolute;
  left:20px;
  bottom:150px;
  width:116px;
  background:#fff;
  padding:10px 12px;
  box-shadow:0 10px 22px rgba(0,0,0,.18);
}
.recovery-badge strong{
  display:block;
  color:#a68f6d;
  font-size:28px;
  line-height:1;
}
.recovery-badge span{
  display:block;
  color:#111;
  font-size:8px;
  line-height:1.25;
  text-transform:uppercase;
  font-weight:800;
}
.slider-dots{
  position:absolute;
  left:50%;
  bottom:22px;
  transform:translateX(-50%);
}
.slider-dots span{
  display:inline-block;
  width:6px;
  height:6px;
  margin:0 4px;
  border-radius:50%;
  background:#fff;
  opacity:.75;
}
.section-dark{background:#151516;color:#fff}
.section-gold{background:#a68f6d;color:#111}
.about{
  padding:58px 0;
}
.about-inner{
  display:grid;
  grid-template-columns:1fr 220px;
  align-items:center;
  gap:70px;
}
.about-copy small,
.section-heading small,
.benefits-copy small{
  display:block;
  font-size:10px;
  line-height:1;
  margin-bottom:10px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#a68f6d;
}
.about-copy h2{
  margin:0 0 12px;
  font-size:28px;
  line-height:1;
  color:#fff;
}
.about-copy p{
  width:620px;
  max-width:100%;
  margin:0;
  color:#fff;
  font-size:15px;
  line-height:1.75;
}
.about-logo{
  width:150px;
  justify-self:center;
}
.differentials{
  padding:58px 0 66px;
}
.section-heading{
  text-align:center;
  margin-bottom:38px;
}
.section-heading small{
  color:rgba(0,0,0,.56);
  margin-bottom:8px;
}
.section-heading h2{
  margin:0;
  font-size:30px;
  line-height:1.08;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.025em;
}
.diff-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
  max-width:860px;
  margin:0 auto;
}
.diff-card{
  background:#f6f4f0;
  border-radius:7px;
  min-height:122px;
  padding:20px 13px 15px;
  text-align:center;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
}
.diff-card img{
  height:39px;
  object-fit:contain;
  margin-bottom:10px;
}
.diff-card p{
  margin:0;
  font-size:11px;
  line-height:1.35;
  font-weight:700;
  color:#111;
}
.benefits{
  min-height:445px;
  background:
    linear-gradient(90deg, #121213 0%, #121213 45%, rgba(18,18,19,.15) 100%),
    url("https://acseg.com.br/wp-content/uploads/2022/09/bg-beneficios-ok.jpg") center/cover no-repeat;
  color:#fff;
}
.benefits-inner{
  min-height:445px;
  display:grid;
  grid-template-columns:1fr 430px;
  align-items:center;
  gap:30px;
}
.benefits-copy small{color:#a68f6d}
.benefits-copy h2{
  margin:0 0 26px;
  color:#fff;
  max-width:470px;
  font-size:36px;
  line-height:1.04;
  font-weight:900;
  text-transform:uppercase;
}
.benefit-line{
  display:grid;
  grid-template-columns:33px 1fr;
  align-items:center;
  gap:14px;
  margin-bottom:14px;
  max-width:535px;
}
.benefit-line img{
  width:30px;
  max-height:32px;
  object-fit:contain;
}
.benefit-line p{
  margin:0;
  font-size:13px;
  line-height:1.4;
  font-weight:600;
}
.benefits-copy .btn{margin-top:12px}
.benefits-phone{
  max-height:330px;
  justify-self:center;
}
.numbers{
  padding:58px 0 64px;
}
.numbers .section-heading strong{
  display:inline-block;
  margin-top:20px;
  font-size:15px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.06em;
  background:rgba(0,0,0,.14);
  padding:8px 24px;
  border-radius:2px;
}
.numbers-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  max-width:850px;
  margin:0 auto;
}
.number-box{
  text-align:center;
  color:#111;
}
.number-box img{
  width:110px;
  height:110px;
  object-fit:contain;
  margin:0 auto 4px;
}
.number-box b{
  display:block;
  font-size:42px;
  line-height:.8;
  font-weight:700;
}
.number-box strong{
  display:block;
  font-size:24px;
  line-height:1.1;
  font-weight:800;
}
.number-box span{
  display:block;
  margin-top:5px;
  font-size:13px;
  text-transform:uppercase;
  font-weight:800;
}
.protect{
  min-height:340px;
  background:
    linear-gradient(90deg, rgba(17,17,17,.15) 0%, rgba(17,17,17,.35) 40%, rgba(255,255,255,.86) 100%),
    url("https://acseg.com.br/wp-content/uploads/2022/09/banner-proteja-seu-veiculo.jpg") center/cover no-repeat;
}
.protect-inner{
  min-height:340px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:flex-end;
  text-align:left;
}
.protect h2{
  width:360px;
  margin:0 0 12px;
  font-size:28px;
  line-height:1.02;
  font-weight:900;
  text-transform:uppercase;
}
.protect p{
  width:360px;
  margin:0 0 18px;
  font-size:13px;
  line-height:1.5;
}
.protect .btn{
  align-self:auto;
  margin-right:250px;
}
.equipments{
  padding:56px 0 66px;
  text-align:center;
}
.section-heading.light small,
.section-heading.light h2{color:#fff}
.equipments .section-heading h2{
  max-width:820px;
  margin:0 auto;
  font-size:27px;
}
.equipment-block{
  max-width:970px;
  margin:36px auto 48px;
  color:#fff;
}
.equipment-block > img{
  height:58px;
  margin:0 auto 8px;
  object-fit:contain;
}
.equipment-block h3{
  margin:0 0 16px;
  color:#a68f6d;
  font-size:26px;
  font-weight:500;
}
.equipment-block p{
  margin:10px auto;
  max-width:850px;
  font-size:14px;
  line-height:1.55;
}
.equipment-block h4{
  margin:26px 0 18px;
  color:#fff;
  font-size:13px;
  text-transform:uppercase;
  font-weight:900;
}
.advantages{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:10px;
}
.advantages div{
  min-height:118px;
  background:#a68f6d;
  color:#111;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  padding:14px 10px;
}
.advantages.light-boxes div{background:#f4f4f4}
.advantages img{
  height:42px;
  object-fit:contain;
  margin-bottom:10px;
}
.advantages span{
  font-size:11px;
  font-weight:800;
  line-height:1.35;
  text-align:center;
  text-transform:uppercase;
  letter-spacing:.025em;
}
.advantages svg{
  display:block;
  margin:0 auto 10px;
  pointer-events:none;
}
.prices{
  background:#242424;
  padding:58px 0 50px;
  color:#fff;
}
.price-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
  max-width:1030px;
  margin:0 auto;
}
.plan{
  background:#fff;
  color:#111;
  min-height:580px;
  padding:24px 14px 18px;
  text-align:center;
  display:flex;
  flex-direction:column;
}
.plan img{
  height:42px;
  object-fit:contain;
  margin:0 auto 12px;
}
.plan h3{
  margin:0 0 8px;
  min-height:36px;
  font-size:13px;
  line-height:1.2;
  font-weight:900;
  text-transform:uppercase;
}
.plan small{
  color:#777;
  font-size:10px;
  font-weight:700;
}
.price{
  color:#111;
  font-size:31px;
  line-height:1;
  font-weight:900;
  margin-top:4px;
}
.price span{
  font-size:12px;
  vertical-align:super;
}
.price sup{font-size:14px}
.plan em{
  font-style:normal;
  font-size:9px;
  color:#777;
  margin-bottom:12px;
}
.plan ul{
  list-style:none;
  margin:0 0 12px;
  padding:0;
  flex:1;
}
.plan li{
  padding:8px 4px;
  border-top:1px solid #e7e7e7;
  font-size:10px;
  line-height:1.25;
  color:#111;
}
.plan a{
  display:block;
  height:27px;
  line-height:27px;
  background:#a68f6d;
  color:#fff;
  font-family:inherit;
  font-size:9px;
  font-weight:900;
  letter-spacing:.05em;
  text-transform:uppercase;
}
.price-note{
  max-width:980px;
  margin:24px auto 0;
  text-align:center;
  color:#d0d0d0;
  font-size:10px;
  line-height:1.5;
}
.payment{
  background:#151515;
  padding:45px 0;
}
.payment-box{
  max-width:860px;
  min-height:72px;
  background:#272727;
  color:#fff;
  display:grid;
  grid-template-columns:70px 1fr 150px;
  gap:18px;
  align-items:center;
  padding:18px 28px;
}
.payment-box img{width:52px}
.payment-box h3{
  margin:0;
  font-size:17px;
  text-transform:uppercase;
}
.payment-box p{
  margin:3px 0 0;
  font-size:12px;
  color:#e8e8e8;
}
.contact{
  background:#fff;
  padding:60px 0 66px;
}
.contact .section-heading{
  max-width:800px;
  margin-left:auto;
  margin-right:auto;
  margin-bottom:36px;
}
.contact .section-heading h2{font-size:32px}
.contact .section-heading p{
  max-width:720px;
  margin:12px auto 0;
  font-size:14px;
  line-height:1.55;
}
.contact-form{
  max-width:650px;
  margin:0 auto;
  background:#101010;
  padding:22px;
}
.contact-form .row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.contact-form input,
.contact-form textarea{
  width:100%;
  border:0;
  height:38px;
  margin-bottom:12px;
  padding:0 12px;
  font-family:inherit;
  font-size:13px;
}
.contact-form textarea{
  height:150px;
  padding-top:12px;
  resize:vertical;
}
.policy{
  display:grid;
  grid-template-columns:16px 1fr;
  gap:8px;
  color:#fff;
  font-size:11px;
  line-height:1.45;
  margin-bottom:14px;
}
.policy input{
  height:auto;
  margin:2px 0 0;
}
.contact-form button{
  width:100%;
  height:36px;
  border:0;
  background:#a68f6d;
  color:#fff;
  text-transform:uppercase;
  font-family:inherit;
  font-size:13px;
  font-weight:900;
  letter-spacing:.05em;
  cursor:pointer;
}
.contact-icons{
  background:#151516;
  color:#fff;
  padding:64px 0;
}
.icon-row{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:30px;
  text-align:center;
}
.icon-circle{
  width:90px;
  height:90px;
  border-radius:50%;
  border:7px solid #a68f6d;
  background:#fff;
  display:grid;
  place-items:center;
  margin:0 auto 20px;
  color:#a68f6d;
  transition:transform .25s ease, box-shadow .25s ease;
}
.icon-circle svg{
  display:block;
  pointer-events:none;
}
.icon-row div:hover .icon-circle{
  transform:scale(1.06);
  box-shadow:0 8px 28px rgba(0,0,0,.3);
}
.icon-row p{
  margin:0;
  color:#a68f6d;
  font-size:13px;
  line-height:1.5;
}
.faq-section{
  background:#eee9df;
  padding:56px 0 68px;
}
.faq-list{
  max-width:720px;
  margin:0 auto;
}
.faq-list details{
  background:#fff;
  margin-bottom:6px;
  border:1px solid #d9d5cc;
}
.faq-list summary{
  display:grid;
  grid-template-columns:42px 1fr 18px;
  align-items:center;
  min-height:42px;
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  cursor:pointer;
  list-style:none;
}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary span{
  height:100%;
  min-height:42px;
  background:#a68f6d;
  display:grid;
  place-items:center;
  margin-right:14px;
  color:#111;
}
.faq-list summary:after{
  content:"+";
  color:#a68f6d;
}
.faq-list details[open] summary:after{content:"-"}
.faq-list p{
  margin:0;
  padding:0 24px 18px 56px;
  font-size:13px;
  line-height:1.6;
  color:#555;
}
.footer{
  background:#191a20;
  color:#fff;
}
.footer-grid{
  padding:52px 0;
  display:grid;
  grid-template-columns:110px 1fr 1fr 140px;
  gap:38px;
  align-items:start;
}
.footer-logo img{
  width:110px;
}
.footer p,
.footer-about p{
  display:block;
  color:#a68f6d;
  font-size:12px;
  line-height:1.7;
  margin:3px 0;
}
.footer b{
  color:#d6d6d6;
  font-weight:600;
}
.footer h4{
  color:#fff;
  font-size:13px;
  font-weight:700;
  margin:0 0 14px;
}
.footer-about p{
  padding-top:4px;
}
.copyright{
  background:#a68f6d;
  color:#111;
  text-align:center;
  font-size:12px;
  padding:16px;
}
.float-whats{
  position:fixed;
  right:18px;
  bottom:18px;
  width:42px;
  height:42px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:#25d366;
  color:#fff;
  z-index:60;
  font-size:18px;
}
@media (max-width:1050px){
  .topbar{height:68px}
  .header-wrap{height:68px}
  .logo img{width:70px}
  .menu-btn{display:block}
  .menu{
    display:none;
    position:absolute;
    left:0;
    right:0;
    top:68px;
    background:#151515;
    padding:12px 17px;
    flex-direction:column;
    align-items:flex-start;
    gap:0;
    border-top:1px solid rgba(255,255,255,.08);
  }
  .menu.open{display:flex}
  .menu a{
    width:100%;
    padding:11px 0;
    border-bottom:1px solid rgba(255,255,255,.07);
    font-size:12px;
  }
  .menu .social{
    display:inline-grid;
    width:24px;
    height:24px;
    padding:0;
    margin-top:8px;
    border:0;
  }
  .whats-mini{
    width:auto!important;
    padding:10px 12px!important;
    border:1px solid #a68f6d!important;
    border-radius:0;
    margin-top:8px;
  }
  .hero{
    padding-top:68px;
  }
  .hero-inner{
    grid-template-columns:1fr 330px;
  }
  .hero h1{font-size:32px}
  .hero p{width:auto}
  .price-grid{grid-template-columns:repeat(3,1fr)}
  .plan{min-height:auto}
}
@media (max-width:780px){
  .container{width:min(100% - 28px, 1100px)}
  .hero{min-height:auto}
  .hero-inner{
    min-height:0;
    grid-template-columns:1fr;
    padding:56px 0 40px;
  }
  .hero-text{text-align:left}
  .hero h1{font-size:29px}
  .hero-phone{
    height:340px;
  }
  .hero-phone > img{
    max-height:330px;
  }
  .recovery-badge{display:none}
  .about-inner,
  .benefits-inner,
  .payment-box{
    grid-template-columns:1fr;
  }
  .footer-grid{
    grid-template-columns:1fr 1fr;
    gap:28px;
  }
  .footer-logo img{
    width:90px;
  }
  .about-logo{
    justify-self:start;
  }
  .diff-grid,
  .numbers-grid,
  .advantages,
  .icon-row{
    grid-template-columns:repeat(2,1fr);
  }
  .benefits-inner{padding:56px 0}
  .benefits-phone{display:none}
  .protect-inner{
    align-items:flex-start;
  }
  .protect .btn{margin-right:0}
  .price-grid{grid-template-columns:repeat(2,1fr)}
  .contact-form .row{grid-template-columns:1fr}
}
@media (max-width:520px){
  .hero h1{font-size:25px}
  .btn-dark{margin-left:0;margin-top:8px}
  .hero-buttons .btn{width:100%;margin-bottom:8px}
  .section-heading h2,
  .benefits-copy h2,
  .contact .section-heading h2{
    font-size:24px;
  }
  .diff-grid,
  .numbers-grid,
  .advantages,
  .price-grid,
  .icon-row{
    grid-template-columns:1fr;
  }
  .protect h2,
  .protect p{
    width:100%;
  }
  .payment-box{text-align:center}
  .payment-box img{margin:0 auto}
  .footer-grid{grid-template-columns:1fr;gap:20px}
}


/* ===========================
   VIDA / OTIMIZAÇÃO V4
   =========================== */

.topbar{
  height:64px;
  transition:height .25s ease, background .25s ease, box-shadow .25s ease;
}

.topbar.scrolled{
  height:58px;
  background:rgba(17,17,17,.98);
  box-shadow:0 12px 28px rgba(0,0,0,.18);
}

.header-wrap{
  height:64px;
  transition:height .25s ease;
}

.topbar.scrolled .header-wrap{
  height:58px;
}

.logo img{
  width:64px;
  max-height:54px;
  object-fit:contain;
  transition:width .25s ease, max-height .25s ease, transform .25s ease;
}

.topbar.scrolled .logo img{
  width:56px;
  max-height:48px;
}

.logo:hover img{
  transform:scale(1.04);
}

.menu{
  gap:11px;
}

.menu a{
  font-size:9px;
  letter-spacing:.025em;
  transition:color .2s ease, opacity .2s ease;
}

.menu a:not(.social):not(.whats-mini){
  position:relative;
}

.menu a:not(.social):not(.whats-mini)::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-9px;
  width:0;
  height:2px;
  background:#a68f6d;
  transition:width .25s ease;
}

.menu a:not(.social):not(.whats-mini):hover::after{
  width:100%;
}

.whats-mini{
  padding:5px 8px;
  transition:background .2s ease, color .2s ease;
}

.whats-mini:hover{
  background:#a68f6d;
  color:#151515;
}

.hero{
  min-height:610px;
  padding-top:64px;
  background:#151516;
}

.hero.carousel{
  position:relative;
}

.hero-slide{
  position:absolute;
  inset:0;
  opacity:0;
  pointer-events:none;
  transition:opacity .75s ease, transform .75s ease;
  transform:scale(1.01);
  background:
    linear-gradient(90deg, rgba(22,21,22,.9) 0%, rgba(22,21,22,.82) 48%, rgba(116,96,65,.68) 100%),
    url("https://acseg.com.br/wp-content/uploads/2022/10/banner-principal-fundo-1080.jpg") center/cover no-repeat;
}

.hero-slide.active{
  opacity:1;
  pointer-events:auto;
  transform:scale(1);
}

.hero-slide.slide-two{
  background:
    linear-gradient(90deg, rgba(21,21,21,.86) 0%, rgba(21,21,21,.55) 45%, rgba(21,21,21,.28) 100%),
    url("https://acseg.com.br/wp-content/uploads/2023/05/banner-dois-acseg.jpg") center/cover no-repeat;
}

.hero-inner{
  min-height:546px;
}

.hero-inner-centered{
  grid-template-columns:1fr;
  justify-items:center;
}

.hero-inner-centered .hero-text{
  max-width:520px;
  text-align:center;
}

.hero-inner-centered .hero-buttons{
  display:flex;
  align-items:center;
  justify-content:center;
}

.hero-inner-centered .hero-text p{
  width:auto;
  max-width:480px;
  margin-left:auto;
  margin-right:auto;
}

.hero-inner-centered .price-seal{
  margin-left:auto;
  margin-right:auto;
}

.hero h1{
  font-size:36px;
}

.hero-phone{
  animation:floatPhone 4.8s ease-in-out infinite;
}

@keyframes floatPhone{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-10px)}
}

.price-seal{
  width:116px;
  height:116px;
  border-radius:50%;
  background:#a68f6d;
  color:#111;
  display:grid;
  place-items:center;
  text-align:center;
  font-size:13px;
  line-height:1.25;
  font-weight:700;
  margin-bottom:22px;
  box-shadow:0 18px 30px rgba(0,0,0,.22);
}

.price-seal b{
  display:block;
  font-size:18px;
}

.carousel-arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  z-index:5;
  width:42px;
  height:42px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.32);
  background:rgba(0,0,0,.28);
  color:#fff;
  font-size:34px;
  line-height:1;
  cursor:pointer;
  transition:background .2s ease, transform .2s ease, border-color .2s ease;
}

.carousel-arrow:hover{
  background:#a68f6d;
  border-color:#a68f6d;
  transform:translateY(-50%) scale(1.05);
}

.carousel-arrow.prev{
  left:24px;
}

.carousel-arrow.next{
  right:24px;
}

.slider-dots button{
  width:7px;
  height:7px;
  margin:0 5px;
  border:0;
  border-radius:50%;
  padding:0;
  background:#fff;
  opacity:.48;
  cursor:pointer;
  transition:opacity .2s ease, transform .2s ease, background .2s ease;
}

.slider-dots button.active{
  opacity:1;
  background:#a68f6d;
  transform:scale(1.25);
}

.slider-dots span{
  display:none;
}

.reveal,
.reveal-section,
.reveal-card{
  opacity:0;
  transform:translateY(26px);
  transition:opacity .75s ease, transform .75s ease;
}

.reveal.visible,
.reveal-section.visible,
.reveal-card.visible{
  opacity:1;
  transform:translateY(0);
}

.delay-1{
  transition-delay:.15s;
}

.diff-card,
.number-box,
.plan,
.equipment-block,
.payment-box,
.contact-form,
.faq-list details{
  transition:opacity .75s ease, transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.diff-card:hover,
.plan:hover,
.payment-box:hover,
.contact-form:hover,
.faq-list details:hover{
  transform:translateY(-5px);
  box-shadow:0 18px 38px rgba(0,0,0,.20);
}

.number-box:hover{
  transform:translateY(-5px);
}

.plan{
  position:relative;
  overflow:hidden;
}

.plan::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:3px;
  background:#a68f6d;
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .25s ease;
}

.plan:hover::before{
  transform:scaleX(1);
}

.plan a,
.btn,
.contact-form button{
  transition:background .2s ease, transform .2s ease, color .2s ease;
}

.plan a:hover,
.btn:hover,
.contact-form button:hover{
  background:#8f7a58;
  transform:translateY(-2px);
}

.benefit-line img,
.diff-card img,
.advantages img{
  transition:transform .25s ease;
}

.benefit-line:hover img,
.diff-card:hover img,
.advantages div:hover img{
  transform:scale(1.08);
}

.advantages div{
  transition:transform .25s ease, background .25s ease;
}

.advantages div:hover{
  transform:translateY(-4px);
  background:#bba37b;
}

.float-whats{
  animation:pulseWhats 1.8s ease-in-out infinite;
}

@keyframes pulseWhats{
  0%,100%{box-shadow:0 0 0 0 rgba(37,211,102,.45)}
  50%{box-shadow:0 0 0 12px rgba(37,211,102,0)}
}

/* Scroll offset para o header fixo */
section[id]{
  scroll-margin-top:64px;
}

/* SVG icons no menu e botão flutuante */
.menu .social svg,
.float-whats svg{
  display:block;
  pointer-events:none;
}

/* Evitar animação de hover no formulário enquanto o usuário digita */
.contact-form:focus-within{
  transform:none!important;
  box-shadow:none!important;
}

/* Feedback de campo inválido */
.contact-form .field-error{
  outline:2px solid #a68f6d!important;
}

/* Mensagem de status do formulário */
.form-status{
  display:none;
  width:100%;
  padding:10px;
  margin-top:8px;
  text-align:center;
  font-size:13px;
  font-weight:700;
  color:#fff;
  background:#4a7c59;
}

@media (max-width:1100px){
  .topbar,
  .header-wrap{
    height:64px;
  }

  .topbar.scrolled,
  .topbar.scrolled .header-wrap{
    height:58px;
  }

  .logo img{
    width:58px;
    max-height:50px;
  }

  .menu{
    top:64px;
  }

  .topbar.scrolled .menu{
    top:58px;
  }

  .hero{
    padding-top:64px;
  }

  .carousel-arrow{
    display:none;
  }
}

@media (max-width:780px){
  .hero{
    min-height:560px;
  }

  .hero-slide{
    position:absolute;
  }

  .hero-inner{
    min-height:496px;
    padding:42px 0 38px;
  }

  .hero h1{
    font-size:27px;
  }

  .hero-phone{
    height:275px;
  }

  .hero-phone > img{
    max-height:285px;
  }

  .price-seal{
    width:92px;
    height:92px;
    font-size:11px;
  }

  .price-seal b{
    font-size:15px;
  }
}

@media (max-width:520px){
  .topbar,
  .header-wrap{
    height:58px;
  }

  .logo img{
    width:50px;
    max-height:44px;
  }

  .menu{
    top:58px;
  }

  .hero{
    min-height:545px;
    padding-top:58px;
  }

  .hero-inner{
    min-height:487px;
  }

  .hero h1{
    font-size:24px;
  }

  .hero p{
    font-size:12px;
  }

  .hero-phone{
    height:235px;
  }

  .hero-phone > img{
    max-height:245px;
  }
}

/* Footer social icon circles */
.footer-social-icons{
  display:flex;
  gap:10px;
  margin-top:4px;
}
.footer-social-btn{
  width:30px;
  height:30px;
  border-radius:50%;
  background:#a68f6d;
  color:#151515;
  display:grid;
  place-items:center;
  transition:background .2s ease, transform .2s ease;
}
.footer-social-btn:hover{
  background:#8f7a58;
  transform:scale(1.08);
}
.footer-social-btn svg{
  display:block;
  pointer-events:none;
}

/* ── Prices section heading ── */
.prices .section-heading h2{
  color:#a68f6d;
  text-transform:none;
  font-weight:500;
  font-size:28px;
  letter-spacing:.01em;
}
.prices .section-heading small{
  opacity:.6;
}

/* ── Plan cards — alternating white / gold ── */
.plan:nth-child(even){
  background:#a68f6d;
}

/* White cards: gold list items */
.plan:nth-child(odd) li{
  color:#a68f6d;
}

/* Gold cards: dark text, adjusted dividers and button */
.plan:nth-child(even) li{
  color:#111;
  border-top-color:rgba(0,0,0,.12);
}
.plan:nth-child(even) small,
.plan:nth-child(even) em{
  color:rgba(0,0,0,.5);
}
.plan:nth-child(even) a{
  background:#111;
}
.plan:nth-child(even) a:hover{
  background:#333;
  transform:translateY(-2px);
}
.plan:nth-child(even)::before{
  background:rgba(0,0,0,.3);
}

/* ═══════════════════════════════════════════════
   REFINAMENTO ESTÉTICO v5 — Acabamento visual
   ═══════════════════════════════════════════════ */

/* ── Botões ── */
.btn{
  border-radius:6px;
  letter-spacing:.04em;
  transition:background .2s ease, transform .2s ease, box-shadow .2s ease, color .2s ease;
}
.btn:hover{
  box-shadow:0 6px 18px rgba(0,0,0,.18);
}
.contact-form button{
  border-radius:0 0 8px 8px;
  transition:background .2s ease, transform .2s ease, box-shadow .2s ease;
}
.contact-form button:hover{
  box-shadow:0 6px 14px rgba(0,0,0,.16);
}

/* ── Cards de diferenciais ── */
.diff-card{
  border-radius:10px;
  box-shadow:0 2px 10px rgba(0,0,0,.06);
}
.diff-card:hover{
  transform:translateY(-4px);
  box-shadow:0 12px 28px rgba(0,0,0,.14);
}

/* ── Vantagens dos equipamentos ── */
.advantages div{
  border-radius:8px;
}

/* ── Números: hover suave ── */
.number-box:hover{
  transform:translateY(-4px);
}

/* ── Cards de planos ── */
.plan{
  border-radius:10px;
  box-shadow:0 4px 18px rgba(0,0,0,.1);
}
.plan:hover{
  transform:translateY(-4px);
  box-shadow:0 14px 34px rgba(0,0,0,.2);
}

/* ── Box de pagamento ── */
.payment-box{
  border-radius:10px;
  box-shadow:0 4px 18px rgba(0,0,0,.1);
}
.payment-box:hover{
  transform:translateY(-4px);
  box-shadow:0 12px 28px rgba(0,0,0,.2);
}

/* ── Formulário ── */
.contact-form{
  border-radius:10px;
}
.contact-form input,
.contact-form textarea{
  border-radius:5px;
}

/* ── FAQ accordion ── */
.faq-list details{
  border-radius:8px;
  overflow:hidden;
  margin-bottom:8px;
  box-shadow:0 1px 6px rgba(0,0,0,.05);
}
.faq-list details:hover{
  transform:translateY(-2px);
  box-shadow:0 6px 16px rgba(0,0,0,.1);
}

/* ── Recovery badge ── */
.recovery-badge{
  border-radius:6px;
}

/* ── Ícones de contato ── */
.icon-circle{
  box-shadow:0 4px 16px rgba(0,0,0,.14);
}

/* ── Carousel: seta menor, dot ativo em pílula ── */
.carousel-arrow{
  font-size:26px;
}
.slider-dots button{
  transition:opacity .2s ease, transform .2s ease, background .2s ease,
             width .25s ease, border-radius .25s ease;
}
.slider-dots button.active{
  width:20px;
  border-radius:4px;
  transform:scale(1);
}

/* ── Menu mobile: fade + deslize ── */
@media (max-width:1050px){
  .menu{
    display:flex;
    opacity:0;
    transform:translateY(-6px);
    pointer-events:none;
    transition:opacity .25s ease, transform .25s ease;
  }
  .menu.open{
    opacity:1;
    transform:translateY(0);
    pointer-events:auto;
  }
  .menu a{
    transition:color .2s ease, background .2s ease;
  }
  .menu a:hover{
    background:rgba(255,255,255,.04);
  }
}


/* ══════════════════════════════════════════════════════════════
   RESPONSIVIDADE COMPLETA v6 — adicionado sobre estrutura original
   Nenhum seletor original foi alterado; apenas overrides abaixo.
   ══════════════════════════════════════════════════════════════ */

/* ──────────────────────────────────────────────────────────────
   ≤ 1050px  Tablet landscape / laptop pequeno
   ────────────────────────────────────────────────────────────── */
@media (max-width: 1050px) {

  /* Protect: remover larguras fixas e margin-right problemática */
  .protect h2,
  .protect p       { width: 100%; max-width: 400px; }
  .protect .btn    { margin-right: 0; }
  .protect-inner   { padding: 52px 0; }

  /* Advantages: 2 colunas no tablet */
  .advantages { grid-template-columns: repeat(2, 1fr); }

  /* Payment box: ajusta proporção */
  .payment-box { grid-template-columns: 60px 1fr auto; gap: 16px; }

  /* Hero paragraph: garante que não ultrapasse a janela */
  .hero p { width: 100%; max-width: 480px; }
}

/* ──────────────────────────────────────────────────────────────
   ≤ 780px  Tablet portrait / mobile landscape
   ────────────────────────────────────────────────────────────── */
@media (max-width: 780px) {

  /* ── Hero carousel: corrige colapso causado por position:absolute ──
     O slide ativo vira in-flow (relative) para o hero ter altura.
     Slides inativos permanecem absolute; a transição de opacidade
     continua funcionando normalmente.                              */
  .hero-slide {
    position: absolute !important;
    inset: 0 !important;
  }
  .hero-slide.active {
    position: relative !important;
    inset: auto !important;
    width: 100%;
  }
  .hero.carousel { min-height: unset; overflow: hidden; }

  /* ── Hero inner: garante coluna única e padding adequado ── */
  .hero-inner {
    display:               grid;
    grid-template-columns: 1fr;
    min-height:            0;
    padding:               54px 0 40px;
    gap:                   0;
  }

  /* ── Hero texto: alinha à esquerda ── */
  .hero-text { text-align: left; max-width: 100%; }
  .hero h1   { font-size: 28px; }
  .hero p    { width: 100%; max-width: 100%; font-size: 13px; }

  /* ── Hero phone: mostra menor abaixo do texto ── */
  .hero-phone {
    height:          300px;
    justify-content: center;
    align-items:     center;
    animation:       none;   /* pausa float em mobile */
  }
  .hero-phone > img { max-height: 290px; }
  .recovery-badge   { display: none; }

  /* ── Hero slide 2 (centered): reajusta para coluna única ── */
  .hero-inner-centered           { justify-items: flex-start; }
  .hero-inner-centered .hero-text { text-align: left; }
  .hero-inner-centered .hero-buttons {
    justify-content: flex-start;
  }

  /* ── About: coluna única ── */
  .about-inner { grid-template-columns: 1fr; gap: 24px; }
  .about-logo  { justify-self: start; width: 120px; }
  .about-copy p { width: 100%; }

  /* ── Benefits: coluna única ── */
  .benefits-inner  { grid-template-columns: 1fr; padding: 52px 0; }
  .benefits-phone  { display: none; }
  .benefits-copy h2 { max-width: 100%; }

  /* ── Diferenciais: 2 colunas ── */
  .diff-grid { grid-template-columns: repeat(2, 1fr); }

  /* ── Numbers: 2 colunas ── */
  .numbers-grid { grid-template-columns: repeat(2, 1fr); }

  /* ── Advantages: 2 colunas ── */
  .advantages { grid-template-columns: repeat(2, 1fr); }

  /* ── Protect: largura total ── */
  .protect h2,
  .protect p       { width: 100%; max-width: 100%; }
  .protect .btn    { margin-right: 0; align-self: flex-start; }
  .protect-inner   { align-items: flex-start; padding: 48px 0; }

  /* ── Prices: 2 colunas ── */
  .price-grid { grid-template-columns: repeat(2, 1fr); }

  /* ── Payment: coluna única ── */
  .payment-box {
    grid-template-columns: 1fr;
    text-align: center;
    padding: 24px 20px;
    gap: 14px;
  }
  .payment-box img { margin: 0 auto; }
  .payment-box .btn { width: fit-content; margin: 0 auto; }

  /* ── Formulário de contato: coluna única ── */
  .contact-form .row { grid-template-columns: 1fr; }

  /* ── Ícones de contato: 2 colunas ── */
  .icon-row { grid-template-columns: repeat(2, 1fr); }

  /* ── Footer: 2 colunas ── */
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 24px; }
  .footer-logo img { width: 90px; }
}

/* ──────────────────────────────────────────────────────────────
   ≤ 520px  Mobile portrait
   ────────────────────────────────────────────────────────────── */
@media (max-width: 520px) {

  /* ── Hero ── */
  .hero h1  { font-size: 22px; }
  .hero p   { font-size: 12px; }
  .hero-phone     { height: 230px; }
  .hero-phone > img { max-height: 220px; }

  /* ── Hero buttons: coluna, largura total ── */
  .hero-buttons {
    display:        flex;
    flex-direction: column;
    gap:            10px;
    align-items:    stretch;
    width:          100%;
  }
  .hero-buttons .btn,
  .hero-buttons .btn-dark {
    width:       100%;
    text-align:  center;
    margin:      0;
    justify-content: center;
  }

  /* ── Tipografia: reduz cabeçalhos ── */
  .section-heading h2,
  .benefits-copy h2,
  .contact .section-heading h2,
  .about-copy h2               { font-size: 21px; }

  /* ── Diferenciais: 1 coluna ── */
  .diff-grid { grid-template-columns: 1fr; }

  /* ── Numbers: 1 coluna ── */
  .numbers-grid { grid-template-columns: 1fr; }

  /* ── Advantages: 1 coluna ── */
  .advantages { grid-template-columns: 1fr; }

  /* ── Prices: 1 coluna ── */
  .price-grid { grid-template-columns: 1fr; }
  .plan { min-height: auto; }

  /* ── Ícones de contato: 1 coluna ── */
  .icon-row { grid-template-columns: 1fr; }

  /* ── Footer: 1 coluna ── */
  .footer-grid { grid-template-columns: 1fr; gap: 20px; }

  /* ── Payment ── */
  .payment-box { padding: 20px 16px; }

  /* ── Protect ── */
  .protect h2 { font-size: 22px; }

  /* ── Equipment ── */
  .equipment-block h3 { font-size: 20px; }
  .equipment-block p  { font-size: 13px; }

  /* ── FAQ: espaçamento interno mobile ── */
  .faq-list summary { font-size: 11px; }
  .faq-list p { padding: 0 14px 14px 56px; }

  /* ── Formulário ── */
  .contact-form { padding: 16px 14px; }

  /* ── Espaçamentos gerais: reduz padding vertical ── */
  .differentials  { padding: 40px 0 48px; }
  .numbers        { padding: 40px 0 48px; }
  .equipments     { padding: 40px 0 50px; }
  .about          { padding: 36px 0;  }
  .contact        { padding: 44px 0 52px; }
  .contact-icons  { padding: 44px 0;  }
  .faq-section    { padding: 40px 0 52px; }

  /* ── Price-seal no slide 2 ── */
  .price-seal { width: 96px; height: 96px; font-size: 11px; margin-left: auto; margin-right: auto; }
  .price-seal b { font-size: 15px; }

  /* ── Benefits copy: benefícios em fonte menor ── */
  .benefit-line p { font-size: 12px; }
  .benefit-line   { gap: 10px; }

  /* ── About logo centralizado ── */
  .about-logo { justify-self: center; margin: 0 auto; }
}

/* ──────────────────────────────────────────────────────────────
   ≤ 380px  Mobile muito pequeno (iPhone SE, etc.)
   ────────────────────────────────────────────────────────────── */
@media (max-width: 380px) {
  .hero h1     { font-size: 20px; }
  .hero-phone  { height: 190px; }
  .hero-phone > img { max-height: 180px; }
  .section-heading h2,
  .benefits-copy h2,
  .contact .section-heading h2 { font-size: 19px; }
  .container { width: calc(100% - 24px); }
  .number-box b  { font-size: 34px; }
  .number-box strong { font-size: 20px; }
}

/* ===========================
   PÁGINA POLÍTICA DE PRIVACIDADE
   Mantém padrão visual ACSEG
   =========================== */
.inline-policy-link,
.policy a{
  color:#a68f6d;
  font-weight:800;
  text-decoration:underline;
  text-underline-offset:3px;
}

.footer-policy-link{
  display:inline-block;
  margin-top:10px;
  color:#a68f6d;
  font-size:12px;
  font-weight:700;
  line-height:1.5;
}

.footer-policy-link:hover{
  color:#fff;
}

.privacy-body{
  background:#0f1016;
  color:#f4f4f4;
}

.privacy-page{
  padding-top:64px;
  background:
    radial-gradient(circle at 20% 0%, rgba(166,143,109,.18), transparent 34%),
    linear-gradient(180deg, #0e1118 0%, #121318 42%, #0f1015 100%);
}

.privacy-hero{
  min-height:285px;
  display:flex;
  align-items:center;
  border-bottom:1px solid rgba(255,255,255,.07);
}

.privacy-hero-inner{
  padding:62px 0 46px;
}

.privacy-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 12px;
  border:1px solid rgba(166,143,109,.35);
  border-radius:999px;
  background:rgba(166,143,109,.10);
  color:#a68f6d;
  font-size:10px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.privacy-eyebrow::before{
  content:"";
  width:7px;
  height:7px;
  border-radius:50%;
  background:#a68f6d;
  box-shadow:0 0 18px rgba(166,143,109,.75);
}

.privacy-hero h1{
  margin:18px 0 12px;
  color:#fff;
  font-size:38px;
  line-height:1.05;
  font-weight:900;
  letter-spacing:.01em;
}

.privacy-hero p{
  max-width:720px;
  margin:0;
  color:#d8d8d8;
  font-size:14px;
  line-height:1.7;
}

.privacy-content{
  padding:36px 0 72px;
}

.privacy-grid{
  display:grid;
  grid-template-columns:270px 1fr;
  gap:24px;
  align-items:start;
}

.privacy-summary{
  position:sticky;
  top:82px;
  padding:20px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  background:rgba(18,20,28,.88);
  box-shadow:0 18px 40px rgba(0,0,0,.20);
}

.privacy-summary h2{
  margin:0 0 12px;
  color:#fff;
  font-size:15px;
  text-transform:uppercase;
  letter-spacing:.05em;
}

.privacy-summary a{
  display:block;
  padding:8px 0;
  border-top:1px solid rgba(255,255,255,.06);
  color:#a68f6d;
  font-size:12px;
  font-weight:700;
  line-height:1.25;
}

.privacy-summary a:hover{
  color:#fff;
  padding-left:4px;
}

.privacy-document{
  display:grid;
  gap:12px;
}

.privacy-card{
  padding:24px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  background:rgba(18,20,28,.92);
  box-shadow:0 12px 30px rgba(0,0,0,.18);
  scroll-margin-top:88px;
}

.privacy-card h2{
  margin:0 0 12px;
  color:#fff;
  font-size:20px;
  line-height:1.25;
}

.privacy-card h3{
  margin:0 0 8px;
  color:#a68f6d;
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.03em;
}

.privacy-card p,
.privacy-card li{
  color:#d5d7dd;
  font-size:13px;
  line-height:1.72;
}

.privacy-card p{
  margin:0 0 12px;
}

.privacy-card ul{
  margin:10px 0 0;
  padding-left:18px;
}

.privacy-card li::marker{
  color:#a68f6d;
}

.privacy-terms{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:12px;
}

.privacy-terms div,
.privacy-contact-box{
  padding:16px;
  border:1px solid rgba(166,143,109,.20);
  border-radius:12px;
  background:rgba(166,143,109,.07);
}

.privacy-contact-box{
  display:grid;
  gap:4px;
  color:#fff;
}

.privacy-contact-box strong{
  color:#a68f6d;
  font-size:16px;
}

.privacy-contact-box span{
  color:#d5d7dd;
  font-size:12px;
}

.privacy-back-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:36px;
  padding:0 18px;
  margin-top:8px;
  border-radius:4px;
  background:#a68f6d;
  color:#fff;
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.05em;
  transition:background .2s ease, transform .2s ease;
}

.privacy-back-button:hover{
  background:#8f7a58;
  transform:translateY(-2px);
}

@media (max-width:1050px){
  .privacy-grid{
    grid-template-columns:1fr;
  }

  .privacy-summary{
    position:relative;
    top:auto;
  }
}

@media (max-width:780px){
  .privacy-page{
    padding-top:64px;
  }

  .privacy-hero-inner{
    padding:46px 0 34px;
  }

  .privacy-hero h1{
    font-size:29px;
  }

  .privacy-content{
    padding:24px 0 52px;
  }

  .privacy-card{
    padding:18px;
  }

  .privacy-terms{
    grid-template-columns:1fr;
  }
}
