:root { --azul: #0000e6; --preto: #000; --branco: #fff; }
* { margin: 0; padding: 0; box-sizing: border-box; }
body { font-family: 'Inter', sans-serif; background: var(--branco); overflow-x: hidden; color: #333; scroll-behavior: smooth; }

/* NAVBAR */
.navbar { position: sticky; top: 0; background: var(--branco); padding: 25px 5%; display: flex; flex-direction: column; align-items: center; z-index: 1000; border-bottom: 2px solid #f0f0f0; }
#logo { height: 110px; margin-bottom: 20px; }
.nav-list { display: flex; gap: 40px; list-style: none; }
.nav-list a { text-decoration: none; color: var(--preto); font-weight: 800; font-size: 13px; text-transform: uppercase; letter-spacing: 2px; }

/* HERO */
.hero { height: 55vh; min-height: 450px; position: relative; display: flex; align-items: center; justify-content: center; }
.hero-video { position: absolute; width: 100%; height: 100%; object-fit: cover; }
.hero-overlay { position: absolute; inset: 0; background: rgba(0, 0, 0, 0.5); }
.hero-content { position: relative; color: var(--branco); text-align: center; z-index: 10; width: 100%; }
.hero h1 { font-family: 'Montserrat', sans-serif; font-size: clamp(50px, 12vw, 110px); font-weight: 900; line-height: 0.85; letter-spacing: -3px; }
.hero h1 span { color: var(--azul); }
.hero p { margin-top: 25px; font-size: 18px; letter-spacing: 5px; text-transform: uppercase; font-weight: 700; }

/* MODALIDADES */
.secao-modalidades { padding: 100px 5%; background: var(--preto); color: var(--branco); }
.header-secao { text-align: center; margin-bottom: 60px; }
.grid-lwo { display: grid; grid-template-columns: repeat(5, 1fr); gap: 15px; max-width: 1400px; margin: 0 auto; }
.item { position: relative; background: #111; border-radius: 8px; height: 300px; overflow: hidden; border: 1px solid #222; }
.item img { width: 100%; height: 100%; object-fit: cover; transition: 0.5s; }
.item:hover img { transform: scale(1.1); }
.label { position: absolute; bottom: 0; width: 100%; background: linear-gradient(to top, var(--azul), transparent); padding: 40px 10px 15px; text-align: center; font-weight: 900; text-transform: uppercase; font-size: 14px; }

/* FAIXA DE IMPACTO */
.faixa-impacto { background: var(--preto); padding: 80px 5%; }
.container-frase { text-align: center; max-width: 1000px; margin: 0 auto; }
.frase-principal { color: #fff; font-size: clamp(30px, 6vw, 65px); font-family: 'Montserrat'; font-weight: 900; line-height: 1.1; }
.frase-principal span { color: var(--azul); }
.linha-animada { width: 100px; height: 6px; background: var(--azul); margin: 30px auto; border-radius: 10px; }

/* ORÇAMENTO */
.faixa-orcamento { background: var(--azul); padding: 100px 5%; color: var(--branco); display: flex; justify-content: center; }
.orcamento-container-horizontal { max-width: 1200px; width: 100%; display: flex; align-items: center; justify-content: center; gap: 60px; }
.orcamento-img-lado img { width: 100%; max-width: 480px; filter: drop-shadow(0 20px 40px rgba(0,0,0,0.3)); }
.orcamento-texto-lado { text-align: center; max-width: 550px; }
.badge-fast { background: #fff; color: var(--azul); display: inline-block; padding: 6px 18px; border-radius: 50px; font-weight: 900; font-size: 12px; margin-bottom: 20px; }
.orcamento-texto-lado h3 { font-family: 'Montserrat', sans-serif; font-size: clamp(32px, 5vw, 55px); line-height: 1.1; margin-bottom: 20px; font-weight: 900; }
.orcamento-texto-lado p { color: #e5e7ff; margin-bottom: 45px; font-size: 18px; }
.btn-orcamento { background: var(--branco); color: var(--azul); padding: 22px 60px; text-decoration: none; font-weight: 900; border-radius: 6px; display: inline-block; text-transform: uppercase; }

/* PRODUÇÃO (FUNDO BRANCO RESTAURADO) */
.secao-producao { background: var(--branco); color: #333; padding: 100px 5%; text-align: center; }
.secao-producao h2 { font-family: 'Montserrat'; font-weight: 900; font-size: 35px; margin-bottom: 60px; }
.processo-row { display: flex; justify-content: space-around; align-items: center; max-width: 1100px; margin: 0 auto; gap: 20px; }
.passo strong { font-size: 60px; font-weight: 900; display: block; font-family: 'Montserrat'; line-height: 1; color: var(--azul); }
.passo p { font-weight: 700; text-transform: uppercase; font-size: 14px; margin-top: 10px; color: #333; }
.passo.prazo { background: var(--azul); color: var(--branco); width: 150px; height: 150px; border-radius: 50%; display: flex; flex-direction: column; justify-content: center; align-items: center; }
.passo.prazo strong { color: var(--branco); font-size: 65px; margin: 0; }
.passo.prazo p { color: var(--branco); margin: 0; font-size: 12px; }

/* GALERIA */
.secao-galeria { padding: 100px 0 0 0; background: var(--preto); color: var(--branco); overflow: hidden; }
.frase-impacto-galeria { font-family: 'Montserrat', sans-serif; font-size: 20px; font-weight: 900; letter-spacing: 4px; color: var(--azul); margin-top: 15px; text-shadow: 0 0 15px rgba(0, 0, 230, 0.4); text-transform: uppercase; text-align: center; }
.galeriaSwiper { width: 100%; padding: 50px 0 80px 0; }
.swiper-slide { width: 600px; aspect-ratio: 15 / 10; border-radius: 12px; overflow: hidden; box-shadow: 0 0 40px rgba(0,0,230,0.2); }
.swiper-slide img { width: 100%; height: 100%; object-fit: cover; }
.swiper-button-next, .swiper-button-prev { color: var(--azul); }
.swiper-pagination-bullet-active { background: var(--azul); }

/* FAIXA DO CONTADOR (AZUL) */
.faixa-contador-azul { background: var(--azul); padding: 80px 5%; text-align: center; width: 100%; }
.faixa-contador-azul span { font-size: 65px; font-weight: 900; color: var(--branco); }
.faixa-contador-azul h3 { font-size: 22px; font-weight: 800; color: var(--branco); text-transform: uppercase; margin-top: 10px; }

/* FOOTER */
footer { background: #0a0a0a; padding: 80px 5%; text-align: center; color: #444; }
.logo-footer { height: 60px; margin-bottom: 30px; }

@media (max-width: 1024px) {
    .grid-lwo { grid-template-columns: repeat(3, 1fr); }
    .orcamento-container-horizontal { flex-direction: column; text-align: center; gap: 40px; }
    .processo-row { flex-direction: column; align-items: center; gap: 50px; }
    .swiper-slide { width: 85%; }
}