:root {
	--color-primary: #1c130a;
	--color-accent: #f6c61b;
	--color-accent-pressed: #d9b20a;
	--color-bg: #1f150b;
	--color-bg-elevated: #29200f;
	--color-gradient-light: #FFFFFF;
	--color-gradient-mid: #3b2910;
	--color-text: #FFFFFF;
	--color-text-muted: #bfbfbf;
	--color-border: #3a2a13;
	--color-border-strong: #5a4220;
	--color-rg-banner: #dc2626;

	--font-display: 'Montserrat', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
	--font-body: 'Montserrat', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;

	--font-size-base: 17px;
	--font-size-sm: 14px;
	--font-size-xs: 12px;
	--font-size-lg: 19px;
	--font-size-xl: 24px;
	--font-size-h1: clamp(34px, 4.6vw, 56px);
	--font-size-h2: clamp(26px, 2.8vw, 36px);
	--font-size-h3: 22px;
	--line-h-base: 1.65;
	--line-h-heading: 1.18;
	--letter-spacing-heading: -0.01em;

	--space-3xs: 4px;
	--space-2xs: 8px;
	--space-xs: 12px;
	--space-sm: 16px;
	--space-md: 24px;
	--space-lg: 32px;
	--space-xl: 48px;
	--space-2xl: 72px;
	--space-3xl: 96px;

	--container-site: 1280px;
	--container-readable: 720px;
	--container-padding-desktop: 32px;
	--container-padding-mobile: 18px;

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

	--header-height-desktop: 132px;
	--header-height-mobile: 72px;
	--rg-banner-h: 28px;

	--shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.35);
	--shadow-md: 0 6px 18px rgba(0, 0, 0, 0.45);
	--shadow-lg: 0 14px 40px rgba(0, 0, 0, 0.55);
	--shadow-gold: 0 0 0 1px rgba(246, 198, 27, 0.15), 0 14px 40px rgba(246, 198, 27, 0.12);

	--motion-fast: 140ms ease-out;
	--motion-base: 220ms cubic-bezier(0.4, 0, 0.2, 1);
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
	overflow-x: clip;
}

html {
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
}

body {
	background-color: var(--color-bg);
	background-image:
		radial-gradient(1200px 600px at 90% -10%, rgba(246, 198, 27, 0.08), transparent 60%),
		radial-gradient(1000px 500px at -10% 30%, rgba(59, 41, 16, 0.55), transparent 60%);
	color: var(--color-text);
	font-family: var(--font-body);
	font-size: var(--font-size-base);
	line-height: var(--line-h-base);
	min-height: 100vh;
	padding-top: calc(var(--header-height-desktop) + var(--rg-banner-h));
}

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

a {
	color: var(--color-accent);
	text-decoration: underline;
	text-decoration-color: rgba(246, 198, 27, 0.45);
	text-underline-offset: 2px;
	transition: color var(--motion-fast);
}
a:hover { color: var(--color-accent-pressed); }
a:focus-visible { outline: 2px solid var(--color-accent); outline-offset: 2px; border-radius: 2px; }

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-display);
	font-weight: 800;
	line-height: var(--line-h-heading);
	letter-spacing: var(--letter-spacing-heading);
	color: var(--color-text);
}
h1 { font-size: var(--font-size-h1); }
h2 { font-size: var(--font-size-h2); }
h3 { font-size: var(--font-size-h3); }

p { margin: 0 0 1em; }
ul, ol { margin: 0 0 1em 1.4em; }
li { margin: 0 0 0.4em; }

button { font: inherit; cursor: pointer; }

.sr-only {
	position: absolute !important;
	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;
	top: -200px;
	left: 16px;
	background: var(--color-accent);
	color: var(--color-primary);
	padding: 10px 14px;
	border-radius: var(--radius-md);
	font-weight: 700;
	z-index: 1000;
	text-decoration: none;
}
.skip-link:not(:focus) { top: -200px !important; }
.skip-link:focus { top: 8px; }

@media (prefers-reduced-motion: reduce) {
	* { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; }
	html { scroll-behavior: auto; }
}

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

