/* components/side-nav.css */
:host {
  display: block;
  width: 240px;
  height: 100%;
  background: var(--surface-dark);
  border-right: 1px solid var(--line-light);
  overflow-y: auto;
}
.sn {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 16px 10px 32px;
}
.sn-cta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin: 0 4px 10px;
  padding: 10px 14px;
  border-radius: 999px;
  background: var(--accent-neon);
  color: var(--ink-primary);
  font-weight: 600;
  text-decoration: none;
}
.sn-cta:hover {
  filter: brightness(1.08);
}
.sn-items {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.sn-item {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 11px 12px;
  border-radius: 10px;
  color: color-mix(in srgb, var(--ink-primary) 70%, var(--ink-secondary));
  text-decoration: none;
  font-size: 0.95rem;
}
.sn-item:hover {
  background: var(--surface-input);
  color: var(--ink-primary);
}
.sn-item.active {
  background: var(--surface-input);
  color: var(--ink-primary);
  font-weight: 600;
}
.sn-item-sub {
  color: var(--ink-secondary);
}
.sn-divider {
  height: 1px;
  background: var(--line-light);
  margin: 8px 6px;
}
