
/* ── VARIÁVEIS ─────────────────────────────────────────── */
:root {
  --neon:        #b6ff3b;   /* verde-cana / sugarcane green */
  --neon-dark:   #8fd629;
  --verde:       #4e8605;
  --dark:        #1b1b1b;
  --dark2:       #252525;
  --white:       #ffffff;
  --gray-light:  #f5f5f5;
  --gray-mid:    #888888;
  --font-title:  "Barlow Condensed", sans-serif;
  --font-body:   "Inter", sans-serif;
  --shadow-neon: 0 0 24px rgba(182,255,59,.22);
  --transition:  all .3s ease;
  --nav-h:       72px;    /* altura visível da barra */
  --logo-drop:   42px;    /* quanto a logo desce abaixo da barra */
}

/* ── RESET ──────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }

html {
  scroll-behavior: smooth;
  /* Bloqueia scroll horizontal NO NÍVEL RAIZ sem esconder
     o menu collapse (que é position:absolute) */
  overflow-x: clip;
}

body {
  font-family: var(--font-body);
  background: var(--white);
  color: var(--dark);
  overflow-x: clip;
  width: 100%;
}

img { max-width:100%; height:auto; display:block; }
a   { text-decoration:none; }

section {
  position: relative;
  width: 100%;
}

/* ── LOADING ────────────────────────────────────────────── */
#loading-screen {
  position:fixed; inset:0;
  background:var(--dark);
  display:flex; align-items:center; justify-content:center;
  z-index:9999;
  transition: opacity .5s ease, visibility .5s ease;
}
#loading-screen.hidden { opacity:0; visibility:hidden; pointer-events:none; }
.loader-logo { animation: pulse 1s ease-in-out infinite alternate; }
.loader-logo img { width:180px; max-width:55vw; }
@keyframes pulse {
  from { opacity:.5; transform:scale(.95); }
  to   { opacity:1;  transform:scale(1.05); }
}

/* ── NAVBAR ─────────────────────────────────────────────── */
/*
   REGRA CRÍTICA: overflow:visible (NÃO hidden) para que:
   1. A logo possa "cair" sobre a hero sem ser cortada.
   2. O menu collapse mobile possa aparecer abaixo da barra.
*/
#mainNav {
  background: rgba(27,27,27,.97);
  backdrop-filter: blur(16px);
  /* Apenas border-bottom — NENHUMA barra lateral */
  border-bottom: 3px solid transparent;
  transition: var(--transition);
  z-index: 1030;
  padding: 0;
  width: 100%;
  height: var(--nav-h);
  /* IMPORTANTE: visible para logo e collapse funcionarem */
  overflow: visible;
}

/* Borda verde-cana só aparece ao rolar a página */
#mainNav.scrolled {
  border-bottom-color: var(--neon);
  box-shadow: 0 4px 30px rgba(0,0,0,.5);
}

#mainNav .container {
  display: flex;
  align-items: center;
  height: var(--nav-h);
  padding: 0 20px;
  gap: 0;
  /* SEM overflow:hidden aqui */
  overflow: visible;
  position: relative;
}

/* ── LOGO: fica POR CIMA da navbar e da hero-left ────────── */
.navbar-brand {
  flex-shrink: 0;
  line-height: 0;
  /* z-index alto → aparece acima de qualquer camada */
  position: relative;
  z-index: 200;
}

.navbar-brand img {
  height: 110px;
  width: auto;
  max-width: 170px;
  /*
    translateY positivo → logo "cai" abaixo da barra,
    sobrepondo o topo da seção hero-left
  */
  transform: translateY(var(--logo-drop));
  filter: drop-shadow(0 6px 24px rgba(182,255,59,.4));
  transition: var(--transition);
}
.navbar-brand img:hover {
  transform: translateY(var(--logo-drop)) scale(1.04);
  filter: drop-shadow(0 8px 32px rgba(182,255,59,.6));
}

/* ── NAV LINKS ──────────────────────────────────────────── */
.nav-link {
  color: var(--white) !important;
  font-weight: 500;
  font-size: .9rem;
  letter-spacing: .5px;
  padding: 6px 12px !important;
  transition: var(--transition);
  position: relative;
  white-space: nowrap;
}
.nav-link::after {
  content:""; position:absolute; bottom:0; left:50%;
  width:0; height:2px; background:var(--neon);
  transition:var(--transition); transform:translateX(-50%);
}
.nav-link:hover            { color:var(--neon) !important; }
.nav-link:hover::after     { width:60%; }

/* ── BOTÃO LIGAR (nav) ──────────────────────────────────── */
.btn-call-nav {
  background: var(--neon);
  color: var(--dark) !important;
  border-radius: 50px;
  padding: 8px 18px;
  font-weight: 700;
  font-size: .85rem;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  transition: var(--transition);
  border: none;
  white-space: nowrap;
  flex-shrink: 0;
}
.btn-call-nav:hover { background:var(--neon-dark); transform:translateY(-1px); color:var(--dark) !important; }

