* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: Arial, Helvetica, sans-serif;
    color: #111827;
    background: #fff;
}



.header{
    background:#071524;
    height:94px;
    border-bottom:2px solid #0d3b66;
}

.header .container{
    width:95%;
    max-width:1800px;
    margin:auto;
    height:94px;
    display:flex;
    align-items:center;
    justify-content:space-between;
}

.logo{
    display:flex;
    align-items:center;
    margin:0;
}

.logo h1{
    margin:0;
    display:flex;
    align-items:center;
    gap:10px;
    font-size:64px;
    font-weight:900;
    line-height:1;
    color:#ffffff;
}

.logo span{
    color:#1688ff;
}

.menu{
    display:flex;
    align-items:center;
    gap:52px;
    margin-left:auto;
}

.menu a{
    color:#fff;
    font-size:19px;
    font-weight:700;
    text-decoration:none;
    text-transform:uppercase;
}

.menu a:hover{
    color:#1688ff;
}



.menu a:hover::after {
    content: "";
    height: 3px;
    width: 100%;
    background: #1688ff;
    position: absolute;
    left: 0;
    bottom: -18px;
}

.hero {
    min-height: 560px;
    background:
        linear-gradient(90deg, rgba(2,12,25,.98) 0%, rgba(2,12,25,.92) 43%, rgba(0,112,207,.35) 100%),
        repeating-linear-gradient(45deg, #061426 0, #061426 12px, #08203a 12px, #08203a 24px);
    color: white;
    display: grid;
    grid-template-columns: 1.1fr .9fr;
    align-items: center;
    padding: 70px 6%;
}

.hero h1 {
    font-size: 78px;
    font-weight: 900;
    margin-bottom: 18px;
}

.hero h1 span {
    color: #1688ff;
}

.hero h2 {
    font-size: 28px;
    font-weight: 400;
    max-width: 660px;
    margin-bottom: 25px;
}

.hero p {
    font-size: 18px;
    max-width: 560px;
    line-height: 1.6;
    color: #dbeafe;
}

.botoes {
    margin-top: 35px;
    display: flex;
    gap: 18px;
}

.btn {
    padding: 16px 28px;
    border-radius: 6px;
    text-decoration: none;
    color: white;
    font-weight: 800;
    text-transform: uppercase;
}

.azul {
    background: #1688ff;
}

.transparente {
    border: 2px solid white;
}

.hero-visual {
    min-height: 360px;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}

.hero-visual div {
    position: absolute;
    font-size: 95px;
    filter: drop-shadow(0 20px 35px rgba(0,0,0,.45));
}

.camera {
    top: 30px;
    left: 40px;
}

.monitor {
    right: 80px;
    bottom: 30px;
}

.rede {
    bottom: 5px;
    left: 150px;
}

.secao {
    padding: 55px 6%;
    text-align: center;
}

.secao h2,
.sobre h2 {
    font-size: 34px;
    text-transform: uppercase;
    margin-bottom: 35px;
    color: #0f172a;
}

.secao h2::after,
.sobre h2::after {
    content: "";
    display: block;
    width: 46px;
    height: 4px;
    background: #1688ff;
    margin: 10px auto 0;
}

.grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 22px;
}

.card {
    background: white;
    border: 1px solid #dbe3ee;
    border-radius: 10px;
    padding: 34px 25px;
    min-height: 260px;
    box-shadow: 0 8px 24px rgba(15,23,42,.08);
}

.card .icone {
    font-size: 70px;
    margin-bottom: 20px;
}

.card h3,
.servico h3 {
    font-size: 20px;
    margin-bottom: 14px;
}

.card p,
.servico p {
    font-size: 15px;
    line-height: 1.5;
}

.cinza {
    background: #f4f7fb;
}

.servico {
    padding: 25px;
}

.servico div {
    font-size: 64px;
    color: #075bb5;
    margin-bottom: 15px;
}

.sobre {
    padding: 55px 6%;
    display: grid;
    grid-template-columns: 1.2fr .8fr;
    gap: 50px;
    align-items: center;
}

.sobre p {
    font-size: 17px;
    line-height: 1.7;
}

