/* re-design */
:root {
    /* Default: Light Mode */
    --primary-color: #f9d25f;
    --primary-accent-color: #0B0B0B;
    --primary-color-2: #fff8dc;
    --logo-filter: invert(0%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(4.3%) contrast(100%);

    --correct-color: #B4C424;
    --incorrect-color: #E25822;
    /* This updates the utility classes like .text-success and .bg-danger */
    --bs-success-rgb: 180, 196, 36;
    /* RGB version of #B4C424 */
    --bs-danger-rgb: 226, 88, 34;
    /* RGB version of #E25822 */
    --bs-primary-rgb: 249, 210, 95;
    /* RGB version of #F9d25F */

    /* Update the hex values for specific components */
    --bs-success: var(--correct-color);
    --bs-danger: var(--incorrect-color);
    --bs-primary: var(--primary-color);
}

[data-theme="dark"] {
    /* Dark Mode Overrides */
    --primary-color: #0B0B0B;
    --primary-accent-color: #f9d25f;
    --primary-color-2: #2c2c2c;
    --logo-filter: invert(86%) sepia(20%) saturate(1400%) hue-rotate(-25deg) brightness(95%) contrast(89%);
}

body {
    background-color: var(--primary-color) !important;
    background-image: none !important;
}

body>.container {
    background-color: var(--primary-color) !important;
}

.topbar {
    background-color: var(--primary-color-2);
}

/* .card {
    background-color: var(--primary-color);
    color: var(--primary-accent-color);
} */

figure.card a {
    background-color: white;
}

.site-font-blue {
    color: var(--primary-accent-color);
}

.btn-view-chart {
    border-color: var(--primary-accent-color);
    color: var(--primary-accent-color);
}

.btn-view-chart:hover,
.btn-view-chart:active,
.btn-view-chart:focus,
.btn-view-chart:focus-visible {
    background-color: var(--primary-accent-color);
    border-color: var(--primary-color);
    color: var(--primary-color);
    opacity: 0.75;
}

.btn-view-chart:hover,
.btn-view-chart:active {
    opacity: 0.75;
}

.btn-view-chart:focus,
.btn-view-chart:focus-visible {
    opacity: 1;
}

.form-check-input:checked {
    background-color: var(--primary-accent-color);
    border-color: var(--primary-accent-color);
}

body>.footer {
    color: var(--primary-accent-color);
}

.topbar-search .btn {
    background-color: var(--primary-color);
    color: white;
}

.accordion-header {
    background-color: var(--primary-accent-color);
    color: var(--primary-color);
}

.accordion-button:not(.collapsed) {
    background-color: var(--primary-color);
    color: var(--primary-accent-color);
}

.dropdown .avatar {
    background-color: var(--primary-color);
}

.dropdown .avatar:hover {
    color: var(--primary-accent-color);
    background-color: var(--primary-color);
}

li.dropend .dropdown-toggle.show {
    background-color: var(--primary-color-2);
    color: var(--primary-accent-color);
}

.dropdown-item.active,
.dropdown-item:active {
    background-color: var(--primary-accent-color);
}

.btn-primary,
.btn-primary:hover,
.btn-primary:active,
.btn-primary:focus,
.btn-primary:focus-visible {
    background-color: var(--primary-accent-color) !important;
}

.bg-primary,
.bg-info div.bg-primary {
    background-color: var(--primary-color) !important;
}

/* .btn-check:checked+.btn, .btn.active, .btn.show, .btn:first-child:active, :not(.btn-check)+.btn:active {
    background-color: var(--dark-primary-accent-color);
    color: white;
} */

.pagination,
.page-link {
    color: var(--primary-color);
}

.table-striped tbody tr:nth-child(odd) {
    background-color: #fff8dc;
}

.table-striped tbody tr:nth-child(even) {
    background-color: #fff !important;
}

.table-striped tbody tr .text-warning {
    color: var(--primary-color) !important;
}

.card-footer.bg-light {
    color: var(--primary-color);
}

.table .thead-light th {
    color: var(--primary-accent-color) !important;
    background-color: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
}

.fa-file-medical-alt::before,
.fa-file-waveform::before {
    /*clear the default icon/image */
    content: "" !important;
    display: inline-block;

    /*set the exact size you want (e.g., 40px image) */
    width: 40px;
    height: 40px;

    /*apply the image as a background */
    background-image: url('../img/logo_transp.png');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;

    filter: var(--logo-filter);

    /*alignment with text */
    vertical-align: middle;
    margin-right: 5px;
}

.sidebar .sidebar-link,
.sidebar .sidebar-brand {
    color: var(--primary-accent-color);
}

.sidebar .sidebar-brand .sidebar-brand-icon {
    transform: rotate(0deg);
}

.sidebar-brand-text.mx-3 {
    margin-left: 0 !important;
}

.bg-danger {
    background-color: var(--incorrect-color) !important;
}

.bg-success {
    background-color: var(--correct-color) !important;
}

/* Optional: Ensure buttons have high contrast text */
.btn-success,
.btn-danger {
    color: #fff !important;
    font-weight: bold;
}

/* Toggle Container */
.theme-toggle {
    --toggle-h: 20px;
    --toggle-w: 40px;
    --knob-size: 14px;
    /* Slightly smaller for a "floating" look */
    --bg-light: #e0e0e050;
    --bg-light-hover: #e0e0e07c;
    --bg-dark: #33333388;
    --bg-dark-hover: #333333b2;

    position: relative;
    display: inline-block;
    width: var(--toggle-w);
    height: var(--toggle-h);
}

.theme-toggle input {
    opacity: 0;
    width: 0;
    height: 0;
}

/* The Slider */
.slider {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: var(--bg-dark);
    transition: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    border-radius: var(--toggle-h);
}

.slider:hover {
    background-color: var(--bg-dark-hover);
}

input:checked+.slider {
    background-color: var(--bg-light);
}

input:checked+.slider:hover {
    background-color: var(--bg-light-hover);
}

/* The Circle (Sun/Moon) */
.slider:before {
    content: "";
    position: absolute;
    height: var(--knob-size);
    width: var(--knob-size);
    left: 3px;
    top: 3px;
    background-color: white;
    transition: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    border-radius: 50%;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
}

input:checked+.slider:before {
    background-color: #f1c40f;
    /* Calculation: TotalWidth - KnobSize - (LeftMargin * 2) */
    /* 40 - 14 - 6 = 20px */
    transform: translateX(20px);
}

.text-dark {
    color: var(--primary-accent-color) !important;
}