/* Dragonslots Casino — app.css | GEO-07 sharp, TYPO-04, SPACE-01, CONT-05 1260, BP-06 */

:root {
	--color-primary: #190505;
	--color-accent: #fdff30;
	--color-accent-pressed: #fdf405;
	--color-bg: #140404;
	--color-bg-soft: #270c0c;
	--color-gradient-mid: #48b738;
	--color-text: #ffffff;
	--color-text-muted: #c0c0c0;
	--color-border: rgba(255, 255, 255, 0.08);
	--color-border-strong: rgba(255, 255, 255, 0.18);

	--container-site: 1260px;
	--container-readable: 700px;
	--container-padding-desktop: 32px;
	--container-padding-mobile: 18px;

	--space-3xs: 4px;
	--space-2xs: 8px;
	--space-xs: 12px;
	--space-sm: 16px;
	--space-md: 24px;
	--space-lg: 36px;
	--space-xl: 56px;
	--space-2xl: 88px;
	--space-3xl: 128px;

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

	--font-display: "Poppins", Arial, sans-serif;
	--font-body: "Poppins", Arial, sans-serif;

	--fs-mega: clamp(36px, 5vw + 8px, 64px);
	--fs-h1: clamp(30px, 3vw + 12px, 48px);
	--fs-h2: clamp(24px, 1.6vw + 12px, 34px);
	--fs-h3: clamp(20px, 1vw + 12px, 24px);
	--fs-body: 16.5px;
	--fs-small: 14px;

	--header-h-desktop: 112px;
	--header-h-mobile: 84px;

	--motion-fast: 140ms;
	--motion-mid: 240ms;
	--motion-slow: 380ms;
	--ease: cubic-bezier(.2, .7, .2, 1);
}

* {
	box-sizing: border-box;
}

html,
body {
	overflow-x: clip;
}

html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
	font-family: var(--font-body);
	font-size: var(--fs-body);
	line-height: 1.6;
	background: var(--color-bg);
	color: var(--color-text);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

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

h1 { font-size: var(--fs-h1); }
h2 { font-size: var(--fs-h2); }
h3 { font-size: var(--fs-h3); }

p {
	margin: 0 0 var(--space-sm);
}

a {
	color: var(--color-accent);
	text-decoration: none;
	transition: color var(--motion-fast) var(--ease);
}

a:hover { color: var(--color-accent-pressed); }
a:focus-visible { outline: 2px solid var(--color-accent); outline-offset: 3px; }

img { max-width: 100%; height: auto; display: block; }

ul, ol { padding-left: 1.4em; margin: 0 0 var(--space-sm); }
ul li, ol li { margin-bottom: var(--space-2xs); }

button {
	font-family: inherit;
	cursor: pointer;
	border: none;
}

/* Skip link */
.skip-link {
	position: absolute;
	left: 12px;
	top: -200px !important;
	background: var(--color-accent);
	color: #111;
	padding: 10px 16px;
	border-radius: var(--radius-sm);
	font-weight: 700;
	z-index: 200;
}
.skip-link:focus { top: 12px !important; }

/* ------- HEADER (HEAD-14) — split single-row: logo | nav | auth ------- */
.boxModule {
	background: var(--color-primary);
	border-bottom: 1px solid var(--color-border);
	position: relative;
	z-index: 50;
}

.boxModule-inner {
	max-width: 1440px;
	margin: 0 auto;
	padding-inline: var(--container-padding-desktop);
	min-height: var(--header-h-desktop);
	display: flex;
	align-items: center;
	gap: var(--space-md);
}

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

.boxModule-logo {
	display: inline-flex;
	align-items: center;
}

.boxModule-logo-img {
	height: 88px;
	width: auto;
	mix-blend-mode: screen;
}

.boxModule-nav {
	display: flex;
	align-items: center;
	flex: 1;
	justify-content: center;
}

.boxModule-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: var(--space-md);
	align-items: center;
}

.boxModule-link {
	color: var(--color-text);
	font-weight: 500;
	font-size: 15px;
	padding: 8px 4px;
	position: relative;
	transition: color var(--motion-fast) var(--ease);
}

.boxModule-link:hover { color: var(--color-accent); }

.boxModule-link[aria-current="page"]::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: -4px;
	height: 2px;
	background: var(--color-accent);
}

/* More dropdown (NAV-02) */
.boxModule-more {
	position: relative;
}

.boxModule-more-toggle {
	background: transparent;
	color: var(--color-text);
	font: inherit;
	font-weight: 500;
	font-size: 15px;
	padding: 8px 12px 8px 4px;
	display: inline-flex;
	align-items: center;
	gap: 6px;
}

