/* Import design tokens */
@import url('tokens.css');

/* =========================================================================
   Global Reset & Base
   ========================================================================= */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* Note: do NOT set overflow-x:hidden on html or body — it breaks position:sticky.
   Instead, constrain width on individual elements that might overflow. */

body {
  font-family: var(--font-body);
  font-size: var(--font-size-base);
  line-height: var(--leading-normal);
  color: var(--color-text);
  background: var(--color-bg);
  transition: background var(--duration-normal) var(--ease-in-out),
              color var(--duration-normal) var(--ease-in-out);
}

a { color: var(--color-link); text-decoration: none; transition: color var(--duration-fast) var(--ease-out); }
a:hover { color: var(--color-link-hover); }
a:visited { color: var(--color-link-visited); }

/* =========================================================================
   Site Header
   ========================================================================= */
.site-header {
  max-width: var(--content-full);
  margin: 0 auto;
  padding: var(--space-6) var(--gutter) var(--space-5);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.site-header--wide { max-width: var(--content-full); width: 100%; }

.site-header--faded {
  opacity: 0.6;
  transition: opacity var(--duration-normal) var(--ease-out);
}
.site-header--faded:hover { opacity: 1; }

.site-title {
  font-family: var(--font-display);
  font-size: var(--font-size-xl);
  font-weight: 400;
  color: var(--color-text);
  text-decoration: none;
  letter-spacing: var(--tracking-tight);
}
.site-title:visited { color: var(--color-text); }
.site-title:hover { color: var(--color-text); opacity: 0.8; }

.header-right { display: flex; align-items: center; gap: var(--space-3); }

.header-nav { font-size: var(--font-size-sm); }
.header-nav .nav {
  list-style: none; display: flex; gap: var(--space-4);
  margin: 0; padding: 0;
}
.header-nav .nav li { margin: 0; padding: 0; }
.header-nav a { color: var(--color-text-muted); font-weight: 500; white-space: nowrap; }
.header-nav a:visited { color: var(--color-text-muted); }
.header-nav a:hover { color: var(--color-text); }

/* Hamburger menu button (mobile only) */
.menu-toggle {
  display: none;
  background: none; border: none; cursor: pointer;
  color: var(--color-text-muted);
  min-width: 44px; min-height: 44px;
  align-items: center; justify-content: center;
  padding: 0;
  transition: opacity var(--duration-fast) var(--ease-out);
}
.menu-toggle:hover { opacity: 0.7; }
.menu-toggle svg { width: 22px; height: 22px; stroke: currentColor; fill: none; }

/* Mobile nav overlay */
.mobile-nav {
  display: none;
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 100;
  background: var(--color-bg);
  padding: var(--space-6) var(--gutter);
  flex-direction: column;
  opacity: 0;
  transition: opacity var(--duration-normal) var(--ease-out);
}
.mobile-nav.is-open {
  display: flex;
  opacity: 1;
}
.mobile-nav__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-7);
}
.mobile-nav__close {
  background: none; border: none; cursor: pointer;
  color: var(--color-text-muted);
  min-width: 44px; min-height: 44px;
  display: flex; align-items: center; justify-content: center;
}
.mobile-nav__close svg { width: 22px; height: 22px; stroke: currentColor; fill: none; }
.mobile-nav__list {
  list-style: none; margin: 0; padding: 0;
}
.mobile-nav__list li { margin-bottom: var(--space-4); }
.mobile-nav__list a {
  font-family: var(--font-display);
  font-size: var(--font-size-xl);
  font-weight: 400;
  color: var(--color-text);
  text-decoration: none;
  letter-spacing: var(--tracking-tight);
}
.mobile-nav__list a:visited { color: var(--color-text); }
.mobile-nav__list a:hover { color: var(--color-link); }

@media (max-width: 640px) {
  .header-nav { display: none; }
  .menu-toggle { display: flex; }
}

.theme-toggle {
  background: none; border: none; cursor: pointer;
  font-size: var(--font-size-base); line-height: 1;
  padding: var(--space-1); border-radius: var(--radius-sm);
  color: var(--color-text-muted);
  transition: opacity var(--duration-fast) var(--ease-out);
  min-width: 44px; min-height: 44px;
  display: flex; align-items: center; justify-content: center;
}
.theme-toggle:hover { opacity: 0.7; }

