/* Casinoly GR — frame.css | TYPO-07 / SPACE-01 / CONT-09 / BP-04 / GEO-09 / MOTION-02 / NAME-07 */

/* ============ tokens ============ */
:root {
	--color-primary: #eac013;
	--color-accent: #ed5a54;
	--color-accent-pressed: #e82d33;
	--color-bg: #212121;
	--color-bg-elevated: #2a2a2a;
	--color-gradient-light: #2a2a2a;
	--color-gradient-mid: #37352d;
	--color-text: #ffffff;
	--color-text-muted: #bdbdbd;
	--color-border: #3a3a3a;
	--color-rg-banner: #dc2626;

	--font-display: 'Roboto', 'Helvetica Neue', Arial, sans-serif;
	--font-body: 'Roboto Condensed', 'Roboto', Arial, sans-serif;

	/* TYPO-07 — Modern reading scale */
	--fs-base: 16px;
	--fs-body: 1.0625rem;
	--fs-small: 0.875rem;
	--fs-h1: clamp(2.25rem, 4vw + 0.8rem, 3.5rem);
	--fs-h2: clamp(1.7rem, 2.4vw + 0.6rem, 2.4rem);
	--fs-h3: clamp(1.25rem, 1.4vw + 0.4rem, 1.6rem);
	--fs-eyebrow: 0.8125rem;
	--lh-body: 1.7;
	--lh-tight: 1.25;
	--ls-display: -0.005em;

	/* SPACE-01 — base 8 */
	--space-2xs: 4px;
	--space-xs: 8px;
	--space-sm: 12px;
	--space-md: 16px;
	--space-lg: 24px;
	--space-xl: 40px;
	--space-2xl: 64px;
	--space-3xl: 96px;

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

	/* GEO-09 — soft */
	--radius-sm: 6px;
	--radius-md: 12px;
	--radius-lg: 20px;
	--radius-pill: 999px;

	/* MOTION-02 */
	--ease: cubic-bezier(.22,.61,.36,1);
	--dur-fast: 160ms;
	--dur-base: 240ms;

	--header-height-desktop: 84px;
	--header-height-mobile: 64px;
	--rg-banner-h: 30px;
}

@media (max-width: 720px) {
	:root {
		--fs-body: 1rem;
		--container-padding-desktop: 16px;
		--header-height-desktop: 64px;
	}
}

/* ============ reset / base ============ */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
html, body { overflow-x: clip; }
body {
	margin: 0;
	font-family: var(--font-body);
	font-size: var(--fs-body);
	line-height: var(--lh-body);
	color: var(--color-text);
	background: var(--color-bg);
	-webkit-font-smoothing: antialiased;
}
img, picture, svg, video { max-width: 100%; height: auto; display: block; }
a { color: var(--color-primary); text-decoration: none; transition: color var(--dur-fast) var(--ease); }
a:hover { color: var(--color-accent); }
h1, h2, h3, h4 {
	font-family: var(--font-display);
	letter-spacing: var(--ls-display);
	line-height: var(--lh-tight);
	margin: 0 0 var(--space-md);
	font-weight: 700;
}
h1 { font-size: var(--fs-h1); }
h2 { font-size: var(--fs-h2); }
h3 { font-size: var(--fs-h3); }
p { margin: 0 0 var(--space-md); }
ul, ol { margin: 0 0 var(--space-md); padding-left: var(--space-lg); }
li { margin-bottom: var(--space-xs); }
strong { color: var(--color-primary); font-weight: 700; }
button { font-family: inherit; cursor: pointer; }

.sr-only {
	position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
	overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
.skip-link {
	position: absolute; left: 0; top: -200px !important;
	background: var(--color-primary); color: #111;
	padding: 12px 18px; font-weight: 700; z-index: 1000;
}
.skip-link:focus { top: 0 !important; }

@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}

