/* BigBoost Casino — global-plus.css */
/* Tokens: TYPO-04 / SPACE-09 / CONT-07 / BP-03 / GEO-08 / MOTION-01 */

:root {
	--color-primary: #150530;
	--color-accent: #ff3c4c;
	--color-accent-pressed: #fd2038;
	--color-bg: #130630;
	--color-bg-elev: #1c0a3e;
	--color-bg-soft: #20104a;
	--color-border: #2e1a55;
	--color-gradient-light: #ffbcc2;
	--color-gradient-mid: #ffffff;
	--color-text: #ffffff;
	--color-text-muted: #c1bfbf;

	--font-display: "Hind", "Outfit", system-ui, sans-serif;
	--font-body: "Hind", "Outfit", system-ui, sans-serif;

	--fs-xs: 13px;
	--fs-sm: 14px;
	--fs-base: 16px;
	--fs-md: 18px;
	--fs-lg: 22px;
	--fs-xl: 28px;
	--fs-2xl: 36px;
	--fs-3xl: 48px;
	--fs-hero: 60px;

	--lh-tight: 1.15;
	--lh-snug: 1.35;
	--lh-base: 1.6;

	--space-2xs: 4px;
	--space-xs: 8px;
	--space-sm: 12px;
	--space-md: 18px;
	--space-lg: 28px;
	--space-xl: 44px;
	--space-2xl: 48px;
	--space-3xl: 80px;

	--container-site: 1140px;
	--container-readable: 670px;
	--container-padding-desktop: 28px;
	--container-padding-mobile: 18px;

	--radius-sm: 6px;
	--radius-md: 12px;
	--radius-lg: 22px;
	--radius-pill: 999px;

	--shadow-soft: 0 6px 22px rgba(0, 0, 0, 0.28);
	--shadow-strong: 0 18px 48px rgba(0, 0, 0, 0.45);

	--motion-fast: 120ms ease;
	--motion-base: 220ms cubic-bezier(0.2, 0.6, 0.2, 1);

	--header-height-desktop: 132px;
	--header-height-mobile: 70px;
}

*, *::before, *::after { box-sizing: border-box; }

html, body { overflow-x: clip; }

html { scroll-behavior: smooth; }

body {
	margin: 0;
	background: var(--color-bg);
	color: var(--color-text);
	font-family: var(--font-body);
	font-size: var(--fs-base);
	line-height: var(--lh-base);
	padding-top: var(--header-height-desktop);
	-webkit-font-smoothing: antialiased;
}

@media (max-width: 720px) {
	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(--motion-fast); }
a:hover { color: var(--color-gradient-light); }
p { margin: 0 0 var(--space-md); }

h1, h2, h3, h4 {
	font-family: var(--font-display);
	line-height: var(--lh-tight);
	margin: 0 0 var(--space-md);
	letter-spacing: -0.01em;
	font-weight: 700;
}

h1 { font-size: var(--fs-3xl); }
h2 { font-size: var(--fs-2xl); margin-top: var(--space-2xl); }
h3 { font-size: var(--fs-xl); margin-top: var(--space-xl); }
h4 { font-size: var(--fs-lg); }

@media (max-width: 720px) {
	h1 { font-size: 34px; }
	h2 { font-size: 26px; }
	h3 { font-size: 20px; }
}

