/* Side Navigation Styles for Mobile */
@media (max-width: 991px) {
    /* Hide Bootstrap collapse - we'll use custom side nav */
    .navbar-collapse {
        display: none \!important;
    }
    
    /* Side Navigation Container */
    .side-nav {
        height: 100%;
        width: 0;
        position: fixed;
        z-index: 9999;
        top: 0;
        right: 0;
        background-color: #0078d4;
        overflow-x: hidden;
        transition: 0.3s;
        padding-top: 60px;
        box-shadow: -2px 0 10px rgba(0,0,0,0.3);
    }
    
    /* Side Nav Links */
    .side-nav a {
        padding: 15px 8px 15px 32px;
        text-decoration: none;
        font-size: 18px;
        color: #ffffff;
        display: block;
        transition: 0.3s;
        border-bottom: 1px solid rgba(255,255,255,0.1);
    }
    
    .side-nav a:hover {
        background-color: rgba(255,255,255,0.1);
        padding-left: 40px;
    }
    
    /* Close Button */
    .side-nav .closebtn {
        position: absolute;
        top: 10px;
        right: 25px;
        font-size: 36px;
        margin-left: 50px;
        color: #ffffff;
        border: none;
    }
    
    /* Dropdown in Side Nav */
    .side-nav .dropdown-menu {
        position: static \!important;
        background-color: rgba(0,0,0,0.2);
        border: none;
        border-radius: 0;
        margin: 0;
        padding: 0;
    }
    
    .side-nav .dropdown-item {
        color: #ffffff;
        padding: 10px 8px 10px 50px;
        font-size: 16px;
    }
    
    .side-nav .dropdown-item:hover {
        background-color: rgba(255,255,255,0.1);
    }
    
    /* User Section */
    .side-nav .user-section {
        padding: 20px;
        border-bottom: 2px solid rgba(255,255,255,0.2);
        margin-bottom: 10px;
    }
    
    /* Authentication Buttons in Side Nav */
    .side-nav .auth-buttons {
        padding: 20px;
    }
    
    .side-nav .auth-buttons .btn {
        display: block;
        width: 100%;
        margin-bottom: 10px;
        background-color: #ffffff;
        color: #0078d4;
        border: none;
    }
    
    .side-nav .auth-buttons .btn:hover {
        background-color: #f0f0f0;
    }
    
    /* When side nav is open */
    .side-nav.open {
        width: 280px;
    }
    
    /* Overlay */
    .nav-overlay {
        display: none;
        position: fixed;
        width: 100%;
        height: 100%;
        top: 0;
        left: 0;
        background-color: rgba(0,0,0,0.5);
        z-index: 9998;
    }
    
    .nav-overlay.show {
        display: block;
    }
    
    /* Ensure hamburger button is visible */
    .navbar-toggler {
        display: block \!important;
        z-index: 10000;
    }
}

/* Ensure navbar toggler shows white lines */
.navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 1%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") \!important;
}
EOF < /dev/null