/* ============================ HEADER · HEAD-06 (Magazine) ============================ */
.t83 {
	position: fixed;
	top: var(--rg-banner-h);
	left: 0; right: 0;
	z-index: 100;
	background: rgba(28, 19, 10, 0.94);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	border-bottom: 1px solid var(--color-border);
	transition: padding var(--motion-base), background var(--motion-base);
}
.t83.is-shrunk {
	background: rgba(28, 19, 10, 0.98);
	box-shadow: var(--shadow-md);
}
.t83-inner {
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.t83-top {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	padding: 14px 0 12px;
	border-bottom: 1px solid rgba(246, 198, 27, 0.12);
	gap: var(--space-md);
}
.t83-eyebrow {
	font-size: 11px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--color-text-muted);
	font-weight: 600;
}
.t83-logo {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	flex-shrink: 0;
	text-decoration: none;
	justify-self: center;
}
.t83-logo, .t83-logo img { flex-shrink: 0; }
.t83-logo-img {
	height: 88px;
	width: auto;
	display: block;
	mix-blend-mode: screen;
}
.t83-top-right {
	display: flex; align-items: center; justify-content: flex-end; gap: 12px;
}
.t83-auth {
	display: flex; align-items: center; gap: 10px;
}
.t83-auth-btn {
	display: inline-flex; align-items: center;
	font-size: var(--font-size-sm);
	font-weight: 700;
	padding: 10px 20px;
	border-radius: var(--radius-pill);
	text-decoration: none;
	white-space: nowrap;
	flex-shrink: 0;
	transition: background var(--motion-fast), color var(--motion-fast);
	letter-spacing: 0.02em;
}
.t83-auth-btn--login {
	color: var(--color-text);
	border: 1px solid var(--color-border-strong);
	background: transparent;
}
.t83-auth-btn--login:hover {
	background: rgba(246, 198, 27, 0.08);
	color: var(--color-accent);
	border-color: var(--color-accent);
}
.t83-auth-btn--register {
	background: var(--color-accent);
	color: var(--color-primary);
}
.t83-auth-btn--register:hover {
	background: var(--color-accent-pressed);
	color: var(--color-primary);
}
.t83-toggle {
	display: none;
	margin-left: auto !important;
	width: 44px; height: 44px;
	border: 1px solid var(--color-border-strong);
	background: transparent;
	color: var(--color-accent);
	border-radius: var(--radius-md);
	align-items: center; justify-content: center;
	font-size: 20px;
}
.t83-toggle span {
	display: block;
	width: 22px;
	height: 2px;
	background: currentColor;
	box-shadow: 0 -7px currentColor, 0 7px currentColor;
}
.t83-bottom {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 8px 0 12px;
	position: relative;
}
.t83-nav {
	display: flex;
	align-items: center;
	gap: 4px;
}
.t83-nav-list {
	list-style: none;
	margin: 0; padding: 0;
	display: flex;
	gap: 6px;
	flex-wrap: nowrap;
}
.t83-nav-link {
	display: inline-block;
	padding: 10px 16px;
	color: var(--color-text);
	text-decoration: none;
	font-size: var(--font-size-sm);
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	border-radius: var(--radius-sm);
	transition: color var(--motion-fast), background var(--motion-fast);
}
.t83-nav-link:hover { color: var(--color-accent); background: rgba(246, 198, 27, 0.06); }
[data-current="/"] .t83-nav-link[href="/"],
[data-current="/bonuses/"] .t83-nav-link[href="/bonuses/"],
[data-current="/mobile/"] .t83-nav-link[href="/mobile/"],
[data-current="/codigo-promo/"] .t83-nav-link[href="/codigo-promo/"],
[data-current="/access/"] .t83-nav-link[href="/access/"],
[data-current="/editor/"] .t83-nav-link[href="/editor/"],
[data-current="/contactanos/"] .t83-nav-link[href="/contactanos/"] {
	color: var(--color-accent);
	background: rgba(246, 198, 27, 0.10);
}

.t83-more {
	position: relative;
}
.t83-more-toggle {
	display: inline-flex; align-items: center; gap: 6px;
	padding: 10px 14px;
	background: transparent;
	border: 1px solid var(--color-border-strong);
	color: var(--color-text);
	border-radius: var(--radius-sm);
	font-size: var(--font-size-sm);
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}
.t83-more-toggle:hover { color: var(--color-accent); border-color: var(--color-accent); }
.t83-more-toggle::after {
	content: '';
	width: 7px; height: 7px;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: rotate(45deg);
	margin-top: -3px;
}
.t83-more-menu {
	display: none;
	position: absolute;
	top: calc(100% + 8px);
	right: 0;
	min-width: 220px;
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border-strong);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-lg);
	padding: 8px;
	list-style: none;
	margin: 0;
	z-index: 50;
}
.t83-more-menu.is-open { display: block; }
.t83-more-menu li { margin: 0; }
.t83-more-menu a {
	display: block;
	padding: 10px 14px;
	color: var(--color-text);
	text-decoration: none;
	font-size: var(--font-size-sm);
	border-radius: var(--radius-sm);
}
.t83-more-menu a:hover { background: rgba(246, 198, 27, 0.08); color: var(--color-accent); }