/* Skip-link OFF-SCREEN */
.skip-link {
	position: absolute;
	left: 0;
	background: var(--color-accent);
	color: #fff;
	padding: 10px 16px;
	z-index: 2000;
	border-radius: 0 0 var(--radius-md) 0;
}
.skip-link:not(:focus) { top: -200px !important; }
.skip-link:focus { top: 0; outline: 2px solid #fff; }

/* Site frame */
.site-frame {
	width: 100%;
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding-inline: var(--container-padding-desktop);
}

@media (max-width: 720px) {
	.site-frame { padding-inline: var(--container-padding-mobile); }
}

/* =============== HEADER HEAD-13 (.beacon-cool) — fixed, two-row NAV-03 with divider =============== */
.beacon-cool {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 90;
	background: linear-gradient(180deg, rgba(19, 6, 48, 0.96), rgba(21, 5, 48, 0.92));
	backdrop-filter: blur(10px);
	border-bottom: 1px solid var(--color-border);
	transition: box-shadow var(--motion-base), background var(--motion-base);
}

.beacon-cool.is-stuck {
	background: rgba(19, 6, 48, 0.98);
	box-shadow: var(--shadow-soft);
}

.beacon-cool-inner {
	display: flex;
	flex-direction: column;
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding-inline: var(--space-md);
}

.beacon-cool-top {
	display: flex;
	align-items: center;
	gap: var(--space-lg);
	min-height: 70px;
	padding-block: 10px;
}

.beacon-cool-logo {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	margin-right: var(--space-lg);
}

.beacon-cool-logo,
.beacon-cool-logo img { flex-shrink: 0; }

.beacon-cool-logo-pill {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: #fff;
	padding: 8px 16px;
	border-radius: var(--radius-md);
}

.beacon-cool-logo-img {
	height: 96px;
	width: auto;
	max-width: 200px;
}

@media (min-width: 721px) {
	.beacon-cool-logo-img { height: 80px; max-width: 240px; }
}

.beacon-cool-nav-top,
.beacon-cool-nav-bottom {
	display: flex;
	align-items: center;
	gap: var(--space-md);
	flex-wrap: nowrap;
	list-style: none;
	margin: 0;
	padding: 0;
}

.beacon-cool-nav-top { margin-left: auto; }
.beacon-cool-nav-bottom { justify-content: center; padding-block: 10px; }

.beacon-cool-nav-top a,
.beacon-cool-nav-bottom a {
	color: var(--color-text);
	font-size: var(--fs-sm);
	font-weight: 600;
	padding: 8px 4px;
	letter-spacing: 0.02em;
	white-space: nowrap;
	border-bottom: 2px solid transparent;
	transition: color var(--motion-fast), border-color var(--motion-fast);
}

.beacon-cool-nav-top a:hover,
.beacon-cool-nav-bottom a:hover,
.beacon-cool-nav-top a[aria-current="page"],
.beacon-cool-nav-bottom a[aria-current="page"] {
	color: var(--color-gradient-light);
	border-bottom-color: var(--color-accent);
}

.beacon-cool-auth {
	display: flex;
	align-items: center;
	gap: var(--space-xs);
	margin-left: var(--space-md);
}

.beacon-cool-auth-btn {
	white-space: nowrap;
	flex-shrink: 0;
	padding-inline: var(--space-lg);
	padding-block: 10px;
	font-size: var(--fs-sm);
	font-weight: 700;
	border-radius: var(--radius-pill);
	border: 2px solid transparent;
	transition: all var(--motion-base);
	cursor: pointer;
	font-family: var(--font-display);
}

.beacon-cool-auth-btn--login {
	background: transparent;
	color: var(--color-text);
	border-color: rgba(255, 255, 255, 0.4);
}
.beacon-cool-auth-btn--login:hover { border-color: var(--color-accent); color: var(--color-accent); }

.beacon-cool-auth-btn--register {
	background: var(--color-accent);
	color: #fff;
}
.beacon-cool-auth-btn--register:hover { background: var(--color-accent-pressed); color: #fff; }
.beacon-cool-auth-btn--register, .beacon-cool-auth-btn--register:visited { color: #fff; }

/* NAV-03 divider */
.beacon-cool-divider {
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--color-border) 20%, var(--color-border) 80%, transparent);
}

/* Burger */
.beacon-cool-toggle {
	display: none;
	margin-left: auto !important;
	background: transparent;
	border: 0;
	color: var(--color-text);
	padding: 10px;
	cursor: pointer;
	width: 44px;
	height: 44px;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 5px;
}

.beacon-cool-toggle span {
	display: block;
	width: 24px;
	height: 2px;
	background: currentColor;
	transition: transform var(--motion-fast), opacity var(--motion-fast);
}

.beacon-cool-mobile {
	display: none;
	background: var(--color-bg-elev);
	border-top: 1px solid var(--color-border);
	padding: var(--space-md);
}

.beacon-cool-mobile.is-open { display: block; }

.beacon-cool-mobile ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
}

.beacon-cool-mobile a {
	display: block;
	padding: 12px var(--space-md);
	color: var(--color-text);
	border-radius: var(--radius-sm);
	font-weight: 600;
	background: rgba(255, 255, 255, 0.04);
}

.beacon-cool-mobile a:hover, .beacon-cool-mobile a[aria-current="page"] {
	background: rgba(255, 60, 76, 0.2);
}

.beacon-cool-mobile-auth {
	display: flex;
	gap: var(--space-sm);
	margin-top: var(--space-md);
}
.beacon-cool-mobile-auth .beacon-cool-auth-btn { flex: 1; text-align: center; }