/* =========================================================================
   Site Footer
   ========================================================================= */
.site-footer {
  max-width: var(--content-width);
  margin: 0 auto;
  padding: var(--space-6) var(--gutter) var(--space-8);
  border-top: var(--border-thin);
  font-size: var(--font-size-xs);
  color: var(--color-text-faint);
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  flex-wrap: wrap;
  gap: var(--space-3);
}
.footer-archives { display: flex; gap: var(--space-2); flex-wrap: wrap; }
.footer-archives a { color: var(--color-text-faint); font-size: var(--font-size-xs); }
.footer-archives a:hover { color: var(--color-text-muted); }

/* =========================================================================
   Index — Stream
   ========================================================================= */
.stream {
  max-width: var(--content-width);
  margin: 0 auto;
  padding: 0 var(--gutter) var(--space-9);
}

.year-divider {
  font-family: var(--font-body);
  font-size: var(--font-size-sm);
  font-weight: 700;
  color: var(--color-text-faint);
  letter-spacing: var(--tracking-wide);
  padding: var(--space-5) 0 var(--space-3);
  border-bottom: var(--border-thin);
  margin-bottom: var(--space-5);
}

/* =========================================================================
   Index — Pinned Section
   ========================================================================= */
.pinned-section {
  margin-bottom: var(--space-7);
  padding-bottom: var(--space-5);
  border-bottom: 2px solid var(--color-border-bold);
}
.pinned-label {
  font-size: var(--font-size-xs); font-weight: 700;
  color: var(--color-text-faint); text-transform: uppercase;
  letter-spacing: var(--tracking-wide); margin-bottom: var(--space-4);
}
.pinned-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-4); }
@media (min-width: 540px) { .pinned-grid { grid-template-columns: 1fr 1fr; } }

.pinned-card {
  padding: var(--space-4);
  border: var(--border-thin);
  border-radius: var(--radius-md);
  background: var(--color-bg-surface);
  transition: background var(--duration-normal) var(--ease-in-out),
              border-color var(--duration-fast) var(--ease-out),
              transform var(--duration-fast) var(--ease-out);
}
.pinned-card:hover { border-color: var(--color-border-bold); transform: translateY(-2px); }

.pinned-card__pin {
  font-size: var(--font-size-xs); color: var(--color-accent);
  font-weight: 700; text-transform: uppercase;
  letter-spacing: var(--tracking-wide); margin-bottom: var(--space-2);
  display: flex; align-items: center; gap: var(--space-1);
}
.pinned-card__pin svg { width: 12px; height: 12px; fill: var(--color-accent); }

.pinned-card__title {
  font-family: var(--font-display);
  font-size: var(--font-size-base); font-weight: 400;
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight); margin-bottom: var(--space-2);
}
.pinned-card__title a { color: var(--color-text); text-decoration: none; }
.pinned-card__title a:visited { color: var(--color-text); }
.pinned-card__title a:hover { color: var(--color-link); }

.pinned-card__desc { font-size: var(--font-size-sm); line-height: var(--leading-normal); color: var(--color-text-muted); }
.pinned-card__meta { font-size: var(--font-size-xs); color: var(--color-text-faint); margin-top: var(--space-2); }

/* =========================================================================
   Post Card — Default (long-form)
   ========================================================================= */
.post-card {
  margin-bottom: var(--space-6);
  padding-bottom: var(--space-6);
  border-bottom: var(--border-thin);
}
.post-card:last-child { border-bottom: none; }

.post-card__date {
  font-size: var(--font-size-xs); color: var(--color-text-faint);
  text-transform: uppercase; letter-spacing: var(--tracking-wide);
  margin-bottom: var(--space-1);
}
.post-card__title {
  font-family: var(--font-display);
  font-size: var(--font-size-lg); font-weight: 400;
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight); margin-bottom: var(--space-2);
}
.post-card__title a { color: var(--color-text); text-decoration: none; }
.post-card__title a:visited { color: var(--color-text); }
.post-card__title a:hover { color: var(--color-link); }

.post-card__excerpt { font-size: var(--font-size-sm); line-height: var(--leading-normal); color: var(--color-text-muted); margin-bottom: var(--space-2); }

