/* kbwen Lab — homepage v5.1 stylesheet
   Tokens come from tokens.css. This file scopes everything to the homepage layout. */

/* ===== Reset / base ===== */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html {
  background: var(--color-bg);
  color-scheme: dark;
  /* Sticky header is 57px; pad anchor scrolls so #main / #editors-picks /
     #explore-category / #recently-added land BELOW the chrome instead of
     under it. Without this, every nav anchor click (and the skip-link)
     scrolled the section heading into the sticky header's blind spot. */
  scroll-padding-top: 72px;
}
body {
  background: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-sans);
  font-size: var(--text-md);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }
h1, h2, h3, h4 { margin: 0; font-weight: 600; line-height: 1.2; }
hr { border: 0; border-top: 1px solid var(--color-border-muted); margin: 0; }

/* Bilingual pattern (server prunes the wrong-lang spans on localized pages;
   this rule keeps the runtime toggle clean for the default page). */
[data-lang] { display: none; }
[data-lang]:not([hidden]) { display: inline; }

.container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--space-6);
}
@media (max-width: 1023px) { .container { padding: 0 var(--space-5); } }
@media (max-width: 719px)  { .container { padding: 0 var(--space-4); } }

/* ===== Header (v5.1, cards variant — emitted by header-lib renderCardHeader) ===== */
/* Skip-to-content link — visible only on keyboard focus. Lives here AND in
   layout.css because home pages load homepage.css alone (no layout.css);
   without this rule the link rendered as plain visible text above the
   header on every browse page. */
.skip-link {
  position: absolute;
  left: 16px;
  top: 8px;
  z-index: 100;
  padding: 8px 12px;
  background: var(--color-primary);
  color: var(--color-on-primary);
  font: 500 13px/1 var(--font-sans);
  border-radius: var(--radius-sm);
  text-decoration: none;
  transform: translateY(-200%);
  transition: transform 160ms ease;
}
.skip-link:focus,
.skip-link:focus-visible {
  transform: translateY(0);
  outline: 2px solid var(--color-text);
  outline-offset: 2px;
}

.site-header[data-header-variant="cards"] {
  position: sticky;
  top: 0;
  z-index: var(--z-header);
  background: color-mix(in oklch, var(--color-bg) 92%, transparent);
  backdrop-filter: saturate(140%) blur(8px);
  -webkit-backdrop-filter: saturate(140%) blur(8px);
  border-bottom: 1px solid var(--color-border-muted);
}
.site-header[data-header-variant="cards"] .site-header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 56px;
  gap: var(--space-5);
}
.site-header[data-header-variant="cards"] .site-brand {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-md);
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--color-text);
}
.site-header[data-header-variant="cards"] .site-brand-mark {
  width: 20px; height: 20px;
  border-radius: 6px;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--cat-ai) 100%);
  display: inline-block;
}
.site-header[data-header-variant="cards"] .site-brand-lab {
  color: var(--chrome-ink-muted, var(--color-text-muted));
  font-weight: 500;
  margin-left: 2px;
}
.site-header[data-header-variant="cards"] .site-nav {
  display: flex;
  align-items: center;
  gap: var(--space-5);
}
.site-header[data-header-variant="cards"] .site-nav-links {
  display: flex;
  gap: var(--space-5);
}
.site-header[data-header-variant="cards"] .site-nav-links a {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  padding: var(--space-2) 0;
  transition: color var(--transition-fast);
}
.site-header[data-header-variant="cards"] .site-nav-links a:hover,
.site-header[data-header-variant="cards"] .site-nav-links a[aria-current="page"] { color: var(--color-text); }
.site-header[data-header-variant="cards"] .site-nav-links a:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
  border-radius: 2px;
}
@media (max-width: 719px) {
  .site-header[data-header-variant="cards"] .site-nav-links { display: none; }
}

/* ===== Lang dropdown ===== */
.lang-dropdown {
  position: relative;
  margin-left: var(--space-3);
}
.lang-dropdown-trigger {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px 6px 8px;
  background: transparent;
  border: 1px solid var(--color-border-muted);
  border-radius: var(--radius-pill);
  color: var(--chrome-ink, var(--color-text));
  font: 500 12px/1 var(--font-sans);
  cursor: pointer;
  transition: border-color var(--transition-fast), background var(--transition-fast);
}
.lang-dropdown-trigger:hover {
  border-color: var(--color-border);
  background: color-mix(in oklch, var(--color-primary) 5%, transparent);
}
.lang-dropdown-trigger:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}
.lang-dropdown-globe { width: 14px; height: 14px; color: var(--chrome-ink-muted, var(--color-text-muted)); }
.lang-dropdown-current {
  font: 500 12px/1 var(--font-mono);
  letter-spacing: 0.06em;
  color: var(--chrome-ink, var(--color-text));
}
.lang-dropdown-caret {
  width: 8px; height: 5px;
  color: var(--color-text-faint);
  transition: transform var(--transition-fast);
}
.lang-dropdown[data-open="true"] .lang-dropdown-caret { transform: rotate(180deg); }
.lang-dropdown-menu {
  position: absolute;
  right: 0;
  top: calc(100% + 6px);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 4px;
  min-width: 200px;
  box-shadow: var(--shadow-md);
  z-index: var(--z-dropdown);
}
.lang-dropdown-menu[hidden] { display: none; }
.lang-dropdown-item {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 10px;
  align-items: center;
  padding: 8px 10px;
  border-radius: var(--radius-sm);
  text-decoration: none;
  color: var(--color-text);
  font: 500 13px/1 var(--font-sans);
  transition: background var(--transition-fast);
}
.lang-dropdown-item:hover { background: var(--color-surface-2); }
.lang-dropdown-code {
  font: 500 11px/1 var(--font-mono);
  letter-spacing: 0.08em;
  color: var(--color-text-muted);
  padding: 2px 6px;
  border: 1px solid var(--color-border-muted);
  border-radius: var(--radius-xs);
}
.lang-dropdown-name { color: var(--color-text); }
.lang-dropdown-check { color: var(--color-primary); font-weight: 700; opacity: 0; }
.lang-dropdown-item.is-active .lang-dropdown-check { opacity: 1; }
.lang-dropdown-item.is-active .lang-dropdown-code {
  border-color: var(--color-primary);
  color: var(--color-primary);
}
.lang-dropdown-item.is-disabled { opacity: 0.45; pointer-events: none; }
.lang-dropdown-soon {
  font: 500 9px/1 var(--font-mono);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-text-faint);
  padding: 3px 6px;
  background: var(--color-bg-deep);
  border-radius: var(--radius-xs);
}

