/* ============================================================
   Dragonia Casino — surface-neat.css
   Spec: dragonia-de-2 | seed 0x8398a4c4ebb3a76b
   ============================================================ */

/* :root tokens */
:root {
	--color-primary: #190a0a;
	--color-accent: #ff7014;
	--color-accent-pressed: #f54f02;
	--color-bg: #0e0606;
	--color-bg-elevated: #1a0d0d;
	--color-bg-soft: #160a0a;
	--color-text: #ffffff;
	--color-text-muted: #bfbfbf;
	--color-gradient-light: #c80f25;
	--color-gradient-mid: #f9d200;
	--color-border: rgba(255,255,255,0.10);
	--color-border-strong: rgba(255,255,255,0.18);
	--color-rg-banner: #dc2626;

	--font-display: 'Bebas Neue', 'Inter', system-ui, sans-serif;
	--font-body: 'Inter', system-ui, -apple-system, sans-serif;

	--fs-micro: 11px;
	--fs-small: 13px;
	--fs-body: 16px;
	--fs-h5: 19px;
	--fs-h4: 22px;
	--fs-h3: 28px;
	--fs-h2: 36px;
	--fs-h1: 52px;

	--lh-tight: 1.15;
	--lh-normal: 1.55;
	--lh-loose: 1.75;

	--fw-normal: 400;
	--fw-medium: 500;
	--fw-semibold: 600;
	--fw-bold: 700;

	--ls-tight: -0.01em;
	--ls-wide: 0.12em;

	--space-3xs: 4px;
	--space-2xs: 6px;
	--space-xs: 8px;
	--space-sm: 12px;
	--space-md: 18px;
	--space-lg: 28px;
	--space-xl: 44px;
	--space-2xl: 64px;
	--space-3xl: 96px;

	--container-site: 1160px;
	--container-readable: 650px;
	--container-padding-desktop: 32px;
	--container-padding-mobile: 18px;

	--header-sidebar-width: 280px;
	--header-height-mobile: 64px;

	--radius-sm: 4px;
	--radius-md: 8px;
	--radius-lg: 14px;

	--shadow-sm: 0 1px 3px rgba(0,0,0,0.3);
	--shadow-md: 0 6px 18px rgba(0,0,0,0.35);
	--shadow-lg: 0 14px 40px rgba(0,0,0,0.45);

	--motion-fast: 140ms ease;
	--motion-base: 220ms ease;
}

@media (max-width: 720px) {
	:root {
		--fs-h1: 34px;
		--fs-h2: 26px;
		--fs-h3: 22px;
		--fs-h4: 18px;
		--space-3xl: 56px;
		--space-2xl: 40px;
	}
}

/* reset / base */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; overflow-x: clip; }
body {
	background: var(--color-bg);
	color: var(--color-text);
	font-family: var(--font-body);
	font-size: var(--fs-body);
	line-height: var(--lh-normal);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: color var(--motion-fast); }
a:hover { color: var(--color-accent); }
button { font-family: inherit; cursor: pointer; }
ul { padding-left: 0; margin: 0; list-style: none; }
table { border-collapse: collapse; width: 100%; }

/* skip link */
.skip-link { position: absolute; left: 8px; top: 8px; z-index: 200; background: var(--color-accent); color: var(--color-bg); padding: 8px 14px; border-radius: var(--radius-sm); }
.skip-link:not(:focus) { top: -200px !important; }

@media (prefers-reduced-motion: reduce) {
	* { animation: none !important; transition: none !important; }
}

/* ===========================
   HEADER :: HEAD-07 Sidebar
   =========================== */
