/* ============================================================
 * Litigation Docs — writing-samples.css
 *
 * Editorial reading-room aesthetic: parchment field, ink text,
 * crimson rationed to sigils and numerals. Each sample is an
 * editorial spread — not a gallery card. The typography does
 * all the structural work; no card backgrounds, no rounded
 * corners, no drop shadows. Letterpress hairlines as dividers.
 *
 * Section order:
 *   1. Width reset & shell
 *   2. Masthead (title + ledger)
 *   3. Empty state
 *   4. Editorial method strip
 *   5. Brief — per-filing editorial spread
 *   6. Compact Register
 *   7. Colophon
 *   8. Reading-room drawer
 *   9. Buttons (shared)
 *  10. Reduced motion
 * ============================================================ */

/* ─── 1. WIDTH RESET & SHELL ─────────────────────────────── */
.ld-main:has(> .ld-samples),
body.post-type-archive-ld_writing_sample .ld-main,
body.single-ld_writing_sample .ld-main {
	max-width: none;
	margin-inline: 0;
	padding: 0;
}

.ld-samples {
	background: var(--ld-parchment);
	color: var(--ld-ink);
	min-height: 100vh;
	padding-bottom: var(--ld-s-8);
	position: relative;
	overflow: hidden;
}

/* Paper-grain overlay for texture — very subtle */
.ld-samples::before {
	content: "";
	position: absolute; inset: 0;
	pointer-events: none;
	opacity: 0.04;
	background-image:
		url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.88' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 1 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
	z-index: 0;
}
.ld-samples > * { position: relative; z-index: 1; }

