/* =====================================================================
   QDR Labs — Main stylesheet
   Editorial-scientific aesthetic. Paper cream, ink, single cobalt accent.
   Fraunces (display serif) + Newsreader (body serif) + JetBrains Mono.
   ===================================================================== */

/* ---------- Tokens ---------- */
:root {
	/* Paper-cream palette */
	--qdr-bg:        #f4efe6;
	--qdr-bg-soft:   #ede7da;
	--qdr-bg-card:   #faf6ee;
	--qdr-ink:       #1a1612;
	--qdr-ink-soft:  #3a342c;
	--qdr-ink-mute:  #6b6358;
	--qdr-ink-faint: #a89d8d;
	--qdr-rule:      #d8cfbe;
	--qdr-rule-soft: #e6dfd0;

	/* Single saturated accent — deep cobalt */
	--qdr-accent:        #1f3a8a;
	--qdr-accent-hover:  #16307a;
	--qdr-accent-soft:   #d6def0;

	/* Source badge colors */
	--qdr-src-zenodo:        #1858c4;
	--qdr-src-academia:      #6b1c1c;
	--qdr-src-researchgate:  #007763;
	--qdr-src-arxiv:         #b31b1b;
	--qdr-src-other:         var(--qdr-ink-mute);

	/* Type */
	--qdr-font-display: 'Fraunces', 'Iowan Old Style', Georgia, serif;
	--qdr-font-body:    'Newsreader', 'Iowan Old Style', Georgia, serif;
	--qdr-font-mono:    'JetBrains Mono', 'SF Mono', Menlo, monospace;

	/* Layout */
	--qdr-shell:        min(1180px, 92vw);
	--qdr-shell-narrow: min(760px, 92vw);

	/* Motion */
	--qdr-ease:  cubic-bezier(.2, .7, .2, 1);

	/* Subtle paper grain (data URI noise) */
	--qdr-grain: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.10  0 0 0 0 0.09  0 0 0 0 0.07  0 0 0 0.045 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* Dark mode (toggleable via [data-theme="dark"]) */
[data-theme="dark"] {
	--qdr-bg:        #14110d;
	--qdr-bg-soft:   #1c1814;
	--qdr-bg-card:   #1a1612;
	--qdr-ink:       #f1ead8;
	--qdr-ink-soft:  #d8d0bd;
	--qdr-ink-mute:  #968b78;
	--qdr-ink-faint: #5e574c;
	--qdr-rule:      #2c271f;
	--qdr-rule-soft: #221d17;

	--qdr-accent:        #94a8e6;
	--qdr-accent-hover:  #b1c0ee;
	--qdr-accent-soft:   #232a44;

	--qdr-src-zenodo:        #94b4f0;
	--qdr-src-academia:      #d68a8a;
	--qdr-src-researchgate:  #6dc7b3;
	--qdr-src-arxiv:         #e07a7a;

	--qdr-grain: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.85  0 0 0 0 0.80  0 0 0 0 0.70  0 0 0 0.025 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* ---------- Reset-ish ---------- */
*,*::before,*::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
	margin: 0;
	background: var(--qdr-bg);
	color: var(--qdr-ink);
	font-family: var(--qdr-font-body);
	font-size: 18px;
	line-height: 1.65;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	font-feature-settings: "kern", "liga", "onum";
	position: relative;
}
body::before {
	content: "";
	position: fixed; inset: 0;
	background-image: var(--qdr-grain);
	opacity: 0.5;
	pointer-events: none;
	z-index: 1;
	mix-blend-mode: multiply;
}
[data-theme="dark"] body::before { mix-blend-mode: screen; opacity: 0.35; }

img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: var(--qdr-accent); text-decoration: none; transition: color .15s var(--qdr-ease); }
a:hover { color: var(--qdr-accent-hover); }
hr { border: 0; border-top: 1px solid var(--qdr-rule); margin: 2em 0; }
button { font: inherit; cursor: pointer; }

.qdr-shell { width: var(--qdr-shell); margin-inline: auto; }
.qdr-skip { position: absolute; left: -9999px; }
.qdr-skip:focus { left: 16px; top: 16px; background: var(--qdr-ink); color: var(--qdr-bg); padding: 8px 14px; z-index: 999; }

.screen-reader-text {
	border: 0; clip: rect(1px,1px,1px,1px); clip-path: inset(50%);
	height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute;
	width: 1px; word-wrap: normal !important;
}

