/******************************************************************************/

.main-wrapper {
    display: flex;
    margin: 0 auto;
    max-width: 1800px;
}

.main-wrapper .outline {
    display: none;
}

@media (min-width: 769px) {
    .main-wrapper {
        display: grid;
        grid-gap: 1rem;
        gap: 1rem;
        grid-template-areas: "main sidebar";
        grid-template-columns: minmax(0, 3fr) minmax(0, 1fr);
        padding-left: 1.5rem;
        padding-right: 3rem;
    }

    .main-wrapper .main-content,
    .main-wrapper .sidebar,
    .main-wrapper .outline {
        padding-bottom: 1rem;
        padding-top: 1rem;
    }

    .main-wrapper .sidebar {
        align-self: start;
        grid-area: sidebar;
        padding-top: 1rem;
    }

    .main-wrapper .main-content {
        grid-area: main;
    }
}

@media (min-width: 1200px) {
    .main-wrapper {
        display: grid;
        grid-gap: 2rem;
        gap: 2rem;
        grid-template-areas: "sidebar main outline";
        grid-template-columns: minmax(0, 1fr) minmax(0, 3fr) minmax(0, 1fr);
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .main-wrapper .outline {
        display: block;
        grid-area: outline;
        height: -webkit-fit-content;
        height: fit-content;
        padding-bottom: 0;
    }

    .main-wrapper .in-nav-outline {
        display: none;
    }
}

/******************************************************************************/

.outline-container {
    padding-bottom: 1rem;
    font-size: 0.75rem;
}

.outline-container ul {
    list-style-type: none;
    padding-left: 10px;
    margin: 0;
}

.sidebar-container {
    font-size: 0.75rem;
    position: -webkit-sticky;
    position: sticky;
}

.sidebar-container ol {
    list-style-type: none;
    padding-left: 10px;
    margin: 0;
}

.sidebar-container li {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

@media (min-width: 769px) and (min-height: 44rem) {
    .sidebar-container {
        display: flex;
        flex-direction: column;
    }
}

@media (min-width: 769px) {
    .sidebar-container {
        z-index: auto;
    }
}

@media (min-width: 769px) and (not (min-height: 44rem)) {
    .sidebar-container {
        overflow: auto;
    }
}

.sidebar-container .outline-container .place,
.sidebar-container.outline-container .place {
    grid-area: outline;
    margin: 0;
}

@media (min-width: 1200px) {
    .sidebar-container {
        display: contents;
    }

    .sidebar-container .sidebar {
        -webkit-mask-image: none;
        mask-image: none;
    }
    .sidebar-container .outline-container,
    .sidebar-container.outline-container {
        display: flex;
        flex-direction: column;
        gap: 0;
        overflow: auto;
        position: -webkit-sticky;
        position: sticky;
    }

    .sidebar-container .outline-container .place,
    .sidebar-container.outline-container .place {
        margin: 1rem 0;
        padding-bottom: 1rem;
    }
}

@media (max-width: 768px) {
    .sidebar-container .outline-container .place,
    .sidebar-container.outline-container .place {
        display: none;
    }
}

@media(max-width: 768px) {
    .sidebar {
	display: none;
        height:100vh;
        left: 0;
        max-height: 100vh;
        position: fixed;
        right: 0;
    }

    .sidebar .sidebar-inner {
        display: grid;
        max-width: 20rem;
        overflow: hidden;
        overflow: auto;
        padding: 1rem;
        position: relative;
        transform: translateX(-100%);
        transition: transform .2s linear;
        width: 80vw;
        will-change: transform
    }

    .sidebar .sidebar-inner .sidebar-inner-nav {
        display: contents;
        padding-bottom: 3rem
    }
}

/******************************************************************************/

.main-page-content {
    overflow-wrap: break-word;
}

/******************************************************************************/