/* ─── 2. HERO (dark-ink, matches About/Contact pattern) ─── */
.ld-samples-hero {
	background: var(--ld-ink);
	color: var(--ld-parchment);
	padding: clamp(64px, 8vw, 120px) 0;  /* vertical only — inner handles horizontal */
	position: relative;
	overflow: hidden;
}
/* Subtle crimson glow in top-right corner (matches About) */
.ld-samples-hero::before {
	content: "";
	position: absolute;
	top: 0; right: 0;
	width: 60%; height: 100%;
	background: radial-gradient(ellipse at top right,
		rgba(172, 31, 43, 0.14),
		transparent 65%);
	pointer-events: none;
}
/* Paper grain overlay for depth */
.ld-samples-hero::after {
	content: "";
	position: absolute; inset: 0;
	pointer-events: none;
	opacity: 0.045;
	background-image:
		url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.88' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 1 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

.ld-samples-hero__inner {
	position: relative;
	z-index: 1;
	max-width: var(--ld-wide);
	margin-inline: auto;
	padding: 0 var(--ld-s-4);
	display: grid;
	grid-template-columns: minmax(0, 1.4fr) 420px;
	gap: clamp(32px, 5vw, 80px);
	align-items: start;
}
@media (min-width: 1024px) {
	.ld-samples-hero__inner { padding-inline: var(--ld-s-5); }
}
@media (max-width: 1080px) {
	.ld-samples-hero__inner { grid-template-columns: 1fr; gap: clamp(32px, 5vw, 48px); }
}

/* ── Main column (left) ── */
.ld-samples-hero__main { min-width: 0; }

.ld-samples-hero__kicker {
	font-family: var(--ld-mono);
	font-size: 11px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: rgba(247, 243, 236, 0.7);
	margin: 0 0 clamp(24px, 3vw, 36px);
	display: inline-flex;
	align-items: center;
	gap: 14px;
	flex-wrap: wrap;
}
.ld-samples-hero__kicker-rule {
	display: inline-block;
	width: 40px;
	height: 1px;
	background: var(--ld-crimson);
}
.ld-samples-hero__kicker-sigil {
	color: var(--ld-crimson);
	font-family: var(--ld-serif);
	font-style: italic;
	font-size: 15px;
	font-weight: 400;
	letter-spacing: 0.01em;
	text-transform: none;
}
.ld-samples-hero__kicker-sigil em {
	font-style: italic;
	font-weight: 400;
	margin-right: 2px;
}
.ld-samples-hero__kicker-label {
	font-family: var(--ld-mono);
	color: rgba(247, 243, 236, 0.7);
	letter-spacing: 0.2em;
}

.ld-samples-hero__title {
	font-family: var(--ld-serif);
	font-size: clamp(52px, 7.5vw, 104px);
	font-weight: 300;
	line-height: 1.02;
	letter-spacing: -0.03em;
	color: var(--ld-parchment);
	margin: 0 0 clamp(24px, 3vw, 36px);
	max-width: 15ch;
}
.ld-samples-hero__title em {
	font-style: italic;
	font-weight: 300;
	color: var(--ld-crimson);
}

.ld-samples-hero__standfirst {
	font-family: var(--ld-serif);
	font-size: clamp(17px, 1.5vw, 20px);
	line-height: 1.55;
	color: rgba(247, 243, 236, 0.82);
	margin: 0 0 clamp(32px, 4vw, 44px);
	max-width: 58ch;
	font-weight: 400;
}

.ld-samples-hero__actions {
	display: flex;
	gap: 14px;
	flex-wrap: wrap;
	margin: 0;
}

/* ── Facts of the volume panel (right) ── */
.ld-samples-hero__facts {
	position: relative;
	padding: clamp(24px, 2vw, 32px) clamp(24px, 2vw, 32px) clamp(20px, 2vw, 28px);
	background: rgba(247, 243, 236, 0.04);
	border: 1px solid rgba(247, 243, 236, 0.1);
	backdrop-filter: blur(2px);
	-webkit-backdrop-filter: blur(2px);
}
.ld-samples-hero__facts-rule {
	position: absolute;
	top: -1px; left: 16px; right: 16px;
	height: 1px;
	background: linear-gradient(90deg,
		transparent 0%,
		var(--ld-crimson) 15%,
		var(--ld-crimson) 85%,
		transparent 100%);
}

.ld-samples-hero__facts-head {
	font-family: var(--ld-mono);
	font-size: 11px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: rgba(247, 243, 236, 0.72);
	margin: 0 0 14px;
	padding-bottom: 14px;
	border-bottom: 1px solid rgba(247, 243, 236, 0.08);
	display: flex;
	align-items: center;
	gap: 10px;
}
.ld-samples-hero__facts-sigil {
	color: var(--ld-crimson);
	font-family: var(--ld-serif);
	font-style: italic;
	font-size: 18px;
	font-weight: 300;
	line-height: 0.7;
	transform: translateY(1px);
}

.ld-samples-hero__facts-list { margin: 0; padding: 0; }
.ld-samples-hero__facts-row {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 16px;
	padding: 11px 0;
	border-bottom: 1px solid rgba(247, 243, 236, 0.07);
}
.ld-samples-hero__facts-row:last-child { border-bottom: none; padding-bottom: 2px; }
.ld-samples-hero__facts-row dt {
	font-family: var(--ld-mono);
	font-size: 10.5px;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: rgba(247, 243, 236, 0.55);
	flex-shrink: 0;
}
.ld-samples-hero__facts-row dd {
	margin: 0;
	text-align: right;
	display: flex;
	align-items: baseline;
	gap: 8px;
	flex-wrap: wrap;
	justify-content: flex-end;
	min-width: 0;
}
.ld-samples-hero__facts-num {
	font-family: var(--ld-serif);
	font-size: 22px;
	font-weight: 400;
	color: var(--ld-parchment);
	line-height: 1;
	letter-spacing: -0.01em;
}
.ld-samples-hero__facts-sub {
	font-family: var(--ld-serif);
	font-size: 14px;
	font-style: italic;
	color: rgba(247, 243, 236, 0.82);
	letter-spacing: 0;
	line-height: 1.3;
	font-weight: 400;
}
.ld-samples-hero__facts-sub--solo {
	font-size: 14px;
	font-style: italic;
	color: rgba(247, 243, 236, 0.82);
}

/* ─── 3. EMPTY STATE ─────────────────────────────────────── */
.ld-samples-empty {
	padding: clamp(64px, 8vw, 120px) var(--ld-s-4);
	text-align: center;
}
@media (min-width: 1024px) {
	.ld-samples-empty { padding-inline: var(--ld-s-5); }
}
.ld-samples-empty__inner { max-width: 56ch; margin: 0 auto; }
.ld-samples-empty__kicker {
	font-family: var(--ld-mono);
	font-size: 12px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--ld-crimson);
	margin: 0 0 var(--ld-s-4);
}
.ld-samples-empty__title {
	font-family: var(--ld-serif);
	font-size: clamp(40px, 5vw, 60px);
	font-weight: 300;
	line-height: 1.05;
	color: var(--ld-ink);
	letter-spacing: -0.02em;
	margin: 0 0 var(--ld-s-4);
}
.ld-samples-empty__title em {
	color: var(--ld-crimson);
	font-style: italic;
	font-weight: 300;
}
.ld-samples-empty__body {
	font-family: var(--ld-serif);
	font-size: 19px;
	line-height: 1.6;
	color: var(--ld-slate);
	margin: 0 0 var(--ld-s-5);
}
.ld-samples-empty__cta {
	display: flex;
	gap: 14px;
	justify-content: center;
	flex-wrap: wrap;
}

