/* ========== Snatch GB — structure-deep.css ========== */
/* TYPO-07 airy / SPACE-01 modular 4 / CONT-03 / BP-07 / GEO-01 sharp / MOTION-01 static / NAME-04 */

/* ===== Tokens ===== */
:root {
	--color-accent: #2cd2ed;
	--color-accent-pressed: #5fe0ff;
	--color-bg: #050d16;
	--color-bg-elevated: #0e1822;
	--color-gradient-light: #228999;
	--color-gradient-mid: #0e505a;
	--color-primary: #ffc705;
	--color-rg-banner: #dc2626;
	--color-text: #ffffff;
	--color-text-muted: #c8ccd0;

	--font-body: "Inter", system-ui, -apple-system, sans-serif;
	--font-display: "Playfair Display", Georgia, serif;
	--font-fallback: system-ui, sans-serif;

	--fs-h1: 48px;
	--fs-h2: 36px;
	--fs-h3: 26px;
	--fs-h4: 21px;
	--fs-h5: 18px;
	--fs-h6: 16px;
	--fs-body: 19px;
	--fs-small: 16px;
	--fs-micro: 14px;

	--fw-bold: 600;
	--fw-medium: 500;
	--fw-regular: 400;

	--lh-tight: 1.2;
	--lh-normal: 1.7;
	--lh-loose: 2.0;

	--ls-tight: -0.01em;
	--ls-normal: 0;
	--ls-wide: 0.02em;

	--space-2xs: 4px;
	--space-xs: 8px;
	--space-sm: 12px;
	--space-md: 16px;
	--space-lg: 24px;
	--space-xl: 40px;
	--space-2xl: 64px;
	--space-3xl: 96px;

	--container-default: 1080px;
	--container-narrow: 640px;
	--container-padding-desktop: 24px;
	--container-padding-mobile: 16px;
	--container-padding-tablet: 32px;
	--container-readable: 720px;
	--container-site: 1380px;
	--container-wide: 1480px;

	--bp-sm: 500px;
	--bp-md: 800px;
	--bp-lg: 1100px;
	--bp-xl: 1480px;

	--border-medium: 2px;
	--border-thick: 4px;
	--border-thin: 1px;
	--radius-circle: 50%;
	--radius-lg: 0;
	--radius-md: 0;
	--radius-pill: 0;
	--radius-sm: 0;
	--radius-xs: 0;
	--shadow-lg: 0 4px 0 rgba(0, 0, 0, 0.16);
	--shadow-md: 0 2px 0 rgba(0, 0, 0, 0.12);
	--shadow-sm: 0 1px 0 rgba(0, 0, 0, 0.08);
	--shadow-xs: none;

	--dur-base: 150ms;
	--dur-fast: 120ms;
	--dur-slow: 200ms;
	--ease-in: cubic-bezier(0.55, 0.06, 0.68, 0.19);
	--ease-in-out: cubic-bezier(0.45, 0.05, 0.55, 0.95);
	--ease-out: cubic-bezier(0.25, 0.46, 0.45, 0.94);
	--ease-spring: cubic-bezier(0.45, 0.05, 0.55, 0.95);
}

/* ===== Reset ===== */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
	background-color: var(--color-bg);
	color: var(--color-text);
	font-family: var(--font-body);
	font-size: var(--fs-body);
	font-weight: var(--fw-regular);
	line-height: var(--lh-loose);
	min-height: 100vh;
	overflow-x: hidden;
}
a {
	color: var(--color-accent);
	text-decoration: none;
	transition: color var(--dur-fast) var(--ease-out);
}
a:hover { color: var(--color-accent-pressed); }
button {
	background: none;
	border: none;
	cursor: pointer;
	font-family: inherit;
	font-size: inherit;
	transition: background-color var(--dur-fast) var(--ease-out);
}
img { display: block; height: auto; max-width: 100%; }
ul, ol { list-style: none; }

/* ===== Typography (TYPO-07 airy generous) ===== */
h1, h2 {
	font-family: var(--font-display);
	font-weight: var(--fw-bold);
	letter-spacing: var(--ls-tight);
	line-height: var(--lh-tight);
}
h1 { font-size: var(--fs-h1); }
h2 { font-size: var(--fs-h2); }
h3, h4 {
	font-family: var(--font-body);
	font-weight: var(--fw-bold);
	line-height: var(--lh-tight);
}
h3 { font-size: var(--fs-h3); }
h4 { font-size: var(--fs-h4); }
h5, h6 {
	font-family: var(--font-body);
	font-weight: var(--fw-medium);
}
h5 { font-size: var(--fs-h5); }
h6 { font-size: var(--fs-h6); }
p { line-height: var(--lh-normal); }

