/* 20Bet Casino CL — main.css */
:root {
	--color-primary: #0e2037;
	--color-accent: #54a933;
	--color-bg: #f0f3f8;
	--color-bg-elevated: #ffffff;
	--color-accent-pressed: #428828;
	--color-gradient-light: #19396b;
	--color-gradient-mid: #ee5a2b;
	--color-text: #202939;
	--color-text-muted: #4a5568;
	--color-rg-banner: #dc2626;
	--color-border: #d7dbe3;

	--font-display: "Roboto", system-ui, -apple-system, sans-serif;
	--font-body: "Roboto", system-ui, -apple-system, sans-serif;

	/* TYPO-04 scale */
	--fs-xs: 12px;
	--fs-sm: 14px;
	--fs-base: 16px;
	--fs-md: 18px;
	--fs-lg: 22px;
	--fs-xl: 28px;
	--fs-2xl: 36px;
	--fs-3xl: 48px;
	--fs-4xl: 60px;

	/* SPACE-02 */
	--space-xs: 6px;
	--space-sm: 12px;
	--space-md: 20px;
	--space-lg: 32px;
	--space-xl: 48px;
	--space-2xl: 72px;
	--space-3xl: 96px;

	/* CONT-02 */
	--container-site: 1380px;
	--container-readable: 720px;
	--container-padding-desktop: 32px;
	--container-padding-mobile: 16px;

	/* GEO-01 */
	--radius-sm: 6px;
	--radius-md: 10px;
	--radius-lg: 16px;
	--radius-pill: 999px;

	/* MOTION-03 */
	--ease: cubic-bezier(.2, .8, .2, 1);
	--dur-fast: 140ms;
	--dur-base: 240ms;
	--dur-slow: 360ms;

	--header-height-desktop: 96px;
	--header-height-mobile: 64px;
}

@media (max-width: 720px) {
	:root {
		--fs-base: 15px;
		--fs-lg: 19px;
		--fs-xl: 24px;
		--fs-2xl: 30px;
		--fs-3xl: 38px;
		--fs-4xl: 44px;
		--space-xl: 36px;
		--space-2xl: 56px;
		--space-3xl: 72px;
	}
}

/* Reset / base */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; overflow-x: clip; }
body {
	font-family: var(--font-body);
	font-size: var(--fs-base);
	line-height: 1.65;
	color: var(--color-text);
	background: var(--color-bg);
	-webkit-font-smoothing: antialiased;
	padding-top: var(--header-height-desktop);
}
@media (max-width: 1100px) {
	body { padding-top: var(--header-height-mobile); }
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--color-accent); text-decoration: none; transition: color var(--dur-fast) var(--ease); }
a:hover { color: var(--color-accent-pressed); }
h1, h2, h3, h4 { font-family: var(--font-display); color: var(--color-primary); line-height: 1.2; margin: 0 0 var(--space-md); font-weight: 700; }
h1 { font-size: var(--fs-3xl); }
h2 { font-size: var(--fs-2xl); }
h3 { font-size: var(--fs-xl); }
p { margin: 0 0 var(--space-md); }
ul, ol { padding-left: 1.4em; margin: 0 0 var(--space-md); }
li { margin-bottom: var(--space-xs); }

.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); }
.skip-link {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	top: -200px !important;
	background: var(--color-accent);
	color: #fff;
	padding: 8px 14px;
	border-radius: var(--radius-sm);
	z-index: 9999;
}
.skip-link:focus { top: 8px !important; }
@media (prefers-reduced-motion: reduce) {
	* { transition-duration: 0.01ms !important; animation-duration: 0.01ms !important; }
}