.boxModule-more-toggle::after {
	content: "";
	width: 7px;
	height: 7px;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: rotate(45deg);
	margin-bottom: 2px;
	transition: transform var(--motion-fast) var(--ease);
}

.boxModule-more-toggle[aria-expanded="true"]::after {
	transform: rotate(-135deg);
	margin-bottom: -3px;
}

.boxModule-more-menu {
	position: absolute;
	right: 0;
	top: calc(100% + 4px);
	min-width: 220px;
	background: var(--color-bg-soft);
	border: 1px solid var(--color-border-strong);
	border-radius: var(--radius-md);
	list-style: none;
	margin: 0;
	padding: 8px;
	display: none;
	flex-direction: column;
	gap: 2px;
	z-index: 60;
	box-shadow: 0 18px 48px rgba(0, 0, 0, 0.6);
}

.boxModule-more-menu[data-open="true"] {
	display: flex;
}

.boxModule-more-menu a {
	color: var(--color-text);
	display: block;
	padding: 10px 12px;
	border-radius: var(--radius-sm);
	font-size: 15px;
}

.boxModule-more-menu a:hover {
	background: rgba(253, 255, 48, 0.12);
	color: var(--color-accent);
}

/* Auth buttons */
.boxModule-auth {
	display: flex;
	align-items: center;
	gap: var(--space-2xs);
}

.boxModule-auth-btn {
	white-space: nowrap;
	flex-shrink: 0;
	padding-inline: var(--space-md);
	padding-block: 10px;
	border-radius: var(--radius-pill);
	font-weight: 600;
	font-size: 14px;
	transition: background var(--motion-fast) var(--ease), color var(--motion-fast) var(--ease), transform var(--motion-fast) var(--ease);
}

.boxModule-auth-login {
	color: var(--color-text);
	border: 1px solid var(--color-border-strong);
	background: transparent;
}

.boxModule-auth-login:hover {
	color: var(--color-accent);
	border-color: var(--color-accent);
}

.boxModule-auth-register {
	background: var(--color-accent);
	color: #1a0606;
}

.boxModule-auth-register:hover {
	background: var(--color-accent-pressed);
	color: #1a0606;
	transform: translateY(-1px);
}

/* Mobile toggle */
.boxModule-toggle {
	display: none;
	margin-left: auto !important;
	background: transparent;
	color: var(--color-text);
	width: 44px;
	height: 44px;
	border-radius: var(--radius-sm);
	align-items: center;
	justify-content: center;
}

.boxModule-toggle-bar {
	display: block;
	width: 24px;
	height: 2px;
	background: currentColor;
	position: relative;
}

.boxModule-toggle-bar::before,
.boxModule-toggle-bar::after {
	content: "";
	position: absolute;
	width: 24px;
	height: 2px;
	background: currentColor;
	left: 0;
}

.boxModule-toggle-bar::before { top: -7px; }
.boxModule-toggle-bar::after { top: 7px; }

/* Mobile drawer */
.boxModule-drawer {
	display: none;
	position: absolute;
	left: 0;
	right: 0;
	top: 100%;
	background: var(--color-primary);
	border-top: 1px solid var(--color-border);
	padding: var(--space-md) var(--container-padding-mobile);
	max-height: calc(100vh - var(--header-h-mobile));
	overflow-y: auto;
	z-index: 55;
}

.boxModule-drawer[data-open="true"] {
	display: block;
}

.boxModule-drawer-list {
	list-style: none;
	margin: 0 0 var(--space-md);
	padding: 0;
}

.boxModule-drawer-list li {
	border-bottom: 1px solid var(--color-border);
}

.boxModule-drawer-list a {
	color: var(--color-text);
	display: block;
	padding: 14px 4px;
	font-size: 16px;
	font-weight: 500;
}

.boxModule-drawer-auth {
	display: flex;
	flex-direction: column;
	gap: var(--space-2xs);
	padding-top: var(--space-md);
}

@media (max-width: 1100px) {
	.boxModule-nav, .boxModule-auth { display: none; }
	.boxModule-toggle { display: inline-flex; }
}

@media (max-width: 720px) {
	.boxModule-inner {
		min-height: var(--header-h-mobile);
		padding-inline: var(--container-padding-mobile);
	}
	.boxModule-logo-img { height: 64px; }
}

/* ------- HERO (HERO-05) — left-aligned text, right asymmetric image ------- */
.quarterPanel {
	background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-bg-soft) 100%);
	position: relative;
	overflow: hidden;
	padding-block: var(--space-2xl);
}