/* ===== A11y ===== */
.skip-link {
	background: var(--color-accent);
	color: var(--color-bg);
	font-weight: var(--fw-bold);
	left: var(--space-sm);
	padding: var(--space-xs) var(--space-md);
	position: absolute;
	top: -100px;
	z-index: 200;
}
.skip-link:focus { top: var(--space-sm); }
.sr-only {
	border: 0;
	clip: rect(0, 0, 0, 0);
	height: 1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	white-space: nowrap;
	width: 1px;
}
:focus-visible { outline: 2px solid var(--color-accent); outline-offset: 2px; }

/* ===== Cookie banner (COOK-04, .boltSlider) — slide-up modal with backdrop ===== */
.boltSliderBackdrop {
	background: rgba(0, 0, 0, 0.4);
	display: none;
	inset: 0;
	position: fixed;
	z-index: 89;
}
.boltSliderBackdrop.is-visible { display: block; }
.boltSlider {
	background: var(--color-bg);
	border-top: 4px solid var(--color-accent);
	bottom: 0;
	display: none;
	inset-inline: 0;
	padding: var(--space-xl);
	position: fixed;
	z-index: 90;
}
.boltSlider.is-visible { display: block; }
.boltSliderInner {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
	margin-inline: auto;
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	text-align: center;
}
.boltSliderTitle {
	color: var(--color-text);
	font-family: var(--font-display);
	font-size: var(--fs-h4);
}
.boltSliderMsg {
	color: var(--color-text-muted);
	font-size: var(--fs-body);
	line-height: var(--lh-normal);
	max-width: 720px;
}
.boltSliderActions { display: flex; flex-wrap: wrap; gap: var(--space-md); justify-content: center; }
.boltSliderBtn {
	color: var(--color-text);
	font-family: var(--font-body);
	font-size: var(--fs-small);
	font-weight: var(--fw-medium);
	height: 48px;
	letter-spacing: var(--ls-wide);
	padding-inline: var(--space-lg);
}
.boltSliderBtn--accept {
	background: var(--color-accent);
	color: var(--color-bg);
}
.boltSliderBtn--accept:hover { background: var(--color-accent-pressed); }
.boltSliderBtn--decline {
	background: transparent;
	border: 1px solid var(--color-text-muted);
}
.boltSliderBtn--decline:hover { border-color: var(--color-text); }

/* ===== Header (HEAD-02, .elementWrapper) — split nav + centered logo ===== */
.elementWrapper {
	background: var(--color-bg);
	padding-block: var(--space-md);
	position: relative;
	width: 100%;
	z-index: 50;
}
.elementWrapperInner {
	align-items: center;
	display: grid;
	gap: var(--space-md);
	grid-template-columns: 1fr auto 1fr;
	margin-inline: auto;
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	padding-inline: var(--container-padding-desktop);
}
.elementWrapperLogo { display: inline-flex; justify-self: center; }
.elementWrapperLogo img {
	height: 144px;
	margin-block: -40px;
	width: auto;
}
.elementWrapperNav { display: flex; align-items: center; }
.elementWrapperNav--left { justify-content: flex-start; }
.elementWrapperNav--right { justify-content: flex-end; }
.elementWrapperNav ul { display: flex; flex-wrap: wrap; gap: var(--space-md); }
.elementWrapperNav a {
	color: var(--color-text);
	font-family: var(--font-body);
	font-size: var(--fs-small);
	font-weight: var(--fw-medium);
	letter-spacing: var(--ls-wide);
}
.elementWrapperNav a:hover,
.elementWrapperNav a[aria-current="page"] { color: var(--color-accent); }
.elementWrapperToggle {
	color: var(--color-text);
	display: none;
	flex-direction: column;
	gap: 5px;
	padding: var(--space-xs);
}
.elementWrapperToggle span {
	background: var(--color-text);
	display: block;
	height: 2px;
	width: 24px;
}
.elementWrapperMobile { display: none; }
.elementWrapperMobile.is-open {
	background: var(--color-bg);
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	display: block;
	inset-block-start: 100%;
	inset-inline: 0;
	padding-block: var(--space-md);
	padding-inline: var(--container-padding-mobile);
	position: absolute;
	z-index: 60;
}
.elementWrapperMobile ul { display: flex; flex-direction: column; gap: var(--space-md); }
.elementWrapperMobile a {
	color: var(--color-text);
	display: block;
	font-family: var(--font-body);
	font-size: var(--fs-h6);
	font-weight: var(--fw-medium);
	padding-block: var(--space-sm);
}
.elementWrapperMobile a[aria-current="page"] { color: var(--color-accent); }

