:root{
    --wine:#7b1f26;
    --wine2:#8b2830;
    --soft:#f3f2f2;
    --ink:#2b2b2b;
    --muted:#777;
    --line:#e9e9e9;
    --radius:18px;
    --shadow: 0 10px 30px rgba(0,0,0,.08);
    --pill:#e7e7e7;
}
html,body{height:100%}
body{font-family:Montserrat,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--ink);}

.container{max-width:1120px}

.topbar{
  background:#fff;
  border-bottom:1px solid var(--line);
}
.brand-logo{height:56px;width:auto}
.addr{
  font-size:12px;
  line-height:1.25;
  color:var(--muted);
  max-width:260px;
  white-space:normal;
}

.nav-pill{
  font-size:12px;
  font-weight:600;
  color:#707070;
  background:var(--pill);
  border-radius:999px;
  padding:10px 18px;
  text-decoration:none;
  transition:.15s ease;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:108px;
}
.nav-pill:hover{background:#dcdcdc;color:#555}

.hero{
  position:relative;
  min-height:400px;
  background:center/cover no-repeat;
  overflow:hidden;
}
.hero::before{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(255,255,255,.70) 0%, rgba(255,255,255,.55) 40%, rgba(255,255,255,.35) 100%);
}
.hero .content{
  position:relative;
  padding:90px 0 0;
  text-align:center;
}
.hero .hero-logo{max-width:360px;margin:0 auto 12px;opacity:.95}
.hero h1{
  margin:0;
  font-size:30px;
  font-weight:500;
  color:#6d6d6d;
  line-height:1.25;
}
.hero h1 b{font-weight:800;color:#555}

.hero-wave{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  bottom:-2px;
  width:140%;
  height:160px;
  background:#fff;
  border-top-left-radius:60% 90%;
  border-top-right-radius:60% 90%;
}

.down-btn{
  position:relative;
  display:inline-grid;
  place-items:center;
  width:48px;
  height:48px;
  border-radius:12px;
  background:#fff;
  box-shadow:0 10px 25px rgba(0,0,0,.15);
  border:1px solid #eee;
  margin-top:22px;
  text-decoration:none;
}
.down-btn svg{width:22px;height:22px;fill:var(--wine);}

section{padding:55px 0}
.kicker{
  color:var(--wine);
  font-weight:800;
  letter-spacing:.12em;
  font-size:12px;
  text-transform:uppercase;
  margin-bottom:6px;
}
.title{
  color:var(--wine);
  font-weight:700;
  letter-spacing:.02em;
  text-transform:uppercase;
  margin:0;
}
.sub{
  color:#a3a3a3;
  font-size:13px;
  line-height:1.6;
  margin-top:10px;
}
.center-line{
  width:420px;
  max-width:90%;
  height:2px;
  background:#d8d8d8;
  margin:12px auto 18px;
  border-radius:999px;
  opacity:.8;
}

.btn-wine{
  background:var(--wine);
  border-color:var(--wine);
  color:#fff;
  font-weight:700;
  border-radius:999px;
  padding:10px 26px;
}
.btn-wine:hover{background:var(--wine2);border-color:var(--wine2);color:#fff}

.btn-wine-sm{
  background:var(--wine);
  border-color:var(--wine);
  color:#fff;
  font-weight:700;
  border-radius:999px;
  padding:8px 18px;
  font-size:12px;
}
.btn-wine-sm:hover{background:var(--wine2);border-color:var(--wine2);color:#fff}

.card-soft{
  border:1px solid #efefef;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  background:#fff;
}

/* ========================= */
/* BANNERS FIXOS */
/* ========================= */

.mini-wrap{margin-top:20px}

.banner-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
}

.mini-img{
  height:220px;
  object-fit:cover;
  width:100%;
  display:block;
}

@media (max-width:768px){
  .banner-grid{
    grid-template-columns:1fr;
  }
}

/* EXAMES */
.exam{
  padding:20px 18px;
  min-height:170px;
}
.exam .icon{
  width:85px;
  height:85px;
  margin-bottom:14px;
  object-fit:contain;
  display:block;
}
.exam h6{
  margin:0 0 6px;
  color:var(--wine);
  font-weight:800;
  text-transform:uppercase;
  font-size:13px;
  letter-spacing:.02em;
}
.exam p{
  margin:0 0 12px;
  color:#9a9a9a;
  font-size:12px;
  line-height:1.45;
}

.soft{background:var(--soft)}
.diffs-title{
  color:var(--wine);
  font-weight:800;
  font-size:18px;
  margin:0;
}

/* ========================= */
/* DIFERENCIAIS - CORREÇÃO DAS SETAS */
/* ========================= */

#carouselDiffs{
  position:relative;
}

.diff-card{
  padding:22px 78px;
  min-height:120px;
  position:relative;
}

.diff-card h6{
  margin:0 0 8px;
  color:var(--wine);
  font-weight:800;
  text-transform:uppercase;
}

.diff-card p{
  margin:0;
  color:#9a9a9a;
  font-size:12px;
  line-height:1.55;
}

#carouselDiffs .carousel-control-prev,
#carouselDiffs .carousel-control-next{
  position:absolute;
  top:50%;
  bottom:auto;
  transform:translateY(-50%);
  width:56px;
  height:56px;
  opacity:1;
  z-index:3;
}

