/* =========================
   RESPONSIVE.CSS
========================= */

/* HEADER MOBILE - BASE */
.topo-acoes-mobile{
    display:none;
}

.menu-toggle{
    display:none;
    width:40px;
    height:40px;
    border:none;
    background:rgba(0,0,0,0.05);
    border-radius:10px;
    cursor:pointer;
    flex-direction:column;
    justify-content:center;
    align-items:center;
    gap:5px;
    padding:0;
    flex-shrink:0;
}

.menu-toggle span{
    width:18px;
    height:2px;
    background:#174A97;
    display:block;
    border-radius:999px;
    transition:0.3s ease;
}

.menu-toggle.ativo span:nth-child(1){
    transform:translateY(7px) rotate(45deg);
}

.menu-toggle.ativo span:nth-child(2){
    opacity:0;
}

.menu-toggle.ativo span:nth-child(3){
    transform:translateY(-7px) rotate(-45deg);
}

@media (max-width: 1280px){
    .container{
        padding-left:24px;
        padding-right:24px;
    }

    .hero .container{
        padding-left:40px;
        padding-right:24px;
    }

    .hero-conteudo{
        max-width:680px;
    }

    .diferenciais-grid,
    .servicos-grid-6,
    .galeria-grid{
        grid-template-columns:repeat(2, minmax(0,1fr));
    }

    .sobre-grid{
        gap:42px;
    }

    .contato-grid{
        grid-template-columns:1fr 1fr;
    }
}

@media (max-width: 1024px){
    .topo-flex{
        gap:20px;
    }

    .topo-esquerda{
        gap:20px;
    }

    .menu{
        gap:16px;
    }

    .hero{
        min-height:auto;
        padding-top:120px;
        padding-bottom:120px;
    }

    .hero .container{
        padding-left:28px;
        padding-right:24px;
    }

    .hero-conteudo{
        max-width:100%;
        margin-top:0;
        padding:34px 28px 30px;
    }

    .hero h1{
        max-width:100%;
        font-size:clamp(2.8rem, 6vw, 4rem);
    }

    .diferenciais-rapidos{
        margin-top:-48px;
        padding-top:14px;
        padding-bottom:34px;
    }

    .diferenciais-grid{
        grid-template-columns:repeat(2, minmax(0,1fr));
        gap:18px;
    }

    .diferencial-item{
        min-height:auto;
    }

    .sobre-grid,
    .contato-grid,
    .rodape-grid,
    .equipe-grid{
        grid-template-columns:1fr;
    }

    .equipe-grid{
        gap:24px;
    }

    .imagem-placeholder.grande{
        min-height:360px;
    }

    .contato-box,
    .form-contato{
        width:100%;
    }
}

@media (max-width: 860px){
    .topo-flex{
        flex-direction:column;
        align-items:flex-start;
        justify-content:center;
        padding:14px 0;
    }

    .topo-esquerda{
        flex-direction:column;
        align-items:flex-start;
        width:100%;
        gap:14px;
    }

    .menu{
        width:100%;
        display:flex;
        flex-wrap:wrap;
        gap:12px 16px;
    }

    .area-cliente{
        width:100%;
    }

    .area-cliente a{
        width:100%;
    }

    .linha-campos{
        grid-template-columns:1fr;
    }

    .diferenciais-grid,
    .servicos-grid-6,
    .galeria-grid{
        grid-template-columns:1fr;
    }
}