/* ============ rg-banner (above fixed header) ============ */
.rg-banner {
	position: fixed; top: 0; left: 0; right: 0;
	z-index: 101;
	min-height: var(--rg-banner-h);
	display: flex; align-items: center; justify-content: center;
	background: var(--color-rg-banner);
	color: #fff;
	font-size: 12px; font-weight: 600;
	letter-spacing: 0.04em;
	padding: 4px var(--space-md);
	text-align: center;
}

/* ============ HEAD-07 — magazine-style with two-row nav (NAV-03) ============ */
.o44 {
	position: fixed;
	top: var(--rg-banner-h);
	left: 0; right: 0;
	z-index: 100;
	background: var(--color-bg);
	border-bottom: 1px solid var(--color-border);
	transition: padding var(--dur-base) var(--ease), background var(--dur-base) var(--ease);
}
.o44.is-shrunk {
	background: rgba(33,33,33,0.96);
	backdrop-filter: blur(8px);
}
.o44-inner {
	max-width: 1440px;
	margin: 0 auto;
	padding: 14px var(--container-padding-desktop) 0;
	display: flex;
	align-items: center;
	gap: var(--space-lg);
}
.o44-logo {
	display: inline-flex;
	align-items: center;
	flex-shrink: 0;
	margin-right: auto;
}
.o44-logo img {
	height: 88px;
	width: auto;
	flex-shrink: 0;
	display: block;
}
.o44.is-shrunk .o44-logo img { height: 72px; }

.o44-toggle {
	display: none;
	margin-left: auto !important;
	width: 44px; height: 44px;
	background: transparent;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	color: var(--color-text);
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 5px;
	flex-shrink: 0;
}
.o44-toggle span {
	width: 22px; height: 2px;
	background: var(--color-text);
	display: block;
}

/* NAV-03 — two-row nav */
.o44-nav {
	display: flex;
	flex-direction: column;
	gap: 0;
	margin-left: auto;
}
.o44-nav-row {
	display: flex;
	list-style: none;
	gap: var(--space-lg);
	padding: 0;
	margin: 0;
}
.o44-nav-row + .o44-nav-row {
	margin-top: 6px;
	padding-top: 8px;
	border-top: 1px solid var(--color-border);
}
.o44-nav-row a {
	color: var(--color-text);
	font-family: var(--font-display);
	font-weight: 500;
	font-size: 0.95rem;
	letter-spacing: 0.01em;
	white-space: nowrap;
	padding: 4px 0;
	position: relative;
}
.o44-nav-row a:hover { color: var(--color-primary); }
.o44-nav-row a[aria-current='page'] {
	color: var(--color-primary);
}
.o44-nav-row a[aria-current='page']::after {
	content: '';
	position: absolute;
	left: 0; right: 0; bottom: -2px;
	height: 2px;
	background: var(--color-primary);
}

/* mobile drawer */
.o44-mobile {
	display: none;
	position: fixed;
	top: calc(var(--header-height-mobile) + var(--rg-banner-h));
	left: 0; right: 0; bottom: 0;
	background: var(--color-bg);
	z-index: 99;
	padding: var(--space-lg);
	overflow-y: auto;
}
.o44-mobile.is-open { display: block; }
.o44-mobile ul {
	list-style: none;
	padding: 0; margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}
.o44-mobile a {
	color: var(--color-text);
	display: block;
	padding: 12px 0;
	border-bottom: 1px solid var(--color-border);
	font-size: 1.15rem;
	font-family: var(--font-display);
}
.o44-mobile a[aria-current='page'] { color: var(--color-primary); }

@media (max-width: 1100px) {
	.o44-nav { display: none; }
	.o44-toggle { display: inline-flex; }
	.o44-inner { padding: 10px var(--container-padding-mobile); }
	.o44-logo img { height: 60px; }
	.o44.is-shrunk .o44-logo img { height: 56px; }
}

