/* =========================
   LAYOUT.CSS
========================= */

/* HEADER */
.topo{
    position:fixed;
    top:0;
    left:0;
    width:100%;
    z-index:999;
    background:rgba(255,255,255,0.86);
    backdrop-filter:blur(14px);
    -webkit-backdrop-filter:blur(14px);
    border-bottom:1px solid rgba(15,23,42,0.06);
    box-shadow:0 8px 24px rgba(15,23,42,0.05);
    transition:background 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease;
}

.topo-flex{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:28px;
    min-height:78px;
}

.topo-esquerda{
    display:flex;
    align-items:center;
    gap:28px;
}

.logo-topo{
    height:44px;
    width:auto;
    object-fit:contain;
    display:block;
}

.menu{
    display:flex;
    align-items:center;
    gap:22px;
    flex-wrap:wrap;
}

.menu a{
    position:relative;
    display:inline-flex;
    align-items:center;
    min-height:36px;
    color:var(--primary);
    font-size:0.83rem;
    font-weight:800;
    letter-spacing:0.08em;
    text-transform:uppercase;
    opacity:0.92;
    transition:color 0.3s ease, opacity 0.3s ease;
}

.menu a::after{
    content:"";
    position:absolute;
    left:0;
    bottom:2px;
    width:100%;
    height:2px;
    background:var(--accent);
    transform:scaleX(0);
    transform-origin:right;
    transition:transform 0.3s ease;
}

.menu a:hover{
    color:var(--accent);
    opacity:1;
}

.menu a:hover::after{
    transform:scaleX(1);
    transform-origin:left;
}

.area-cliente a{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:44px;
    padding:0 18px;
    border-radius:var(--radius-sm);
    background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);
    border:1px solid rgba(23,74,151,0.90);
    box-shadow:0 8px 18px rgba(23,74,151,0.20);
    color:var(--white);
    font-size:0.76rem;
    font-weight:800;
    letter-spacing:0.06em;
    text-transform:uppercase;
    line-height:1.15;
    transition:transform 0.3s ease, box-shadow 0.3s ease;
}

.area-cliente a:hover{
    transform:translateY(-2px);
    box-shadow:0 14px 26px rgba(23,74,151,0.28);
}

/* HERO */
  .hero{
    position:relative;

    min-height:78vh; /* altura principal */

    display:flex;
    align-items:center;

    padding-top:140px;
    padding-bottom:120px;

    overflow:hidden;
}

.hero-bg{
    position:absolute;
    inset:0;
    z-index:1;
    overflow:hidden;
}

.hero-slide{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center center;
    opacity:0;
    transform:scale(1.04);
    filter:saturate(0.95) contrast(1.02) brightness(0.82);
}

.hero-slide.ativo{
    opacity:1;
    transform:scale(1);
}

.hero::before{
    content:"";
    position:absolute;
    inset:0;
    z-index:2;
    background:linear-gradient(
        90deg,
        rgba(6,12,22,0.78) 0%,
        rgba(8,16,29,0.60) 30%,
        rgba(10,18,32,0.34) 55%,
        rgba(10,18,32,0.14) 76%,
        rgba(10,18,32,0.03) 100%
    );
}

.hero::after{
    content:"";
    position:absolute;
    inset:0;
    z-index:2;
    background:linear-gradient(
        180deg,
        rgba(0,0,0,0.08) 0%,
        rgba(0,0,0,0.12) 38%,
        rgba(0,0,0,0.28) 100%
    );
    pointer-events:none;
}

.hero .container{
    position:relative;
    z-index:3;
    max-width:1800px;
    padding-left:40px;
    padding-right:32px;
    display:flex;
    justify-content:flex-start;
}

.hero-wrap{
    position:relative;
    z-index:3;
    width:100%;
}

.hero-conteudo{
    max-width:700px;
    margin-top:-44px;
    padding:40px 40px 34px;
    background:linear-gradient(180deg, rgba(15,23,42,0.56) 0%, rgba(15,23,42,0.38) 100%);
    border:1px solid var(--glass-border);
    border-radius:var(--radius-md);
    backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);
    box-shadow:var(--shadow-hero), inset 0 1px 0 rgba(255,255,255,0.06);
}