/* ===== Hero (HERO-10, .chamberGroup) — tall vertical letterform ===== */
.chamberGroup {
	min-height: 100vh;
	overflow: hidden;
	position: relative;
}
.chamberGroupInner {
	display: flex;
	margin-inline: auto;
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	min-height: 100vh;
	padding-inline: var(--container-padding-desktop);
	position: relative;
}
.chamberGroupLetterform {
	align-items: center;
	color: rgba(255, 255, 255, 0.04);
	display: flex;
	font-family: var(--font-display);
	font-size: 60vh;
	font-weight: var(--fw-bold);
	height: 100%;
	inset-block-start: 0;
	inset-inline-start: var(--container-padding-desktop);
	justify-content: center;
	line-height: 0.8;
	overflow: hidden;
	pointer-events: none;
	position: absolute;
	width: 30%;
	z-index: 1;
}
.chamberGroupContent {
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding-block: var(--space-xl);
	padding-inline-start: 35%;
	position: relative;
	width: 100%;
	z-index: 2;
}
.chamberGroupEyebrow {
	color: var(--color-accent);
	font-family: var(--font-body);
	font-size: var(--fs-small);
	font-weight: var(--fw-medium);
	letter-spacing: var(--ls-wide);
	margin-bottom: var(--space-md);
}
.chamberGroupTitle { color: var(--color-text); }
.chamberGroupSubtitle {
	color: var(--color-text-muted);
	font-family: var(--font-body);
	font-size: var(--fs-h5);
	font-weight: var(--fw-regular);
	letter-spacing: var(--ls-normal);
	line-height: var(--lh-normal);
	margin-top: var(--space-md);
	max-width: 640px;
}
.chamberGroupCta {
	align-items: center;
	background: var(--color-primary);
	color: var(--color-bg);
	display: inline-flex;
	font-family: var(--font-display);
	font-size: var(--fs-h6);
	font-weight: var(--fw-medium);
	height: 56px;
	margin-top: var(--space-xl);
	padding-inline: var(--space-2xl);
	transition: background-color var(--dur-fast) var(--ease-out);
	width: max-content;
}
.chamberGroupCta:hover { background: var(--color-accent); color: var(--color-bg); }

/* ===== Page header (PHEAD-07, .crateBar) — number + title ===== */
.crateBar { padding-block: var(--space-xl); }
.crateBarInner {
	display: grid;
	gap: var(--space-lg);
	grid-template-columns: 120px 1fr;
	margin-inline: auto;
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	padding-inline: var(--container-padding-desktop);
}
.crateBarNumber {
	align-self: start;
	color: var(--color-accent);
	font-family: var(--font-display);
	font-size: calc(var(--fs-h1) * 1.4);
	font-weight: var(--fw-bold);
	letter-spacing: var(--ls-tight);
	line-height: 1;
}
.crateBarBody {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}
.crateBarTitle { color: var(--color-text); }
.crateBarDescription {
	color: var(--color-text-muted);
	font-family: var(--font-body);
	font-size: var(--fs-h5);
	font-weight: var(--fw-regular);
	line-height: var(--lh-normal);
}

/* ===== Items grid (GRID-07, .vectorFooter) — editorial article-style ===== */
.vectorFooter { padding-block: var(--space-xl); }
.vectorFooterInner {
	margin-inline: auto;
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	padding-inline: var(--container-padding-desktop);
}
.vectorFooterHeading { color: var(--color-text); margin-bottom: var(--space-xl); }
.vectorFooterList { display: flex; flex-direction: column; gap: var(--space-xl); }
.vectorFooterItem { display: flex; flex-direction: column; }
.vectorFooterItemTitle {
	color: var(--color-text);
	font-family: var(--font-display);
	font-size: var(--fs-h3);
	font-weight: var(--fw-bold);
}
.vectorFooterItemDivider {
	background: var(--color-accent);
	border: 0;
	height: 2px;
	margin: var(--space-sm) 0;
	width: 60px;
}
.vectorFooterItemText {
	color: var(--color-text-muted);
	font-family: var(--font-body);
	font-size: var(--fs-body);
	line-height: var(--lh-loose);
}

