/* Custom styles */
body {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

.container-fluid {
    flex: 1;
}

.hover-card:hover {
    transform: translateY(-5px);
    transition: transform 0.3s ease;
    cursor: pointer;
}

.hover-lift {
    transition: transform 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
}
.hover-lift:hover {
    transform: translateY(-5px);
    box-shadow: 0 .5rem 1rem rgba(0,0,0,.15)!important;
}

/* Estados */
.estado-badge {
    padding: 0.5em 0.8em;
    border-radius: 0.25rem;
    font-weight: bold;
    font-size: 0.9em;
}
.estado-OTORGADO { color: #6c757d; background-color: #f8f9fa; border: 1px solid #dee2e6; }
.estado-CONFIRMADO { color: #fff; background-color: #0d6efd; }
.estado-EN_ATENCION { color: #fff; background-color: #198754; animation: pulse 2s infinite; }
.estado-ATENDIDO { color: #fff; background-color: #212529; }
.estado-CANCELADO { color: #fff; background-color: #dc3545; }
.estado-AUSENTE { color: #fff; background-color: #fd7e14; }

@keyframes pulse {
    0% { opacity: 1; }
    50% { opacity: 0.8; }
    100% { opacity: 1; }
}

/* Tablas */
.table-responsive {
    border-radius: 8px;
    box-shadow: 0 2px 4px rgba(0,0,0,0.05);
}

/* Navbar / Dropdowns */
.navbar {
    position: relative;
    z-index: 5000 !important;
}
.navbar .dropdown-menu {
    z-index: 6000 !important;
}

/* Bandejas */
.card-atencion-activa {
    border-left: 5px solid #198754;
}

.turno-numero-grande {
    font-size: 2.5rem;
    font-weight: 800;
    line-height: 1;
}

/* Utilidades de altura */
@media (min-width: 992px) {
    .h-100-visual {
        height: calc(100vh - 180px); /* Ajuste aproximado para ocupar pantalla */
        overflow-y: auto;
    }
}
@media (max-width: 991.98px) {
    .h-100-visual {
        height: auto;
        overflow-y: visible;
    }
}