@media (max-width: 960px) {
	.beacon-cool-nav-top,
	.beacon-cool-nav-bottom,
	.beacon-cool-divider,
	.beacon-cool-auth { display: none; }
	.beacon-cool-toggle { display: inline-flex; }
	.beacon-cool-top { min-height: 64px; }
	.beacon-cool-logo-img { height: 64px; }
}

/* =============== HERO HERO-08 (.hutch-alt) — split layout: text left, image right, soft gradient frame =============== */
.hutch-alt {
	position: relative;
	background: radial-gradient(circle at 80% 20%, rgba(255, 60, 76, 0.18), transparent 55%),
	            linear-gradient(160deg, var(--color-bg) 30%, var(--color-bg-soft));
	padding-block: var(--space-3xl);
	overflow: hidden;
}

.hutch-alt::before {
	content: "";
	position: absolute;
	inset: auto -10% -20% auto;
	width: 50%;
	height: 60%;
	background: linear-gradient(135deg, var(--color-gradient-light), transparent);
	opacity: 0.12;
	filter: blur(60px);
	pointer-events: none;
}

.hutch-alt-grid {
	display: grid;
	grid-template-columns: 1.05fr 0.95fr;
	gap: var(--space-2xl);
	align-items: center;
}

.hutch-alt-text { display: flex; flex-direction: column; align-items: flex-start; }

.hutch-alt-eyebrow {
	display: inline-block;
	font-size: var(--fs-xs);
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--color-gradient-light);
	padding: 6px 14px;
	border-radius: var(--radius-pill);
	border: 1px solid rgba(255, 188, 194, 0.4);
	margin-bottom: var(--space-md);
}

.hutch-alt-title {
	font-size: var(--fs-hero);
	line-height: 1.05;
	margin: 0 0 var(--space-md);
	background: linear-gradient(120deg, var(--color-gradient-mid), var(--color-gradient-light));
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}

.hutch-alt-subtitle {
	font-size: var(--fs-md);
	color: var(--color-text-muted);
	max-width: 56ch;
	margin-bottom: var(--space-lg);
}

.hutch-alt-cta {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	background: var(--color-accent);
	color: #fff;
	padding: 16px 36px;
	border-radius: var(--radius-pill);
	font-weight: 800;
	font-size: var(--fs-md);
	font-family: var(--font-display);
	transition: transform var(--motion-base), background var(--motion-base);
	box-shadow: 0 12px 30px rgba(255, 60, 76, 0.35);
}
.hutch-alt-cta:hover { background: var(--color-accent-pressed); transform: translateY(-2px); color: #fff; }

.hutch-alt-image {
	position: relative;
	border-radius: var(--radius-lg);
	overflow: hidden;
	aspect-ratio: 4 / 3;
	box-shadow: var(--shadow-strong);
	border: 1px solid var(--color-border);
}
.hutch-alt-image img { width: 100%; height: 100%; object-fit: cover; }

@media (max-width: 960px) {
	.hutch-alt { padding-block: var(--space-2xl); }
	.hutch-alt-grid { grid-template-columns: 1fr; gap: var(--space-xl); }
	.hutch-alt-title { font-size: 40px; }
	.hutch-alt-image { aspect-ratio: 16/10; order: -1; }
}

/* =============== PAGE-HEADER PHEAD-08 (.landing-warm) — centered with accent underline =============== */
.landing-warm {
	background: linear-gradient(180deg, var(--color-bg-soft), var(--color-bg) 90%);
	padding-block: var(--space-2xl);
	border-bottom: 1px solid var(--color-border);
	position: relative;
}

.landing-warm-inner {
	text-align: center;
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
}

.landing-warm-text {
	max-width: 820px;
	margin: 0 auto;
}

.landing-warm-eyebrow {
	display: inline-block;
	font-size: var(--fs-xs);
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--color-gradient-light);
	margin-bottom: var(--space-md);
	font-weight: 700;
}

.landing-warm-title {
	font-size: var(--fs-3xl);
	margin: 0 0 var(--space-md);
}

.landing-warm-title::after {
	content: "";
	display: block;
	width: 80px;
	height: 4px;
	background: var(--color-accent);
	border-radius: var(--radius-pill);
	margin: var(--space-md) auto 0;
}