/* ===== FAQ (FAQ-04, .ticketGrid) — side-numbered accordion ===== */
.ticketGrid { padding-block: var(--space-xl); }
.ticketGridInner {
	margin-inline: auto;
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	padding-inline: var(--container-padding-desktop);
}
.ticketGridHeading { color: var(--color-text); margin-bottom: var(--space-xl); }
.ticketGridList { display: flex; flex-direction: column; }
.ticketGridItem {
	border-bottom: 1px solid rgba(255, 255, 255, 0.10);
	padding-block: var(--space-md);
}
.ticketGridQ {
	color: var(--color-text);
	cursor: pointer;
	display: grid;
	font-family: var(--font-body);
	font-size: var(--fs-h4);
	font-weight: var(--fw-bold);
	gap: var(--space-md);
	grid-template-columns: 60px 1fr auto;
	list-style: none;
	padding-block: var(--space-xs);
}
.ticketGridQ::-webkit-details-marker { display: none; }
.ticketGridQ::after {
	align-self: center;
	border-bottom: 2px solid currentColor;
	border-right: 2px solid currentColor;
	content: "";
	height: 10px;
	transform: rotate(45deg);
	transition: transform var(--dur-base) var(--ease-out);
	width: 10px;
}
.ticketGridItem[open] .ticketGridQ::after { transform: rotate(225deg); }
.ticketGridNum {
	color: var(--color-accent);
	font-family: var(--font-display);
	font-size: var(--fs-h3);
	font-weight: var(--fw-bold);
}
.ticketGridA {
	color: var(--color-text-muted);
	display: grid;
	font-family: var(--font-body);
	font-size: var(--fs-body);
	gap: var(--space-md);
	grid-template-columns: 60px 1fr;
	line-height: var(--lh-loose);
	padding-block: var(--space-md);
}
.ticketGridA p { grid-column: 2; }

/* ===== Reviews (REV-01, .plateBlock) — three-column cards with stars ===== */
.plateBlock { padding-block: var(--space-xl); }
.plateBlockInner {
	margin-inline: auto;
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	padding-inline: var(--container-padding-desktop);
}
.plateBlockHeading { color: var(--color-text); margin-bottom: var(--space-xl); }
.plateBlockList {
	display: grid;
	gap: var(--space-lg);
	grid-template-columns: repeat(3, 1fr);
}
.plateBlockItem {
	background: var(--color-bg-elevated);
	border: 1px solid rgba(255, 255, 255, 0.08);
	padding: var(--space-lg);
}
.plateBlockHeader {
	align-items: baseline;
	display: flex;
	gap: var(--space-md);
	justify-content: space-between;
	margin-bottom: var(--space-sm);
}
.plateBlockAuthor {
	color: var(--color-text);
	font-family: var(--font-body);
	font-size: var(--fs-body);
	font-weight: var(--fw-bold);
}
.plateBlockDate {
	color: var(--color-text-muted);
	font-family: var(--font-body);
	font-size: var(--fs-micro);
}
.plateBlockRating {
	color: var(--color-accent);
	font-size: 18px;
	margin-bottom: var(--space-sm);
}
.plateBlockText {
	color: var(--color-text-muted);
	font-family: var(--font-body);
	font-size: var(--fs-body);
	line-height: var(--lh-loose);
}

/* ===== CTA (CTA-06, .huskRegion) — sticky bottom banner ===== */
.huskRegion {
	background: var(--color-accent);
	bottom: 0;
	box-shadow: var(--shadow-lg);
	display: none;
	inset-inline: 0;
	position: sticky;
	z-index: 80;
}
.huskRegion.is-visible { display: block; }
.huskRegionInner {
	align-items: center;
	display: flex;
	gap: var(--space-md);
	justify-content: space-between;
	margin-inline: auto;
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	padding-block: var(--space-md);
	padding-inline: var(--container-padding-desktop);
}
.huskRegionTitle {
	color: var(--color-bg);
	font-family: var(--font-body);
	font-size: var(--fs-body);
	font-weight: var(--fw-bold);
}
.huskRegionBtn {
	background: var(--color-bg);
	color: var(--color-accent);
	font-family: var(--font-display);
	font-size: var(--fs-small);
	font-weight: var(--fw-bold);
	letter-spacing: var(--ls-wide);
	padding: var(--space-sm) var(--space-lg);
	text-transform: uppercase;
}
.huskRegionBtn:hover { background: var(--color-text); color: var(--color-bg); }
.huskRegionClose {
	background: transparent;
	color: var(--color-bg);
	font-size: 20px;
	height: 32px;
	width: 32px;
}