/* Mobile tap target — mirrors layout.css so home + category pages match
   the 44px Apple HIG / WCAG 2.5.5 minimum that tool pages already render.
   Without this, the trigger renders 28px tall on home + category and the
   user gets a sub-spec tap target on every browse-surface page.
   Breakpoint covers iPad portrait (768/834) plus narrower — design-review
   flagged the 721-900 window as an iPad portrait dead zone where the
   trigger reverted to 28px. */
@media (max-width: 900px) {
  .lang-dropdown-trigger {
    min-height: 44px;
    padding: 8px 14px;
  }
  /* Mobile tap target — chrome links rendered as bare text height (22-26px)
     leave fingers fishing on the footer column links and the brand mark.
     Bump them to the 44px floor with vertical padding on the anchor itself
     so the underline / hover area matches the tappable area. */
  .site-footer-col a {
    min-height: 44px;
    display: flex;
    align-items: center;
  }
  .site-header[data-header-variant="cards"] .site-brand,
  .site-header[data-header-variant="tool"] .site-brand {
    min-height: 44px;
    align-items: center;
  }
}

/* ===== Hero ===== */
.surface-hero {
  position: relative;
  padding: var(--space-7) 0 var(--space-6);
  overflow: hidden;
  border-bottom: 1px solid var(--color-border-muted);
}
.surface-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 50% 70% at 12% 0%, color-mix(in oklch, var(--color-surface-2) 70%, transparent) 0%, transparent 55%),
    radial-gradient(ellipse 40% 60% at 95% 20%, color-mix(in oklch, var(--cat-ai) 4%, transparent) 0%, transparent 60%);
  pointer-events: none;
}
.surface-hero > .container { position: relative; }

.hero-v5-1 {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  padding: var(--space-3) 0 var(--space-2);
}
.hero-v5-1-band {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  gap: var(--space-7);
  align-items: end;
  padding-bottom: var(--space-5);
  border-bottom: 1px solid var(--color-border-muted);
}
.hero-v5-1-text { padding-top: var(--space-2); }
.brand-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  color: var(--color-primary);
  margin-bottom: var(--space-4);
}
.brand-eyebrow::before {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: var(--radius-xs);
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-accent) 100%);
  box-shadow: 0 0 0 2px color-mix(in oklch, var(--color-primary) 20%, transparent);
}
.hero-v5-1-title {
  font-size: 48px;
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin: 0 0 var(--space-3);
  max-width: 18ch;
  text-wrap: balance;
}
.hero-v5-1-subtitle {
  font-size: var(--text-md);
  max-width: 44ch;
  margin: 0;
  color: var(--color-text-muted);
  line-height: 1.55;
  text-wrap: pretty;
}

.hero-signature--inline {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  align-items: flex-start;
  margin: 0;
  padding: 0;
  border-top: none;
}
.hero-signature-label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}
.hero-signature-dots {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}
.hero-signature-dot {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px 4px 8px;
  border-radius: var(--radius-pill);
  background: color-mix(in oklch, var(--dot) 10%, var(--color-surface));
  border: 1px solid color-mix(in oklch, var(--dot) 18%, var(--color-border));
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--color-text-muted);
  transition: background var(--transition-fast), color var(--transition-fast), transform var(--transition-fast);
}

@media (max-width: 900px) {
  /* Touch / portrait-tablet: ensure each category dot meets the 44px
     tap-target floor. Width-gated rather than (pointer:coarse) because
     devtools emulators and many Android Chrome variants report mixed
     pointer/hover values; 900px matches the existing hero breakpoint. */
  .hero-signature-dot { min-height: 44px; }
}
.hero-signature-dot::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: var(--dot);
  box-shadow: 0 0 0 2px color-mix(in oklch, var(--dot) 20%, transparent);
}
.hero-signature-dot:hover {
  color: var(--color-text);
  background: color-mix(in oklch, var(--dot) 16%, var(--color-surface-2));
  transform: translateY(-1px);
}
.hero-signature-dot:focus-visible {
  outline: 2px solid var(--dot);
  outline-offset: 2px;
}
.hero-signature-count {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--color-text-muted);
  opacity: 0.7;
}

@media (max-width: 900px) {
  .hero-v5-1-band { grid-template-columns: 1fr; gap: var(--space-5); }
  .hero-v5-1-title { font-size: 38px; }
  .hero-signature-dots { flex-wrap: wrap; }
}

/* ===== Pick card ===== */
.pick-card {
  position: relative;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.04) inset,
    0 24px 48px -24px rgba(0,0,0,0.5);
  --card-accent: var(--cat-quant);
}
.pick-card[data-cat="dev"]    { --card-accent: var(--cat-dev); }
.pick-card[data-cat="ai"]     { --card-accent: var(--cat-ai); }
.pick-card[data-cat="quant"]  { --card-accent: var(--cat-quant); }
.pick-card[data-cat="games"]  { --card-accent: var(--cat-games); }
.pick-card[data-cat="text"]   { --card-accent: var(--cat-text); }
.pick-card[data-cat="design"] { --card-accent: var(--cat-design); }
.pick-card[data-cat="time"]   { --card-accent: var(--cat-time); }
.pick-card[data-cat="edu"]    { --card-accent: var(--cat-edu); }
.pick-card[data-cat="local"]  { --card-accent: var(--cat-local); }