/* Wrapper layering above grain */
.qdr-site-header, .qdr-main, .qdr-site-footer { position: relative; z-index: 2; }

/* ---------- Site Header ---------- */
.qdr-site-header {
	border-bottom: 1px solid var(--qdr-rule);
	padding: 18px 0;
	background: var(--qdr-bg);
}
.qdr-site-header__shell {
	display: flex; align-items: center; justify-content: space-between;
	gap: 32px; flex-wrap: wrap;
}
.qdr-brand {
	display: inline-flex; align-items: center; gap: 14px;
	color: var(--qdr-ink); text-decoration: none;
}
.qdr-brand:hover { color: var(--qdr-ink); }
.qdr-brand__mark { color: var(--qdr-ink); display: inline-flex; }
.qdr-brand__text { display: flex; flex-direction: column; line-height: 1.05; }
.qdr-brand__name {
	font-family: var(--qdr-font-display);
	font-weight: 600;
	font-size: 1.35rem;
	letter-spacing: -0.01em;
}
.qdr-brand__tag {
	font-family: var(--qdr-font-mono);
	font-size: 0.72rem;
	color: var(--qdr-ink-mute);
	margin-top: 4px;
	letter-spacing: 0.02em;
	text-transform: uppercase;
}

.qdr-nav { display: flex; align-items: center; gap: 28px; }
.qdr-nav__list { list-style: none; padding: 0; margin: 0; display: flex; gap: 28px; }
.qdr-nav__list a {
	color: var(--qdr-ink-soft);
	font-family: var(--qdr-font-display);
	font-weight: 400;
	font-size: 1rem;
	letter-spacing: 0;
	position: relative;
	padding-bottom: 4px;
}
.qdr-nav__list a:hover { color: var(--qdr-ink); }
.qdr-nav__list a::after {
	content: "";
	position: absolute; left: 0; right: 100%; bottom: 0;
	border-bottom: 1px solid var(--qdr-ink);
	transition: right .25s var(--qdr-ease);
}
.qdr-nav__list a:hover::after { right: 0; }

.qdr-theme-toggle {
	background: transparent; border: 1px solid var(--qdr-rule);
	width: 36px; height: 36px; border-radius: 50%;
	color: var(--qdr-ink); display: inline-flex; align-items: center; justify-content: center;
	transition: border-color .2s, transform .2s var(--qdr-ease);
}
.qdr-theme-toggle:hover { border-color: var(--qdr-ink); transform: rotate(15deg); }
.qdr-theme-toggle__moon { display: none; }
.qdr-theme-toggle__sun  { display: inline; }
[data-theme="dark"] .qdr-theme-toggle__sun  { display: none; }
[data-theme="dark"] .qdr-theme-toggle__moon { display: inline; }

/* ---------- Hero ---------- */
.qdr-hero {
	padding: 96px 0 80px;
	border-bottom: 1px solid var(--qdr-rule);
	position: relative;
	overflow: hidden;
}
.qdr-hero::before {
	content: "";
	position: absolute; right: -180px; top: -120px; width: 580px; height: 580px;
	background: radial-gradient(circle at center, var(--qdr-accent-soft) 0%, transparent 60%);
	opacity: 0.55;
	pointer-events: none;
}
.qdr-hero__shell { position: relative; max-width: 880px; }
.qdr-hero__eyebrow {
	font-family: var(--qdr-font-mono);
	font-size: 0.78rem;
	color: var(--qdr-ink-mute);
	text-transform: uppercase;
	letter-spacing: 0.12em;
	margin: 0 0 28px;
	display: inline-flex; align-items: center; gap: 12px;
}
.qdr-hero__eyebrow::before {
	content: ""; display: inline-block; width: 28px; height: 1px; background: var(--qdr-ink-mute);
}
.qdr-hero__headline {
	font-family: var(--qdr-font-display);
	font-weight: 400;
	font-variation-settings: "opsz" 144, "SOFT" 0;
	font-size: clamp(2.4rem, 5vw, 4.2rem);
	line-height: 1.04;
	letter-spacing: -0.022em;
	margin: 0 0 28px;
	color: var(--qdr-ink);
	text-wrap: balance;
}
.qdr-hero__sub {
	font-family: var(--qdr-font-body);
	font-size: 1.22rem;
	line-height: 1.55;
	color: var(--qdr-ink-soft);
	max-width: 60ch;
	margin: 0 0 36px;
	font-style: italic;
	font-weight: 300;
}
.qdr-hero__actions { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 48px; }
.qdr-hero__meta {
	display: flex; align-items: center; gap: 20px; flex-wrap: wrap;
	padding-top: 28px; border-top: 1px solid var(--qdr-rule);
	font-family: var(--qdr-font-mono);
	font-size: 0.78rem;
}
.qdr-hero__meta-label {
	color: var(--qdr-ink-mute); text-transform: uppercase; letter-spacing: 0.1em;
}
.qdr-hero__meta a {
	color: var(--qdr-ink);
	border-bottom: 1px dotted var(--qdr-ink-mute);
	padding-bottom: 1px;
}
.qdr-hero__meta a:hover { color: var(--qdr-accent); border-bottom-color: var(--qdr-accent); }