/* ── HEADER (HEAD-05 + NAV-03 two-row, STICKY-04 fixed, AUTH-LOGIN) ── */
.pavillon-alt {
	position: fixed;
	top: 0; left: 0; right: 0;
	z-index: 100;
	background: var(--color-primary);
	color: #fff;
	min-height: var(--header-height-desktop);
	box-shadow: 0 1px 0 rgba(255, 255, 255, 0.06);
	transition: box-shadow var(--dur-base) var(--ease);
}
.pavillon-alt.is-shrunk { box-shadow: 0 6px 20px rgba(0, 0, 0, 0.3); }
.pavillon-alt-inner {
	display: flex;
	align-items: center;
	gap: var(--space-lg);
	max-width: 1440px;
	margin: 0 auto;
	padding: 8px var(--space-md);
	min-height: var(--header-height-desktop);
}
.pavillon-alt-brand { display: inline-flex; align-items: center; flex-shrink: 0; }
.pavillon-alt-logo, .pavillon-alt-brand img { flex-shrink: 0; }
.pavillon-alt-logo {
	height: 88px;
	width: auto;
	display: block;
}
.pavillon-alt-nav {
	display: flex;
	flex-direction: column;
	gap: 4px;
	flex: 1 1 auto;
	min-width: 0;
}
.pavillon-alt-nav-row { display: flex; }
.pavillon-alt-nav-list {
	list-style: none;
	margin: 0; padding: 0;
	display: flex;
	flex-wrap: nowrap;
	gap: var(--space-md);
	align-items: center;
}
.pavillon-alt-nav-list li { margin: 0; }
.pavillon-alt-nav-list a {
	color: rgba(255, 255, 255, 0.85);
	font-weight: 500;
	font-size: var(--fs-sm);
	padding: 6px 4px;
	letter-spacing: 0.02em;
	white-space: nowrap;
}
.pavillon-alt-nav-list a:hover,
.pavillon-alt-nav-list a[aria-current="page"] { color: var(--color-accent); }
.pavillon-alt-nav-divider {
	height: 1px;
	background: rgba(255, 255, 255, 0.12);
	width: 100%;
}
.pavillon-alt-actions { display: flex; align-items: center; gap: var(--space-sm); flex-shrink: 0; }
.pavillon-alt-auth-btn {
	background: var(--color-accent);
	color: #fff;
	padding: 10px var(--space-lg);
	border-radius: var(--radius-md);
	font-weight: 700;
	white-space: nowrap;
	flex-shrink: 0;
	transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}
.pavillon-alt-auth-btn:hover {
	background: var(--color-accent-pressed);
	color: #fff;
}
.pavillon-alt-toggle {
	display: none;
	background: transparent;
	border: 0;
	padding: 8px;
	cursor: pointer;
	flex-direction: column;
	gap: 5px;
	margin-left: auto !important;
}
.pavillon-alt-toggle span {
	display: block;
	width: 26px;
	height: 2px;
	background: #fff;
	border-radius: 2px;
}
.pavillon-alt-mobile {
	display: none;
	background: var(--color-primary);
	border-top: 1px solid rgba(255, 255, 255, 0.1);
	padding: var(--space-md);
}
.pavillon-alt-mobile ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
}
.pavillon-alt-mobile a {
	color: #fff;
	display: block;
	padding: 10px var(--space-sm);
	font-size: var(--fs-md);
	border-radius: var(--radius-sm);
}
.pavillon-alt-mobile a:hover { background: rgba(255, 255, 255, 0.08); color: var(--color-accent); }

@media (max-width: 1100px) {
	.pavillon-alt { min-height: var(--header-height-mobile); }
	.pavillon-alt-inner { min-height: var(--header-height-mobile); padding: 6px var(--space-sm); }
	.pavillon-alt-logo { height: 64px; }
	.pavillon-alt-nav { display: none; }
	.pavillon-alt-auth-btn { display: none; }
	.pavillon-alt-toggle { display: inline-flex; }
	.pavillon-alt-mobile.is-open { display: block; }
}

/* ── HERO (HERO-07 — image right, text left) ── */
.gangway-prime {
	background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-gradient-light) 60%, var(--color-gradient-mid) 130%);
	color: #fff;
	padding: var(--space-3xl) 0;
}
.gangway-prime-inner {
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: var(--space-2xl);
	align-items: center;
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.gangway-prime-eyebrow {
	display: inline-block;
	font-size: var(--fs-xs);
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--color-accent);
	margin-bottom: var(--space-sm);
	font-weight: 700;
}
.gangway-prime-h1 {
	color: #fff;
	font-size: var(--fs-4xl);
	letter-spacing: -0.02em;
	margin-bottom: var(--space-lg);
}
.gangway-prime-subtitle {
	font-size: var(--fs-md);
	color: rgba(255, 255, 255, 0.88);
	max-width: 580px;
	margin-bottom: var(--space-xl);
	line-height: 1.6;
}
.gangway-prime-cta {
	display: inline-block;
	background: var(--color-accent);
	color: #fff;
	padding: 16px var(--space-2xl);
	border-radius: var(--radius-md);
	font-weight: 700;
	font-size: var(--fs-md);
	letter-spacing: 0.04em;
	text-transform: uppercase;
	transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease), transform var(--dur-fast) var(--ease);
}
.gangway-prime-cta:hover {
	background: var(--color-accent-pressed);
	color: #fff;
	transform: translateY(-2px);
}
.gangway-prime-media img {
	border-radius: var(--radius-lg);
	box-shadow: 0 24px 48px rgba(0, 0, 0, 0.32);
}
@media (max-width: 900px) {
	.gangway-prime-inner { grid-template-columns: 1fr; }
	.gangway-prime { padding: var(--space-2xl) 0; }
}

