/* Routinova Edge - editorial design system (ported 1:1 from the Figma Make
   "Redesign News Page"). Fonts: Playfair Display (display), Inter (body),
   DM Mono (labels/meta). Zero-JS SSR: interactive bits are links/forms. */

:root {
  --bg: #f8f8f6;
  --ink: #111111;
  --card: #ffffff;
  --secondary: #f0f0ee;
  --muted: #e8e8e6;
  --muted-fg: #666660;
  --accent: #d9291b;
  --accent-fg: #ffffff;
  --border: rgba(0, 0, 0, 0.08);
  --border-strong: rgba(0, 0, 0, 0.16);
  --radius: 0;
  --radius-control: 4px;
  --maxw: 1280px;
  --serif: "Playfair Display", Georgia, "Times New Roman", serif;
  --sans: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --mono: "DM Mono", ui-monospace, "SF Mono", Menlo, monospace;
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--sans);
  background: var(--bg);
  color: var(--ink);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
svg { flex: none; }
.mono { font-family: var(--mono); }

.container { max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }
@media (max-width: 640px) { .container { padding: 0 16px; } }

.skip-link { position: absolute; left: -999px; }
.skip-link:focus { left: 12px; top: 12px; z-index: 100; background: var(--ink); color: #fff; padding: 8px 14px; }

/* 2-line clamp used across cards */
.post-card__title, .post-card__excerpt, .pick-card__title,
.trending__title, .saved__title, .hero-excerpt {
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}

/* ---------- Section head (icon + mono label + rule + see-all) ---------- */
.sect-head { display: flex; align-items: center; gap: 12px; margin: 0 0 20px; color: var(--ink); }
.sect-head__icon { color: var(--ink); }
.sect-head__icon.is-accent, .is-accent { color: var(--accent); }
.sect-head__label {
  font-family: var(--mono); font-size: 10px; font-weight: 500;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted-fg);
}
.sect-head__line { flex: 1; height: 1px; background: var(--border); }
.sect-head__more {
  display: inline-flex; align-items: center; gap: 4px;
  font-family: var(--mono); font-size: 10px; color: var(--muted-fg); white-space: nowrap;
}
.sect-head__more:hover { color: var(--ink); }

/* Legacy eyebrow (list pages) */
.eyebrow { display: flex; align-items: center; gap: 12px; margin: 0 0 22px; }
.eyebrow__text {
  font-family: var(--mono); font-size: 12px; font-weight: 500;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted-fg);
}
.eyebrow__mark { width: 12px; height: 12px; background: var(--accent); flex: none; }
.eyebrow__line { flex: 1; height: 1px; background: var(--border); }

/* ---------- Top strip ---------- */
.topbar { background: var(--ink); color: #fff; border-bottom: 1px solid rgba(255, 255, 255, 0.2); }
.topbar__inner {
  max-width: var(--maxw); margin: 0 auto; padding: 0 24px; height: 32px;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
}
.topbar__left { display: flex; align-items: center; gap: 16px; min-width: 0; overflow: hidden; flex: 1; }
.topbar__breaking { overflow: hidden; }
.topbar__date {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em;
  text-transform: uppercase; color: rgba(255, 255, 255, 0.5); white-space: nowrap;
}
.topbar__sep { color: rgba(255, 255, 255, 0.2); font-size: 11px; }
.topbar__breaking {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--accent); white-space: nowrap;
}
.topbar__pulse {
  width: 6px; height: 6px; border-radius: 50%; background: var(--accent); flex: none;
  animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}
@keyframes pulse { 50% { opacity: 0.4; } }
.topbar__links { display: flex; gap: 16px; flex: none; }
.topbar__links a {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em;
  text-transform: uppercase; color: rgba(255, 255, 255, 0.5);
}
.topbar__links a:hover { color: #fff; }
@media (max-width: 640px) {
  .topbar__inner { padding: 0 16px; }
  .topbar__links { display: none; }
}

/* ---------- Header ---------- */
.site-header {
  position: sticky; top: 0; z-index: 50; background: var(--card);
  border-bottom: 1px solid var(--border);
}
.site-header__inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; height: 56px;
}
/* Brand lockup (Orbit + Nova mark, brand guidelines v1.0):
   wordmark = 0.78 x mark size, gap 10px, arc follows currentColor. */
.site-logo { display: inline-flex; align-items: center; gap: 10px; color: var(--ink); flex: none; }
.site-logo svg { flex: none; }
.site-logo__word {
  font-family: var(--serif); font-weight: 900; font-size: 20px;
  letter-spacing: -0.025em; line-height: 1; color: var(--ink);
}
.site-nav {
  display: flex; align-items: center; justify-content: center; gap: 20px;
  flex: 1; min-width: 0; overflow-x: auto; scrollbar-width: none;
}
.site-nav::-webkit-scrollbar { display: none; }
.site-nav a {
  font-family: var(--mono); font-size: 11px; font-weight: 500;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted-fg);
  white-space: nowrap; padding: 2px 0; border-bottom: 2px solid transparent;
}
.site-nav a:hover { color: var(--ink); }
.site-nav a.is-active { color: var(--ink); border-bottom-color: var(--accent); }
.site-actions { display: flex; align-items: center; gap: 8px; flex: none; }

/* Zero-JS expanding search: icon only, grows on focus */
.site-search { display: flex; align-items: center; border-radius: var(--radius-control); }
.site-search__icon {
  display: flex; align-items: center; justify-content: center;
  padding: 8px; color: var(--muted-fg); cursor: pointer;
}
.site-search__icon:hover { color: var(--ink); }
.site-search input {
  width: 0; padding: 0; border: 0; opacity: 0; background: transparent;
  font-family: var(--mono); font-size: 13px; color: var(--ink);
  transition: width 0.2s ease, opacity 0.2s ease;
}
.site-search input::placeholder { color: var(--muted-fg); }
.site-search input:focus { outline: none; }
.site-search:focus-within { background: var(--secondary); }
.site-search:focus-within input,
.site-search input:not(:placeholder-shown) { width: 144px; opacity: 1; padding-right: 12px; }

.btn-subscribe {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--mono); font-size: 11px; font-weight: 500; letter-spacing: 0.06em;
  background: var(--accent); color: var(--accent-fg); border: 0;
  padding: 7px 12px; border-radius: var(--radius-control); cursor: pointer; white-space: nowrap;
}
.btn-subscribe:hover { background: #c01f12; }
@media (max-width: 640px) { .btn-subscribe { display: none; } }

/* Zero-JS mobile menu (checkbox hack) */
.nav-toggle { position: absolute; width: 1px; height: 1px; opacity: 0; pointer-events: none; }
.nav-burger {
  display: none; align-items: center; justify-content: center;
  padding: 8px; color: var(--muted-fg); cursor: pointer;
}
.nav-burger:hover { color: var(--ink); }
.nav-burger__open, .nav-burger__close { display: flex; }
.nav-burger__close { display: none; }
#nav-toggle:checked ~ .site-header__inner .nav-burger__open { display: none; }
#nav-toggle:checked ~ .site-header__inner .nav-burger__close { display: flex; }
.mobile-nav { display: none; }
@media (max-width: 767px) {
  .site-nav { display: none; }
  .nav-burger { display: flex; }
  #nav-toggle:checked ~ .mobile-nav {
    display: flex; flex-wrap: wrap; gap: 8px;
    padding-top: 12px; padding-bottom: 16px;
    border-top: 1px solid var(--border);
  }
  .mobile-nav .pill { padding: 6px 12px; letter-spacing: 0.12em; }
}

/* ---------- Main ---------- */
.site-main { padding-top: 32px; padding-bottom: 8px; min-height: 50vh; }
.home-sect { margin-bottom: 48px; }

/* ---------- Category tag / pill ---------- */
.cat-tag {
  font-family: var(--mono); font-weight: 500; font-size: 10px;
  letter-spacing: 0.16em; text-transform: uppercase;
}
.cat-tag--xs { font-size: 10px; }
.cat-pill {
  display: inline-block; font-family: var(--mono); font-weight: 500; font-size: 10px;
  letter-spacing: 0.14em; text-transform: uppercase;
  padding: 2px 8px; border-radius: 999px;
}