/* ---------- Buttons ---------- */
.qdr-btn {
	display: inline-flex; align-items: center; justify-content: center;
	padding: 13px 22px;
	font-family: var(--qdr-font-display);
	font-size: 1rem;
	font-weight: 500;
	letter-spacing: -0.005em;
	border-radius: 2px;
	transition: all .18s var(--qdr-ease);
	border: 1px solid transparent;
	text-decoration: none !important;
}
.qdr-btn--primary {
	background: var(--qdr-ink); color: var(--qdr-bg);
}
.qdr-btn--primary:hover {
	background: var(--qdr-accent); color: var(--qdr-bg);
	transform: translateY(-1px);
}
.qdr-btn--ghost {
	background: transparent; color: var(--qdr-ink); border-color: var(--qdr-ink);
}
.qdr-btn--ghost:hover {
	background: var(--qdr-ink); color: var(--qdr-bg);
}

/* ---------- Sections ---------- */
.qdr-section { padding: 80px 0; border-bottom: 1px solid var(--qdr-rule); }
.qdr-section--featured { background: var(--qdr-bg-soft); }
.qdr-section--split { padding: 88px 0; }
.qdr-section__header {
	display: flex; align-items: baseline; justify-content: space-between;
	margin-bottom: 40px; gap: 20px; flex-wrap: wrap;
	border-bottom: 1px solid var(--qdr-rule);
	padding-bottom: 18px;
}
.qdr-section__title {
	font-family: var(--qdr-font-display);
	font-weight: 500;
	font-size: clamp(1.7rem, 2.5vw, 2.25rem);
	letter-spacing: -0.012em;
	margin: 0;
	color: var(--qdr-ink);
}
.qdr-section__sub {
	margin: 6px 0 0;
	color: var(--qdr-ink-mute);
	font-style: italic;
	font-size: 0.98rem;
}
.qdr-section__more {
	font-family: var(--qdr-font-mono);
	font-size: 0.8rem;
	color: var(--qdr-ink);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	border-bottom: 1px solid var(--qdr-ink-faint);
	padding-bottom: 2px;
}
.qdr-section__more:hover { color: var(--qdr-accent); border-bottom-color: var(--qdr-accent); }

/* ---------- Grids & lists ---------- */
.qdr-grid { display: grid; gap: 36px; }
.qdr-grid--2 { grid-template-columns: repeat(2, 1fr); }
.qdr-grid--3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 900px) {
	.qdr-grid--2, .qdr-grid--3 { grid-template-columns: 1fr; gap: 28px; }
}

.qdr-list { display: flex; flex-direction: column; gap: 0; }
.qdr-list-item {
	padding: 28px 0;
	border-top: 1px solid var(--qdr-rule);
	display: grid;
	grid-template-columns: 160px 1fr;
	gap: 36px;
	align-items: start;
}
.qdr-list-item:last-child { border-bottom: 1px solid var(--qdr-rule); }
.qdr-list-item__meta {
	display: flex; flex-direction: column; gap: 8px;
	font-family: var(--qdr-font-mono); font-size: 0.78rem;
	color: var(--qdr-ink-mute);
}
.qdr-list-item__year {
	color: var(--qdr-ink); font-weight: 600; font-size: 0.92rem; letter-spacing: 0.02em;
}
.qdr-list-item__title {
	font-family: var(--qdr-font-display);
	font-weight: 500;
	font-size: 1.5rem;
	line-height: 1.15;
	letter-spacing: -0.012em;
	margin: 0 0 10px;
}
.qdr-list-item__title a { color: var(--qdr-ink); }
.qdr-list-item__title a:hover { color: var(--qdr-accent); }
.qdr-list-item__authors {
	font-family: var(--qdr-font-body);
	font-style: italic;
	margin: 0 0 4px;
	color: var(--qdr-ink-soft);
	font-size: 0.96rem;
}
.qdr-list-item__venue {
	font-family: var(--qdr-font-mono);
	font-size: 0.78rem;
	color: var(--qdr-ink-mute);
	margin: 0 0 10px;
	letter-spacing: 0.02em;
}
.qdr-list-item__excerpt {
	font-size: 1rem;
	color: var(--qdr-ink-soft);
	margin: 6px 0 0;
	max-width: 60ch;
}
@media (max-width: 700px) {
	.qdr-list-item { grid-template-columns: 1fr; gap: 12px; }
}