/* ── PAGE HEADER (PHEAD-03) ── */
.pavilion-grand {
	background: var(--color-primary);
	color: #fff;
	padding: var(--space-2xl) 0 var(--space-xl);
}
.pavilion-grand-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
	text-align: left;
}
.pavilion-grand-eyebrow {
	color: var(--color-accent);
	font-size: var(--fs-xs);
	letter-spacing: 0.18em;
	text-transform: uppercase;
	font-weight: 700;
	margin: 0 0 var(--space-sm);
}
.pavilion-grand-h1 {
	color: #fff;
	font-size: var(--fs-3xl);
	margin: 0;
}

/* ── PROSE (PROSE-06) ── */
.hallway-light { padding: var(--space-xl) 0; }
.hallway-light-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.hallway-light-inner > p,
.hallway-light-inner > ul,
.hallway-light-inner > ol {
	max-width: var(--container-readable);
}
.hallway-light h2 { margin-top: var(--space-2xl); }
.hallway-light h2:first-child { margin-top: 0; }
.hallway-light h3 { margin-top: var(--space-xl); }
.hallway-light strong { color: var(--color-primary); }
.hallway-light a { text-decoration: underline; text-underline-offset: 3px; }
.hallway-light-figure { margin: var(--space-xl) 0; }
.hallway-light-figure img {
	width: 100%;
	max-height: 540px;
	object-fit: cover;
	border-radius: var(--radius-md);
}

/* ── ITEMS GRID (GRID-02) ── */
.vault-plus { padding: var(--space-2xl) 0; background: var(--color-bg-elevated); }
.vault-plus-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.vault-plus-h2 { margin-bottom: var(--space-xl); }
.vault-plus-list {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: var(--space-md);
}
.vault-plus-card {
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-lg);
	transition: transform var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease);
}
.vault-plus-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 28px rgba(14, 32, 55, 0.12);
	border-color: var(--color-accent);
}
.vault-plus-card-title {
	font-size: var(--fs-md);
	margin-bottom: var(--space-sm);
	color: var(--color-primary);
}
.vault-plus-card-text { color: var(--color-text-muted); font-size: var(--fs-sm); margin: 0; }

