/* ─────────────────────────────────────────────────────────────────────
 * Shared chrome for /framework/blocks/templates/* pages.
 * Tokens + topbar + index grid + page-template primitives.
 * Tokens & primitives mirror /framework/imports/_shell.css so converted
 * blocks, sections and components compose naturally on these pages.
 * ───────────────────────────────────────────────────────────────────── */

:root {--elev-step:6%;--elev-step-2:13%;--ink-dim-step:0.75;--ink-faint-step:0.66;--line-step:8%;--line-strong-step:16%;
  --bg: #07060f;
  --bg-elev: color-mix(in oklch,var(--bg),var(--ink) var(--elev-step));
  --bg-elev-2: color-mix(in oklch,var(--bg),var(--ink) var(--elev-step-2));
  --line: color-mix(in srgb,transparent,var(--ink) var(--line-step));
  --line-strong: color-mix(in srgb,transparent,var(--ink) var(--line-strong-step));
  --ink: #ece9ff;
  --ink-dim: oklch(from var(--ink) calc(l * var(--ink-dim-step)) c h);
  --ink-faint: oklch(from var(--ink) calc(l * var(--ink-faint-step)) c h);
  --accent: #a78bfa;
  --accent-2: #22d3ee;
  --accent-3: #f472b6;
  --ok: #4ade80;
  --r-sm: 6px;
  --r-md: 10px;
  --r-lg: 16px;
  --r-xl: 24px;
  --font-sans: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --font-mono: ui-monospace, "SF Mono", Menlo, monospace;
  --font-display: "Inter Tight", ui-sans-serif, system-ui, sans-serif;
}

* { box-sizing: border-box; }
body {
  margin: 0; background: var(--bg); color: var(--ink);
  font-family: var(--font-sans); font-size: 15px; line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
a:hover { color: var(--accent); }
code, pre { font-family: var(--font-mono); }
img { max-width: 100%; display: block; }

/* ── topbar ───────────────────────────────────────────────────────── */
.fw-topbar {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in oklch, var(--bg) 84%, transparent);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--line);
}
.fw-topbar__row {
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px; padding: 10px 28px; max-width: 1280px; margin: 0 auto;
}
.fw-topbar__brand { display: flex; align-items: center; gap: 10px; font-weight: 600; letter-spacing: 0.02em; }
.fw-topbar__brand-dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  box-shadow: 0 0 18px var(--accent);
}
.fw-topbar__primary { display: flex; gap: 18px; color: var(--ink-dim); font-size: 13px; flex-wrap: wrap; }
.fw-topbar__primary a { transition: color 160ms; }
.fw-topbar__primary a:hover { color: var(--ink); }
.fw-topbar__primary a.is-current { color: var(--accent); position: relative; }
.fw-topbar__primary a.is-current::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: -12px; height: 2px; background: var(--accent);
}