/* ---------- Cards (paper / post / stream) ---------- */
.qdr-card {
	background: var(--qdr-bg-card);
	border: 1px solid var(--qdr-rule);
	padding: 28px 26px 26px;
	border-radius: 2px;
	display: flex; flex-direction: column;
	transition: border-color .2s var(--qdr-ease), transform .25s var(--qdr-ease), box-shadow .25s var(--qdr-ease);
	position: relative;
	overflow: hidden;
}
.qdr-card::before {
	content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
	background: var(--qdr-accent);
	transform: scaleY(0); transform-origin: top;
	transition: transform .3s var(--qdr-ease);
}
.qdr-card:hover {
	border-color: var(--qdr-ink);
	transform: translateY(-2px);
	box-shadow: 0 12px 32px -16px rgba(26,22,18,0.18);
}
.qdr-card:hover::before { transform: scaleY(1); }

.qdr-card__meta {
	display: flex; align-items: center; gap: 12px;
	font-family: var(--qdr-font-mono); font-size: 0.74rem;
	color: var(--qdr-ink-mute);
	margin-bottom: 14px;
	flex-wrap: wrap;
}
.qdr-card__year {
	color: var(--qdr-ink); font-weight: 600;
	letter-spacing: 0.04em;
}
.qdr-card__cat {
	color: var(--qdr-ink-mute);
	text-transform: uppercase; letter-spacing: 0.08em;
}
.qdr-card__title {
	font-family: var(--qdr-font-display);
	font-weight: 500;
	font-size: 1.32rem;
	line-height: 1.18;
	letter-spacing: -0.01em;
	margin: 0 0 10px;
}
.qdr-card__title a { color: var(--qdr-ink); }
.qdr-card__title a:hover { color: var(--qdr-accent); }
.qdr-card__authors {
	font-family: var(--qdr-font-body);
	font-style: italic;
	color: var(--qdr-ink-soft);
	margin: 0 0 4px;
	font-size: 0.95rem;
}
.qdr-card__venue {
	font-family: var(--qdr-font-mono);
	font-size: 0.74rem;
	color: var(--qdr-ink-mute);
	margin: 0 0 14px;
	letter-spacing: 0.02em;
}
.qdr-card__excerpt {
	font-size: 0.96rem;
	color: var(--qdr-ink-soft);
	margin: 4px 0 18px;
	line-height: 1.55;
	flex-grow: 1;
}
.qdr-card__more {
	font-family: var(--qdr-font-mono);
	font-size: 0.78rem;
	color: var(--qdr-ink);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	border-bottom: 1px solid var(--qdr-ink-faint);
	padding-bottom: 2px;
	align-self: flex-start;
}
.qdr-card__more:hover { color: var(--qdr-accent); border-bottom-color: var(--qdr-accent); }

/* Stream card */
.qdr-stream__link { display: block; color: var(--qdr-ink); text-decoration: none; }
.qdr-stream__thumb-wrap {
	position: relative; aspect-ratio: 16 / 9;
	background: var(--qdr-bg-soft);
	border: 1px solid var(--qdr-rule);
	overflow: hidden;
	margin: -28px -26px 18px;
	border-bottom: 1px solid var(--qdr-rule);
}
.qdr-stream__thumb { width: 100%; height: 100%; object-fit: cover; }
.qdr-stream__thumb-placeholder {
	width: 100%; height: 100%;
	background:
		linear-gradient(135deg, transparent 49%, var(--qdr-rule) 49%, var(--qdr-rule) 51%, transparent 51%),
		linear-gradient(45deg, transparent 49%, var(--qdr-rule) 49%, var(--qdr-rule) 51%, transparent 51%);
	background-size: 36px 36px;
	background-color: var(--qdr-bg-soft);
}
.qdr-stream__duration {
	position: absolute; bottom: 8px; right: 8px;
	background: var(--qdr-ink); color: var(--qdr-bg);
	font-family: var(--qdr-font-mono); font-size: 0.72rem;
	padding: 3px 8px; border-radius: 1px;
	letter-spacing: 0.02em;
}