/* ── SELETOR DE IDIOMA ──────────────────────────────────── */
.lang-switcher {
  display: flex;
  align-items: center;
  gap: 4px;
  background: rgba(255,255,255,.1);
  border-radius: 50px;
  padding: 4px 10px;
  /* Sem borda lateral extra */
  border: 1px solid rgba(255,255,255,.2);
  flex-shrink: 0;
}
.lang-btn {
  background: none;
  border: none;
  color: rgba(255,255,255,.65);
  font-size: .8rem;
  font-weight: 700;
  cursor: pointer;
  padding: 3px 8px;
  border-radius: 20px;
  transition: var(--transition);
  line-height: 1;
  white-space: nowrap;
}
.lang-btn.active { background:var(--neon); color:var(--dark); }
.lang-btn:hover:not(.active) { color:var(--white); }

/* ── TOGGLER ────────────────────────────────────────────── */
.navbar-toggler {
  border: 2px solid var(--neon);
  border-radius: 8px;
  padding: 6px 10px;
  flex-shrink: 0;
  /* Sem box-shadow que pareça uma barra */
  box-shadow: none !important;
}
.navbar-toggler:focus { box-shadow: none !important; }
.navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='%23B6FF3B' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

/* ── COLLAPSE MENU ──────────────────────────────────────── */
/*
  Bootstrap 5 controla o display via .show/.collapse.
  NÃO sobrescrevemos position aqui no desktop.
*/
#navContent {
  /* No mobile, o Bootstrap vai adicionar .show e exibir o menu */
}

/* ── HERO ───────────────────────────────────────────────── */
#hero {
  min-height: 100vh;
  background: var(--dark);
  display: flex;
  align-items: stretch;
  overflow: hidden;
  width: 100%;
}

.hero-left {
  flex: 0 0 55%;
  max-width: 55%;
  /*
    padding-top = altura navbar + quanto a logo cai + margem extra
    nav-h (72px) + logo-drop (42px) + extra (40px) = ~154px
  */
  padding: 160px 60px 80px 80px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  z-index: 2;
}
.hero-left::after {
  content:""; position:absolute; top:0; right:-60px;
  width:120px; height:100%;
  background:linear-gradient(to right, var(--dark), transparent);
  z-index:3; pointer-events:none;
}

.hero-right {
  flex: 0 0 45%;
  max-width: 45%;
  position: relative;
  overflow: hidden;
}
.hero-right::before {
  content:""; position:absolute; inset:0;
  background:linear-gradient(to right, var(--dark) 0%, rgba(27,27,27,.3) 40%, transparent 100%);
  z-index:2;
}
.hero-right img {
  width:100%; height:100%;
  object-fit:cover; object-position:center;
  transform:scale(1.05); transition:transform 8s ease;
}
#hero:hover .hero-right img { transform:scale(1); }

.hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(182,255,59,.1);
  border:1px solid rgba(182,255,59,.4);
  border-radius:50px; padding:6px 16px;
  font-size:.8rem; font-weight:700; color:var(--neon);
  letter-spacing:1.5px; text-transform:uppercase;
  margin-bottom:24px; width:fit-content; max-width:100%;
}
.hero-badge .dot {
  width:8px; height:8px; min-width:8px;
  background:var(--neon); border-radius:50%;
  animation:blink 1.5s infinite;
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.3} }

.hero-title {
  font-family:var(--font-title);
  font-size:clamp(1.9rem,4vw,3.2rem);
  font-weight:900; line-height:1.05;
  color:var(--white); text-transform:uppercase;
  margin-bottom:8px; word-break:break-word;
}
.hero-title span { color:var(--neon); display:block; }

.hero-subtitle {
  font-size:clamp(.9rem,2vw,1.05rem);
  color:rgba(255,255,255,.75); line-height:1.7;
  margin-bottom:32px; max-width:500px;
}

.hero-services-list { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:36px; }
.hero-tag {
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:50px; padding:5px 14px;
  font-size:.82rem; color:rgba(255,255,255,.7);
  transition:var(--transition);
}
.hero-tag:hover { border-color:var(--neon); color:var(--neon); }

.hero-buttons { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:48px; }

.btn-primary-cta {
  background:var(--neon); color:var(--dark);
  font-family:var(--font-title); font-size:1.1rem; font-weight:800;
  text-transform:uppercase; letter-spacing:1px;
  padding:14px 32px; border-radius:50px;
  border:none; cursor:pointer;
  transition:var(--transition); box-shadow:var(--shadow-neon);
  display:inline-flex; align-items:center; gap:8px;
  white-space:nowrap;
}
.btn-primary-cta:hover {
  background:var(--neon-dark); transform:translateY(-3px);
  box-shadow:0 12px 40px rgba(182,255,59,.4); color:var(--dark);
}

