/*
Theme Name:   Navotram
Theme URI:    https://navotram.com/
Description:  Custom child theme of Hello Elementor for navotram.com — hyper-modern dark, purple primary, gold trim, with sparing Latin/lapidary accents. The Roman idea is embedded in typography and naming, not in textures or skeuomorphism.
Author:       Navot Ram
Author URI:   https://navotram.com/
Template:     hello-elementor
Version:      0.3.0
License:      GNU General Public License v3 or later
License URI:  https://www.gnu.org/licenses/gpl-3.0.html
Text Domain:  navotram
Tags:         custom-colors, custom-logo, custom-menu, editor-style, dark-mode-support
*/

/* ============================================================================
 * Tokens
 * ========================================================================== */

:root {
	/* surfaces */
	--bg:           #0a0a0d;
	--bg-raised:    #131319;
	--bg-sunken:    #050507;
	--bg-panel:     #0f0f15;
	--rule:         #26262f;
	--rule-soft:    #1a1a22;
	--rule-strong:  #3a3a47;

	/* ink — tuned for AA contrast on dark surfaces */
	--text:         #f2f2f6;
	--text-dim:     #c2c2d0;
	--text-faint:   #8a8a9a;

	/* primary — purple, modern, slightly cool */
	--purple:       #a78bfa;
	--purple-hi:    #c4b1ff;
	--purple-deep:  #6e4ee0;
	--purple-glow:  color-mix(in oklab, var(--purple) 40%, transparent);

	/* trim accent — toggleable via :root[data-trim] */
	--gold:         #e6b449;
	--gold-hi:      #f5cc6b;
	--cyan:         #5ee5fb;
	--cyan-hi:      #9ef2ff;
	--bone:         #f0f0f5;
	--bone-hi:      #ffffff;

	--trim:         var(--gold);
	--trim-hi:      var(--gold-hi);

	--status-on:    var(--cyan);

	--max:          38rem;
	--gutter:       1.5rem;

	--sans:         "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	--mono:         "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;
	--display:      "Cinzel", "Trajan Pro", serif;
}

:root[data-trim="cyan"] { --trim: var(--cyan); --trim-hi: var(--cyan-hi); }
:root[data-trim="bone"] { --trim: var(--bone); --trim-hi: var(--bone-hi); }

:root[data-theme="light"] {
	--bg:           #f6f6f9;
	--bg-raised:    #ededf2;
	--bg-sunken:    #fafafd;
	--bg-panel:     #ffffff;
	--rule:         #c8c8d2;
	--rule-soft:    #dcdce4;
	--rule-strong:  #9c9cae;
	--text:         #0d0d12;
	--text-dim:     #3a3a4a;
	--text-faint:   #5e5e72;
	--purple:       #6d4dd6;
	--purple-hi:    #8a6df0;
	--purple-glow:  color-mix(in oklab, var(--purple) 22%, transparent);
	--gold:         #b88a18;
	--gold-hi:      #d6a629;
	--cyan:         #1593b3;
	--cyan-hi:      #1bafd1;
	--bone:         #1a1a22;
	--bone-hi:      #000;
}

/* ============================================================================
 * Reset / base
 * ========================================================================== */

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }

body {
	background: var(--bg);
	color: var(--text);
	font-family: var(--sans);
	font-size: 16px;
	line-height: 1.6;
	font-weight: 400;
	letter-spacing: -0.005em;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
	min-height: 100vh;

	/* subtle radial wash anchoring the upper half — purple bias */
	background-image:
		radial-gradient(ellipse 80% 60% at 50% -10%,
			color-mix(in oklab, var(--purple) 14%, transparent) 0%,
			transparent 70%);
	background-attachment: fixed;
}

/* fine grid texture, very subtle */
body::before {
	content: "";
	position: fixed; inset: 0;
	pointer-events: none;
	background-image: linear-gradient(to right, var(--rule-soft) 1px, transparent 1px);
	background-size: 80px 100%;
	opacity: .35;
	mask-image: linear-gradient(to bottom, transparent, black 20%, black 80%, transparent);
	z-index: 0;
}