/* ─── 4. EDITORIAL METHOD ────────────────────────────────── */
.ld-samples-method {
	padding: clamp(56px, 6vw, 88px) 0;
	border-top: 1px solid var(--ld-rule-strong);
	border-bottom: 1px solid var(--ld-rule-strong);
	background: var(--ld-parchment-alt);
}
.ld-samples-method__inner {
	max-width: var(--ld-wide);
	margin-inline: auto;
	padding: 0 var(--ld-s-4);
}
@media (min-width: 1024px) {
	.ld-samples-method__inner { padding-inline: var(--ld-s-5); }
}
.ld-samples-method__head {
	margin-bottom: clamp(32px, 4vw, 56px);
}
.ld-samples-method__kicker {
	font-family: var(--ld-mono);
	font-size: 12px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--ld-muted);
	margin: 0 0 14px;
	display: inline-flex;
	align-items: baseline;
	gap: 12px;
}
.ld-samples-method__num {
	color: var(--ld-crimson);
	font-family: var(--ld-serif);
	font-style: italic;
	font-size: 18px;
	font-weight: 400;
	letter-spacing: 0;
}
.ld-samples-method__title {
	font-family: var(--ld-serif);
	font-size: clamp(32px, 3.8vw, 48px);
	font-weight: 300;
	letter-spacing: -0.015em;
	line-height: 1.1;
	color: var(--ld-ink);
	margin: 0;
	max-width: 22ch;
}

.ld-samples-method__columns {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0;
}
@media (max-width: 860px) {
	.ld-samples-method__columns { grid-template-columns: 1fr; }
}
.ld-samples-method__col {
	padding: var(--ld-s-4) var(--ld-s-5);
	border-right: 1px solid var(--ld-rule);
	position: relative;
}
.ld-samples-method__col:first-child { padding-left: 0; }
.ld-samples-method__col:last-child { border-right: none; padding-right: 0; }
@media (max-width: 860px) {
	.ld-samples-method__col {
		border-right: none;
		border-bottom: 1px solid var(--ld-rule);
		padding: var(--ld-s-4) 0;
	}
	.ld-samples-method__col:last-child { border-bottom: none; }
}
.ld-samples-method__col-num {
	font-family: var(--ld-serif);
	font-style: italic;
	font-size: 22px;
	font-weight: 300;
	color: var(--ld-crimson);
	letter-spacing: -0.01em;
	display: block;
	margin-bottom: 10px;
}
.ld-samples-method__col-title {
	font-family: var(--ld-serif);
	font-size: 22px;
	font-weight: 400;
	letter-spacing: -0.01em;
	line-height: 1.25;
	margin: 0 0 10px;
	color: var(--ld-ink);
}
.ld-samples-method__col p {
	font-family: var(--ld-serif);
	font-size: 16px;
	line-height: 1.6;
	color: var(--ld-slate);
	margin: 0;
	max-width: 40ch;
}