.btn-sms-cta {
  background:transparent; color:var(--white);
  font-family:var(--font-title); font-size:1.1rem; font-weight:700;
  text-transform:uppercase; letter-spacing:1px;
  padding:14px 32px; border-radius:50px;
  border:2px solid #5ac8fa; cursor:pointer;
  transition:var(--transition);
  display:inline-flex; align-items:center; gap:8px;
  white-space:nowrap;
}
.btn-sms-cta:hover { background:#5ac8fa; color:var(--dark); transform:translateY(-3px); }

.hero-stats { display:flex; gap:36px; flex-wrap:wrap; }
.hero-stat  { text-align:left; }
.hero-stat .number {
  font-family:var(--font-title);
  font-size:clamp(1.8rem,3vw,2.4rem);
  font-weight:900; color:var(--neon); line-height:1;
}
.hero-stat .label {
  font-size:.8rem; color:rgba(255,255,255,.55);
  text-transform:uppercase; letter-spacing:1px; margin-top:2px;
}
.hero-divider { width:1px; background:rgba(255,255,255,.15); height:50px; align-self:center; }

/* ── TÍTULOS DE SEÇÃO ───────────────────────────────────── */
.section-eyebrow {
  font-size:.78rem; font-weight:700; letter-spacing:3px;
  text-transform:uppercase; color:var(--verde); margin-bottom:10px;
}
.section-title {
  font-family:var(--font-title);
  font-size:clamp(1.8rem,4vw,3rem);
  font-weight:900; text-transform:uppercase;
  line-height:1.1; margin-bottom:16px; word-break:break-word;
}
.section-title.dark  { color:var(--dark); }
.section-title.light { color:var(--white); }
.section-subtitle {
  font-size:clamp(.9rem,2vw,1rem);
  line-height:1.7; max-width:580px;
}
.section-subtitle.dark  { color:rgba(27,27,27,.7); }
.section-subtitle.light { color:rgba(255,255,255,.7); }
.title-line { width:60px; height:4px; background:var(--neon); border-radius:2px; margin-bottom:20px; }

/* ── SERVICES ───────────────────────────────────────────── */
#services { background:var(--gray-light); padding:100px 0; }
.services-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:24px;
}
.service-card {
  background:var(--white); border-radius:16px;
  padding:36px 28px;
  border:1px solid rgba(0,0,0,.06);
  transition:var(--transition); position:relative; overflow:hidden;
}
.service-card::before {
  content:""; position:absolute; bottom:0; left:0; right:0;
  height:4px; background:var(--neon);
  transform:scaleX(0); transition:transform .3s ease;
}
.service-card:hover { transform:translateY(-8px); box-shadow:0 20px 60px rgba(0,0,0,.12); border-color:rgba(182,255,59,.3); }
.service-card:hover::before { transform:scaleX(1); }
.service-icon-wrap {
  width:70px; height:70px; background:var(--dark);
  border-radius:16px; display:flex; align-items:center; justify-content:center;
  margin-bottom:20px; transition:var(--transition);
}
.service-card:hover .service-icon-wrap { background:var(--neon); }
.service-icon-wrap i { font-size:2rem; color:var(--neon); transition:var(--transition); }
.service-card:hover .service-icon-wrap i { color:var(--dark); }
.service-card h3 {
  font-family:var(--font-title); font-size:1.3rem; font-weight:800;
  text-transform:uppercase; color:var(--dark); margin-bottom:10px;
}
.service-card p { font-size:.9rem; color:var(--gray-mid); line-height:1.65; }

/* ── WHY ────────────────────────────────────────────────── */
#why { background:var(--dark); padding:100px 0; }
.why-card {
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px; padding:32px 24px;
  text-align:center; transition:var(--transition); height:100%;
}
.why-card:hover { background:rgba(182,255,59,.07); border-color:rgba(182,255,59,.3); transform:translateY(-6px); }
.why-icon {
  width:64px; height:64px;
  background:rgba(182,255,59,.1); border:2px solid rgba(182,255,59,.3);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  margin:0 auto 20px; transition:var(--transition);
}
.why-card:hover .why-icon { background:var(--neon); border-color:var(--neon); }
.why-icon i { font-size:1.6rem; color:var(--neon); transition:var(--transition); }
.why-card:hover .why-icon i { color:var(--dark); }
.why-card h4 {
  font-family:var(--font-title); font-size:1.1rem; font-weight:800;
  text-transform:uppercase; color:var(--white); margin-bottom:8px;
}
.why-card p { font-size:.85rem; color:rgba(255,255,255,.55); line-height:1.6; }