@media (max-width: 768px){
    .container{
        padding-left:20px;
        padding-right:20px;
    }

    .topo{
        position:fixed;
        top:0;
        left:0;
        width:100%;
        z-index:1000;
        background:#ffffff;
        border-bottom:1px solid rgba(0,0,0,0.06);
        backdrop-filter:none;
        -webkit-backdrop-filter:none;
    }

    .topo-flex{
        padding:10px 0;
        gap:0;
    }

    .topo-esquerda{
        width:100%;
        display:flex;
        align-items:center;
        justify-content:space-between;
        gap:10px;
        flex-direction:row;
        position:relative;
    }

    .topo-direita{
        display:none !important;
    }

    .topo-acoes-mobile{
        display:flex !important;
        align-items:center;
        gap:8px;
        margin-left:auto;
        flex-shrink:0;
    }

    .logo-topo{
        height:34px;
        width:auto;
        max-width:135px;
        flex-shrink:0;
    }

    .btn-whatsapp-mobile{
        display:inline-flex;
        align-items:center;
        justify-content:center;
        gap:6px;
        min-height:40px;
        padding:0 12px;
        font-size:0.72rem;
        white-space:nowrap;
        border-radius:10px;
        background:#174A97;
        color:#ffffff;
    }

    .btn-whatsapp-mobile i{
        font-size:0.95rem;
    }

    .menu-toggle{
        display:flex !important;
        background:rgba(0,0,0,0.05);
    }

    .hero .container{
        padding-left:20px;
        padding-right:20px;
    }

    .hero{
        padding-top:96px !important;
        padding-bottom:88px;
    }

    .hero-conteudo{
        padding:28px 20px 24px;
        border-radius:12px;
    }

    .hero h1{
        font-size:clamp(2.2rem, 8vw, 3rem);
        line-height:1.02;
    }

    .hero p{
        font-size:0.98rem;
        line-height:1.7;
    }

    .hero-acoes{
        flex-direction:column;
        align-items:stretch;
    }

    .hero-acoes .btn-servico,
    .hero-acoes .btn-secundario{
        width:100%;
    }

    .menu{
        position:absolute;
        top:calc(100% + 10px);
        left:0;
        right:0;
        display:none !important;
        flex-direction:column;
        align-items:flex-start;
        gap:0;
        padding:16px;
        border-radius:14px;
        background:#ffffff;
        border:1px solid rgba(0,0,0,0.06);
        box-shadow:0 18px 40px rgba(0,0,0,0.12);
        z-index:1001;
    }

    .menu.ativo{
        display:flex !important;
    }

    .menu a{
        width:100%;
        padding:12px 0;
        border-bottom:1px solid rgba(0,0,0,0.06);
        font-size:0.95rem;
        color:#0f172a;
    }

    .menu a:last-child{
        border-bottom:none;
    }

    .diferenciais-rapidos{
        margin-top:-28px;
        padding-top:12px;
        padding-bottom:28px;
    }

    .diferenciais-grid{
        grid-template-columns:1fr;
        gap:16px;
    }

    .diferencial-item{
        padding:18px 18px 16px;
        border-radius:14px;
    }

    .diferencial-item::before{
        left:16px;
        right:16px;
    }

    .diferencial-item h3{
        font-size:0.98rem;
        margin-bottom:8px;
    }

    .diferencial-item p{
        font-size:0.94rem;
        line-height:1.6;
    }

    .sobre-home,
    .servicos-section,
    .equipe,
    .projetos,
    .contato{
        padding:72px 0;
    }

    .sobre-grid{
        gap:28px;
    }

    .sobre-conteudo h2,
    .section-header h2,
    .servicos-header h2{
        font-size:clamp(1.9rem, 7vw, 2.6rem);
    }

    .servico-card-home,
    .diferencial-item,
    .membro-card{
        min-height:auto;
    }

    .membro-foto,
    .galeria-item,
    .imagem-placeholder.grande{
        min-height:240px;
    }

    .whatsapp-float{
        right:20px;
        bottom:20px;
        width:54px;
        height:54px;
    }

    .whatsapp-badge{
        display:none;
    }
}