a {
	color: inherit;
	text-decoration: none;
	transition: color .14s ease;
}

::selection { background: var(--purple); color: var(--bg); }

/* Suppress Elementor's Theme Builder header and footer everywhere — we ship
 * our own topbar and footer per page. */
.elementor-location-header,
.elementor-location-footer,
#site-header,
.site-header,
#site-navigation { display: none; }

/* ============================================================================
 * A · cursor-tracked aurora
 * ========================================================================== */

.aurora {
	position: fixed; inset: 0;
	pointer-events: none;
	z-index: 0;
	--mx: 50%; --my: 30%;
	background: radial-gradient(
		420px 320px at var(--mx) var(--my),
		color-mix(in oklab, var(--purple) 28%, transparent) 0%,
		color-mix(in oklab, var(--purple) 10%, transparent) 35%,
		transparent 65%);
	mix-blend-mode: screen;
	transition: background-position .08s linear;
	opacity: .85;
}

:root[data-theme="light"] .aurora {
	mix-blend-mode: multiply;
	opacity: .35;
}

@media (prefers-reduced-motion: reduce) { .aurora { display: none; } }
@media (hover: none)                     { .aurora { display: none; } }

/* ============================================================================
 * Topbar
 * ========================================================================== */

.topbar {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 1.1rem var(--gutter);
	max-width: calc(var(--max) + 8rem);
	margin: 0 auto;
	font-family: var(--mono);
	font-size: 11px;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--text-faint);
	position: relative;
	z-index: 2;
}

.topbar .left,
.topbar .right { display: flex; gap: 1.25rem; align-items: center; }

.topbar .brand {
	font-family: var(--mono);
	font-weight: 600;
	letter-spacing: .14em;
	color: var(--text-dim);
	display: flex; gap: .55rem; align-items: center;
}

.topbar .brand .glyph {
	width: 14px; height: 14px;
	background: linear-gradient(135deg, var(--purple), var(--purple-deep));
	border: 1px solid var(--trim);
	transform: rotate(45deg);
}

.topbar a.brand:hover { color: var(--text); }

.dot-on {
	display: inline-block; width: 6px; height: 6px; border-radius: 50%;
	background: var(--status-on);
	box-shadow: 0 0 8px var(--status-on), 0 0 0 0 var(--status-on);
	margin-right: .45rem; vertical-align: middle;
	animation: nv-pulse 2.4s ease-out infinite;
}

@keyframes nv-pulse {
	0%   { box-shadow: 0 0 8px var(--status-on), 0 0 0 0 color-mix(in oklab, var(--status-on) 60%, transparent); }
	70%  { box-shadow: 0 0 8px var(--status-on), 0 0 0 8px transparent; }
	100% { box-shadow: 0 0 8px var(--status-on), 0 0 0 0 transparent; }
}

.theme-toggle {
	background: transparent;
	border: 1px solid var(--rule);
	color: var(--text-faint);
	font: inherit;
	padding: .35rem .65rem;
	cursor: pointer;
	letter-spacing: .14em;
	transition: border-color .14s, color .14s;
}

.theme-toggle:hover { color: var(--trim-hi); border-color: var(--trim); }

@media (max-width: 30rem) {
	.topbar .hide-sm { display: none; }
}

/* ============================================================================
 * Layout
 * ========================================================================== */

main {
	position: relative;
	z-index: 1;
	max-width: var(--max);
	margin: 0 auto;
	padding: 2rem var(--gutter) 5rem;
}

main.archive { max-width: 42rem; }

/* ============================================================================
 * Hero — typographic lockup with a small Cinzel mark
 * ========================================================================== */

.hero {
	margin: 3rem 0 2.5rem;
	position: relative;
}

.hero .mark {
	font-family: var(--display);
	font-weight: 600;
	font-size: 11px;
	letter-spacing: .42em;
	color: var(--trim);
	margin: 0 0 1.2rem;
	display: inline-flex; align-items: center; gap: .6rem;
}