.s75 { display: block; }
.s75-sidebar {
	display: none;
}
.s75-bar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: var(--header-height-mobile);
	background: var(--color-bg);
	border-bottom: 1px solid var(--color-border);
	padding-inline: var(--container-padding-mobile);
	position: relative;
	z-index: 80;
}
.s75-logo { display: inline-flex; align-items: center; flex-shrink: 0; }
.s75-logo-img, .s75-logo img { flex-shrink: 0; max-width: none; }
.s75-bar .s75-logo-img { height: 60px; width: auto; }
.s75-toggle {
	margin-left: auto !important;
	background: transparent; border: 1px solid var(--color-border-strong);
	width: 44px; height: 44px; border-radius: var(--radius-sm);
	display: inline-flex; align-items: center; justify-content: center;
	color: var(--color-text);
}
.s75-burger, .s75-burger::before, .s75-burger::after {
	content: ''; display: block; width: 22px; height: 2px; background: currentColor;
	position: relative;
}
.s75-burger::before { position: absolute; top: -7px; left: 0; }
.s75-burger::after { position: absolute; top: 7px; left: 0; }
.s75-drawer {
	display: none;
	background: var(--color-primary);
	border-bottom: 1px solid var(--color-border);
	padding-block: var(--space-md);
}
.s75-drawer.is-open { display: block; }
.s75-mobile-nav ul li {
	border-bottom: 1px solid var(--color-border);
}
.s75-mobile-nav ul li:last-child { border-bottom: none; }
.s75-mobile-nav a {
	display: block;
	padding: 14px var(--container-padding-mobile);
	font-size: var(--fs-body);
	font-weight: var(--fw-semibold);
	color: var(--color-text);
	word-break: keep-all;
}
.s75-mobile-nav a:hover { background: rgba(255,112,20,0.10); color: var(--color-accent); }

@media (min-width: 1281px) {
	.s75-bar { display: none; }
	.s75-drawer { display: none !important; }
	.s75-sidebar {
		display: flex;
		flex-direction: column;
		gap: var(--space-xl);
		position: fixed;
		top: 0; left: 0;
		width: var(--header-sidebar-width);
		height: 100vh;
		padding: var(--space-xl) var(--space-lg);
		background: var(--color-bg);
		border-right: 1px solid var(--color-border);
		overflow-y: auto;
		z-index: 80;
	}
	.s75-sidebar .s75-logo { display: inline-flex; }
	.s75-sidebar .s75-logo-img { height: 88px; width: auto; max-width: none; }
	.s75-nav { width: 100%; }
	.s75-list { display: flex; flex-direction: column; }
	.s75-list li { border-bottom: 1px solid var(--color-border); }
	.s75-list li:last-child { border-bottom: none; }
	.s75-link {
		display: block;
		padding: var(--space-sm) var(--space-xs);
		font-size: var(--fs-small);
		font-weight: var(--fw-semibold);
		letter-spacing: 0.02em;
		color: var(--color-text-muted);
		word-break: keep-all;
		transition: background var(--motion-fast), color var(--motion-fast);
	}
	.s75-link:hover { color: var(--color-accent); }
	.s75-link--active { background: var(--color-accent); color: var(--color-bg); }
	.s75-link--active:hover { background: var(--color-accent-pressed); color: var(--color-bg); }
	body { padding-left: var(--header-sidebar-width); }
}

/* ===========================
   HERO :: HERO-12 Editorial
   =========================== */
.x24 { background: var(--color-bg); padding-block: var(--space-3xl); position: relative; }
.x24-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin-inline: auto;
	padding-inline: var(--container-padding-desktop);
}
.x24-text { max-width: 760px; margin-inline: auto; text-align: center; }
.x24-kicker {
	font-style: italic;
	font-size: var(--fs-small);
	color: var(--color-accent);
	letter-spacing: var(--ls-wide);
	text-transform: uppercase;
	margin: 0 0 var(--space-md);
}
.x24-h1 {
	font-family: var(--font-display);
	font-weight: var(--fw-bold);
	font-size: var(--fs-h1);
	line-height: var(--lh-tight);
	letter-spacing: var(--ls-tight);
	margin: 0 0 var(--space-md);
	background: linear-gradient(120deg, var(--color-text) 0%, var(--color-gradient-mid) 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}
.x24-lead {
	font-style: italic;
	font-size: var(--fs-h5);
	color: var(--color-text-muted);
	max-width: 600px;
	margin: 0 auto var(--space-lg);
	line-height: var(--lh-normal);
}
.x24-meta {
	font-size: var(--fs-micro);
	letter-spacing: var(--ls-wide);
	color: var(--color-text-muted);
	text-transform: uppercase;
}
.x24-figure { margin: var(--space-2xl) 0 0; }
.x24-image {
	width: 100%;
	aspect-ratio: 21/9;
	object-fit: cover;
	border-radius: var(--radius-md);
}
.x24-caption {
	font-style: italic;
	font-size: var(--fs-micro);
	color: var(--color-text-muted);
	padding-top: var(--space-xs);
	text-align: center;
}
@media (max-width: 720px) {
	.x24-image { aspect-ratio: 16/10; }
}

/* ===========================
   PAGE HEADER :: PHEAD-10 Manifesto
   =========================== */
.t10 { background: var(--color-bg); padding-block: var(--space-3xl) var(--space-2xl); border-bottom: 1px solid var(--color-border); }
.t10-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin-inline: auto;
	padding-inline: var(--container-padding-desktop);
	text-align: center;
}
.t10-eyebrow {
	font-size: var(--fs-micro);
	letter-spacing: var(--ls-wide);
	text-transform: uppercase;
	color: var(--color-accent);
	font-weight: var(--fw-bold);
	margin: 0 0 var(--space-md);
}
.t10-h1 {
	font-family: var(--font-display);
	font-size: var(--fs-h1);
	font-weight: var(--fw-bold);
	line-height: var(--lh-tight);
	margin: 0 0 var(--space-md);
	color: var(--color-text);
}
.t10-deck {
	font-size: var(--fs-h5);
	color: var(--color-text-muted);
	max-width: 720px;
	margin: 0 auto var(--space-lg);
	line-height: var(--lh-normal);
}
.t10-meta { font-size: var(--fs-small); color: var(--color-text-muted); }
.t10-date { color: var(--color-text-muted); }