/* ---------- Meta bits ---------- */
.meta-sep { width: 3px; height: 3px; border-radius: 50%; background: rgba(0, 0, 0, 0.28); display: inline-block; flex: none; }
.meta-time, .meta-views { display: inline-flex; align-items: center; gap: 5px; white-space: nowrap; }
.avatar {
  width: 24px; height: 24px; border-radius: 50%; background: var(--secondary);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 9px; font-weight: 700; color: var(--ink); flex: none; letter-spacing: 0.02em;
}
.avatar--light { background: rgba(255, 255, 255, 0.2); color: #fff; }
.bookmark { display: inline-flex; padding: 4px; color: var(--muted-fg); }

/* ---------- Hero (featured stories) ---------- */
.hero { display: grid; grid-template-columns: 3fr 2fr; gap: 20px; }

.hero-main { position: relative; }
.hero-main__media {
  display: block; position: relative; overflow: hidden; border-radius: var(--radius);
  height: 420px; background: var(--muted);
}
.hero-main__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.7s ease; }
.hero-main:hover .hero-main__media img { transform: scale(1.05); }
.hero-main__media::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.85) 0%, rgba(0, 0, 0, 0.25) 50%, transparent 100%);
}
.hero-main__pill { position: absolute; top: 16px; left: 16px; z-index: 2; }
.hero-main__body { position: absolute; left: 0; right: 0; bottom: 0; padding: 24px; z-index: 1; }
.hero-title {
  font-family: var(--serif); font-weight: 700; color: #fff;
  font-size: 24px; line-height: 1.25; letter-spacing: -0.01em; margin: 0;
}
.hero-title a { color: #fff; }
.hero-excerpt { color: rgba(255, 255, 255, 0.7); font-size: 13px; line-height: 1.6; margin: 8px 0 0; }
.hero-meta {
  display: flex; align-items: center; gap: 10px; margin-top: 12px;
  color: rgba(255, 255, 255, 0.7); font-size: 12px;
}
.hero-meta .meta-sep { background: rgba(255, 255, 255, 0.3); }
.hero-meta .meta-time, .hero-meta .meta-views { color: rgba(255, 255, 255, 0.6); }
.hero-meta .meta-time svg, .hero-meta .meta-views svg { color: rgba(255, 255, 255, 0.5); }
.hero-meta .mono { font-size: 12px; }
.hero-share {
  margin-left: auto; display: inline-flex; padding: 6px;
  background: rgba(255, 255, 255, 0.1); border-radius: var(--radius-control); color: #fff;
}
.hero-share:hover { background: rgba(255, 255, 255, 0.2); }

/* Secondary featured: 2 stacked overlay cards, same total height as hero */
.hero-secondary { display: grid; grid-template-rows: 1fr 1fr; gap: 20px; height: 420px; }
.hero-sub { position: relative; overflow: hidden; border-radius: var(--radius); background: var(--muted); }
.hero-sub__media { display: block; position: absolute; inset: 0; }
.hero-sub__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.hero-sub:hover .hero-sub__media img { transform: scale(1.05); }
.hero-sub__media::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0.1) 50%, transparent 100%);
}
.hero-sub__pill { position: absolute; top: 12px; left: 12px; z-index: 2; }
.hero-sub__body { position: absolute; left: 0; right: 0; bottom: 0; padding: 16px; z-index: 1; }
.hero-sub__title { font-family: var(--serif); font-weight: 700; font-size: 15px; line-height: 1.375; margin: 0; }
.hero-sub__title a { color: #fff; }
.hero-sub__meta {
  display: flex; align-items: center; gap: 8px; margin-top: 8px;
  color: rgba(255, 255, 255, 0.6); font-size: 11px;
}
.hero-sub__meta .meta-sep { background: rgba(255, 255, 255, 0.3); }
.hero-sub__meta svg { color: rgba(255, 255, 255, 0.5); }
.hero-sub__meta .mono { font-size: 11px; }

/* ---------- Editor's picks ---------- */
.picks-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.pick-card__media {
  display: block; overflow: hidden; border-radius: var(--radius);
  aspect-ratio: 4 / 3; background: var(--muted);
}
.pick-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.pick-card:hover .pick-card__media img { transform: scale(1.05); }
.pick-card__body { margin-top: 10px; }
.pick-card__title { font-family: var(--serif); font-weight: 700; font-size: 13px; line-height: 1.375; margin: 4px 0 0; }
.pick-card:hover .pick-card__title { color: var(--accent); }
.pick-card__meta {
  display: flex; align-items: center; gap: 6px; margin-top: 6px;
  color: var(--muted-fg); font-size: 11px;
}
.pick-card__meta .mono { font-size: 11px; }

/* ---------- Content + sidebar ---------- */
.layout-cols { display: grid; grid-template-columns: 1fr 300px; gap: 40px; }
.layout-cols > * { min-width: 0; }

.list-head { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 24px; }
.list-head .sect-head { margin-bottom: 0; }

.filter-pills { display: flex; gap: 6px; overflow-x: auto; scrollbar-width: none; padding-bottom: 2px; min-width: 0; }
.filter-pills::-webkit-scrollbar { display: none; }
.pill {
  font-family: var(--mono); font-size: 10px; font-weight: 500; letter-spacing: 0.08em;
  border: 1px solid var(--border); border-radius: 999px; padding: 4px 10px;
  color: var(--muted-fg); white-space: nowrap;
}
.pill:hover { border-color: var(--ink); color: var(--ink); }
.pill.is-active { background: var(--ink); color: #fff; border-color: var(--ink); }

/* ---------- Post cards (Latest grid, list pages) ---------- */
.post-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 32px 24px; }
.post-card { display: flex; flex-direction: column; }
.post-card__media {
  display: block; overflow: hidden; border-radius: var(--radius);
  aspect-ratio: 4 / 3; background: var(--muted);
}
.post-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.post-card:hover .post-card__media img { transform: scale(1.05); }
.post-card__body { margin-top: 12px; display: flex; flex-direction: column; flex: 1; }
.post-card__title { font-family: var(--serif); font-weight: 700; font-size: 15px; line-height: 1.375; margin: 6px 0 0; }
.post-card:hover .post-card__title { color: var(--accent); }
.post-card__excerpt { color: var(--muted-fg); font-size: 13px; line-height: 1.6; margin: 6px 0 0; flex: 1; }
.post-card__foot {
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
  margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--border);
}
.post-card__meta { display: flex; align-items: center; gap: 10px; min-width: 0; color: var(--muted-fg); }
.post-card__author { font-size: 11px; font-weight: 500; color: var(--muted-fg); white-space: nowrap; }
.post-card__meta .meta-time svg { color: var(--muted-fg); }
.post-card__meta .mono { font-size: 11px; }
.post-card__stats { display: flex; align-items: center; gap: 6px; color: var(--muted-fg); }
.post-card__stats .mono { font-size: 10px; }

.list-page .post-grid { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 960px) { .list-page .post-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .list-page .post-grid { grid-template-columns: 1fr; } }

.empty {
  text-align: center; padding: 80px 0; color: var(--muted-fg);
  border: 1px dashed var(--border); border-radius: var(--radius);
  font-family: var(--mono); font-size: 14px;
}

.btn-row { display: flex; justify-content: center; margin-top: 32px; }
.btn-outline {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--mono); font-size: 12px; font-weight: 500; letter-spacing: 0.04em;
  border: 1px solid var(--border); border-radius: var(--radius); padding: 10px 24px;
  color: var(--muted-fg); background: transparent; cursor: pointer;
}
.btn-outline:hover { border-color: var(--ink); color: var(--ink); }

/* ---------- Sidebar ---------- */
.sidebar { display: flex; flex-direction: column; gap: 32px; }
.sidebar .sect-head { margin-bottom: 16px; }
.sidebar__divider { height: 1px; background: var(--border); }

.trending__item { display: flex; gap: 12px; padding: 12px 0; border-top: 1px solid var(--border); }
.trending__item:first-child { border-top: 0; padding-top: 0; }
.trending__num {
  font-family: var(--serif); font-weight: 900; font-size: 20px; line-height: 1;
  color: rgba(0, 0, 0, 0.2); width: 24px; flex: none; margin-top: 2px;
  font-variant-numeric: tabular-nums;
}
.trending__title { font-family: var(--serif); font-size: 13px; font-weight: 600; line-height: 1.375; margin: 2px 0 0; }
.trending__item:hover .trending__title { color: var(--accent); }
.trending__meta { display: flex; align-items: center; gap: 8px; margin-top: 4px; color: var(--muted-fg); }
.trending__meta .mono { font-size: 10px; }