.hero .mark::before {
	content: "";
	display: inline-block; width: 22px; height: 1px;
	background: var(--trim);
}

.hero h1 {
	margin: 0;
	font-family: var(--sans);
	font-weight: 300;
	font-size: clamp(2.4rem, 8vw, 3.6rem);
	line-height: 1;
	letter-spacing: -0.035em;
	color: var(--text);
}

.hero h1 .first { color: var(--text-dim); font-weight: 300; }
.hero h1 .last  { color: var(--text); font-weight: 600; }

.hero .role {
	margin: 1rem 0 0;
	display: flex; flex-wrap: wrap; gap: .75rem;
	font-family: var(--mono);
	font-size: 12px;
	letter-spacing: .04em;
	color: var(--text-dim);
}

.hero .role .chip {
	display: inline-flex; align-items: center;
	border: 1px solid var(--rule);
	padding: .3rem .6rem;
	background: var(--bg-panel);
}

.hero .role .chip.primary {
	border-color: var(--purple);
	color: var(--purple-hi);
	background: color-mix(in oklab, var(--purple) 12%, var(--bg-panel));
}

.hero .role .chip .pip {
	width: 5px; height: 5px; border-radius: 50%;
	background: var(--trim); margin-right: .5rem;
}

.hero .role .chip.primary .pip { background: var(--purple); }

.hero .motto {
	margin: 1.4rem 0 0;
	font-family: var(--display);
	font-weight: 500;
	font-size: 10px;
	letter-spacing: .5em;
	color: var(--text-faint);
	text-transform: uppercase;
}

/* Archive variant of the hero — smaller h1 + sub line */
.hero .sub {
	font-family: var(--mono);
	font-size: 12px;
	letter-spacing: .16em;
	color: var(--text-faint);
	text-transform: uppercase;
	margin: .6rem 0 0;
}

main.archive .hero h1 {
	font-size: clamp(2rem, 7vw, 3rem);
	line-height: 1;
	margin: 0 0 .5rem;
}

/* ============================================================================
 * Bio
 * ========================================================================== */

.bio {
	margin: 2.6rem 0;
	font-size: 1rem;
	line-height: 1.65;
	color: var(--text-dim);
	text-wrap: pretty;
	max-width: 34rem;
}

.bio p { margin: 0 0 1.05em; }
.bio p:last-child { margin-bottom: 0; }
.bio strong { color: var(--text); font-weight: 600; }

.bio a {
	color: var(--text);
	border-bottom: 1px solid var(--rule-strong);
	padding-bottom: 1px;
}

.bio a:hover { color: var(--purple-hi); border-bottom-color: var(--purple); }

/* ============================================================================
 * Section labels
 * ========================================================================== */

.section-label {
	display: flex;
	align-items: center;
	gap: .9rem;
	font-family: var(--mono);
	font-weight: 500;
	font-size: 11px;
	letter-spacing: .22em;
	text-transform: uppercase;
	color: var(--text-faint);
	margin: 0 0 1.2rem;
}

.section-label .num {
	color: var(--trim);
	font-feature-settings: "tnum";
}

.section-label .aside {
	color: var(--text-faint);
	font-weight: 400;
}

.section-label::after {
	content: "";
	flex: 1;
	height: 1px;
	background: linear-gradient(to right, var(--rule), transparent);
}

/* ============================================================================
 * Divider — minimal hairline with diamond mark
 * ========================================================================== */

.divider {
	display: flex; align-items: center; justify-content: center;
	gap: 1rem;
	margin: 3rem 0;
}

.divider::before,
.divider::after {
	content: "";
	flex: 1;
	height: 1px;
	background: linear-gradient(to right, transparent, var(--rule-soft), transparent);
}

.divider .mark {
	width: 5px; height: 5px;
	background: var(--trim);
	transform: rotate(45deg);
	flex: none;
}

/* ============================================================================
 * F · constellation divider — six nodes, packets travel along edges
 * ========================================================================== */