.landing-warm-subtitle {
	color: var(--color-text-muted);
	font-size: var(--fs-md);
}

@media (max-width: 720px) {
	.landing-warm { padding-block: var(--space-xl); }
	.landing-warm-title { font-size: 30px; }
}

/* =============== PROSE PROSE-04 (.medaillon-plus) — body content with accent quotes =============== */
.medaillon-plus {
	padding-block: var(--space-2xl);
}

.medaillon-plus-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
}

.medaillon-plus-readable {
	max-width: var(--container-readable);
	margin: 0 auto;
}

.medaillon-plus h2 {
	font-size: var(--fs-2xl);
	color: var(--color-gradient-light);
	margin-top: var(--space-2xl);
	padding-left: var(--space-md);
	border-left: 4px solid var(--color-accent);
}
.medaillon-plus h2:first-child { margin-top: 0; }

.medaillon-plus h3 { color: var(--color-text); }

.medaillon-plus p, .medaillon-plus li {
	font-size: var(--fs-md);
	line-height: 1.7;
	color: var(--color-text);
}

.medaillon-plus ul, .medaillon-plus ol {
	padding-left: var(--space-lg);
	margin-block: var(--space-md);
}

.medaillon-plus li { margin-bottom: var(--space-xs); }

.medaillon-plus strong { color: var(--color-gradient-light); }
.medaillon-plus em { color: var(--color-text); font-style: italic; }
.medaillon-plus a { text-decoration: underline; text-underline-offset: 3px; }

/* Page-context image inside prose */
.medaillon-plus-figure {
	margin: var(--space-xl) 0;
	border-radius: var(--radius-lg);
	overflow: hidden;
	border: 1px solid var(--color-border);
}
.medaillon-plus-figure img { width: 100%; height: auto; }
.medaillon-plus-figure figcaption {
	background: var(--color-bg-soft);
	color: var(--color-text-muted);
	font-size: var(--fs-sm);
	padding: var(--space-sm) var(--space-md);
	text-align: center;
}

/* =============== ITEMS-GRID GRID-11 (.pave-classic) — 3-column flat cards with top-accent stripe =============== */
.pave-classic {
	padding-block: var(--space-2xl);
	background: linear-gradient(180deg, var(--color-bg), var(--color-bg-elev));
}

.pave-classic-heading {
	font-size: var(--fs-2xl);
	text-align: center;
	margin-bottom: var(--space-xl);
}

.pave-classic-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-md);
}

.pave-classic-card {
	position: relative;
	background: var(--color-bg-soft);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-lg);
	padding-top: calc(var(--space-lg) + 6px);
	transition: transform var(--motion-base), border-color var(--motion-base);
}

.pave-classic-card::before {
	content: "";
	position: absolute;
	top: 0;
	left: var(--space-lg);
	right: var(--space-lg);
	height: 3px;
	background: var(--color-accent);
	border-radius: 0 0 var(--radius-sm) var(--radius-sm);
}

.pave-classic-card:hover { transform: translateY(-3px); border-color: var(--color-accent); }

.pave-classic-card h3 {
	font-size: var(--fs-lg);
	margin: 0 0 var(--space-sm);
	color: var(--color-gradient-light);
	line-height: var(--lh-snug);
}

.pave-classic-card p {
	font-size: var(--fs-sm);
	color: var(--color-text);
	line-height: 1.6;
	margin: 0;
}

@media (max-width: 960px) {
	.pave-classic-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
	.pave-classic-grid { grid-template-columns: 1fr; }
}

/* =============== FAQ FAQ-09 (.barrow-bold) — bold-bordered accordion =============== */
.barrow-bold {
	padding-block: var(--space-2xl);
}

.barrow-bold-heading {
	font-size: var(--fs-2xl);
	text-align: center;
	margin-bottom: var(--space-xl);
}

.barrow-bold-list {
	max-width: 820px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
}

.barrow-bold-item {
	border: 2px solid var(--color-border);
	border-radius: var(--radius-md);
	background: var(--color-bg-soft);
	overflow: hidden;
	transition: border-color var(--motion-base);
}

.barrow-bold-item[open] {
	border-color: var(--color-accent);
}

.barrow-bold-item summary {
	padding: var(--space-md) var(--space-lg);
	cursor: pointer;
	font-weight: 700;
	font-size: var(--fs-md);
	color: var(--color-text);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-md);
	list-style: none;
}
.barrow-bold-item summary::-webkit-details-marker { display: none; }
.barrow-bold-item summary::after {
	content: "+";
	font-size: 24px;
	color: var(--color-accent);
	transition: transform var(--motion-base);
	flex-shrink: 0;
}
.barrow-bold-item[open] summary::after { content: "−"; }