.post-card__tags { display: flex; gap: var(--space-2); flex-wrap: wrap; }
.post-card__tag {
  font-size: var(--font-size-xs); color: var(--color-text-faint);
  background: var(--color-bg-code); padding: 2px var(--space-2);
  border-radius: var(--radius-sm);
  transition: background var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out);
}
.post-card__tag:hover { color: var(--color-text); background: var(--color-border); }
.post-card__tag:visited { color: var(--color-text-faint); }
.post-card__read-time { font-size: var(--font-size-xs); color: var(--color-text-faint); }

/* =========================================================================
   TIL Card
   ========================================================================= */
.til-card {
  margin-bottom: var(--space-4); padding-bottom: var(--space-4);
  border-bottom: var(--border-thin);
  padding-left: var(--space-4); border-left: 3px solid var(--color-accent);
}
.til-card__label { font-size: var(--font-size-xs); font-weight: 700; color: var(--color-accent); text-transform: uppercase; letter-spacing: var(--tracking-wide); margin-bottom: var(--space-1); }
.til-card__title { font-family: var(--font-body); font-size: var(--font-size-base); font-weight: 600; line-height: var(--leading-tight); color: var(--color-text); margin-bottom: var(--space-1); }
.til-card__body { font-size: var(--font-size-sm); line-height: var(--leading-normal); color: var(--color-text-muted); }
.til-card__body p { margin-bottom: var(--space-2); }
.til-card__body p:last-child { margin-bottom: 0; }
.til-card__body code { font-family: var(--font-mono); font-size: 0.9em; background: var(--color-bg-code); padding: 0.1em 0.3em; border-radius: 3px; }
.til-card__body pre { background: var(--color-bg-code); border-radius: var(--radius-sm); padding: var(--space-3); overflow-x: auto; margin-bottom: var(--space-2); font-family: var(--font-mono); font-size: var(--font-size-xs); line-height: var(--leading-normal); color: var(--color-code-text); }
.til-card__body pre code { background: none; padding: 0; font-size: inherit; }
.til-card__body img { max-width: 100%; height: auto; border-radius: var(--radius-sm); }
.til-card__title a { color: var(--color-text); text-decoration: none; }
.til-card__title a:visited { color: var(--color-text); }
.til-card__title a:hover { color: var(--color-link); }
.til-card__date { font-size: var(--font-size-xs); color: var(--color-text-faint); margin-top: var(--space-2); }

/* =========================================================================
   Note Card
   ========================================================================= */
.note-card { margin-bottom: var(--space-4); padding-bottom: var(--space-4); border-bottom: var(--border-thin); }
.note-card__label { font-size: var(--font-size-xs); font-weight: 700; color: var(--color-text-faint); text-transform: uppercase; letter-spacing: var(--tracking-wide); margin-bottom: var(--space-1); }
.note-card__body { font-size: var(--font-size-base); line-height: var(--leading-normal); color: var(--color-text); }
.note-card__body p { margin-bottom: var(--space-2); }
.note-card__body p:last-child { margin-bottom: 0; }
.note-card__date { font-size: var(--font-size-xs); color: var(--color-text-faint); margin-top: var(--space-2); }

/* =========================================================================
   Link Card
   ========================================================================= */
.link-card { margin-bottom: var(--space-4); padding-bottom: var(--space-4); border-bottom: var(--border-thin); }
.link-card__label { font-size: var(--font-size-xs); font-weight: 700; color: var(--color-text-faint); text-transform: uppercase; letter-spacing: var(--tracking-wide); margin-bottom: var(--space-1); }
.link-card__title { font-family: var(--font-body); font-size: var(--font-size-base); font-weight: 600; line-height: var(--leading-tight); color: var(--color-link); margin-bottom: var(--space-1); }
.link-card__title a { color: var(--color-link); }
.link-card__title a:hover { color: var(--color-link-hover); }
.link-card__title a::after { content: " ↗"; font-size: 0.8em; opacity: 0.5; }
.link-card__comment { font-size: var(--font-size-sm); line-height: var(--leading-normal); color: var(--color-text-muted); }
.link-card__comment p { margin-bottom: var(--space-2); }
.link-card__comment p:last-child { margin-bottom: 0; }
.link-card__date { font-size: var(--font-size-xs); color: var(--color-text-faint); margin-top: var(--space-2); }