.constellation {
	display: block;
	margin: 2.6rem auto;
	width: 100%;
	max-width: 320px;
	height: 60px;
	color: var(--text-faint);
	overflow: visible;
}

.constellation .nodes circle { fill: var(--trim); opacity: .85; }

.constellation .edges line {
	stroke: var(--rule-strong);
	stroke-width: 1;
	fill: none;
	opacity: .7;
}

.constellation .packets line {
	stroke: var(--purple);
	stroke-width: 1.5;
	stroke-linecap: round;
	fill: none;
	stroke-dasharray: 8 200;
	filter: drop-shadow(0 0 3px var(--purple-glow));
	animation: nv-packet 6s linear infinite;
}

.constellation .packets line:nth-child(1) { animation-delay:  0s; }
.constellation .packets line:nth-child(2) { animation-delay: -1.5s; stroke: var(--trim); filter: drop-shadow(0 0 2px color-mix(in oklab, var(--trim) 40%, transparent)); }
.constellation .packets line:nth-child(3) { animation-delay: -3s; }
.constellation .packets line:nth-child(4) { animation-delay: -4.5s; stroke: var(--trim); filter: drop-shadow(0 0 2px color-mix(in oklab, var(--trim) 40%, transparent)); }

@keyframes nv-packet {
	0%   { stroke-dashoffset: 208; }
	100% { stroke-dashoffset: 0; }
}

@media (prefers-reduced-motion: reduce) {
	.constellation .packets line { animation: none; opacity: 0; }
}

/* ============================================================================
 * FAMILIA — the centerpiece dashboard
 * ========================================================================== */

.familia {
	background: linear-gradient(to bottom, var(--bg-panel), var(--bg-raised));
	border: 1px solid var(--rule);
	border-radius: 0;
	position: relative;
	overflow: hidden;
}

/* D · gold filament — slow polished-metal shimmer */
.familia::before {
	content: "";
	position: absolute; inset: 0 0 auto 0;
	height: 1px;
	background: linear-gradient(
		90deg,
		transparent 0%,
		color-mix(in oklab, var(--trim) 60%, transparent) 18%,
		var(--trim-hi) 50%,
		color-mix(in oklab, var(--trim) 60%, transparent) 82%,
		transparent 100%);
	background-size: 220% 100%;
	background-position: 0% 0%;
	opacity: .7;
	animation: nv-filament 14s ease-in-out infinite;
}

@keyframes nv-filament {
	0%   { background-position: -40% 0%; }
	50%  { background-position: 140% 0%; }
	100% { background-position: -40% 0%; }
}

@media (prefers-reduced-motion: reduce) { .familia::before { animation: none; } }

.familia .head {
	display: flex; justify-content: space-between; align-items: center;
	padding: 1rem 1.3rem;
	border-bottom: 1px solid var(--rule);
	font-family: var(--mono);
	font-size: 11px;
	letter-spacing: .18em;
	text-transform: uppercase;
}

.familia .head .title { color: var(--text); font-weight: 600; }

.familia .head .title .latin {
	color: var(--trim);
	font-family: var(--display);
	font-weight: 600;
	letter-spacing: .28em;
	margin-right: .55rem;
}

.familia .head .status { color: var(--text-faint); font-weight: 400; }

.roll { display: flex; flex-direction: column; }

.roll .row {
	display: grid;
	grid-template-columns: 7.5rem 1fr auto;
	gap: 1.1rem;
	align-items: center;
	padding: .85rem 1.3rem;
	border-top: 1px solid var(--rule-soft);
	font-family: var(--mono);
	font-size: 13px;
	position: relative;
	transition: background .14s ease;
	color: inherit;
}

.roll .row:first-child { border-top: 0; }

.roll .row:hover {
	background: color-mix(in oklab, var(--purple) 10%, transparent);
}