/* ===========================
   PROSE :: PROSE-04 Drop-Cap Magazine
   =========================== */
.n87 { padding-block: var(--space-2xl); }
.n87-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin-inline: auto;
	padding-inline: var(--container-padding-desktop);
}
.n87-section { margin-block: var(--space-xl); }
.n87-section + .n87-section { margin-top: var(--space-2xl); }
.n87-heading {
	font-family: var(--font-display);
	font-size: var(--fs-h2);
	font-weight: var(--fw-bold);
	line-height: var(--lh-tight);
	margin: 0 0 var(--space-md);
	color: var(--color-text);
}
.n87-sub {
	font-family: var(--font-display);
	font-size: var(--fs-h4);
	font-weight: var(--fw-semibold);
	margin-block: var(--space-lg) var(--space-sm);
	color: var(--color-accent);
}
.n87-p {
	font-size: var(--fs-body);
	line-height: var(--lh-loose);
	color: var(--color-text);
	margin: 0 0 var(--space-md);
	max-width: none;
}
.n87-section > .n87-p:first-of-type::first-letter {
	font-family: var(--font-display);
	font-size: 3.6em;
	float: left;
	line-height: 0.9;
	padding: 6px 10px 0 0;
	color: var(--color-accent);
	font-weight: var(--fw-bold);
}
.n87-list { margin: 0 0 var(--space-md) var(--space-lg); }
.n87-list li {
	list-style: disc;
	margin-bottom: var(--space-2xs);
	color: var(--color-text);
}
.n87 a { color: var(--color-accent); border-bottom: 1px solid currentColor; }
.n87 a:hover { color: var(--color-accent-pressed); background: rgba(255,112,20,0.08); }
.n87 strong { font-weight: var(--fw-bold); color: var(--color-text); }
.n87 em { font-style: italic; color: var(--color-gradient-mid); }
.n87-images { padding-block: var(--space-lg); }
.n87-figure { margin: var(--space-md) 0; }
.n87-figure img { border-radius: var(--radius-md); }

/* ===========================
   ITEMS GRID :: GRID-10 Compact 4-col Tile
   =========================== */
.j65 { padding-block: var(--space-2xl); background: var(--color-bg-soft); }
.j65-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin-inline: auto;
	padding-inline: var(--container-padding-desktop);
}
.j65-heading {
	font-family: var(--font-display);
	font-size: var(--fs-h2);
	margin: 0 0 var(--space-xl);
	letter-spacing: var(--ls-tight);
	color: var(--color-text);
}
.j65-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--space-md);
}
.j65-card {
	background: var(--color-bg-elevated);
	padding: var(--space-md);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	transition: transform var(--motion-base), border-color var(--motion-base);
}
.j65-card:hover {
	transform: translateY(-2px);
	border-color: var(--color-accent);
}
.j65-card-title {
	font-family: var(--font-display);
	font-size: var(--fs-h5);
	margin: 0 0 var(--space-xs);
	color: var(--color-accent);
}
.j65-card-text { font-size: var(--fs-small); color: var(--color-text-muted); line-height: var(--lh-normal); margin: 0; }
@media (max-width: 1100px) {
	.j65-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
	.j65-grid { grid-template-columns: 1fr; }
}