body { padding-top: calc(var(--header-height-desktop) + var(--rg-banner-h) + 28px); }
@media (max-width: 1100px) {
	body { padding-top: calc(var(--header-height-mobile) + var(--rg-banner-h)); }
}

/* ============ HERO-07 — split layout w/ image-right ============ */
.h44 {
	padding: var(--space-3xl) 0 var(--space-2xl);
	background:
		radial-gradient(60% 80% at 100% 0%, rgba(234,192,19,0.08), transparent 60%),
		linear-gradient(135deg, var(--color-gradient-light), var(--color-gradient-mid));
	border-bottom: 1px solid var(--color-border);
	overflow: hidden;
}
.h44-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
	display: grid;
	grid-template-columns: 1.1fr 0.9fr;
	gap: var(--space-2xl);
	align-items: center;
}
.h44-content { display: flex; flex-direction: column; gap: var(--space-md); }
.h44-eyebrow {
	display: inline-block;
	color: var(--color-primary);
	font-family: var(--font-display);
	font-size: var(--fs-eyebrow);
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	margin-bottom: var(--space-xs);
}
.h44-title { margin: 0; }
.h44-subtitle {
	font-size: 1.1rem;
	color: var(--color-text-muted);
	max-width: 480px;
}
.h44-cta {
	display: inline-flex;
	align-items: center;
	gap: var(--space-xs);
	background: var(--color-accent);
	color: #fff;
	font-family: var(--font-display);
	font-weight: 700;
	font-size: 1.05rem;
	padding: 16px 36px;
	border-radius: var(--radius-pill);
	margin-top: var(--space-sm);
	width: max-content;
	box-shadow: 0 6px 24px rgba(237,90,84,0.25);
	transition: background var(--dur-base) var(--ease), transform var(--dur-fast) var(--ease);
}
.h44-cta:hover {
	background: var(--color-accent-pressed);
	color: #fff;
	transform: translateY(-1px);
}
.h44-media {
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: 0 12px 40px rgba(0,0,0,0.4);
}
.h44-media img { width: 100%; height: 100%; object-fit: cover; }

.h44-stats {
	display: flex;
	gap: var(--space-xl);
	margin-top: var(--space-lg);
	flex-wrap: wrap;
}
.h44-stat {
	display: flex; flex-direction: column;
}
.h44-stat-value {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: 1.5rem;
	color: var(--color-primary);
}
.h44-stat-label {
	font-size: var(--fs-small);
	color: var(--color-text-muted);
}

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

/* ============ PHEAD-07 — page header on inner pages ============ */
.l27 {
	padding: var(--space-2xl) 0 var(--space-xl);
	background: linear-gradient(135deg, var(--color-gradient-light), var(--color-gradient-mid));
	border-bottom: 1px solid var(--color-border);
}
.l27-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.l27-eyebrow {
	color: var(--color-primary);
	font-family: var(--font-display);
	font-size: var(--fs-eyebrow);
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	display: block;
	margin-bottom: var(--space-xs);
}
.l27-title { margin: 0 0 var(--space-md); }
.l27-lead { color: var(--color-text-muted); font-size: 1.1rem; max-width: 60ch; }

/* ============ section frame ============ */
section[class*='-section'], .section-frame {
	padding: var(--space-2xl) 0;
}
.section-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.section-eyebrow {
	color: var(--color-primary);
	font-family: var(--font-display);
	font-size: var(--fs-eyebrow);
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	display: block;
	margin-bottom: var(--space-xs);
}

/* ============ PROSE-04 — wide prose */
.i90 {
	padding: var(--space-2xl) 0;
}
.i90-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.i90 h2 { margin-top: var(--space-2xl); }
.i90 h2:first-child { margin-top: 0; }
.i90 h3 { margin-top: var(--space-xl); color: var(--color-primary); }
.i90 p, .i90 ul, .i90 ol { font-size: 1.05rem; }
.i90 ul li::marker { color: var(--color-primary); }
.i90 .prose-image {
	border-radius: var(--radius-md);
	overflow: hidden;
	margin: var(--space-xl) 0;
	box-shadow: 0 6px 24px rgba(0,0,0,0.3);
}
.i90 .prose-image img { width: 100%; }