/* purple left accent on hover */
.roll .row::before {
	content: "";
	position: absolute; left: 0; top: 0; bottom: 0;
	width: 2px;
	background: var(--purple);
	transform: scaleY(0);
	transform-origin: top;
	transition: transform .18s ease;
}

.roll .row:hover::before { transform: scaleY(1); }

/* B · cohort heartbeat — pulses one row at a time */
.roll .row.beat::before {
	transform: scaleY(1);
	background: var(--purple);
	box-shadow: 0 0 12px var(--purple-glow);
	animation: nv-beat-bar .9s ease-out;
}

.roll .row.beat .meta { color: var(--purple-hi); }

.roll .row.beat .meta .pip {
	background: var(--purple);
	box-shadow: 0 0 8px var(--purple);
}

.roll .row .toast {
	position: absolute;
	right: 1.3rem;
	font-family: var(--mono);
	font-size: 10px;
	letter-spacing: .08em;
	color: var(--purple-hi);
	opacity: 0;
	transform: translateY(2px);
	pointer-events: none;
	white-space: nowrap;
	background: var(--bg-panel);
	padding: 0 .35rem;
}

.roll .row.beat .toast { animation: nv-toast .9s ease-out; }

@keyframes nv-beat-bar {
	0%   { transform: scaleY(0); }
	20%  { transform: scaleY(1); }
	100% { transform: scaleY(1); }
}

@keyframes nv-toast {
	0%   { opacity: 0; transform: translateY(4px); }
	25%  { opacity: 1; transform: translateY(0); }
	75%  { opacity: 1; }
	100% { opacity: 0; transform: translateY(-2px); }
}

@media (prefers-reduced-motion: reduce) {
	.roll .row.beat::before { animation: none; }
	.roll .row.beat .toast  { animation: none; opacity: 0; }
}

@media (max-width: 30rem) { .roll .row .toast { display: none; } }

.roll .role {
	font-family: var(--display);
	font-weight: 600;
	font-size: 11px;
	letter-spacing: .26em;
	color: var(--trim);
}

.roll .body { display: flex; flex-direction: column; gap: .15rem; min-width: 0; }

.roll .body .name {
	color: var(--text);
	font-weight: 500;
	white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

.roll .body .desc {
	color: var(--text-dim);
	font-size: 12px;
	font-family: var(--sans);
}

.roll .meta {
	font-size: 10px;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--text-faint);
	display: inline-flex; align-items: center; gap: .35rem;
}

.roll .meta .pip {
	width: 5px; height: 5px; border-radius: 50%;
	background: var(--status-on);
	box-shadow: 0 0 6px var(--status-on);
}

@media (max-width: 30rem) {
	.roll .row { grid-template-columns: 1fr; gap: .25rem; padding: .8rem 1rem; }
	.roll .meta { justify-self: start; }
	.familia .head { padding: .9rem 1rem; }
}

.familia-note {
	margin: .75rem 0 0;
	font-family: var(--mono);
	font-size: 11px;
	letter-spacing: .04em;
	color: var(--text-faint);
}

.familia-note .latin {
	font-family: var(--display);
	color: var(--trim);
	letter-spacing: .26em;
	margin-right: .5rem;
}

/* ============================================================================
 * Pliny epigraph
 * ========================================================================== */

.epigraph {
	margin: 3rem 0;
	padding: 1.4rem 1.5rem;
	background: var(--bg-panel);
	border: 1px solid var(--rule);
	border-left: 2px solid var(--trim);
	display: grid; gap: .55rem;
}

.epigraph .latin {
	font-family: var(--sans);
	font-style: italic;
	font-weight: 400;
	font-size: 1.02rem;
	color: var(--text);
	line-height: 1.5;
	letter-spacing: -0.005em;
}

.epigraph .gloss {
	font-size: .95rem;
	color: var(--text-dim);
	line-height: 1.5;
}

.epigraph .cite {
	font-family: var(--mono);
	font-size: 10.5px;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--text-faint);
	margin-top: .35rem;
}

.epigraph .cite .name { color: var(--trim); }

/* ============================================================================
 * Inveni Me
 * ========================================================================== */