/* Permalink icon — subtle link to the post's own page for sharing */
.permalink-icon {
  color: var(--color-text-faint);
  font-size: var(--font-size-xs);
  text-decoration: none;
  opacity: 0.6;
  transition: opacity var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out);
}
.permalink-icon:visited { color: var(--color-text-faint); }
.permalink-icon:hover { opacity: 1; color: var(--color-link); }

/* =========================================================================
   Post Page — Layout
   ========================================================================= */
.post-layout {
  max-width: var(--content-full);
  width: 100%;
  margin: 0 auto; padding: 0 var(--gutter);
  display: grid; grid-template-columns: 1fr; gap: 0;
}
@media (min-width: 960px) {
  .post-layout { grid-template-columns: 1fr var(--sidebar-width); gap: var(--space-7); padding: 0 var(--gutter-wide); }
}

.post-content {
  max-width: var(--content-width);
  width: 100%;
  min-width: 0; /* prevent grid blowout from long words/URLs/code */
  padding-bottom: var(--space-9);
  overflow-wrap: break-word;
  word-break: break-word;
}

/* Post Header */
.post-header { margin-bottom: var(--space-7); padding-bottom: var(--space-5); border-bottom: var(--border-thin); }
.post-header__tags { display: flex; gap: var(--space-2); margin-bottom: var(--space-3); }
.post-header__tag { font-size: var(--font-size-xs); font-weight: 700; color: var(--color-accent); text-transform: uppercase; letter-spacing: var(--tracking-wide); }
.post-header__title { font-family: var(--font-display); font-size: var(--font-size-2xl); font-weight: 400; line-height: var(--leading-tight); letter-spacing: var(--tracking-tight); margin-bottom: var(--space-4); color: var(--color-text); }
.post-header__meta { font-size: var(--font-size-sm); color: var(--color-text-muted); display: flex; gap: var(--space-3); flex-wrap: wrap; }
.post-header__meta span { white-space: nowrap; }

/* Post Body */
.post-body { font-size: var(--font-size-md); line-height: var(--leading-loose); }
.post-body p { margin-bottom: var(--space-5); }
.post-body h2, .post-body h3 { font-family: var(--font-display); letter-spacing: var(--tracking-tight); line-height: var(--leading-tight); color: var(--color-text); scroll-margin-top: var(--space-6); }
.post-body h2 { font-size: var(--font-size-xl); font-weight: 400; margin-top: var(--space-8); margin-bottom: var(--space-4); }
.post-body h3 { font-size: var(--font-size-lg); font-weight: 400; margin-top: var(--space-7); margin-bottom: var(--space-3); }
.post-body a { text-decoration: underline; text-underline-offset: 2px; }
.post-body a:hover { text-decoration-color: var(--color-link-hover); }
.post-body code { font-family: var(--font-mono); font-size: 0.85em; background: var(--color-bg-code); padding: 0.15em 0.4em; border-radius: 3px; color: var(--color-code-text); }
.post-body pre { background: var(--color-bg-code); border-radius: var(--radius-md); padding: var(--space-4); overflow-x: auto; max-width: 100%; margin-bottom: var(--space-5); font-family: var(--font-mono); font-size: var(--font-size-sm); line-height: var(--leading-normal); color: var(--color-code-text); }
.post-body pre code { background: none; padding: 0; border-radius: 0; font-size: inherit; }
.post-body img { max-width: 100%; height: auto; border-radius: var(--radius-md); margin-bottom: var(--space-5); }
.post-body table { width: 100%; max-width: 100%; border-collapse: collapse; margin-bottom: var(--space-5); font-size: var(--font-size-sm); overflow-x: auto; display: block; }
.post-body th, .post-body td { padding: var(--space-2) var(--space-3); text-align: left; border-bottom: var(--border-thin); }
.post-body th { font-weight: 700; color: var(--color-text); }
.post-body td { color: var(--color-text-muted); }
.post-body figcaption { font-size: var(--font-size-xs); color: var(--color-text-faint); text-align: center; margin-top: calc(-1 * var(--space-3)); margin-bottom: var(--space-5); }
.post-body ul, .post-body ol { margin-bottom: var(--space-5); padding-left: var(--space-5); }
.post-body li { margin-bottom: var(--space-2); }
.post-body blockquote { border-left: 3px solid var(--color-accent); padding-left: var(--space-4); margin-bottom: var(--space-5); color: var(--color-text-muted); font-style: italic; }