.barrow-bold-answer {
	padding: 0 var(--space-lg) var(--space-md);
	color: var(--color-text-muted);
	font-size: var(--fs-base);
	line-height: 1.6;
}

/* =============== REVIEWS REV-07 (.seuil-plus) — grid cards with quote marker =============== */
.seuil-plus {
	padding-block: var(--space-2xl);
	background: var(--color-bg-elev);
}

.seuil-plus-heading {
	font-size: var(--fs-2xl);
	text-align: center;
	margin-bottom: var(--space-xl);
}

.seuil-plus-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-md);
}

.seuil-plus-card {
	background: var(--color-bg-soft);
	border-radius: var(--radius-md);
	padding: var(--space-lg);
	border: 1px solid var(--color-border);
	position: relative;
}

.seuil-plus-card::before {
	content: "\201C";
	position: absolute;
	top: -8px;
	left: var(--space-md);
	font-family: Georgia, serif;
	font-size: 60px;
	line-height: 1;
	color: var(--color-accent);
}

.seuil-plus-stars {
	color: var(--color-gradient-light);
	font-size: var(--fs-md);
	letter-spacing: 0.1em;
	margin-bottom: var(--space-xs);
}

.seuil-plus-text {
	font-size: var(--fs-sm);
	line-height: 1.6;
	color: var(--color-text);
	margin: 0 0 var(--space-md);
}

.seuil-plus-author {
	font-size: var(--fs-sm);
	font-weight: 700;
	color: var(--color-gradient-light);
}

@media (max-width: 960px) {
	.seuil-plus-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
	.seuil-plus-grid { grid-template-columns: 1fr; }
}

/* =============== CTA CTA-03 (.spread-raw) — wide banner with gradient frame =============== */
.spread-raw {
	padding-block: var(--space-2xl);
}

.spread-raw-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	background: linear-gradient(135deg, var(--color-accent), #c8203a);
	border-radius: var(--radius-lg);
	padding: var(--space-2xl) var(--space-xl);
	text-align: center;
	box-shadow: var(--shadow-strong);
	position: relative;
	overflow: hidden;
}

.spread-raw-inner::after {
	content: "";
	position: absolute;
	inset: -20%;
	background: radial-gradient(circle at 30% 0%, rgba(255, 188, 194, 0.4), transparent 50%);
	pointer-events: none;
}

.spread-raw-title {
	font-size: var(--fs-2xl);
	color: #fff;
	margin: 0 0 var(--space-sm);
}

.spread-raw-text {
	color: rgba(255, 255, 255, 0.92);
	font-size: var(--fs-md);
	max-width: 56ch;
	margin: 0 auto var(--space-lg);
}

