/* ==========================================
   ESTILOS PARA CARDS COLAPSÁVEIS DOS RELATÓRIOS
   ========================================== */

/* ==========================================
   ESTILOS PARA CHECKBOXES - FORÇAR APARÊNCIA NATIVA
   ========================================== */

/* Estilo para checkboxes do dashboard - Forçar aparência nativa */
#empresas_dashboard_list input[type="checkbox"],
#usuarios_dashboard_list input[type="checkbox"],
.empresa-checkbox-dashboard,
.usuario-checkbox-dashboard {
    -webkit-appearance: checkbox !important;
    -moz-appearance: checkbox !important;
    appearance: checkbox !important;
    accent-color: #4caf50 !important;
    opacity: 1 !important;
    visibility: visible !important;
    display: inline-block !important;
    position: static !important;
    width: 20px !important;
    height: 20px !important;
    min-width: 20px !important;
    min-height: 20px !important;
    margin: 0 !important;
    padding: 0 !important;
    flex-shrink: 0 !important;
    cursor: pointer !important;
}

/* Garantir que checkboxes "selecionar todos" também apareçam */
#selecionar_todas_empresas_dashboard,
#selecionar_todos_usuarios_dashboard {
    -webkit-appearance: checkbox !important;
    -moz-appearance: checkbox !important;
    appearance: checkbox !important;
    accent-color: #1976d2 !important;
    opacity: 1 !important;
    visibility: visible !important;
    display: inline-block !important;
    position: static !important;
    width: 20px !important;
    height: 20px !important;
    min-width: 20px !important;
    min-height: 20px !important;
    margin: 0 !important;
    padding: 0 !important;
    flex-shrink: 0 !important;
    cursor: pointer !important;
}

.empresa-item-dashboard.selected {
    background-color: #e8f5e9 !important;
    border-left: 4px solid #4caf50 !important;
}

.usuario-item-dashboard.selected {
    background-color: #e3f2fd !important;
    border-left: 4px solid #2196f3 !important;
}

/* Garantir que o label funcione */
.empresa-item-dashboard label,
.usuario-item-dashboard label {
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
}

/* Estilo para checkboxes de empresas no relatório unificado */
#empresas_unificado_list input[type="checkbox"],
.empresa-checkbox-unificado {
    -webkit-appearance: checkbox !important;
    -moz-appearance: checkbox !important;
    appearance: checkbox !important;
    accent-color: #4caf50 !important;
    opacity: 1 !important;
    visibility: visible !important;
    display: inline-block !important;
    position: static !important;
    width: 20px !important;
    height: 20px !important;
    min-width: 20px !important;
    min-height: 20px !important;
    margin: 0 !important;
    padding: 0 !important;
    flex-shrink: 0 !important;
    cursor: pointer !important;
}

/* Garantir que checkbox "selecionar todas" também apareça no unificado */
#selecionar_todas_empresas_unificado {
    -webkit-appearance: checkbox !important;
    -moz-appearance: checkbox !important;
    appearance: checkbox !important;
    accent-color: #1976d2 !important;
    opacity: 1 !important;
    visibility: visible !important;
    display: inline-block !important;
    position: static !important;
    width: 20px !important;
    height: 20px !important;
    min-width: 20px !important;
    min-height: 20px !important;
    margin: 0 !important;
    padding: 0 !important;
    flex-shrink: 0 !important;
    cursor: pointer !important;
}

.empresa-item-unificado.selected {
    background-color: #e8f5e9 !important;
    border-left: 4px solid #4caf50 !important;
}

.empresa-item-unificado label {
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
}

/* ==========================================
   CARDS COLAPSÁVEIS
   ========================================== */

.collapsible-card {
    margin-bottom: 20px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
    border-radius: 8px;
    overflow: hidden;
    transition: box-shadow 0.3s ease;
}

.collapsible-card.active {
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
}

.collapsible-card .header {
    cursor: pointer;
    position: relative;
    user-select: none;
    transition: background-color 0.3s ease;
    padding-right: 60px; /* Espaço para o ícone */
}

.collapsible-card .header:hover {
    opacity: 0.95;
}

.collapsible-card .header h2 {
    margin: 0;
    padding: 0;
}

/* Ícone de expandir/colapsar */
.collapsible-card .header::after {
    content: 'expand_more';
    font-family: 'Material Icons';
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY(-50%) rotate(0deg);
    font-size: 32px;
    transition: transform 0.3s ease;
    color: rgba(255, 255, 255, 0.9);
}

.collapsible-card.active .header::after {
    transform: translateY(-50%) rotate(180deg);
}

/* Body do card - oculto por padrão */
.collapsible-card .body {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease, padding 0.3s ease;
    padding: 0 20px;
}

.collapsible-card.active .body {
    max-height: 5000px; /* Valor alto o suficiente para todo conteúdo */
    padding: 20px;
}

/* ==========================================
   BOTÃO "PRÓXIMO"
   ========================================== */