#carouselDiffs .carousel-control-prev{
  left:12px;
}

#carouselDiffs .carousel-control-next{
  right:12px;
}

#carouselDiffs .carousel-control-prev .dot,
#carouselDiffs .carousel-control-next .dot{
  width:56px;
  height:56px;
  border-radius:16px;
  background:#d9d9d9;
  box-shadow:none;
  font-size:28px;
  color:#9d9d9d;
  display:flex;
  align-items:center;
  justify-content:center;
  line-height:1;
}

.heart-img{max-width:320px;width:100%;height:auto}

.team-title{color:var(--wine);font-weight:800;text-transform:uppercase}
.team-p{color:#9a9a9a;font-size:12px;line-height:1.5}

.post-img{height:170px;object-fit:cover;width:100%}
.post-body{padding:14px}
.post-body h6{margin:0 0 6px;color:var(--wine);font-weight:800;text-transform:uppercase}
.post-body p{margin:0 0 12px;color:#9a9a9a;font-size:12px;line-height:1.45}

/* ========================= */
/* DEPOIMENTOS */
/* ========================= */

.depo-bg{
  background:url('assets/img/imagem-vermelha.png') center center no-repeat;
  background-size:cover;
  position:relative;
  padding:100px 0;
}

.depo-bg::before{
  content:"";
  position:absolute;
  inset:0;
  background:rgba(123,31,38,.75);
}

.depo-bg .container{
  position:relative;
  z-index:2;
}

.depo-bg .kicker{
  color:#fff;
  text-align:center;
  margin-bottom:40px;
  font-size:20px;
  letter-spacing:.08em;
}

.depo-box{
  max-width:780px;
  margin:0 auto;
  padding:50px 40px;
  border-radius:22px;
  background:#fff;
  box-shadow:0 25px 60px rgba(0,0,0,.25);
}

.depo-box h6{
  color:var(--wine);
  font-weight:800;
  text-transform:uppercase;
  margin-bottom:10px;
}

.depo-box p{
  color:#9a9a9a;
  font-size:14px;
}

.carousel-control-prev,
.carousel-control-next{
  width:auto;
}

.carousel-control-prev .dot,
.carousel-control-next .dot{
  width:46px;
  height:46px;
  border-radius:12px;
  background:#d9d9d9;
  box-shadow:none;
  font-size:26px;
  color:#666;
}

.depo-btn{
  display:block;
  width:280px;
  margin:30px auto 0;
  text-align:center;
  background:#a12828;
  color:#fff;
  padding:12px 0;
  border-radius:999px;
  font-weight:600;
  text-decoration:none;
}

.depo-btn:hover{
  background:#8b1f1f;
  color:#fff;
}

.chip{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid #ddd;
  background:#fff;
  color:#666;
  text-decoration:none;
  font-size:12px;
  font-weight:600;
}

.contact-box{
  background:var(--wine);
  border-radius:18px;
  padding:18px 18px;
  color:#fff;
  box-shadow:var(--shadow);
}
.contact-box .form-control{
  height:36px;
  border-radius:999px;
  border:0;
  background:#fff;
  color:#333;
  font-size:12px;
}
.contact-box textarea.form-control{
  height:auto;
  border-radius:14px;
  min-height:88px;
}
.contact-box label{
  font-size:12px;
  font-weight:700;
  margin:0 0 6px;
  display:block;
  opacity:.95;
}

footer{
  padding:34px 0;
  border-top:1px solid var(--line);
  background:#f5f5f5;
}
.footer-title{
  color:var(--wine);
  font-weight:800;
  text-transform:uppercase;
}
.footer-p{
  color:#8f8f8f;
  font-size:12px;
  line-height:1.6;
  margin:0;
}
.footer-logo{
  height:70px;
  width:auto;
}

@media (max-width: 992px){
  .addr{max-width:220px}
  .nav-pill{min-width:auto;padding:10px 14px}
  .hero{min-height:480px}
  .hero .content{padding-top:70px}
  .hero h1{font-size:26px}

  .diff-card{
    padding:22px 72px;
  }

  #carouselDiffs .carousel-control-prev{
    left:8px;
  }

  #carouselDiffs .carousel-control-next{
    right:8px;
  }
}