/* ===========================
   FAQ :: FAQ-07 Compact
   =========================== */
.g76 { padding-block: var(--space-2xl); }
.g76-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin-inline: auto;
	padding-inline: var(--container-padding-desktop);
}
.g76-heading {
	font-family: var(--font-display);
	font-size: var(--fs-h2);
	margin: 0 0 var(--space-xl);
	color: var(--color-text);
}
.g76-row {
	border-top: 1px solid var(--color-border);
	padding-block: var(--space-sm);
}
.g76-row:last-child { border-bottom: 1px solid var(--color-border); }
.g76-q {
	font-family: var(--font-display);
	font-size: var(--fs-h5);
	color: var(--color-text);
	cursor: pointer;
	padding-block: var(--space-sm);
	list-style: none;
	position: relative;
	padding-right: var(--space-lg);
}
.g76-q::-webkit-details-marker { display: none; }
.g76-q::after {
	content: '+';
	position: absolute; right: 0; top: 50%; transform: translateY(-50%);
	font-size: var(--fs-h4); color: var(--color-accent);
	transition: transform var(--motion-base);
}
.g76-row[open] .g76-q::after { content: '−'; }
.g76-a { padding-block: var(--space-sm); color: var(--color-text-muted); line-height: var(--lh-loose); }
.g76-a a { color: var(--color-accent); border-bottom: 1px solid currentColor; }

/* ===========================
   REVIEWS :: REV-02 Quote Editorial
   =========================== */
.h81 { padding-block: var(--space-2xl); background: var(--color-bg-soft); }
.h81-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin-inline: auto;
	padding-inline: var(--container-padding-desktop);
}
.h81-heading {
	font-family: var(--font-display);
	font-size: var(--fs-h2);
	margin: 0 0 var(--space-xl);
	color: var(--color-text);
}
.h81-item { margin-bottom: var(--space-xl); padding-left: var(--space-lg); border-left: 3px solid var(--color-accent); }
.h81-quote {
	font-size: var(--fs-h5);
	font-style: italic;
	font-family: var(--font-body);
	margin: 0 0 var(--space-sm);
	line-height: var(--lh-normal);
	color: var(--color-text);
}
.h81-quote::before { content: '“'; color: var(--color-accent); font-size: var(--fs-h1); line-height: 0; vertical-align: -0.4em; margin-right: 8px; font-family: var(--font-display); }
.h81-credit {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-md);
	font-size: var(--fs-small);
	color: var(--color-text-muted);
}
.h81-author { font-weight: var(--fw-bold); color: var(--color-text); }
.h81-rating { color: var(--color-gradient-mid); font-weight: var(--fw-semibold); }
.h81-date { color: var(--color-text-muted); }

/* ===========================
   CTA :: CTA-01 Full-width Strip on Accent
   =========================== */
.m83 {
	padding-block: var(--space-2xl);
	background: linear-gradient(135deg, var(--color-accent) 0%, var(--color-gradient-light) 100%);
	color: var(--color-bg);
	text-align: center;
}
.m83-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin-inline: auto;
	padding-inline: var(--container-padding-desktop);
}
.m83-heading {
	font-family: var(--font-display);
	font-size: var(--fs-h2);
	margin: 0 0 var(--space-sm);
	color: var(--color-bg);
}
.m83-text { font-size: var(--fs-body); max-width: 720px; margin: 0 auto var(--space-lg); line-height: var(--lh-normal); color: var(--color-bg); }
.m83-button {
	display: inline-block;
	padding: 14px 32px;
	background: var(--color-bg);
	color: var(--color-text);
	font-weight: var(--fw-bold);
	font-family: var(--font-display);
	font-size: var(--fs-h5);
	letter-spacing: var(--ls-wide);
	text-transform: uppercase;
	border-radius: var(--radius-md);
	transition: background var(--motion-fast), color var(--motion-fast);
}
.m83-button:hover { background: var(--color-primary); color: var(--color-accent); }

/* ===========================
   TABLE :: TABLE-02 Borderless Editorial
   =========================== */