.topics { display: flex; flex-wrap: wrap; gap: 8px; }
.topic-btn {
  font-family: var(--mono); font-size: 11px; border: 1px solid var(--border);
  border-radius: var(--radius); padding: 4px 10px; color: var(--muted-fg);
}
.topic-btn:hover { background: var(--ink); color: #fff; border-color: var(--ink); }

/* Dark newsletter card */
.news-card { background: var(--ink); border-radius: var(--radius); padding: 20px; }
.news-card__eyebrow {
  display: flex; align-items: center; gap: 8px; margin-bottom: 12px;
  font-family: var(--mono); font-size: 10px; font-weight: 500; letter-spacing: 0.18em;
  text-transform: uppercase; color: rgba(255, 255, 255, 0.5);
}
.news-card__title { font-family: var(--serif); font-weight: 700; font-size: 17px; line-height: 1.375; color: #fff; margin: 0; }
.news-card__text { font-size: 12px; color: rgba(255, 255, 255, 0.55); margin: 8px 0 0; line-height: 1.6; }
.news-card__form { display: flex; flex-direction: column; gap: 8px; margin-top: 16px; }
.news-card__form input {
  font-family: var(--mono); font-size: 12px; background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.1); border-radius: var(--radius);
  padding: 8px 12px; color: #fff;
}
.news-card__form input::placeholder { color: rgba(255, 255, 255, 0.3); }
.news-card__form input:focus { outline: none; border-color: var(--accent); }
.news-card__form button {
  font-family: var(--mono); font-size: 11px; font-weight: 500; letter-spacing: 0.14em;
  text-transform: uppercase; background: var(--accent); color: #fff; border: 0;
  border-radius: var(--radius); padding: 8px; cursor: pointer;
}
.news-card__form button:hover { background: #c01f12; }

/* Most saved */
.saved { display: flex; flex-direction: column; gap: 12px; }
.saved__item { display: flex; gap: 12px; }
.saved__thumb { width: 56px; height: 56px; flex: none; overflow: hidden; border-radius: var(--radius); background: var(--muted); }
.saved__thumb img { width: 100%; height: 100%; object-fit: cover; }
.saved__title { font-size: 12px; font-weight: 600; line-height: 1.375; margin: 2px 0 0; }
.saved__item:hover .saved__title { color: var(--accent); }
.saved__meta { display: flex; align-items: center; gap: 4px; margin-top: 4px; color: var(--muted-fg); }
.saved__meta .mono { font-size: 10px; }

/* ---------- List/index pages ---------- */
.page-header { margin-bottom: 28px; max-width: 720px; }
.page-header h1 { font-family: var(--serif); font-weight: 800; font-size: 38px; line-height: 1.1; letter-spacing: -0.02em; margin: 8px 0 0; }
.page-header p { color: var(--muted-fg); margin: 12px 0 0; }
.author-header { display: flex; gap: 20px; align-items: center; }
.author-avatar { width: 88px; height: 88px; border-radius: 50%; object-fit: cover; flex: none; }

/* ---------- Breadcrumb ---------- */
.breadcrumb { margin: 0 0 22px; }
.breadcrumb ol { list-style: none; display: flex; flex-wrap: wrap; gap: 8px; padding: 0; margin: 0; font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted-fg); }
.breadcrumb a:hover { color: var(--accent); }
.breadcrumb li:not(:last-child)::after { content: "/"; margin-left: 8px; color: rgba(0, 0, 0, 0.25); }
.breadcrumb [aria-current="page"] { color: var(--ink); }
@media (max-width: 400px) { .breadcrumb { display: none; } }

/* ---------- Pagination ---------- */
.pagination { display: flex; align-items: center; justify-content: center; gap: 20px; margin: 40px 0 0; }
.pagination a { font-family: var(--mono); font-size: 13px; font-weight: 500; border: 1px solid var(--border); border-radius: var(--radius); padding: 8px 16px; }
.pagination a:hover { border-color: var(--ink); }
.pagination__status { font-family: var(--mono); font-size: 12px; color: var(--muted-fg); }

/* ---------- Article detail (Figma detail page) ---------- */
.site-main--bare { padding-top: 0; padding-bottom: 0; }

/* Reading progress: thin accent bar pinned under the stuck header.
   CSS scroll-driven; hidden where scroll timelines are unsupported. */
.read-progress {
  position: fixed; top: 54px; left: 0; height: 2px; width: 100%;
  background: var(--accent); z-index: 60;
  transform: scaleX(0); transform-origin: 0 50%;
  display: none;
}
@supports (animation-timeline: scroll()) {
  .read-progress { display: block; animation: progress-grow linear both; animation-timeline: scroll(root); }
}
@keyframes progress-grow { from { transform: scaleX(0); } to { transform: scaleX(1); } }

/* Hero */
.detail-hero { position: relative; width: 100%; background: var(--ink); overflow: hidden; height: clamp(380px, 55vw, 580px); }
.detail-hero__img { width: 100%; height: 100%; object-fit: cover; opacity: 1; }
.detail-hero__scrim { position: absolute; inset: 0; background: linear-gradient(to top, rgba(17, 17, 17, 0.8) 0%, rgba(17, 17, 17, 0.42) 34%, rgba(17, 17, 17, 0) 68%); }
.detail-hero__inner { position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: flex-end; }
.detail-hero__body { max-width: 896px; margin: 0 auto; padding: 0 24px 40px; width: 100%; }
.detail-crumb { display: flex; align-items: center; gap: 6px; margin-bottom: 16px; color: rgba(255, 255, 255, 0.3); }
.detail-crumb a { font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(255, 255, 255, 0.5); }
.detail-crumb a:hover { color: #fff; }
.detail-crumb a.detail-crumb__cat { color: var(--accent); }
.detail-title { font-family: var(--serif); font-weight: 700; color: #fff; font-size: clamp(24px, 3.5vw, 36px); line-height: 1.25; margin: 12px 0 0; max-width: 768px; }
.detail-title a { color: #fff; }
.detail-excerpt { color: rgba(255, 255, 255, 0.65); font-size: 14px; line-height: 1.6; margin: 12px 0 0; max-width: 672px; }
.detail-meta { display: flex; flex-wrap: wrap; align-items: center; gap: 12px; margin-top: 20px; color: rgba(255, 255, 255, 0.6); font-size: 12px; }
.detail-meta__avatar { width: 32px; height: 32px; border-radius: 50%; object-fit: cover; border: 1px solid rgba(255, 255, 255, 0.2); }
.detail-meta__who { display: flex; flex-direction: column; gap: 3px; }
.detail-meta__name { color: #fff; font-size: 13px; font-weight: 600; line-height: 1; }
.detail-meta__role { color: rgba(255, 255, 255, 0.5); font-family: var(--mono); font-size: 10px; line-height: 1; }
.detail-meta__bar { width: 1px; height: 16px; background: rgba(255, 255, 255, 0.2); margin: 0 4px; }
.detail-meta .meta-time svg, .detail-meta .meta-views svg { color: rgba(255, 255, 255, 0.5); }
.detail-meta .mono { font-size: 12px; }
.detail-meta__date { margin-left: auto; color: rgba(255, 255, 255, 0.4); font-size: 11px; }
@media (max-width: 640px) {
  .detail-hero__body { padding: 0 16px 32px; }
  .detail-excerpt, .detail-meta__date, .detail-meta__bar { display: none; }
}

/* Sticky action bar */
.action-bar { position: sticky; top: 56px; z-index: 40; background: var(--card); border-bottom: 1px solid var(--border); }
.action-bar__inner { max-width: 896px; margin: 0 auto; padding: 0 24px; height: 44px; display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.action-bar__group { display: flex; align-items: center; gap: 4px; }
.action-btn { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; border-radius: var(--radius-control); font-family: var(--mono); font-size: 11px; font-weight: 500; color: var(--muted-fg); white-space: nowrap; }
.action-btn:hover { color: var(--ink); }
.action-btn--icon { padding: 6px; }
@media (max-width: 640px) { .action-bar__inner { padding: 0 16px; } .action-btn--icon { display: none; } }

/* 3-column layout */
.detail-grid { display: grid; grid-template-columns: 220px 1fr 260px; gap: 40px; padding-top: 40px; padding-bottom: 40px; }
.detail-grid > * { min-width: 0; }
.detail-toc__sticky { position: sticky; top: 128px; }
.detail-side__sticky { position: sticky; top: 128px; display: flex; flex-direction: column; gap: 32px; }
@media (max-width: 1024px) {
  .detail-grid { grid-template-columns: 1fr; }
  .detail-toc, .detail-side { display: none; }
}

.side-head { display: flex; align-items: center; gap: 8px; margin-bottom: 14px; color: var(--muted-fg); }
.side-head span, .side-head__label {
  font-family: var(--mono); font-size: 10px; font-weight: 500;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted-fg);
}

/* Table of contents */
.toc__list { display: flex; flex-direction: column; gap: 2px; }
.toc__link { display: block; padding: 8px 12px; font-size: 12px; line-height: 1.4; color: var(--muted-fg); border-left: 2px solid transparent; }
.toc__link:hover { color: var(--ink); border-left-color: var(--border-strong); }
.toc__tags { margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--border); }
.tag-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.tag-chip { display: inline-block; padding: 2px 8px; background: var(--secondary); color: var(--ink); font-family: var(--mono); font-size: 10px; border: 1px solid var(--border); border-radius: 2px; }
.tag-chip:hover { background: var(--muted); }

/* Mobile ToC + tags */
.toc-mobile { display: none; margin-bottom: 32px; background: var(--secondary); border: 1px solid var(--border); border-radius: 2px; }
.toc-mobile summary {
  display: flex; align-items: center; gap: 8px; padding: 12px 16px; cursor: pointer; list-style: none;
  font-family: var(--mono); font-size: 11px; font-weight: 500; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted-fg);
}
.toc-mobile summary::-webkit-details-marker { display: none; }
.toc-mobile__list { padding: 0 16px 16px; }
.toc-mobile .toc__link { padding: 6px 0; border-left: 0; }
.detail-tags-mobile { display: none; margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--border); }
.detail-tags-mobile .tag-chip { padding: 4px 10px; font-size: 11px; }
@media (max-width: 1024px) {
  .toc-mobile { display: block; }
  .detail-tags-mobile { display: flex; }
}

/* Body typography */
.article__body { font-size: 15px; line-height: 1.7; }
.article__body h2 {
  font-family: var(--serif); font-weight: 700; font-size: clamp(20px, 2.2vw, 24px);
  line-height: 1.375; letter-spacing: -0.01em; margin: 2.4em 0 0.9em; scroll-margin-top: 128px;
}
.article__body h2:first-child { margin-top: 0; }
.article__body h3 { font-weight: 700; font-size: 18px; margin: 1.6em 0 0.5em; }
.article__body p { margin: 0 0 1.1em; }
.article__body > p:first-of-type,
.article__body > h2:first-child + p { font-size: 16px; }
.article__body > p:first-of-type::first-letter,
.article__body > h2:first-child + p::first-letter {
  font-weight: 900; float: left; font-size: 48px; line-height: 0.85; padding: 5px 8px 0 0; color: var(--ink);
}
.article__body a { color: var(--accent); text-decoration: underline; text-underline-offset: 2px; }
.article__body strong { font-weight: 600; }
.article__body figure { margin: 32px 0; }
.article__body figure img { width: 100%; border-radius: 2px; object-fit: cover; height: clamp(200px, 35vw, 340px); background: var(--muted); }
.article__body figcaption { margin-top: 10px; font-family: var(--mono); font-size: 11px; color: var(--muted-fg); text-align: center; }
.article__body blockquote { margin: 32px 0; padding: 20px 24px; border-left: 4px solid var(--accent); background: var(--secondary); border-radius: 2px; }
.article__body blockquote p { font-family: var(--serif); font-size: clamp(18px, 2vw, 20px); font-weight: 700; font-style: italic; line-height: 1.4; margin: 0; color: var(--ink); }
.article__body blockquote cite { display: block; margin-top: 12px; font-family: var(--mono); font-size: 11px; font-style: normal; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted-fg); }

/* Key takeaways (dark card emitted by the content pipeline) */
.takeaways { margin: 32px 0 0; background: var(--ink); border-radius: 2px; padding: 24px; }
.takeaways h3 { font-family: var(--mono); font-size: 11px; font-weight: 500; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(255, 255, 255, 0.5); margin: 0 0 16px; }
.takeaways ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.takeaways li { position: relative; padding-left: 32px; font-size: 13px; line-height: 1.6; color: rgba(255, 255, 255, 0.8); }
.takeaways li::before {
  content: ""; position: absolute; left: 0; top: 1px; width: 20px; height: 20px; border-radius: 50%;
  background: var(--accent) url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="white" stroke-width="3" stroke-linecap="round" stroke-linejoin="round"><path d="M20 6 9 17l-5-5"/></svg>') center / 10px no-repeat;
}

/* Share row */
.share-row { margin-top: 40px; padding-top: 32px; border-top: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 16px; }
.share-row__label { font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted-fg); }
.share-row__btns { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.share-btn { display: inline-flex; align-items: center; gap: 6px; padding: 8px 12px; border: 1px solid var(--border); border-radius: 2px; font-family: var(--mono); font-size: 11px; color: var(--muted-fg); }
.share-btn:hover { color: var(--ink); border-color: var(--ink); }

/* Author card */
.author-card { margin-top: 40px; padding: 24px; background: var(--card); border: 1px solid var(--border); border-radius: 2px; display: flex; gap: 16px; }
.author-card__avatar { width: 56px; height: 56px; border-radius: 50%; object-fit: cover; flex: none; background: var(--muted); }
.author-card__main { flex: 1; min-width: 0; }
.author-card__top { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; flex-wrap: wrap; }
.author-card__top .side-head { margin-bottom: 0; }
.author-card__name { font-family: var(--serif); font-weight: 700; font-size: 16px; margin: 4px 0 2px; }
.author-card__role { font-size: 11px; color: var(--muted-fg); }
.follow-btn { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; background: var(--ink); color: #fff; font-family: var(--mono); font-size: 11px; font-weight: 500; border-radius: var(--radius-control); }
.follow-btn:hover { background: #333; }
.author-card__bio { margin: 12px 0 0; font-size: 13px; line-height: 1.6; color: var(--muted-fg); }
.author-card__stats { display: flex; align-items: center; gap: 12px; margin-top: 12px; font-size: 11px; color: var(--muted-fg); }

/* Comments (mock until Phase 3) */
.comments { margin-top: 48px; }
.comments .sect-head { margin-bottom: 24px; }
.c-avatar { width: 32px; height: 32px; border-radius: 50%; background: var(--secondary); border: 1px solid var(--border); display: inline-flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 700; color: var(--ink); flex: none; }
.c-avatar--dark { width: 28px; height: 28px; background: var(--ink); border: 0; color: #fff; }
.comment-form { margin-bottom: 32px; background: var(--card); border: 1px solid var(--border); border-radius: 2px; padding: 16px; }
.comment-form__head { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; font-size: 12px; font-weight: 600; }
.comment-form textarea { width: 100%; background: var(--secondary); color: var(--ink); font-family: var(--sans); font-size: 13px; line-height: 1.6; padding: 8px 12px; border: 1px solid var(--border); border-radius: 2px; resize: none; }
.comment-form textarea::placeholder { color: var(--muted-fg); }
.comment-form__foot { display: flex; justify-content: flex-end; margin-top: 8px; }
.comment-form button { padding: 6px 16px; background: var(--ink); color: #fff; border: 0; border-radius: var(--radius-control); font-family: var(--mono); font-size: 11px; font-weight: 500; }
.comment-form button:disabled { opacity: 0.4; cursor: not-allowed; }
.comment-list { display: flex; flex-direction: column; gap: 20px; }
.comment { display: flex; gap: 12px; }
.comment .c-avatar { margin-top: 2px; }
.comment__main { flex: 1; min-width: 0; }
.comment__head { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.comment__author { font-size: 13px; font-weight: 600; }
.comment__date { font-size: 10px; color: var(--muted-fg); }
.comment__text { margin: 6px 0 0; font-size: 13px; line-height: 1.6; }
.comment__actions { display: flex; align-items: center; gap: 16px; margin-top: 8px; font-size: 11px; color: var(--muted-fg); }
.comment__like { display: inline-flex; align-items: center; gap: 4px; }

/* Right sidebar */
.progress-card { background: var(--card); border: 1px solid var(--border); border-radius: 2px; padding: 16px; }
.progress-card__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.progress-card__track { width: 100%; height: 6px; background: var(--muted); border-radius: 999px; overflow: hidden; }
.progress-card__fill { height: 100%; background: var(--accent); border-radius: 999px; transform: scaleX(0); transform-origin: 0 50%; }
@supports (animation-timeline: scroll()) {
  .progress-card__fill { animation: progress-grow linear both; animation-timeline: scroll(root); }
}
.progress-card__time { display: flex; align-items: center; gap: 8px; margin-top: 10px; color: var(--muted-fg); }
.progress-card__time .mono { font-size: 11px; }
.news-card--mini > svg { margin-bottom: 8px; }
.news-card--mini .news-card__title { font-size: 15px; }
.news-card--mini .news-card__text { font-size: 11px; }
.side-trending { display: flex; flex-direction: column; gap: 16px; }
.side-trending__item { display: flex; gap: 12px; }
.side-trending__num { font-family: var(--serif); font-weight: 900; font-size: 18px; line-height: 1; color: rgba(0, 0, 0, 0.2); width: 20px; flex: none; margin-top: 2px; font-variant-numeric: tabular-nums; }
.side-trending__title { font-family: var(--serif); font-size: 12px; font-weight: 600; line-height: 1.375; margin: 2px 0 0; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.side-trending__item:hover .side-trending__title { color: var(--accent); }
.side-trending__meta { display: flex; align-items: center; gap: 6px; margin-top: 4px; color: var(--muted-fg); }
.side-trending__meta .mono { font-size: 10px; }

/* You might also like */
.related-band { border-top: 1px solid var(--border); background: var(--card); margin-top: 48px; }
.related-band .container { padding-top: 48px; padding-bottom: 48px; }
.related-band .sect-head { margin-bottom: 32px; }
.rel-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.rel-card__media { display: block; overflow: hidden; border-radius: 2px; aspect-ratio: 16 / 10; background: var(--muted); }
.rel-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.rel-card:hover .rel-card__media img { transform: scale(1.05); }
.rel-card__body { margin-top: 12px; }
.rel-card__title { font-family: var(--serif); font-weight: 700; font-size: 15px; line-height: 1.375; margin: 6px 0 0; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.rel-card:hover .rel-card__title { color: var(--accent); }
.rel-card__excerpt { margin: 6px 0 0; font-size: 12px; line-height: 1.6; color: var(--muted-fg); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.rel-card__meta { display: flex; align-items: center; gap: 8px; margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--border); font-size: 11px; color: var(--muted-fg); }
.rel-card__meta .mono { font-size: 11px; }
.rel-card__views { margin-left: auto; }
.rel-card__views .mono { font-size: 10px; }
@media (max-width: 640px) { .rel-grid { grid-template-columns: 1fr; } }

/* ---------- Category page (Figma category design) ---------- */
.cat-hero { position: relative; overflow: hidden; background: var(--ink); height: clamp(280px, 38vw, 400px); }
.cat-hero__img { width: 100%; height: 100%; object-fit: cover; opacity: 0.3; }
.cat-hero__scrim { position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(17, 17, 17, 0.4) 0%, rgba(17, 17, 17, 0.6) 50%, rgba(17, 17, 17, 0.95) 100%); }
.cat-hero__initial {
  position: absolute; right: 0; top: 0; bottom: 0; width: 33%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--serif); font-weight: 900; font-size: 280px; line-height: 1;
  color: rgba(255, 255, 255, 0.05); pointer-events: none; user-select: none;
}
.cat-hero__inner { position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: flex-end; }
.cat-hero__body { padding-bottom: 40px; width: 100%; }
.cat-hero__crumb { margin-bottom: 20px; }
.cat-hero__crumb a, .cat-hero__crumb-topics, .cat-hero__crumb-cat {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase;
}
.cat-hero__crumb a { color: rgba(255, 255, 255, 0.4); }
.cat-hero__crumb a:hover { color: rgba(255, 255, 255, 0.7); }
.cat-hero__crumb-topics { color: rgba(255, 255, 255, 0.7); }
.cat-hero__crumb-cat { font-weight: 500; }
.cat-hero__row { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; }
.cat-stripe { display: block; width: 32px; height: 4px; border-radius: 999px; margin-bottom: 12px; }
.cat-stripe--sm { width: 24px; margin-bottom: 0; }
.cat-hero__title { font-family: var(--serif); font-weight: 900; color: #fff; font-size: clamp(30px, 3.5vw, 36px); line-height: 1; margin: 0; }
.cat-hero__desc { margin: 8px 0 0; color: rgba(255, 255, 255, 0.6); font-size: 14px; line-height: 1.6; max-width: 576px; }
.cat-hero__stats { display: flex; align-items: center; gap: 24px; margin-top: 20px; flex-wrap: wrap; }
.cat-stat { display: inline-flex; align-items: center; gap: 8px; color: rgba(255, 255, 255, 0.4); }
.cat-stat b { color: #fff; font-weight: 700; font-size: 14px; }
.cat-stat .mono { font-size: 11px; }
.cat-follow {
  display: inline-flex; align-items: center; gap: 8px; flex: none;
  padding: 10px 20px; border-radius: var(--radius-control); color: #fff;
  font-family: var(--mono); font-size: 12px; font-weight: 500; white-space: nowrap;
}
.cat-follow:hover { opacity: 0.9; }
@media (max-width: 640px) {
  .cat-hero { height: auto; min-height: 280px; }
  .cat-hero__img { position: absolute; inset: 0; }
  .cat-hero__inner { position: relative; inset: auto; padding-top: 72px; }
  .cat-hero__initial { display: none; }
  .cat-hero__row { flex-direction: column; align-items: flex-start; gap: 16px; }
  .cat-hero__body { padding-bottom: 32px; }
}

/* Sticky filter bar */
.cat-filter { position: sticky; top: 56px; z-index: 40; background: var(--card); border-bottom: 1px solid var(--border); }
.cat-filter__inner { display: flex; align-items: center; justify-content: space-between; gap: 16px; height: 48px; }
.cat-tabs { display: flex; align-items: center; flex: 1; min-width: 0; overflow-x: auto; scrollbar-width: none; height: 48px; }
.cat-tabs::-webkit-scrollbar { display: none; }
.cat-tab {
  display: inline-flex; align-items: center; height: 48px; padding: 0 12px;
  font-family: var(--mono); font-size: 11px; font-weight: 500; white-space: nowrap;
  color: var(--muted-fg); border-bottom: 2px solid transparent;
}
.cat-tab:hover { color: var(--ink); }
.cat-tab.is-active { color: var(--ink); border-bottom-color: var(--accent); }
.cat-controls { display: flex; align-items: center; gap: 4px; flex: none; }
.seg { display: flex; align-items: center; border: 1px solid var(--border); border-radius: 2px; overflow: hidden; }
.seg__btn {
  display: inline-flex; align-items: center; padding: 6px 12px;
  font-family: var(--mono); font-size: 10px; font-weight: 500; letter-spacing: 0.04em;
  color: var(--muted-fg); white-space: nowrap;
}
.seg--icons .seg__btn { padding: 6px; }
.seg__btn:hover { color: var(--ink); }
.seg__btn.is-active { background: var(--ink); color: #fff; }
@media (max-width: 560px) { .seg--sort .seg__btn { padding: 6px 8px; } }

/* Layout */
.cat-container { padding-top: 32px; padding-bottom: 48px; }
.cat-cols { display: grid; grid-template-columns: 1fr 280px; gap: 40px; }
.cat-cols > * { min-width: 0; }
.cat-side__sticky { position: sticky; top: 128px; display: flex; flex-direction: column; gap: 32px; }
.cat-sect { margin-bottom: 40px; }
@media (max-width: 1024px) {
  .cat-cols { grid-template-columns: 1fr; }
  .cat-side { display: none; }
}

/* Featured in category */
.feat-cat { display: grid; grid-template-columns: 1fr 1fr; border: 1px solid var(--border); border-radius: 2px; overflow: hidden; }
.feat-cat__media { display: block; position: relative; background: var(--muted); min-height: 256px; }
.feat-cat__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s ease; }
.feat-cat:hover .feat-cat__media img { transform: scale(1.05); }
.feat-cat__body { display: flex; flex-direction: column; justify-content: center; padding: 32px; background: var(--card); }
.feat-cat__head { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; }
.feat-cat__bar { display: block; width: 4px; height: 48px; border-radius: 999px; flex: none; }
.feat-cat__pick { margin-top: 4px; font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted-fg); }
.feat-cat__title { font-family: var(--serif); font-weight: 700; font-size: clamp(20px, 2.2vw, 24px); line-height: 1.375; margin: 0; }
.feat-cat:hover .feat-cat__title { color: var(--accent); }
.feat-cat__excerpt {
  margin: 12px 0 0; font-size: 13px; line-height: 1.6; color: var(--muted-fg);
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
}
.feat-cat__tags { margin-top: 16px; }
.feat-cat__meta { display: flex; align-items: center; gap: 12px; margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--border); }
.feat-cat__meta .avatar { width: 28px; height: 28px; font-size: 10px; }
.feat-cat__who { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.feat-cat__who b { font-size: 12px; font-weight: 600; }
.feat-cat__who .mono { font-size: 10px; color: var(--muted-fg); }
.feat-cat__nums { margin-left: auto; display: flex; align-items: center; gap: 12px; color: var(--muted-fg); }
.feat-cat__nums .mono { font-size: 11px; }
@media (max-width: 640px) {
  .feat-cat { grid-template-columns: 1fr; }
  .feat-cat__body { padding: 24px; }
}

/* Category article grid (compact cards) */
.cat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
@media (max-width: 1200px) { .cat-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .cat-grid { grid-template-columns: 1fr; } }
.cat-card { display: flex; flex-direction: column; }
.cat-card__media { display: block; overflow: hidden; border-radius: 2px; aspect-ratio: 4 / 3; background: var(--muted); }
.cat-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.cat-card:hover .cat-card__media img { transform: scale(1.05); }
.cat-card__body { margin-top: 12px; display: flex; flex-direction: column; flex: 1; }
.cat-card__title {
  font-family: var(--serif); font-weight: 700; font-size: 14px; line-height: 1.375; margin: 6px 0 0;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.cat-card:hover .cat-card__title { color: var(--accent); }
.cat-card__excerpt {
  margin: 6px 0 0; font-size: 12px; line-height: 1.6; color: var(--muted-fg); flex: 1;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.cat-card__foot { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--border); }
.cat-card__meta { display: flex; align-items: center; gap: 8px; min-width: 0; color: var(--muted-fg); font-size: 11px; }
.cat-card__meta .avatar { width: 20px; height: 20px; font-size: 8px; }
.cat-card__meta .mono { font-size: 11px; }

/* Category list layout */
.post-row { display: flex; gap: 20px; padding: 20px 0; border-bottom: 1px solid var(--border); }
.post-row:last-child { border-bottom: 0; }
.post-row__media { display: block; overflow: hidden; border-radius: 2px; background: var(--muted); flex: none; width: 176px; height: 128px; }
.post-row__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.post-row:hover .post-row__media img { transform: scale(1.05); }
.post-row__body { flex: 1; min-width: 0; display: flex; flex-direction: column; justify-content: space-between; padding: 2px 0; }
.post-row__title {
  font-family: var(--serif); font-weight: 700; font-size: 15px; line-height: 1.375; margin: 4px 0 0;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.post-row:hover .post-row__title { color: var(--accent); }
.post-row__excerpt {
  margin: 6px 0 0; font-size: 12px; line-height: 1.6; color: var(--muted-fg);
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.post-row__foot { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-top: 8px; }
.post-row__meta { display: flex; align-items: center; gap: 10px; color: var(--muted-fg); font-size: 11px; }
.post-row__meta .mono { font-size: 11px; }
@media (max-width: 640px) {
  .post-row { gap: 16px; }
  .post-row__media { width: 128px; height: 112px; }
  .post-row__excerpt, .post-row__views { display: none; }
}

.cat-end { margin-top: 32px; text-align: center; font-size: 11px; color: var(--muted-fg); }
.cat-end a { text-decoration: underline; }
.cat-end a:hover { color: var(--ink); }

/* Explore other topics */
.other-topics { border-top: 1px solid var(--border); padding-top: 32px; }
.topics-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
@media (max-width: 640px) { .topics-grid { grid-template-columns: repeat(2, 1fr); } }
.topic-card {
  display: flex; flex-direction: column; gap: 8px; padding: 16px; text-align: left;
  background: var(--card); border: 1px solid var(--border); border-radius: 2px;
}
.topic-card:hover { border-color: var(--ink); }
.topic-card__name { font-family: var(--serif); font-weight: 700; font-size: 13px; }
.topic-card:hover .topic-card__name { color: var(--accent); }
.topic-card__desc { font-size: 11px; line-height: 1.4; color: var(--muted-fg); }
.topic-card__count { display: inline-flex; align-items: center; gap: 4px; margin-top: 4px; color: var(--muted-fg); }
.topic-card__count .mono { font-size: 10px; }

/* Category sidebar */
.about-card { border-radius: 2px; padding: 20px; color: #fff; }
.about-card__label { font-family: var(--mono); font-size: 10px; font-weight: 500; letter-spacing: 0.18em; text-transform: uppercase; opacity: 0.7; margin-bottom: 12px; }
.about-card__text { margin: 0; font-size: 13px; line-height: 1.6; opacity: 0.9; }
.about-card__stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-top: 16px; padding-top: 16px; border-top: 1px solid rgba(255, 255, 255, 0.2); }
.about-card__stat { text-align: center; }
.about-card__stat b { display: block; font-size: 15px; font-weight: 900; }
.about-card__stat .mono { font-size: 9px; opacity: 0.6; margin-top: 2px; display: block; }
.about-card__btn {
  display: block; width: 100%; margin-top: 16px; padding: 8px 0; text-align: center;
  background: #fff; color: var(--ink); border-radius: var(--radius-control);
  font-family: var(--mono); font-size: 11px; font-weight: 500;
}
.about-card__btn:hover { background: rgba(255, 255, 255, 0.9); }

.contribs { display: flex; flex-direction: column; gap: 12px; }
.contrib { display: flex; align-items: center; gap: 12px; }
.contrib__avatar {
  width: 36px; height: 36px; border-radius: 50%; flex: none;
  display: inline-flex; align-items: center; justify-content: center;
  color: #fff; font-size: 11px; font-weight: 700;
}
.contrib__who { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.contrib__who b { font-size: 13px; font-weight: 600; line-height: 1; }
.contrib:hover .contrib__who b { color: var(--accent); }
.contrib__who .mono { font-size: 10px; color: var(--muted-fg); }
.contrib__n { text-align: right; flex: none; display: flex; flex-direction: column; gap: 1px; }
.contrib__n b { font-size: 12px; font-weight: 700; }
.contrib__n .mono { font-size: 9px; color: var(--muted-fg); }

.most-read__item { display: flex; gap: 12px; padding: 12px 0; border-top: 1px solid var(--border); }
.most-read__item:first-child { border-top: 0; padding-top: 0; }
.most-read__num { font-family: var(--serif); font-weight: 900; font-size: 20px; line-height: 1; color: rgba(0, 0, 0, 0.2); width: 20px; flex: none; margin-top: 2px; font-variant-numeric: tabular-nums; }
.most-read__title {
  font-family: var(--serif); font-size: 12px; font-weight: 600; line-height: 1.375; margin: 0;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.most-read__item:hover .most-read__title { color: var(--accent); }
.most-read__meta { display: flex; align-items: center; gap: 8px; margin-top: 4px; color: var(--muted-fg); }
.most-read__meta .mono { font-size: 10px; }

/* ---------- Search page ---------- */
mark { background: #fef3c7; color: #92400e; border-radius: 2px; padding: 0 2px; }
.search-hero { background: var(--ink); border-bottom: 1px solid rgba(255, 255, 255, 0.2); }
.search-hero__inner { max-width: 768px; margin: 0 auto; padding: 40px 24px; }
.search-hero__label { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; color: var(--muted-fg); }
.search-hero__label span { font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(255, 255, 255, 0.4); }
.search-big { display: flex; gap: 8px; }
.search-big__field {
  flex: 1; display: flex; align-items: center; gap: 12px; min-width: 0;
  background: rgba(255, 255, 255, 0.1); border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: 2px; padding: 12px 16px; color: rgba(255, 255, 255, 0.4);
}
.search-big__field:focus-within { border-color: var(--accent); }
.search-big__field input {
  flex: 1; min-width: 0; background: transparent; border: 0; outline: none;
  color: #fff; font-family: var(--mono); font-size: 15px;
}
.search-big__field input::placeholder { color: rgba(255, 255, 255, 0.3); }
.search-big button {
  padding: 12px 20px; background: var(--accent); color: #fff; border: 0; cursor: pointer;
  border-radius: 2px; font-family: var(--mono); font-size: 12px; font-weight: 500;
  letter-spacing: 0.08em; text-transform: uppercase; white-space: nowrap;
}
.search-big button:hover { background: #c01f12; }
.search-try { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; margin-top: 16px; }
.search-try__label { font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(255, 255, 255, 0.3); }
.search-try__pill {
  padding: 4px 10px; border: 1px solid rgba(255, 255, 255, 0.2); border-radius: 999px;
  font-family: var(--mono); font-size: 10px; color: rgba(255, 255, 255, 0.6);
}
.search-try__pill:hover { border-color: rgba(255, 255, 255, 0.5); color: #fff; }
.search-try__pill.is-active { background: var(--accent); border-color: var(--accent); color: #fff; }

.search-container { padding-top: 32px; padding-bottom: 48px; }
.search-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; flex-wrap: wrap; margin-bottom: 24px; }
.search-head__title { font-family: var(--serif); font-weight: 700; font-size: 18px; margin: 0; }
.is-accent-text { color: var(--accent); }
.search-head__count { font-size: 12px; color: var(--muted-fg); margin: 2px 0 0; }
.search-controls { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.search-related { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 24px; }
.search-related__label { font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted-fg); }
.search-related__tag {
  display: inline-flex; align-items: center; gap: 4px; padding: 4px 10px;
  background: var(--secondary); border: 1px solid var(--border); border-radius: 2px;
  font-family: var(--mono); font-size: 10px; color: var(--muted-fg);
}
.search-related__tag:hover { color: var(--ink); border-color: var(--ink); }
.search-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
@media (max-width: 640px) { .search-grid { grid-template-columns: 1fr; } }
.search-empty { text-align: center; padding: 80px 24px; border: 1px dashed var(--border); border-radius: 2px; }
.search-empty__icon { color: var(--muted-fg); opacity: 0.3; margin: 0 auto 16px; display: block; }
.search-empty__title { font-family: var(--serif); font-weight: 700; font-size: 16px; margin: 0 0 8px; }
.search-empty__text { font-size: 13px; color: var(--muted-fg); margin: 0 0 24px; }
.search-empty__sugs { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; }
.search-empty__sug { padding: 6px 12px; border: 1px solid var(--border); border-radius: 2px; font-family: var(--mono); font-size: 11px; color: var(--muted-fg); }
.search-empty__sug:hover { color: var(--ink); border-color: var(--ink); }

/* ---------- Tag page ---------- */
.tag-hero { background: var(--ink); border-bottom: 1px solid rgba(255, 255, 255, 0.1); }
.tag-hero__inner { padding-top: 48px; padding-bottom: 48px; }
.tag-hero__crumb { margin-bottom: 24px; }
.tag-hero__crumb a, .tag-hero__crumb-mid, .tag-hero__crumb-tag { font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; }
.tag-hero__crumb a { color: rgba(255, 255, 255, 0.4); }
.tag-hero__crumb a:hover { color: rgba(255, 255, 255, 0.7); }
.tag-hero__crumb-mid { color: rgba(255, 255, 255, 0.4); }
.tag-hero__crumb-tag { color: var(--accent); font-weight: 500; }
.tag-hero__row { display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.tag-hero__name { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.tag-hero__hash {
  width: 40px; height: 40px; border-radius: 2px; flex: none;
  background: rgba(217, 41, 27, 0.2); border: 1px solid rgba(217, 41, 27, 0.3);
  display: inline-flex; align-items: center; justify-content: center; color: var(--accent);
}
.tag-hero__title { font-family: var(--serif); font-weight: 900; color: #fff; font-size: clamp(30px, 3.5vw, 36px); line-height: 1; margin: 0; }
.tag-hero__desc { margin: 0; color: rgba(255, 255, 255, 0.6); font-size: 14px; line-height: 1.6; max-width: 576px; }
.tag-hero__main .cat-hero__stats { margin-top: 20px; }
.tag-hero__follow {
  display: inline-flex; align-items: center; gap: 8px; flex: none;
  padding: 10px 20px; background: var(--accent); color: #fff; border-radius: 2px;
  font-family: var(--mono); font-size: 12px; font-weight: 500; white-space: nowrap;
}
.tag-hero__follow:hover { background: #c01f12; }
.tag-hero__related { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-top: 32px; }
.tag-hero__related-label { font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(255, 255, 255, 0.3); }
.tag-hero__related-pill {
  display: inline-flex; align-items: center; gap: 4px; padding: 4px 12px;
  border: 1px solid rgba(255, 255, 255, 0.15); border-radius: 999px;
  font-family: var(--mono); font-size: 11px; color: rgba(255, 255, 255, 0.6);
}
.tag-hero__related-pill:hover { color: #fff; border-color: rgba(255, 255, 255, 0.4); }
@media (max-width: 640px) { .tag-hero__row { flex-direction: column; align-items: flex-start; gap: 16px; } }
.tag-filter__count { font-size: 11px; color: var(--muted-fg); }
.tag-filter__count strong { color: var(--ink); }
.tag-cloud { margin-top: 48px; padding-top: 32px; border-top: 1px solid var(--border); }
.tag-cloud__list { display: flex; flex-wrap: wrap; gap: 8px; }
.tag-cloud__item { padding: 6px 12px; border: 1px solid var(--border); border-radius: 2px; font-family: var(--mono); font-size: 11px; color: var(--muted-fg); }
.tag-cloud__item:hover { color: var(--ink); border-color: var(--ink); }
.tag-cloud__item.is-active { background: var(--ink); color: #fff; border-color: var(--ink); }
.tag-cloud__n { opacity: 0.5; margin-left: 4px; }

/* ---------- Author page ---------- */
.author-hero { background: var(--ink); }
.author-hero__inner { padding-top: 48px; padding-bottom: 48px; }
.author-hero__crumb { margin-bottom: 32px; }
.author-hero__crumb a, .author-hero__crumb-mid, .author-hero__crumb-name { font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; }
.author-hero__crumb a { color: rgba(255, 255, 255, 0.4); }
.author-hero__crumb a:hover { color: rgba(255, 255, 255, 0.7); }
.author-hero__crumb-mid { color: rgba(255, 255, 255, 0.4); }
.author-hero__crumb-name { color: var(--accent); font-weight: 500; }
.author-hero__row { display: flex; gap: 28px; align-items: flex-start; }
.author-hero__avatar-wrap { position: relative; flex: none; }
.author-hero__avatar { width: 112px; height: 112px; border-radius: 50%; object-fit: cover; border: 2px solid rgba(255, 255, 255, 0.1); }
.author-hero__dot { position: absolute; bottom: 4px; right: 4px; width: 20px; height: 20px; background: #10b981; border-radius: 50%; border: 2px solid var(--ink); }
.author-hero__info { flex: 1; min-width: 0; }
.author-hero__top { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.author-hero__name { font-family: var(--serif); font-weight: 900; color: #fff; font-size: clamp(24px, 3vw, 30px); line-height: 1.2; margin: 0; }
.author-hero__meta { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-top: 6px; color: rgba(255, 255, 255, 0.4); }
.author-hero__meta .mono { font-size: 11px; }
.author-hero__role { color: var(--accent); font-size: 12px; font-weight: 500; }
.meta-sep--light { background: rgba(255, 255, 255, 0.2); }
.author-hero__bio { margin: 12px 0 0; color: rgba(255, 255, 255, 0.6); font-size: 13px; line-height: 1.6; max-width: 576px; }
.author-hero__social { display: flex; align-items: center; gap: 12px; margin-top: 16px; flex-wrap: wrap; }
.author-hero__social a { display: inline-flex; align-items: center; gap: 6px; font-family: var(--mono); font-size: 11px; color: rgba(255, 255, 255, 0.4); }
.author-hero__social a:hover { color: #fff; }
.author-hero__actions { display: flex; align-items: center; gap: 8px; flex: none; }
.author-hero__follow {
  display: inline-flex; align-items: center; gap: 8px; padding: 8px 16px;
  background: var(--accent); color: #fff; border-radius: 2px;
  font-family: var(--mono); font-size: 12px; font-weight: 500;
}
.author-hero__follow:hover { background: #c01f12; }
.author-hero__share { display: inline-flex; padding: 8px; border: 1px solid rgba(255, 255, 255, 0.15); border-radius: 2px; color: rgba(255, 255, 255, 0.4); }
.author-hero__share:hover { color: #fff; border-color: rgba(255, 255, 255, 0.4); }
.author-hero__stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 28px; padding-top: 24px; border-top: 1px solid rgba(255, 255, 255, 0.1); max-width: 384px; }
.author-hero__stat b { display: block; font-size: 20px; font-weight: 900; color: #fff; line-height: 1; }
.author-hero__stat .mono { font-size: 10px; color: rgba(255, 255, 255, 0.4); margin-top: 2px; display: block; }
.author-hero__seen { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-top: 20px; }
.author-hero__seen-label { font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(255, 255, 255, 0.3); }
.author-hero__pub { font-family: var(--mono); font-size: 11px; color: rgba(255, 255, 255, 0.5); padding: 2px 10px; border: 1px solid rgba(255, 255, 255, 0.1); border-radius: 2px; }
@media (max-width: 640px) {
  .author-hero__row { flex-direction: column; gap: 20px; }
  .author-hero__avatar { width: 96px; height: 96px; }
}

.author-about { max-width: 672px; display: flex; flex-direction: column; gap: 32px; }
.author-about__head { font-size: 11px; font-weight: 500; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted-fg); margin: 0 0 14px; }
.author-about__bio { font-size: 15px; line-height: 1.7; margin: 0; }
.author-about__chips { display: flex; flex-wrap: wrap; gap: 8px; }
.author-about__chip { padding: 6px 12px; background: var(--secondary); border: 1px solid var(--border); border-radius: 2px; font-size: 12px; color: var(--ink); }
.author-about__pubs { display: flex; flex-wrap: wrap; gap: 12px; }
.author-about__pub { display: inline-flex; align-items: center; gap: 8px; padding: 10px 16px; background: var(--card); border: 1px solid var(--border); border-radius: 2px; }
.author-about__pub b { font-size: 13px; font-weight: 600; }
.is-star { color: #f59e0b; }
.author-about__contacts { display: flex; flex-direction: column; gap: 12px; }
.contact-row { display: flex; align-items: center; gap: 12px; }
.contact-row__icon { width: 32px; height: 32px; flex: none; background: var(--secondary); border: 1px solid var(--border); border-radius: 2px; display: inline-flex; align-items: center; justify-content: center; color: var(--muted-fg); }
.contact-row__body { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.contact-row__label { font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted-fg); }
.contact-row__value { font-size: 13px; font-weight: 500; }
.contact-row:hover .contact-row__value { color: var(--accent); }
.contrib__img { width: 36px; height: 36px; border-radius: 50%; object-fit: cover; flex: none; }

/* ---------- Subscribe page ---------- */
.sub-hero { background: var(--ink); }
.sub-hero__inner { max-width: 768px; margin: 0 auto; padding: 64px 24px; text-align: center; }
.sub-hero__pill {
  display: inline-flex; align-items: center; gap: 8px; padding: 6px 12px;
  background: rgba(217, 41, 27, 0.15); border: 1px solid rgba(217, 41, 27, 0.3);
  border-radius: 999px; margin-bottom: 24px; color: var(--accent);
}
.sub-hero__pill span { font-family: var(--mono); font-size: 10px; font-weight: 500; letter-spacing: 0.18em; text-transform: uppercase; }
.sub-hero__title { font-family: var(--serif); font-weight: 900; color: #fff; font-size: clamp(30px, 5vw, 48px); line-height: 1.25; margin: 0; }
.sub-hero__desc { margin: 20px auto 0; color: rgba(255, 255, 255, 0.6); font-size: 15px; line-height: 1.6; max-width: 576px; }
.sub-hero__checks { display: flex; align-items: center; justify-content: center; gap: 24px; margin-top: 32px; flex-wrap: wrap; }
.sub-hero__check { display: inline-flex; align-items: center; gap: 6px; font-family: var(--mono); font-size: 12px; color: rgba(255, 255, 255, 0.4); }
.sub-hero__check svg { color: #10b981; }

.sub-container { max-width: 1024px; margin: 0 auto; padding: 64px 24px; }
.sub-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; }
@media (max-width: 1024px) { .sub-cols { grid-template-columns: 1fr; } }
.sub-signup { max-width: 560px; margin: 0 auto; }
.sub-h2 { font-family: var(--serif); font-weight: 700; font-size: 20px; margin: 0 0 4px; }
.sub-sub { font-size: 13px; color: var(--muted-fg); margin: 0 0 24px; }
.sub-form { display: flex; flex-direction: column; gap: 16px; }
.sub-label { display: block; font-size: 10px; font-weight: 500; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted-fg); margin-bottom: 6px; }
.sub-field input[type="text"], .sub-field input[type="email"] {
  width: 100%; background: var(--card); border: 1px solid var(--border); border-radius: 2px;
  color: var(--ink); font-family: var(--sans); font-size: 14px; padding: 12px 16px;
}
.sub-field input:focus { outline: none; border-color: var(--ink); }
.sub-field input::placeholder { color: var(--muted-fg); }
.freq-row { display: flex; gap: 8px; }
.freq-opt { flex: 1; cursor: pointer; }
.freq-opt input { position: absolute; opacity: 0; pointer-events: none; }
.freq-opt__body { display: block; padding: 12px; border: 1px solid var(--border); border-radius: 2px; color: var(--muted-fg); }
.freq-opt:hover .freq-opt__body { border-color: var(--ink); }
.freq-opt__name { display: block; font-size: 12px; font-weight: 600; color: var(--ink); line-height: 1; }
.freq-opt__desc { display: block; font-size: 10px; margin-top: 5px; color: var(--muted-fg); }
.freq-opt input:checked + .freq-opt__body { background: var(--ink); border-color: var(--ink); }
.freq-opt input:checked + .freq-opt__body .freq-opt__name { color: #fff; }
.freq-opt input:checked + .freq-opt__body .freq-opt__desc { color: rgba(255, 255, 255, 0.6); }
.topic-choices { display: flex; flex-wrap: wrap; gap: 8px; }
.topic-choice { cursor: pointer; }
.topic-choice input { position: absolute; opacity: 0; pointer-events: none; }
.topic-choice span {
  display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px;
  border: 1px solid var(--border); border-radius: 999px;
  font-family: var(--mono); font-size: 11px; font-weight: 500; color: var(--muted-fg);
}
.topic-choice span svg { display: none; }
.topic-choice:hover span { border-color: var(--ink); }
.topic-choice input:checked + span { background: var(--ink); border-color: var(--ink); color: #fff; }
.topic-choice input:checked + span svg { display: block; }
.sub-submit {
  width: 100%; padding: 14px; margin-top: 8px; background: var(--accent); color: #fff;
  border: 0; border-radius: 2px; cursor: pointer;
  font-size: 13px; font-weight: 500; letter-spacing: 0.14em; text-transform: uppercase;
}
.sub-submit:hover { background: #c01f12; }
.sub-legal { font-size: 10px; color: var(--muted-fg); text-align: center; margin: 0; }
.sub-legal a { text-decoration: underline; }
.sub-done { display: flex; flex-direction: column; align-items: center; gap: 16px; padding: 48px 24px; text-align: center; border: 1px dashed #a7f3d0; border-radius: 2px; background: #ecfdf5; }
.sub-done__icon { color: #10b981; }
.sub-done__title { font-family: var(--serif); font-weight: 700; font-size: 18px; margin: 0; }
.sub-done__text { font-size: 13px; color: var(--muted-fg); max-width: 320px; margin: 0; }
.sub-done__btn { display: inline-flex; align-items: center; gap: 8px; margin-top: 8px; padding: 10px 20px; background: var(--ink); color: #fff; border-radius: 2px; font-family: var(--mono); font-size: 12px; font-weight: 500; }
.sub-done__btn:hover { background: #333; }

/* Plans (zero-JS radio toggle) */
.sub-plans { position: relative; }
.plan-radio { position: absolute; opacity: 0; pointer-events: none; }
.plans-toggle { display: flex; align-items: center; gap: 8px; margin-bottom: 16px; }
.plans-toggle .seg__btn { cursor: pointer; padding: 8px 20px; font-size: 11px; }
.plans-badge { display: none; padding: 2px 10px; background: var(--accent); color: #fff; border-radius: 999px; font-size: 10px; font-weight: 500; letter-spacing: 0.18em; text-transform: uppercase; }
.plan-card { display: none; background: var(--card); border: 1px solid var(--border); border-radius: 2px; overflow: hidden; }
.plan-radio--free:checked ~ .plan-card--free { display: block; }
.plan-radio--pro:checked ~ .plan-card--pro { display: block; }
.plan-radio--free:checked ~ .plans-toggle .plans-toggle__free,
.plan-radio--pro:checked ~ .plans-toggle .plans-toggle__pro { background: var(--ink); color: #fff; }
.plan-radio--pro:checked ~ .plans-toggle .plans-badge { display: inline-block; }
.plan-card__head { padding: 24px; }
.plan-card__head--dark { background: var(--ink); }
.plan-card__label { font-size: 10px; font-weight: 500; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted-fg); margin-bottom: 4px; }
.plan-card__head--dark .plan-card__label { color: rgba(255, 255, 255, 0.5); }
.plan-card__price b { font-family: var(--serif); font-weight: 900; font-size: 36px; }
.plan-card__head--dark .plan-card__price b { color: #fff; }
.plan-card__price .mono { font-size: 13px; color: rgba(255, 255, 255, 0.4); margin-left: 8px; }
.plan-card__desc { margin: 8px 0 0; font-size: 13px; line-height: 1.6; color: var(--muted-fg); }
.plan-card__head--dark .plan-card__desc { color: rgba(255, 255, 255, 0.6); }
.plan-card__list { list-style: none; margin: 0; padding: 24px; display: flex; flex-direction: column; gap: 12px; }
.plan-card__list li { display: flex; align-items: center; gap: 12px; font-size: 13px; }
.plan-card__tick { width: 16px; height: 16px; border-radius: 50%; flex: none; display: inline-flex; align-items: center; justify-content: center; }
.plan-card__list li.is-on .plan-card__tick { background: #d1fae5; color: #059669; }
.plan-card__list li.is-off .plan-card__tick { background: var(--muted); color: var(--muted-fg); }
.plan-card__list li.is-off span:last-child { color: var(--muted-fg); text-decoration: line-through; text-decoration-color: rgba(0, 0, 0, 0.2); }

/* Benefits / testimonials / FAQ / CTA */
.sub-sect { margin-top: 80px; }
.sub-sect__head { text-align: center; margin-bottom: 40px; }
.sub-sect__title { font-family: var(--serif); font-weight: 900; font-size: clamp(24px, 2.6vw, 30px); margin: 0; }
.sub-sect__sub { font-size: 13px; color: var(--muted-fg); margin: 8px 0 0; }
.benefits-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
@media (max-width: 960px) { .benefits-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .benefits-grid { grid-template-columns: 1fr; } }
.benefit { padding: 20px; background: var(--card); border: 1px solid var(--border); border-radius: 2px; }
.benefit:hover { border-color: var(--ink); }
.benefit__icon { width: 36px; height: 36px; background: var(--secondary); border: 1px solid var(--border); border-radius: 2px; display: inline-flex; align-items: center; justify-content: center; margin-bottom: 16px; color: var(--ink); }
.benefit__title { font-family: var(--serif); font-weight: 700; font-size: 14px; margin: 0 0 6px; }
.benefit__desc { font-size: 12px; line-height: 1.6; color: var(--muted-fg); margin: 0; }
.quotes-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
@media (max-width: 640px) { .quotes-grid { grid-template-columns: 1fr; } }
.quote-card { padding: 20px; background: var(--card); border: 1px solid var(--border); border-radius: 2px; }
.quote-card__who { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
.quote-card__avatar { width: 36px; height: 36px; font-size: 11px; }
.quote-card__id { display: flex; flex-direction: column; gap: 2px; }
.quote-card__id b { font-size: 13px; font-weight: 600; }
.quote-card__id .mono { font-size: 10px; color: var(--muted-fg); }
.quote-card__stars { display: flex; gap: 2px; margin-bottom: 12px; }
.quote-card__stars svg { color: #fbbf24; fill: #fbbf24; }
.quote-card__text { font-size: 13px; line-height: 1.6; color: var(--muted-fg); font-style: italic; margin: 0; }
.sub-faq { margin-top: 80px; max-width: 672px; margin-left: auto; margin-right: auto; }
.sub-faq__title { text-align: center; margin-bottom: 32px; }
.faq-list { border: 1px solid var(--border); border-radius: 2px; overflow: hidden; }
.faq { border-bottom: 1px solid var(--border); }
.faq:last-child { border-bottom: 0; }
.faq summary {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 16px 20px; cursor: pointer; list-style: none;
  font-size: 14px; font-weight: 600;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary:hover { background: var(--secondary); }
.faq summary svg { color: var(--muted-fg); transition: transform 0.2s ease; flex: none; }
.faq[open] summary svg { transform: rotate(180deg); }
.faq p { margin: 0; padding: 0 20px 16px; font-size: 13px; line-height: 1.6; color: var(--muted-fg); }
.sub-cta { margin-top: 80px; padding: 64px 24px; background: var(--ink); border-radius: 2px; text-align: center; }
.sub-cta__title { font-family: var(--serif); font-weight: 900; color: #fff; font-size: clamp(24px, 2.6vw, 30px); margin: 0 0 12px; }
.sub-cta__text { color: rgba(255, 255, 255, 0.6); font-size: 14px; margin: 0 0 32px; }
.sub-cta__btn {
  display: inline-flex; align-items: center; gap: 8px; padding: 14px 32px;
  background: var(--accent); color: #fff; border-radius: 2px;
  font-size: 13px; font-weight: 500; letter-spacing: 0.08em; text-transform: uppercase;
}
.sub-cta__btn:hover { background: #c01f12; }

/* Back to top (appears after ~300px of scroll where supported) */
.scroll-top {
  position: fixed; bottom: 24px; right: 24px; width: 40px; height: 40px;
  background: var(--ink); color: #fff; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.2); z-index: 50;
}
.scroll-top:hover { background: #333; }
@supports (animation-timeline: scroll()) {
  .scroll-top {
    opacity: 0; visibility: hidden;
    animation: scrolltop-in linear both; animation-timeline: scroll(root);
    animation-range: 300px 700px;
  }
}
@keyframes scrolltop-in { to { opacity: 1; visibility: visible; } }

/* ---------- Static / search / error ---------- */
.prose { max-width: 720px; margin: 0 auto; }
.prose h1 { font-family: var(--serif); font-weight: 800; font-size: 38px; letter-spacing: -0.02em; }
.prose h2 { font-family: var(--serif); font-weight: 700; font-size: 25px; letter-spacing: -0.01em; margin: 40px 0 12px; }
.prose h3 { font-family: var(--serif); font-weight: 700; font-size: 19px; margin: 28px 0 8px; }
.prose p { font-size: 17px; line-height: 1.7; margin: 16px 0; }
.prose .lead { font-size: 19px; color: var(--muted-fg); line-height: 1.65; }
.prose ul, .prose ol { margin: 16px 0; padding-left: 22px; }
.prose li { font-size: 17px; line-height: 1.7; margin: 6px 0; }
.prose li strong, .prose p strong { font-weight: 700; color: var(--ink); }
.prose a { color: var(--accent); text-decoration: underline; }
.prose .prose-note { margin: 28px 0 0; padding: 16px 18px; background: var(--card); border: 1px solid var(--border); border-left: 3px solid var(--accent); }
.prose .prose-note p { font-size: 14px; line-height: 1.6; margin: 0; color: var(--muted-fg); }
.prose .prose-updated { margin-top: 40px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted-fg); }
.search-form { display: flex; gap: 10px; margin: 18px 0; max-width: 520px; }
.search-form input { flex: 1; font-family: var(--mono); border: 1px solid var(--border); border-radius: var(--radius-control); padding: 11px 16px; background: var(--card); }
.search-form button { font-family: var(--mono); background: var(--accent); color: #fff; border: 0; border-radius: var(--radius-control); padding: 11px 22px; cursor: pointer; }

/* ---------- Footer ---------- */
.site-footer { margin-top: 64px; border-top: 1px solid var(--border); background: var(--card); }
.site-main--bare + .site-footer { margin-top: 0; }
.site-footer__inner { padding-top: 40px; padding-bottom: 40px; }
.footer-grid { display: grid; grid-template-columns: 1.3fr 2fr 1fr 1fr; gap: 32px; margin-bottom: 32px; }
.footer-brand__logo { display: inline-flex; align-items: center; gap: 9px; color: var(--ink); }
.footer-brand__name { font-family: var(--serif); font-weight: 900; font-size: 19px; letter-spacing: -0.025em; line-height: 1; }
.footer-brand p { color: var(--muted-fg); font-size: 12px; line-height: 1.6; margin: 8px 0 0; max-width: 34ch; }
.footer-col h5 { font-family: var(--mono); font-size: 10px; font-weight: 500; letter-spacing: 0.18em; text-transform: uppercase; margin: 0 0 12px; }
.footer-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.footer-col a { color: var(--muted-fg); font-size: 12px; }
.footer-col a:hover { color: var(--ink); }
/* Topics column: 10 categories split into 2 sub-columns (5 + 5) so the footer
   row stays balanced instead of one very tall column. */
.footer-col--topics ul { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 24px; }
@media (max-width: 900px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .footer-grid { grid-template-columns: 1fr; } }
.footer-bottom { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 12px; border-top: 1px solid var(--border); padding-top: 24px; }
.footer-bottom span { font-family: var(--mono); font-size: 10px; color: var(--muted-fg); }
.footer-bottom span a { color: var(--muted-fg); text-decoration: underline; text-underline-offset: 2px; }
.footer-bottom span a:hover { color: var(--ink); }
.footer-disclosure { margin: 16px 0 0; font-size: 11px; line-height: 1.6; color: var(--muted-fg); max-width: 96ch; }
.footer-disclosure a { color: var(--muted-fg); text-decoration: underline; text-underline-offset: 2px; }
.footer-disclosure a:hover { color: var(--ink); }
.health-disclaimer { display: block; margin: 28px 0 0; padding: 14px 16px; background: var(--card); border: 1px solid var(--border); border-left: 3px solid var(--accent); font-size: 13px; line-height: 1.6; color: var(--muted-fg); }
.health-disclaimer strong { color: var(--ink); }

/* ---------- Responsive ---------- */
@media (max-width: 1024px) {
  .hero { grid-template-columns: 1fr; }
  .hero-secondary { height: auto; grid-template-rows: none; grid-template-columns: 1fr 1fr; }
  .hero-sub { min-height: 200px; }
  .layout-cols { grid-template-columns: 1fr; gap: 48px; }
}
@media (max-width: 640px) {
  .hero-main__media { height: 320px; }
  .hero-excerpt { display: none; }
  .hero-secondary { grid-template-columns: 1fr; }
  .picks-grid { grid-template-columns: repeat(2, 1fr); }
  .post-grid { grid-template-columns: 1fr; }
  .hero-title { font-size: 21px; }
  .page-header h1 { font-size: 30px; }
}

/* ==========================================================================
   About page (redesigned "Ve chung toi")
   ========================================================================== */
.about-hero { background: var(--ink); color: #fff; }
.about-hero__inner { padding-top: 56px; padding-bottom: 56px; }
.about-hero__crumb { display: flex; align-items: center; gap: 8px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(255, 255, 255, 0.4); margin-bottom: 28px; }
.about-hero__crumb a { color: rgba(255, 255, 255, 0.4); }
.about-hero__crumb a:hover { color: rgba(255, 255, 255, 0.75); }
.about-hero__eyebrow { font-family: var(--mono); font-size: 11px; letter-spacing: 0.22em; color: var(--accent); margin: 0 0 16px; }
.about-hero__title { font-family: var(--serif); font-weight: 900; color: #fff; font-size: clamp(28px, 5vw, 48px); line-height: 1.12; letter-spacing: -0.02em; margin: 0; max-width: 20ch; }
.about-hero__lead { margin: 20px 0 0; color: rgba(255, 255, 255, 0.62); font-size: clamp(15px, 1.6vw, 18px); line-height: 1.7; max-width: 60ch; }

.about-stats { background: var(--ink); border-top: 1px solid rgba(255, 255, 255, 0.1); }
.about-stats__grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.about-stat { padding: 28px 20px; text-align: center; border-left: 1px solid rgba(255, 255, 255, 0.08); }
.about-stat:first-child { border-left: 0; }
.about-stat__value { display: flex; align-items: center; justify-content: center; gap: 8px; color: #fff; }
.about-stat__value b { font-family: var(--serif); font-weight: 800; font-size: clamp(26px, 3.5vw, 36px); line-height: 1; }
.about-stat__icon { color: var(--accent); }
.about-stat__label { display: block; margin-top: 8px; font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(255, 255, 255, 0.45); }

.about-section { padding-top: 56px; }
.about-mission__text { font-family: var(--serif); font-size: clamp(20px, 2.6vw, 28px); line-height: 1.5; color: var(--ink); margin: 4px 0 0; max-width: 40ch; font-weight: 500; }

.about-values { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin-top: 40px; }
.value-card { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: 24px 20px; }
.value-card__icon { display: inline-flex; align-items: center; justify-content: center; width: 42px; height: 42px; border-radius: var(--radius); background: rgba(217, 41, 27, 0.08); color: var(--accent); margin-bottom: 16px; }
.value-card__title { font-family: var(--serif); font-weight: 700; font-size: 17px; line-height: 1.3; color: var(--ink); margin: 0; }
.value-card__body { font-size: 13px; line-height: 1.65; color: var(--muted-fg); margin: 10px 0 0; }

.about-team { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin-top: 40px; }
.team-card { display: flex; flex-direction: column; align-items: center; text-align: center; background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: 28px 18px; transition: border-color 0.15s ease, transform 0.15s ease; }
.team-card:hover { border-color: var(--border-strong); transform: translateY(-2px); }
.team-card__avatar { width: 72px; height: 72px; border-radius: 50%; object-fit: cover; border: 2px solid var(--border); }
.team-card__avatar--fallback { display: inline-flex; align-items: center; justify-content: center; background: var(--muted); color: var(--muted-fg); }
.team-card__name { font-family: var(--serif); font-weight: 700; font-size: 17px; color: var(--ink); margin: 14px 0 0; }
.team-card__role { display: block; font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent); margin-top: 6px; }
.team-card__bio { font-size: 12px; line-height: 1.6; color: var(--muted-fg); margin: 10px 0 0; }
.team-card__link { display: inline-flex; align-items: center; gap: 5px; font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted-fg); margin-top: 14px; }
.team-card:hover .team-card__link { color: var(--ink); }
.about-team__note { font-size: 12px; line-height: 1.65; color: var(--muted-fg); margin: 20px 0 0; max-width: 80ch; }
.about-team__note a { color: var(--muted-fg); text-decoration: underline; text-underline-offset: 2px; }
.about-team__note a:hover { color: var(--ink); }

.about-contact { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 40px; }
.contact-card { display: flex; flex-direction: column; background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: 24px; transition: border-color 0.15s ease; }
.contact-card:hover { border-color: var(--border-strong); }
.contact-card__icon { display: inline-flex; align-items: center; justify-content: center; width: 42px; height: 42px; border-radius: var(--radius); background: var(--ink); color: #fff; margin-bottom: 16px; }
.contact-card__title { font-family: var(--serif); font-weight: 700; font-size: 17px; color: var(--ink); margin: 0; }
.contact-card__body { font-size: 13px; line-height: 1.6; color: var(--muted-fg); margin: 8px 0 16px; flex: 1; }
.contact-card__email { font-size: 12px; color: var(--accent); }
.contact-card__cta { display: inline-flex; align-items: center; gap: 5px; font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted-fg); margin-top: 12px; }
.contact-card:hover .contact-card__cta { color: var(--ink); }

.about-cta { margin-top: 56px; background: var(--ink); }
.about-cta__inner { display: flex; align-items: center; justify-content: space-between; gap: 32px; padding-top: 44px; padding-bottom: 44px; flex-wrap: wrap; }
.about-cta__eyebrow { font-size: 11px; letter-spacing: 0.2em; color: var(--accent); margin: 0 0 12px; }
.about-cta__title { font-family: var(--serif); font-weight: 800; font-size: clamp(22px, 3vw, 30px); color: #fff; margin: 0; line-height: 1.25; }
.about-cta__text { color: rgba(255, 255, 255, 0.6); font-size: 14px; line-height: 1.6; margin: 12px 0 0; max-width: 46ch; }
.about-cta__form { display: flex; gap: 10px; flex: none; }
.about-cta__form input { min-width: 240px; padding: 13px 16px; background: rgba(255, 255, 255, 0.08); border: 1px solid rgba(255, 255, 255, 0.15); border-radius: var(--radius); color: #fff; font-family: var(--mono); font-size: 13px; }
.about-cta__form input::placeholder { color: rgba(255, 255, 255, 0.3); }
.about-cta__form input:focus { outline: none; border-color: var(--accent); }
.about-cta__form button { padding: 13px 22px; background: var(--accent); color: #fff; border: 0; border-radius: var(--radius); font-family: var(--mono); font-size: 12px; font-weight: 500; letter-spacing: 0.04em; cursor: pointer; white-space: nowrap; }
.about-cta__form button:hover { background: #c01f12; }

@media (max-width: 900px) {
  .about-values, .about-team { grid-template-columns: repeat(2, 1fr); }
  .about-contact { grid-template-columns: 1fr; }
  .about-stats__grid { grid-template-columns: repeat(2, 1fr); }
  .about-stat:nth-child(3) { border-left: 0; }
  .about-stat:nth-child(n + 3) { border-top: 1px solid rgba(255, 255, 255, 0.08); }
  .about-cta__inner { flex-direction: column; align-items: flex-start; }
  .about-cta__form { width: 100%; }
  .about-cta__form input { flex: 1; min-width: 0; }
}
@media (max-width: 560px) {
  .about-values, .about-team { grid-template-columns: 1fr; }
}

/* ==========================================================================
   Legal hub (sticky sidebar: privacy / terms / cookie)
   ========================================================================== */
.legal-layout { display: grid; grid-template-columns: 260px 1fr; gap: 48px; padding-top: 48px; padding-bottom: 64px; align-items: start; }
.legal-sidebar__sticky { position: sticky; top: 88px; }
.legal-nav { display: flex; flex-direction: column; gap: 4px; margin-top: 16px; }
.legal-nav__link { display: flex; align-items: center; gap: 10px; padding: 11px 14px; border-radius: var(--radius); font-size: 13px; color: var(--muted-fg); border: 1px solid transparent; }
.legal-nav__link:hover { background: var(--card); color: var(--ink); }
.legal-nav__link.is-active { background: var(--card); border-color: var(--border); color: var(--ink); font-weight: 500; box-shadow: inset 2px 0 0 var(--accent); }
.legal-nav__link.is-active svg { color: var(--accent); }
.legal-sidebar__updated { margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--border); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted-fg); }
.legal-content { max-width: 720px; min-width: 0; }

@media (max-width: 860px) {
  .legal-layout { grid-template-columns: 1fr; gap: 24px; }
  .legal-sidebar__sticky { position: static; }
  .legal-nav { flex-direction: row; flex-wrap: wrap; }
  .legal-nav__link { flex: 1; min-width: 150px; justify-content: center; }
}