/* ---------- Source badges ---------- */
.qdr-sources { display: inline-flex; gap: 6px; flex-wrap: wrap; }
.qdr-badge {
	font-family: var(--qdr-font-mono);
	font-size: 0.68rem;
	font-weight: 500;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	padding: 2px 8px;
	border-radius: 2px;
	display: inline-flex; align-items: center;
	border: 1px solid currentColor;
	color: var(--qdr-src-other);
	background: transparent;
	text-decoration: none !important;
	line-height: 1.6;
}
.qdr-badge:hover { background: currentColor; }
.qdr-badge:hover { color: currentColor; }
/* invert text via background-clip trick */
.qdr-badge { transition: all .15s var(--qdr-ease); }
.qdr-badge--zenodo        { color: var(--qdr-src-zenodo); }
.qdr-badge--academia-edu  { color: var(--qdr-src-academia); }
.qdr-badge--researchgate  { color: var(--qdr-src-researchgate); }
.qdr-badge--arxiv         { color: var(--qdr-src-arxiv); }
.qdr-badge--type          { color: var(--qdr-ink-mute); }

/* ---------- Split sections ---------- */
.qdr-split {
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: 64px;
}
@media (max-width: 900px) { .qdr-split { grid-template-columns: 1fr; gap: 56px; } }
.qdr-split .qdr-list { display: flex; flex-direction: column; gap: 28px; }
.qdr-split .qdr-card { padding: 0; background: transparent; border: 0; border-top: 1px solid var(--qdr-rule); padding-top: 22px; }
.qdr-split .qdr-card:first-of-type { border-top: 0; padding-top: 0; }
.qdr-split .qdr-card:hover { transform: none; box-shadow: none; }
.qdr-split .qdr-card::before { display: none; }
.qdr-split .qdr-stream__thumb-wrap { margin: 0 0 14px; }

/* ---------- Archive header ---------- */
.qdr-archive-header {
	padding: 80px 0 50px;
	border-bottom: 1px solid var(--qdr-rule);
}
.qdr-archive-header__eyebrow {
	font-family: var(--qdr-font-mono);
	color: var(--qdr-ink-mute);
	text-transform: uppercase;
	letter-spacing: 0.12em;
	font-size: 0.78rem;
	margin: 0 0 18px;
}
.qdr-archive-header__title {
	font-family: var(--qdr-font-display);
	font-weight: 400;
	font-size: clamp(2.2rem, 4vw, 3.6rem);
	letter-spacing: -0.02em;
	margin: 0 0 18px;
	line-height: 1.05;
}
.qdr-archive-header__sub {
	margin: 0; color: var(--qdr-ink-soft);
	font-style: italic; font-size: 1.1rem; max-width: 60ch;
}

/* ---------- Single paper ---------- */
.qdr-paper, .qdr-post, .qdr-page, .qdr-stream { padding: 72px 0; }
.qdr-paper__shell, .qdr-post__shell, .qdr-page__shell, .qdr-stream__shell {
	max-width: 760px; margin-inline: auto;
}
.qdr-paper__breadcrumbs, .qdr-post__eyebrow {
	font-family: var(--qdr-font-mono);
	font-size: 0.78rem;
	color: var(--qdr-ink-mute);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	margin: 0 0 22px;
}
.qdr-paper__breadcrumbs span[aria-hidden] { color: var(--qdr-ink-faint); margin: 0 6px; }
.qdr-paper__title, .qdr-post__title, .qdr-page__title, .qdr-stream__title {
	font-family: var(--qdr-font-display);
	font-weight: 400;
	font-size: clamp(2rem, 3.6vw, 3.2rem);
	line-height: 1.08;
	letter-spacing: -0.022em;
	margin: 0 0 22px;
	text-wrap: balance;
}
.qdr-paper__authors {
	font-family: var(--qdr-font-body);
	font-style: italic;
	font-size: 1.15rem;
	color: var(--qdr-ink-soft);
	margin: 0 0 14px;
}
.qdr-paper__meta, .qdr-post__meta, .qdr-stream__meta {
	display: flex; gap: 16px; flex-wrap: wrap;
	font-family: var(--qdr-font-mono);
	font-size: 0.8rem;
	color: var(--qdr-ink-mute);
	letter-spacing: 0.02em;
	margin: 0 0 32px;
	padding-bottom: 28px;
	border-bottom: 1px solid var(--qdr-rule);
	align-items: center;
}
.qdr-paper__actions {
	display: flex; gap: 12px; flex-wrap: wrap; margin: 28px 0 36px;
}
.qdr-paper__figure { margin: 36px 0; }
.qdr-paper__figure img { width: 100%; }