.quarterPanel::before {
	content: "";
	position: absolute;
	right: -10%;
	top: -25%;
	width: 60vw;
	height: 140%;
	background: radial-gradient(ellipse at center, rgba(72, 183, 56, 0.16) 0%, transparent 70%);
	pointer-events: none;
}

.quarterPanel-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding-inline: var(--container-padding-desktop);
	display: grid;
	grid-template-columns: 1.05fr 1fr;
	gap: var(--space-xl);
	align-items: center;
	position: relative;
	z-index: 1;
}

.quarterPanel-content {
	max-width: 640px;
}

.quarterPanel-eyebrow {
	display: inline-block;
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--color-accent);
	padding: 6px 14px;
	border: 1px solid var(--color-accent);
	border-radius: var(--radius-pill);
	margin-bottom: var(--space-md);
}

.quarterPanel-title {
	font-size: var(--fs-mega);
	margin: 0 0 var(--space-md);
	color: var(--color-text);
}

.quarterPanel-subtitle {
	font-size: 18px;
	color: var(--color-text-muted);
	max-width: 56ch;
	margin: 0 0 var(--space-lg);
}

.quarterPanel-actions {
	display: flex;
	gap: var(--space-sm);
	flex-wrap: wrap;
}

.quarterPanel-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 14px 32px;
	border-radius: var(--radius-pill);
	font-weight: 700;
	font-size: 15px;
	letter-spacing: 0.02em;
	transition: background var(--motion-fast) var(--ease), color var(--motion-fast) var(--ease), transform var(--motion-fast) var(--ease);
}

.quarterPanel-btn-primary {
	background: var(--color-accent);
	color: #1a0606;
}

.quarterPanel-btn-primary:hover {
	background: var(--color-accent-pressed);
	color: #1a0606;
	transform: translateY(-1px);
}

.quarterPanel-btn-ghost {
	background: transparent;
	color: var(--color-text);
	border: 1px solid var(--color-border-strong);
}

.quarterPanel-btn-ghost:hover {
	border-color: var(--color-accent);
	color: var(--color-accent);
}

.quarterPanel-figure {
	margin: 0;
	position: relative;
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: 0 30px 60px rgba(0, 0, 0, 0.45);
	transform: rotate(0.5deg);
}

.quarterPanel-image {
	display: block;
	width: 100%;
	height: auto;
	object-fit: cover;
	aspect-ratio: 4/3;
}

@media (max-width: 900px) {
	.quarterPanel-inner {
		grid-template-columns: 1fr;
		gap: var(--space-lg);
	}
	.quarterPanel { padding-block: var(--space-xl); }
}

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

/* ------- PAGE HEADER (PHEAD-04) — centered, ribbon eyebrow ------- */
.podSpan {
	background: var(--color-primary);
	padding-block: var(--space-xl) var(--space-lg);
	text-align: center;
	border-bottom: 1px solid var(--color-border);
}

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

.podSpan-eyebrow {
	display: inline-block;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--color-accent);
	margin-bottom: var(--space-sm);
}

.podSpan-title {
	font-size: var(--fs-h1);
	max-width: 22ch;
	margin: 0 auto var(--space-sm);
}

.podSpan-meta {
	color: var(--color-text-muted);
	font-size: 14px;
	display: flex;
	gap: var(--space-sm);
	justify-content: center;
	flex-wrap: wrap;
}

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

/* ------- MAIN ------- */
.main {
	display: block;
}

.section {
	padding-block: var(--space-xl);
}

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

.section-eyebrow {
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--color-accent);
	margin-bottom: var(--space-2xs);
	display: block;
}

.section-title {
	font-size: var(--fs-h2);
	max-width: 30ch;
	margin-bottom: var(--space-lg);
}

@media (max-width: 720px) {
	.section-inner { padding-inline: var(--container-padding-mobile); }
	.section { padding-block: var(--space-lg); }
}

/* ------- PROSE (PROSE-08) ------- */
.componentGroup {
	padding-block: var(--space-lg);
}

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

.componentGroup-body {
	color: var(--color-text);
}

.componentGroup-body section {
	padding-block: var(--space-md) var(--space-sm);
	border-top: 1px solid var(--color-border);
}

.componentGroup-body section:first-child {
	border-top: none;
}

.componentGroup-body h2 {
	font-size: var(--fs-h2);
	margin-bottom: var(--space-sm);
	color: var(--color-text);
	position: relative;
	padding-left: var(--space-md);
}

.componentGroup-body h2::before {
	content: "";
	position: absolute;
	left: 0;
	top: 12px;
	width: 4px;
	height: 0.85em;
	background: var(--color-accent);
}