.counters-row {
  background:var(--neon); border-radius:16px;
  padding:48px 40px; margin-top:60px;
}
.counter-item { text-align:center; }
.counter-number {
  font-family:var(--font-title);
  font-size:clamp(2rem,5vw,3.5rem);
  font-weight:900; color:var(--dark); line-height:1;
}
.counter-label {
  font-size:.9rem; font-weight:700;
  color:rgba(27,27,27,.7); text-transform:uppercase;
  letter-spacing:1px; margin-top:4px;
}

/* ── GALLERY ────────────────────────────────────────────── */
#gallery { padding:100px 0; background:var(--white); }
.gallery-filters {
  display:flex; justify-content:center; gap:10px;
  margin-bottom:36px; flex-wrap:wrap;
}
.gallery-filter-btn {
  background:transparent; border:2px solid rgba(0,0,0,.12);
  color:var(--gray-mid); font-family:var(--font-title);
  font-size:1rem; font-weight:700; text-transform:uppercase; letter-spacing:1px;
  padding:9px 28px; border-radius:50px; cursor:pointer;
  transition:var(--transition); display:inline-flex; align-items:center; gap:7px;
}
.gallery-filter-btn:hover,
.gallery-filter-btn.active { background:var(--neon); border-color:var(--neon); color:var(--dark); }
.gallery-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.gallery-item {
  position:relative; overflow:hidden; border-radius:12px;
  aspect-ratio:4/3; cursor:pointer; transition:opacity .35s ease;
}
.gallery-item.tall { grid-row:span 2; aspect-ratio:auto; }
.gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.gallery-item:hover img { transform:scale(1.08); }
.gallery-overlay {
  position:absolute; inset:0; background:rgba(27,27,27,.7);
  display:flex; align-items:center; justify-content:center;
  opacity:0; transition:var(--transition);
}
.gallery-item:hover .gallery-overlay { opacity:1; }
.gallery-overlay i { font-size:2.5rem; color:var(--neon); }
.gallery-item.hidden-item { display:none; }
.gallery-video-badge {
  position:absolute; top:12px; left:12px;
  background:rgba(0,0,0,.7); border:1px solid var(--neon);
  border-radius:20px; padding:3px 10px;
  font-size:.72rem; font-weight:700; color:var(--neon);
  text-transform:uppercase; letter-spacing:1px;
  z-index:3; display:flex; align-items:center; gap:4px;
}

/* ── LIGHTBOX ───────────────────────────────────────────── */
#lightbox {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,.95); z-index:9998;
  align-items:center; justify-content:center; padding:20px;
}
#lightbox.active { display:flex; }
#lightbox img { max-width:90vw; max-height:85vh; border-radius:8px; width:auto; height:auto; }
#lightbox-close {
  position:absolute; top:20px; right:30px;
  font-size:2rem; color:var(--white); cursor:pointer; background:none; border:none;
}

/* ── REVIEWS — 1 CARD POR VEZ ───────────────────────────── */
#reviews { background:var(--gray-light); padding:100px 0; }

#reviewsCarousel .carousel-item .review-card-wrap {
  max-width:700px;
  margin:0 auto;
  padding:0 16px;
}

.review-card {
  background:var(--white); border-radius:16px;
  padding:40px 36px;
  box-shadow:0 4px 24px rgba(0,0,0,.07);
  border:1px solid rgba(0,0,0,.05);
  transition:var(--transition); position:relative; text-align:left;
}
.review-card:hover { transform:translateY(-6px); box-shadow:0 16px 50px rgba(0,0,0,.12); }
.review-card::before {
  content:"\201C"; position:absolute; top:16px; right:24px;
  font-size:5rem; line-height:1; color:rgba(182,255,59,.2); font-family:Georgia,serif;
}
.stars { color:#f5a623; font-size:1rem; margin-bottom:14px; }
.review-text {
  font-size:1rem; color:rgba(27,27,27,.75);
  line-height:1.75; margin-bottom:24px; font-style:italic;
}
.reviewer { display:flex; align-items:center; gap:12px; }
.reviewer-avatar {
  width:48px; height:48px; min-width:48px;
  border-radius:50%; background:var(--neon);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-title); font-weight:900; font-size:1.2rem; color:var(--dark);
}
.reviewer-name  { font-weight:700; font-size:.95rem; color:var(--dark); }
.reviewer-location { font-size:.78rem; color:var(--gray-mid); }
.google-badge { display:flex; align-items:center; gap:6px; margin-top:6px; }
.google-badge span { font-size:.75rem; color:var(--gray-mid); }