.t83-mobile {
	display: none;
	position: fixed;
	top: calc(var(--rg-banner-h) + var(--header-height-mobile));
	left: 0; right: 0; bottom: 0;
	background: var(--color-bg);
	border-top: 1px solid var(--color-border);
	padding: var(--space-lg) var(--container-padding-mobile);
	overflow-y: auto;
	z-index: 99;
}
.t83-mobile.is-open { display: block; }
.t83-mobile-list { list-style: none; margin: 0 0 var(--space-lg); padding: 0; }
.t83-mobile-list li { margin: 0; border-bottom: 1px solid var(--color-border); }
.t83-mobile-list a {
	display: block;
	padding: 16px 4px;
	color: var(--color-text);
	text-decoration: none;
	font-size: var(--font-size-lg);
	font-weight: 600;
}
.t83-mobile-list a:hover { color: var(--color-accent); }
.t83-mobile-auth {
	display: flex; flex-direction: column; gap: 12px;
	margin-top: var(--space-lg);
}

/* ============================ HERO · HERO-03 ============================ */
.e54 {
	padding: var(--space-3xl) 0 var(--space-2xl);
	position: relative;
	overflow: hidden;
}
.e54-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;
}
.e54-text { display: flex; flex-direction: column; gap: var(--space-md); }
.e54-eyebrow {
	font-size: 13px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--color-accent);
	font-weight: 700;
}
.e54-title {
	font-size: var(--font-size-h1);
	background: linear-gradient(120deg, #FFFFFF 0%, #f6c61b 70%, #d9b20a 100%);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}
.e54-subtitle {
	font-size: var(--font-size-lg);
	color: var(--color-text-muted);
	max-width: 540px;
	line-height: 1.55;
}
.e54-actions { display: flex; flex-wrap: wrap; gap: var(--space-sm); align-items: center; margin-top: var(--space-xs); }
.e54-cta {
	display: inline-flex; align-items: center; gap: 10px;
	padding: 16px 28px;
	background: var(--color-accent);
	color: var(--color-primary);
	font-weight: 800;
	border-radius: var(--radius-pill);
	text-decoration: none;
	font-size: var(--font-size-lg);
	letter-spacing: 0.02em;
	box-shadow: var(--shadow-gold);
	transition: transform var(--motion-fast), background var(--motion-fast);
}
.e54-cta:hover {
	background: var(--color-accent-pressed);
	color: var(--color-primary);
	transform: translateY(-1px);
}
.e54-meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-lg);
	color: var(--color-text-muted);
	font-size: var(--font-size-sm);
	margin-top: var(--space-md);
	padding-top: var(--space-md);
	border-top: 1px solid var(--color-border);
}
.e54-meta strong { color: var(--color-accent); font-weight: 700; }
.e54-media {
	position: relative;
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow-gold);
	aspect-ratio: 4 / 5;
}
.e54-media img {
	width: 100%; height: 100%; object-fit: cover; display: block;
}
.e54-media::after {
	content: '';
	position: absolute; inset: 0;
	background: linear-gradient(180deg, transparent 55%, rgba(28, 19, 10, 0.75));
	pointer-events: none;
}

/* ============================ PAGE HEADER · PHEAD-10 ============================ */
.h82 {
	padding: var(--space-2xl) 0 var(--space-lg);
	background: linear-gradient(180deg, rgba(59, 41, 16, 0.4), transparent 80%);
	border-bottom: 1px solid var(--color-border);
}
.h82-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
}
.h82-eyebrow {
	font-size: 12px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--color-accent);
	font-weight: 700;
}
.h82-title {
	font-size: var(--font-size-h1);
	max-width: 980px;
}
.h82-lede {
	color: var(--color-text-muted);
	font-size: var(--font-size-lg);
	max-width: 760px;
}
.h82-meta {
	display: flex; flex-wrap: wrap; gap: var(--space-md);
	color: var(--color-text-muted);
	font-size: var(--font-size-sm);
	margin-top: var(--space-xs);
}
.h82-meta time { color: var(--color-text); }

/* ============================ PROSE · PROSE-08 ============================ */
.f08 {
	padding: var(--space-2xl) 0;
}
.f08-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.f08-section {
	padding: var(--space-xl) 0;
	border-top: 1px dashed var(--color-border);
}
.f08-section:first-child { border-top: 0; padding-top: 0; }
.f08-section h2 {
	margin: 0 0 var(--space-md);
	position: relative;
	padding-left: 22px;
}
.f08-section h2::before {
	content: '';
	position: absolute; left: 0; top: 12px;
	width: 12px; height: 12px;
	background: var(--color-accent);
	transform: rotate(45deg);
}
.f08-section p {
	font-size: var(--font-size-base);
	color: var(--color-text);
	margin-bottom: 1em;
}
.f08-section ul, .f08-section ol {
	margin-left: 1.5em;
	color: var(--color-text);
}
.f08-section strong { color: var(--color-accent); font-weight: 700; }
.f08-section a { color: var(--color-accent); }