/* ─── 5. BRIEF — per-filing editorial spread ─────────────── */
.ld-brief {
	padding: clamp(56px, 7vw, 100px) 0;
	border-bottom: 1px solid var(--ld-rule-strong);
}
.ld-brief:last-of-type { border-bottom: none; }
.ld-brief__inner {
	max-width: var(--ld-wide);
	margin-inline: auto;
	padding: 0 var(--ld-s-4);
}
@media (min-width: 1024px) {
	.ld-brief__inner { padding-inline: var(--ld-s-5); }
}

/* Running header */
.ld-brief__head {
	display: flex;
	align-items: baseline;
	gap: clamp(20px, 3vw, 40px);
	padding-bottom: var(--ld-s-4);
	border-bottom: 1px solid var(--ld-rule);
	margin-bottom: var(--ld-s-5);
	flex-wrap: wrap;
}
.ld-brief__folio {
	display: inline-flex;
	align-items: baseline;
	gap: 10px;
	padding-right: clamp(16px, 2vw, 28px);
	border-right: 1px solid var(--ld-rule-strong);
}
.ld-brief__folio-num {
	font-family: var(--ld-serif);
	font-style: italic;
	font-size: 32px;
	font-weight: 300;
	color: var(--ld-crimson);
	letter-spacing: -0.02em;
	line-height: 1;
}
.ld-brief__folio-label {
	font-family: var(--ld-mono);
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--ld-muted);
}
.ld-brief__meta {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	gap: 14px;
	align-items: baseline;
	flex-wrap: wrap;
	font-family: var(--ld-mono);
	font-size: 11px;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--ld-muted);
}
.ld-brief__meta-item::after {
	content: "·";
	color: var(--ld-crimson);
	margin-left: 14px;
	font-weight: 700;
}
.ld-brief__meta-item:last-child::after { display: none; }
.ld-brief__meta-item--strong {
	color: var(--ld-ink);
	font-weight: 500;
	letter-spacing: 0.18em;
}

/* Display caption */
.ld-brief__caption {
	font-family: var(--ld-serif);
	font-size: clamp(40px, 5.5vw, 76px);
	font-weight: 300;
	line-height: 1.02;
	letter-spacing: -0.025em;
	color: var(--ld-ink);
	margin: 0 0 clamp(32px, 4vw, 56px);
	max-width: 22ch;
}
.ld-brief__caption em {
	font-style: italic;
	font-weight: 300;
}

/* Body layout — two columns: main editorial + spec rail */
.ld-brief__body {
	display: grid;
	grid-template-columns: 1fr 300px;
	gap: clamp(32px, 5vw, 80px);
	align-items: start;
}
@media (max-width: 1024px) {
	.ld-brief__body { grid-template-columns: 1fr; }
}

.ld-brief__main {
	min-width: 0;
	max-width: 64ch;
}

/* Question presented */
.ld-brief__qp {
	margin: 0 0 var(--ld-s-6);
	padding: var(--ld-s-4) 0 var(--ld-s-4) var(--ld-s-4);
	border-left: 3px solid var(--ld-crimson);
	background: linear-gradient(90deg, rgba(172, 31, 43, 0.04), transparent 80%);
}
.ld-brief__qp-kicker {
	font-family: var(--ld-mono);
	font-size: 11px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--ld-crimson);
	margin: 0 0 10px;
}
.ld-brief__qp-body {
	font-family: var(--ld-serif);
	font-size: clamp(22px, 2.2vw, 28px);
	font-style: italic;
	font-weight: 300;
	line-height: 1.4;
	color: var(--ld-ink);
	margin: 0;
	letter-spacing: -0.01em;
	max-width: 48ch;
}