/* ── REVIEWS (REV-04) ── */
.alcove-light { padding: var(--space-2xl) 0; background: var(--color-primary); color: #fff; }
.alcove-light-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.alcove-light-h2 { color: #fff; margin-bottom: var(--space-xl); }
.alcove-light-list {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
	gap: var(--space-md);
}
.alcove-light-card {
	background: rgba(255, 255, 255, 0.05);
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: var(--radius-md);
	padding: var(--space-lg);
}
.alcove-light-rating { display: flex; align-items: center; gap: var(--space-sm); margin-bottom: var(--space-sm); }
.alcove-light-stars { color: var(--color-gradient-mid); font-size: var(--fs-md); letter-spacing: 2px; }
.alcove-light-rating-num { color: rgba(255, 255, 255, 0.7); font-size: var(--fs-sm); }
.alcove-light-text { color: rgba(255, 255, 255, 0.92); font-size: var(--fs-base); line-height: 1.6; }
.alcove-light-author { color: var(--color-accent); font-weight: 700; font-size: var(--fs-sm); margin: var(--space-sm) 0 0; }

/* ── FAQ (FAQ-02) ── */
.buffet-noble { padding: var(--space-2xl) 0; }
.buffet-noble-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.buffet-noble-h2 { margin-bottom: var(--space-xl); }
.buffet-noble-list { display: flex; flex-direction: column; gap: var(--space-sm); }
.buffet-noble-item {
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	overflow: hidden;
}
.buffet-noble-item[open] { border-color: var(--color-accent); }
.buffet-noble-q {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-sm);
	cursor: pointer;
	padding: var(--space-md) var(--space-lg);
	font-weight: 700;
	color: var(--color-primary);
	font-size: var(--fs-md);
	list-style: none;
}
.buffet-noble-q::-webkit-details-marker { display: none; }
.buffet-noble-icon {
	font-size: var(--fs-xl);
	color: var(--color-accent);
	transition: transform var(--dur-base) var(--ease);
	flex-shrink: 0;
}
.buffet-noble-item[open] .buffet-noble-icon { transform: rotate(45deg); }
.buffet-noble-a {
	padding: 0 var(--space-lg) var(--space-md);
	color: var(--color-text);
}
.buffet-noble-a p { margin: 0; }

/* ── CTA-02 ── */
.panneau-prime {
	padding: var(--space-2xl) 0;
	background: linear-gradient(120deg, var(--color-gradient-mid) 0%, var(--color-accent) 100%);
	color: #fff;
}
.panneau-prime-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
	text-align: center;
}
.panneau-prime-h2 { color: #fff; font-size: var(--fs-2xl); margin-bottom: var(--space-md); }
.panneau-prime-text { max-width: 580px; margin: 0 auto var(--space-xl); font-size: var(--fs-md); color: rgba(255, 255, 255, 0.92); }
.panneau-prime-btn {
	display: inline-block;
	background: var(--color-primary);
	color: #fff;
	padding: 16px var(--space-2xl);
	border-radius: var(--radius-md);
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}
.panneau-prime-btn:hover {
	background: #04101f;
	color: #fff;
}

/* ── INLINE CTA (INLINE-CTA-02) ── */
.shelf-dark {
	background: var(--color-primary);
	color: #fff;
	padding: var(--space-lg) 0;
	margin: var(--space-xl) 0;
}
.shelf-dark-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-lg);
	flex-wrap: wrap;
}
.shelf-dark-text { margin: 0; color: rgba(255, 255, 255, 0.92); font-size: var(--fs-md); }
.shelf-dark-btn {
	display: inline-block;
	background: var(--color-accent);
	color: #fff;
	padding: 12px var(--space-xl);
	border-radius: var(--radius-md);
	font-weight: 700;
	white-space: nowrap;
	transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}
.shelf-dark-btn:hover {
	background: var(--color-accent-pressed);
	color: #fff;
}

/* ── TABLE (TABLE-05) ── */
.quai-crisp { padding: var(--space-xl) 0; }
.quai-crisp-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.quai-crisp-scroll { overflow-x: auto; border-radius: var(--radius-md); border: 1px solid var(--color-border); }
.quai-crisp-table {
	width: 100%;
	border-collapse: collapse;
	background: var(--color-bg-elevated);
}
.quai-crisp-table th,
.quai-crisp-table td {
	padding: var(--space-sm) var(--space-md);
	text-align: left;
	border-bottom: 1px solid var(--color-border);
	font-size: var(--fs-sm);
}
.quai-crisp-table thead th {
	background: var(--color-primary);
	color: #fff;
	font-weight: 700;
}
.quai-crisp-table tbody tr:nth-child(even) { background: var(--color-bg); }
.quai-crisp-table tbody tr:last-child td { border-bottom: 0; }

/* ── LEGAL (LEGAL-04) ── */
.frieze-premium { padding: var(--space-2xl) 0; }
.frieze-premium-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.frieze-premium-h1 { font-size: var(--fs-3xl); margin-bottom: var(--space-sm); }
.frieze-premium-updated { color: var(--color-text-muted); font-size: var(--fs-sm); margin-bottom: var(--space-lg); }
.frieze-premium-intro { font-size: var(--fs-md); color: var(--color-text-muted); margin-bottom: var(--space-xl); }
.frieze-premium-section { margin-bottom: var(--space-xl); }
.frieze-premium-section h2 {
	font-size: var(--fs-xl);
	margin-bottom: var(--space-md);
	color: var(--color-primary);
	border-left: 4px solid var(--color-accent);
	padding-left: var(--space-md);
}
.frieze-premium-support {
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-left: 4px solid var(--color-accent);
	padding: var(--space-lg);
	border-radius: var(--radius-md);
	margin-top: var(--space-xl);
}
.frieze-premium-support h2 { font-size: var(--fs-lg); margin-bottom: var(--space-sm); border: 0; padding: 0; }
.frieze-premium-disclaimer {
	margin-top: var(--space-xl);
	padding: var(--space-md);
	background: rgba(220, 38, 38, 0.06);
	border-left: 4px solid var(--color-rg-banner);
	color: var(--color-text);
	font-size: var(--fs-sm);
	border-radius: var(--radius-sm);
}

