/**
 * Custom fixes for specific styling issues
 */

/* Custom Navbar Styles */
.navbar {
    background-color: var(--clr-surface-a0) !important;
}

/* Custom Logo Styles */
.custom-logo-link {
    display: inline-block;
    max-width: 100%;
    height: auto;
    margin-right: 1rem;
}

.custom-logo {
    max-height: 60px;
    max-width: 240px;
    width: auto;
    height: auto; /* Maintain aspect ratio */
    object-fit: contain; /* Ensure the logo maintains its aspect ratio */
}

.mobile-logo {
    display: none;
}

/* Ensure the logo container doesn't force dimensions that could stretch the logo */
.site-branding {
    display: flex;
    align-items: center;
}

.site-branding .custom-logo-link {
    display: flex; /* This helps maintain aspect ratio */
    align-items: center;
    justify-content: center;
}

/* Fix for desktop logo container */
.desktop-logo {
    display: flex;
    align-items: center;
}

/* Ensure images don't get stretched */
img.custom-logo {
    object-fit: contain;
    width: auto;
    height: auto;
    max-width: 100%;
}

@media (max-width: 767.98px) {
    .custom-logo {
        max-height: 40px;
        max-width: 180px;
        height: auto;
        width: auto;
    }

    .desktop-logo {
        display: none !important;
    }

    .mobile-logo {
        display: flex !important;
    }

    /* Ensure mobile logo container has proper display */
    a.custom-logo-link.mobile-logo {
        display: flex !important;
        align-items: center;
    }
}

/* Thumbnail Aspect Ratio Styles */
.card-img-container {
    position: relative;
    width: 100%;
    padding-top: 75%; /* 4:3 Aspect Ratio (4/3 = 0.75 = 75%) */
    overflow: hidden;
}

.card-img-container .card-img-top {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

/* Apply to direct thumbnails without container */
.card .card-img-top {
    aspect-ratio: 4/3;
    object-fit: cover;
    object-position: center;
    width: 100%;
}

/* Video thumbnail container */
.video-thumbnail-container {
    position: relative;
    width: 100%;
    padding-top: 75%; /* 4:3 Aspect Ratio */
    overflow: hidden;
}

.video-thumbnail-container img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

/* Custom hamburger icon with primary color */
.custom-toggler .navbar-toggler-icon {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(41, 240, 160, 1)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 8h24M4 16h24M4 24h24'/%3E%3C/svg%3E") !important;
}

.custom-toggler {
    border: none !important;
    padding: 0.5rem !important;
    outline: none !important;
    box-shadow: none !important;
    position: relative !important;
    z-index: 1050 !important;
}

.custom-toggler:focus {
    outline: none !important;
    box-shadow: none !important;
}

/* Navigation improvements */
.navbar-nav {
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
}

.navbar-nav .nav-item {
    white-space: nowrap;
    margin-left: 0.5rem;
    margin-right: 0.5rem;
}

/* Mobile navigation improvements */
@media (max-width: 991.98px) {
    /* Make logo text smaller on mobile */
    .site-branding.navbar-brand {
        padding-left: 16px !important;
        padding-right: 16px !important;
    }

    .site-header .site-title a {
        font-size: 1.4rem !important;
    }

    .navbar-collapse {
        background-color: var(--clr-surface-a10);
        padding: 1rem;
        border-radius: 0.5rem;
        margin-top: 1rem;
        position: absolute;
        top: 100%;
        right: 1rem;
        left: 1rem;
        z-index: 1000;
        transition: all 0.3s ease-in-out;
        opacity: 0;
        transform: translateY(-10px);
        pointer-events: none;
    }

    .navbar-collapse.show {
        opacity: 1;
        transform: translateY(0);
        pointer-events: auto;
    }

    .navbar-nav {
        flex-direction: column;
    }

    .navbar-nav .nav-item {
        margin-bottom: 0.5rem;
        margin-left: 0;
        margin-right: 0;
    }

    .navbar-nav .btn {
        display: block;
        width: 100%;
        text-align: center;
        margin-top: 0.5rem;
    }

    /* Fix for navbar toggler position */
    .navbar-toggler {
        position: relative !important;
        right: 0 !important;
        top: 0 !important;
        margin-right: 16px !important;
    }
}

/* Fix for dashboard sidebar active item text color */
a.list-group-item.list-group-item-action.active {
    color: #121212 !important;
}

a.list-group-item.list-group-item-action.active * {
    color: #121212 !important;
}

/* Override with inline style as a last resort */
.dashboard-nav .list-group-item.active {
    color: #121212 !important;
}

/* Target the exact selector from the inspector */
.list-group-item.list-group-item-action.active {
    color: #121212 !important;
}

/* Target the exact selector from the inspector with !important */
a.list-group-item.list-group-item-action.active,
a.list-group-item.list-group-item-action.active span,
a.list-group-item.list-group-item-action.active i {
    color: #121212 !important;
}

/* Extremely specific selector to override Bootstrap */
html body .container .row .col-lg-3 .list-group a.list-group-item.list-group-item-action.active,
html body .container .row .col-lg-3 .list-group a.list-group-item.list-group-item-action.active *,
html body .container .row .col-lg-3 .list-group a.list-group-item.list-group-item-action.active span,
html body .container .row .col-lg-3 .list-group a.list-group-item.list-group-item-action.active i {
    color: #121212 !important;
}

/* Direct style override for Bootstrap */
.list-group-item.active,
.list-group-item.active:hover,
.list-group-item.active:focus,
.list-group-item.active:active,
.list-group-item.active *,
.list-group-item.active span,
.list-group-item.active i {
    color: #121212 !important;
}

/* Override Bootstrap's text-white class */
.list-group-item.active.text-white,
.list-group-item.active .text-white,
.list-group-item.active span.text-white,
.list-group-item.active i.text-white {
    color: #121212 !important;
}

/* Target the exact selector from the screenshot */
a.list-group-item.list-group-item-action.active {
    color: #121212 !important;
}

/* Add !important to all color properties */
.list-group-item.list-group-item-action.active {
    color: #121212 !important;
}

/* Add style attribute directly */
.list-group-item.list-group-item-action.active[style] {
    color: #121212 !important;
}

/* Target with attribute selector and higher specificity */
.list-group a.list-group-item.list-group-item-action.active[class*="active"] {
    color: #121212 !important;
}

/* Use the exact selector from the screenshot with !important and inline style */
body a.list-group-item.list-group-item-action.active {
    color: #121212 !important;
}

/* Add a custom class to override Bootstrap */
.dark-text-active.list-group-item.active,
.dark-text-active.list-group-item.active *,
.dark-text-active.list-group-item.active span,
.dark-text-active.list-group-item.active i {
    color: #121212 !important;
}

/* Make Vibe Coding Ideas framework tags text darker for better visibility */
.badge.bg-primary.bg-opacity-10.text-primary {
    color: #0a58ca !important; /* Darker blue for better contrast */
}

/* Video Archive Filter Styles */
.active-filters {
    background-color: var(--clr-surface-a10);
    border-radius: 0.5rem;
    padding: 0.75rem 1rem;
}

.active-filters .badge {
    font-weight: normal;
    padding: 0.5rem 0.75rem;
}

.video-filters-sidebar .card {
    position: sticky;
    top: 20px;
}