.pick-card-strip {
  position: relative;
  height: 56px;
  background:
    linear-gradient(180deg,
      color-mix(in oklch, var(--card-accent) 22%, var(--color-surface)) 0%,
      color-mix(in oklch, var(--card-accent) 8%, var(--color-surface)) 100%);
  border-bottom: 1px solid color-mix(in oklch, var(--card-accent) 35%, var(--color-border));
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) var(--space-6);
}
.pick-card-strip .pattern {
  position: absolute;
  inset: 0;
  opacity: 0.45;
  color: var(--card-accent);
  mix-blend-mode: screen;
  pointer-events: none;
}
.pick-card-strip .pattern svg { width: 100%; height: 100%; display: block; }
.pick-card-eyebrow {
  position: relative;
  z-index: 2;
  font: 500 11px/1 var(--font-mono);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-text);
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}
.pick-card-eyebrow-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--card-accent);
  font-size: 0;
  box-shadow: 0 0 0 3px color-mix(in oklch, var(--card-accent) 18%, transparent);
  animation: pickPulse 2.4s ease-in-out infinite;
}
@keyframes pickPulse {
  0%, 100% { box-shadow: 0 0 0 3px color-mix(in oklch, var(--card-accent) 18%, transparent); }
  50%      { box-shadow: 0 0 0 7px color-mix(in oklch, var(--card-accent) 0%, transparent); }
}
.pick-card-strip-meta {
  position: relative;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font: 500 11px/1 var(--font-mono);
  letter-spacing: 0.08em;
  color: var(--color-text-muted);
}
.pick-card-strip-meta-key { color: var(--color-text-faint); text-transform: uppercase; }
.pick-card-strip-meta-val { color: var(--color-text); }
.pick-card-strip-meta-sep { color: var(--color-text-faint); margin: 0 4px; }

.pick-card-split {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
  align-items: stretch;
}

/* Preview pane (left) — elastic; min-height keeps shorter picks (timer, calendar)
   from collapsing too small, but longer picks (tree, diff) grow naturally. */
