/* ==========================================================================
   SIDEBAR NAVIGATION (MENU LATERAL) - v1.0
   ========================================================================== */

/* Container Principal da Sidebar */
.sidebar {
    position: fixed;
    top: 0;
    left: 0;
    width: 260px;
    background: var(--primary-color);
    color: #fff;
    display: flex;
    flex-direction: column; /* Organiza em coluna: Topo - Menu - Rodapé */
    z-index: 1040;
    transition: transform 0.3s ease;
    
    /* CORREÇÃO DE ALTURA PARA MOBILE */
    height: 100vh; /* Fallback para navegadores antigos */
    height: 100dvh; /* Altura dinâmica real (desconta barra do navegador) */
    padding-bottom: 0; /* Remove padding extra que empurrava pra fora */
}



/* Logo / Brand no Topo */
.sidebar-brand {
    padding: 25px 20px;
    display: flex;
    align-items: center;
    gap: 12px;
    border-bottom: 1px solid rgba(255,255,255,0.1);
    background: rgba(0,0,0,0.1); /* Levemente mais escuro */
}
.sidebar-brand-icon {
    width: 40px; height: 40px;
    background: var(--accent-color);
    border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.2rem;
    box-shadow: 0 4px 10px rgba(0,0,0,0.2);
}
.sidebar-brand-text h5 { margin: 0; font-weight: 800; letter-spacing: -0.5px; color: #fff; font-size: 1.1rem; }
.sidebar-brand-text small { font-size: 0.75rem; opacity: 0.6; display: block; }

/* Lista de Menus */
/* O Menu do meio (que pode crescer) */
.sidebar-menu {
    list-style: none;
    padding: 15px 10px;
    margin: 0;
    
    /* O PULO DO GATO: Ocupa o espaço que sobra e cria rolagem SE precisar */
    flex-grow: 1; 
    overflow-y: auto; 
    overflow-x: hidden;
}

.nav-item { margin-bottom: 5px; }

/* Links do Menu */
.nav-link {
    display: flex;
    align-items: center;
    padding: 12px 15px;
    color: rgba(255,255,255,0.7);
    text-decoration: none;
    border-radius: 10px;
    transition: all 0.2s;
    font-weight: 500;
    font-size: 0.95rem;
    cursor: pointer;
}

.nav-link:hover, .nav-link.active {
    background: rgba(255,255,255,0.1);
    color: #fff;
    transform: translateX(5px);
}

.nav-link i {
    width: 25px;
    font-size: 1.1rem;
    margin-right: 10px;
    text-align: center;
}

/* Badges no Menu (Notificações) */
.menu-badge {
    margin-left: auto;
    background: var(--danger-color);
    color: white;
    font-size: 0.7rem;
    padding: 2px 8px;
    border-radius: 10px;
}

/* Submenus (Dropdowns na Lateral) */
.sidebar-dropdown {
    padding-left: 30px; /* Indentação */
    display: none; /* Escondido por padrão */
    list-style: none;
    margin-top: 5px;
}
.sidebar-dropdown.show { display: block; animation: slideDown 0.3s ease; }

.sidebar-dropdown .nav-link {
    font-size: 0.85rem;
    padding: 8px 15px;
}

/* O Rodapé (Logout) - Fixo no fundo */
.sidebar-footer {
    flex-shrink: 0; /* Impede que ele seja esmagado */
    padding: 20px;
    background: rgba(0,0,0,0.2);
    border-top: 1px solid rgba(255,255,255,0.1);
}
.user-info {
    display: flex;
    align-items: center;
    gap: 12px;
    color: white;
    cursor: pointer;
}
.user-avatar {
    width: 40px; height: 40px;
    border-radius: 50%;
    background: var(--success-color);
    display: flex; align-items: center; justify-content: center;
    font-weight: bold;
    border: 2px solid rgba(255,255,255,0.2);
}
.user-details h6 { margin: 0; font-size: 0.9rem; font-weight: 700; }
.user-details span { font-size: 0.75rem; opacity: 0.7; display: block; }
.user-logout { margin-left: auto; color: rgba(255,255,255,0.5); transition: 0.2s; }
.user-logout:hover { color: var(--danger-color); }

/* css/sidebar.css */

/* ... (mantenha o resto do arquivo igual) ... */

/* Toggle Mobile (Botão de abrir menu) */
.mobile-toggle {
    display: none; /* ESCONDIDO POR PADRÃO (Desktop) */
    position: fixed; 
    top: 15px; 
    left: 15px; 
    z-index: 1100;
    background: var(--primary-color); 
    color: white;
    border: none; 
    padding: 10px 15px; /* Um pouco maior para toque */
    border-radius: 8px;
    box-shadow: 0 4px 10px rgba(0,0,0,0.2);
    cursor: pointer;
}

/* Ajuste Mobile */
@media (max-width: 991.98px) {
    .sidebar {
        transform: translateX(-100%);
        width: 280px; /* Um pouco mais largo no celular para toque */
        box-shadow: 10px 0 30px rgba(0,0,0,0.5);
    }
    .sidebar.mobile-open {
        transform: translateX(0);
    }
    
    /* O botão só aparece aqui */
    .mobile-toggle { 
        display: block !important; 
    }
}

/* GARANTIA DE DESKTOP: Força o botão a sumir em telas grandes */
@media (min-width: 992px) {
    .mobile-toggle {
        display: none !important;
    }
    .sidebar {
        transform: translateX(0) !important; /* Sidebar sempre visível no desktop */
    }
}

/* css/sidebar.css - CORREÇÃO PARA TÉCNICO */

/* Força o botão mobile a sumir se o body tiver a classe 'role-tecnico' */
body.role-tecnico .mobile-toggle {
    display: none !important;
}

/* Garante que a sidebar nunca abra para o técnico */
body.role-tecnico .sidebar {
    display: none !important;
}