﻿#sidebar {
    height: 100vh;
    -ms-transition: width 0.3s;
    -o-transition: width 0.3s;
    -webkit-transition: width 0.3s;
    transition: width 0.3s;
    background-color: rgba(78, 1, 122) !important;
    border-bottom-right-radius: 18px;
    border-top-right-radius: 16px;
    margin-right: 16px;
    margin-top: 20px;
}

#sidebar.collapsed {
    width: 200px;
}

#sidebar.expanded {
    width: 360px;
}

.sidebar-item {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    padding: 15px;
}

#main-content {
    -ms-transition: margin-left 0.3s;
    -o-transition: margin-left 0.3s;
    -webkit-transition: margin-left 0.3s;
    transition: margin-left 0.3s;
}

@media (max-width: 768px) {
    #sidebar {
        display: none;
    }

    #main-content {
        margin-left: 0 !important;
    }
}

.submenu {
    -ms-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    -webkit-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
}

.submenu-item {
    padding-left: 1rem;
    cursor: pointer;
}

#offcanvasSidebar {
    background-color: rgba(78, 1, 122) !important;
    border-bottom-right-radius: 18px;
    border-top-right-radius: 16px;
    padding-top: 1rem;
    width: 300px; /* Largura próxima ao sidebar desktop (ajuste se quiser) */
}

    #offcanvasSidebar .sidebar-item {
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        padding: 15px;
        display: flex;
        align-items: center;
    }

        #offcanvasSidebar .sidebar-item i {
            font-size: 22px;
            margin-right: 8px;
        }

    #offcanvasSidebar .offcanvas-header {
        border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    }

    #offcanvasSidebar .submenu-item {
        padding-left: 2rem;
        cursor: pointer;
        padding-top: 8px;
        padding-bottom: 8px;
    }

    #offcanvasSidebar ul li {
        color: white;
    }

    #offcanvasSidebar .offcanvas-title {
        color: white;
        font-weight: bold;
        text-transform: uppercase;
    }

    #offcanvasSidebar .btn-close-white {
        filter: brightness(0) invert(1);
    }