.pick-preview {
  background:
    linear-gradient(180deg,
      color-mix(in oklch, var(--card-accent) 6%, var(--color-bg-deep)) 0%,
      color-mix(in oklch, var(--card-accent) 2%, var(--color-bg-deep)) 100%);
  padding: var(--space-5);
  border-right: 1px solid var(--color-border-muted);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  min-height: 340px;
}
.pick-preview-frame {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  background: var(--color-bg-deep);
  border: 1px solid color-mix(in oklch, var(--card-accent) 25%, var(--color-border));
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: 0 8px 24px -12px rgba(0,0,0,0.45);
}
.pick-preview-chrome {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  background: color-mix(in oklch, var(--card-accent) 8%, #0a1220);
  border-bottom: 1px solid color-mix(in oklch, var(--card-accent) 18%, var(--color-border-muted));
}
.pick-preview-dot {
  width: 9px; height: 9px;
  border-radius: 50%;
  background: color-mix(in oklch, var(--card-accent) 30%, #2a3348);
}
.pick-preview-dot:nth-child(1) { background: #ff5f57; opacity: 0.55; }
.pick-preview-dot:nth-child(2) { background: #febc2e; opacity: 0.55; }
.pick-preview-dot:nth-child(3) { background: #28c840; opacity: 0.55; }
.pick-preview-url {
  margin-left: 12px;
  font: 500 11px/1 var(--font-mono);
  color: var(--color-text-muted);
  letter-spacing: 0.04em;
  flex: 1;
  text-align: center;
  padding-right: 50px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pick-preview-canvas {
  flex: 1 1 auto;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  min-height: 200px;
}
.pick-preview-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  color: var(--card-accent);
}
.pick-preview-placeholder svg {
  width: 100%;
  flex: 1 1 auto;
  max-height: 160px;
}
.pp-line {
  stroke-dasharray: 600;
  stroke-dashoffset: 600;
  animation: ppDraw 2.4s ease-out forwards;
}
.pp-dot { opacity: 0; animation: ppFade 0.5s ease-out 2s forwards; }
@keyframes ppDraw { from { stroke-dashoffset: 600; } to { stroke-dashoffset: 0; } }
@keyframes ppFade { from { opacity: 0; } to { opacity: 1; } }
.pick-preview-readout {
  display: flex;
  align-items: baseline;
  gap: 8px;
  font: 500 12px/1 var(--font-mono);
  padding: 10px 12px;
  background: color-mix(in oklch, var(--card-accent) 10%, var(--color-bg-deep));
  border-radius: var(--radius-sm);
  border: 1px solid color-mix(in oklch, var(--card-accent) 22%, var(--color-border-muted));
}
.pp-key { color: var(--color-text-muted); letter-spacing: 0.04em; }
.pp-val { color: var(--card-accent); font-weight: 600; font-size: 13px; }
.pick-preview-caption {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font: 500 11px/1 var(--font-mono);
  letter-spacing: 0.06em;
  color: var(--color-text-faint);
  text-transform: uppercase;
}
.pp-live {
  color: #ef4444;
  font-size: 8px;
  animation: ppLive 1.6s ease-in-out infinite;
}
@keyframes ppLive { 0%, 100% { opacity: 1; } 50% { opacity: 0.3; } }

/* Preview templates */
.pp-diff { gap: var(--space-2); }
.pp-diff-rows {
  flex: 1; display: flex; flex-direction: column; gap: 4px; min-height: 0;
  font: 500 11px/1.5 var(--font-mono);
  letter-spacing: 0.02em;
}
.pp-diff-row {
  padding: 4px 8px;
  border-radius: var(--radius-xs);
  display: flex; gap: 6px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.pp-diff-mark { font-weight: 700; width: 12px; flex-shrink: 0; text-align: center; }
.pp-diff-old {
  background: color-mix(in oklch, #ef4444 12%, transparent);
  color: color-mix(in oklch, #ef4444 85%, var(--color-text));
  text-decoration: line-through;
  text-decoration-color: rgba(239,68,68,0.3);
}
.pp-diff-new {
  background: color-mix(in oklch, var(--card-accent) 14%, transparent);
  color: var(--card-accent);
}
.pp-grid-board { gap: var(--space-2); align-items: center; }
.pp-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 3px;
  width: 100%;
  max-width: 180px;
  aspect-ratio: 1 / 1;
  padding: 4px;
  background: color-mix(in oklch, var(--card-accent) 20%, var(--color-bg-deep));
  border-radius: var(--radius-sm);
  margin: 0 auto;
}
.pp-tile {
  display: flex; align-items: center; justify-content: center;
  background: color-mix(in oklch, var(--card-accent) 8%, var(--color-bg-deep));
  border-radius: var(--radius-xs);
  font: 700 13px/1 var(--font-sans);
  color: var(--color-text-muted);
}
.pp-tile[data-v="2"]    { background: color-mix(in oklch, var(--card-accent) 18%, var(--color-bg-deep)); color: var(--color-text); }
.pp-tile[data-v="4"]    { background: color-mix(in oklch, var(--card-accent) 28%, var(--color-bg-deep)); color: var(--color-text); }
.pp-tile[data-v="8"]    { background: color-mix(in oklch, var(--card-accent) 40%, var(--color-bg-deep)); color: #fff; }
.pp-tile[data-v="16"]   { background: color-mix(in oklch, var(--card-accent) 55%, var(--color-bg-deep)); color: #fff; }
.pp-tile[data-v="32"]   { background: color-mix(in oklch, var(--card-accent) 65%, var(--color-bg-deep)); color: #fff; font-size: 12px; }
.pp-tile[data-v="64"]   { background: color-mix(in oklch, var(--card-accent) 75%, var(--color-bg-deep)); color: #0a0c10; font-size: 12px; }
.pp-tile[data-v=""]     { opacity: 0.6; }
.pp-cal { gap: var(--space-2); }
.pp-cal-head {
  font: 500 11px/1 var(--font-mono);
  letter-spacing: 0.08em;
  color: var(--color-text-muted);
  text-transform: uppercase;
}
.pp-cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px;
  /* DO NOT use flex:1 here — combined with aspect-ratio:1/1 on each day,
     it forced the grid wider than its natural column allocation when the
     parent .pick-preview had min-height: 340px. The pick-card-split column
     stretched to ~476px instead of the intended ~1.15fr share, blowing up
     the whole "Today's pick for you" section. Bound the grid by max-width
     so each cell stays square without commandeering horizontal space. */
  width: 100%;
  max-width: 280px;
  margin: 0 auto;
  align-self: center;
}
.pp-cal-day {
  display: flex; align-items: center; justify-content: center;
  font: 500 10px/1 var(--font-mono);
  color: var(--color-text-faint);
  background: color-mix(in oklch, var(--card-accent) 4%, var(--color-bg-deep));
  border-radius: 2px;
  aspect-ratio: 1 / 1;
}
.pp-cal-day.is-holiday {
  background: color-mix(in oklch, var(--card-accent) 35%, var(--color-bg-deep));
  color: #fff;
  font-weight: 600;
}
.pp-tree { gap: var(--space-2); }
.pp-tree-text {
  flex: 1;
  margin: 0;
  padding: 10px 12px;
  background: color-mix(in oklch, var(--card-accent) 5%, var(--color-bg-deep));
  border: 1px solid color-mix(in oklch, var(--card-accent) 20%, var(--color-border-muted));
  border-radius: var(--radius-sm);
  font: 500 11px/1.55 var(--font-mono);
  color: var(--color-text-muted);
  overflow: hidden;
  white-space: pre;
}
.pp-tok-num  { color: var(--card-accent); }
.pp-tok-str  { color: #ffd58a; }
.pp-tok-bool { color: #94e3b1; }
.pp-timer { gap: var(--space-2); align-items: center; }
.pp-timer-ring {
  position: relative;
  width: 130px; height: 130px;
  margin: 0 auto;
  flex: 0 0 auto;
}
.pp-timer-ring svg { width: 100%; height: 100%; color: var(--card-accent); }
.pp-timer-arc { animation: pomTick 4s ease-out forwards; }
@keyframes pomTick {
  from { stroke-dashoffset: 263.9; }
  to   { stroke-dashoffset: 80; }
}
.pp-timer-num {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font: 700 22px/1 var(--font-mono);
  color: var(--color-text);
  letter-spacing: 0.02em;
}

/* Meta pane (right) — elastic, grows to fit content */
.pick-meta {
  padding: var(--space-5) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  background: var(--color-surface);
}
.pick-card-headline {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-4);
  align-items: center;
  margin-top: var(--space-1);
}
.pick-card-icon {
  width: 56px; height: 56px;
  border-radius: var(--radius-md);
  background: color-mix(in oklch, var(--card-accent) 10%, var(--color-surface-2));
  border: 1px solid color-mix(in oklch, var(--card-accent) 30%, var(--color-border));
  color: var(--card-accent);
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.pick-card-icon svg { width: 28px; height: 28px; }
.pick-card-cat {
  font: 500 11px/1 var(--font-mono);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: color-mix(in oklch, var(--card-accent) 80%, var(--color-text-muted));
  margin-bottom: 6px;
}
.pick-card-title {
  font: 700 26px/1.2 var(--font-sans);
  color: var(--color-text);
  letter-spacing: -0.01em;
  margin: 0;
}
.pick-card-text {
  font-size: var(--text-sm);
  line-height: 1.55;
  color: var(--color-text-muted);
  margin: 0;
}
.pick-card-reason {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 6px 10px;
  border-radius: var(--radius-pill);
  background: color-mix(in oklch, var(--card-accent) 8%, var(--color-surface-2));
  border: 1px solid color-mix(in oklch, var(--card-accent) 28%, var(--color-border-muted));
  font: 500 12px/1.4 var(--font-sans);
  color: var(--color-text);
  align-self: flex-start;
}
.pick-card-reason-icon {
  font-family: var(--font-mono);
  color: var(--card-accent);
  font-weight: 600;
}
.pick-card-reason-text strong { font-weight: 700; color: var(--color-text); }
.pick-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  font: 500 12px/1 var(--font-mono);
  color: var(--color-text-muted);
  letter-spacing: 0.04em;
}
.pick-card-meta .dim { color: var(--color-text-faint); }
.pick-card-actions {
  display: flex;
  gap: var(--space-3);
  align-items: center;
  margin-top: var(--space-2);
  flex-wrap: wrap;
}
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-sm);
  font-weight: 500;
  min-height: 44px;
  text-decoration: none;
  background: transparent;
  color: var(--color-text);
  transition: background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);
}
.btn:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}
.btn-primary {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #07101e;
}
.btn-primary:hover {
  background: var(--color-primary-strong);
  border-color: var(--color-primary-strong);
  color: #fff;
  transform: translateY(-1px);
}
.pick-card-shuffle {
  background: transparent;
  border: 1px solid var(--color-border);
  color: var(--color-text);
}
.pick-card-shuffle:hover {
  background: var(--color-surface-2);
  border-color: var(--color-primary);
}
.pick-card-shuffle .dice {
  color: var(--color-primary);
  font-size: 14px;
  display: inline-block;
  transition: transform var(--transition-base);
}
.pick-card-shuffle:hover .dice { transform: rotate(180deg); }

.pick-card.is-swapping .pick-meta > *,
.pick-card.is-swapping .pick-preview-frame { animation: pickSwap 0.42s ease-out; }
@keyframes pickSwap {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

@media (max-width: 900px) {
  .pick-card-split { grid-template-columns: minmax(0, 1fr); }
  .pick-preview {
    border-right: none;
    border-bottom: 1px solid var(--color-border-muted);
    min-height: 280px;
    min-width: 0;
  }
  .pick-preview-frame { min-width: 0; }
  .pick-preview-url { padding-right: 8px; }
}

/* ===== Surface sections ===== */
.surface-section { padding: var(--space-7) 0; }
.surface-section--band {
  background: linear-gradient(180deg,
    color-mix(in oklch, var(--section-accent, var(--color-primary)) 5%, var(--color-surface)) 0%,
    var(--color-surface) 100%);
  border-top: 1px solid var(--color-border-muted);
  border-bottom: 1px solid var(--color-border-muted);
}
.surface-section-heading {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}
.surface-section-heading h2 {
  font-size: var(--text-2xl);
  letter-spacing: -0.01em;
  position: relative;
  padding-left: var(--space-4);
  margin: 0;
}
.surface-section-heading h2::before {
  content: "";
  position: absolute;
  left: 0;
  top: 6px;
  bottom: 6px;
  width: 3px;
  border-radius: 2px;
  background: var(--section-accent, var(--color-primary));
}
.surface-section-heading .heading-sub {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-top: var(--space-2);
  padding-left: var(--space-4);
}
.surface-section-heading .heading-right {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-variant-numeric: tabular-nums;
}
.surface-section-heading .heading-right strong { color: var(--color-text); font-weight: 600; }

/* ===== Guide row (mood chips) ===== */
.guide-row {
  display: flex;
  align-items: center;
  gap: var(--space-5);
  padding: var(--space-4) var(--space-5);
  margin-bottom: var(--space-6);
  background: var(--color-surface);
  border: 1px solid var(--color-border-muted);
  border-radius: var(--radius-lg);
  position: relative;
  overflow: hidden;
  flex-wrap: wrap;
}
.guide-row::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 3px;
  background: var(--color-primary);
  border-radius: 2px 0 0 2px;
}
.guide-row-label {
  font: 500 13px/1.3 var(--font-sans);
  color: var(--color-text);
  flex: 0 0 auto;
}
.guide-row-label .mono {
  font-family: var(--font-mono);
  color: var(--color-text-muted);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  display: block;
  margin-bottom: 2px;
}
.guide-row-chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  flex: 1 1 auto;
}
.guide-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border-muted);
  border-radius: var(--radius-pill);
  font: 500 13px/1 var(--font-sans);
  color: var(--color-text);
  text-decoration: none;
  transition: background var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);
  cursor: pointer;
}

@media (max-width: 900px) {
  /* Touch / portrait-tablet: enforce 44px tap-target floor on guide chips. */
  .guide-chip { min-height: 44px; }
}
.guide-chip-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--chip-dot, var(--color-primary));
}
.guide-chip:hover {
  background: color-mix(in oklch, var(--chip-dot, var(--color-primary)) 12%, var(--color-surface-2));
  border-color: color-mix(in oklch, var(--chip-dot, var(--color-primary)) 40%, var(--color-border));
  transform: translateY(-1px);
}
.guide-chip:focus-visible {
  outline: 2px solid var(--chip-dot, var(--color-primary));
  outline-offset: 2px;
}

@media (max-width: 720px) {
  .guide-row { flex-direction: column; align-items: flex-start; }
}

/* ===== Cards (spotlight + 6-grid) ===== */
/* Default card accent ONLY when no .cat-* class is present. The :where()
   wrapper keeps specificity at 0 so .cat-quant etc. always win. */
:where(.card) { --card-accent: var(--color-primary); }
.card {
  --card-accent-bg: color-mix(in oklch, var(--card-accent) 8%, transparent);
  position: relative;
  display: flex;
  flex-direction: column;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  min-height: 280px;
  transition: transform var(--transition-base), border-color var(--transition-base), background var(--transition-base);
  color: inherit;
  text-decoration: none;
}
.card:hover {
  transform: translateY(-2px);
  border-color: color-mix(in oklch, var(--card-accent) 40%, var(--color-border));
}
.card:hover .card-header-strip { filter: brightness(1.12); }
.card:hover .card-header-strip::after { opacity: 1; }
.card:focus-visible { outline: 2px solid var(--card-accent); outline-offset: 2px; }

.card-header-strip {
  position: relative;
  height: 64px;
  background:
    linear-gradient(180deg,
      color-mix(in oklch, var(--card-accent) 22%, var(--color-surface)) 0%,
      color-mix(in oklch, var(--card-accent) 10%, var(--color-surface)) 100%);
  overflow: hidden;
  transition: filter var(--transition-base);
  border-bottom: 1px solid color-mix(in oklch, var(--card-accent) 40%, var(--color-border));
}
.card-header-strip::before {
  content: "";
  position: absolute;
  top: 10px;
  right: 12px;
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: var(--card-accent);
  box-shadow: 0 0 0 3px color-mix(in oklch, var(--card-accent) 16%, transparent);
  z-index: 2;
}
.card-header-strip::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 2px;
  background: var(--card-accent);
  opacity: 0;
  transition: opacity var(--transition-base);
  z-index: 2;
}
.card-header-strip .pattern {
  position: absolute;
  inset: 0;
  opacity: 0.55;
  color: var(--card-accent);
  mix-blend-mode: screen;
  pointer-events: none;
}
.card-header-strip .pattern svg { display: block; width: 100%; height: 100%; }