/* ===== Prose (PROSE-02, .nookDisplay) — two-column editorial ===== */
.nookDisplay { padding-block: var(--space-xl); }
.nookDisplayInner {
	column-count: 2;
	column-gap: var(--space-2xl);
	margin-inline: auto;
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	padding-inline: var(--container-padding-desktop);
}
.nookDisplayInner h2 {
	color: var(--color-text);
	column-span: all;
	font-family: var(--font-display);
	margin-block: var(--space-xl) var(--space-md);
	text-align: center;
}
.nookDisplayInner h2:first-child { margin-block-start: 0; }
.nookDisplayInner h3 {
	color: var(--color-text);
	margin-top: var(--space-lg);
}
.nookDisplayInner p {
	color: var(--color-text);
	font-family: var(--font-body);
	font-size: var(--fs-body);
	line-height: var(--lh-loose);
	margin-bottom: var(--space-sm);
	text-indent: 1.5em;
}
.nookDisplayInner h2 + p { text-indent: 0; }
.nookDisplayInner a { color: var(--color-accent); text-decoration: underline; }
.nookDisplayInner strong { color: var(--color-text); font-weight: var(--fw-bold); }
.nookDisplayInner em { color: var(--color-text); font-style: italic; }
.nookDisplayInner ul,
.nookDisplayInner ol {
	color: var(--color-text);
	line-height: var(--lh-loose);
	margin-bottom: var(--space-md);
	padding-left: var(--space-lg);
}
.nookDisplayInner ul li { list-style: disc; margin-bottom: var(--space-xs); }
.nookDisplayInner ol li { list-style: decimal; margin-bottom: var(--space-xs); }

/* ===== Data table (TABLE-07, .courtBlock) — two-tone alternating columns ===== */
.courtBlock { padding-block: var(--space-xl); }
.courtBlockInner {
	margin-inline: auto;
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	padding-inline: var(--container-padding-desktop);
}
.courtBlockHeading { color: var(--color-text); margin-bottom: var(--space-lg); }
.courtBlockWrap { overflow: hidden; overflow-x: auto; }
.courtBlockTable {
	background: var(--color-bg-elevated);
	border-collapse: collapse;
	min-width: 600px;
	width: 100%;
}
.courtBlockTable thead { background: var(--color-primary); }
.courtBlockTable th {
	color: var(--color-bg);
	font-family: var(--font-body);
	font-size: var(--fs-h6);
	font-weight: var(--fw-bold);
	letter-spacing: var(--ls-wide);
	padding: var(--space-md);
	text-align: left;
}
.courtBlockTable td {
	color: var(--color-text);
	font-family: var(--font-body);
	font-size: var(--fs-body);
	padding: var(--space-md);
	text-align: left;
}
.courtBlockTable td:nth-child(even),
.courtBlockTable th:nth-child(even) {
	background: rgba(255, 255, 255, 0.03);
}

/* ===== Legal (LEGAL-01, .cellBar) — continuous document ===== */
.cellBar { padding-block: var(--space-xl); }
.cellBarInner {
	margin-inline: auto;
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	padding-inline: var(--container-padding-desktop);
}
.cellBarUpdated {
	color: var(--color-text-muted);
	font-family: var(--font-body);
	font-size: var(--fs-micro);
	font-weight: var(--fw-medium);
	letter-spacing: var(--ls-wide);
	margin-bottom: var(--space-xl);
	text-transform: uppercase;
}
.cellBarIntro {
	color: var(--color-text);
	font-family: var(--font-body);
	font-size: var(--fs-h5);
	line-height: var(--lh-normal);
	margin-bottom: var(--space-lg);
}
.cellBarSection {
	border-block-start: 1px solid rgba(255, 255, 255, 0.06);
	padding-block-start: var(--space-xl);
}
.cellBarSection:first-of-type {
	border-block-start: 0;
	padding-block-start: 0;
}
.cellBarSection h3 {
	color: var(--color-text);
	font-family: var(--font-display);
	font-size: var(--fs-h3);
	font-weight: var(--fw-bold);
	margin-block-end: var(--space-md);
}
.cellBarSection p {
	color: var(--color-text-muted);
	font-family: var(--font-body);
	font-size: var(--fs-body);
	line-height: var(--lh-loose);
	margin-block-end: var(--space-md);
}
.cellBarContacts {
	background: var(--color-bg-elevated);
	margin-block-start: var(--space-xl);
	padding: var(--space-lg);
}
.cellBarContacts h3 { color: var(--color-text); font-size: var(--fs-h4); margin-bottom: var(--space-sm); }
.cellBarContacts ul { display: flex; flex-direction: column; gap: var(--space-xs); }
.cellBarContacts li { color: var(--color-text-muted); font-family: var(--font-body); font-size: var(--fs-small); line-height: var(--lh-normal); }
.cellBarDisclaim {
	background: rgba(220, 38, 38, 0.08);
	border-inline-start: 3px solid var(--color-rg-banner);
	color: var(--color-text-muted);
	font-family: var(--font-body);
	font-size: var(--fs-small);
	line-height: var(--lh-loose);
	margin-block-start: var(--space-xl);
	padding: var(--space-md);
}