/* Ghost callout cards */
.kg-callout-card { display: flex; gap: var(--space-3); padding: var(--space-4); background: var(--color-bg-code); border-radius: var(--radius-md); margin-bottom: var(--space-5); font-size: var(--font-size-sm); line-height: var(--leading-normal); }
.kg-callout-emoji { font-size: var(--font-size-lg); flex-shrink: 0; line-height: 1; }

/* Ghost code card */
.kg-code-card { margin-bottom: var(--space-5); }
.kg-code-card pre { margin-bottom: 0; }
.kg-code-card figcaption { margin-top: var(--space-2); }

/* Ghost product cards (used on Projects page) */
.kg-product-card {
  margin-bottom: var(--space-6);
  border: var(--border-thin);
  border-radius: var(--radius-lg);
  background: var(--color-bg-surface);
  overflow: hidden;
  transition: border-color var(--duration-fast) var(--ease-out),
              transform var(--duration-fast) var(--ease-out);
}
.kg-product-card:hover {
  border-color: var(--color-border-bold);
  transform: translateY(-2px);
}
.kg-product-card-container {
  display: flex;
  flex-direction: column;
}
.kg-product-card-image {
  width: 100%;
  height: auto;
  display: block;
  border-bottom: var(--border-thin);
}
.kg-product-card-title-container {
  padding: var(--space-4) var(--space-4) var(--space-2);
}
.kg-product-card-title {
  font-family: var(--font-display);
  font-size: var(--font-size-lg);
  font-weight: 400;
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  margin: 0;
}
.kg-product-card-title a {
  color: var(--color-link);
  text-decoration: none;
}
.kg-product-card-title a:hover { color: var(--color-link-hover); }
.kg-product-card-description {
  padding: 0 var(--space-4) var(--space-4);
  font-size: var(--font-size-sm);
  line-height: var(--leading-normal);
  color: var(--color-text-muted);
}
.kg-product-card-description p { margin-bottom: var(--space-2); }
.kg-product-card-description p:last-child { margin-bottom: 0; }
.kg-product-card-rating { display: none; }
.kg-product-card-button {
  display: inline-block;
  margin: 0 var(--space-4) var(--space-4);
  padding: var(--space-2) var(--space-4);
  font-size: var(--font-size-sm);
  font-weight: 500;
  font-family: var(--font-body);
  color: var(--color-bg);
  background: var(--color-accent);
  border: none;
  border-radius: var(--radius-md);
  text-decoration: none;
  cursor: pointer;
  transition: opacity var(--duration-fast) var(--ease-out);
}
.kg-product-card-button:hover { opacity: 0.85; }
.kg-product-card-button:visited { color: var(--color-bg); }

/* Ghost image cards */
.kg-image-card { margin-bottom: var(--space-5); }
.kg-image-card img { max-width: 100%; height: auto; border-radius: var(--radius-md); }
.kg-width-wide { max-width: var(--content-wide); margin-left: auto; margin-right: auto; }
.kg-width-full { max-width: 100%; }

/* Post Footer */
.post-footer { border-top: var(--border-thin); padding-top: var(--space-5); margin-top: var(--space-7); }
.post-footer__back { font-size: var(--font-size-sm); color: var(--color-text-muted); }
.post-footer__back:hover { color: var(--color-link); }

/* =========================================================================
   TOC — Sidebar (wide screens)
   ========================================================================= */