@media (max-width: 576px){
  .brand-logo{height:48px}
  .hero-logo{max-width:280px}
  .hero h1{font-size:22px}
}

/* ========================= */
/* AJUSTES EXCLUSIVOS MOBILE */
/* ========================= */

@media (max-width: 576px) {
  .brand-logo {
    height:40px;
  }
  
  .topbar .container {
    padding-left:10px;
    padding-right:10px;
  }

  .hero {
    min-height:420px;
  }

  .hero .content {
    padding:60px 15px 0;
  }

  .hero .hero-logo {
    max-width:220px;
    margin-bottom:20px;
  }

  .hero h1 {
    font-size:18px;
    padding:0 10px;
  }

  .hero-wave {
    height:80px;
    width:180%;
  }

  section {
    padding:35px 0;
  }

  .title {
    font-size:20px;
  }

  .center-line {
    width:100px;
    margin:10px auto;
  }

  .depo-bg {
    padding:50px 0;
  }

  .depo-box {
    padding:25px 20px;
    margin:0 15px;
  }

  .depo-bg .kicker {
    font-size:16px;
    margin-bottom:20px;
  }

  .carousel-control-prev .dot,
  .carousel-control-next .dot {
    width:36px;
    height:36px;
    font-size:20px;
  }

  .exam,
  .diff-card {
    min-height:auto;
    margin-bottom:15px;
  }

  .exam{
    padding:20px;
  }

  .diff-card{
    padding:20px 58px;
  }

  .exam .icon{
    width:65px;
    height:65px;
  }

  #carouselDiffs .carousel-control-prev,
  #carouselDiffs .carousel-control-next{
    width:42px;
    height:42px;
  }

  #carouselDiffs .carousel-control-prev{
    left:8px;
  }

  #carouselDiffs .carousel-control-next{
    right:8px;
  }

  #carouselDiffs .carousel-control-prev .dot,
  #carouselDiffs .carousel-control-next .dot{
    width:42px;
    height:42px;
    font-size:22px;
    border-radius:14px;
  }

  .contact-box {
    padding:20px 15px;
  }
  
  .footer-logo {
    height:50px;
    margin-bottom:15px;
  }
}