/* ===== Contact form (FORM-08, .moduleZone) — asymmetric wide submit ===== */
.moduleZone { padding-block: var(--space-xl); }
.moduleZoneInner {
	margin-inline: auto;
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	padding-inline: var(--container-padding-desktop);
}
.moduleZoneIntro {
	color: var(--color-text-muted);
	font-family: var(--font-body);
	font-size: var(--fs-body);
	line-height: var(--lh-loose);
	margin-bottom: var(--space-lg);
}
.moduleZoneForm {
	background: var(--color-bg-elevated);
	display: flex;
	flex-direction: column;
	gap: var(--space-lg);
	padding: var(--space-xl);
}
.moduleZoneField { display: flex; flex-direction: column; gap: var(--space-xs); }
.moduleZoneLabel {
	color: var(--color-text-muted);
	font-family: var(--font-body);
	font-size: var(--fs-small);
	font-weight: var(--fw-medium);
	letter-spacing: var(--ls-wide);
	text-transform: uppercase;
}
.moduleZoneInput,
.moduleZoneTextarea {
	background: var(--color-bg);
	border: 2px solid rgba(255, 255, 255, 0.12);
	color: var(--color-text);
	font-family: var(--font-body);
	font-size: var(--fs-body);
	padding: var(--space-sm) var(--space-md);
	transition: border-color var(--dur-fast) var(--ease-out);
	width: 100%;
}
.moduleZoneTextarea { min-height: 140px; resize: vertical; }
.moduleZoneInput:focus,
.moduleZoneTextarea:focus { border-color: var(--color-accent); outline: none; }
.moduleZoneSubmit {
	background: var(--color-accent);
	color: var(--color-bg);
	font-family: var(--font-display);
	font-size: var(--fs-h4);
	font-weight: var(--fw-bold);
	height: 72px;
	letter-spacing: var(--ls-wide);
	margin-top: var(--space-md);
	text-transform: uppercase;
	width: 100%;
}
.moduleZoneSubmit:hover { background: var(--color-accent-pressed); }
.moduleZoneOk {
	background: rgba(44, 210, 237, 0.08);
	border-inline-start: 4px solid var(--color-accent);
	color: var(--color-text);
	display: none;
	margin-top: var(--space-lg);
	padding: var(--space-md);
}
.moduleZoneOk.is-visible { display: block; }

/* ===== Author card (AUTH-06, .beamTrack) — full-hero style for /author/ ===== */
.beamTrack {
	background: linear-gradient(135deg, rgba(255, 199, 5, 0.10), var(--color-bg));
	padding-block: var(--space-3xl);
}
.beamTrackInner {
	margin-inline: auto;
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	padding-inline: var(--container-padding-desktop);
}
.beamTrackGrid {
	display: grid;
	gap: var(--space-2xl);
	grid-template-columns: 280px 1fr;
}
.beamTrackPortrait {
	aspect-ratio: 4 / 5;
	box-shadow: var(--shadow-lg);
	object-fit: cover;
	object-position: center top;
	width: 280px;
}
.beamTrackBody { display: flex; flex-direction: column; }
.beamTrackEyebrow {
	color: var(--color-accent);
	font-family: var(--font-body);
	font-size: var(--fs-small);
	font-weight: var(--fw-medium);
	letter-spacing: var(--ls-wide);
	margin-bottom: var(--space-sm);
	text-transform: uppercase;
}
.beamTrackName {
	color: var(--color-text);
	font-size: clamp(40px, 6vw, 64px);
}
.beamTrackBio {
	color: rgba(255, 255, 255, 0.85);
	font-family: var(--font-body);
	font-size: var(--fs-h5);
	line-height: var(--lh-normal);
	margin-block-start: var(--space-md);
	max-width: 540px;
}
.beamTrackExpertise {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-sm);
	margin-top: var(--space-lg);
}
.beamTrackTag {
	background: var(--color-bg-elevated);
	color: var(--color-accent);
	font-family: var(--font-body);
	font-size: var(--fs-micro);
	font-weight: var(--fw-medium);
	letter-spacing: var(--ls-wide);
	padding: var(--space-xs) var(--space-sm);
	text-transform: uppercase;
}