.toc-sidebar { display: none; }
@media (min-width: 960px) {
  .toc-sidebar {
    display: block;
    position: sticky;
    top: var(--space-6);
    align-self: start;
    padding-top: var(--space-7);
    max-height: calc(100vh - var(--space-7));
    overflow-y: auto;
  }
  /* The grid row must be taller than the sidebar for sticky to work.
     Ensure the content column drives the row height, not the sidebar. */
  .post-content { min-height: 100vh; }
}
.toc__label { font-size: var(--font-size-xs); font-weight: 700; color: var(--color-text-faint); text-transform: uppercase; letter-spacing: var(--tracking-wide); margin-bottom: var(--space-3); }
.toc__list { list-style: none; border-left: 2px solid var(--color-border); }
.toc__item { position: relative; }
.toc__link { display: block; padding: var(--space-2) var(--space-3); font-size: var(--font-size-xs); line-height: var(--leading-normal); color: var(--color-text-faint); text-decoration: none; transition: color var(--duration-fast) var(--ease-out); }
.toc__link:hover { color: var(--color-text); }
.toc__link:visited { color: var(--color-text-faint); }
.toc__link--h3 { padding-left: var(--space-5); }
.toc__item--active .toc__link { color: var(--color-text); font-weight: 500; }
.toc__item--active::before { content: ""; position: absolute; left: -2px; top: 0; bottom: 0; width: 2px; background: var(--color-accent); }

/* TOC — Mobile */
.toc-mobile { margin-bottom: var(--space-6); }
@media (min-width: 960px) { .toc-mobile { display: none; } }
.toc-mobile__toggle { background: none; border: var(--border-thin); border-radius: var(--radius-md); padding: var(--space-2) var(--space-3); font-size: var(--font-size-sm); color: var(--color-text-muted); cursor: pointer; display: flex; align-items: center; gap: var(--space-2); width: 100%; transition: border-color var(--duration-fast) var(--ease-out); font-family: var(--font-body); }
.toc-mobile__toggle:hover { border-color: var(--color-border-bold); }
.toc-mobile__toggle svg { width: 14px; height: 14px; fill: var(--color-text-faint); transition: transform var(--duration-fast) var(--ease-out); }
.toc-mobile__toggle[aria-expanded="true"] svg { transform: rotate(90deg); }
.toc-mobile__list { list-style: none; margin-top: var(--space-3); padding-left: var(--space-3); border-left: 2px solid var(--color-border); display: none; }
.toc-mobile__list.is-open { display: block; }
.toc-mobile__list a { display: block; padding: var(--space-1) var(--space-2); font-size: var(--font-size-sm); color: var(--color-text-muted); text-decoration: none; }
.toc-mobile__list a:hover { color: var(--color-text); }

/* =========================================================================
   Interactive Post — Hero
   ========================================================================= */
.hero { max-width: var(--content-width); margin: var(--space-8) auto var(--space-7); padding: 0 var(--gutter); text-align: center; }
.hero__label { font-size: var(--font-size-xs); font-weight: 700; color: var(--color-accent); text-transform: uppercase; letter-spacing: var(--tracking-wide); margin-bottom: var(--space-4); }
.hero__title { font-family: var(--font-display); font-size: var(--font-size-3xl); font-weight: 400; line-height: var(--leading-tight); letter-spacing: var(--tracking-tight); color: var(--color-text); margin-bottom: var(--space-4); }
.hero__meta { font-size: var(--font-size-sm); color: var(--color-text-muted); }

/* Interactive prose sections */
.prose { max-width: var(--content-width); margin: 0 auto; padding: 0 var(--gutter); font-size: var(--font-size-md); line-height: var(--leading-loose); }
.prose p { margin-bottom: var(--space-5); }
.prose h2 { font-family: var(--font-display); font-size: var(--font-size-xl); font-weight: 400; letter-spacing: var(--tracking-tight); line-height: var(--leading-tight); margin-top: var(--space-9); margin-bottom: var(--space-4); color: var(--color-text); }
.prose h3 { font-family: var(--font-display); font-size: var(--font-size-lg); font-weight: 400; letter-spacing: var(--tracking-tight); line-height: var(--leading-tight); margin-top: var(--space-7); margin-bottom: var(--space-3); color: var(--color-text); }
.prose a { text-decoration: underline; text-underline-offset: 2px; }
.prose code { font-family: var(--font-mono); font-size: 0.85em; background: var(--color-bg-code); padding: 0.15em 0.4em; border-radius: 3px; }
.prose strong { font-weight: 700; color: var(--color-text); }