/* ============ GRID-07 — items grid card style */
.t11 {
	padding: var(--space-2xl) 0;
	background: var(--color-bg);
}
.t11-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.t11-header { margin-bottom: var(--space-xl); }
.t11-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: var(--space-lg);
}
.t11-card {
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-lg);
	transition: transform var(--dur-base) var(--ease), border-color var(--dur-base) var(--ease);
}
.t11-card:hover {
	transform: translateY(-3px);
	border-color: var(--color-primary);
}
.t11-card h3 {
	font-size: 1.2rem;
	margin-bottom: var(--space-sm);
	color: var(--color-primary);
}
.t11-card p {
	color: var(--color-text-muted);
	font-size: 0.98rem;
	margin: 0;
}

/* ============ FAQ-10 — bold accordion with thick separators */
.g18 {
	padding: var(--space-2xl) 0;
	background: linear-gradient(180deg, var(--color-bg), var(--color-gradient-light));
}
.g18-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.g18-header { margin-bottom: var(--space-xl); }
.g18-list {
	border-top: 2px solid var(--color-border);
}
.g18-item {
	border-bottom: 2px solid var(--color-border);
}
.g18-q {
	width: 100%;
	background: none;
	border: 0;
	color: var(--color-text);
	font-family: var(--font-display);
	font-weight: 700;
	font-size: 1.1rem;
	text-align: left;
	padding: var(--space-lg) 0;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-md);
}
.g18-q::after {
	content: '+';
	font-size: 1.8rem;
	font-weight: 300;
	color: var(--color-primary);
	transition: transform var(--dur-base) var(--ease);
	flex-shrink: 0;
}
.g18-q[aria-expanded='true']::after { content: '−'; }
.g18-a {
	max-height: 0;
	overflow: hidden;
	transition: max-height var(--dur-base) var(--ease);
	color: var(--color-text-muted);
}
.g18-q[aria-expanded='true'] + .g18-a {
	max-height: 2000px;
}
.g18-a p {
	padding-bottom: var(--space-lg);
	margin: 0;
}

/* ============ REV-06 — review masonry-style grid */
.e11 {
	padding: var(--space-2xl) 0;
	background: var(--color-bg);
}
.e11-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.e11-header { margin-bottom: var(--space-xl); }
.e11-aggregate {
	display: flex;
	align-items: center;
	gap: var(--space-md);
	margin-bottom: var(--space-lg);
	color: var(--color-text-muted);
}
.e11-aggregate-stars { color: var(--color-primary); font-size: 1.4rem; }
.e11-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
	gap: var(--space-lg);
}
.e11-card {
	background: var(--color-bg-elevated);
	border-left: 4px solid var(--color-primary);
	padding: var(--space-lg);
	border-radius: 0 var(--radius-md) var(--radius-md) 0;
}
.e11-card-head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: var(--space-sm);
}
.e11-card-author {
	font-family: var(--font-display);
	font-weight: 700;
}
.e11-card-rating {
	color: var(--color-primary);
	font-weight: 700;
}
.e11-card p { margin: 0; color: var(--color-text-muted); }