/* Abstract */
.qdr-abstract {
	background: var(--qdr-bg-card);
	border-left: 3px solid var(--qdr-accent);
	padding: 24px 28px;
	margin: 0 0 40px;
}
.qdr-abstract h2 {
	font-family: var(--qdr-font-mono);
	font-size: 0.78rem;
	font-weight: 600;
	color: var(--qdr-ink-mute);
	text-transform: uppercase;
	letter-spacing: 0.12em;
	margin: 0 0 12px;
}
.qdr-abstract p {
	margin: 0 0 12px; font-size: 1.02rem; line-height: 1.65;
	color: var(--qdr-ink-soft);
}
.qdr-abstract p:last-child { margin-bottom: 0; }

/* Citation block */
.qdr-citation {
	margin-top: 56px; padding: 28px;
	border: 1px solid var(--qdr-rule); border-radius: 2px;
	background: var(--qdr-bg-card);
}
.qdr-citation h3 {
	font-family: var(--qdr-font-mono);
	font-size: 0.78rem;
	font-weight: 600;
	color: var(--qdr-ink-mute);
	text-transform: uppercase;
	letter-spacing: 0.12em;
	margin: 0 0 14px;
}
.qdr-citation__plain p { margin: 0 0 6px; font-size: 0.96rem; }
.qdr-citation__doi { font-family: var(--qdr-font-mono); font-size: 0.84rem; }
.qdr-citation__bib { margin-top: 18px; }
.qdr-citation__bib summary {
	cursor: pointer; font-family: var(--qdr-font-mono);
	font-size: 0.82rem; color: var(--qdr-accent);
	letter-spacing: 0.02em;
}
.qdr-citation__bib pre {
	background: var(--qdr-ink); color: var(--qdr-bg);
	padding: 18px 20px; border-radius: 2px; overflow-x: auto;
	font-family: var(--qdr-font-mono); font-size: 0.82rem;
	margin: 12px 0 0;
}

.qdr-paper__areas { margin-top: 48px; padding-top: 24px; border-top: 1px solid var(--qdr-rule); }
.qdr-paper__areas h3 {
	font-family: var(--qdr-font-mono);
	font-size: 0.76rem; text-transform: uppercase; letter-spacing: 0.12em;
	color: var(--qdr-ink-mute); margin: 0 0 12px;
}
.qdr-paper__areas ul { list-style: none; padding: 0; margin: 0; display: flex; gap: 8px; flex-wrap: wrap; }
.qdr-paper__areas a {
	display: inline-block;
	padding: 6px 12px;
	border: 1px solid var(--qdr-rule);
	color: var(--qdr-ink-soft);
	font-family: var(--qdr-font-mono); font-size: 0.78rem;
	border-radius: 2px;
}
.qdr-paper__areas a:hover { border-color: var(--qdr-accent); color: var(--qdr-accent); }