.f08-image {
	margin: var(--space-lg) 0;
	border-radius: var(--radius-md);
	overflow: hidden;
	border: 1px solid var(--color-border);
}
.f08-image img { width: 100%; height: auto; display: block; }
.f08-image figcaption {
	padding: 10px 16px;
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	background: rgba(0, 0, 0, 0.25);
	border-top: 1px solid var(--color-border);
}

/* ============================ ITEMS GRID · GRID-01 ============================ */
.a92 {
	padding: var(--space-2xl) 0;
	background: rgba(28, 19, 10, 0.5);
	border-top: 1px solid var(--color-border);
	border-bottom: 1px solid var(--color-border);
}
.a92-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.a92-head { margin-bottom: var(--space-xl); }
.a92-eyebrow {
	font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase;
	color: var(--color-accent); font-weight: 700;
	margin-bottom: var(--space-2xs);
}
.a92-title { font-size: var(--font-size-h2); max-width: 800px; }
.a92-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-md);
}
.a92-card {
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	padding: var(--space-md) var(--space-md) calc(var(--space-md) + 4px);
	border-radius: var(--radius-md);
	display: flex; flex-direction: column; gap: 10px;
	transition: border-color var(--motion-fast), transform var(--motion-fast);
}
.a92-card:hover {
	border-color: var(--color-accent);
	transform: translateY(-2px);
}
.a92-card-no {
	font-family: var(--font-display);
	font-weight: 800;
	font-size: 14px;
	color: var(--color-accent);
	letter-spacing: 0.1em;
}
.a92-card-title {
	font-size: 18px;
	line-height: 1.3;
	margin: 0;
}
.a92-card-text {
	color: var(--color-text-muted);
	font-size: 15px;
	line-height: 1.55;
	margin: 0;
}

/* ============================ FAQ · FAQ-02 ============================ */
.h14 { padding: var(--space-2xl) 0; }
.h14-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.h14-head { margin-bottom: var(--space-xl); }
.h14-eyebrow {
	font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase;
	color: var(--color-accent); font-weight: 700; margin-bottom: var(--space-2xs);
}
.h14-title { font-size: var(--font-size-h2); }
.h14-list { display: flex; flex-direction: column; gap: 12px; }
.h14-item {
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	overflow: hidden;
}
.h14-question {
	width: 100%;
	display: flex; align-items: center; justify-content: space-between;
	gap: 18px;
	padding: 18px 22px;
	background: transparent;
	color: var(--color-text);
	font-size: 17px;
	font-weight: 600;
	border: 0;
	text-align: left;
	cursor: pointer;
	font-family: var(--font-display);
}
.h14-question:hover { color: var(--color-accent); }
.h14-icon {
	flex-shrink: 0;
	width: 26px; height: 26px;
	border-radius: 50%;
	background: rgba(246, 198, 27, 0.12);
	color: var(--color-accent);
	display: inline-flex; align-items: center; justify-content: center;
	font-size: 18px;
	font-weight: 800;
	transition: transform var(--motion-base);
}
.h14-question[aria-expanded="true"] .h14-icon { transform: rotate(45deg); }
.h14-question[aria-expanded="true"] { color: var(--color-accent); }
.h14-answer {
	max-height: 0;
	overflow: hidden;
	transition: max-height var(--motion-base);
}
.h14-answer-inner {
	padding: 0 22px 22px;
	color: var(--color-text-muted);
	font-size: 16px;
	line-height: 1.65;
}
.h14-item.is-open .h14-answer { max-height: 800px; }

/* ============================ REVIEWS · REV-05 ============================ */
.p41 {
	padding: var(--space-2xl) 0;
	background: linear-gradient(180deg, transparent, rgba(59, 41, 16, 0.3));
	border-top: 1px solid var(--color-border);
}
.p41-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.p41-head { margin-bottom: var(--space-xl); display: flex; align-items: flex-end; justify-content: space-between; flex-wrap: wrap; gap: var(--space-md); }
.p41-eyebrow {
	font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase;
	color: var(--color-accent); font-weight: 700; margin-bottom: var(--space-2xs);
}
.p41-title { font-size: var(--font-size-h2); }
.p41-summary {
	display: flex; flex-direction: column; align-items: flex-end;
	font-family: var(--font-display);
}
.p41-summary-value {
	font-size: 42px;
	font-weight: 800;
	color: var(--color-accent);
	line-height: 1;
}
.p41-summary-label {
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	margin-top: 4px;
}
.p41-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-md);
}
.p41-card {
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-md) var(--space-md) calc(var(--space-md) + 4px);
	display: flex; flex-direction: column; gap: 12px;
	position: relative;
}
.p41-card::before {
	content: '\201C';
	position: absolute;
	top: 8px; right: 16px;
	font-size: 72px;
	color: rgba(246, 198, 27, 0.18);
	font-family: Georgia, serif;
	line-height: 1;
}
.p41-meta { display: flex; align-items: center; justify-content: space-between; gap: var(--space-sm); flex-wrap: wrap; }
.p41-author { font-weight: 700; font-size: 16px; color: var(--color-text); }
.p41-date { color: var(--color-text-muted); font-size: var(--font-size-sm); }
.p41-rating { display: inline-flex; align-items: center; gap: 6px; color: var(--color-accent); font-weight: 700; font-size: var(--font-size-sm); }
.p41-rating-stars { letter-spacing: 2px; }
.p41-text { color: var(--color-text-muted); font-size: 15px; line-height: 1.6; margin: 0; }