.n66 { padding-block: var(--space-lg); }
.n66-table { border: none; }
.n66-table caption { text-align: left; font-style: italic; margin-bottom: var(--space-sm); color: var(--color-text-muted); }
.n66-table thead th {
	text-align: left;
	padding: var(--space-sm) var(--space-md);
	border-bottom: 2px solid var(--color-border-strong);
	font-family: var(--font-display);
	font-size: var(--fs-small);
	text-transform: uppercase;
	letter-spacing: var(--ls-wide);
	color: var(--color-accent);
}
.n66-table tbody td {
	padding: var(--space-sm) var(--space-md);
	border-bottom: 1px solid var(--color-border);
	color: var(--color-text);
}
.n66-table tbody tr:hover { background: rgba(255,112,20,0.04); }

/* ===========================
   LEGAL :: LEGAL-08 Minimal Plain
   =========================== */
.s37 { padding-block: var(--space-2xl); }
.s37-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin-inline: auto;
	padding-inline: var(--container-padding-desktop);
}
.s37-intro { font-size: var(--fs-h5); margin: 0 0 var(--space-lg); color: var(--color-text-muted); }
.s37-section { margin-block: var(--space-xl); }
.s37-heading {
	font-family: var(--font-display);
	font-size: var(--fs-h3);
	margin: 0 0 var(--space-md);
	color: var(--color-text);
}
.s37-updated { font-size: var(--fs-small); color: var(--color-accent); margin: 0 0 var(--space-md); }
.s37-contacts { margin-block: var(--space-xl); padding: var(--space-lg); border: 1px solid var(--color-border); border-radius: var(--radius-md); }
.s37-contacts h3 { font-family: var(--font-display); margin-top: 0; color: var(--color-accent); }
.s37-disclaimer { font-size: var(--fs-small); color: var(--color-text-muted); padding-top: var(--space-lg); border-top: 1px solid var(--color-border); }

/* ===========================
   FORM :: FORM-05 Bordered Editorial
   =========================== */