.carousel-indicators-custom {
  display:flex; justify-content:center; gap:8px;
  margin-top:28px; flex-wrap:wrap;
}
.carousel-indicators-custom button {
  background:rgba(0,0,0,.2); width:30px; height:4px;
  border-radius:2px; border:none; cursor:pointer;
  transition:var(--transition); padding:0;
}
.carousel-indicators-custom button.active { background:var(--neon); width:44px; }

/* ── ABOUT — TEXTO JUSTIFICADO ──────────────────────────── */
#about { padding:100px 0; background:var(--white); }
.about-image-wrap { position:relative; border-radius:20px; overflow:hidden; }
.about-image-wrap img { width:100%; height:500px; object-fit:cover; border-radius:20px; display:block; }
.about-badge {
  position:absolute; bottom:-20px; right:-20px;
  background:var(--neon); border-radius:16px;
  padding:24px 28px; text-align:center; box-shadow:var(--shadow-neon);
}
.about-badge .num { font-family:var(--font-title); font-size:3rem; font-weight:900; color:var(--dark); line-height:1; }
.about-badge .lbl { font-size:.8rem; font-weight:700; color:rgba(27,27,27,.7); text-transform:uppercase; }
.about-content { padding:20px 0 0 40px; }

/* JUSTIFICADO */
#about .about-text {
  color:rgba(27,27,27,.72);
  line-height:1.8;
  margin-bottom:16px;
  text-align:justify;
  hyphens:auto;
  -webkit-hyphens:auto;
}

.about-quality-badges { display:flex; gap:10px; flex-wrap:wrap; margin-top:28px; }
.quality-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--gray-light); border-radius:50px;
  padding:8px 18px; font-size:.85rem; font-weight:600; color:var(--dark);
  border:1px solid rgba(0,0,0,.06);
}
.quality-badge i { color:var(--neon); }

/* ── ESTIMATE FORM ──────────────────────────────────────── */
#estimate { background:var(--dark2); padding:100px 0; }
.form-card {
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);
  border-radius:20px; padding:50px 48px;
}
.form-control,.form-select {
  background:rgba(255,255,255,.07) !important;
  border:1px solid rgba(255,255,255,.15) !important;
  color:var(--white) !important;
  border-radius:10px !important; padding:14px 16px !important;
  font-size:.95rem !important; transition:var(--transition) !important; width:100%;
}
.form-control::placeholder { color:rgba(255,255,255,.35) !important; }
.form-control:focus,.form-select:focus {
  border-color:var(--neon) !important;
  box-shadow:0 0 0 3px rgba(182,255,59,.15) !important;
}
.form-select option { background:var(--dark); }
.form-label { color:rgba(255,255,255,.75); font-size:.85rem; font-weight:600; margin-bottom:6px; display:block; }
.btn-submit {
  background:var(--neon); color:var(--dark);
  font-family:var(--font-title); font-size:1.2rem; font-weight:800;
  text-transform:uppercase; letter-spacing:1px;
  padding:16px 40px; border-radius:50px;
  border:none; cursor:pointer; transition:var(--transition);
  width:100%; box-shadow:var(--shadow-neon);
}
.btn-submit:hover { background:var(--neon-dark); transform:translateY(-2px); }
.btn-submit:disabled { opacity:.7; cursor:not-allowed; transform:none; }
.invalid-feedback { color:#ff6b6b !important; font-size:.8rem; }
.success-msg {
  display:none; background:rgba(182,255,59,.1);
  border:1px solid var(--neon); border-radius:10px;
  padding:16px; color:var(--neon); font-weight:600; margin-top:16px;
}

/* ── MODAL ──────────────────────────────────────────────── */
#estimateModal .modal-content {
  background:var(--dark2); border:1px solid rgba(255,255,255,.1);
  border-radius:20px; color:var(--white);
}
#estimateModal .modal-header { border-bottom:1px solid rgba(255,255,255,.1); padding:24px 32px; }
#estimateModal .modal-title {
  font-family:var(--font-title); font-size:clamp(1.3rem,4vw,1.8rem);
  font-weight:900; text-transform:uppercase; color:var(--neon);
}
#estimateModal .modal-subtitle { font-size:.9rem; color:rgba(255,255,255,.55); margin-top:4px; }
#estimateModal .btn-close { filter:invert(1); opacity:.7; }
#estimateModal .modal-body { padding:32px; }
#estimateModal .form-label { color:rgba(255,255,255,.75); font-size:.85rem; font-weight:600; margin-bottom:6px; }
#estimateModal .form-control,#estimateModal .form-select {
  background:rgba(255,255,255,.07) !important;
  border:1px solid rgba(255,255,255,.15) !important;
  color:var(--white) !important; border-radius:10px !important; padding:12px 16px !important;
}
#estimateModal .form-control::placeholder { color:rgba(255,255,255,.3) !important; }
#estimateModal .form-control:focus,#estimateModal .form-select:focus {
  border-color:var(--neon) !important; box-shadow:0 0 0 3px rgba(182,255,59,.15) !important;
}
#estimateModal .form-select option { background:var(--dark); }
#estimateModal input[type="date"] { color-scheme:dark; }
.modal-btn-submit {
  background:var(--neon); color:var(--dark) !important;
  font-family:var(--font-title); font-size:1.15rem; font-weight:800;
  text-transform:uppercase; letter-spacing:1px;
  padding:14px 32px; border-radius:50px; border:none;
  width:100%; cursor:pointer; transition:var(--transition);
  display:flex; align-items:center; justify-content:center; gap:8px;
  box-shadow:var(--shadow-neon);
}
.modal-btn-submit:hover { background:var(--neon-dark); transform:translateY(-2px); }
.modal-btn-submit:disabled { opacity:.7; cursor:not-allowed; transform:none; }
.modal-thankyou { display:none; text-align:center; padding:20px 0; }
.modal-thankyou .ty-icon { font-size:4rem; color:var(--neon); margin-bottom:16px; }
.modal-thankyou h3 {
  font-family:var(--font-title); font-size:2rem; font-weight:900;
  text-transform:uppercase; color:var(--neon); margin-bottom:10px;
}
.modal-thankyou p { color:rgba(255,255,255,.65); font-size:.95rem; line-height:1.7; }