/* Craft note */
.ld-brief__note {
	margin: 0 0 var(--ld-s-6);
}
.ld-brief__note-kicker {
	font-family: var(--ld-mono);
	font-size: 11px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--ld-muted);
	margin: 0 0 12px;
	display: inline-flex;
	align-items: baseline;
	gap: 8px;
}
.ld-brief__note-kicker span[aria-hidden] {
	font-family: var(--ld-serif);
	font-style: italic;
	font-size: 16px;
	color: var(--ld-crimson);
	line-height: 0.7;
	transform: translateY(1px);
}
.ld-brief__note-body {
	font-family: var(--ld-serif);
	font-size: 18px;
	line-height: 1.65;
	color: var(--ld-slate);
}
.ld-brief__note-body p { margin: 0 0 14px; }
.ld-brief__note-body p:last-child { margin: 0; }

/* Reading excerpt — the core editorial treatment */
.ld-brief__excerpt {
	margin: 0 0 var(--ld-s-5);
	padding-top: var(--ld-s-4);
	border-top: 1px solid var(--ld-rule);
}
.ld-brief__excerpt-kicker {
	font-family: var(--ld-mono);
	font-size: 11px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--ld-muted);
	margin: 0 0 var(--ld-s-3);
	display: inline-flex;
	align-items: baseline;
	gap: 8px;
}
.ld-brief__excerpt-kicker span[aria-hidden] {
	font-family: var(--ld-serif);
	font-style: italic;
	font-size: 16px;
	color: var(--ld-crimson);
	line-height: 0.7;
	transform: translateY(1px);
}
.ld-brief__excerpt-body {
	font-family: var(--ld-serif);
	font-size: 19px;
	line-height: 1.75;
	color: var(--ld-ink);
	position: relative;
	/* Drop-cap on the first paragraph for editorial feel */
	padding-left: var(--ld-s-4);
	border-left: 1px solid var(--ld-rule-strong);
}
.ld-brief__excerpt-body p {
	margin: 0 0 var(--ld-s-3);
}
.ld-brief__excerpt-body p:last-child { margin: 0; }
.ld-brief__excerpt-body p:first-child::first-letter {
	font-family: var(--ld-serif);
	font-weight: 300;
	font-size: 4.2em;
	line-height: 0.85;
	float: left;
	margin: 4px 10px 0 0;
	color: var(--ld-crimson);
	font-style: italic;
}

/* Pull-quote fallback (used when excerpt_text isn't filled in) */
.ld-brief__excerpt--quote .ld-brief__excerpt-body { display: none; }
.ld-brief__excerpt-quote {
	font-family: var(--ld-serif);
	font-size: clamp(22px, 2.2vw, 28px);
	font-style: italic;
	font-weight: 300;
	line-height: 1.5;
	color: var(--ld-ink);
	margin: 0;
	padding-left: var(--ld-s-4);
	border-left: 2px solid var(--ld-crimson);
	letter-spacing: -0.005em;
	max-width: 48ch;
}

/* Actions */
.ld-brief__actions {
	display: flex;
	gap: 14px;
	flex-wrap: wrap;
	margin-top: var(--ld-s-5);
	padding-top: var(--ld-s-4);
	border-top: 1px solid var(--ld-rule);
}

/* Spec rail */
.ld-brief__specs {
	position: sticky;
	top: var(--ld-s-4);
	padding: var(--ld-s-4);
	background: var(--ld-white);
	border-top: 3px solid var(--ld-ink);
}
@media (max-width: 1024px) {
	.ld-brief__specs { position: static; }
}
.ld-brief__specs-list { margin: 0; padding: 0; }
.ld-brief__specs-row {
	padding: 12px 0;
	border-bottom: 1px solid var(--ld-rule);
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: var(--ld-s-3);
}
.ld-brief__specs-row:last-child { border-bottom: none; padding-bottom: 0; }
.ld-brief__specs-row:first-child { padding-top: 0; }
.ld-brief__specs-row dt {
	font-family: var(--ld-mono);
	font-size: 10.5px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--ld-muted);
	flex-shrink: 0;
}
.ld-brief__specs-row dd {
	font-family: var(--ld-serif);
	font-size: 17px;
	color: var(--ld-ink);
	margin: 0;
	text-align: right;
	line-height: 1.35;
}
.ld-brief__specs-sub {
	font-family: var(--ld-mono);
	font-size: 10px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--ld-muted);
	margin-left: 6px;
	font-style: normal;
}