.spread-raw-btn {
	display: inline-block;
	background: var(--color-bg);
	color: var(--color-text);
	padding: 14px 32px;
	border-radius: var(--radius-pill);
	font-weight: 800;
	font-size: var(--fs-md);
	font-family: var(--font-display);
	transition: background var(--motion-base), transform var(--motion-base);
	position: relative;
	z-index: 1;
}
.spread-raw-btn:hover { background: #000; color: #fff; transform: translateY(-2px); }

/* =============== DATA-TABLE TABLE-06 (.cloche-fine) — alternating row band, accent header =============== */
.cloche-fine {
	width: 100%;
	border-collapse: collapse;
	background: var(--color-bg-soft);
	border-radius: var(--radius-md);
	overflow: hidden;
	margin: var(--space-lg) 0;
	font-size: var(--fs-sm);
}

.cloche-fine thead { background: var(--color-accent); color: #fff; }
.cloche-fine th { padding: 14px 16px; text-align: left; font-weight: 700; }
.cloche-fine td { padding: 14px 16px; border-bottom: 1px solid var(--color-border); }
.cloche-fine tbody tr:nth-child(even) { background: rgba(255, 255, 255, 0.03); }
.cloche-fine tbody tr:last-child td { border-bottom: 0; }

/* =============== LEGAL-SECTION LEGAL-02 (.imposte-alt) — single-column with numbered sections =============== */
.imposte-alt {
	padding-block: var(--space-2xl);
}

.imposte-alt-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
}

.imposte-alt-readable {
	max-width: var(--container-readable);
	margin: 0 auto;
}

.imposte-alt-intro {
	font-size: var(--fs-md);
	color: var(--color-text-muted);
	padding: var(--space-md);
	border-left: 3px solid var(--color-accent);
	background: var(--color-bg-soft);
	border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
	margin-bottom: var(--space-xl);
}

.imposte-alt-section {
	margin-bottom: var(--space-xl);
	counter-increment: legal-section;
}

.imposte-alt-section h2 {
	font-size: var(--fs-xl);
	color: var(--color-gradient-light);
	margin-top: 0;
	display: flex;
	align-items: baseline;
	gap: var(--space-sm);
}
.imposte-alt-section h2::before {
	content: counter(legal-section, decimal-leading-zero);
	font-size: var(--fs-lg);
	color: var(--color-accent);
	font-family: var(--font-display);
}

.imposte-alt-inner { counter-reset: legal-section; }

.imposte-alt-section p {
	font-size: var(--fs-base);
	line-height: 1.7;
}

.imposte-alt-contacts {
	background: var(--color-bg-soft);
	padding: var(--space-md);
	border-radius: var(--radius-md);
	border: 1px solid var(--color-border);
}
.imposte-alt-contacts h3 { margin-top: 0; font-size: var(--fs-md); }
.imposte-alt-contacts ul { padding-left: var(--space-lg); }
.imposte-alt-contacts li { font-size: var(--fs-sm); margin-bottom: var(--space-xs); }

.imposte-alt-disclaimer {
	margin-top: var(--space-xl);
	font-size: var(--fs-sm);
	color: var(--color-text-muted);
	font-style: italic;
}

/* =============== CONTACT-FORM FORM-05 (.gable-crisp) — stacked, large fields =============== */
.gable-crisp {
	padding-block: var(--space-2xl);
}

.gable-crisp-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
}

.gable-crisp-form {
	max-width: 640px;
	margin: 0 auto;
	background: var(--color-bg-soft);
	border-radius: var(--radius-lg);
	padding: var(--space-xl);
	border: 1px solid var(--color-border);
}

.gable-crisp-intro {
	margin-bottom: var(--space-lg);
	color: var(--color-text-muted);
}

.gable-crisp-field {
	display: flex;
	flex-direction: column;
	margin-bottom: var(--space-md);
}

.gable-crisp-field label {
	font-size: var(--fs-sm);
	font-weight: 600;
	color: var(--color-gradient-light);
	margin-bottom: 6px;
	letter-spacing: 0.02em;
}

.gable-crisp-field input,
.gable-crisp-field textarea {
	background: var(--color-bg);
	border: 2px solid var(--color-border);
	color: var(--color-text);
	padding: 14px 16px;
	border-radius: var(--radius-sm);
	font-family: var(--font-body);
	font-size: var(--fs-base);
	transition: border-color var(--motion-fast);
}

.gable-crisp-field input:focus,
.gable-crisp-field textarea:focus {
	outline: 0;
	border-color: var(--color-accent);
}

.gable-crisp-field textarea {
	min-height: 140px;
	resize: vertical;
}

.gable-crisp-submit {
	background: var(--color-accent);
	color: #fff;
	border: 0;
	padding: 14px 30px;
	border-radius: var(--radius-pill);
	font-weight: 800;
	font-size: var(--fs-md);
	font-family: var(--font-display);
	cursor: pointer;
	transition: background var(--motion-base);
	width: 100%;
}
.gable-crisp-submit:hover { background: var(--color-accent-pressed); }

.gable-crisp-success {
	display: none;
	padding: var(--space-md);
	background: rgba(255, 60, 76, 0.15);
	border: 1px solid var(--color-accent);
	border-radius: var(--radius-sm);
	margin-top: var(--space-md);
	color: var(--color-gradient-light);
}
.gable-crisp-success.is-visible { display: block; }

/* =============== AUTHOR-BYLINE BYLINE-02 (.pilier-keen) — horizontal card with photo left =============== */
.pilier-keen {
	max-width: var(--container-readable);
	margin: var(--space-2xl) auto var(--space-lg);
	background: var(--color-bg-soft);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-md);
	display: flex;
	align-items: center;
	gap: var(--space-md);
}