.componentGroup-body p {
	font-size: 16.5px;
	color: var(--color-text);
}

.componentGroup-body ul,
.componentGroup-body ol {
	margin-bottom: var(--space-sm);
}

.componentGroup-body a {
	color: var(--color-accent);
	text-decoration: underline;
	text-underline-offset: 3px;
	text-decoration-thickness: 1px;
}

.componentGroup-body a:hover {
	color: var(--color-accent-pressed);
}

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

/* Page image figures inside prose */
.componentGroup-figure {
	margin: var(--space-md) 0;
	border-radius: var(--radius-md);
	overflow: hidden;
	border: 1px solid var(--color-border);
}

.componentGroup-figure img {
	width: 100%;
	height: auto;
	display: block;
}

.componentGroup-figure-caption {
	padding: 10px 14px;
	color: var(--color-text-muted);
	font-size: 13px;
	background: rgba(255, 255, 255, 0.03);
}

/* ------- ITEMS GRID (GRID-10) — 3 column borderless cards ------- */
.streamStrip {
	padding-block: var(--space-xl);
}

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

.streamStrip-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-md);
}

.streamStrip-card {
	background: var(--color-bg-soft);
	padding: var(--space-md);
	border-radius: var(--radius-md);
	border: 1px solid var(--color-border);
	transition: border-color var(--motion-fast) var(--ease), transform var(--motion-fast) var(--ease);
	display: flex;
	flex-direction: column;
	gap: var(--space-2xs);
}

.streamStrip-card:hover {
	border-color: rgba(253, 255, 48, 0.5);
	transform: translateY(-2px);
}

.streamStrip-card-number {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: 32px;
	color: var(--color-accent);
	line-height: 1;
}

.streamStrip-card-title {
	font-size: 18px;
	margin: 0;
	color: var(--color-text);
}

.streamStrip-card-text {
	margin: 0;
	color: var(--color-text-muted);
	font-size: 15px;
	line-height: 1.55;
}

@media (max-width: 900px) {
	.streamStrip-list { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 600px) {
	.streamStrip-list { grid-template-columns: 1fr; }
	.streamStrip-inner { padding-inline: var(--container-padding-mobile); }
}

/* ------- FAQ (FAQ-10) — always-open accordion list, divider lines ------- */
.hingeRail {
	padding-block: var(--space-xl);
	background: var(--color-bg);
}

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

.hingeRail-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.hingeRail-item {
	border-top: 1px solid var(--color-border-strong);
}

.hingeRail-item:last-child {
	border-bottom: 1px solid var(--color-border-strong);
}

.hingeRail-item-button {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	background: transparent;
	color: var(--color-text);
	text-align: left;
	font-family: inherit;
	font-weight: 600;
	font-size: 17px;
	padding: var(--space-md) 0;
	gap: var(--space-md);
}

.hingeRail-item-icon {
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background: var(--color-accent);
	color: #1a0606;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	font-size: 16px;
	font-weight: 700;
	transition: transform var(--motion-mid) var(--ease);
}

.hingeRail-item[data-open="true"] .hingeRail-item-icon {
	transform: rotate(45deg);
}

.hingeRail-item-panel {
	max-height: 0;
	overflow: hidden;
	transition: max-height var(--motion-mid) var(--ease);
}

.hingeRail-item[data-open="true"] .hingeRail-item-panel {
	max-height: 600px;
}

.hingeRail-item-panel-inner {
	padding: 0 0 var(--space-md);
	color: var(--color-text-muted);
	font-size: 16px;
	line-height: 1.65;
	max-width: 70ch;
}

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

/* ------- REVIEWS (REV-08) — card-grid with rating chip ------- */
.moduleRail {
	padding-block: var(--space-xl);
	background: var(--color-primary);
}

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

.moduleRail-summary {
	display: flex;
	align-items: center;
	gap: var(--space-md);
	margin-bottom: var(--space-lg);
	flex-wrap: wrap;
}

.moduleRail-rating-big {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: 56px;
	color: var(--color-accent);
	line-height: 1;
}

.moduleRail-rating-meta {
	color: var(--color-text-muted);
	font-size: 14px;
}

.moduleRail-rating-stars {
	display: inline-block;
	color: var(--color-accent);
	font-size: 18px;
	letter-spacing: 2px;
}

.moduleRail-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-md);
}

.moduleRail-card {
	background: var(--color-bg-soft);
	border: 1px solid var(--color-border);
	padding: var(--space-md);
	border-radius: var(--radius-md);
	display: flex;
	flex-direction: column;
	gap: var(--space-2xs);
}