/* ---------- Prose (article body) ---------- */
.qdr-prose { font-size: 1.08rem; line-height: 1.72; color: var(--qdr-ink-soft); }
.qdr-prose > * + * { margin-top: 1.1em; }
.qdr-prose p { margin: 0 0 1.1em; }
.qdr-prose h2 {
	font-family: var(--qdr-font-display);
	font-weight: 500; font-size: 1.85rem;
	letter-spacing: -0.01em; line-height: 1.18;
	margin-top: 2em; margin-bottom: 0.6em;
	color: var(--qdr-ink);
}
.qdr-prose h3 {
	font-family: var(--qdr-font-display);
	font-weight: 500; font-size: 1.4rem;
	margin-top: 1.6em; margin-bottom: 0.4em;
	color: var(--qdr-ink);
}
.qdr-prose a {
	color: var(--qdr-accent);
	border-bottom: 1px solid var(--qdr-accent-soft);
	padding-bottom: 1px;
}
.qdr-prose a:hover { background: var(--qdr-accent-soft); }
.qdr-prose blockquote {
	margin: 1.6em 0; padding: 6px 22px;
	border-left: 3px solid var(--qdr-accent);
	font-style: italic; color: var(--qdr-ink-soft);
}
.qdr-prose code {
	font-family: var(--qdr-font-mono);
	font-size: 0.9em;
	background: var(--qdr-bg-soft);
	padding: 1px 6px; border-radius: 2px;
}
.qdr-prose pre {
	background: var(--qdr-ink); color: var(--qdr-bg);
	padding: 22px 24px; border-radius: 2px; overflow-x: auto;
	font-family: var(--qdr-font-mono); font-size: 0.88rem;
	line-height: 1.55;
	margin: 1.6em 0;
}
.qdr-prose pre code { background: transparent; padding: 0; color: inherit; font-size: inherit; }
.qdr-prose ul, .qdr-prose ol { padding-left: 1.4em; margin: 0 0 1.1em; }
.qdr-prose li { margin: 0 0 0.4em; }
.qdr-prose img { margin: 1.6em 0; }
.qdr-prose hr { margin: 2.4em 0; border-top: 1px solid var(--qdr-rule); }
.qdr-prose figcaption {
	font-family: var(--qdr-font-mono);
	font-size: 0.78rem; color: var(--qdr-ink-mute);
	text-align: center; margin-top: 0.6em;
}

/* Drop cap on first paragraph of long-form posts */
.qdr-post__body > p:first-of-type::first-letter {
	font-family: var(--qdr-font-display);
	font-weight: 600; font-size: 4.2rem; line-height: 0.85;
	float: left; margin: 6px 12px 0 0; color: var(--qdr-accent);
}

/* ---------- Pagination ---------- */
.qdr-pagination { margin-top: 56px; }
.qdr-pagination .nav-links {
	display: flex; gap: 10px; flex-wrap: wrap;
	font-family: var(--qdr-font-mono); font-size: 0.84rem;
}
.qdr-pagination .page-numbers {
	padding: 8px 14px; border: 1px solid var(--qdr-rule);
	color: var(--qdr-ink); border-radius: 2px;
	text-decoration: none;
}
.qdr-pagination .page-numbers.current {
	background: var(--qdr-ink); color: var(--qdr-bg); border-color: var(--qdr-ink);
}
.qdr-pagination .page-numbers:hover:not(.current) {
	border-color: var(--qdr-ink); color: var(--qdr-ink);
}

/* ---------- 404 ---------- */
.qdr-404 { padding: 120px 0; text-align: left; }
.qdr-404__shell { max-width: 720px; margin-inline: auto; }
.qdr-404__code {
	font-family: var(--qdr-font-mono);
	font-size: 0.84rem; color: var(--qdr-ink-mute);
	letter-spacing: 0.18em;
	margin: 0 0 16px;
}
.qdr-404__title {
	font-family: var(--qdr-font-display);
	font-weight: 400; font-size: clamp(2.4rem, 5vw, 4rem);
	letter-spacing: -0.02em; line-height: 1.04;
	margin: 0 0 18px;
}
.qdr-404__sub { font-style: italic; color: var(--qdr-ink-soft); font-size: 1.15rem; margin: 0 0 32px; max-width: 50ch; }
.qdr-404__search { margin-top: 44px; }

/* ---------- Search form ---------- */
.qdr-search-form {
	display: flex; gap: 8px; max-width: 520px;
	border: 1px solid var(--qdr-rule); padding: 4px;
	border-radius: 2px; background: var(--qdr-bg-card);
}
.qdr-search-form input[type="search"] {
	flex: 1; border: 0; padding: 10px 14px;
	background: transparent; color: var(--qdr-ink);
	font-family: var(--qdr-font-body); font-size: 1rem;
	outline: none;
}
.qdr-search-form button {
	background: var(--qdr-ink); color: var(--qdr-bg);
	border: 0; padding: 10px 18px; border-radius: 2px;
	font-family: var(--qdr-font-mono); font-size: 0.84rem;
	letter-spacing: 0.04em; text-transform: uppercase;
}
.qdr-search-form button:hover { background: var(--qdr-accent); }

