/* Sidebar shared styles */
:root { --sidebar-w: clamp(320px, 85vw, 560px); }

.hamburger {
  position: fixed;
  top: 16px;
  right: 16px;
  z-index: 1200;
  width: 42px;
  height: 36px;
  padding: 8px;
  background: #fff;
  color: var(--ink);
  border: 1px solid var(--rule);
  border-radius: 6px;
  display: grid;
  gap: 6px;
  align-content: center;
  cursor: pointer;
}
.hamburger span { display: block; height: 2px; background: var(--ink); }
.hamburger:focus-visible { outline: 2px solid #000; outline-offset: 2px; }
.hamburger span { transition: transform 220ms ease, opacity 160ms ease; transform-origin: center; }
.hamburger.is-open span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.hamburger.is-open span:nth-child(2) { opacity: 0; }
.hamburger.is-open span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }

#sidebar-overlay { position: fixed; inset: 0; background: rgba(255,255,255,0.55); z-index: 1000; opacity: 0; pointer-events: none; transition: opacity 0.2s ease; }
#sidebar-overlay.show { opacity: 1; pointer-events: auto; }

#sidebar {
  position: fixed; top: 0; left: auto; right: 0; bottom: 0;
  width: var(--sidebar-w); height: 100%;
  background: var(--page-bg);
  padding: 88px 24px 28px;
  transform: translateX(100%);
  transition: transform 600ms cubic-bezier(0.56, -0.44, 0.44, 1.485);
  z-index: 8000; display: block; overflow-y: auto; overflow-x: hidden;
}
#sidebar.is-open { transform: translateX(0); }

/* Push page left in sync */
.wrap { transition: transform 600ms cubic-bezier(0.56, -0.44, 0.44, 1.485); will-change: transform; }
body.sidebar-open .wrap { transform: translateX(calc(-1 * var(--sidebar-w))); }

.sidebar-header { display: none; }
.sidebar-section { padding: 18px 20px 22px; }
.sidebar-section h3 { margin: 0 0 10px; font-size: clamp(13.5px, 3.4vw, 15.5px); }
.sidebar-section p, .sidebar-section li { color: var(--muted); line-height: 1.6; margin: 0 0 18px; font-size: clamp(13px, 3.5vw, 15px); }
.sidebar-section ul { margin: 10px 0 0; padding-left: 18px; }

.about-block { display: flow-root; }
.about-avatar { float: left; width: clamp(96px, 34vw, 160px); height: clamp(96px, 34vw, 160px); border-radius: 8px; background: #e9e9e9; margin: 2px 14px 10px 0; object-fit: cover; }
.about-meta { margin: 0; }
.about-meta a { color: inherit; }
@media (max-width: 540px) {
  :root { --sidebar-w: 100vw; }
  #sidebar { padding: 74px 20px 22px; }
  .sidebar-section ul { padding-left: 16px; }
  .sidebar-section h3 { font-size: 14px; }
  .sidebar-section p, .sidebar-section li { font-size: 13.2px; line-height: 1.55; }
}

html.no-scroll, body.no-scroll { overflow: hidden; }


#sidebar .sidebar-content { background: var(--page-bg); max-width: 600px; margin: 0 auto; z-index: 9999; }
.bio { display: flow-root; }
.bio-image { float: left; width: clamp(128px, 40vw, 220px); height: auto; border-radius: 0; background: #e9e9e9; margin: 2px 18px 14px 0; object-fit: cover; }
.nav-menu { list-style: none; padding: 0; margin: 0 0 16px; display: flex; gap: 16px; flex-wrap: wrap; }
.nav-menu a { color: inherit; text-decoration: none; }
.nav-menu a:hover { text-decoration: underline; }
.social { display: flex; gap: 10px; align-items: center; }

/* Desktop: match example width and padding */
@media (min-width: 1024px) {
  :root { --sidebar-w: 50vw; }
  #sidebar { padding: 108px 60px 60px; }
}

.sidebar-buttons { display: flex; gap: 10px; flex-wrap: wrap; }
.sidebar-buttons .btn { text-transform: uppercase; font-weight: 600; font-size: 12px; letter-spacing: 0.08em; padding: 10px 14px; border: 1px solid var(--ink); border-radius: 4px; color: var(--ink); background: #fff; text-decoration: none; }
.sidebar-buttons .btn:hover { text-decoration: underline; }