.btn-next-card {
    margin-top: 20px;
    padding: 12px 30px;
    font-size: 16px;
    background: #acbe4b;
    color: white;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.3s ease;
/* ==========================================
   BOTÃO PRÓXIMO - REMOVIDO (não usado mais)
   ========================================== */

/* 
.btn-next-card {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    box-shadow: 0 4px 15px rgba(76, 175, 80, 0.4);
}

.btn-next-card:hover {
    background: #acbe4b;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(76, 175, 80, 0.6);
}

.btn-next-card:active {
    transform: translateY(0);
}

.btn-next-card i {
    font-size: 20px;
}

.next-button-container {
    text-align: center;
    margin-top: 15px;
    padding-top: 15px;
    border-top: 1px solid #e0e0e0;
}
*/

/* ==========================================
   BADGES E INDICADORES
   ========================================== */

.card-step-badge {
    display: inline-block;
    background: rgba(255, 255, 255, 0.3);
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: bold;
    margin-left: 10px;
    vertical-align: middle;
}

.card-completed-badge {
    display: inline-block;
    background: rgba(76, 175, 80, 0.2);
    color: #2e7d32;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: bold;
    margin-left: 10px;
    vertical-align: middle;
}

/* ==========================================
   RESPONSIVIDADE
   ========================================== */

@media (max-width: 768px) {
    .collapsible-card .header {
        padding-right: 50px;
    }
    
    .collapsible-card .header::after {
        right: 15px;
        font-size: 28px;
    }
    
    .collapsible-card .header h2 {
        font-size: 16px;
    }
    
    .collapsible-card .header h2 small {
        display: block;
        margin-top: 5px;
    }
    
    .collapsible-card .body {
        padding: 0 15px;
    }
    
    .collapsible-card.active .body {
        padding: 15px;
    }
    
    /* Botão "Próximo" - REMOVIDO
    .btn-next-card {
        width: 100%;
        justify-content: center;
        padding: 14px 20px;
        font-size: 15px;
    }
    */
    
    /* Botões de tipo de relatório - responsivos */
    .tipo-relatorio-btn {
        font-size: 14px !important;
        padding: 15px !important;
        white-space: normal !important;
        word-wrap: break-word !important;
    }
    
    /* Cards de equipamentos - responsivos */
    .equipment-card-module {
        padding: 10px !important;
    }
    
    .equipment-image img {
        max-width: 40px !important;
        max-height: 40px !important;
    }
    
    .equipment-name {
        font-size: 11px !important;
        line-height: 1.3 !important;
    }
    
    /* Ajustes para listas de empresas/usuários */
    .empresa-item-dashboard,
    .empresa-item-unificado,
    .usuario-item-dashboard {
        padding: 10px 8px !important;
    }
    
    /* Botões de ação consolidados */
    .acoes-consolidado {
        display: flex;
        flex-direction: column;
        gap: 10px;
        padding: 15px;
    }
    
    .acoes-consolidado .btn {
        width: 100%;
        margin-left: 0 !important;
        margin-bottom: 10px;
        font-size: 18px !important;
        padding: 18px 30px !important;
        min-height: 56px !important;
    }
    
    .acoes-consolidado .btn .material-icons {
        font-size: 24px !important;
        vertical-align: middle !important;
    }
}

@media (max-width: 480px) {
    /* Ajustes extras para telas muito pequenas */
    .collapsible-card {
        margin-bottom: 15px;
        border-radius: 6px;
    }
    
    .collapsible-card .header {
        padding: 15px 45px 15px 15px;
    }
    
    .collapsible-card .header::after {
        right: 10px;
        font-size: 24px;
    }
    
    /* Botões ainda maiores em telas muito pequenas */
    .acoes-consolidado {
        padding: 10px;
        text-align: center;
    }
    
    .acoes-consolidado .btn {
        font-size: 20px !important;
        padding: 20px 35px !important;
        min-height: 60px !important;
    }
    
    .acoes-consolidado .btn .material-icons {
        font-size: 26px !important;
    }
    
    .collapsible-card .header h2 {
        font-size: 14px;
        line-height: 1.4;
    }
    
    .collapsible-card .body {
        padding: 0 10px;
    }
    
    .collapsible-card.active .body {
        padding: 12px 10px;
    }
    
    .btn-next-card {
        padding: 12px 15px;
        font-size: 14px;
    }
    
    .btn-next-card i {
        font-size: 18px;
    }
    
    /* Botões de tipo de relatório - extra pequenos */
    .tipo-relatorio-btn {
        font-size: 13px !important;
        padding: 12px 10px !important;
        min-height: 60px !important;
    }
    
    .tipo-relatorio-btn span {
        font-size: 13px !important;
    }
    
    /* Cards de equipamentos - extra responsivos */
    .checkbox-card-ru {
        margin: 5px 0;
    }
    
    .equipment-card-module {
        padding: 8px !important;
        min-height: auto !important;
    }
    
    .equipment-image {
        margin-bottom: 4px !important;
    }
    
    .equipment-image img {
        max-width: 35px !important;
        max-height: 35px !important;
    }
    
    .equipment-name {
        font-size: 10px !important;
        padding: 0 2px !important;
    }
    
    /* Formulários - campos menores */
    .form-group {
        margin-bottom: 10px !important;
    }
    
    .form-group label,
    .form-group b {
        font-size: 13px !important;
    }
    
    .form-control {
        font-size: 13px !important;
        padding: 8px !important;
    }
    
    /* Resumo de geração */
    #resumo_geracao_ru {
        font-size: 13px !important;
        padding: 10px !important;
    }
    
    /* Badges menores */
    .card-step-badge,
    .card-completed-badge {
        font-size: 10px;
        padding: 3px 8px;
    }
}

/* Ajustes específicos para landscape em mobile */
@media (max-width: 768px) and (orientation: landscape) {
    .collapsible-card .header h2 {
        font-size: 15px;
    }
    
    .tipo-relatorio-btn {
        font-size: 13px !important;
        padding: 12px !important;
    }
}

/* ==========================================
   ANIMAÇÕES ADICIONAIS
   ========================================== */

/* Animações removidas para evitar "piscar" durante expansão.
   A transição de max-height já fornece o efeito de slide down. */