.u77 { padding-block: var(--space-2xl); }
.u77-inner {
	max-width: 720px;
	margin-inline: auto;
	padding-inline: var(--container-padding-desktop);
}
.u77-intro { font-size: var(--fs-body); color: var(--color-text-muted); margin: 0 0 var(--space-lg); }
.u77-form {
	display: flex; flex-direction: column;
	gap: var(--space-md);
	border: 1px solid var(--color-border-strong);
	padding: var(--space-xl);
	border-radius: var(--radius-md);
	background: var(--color-bg-elevated);
}
.u77-label { display: flex; flex-direction: column; gap: var(--space-2xs); font-size: var(--fs-small); color: var(--color-text-muted); }
.u77-label span { font-weight: var(--fw-semibold); color: var(--color-text); }
.u77-input, .u77-textarea {
	padding: 12px 14px;
	border: 1px solid var(--color-border-strong);
	background: var(--color-bg);
	color: var(--color-text);
	font-family: inherit;
	font-size: var(--fs-body);
	border-radius: var(--radius-sm);
}
.u77-input:focus, .u77-textarea:focus { outline: 2px solid var(--color-accent); border-color: var(--color-accent); }
.u77-submit {
	background: var(--color-accent);
	color: var(--color-bg);
	font-weight: var(--fw-bold);
	font-family: var(--font-display);
	font-size: var(--fs-h5);
	letter-spacing: var(--ls-wide);
	text-transform: uppercase;
	border: none;
	padding: 14px 32px;
	border-radius: var(--radius-md);
}
.u77-submit:hover { background: var(--color-accent-pressed); color: var(--color-text); }
.u77-success { padding: var(--space-lg); background: rgba(34,197,94,0.10); border: 1px solid #22c55e; border-radius: var(--radius-md); color: #22c55e; margin-top: var(--space-md); }

/* ===========================
   AUTHOR CARD :: AUTH-02 Vertical Centered Editorial
   =========================== */
.e17 { padding-block: var(--space-3xl); text-align: center; }
.e17-inner {
	max-width: 720px;
	margin-inline: auto;
	padding-inline: var(--container-padding-desktop);
}
.e17-portrait {
	width: 220px; height: 220px;
	border-radius: 50%;
	object-fit: cover;
	margin: 0 auto var(--space-lg);
	border: 3px solid var(--color-accent);
}
.e17-name {
	font-family: var(--font-display);
	font-size: var(--fs-h1);
	margin: 0 0 var(--space-xs);
	color: var(--color-text);
}
.e17-role { color: var(--color-accent); font-size: var(--fs-h5); margin: 0 0 var(--space-lg); }
.e17-bio { font-size: var(--fs-body); line-height: var(--lh-loose); margin: 0 0 var(--space-lg); color: var(--color-text-muted); }
.e17-expertise-heading {
	font-family: var(--font-display); font-size: var(--fs-h4); margin-block: var(--space-lg) var(--space-sm); color: var(--color-text);
}
.e17-expertise { display: flex; flex-wrap: wrap; gap: var(--space-sm); justify-content: center; }
.e17-expertise li {
	padding: 6px 14px;
	border: 1px solid var(--color-accent);
	border-radius: 999px;
	color: var(--color-accent);
	font-size: var(--fs-small);
}
.e17-articles {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin-inline: auto;
	padding: var(--space-2xl) var(--container-padding-desktop);
	text-align: left;
}
.e17-articles-heading {
	font-family: var(--font-display); font-size: var(--fs-h2); margin: 0 0 var(--space-lg);
}
.e17-articles-list { display: grid; gap: var(--space-md); }
.e17-articles-item {
	padding: var(--space-md); border: 1px solid var(--color-border); border-radius: var(--radius-md);
	display: flex; flex-direction: column; gap: var(--space-2xs);
}
.e17-articles-item:hover { border-color: var(--color-accent); }
.e17-articles-item a { color: var(--color-text); }
.e17-articles-item a:hover { color: var(--color-accent); }
.e17-articles-item span { color: var(--color-text-muted); font-size: var(--fs-small); }

/* ===========================
   BYLINE :: BYLINE-07 Expertise Tags Block
   =========================== */
.d54 { padding-block: var(--space-2xl); border-top: 1px solid var(--color-border); }
.d54-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin-inline: auto;
	padding-inline: var(--container-padding-desktop);
	display: grid;
	grid-template-columns: 96px 1fr;
	gap: var(--space-lg);
	align-items: start;
}
.d54-portrait { width: 88px; height: 88px; border-radius: 50%; object-fit: cover; border: 2px solid var(--color-accent); }
.d54-kicker { font-size: var(--fs-micro); letter-spacing: var(--ls-wide); text-transform: uppercase; color: var(--color-text-muted); margin: 0 0 var(--space-xs); }
.d54-name { font-family: var(--font-display); font-size: var(--fs-h4); margin: 0 0 var(--space-3xs); }
.d54-name a { color: var(--color-text); border-bottom: 1px solid transparent; }
.d54-name a:hover { color: var(--color-accent); border-bottom-color: currentColor; }
.d54-role { color: var(--color-text-muted); font-size: var(--fs-small); margin: 0 0 var(--space-sm); }
.d54-tags { display: flex; flex-wrap: wrap; gap: var(--space-2xs); margin-bottom: var(--space-sm); }
.d54-tag { padding: 4px 12px; background: rgba(255,112,20,0.10); color: var(--color-accent); border-radius: 999px; font-size: var(--fs-micro); }
.d54-date { font-size: var(--fs-micro); color: var(--color-text-muted); display: block; }
@media (max-width: 600px) {
	.d54-inner { grid-template-columns: 64px 1fr; }
	.d54-portrait { width: 64px; height: 64px; }
}

/* ===========================
   ERROR :: ERR-01 Centered Hero-Style
   =========================== */
.p69 { padding-block: var(--space-3xl); min-height: 60vh; display: flex; align-items: center; }
.p69-inner {
	max-width: 640px;
	margin-inline: auto;
	padding-inline: var(--container-padding-desktop);
	text-align: center;
}
.p69-code { font-family: var(--font-display); font-size: 120px; color: var(--color-accent); margin: 0; line-height: 1; }
.p69-title { font-family: var(--font-display); font-size: var(--fs-h1); margin: var(--space-md) 0; }
.p69-text { color: var(--color-text-muted); margin: 0 0 var(--space-lg); }
.p69-button {
	display: inline-block;
	padding: 12px 28px;
	background: var(--color-accent);
	color: var(--color-bg);
	font-weight: var(--fw-bold);
	font-family: var(--font-display);
	letter-spacing: var(--ls-wide);
	text-transform: uppercase;
	border-radius: var(--radius-md);
}
.p69-button:hover { background: var(--color-accent-pressed); color: var(--color-text); }