.ld-brief__outcome {
	margin-top: var(--ld-s-4);
	padding-top: var(--ld-s-4);
	border-top: 1px dashed var(--ld-rule-strong);
}
.ld-brief__outcome-kicker {
	font-family: var(--ld-mono);
	font-size: 10.5px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--ld-crimson);
	margin: 0 0 6px;
}
.ld-brief__outcome-body {
	font-family: var(--ld-serif);
	font-size: 17px;
	font-style: italic;
	font-weight: 400;
	line-height: 1.4;
	color: var(--ld-ink);
	margin: 0;
	letter-spacing: -0.005em;
}

/* ─── 6. COMPACT REGISTER ────────────────────────────────── */
.ld-samples-index {
	padding: clamp(56px, 7vw, 100px) 0;
	background: var(--ld-parchment-alt);
	border-top: 1px solid var(--ld-rule-strong);
}
.ld-samples-index__inner {
	max-width: var(--ld-wide);
	margin-inline: auto;
	padding: 0 var(--ld-s-4);
}
@media (min-width: 1024px) {
	.ld-samples-index__inner { padding-inline: var(--ld-s-5); }
}
.ld-samples-index__head {
	margin-bottom: clamp(28px, 4vw, 48px);
}
.ld-samples-index__kicker {
	font-family: var(--ld-mono);
	font-size: 12px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--ld-muted);
	margin: 0 0 12px;
	display: inline-flex;
	align-items: baseline;
	gap: 12px;
}
.ld-samples-index__num {
	color: var(--ld-crimson);
	font-family: var(--ld-serif);
	font-style: italic;
	font-size: 18px;
	font-weight: 400;
	letter-spacing: 0;
}
.ld-samples-index__title {
	font-family: var(--ld-serif);
	font-size: clamp(32px, 3.5vw, 44px);
	font-weight: 300;
	letter-spacing: -0.015em;
	line-height: 1.1;
	color: var(--ld-ink);
	margin: 0;
}

.ld-samples-filter {
	display: flex;
	flex-wrap: wrap;
	gap: var(--ld-s-4);
	padding: var(--ld-s-4) 0;
	margin-bottom: var(--ld-s-4);
	border-bottom: 1px solid var(--ld-rule-strong);
	align-items: baseline;
}
.ld-samples-filter__btn {
	appearance: none;
	background: transparent;
	border: none;
	padding: 4px 0;
	cursor: pointer;
	font-family: var(--ld-serif);
	font-size: 20px;
	color: var(--ld-muted);
	letter-spacing: 0;
	line-height: 1;
	transition: color 180ms var(--ld-ease);
	position: relative;
	font-weight: 400;
}
.ld-samples-filter__btn:hover { color: var(--ld-ink); }
.ld-samples-filter__btn.is-active {
	color: var(--ld-crimson);
	font-style: italic;
}
.ld-samples-filter__btn.is-active::after {
	content: "";
	position: absolute;
	left: 0; right: 0;
	bottom: -6px;
	height: 2px;
	background: var(--ld-crimson);
}
.ld-samples-filter__btn sup {
	font-family: var(--ld-mono);
	font-size: 10px;
	letter-spacing: 0.08em;
	color: var(--ld-crimson);
	margin-left: 4px;
	vertical-align: super;
	line-height: 1;
}