.card-header {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-5) var(--space-5) 0;
  min-height: 36px;
  margin-top: -20px;
}
.card-icon-frame {
  width: 40px; height: 40px;
  border-radius: 10px;
  background: var(--color-surface);
  border: 1px solid color-mix(in oklch, var(--card-accent) 35%, var(--color-border));
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--card-accent);
  box-shadow:
    0 0 0 3px var(--color-surface),
    0 4px 12px color-mix(in oklch, var(--card-accent) 20%, transparent);
}
.card-icon-frame svg { width: 20px; height: 20px; }

.card-body {
  padding: var(--space-4) var(--space-5) var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  flex: 1;
}
.card-eyebrow {
  font: 600 var(--text-xs)/1 var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--card-accent);
}
.card-title {
  font-size: var(--text-xl);
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--color-text);
  line-height: 1.25;
  margin: 0;
}
.card-text {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.6;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.card-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-top: auto;
  padding-top: var(--space-3);
}
.card-pill {
  display: inline-flex;
  align-items: center;
  height: 22px;
  padding: 0 var(--space-2);
  border-radius: 6px;
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: color-mix(in oklch, var(--card-accent) 18%, transparent);
  color: color-mix(in oklch, var(--card-accent) 90%, white);
  font-family: var(--font-mono);
}
.card-badge-updated {
  font: 500 var(--text-xs)/1 var(--font-mono);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}