/* ===== Author byline (BYLINE-08, .hingeContainer) — expertise tags block ===== */
.hingeContainer { padding-block: var(--space-lg); }
.hingeContainerInner {
	margin-inline: auto;
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	padding-inline: var(--container-padding-desktop);
}
.hingeContainerCard {
	background: var(--color-bg-elevated);
	box-shadow: var(--shadow-sm);
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
	margin-inline: auto;
	max-width: 720px;
	padding: var(--space-lg);
}
.hingeContainerHeader {
	display: flex;
	gap: var(--space-sm);
}
.hingeContainerPortrait {
	border-radius: var(--radius-circle);
	flex-shrink: 0;
	height: 72px;
	object-fit: cover;
	object-position: center top;
	width: 72px;
}
.hingeContainerName {
	color: var(--color-text);
	font-family: var(--font-display);
	font-size: var(--fs-h4);
	font-weight: var(--fw-bold);
}
.hingeContainerName a { color: inherit; }
.hingeContainerName a:hover { text-decoration: underline; }
.hingeContainerRole {
	color: var(--color-text-muted);
	font-family: var(--font-body);
	font-size: var(--fs-small);
}
.hingeContainerBio {
	color: var(--color-text-muted);
	font-family: var(--font-body);
	font-size: var(--fs-body);
	line-height: var(--lh-loose);
}
.hingeContainerExpertise { display: flex; flex-wrap: wrap; gap: var(--space-xs); }
.hingeContainerTag {
	background: var(--color-primary);
	color: var(--color-bg);
	font-family: var(--font-body);
	font-size: var(--fs-micro);
	font-weight: var(--fw-medium);
	letter-spacing: var(--ls-wide);
	padding: var(--space-2xs) var(--space-sm);
	text-transform: uppercase;
}
.hingeContainerLink {
	color: var(--color-accent);
	font-family: var(--font-body);
	font-size: var(--fs-small);
	text-decoration: underline;
}

/* ===== Error block (ERR-02, .pivotGrid) — split editorial ===== */
.pivotGrid { padding-block: var(--space-3xl); }
.pivotGridInner {
	display: grid;
	gap: var(--space-2xl);
	grid-template-columns: 1fr 1fr;
	margin-inline: auto;
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	padding-inline: var(--container-padding-desktop);
}
.pivotGridLeft {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}
.pivotGridTitle { color: var(--color-text); }
.pivotGridText {
	color: var(--color-text-muted);
	font-family: var(--font-body);
	font-size: var(--fs-h5);
	line-height: var(--lh-normal);
}
.pivotGridBtn {
	align-items: center;
	background: var(--color-accent);
	color: var(--color-bg);
	display: inline-flex;
	font-family: var(--font-display);
	font-size: var(--fs-h6);
	font-weight: var(--fw-bold);
	height: 52px;
	letter-spacing: var(--ls-wide);
	margin-top: var(--space-lg);
	padding-inline: var(--space-xl);
	text-transform: uppercase;
	width: max-content;
}
.pivotGridBtn:hover { background: var(--color-accent-pressed); color: var(--color-bg); }
.pivotGridCode {
	align-self: start;
	background: linear-gradient(135deg, var(--color-accent), var(--color-primary));
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	font-family: var(--font-display);
	font-size: clamp(120px, 24vw, 280px);
	font-weight: var(--fw-bold);
	line-height: 1;
}