.moduleRail-card-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-sm);
}

.moduleRail-card-author {
	font-weight: 600;
	color: var(--color-text);
}

.moduleRail-card-rating {
	background: var(--color-accent);
	color: #1a0606;
	padding: 2px 10px;
	border-radius: var(--radius-pill);
	font-weight: 700;
	font-size: 13px;
}

.moduleRail-card-date {
	color: var(--color-text-muted);
	font-size: 13px;
}

.moduleRail-card-text {
	margin: 0;
	color: var(--color-text-muted);
	font-size: 14.5px;
	line-height: 1.6;
}

@media (max-width: 900px) {
	.moduleRail-list { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 600px) {
	.moduleRail-list { grid-template-columns: 1fr; }
	.moduleRail-inner { padding-inline: var(--container-padding-mobile); }
}

/* ------- CTA BLOCK (CTA-07) — full-width strip with accent ------- */
.axisCarousel {
	padding-block: var(--space-xl);
	background: linear-gradient(110deg, var(--color-bg-soft), var(--color-primary));
	border-block: 1px solid var(--color-border);
}

.axisCarousel-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding-inline: var(--container-padding-desktop);
	display: grid;
	grid-template-columns: 1.6fr auto;
	gap: var(--space-lg);
	align-items: center;
}

.axisCarousel-content {
	max-width: 60ch;
}

.axisCarousel-title {
	font-size: var(--fs-h2);
	margin-bottom: var(--space-2xs);
}

.axisCarousel-text {
	color: var(--color-text-muted);
	margin: 0;
}

.axisCarousel-btn {
	display: inline-flex;
	align-items: center;
	padding: 16px 36px;
	background: var(--color-accent);
	color: #1a0606;
	border-radius: var(--radius-pill);
	font-weight: 700;
	font-size: 16px;
	transition: background var(--motion-fast) var(--ease), color var(--motion-fast) var(--ease), transform var(--motion-fast) var(--ease);
	white-space: nowrap;
}

.axisCarousel-btn:hover {
	background: var(--color-accent-pressed);
	color: #1a0606;
	transform: translateY(-1px);
}

@media (max-width: 720px) {
	.axisCarousel-inner {
		grid-template-columns: 1fr;
		padding-inline: var(--container-padding-mobile);
	}
}

/* ------- INLINE CTA (INLINE-CTA-06) — slim banner inside content ------- */
.axisWrapper {
	margin-block: var(--space-lg);
	padding: var(--space-md);
	background: var(--color-bg-soft);
	border: 1px solid var(--color-accent);
	border-radius: var(--radius-md);
	display: flex;
	gap: var(--space-md);
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
}

.axisWrapper-text {
	margin: 0;
	color: var(--color-text);
	font-weight: 500;
	font-size: 16px;
	flex: 1 1 320px;
}

.axisWrapper-btn {
	background: var(--color-accent);
	color: #1a0606;
	padding: 12px 26px;
	border-radius: var(--radius-pill);
	font-weight: 700;
	font-size: 14px;
	white-space: nowrap;
	transition: background var(--motion-fast) var(--ease), color var(--motion-fast) var(--ease);
}

.axisWrapper-btn:hover {
	background: var(--color-accent-pressed);
	color: #1a0606;
}

/* ------- DATA TABLE (TABLE-04) — striped, soft borders ------- */
.courtLane {
	padding-block: var(--space-lg);
}

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

.courtLane-table {
	width: 100%;
	border-collapse: collapse;
	background: var(--color-bg-soft);
	border-radius: var(--radius-md);
	overflow: hidden;
}

.courtLane-table thead {
	background: var(--color-primary);
}

.courtLane-table th {
	color: var(--color-accent);
	text-align: left;
	padding: 14px 18px;
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	border-bottom: 1px solid var(--color-border-strong);
}

.courtLane-table td {
	padding: 14px 18px;
	color: var(--color-text);
	font-size: 15px;
	border-bottom: 1px solid var(--color-border);
}

.courtLane-table tbody tr:nth-child(even) td {
	background: rgba(255, 255, 255, 0.025);
}

.courtLane-table tbody tr:last-child td {
	border-bottom: none;
}

@media (max-width: 720px) {
	.courtLane-inner { padding-inline: var(--container-padding-mobile); }
	.courtLane-table th, .courtLane-table td { padding: 10px 12px; font-size: 14px; }
}

/* ------- LEGAL SECTION (LEGAL-06) — narrow column, side index ------- */
.slateLane {
	padding-block: var(--space-xl);
}

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