/* ============================ CTA · CTA-03 ============================ */
.j90 {
	padding: var(--space-2xl) 0;
}
.j90-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.j90-card {
	background: linear-gradient(135deg, var(--color-gradient-mid), var(--color-primary));
	border: 1px solid var(--color-accent);
	border-radius: var(--radius-lg);
	padding: var(--space-2xl);
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: var(--space-xl);
	align-items: center;
	box-shadow: var(--shadow-gold);
}
.j90-title {
	font-size: clamp(28px, 3.2vw, 40px);
	margin-bottom: var(--space-sm);
}
.j90-text {
	color: var(--color-text-muted);
	font-size: var(--font-size-lg);
	margin: 0;
	max-width: 580px;
}
.j90-actions { display: flex; flex-direction: column; gap: var(--space-sm); justify-self: end; }
.j90-button {
	display: inline-flex; align-items: center; justify-content: center;
	padding: 18px 32px;
	background: var(--color-accent);
	color: var(--color-primary);
	border-radius: var(--radius-pill);
	font-weight: 800;
	font-size: var(--font-size-lg);
	text-decoration: none;
	letter-spacing: 0.02em;
	transition: background var(--motion-fast), color var(--motion-fast);
	white-space: nowrap;
}
.j90-button:hover { background: var(--color-accent-pressed); color: var(--color-primary); }
.j90-note {
	font-size: var(--font-size-xs);
	color: var(--color-text-muted);
	letter-spacing: 0.04em;
	text-align: center;
}

/* ============================ TABLE · TABLE-04 ============================ */
.s72 {
	padding: var(--space-xl) 0;
}
.s72-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
	overflow-x: auto;
}
.s72-table {
	width: 100%;
	border-collapse: collapse;
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	overflow: hidden;
	font-size: 15px;
}
.s72-table thead { background: rgba(246, 198, 27, 0.08); }
.s72-table th {
	padding: 14px 18px;
	text-align: left;
	font-family: var(--font-display);
	font-weight: 700;
	color: var(--color-accent);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	font-size: 13px;
	border-bottom: 1px solid var(--color-border-strong);
}
.s72-table td {
	padding: 14px 18px;
	border-top: 1px solid var(--color-border);
	color: var(--color-text);
}
.s72-table tbody tr:hover { background: rgba(246, 198, 27, 0.04); }

/* ============================ LEGAL · LEGAL-08 ============================ */
.i38 {
	padding: var(--space-xl) 0 var(--space-2xl);
}
.i38-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.i38-intro {
	font-size: var(--font-size-lg);
	color: var(--color-text-muted);
	border-left: 3px solid var(--color-accent);
	padding: var(--space-sm) var(--space-md);
	margin-bottom: var(--space-xl);
	background: rgba(246, 198, 27, 0.04);
}
.i38-updated {
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	margin-bottom: var(--space-xl);
}
.i38-section { padding: var(--space-md) 0; border-top: 1px solid var(--color-border); }
.i38-section h2 {
	font-size: 24px;
	margin-bottom: var(--space-sm);
	color: var(--color-accent);
}
.i38-section p { color: var(--color-text); margin-bottom: 0.8em; }
.i38-contacts {
	margin-top: var(--space-xl);
	padding: var(--space-md);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	background: rgba(0, 0, 0, 0.25);
}
.i38-contacts h3 { font-size: 18px; margin-bottom: var(--space-sm); color: var(--color-accent); }
.i38-contacts ul { margin: 0; padding-left: 1.4em; }
.i38-contacts li { color: var(--color-text); }
.i38-disclaimer {
	margin-top: var(--space-lg);
	padding: var(--space-md);
	border: 1px dashed var(--color-border-strong);
	border-radius: var(--radius-md);
	color: var(--color-text-muted);
	font-size: var(--font-size-sm);
	line-height: 1.55;
}