.inveni {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0;
	border: 1px solid var(--rule);
	background: var(--bg-panel);
}

.inveni a {
	display: flex;
	flex-direction: column;
	gap: .3rem;
	padding: 1rem 1.1rem;
	border-right: 1px solid var(--rule);
	border-bottom: 1px solid var(--rule);
	position: relative;
	transition: background .14s;
}

.inveni a:nth-child(2n) { border-right: 0; }
.inveni a:nth-last-child(-n+2):not(:nth-last-child(odd)) { border-bottom: 0; }
.inveni a:last-child { border-bottom: 0; }
.inveni a:hover { background: color-mix(in oklab, var(--purple) 10%, transparent); }
.inveni a:hover .arrow { color: var(--trim); transform: translateX(3px); }

.inveni .tag {
	font-family: var(--display);
	font-weight: 600;
	font-size: 10px;
	letter-spacing: .32em;
	color: var(--trim);
}

.inveni .url {
	font-family: var(--mono);
	font-size: 13px;
	color: var(--text);
	display: flex; align-items: center; gap: .4rem;
}

.inveni .url .arrow {
	color: var(--text-faint);
	transition: transform .14s, color .14s;
	display: inline-block;
}

@media (max-width: 30rem) {
	.inveni { grid-template-columns: 1fr; }
	.inveni a { border-right: 0; }
	.inveni a:not(:last-child) { border-bottom: 1px solid var(--rule); }
}

/* ============================================================================
 * Footer
 * ========================================================================== */

.site-footer {
	margin-top: 4rem;
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 1rem;
	padding-top: 1.4rem;
	border-top: 1px solid var(--rule-soft);
	font-family: var(--mono);
	font-size: 11px;
	letter-spacing: .12em;
	color: var(--text-faint);
	text-transform: uppercase;
}

.site-footer a {
	color: var(--text-dim);
	display: inline-flex; align-items: center; gap: .4rem;
	transition: color .14s;
}

.site-footer a:hover { color: var(--trim-hi); }
.site-footer a:hover .arrow { transform: translateX(3px); color: var(--trim); }
.site-footer .archive-link { font-weight: 600; letter-spacing: .18em; }
.site-footer .arrow { transition: transform .14s, color .14s; display: inline-block; }

/* ============================================================================
 * Archive page (/archive — Opera Anteacta)
 * ========================================================================== */

.back {
	display: inline-flex; align-items: center; gap: .4rem;
	font-family: var(--mono);
	font-size: 11px;
	letter-spacing: .18em;
	color: var(--text-dim);
	margin-bottom: 1.5rem;
	text-transform: uppercase;
	transition: color .14s;
}

.back:hover { color: var(--trim-hi); }
.back .arrow { transition: transform .14s; }
.back:hover .arrow { transform: translateX(-3px); color: var(--trim); }

.preface {
	max-width: 34rem;
	color: var(--text-dim);
	margin: 1.4rem 0 2.6rem;
	line-height: 1.65;
	text-wrap: pretty;
}

.preface .latin { color: var(--text); font-style: italic; }

.entries { display: flex; flex-direction: column; }

.entry {
	display: grid;
	grid-template-columns: 5rem 1fr;
	gap: 1.4rem;
	padding: 1.5rem 0;
	border-top: 1px solid var(--rule-soft);
	align-items: start;
	position: relative;
}

.entry:last-child { border-bottom: 1px solid var(--rule-soft); }

.entry .year {
	font-family: var(--display);
	font-weight: 600;
	font-size: 13px;
	letter-spacing: .18em;
	color: var(--trim);
	text-align: right;
	padding-top: .15rem;
}

.entry .body h2 {
	margin: 0 0 .35rem;
	font-family: var(--sans);
	font-weight: 600;
	font-size: 1.05rem;
	letter-spacing: -0.01em;
	color: var(--text);
}

.entry .body .meta {
	font-family: var(--mono);
	font-size: 11px;
	letter-spacing: .14em;
	color: var(--text-faint);
	text-transform: uppercase;
	margin: 0 0 .6rem;
}