.slateLane-grid {
	display: grid;
	grid-template-columns: 220px 1fr;
	gap: var(--space-xl);
	align-items: start;
}

.slateLane-index {
	position: sticky;
	top: 32px;
	background: var(--color-bg-soft);
	padding: var(--space-md);
	border-radius: var(--radius-md);
	border: 1px solid var(--color-border);
}

.slateLane-index-title {
	font-size: 12px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--color-accent);
	margin: 0 0 var(--space-sm);
}

.slateLane-index-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-2xs);
}

.slateLane-index-list a {
	color: var(--color-text);
	font-size: 14px;
	line-height: 1.4;
	display: block;
	padding: 6px 0;
}

.slateLane-index-list a:hover {
	color: var(--color-accent);
}

.slateLane-body {
	max-width: 70ch;
}

.slateLane-intro {
	font-size: 17px;
	color: var(--color-text-muted);
	margin-bottom: var(--space-lg);
}

.slateLane-updated {
	font-size: 13px;
	color: var(--color-text-muted);
	margin-bottom: var(--space-md);
	font-style: italic;
}

.slateLane-section {
	margin-bottom: var(--space-lg);
}

.slateLane-section h2 {
	font-size: 22px;
	color: var(--color-text);
	margin-bottom: var(--space-2xs);
}

.slateLane-section p {
	color: var(--color-text-muted);
	margin-bottom: var(--space-sm);
	line-height: 1.7;
}

.slateLane-support {
	background: var(--color-bg-soft);
	padding: var(--space-md);
	border-radius: var(--radius-md);
	margin-top: var(--space-lg);
}

.slateLane-support h3 {
	font-size: 16px;
	margin-bottom: var(--space-2xs);
	color: var(--color-accent);
}

.slateLane-support ul {
	margin: 0;
	padding-left: 1.2em;
	color: var(--color-text-muted);
}

.slateLane-disclaimer {
	margin-top: var(--space-md);
	padding: var(--space-sm);
	border-left: 3px solid var(--color-accent);
	color: var(--color-text-muted);
	font-size: 14px;
	background: rgba(253, 255, 48, 0.05);
}

@media (max-width: 900px) {
	.slateLane-grid {
		grid-template-columns: 1fr;
	}
	.slateLane-index {
		position: relative;
		top: 0;
	}
}

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

/* ------- CONTACT FORM (FORM-07) ------- */
.elementPanel {
	padding-block: var(--space-xl);
}

.elementPanel-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding-inline: var(--container-padding-desktop);
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-xl);
	align-items: start;
}

.elementPanel-intro h2 {
	font-size: var(--fs-h2);
}

.elementPanel-intro p {
	color: var(--color-text-muted);
}

.elementPanel-contact-list {
	margin-top: var(--space-md);
	display: flex;
	flex-direction: column;
	gap: var(--space-2xs);
}

.elementPanel-contact-list a {
	color: var(--color-accent);
}

.elementPanel-form {
	background: var(--color-bg-soft);
	border: 1px solid var(--color-border);
	padding: var(--space-lg);
	border-radius: var(--radius-md);
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
}

.elementPanel-field {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.elementPanel-label {
	font-size: 13px;
	font-weight: 600;
	color: var(--color-text-muted);
	letter-spacing: 0.04em;
}

.elementPanel-input,
.elementPanel-textarea {
	background: var(--color-primary);
	color: var(--color-text);
	border: 1px solid var(--color-border-strong);
	padding: 12px 14px;
	font: inherit;
	font-size: 15px;
	border-radius: var(--radius-sm);
	width: 100%;
	transition: border-color var(--motion-fast) var(--ease);
}

.elementPanel-input:focus,
.elementPanel-textarea:focus {
	outline: none;
	border-color: var(--color-accent);
}

.elementPanel-textarea {
	min-height: 140px;
	resize: vertical;
}

.elementPanel-submit {
	background: var(--color-accent);
	color: #1a0606;
	padding: 14px 28px;
	border-radius: var(--radius-pill);
	font-weight: 700;
	font-size: 15px;
	align-self: flex-start;
	transition: background var(--motion-fast) var(--ease), transform var(--motion-fast) var(--ease);
}

.elementPanel-submit:hover {
	background: var(--color-accent-pressed);
	color: #1a0606;
	transform: translateY(-1px);
}

.elementPanel-success {
	color: var(--color-gradient-mid);
	font-weight: 500;
	margin-top: var(--space-sm);
	display: none;
}

.elementPanel-success[data-visible="true"] {
	display: block;
}

@media (max-width: 720px) {
	.elementPanel-inner {
		grid-template-columns: 1fr;
		padding-inline: var(--container-padding-mobile);
	}
	.elementPanel-form { padding: var(--space-md); }
}

/* ------- AUTHOR BYLINE (BYLINE-03) — portrait + name + dates row ------- */
.boardSet {
	padding-block: var(--space-lg);
	border-top: 1px solid var(--color-border);
	margin-top: var(--space-xl);
}

.boardSet-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding-inline: var(--container-padding-desktop);
	display: flex;
	gap: var(--space-md);
	align-items: center;
	flex-wrap: wrap;
}

