﻿/* Alinhamento do Cabeçalho */
.container-fluid.d-flex {
    display: flex !important;
    justify-content: space-between;
    align-items: center;
    width: 100%;
}

.d-flex.align-items-center {
    display: flex;
    align-items: center;
}

/* 🟢 STATUS LOGIN (Com margem para não colar no menu) */
.status-login {
    font-size: 0.65rem;
    font-weight: 800;
    margin-right: 35px; /* Afastado das barrinhas */
    padding: 2px 10px;
    border-radius: 10px;
    letter-spacing: 0.5px;
    border: 1px solid;
    white-space: nowrap;
    display: inline-block;
}

    .status-login.on {
        color: #2ecc71 !important;
        border-color: #2ecc71 !important;
        background: rgba(46, 204, 113, 0.1) !important;
    }

    .status-login.off {
        color: #95a5a6 !important;
        border-color: #95a5a6 !important;
        background: rgba(149, 165, 166, 0.1) !important;
    }

.menu-bloqueado {
    opacity: 0.6;
    pointer-events: none;
    filter: grayscale(50%);
}

.loader-aviso {
    position: fixed;
    bottom: 10px;
    right: 10px;
    background: #333;
    color: white;
    padding: 5px 15px;
    border-radius: 20px;
    font-size: 0.8rem;
    z-index: 2000;
}

/* Menu lateral */
/* Container que segura a lista de navegação */
.custom-nav-list {
    display: flex;
    flex-wrap: wrap; /* Permite quebrar a linha */
    gap: 10px; /* Espaço entre os botões */
    padding: 10px;
    justify-content: center; /* Centraliza os botões */
}

/* Cada item do menu ocupa quase 50% da largura (2 por linha) */
.nav-item-custom {
    flex: 1 1 calc(50% - 15px); /* Base de 50% menos o espaço do gap */
    min-width: 140px; /* Largura mínima para não esmagar */
}

/* O Link com cara de Botão Quadrado/Retangular */
.nav-link-button {
    display: flex;
    flex-direction: column; /* Ícone em cima, texto embaixo */
    align-items: center;
    justify-content: center;
    background-color: #052a6d;
    color: #ffffff !important;
    border-radius: 12px;
    padding: 15px 5px !important;
    font-size: 1.1rem;
    text-align: center;
    transition: all 0.2s ease;
    border: 1px solid rgba(255,255,255,0.1);
    text-decoration: none;
    height: 100%; /* Garante que todos tenham a mesma altura */
}

/* Ícone maior para o estilo grid */
.icon-menu {
    font-size: 1.6rem;
    margin-bottom: 5px;
    margin-right: 0 !important; /* Remove a margem lateral antiga */
}

/* Efeito Hover e Ativo */
.nav-link-button:hover {
    background-color: #1b6ec2;
    transform: translateY(-3px); /* Sobe um pouquinho */
}

.nav-link-button.active {
    background-color: #008000 !important;
    border-color: #fff;
    box-shadow: 0 4px 8px rgba(0,0,0,0.2);
}

/* Responsividade: Se a tela for muito pequena, mantém os 2 por linha */
@media (max-width: 400px) {
    .nav-link-button {
        font-size: 0.9rem;
        padding: 10px 5px !important;
    }
}