/* ── CTA FINAL ──────────────────────────────────────────── */
#cta-final { background:var(--dark); padding:100px 0; position:relative; overflow:hidden; }
#cta-final::before {
  content:""; position:absolute; inset:0;
  background:radial-gradient(ellipse at center, rgba(182,255,59,.08) 0%, transparent 70%);
}
.cta-title {
  font-family:var(--font-title); font-size:clamp(2rem,5vw,4rem);
  font-weight:900; text-transform:uppercase; color:var(--white);
  line-height:1.1; margin-bottom:20px;
}
.cta-buttons { display:flex; gap:16px; flex-wrap:wrap; justify-content:center; margin-top:36px; }
.btn-call {
  background:transparent; color:var(--white); border:2px solid var(--white);
  font-family:var(--font-title); font-size:1.1rem; font-weight:700;
  text-transform:uppercase; padding:14px 32px; border-radius:50px;
  transition:var(--transition); display:inline-flex; align-items:center; gap:8px;
  white-space:nowrap;
}
.btn-call:hover { background:var(--white); color:var(--dark); transform:translateY(-2px); }

/* ── FAQ ────────────────────────────────────────────────── */
#faq { background:#fff; padding:100px 0 80px; }
#faq .accordion-item {
  border:1px solid rgba(0,0,0,.08); border-radius:12px !important;
  margin-bottom:12px; overflow:hidden;
  box-shadow:0 2px 8px rgba(0,0,0,.04); transition:box-shadow .2s;
}
#faq .accordion-item:hover { box-shadow:0 4px 20px rgba(0,0,0,.09); }
#faq .accordion-button {
  font-family:var(--font-title); font-size:clamp(1rem,2vw,1.18rem); font-weight:700;
  color:#1b1b1b; background:#fff; padding:22px 24px;
  border-radius:12px !important; word-break:break-word;
}
#faq .accordion-button:not(.collapsed) { color:#fff; background:#1b1b1b; box-shadow:none; }
#faq .accordion-button::after { filter:none; }
#faq .accordion-button:not(.collapsed)::after { filter:invert(1); }
#faq .accordion-button:focus { box-shadow:0 0 0 3px rgba(182,255,59,.35); }
#faq .accordion-body {
  font-size:clamp(.88rem,2vw,1rem); color:rgba(27,27,27,.72);
  line-height:1.75; padding:0 24px 22px;
}
#faq .faq-icon {
  width:44px; height:44px; min-width:44px;
  background:#cbff00; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:1.2rem; flex-shrink:0; margin-right:14px;
}
#faq .faq-question-wrap { display:flex; align-items:center; }