@media (max-width: 600px){
    .logo-topo{
        height:32px;
        max-width:124px;
    }

    .menu{
        left:0;
        right:0;
    }

    .hero{
        padding-top:88px !important;
        padding-bottom:72px;
    }

    .hero-conteudo{
        padding:24px 18px 22px;
    }

    .hero h1{
        font-size:2.05rem;
    }

    .hero p{
        font-size:0.95rem;
    }

    .diferenciais-rapidos{
        margin-top:-20px;
        padding-bottom:36px;
    }

    .diferencial-item,
    .servico-card-home,
    .membro-card,
    .form-contato,
    .contato-box{
        padding-left:18px;
        padding-right:18px;
    }

    .form-contato input,
    .form-contato textarea{
        font-size:0.95rem;
    }

    .servico-card-home h3,
    .diferencial-item h3{
        font-size:1rem;
    }

    .servico-card-home p,
    .diferencial-item p,
    .membro-card p{
        font-size:0.94rem;
    }

    .galeria-item{
        min-height:220px;
    }
}

@media (max-width: 480px){
    .container{
        padding-left:16px;
        padding-right:16px;
    }

    .hero .container{
        padding-left:16px;
        padding-right:16px;
    }

    .topo-flex{
        padding:8px 0;
    }

    .logo-topo{
        height:30px;
        max-width:118px;
    }

    .topo-acoes-mobile{
        gap:6px;
    }

    .btn-whatsapp-mobile{
        min-height:36px;
        padding:0 10px;
        font-size:0.66rem;
        border-radius:9px;
    }

    .btn-whatsapp-mobile i{
        font-size:0.88rem;
    }

    .menu-toggle{
        width:36px;
        height:36px;
        border-radius:9px;
    }

    .menu-toggle span{
        width:16px;
    }

    .hero{
        padding-top:84px !important;
    }

    .hero h1{
        font-size:1.9rem;
    }

    .hero-conteudo{
        padding:22px 16px 20px;
    }

    .btn-servico,
    .btn-secundario{
        min-height:46px;
        padding:0 16px;
        font-size:0.76rem;
    }

    .membro-foto,
    .galeria-item,
    .imagem-placeholder.grande{
        min-height:220px;
    }

    .contato-box,
    .form-contato,
    .membro-card,
    .servico-card-home,
    .diferencial-item{
        border-radius:12px;
    }

    .diferenciais-rapidos{
        margin-top:-18px;
        padding-top:10px;
        padding-bottom:24px;
    }

    .diferencial-item{
        padding:16px 16px 15px;
        border-radius:12px;
    }

    .diferencial-item::before{
        left:14px;
        right:14px;
    }

    .diferencial-item h3{
        font-size:0.95rem;
    }

    .diferencial-item p{
        font-size:0.92rem;
        line-height:1.55;
    }
}

/* ===== RESPONSIVO ADMIN ===== */

@media (max-width: 980px){
    .admin-sidebar{
        position:relative;
        width:100%;
        top:auto;
        left:auto;
        bottom:auto;
        z-index:auto;
    }

    .admin-layout{
        flex-direction:column;
    }

    .admin-main{
        margin-left:0;
        width:100%;
        padding:18px;
    }

    .colaboradores-grid,
    .grid-duplo,
    .form-grid,
    .permissoes-grid,
    .cards-resumo,
    .cards-resumo-3{
        grid-template-columns:1fr !important;
    }

    .bloco-topo-flex{
        flex-direction:column;
        align-items:flex-start;
    }

    .busca-admin{
        max-width:100%;
        width:100%;
    }

    .busca-admin input{
        width:100%;
    }

    .relatorios-grid,
    .permissoes-paineis,
    .configuracoes-grid{
        grid-template-columns:1fr;
    }
}

@media (max-width: 640px){
    .admin-main{
        padding:14px;
    }

    .bloco-admin,
    .admin-topbar{
        padding:18px;
    }

    .form-acoes,
    .modal-acoes{
        flex-direction:column;
    }

    .btn-admin,
    .form-acoes .btn-admin{
        width:100%;
    }

    .tabela-admin{
        min-width:700px;
    }

    .login-box{
        padding:24px 18px;
        border-radius:20px;
    }

    .login-brand{
        align-items:center;
    }

    .login-logo-box{
        width:60px;
        height:60px;
    }

    .login-brand-text strong{
        font-size:20px;
    }

    .login-header h1{
        font-size:24px;
    }
}