.sideNav { background-color: var(--color-bg); min-width: var(--layout-sidenav-width); max-width: var(--layout-sidenav-width); border-right: 1.5px solid var(--color-border); overflow: hidden; position: sticky; top: 0; left: 0; height: fit-content; } .sideNavTop { height: var(--layout-nav-height); background-color: var(--color-bg); border-bottom: 1.5px solid var(--color-border); } .sideNavInner { display: flex; flex-direction: column; gap: var(--s-2); padding: var(--s-1-5); padding-block-end: var(--s-2); overflow-y: auto; height: calc(100dvh - var(--layout-nav-height)); } .sideNavHeader { color: var(--color-text-high); padding: var(--s-1-5) var(--s-2); margin-inline: calc(-1 * var(--s-1-5)); background-color: var(--color-bg-high); display: flex; align-items: center; gap: var(--s-2); border-color: var(--color-border); border-top: 1.5px solid var(--color-border); border-bottom: 1.5px solid var(--color-border); } .sideNavHeader:first-child { margin-block-start: calc(-1 * var(--s-1-5)); border-top: none; } .sideNavHeader h2 { font-size: var(--fonts-xs); font-weight: var(--bold); } .sideNavHeaderClose { margin-inline-start: auto; margin-inline-end: var(--s-1); } .sideNavHeader svg { width: 18px; } .iconContainer { background-color: var(--color-bg-high); border-radius: var(--rounded-sm); padding: var(--s-1-5); } .sideNavLink { font-size: var(--fonts-xs); color: var(--color-text); text-decoration: none; padding: var(--s-1) var(--s-2); border-radius: var(--rounded-xs); transition: background-color 0.15s, color 0.15s; display: flex; align-items: center; gap: var(--s-2); &:hover { &:not(:has(.sideNavLinkSubtitle)) { color: var(--color-text); } background-color: var(--color-bg-higher); } &[aria-current="page"] { color: var(--color-text); background-color: var(--color-bg-higher); font-weight: 600; } } .sideNavLinkImage { width: 32px; height: 32px; border-radius: var(--rounded-xs); object-fit: cover; flex-shrink: 0; } .sideNavLinkContent { display: flex; flex-direction: column; min-width: 0; gap: var(--s-0-5); width: 100%; } .sideNavLinkTitle { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; &:has(+ .sideNavLinkSubtitle) { color: var(--color-text); } } .sideNavLinkSubtitleRow { display: flex; align-items: center; width: 100%; color: var(--color-text-high); } .sideNavLinkSubtitle { font-size: var(--fonts-xxs); color: var(--color-text-lighter); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .sideNavLinkBadge { margin-left: auto; font-size: var(--fonts-xxxs); font-weight: var(--semi-bold); color: var(--color-accent-low); background-color: var(--color-accent-high); padding: 0 var(--s-1); border-radius: var(--rounded-xs); flex-shrink: 0; } .sideNavPanelOverlay { position: fixed; inset: 0; z-index: 10; background-color: rgba(0, 0, 0, 0.25); backdrop-filter: blur(10px); } .sideNavPanelOverlay[data-entering] { animation: fade-in 200ms ease-out; } @keyframes fade-in { from { opacity: 0; } to { opacity: 1; } } .sideNavPanel { position: fixed; top: 50%; left: 0; transform: translateY(-50%); max-height: 90vh; overflow-y: auto; border-radius: var(--rounded); } .sideNavPanel[data-entering] { animation: slide-in-left 200ms ease-out; } @keyframes slide-in-left { from { transform: translateX(-100%) translateY(-50%); } to { transform: translateX(0) translateY(-50%); } } .sideNavPanelDialog { outline: none; }