/* ── FOOTER ─────────────────────────────────────────────── */
footer { background:#111; color:rgba(255,255,255,.7); padding:70px 0 0; overflow-x:hidden; }
.footer-logo img { height:60px; width:auto; max-width:160px; margin-bottom:20px; }
.footer-desc { font-size:.9rem; line-height:1.7; max-width:300px; color:rgba(255,255,255,.5); }
.footer-title {
  font-family:var(--font-title); font-size:1.1rem; font-weight:800;
  text-transform:uppercase; color:var(--white); margin-bottom:18px; position:relative;
}
.footer-title::after { content:""; display:block; width:30px; height:3px; background:var(--neon); margin-top:6px; border-radius:2px; }
.footer-links { list-style:none; padding:0; }
.footer-links li { margin-bottom:10px; }
.footer-links a { color:rgba(255,255,255,.5); font-size:.9rem; transition:var(--transition); display:flex; align-items:center; gap:6px; }
.footer-links a:hover { color:var(--neon); padding-left:4px; }
.footer-links a i { font-size:.75rem; }
.footer-contact-item { display:flex; align-items:flex-start; gap:12px; margin-bottom:14px; }
.footer-contact-item i { color:var(--neon); font-size:1.1rem; flex-shrink:0; margin-top:2px; }
.footer-contact-item a { color:rgba(255,255,255,.6); font-size:.9rem; transition:var(--transition); }
.footer-contact-item a:hover { color:var(--neon); }
.footer-social { display:flex; gap:10px; margin-top:20px; flex-wrap:wrap; }
.social-btn {
  width:38px; height:38px; border:1px solid rgba(255,255,255,.15);
  border-radius:8px; display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,.5); font-size:1rem; transition:var(--transition);
}
.social-btn:hover { background:var(--neon); border-color:var(--neon); color:var(--dark); }
.footer-map iframe { width:100%; height:180px; border-radius:10px; border:none; filter:grayscale(40%); display:block; }
.footer-bottom {
  border-top:1px solid rgba(255,255,255,.08);
  padding:20px 0; margin-top:50px;
  text-align:center; font-size:.82rem; color:rgba(255,255,255,.35);
}
.footer-areas { display:flex; flex-wrap:wrap; gap:6px; margin-top:8px; }
.area-tag { background:rgba(255,255,255,.06); border-radius:4px; padding:3px 10px; font-size:.78rem; color:rgba(255,255,255,.5); }
.rubi-credit a { color:var(--neon); font-weight:600; transition:var(--transition); }
.rubi-credit a:hover { color:var(--neon-dark); text-decoration:underline; }