/* ============ CTA-01 — center-aligned banner */
.j62 {
	padding: var(--space-2xl) 0;
}
.j62-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.j62-card {
	background:
		radial-gradient(60% 100% at 50% 0%, rgba(237,90,84,0.18), transparent 65%),
		linear-gradient(135deg, var(--color-gradient-light), var(--color-gradient-mid));
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: var(--space-2xl) var(--space-xl);
	text-align: center;
}
.j62-title { margin: 0 0 var(--space-sm); color: var(--color-primary); }
.j62-text {
	color: var(--color-text-muted);
	max-width: 580px;
	margin: 0 auto var(--space-lg);
}
.j62-button {
	display: inline-flex;
	background: var(--color-accent);
	color: #fff;
	padding: 16px 36px;
	font-family: var(--font-display);
	font-weight: 700;
	font-size: 1.05rem;
	border-radius: var(--radius-pill);
	box-shadow: 0 6px 24px rgba(237,90,84,0.25);
	transition: background var(--dur-base) var(--ease), color var(--dur-base) var(--ease);
}
.j62-button:hover {
	background: var(--color-accent-pressed);
	color: #fff;
}

/* ============ TABLE-03 — striped data table */
.y21 {
	padding: var(--space-xl) 0;
}
.y21-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
	overflow-x: auto;
}
.y21-table {
	width: 100%;
	border-collapse: collapse;
	background: var(--color-bg-elevated);
	border-radius: var(--radius-md);
	overflow: hidden;
	font-size: 0.98rem;
}
.y21-table th {
	background: var(--color-gradient-mid);
	color: var(--color-primary);
	font-family: var(--font-display);
	text-align: left;
	padding: var(--space-md);
	font-weight: 700;
}
.y21-table td {
	padding: var(--space-md);
	border-top: 1px solid var(--color-border);
}
.y21-table tr:nth-child(even) td { background: rgba(255,255,255,0.02); }

/* ============ LEGAL-06 — legal sections */
.q69 {
	padding: var(--space-2xl) 0;
}
.q69-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.q69-intro {
	color: var(--color-text-muted);
	font-size: 1.1rem;
	max-width: 70ch;
	margin-bottom: var(--space-xl);
}
.q69-section {
	margin-bottom: var(--space-xl);
	padding-bottom: var(--space-xl);
	border-bottom: 1px solid var(--color-border);
}
.q69-section:last-child { border-bottom: 0; }
.q69-section h2 {
	color: var(--color-primary);
	font-size: 1.5rem;
}
.q69-updated {
	font-size: var(--fs-small);
	color: var(--color-text-muted);
	margin-bottom: var(--space-md);
	font-style: italic;
}
.q69-support {
	background: var(--color-bg-elevated);
	border-radius: var(--radius-md);
	padding: var(--space-lg);
	margin-top: var(--space-xl);
}
.q69-disclaimer {
	font-size: var(--fs-small);
	color: var(--color-text-muted);
	margin-top: var(--space-xl);
	padding-top: var(--space-md);
	border-top: 1px solid var(--color-border);
}

/* ============ FORM-02 — clean contact form */
.j48 {
	padding: var(--space-2xl) 0;
}
.j48-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-2xl);
}
.j48-intro p { color: var(--color-text-muted); }
.j48-intro h2 { color: var(--color-primary); }
.j48-form {
	background: var(--color-bg-elevated);
	padding: var(--space-xl);
	border-radius: var(--radius-md);
	border: 1px solid var(--color-border);
}
.j48-field {
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
	margin-bottom: var(--space-md);
}
.j48-field label {
	font-family: var(--font-display);
	font-weight: 600;
	font-size: 0.95rem;
}
.j48-field input, .j48-field textarea {
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	color: var(--color-text);
	padding: 12px 14px;
	font-family: var(--font-body);
	font-size: 1rem;
	border-radius: var(--radius-sm);
	transition: border-color var(--dur-fast) var(--ease);
}
.j48-field input:focus, .j48-field textarea:focus {
	outline: none;
	border-color: var(--color-primary);
}
.j48-field textarea { min-height: 140px; resize: vertical; }
.j48-submit {
	background: var(--color-accent);
	color: #fff;
	border: 0;
	padding: 14px 28px;
	font-family: var(--font-display);
	font-weight: 700;
	font-size: 1rem;
	border-radius: var(--radius-pill);
	margin-top: var(--space-sm);
	transition: background var(--dur-base) var(--ease);
}
.j48-submit:hover { background: var(--color-accent-pressed); }
.j48-success {
	display: none;
	background: rgba(46, 204, 113, 0.1);
	border-left: 4px solid #2ecc71;
	padding: var(--space-md);
	border-radius: var(--radius-sm);
	margin-top: var(--space-md);
	color: var(--color-text);
}
.j48-success.is-visible { display: block; }
@media (max-width: 720px) { .j48-inner { grid-template-columns: 1fr; } }