/* ============================ CONTACT FORM · FORM-04 ============================ */
.s06 {
	padding: var(--space-xl) 0 var(--space-2xl);
}
.s06-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 1.4fr;
	gap: var(--space-2xl);
	align-items: start;
}
.s06-info h2 { font-size: 26px; margin-bottom: var(--space-sm); }
.s06-info p { color: var(--color-text-muted); }
.s06-info-list { list-style: none; margin: var(--space-md) 0 0; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.s06-info-list li {
	display: flex; gap: 12px; align-items: flex-start;
	padding: 12px 14px;
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	font-size: 15px;
}
.s06-info-list strong { color: var(--color-accent); display: block; }
.s06-form {
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-xl);
	display: flex; flex-direction: column; gap: var(--space-md);
}
.s06-field { display: flex; flex-direction: column; gap: 6px; }
.s06-field label {
	font-weight: 600;
	font-size: var(--font-size-sm);
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--color-text-muted);
}
.s06-field input, .s06-field textarea {
	background: rgba(0, 0, 0, 0.4);
	border: 1px solid var(--color-border-strong);
	color: var(--color-text);
	padding: 12px 14px;
	border-radius: var(--radius-md);
	font-family: var(--font-body);
	font-size: 15px;
	transition: border-color var(--motion-fast), background var(--motion-fast);
}
.s06-field input:focus, .s06-field textarea:focus {
	outline: none;
	border-color: var(--color-accent);
	background: rgba(0, 0, 0, 0.55);
}
.s06-field textarea { resize: vertical; min-height: 140px; }
.s06-submit {
	align-self: flex-start;
	padding: 14px 28px;
	background: var(--color-accent);
	color: var(--color-primary);
	border: 0;
	border-radius: var(--radius-pill);
	font-weight: 800;
	font-size: var(--font-size-base);
	transition: background var(--motion-fast);
}
.s06-submit:hover { background: var(--color-accent-pressed); color: var(--color-primary); }
.s06-success {
	display: none;
	padding: var(--space-md);
	background: rgba(34, 197, 94, 0.12);
	border: 1px solid rgba(34, 197, 94, 0.5);
	color: #86efac;
	border-radius: var(--radius-md);
}
.s06-form.is-success .s06-success { display: block; }
.s06-form.is-success .s06-field,
.s06-form.is-success .s06-submit { display: none; }

/* ============================ AUTHOR BYLINE · BYLINE-01 ============================ */
.w59 {
	display: flex;
	align-items: center;
	gap: var(--space-md);
	padding: var(--space-md);
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	margin-top: var(--space-xl);
}
.w59-portrait {
	flex-shrink: 0;
	width: 56px; height: 56px;
	border-radius: 50%;
	overflow: hidden;
	border: 2px solid var(--color-accent);
}
.w59-portrait img { width: 100%; height: 100%; object-fit: cover; }
.w59-body { display: flex; flex-direction: column; gap: 2px; }
.w59-line {
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	letter-spacing: 0.04em;
}
.w59-name {
	font-weight: 700;
	color: var(--color-text);
	font-size: 16px;
}
.w59-name a { color: var(--color-text); text-decoration: none; border-bottom: 1px dashed var(--color-border-strong); }
.w59-name a:hover { color: var(--color-accent); border-bottom-color: var(--color-accent); }
.w59-role { font-size: 13px; color: var(--color-text-muted); }
.w59-dates {
	display: flex; flex-wrap: wrap; gap: 12px;
	font-size: 13px; color: var(--color-text-muted);
	margin-top: 4px;
}
.w59-dates time { color: var(--color-text); }

/* ============================ AUTHOR CARD · AUTH-08 ============================ */
.r45 {
	padding: var(--space-2xl) 0;
}
.r45-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.r45-card {
	display: grid;
	grid-template-columns: 220px 1fr;
	gap: var(--space-xl);
	align-items: flex-start;
	padding: var(--space-xl);
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
}
.r45-portrait {
	width: 220px; height: 220px;
	border-radius: 50%;
	overflow: hidden;
	border: 3px solid var(--color-accent);
	box-shadow: var(--shadow-gold);
}
.r45-portrait img { width: 100%; height: 100%; object-fit: cover; }
.r45-name { font-size: 32px; margin-bottom: 6px; }
.r45-role {
	color: var(--color-accent);
	font-weight: 700;
	letter-spacing: 0.04em;
	margin-bottom: var(--space-md);
}
.r45-bio { color: var(--color-text); margin-bottom: var(--space-md); }
.r45-expertise h3 {
	font-size: 14px;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--color-text-muted);
	margin-bottom: var(--space-sm);
}
.r45-expertise ul {
	list-style: none; margin: 0; padding: 0;
	display: flex; flex-wrap: wrap; gap: 8px;
}
.r45-expertise li {
	display: inline-block;
	padding: 6px 14px;
	border: 1px solid var(--color-border-strong);
	border-radius: var(--radius-pill);
	font-size: var(--font-size-sm);
	color: var(--color-text);
}
.r45-articles {
	margin-top: var(--space-xl);
	padding: var(--space-xl);
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
}
.r45-articles-heading { font-size: 22px; margin-bottom: var(--space-md); }
.r45-articles-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.r45-articles-item {
	display: flex; align-items: center; gap: 12px;
	padding: 10px 0;
	border-bottom: 1px solid var(--color-border);
}
.r45-articles-item:last-child { border-bottom: 0; }
.r45-articles-item::before { content: '→'; color: var(--color-accent); font-weight: 800; }
.r45-articles-item a { color: var(--color-text); text-decoration: none; font-weight: 600; }
.r45-articles-item a:hover { color: var(--color-accent); }

