/* ====== Colores institucionales UTB ====== */
.bg-utb {
    background-color: #007a33 !important; /* Verde UTB */
}
.text-utb { color: #007a33 !important; }
.btn-utb {
    background-color: #007a33;
    border-color: #007a33;
    color: #fff;
    font-weight: 600;
    transition: 0.2s;
}
.btn-utb:hover {
    background-color: #005a25;
    border-color: #005a25;
    color: #fff;
}

/* ====== Marca (logo + texto) ====== */
.navbar .utb-logo {
    height: 40px;
    width: auto;
    transition: transform 0.2s ease;
}

.navbar .utb-logo:hover {
    transform: scale(1.05);
}

.navbar .brand-text {
    color: #ffffff;
    font-weight: 700;
    font-size: 1.25rem;
    letter-spacing: 0.5px;
}

.navbar .brand-text span {
    color: #ffcc00; /* Dorado institucional */
}

/* ====== Enlaces ====== */
.navbar.bg-utb .navbar-nav .nav-link {
    color: #ffffff !important;
    font-weight: 500;
    padding: 0.5rem 1rem;
    transition: all 0.2s ease-in-out;
}

.navbar.bg-utb .navbar-nav .nav-link:hover {
    color: #ffffff;
    background-color: #005a25;
    border-radius: 0.25rem;
}

/* ====== Botón de logout ====== */
.navbar .logout:hover {
    text-decoration: underline;
}

/**********/

body {
    background-color: #f8fafc;
}

.card {
    transition: all 0.3s ease;
}

.card:hover {
    transform: translateY(-5px);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.08);
}

.text-primary {
    color: #0a3981 !important; /* Azul institucional UTB */
}

.btn-primary {
    background-color: #0a3981;
    border-color: #0a3981;
}

.btn-primary:hover {
    background-color: #072a61;
    border-color: #072a61;
}

.btn-outline-warning:hover {
    background-color: #ffb100;
    color: white;
}

.rounded-4 {
    border-radius: 1rem !important;
}

/* --- Fix visual de Select2 en Bootstrap 5 --- */
.select2-container--krajee-bs5 .select2-selection--multiple {
    display: flex!important;
    flex-wrap: wrap;
    min-height: 38px;
    height: auto !important;
    overflow: visible !important;
    white-space: normal !important;
    border: 1px solid #ced4da;
    border-radius: 0.375rem;
    padding: 4px;
}

.select2-container--krajee-bs5 .select2-selection__choice {
    background-color: #f1f3f5;
    border: 1px solid #dee2e6;
    color: #212529;
    border-radius: 20px;
    padding: 3px 8px;
    margin: 3px 5px 3px 0;
    font-size: 0.9rem;
    display: flex!important;
}

.select2-container--krajee-bs5 .select2-selection__choice__remove {
    color: #6c757d !important;
    margin-right: 5px;
    font-weight: bold;
}

.select2-container--krajee-bs5 .select2-selection__clear {
    color: #dc3545 !important;
    margin-right: 8px;
    cursor: pointer;
}

.select2-container--krajee-bs5 .select2-selection__choice__remove:hover {
    color: #000 !important;
}
