| |
| |
| |
|
|
| |
| .sidebar { |
| width: var(--sidebar-width); |
| background-color: var(--sidebar-bg); |
| position: fixed; |
| top: 0; |
| left: 0; |
| bottom: 0; |
| box-shadow: 2px 0 10px var(--shadow-color); |
| z-index: 100; |
| -webkit-backface-visibility: hidden; |
| backface-visibility: hidden; |
| transform: translateZ(0); |
| height: var(--app-height, 100vh); |
| display: grid; |
| grid-template-rows: auto 1fr auto auto; |
| grid-template-areas: |
| 'header' |
| 'content' |
| 'social' |
| 'footer'; |
| scrollbar-width: thin; |
| scrollbar-color: var(--scrollbar-color) transparent; |
| overflow-y: hidden; |
| transition: background-color var(--transition-normal); |
| } |
|
|
| |
| .sidebar.collapsed { |
| width: var(--sidebar-collapsed-width); |
| overflow-x: hidden; |
| } |
|
|
| |
| .sidebar.collapsed .logo { |
| padding: 1.2rem 0.5rem 0.6rem; |
| justify-content: center; |
| display: flex; |
| align-items: center; |
| height: 3.75rem; |
| |
| margin-bottom: 0.8rem; |
| |
| } |
|
|
| |
| .sidebar.collapsed .nav-section { |
| gap: 2px; |
| } |
|
|
| |
| .sidebar.collapsed .sidebar-footer { |
| padding: 0; |
| height: 0; |
| min-height: 0; |
| margin: 0; |
| overflow: hidden; |
| border: none; |
| } |
|
|
| |
| .sidebar .logo { |
| grid-area: header; |
| padding: 1.2rem 1.2rem 0.6rem; |
| |
| display: flex; |
| align-items: center; |
| overflow: hidden; |
| |
| position: relative; |
| |
| height: 3.75rem; |
| |
| margin-bottom: 0.8rem; |
| |
| transition: padding 0.3s ease; |
| |
| } |
|
|
| .logo-brand { |
| display: flex; |
| align-items: center; |
| gap: 0.6rem; |
| min-width: 0; |
| flex: 1; |
| padding-right: 2.2rem; |
| |
| } |
|
|
| .logo-brand h1 { |
| padding-left: 0; |
| } |
|
|
| .logo-image { |
| width: 26px; |
| height: 26px; |
| flex-shrink: 0; |
| } |
|
|
| .sidebar.collapsed .logo-image { |
| display: none; |
| } |
|
|
| .logo h1 { |
| font-size: 1.4rem; |
| color: var(--text-bright); |
| margin-bottom: 0; |
| padding-left: 0.5rem; |
| letter-spacing: 0.5px; |
| transition: |
| opacity 0.3s ease, |
| transform 0.3s ease; |
| white-space: nowrap; |
| overflow: hidden; |
| text-overflow: ellipsis; |
| flex: 1; |
| } |
|
|
| |
| .sidebar-toggle { |
| background: transparent; |
| border: none; |
| color: var(--accent-color); |
| height: 28px; |
| width: 28px; |
| border-radius: 50%; |
| display: flex; |
| align-items: center; |
| justify-content: center; |
| cursor: pointer; |
| transition: background 0.3s ease; |
| |
| padding: 0; |
| flex-shrink: 0; |
| |
| position: absolute; |
| |
| right: 1.2rem; |
| |
| top: 60%; |
| transform: translateY(-50%); |
| |
| } |
|
|
| .sidebar-toggle .toggle-icon { |
| font-size: 0.9rem; |
| transition: transform 0.3s ease; |
| display: flex; |
| align-items: center; |
| justify-content: center; |
| width: 100%; |
| height: 100%; |
| } |
|
|
| .sidebar-toggle:hover { |
| background: var(--secondary-bg); |
| } |
|
|
| .sidebar-toggle:active { |
| background: var(--secondary-bg); |
| } |
|
|
| |
| .sidebar.collapsed .sidebar-toggle { |
| left: 50%; |
| |
| right: auto; |
| |
| transform: translate(-50%, -50%); |
| |
| } |
|
|
| .sidebar.collapsed .sidebar-toggle:hover { |
| background: var(--secondary-bg); |
| } |
|
|
| .sidebar.collapsed .sidebar-toggle:active { |
| background: var(--secondary-bg); |
| } |
|
|
| |
| .sidebar.collapsed .toggle-icon { |
| transform: rotate(180deg); |
| } |
|
|
| |
| .sidebar-content { |
| grid-area: content; |
| min-height: 0; |
| |
| overflow: hidden; |
| |
| padding: 0 1.2rem; |
| display: flex; |
| flex-direction: column; |
| gap: 0.6rem; |
| |
| } |
|
|
| .sidebar-content::-webkit-scrollbar { |
| display: none; |
| |
| } |
|
|
| |
| .sidebar:not(.collapsed) .nav-item-wrapper > .submenu { |
| display: none; |
| } |
|
|
| |
| .sidebar-submenu-panel { |
| flex: 1 1 auto; |
| min-height: 0; |
| overflow-y: auto; |
| padding: 0 0 0.6rem; |
| |
| scrollbar-width: none; |
| |
| opacity: 0; |
| visibility: hidden; |
| pointer-events: none; |
| transition: |
| opacity 0.18s ease, |
| visibility 0s linear 0.18s; |
| } |
|
|
| .sidebar-submenu-panel:empty { |
| display: none; |
| } |
|
|
| .sidebar.submenu-panel-visible .sidebar-submenu-panel:not(:empty) { |
| opacity: 1; |
| visibility: visible; |
| pointer-events: auto; |
| transition: |
| opacity 0.18s ease, |
| visibility 0s linear 0s; |
| } |
|
|
| .sidebar-submenu-panel::-webkit-scrollbar { |
| display: none; |
| |
| } |
|
|
| |
| .sidebar-submenu-panel .submenu { |
| max-height: none; |
| overflow: visible; |
| opacity: 1; |
| visibility: visible; |
| margin-left: 0; |
| transition: none; |
| } |
|
|
| |
| .sidebar.collapsed .sidebar-content { |
| padding: 0 0.5rem; |
| overflow-y: auto; |
| overflow-x: hidden; |
| scrollbar-width: none; |
| |
| } |
|
|
| .sidebar.collapsed .sidebar-content::-webkit-scrollbar { |
| display: none; |
| |
| } |
|
|
| .sidebar.collapsed .sidebar-submenu-panel { |
| display: none; |
| } |
|
|
| |
| .sidebar.collapsed .nav-item-wrapper > .submenu { |
| display: none; |
| } |
|
|
| |
| .submenu-header { |
| display: none; |
| font-size: 0.85rem; |
| font-weight: 500; |
| text-transform: uppercase; |
| color: var(--text-muted); |
| letter-spacing: 0.5px; |
| padding: 0.8rem 1rem 0.6rem; |
| margin-bottom: 0.2rem; |
| border-bottom: 1px solid var(--border-color); |
| transition: |
| color var(--transition-normal), |
| background-color var(--transition-normal), |
| border-bottom-color var(--transition-normal); |
| opacity: 0.8; |
| } |
|
|
| |
| .sidebar-submenu-panel .submenu-header { |
| display: block; |
| position: sticky; |
| top: 0; |
| margin-top: 0; |
| margin-bottom: 0.2rem; |
| |
| background-color: var(--sidebar-bg); |
| opacity: 1; |
| |
| z-index: 1; |
| |
| } |
|
|
| |
| .submenu-item { |
| display: flex; |
| align-items: center; |
| gap: 0.8rem; |
| padding: 0.6rem 1rem; |
| color: var(--nav-item-color); |
| text-decoration: none; |
| border-radius: var(--radius-md); |
| transition: all var(--transition-normal); |
| margin-bottom: 2px; |
| font-size: 0.95rem; |
| position: relative; |
| overflow: hidden; |
| } |
|
|
| .submenu-item i { |
| width: 1.4rem; |
| text-align: center; |
| font-size: 1rem; |
| opacity: 0.8; |
| transition: transform var(--transition-normal); |
| } |
|
|
| .submenu-item span { |
| flex: 1; |
| white-space: nowrap; |
| overflow: hidden; |
| text-overflow: ellipsis; |
| } |
|
|
| |
| .submenu-item:hover { |
| background-color: var(--secondary-bg); |
| color: var(--text-bright); |
| padding-left: 1.2rem; |
| |
| } |
|
|
| .submenu-item:hover i { |
| transform: scale(1.1); |
| color: var(--accent-color); |
| opacity: 1; |
| } |
|
|
| |
| .submenu-item.active { |
| background-color: rgba(var(--accent-rgb), 0.15); |
| color: var(--accent-color); |
| font-weight: 500; |
| } |
|
|
| .submenu-item.active i { |
| color: var(--accent-color); |
| opacity: 1; |
| } |
|
|
| |
| .submenu-item.active::before { |
| content: ''; |
| position: absolute; |
| left: 0; |
| top: 50%; |
| transform: translateY(-50%); |
| height: 60%; |
| width: 3px; |
| background-color: var(--accent-color); |
| border-radius: 0 2px 2px 0; |
| } |
|
|
| |
| .sidebar.collapsed .logo h1 { |
| opacity: 0; |
| transform: translateX(-20px); |
| width: 0; |
| visibility: hidden; |
| |
| pointer-events: none; |
| |
| } |
|
|
| |
| .nav-section { |
| display: flex; |
| flex-direction: column; |
| gap: 0; |
| |
| flex: 0 0 auto; |
| |
| overflow: visible; |
| |
| } |
|
|
| .section-title { |
| font-size: 1rem; |
| color: var(--accent-color); |
| padding: 0.4rem 0.5rem; |
| |
| margin-bottom: 0.2rem; |
| |
| display: flex; |
| align-items: center; |
| gap: 0.5rem; |
| transition: color 0.3s ease; |
| } |
|
|
| .section-title i { |
| font-size: 1.2rem; |
| } |
|
|
| |
| .sidebar.collapsed .section-title { |
| justify-content: center; |
| |
| padding: 0.4rem 0; |
| text-align: center; |
| margin-bottom: 0.2rem; |
| |
| } |
|
|
| .sidebar.collapsed .section-title i { |
| margin: 0 auto; |
| font-size: 1.2rem; |
| } |
|
|
| |
| .sidebar.collapsed .nav-section { |
| gap: 0.4rem; |
| align-items: center; |
| } |
|
|
| .sidebar.collapsed .nav-item { |
| padding: 0; |
| justify-content: center; |
| width: 2.75rem; |
| |
| height: 2.75rem; |
| |
| text-align: center; |
| margin-left: auto; |
| margin-right: auto; |
| border-radius: var(--radius-md); |
| |
| display: flex; |
| align-items: center; |
| box-sizing: border-box; |
| } |
|
|
| .sidebar.collapsed .nav-item i { |
| font-size: 1.25rem; |
| width: auto; |
| margin: 0; |
| padding: 0; |
| } |
|
|
| .sidebar.collapsed .nav-item .icon-container { |
| margin: 0; |
| width: 100%; |
| height: 100%; |
| display: flex; |
| justify-content: center; |
| align-items: center; |
| } |
|
|
| |
| .sidebar.collapsed .nav-item .nav-text, |
| .sidebar.collapsed .nav-item .external-icon { |
| opacity: 0; |
| transform: translateX(-10px); |
| width: 0; |
| display: none; |
| |
| visibility: hidden; |
| } |
|
|
| .nav-item { |
| display: flex; |
| align-items: center; |
| height: 44px; |
| padding: 0 0.9rem; |
| margin-bottom: 0.4rem; |
| |
| color: var(--nav-item-color); |
| text-decoration: none; |
| border-radius: var(--radius-md); |
| transition: |
| background-color var(--transition-normal), |
| color var(--transition-normal), |
| box-shadow var(--transition-normal); |
| position: relative; |
| } |
|
|
| .nav-item-wrapper:last-child .nav-item { |
| margin-bottom: 0; |
| |
| } |
|
|
| .nav-item .icon-container { |
| width: 24px; |
| height: 100%; |
| display: flex; |
| justify-content: center; |
| align-items: center; |
| margin-right: var(--spacing-md); |
| transition: margin var(--transition-normal); |
| } |
|
|
| .nav-item .nav-text { |
| flex: 1; |
| transition: |
| opacity var(--transition-normal), |
| transform var(--transition-normal); |
| white-space: nowrap; |
| overflow: hidden; |
| } |
|
|
| .nav-item .external-icon { |
| font-size: 0.9rem; |
| opacity: 0.6; |
| margin-left: 0.5rem; |
| transition: all var(--transition-normal); |
| } |
|
|
| .nav-item:hover { |
| background-color: var(--secondary-bg); |
| color: var(--text-bright); |
| } |
|
|
| .nav-item:hover .external-icon { |
| opacity: 1; |
| transform: translateX(2px); |
| } |
|
|
| .nav-item.active { |
| background-color: var(--secondary-bg); |
| color: var(--text-bright); |
| } |
|
|
| .nav-item i { |
| width: 20px; |
| text-align: center; |
| } |
|
|
| |
| .sidebar.collapsed .sidebar-footer { |
| visibility: hidden; |
| pointer-events: none; |
| } |
|
|
| |
| main.content { |
| flex: 1; |
| margin-left: var(--sidebar-width); |
| padding: 1.5rem 1rem; |
| background-color: var(--bg-color); |
| position: relative; |
| height: var(--app-height, 100vh); |
| |
| overflow-y: auto; |
| |
| overflow-x: hidden; |
| width: calc(100vw - var(--sidebar-width)); |
| display: flex; |
| flex-direction: column; |
| align-items: center; |
| |
| scrollbar-gutter: stable; |
| |
| scrollbar-width: thin; |
| scrollbar-color: var(--scrollbar-color) transparent; |
| } |
|
|
| |
| main.content::-webkit-scrollbar { |
| width: 8px; |
| } |
|
|
| main.content::-webkit-scrollbar-track { |
| background: transparent; |
| } |
|
|
| main.content::-webkit-scrollbar-thumb { |
| background-color: var(--scrollbar-color); |
| border-radius: var(--radius-full); |
| |
| border: 2px solid transparent; |
| background-clip: content-box; |
| } |
|
|
| main.content::-webkit-scrollbar-thumb:hover { |
| background-color: var(--scrollbar-hover-color); |
| } |
|
|
| |
| @supports not (scrollbar-gutter: stable) { |
| main.content { |
| overflow-y: scroll; |
| } |
| } |
|
|
| |
| body main.content.expanded { |
| margin-left: var(--sidebar-collapsed-width); |
| width: calc(100vw - var(--sidebar-collapsed-width)); |
| } |
|
|
| |
| .with-anim .sidebar { |
| transition: |
| width 0.3s ease, |
| background-color 0.3s ease; |
| } |
|
|
| .with-anim main.content { |
| transition: |
| background-color 0.3s ease, |
| margin-left 0.3s ease, |
| width 0.3s ease; |
| } |
|
|