/* ============================ ERROR · ERR-06 (404) ============================ */
.b85 {
	padding: var(--space-3xl) 0;
	min-height: 60vh;
	display: flex; align-items: center;
}
.b85-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
	text-align: center;
	display: flex; flex-direction: column; gap: var(--space-md);
	align-items: center;
}
.b85-code {
	font-size: clamp(120px, 18vw, 220px);
	font-weight: 900;
	line-height: 1;
	background: linear-gradient(120deg, var(--color-accent), #fff 60%, var(--color-accent));
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}
.b85-title { font-size: clamp(28px, 4vw, 44px); max-width: 760px; }
.b85-text { color: var(--color-text-muted); font-size: var(--font-size-lg); max-width: 600px; }
.b85-button {
	display: inline-flex; align-items: center; gap: 8px;
	padding: 16px 32px;
	background: var(--color-accent);
	color: var(--color-primary);
	font-weight: 800;
	border-radius: var(--radius-pill);
	text-decoration: none;
	margin-top: var(--space-sm);
}
.b85-button:hover { background: var(--color-accent-pressed); color: var(--color-primary); }

/* ============================ COOKIE · COOK-01 ============================ */
.o16 {
	position: fixed;
	bottom: 16px;
	left: 16px; right: 16px;
	max-width: 720px;
	margin: 0 auto;
	background: var(--color-bg-elevated);
	border: 1px solid var(--color-accent);
	border-radius: var(--radius-md);
	padding: 18px 22px;
	z-index: 90;
	box-shadow: var(--shadow-lg);
	display: none;
}
.o16.is-visible { display: block; }
.o16-inner {
	display: flex; align-items: center; gap: var(--space-md); flex-wrap: wrap;
}
.o16-title {
	font-family: var(--font-display); font-size: 15px; font-weight: 700;
	color: var(--color-accent); letter-spacing: 0.06em; text-transform: uppercase;
}
.o16-message {
	flex: 1; min-width: 240px;
	font-size: 14px; color: var(--color-text-muted); margin: 0;
	line-height: 1.5;
}
.o16-actions { display: flex; gap: 8px; }
.o16-button {
	padding: 10px 18px; border-radius: var(--radius-pill); font-weight: 700;
	border: 1px solid var(--color-border-strong);
	background: transparent; color: var(--color-text);
	font-size: 14px;
}
.o16-button:hover { color: var(--color-accent); border-color: var(--color-accent); }
.o16-button--primary {
	background: var(--color-accent); color: var(--color-primary); border-color: var(--color-accent);
}
.o16-button--primary:hover { background: var(--color-accent-pressed); color: var(--color-primary); border-color: var(--color-accent-pressed); }

/* ============================ FOOTER · FOOT-04 ============================ */
.k79 {
	background: linear-gradient(180deg, var(--color-bg), #15100a);
	border-top: 1px solid var(--color-border);
	padding: var(--space-2xl) 0 0;
	margin-top: var(--space-2xl);
}
.k79-inner {
	max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
	margin: 0 auto;
	padding: 0 var(--container-padding-desktop);
}
.k79-top {
	display: grid;
	grid-template-columns: 1.3fr 1fr 1fr 1.2fr;
	gap: var(--space-xl);
	padding-bottom: var(--space-xl);
	border-bottom: 1px solid var(--color-border);
}
.k79-brand { display: flex; flex-direction: column; gap: var(--space-sm); }
.k79-logo img {
	height: 64px; width: auto;
	mix-blend-mode: screen;
}
.k79-tagline { color: var(--color-text-muted); font-size: 14px; line-height: 1.55; max-width: 320px; }
.k79-col h3 {
	font-size: 13px; letter-spacing: 0.18em; text-transform: uppercase;
	color: var(--color-accent); margin-bottom: var(--space-md);
}
.k79-col ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.k79-col a { color: var(--color-text-muted); text-decoration: none; font-size: 15px; transition: color var(--motion-fast); }
.k79-col a:hover { color: var(--color-accent); }
.k79-contact-list { display: flex; flex-direction: column; gap: 10px; color: var(--color-text-muted); font-size: 14px; }
.k79-contact-list strong { color: var(--color-text); display: block; }

.k79-payments {
	display: flex; flex-wrap: wrap; gap: 6px;
	padding: var(--space-md) 0;
	border-bottom: 1px solid var(--color-border);
}
.k79-payment {
	padding: 5px 12px;
	border: 1px solid var(--color-border-strong);
	border-radius: var(--radius-sm);
	font-size: 11px;
	color: var(--color-text-muted);
	letter-spacing: 0.06em;
	text-transform: uppercase;
}
.k79-bottom {
	display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap;
	gap: var(--space-sm);
	padding: var(--space-md) 0;
	font-size: 13px;
	color: var(--color-text-muted);
}
.k79-bottom-meta { display: flex; gap: var(--space-md); flex-wrap: wrap; }
.k79-bottom-meta a { color: var(--color-text-muted); text-decoration: none; }
.k79-bottom-meta a:hover { color: var(--color-accent); }
.k79-license {
	padding: var(--space-md) 0 var(--space-lg);
	border-top: 1px dashed var(--color-border);
	color: var(--color-text-muted);
	font-size: 12px;
	line-height: 1.55;
}
.k79-license strong { color: var(--color-accent); }
.k79-age {
	display: inline-flex; align-items: center; justify-content: center;
	width: 38px; height: 38px;
	border: 2px solid var(--color-rg-banner);
	color: var(--color-rg-banner);
	border-radius: 50%;
	font-weight: 800;
	font-size: 14px;
	margin-right: 12px;
	vertical-align: middle;
}

/* ============================ MAIN content guard ============================ */
main { min-height: 50vh; display: block; }

/* ============================ MOBILE OVERRIDES ============================ */
@media (max-width: 1100px) {
	.t83-nav-list { gap: 2px; }
	.t83-nav-link { padding: 10px 10px; font-size: 13px; }
	.t83-more-toggle { padding: 10px 10px; font-size: 13px; }
}

@media (max-width: 960px) {
	body {
		padding-top: calc(var(--header-height-mobile) + var(--rg-banner-h));
	}
	.t83-inner {
		padding: 0 var(--container-padding-mobile);
	}
	.t83-top {
		grid-template-columns: 1fr auto;
		padding: 14px 0;
		border-bottom: 0;
		min-height: var(--header-height-mobile);
	}
	.t83-eyebrow { display: none; }
	.t83-logo { justify-self: start; }
	.t83-logo-img { height: 64px; }
	.t83-top-right { display: none; }
	.t83-toggle {
		display: inline-flex;
	}
	.t83-bottom { display: none; }

	.e54 { padding: var(--space-xl) 0; }
	.e54-inner { grid-template-columns: 1fr; gap: var(--space-lg); padding: 0 var(--container-padding-mobile); }
	.e54-media { aspect-ratio: 16 / 11; }

	.h82-inner, .a92-inner, .h14-inner, .p41-inner, .j90-inner, .f08-inner, .s72-inner, .i38-inner, .s06-inner, .r45-inner, .b85-inner, .k79-inner {
		padding: 0 var(--container-padding-mobile);
	}

	.a92-grid { grid-template-columns: 1fr; gap: 12px; }
	.p41-grid { grid-template-columns: 1fr; gap: 12px; }
	.p41-head { flex-direction: column; align-items: flex-start; }
	.p41-summary { align-items: flex-start; }

	.j90-card { grid-template-columns: 1fr; padding: var(--space-xl) var(--space-md); gap: var(--space-md); }
	.j90-actions { justify-self: start; }

	.s06-inner { grid-template-columns: 1fr; gap: var(--space-xl); }
	.s06-form { padding: var(--space-md); }

	.r45-card { grid-template-columns: 1fr; padding: var(--space-md); }
	.r45-portrait { width: 160px; height: 160px; margin: 0 auto; }
	.r45-name { text-align: center; }
	.r45-role { text-align: center; }

	.k79-top { grid-template-columns: 1fr 1fr; gap: var(--space-md); }
	.k79-bottom { flex-direction: column; align-items: flex-start; }

	h1 { font-size: clamp(28px, 8vw, 38px); }
	h2 { font-size: clamp(22px, 5vw, 28px); }
}

@media (max-width: 720px) {
	.k79-top { grid-template-columns: 1fr; }
	.o16, .o16-inner { padding: 12px 14px !important; gap: 8px !important; font-size: 13px !important; line-height: 1.35 !important; }
	.o16-title { display: none !important; }
	.o16-button { padding: 8px 14px !important; font-size: 12px !important; min-height: 36px !important; }
	.e54-actions { flex-direction: column; align-items: stretch; }
	.e54-cta { justify-content: center; }
}