.card--spotlight {
  background:
    linear-gradient(180deg,
      color-mix(in oklch, var(--card-accent) 5%, var(--color-surface)) 0%,
      var(--color-surface) 60%);
  border-color: color-mix(in oklch, var(--card-accent) 25%, var(--color-border));
}
.card--spotlight .card-header-strip { height: 96px; }
.card--spotlight .card-header-strip .pattern { opacity: 0.7; }
.card--spotlight::before {
  content: "";
  position: absolute;
  top: 0;
  left: var(--space-5);
  width: 3px;
  height: 24px;
  background: var(--card-accent);
  border-radius: 0 0 var(--radius-xs) var(--radius-xs);
  z-index: 3;
}
.card--spotlight .card-title { font-size: 26px; }

/* ===== Grids ===== */
.grid-6, .grid-9, .grid-spotlight {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-5);
}
@media (max-width: 1023px) {
  .grid-6, .grid-9, .grid-spotlight { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 719px) {
  .grid-6, .grid-9, .grid-spotlight { grid-template-columns: 1fr; }
}

/* ===== Category card ===== */
:where(.category-card) { --card-accent: var(--color-primary); }
.category-card {
  display: flex;
  flex-direction: column;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  min-height: 240px;
  color: inherit;
  text-decoration: none;
  transition: transform var(--transition-base), border-color var(--transition-base);
}
.category-card:hover {
  transform: translateY(-2px);
  border-color: color-mix(in oklch, var(--card-accent) 30%, var(--color-border));
}
.category-card:hover .category-card-header-strip { filter: brightness(1.06); }
.category-card:focus-visible { outline: 2px solid var(--card-accent); outline-offset: 2px; }

.category-card-header-strip {
  position: relative;
  height: 56px;
  background:
    linear-gradient(180deg,
      color-mix(in oklch, var(--card-accent) 22%, var(--color-surface)) 0%,
      color-mix(in oklch, var(--card-accent) 10%, var(--color-surface)) 100%);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--space-5);
  overflow: hidden;
  transition: filter var(--transition-base);
  border-bottom: 1px solid color-mix(in oklch, var(--card-accent) 40%, var(--color-border));
}
.category-card-header-strip .pattern {
  position: absolute; inset: 0;
  opacity: 0.55;
  color: var(--card-accent);
  mix-blend-mode: screen;
  pointer-events: none;
}
.category-card-header-strip .pattern svg { width: 100%; height: 100%; display: block; }
.category-card-header-strip .cat-icon {
  position: relative;
  color: var(--card-accent);
  width: 24px; height: 24px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.category-card-header-strip .cat-icon svg { width: 24px; height: 24px; }
.category-card-header-strip .cat-label {
  position: relative;
  z-index: 2;
  font: 600 10px/1 var(--font-mono);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--card-accent);
  font-variant-numeric: tabular-nums;
}

.category-card-body {
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  flex: 1;
}
.category-card-body h3 {
  font-size: var(--text-xl);
  font-weight: 600;
  letter-spacing: -0.01em;
  margin: 0;
}
.category-card-count {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.02em;
}
.category-card-preview {
  list-style: none;
  padding: 0;
  margin: var(--space-3) 0 0;
  display: grid;
  gap: 6px;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}
.category-card-preview li {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  line-height: 1.4;
}
.category-card-preview li::before {
  content: "";
  flex-shrink: 0;
  width: 3px;
  height: 12px;
  background: color-mix(in oklch, var(--card-accent) 60%, var(--color-border));
  border-radius: 2px;
}
.category-card:hover .category-card-preview li::before { background: var(--card-accent); }
.category-card-see-all {
  font-size: var(--text-sm);
  color: var(--card-accent);
  margin-top: auto;
  padding-top: var(--space-4);
  font-weight: 500;
  letter-spacing: 0.01em;
}