/* ── page header (used by indexes) ────────────────────────────────── */
.hero { max-width: 1200px; margin: 0 auto; padding: 80px 28px 40px; }
.hero__eyebrow { font-size: 12px; text-transform: uppercase; letter-spacing: 0.22em; color: var(--accent); margin-bottom: 16px; }
.hero__title {
  font-family: var(--font-display);
  font-size: clamp(36px, 5.4vw, 64px);
  font-weight: 200; letter-spacing: -0.03em; line-height: 1.02;
  margin: 0 0 18px; max-width: 22ch;
  background: linear-gradient(120deg, var(--ink), var(--accent) 60%, var(--accent-3));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.hero__sub { color: var(--ink-dim); max-width: 64ch; font-size: 16px; margin: 0; }
.hero__meta {
  margin-top: 18px; display: flex; gap: 14px; flex-wrap: wrap;
  font-size: 12px; color: var(--ink-faint); font-family: var(--font-mono); letter-spacing: 0.05em;
}
.hero__meta a { color: var(--accent-2); }

/* ── index grid (template-type cards + variant cards) ─────────────── */
.tpl-list { container-type: inline-size; container-name: tpl-list; max-width: 1280px; margin: 0 auto; padding: 16px 28px 80px; }
.tpl-grid { display: grid; gap: 22px; grid-template-columns: 1fr; }
@container tpl-list (min-width: 600px)  { .tpl-grid { grid-template-columns: repeat(2, 1fr); } }
@container tpl-list (min-width: 1000px) { .tpl-grid { grid-template-columns: repeat(3, 1fr); } }

.tpl-card {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--r-lg);
  padding: 20px; display: flex; flex-direction: column; gap: 14px;
  transition: border-color 220ms, transform 220ms;
}
.tpl-card:hover { border-color: var(--line-strong); transform: translateY(-2px); color: inherit; }
.tpl-card__preview {
  aspect-ratio: 16/10; border-radius: var(--r-md); border: 1px solid var(--line);
  position: relative; overflow: hidden;
  background: linear-gradient(135deg, #1c1740 0%, #3a1d57 60%, #5b1d57 100%);
}
.tpl-card__preview::after {
  content: attr(data-preview);
  position: absolute; inset: 0; display: grid; place-items: center;
  color: rgba(255,255,255,0.66);
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
  text-shadow: 0 1px 4px rgba(0,0,0,0.6);
}
.tpl-card__num { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ink-faint); }
.tpl-card__title { font-family: var(--font-display); font-size: 22px; font-weight: 500; margin: 0; letter-spacing: -0.01em; }
.tpl-card__desc { color: var(--ink-dim); font-size: 13px; margin: 0; line-height: 1.55; }
.tpl-card__chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 4px; }
.tpl-card__chip {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  padding: 4px 8px; border-radius: 999px;
  background: color-mix(in oklch, var(--accent) 14%, var(--bg-elev-2));
  color: var(--ink-dim); border: 1px solid var(--line);
}
.tpl-card__slug { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ink-faint); margin-top: auto; }