.entry .body p {
	margin: 0 0 .6rem;
	color: var(--text-dim);
	line-height: 1.6;
	text-wrap: pretty;
}

.entry .body .link {
	font-family: var(--mono);
	font-size: 12px;
	color: var(--text);
	display: inline-flex; align-items: center; gap: .35rem;
	border-bottom: 1px solid var(--rule);
	padding-bottom: 1px;
	transition: color .14s, border-color .14s;
}

.entry .body .link:hover { color: var(--purple-hi); border-bottom-color: var(--purple); }
.entry .body .link .arrow { transition: transform .14s; }
.entry .body .link:hover .arrow { transform: translateX(3px); }

.entry .body .status {
	display: inline-block;
	font-family: var(--mono);
	font-size: 10px;
	letter-spacing: .16em;
	text-transform: uppercase;
	color: var(--text-faint);
	border: 1px dashed var(--rule);
	padding: .1rem .45rem;
}

@media (max-width: 30rem) {
	.entry { grid-template-columns: 1fr; gap: .4rem; }
	.entry .year { text-align: left; }
}

/* ============================================================================
 * 404 — Damnatio memoriae
 * ========================================================================== */

body.error404 main { display: grid; place-items: center; min-height: calc(100vh - 4rem); }

.panel-404 {
	max-width: 36rem;
	width: 100%;
	text-align: center;
	padding: 3rem 2rem;
	background: var(--bg-panel);
	border: 1px solid var(--rule);
	position: relative;
	overflow: hidden;
}

.panel-404::before {
	content: "";
	position: absolute; inset: 0 0 auto 0;
	height: 1px;
	background: linear-gradient(to right, transparent, var(--trim) 18%, var(--trim) 82%, transparent);
	opacity: .55;
}

.panel-404 .code {
	font-family: var(--mono);
	font-size: 11px;
	letter-spacing: .18em;
	color: var(--text-faint);
	text-transform: uppercase;
	margin-bottom: 1.6rem;
}

.panel-404 .code .num { color: var(--trim); font-weight: 600; }

.panel-404 h1 {
	font-family: var(--sans);
	font-weight: 300;
	font-size: clamp(1.8rem, 5vw, 2.4rem);
	letter-spacing: -0.035em;
	margin: 0 0 .25rem;
	line-height: 1.1;
}

.panel-404 h1 .last { font-weight: 600; }

.panel-404 .subhead {
	font-family: var(--display);
	font-size: 11px;
	letter-spacing: .4em;
	color: var(--trim);
	margin: .6rem 0 1.5rem;
	text-transform: uppercase;
}

.panel-404 .body-text {
	font-size: 1rem;
	line-height: 1.6;
	color: var(--text-dim);
	text-wrap: pretty;
	max-width: 30rem;
	margin: 0 auto;
}

.panel-404 .body-text em { color: var(--text); font-style: italic; }
.panel-404 .body-text .latin { font-style: italic; color: var(--text); }

.panel-404 .actions {
	margin-top: 2rem;
	display: flex;
	gap: .6rem;
	justify-content: center;
	flex-wrap: wrap;
}

.panel-404 .actions a {
	font-family: var(--mono);
	font-size: 11px;
	letter-spacing: .16em;
	text-transform: uppercase;
	color: var(--text);
	text-decoration: none;
	border: 1px solid var(--rule);
	padding: .55rem 1rem;
	transition: border-color .14s, color .14s, background .14s;
}

.panel-404 .actions a:hover {
	border-color: var(--trim);
	color: var(--trim-hi);
	background: color-mix(in oklab, var(--purple) 8%, transparent);
}

/* ============================================================================
 * Print — strip embellishments
 * ========================================================================== */

@media print {
	body { background: #fff; color: #000; }
	body::before, .topbar, .theme-toggle, .aurora { display: none; }
	.familia, .epigraph, .inveni { background: #fff; border-color: #ccc; }
}