/* ===== Recently added timeline ===== */
.recent-list {
  position: relative;
  padding-left: var(--space-6);
}
.recent-list::before {
  content: "";
  position: absolute;
  left: 7px;
  top: 8px;
  bottom: 8px;
  width: 1px;
  background: linear-gradient(180deg,
    var(--color-border-muted) 0%,
    var(--color-border) 50%,
    var(--color-border-muted) 100%);
}
.recent-row {
  position: relative;
  display: grid;
  grid-template-columns: 112px 1fr auto auto;
  gap: var(--space-4);
  align-items: center;
  padding: var(--space-4) var(--space-3);
  border-bottom: 1px solid var(--color-border-muted);
  border-radius: 6px;
  color: inherit;
  text-decoration: none;
  transition: background var(--transition-fast);
}
.recent-row::before {
  content: "";
  position: absolute;
  left: calc(-1 * var(--space-6) + 4px);
  top: 50%;
  transform: translateY(-50%);
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--color-surface);
  border: 2px solid color-mix(in oklch, var(--card-accent, var(--color-border)) 70%, var(--color-border));
  transition: background var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);
}
.recent-row:hover::before {
  background: var(--card-accent, var(--color-primary));
  border-color: var(--card-accent, var(--color-primary));
  transform: translateY(-50%) scale(1.2);
  box-shadow: 0 0 0 4px color-mix(in oklch, var(--card-accent, var(--color-primary)) 14%, transparent);
}
.recent-row:hover { background: var(--color-surface); }
.recent-row:focus-visible { outline: 2px solid var(--card-accent, var(--color-primary)); outline-offset: 2px; }
.recent-date {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.02em;
}
.recent-name {
  font-size: var(--text-md);
  color: var(--color-text);
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.recent-row:hover .recent-name::after {
  transform: translateX(3px);
  opacity: 1;
}
.recent-name::after {
  content: "→";
  font-weight: 400;
  color: var(--color-text-muted);
  opacity: 0;
  transition: transform var(--transition-fast), opacity var(--transition-fast);
}
.recent-sub {
  grid-column: 2 / 5;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-top: 2px;
}
.recent-sub::before { content: "↳ "; color: var(--color-border); margin-right: 4px; }
.recent-pill {
  display: inline-flex;
  align-items: center;
  height: 22px;
  padding: 0 var(--space-2);
  border-radius: 6px;
  font: 500 var(--text-xs)/1 var(--font-mono);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: color-mix(in oklch, var(--card-accent, var(--color-primary)) 20%, transparent);
  color: var(--card-accent, var(--color-primary));
}
.recent-event {
  font: 600 var(--text-xs)/1 var(--font-mono);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  min-width: 72px;
  text-align: right;
}
.recent-event.is-new { color: var(--color-new); }
.recent-event.is-updated { color: var(--color-text-muted); }
.recent-footer {
  display: flex;
  justify-content: flex-end;
  margin-top: var(--space-4);
  padding-right: var(--space-3);
}
.recent-footer a {
  font-size: var(--text-sm);
  color: var(--color-primary);
}
@media (max-width: 900px) {
  /* Touch / portrait-tablet: the "View all in {category}" link at the
     foot of the recent-activity strip is just inline text by default —
     bump it to 44px so it's actually tappable. Width-gated to keep
     desktop's compact end-of-strip aesthetic. */
  .recent-footer a {
    display: inline-flex;
    align-items: center;
    min-height: 44px;
  }
}
.recent-footer a:hover { text-decoration: underline; }
@media (max-width: 719px) {
  .recent-row {
    grid-template-columns: auto 1fr auto;
    gap: var(--space-3);
  }
  .recent-event { grid-column: 1 / 4; text-align: left; min-width: 0; padding-top: 2px; }
  .recent-sub { grid-column: 1 / 4; }
  .recent-pill { grid-row: 1; }
}

/* ===== Footer (v5.1, cards variant — emitted by footer-lib renderCardFooter) ===== */
.site-footer[data-footer-variant="cards"] {
  background:
    linear-gradient(180deg, transparent 0%, color-mix(in oklch, var(--color-primary) 4%, transparent) 100%),
    var(--color-bg);
  border-top: 1px solid var(--color-border-muted);
  padding: var(--space-8) 0 var(--space-6);
  margin-top: var(--space-8);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}
.site-footer[data-footer-variant="cards"] .site-footer-inner {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1.6fr);
  gap: var(--space-7);
  align-items: start;
}
.site-footer-brand { max-width: 480px; }
.site-footer-eyebrow {
  display: flex;
  align-items: center;
  gap: 8px;
  font: 500 11px/1 var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--chrome-ink-muted, var(--color-text-muted));
  margin-bottom: var(--space-3);
  flex-wrap: wrap;
}
.site-footer-eyebrow .mono {
  color: var(--color-primary);
  background: color-mix(in oklch, var(--color-primary) 10%, transparent);
  padding: 3px 8px;
  border-radius: var(--radius-xs);
  font-weight: 600;
}
.site-footer-eyebrow-sep { opacity: 0.5; }
.site-footer-tagline {
  font-size: var(--text-md);
  line-height: 1.55;
  color: var(--chrome-ink, var(--color-text));
  margin: 0 0 var(--space-4);
  text-wrap: pretty;
}
.site-footer-credit {
  font-size: var(--text-xs);
  color: var(--chrome-ink-muted, var(--color-text-muted));
  letter-spacing: 0.02em;
}
.site-footer-cols {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-5);
}
.site-footer-col { display: flex; flex-direction: column; gap: 8px; min-width: 0; }
.site-footer-col-title {
  font: 600 11px/1 var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--chrome-ink, var(--color-text));
  margin-bottom: 4px;
}
.site-footer-col-links {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
/* Browse column has 10 links — wrap to 2 cols so the footer stays compact */
.site-footer-col-links--wrap {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px var(--space-4);
}
.site-footer-col a {
  font-size: var(--text-sm);
  color: var(--chrome-ink-muted, var(--color-text-muted));
  text-decoration: none;
  transition: color var(--transition-fast), padding var(--transition-fast);
}
.site-footer-col a:hover {
  color: var(--chrome-ink, var(--color-text));
  padding-left: 4px;
}
.site-footer-col a:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
  border-radius: 2px;
}
/* Ko-fi button — homepage.css doesn't load layout.css, so the rule from
   layout.css can't be shared. Inline it here. The selector is double-classed
   so its `color` wins over `.site-footer-col a { color: var(--color-text-
   muted) }`, which previously turned the bright primary-blue button into
   muted-grey-on-blue (~1.05:1 contrast). */
.site-footer-col .footer-kofi-widget { margin-top: 4px; }
.site-footer .footer-kofi-button,
.footer-kofi-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 14px;
  border-radius: var(--radius-sm);
  background: var(--color-primary);
  color: var(--color-on-primary);
  font: 500 13px/1 var(--font-sans);
  text-decoration: none;
  transition: background var(--transition-fast), transform var(--transition-fast);
}
.footer-kofi-button:hover {
  background: var(--color-primary-strong);
  color: #fff;
  transform: translateY(-1px);
}
.site-footer-col .footer-kofi-button:hover { padding-left: 14px; }
@media (max-width: 900px) {
  .site-footer[data-footer-variant="cards"] .site-footer-inner { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .site-footer-cols { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 479px) {
  .site-footer-cols { grid-template-columns: 1fr; }
  /* Browse column keeps its 2-col grid on mobile — 10 links in a single
     475px-tall stack reads like dead space. Two columns of 5 rows is
     scannable and roughly half the height. */
}

/* ===== Category page hero ===== */
.category-hero {
  position: relative;
  padding: var(--space-7) 0 var(--space-6);
  overflow: hidden;
  border-bottom: 1px solid var(--color-border-muted);
}
.category-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 70% at 50% -20%, color-mix(in oklch, var(--card-accent) 16%, transparent) 0%, transparent 55%),
    radial-gradient(ellipse 30% 40% at 10% 100%, color-mix(in oklch, var(--card-accent) 6%, transparent) 0%, transparent 60%);
  pointer-events: none;
}
.category-hero > .container { position: relative; z-index: 1; }
.category-hero .surface-eyebrow {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--card-accent);
  margin-bottom: var(--space-4);
}
.category-hero-icon {
  width: 48px;
  height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--card-accent);
  border-radius: var(--radius-md);
  background: color-mix(in oklch, var(--card-accent) 10%, var(--color-surface));
  border: 1px solid color-mix(in oklch, var(--card-accent) 30%, var(--color-border));
  margin-bottom: var(--space-4);
}
.category-hero-icon svg { width: 28px; height: 28px; }
.category-hero .page-title {
  font-size: clamp(32px, 4.4vw, 48px);
  font-weight: 600;
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin: 0 0 var(--space-3);
  max-width: 780px;
  text-wrap: balance;
}
.category-hero .page-subtitle {
  font-size: var(--text-lg);
  color: var(--color-text-muted);
  max-width: 620px;
  margin: 0 0 var(--space-4);
  line-height: 1.55;
  text-wrap: pretty;
}
.category-hero-meta {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  flex-wrap: wrap;
}