/* ===== Footer (FOOT-05, .blockRail) — four-column information-dense ===== */
.blockRail {
	background: var(--color-primary);
	padding-block: var(--space-xl);
}
.blockRailInner {
	margin-inline: auto;
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	padding-inline: var(--container-padding-desktop);
}
.blockRailGrid {
	display: grid;
	gap: var(--space-xl);
	grid-template-columns: 1.5fr 1fr 1fr 1fr;
}
.blockRailColumn { display: flex; flex-direction: column; }
.blockRailBrand { display: inline-flex; margin-bottom: var(--space-md); }
.blockRailBrandImg { height: 80px; width: auto; }
.blockRailTagline {
	color: rgba(5, 13, 22, 0.7);
	font-family: var(--font-body);
	font-size: var(--fs-small);
	line-height: var(--lh-normal);
	max-width: 280px;
}
.blockRailHeading {
	color: var(--color-bg);
	font-family: var(--font-display);
	font-size: var(--fs-small);
	font-weight: var(--fw-bold);
	letter-spacing: var(--ls-wide);
	margin-bottom: var(--space-md);
	text-transform: uppercase;
}
.blockRailList { display: flex; flex-direction: column; gap: var(--space-xs); }
.blockRailLink {
	color: rgba(5, 13, 22, 0.75);
	font-family: var(--font-body);
	font-size: var(--fs-small);
}
.blockRailLink:hover { color: var(--color-bg); }
.blockRailBottom {
	align-items: center;
	border-top: 1px solid rgba(5, 13, 22, 0.2);
	color: rgba(5, 13, 22, 0.7);
	display: flex;
	flex-wrap: wrap;
	font-family: var(--font-body);
	font-size: var(--fs-small);
	gap: var(--space-md);
	justify-content: space-between;
	margin-top: var(--space-xl);
	padding-top: var(--space-md);
}
.blockRailRg {
	background: var(--color-rg-banner);
	color: var(--color-text);
	font-family: var(--font-display);
	font-size: var(--fs-micro);
	font-weight: var(--fw-bold);
	letter-spacing: var(--ls-wide);
	padding: var(--space-2xs) var(--space-sm);
	text-transform: uppercase;
}

/* ===== Reduced motion ===== */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		scroll-behavior: auto !important;
		transition-duration: 0.01ms !important;
	}
}

/* ===== Tablet (≤1100px) ===== */
@media (max-width: 1100px) {
	.elementWrapperInner,
	.chamberGroupInner,
	.crateBarInner,
	.vectorFooterInner,
	.ticketGridInner,
	.plateBlockInner,
	.huskRegionInner,
	.nookDisplayInner,
	.courtBlockInner,
	.cellBarInner,
	.moduleZoneInner,
	.beamTrackInner,
	.hingeContainerInner,
	.pivotGridInner,
	.blockRailInner,
	.boltSliderInner { padding-inline: var(--container-padding-tablet); }
	.boltSlider { padding-inline: var(--container-padding-tablet); }
	.plateBlockList { grid-template-columns: repeat(2, 1fr); }
	.beamTrackGrid { grid-template-columns: 1fr; }
	.beamTrackPortrait { margin-inline: auto; }
	.nookDisplayInner { column-count: 1; }
	.pivotGridInner { grid-template-columns: 1fr; }
	.blockRailGrid { grid-template-columns: repeat(2, 1fr); }
	.chamberGroupContent { padding-inline-start: 30%; }
}

/* ===== Mobile (≤800px) ===== */
@media (max-width: 800px) {
	:root {
		--fs-h1: 32px;
		--fs-h2: 26px;
		--fs-h3: 22px;
		--fs-h4: 19px;
		--fs-h5: 17px;
		--fs-h6: 15px;
		--fs-body: 18px;
		--fs-small: 15px;
		--fs-micro: 13px;
	}
	.elementWrapperInner,
	.chamberGroupInner,
	.crateBarInner,
	.vectorFooterInner,
	.ticketGridInner,
	.plateBlockInner,
	.huskRegionInner,
	.nookDisplayInner,
	.courtBlockInner,
	.cellBarInner,
	.moduleZoneInner,
	.beamTrackInner,
	.hingeContainerInner,
	.pivotGridInner,
	.blockRailInner,
	.boltSliderInner { padding-inline: var(--container-padding-mobile); }
	.boltSlider { padding-inline: var(--container-padding-mobile); }
	.elementWrapperInner { grid-template-columns: auto 1fr; }
	.elementWrapperNav { display: none; }
	.elementWrapperToggle { display: flex; }
	.elementWrapperLogo { justify-self: end; }
	.chamberGroupLetterform { font-size: 30vh; width: 100%; opacity: 0.5; }
	.chamberGroupContent { padding-inline-start: 0; }
	.crateBarInner { grid-template-columns: 64px 1fr; }
	.crateBarNumber { font-size: var(--fs-h2); }
	.plateBlockList { grid-template-columns: 1fr; }
	.blockRailGrid { grid-template-columns: 1fr; gap: var(--space-lg); }
	.huskRegionInner { flex-direction: column; padding-block: var(--space-sm); }
}