.ld-samples-register {
	list-style: none;
	padding: 0;
	margin: 0;
}
.ld-samples-register__row[hidden] { display: none; }
.ld-samples-register__link {
	display: grid;
	grid-template-columns: 48px 1fr auto;
	gap: clamp(16px, 2vw, 32px);
	align-items: baseline;
	padding: 18px 0;
	border-bottom: 1px solid var(--ld-rule);
	color: inherit;
	text-decoration: none;
	transition: background 200ms var(--ld-ease);
}
.ld-samples-register__link:hover {
	background: rgba(172, 31, 43, 0.03);
}
.ld-samples-register__row:last-child .ld-samples-register__link {
	border-bottom: 1px solid var(--ld-rule-strong);
}
.ld-samples-register__folio {
	font-family: var(--ld-serif);
	font-style: italic;
	font-size: 22px;
	font-weight: 300;
	color: var(--ld-crimson);
	letter-spacing: -0.02em;
}
.ld-samples-register__caption {
	display: block;
	font-family: var(--ld-serif);
	font-size: clamp(19px, 1.8vw, 24px);
	font-weight: 400;
	line-height: 1.25;
	letter-spacing: -0.01em;
	color: var(--ld-ink);
	margin-bottom: 4px;
}
.ld-samples-register__meta {
	display: block;
	font-family: var(--ld-mono);
	font-size: 11px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--ld-muted);
}
.ld-samples-register__measures {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
	justify-content: flex-end;
	font-family: var(--ld-mono);
	font-size: 11px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--ld-muted);
}
.ld-samples-register__measures span {
	display: inline-block;
	white-space: nowrap;
}
@media (max-width: 720px) {
	.ld-samples-register__link { grid-template-columns: 32px 1fr; }
	.ld-samples-register__measures { grid-column: 2; justify-content: flex-start; margin-top: 6px; }
}

/* ─── 7. COLOPHON ────────────────────────────────────────── */
.ld-samples-colophon {
	padding: clamp(64px, 8vw, 112px) 0;
	border-top: 1px solid var(--ld-rule-strong);
}
.ld-samples-colophon__inner {
	max-width: var(--ld-wide);
	margin-inline: auto;
	padding: 0 var(--ld-s-4);
	display: grid;
	grid-template-columns: 2fr 1fr;
	gap: clamp(32px, 5vw, 80px);
	align-items: start;
}
@media (min-width: 1024px) {
	.ld-samples-colophon__inner { padding-inline: var(--ld-s-5); }
}
@media (max-width: 960px) {
	.ld-samples-colophon__inner { grid-template-columns: 1fr; }
}
.ld-samples-colophon__kicker {
	font-family: var(--ld-mono);
	font-size: 11px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--ld-crimson);
	margin: 0 0 14px;
	display: inline-flex;
	align-items: baseline;
	gap: 8px;
}
.ld-samples-colophon__kicker span[aria-hidden] {
	font-family: var(--ld-serif);
	font-style: italic;
	font-size: 16px;
	line-height: 0.7;
	transform: translateY(1px);
}
.ld-samples-colophon__title {
	font-family: var(--ld-serif);
	font-size: clamp(32px, 3.8vw, 48px);
	font-weight: 300;
	line-height: 1.1;
	letter-spacing: -0.02em;
	color: var(--ld-ink);
	margin: 0 0 var(--ld-s-4);
	max-width: 22ch;
}
.ld-samples-colophon__body {
	font-family: var(--ld-serif);
	font-size: 17px;
	line-height: 1.65;
	color: var(--ld-slate);
	margin: 0 0 var(--ld-s-3);
	max-width: 60ch;
}
.ld-samples-colophon__body:last-child { margin: 0; }
.ld-samples-colophon__cta {
	display: flex;
	flex-direction: column;
	gap: 12px;
	padding-top: 34px; /* Aligns with colophon title baseline */
}
@media (max-width: 960px) {
	.ld-samples-colophon__cta { padding-top: 0; }
}