/* ============ BYLINE-01 — content page byline */
.y88 {
	display: flex;
	align-items: center;
	gap: var(--space-md);
	padding: var(--space-lg);
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	margin: var(--space-2xl) 0;
}
.y88-img {
	width: 56px; height: 56px;
	border-radius: 50%;
	object-fit: cover;
	flex-shrink: 0;
}
.y88-meta { display: flex; flex-direction: column; gap: 2px; }
.y88-by { font-size: var(--fs-small); color: var(--color-text-muted); }
.y88-name {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: 1.05rem;
	color: var(--color-text);
}
.y88-name a { color: inherit; }
.y88-name a:hover { color: var(--color-primary); }
.y88-role { font-size: var(--fs-small); color: var(--color-text-muted); }

/* ============ AUTH-01 — author card */
.b46 {
	padding: var(--space-2xl) 0;
}
.b46-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.b46-card {
	display: grid;
	grid-template-columns: 200px 1fr;
	gap: var(--space-xl);
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: var(--space-xl);
	align-items: start;
}
.b46-img {
	width: 200px; height: 200px;
	border-radius: var(--radius-md);
	object-fit: cover;
}
.b46-name { margin: 0 0 var(--space-xs); color: var(--color-primary); }
.b46-role {
	font-family: var(--font-display);
	color: var(--color-text-muted);
	margin-bottom: var(--space-md);
}
.b46-bio { color: var(--color-text); }
.b46-expertise {
	list-style: none; padding: 0;
	display: flex; flex-wrap: wrap; gap: var(--space-xs);
	margin-top: var(--space-md);
}
.b46-expertise li {
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	padding: 6px 14px;
	border-radius: var(--radius-pill);
	font-size: var(--fs-small);
	color: var(--color-primary);
	margin: 0;
}
@media (max-width: 720px) {
	.b46-card { grid-template-columns: 1fr; }
	.b46-img { width: 140px; height: 140px; margin: 0 auto; }
}