.pilier-keen-photo {
	width: 72px;
	height: 72px;
	border-radius: 50%;
	overflow: hidden;
	flex-shrink: 0;
	border: 2px solid var(--color-accent);
}
.pilier-keen-photo img { width: 100%; height: 100%; object-fit: cover; }

.pilier-keen-meta { flex: 1; min-width: 0; }
.pilier-keen-label {
	font-size: var(--fs-xs);
	color: var(--color-text-muted);
	letter-spacing: 0.15em;
	text-transform: uppercase;
}
.pilier-keen-name {
	font-size: var(--fs-md);
	font-weight: 700;
	color: var(--color-gradient-light);
	margin: 2px 0;
}
.pilier-keen-name a { color: inherit; text-decoration: none; }
.pilier-keen-name a:hover { text-decoration: underline; }
.pilier-keen-role {
	font-size: var(--fs-sm);
	color: var(--color-text-muted);
}

/* =============== AUTHOR-CARD AUTH-05 (.gallery-premium) — full bio block with portrait =============== */
.gallery-premium {
	padding-block: var(--space-2xl);
}

.gallery-premium-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
}

.gallery-premium-card {
	max-width: 920px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 240px 1fr;
	gap: var(--space-xl);
	align-items: start;
	background: var(--color-bg-soft);
	padding: var(--space-xl);
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-border);
}

.gallery-premium-portrait {
	width: 100%;
	aspect-ratio: 1;
	border-radius: var(--radius-md);
	overflow: hidden;
	border: 3px solid var(--color-accent);
}
.gallery-premium-portrait img { width: 100%; height: 100%; object-fit: cover; }

.gallery-premium-meta { min-width: 0; }

.gallery-premium-name {
	font-size: var(--fs-2xl);
	margin: 0 0 var(--space-xs);
}
.gallery-premium-role {
	color: var(--color-gradient-light);
	font-weight: 600;
	margin-bottom: var(--space-md);
}
.gallery-premium-bio {
	color: var(--color-text);
	line-height: 1.7;
	margin-bottom: var(--space-md);
}
.gallery-premium-expertise {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	list-style: none;
	padding: 0;
	margin: 0;
}
.gallery-premium-expertise li {
	background: var(--color-bg);
	color: var(--color-text);
	padding: 6px 14px;
	border-radius: var(--radius-pill);
	border: 1px solid var(--color-border);
	font-size: var(--fs-sm);
}

/* Articles list */
.gallery-premium-articles {
	max-width: 920px;
	margin: var(--space-xl) auto 0;
	background: var(--color-bg-soft);
	padding: var(--space-xl);
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-border);
}
.gallery-premium-articles-heading {
	font-size: var(--fs-xl);
	margin: 0 0 var(--space-md);
	color: var(--color-gradient-light);
}
.gallery-premium-articles-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
}
.gallery-premium-articles-item {
	padding: var(--space-sm) var(--space-md);
	background: var(--color-bg);
	border-radius: var(--radius-sm);
	border-left: 3px solid var(--color-border);
	transition: border-color var(--motion-fast);
}
.gallery-premium-articles-item:hover { border-left-color: var(--color-accent); }
.gallery-premium-articles-item--featured { border-left-color: var(--color-accent); }
.gallery-premium-articles-item a { color: var(--color-text); font-weight: 600; }
.gallery-premium-articles-item a:hover { color: var(--color-gradient-light); }

@media (max-width: 720px) {
	.gallery-premium-card { grid-template-columns: 1fr; padding: var(--space-md); }
	.gallery-premium-portrait { max-width: 200px; margin: 0 auto; }
}

/* =============== COOKIE-BANNER COOK-02 (.deck-pure) — bottom centered pill =============== */
.deck-pure {
	position: fixed;
	left: 50%;
	bottom: 24px;
	transform: translateX(-50%);
	width: min(720px, calc(100vw - 32px));
	z-index: 80;
	background: var(--color-bg-elev);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-strong);
	padding: var(--space-md) var(--space-lg);
	display: flex;
	align-items: center;
	gap: var(--space-md);
}
.deck-pure[hidden] { display: none !important; }

.deck-pure-message {
	flex: 1;
	font-size: var(--fs-sm);
	color: var(--color-text);
	line-height: 1.45;
	margin: 0;
}

.deck-pure-buttons {
	display: flex;
	gap: var(--space-xs);
	flex-shrink: 0;
}