.home-category-toolbar {
  display: flex;
  justify-content: flex-end;
  margin: calc(var(--space-3) * -1) 0 var(--space-4);
}
.home-search {
  position: relative;
  width: min(100%, 360px);
}
.home-search-label {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
}
.home-search-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 4px;
  align-items: center;
  padding: 4px;
  border: 1px solid var(--color-border-muted);
  border-radius: var(--radius-sm);
  background: var(--color-surface);
  box-shadow: 0 6px 18px rgba(0,0,0,0.18);
}
.home-search-input {
  width: 100%;
  min-height: 32px;
  border: 0;
  border-radius: calc(var(--radius-sm) - 2px);
  background: transparent;
  color: var(--color-text);
  padding: 0 10px;
  font: 500 var(--text-sm)/1.2 var(--font-sans);
}
.home-search-input::placeholder { color: var(--color-text-muted); }
.home-search-input:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 0;
}
.home-search-button {
  min-height: 32px;
  border: 1px solid var(--color-border-muted);
  border-radius: calc(var(--radius-sm) - 2px);
  background: var(--color-primary);
  color: #07101e;
  padding: 0 11px;
  font: 800 var(--text-xs)/1 var(--font-sans);
  cursor: pointer;
}
.home-search-count {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
}
.home-search-results {
  display: grid;
  position: absolute;
  right: 0;
  top: calc(100% + 8px);
  z-index: 20;
  width: min(420px, calc(100vw - 32px));
  max-height: 320px;
  overflow: auto;
  gap: 0;
  border: 1px solid var(--color-border-muted);
  border-radius: var(--radius-sm);
  background: var(--color-surface);
  box-shadow: var(--shadow-md);
}
.home-search-result {
  display: grid;
  gap: 4px;
  padding: 11px 13px;
  border-bottom: 1px solid var(--color-border-muted);
  background: var(--color-surface);
  color: var(--color-text);
  text-decoration: none;
}
.home-search-result:last-child { border-bottom: 0; }
.home-search-result:hover { background: var(--color-surface-3); }
.home-search-result:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: -2px;
}
.home-search-result-title {
  font-size: var(--text-sm);
  font-weight: 700;
}
.home-search-result-meta {
  color: var(--color-text-muted);
  font-size: var(--text-xs);
}
.home-search-empty {
  margin: 0;
  padding: 12px 14px;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}
@media (max-width: 560px) {
  .home-category-toolbar { justify-content: stretch; }
  .home-search { width: 100%; }
  .home-search-results {
    left: 0;
    right: auto;
    width: 100%;
  }
}

/* ===== Filter chips ===== */
.filter-chips {
  display: flex;
  gap: var(--space-2);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
  align-items: center;
}
.pill-sm {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background: var(--color-surface-2);
  color: var(--color-text);
  border: 1px solid var(--color-border-muted);
  border-radius: var(--radius-sm);
  padding: 8px 14px;
  font-size: var(--text-sm);
  font-family: var(--font-sans);
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  min-height: 36px;
  cursor: pointer;
  transition: background var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);
}
.pill-sm:hover { background: var(--color-surface-3); }
.pill-sm:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}
.pill-sm.is-active {
  background: var(--color-primary);
  color: #07101e;
  border-color: var(--color-primary);
}
.filter-empty {
  padding: var(--space-6) 0;
  text-align: center;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}
.card-badge-new {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--card-accent);
  font-weight: 600;
}

/* ===== Featured-in-category card ===== */
.card--featured-in-category {
  border-left: 4px solid var(--card-accent);
  background:
    linear-gradient(to bottom right, color-mix(in oklch, var(--card-accent) 8%, transparent) 0%, transparent 40%),
    var(--color-surface);
}
.card--featured-in-category .card-header-strip { height: 80px; }
.card--featured-in-category .card-title { font-size: 22px; }

/* ===== Related categories grid (compact) ===== */
.grid-related {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-4);
}
@media (max-width: 1023px) {
  .grid-related { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 719px) {
  .grid-related { grid-template-columns: 1fr; }
}
.category-card--compact { min-height: 120px; }
.category-card--compact .category-card-header-strip { height: 40px; }
.category-card--compact .category-card-body {
  padding: var(--space-4) var(--space-5);
  gap: var(--space-1);
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
}
.category-card--compact .category-card-body h3 { font-size: var(--text-lg); margin: 0; }

/* ===== Reduced motion ===== */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  .pp-line { stroke-dashoffset: 0; }
  .pp-dot { opacity: 1; }
  .pp-timer-arc { stroke-dashoffset: 80; }
}

/* ===== Mobile fine-tuning ===== */
@media (max-width: 479px) {
  .surface-hero { padding: var(--space-6) 0 var(--space-5); }
  .surface-section { padding: var(--space-6) 0; }
  .hero-v5-1-title { font-size: 32px; }
  .surface-section-heading h2 { font-size: 24px; }
  .recent-list { padding-left: var(--space-5); }
  .pick-card-strip { padding: var(--space-3) var(--space-4); height: auto; flex-wrap: wrap; gap: var(--space-2); }
  .pick-card-strip-meta { font-size: 10px; }
  .pick-meta { padding: var(--space-4); }
  .pick-card-title { font-size: 22px; }
  .pick-card-icon { width: 44px; height: 44px; }
  .pick-card-icon svg { width: 22px; height: 22px; }
}