/* ============ COOK-07 — bottom-right card cookie banner */
.m46 {
	position: fixed;
	bottom: var(--space-lg);
	right: var(--space-lg);
	max-width: 360px;
	z-index: 200;
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-lg);
	box-shadow: 0 12px 40px rgba(0,0,0,0.5);
	display: none;
}
.m46.is-visible { display: block; }
.m46-inner { display: flex; flex-direction: column; gap: var(--space-md); }
.m46-text {
	color: var(--color-text-muted);
	font-size: 0.92rem;
	line-height: 1.5;
	margin: 0;
}
.m46-actions {
	display: flex;
	gap: var(--space-xs);
	flex-wrap: wrap;
}
.m46-button {
	border: 0;
	background: var(--color-accent);
	color: #fff;
	padding: 10px 18px;
	font-family: var(--font-display);
	font-weight: 700;
	font-size: 0.9rem;
	border-radius: var(--radius-pill);
	transition: background var(--dur-base) var(--ease);
}
.m46-button:hover { background: var(--color-accent-pressed); color: #fff; }
.m46-button--ghost {
	background: transparent;
	border: 1px solid var(--color-border);
	color: var(--color-text);
}
.m46-button--ghost:hover { background: var(--color-bg); color: var(--color-text); }

@media (max-width: 720px) {
	.m46, .m46-inner {
		padding: 12px 14px !important;
		gap: 8px !important;
		font-size: 13px !important;
		line-height: 1.35 !important;
	}
	.m46-title, .m46-heading { display: none !important; }
	.m46-button, .m46 button {
		padding: 8px 14px !important;
		font-size: 12px !important;
		min-height: 36px !important;
	}
	.m46 {
		left: var(--space-md);
		right: var(--space-md);
		bottom: var(--space-md);
		max-width: none;
	}
}

/* ============ ERR-02 — 404 block */
.i52 {
	padding: var(--space-3xl) 0;
	text-align: center;
	min-height: 60vh;
	display: flex;
	align-items: center;
}
.i52-inner {
	max-width: 640px;
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.i52-code {
	font-family: var(--font-display);
	font-size: clamp(6rem, 14vw, 12rem);
	font-weight: 900;
	color: var(--color-primary);
	line-height: 0.9;
	margin: 0 0 var(--space-md);
}
.i52-title { margin: 0 0 var(--space-md); }
.i52-text { color: var(--color-text-muted); margin-bottom: var(--space-xl); }
.i52-button {
	background: var(--color-accent);
	color: #fff;
	padding: 14px 32px;
	display: inline-flex;
	border-radius: var(--radius-pill);
	font-family: var(--font-display);
	font-weight: 700;
}
.i52-button:hover { background: var(--color-accent-pressed); color: #fff; }

/* ============ FOOT-04 — three-column footer with brand row */
.c04 {
	background: linear-gradient(180deg, var(--color-bg), #161616);
	border-top: 1px solid var(--color-border);
	padding: var(--space-2xl) 0 var(--space-xl);
	margin-top: var(--space-2xl);
}
.c04-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.c04-cols {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr;
	gap: var(--space-xl);
	padding-bottom: var(--space-xl);
	border-bottom: 1px solid var(--color-border);
}
.c04-brand img {
	height: 70px;
	width: auto;
	margin-bottom: var(--space-md);
}
.c04-brand p {
	color: var(--color-text-muted);
	max-width: 380px;
	font-size: 0.95rem;
}
.c04-col h3 {
	font-size: 1rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--color-primary);
	margin-bottom: var(--space-md);
}
.c04-col ul {
	list-style: none;
	padding: 0; margin: 0;
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.c04-col a {
	color: var(--color-text-muted);
	font-size: 0.95rem;
}
.c04-col a:hover { color: var(--color-primary); }
.c04-bottom {
	padding-top: var(--space-lg);
	display: flex;
	justify-content: space-between;
	gap: var(--space-md);
	flex-wrap: wrap;
}
.c04-copy {
	color: var(--color-text-muted);
	font-size: 0.88rem;
	margin: 0;
}
.c04-rg {
	color: var(--color-text-muted);
	font-size: 0.85rem;
	display: flex;
	align-items: center;
	gap: var(--space-xs);
}
.c04-rg::before {
	content: '18+';
	background: var(--color-rg-banner);
	color: #fff;
	padding: 2px 8px;
	border-radius: var(--radius-sm);
	font-weight: 700;
	font-size: 0.78rem;
}
@media (max-width: 900px) {
	.c04-cols { grid-template-columns: 1fr; gap: var(--space-lg); }
	.c04-bottom { flex-direction: column; }
}

/* ============ image utilities ============ */
.context-image {
	border-radius: var(--radius-md);
	overflow: hidden;
	margin: var(--space-xl) auto;
	max-width: 100%;
	box-shadow: 0 8px 32px rgba(0,0,0,0.3);
}
.context-image img { width: 100%; }
.figure-row {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: var(--space-lg);
	margin: var(--space-xl) 0;
}
.figure-row figure { margin: 0; border-radius: var(--radius-md); overflow: hidden; background: var(--color-bg-elevated); }
.figure-row figure img { width: 100%; }
.figure-row figcaption { padding: var(--space-sm) var(--space-md); font-size: var(--fs-small); color: var(--color-text-muted); }