/* Tag Page */
.tag-header { max-width: var(--content-width); margin: 0 auto; padding: var(--space-6) var(--gutter) var(--space-5); border-bottom: 2px solid var(--color-border-bold); margin-bottom: var(--space-6); }
.tag-header__label { font-size: var(--font-size-xs); font-weight: 700; color: var(--color-text-faint); text-transform: uppercase; letter-spacing: var(--tracking-wide); margin-bottom: var(--space-2); }
.tag-header__name { font-family: var(--font-display); font-size: var(--font-size-2xl); font-weight: 400; line-height: var(--leading-tight); letter-spacing: var(--tracking-tight); color: var(--color-text); margin-bottom: var(--space-2); }
.tag-header__count { font-size: var(--font-size-sm); color: var(--color-text-muted); }
.tag-posts { max-width: var(--content-width); margin: 0 auto; padding: 0 var(--gutter) var(--space-9); }

/* 404 */
.error-page { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: var(--space-6) var(--gutter); min-height: 60vh; }
.error-code { font-family: var(--font-display); font-size: 6rem; font-weight: 400; line-height: 1; color: var(--color-border-bold); letter-spacing: var(--tracking-tight); margin-bottom: var(--space-4); }
.error-title { font-family: var(--font-display); font-size: var(--font-size-xl); font-weight: 400; line-height: var(--leading-tight); color: var(--color-text); margin-bottom: var(--space-3); }
.error-desc { font-size: var(--font-size-sm); color: var(--color-text-muted); max-width: 28rem; margin-bottom: var(--space-6); }
.error-link { font-size: var(--font-size-sm); font-weight: 500; color: var(--color-link); padding: var(--space-2) var(--space-4); border: var(--border-thin); border-radius: var(--radius-md); transition: border-color var(--duration-fast) var(--ease-out); }
.error-link:hover { border-color: var(--color-link); }

/* =========================================================================
   Projects Page (custom-projects.hbs)
   ========================================================================= */
.projects-page {
  max-width: var(--content-wide);
  margin: 0 auto;
  padding: 0 var(--gutter) var(--space-9);
}

.projects-header {
  padding: var(--space-6) 0 var(--space-5);
  margin-bottom: var(--space-5);
  border-bottom: 2px solid var(--color-border-bold);
}

.projects-header__title {
  font-family: var(--font-display);
  font-size: var(--font-size-2xl);
  font-weight: 400;
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--color-text);
}

/* Lay out product cards in a 2-column grid on the projects page */
.projects-body .kg-product-card {
  break-inside: avoid;
}

.projects-body {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}

@media (min-width: 640px) {
  .projects-body {
    grid-template-columns: 1fr 1fr;
  }
}

/* Inside the grid, product cards fill their cell */
.projects-body > .kg-card {
  margin-bottom: 0;
}
.projects-body .kg-product-card {
  margin-bottom: 0;
  height: 100%;
  display: flex;
  flex-direction: column;
}
.projects-body .kg-product-card-container {
  flex: 1;
  display: flex;
  flex-direction: column;
}
.projects-body .kg-product-card-description {
  flex: 1;
}

/* Non-product content (plain text paragraphs) spans full width */
.projects-body > p,
.projects-body > h2,
.projects-body > h3 {
  grid-column: 1 / -1;
}

/* =========================================================================
   Responsive
   ========================================================================= */
@media (min-width: 640px) {
  .site-header { padding: var(--space-7) var(--gutter-wide) var(--space-6); }
  .stream { padding: 0 var(--gutter-wide) var(--space-9); }
  .site-footer { padding: var(--space-6) var(--gutter-wide) var(--space-8); }
  .post-body { font-size: var(--font-size-md); }
  .prose { font-size: var(--font-size-md); }
}

@media (max-width: 640px) {
  .site-title { font-size: var(--font-size-lg); }
  .post-card__title { font-size: var(--font-size-base); font-weight: 600; }
  .post-header__title { font-size: var(--font-size-xl); }
  .post-body { font-size: var(--font-size-base); }
  .post-body pre { font-size: var(--font-size-xs); padding: var(--space-3); }
  .hero__title { font-size: var(--font-size-2xl); }
  .hero { margin: var(--space-6) auto var(--space-5); }
  .tag-header__name { font-size: var(--font-size-xl); }
  .error-code { font-size: 4rem; }
  /* Prevent horizontal overflow on post pages */
  .post-content { max-width: 100%; overflow-wrap: break-word; word-break: break-word; }
  .post-body img { max-width: 100%; height: auto; }
  .post-body .kg-card { max-width: 100%; overflow-x: auto; }
}
