/*
Side Navigation Component
面板式可折叠菜单组件，支持父子缩进关系
Styleguide 2.0
*/

/* 使用CutestUI变量系统 */
:root {
    --side-nav-width: 280px;
    --side-nav-item-padding: var(--spacing-3);
    --side-nav-indent: 1.5rem;
}

/* 侧边导航容器 */
.side-nav {
    width: var(--side-nav-width);
    background-color: var(--color-neutral-tint4);
    border-right: var(--border-width) solid var(--color-neutral-tint1);
    font-family: var(--font-sans);
    height: 100vh;
    overflow: hidden;
    position: sticky;
    top: 0;
}

/* 导航菜单包装器 */
.nav-wrapper {
    height: 100%;
    overflow-y: auto;
}

/* 导航菜单 */
.nav-menu {
    list-style: none;
    margin: 0;
    padding: var(--spacing-2) 0;
}

/* 导航分组 */
.nav-group {
    border-bottom: var(--border-width) solid var(--color-neutral-tint1);
}

/* 分组标题/可折叠项 */
.nav-group-title {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--side-nav-item-padding);
    font-weight: 600;
    color: var(--color-text);
    cursor: pointer;
    user-select: none;
    transition: all 0.2s ease;
    background-color: var(--color-neutral-tint3);
}

.nav-group-title:hover {
    background-color: var(--color-neutral-tint3);
    color: var(--color-primary);
}

/* 切换图标 */
.nav-toggle {
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-muted);
    transition: all 0.2s ease;
    font-size: 0.875rem;
}

.nav-group-title:hover .nav-toggle {
    color: var(--color-text);
}

/* 折叠状态 */
.nav-group.-collapsed .nav-toggle {
    transform: rotate(-90deg);
}

/* 子菜单容器 */
.nav-submenu {
    list-style: none;
    margin: 0;
    padding: 0;
    border-left: var(--border-width) solid var(--color-neutral-tint1);
    transition: all 0.2s ease;
    /* 第一级子菜单缩进 */
    padding-left: var(--spacing-4);
}

/* 嵌套子菜单缩进调整 */
.nav-submenu .nav-submenu {
    /* 第二级及更深层级子菜单进一步缩进 */
    padding-left: var(--spacing-6);
}

/* 导航项 */
.nav-group.-collapsed .nav-submenu {
    display: none;
}

/* 导航项 */
.nav-item {
    border-left: 3px solid transparent;
    transition: all 0.2s ease;
}

/* 导航链接 */
.nav-link {
    display: block;
    padding: var(--side-nav-item-padding);
    color: var(--color-text);
    text-decoration: none;
    transition: all 0.2s ease;
}

.nav-link:hover {
    color: var(--color-primary);
    background-color: var(--color-neutral-tint3);
}

/* 活动状态 */
.nav-item.-active {
    border-left-color: var(--color-primary);
    background-color: var(--color-neutral-tint3);
}

.nav-item.-active .nav-link {
    color: var(--color-primary);
    font-weight: 500;
}

/* 子菜单缩进 */
.nav-submenu .nav-group {
    border-bottom: none;
    border-left: var(--border-width) solid var(--color-neutral-tint1);
}

.nav-submenu .nav-group-title {
    padding-left: calc(var(--side-nav-item-padding) + var(--side-nav-indent));
    background-color: transparent;
    font-weight: 500;
}

.nav-submenu .nav-submenu {
    border-left: var(--border-width) solid var(--color-neutral-tint1);
}

.nav-submenu .nav-submenu .nav-group-title {
    padding-left: calc(var(--side-nav-item-padding) + 2 * var(--side-nav-indent));
}

/* 多级子菜单 */
.nav-submenu .nav-submenu .nav-submenu .nav-group-title {
    padding-left: calc(var(--side-nav-item-padding) + 3 * var(--side-nav-indent));
}

/* 滚动条样式 - 使用CutestUI标准样式 */
.side-nav {
    scrollbar-width: thin;
    scrollbar-color: var(--color-muted) var(--color-neutral-tint3);
}

.side-nav::-webkit-scrollbar {
    width: 6px;
}

.side-nav::-webkit-scrollbar-track {
    background: var(--color-neutral-tint3);
}

.side-nav::-webkit-scrollbar-thumb {
    background: var(--color-muted);
    border-radius: var(--radius);
}

.side-nav::-webkit-scrollbar-thumb:hover {
    background: var(--color-text);
}

/* 响应式设计 - 使用CutestUI的断点系统 */
/* 中等屏幕 */
@media (max-width: 991px) {
    .side-nav {
        width: 240px;
    }
}

/* 小屏幕 */
@media (max-width: 767px) {
    .side-nav {
        width: 100%;
        height: auto;
        position: relative;
        border-right: none;
        border-bottom: var(--border-width) solid var(--color-neutral-tint1);
    }
    
    .nav-group-title {
        padding: var(--spacing-2);
    }
    
    .nav-link {
        padding: var(--spacing-2);
    }
    
    .nav-submenu .nav-group-title {
        padding-left: calc(var(--spacing-2) + var(--side-nav-indent));
    }
    
    .nav-submenu .nav-submenu .nav-group-title {
        padding-left: calc(var(--spacing-2) + 2 * var(--side-nav-indent));
    }
    
    .nav-layout {
        flex-direction: column;
    }
}

/* 内容与导航组合布局 - 使用CutestUI的布局模式 */
.nav-layout {
    display: flex;
    height: 100vh;
    overflow: hidden;
}

.nav-content {
    flex: 1;
    padding: var(--spacing-4);
    overflow-y: auto;
    background-color: var(--color-background);
}

/* 防止内容区域在小屏幕时溢出 */
@media (max-width: 767px) {
    .nav-content {
        padding: var(--spacing-3);
    }
}

/* 标题样式 */
.nav-content h1 {
    font-size: 2rem;
    margin-bottom: 1.5rem;
    color: var(--color-text);
}

.nav-content h2 {
    font-size: 1.5rem;
    margin: 2rem 0 1rem;
    color: var(--color-text);
}

.nav-content p {
    margin-bottom: 1rem;
    color: var(--color-text);
    line-height: 1.6;
}

/* 代码块样式 */
.nav-content pre {
    background-color: var(--color-code-bg);
    padding: 1rem;
    border-radius: var(--radius);
    overflow-x: auto;
    margin-bottom: 1.5rem;
}

.nav-content code {
    font-family: var(--font-mono);
    font-size: 0.875rem;
    color: var(--color-text);
}

/* 链接样式 */
.nav-content a {
    color: var(--color-link);
    text-decoration: none;
}

.nav-content a:hover {
    color: var(--color-link-hover);
    text-decoration: underline;
}