/* ===========================
   FOOTER :: FOOT-06 Manifesto
   =========================== */
.b67 { background: var(--color-bg); padding-block: var(--space-3xl); border-top: 1px solid var(--color-border); }
.b67-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin-inline: auto;
	padding-inline: var(--container-padding-desktop);
}
.b67-manifesto { text-align: center; max-width: 760px; margin-inline: auto; }
.b67-statement {
	font-family: var(--font-display);
	font-size: var(--fs-h2);
	font-weight: var(--fw-bold);
	line-height: var(--lh-tight);
	margin: 0 0 var(--space-lg);
	color: var(--color-text);
}
.b67-cta {
	display: inline-block;
	font-family: var(--font-display);
	font-size: var(--fs-h5);
	text-transform: uppercase;
	letter-spacing: var(--ls-wide);
	border-bottom: 2px solid var(--color-accent);
	padding-bottom: 4px;
	color: var(--color-text);
}
.b67-cta:hover { color: var(--color-accent); background: transparent; }
.b67-divider {
	height: 1px;
	background: rgba(255,255,255,0.10);
	margin-block: var(--space-xl);
}
.b67-meta {
	display: grid;
	grid-template-columns: auto 1fr 1fr;
	gap: var(--space-xl);
	align-items: start;
}
.b67-logo img { height: 72px; width: auto; flex-shrink: 0; max-width: none; }
.b67-nav-title {
	font-family: var(--font-display);
	font-size: var(--fs-small);
	text-transform: uppercase;
	letter-spacing: var(--ls-wide);
	color: var(--color-accent);
	margin: 0 0 var(--space-sm);
}
.b67-list li { padding: 4px 0; }
.b67-link { color: var(--color-text-muted); font-size: var(--fs-small); }
.b67-link:hover { color: var(--color-accent); }
.b67-bottom { margin-top: var(--space-xl); padding-top: var(--space-lg); border-top: 1px solid var(--color-border); text-align: center; }
.b67-rg { font-size: var(--fs-small); color: var(--color-text-muted); margin: 0 0 var(--space-sm); }
.b67-rg a { color: var(--color-accent); border-bottom: 1px solid currentColor; }
.b67-copy { font-size: var(--fs-micro); color: var(--color-text-muted); display: block; }
@media (max-width: 900px) {
	.b67-meta { grid-template-columns: 1fr; text-align: center; }
	.b67-logo img { margin-inline: auto; }
}

/* ===========================
   COOKIE :: COOK-02 Full-Width Bottom Strip
   =========================== */
.l09 {
	position: fixed; bottom: 0; left: 0; right: 0;
	z-index: 90;
	background: var(--color-primary);
	border-top: 1px solid rgba(255,255,255,0.08);
	padding: var(--space-md) var(--container-padding-desktop);
}
.l09[hidden] { display: none; }
.l09-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin-inline: auto;
	display: flex;
	gap: var(--space-md);
	align-items: center;
	justify-content: space-between;
}
.l09-message { flex: 1; font-size: var(--fs-small); color: var(--color-text-muted); margin: 0; }
.l09-actions { display: flex; gap: var(--space-sm); flex-shrink: 0; }
.l09-button {
	padding: 10px 20px;
	font-size: var(--fs-small);
	font-weight: var(--fw-semibold);
	border-radius: var(--radius-sm);
	border: 1px solid var(--color-accent);
	background: transparent;
	color: var(--color-accent);
	transition: background var(--motion-fast), color var(--motion-fast);
}
.l09-button--accept { background: var(--color-accent); color: var(--color-bg); }
.l09-button--accept:hover { background: var(--color-accent-pressed); color: var(--color-text); border-color: var(--color-accent-pressed); }
.l09-button--decline:hover { background: rgba(255,112,20,0.10); }
@media (max-width: 720px) {
	.l09, .l09-inner {
		padding: 12px 14px !important;
		gap: 8px !important;
		font-size: 13px !important;
		line-height: 1.35 !important;
	}
	.l09-inner { flex-direction: column; }
	.l09-actions { width: 100%; justify-content: stretch; }
	.l09-button {
		padding: 8px 14px !important;
		font-size: 12px !important;
		min-height: 36px !important;
		flex: 1;
	}
}

/* utility */
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.main { display: block; }
