:root {
	--abik-obsidian: #07090d;
	--abik-midnight: #0d141d;
	--abik-charcoal: #1a212c;
	--abik-gold: #b6955c;
	--abik-gold-soft: #dbc48d;
	--abik-silver: #8d98a7;
	--abik-platinum: #cfd5de;
	--abik-paper: #f5f1e8;
	--abik-line: rgba(207, 213, 222, 0.14);
	--abik-panel: rgba(13, 20, 29, 0.84);
	--abik-panel-strong: rgba(7, 9, 13, 0.9);
	--abik-glass: rgba(255, 255, 255, 0.04);
	--abik-shadow: 0 28px 64px rgba(0, 0, 0, 0.35);
	--abik-shadow-gold: 0 0 0 1px rgba(182, 149, 92, 0.2), 0 24px 56px rgba(182, 149, 92, 0.16);
}

html {
	scroll-behavior: smooth;
}

body {
	background:
		radial-gradient(circle at top right, rgba(182, 149, 92, 0.18), transparent 26%),
		radial-gradient(circle at 14% 18%, rgba(207, 213, 222, 0.1), transparent 20%),
		linear-gradient(180deg, #06070a 0%, #0a1018 54%, #07090d 100%);
	color: var(--abik-platinum);
	min-height: 100vh;
}

body::before {
	background-image: linear-gradient(rgba(255, 255, 255, 0.03) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, 0.03) 1px, transparent 1px);
	background-position: center center;
	background-size: 80px 80px;
	content: "";
	inset: 0;
	opacity: 0.2;
	pointer-events: none;
	position: fixed;
	z-index: 0;
}

.wp-site-blocks {
	isolation: isolate;
	position: relative;
	z-index: 1;
}

.wp-site-blocks > * {
	position: relative;
	z-index: 1;
}

a {
	transition: color 180ms ease, opacity 180ms ease;
}

a:hover,
a:focus-visible {
	color: var(--abik-paper);
}

.wp-block-button__link,
.wp-element-button {
	transition: transform 180ms ease, box-shadow 180ms ease, background-color 180ms ease, color 180ms ease;
}

.wp-block-button__link:hover,
.wp-block-button__link:focus-visible,
.wp-element-button:hover,
.wp-element-button:focus-visible {
	box-shadow: var(--abik-shadow-gold);
	transform: translateY(-2px);
}

.abik-shell {
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.01));
	border: 1px solid var(--abik-line);
	box-shadow: var(--abik-shadow);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
}

.abik-panel-accent {
	box-shadow: var(--abik-shadow-gold);
	border-color: rgba(182, 149, 92, 0.28);
}

.abik-kicker {
	color: var(--abik-gold-soft);
	font-size: 0.8rem;
	font-weight: 700;
	letter-spacing: 0.24em;
	text-transform: uppercase;
}

.abik-subtle {
	color: var(--abik-silver);
}

.abik-divider {
	background: linear-gradient(90deg, transparent 0%, rgba(182, 149, 92, 0.75) 50%, transparent 100%);
	height: 1px;
	margin: 0;
	width: 100%;
}

.abik-stat-card {
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.015));
	border: 1px solid var(--abik-line);
	border-radius: 1.25rem;
	padding: 1.25rem;
	position: relative;
	overflow: hidden;
}

.abik-stat-card::after {
	background: linear-gradient(135deg, transparent, rgba(182, 149, 92, 0.18));
	content: "";
	inset: 0;
	opacity: 0;
	position: absolute;
	transition: opacity 220ms ease;
	pointer-events: none;
}

.abik-stat-card:hover::after,
.abik-stat-card:focus-within::after {
	opacity: 1;
}

.abik-service-card,
.wp-block-post-template > li {
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.018));
	border: 1px solid var(--abik-line);
	border-radius: 1.5rem;
	box-shadow: var(--abik-shadow);
	padding: clamp(1.4rem, 2vw, 1.8rem);
	transition: border-color 200ms ease, transform 200ms ease, box-shadow 200ms ease;
}

.abik-service-card:hover,
.abik-service-card:focus-within,
.wp-block-post-template > li:hover,
.wp-block-post-template > li:focus-within {
	border-color: rgba(182, 149, 92, 0.36);
	box-shadow: var(--abik-shadow-gold);
	transform: translateY(-4px);
}

.abik-step-card {
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0.015));
	border: 1px solid var(--abik-line);
	border-radius: 1.5rem;
	padding: 1.5rem;
	position: relative;
	overflow: hidden;
}

.abik-step-index {
	color: var(--abik-gold-soft);
	font-family: 'IBM Plex Mono', 'SFMono-Regular', Consolas, monospace;
	font-size: 0.82rem;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
}

.abik-metric-value {
	color: var(--abik-paper);
	font-family: 'Iowan Old Style', 'Palatino Linotype', 'Book Antiqua', Georgia, serif;
	font-size: clamp(2rem, 5vw, 3.4rem);
	font-weight: 700;
	letter-spacing: -0.05em;
	line-height: 0.95;
}

.abik-metric-copy {
	color: var(--abik-silver);
	font-size: 0.95rem;
	line-height: 1.55;
}

.abik-cta-panel {
	background:
		linear-gradient(135deg, rgba(182, 149, 92, 0.2), rgba(13, 20, 29, 0.85) 48%, rgba(207, 213, 222, 0.08) 100%),
		linear-gradient(180deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.015));
	border: 1px solid rgba(182, 149, 92, 0.28);
	box-shadow: var(--abik-shadow-gold);
}

.wp-block-post-template {
	gap: 1.5rem;
	list-style: none;
	padding-left: 0;
}

.wp-block-post-template > li h2,
.wp-block-post-template > li h3 {
	margin-top: 0;
}

.wp-block-post-featured-image img,
.wp-block-image img {
	border-radius: 1.5rem;
	box-shadow: var(--abik-shadow);
}

.abik-dot-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.abik-dot-list li {
	align-items: center;
	display: flex;
	gap: 0.8rem;
	padding: 0.4rem 0;
}

.abik-dot-list li::before {
	background: linear-gradient(135deg, var(--abik-gold), var(--abik-gold-soft));
	border-radius: 999px;
	content: "";
	flex: 0 0 0.55rem;
	height: 0.55rem;
	width: 0.55rem;
}

.abik-footer-note {
	border-top: 1px solid var(--abik-line);
	color: var(--abik-silver);
	font-size: 0.92rem;
	padding-top: 1.25rem;
}

.abik-inline-chip {
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid rgba(182, 149, 92, 0.24);
	border-radius: 999px;
	color: var(--abik-paper);
	display: inline-flex;
	font-family: inherit;
	font-size: 0.82rem;
	font-weight: 600;
	gap: 0.5rem;
	letter-spacing: 0.08em;
	padding: 0.6rem 0.9rem;
	text-transform: uppercase;
}

.abik-post-intro {
	max-width: 44rem;
}

:where(.wp-site-blocks *:focus-visible) {
	outline: 2px solid var(--abik-gold-soft);
	outline-offset: 3px;
}

@media (max-width: 781px) {
	body::before {
		background-size: 44px 44px;
		opacity: 0.14;
	}

	.wp-block-post-template,
	.wp-block-columns {
		gap: 1.25rem;
	}
}