.hero h1{
    max-width:14ch;
    margin-bottom:22px;
    color:var(--white);
    font-size:clamp(2.4rem,4.8vw,3.9rem);
    line-height:1.02;
    letter-spacing:-0.045em;
    font-weight:900;
    text-wrap:balance;
}

.hero p{
    max-width:54ch;
    margin-bottom:28px;
    color:rgba(255,255,255,0.84);
    font-size:1.04rem;
    line-height:1.8;
}

.hero-acoes{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
}

/* DIFERENCIAIS */
.diferenciais-rapidos{
    position:relative;
    z-index:6;
    margin-top:-80px;
    padding-bottom:44px;
}

.diferenciais-grid{
    display:grid;
    grid-template-columns:repeat(4, minmax(0,1fr));
    gap:22px;
    align-items:stretch;
}

/* SOBRE */
.sobre-home{
    padding:00px
    background:linear-gradient(180deg,#ffffff 0%,#f8fafc 100%);
}

.sobre-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:56px;
    align-items:center;
}

.imagem-placeholder.grande{
    min-height:500px;
}

.sobre-conteudo{
    max-width:640px;
    display:flex;
    flex-direction:column;
    justify-content:center;
}

.sobre-conteudo h2{
    max-width:23ch;
    margin-bottom:20px;
    color:var(--text-dark);
    font-size:clamp(38px,3.2vw,46px);
    line-height:1.05;
    letter-spacing:-0.035em;
    font-weight:900;
}

.sobre-conteudo p{
    max-width:56ch;
    margin-bottom:22px;
    color:var(--text-light);
    font-size:1rem;
    line-height:1.9;
}

.lista-beneficios{
    margin:8px 0 30px;
    padding-left:22px;
}

.lista-beneficios li{
    margin-bottom:14px;
    padding-left:4px;
    color:#1e293b;
    font-size:1rem;
    line-height:1.75;
}

.lista-beneficios li::marker{
    color:var(--accent);
}

/* SERVIÇOS */
.servicos-section{
    padding:104px 0;
    background:linear-gradient(180deg,#eef3f8 0%,#f8fafc 45%,#ffffff 100%);
}

.servicos-grid{
    display:grid;
    gap:24px;
}

.servicos-grid-6{
    grid-template-columns:repeat(3, minmax(0,1fr));
}

/* EQUIPE */
.equipe{
    padding:0px 0;
    background:#ffffff;
}

.equipe-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(420px,1fr));
    gap:32px;
    width:100%;
}

/* PROJETOS */
.projetos{
    padding:96px 0;
    background:linear-gradient(180deg,#f8fafc 0%,#eef3f9 100%);
}

.galeria-grid{
    display:grid;
    grid-template-columns:repeat(3, minmax(0,1fr));
    gap:24px;
    align-items:stretch;
}

/* CONTATO */
.contato{
    padding:96px 0;
    background:linear-gradient(180deg,#f8fafc 0%,#eef3f9 100%);
}

.contato-grid{
    display:grid;
    grid-template-columns:0.88fr 1.12fr;
    gap:24px;
    align-items:start;
}

.linha-campos{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:14px;
    margin-bottom:14px;
}

/* RODAPÉ */
.rodape{
    padding:44px 0;
    background:linear-gradient(135deg,#0b1422 0%,#123054 100%);
    color:var(--white);
    border-top:1px solid rgba(255,255,255,0.06);
}

.rodape-grid{
    display:grid;
    grid-template-columns:1.2fr 0.8fr 0.8fr;
    gap:24px;
    align-items:start;
}

.logo-rodape{
    height:44px;
    width:auto;
    margin-bottom:14px;
    filter:brightness(0) invert(1);
}

.rodape h3{
    margin-bottom:12px;
    color:var(--white);
    font-size:1rem;
    line-height:1.3;
    font-weight:800;
}

.rodape p,
.rodape a{
    display:block;
    margin-bottom:8px;
    color:rgba(255,255,255,0.84);
    font-size:0.95rem;
    line-height:1.75;
}

.rodape a:hover{
    color:var(--accent);
}