.boardSet-portrait {
	width: 72px;
	height: 72px;
	border-radius: 50%;
	overflow: hidden;
	flex-shrink: 0;
	border: 2px solid var(--color-accent);
}

.boardSet-portrait img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.boardSet-info {
	flex: 1 1 240px;
}

.boardSet-prefix {
	display: block;
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.16em;
	color: var(--color-text-muted);
	margin-bottom: 2px;
}

.boardSet-name {
	display: inline;
	font-family: var(--font-display);
	font-weight: 700;
	font-size: 18px;
	color: var(--color-text);
}

.boardSet-name a {
	color: var(--color-text);
}

.boardSet-name a:hover { color: var(--color-accent); }

.boardSet-role {
	color: var(--color-text-muted);
	font-size: 14px;
	margin-top: 2px;
}

.boardSet-dates {
	font-size: 13px;
	color: var(--color-text-muted);
	display: flex;
	gap: var(--space-sm);
	flex-wrap: wrap;
}

.boardSet-dates time {
	white-space: nowrap;
}

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

/* ------- AUTHOR CARD (AUTH-07) ------- */
.moduleHeader {
	padding-block: var(--space-xl);
}

.moduleHeader-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding-inline: var(--container-padding-desktop);
	display: grid;
	grid-template-columns: 260px 1fr;
	gap: var(--space-xl);
	align-items: start;
}

.moduleHeader-portrait {
	border-radius: var(--radius-lg);
	overflow: hidden;
	border: 1px solid var(--color-border);
}

.moduleHeader-portrait img {
	width: 100%;
	height: auto;
	display: block;
}

.moduleHeader-role {
	display: inline-block;
	font-size: 12px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--color-accent);
	margin-bottom: var(--space-2xs);
}

.moduleHeader-name {
	font-size: var(--fs-h1);
	margin-bottom: var(--space-sm);
}

.moduleHeader-bio {
	color: var(--color-text-muted);
	font-size: 17px;
	line-height: 1.7;
	margin-bottom: var(--space-md);
}

.moduleHeader-expertise-title {
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--color-text);
	margin-bottom: var(--space-2xs);
}

.moduleHeader-expertise-list {
	list-style: none;
	padding: 0;
	margin: 0 0 var(--space-md);
	display: flex;
	gap: var(--space-2xs);
	flex-wrap: wrap;
}

.moduleHeader-expertise-list li {
	background: var(--color-bg-soft);
	border: 1px solid var(--color-border-strong);
	padding: 6px 14px;
	border-radius: var(--radius-pill);
	font-size: 13px;
	color: var(--color-text-muted);
}

.moduleHeader-articles {
	margin-top: var(--space-xl);
	padding-top: var(--space-lg);
	border-top: 1px solid var(--color-border);
}

.moduleHeader-articles-heading {
	font-size: var(--fs-h3);
	margin-bottom: var(--space-md);
}

.moduleHeader-articles-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-2xs);
}

.moduleHeader-articles-item {
	padding: 10px 12px;
	background: var(--color-bg-soft);
	border-radius: var(--radius-sm);
	color: var(--color-text);
	font-size: 15px;
}

@media (max-width: 720px) {
	.moduleHeader-inner {
		grid-template-columns: 1fr;
		padding-inline: var(--container-padding-mobile);
	}
}

/* ------- ERROR BLOCK (ERR-07) — centered hero-style ------- */
.stallPanel {
	min-height: 60vh;
	display: flex;
	align-items: center;
	justify-content: center;
	padding-block: var(--space-2xl);
	text-align: center;
	background: linear-gradient(160deg, var(--color-primary), var(--color-bg-soft));
}

.stallPanel-inner {
	max-width: 640px;
	margin: 0 auto;
	padding-inline: var(--container-padding-desktop);
}

.stallPanel-code {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: clamp(80px, 14vw, 160px);
	color: var(--color-accent);
	line-height: 1;
	margin-bottom: var(--space-md);
}