.deck-pure-button {
	border: 0;
	cursor: pointer;
	padding: 10px 18px;
	border-radius: var(--radius-pill);
	font-weight: 700;
	font-size: var(--fs-sm);
	font-family: var(--font-display);
}
.deck-pure-button--accept { background: var(--color-accent); color: #fff; }
.deck-pure-button--accept:hover { background: var(--color-accent-pressed); }
.deck-pure-button--decline { background: transparent; color: var(--color-text); border: 1px solid var(--color-border); }
.deck-pure-button--decline:hover { background: rgba(255, 255, 255, 0.05); }

@media (max-width: 720px) {
	.deck-pure, .deck-pure-inner {
		padding: 12px 14px !important;
		gap: 8px !important;
		font-size: 13px !important;
		line-height: 1.35 !important;
		bottom: 12px;
		flex-direction: column;
	}
	.deck-pure-title, .deck-pure-heading { display: none !important; }
	.deck-pure-button, .deck-pure button {
		padding: 8px 14px !important;
		font-size: 12px !important;
		min-height: 36px !important;
	}
	.deck-pure-buttons { width: 100%; }
	.deck-pure-button { flex: 1; }
}

/* =============== ERROR-BLOCK ERR-04 (.arbor-opus) — centered, large 404 numeral =============== */
.arbor-opus {
	padding-block: var(--space-3xl);
	text-align: center;
	min-height: 60vh;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: var(--space-md);
}
.arbor-opus-code {
	font-size: 140px;
	line-height: 1;
	font-family: var(--font-display);
	font-weight: 800;
	background: linear-gradient(135deg, var(--color-accent), var(--color-gradient-light));
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	margin: 0;
}
.arbor-opus-title { font-size: var(--fs-2xl); margin: 0; }
.arbor-opus-text { color: var(--color-text-muted); max-width: 56ch; margin: 0 auto; }
.arbor-opus-button {
	display: inline-block;
	background: var(--color-accent);
	color: #fff;
	padding: 14px 32px;
	border-radius: var(--radius-pill);
	font-weight: 800;
	margin-top: var(--space-md);
}
.arbor-opus-button:hover { background: var(--color-accent-pressed); color: #fff; }

/* =============== FOOTER FOOT-04 (.cour-clean) — 4 columns: brand + nav + legal + contact =============== */
.cour-clean {
	background: linear-gradient(180deg, var(--color-bg-elev), #0a0420);
	padding-block: var(--space-2xl) var(--space-md);
	border-top: 1px solid var(--color-border);
	margin-top: var(--space-3xl);
}

.cour-clean-cols {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1fr;
	gap: var(--space-xl);
}

.cour-clean-col { display: flex; flex-direction: column; }

.cour-clean-brand-logo {
	background: #fff;
	display: inline-flex;
	padding: 6px 14px;
	border-radius: var(--radius-md);
	margin-bottom: var(--space-md);
}
.cour-clean-brand-logo img { height: 60px; width: auto; }
.cour-clean-brand p {
	color: var(--color-text-muted);
	font-size: var(--fs-sm);
	max-width: 38ch;
}

.cour-clean-heading {
	font-size: var(--fs-sm);
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--color-gradient-light);
	margin: 0 0 var(--space-md);
}

.cour-clean-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.cour-clean-list a {
	color: var(--color-text);
	font-size: var(--fs-sm);
}
.cour-clean-list a:hover { color: var(--color-accent); }

.cour-clean-contact-item {
	font-size: var(--fs-sm);
	color: var(--color-text-muted);
}
.cour-clean-contact-item a { color: var(--color-text); }

.cour-clean-bottom {
	margin-top: var(--space-xl);
	padding-top: var(--space-md);
	border-top: 1px solid var(--color-border);
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-md);
	font-size: var(--fs-xs);
	color: var(--color-text-muted);
	flex-wrap: wrap;
}

.cour-clean-badges {
	display: flex;
	gap: var(--space-sm);
	align-items: center;
}
.cour-clean-badge {
	padding: 4px 10px;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	font-weight: 700;
	font-size: 11px;
	letter-spacing: 0.05em;
	color: var(--color-text-muted);
}

@media (max-width: 960px) {
	.cour-clean-cols { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
	.cour-clean-cols { grid-template-columns: 1fr; gap: var(--space-lg); }
}

/* Inline images for items-grid cards image variant — not used here */

/* Utility */
.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	margin: -1px;
	padding: 0;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	border: 0;
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
	* { transition-duration: 0.01ms !important; animation-duration: 0.01ms !important; }
}