.fachada {
    background: linear-gradient(135deg, #061426, #0b65bd);
    color: white;
    min-height: 210px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    font-size: 34px;
    font-weight: 900;
    border-radius: 8px;
    box-shadow: 0 14px 30px rgba(0,0,0,.18);
}

.fachada small {
    font-size: 16px;
    margin-top: 8px;
}

footer {
    background: #061426;
    color: white;
    padding: 35px 6%;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 35px;
}

footer h3 {
    margin-bottom: 15px;
    text-transform: uppercase;
}

footer p {
    color: #dbeafe;
    margin-bottom: 8px;
}

.whatsapp {
    position: fixed;
    right: 28px;
    bottom: 28px;
    width: 72px;
    height: 72px;
    background: #25d366;
    color: white;
    text-decoration: none;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 34px;
    box-shadow: 0 12px 30px rgba(0,0,0,.25);
}

@media (max-width: 900px) {
    .header {
        height: auto;
        padding: 20px;
        flex-direction: column;
        gap: 18px;
    }

    .menu {
        flex-wrap: wrap;
        justify-content: center;
        gap: 18px;
    }

    .hero {
        grid-template-columns: 1fr;
        text-align: center;
    }

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

    .botoes {
        justify-content: center;
        flex-wrap: wrap;
    }

    .hero-visual {
        display: none;
    }

    .grid,
    .sobre,
    footer {
        grid-template-columns: 1fr;
    }
}

.header .container{
    width:100% !important;
    max-width:none !important;
    padding:0 70px !important;
}

.logo h1{
    font-size:44px !important;
}



/* ===== AJUSTE DO CABEÇALHO ===== */

.header{
    height:80px !important;
}

.header .container{
    display:flex !important;
    justify-content:space-between !important;
    align-items:center !important;
    width:100% !important;
    max-width:100% !important;
    padding:0 60px !important;
}

.logo{
    display:flex !important;
    align-items:center !important;
}

.logo h1{
    margin:0 !important;
    display:flex !important;
    align-items:center !important;
    gap:8px !important;
    font-size:46px !important;
    font-weight:900 !important;
    line-height:1 !important;
}

.menu{
    display:flex !important;
    align-items:center !important;
    gap:38px !important;
    margin-left:auto !important;
}

.menu a{
    font-size:16px !important;
    font-weight:700 !important;
    line-height:80px !important;
}



/* ===== SLOGAN AO LADO DA LOGO ===== */

.logo{
    display:flex;
    align-items:center;
    gap:18px;
}

.logo-slogan{
    display:flex;
    align-items:center;
    gap:18px;
}

.logo-slogan .barra{
    width:2px;
    height:42px;
    background:rgba(255,255,255,.35);
}

.logo-slogan p{
    margin:0;
    color:#d8e3ef;
    font-size:16px;
    font-weight:500;
    line-height:1.3;
    letter-spacing:.3px;
}



/* Ajuste fino do slogan */

.logo-slogan{
    display:flex;
    align-items:flex-end !important;
    margin-top:14px;
}

.logo-slogan .barra{
    margin-top:0;
    height:34px;
}

.logo-slogan p{
    margin:0 0 2px 0;
    line-height:1.2;
}



/* ===== HERO PROFISSIONAL ===== */

.hero{
    min-height:720px;
    display:flex;
    align-items:center;
    background:
        linear-gradient(90deg,#03101d 0%,#04182d 55%,#0b4f9d 100%);
}

.hero-container{
    width:92%;
    max-width:1800px;
    margin:auto;
    display:grid;
    grid-template-columns:48% 52%;
    align-items:center;
    gap:40px;
}

.hero-mini{
    display:block;
    color:#1f8fff;
    font-size:18px;
    font-weight:700;
    letter-spacing:.5px;
    margin-bottom:25px;
}

.hero-esquerda h2{
    color:#fff;
    font-size:68px;
    font-weight:800;
    line-height:1.08;
    margin-bottom:30px;
}

.hero-esquerda h2 span{
    color:#1f8fff;
}

.hero-esquerda p{
    color:#d8e5f5;
    font-size:24px;
    line-height:1.8;
    max-width:700px;
}

.hero-botoes{
    display:flex;
    gap:20px;
    margin-top:45px;
}

.btn-azul,
.btn-borda{
    padding:18px 34px;
    border-radius:8px;
    text-decoration:none;
    font-weight:700;
    font-size:18px;
}

.btn-azul{
    background:#167dff;
    color:#fff;
}

.btn-borda{
    color:#fff;
    border:2px solid #ffffff;
}

.hero-direita{
    min-height:560px;
}



.hero-direita{
    min-height:620px;
    display:flex;
    align-items:center;
    justify-content:center;
    position:relative;
}

.hero-direita::before{
    content:"EM BREVE
IMAGEM DOS PRODUTOS";
    white-space:pre;
    display:flex;
    align-items:center;
    justify-content:center;
    text-align:center;
    width:620px;
    height:420px;
    border:2px dashed rgba(255,255,255,.25);
    border-radius:18px;
    color:rgba(255,255,255,.45);
    font-size:28px;
    font-weight:700;
}



/* ===== IMAGEM PRINCIPAL DO BANNER ===== */

.hero-direita{
    display:flex;
    justify-content:center;
    align-items:center;
}

.hero-direita::before{
    content:"";
    width:100%;
    height:620px;
    display:block;
    background:url("../img/banner/hero.png") no-repeat center center;
    background-size:contain;
    border:none !important;
}



/* ===== BOTÃO WHATSAPP NO BANNER ===== */

.hero{
    position:relative !important;
    overflow:hidden;
}

.whatsapp-hero{
    position:absolute;
    right:70px;
    bottom:55px;
    display:flex;
    align-items:center;
    gap:18px;
    min-width:420px;
    padding:18px 26px;
    border:3px solid #25d366;
    border-radius:70px;
    background:rgba(2,18,36,.72);
    color:#ffffff;
    text-decoration:none;
    box-shadow:0 0 22px rgba(37,211,102,.55);
    backdrop-filter:blur(8px);
    z-index:20;
    transition:.25s;
}

.whatsapp-hero:hover{
    transform:translateY(-4px);
    color:#ffffff;
    box-shadow:0 0 34px rgba(37,211,102,.9);
}

.whatsapp-icone{
    width:62px;
    height:62px;
    border-radius:50%;
    background:#25d366;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:32px;
    font-weight:900;
    flex-shrink:0;
}

.whatsapp-hero strong{
    display:block;
    font-size:20px;
    font-weight:800;
    line-height:1.2;
}

.whatsapp-hero small{
    display:block;
    font-size:15px;
    color:#d9f7e6;
    margin-top:4px;
}

.whatsapp-hero b{
    margin-left:auto;
    font-size:36px;
    font-weight:300;
    color:#ffffff;
}

@media(max-width:900px){
    .whatsapp-hero{
        position:fixed;
        right:18px;
        bottom:18px;
        min-width:auto;
        width:calc(100% - 36px);
        padding:14px 18px;
        z-index:9999;
    }

    .whatsapp-hero strong{
        font-size:16px;
    }

    .whatsapp-hero small{
        font-size:13px;
    }

    .whatsapp-icone{
        width:52px;
        height:52px;
        font-size:26px;
    }
}


/* RESPONSIVIDADE GERAL */
@media (max-width: 1100px) {
    .header {
        height: auto;
    }

    .header .container {
        height: auto;
        min-height: 94px;
        padding: 18px 0;
        flex-direction: column;
        gap: 18px;
    }

    .logo h1 {
        font-size: clamp(32px, 7vw, 56px);
    }

    .menu {
        margin-left: 0;
        gap: 18px;
        flex-wrap: wrap;
        justify-content: center;
    }

    .menu a {
        font-size: 14px;
    }

    .hero {
        grid-template-columns: 1fr;
        text-align: center;
        padding: 50px 5%;
    }

    .hero h1 {
        font-size: clamp(38px, 9vw, 78px);
    }

    .hero h2 {
        font-size: clamp(20px, 4vw, 28px);
        margin-left: auto;
        margin-right: auto;
    }

    .hero p {
        margin-left: auto;
        margin-right: auto;
    }

    .botoes {
        justify-content: center;
        flex-wrap: wrap;
    }

    .hero-visual {
        min-height: 300px;
        transform: scale(.85);
    }
}

@media (max-width: 600px) {
    .header .container {
        width: 92%;
        align-items: center;
    }

    .menu {
        flex-direction: column;
        gap: 12px;
    }

    .hero {
        min-height: auto;
        padding: 38px 18px 120px;
    }

    .hero h1 {
        line-height: 1.05;
    }

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

    .botoes {
        flex-direction: column;
    }

    .btn {
        width: 100%;
        text-align: center;
    }

    .hero-visual {
        min-height: 220px;
        transform: scale(.65);
        margin-top: -25px;
    }
}

/* AJUSTE PARA MONITORES GRANDES E ULTRAWIDE */
@media (min-width: 1600px) {
    .hero {
        min-height: 760px;
    }

    .hero-container {
        max-width: 1780px;
        grid-template-columns: 46% 54%;
        gap: 70px;
    }

    .hero-esquerda h2 {
        font-size: 76px;
        max-width: 780px;
    }

    .hero-esquerda p {
        font-size: 25px;
        max-width: 760px;
    }

    .hero-direita::before {
        height: 700px;
        transform: scale(1.12);
    }
}

/* HERO RESPONSIVA DEFINITIVA */
.hero {
    min-height: calc(100vh - 82px) !important;
    padding: clamp(45px, 6vw, 90px) 4% !important;
    display: flex !important;
    align-items: center !important;
}

.hero-container {
    width: 100% !important;
    max-width: 1800px !important;
    margin: 0 auto !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: clamp(40px, 6vw, 120px) !important;
}

.hero-esquerda {
    flex: 1 1 48% !important;
    max-width: 760px !important;
}

.hero-esquerda h2 {
    font-size: clamp(46px, 4.2vw, 86px) !important;
    line-height: 1.08 !important;
}

.hero-esquerda p {
    font-size: clamp(17px, 1.25vw, 24px) !important;
    max-width: 720px !important;
}

.hero-direita {
    flex: 1 1 52% !important;
    min-height: clamp(320px, 34vw, 680px) !important;
}

.hero-direita::before {
    width: 100% !important;
    height: clamp(320px, 34vw, 720px) !important;
    background-size: contain !important;
}

@media (max-width: 1100px) {
    .hero {
        min-height: auto !important;
        padding: 55px 24px 130px !important;
    }

    .hero-container {
        flex-direction: column !important;
        text-align: center !important;
        gap: 25px !important;
    }

    .hero-esquerda {
        max-width: 820px !important;
    }

    .hero-botoes {
        justify-content: center !important;
        flex-wrap: wrap !important;
    }

    .hero-direita {
        width: 100% !important;
        min-height: 320px !important;
    }
}

@media (max-width: 600px) {
    .hero {
        padding: 38px 18px 150px !important;
    }

    .hero-esquerda h2 {
        font-size: clamp(34px, 12vw, 48px) !important;
    }

    .hero-botoes {
        flex-direction: column !important;
    }

    .btn-azul,
    .btn-borda {
        width: 100% !important;
        text-align: center !important;
    }

    .hero-direita {
        min-height: 230px !important;
    }

    .hero-direita::before {
        height: 250px !important;
    }
}

/* MENU PREMIUM */
.menu a{
    position:relative;
    transition:.25s ease;
}

.menu a::after{
    content:"";
    position:absolute;
    left:0;
    bottom:-10px;
    width:0;
    height:3px;
    background:#1f8fff;
    border-radius:10px;
    transition:width .25s ease;
}

.menu a:hover{
    color:#1f8fff;
}

.menu a:hover::after{
    width:100%;
}

/* AJUSTE FINAL DO MENU */
.header .menu {
    gap: 52px !important;
    align-items: center !important;
}

.header .menu a {
    font-size: 19px !important;
    font-weight: 800 !important;
    letter-spacing: .3px !important;
    position: relative !important;
    padding: 8px 0 !important;
}

.header .menu a::after {
    content: "" !important;
    position: absolute !important;
    left: 0 !important;
    bottom: -8px !important;
    width: 0 !important;
    height: 3px !important;
    background: #1f8fff !important;
    border-radius: 10px !important;
    transition: width .25s ease !important;
}

.header .menu a:hover {
    color: #1f8fff !important;
}

.header .menu a:hover::after {
    width: 100% !important;
}
