/* Custom Theme Override matching TAIS Logo and BRD */
:root, [data-bs-theme="light"] {
    --bs-primary: #012f87;
    --bs-primary-rgb: 1, 47, 135;
    
    --bs-secondary: #2E75B6;
    --bs-secondary-rgb: 46, 117, 182;
    
    --bs-success: #17A589;
    --bs-success-rgb: 23, 165, 137;
    
    --bs-warning: #fcb82f;
    --bs-warning-rgb: 252, 184, 47;
    
    --bs-danger: #C0392B;
    --bs-danger-rgb: 192, 57, 43;
    
    /* Ensure link colors match secondary (blue) as per BRD */
    --bs-link-color: #2E75B6;
    --bs-link-color-rgb: 46, 117, 182;
    --bs-link-hover-color: #012f87;
    --bs-link-hover-color-rgb: 1, 47, 135;
    
    /* Topbar and Menu specific overwrites if they rely on custom variables */
    --bs-topbar-bg: #012f87;
    --bs-topbar-item-color: rgba(255, 255, 255, 0.75);
    --bs-topbar-item-hover-color: #ffffff;
    
    --bs-menu-bg: #ffffff;
    --bs-menu-item-active-color: #012f87;

    /* Logo Height Overrides */
    --bs-logo-lg-height: 60px;
}

/* Logo Text Styles */
.logo-lg {
    display: flex !important;
    align-items: center;
    height: 100%;
}

.logo-text-container {
    margin-left: 10px;
    text-align: left;
    white-space: nowrap;
    line-height: 1.3;
}

.logo-text-school {
    display: block;
    font-size: 14px;
    font-weight: 800;
    letter-spacing: 0.5px;
}

.logo-text-system {
    display: block;
    font-size: 10px;
    font-weight: 500;
    opacity: 0.8;
}

.logo-light .logo-text-school,
.logo-light .logo-text-system {
    color: #ffffff;
}

.logo-dark .logo-text-school,
.logo-dark .logo-text-system {
    color: var(--bs-primary);
}

/* Topbar logo text — always white since topbar background is dark */
.app-topbar .logo-topbar .logo-text-school,
.app-topbar .logo-topbar .logo-text-system {
    color: #ffffff;
}

/* Sidebar logo: add bottom margin for spacing */
.sidenav-menu > a.logo {
    margin-bottom: 8px;
}

/* logo-topbar: flex align for image + text */
.logo-topbar {
    display: none;
    align-items: center;
}

.logo-topbar span.logo-lg {
    display: flex;
    align-items: center;
}

/* Ensure logo images are sized consistently */
.logo-lg img {
    height: 40px !important;
    width: auto;
}

/* Mobile: hide sidebar logo, show topbar logo centered */
@media (max-width: 768px) {
    /* Anchor for absolute-positioned logo */
    .topbar-menu {
        position: relative;
    }

    /* Hide logo inside the sidebar */
    .sidenav-menu > a.logo {
        display: none !important;
    }

    /* Show the topbar logo on mobile, centered */
    .logo-topbar {
        display: flex !important;
        position: absolute;
        left: 50%;
        transform: translateX(-50%);
        pointer-events: auto;
        z-index: 1;
    }
}

/* Ensure background classes respect the variables */
.bg-primary {
    background-color: var(--bs-primary) !important;
}
.text-primary {
    color: var(--bs-primary) !important;
}
.btn-primary {
    --bs-btn-bg: var(--bs-primary);
    --bs-btn-border-color: var(--bs-primary);
    --bs-btn-hover-bg: #01266d;
    --bs-btn-hover-border-color: #01266d;
    --bs-btn-active-bg: #01266d;
    --bs-btn-active-border-color: #01266d;
}