/* ---------- Empty states ---------- */
.qdr-empty {
	text-align: center; padding: 60px 0;
	color: var(--qdr-ink-mute); font-style: italic;
}

/* ---------- Footer ---------- */
.qdr-site-footer {
	background: var(--qdr-bg-soft);
	padding: 72px 0 32px;
	border-top: 1px solid var(--qdr-rule);
}
.qdr-footer-grid {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1fr;
	gap: 48px;
	padding-bottom: 56px;
	border-bottom: 1px solid var(--qdr-rule);
}
@media (max-width: 800px) {
	.qdr-footer-grid { grid-template-columns: 1fr 1fr; gap: 36px; }
}
.qdr-footer__sigil {
	font-family: var(--qdr-font-display);
	font-weight: 700; font-size: 2.6rem;
	letter-spacing: -0.02em;
	margin: 0 0 14px;
	color: var(--qdr-ink);
	line-height: 1;
}
.qdr-footer__about {
	margin: 0 0 22px; max-width: 36ch;
	color: var(--qdr-ink-soft); font-style: italic; font-size: 1rem;
}
.qdr-footer__repos { display: flex; flex-wrap: wrap; gap: 8px; margin: 0; }
.qdr-footer__repos a {
	font-family: var(--qdr-font-mono);
	font-size: 0.74rem; color: var(--qdr-ink);
	border: 1px solid var(--qdr-rule); padding: 4px 10px;
	border-radius: 2px; text-decoration: none;
	transition: all .15s var(--qdr-ease);
}
.qdr-footer__repos a:hover {
	border-color: var(--qdr-accent); color: var(--qdr-accent);
}
.qdr-footer__col .widget-title {
	font-family: var(--qdr-font-mono);
	font-size: 0.78rem; text-transform: uppercase;
	letter-spacing: 0.12em; color: var(--qdr-ink-mute);
	margin: 0 0 16px; font-weight: 600;
}
.qdr-footer__col ul { list-style: none; padding: 0; margin: 0; }
.qdr-footer__col li { margin: 0 0 8px; }
.qdr-footer__col a { color: var(--qdr-ink-soft); }
.qdr-footer__col a:hover { color: var(--qdr-accent); }

.qdr-colophon {
	display: flex; align-items: center; justify-content: space-between;
	padding-top: 28px; gap: 24px; flex-wrap: wrap;
	font-family: var(--qdr-font-mono);
	font-size: 0.76rem; color: var(--qdr-ink-mute);
}
.qdr-colophon p { margin: 0; max-width: 60ch; }
.qdr-colophon__menu { display: flex; gap: 18px; list-style: none; padding: 0; margin: 0; }
.qdr-colophon__menu a { color: var(--qdr-ink-mute); }
.qdr-colophon__menu a:hover { color: var(--qdr-ink); }

/* ---------- Stream player wrapper ---------- */
.qdr-stream__player {
	margin: 0 0 36px; aspect-ratio: 16 / 9;
}
.qdr-stream__player iframe { width: 100%; height: 100%; border: 0; }

/* ---------- Page-load reveal ---------- */
.qdr-hero__eyebrow, .qdr-hero__headline, .qdr-hero__sub, .qdr-hero__actions, .qdr-hero__meta {
	opacity: 0; transform: translateY(8px);
	animation: qdr-rise .7s var(--qdr-ease) forwards;
}
.qdr-hero__eyebrow { animation-delay: .05s; }
.qdr-hero__headline { animation-delay: .15s; }
.qdr-hero__sub { animation-delay: .28s; }
.qdr-hero__actions { animation-delay: .38s; }
.qdr-hero__meta { animation-delay: .48s; }

@keyframes qdr-rise {
	to { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after { animation: none !important; transition: none !important; }
	html { scroll-behavior: auto; }
}

/* ---------- Mobile tweaks ---------- */
@media (max-width: 700px) {
	body { font-size: 17px; }
	.qdr-site-header { padding: 14px 0; }
	.qdr-nav { gap: 18px; }
	.qdr-nav__list { gap: 18px; }
	.qdr-hero { padding: 64px 0 56px; }
	.qdr-section { padding: 56px 0; }
	.qdr-archive-header { padding: 56px 0 36px; }
	.qdr-paper, .qdr-post, .qdr-page, .qdr-stream { padding: 56px 0; }
	.qdr-citation { padding: 22px; }
}