.stallPanel-title {
	font-size: var(--fs-h1);
	margin-bottom: var(--space-sm);
}

.stallPanel-text {
	color: var(--color-text-muted);
	font-size: 17px;
	margin-bottom: var(--space-lg);
}

.stallPanel-btn {
	display: inline-block;
	padding: 14px 32px;
	background: var(--color-accent);
	color: #1a0606;
	border-radius: var(--radius-pill);
	font-weight: 700;
	transition: background var(--motion-fast) var(--ease);
}

.stallPanel-btn:hover {
	background: var(--color-accent-pressed);
	color: #1a0606;
}

/* ------- FOOTER (FOOT-10) — 4-column wide, brand in first column ------- */
.knobBar {
	background: var(--color-primary);
	border-top: 1px solid var(--color-border);
	padding-block: var(--space-xl) var(--space-md);
	margin-top: var(--space-2xl);
}

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

.knobBar-cols {
	display: grid;
	grid-template-columns: 1.5fr 1fr 1fr 1fr;
	gap: var(--space-lg);
}

.knobBar-brand-logo {
	height: 76px;
	width: auto;
	margin-bottom: var(--space-sm);
	mix-blend-mode: screen;
}

.knobBar-brand-desc {
	color: var(--color-text-muted);
	font-size: 14px;
	line-height: 1.6;
	max-width: 36ch;
}

.knobBar-col-title {
	font-size: 13px;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--color-accent);
	margin-bottom: var(--space-sm);
	font-weight: 700;
}

.knobBar-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.knobBar-list a {
	color: var(--color-text-muted);
	font-size: 14px;
	transition: color var(--motion-fast) var(--ease);
}

.knobBar-list a:hover {
	color: var(--color-accent);
}

.knobBar-contact {
	color: var(--color-text-muted);
	font-size: 14px;
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.knobBar-contact a {
	color: var(--color-accent);
}

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

.knobBar-bottom-rg {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.knobBar-bottom-rg-badge {
	width: 36px;
	height: 22px;
	background: var(--color-text);
	color: #111;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	font-size: 11px;
	border-radius: 4px;
}

@media (max-width: 900px) {
	.knobBar-cols {
		grid-template-columns: 1fr 1fr;
	}
}

@media (max-width: 600px) {
	.knobBar-cols {
		grid-template-columns: 1fr;
	}
	.knobBar-inner { padding-inline: var(--container-padding-mobile); }
}

/* ------- COOKIE BANNER (COOK-03) — bottom-center compact pill ------- */
.annexZone {
	position: fixed;
	left: 50%;
	bottom: 24px;
	transform: translateX(-50%);
	max-width: 880px;
	width: calc(100% - 32px);
	background: var(--color-bg-soft);
	color: var(--color-text);
	border: 1px solid var(--color-accent);
	border-radius: var(--radius-md);
	box-shadow: 0 20px 56px rgba(0, 0, 0, 0.55);
	z-index: 100;
	display: none;
}

.annexZone[data-visible="true"] {
	display: block;
}

.annexZone-inner {
	padding: 18px 22px;
	display: flex;
	gap: var(--space-md);
	align-items: center;
	flex-wrap: wrap;
}

.annexZone-message {
	flex: 1 1 320px;
	margin: 0;
	font-size: 14.5px;
	line-height: 1.5;
}

.annexZone-buttons {
	display: flex;
	gap: var(--space-2xs);
}

.annexZone-button {
	padding: 10px 18px;
	border-radius: var(--radius-pill);
	font-weight: 700;
	font-size: 14px;
	font-family: inherit;
	transition: background var(--motion-fast) var(--ease), color var(--motion-fast) var(--ease);
}

.annexZone-button-accept {
	background: var(--color-accent);
	color: #1a0606;
}

.annexZone-button-accept:hover {
	background: var(--color-accent-pressed);
	color: #1a0606;
}

.annexZone-button-decline {
	background: transparent;
	color: var(--color-text-muted);
	border: 1px solid var(--color-border-strong);
}

.annexZone-button-decline:hover {
	color: var(--color-text);
	border-color: var(--color-text);
}

@media (max-width: 720px) {
	.annexZone, .annexZone-inner {
		padding: 12px 14px !important;
		gap: 8px !important;
		font-size: 13px !important;
		line-height: 1.35 !important;
	}
	.annexZone-title, .annexZone-heading { display: none !important; }
	.annexZone-button, .annexZone button {
		padding: 8px 14px !important;
		font-size: 12px !important;
		min-height: 36px !important;
	}
	.annexZone {
		bottom: 12px;
		width: calc(100% - 24px);
	}
}