/* ── CONTACT FORM (FORM-01) ── */
.loft-bright { padding: var(--space-2xl) 0; }
.loft-bright-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.loft-bright-intro { font-size: var(--fs-md); color: var(--color-text-muted); margin-bottom: var(--space-lg); }
.loft-bright-form {
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-xl);
	max-width: 680px;
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}
.loft-bright-label { display: flex; flex-direction: column; gap: var(--space-xs); font-weight: 500; }
.loft-bright-label input,
.loft-bright-label textarea {
	font-family: var(--font-body);
	font-size: var(--fs-base);
	padding: 12px var(--space-md);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	background: var(--color-bg);
	color: var(--color-text);
}
.loft-bright-label input:focus,
.loft-bright-label textarea:focus {
	outline: 2px solid var(--color-accent);
	outline-offset: 1px;
}
.loft-bright-submit {
	align-self: flex-start;
	background: var(--color-accent);
	color: #fff;
	border: 0;
	padding: 14px var(--space-2xl);
	border-radius: var(--radius-md);
	font-weight: 700;
	cursor: pointer;
	font-family: var(--font-display);
	font-size: var(--fs-md);
	transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}
.loft-bright-submit:hover {
	background: var(--color-accent-pressed);
	color: #fff;
}
.loft-bright-success {
	padding: var(--space-md);
	background: rgba(84, 169, 51, 0.1);
	border-left: 4px solid var(--color-accent);
	color: var(--color-primary);
	border-radius: var(--radius-sm);
}

/* ── BYLINE (BYLINE-04) ── */
.turret-fast { margin: var(--space-2xl) auto; }
.turret-fast-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: var(--space-lg) var(--container-padding-desktop);
	display: flex;
	align-items: center;
	gap: var(--space-md);
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
}
.turret-fast-portrait {
	width: 72px;
	height: 72px;
	border-radius: 50%;
	object-fit: cover;
	flex-shrink: 0;
}
.turret-fast-name { margin: 0; font-weight: 700; font-size: var(--fs-md); color: var(--color-primary); }
.turret-fast-name a { color: inherit; text-decoration: none; }
.turret-fast-name a:hover { color: var(--color-accent); }
.turret-fast-role { margin: 4px 0 0; color: var(--color-text-muted); font-size: var(--fs-sm); }

/* ── AUTHOR CARD (AUTH-06) ── */
.facet-deep { padding: var(--space-2xl) 0; }
.facet-deep-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.facet-deep-hero {
	display: grid;
	grid-template-columns: 220px 1fr;
	gap: var(--space-xl);
	align-items: start;
	margin-bottom: var(--space-2xl);
}
.facet-deep-portrait {
	width: 220px;
	height: 220px;
	border-radius: var(--radius-lg);
	object-fit: cover;
}
.facet-deep-name { font-size: var(--fs-3xl); margin: 0 0 var(--space-xs); }
.facet-deep-role { color: var(--color-accent); font-weight: 700; margin-bottom: var(--space-md); }
.facet-deep-bio { font-size: var(--fs-md); color: var(--color-text); margin-bottom: var(--space-lg); }
.facet-deep-expertise-h { font-size: var(--fs-lg); margin-bottom: var(--space-sm); }
.facet-deep-expertise { padding-left: 1.2em; }
.facet-deep-body { margin-bottom: var(--space-2xl); }
.facet-deep-articles {
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-xl);
}
.facet-deep-articles-heading { font-size: var(--fs-xl); margin-bottom: var(--space-md); }
.facet-deep-articles-list { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--space-sm); }
.facet-deep-articles-list a {
	display: block;
	padding: var(--space-sm) var(--space-md);
	background: var(--color-bg);
	border-radius: var(--radius-sm);
	color: var(--color-primary);
	font-weight: 500;
	transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}
