[data-bs-theme="dark"] {
    --bs-body-bg: #0a0a0a;
    --bs-body-color: #ffffff;
    --bs-tertiary-bg: #0a0a0a !important;
    --bs-secondary-bg: #0a0a0a;
    --bs-border-color: #ffffff !important;
    --bs-card-bg: #0a0a0a;
    --bs-navbar-bg: #0a0a0a;
}

[data-bs-theme="light"] {
    --bs-body-bg: #FFFEEF;
    --bs-body-color: #000000;
    --bs-tertiary-bg: #FFFEEF !important;
    --bs-secondary-bg: #FFFEEF;
    --bs-border-color: #000000 !important;
    --bs-card-bg: #FFFEEF;
    --bs-navbar-bg: #FFFEEF;
}

body {
    font-family: "Comic Relief", system-ui;
    font-weight: 400;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

main {
    flex: 1;
}

html {
    scrollbar-width: none;
}

.navbar,
footer {
    background-color: var(--bs-navbar-bg) !important;
}

.navbar.bg-body-tertiary,
footer.bg-body-tertiary {
    background-color: var(--bs-tertiary-bg) !important;
}

.nav-link.active {
    color: #ffffff !important;
    background-color: #dc3545 !important;
    border-radius: 0.375rem;
}

.nav-link:hover {
    color: #dc3545 !important;
    background-color: transparent !important;
}

.scroll-progress {
    position: fixed;
    top: 0;
    left: 0;
    width: 0%;
    height: 4px;
    background: #dc3545;
    transition: width 0.1s ease-out;
    z-index: 9999;
}

.project-card {
    border: 1px solid var(--bs-border-color);
    border-radius: 1rem;
    background-color: var(--bs-card-bg);
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.project-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(220, 53, 69, 0.18);
    border-color: #dc3545 !important;
}

.tech-badge {
    font-size: 0.72rem;
    padding: 0.25em 0.6em;
    border-radius: 0.375rem;
    background-color: rgba(220, 53, 69, 0.12);
    color: #dc3545;
    border: 1px solid rgba(220, 53, 69, 0.3);
    font-weight: 700;
}

.floating {
    animation: floating 3s ease-in-out infinite;
}

@keyframes floating {

    0%,
    100% {
        transform: translateY(0);
    }

    50% {
        transform: translateY(-8px);
    }
}

.section-label {
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
}