/* preview palettes */
.prev-1 { background: linear-gradient(135deg, #1c1740 0%, #3a1d57 60%, #5b1d57 100%); }
.prev-2 { background: linear-gradient(120deg, #102036 0%, #2a1a4a 100%); }
.prev-3 { background: linear-gradient(160deg, #1a0e2c, #2a1a4a 50%, #3b1d4a); }
.prev-4 { background: linear-gradient(135deg, #11141f, #1a2236 100%); }
.prev-5 { background: linear-gradient(135deg, #0c1428, #1a253e); }
.prev-6 { background: linear-gradient(135deg, #1c1740, #0a1230 100%); }
.prev-7 { background: conic-gradient(from 220deg, #1a0e2c, #2a1a4a, #3a1d57, #1a0e2c); }
.prev-8 { background: linear-gradient(120deg, #181530, #2a1a4a 50%, #4a1f2a 100%); }
.prev-9 { background: linear-gradient(135deg, #14102c, #20254a 100%); }
.prev-10 { background: linear-gradient(135deg, #1a2236, #2a1a4a 60%, #3a1d57); }

.foot {
  max-width: 1280px; margin: 24px auto 0; padding: 32px 28px;
  border-top: 1px solid var(--line); color: var(--ink-faint); font-size: 13px;
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 16px;
}
.foot a { color: var(--accent-2); }

/* ───────────────────────────────────────────────────────────────────
   PAGE-TEMPLATE PRIMITIVES
   Used by every v1..v4 page. Composes existing visual language.
   container-queries only, no @media for layout.
   ─────────────────────────────────────────────────────────────────── */

.pg { container-type: inline-size; container-name: pg; }
.pg-wrap { max-width: 1200px; margin: 0 auto; padding: 0 28px; }

/* Section spacing rhythm */
.pg-section { padding-block: 80px; position: relative; }
.pg-section--tight { padding-block: 48px; }
.pg-section--hero { padding-block: 96px 64px; }
.pg-section--alt { background: var(--bg-elev); border-block: 1px solid var(--line); }

/* Section eyebrow + title */
.pg-eyebrow { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--accent); margin: 0 0 12px; }
.pg-h1 { font-family: var(--font-display); font-size: clamp(40px, 6vw, 80px); font-weight: 200; letter-spacing: -0.03em; line-height: 1.0; margin: 0 0 20px; }
.pg-h1--gradient { background: linear-gradient(120deg, var(--ink), var(--accent) 60%, var(--accent-3)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.pg-h2 { font-family: var(--font-display); font-size: clamp(30px, 4vw, 48px); font-weight: 300; letter-spacing: -0.02em; line-height: 1.1; margin: 0 0 16px; }
.pg-h3 { font-family: var(--font-display); font-size: clamp(20px, 2.2vw, 26px); font-weight: 500; letter-spacing: -0.01em; margin: 0 0 10px; }
.pg-lead { color: var(--ink-dim); font-size: clamp(16px, 1.4vw, 19px); line-height: 1.55; max-width: 64ch; margin: 0 0 24px; }
.pg-text { color: var(--ink-dim); font-size: 15px; line-height: 1.7; max-width: 64ch; margin: 0 0 14px; }

/* CTA row */
.pg-cta-row { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }

/* Grid helpers — container-query responsive */
.pg-grid { display: grid; gap: 22px; grid-template-columns: 1fr; }
.pg-grid--2 { grid-template-columns: 1fr; }
.pg-grid--3 { grid-template-columns: 1fr; }
.pg-grid--4 { grid-template-columns: 1fr; }
.pg-grid--6 { grid-template-columns: 1fr; }
@container pg (min-width: 640px)  { .pg-grid--2 { grid-template-columns: repeat(2, 1fr); } .pg-grid--3 { grid-template-columns: repeat(2, 1fr); } .pg-grid--4 { grid-template-columns: repeat(2, 1fr); } .pg-grid--6 { grid-template-columns: repeat(2, 1fr); } }
@container pg (min-width: 980px)  { .pg-grid--3 { grid-template-columns: repeat(3, 1fr); } .pg-grid--4 { grid-template-columns: repeat(4, 1fr); } .pg-grid--6 { grid-template-columns: repeat(3, 1fr); } }
@container pg (min-width: 1200px) { .pg-grid--6 { grid-template-columns: repeat(6, 1fr); } }

.pg-split { display: grid; gap: 36px; grid-template-columns: 1fr; align-items: center; }
@container pg (min-width: 880px) { .pg-split { grid-template-columns: 1fr 1fr; gap: 56px; } }
.pg-split--40-60 { display: grid; gap: 36px; grid-template-columns: 1fr; }
@container pg (min-width: 880px) { .pg-split--40-60 { grid-template-columns: 2fr 3fr; gap: 56px; } }
.pg-split--60-40 { display: grid; gap: 36px; grid-template-columns: 1fr; }
@container pg (min-width: 880px) { .pg-split--60-40 { grid-template-columns: 3fr 2fr; gap: 56px; } }

/* Card surface (re-skinned from .lsd-card / .im-card) */
.pg-card {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--r-lg);
  padding: 24px; display: flex; flex-direction: column; gap: 12px;
  transition: border-color 220ms, transform 220ms;
}
.pg-card:hover { border-color: var(--line-strong); }
.pg-card--feature { padding: 28px; }
.pg-card--solid { background: var(--bg-elev-2); }
.pg-card--outlined { background: transparent; }
.pg-card--highlight { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent), 0 24px 60px -36px color-mix(in oklch, var(--accent) 60%, transparent); }
.pg-card__icon { width: 38px; height: 38px; border-radius: 10px; background: color-mix(in oklch, var(--accent) 18%, var(--bg-elev-2)); color: var(--accent); display: grid; place-items: center; font-size: 18px; }
.pg-card__title { font-family: var(--font-display); font-size: 20px; font-weight: 500; margin: 0; letter-spacing: -0.01em; }
.pg-card__desc { color: var(--ink-dim); font-size: 14px; margin: 0; line-height: 1.6; }
.pg-card__meta { display: flex; gap: 12px; font-size: 12px; color: var(--ink-faint); font-family: var(--font-mono); margin-top: auto; letter-spacing: 0.05em; text-transform: uppercase; }
.pg-card__price { font-family: var(--font-display); font-size: 40px; font-weight: 300; color: var(--ink); letter-spacing: -0.02em; }
.pg-card__price small { font-size: 14px; color: var(--ink-faint); letter-spacing: 0.04em; }

/* Image / mock frame */
.pg-mock {
  position: relative; overflow: hidden;
  border: 1px solid var(--line); border-radius: var(--r-lg);
  background: var(--bg-elev-2);
  aspect-ratio: 16/10;
}
.pg-mock--square { aspect-ratio: 1/1; }
.pg-mock--portrait { aspect-ratio: 9/16; max-width: 360px; }
.pg-mock--wide { aspect-ratio: 21/9; }
.pg-mock--screen {
  background:
    linear-gradient(180deg, rgba(255,255,255,0.04), transparent 40%),
    linear-gradient(135deg, color-mix(in oklch, var(--accent) 22%, var(--bg-elev-2)) 0%, color-mix(in oklch, var(--accent-3) 22%, var(--bg-elev-2)) 100%);
}
.pg-mock--ux { background: linear-gradient(135deg, #11141f, #1a2236 60%, #3a1d57 130%); }
.pg-mock--portrait-photo { background: linear-gradient(160deg, color-mix(in oklch, var(--accent-3) 30%, var(--bg-elev-2)), color-mix(in oklch, var(--accent) 25%, var(--bg-elev-2))); }
.pg-mock--photo-1 { background: linear-gradient(120deg, #2a1a4a 0%, #4a1f2a 100%); }
.pg-mock--photo-2 { background: linear-gradient(135deg, #102036, #2a1a4a 100%); }
.pg-mock--photo-3 { background: linear-gradient(135deg, #14102c, #3a1d57 100%); }
.pg-mock--photo-4 { background: linear-gradient(120deg, #1a253e, #1c1740 100%); }
.pg-mock--photo-5 { background: linear-gradient(160deg, #20254a, #3b1d4a 100%); }
.pg-mock--photo-6 { background: linear-gradient(180deg, #181530, #5b1d57 100%); }
.pg-mock__label {
  position: absolute; left: 14px; bottom: 14px;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
  background: color-mix(in oklch, var(--bg) 70%, transparent);
  padding: 5px 10px; border-radius: 999px; border: 1px solid var(--line);
}

/* Chips / pills */
.pg-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 12px; border-radius: 999px;
  background: color-mix(in oklch, var(--accent) 14%, var(--bg-elev-2));
  color: var(--ink-dim); border: 1px solid var(--line);
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
}
.pg-chip--solid { background: var(--accent); color: #0a0716; border-color: transparent; }
.pg-chip--outlined { background: transparent; color: var(--accent); border-color: var(--accent); }
.pg-chip--ok { background: color-mix(in oklch, var(--ok) 22%, var(--bg-elev-2)); color: var(--ok); }
.pg-chip--info { background: color-mix(in oklch, var(--accent-2) 22%, var(--bg-elev-2)); color: var(--accent-2); }
.pg-chip-cloud { display: flex; flex-wrap: wrap; gap: 8px; }

/* Button — uses .lsd-btn shape but template-scoped fallback */
.pg-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 12px 20px; border: 1px solid transparent; border-radius: var(--r-md);
  background: var(--accent); color: #0a0716;
  font-family: var(--font-sans); font-size: 14px; font-weight: 500; letter-spacing: 0.01em;
  cursor: pointer; text-decoration: none; user-select: none;
  transition: transform 180ms cubic-bezier(0.22,1,0.36,1), background 180ms, color 180ms, border-color 180ms;
}
.pg-btn:hover { transform: translateY(-1px); color: #0a0716; }
.pg-btn--lg { padding: 16px 28px; font-size: 16px; }
.pg-btn--ghost { background: transparent; color: var(--ink); border-color: var(--line-strong); }
.pg-btn--ghost:hover { color: var(--ink); border-color: var(--ink); }
.pg-btn--outlined { background: transparent; color: var(--accent); border-color: var(--accent); }
.pg-btn--outlined:hover { color: var(--accent); border-color: var(--accent-2); }
.pg-btn--block { width: 100%; }

/* Field / form */
.pg-field { display: flex; flex-direction: column; gap: 6px; }
.pg-field__label { font-size: 12px; color: var(--ink-dim); letter-spacing: 0.04em; }
.pg-input {
  font-family: var(--font-sans); font-size: 14px;
  padding: 12px 14px; width: 100%;
  background: var(--bg-elev-2); color: var(--ink);
  border: 1px solid var(--line-strong); border-radius: var(--r-md);
  transition: border-color 180ms;
}
.pg-input:focus { outline: none; border-color: var(--accent); }
.pg-textarea { resize: vertical; min-height: 120px; }
.pg-select { appearance: none; background-image: linear-gradient(45deg, transparent 50%, var(--ink-dim) 50%), linear-gradient(135deg, var(--ink-dim) 50%, transparent 50%); background-position: calc(100% - 18px) center, calc(100% - 13px) center; background-size: 5px 5px; background-repeat: no-repeat; padding-right: 36px; }

/* Trust strip */
.pg-logos { display: flex; flex-wrap: wrap; align-items: center; gap: 28px 40px; opacity: 0.7; }
.pg-logo {
  font-family: var(--font-display); font-size: 18px; font-weight: 500; letter-spacing: -0.01em;
  color: var(--ink-dim); padding: 8px 14px; border: 1px solid var(--line); border-radius: var(--r-md);
}

/* Stats */
.pg-stats { display: grid; gap: 18px; grid-template-columns: 1fr; }
@container pg (min-width: 640px) { .pg-stats { grid-template-columns: repeat(2, 1fr); } }
@container pg (min-width: 980px) { .pg-stats { grid-template-columns: repeat(4, 1fr); } }
.pg-stat { padding: 22px; border: 1px solid var(--line); border-radius: var(--r-lg); background: var(--bg-elev); }
.pg-stat__num { font-family: var(--font-display); font-size: clamp(36px, 4vw, 56px); font-weight: 300; letter-spacing: -0.02em; background: linear-gradient(120deg, var(--ink), var(--accent)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.pg-stat__label { color: var(--ink-dim); font-size: 13px; margin-top: 4px; }

/* FAQ */
.pg-faq { display: flex; flex-direction: column; gap: 8px; }
.pg-faq details {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--r-md);
  padding: 4px 18px;
}
.pg-faq details[open] { border-color: var(--line-strong); }
.pg-faq summary {
  cursor: pointer; padding: 14px 0; font-family: var(--font-display); font-size: 17px; font-weight: 500;
  list-style: none; display: flex; justify-content: space-between; gap: 16px;
}
.pg-faq summary::-webkit-details-marker { display: none; }
.pg-faq summary::after { content: '+'; color: var(--accent); font-size: 22px; line-height: 1; }
.pg-faq details[open] summary::after { content: '−'; }
.pg-faq__body { padding: 0 0 18px; color: var(--ink-dim); font-size: 14px; line-height: 1.65; }

/* Footer (page-level, not the small framework foot) */
.pg-footer { background: var(--bg-elev); border-top: 1px solid var(--line); padding: 64px 28px 32px; margin-top: 64px; }
.pg-footer__wrap { max-width: 1200px; margin: 0 auto; display: grid; gap: 36px; grid-template-columns: 1fr; }
@container pg (min-width: 720px) { .pg-footer__wrap { grid-template-columns: 2fr 1fr 1fr 1fr; } }
.pg-footer__brand { display: flex; flex-direction: column; gap: 12px; max-width: 36ch; }
.pg-footer__brand-name { font-family: var(--font-display); font-size: 22px; font-weight: 500; }
.pg-footer__col-title { font-size: 12px; text-transform: uppercase; letter-spacing: 0.22em; color: var(--ink-faint); margin: 0 0 12px; }
.pg-footer__links { display: flex; flex-direction: column; gap: 8px; color: var(--ink-dim); font-size: 14px; }
.pg-footer__legal { max-width: 1200px; margin: 48px auto 0; padding-top: 24px; border-top: 1px solid var(--line); display: flex; justify-content: space-between; font-size: 12px; color: var(--ink-faint); flex-wrap: wrap; gap: 12px; }

/* Page-level brand topbar (template-only) */
.pg-topbar { position: sticky; top: 0; z-index: 60; background: color-mix(in oklch, var(--bg) 88%, transparent); backdrop-filter: blur(14px); border-bottom: 1px solid var(--line); }
.pg-topbar__row { max-width: 1200px; margin: 0 auto; padding: 14px 28px; display: flex; align-items: center; gap: 24px; justify-content: space-between; }
.pg-topbar__brand { display: flex; align-items: center; gap: 10px; font-family: var(--font-display); font-weight: 600; }
.pg-topbar__brand-dot { width: 12px; height: 12px; border-radius: 3px; background: linear-gradient(135deg, var(--accent), var(--accent-3)); }
.pg-topbar__nav { display: flex; gap: 22px; font-size: 14px; color: var(--ink-dim); flex-wrap: wrap; }
.pg-topbar__nav a:hover { color: var(--ink); }
.pg-topbar__cta { display: flex; gap: 10px; }

/* Tag/category strip */
.pg-tags { display: flex; flex-wrap: wrap; gap: 8px; }

/* Tabs */
.pg-tabs { display: flex; gap: 4px; border-bottom: 1px solid var(--line); margin-bottom: 24px; flex-wrap: wrap; }
.pg-tab { padding: 12px 16px; cursor: pointer; color: var(--ink-dim); border-bottom: 2px solid transparent; font-size: 14px; }
.pg-tab.is-active { color: var(--accent); border-bottom-color: var(--accent); }

/* Table */
.pg-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.pg-table th, .pg-table td { padding: 14px 16px; text-align: left; border-bottom: 1px solid var(--line); }
.pg-table th { color: var(--ink-faint); font-weight: 500; font-size: 12px; text-transform: uppercase; letter-spacing: 0.1em; }
.pg-table tr:hover td { background: color-mix(in oklch, var(--accent) 6%, transparent); }
.pg-table .ok { color: var(--ok); }
.pg-table .no { color: var(--ink-faint); }

/* Article body */
.pg-article { max-width: 720px; margin: 0 auto; }
.pg-article p { color: var(--ink); font-size: 17px; line-height: 1.75; margin: 0 0 24px; }
.pg-article h2 { font-family: var(--font-display); font-size: 30px; font-weight: 400; letter-spacing: -0.02em; margin: 48px 0 16px; }
.pg-article h3 { font-family: var(--font-display); font-size: 22px; font-weight: 500; margin: 36px 0 12px; }
.pg-article blockquote { border-left: 3px solid var(--accent); padding: 4px 0 4px 24px; margin: 32px 0; font-family: var(--font-display); font-size: 22px; font-weight: 300; font-style: italic; color: var(--ink); }
.pg-article pre { background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--r-md); padding: 18px; overflow-x: auto; font-size: 13px; line-height: 1.6; margin: 24px 0; color: var(--ink-dim); }
.pg-article ul, .pg-article ol { color: var(--ink); font-size: 17px; line-height: 1.7; padding-left: 22px; }
.pg-article li { margin-bottom: 8px; }

/* Sidebar layout (docs / longform) */
.pg-sidebar-layout { display: grid; gap: 36px; grid-template-columns: 1fr; }
@container pg (min-width: 1000px) { .pg-sidebar-layout { grid-template-columns: 220px 1fr; } }
.pg-sidebar-layout--3 { display: grid; gap: 36px; grid-template-columns: 1fr; }
@container pg (min-width: 1100px) { .pg-sidebar-layout--3 { grid-template-columns: 220px 1fr 220px; } }
.pg-toc { position: sticky; top: 80px; font-size: 13px; color: var(--ink-dim); align-self: start; }
.pg-toc h4 { font-size: 11px; text-transform: uppercase; letter-spacing: 0.18em; color: var(--ink-faint); margin: 0 0 12px; }
.pg-toc ol, .pg-toc ul { padding-left: 18px; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.pg-toc a:hover { color: var(--accent); }

/* Marquee strip */
.pg-marquee { overflow: hidden; border-block: 1px solid var(--line); padding-block: 24px; background: var(--bg-elev); }
.pg-marquee__track { display: flex; gap: 56px; animation: pg-marquee 32s linear infinite; white-space: nowrap; }
@media (prefers-reduced-motion: reduce) { .pg-marquee__track { animation: none; } }
@keyframes pg-marquee { to { transform: translateX(-50%); } }
.pg-marquee__item { font-family: var(--font-display); font-size: 24px; color: var(--ink-dim); display: inline-flex; align-items: center; gap: 16px; }
.pg-marquee__dot { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); }

/* Process steps */
.pg-steps { display: grid; gap: 22px; grid-template-columns: 1fr; counter-reset: pg-step; }
@container pg (min-width: 720px) { .pg-steps { grid-template-columns: repeat(3, 1fr); } }
.pg-steps--4 { grid-template-columns: 1fr; }
@container pg (min-width: 720px) { .pg-steps--4 { grid-template-columns: repeat(2, 1fr); } }
@container pg (min-width: 1000px) { .pg-steps--4 { grid-template-columns: repeat(4, 1fr); } }
.pg-step { padding: 24px; border: 1px solid var(--line); border-radius: var(--r-lg); background: var(--bg-elev); position: relative; }
.pg-step::before { counter-increment: pg-step; content: "0" counter(pg-step); font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.22em; color: var(--accent); }
.pg-step h3 { margin: 12px 0 6px; font-family: var(--font-display); font-size: 20px; font-weight: 500; }
.pg-step p { color: var(--ink-dim); font-size: 14px; margin: 0; }

/* Quote */
.pg-quote {
  font-family: var(--font-display); font-size: clamp(22px, 2.6vw, 32px);
  font-weight: 300; letter-spacing: -0.01em; line-height: 1.35; color: var(--ink);
  max-width: 36ch;
}
.pg-quote__attr { display: flex; align-items: center; gap: 12px; margin-top: 20px; font-size: 14px; color: var(--ink-dim); }
.pg-quote__avatar { width: 44px; height: 44px; border-radius: 50%; background: linear-gradient(135deg, var(--accent), var(--accent-3)); }

/* Hero gradient (page-template hero) */
.pg-hero {
  position: relative; overflow: hidden;
  padding: 96px 28px 96px;
}
.pg-hero::before {
  content: ''; position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(60% 50% at 20% 20%, color-mix(in oklch, var(--accent) 30%, transparent), transparent 70%),
    radial-gradient(60% 50% at 80% 80%, color-mix(in oklch, var(--accent-3) 25%, transparent), transparent 70%);
}
.pg-hero > * { position: relative; z-index: 1; }
.pg-hero__wrap { max-width: 1200px; margin: 0 auto; }

/* Newsletter strip */
.pg-newsletter { background: var(--bg-elev); border-block: 1px solid var(--line); padding: 56px 28px; }
.pg-newsletter__wrap { max-width: 720px; margin: 0 auto; text-align: center; display: flex; flex-direction: column; gap: 16px; align-items: center; }
.pg-newsletter__form { display: flex; gap: 8px; width: 100%; max-width: 480px; flex-wrap: wrap; justify-content: center; }
.pg-newsletter__form .pg-input { flex: 1; min-width: 200px; }

/* Entrance animations (chained on key sections) */
@keyframes pg-fadeUp { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: none; } }
.pg-fx-rise { animation: pg-fadeUp 720ms cubic-bezier(0.2, 0.8, 0.2, 1) both; }
.pg-fx-rise--d1 { animation-delay: 80ms; }
.pg-fx-rise--d2 { animation-delay: 160ms; }
.pg-fx-rise--d3 { animation-delay: 240ms; }
.pg-fx-rise--d4 { animation-delay: 320ms; }
@media (prefers-reduced-motion: reduce) {
  .pg-fx-rise, .pg-fx-rise--d1, .pg-fx-rise--d2, .pg-fx-rise--d3, .pg-fx-rise--d4 { animation: none; opacity: 1; transform: none; }
}

/* Pull-quote / large stat callout */
.pg-pullquote { font-family: var(--font-display); font-size: clamp(28px, 4vw, 44px); font-weight: 300; letter-spacing: -0.02em; line-height: 1.2; max-width: 30ch; }

/* Masonry-ish gallery */
.pg-mas { display: grid; gap: 16px; grid-template-columns: 1fr; }
@container pg (min-width: 640px) { .pg-mas { grid-template-columns: repeat(2, 1fr); } }
@container pg (min-width: 980px) { .pg-mas { grid-template-columns: repeat(3, 1fr); } }
.pg-mas > :nth-child(3n+1) { aspect-ratio: 4/5; }
.pg-mas > :nth-child(3n+2) { aspect-ratio: 1/1; }
.pg-mas > :nth-child(3n) { aspect-ratio: 4/3; }

/* Article meta strip */
.pg-meta { display: flex; flex-wrap: wrap; gap: 18px; align-items: center; font-size: 13px; color: var(--ink-faint); }
.pg-meta__author { display: flex; align-items: center; gap: 10px; color: var(--ink-dim); }
.pg-meta__author-avatar { width: 32px; height: 32px; border-radius: 50%; background: linear-gradient(135deg, var(--accent-2), var(--accent)); }

/* Timeline */
.pg-timeline { position: relative; padding-left: 32px; }
.pg-timeline::before { content: ''; position: absolute; left: 8px; top: 0; bottom: 0; width: 2px; background: var(--line); }
.pg-timeline__item { position: relative; padding: 16px 0 32px; }
.pg-timeline__item::before { content: ''; position: absolute; left: -28px; top: 22px; width: 14px; height: 14px; border-radius: 50%; background: var(--bg); border: 2px solid var(--accent); }
.pg-timeline__date { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em; color: var(--accent); text-transform: uppercase; }
.pg-timeline__title { font-family: var(--font-display); font-size: 20px; font-weight: 500; margin: 6px 0 8px; }

/* Reveal-on-hover for portfolio tiles */
.pg-reveal { position: relative; overflow: hidden; border-radius: var(--r-lg); border: 1px solid var(--line); cursor: pointer; }
.pg-reveal__media { aspect-ratio: 4/3; }
.pg-reveal__caption {
  position: absolute; inset: auto 0 0 0; padding: 18px 20px;
  background: linear-gradient(180deg, transparent, color-mix(in oklch, var(--bg) 86%, transparent) 60%);
  transform: translateY(40%); opacity: 0;
  transition: transform 280ms cubic-bezier(0.22,1,0.36,1), opacity 280ms;
}
.pg-reveal:hover .pg-reveal__caption { transform: none; opacity: 1; }
.pg-reveal__title { font-family: var(--font-display); font-size: 20px; font-weight: 500; margin: 0; }
.pg-reveal__cat { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--accent); }

/* Pagination */
.pg-pagination { display: flex; gap: 8px; justify-content: center; padding-top: 32px; flex-wrap: wrap; }
.pg-pagination a { padding: 8px 14px; border: 1px solid var(--line); border-radius: var(--r-md); font-family: var(--font-mono); font-size: 13px; color: var(--ink-dim); }
.pg-pagination a:hover { border-color: var(--accent); color: var(--accent); }
.pg-pagination a.is-current { background: var(--accent); color: #0a0716; border-color: transparent; }

/* Office clock strip */
.pg-clock-strip { display: grid; gap: 18px; grid-template-columns: 1fr; }
@container pg (min-width: 640px) { .pg-clock-strip { grid-template-columns: repeat(2, 1fr); } }
@container pg (min-width: 980px) { .pg-clock-strip { grid-template-columns: repeat(4, 1fr); } }
.pg-clock { display: flex; flex-direction: column; gap: 4px; padding: 18px; border: 1px solid var(--line); border-radius: var(--r-md); }
.pg-clock__time { font-family: var(--font-display); font-size: 28px; font-weight: 300; }
.pg-clock__city { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-faint); }

/* Search bar */
.pg-search { display: flex; gap: 8px; max-width: 640px; width: 100%; }
.pg-search .pg-input { flex: 1; }

/* Variant index — slimmer cards */
.tpl-variant-grid { display: grid; gap: 20px; grid-template-columns: 1fr; }
@container tpl-list (min-width: 700px) { .tpl-variant-grid { grid-template-columns: repeat(2, 1fr); } }

/* Filter sidebar */
.pg-filter { display: flex; flex-direction: column; gap: 24px; font-size: 14px; }
.pg-filter h4 { font-size: 12px; text-transform: uppercase; letter-spacing: 0.2em; color: var(--ink-faint); margin: 0 0 8px; }
.pg-filter label { display: flex; gap: 8px; color: var(--ink-dim); padding: 4px 0; cursor: pointer; }