/* ── FLOATING BUTTONS ───────────────────────────────────── */
.float-wa {
  position:fixed; bottom:90px; right:24px;
  width:56px; height:56px; background:#25d366; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 6px 24px rgba(37,211,102,.5);
  z-index:1000; transition:var(--transition); color:var(--white); font-size:1.6rem;
}
.float-wa:hover { background:#1ebe5d; transform:scale(1.1); color:var(--white); }
.float-top {
  position:fixed; bottom:24px; right:24px;
  width:48px; height:48px; background:var(--neon); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  box-shadow:var(--shadow-neon); z-index:1000;
  transition:var(--transition); color:var(--dark); font-size:1.2rem;
  opacity:0; pointer-events:none;
}
.float-top.show { opacity:1; pointer-events:all; }
.float-top:hover { background:var(--neon-dark); transform:scale(1.1); }
.spinner-border-sm { vertical-align:middle; }

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════════════ */

/* ── ≤ 992px (Tablet / Mobile) ──────────────────────────── */
@media (max-width:992px) {

  /* NAVBAR */
  #mainNav {
    height: auto;
    min-height: var(--nav-h);
    /* CRÍTICO: visible para o collapse mobile abrir corretamente */
    overflow: visible;
  }

  #mainNav .container {
    height: auto;
    min-height: var(--nav-h);
    padding: 10px 16px;
    flex-wrap: wrap;
    align-items: center;
    /* Linha 1: logo | lang | toggler */
    position: relative;
  }

  /* Logo menor no mobile */
  .navbar-brand img {
    height: 80px;
    max-width: 130px;
    /* No mobile a logo fica centralizada na barra, sem cair muito */
    transform: translateY(16px);
  }

  /* Collapse abre como dropdown full-width */
  #navContent {
    /* Ocupa toda a largura abaixo da barra */
    width: 100%;
    flex-basis: 100%;
    background: rgba(18,18,18,.98);
    border-top: 1px solid rgba(255,255,255,.08);
    border-radius: 0 0 16px 16px;
    padding: 16px 8px 20px;
    /* Não usa position:absolute para não quebrar o Bootstrap collapse */
  }

  .navbar-nav { gap: 2px !important; width: 100%; }

  .nav-link {
    padding: 10px 16px !important;
    border-radius: 8px;
    font-size: 1rem;
    white-space: normal;
  }
  .nav-link:hover { background: rgba(255,255,255,.06); }

  /* Botão ligar + lang dentro do collapse */
  #navContent .d-flex {
    flex-wrap: wrap;
    gap: 10px !important;
    padding: 12px 8px 0;
    align-items: center;
  }

  .btn-call-nav {
    flex: 1;
    justify-content: center;
    font-size: .9rem;
  }

  .lang-switcher {
    /* Visível no collapse mobile */
    display: flex !important;
  }

  /* HERO */
  #hero { flex-direction:column; min-height:auto; }
  .hero-left {
    flex:none; max-width:100%; width:100%;
    padding: 130px 30px 50px;
  }
  .hero-left::after { display:none; }
  .hero-right { flex:none; max-width:100%; width:100%; height:300px; }
  .hero-right img { width:100%; height:100%; object-fit:cover; }

  /* About */
  .about-content { padding: 30px 0 0; }
  .about-image-wrap img { height:380px; }
  .about-badge { bottom:-10px; right:-10px; padding:18px 22px; }

  /* Form */
  .form-card { padding:32px 24px; }
  .services-grid { grid-template-columns:repeat(2,1fr); }
}

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

  :root { --logo-drop: 20px; }

  /* Navbar brand */
  .navbar-brand img {
    height: 68px;
    max-width: 120px;
    transform: translateY(14px);
  }

  /* Hero */
  .hero-left { padding: 100px 20px 40px; }
  .hero-title { font-size:clamp(1.7rem,7vw,2.2rem); }
  .hero-subtitle { font-size:.95rem; }
  .hero-buttons { flex-direction:column; align-items:stretch; }
  .btn-primary-cta,.btn-sms-cta { justify-content:center; width:100%; font-size:1rem; padding:14px 20px; }
  .hero-stats { gap:20px; }
  .hero-right { height:240px; }
  .hero_badge { margin-top: 15px; }

  /* Sections */
  #services,#why,#gallery,#reviews,#about,#faq,#estimate,#cta-final { padding:70px 0; }

  /* Services */
  .services-grid { grid-template-columns:1fr; gap:16px; }

  /* Gallery */
  .gallery-grid { grid-template-columns:repeat(2,1fr); gap:8px; }
  .gallery-item.tall { grid-row:span 1; aspect-ratio:4/3; }

  /* Counters */
  .counters-row { padding:32px 20px; }

  /* CTA */
  .cta-buttons { flex-direction:column; align-items:stretch; }
  .btn-call,.btn-sms-cta,.btn-primary-cta { justify-content:center; width:100%; }

  /* About */
  .about-image-wrap img { height:280px; }
  .about-badge { position:static; margin-top:20px; display:inline-flex; align-items:center; gap:12px; border-radius:12px; padding:14px 20px; }
  .about-badge .num { font-size:2rem; }
  /* Mobile: left align — mais legível em tela pequena */
  #about .about-text { text-align:left; }

  /* Review card */
  .review-card { padding:28px 22px; }

  /* FAQ */
  #faq .faq-icon { width:36px; height:36px; min-width:36px; font-size:1rem; margin-right:10px; }
  #faq .accordion-button { padding:16px; font-size:1rem; }
  #faq .accordion-body { padding:0 16px 18px; font-size:.92rem; }

  /* Footer */
  footer { padding:50px 0 0; }
  .footer-map iframe { height:140px; }

  /* Floating */
  .float-wa { bottom:78px; right:16px; width:50px; height:50px; font-size:1.4rem; }
  .float-top { bottom:20px; right:16px; width:42px; height:42px; }
}

/* ── ≤ 576px (Mobile pequeno) ───────────────────────────── */
@media (max-width:576px) {

  .navbar-brand img { height:60px; max-width:110px; transform:translateY(10px); }

  .hero-left { padding:90px 16px 36px; }
  .hero-badge { font-size:.72rem; padding:5px 12px; margin-top: 15px;}
  .hero-stats { gap:14px; }
  .hero-stat .number { font-size:1.8rem; }
  .hero-divider { height:36px; }

  .service-card { padding:28px 20px; }

  .gallery-grid { grid-template-columns:1fr; }
  .gallery-filter-btn { padding:8px 18px; font-size:.88rem; }

  .form-card { padding:24px 16px; }
  #estimateModal .modal-body { padding:16px; }
  #estimateModal .modal-header { padding:16px 20px; }

  #why .row .col-6 { flex:0 0 100%; max-width:100%; }
  .counters-row { border-radius:12px; padding:28px 16px; }

  footer { padding:40px 0 0; }
  .footer-desc { max-width:100%; }
  .area-tag { font-size:.72rem; padding:2px 8px; }
}

/* ── ≤ 400px (Telefones muito pequenos) ─────────────────── */
@media (max-width:400px) {
  .hero-title { font-size:1.6rem; }
  .hero-badge { font-size:.72rem; padding:5px 12px; margin-top: 15px;}  
  .hero-subtitle { font-size:.88rem; }
  .btn-primary-cta,.btn-sms-cta { font-size:.9rem; padding:12px 14px; }
  .section-title { font-size:1.5rem; }
  .counter-number { font-size:1.8rem; }
  .navbar-brand img { height:54px; max-width:100px; }
  .btn-call-nav { font-size:.75rem; padding:6px 10px; }
}