.facet-deep-articles-list a:hover { background: var(--color-accent); color: #fff; }
@media (max-width: 720px) {
	.facet-deep-hero { grid-template-columns: 1fr; text-align: center; }
	.facet-deep-portrait { margin: 0 auto; }
}

/* ── ERROR (ERR-03) ── */
.pave-modern {
	min-height: 60vh;
	display: flex;
	align-items: center;
	background: var(--color-primary);
	color: #fff;
}
.pave-modern-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: var(--space-2xl) var(--container-padding-desktop);
	text-align: center;
}
.pave-modern-code {
	font-size: 8rem;
	font-weight: 700;
	color: var(--color-accent);
	line-height: 1;
	margin: 0 0 var(--space-md);
	font-family: var(--font-display);
}
.pave-modern-h1 { color: #fff; font-size: var(--fs-3xl); }
.pave-modern-text { color: rgba(255, 255, 255, 0.85); max-width: 580px; margin: 0 auto var(--space-xl); }
.pave-modern-btn {
	display: inline-block;
	background: var(--color-accent);
	color: #fff;
	padding: 14px var(--space-2xl);
	border-radius: var(--radius-md);
	font-weight: 700;
	transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}
.pave-modern-btn:hover { background: var(--color-accent-pressed); color: #fff; }

/* ── FOOTER (FOOT-01) ── */
.pediment-swift {
	background: var(--color-primary);
	color: rgba(255, 255, 255, 0.78);
	padding: var(--space-2xl) 0 var(--space-lg);
}
.pediment-swift-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr;
	gap: var(--space-2xl);
}
.pediment-swift-brand-col { display: flex; flex-direction: column; gap: var(--space-md); }
.pediment-swift-logo { height: 64px; width: auto; }
.pediment-swift-tagline { color: rgba(255, 255, 255, 0.7); font-size: var(--fs-sm); margin: 0; }
.pediment-swift-nav-col h3,
.pediment-swift-legal-col h3 {
	color: #fff;
	font-size: var(--fs-md);
	margin-bottom: var(--space-md);
}
.pediment-swift-nav-col ul,
.pediment-swift-legal-col ul {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
}
.pediment-swift-nav-col a,
.pediment-swift-legal-col a {
	color: rgba(255, 255, 255, 0.78);
	font-size: var(--fs-sm);
}
.pediment-swift-nav-col a:hover,
.pediment-swift-legal-col a:hover { color: var(--color-accent); }
.pediment-swift-base {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: var(--space-xl) auto 0;
	padding: var(--space-md) var(--container-padding-desktop) 0;
	border-top: 1px solid rgba(255, 255, 255, 0.12);
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-md);
	flex-wrap: wrap;
}
.pediment-swift-copyright { font-size: var(--fs-xs); color: rgba(255, 255, 255, 0.6); margin: 0; }
.pediment-swift-eighteen { font-size: var(--fs-xs); color: var(--color-accent); margin: 0; font-weight: 700; }
@media (max-width: 900px) {
	.pediment-swift-inner { grid-template-columns: 1fr; gap: var(--space-xl); }
}

/* ── COOKIE BANNER (COOK-04) ── */
.canopy-clean {
	position: fixed;
	left: 0; right: 0; bottom: 0;
	z-index: 200;
	background: var(--color-primary);
	color: #fff;
	box-shadow: 0 -8px 24px rgba(0, 0, 0, 0.32);
}
.canopy-clean[hidden] { display: none !important; }
.canopy-clean-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: var(--space-md) var(--container-padding-desktop);
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-md);
	flex-wrap: wrap;
}
.canopy-clean-message { margin: 0; font-size: var(--fs-sm); max-width: 720px; }
.canopy-clean-actions { display: flex; gap: var(--space-sm); flex-shrink: 0; }
.canopy-clean-button {
	background: var(--color-accent);
	color: #fff;
	border: 0;
	padding: 10px var(--space-lg);
	border-radius: var(--radius-md);
	font-weight: 700;
	cursor: pointer;
	transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
	font-size: var(--fs-sm);
}
.canopy-clean-button:hover {
	background: var(--color-accent-pressed);
	color: #fff;
}
.canopy-clean-button--ghost {
	background: transparent;
	border: 1px solid rgba(255, 255, 255, 0.5);
}
.canopy-clean-button--ghost:hover {
	background: rgba(255, 255, 255, 0.08);
	color: #fff;
}
@media (max-width: 720px) {
	.canopy-clean, .canopy-clean-inner {
		padding: 12px 14px !important;
		gap: 8px !important;
		font-size: 13px !important;
		line-height: 1.35 !important;
	}
	.canopy-clean-message { font-size: 13px; }
	.canopy-clean-button {
		padding: 8px 14px !important;
		font-size: 12px !important;
		min-height: 36px !important;
	}
}