/* ─── 8. READING-ROOM DRAWER ─────────────────────────────── */
.ld-reader {
	position: fixed;
	inset: 0;
	z-index: 1000;
	display: none;
	align-items: stretch;
	justify-content: flex-end;
}
.ld-reader[aria-hidden="false"] { display: flex; }
.ld-reader__shade {
	position: absolute;
	inset: 0;
	background: rgba(14, 14, 16, 0.55);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	animation: ld-reader-fade 320ms var(--ld-ease);
}
.ld-reader__panel {
	position: relative;
	width: min(1040px, 96vw);
	background: var(--ld-parchment);
	box-shadow: -20px 0 60px rgba(14, 14, 16, 0.4);
	display: flex;
	flex-direction: column;
	animation: ld-reader-slide 420ms var(--ld-ease);
}
.ld-reader__head {
	display: flex;
	align-items: center;
	gap: var(--ld-s-4);
	padding: 20px 28px;
	border-bottom: 1px solid var(--ld-rule-strong);
	background: var(--ld-parchment);
}
.ld-reader__kicker {
	font-family: var(--ld-mono);
	font-size: 11px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--ld-crimson);
	margin: 0;
	flex-shrink: 0;
}
.ld-reader__title {
	font-family: var(--ld-serif);
	font-style: italic;
	font-size: 19px;
	font-weight: 400;
	color: var(--ld-ink);
	margin: 0;
	flex: 1;
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.ld-reader__close {
	appearance: none;
	background: transparent;
	border: 1px solid var(--ld-rule-strong);
	width: 36px; height: 36px;
	border-radius: 50%;
	cursor: pointer;
	color: var(--ld-ink);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: all 180ms var(--ld-ease);
}
.ld-reader__close:hover {
	background: var(--ld-ink);
	color: var(--ld-parchment);
	border-color: var(--ld-ink);
}
.ld-reader__body {
	flex: 1;
	overflow: hidden;
	background: #4a4544;
}
.ld-reader__frame {
	width: 100%;
	height: 100%;
	border: 0;
	background: #4a4544;
}
@keyframes ld-reader-fade { from { opacity: 0; } to { opacity: 1; } }
@keyframes ld-reader-slide { from { transform: translateX(40px); opacity: 0; } to { transform: none; opacity: 1; } }

/* ─── 9. BUTTONS (shared across page) ────────────────────── */
.ld-btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 13px 24px;
	font-family: var(--ld-mono);
	font-size: 12px;
	font-weight: 500;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	text-decoration: none;
	border: 1px solid transparent;
	cursor: pointer;
	transition: all 220ms var(--ld-ease);
	border-radius: 0;
	white-space: nowrap;
	justify-content: center;
}
.ld-btn--primary {
	background: var(--ld-crimson);
	color: var(--ld-parchment);
	border-color: var(--ld-crimson);
}
.ld-btn--primary:hover {
	background: var(--ld-crimson-deep);
	border-color: var(--ld-crimson-deep);
	color: var(--ld-parchment);
}
.ld-btn--ghost {
	background: transparent;
	color: var(--ld-ink);
	border-color: var(--ld-ink);
}
.ld-btn--ghost:hover {
	background: var(--ld-ink);
	color: var(--ld-parchment);
}
/* Ghost button on dark hero — inverts to parchment text on parchment-border */
.ld-btn--ghost.ld-btn--on-dark {
	color: var(--ld-parchment);
	border-color: rgba(247, 243, 236, 0.35);
}
.ld-btn--ghost.ld-btn--on-dark:hover {
	background: var(--ld-parchment);
	color: var(--ld-ink);
	border-color: var(--ld-parchment);
}
.ld-btn--lg { padding: 16px 30px; font-size: 13px; letter-spacing: 0.16em; }
.ld-btn__meta {
	font-family: var(--ld-mono);
	font-size: 10px;
	letter-spacing: 0.1em;
	opacity: 0.75;
	padding-left: 10px;
	border-left: 1px solid currentColor;
	margin-left: 4px;
	text-transform: uppercase;
}

/* ─── 10. REDUCED MOTION ─────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
	.ld-reader__shade, .ld-reader__panel { animation: none; }
	* { transition: none !important; }
}
