/*
Theme Name: Oseka Theme
Theme URI: https://osekamedia.hr/
Author: Oseka Media
Author URI: https://osekamedia.hr/
Description: Premium black/white/red block theme for Oseka Media service pages, portfolio, blog layouts, and SEO landing pages.
Version: 3.0.9
Requires at least: 6.5
Tested up to: 6.9
Requires PHP: 8.0
Text Domain: oseka-theme
*/

@font-face {
	font-display: swap;
	font-family: "Inter";
	font-style: normal;
	font-weight: 100 900;
	src: url("assets/fonts/inter-latin-ext-wght-normal.woff2") format("woff2");
}

@font-face {
	font-display: swap;
	font-family: "Space Grotesk";
	font-style: normal;
	font-weight: 700;
	src: url("assets/fonts/space-grotesk-latin-ext-700-normal.woff2") format("woff2");
}

:root {
	--color-core-black: #07080b;
	--color-signal-red: #d7264f;
	--color-pure-white: #f4f4f4;
	--color-charcoal: #1a1d24;
	--color-soft-gray: #c7cbd1;
	--color-mist-gray: #eceef1;
	--font-display: "Space Grotesk";
	--font-body: "Inter";
	--radius-brand: 8px;
	--omx-red: var(--color-signal-red);
	--omx-red-dark: #b51236;
	--omx-red-soft: rgba(215, 38, 79, 0.08);
	--omx-ink: var(--color-core-black);
	--omx-ink-2: var(--color-charcoal);
	--omx-muted: #656b76;
	--omx-line: rgba(7, 8, 11, 0.12);
	--omx-paper: var(--color-pure-white);
	--omx-soft: var(--color-mist-gray);
	--omx-white: #ffffff;
	--omx-shadow: 0 18px 58px rgba(7, 8, 11, 0.12);
	--omx-radius: var(--radius-brand);
	--omx-wrap: 1280px;
	--omx-font: var(--font-body), ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

html {
	scroll-behavior: smooth;
}

body {
	background: var(--color-pure-white);
	color: var(--omx-ink);
	font-family: var(--omx-font);
	letter-spacing: 0;
	text-rendering: optimizeLegibility;
}

body,
button,
input,
select,
textarea {
	font-size: 16px;
	line-height: 1.65;
}

a {
	color: var(--omx-red-dark);
	text-underline-offset: 0.2em;
}

a:hover {
	color: var(--omx-red);
}

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

.wp-site-blocks {
	background:
		linear-gradient(90deg, rgba(7, 8, 11, 0.035) 1px, transparent 1px),
		linear-gradient(180deg, rgba(7, 8, 11, 0.025) 1px, transparent 1px),
		var(--color-pure-white);
	background-size: 56px 56px;
	overflow-x: clip;
}

.entry-content {
	margin-block-start: 0;
}

.wp-block-post-content > * {
	margin-block-start: 0;
}

.wp-block-post-content:has(.omx-page) {
	max-width: none !important;
	padding: 0 !important;
}

.wp-block-post-content > .omx-page,
.entry-content > .omx-page {
	margin-left: 0;
	margin-right: 0;
	max-width: 100%;
	width: 100%;
}

.oseka-header {
	backdrop-filter: blur(14px);
	background: rgba(244, 244, 244, 0.92);
	border-bottom: 1px solid rgba(7, 8, 11, 0.1);
	position: sticky;
	top: 0;
	z-index: 50;
}

.admin-bar .oseka-header {
	top: 32px;
}

.oseka-nav-shell {
	min-height: 76px;
}

.oseka-brand,
.wp-block-site-title a {
	color: var(--omx-ink);
	font-family: var(--font-display), var(--omx-font);
	font-weight: 700;
	letter-spacing: 0;
	text-decoration: none;
}

.wp-block-navigation a {
	font-weight: 750;
	text-decoration: none;
}

.wp-block-navigation .wp-block-navigation-item__content:hover {
	color: var(--omx-red);
}

.oseka-header-cta .wp-block-button__link {
	background: var(--omx-red);
	border-radius: var(--omx-radius);
	color: #fff;
	padding: 0.72rem 1rem;
}

.oseka-template-main {
	margin: 0;
}

.oseka-template-main > .wp-block-post-content,
.oseka-template-main .wp-block-post-content {
	max-width: none;
	width: 100%;
}

body .is-layout-constrained > .omx-page {
	margin-left: 0 !important;
	margin-right: 0 !important;
	max-width: 100% !important;
	width: 100% !important;
}

.oseka-footer {
	background: var(--color-core-black);
	color: #fff;
}

.oseka-footer a {
	color: #fff;
	text-decoration: none;
}

.oseka-footer a:hover {
	color: #ffd8dc;
}

.oseka-footer p {
	color: rgba(255, 255, 255, 0.72);
}

.oseka-section-tight {
	padding-block: clamp(2.4rem, 4vw, 4rem);
}

.oseka-section {
	padding-block: clamp(3.25rem, 5.6vw, 5.6rem);
}

.oseka-kicker {
	color: var(--omx-red);
	font-size: 0.78rem;
	font-weight: 900;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.oseka-lead {
	color: #3c4048;
	font-size: clamp(1.08rem, 1.7vw, 1.25rem);
	line-height: 1.72;
}

.oseka-card,
.oseka-post-card,
.oseka-contact-panel {
	background: #fff;
	border: 1px solid var(--omx-line);
	border-radius: var(--omx-radius);
	box-shadow: var(--omx-shadow);
}

.is-style-oseka-card,
.oseka-service-card,
.oseka-step {
	background: #fff;
	border: 1px solid var(--omx-line);
	box-shadow: 0 14px 42px rgba(7, 8, 11, 0.1);
	color: var(--omx-ink);
	padding: clamp(1.05rem, 2vw, 1.45rem);
}

.oseka-step {
	border-left: 3px solid var(--omx-red);
}

.oseka-service-card h3,
.oseka-step h3 {
	color: var(--omx-ink);
	margin-bottom: 0.65rem;
}

.oseka-service-card h3 a,
.oseka-step h3 a {
	color: inherit;
	text-decoration: none;
}

.oseka-service-card p,
.oseka-step p {
	color: #343944;
	line-height: 1.62;
}

.wp-block-button__link,
.wp-element-button {
	border-radius: var(--omx-radius);
	font-weight: 850;
	min-height: 44px;
}

.is-style-outline .wp-block-button__link {
	border-width: 1px;
}

.oseka-post-meta {
	color: var(--omx-muted);
	font-size: 0.92rem;
}

/* Generated page system */
.omx-page {
	background: var(--omx-paper);
	color: var(--omx-ink);
	font-family: var(--omx-font);
	margin: 0;
	overflow: clip;
}

.omx-wrap {
	margin-inline: auto;
	max-width: var(--omx-wrap);
	padding-inline: clamp(20px, 4vw, 40px);
	position: relative;
	width: 100%;
}

.omx-hero,
.omx-section,
.omx-final {
	position: relative;
}

.omx-hero {
	padding-block: clamp(4.2rem, 7.4vw, 6.6rem);
}

.omx-hero::before {
	background: linear-gradient(135deg, rgba(215, 25, 32, 0.12), transparent 34%), linear-gradient(180deg, #fff, rgba(255, 250, 248, 0));
	content: "";
	inset: 0;
	pointer-events: none;
	position: absolute;
}

.omx-section {
	padding-block: clamp(3.35rem, 5.8vw, 5.8rem);
}

.omx-soft {
	background: linear-gradient(180deg, #fff, var(--omx-soft));
	border-block: 1px solid var(--omx-line);
}

.omx-band {
	background: var(--omx-ink);
	color: #fff;
	padding-block: 1rem;
}

.omx-band p {
	color: rgba(255, 255, 255, 0.82);
	font-weight: 700;
	margin: 0;
}

.omx-band a {
	color: #fff;
}

.omx-hero-grid,
.omx-service-hero,
.omx-split,
.omx-two-panel,
.omx-contact-grid {
	display: grid;
	gap: clamp(1.5rem, 3vw, 3rem);
	grid-template-columns: minmax(0, 1.1fr) minmax(360px, 0.9fr);
}

.omx-hero-grid,
.omx-service-hero {
	align-items: center;
}

.omx-split {
	align-items: start;
}

.omx-eyebrow {
	align-items: center;
	color: var(--omx-red);
	display: inline-flex;
	font-size: 0.78rem;
	font-weight: 900;
	gap: 0.6rem;
	letter-spacing: 0.08em;
	margin: 0 0 1rem;
	text-transform: uppercase;
}

.omx-eyebrow::before {
	background: currentColor;
	content: "";
	height: 2px;
	width: 28px;
}

.omx-page h1,
.omx-page h2,
.omx-page h3 {
	color: var(--omx-ink);
	font-family: var(--font-display), var(--omx-font);
	font-weight: 900;
	letter-spacing: 0;
	line-height: 1.04;
	margin: 0;
	text-wrap: balance;
}

.omx-page h1 {
	font-size: clamp(2.55rem, 5.1vw, 4.9rem);
	max-width: 900px;
}

.omx-page h2 {
	font-size: clamp(2rem, 4vw, 3.55rem);
	max-width: 820px;
}

.omx-page h3 {
	font-size: clamp(1.15rem, 1.6vw, 1.38rem);
	line-height: 1.16;
}

.omx-page p {
	color: var(--omx-muted);
	font-size: 1rem;
	line-height: 1.78;
	margin: 0;
}

.omx-lead {
	color: #3c4048;
	font-size: clamp(1.1rem, 1.7vw, 1.28rem) !important;
	line-height: 1.72 !important;
	margin-top: 1.5rem !important;
	max-width: 720px;
}

.omx-actions {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 0.8rem;
	margin-top: 2rem;
}

.omx-btn {
	align-items: center;
	border-radius: var(--omx-radius);
	display: inline-flex;
	font-weight: 900;
	justify-content: center;
	min-height: 48px;
	padding: 0.88rem 1.15rem;
	text-decoration: none;
	transition: background 180ms ease, border-color 180ms ease, color 180ms ease, transform 180ms ease;
}

.omx-btn:hover {
	transform: translateY(-2px);
}

.omx-btn-primary {
	background: var(--omx-red);
	color: #fff;
}

.omx-btn-primary:hover {
	background: var(--omx-red-dark);
	color: #fff;
}

.omx-btn-secondary {
	background: #fff;
	border: 1px solid var(--omx-line);
	color: var(--omx-ink);
}

.omx-btn-secondary:hover {
	border-color: var(--omx-red);
	color: var(--omx-red-dark);
}

.wp-block-button.omx-btn {
	background: transparent;
	border: 0;
	display: block;
	min-height: auto;
	padding: 0;
}

.wp-block-button.omx-btn .wp-block-button__link {
	align-items: center;
	border-radius: var(--omx-radius);
	display: inline-flex;
	font-weight: 900;
	justify-content: center;
	min-height: 48px;
	padding: 0.88rem 1.15rem;
}

.wp-block-button.omx-btn-primary .wp-block-button__link {
	background: var(--omx-red);
	color: #fff;
}

.wp-block-button.omx-btn-secondary .wp-block-button__link {
	background: #fff;
	border: 1px solid var(--omx-line);
	color: var(--omx-ink);
}

.omx-proof-row {
	display: grid;
	gap: 0.75rem;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	margin-top: 3rem;
	max-width: 720px;
}

.omx-stat {
	background: rgba(255, 255, 255, 0.78);
	border: 1px solid var(--omx-line);
	border-radius: var(--omx-radius);
	padding: 1rem;
}

.omx-stat strong {
	color: var(--omx-red);
	display: block;
	font-size: clamp(1.45rem, 3vw, 2.15rem);
	line-height: 1;
}

.omx-stat span {
	color: var(--omx-muted);
	display: block;
	font-size: 0.84rem;
	font-weight: 750;
	margin-top: 0.45rem;
}

.omx-hero-panel,
.omx-brief-card,
.omx-contact-card,
.omx-form,
.omx-card,
.omx-project-card,
.omx-list-panel,
.omx-process,
.omx-final-box {
	background: #fff;
	border: 1px solid var(--omx-line);
	border-radius: var(--omx-radius);
	box-shadow: var(--omx-shadow);
}

.omx-hero-panel,
.omx-brief-card,
.omx-contact-card,
.omx-form,
.omx-list-panel,
.omx-process {
	padding: clamp(1.4rem, 3vw, 2rem);
}

.omx-panel-top {
	align-items: center;
	border-bottom: 1px solid var(--omx-line);
	display: flex;
	justify-content: space-between;
	margin-bottom: 1.4rem;
	padding-bottom: 1rem;
}

.omx-panel-top span,
.omx-brief-card span,
.omx-project-body span {
	color: var(--omx-red);
	font-size: 0.76rem;
	font-weight: 900;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.omx-panel-top strong {
	color: var(--omx-ink);
}

.omx-roadmap {
	display: grid;
	gap: 1rem;
}

.omx-roadmap div,
.omx-step {
	border-left: 3px solid var(--omx-red);
	padding-left: 1rem;
}

.omx-roadmap span,
.omx-step span,
.omx-card span {
	color: var(--omx-red);
	display: block;
	font-size: 0.8rem;
	font-weight: 900;
	letter-spacing: 0.08em;
	margin-bottom: 0.35rem;
	text-transform: uppercase;
}

.omx-roadmap strong,
.omx-step strong {
	color: var(--omx-ink);
	display: block;
	font-size: 1.05rem;
	margin-bottom: 0.2rem;
}

.omx-roadmap p,
.omx-step p {
	font-size: 0.92rem;
}

.omx-section-head {
	margin-bottom: clamp(1.45rem, 3vw, 2.25rem);
	max-width: 760px;
}

.omx-section-head p:last-child {
	margin-top: 1rem;
}

.omx-copy {
	display: grid;
	gap: 1.1rem;
}

.omx-copy p {
	color: #3f4652;
	font-size: 1.04rem;
}

.omx-card-grid,
.omx-project-grid,
.omx-link-grid {
	display: grid;
	gap: clamp(0.85rem, 1.6vw, 1.25rem);
}

.omx-card-grid-3,
.omx-project-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.omx-project-grid-large {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.omx-card {
	color: var(--omx-ink);
	padding: clamp(1.05rem, 2vw, 1.45rem);
	transition: border-color 180ms ease, transform 180ms ease, box-shadow 180ms ease;
}

.omx-card:hover,
.omx-project-card:hover {
	border-color: rgba(215, 25, 32, 0.36);
	box-shadow: 0 22px 58px rgba(27, 20, 18, 0.12);
	transform: translateY(-4px);
}

.omx-card h3 {
	margin-bottom: 0.75rem;
}

.omx-card p {
	color: #343944;
	font-size: 0.95rem;
	line-height: 1.62;
}

.omx-hub-card {
	display: flex;
	flex-direction: column;
	min-height: 260px;
}

.omx-hub-card a {
	font-weight: 900;
	margin-top: auto;
	text-decoration: none;
}

.omx-project-card {
	overflow: hidden;
	transition: border-color 180ms ease, transform 180ms ease, box-shadow 180ms ease;
}

.omx-project-media {
	background: #f0ebe8;
	display: block;
	overflow: hidden;
}

.omx-project-media img {
	aspect-ratio: 16 / 10;
	display: block;
	object-fit: cover;
	width: 100%;
}

.omx-project-visual {
	aspect-ratio: 16 / 10;
	background:
		linear-gradient(90deg, rgba(215, 25, 32, 0.09) 1px, transparent 1px),
		linear-gradient(180deg, rgba(215, 25, 32, 0.08) 1px, transparent 1px),
		linear-gradient(135deg, #fff, #fff0f1);
	background-size: 28px 28px, 28px 28px, auto;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	min-height: 210px;
	padding: 1rem;
}

.omx-project-browser {
	align-items: center;
	background: rgba(255, 255, 255, 0.82);
	border: 1px solid var(--omx-line);
	border-radius: 8px;
	display: flex;
	gap: 0.4rem;
	height: 34px;
	padding-inline: 0.8rem;
}

.omx-project-browser i {
	background: var(--omx-red);
	border-radius: 999px;
	display: block;
	height: 8px;
	opacity: 0.75;
	width: 8px;
}

.omx-project-visual strong {
	color: var(--omx-ink);
	display: block;
	font-size: clamp(1.35rem, 2.2vw, 2.1rem);
	line-height: 1;
	max-width: 300px;
}

.omx-project-visual em {
	color: var(--omx-red);
	display: block;
	font-style: normal;
	font-weight: 900;
	margin-top: 0.55rem;
}

.omx-project-body {
	padding: clamp(1.1rem, 2.2vw, 1.55rem);
}

.omx-project-body h3 {
	margin-top: 0.4rem;
}

.omx-project-body p {
	font-size: 0.94rem;
	margin-top: 0.65rem;
}

.omx-project-body a {
	display: inline-block;
	font-weight: 900;
	margin-top: 1rem;
	text-decoration: none;
}

.omx-center {
	margin-top: 2rem;
	text-align: center;
}

.omx-brief-card strong {
	color: var(--omx-ink);
	display: block;
	font-size: clamp(1.35rem, 2.2vw, 1.9rem);
	line-height: 1.12;
	margin: 0.6rem 0 1.2rem;
}

.omx-brief-card ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.omx-brief-card li {
	border-top: 1px solid var(--omx-line);
	color: var(--omx-muted);
	display: flex;
	gap: 0.75rem;
	justify-content: space-between;
	padding: 0.85rem 0;
}

.omx-brief-card li b {
	color: var(--omx-red);
	min-width: 72px;
}

.omx-check-list {
	list-style: none;
	margin: 1.5rem 0 0;
	padding: 0;
}

.omx-check-list li {
	border-top: 1px solid var(--omx-line);
	color: #3f4652;
	font-weight: 720;
	padding: 0.85rem 0 0.85rem 1.8rem;
	position: relative;
}

.omx-check-list li::before {
	background: var(--omx-red);
	border-radius: 999px;
	content: "";
	height: 8px;
	left: 0;
	position: absolute;
	top: 1.55rem;
	width: 8px;
}

.omx-process {
	display: grid;
	gap: 0.8rem;
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.02)),
		var(--color-core-black);
	border-color: rgba(244, 244, 244, 0.14);
	box-shadow: 0 24px 72px rgba(7, 8, 11, 0.22);
	color: var(--color-pure-white);
	padding: clamp(1.1rem, 2.2vw, 1.55rem);
}

.omx-link-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.omx-link-grid a {
	background: #fff;
	border: 1px solid var(--omx-line);
	border-radius: var(--omx-radius);
	color: var(--omx-ink);
	font-weight: 850;
	padding: 1rem;
	text-decoration: none;
	transition: border-color 180ms ease, color 180ms ease, transform 180ms ease;
}

.omx-link-grid a:hover {
	border-color: var(--omx-red);
	color: var(--omx-red-dark);
	transform: translateY(-2px);
}

.omx-muted {
	color: var(--omx-muted);
	font-size: 0.92rem;
	margin-top: 1rem !important;
}

.omx-faq {
	display: grid;
	gap: 0.8rem;
	max-width: 900px;
}

.omx-faq details {
	background: #fff;
	border: 1px solid var(--omx-line);
	border-radius: var(--omx-radius);
	padding: 1rem 1.15rem;
}

.omx-faq summary {
	color: var(--omx-ink);
	cursor: pointer;
	font-weight: 900;
}

.omx-faq p {
	margin-top: 0.8rem;
}

.omx-final {
	padding-block: clamp(3.25rem, 5.6vw, 5.6rem);
}

.omx-final-box {
	align-items: center;
	background: linear-gradient(135deg, #fff, var(--omx-red-soft));
	display: grid;
	gap: clamp(1.25rem, 2.5vw, 2rem);
	grid-template-columns: 1fr auto;
	padding: clamp(1.25rem, 3vw, 2.35rem);
}

.omx-final-box h2 {
	max-width: 760px;
}

.omx-final-box p {
	margin-top: 1rem;
	max-width: 680px;
}

.omx-contact-grid {
	align-items: start;
}

.omx-contact-methods {
	display: grid;
	gap: 0.85rem;
	margin-top: 2rem;
}

.omx-contact-methods a {
	background: var(--omx-paper);
	border: 1px solid var(--omx-line);
	border-radius: var(--omx-radius);
	color: var(--omx-ink);
	padding: 1rem;
	text-decoration: none;
}

.omx-contact-methods span {
	color: var(--omx-muted);
	display: block;
	font-size: 0.82rem;
	font-weight: 850;
	text-transform: uppercase;
}

.omx-contact-methods strong {
	display: block;
	font-size: 1.1rem;
	margin-top: 0.2rem;
}

.omx-form {
	display: grid;
	gap: 1rem;
}

.omx-contact-form {
	display: grid;
	gap: 1rem;
}

.omx-form label {
	color: var(--omx-ink);
	display: grid;
	font-weight: 850;
	gap: 0.35rem;
}

.omx-form input,
.omx-form select,
.omx-form textarea {
	background: var(--omx-paper);
	border: 1px solid var(--omx-line);
	border-radius: var(--omx-radius);
	color: var(--omx-ink);
	font: inherit;
	padding: 0.85rem 0.9rem;
	width: 100%;
}

.omx-contact-form textarea {
	resize: vertical;
}

.omx-form input:focus,
.omx-form select:focus,
.omx-form textarea:focus {
	border-color: var(--omx-red);
	box-shadow: 0 0 0 3px rgba(215, 25, 32, 0.12);
	outline: none;
}

.omx-submit {
	background: var(--omx-red);
	border: 0;
	border-radius: var(--omx-radius);
	color: #fff;
	cursor: pointer;
	font-weight: 900;
	min-height: 50px;
	padding: 0.9rem 1.1rem;
}

.omx-submit:hover {
	background: var(--omx-red-dark);
}

.omx-form-note {
	font-size: 0.82rem !important;
}

.omx-hp {
	left: -9999px;
	position: absolute;
}

/* Blog and archives */
.oseka-article-shell {
	background: #fff;
}

.oseka-article-hero {
	background: linear-gradient(180deg, var(--omx-red-soft), #fff);
	border-bottom: 1px solid var(--omx-line);
	padding-block: clamp(4rem, 7vw, 6.5rem);
}

.oseka-article-hero .wp-block-post-title {
	font-size: clamp(2.35rem, 5vw, 4.6rem);
	letter-spacing: 0;
	line-height: 1.05;
	max-width: 920px;
}

.oseka-article-meta {
	color: var(--omx-red-dark);
	font-size: 0.9rem;
	font-weight: 850;
	text-transform: uppercase;
}

.oseka-article-content {
	padding-block: clamp(3rem, 6vw, 5.5rem);
}

.oseka-article-content .wp-block-post-content {
	font-size: 1.08rem;
	line-height: 1.85;
}

.oseka-article-content .wp-block-post-content h2,
.oseka-article-content .wp-block-post-content h3 {
	letter-spacing: 0;
	line-height: 1.15;
	margin-top: 2.2em;
}

.oseka-article-content .wp-block-post-content p,
.oseka-article-content .wp-block-post-content li {
	color: #343944;
}

.oseka-article-content .wp-block-post-content img {
	border-radius: var(--omx-radius);
}

.oseka-post-card {
	padding: 1.4rem;
}

.oseka-post-card .wp-block-post-title a {
	color: var(--omx-ink);
	text-decoration: none;
}

.oseka-post-card .wp-block-post-title a:hover {
	color: var(--omx-red);
}

.wp-block-query-pagination a,
.wp-block-query-pagination .current {
	border: 1px solid var(--omx-line);
	border-radius: var(--omx-radius);
	display: inline-flex;
	min-width: 42px;
	padding: 0.45rem 0.75rem;
	text-decoration: none;
}

.oseka-portfolio-grid {
	gap: clamp(0.9rem, 1.8vw, 1.35rem);
	margin-block: clamp(1.2rem, 2.2vw, 2rem);
}

.oseka-portfolio-card,
.oseka-empty-state {
	border: 1px solid rgba(7, 8, 11, 0.14);
	border-radius: var(--omx-radius);
	box-shadow: 0 14px 42px rgba(7, 8, 11, 0.1);
}

.oseka-portfolio-card__media {
	background: var(--omx-soft);
}

.oseka-portfolio-card__body {
	padding: clamp(1rem, 1.8vw, 1.35rem);
}

.oseka-portfolio-card__body h3 {
	font-size: clamp(1.08rem, 1.4vw, 1.25rem);
	line-height: 1.16;
	margin: 0;
}

.oseka-portfolio-card__body h3 a {
	color: var(--omx-ink);
	text-decoration: none;
}

.oseka-portfolio-card__body h3 a:hover {
	color: var(--omx-red-dark);
}

.oseka-portfolio-card__body p {
	color: #343944;
	line-height: 1.62;
	margin: 0.65rem 0 0;
}

.oseka-portfolio-card .oseka-text-link {
	display: inline-flex;
	margin-top: 0.95rem;
}

.oseka-empty-state {
	background: var(--color-core-black);
	border-color: rgba(244, 244, 244, 0.14);
	box-shadow: 0 24px 72px rgba(7, 8, 11, 0.22);
	color: var(--color-pure-white);
	margin-block: clamp(1.2rem, 2.2vw, 2rem);
	padding: clamp(1.35rem, 2.6vw, 2rem);
	position: relative;
}

.oseka-empty-state::before {
	background: var(--omx-red);
	content: "";
	height: 4px;
	inset: 0 0 auto;
	position: absolute;
}

.oseka-empty-state h3 {
	color: var(--color-pure-white);
	font-size: clamp(1.2rem, 1.8vw, 1.55rem);
	line-height: 1.15;
	margin: 0;
}

.oseka-empty-state p {
	color: rgba(244, 244, 244, 0.78);
	line-height: 1.62;
	margin: 0.65rem 0 1.1rem;
	max-width: 56ch;
}

.oseka-empty-state .oseka-button {
	background: var(--omx-red);
	color: #fff;
}

.oseka-empty-state .oseka-button:hover {
	background: var(--omx-red-dark);
}

@media (max-width: 1024px) {
	.omx-hero-grid,
	.omx-service-hero,
	.omx-split,
	.omx-two-panel,
	.omx-contact-grid,
	.omx-final-box {
		grid-template-columns: 1fr;
	}

	.omx-card-grid-3,
	.omx-project-grid,
	.omx-project-grid-large,
	.omx-link-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 780px) {
	.admin-bar .oseka-header {
		top: 0;
	}

	.oseka-nav-shell {
		min-height: auto;
		padding-block: 0.85rem;
	}

	.omx-page h1 {
		font-size: 2.55rem;
	}

	.omx-proof-row,
	.omx-card-grid-3,
	.omx-project-grid,
	.omx-project-grid-large,
	.omx-link-grid {
		grid-template-columns: 1fr;
	}

	.omx-actions,
	.omx-final-box .omx-actions {
		align-items: stretch;
		flex-direction: column;
	}

	.omx-btn {
		width: 100%;
	}

	.omx-brief-card li {
		display: block;
	}
}

/* Oseka 3.0 visual system */
.omx-hero,
.oseka-hero {
	background:
		radial-gradient(circle at 78% 20%, rgba(215, 38, 79, 0.18), transparent 28%),
		linear-gradient(135deg, var(--color-core-black), var(--color-charcoal));
	color: var(--color-pure-white);
	overflow: hidden;
}

.omx-hero::before,
.oseka-hero::before {
	background:
		linear-gradient(90deg, rgba(244, 244, 244, 0.045) 1px, transparent 1px),
		linear-gradient(180deg, rgba(244, 244, 244, 0.035) 1px, transparent 1px);
	background-size: 72px 72px;
}

.omx-hero::after,
.oseka-hero::after {
	background: var(--color-signal-red);
	clip-path: polygon(16% 0, 100% 0, 84% 100%, 0 100%);
	content: "";
	height: clamp(180px, 22vw, 340px);
	opacity: 0.95;
	position: absolute;
	right: clamp(-120px, -8vw, -40px);
	top: 0;
	width: clamp(160px, 18vw, 300px);
}

.omx-hero .omx-wrap,
.oseka-hero .wp-block-columns {
	z-index: 1;
}

.omx-hero h1,
.omx-hero h2,
.omx-hero h3,
.oseka-hero h1,
.oseka-hero h2,
.oseka-hero h3 {
	color: var(--color-pure-white);
}

.omx-hero p,
.oseka-hero p {
	color: rgba(244, 244, 244, 0.78);
}

.omx-hero-panel,
.omx-brief-card {
	background: rgba(26, 29, 36, 0.88);
	border-color: rgba(244, 244, 244, 0.14);
	box-shadow: 0 28px 80px rgba(0, 0, 0, 0.28);
	color: var(--color-pure-white);
}

.omx-hero-panel p,
.omx-brief-card p,
.omx-hero .omx-roadmap p,
.omx-hero .omx-step p,
.is-style-oseka-dark .omx-step p {
	color: rgba(244, 244, 244, 0.66);
}

.omx-hero .omx-roadmap strong,
.omx-hero .omx-step strong,
.is-style-oseka-dark .omx-step strong,
.omx-panel-top strong,
.omx-brief-card strong {
	color: var(--color-pure-white);
}

.omx-process .omx-eyebrow {
	color: var(--omx-red);
	margin-bottom: 0.15rem;
}

.omx-process .omx-step {
	background: rgba(244, 244, 244, 0.78);
	border: 1px solid var(--omx-line);
	border-left: 3px solid var(--omx-red);
	border-radius: var(--omx-radius);
	padding: clamp(0.9rem, 1.7vw, 1.1rem);
}

.omx-process .omx-step span {
	color: var(--omx-red);
}

.omx-process .omx-step strong {
	color: var(--omx-ink);
}

.omx-process .omx-step p {
	color: #3f4652;
	line-height: 1.58;
}

.omx-hero .omx-process .omx-step,
.is-style-oseka-dark .omx-process .omx-step {
	background: rgba(255, 255, 255, 0.06);
	border-color: rgba(244, 244, 244, 0.12);
}

.omx-hero .omx-process .omx-step span,
.is-style-oseka-dark .omx-process .omx-step span {
	color: #ff6a82;
}

.omx-hero .omx-process .omx-step strong,
.is-style-oseka-dark .omx-process .omx-step strong {
	color: var(--color-pure-white);
}

.omx-hero .omx-process .omx-step p,
.is-style-oseka-dark .omx-process .omx-step p {
	color: rgba(244, 244, 244, 0.78);
}

.omx-panel-top,
.omx-brief-card li {
	border-color: rgba(244, 244, 244, 0.14);
}

.omx-service-visual,
.oseka-generated-visual {
	border-radius: var(--radius-brand);
	box-shadow: 0 22px 68px rgba(7, 8, 11, 0.18);
	display: block;
	overflow: hidden;
}

.omx-image-led {
	align-items: center;
	display: grid;
	gap: clamp(1.25rem, 3vw, 2.8rem);
	grid-template-columns: minmax(0, 0.9fr) minmax(280px, 1.1fr);
}

.omx-image-led-reverse {
	grid-template-columns: minmax(280px, 1.1fr) minmax(0, 0.9fr);
}

.omx-image-led-reverse .omx-visual-copy {
	order: 2;
}

.omx-generated-frame {
	background:
		linear-gradient(135deg, rgba(7, 8, 11, 0.96), rgba(26, 29, 36, 0.92)),
		var(--omx-ink);
	border: 1px solid rgba(7, 8, 11, 0.08);
	border-radius: var(--omx-radius);
	box-shadow: 0 28px 80px rgba(7, 8, 11, 0.18);
	margin: 0;
	overflow: hidden;
}

.omx-generated-frame img,
.omx-hero-art img {
	display: block;
	height: auto;
	width: 100%;
}

.omx-hero-art {
	border: 1px solid rgba(244, 244, 244, 0.14);
	border-radius: var(--omx-radius);
	margin-top: 1.25rem;
	overflow: hidden;
}

.omx-visual-copy {
	display: grid;
	gap: 1rem;
}

.omx-visual-copy p {
	color: #3f4652;
	font-size: 1.04rem;
}

.omx-visual-strip {
	margin-top: clamp(1.25rem, 3vw, 2.5rem);
}

.omx-service-page.omx-layout-seo .omx-image-led,
.omx-service-page.omx-layout-wordpress .omx-image-led {
	grid-template-columns: minmax(320px, 1.1fr) minmax(0, 0.9fr);
}

.omx-service-page.omx-layout-local-seo .omx-brief-card,
.omx-service-page.omx-layout-commerce .omx-brief-card {
	background:
		linear-gradient(135deg, rgba(215, 38, 79, 0.18), rgba(26, 29, 36, 0.94)),
		var(--color-charcoal);
}

.omx-service-page.omx-layout-redesign .omx-section:nth-of-type(2),
.omx-service-page.omx-layout-care .omx-section:nth-of-type(2) {
	background: var(--color-core-black);
	color: var(--color-pure-white);
}

.omx-service-page.omx-layout-redesign .omx-section:nth-of-type(2) h2,
.omx-service-page.omx-layout-redesign .omx-section:nth-of-type(2) p,
.omx-service-page.omx-layout-care .omx-section:nth-of-type(2) h2,
.omx-service-page.omx-layout-care .omx-section:nth-of-type(2) p {
	color: var(--color-pure-white);
}

.omx-service-page.omx-layout-redesign .omx-section:nth-of-type(2) .omx-copy p,
.omx-service-page.omx-layout-care .omx-section:nth-of-type(2) .omx-copy p {
	color: rgba(244, 244, 244, 0.76);
}

.omx-service-page.omx-layout-tourism .omx-generated-frame,
.omx-service-page.omx-layout-commerce .omx-generated-frame {
	box-shadow: 0 34px 96px rgba(215, 38, 79, 0.16), 0 22px 68px rgba(7, 8, 11, 0.18);
}

.omx-service-page.omx-layout-web .omx-card-grid-3,
.omx-service-page.omx-layout-wordpress .omx-card-grid-3 {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.oseka-image-led {
	align-items: center;
	display: grid;
	gap: clamp(2rem, 4vw, 4rem);
	grid-template-columns: minmax(0, 0.92fr) minmax(420px, 1.08fr);
}

.oseka-image-led > figure,
.oseka-image-led > .wp-block-image {
	margin: 0;
}

.is-style-oseka-card,
.oseka-card,
.oseka-service-card,
.oseka-step {
	border-radius: var(--radius-brand);
}

.is-style-oseka-dark {
	background:
		radial-gradient(circle at 82% 18%, rgba(215, 38, 79, 0.18), transparent 32%),
		linear-gradient(135deg, var(--color-core-black), var(--color-charcoal));
	color: var(--color-pure-white);
}

.is-style-oseka-dark h1,
.is-style-oseka-dark h2,
.is-style-oseka-dark h3 {
	color: var(--color-pure-white);
}

.is-style-oseka-dark p {
	color: rgba(244, 244, 244, 0.74);
}

.wp-block-button.is-style-oseka-secondary .wp-block-button__link {
	background: transparent;
	border: 1px solid currentColor;
	color: currentColor;
}

.oseka-red-cut {
	clip-path: polygon(18% 0, 100% 0, 82% 100%, 0 100%);
	display: inline-block;
}

:focus-visible {
	outline: 3px solid var(--color-signal-red);
	outline-offset: 3px;
}

@media (max-width: 900px) {
	.omx-image-led,
	.oseka-image-led {
		grid-template-columns: 1fr;
	}

	.omx-image-led-reverse .omx-visual-copy {
		order: 0;
	}
}

/* Mobile layout fixes 3.0.6 */
body {
	overflow-x: clip;
}

.omx-page,
.omx-wrap,
.omx-hero,
.omx-section,
.omx-final {
	max-width: 100%;
}

.omx-page h1,
.omx-page h2,
.omx-page h3,
.oseka-article-hero .wp-block-post-title {
	overflow-wrap: break-word;
	word-wrap: break-word;
	hyphens: manual;
}

.omx-page p,
.omx-page li,
.omx-page a {
	overflow-wrap: break-word;
	word-wrap: break-word;
}

@media (max-width: 780px) {
	.omx-page h1,
	.omx-page h2,
	.omx-page h3 {
		text-wrap: pretty;
	}

	.omx-hero {
		padding-block: clamp(2.4rem, 8vw, 3.6rem);
	}

	.omx-hero::after,
	.oseka-hero::after {
		height: clamp(120px, 36vw, 200px);
		opacity: 0.55;
		right: -40px;
		width: clamp(80px, 28vw, 140px);
	}

	.omx-final-box {
		grid-template-columns: 1fr;
		padding: 1.25rem;
		text-align: left;
	}

	.omx-final-box h2 {
		font-size: clamp(1.6rem, 6vw, 2.2rem);
	}

	.omx-proof-row {
		gap: 0.5rem;
		grid-template-columns: repeat(3, minmax(0, 1fr));
		margin-top: 2rem;
	}

	.omx-stat {
		padding: 0.75rem;
	}

	.omx-stat strong {
		font-size: 1.3rem;
	}

	.omx-stat span {
		font-size: 0.74rem;
	}

	.omx-section-head,
	.omx-copy {
		max-width: 100%;
	}

	.omx-panel-top {
		flex-wrap: wrap;
		gap: 0.5rem;
	}

	.oseka-article-hero {
		padding-block: clamp(2.6rem, 9vw, 4rem);
	}

	.oseka-article-hero .wp-block-post-title {
		font-size: clamp(1.85rem, 7.2vw, 2.6rem);
	}

	.oseka-nav-shell .wp-block-navigation {
		max-width: 100%;
	}

	.omx-faq summary {
		font-size: 0.98rem;
	}
}

@media (max-width: 600px) {
	.omx-wrap {
		padding-inline: 16px;
	}

	.omx-page h1 {
		font-size: clamp(1.95rem, 8.4vw, 2.4rem);
		line-height: 1.1;
	}

	.omx-page h2 {
		font-size: clamp(1.55rem, 6.8vw, 2rem);
		line-height: 1.12;
	}

	.omx-page h3 {
		font-size: 1.08rem;
	}

	.omx-page p {
		font-size: 0.98rem;
	}

	.omx-lead {
		font-size: 1.04rem !important;
		line-height: 1.62 !important;
	}

	.omx-hero-panel,
	.omx-brief-card,
	.omx-contact-card,
	.omx-form,
	.omx-list-panel,
	.omx-process,
	.omx-card {
		padding: 1rem;
	}

	.omx-final-box {
		padding: 1.1rem;
	}

	.omx-proof-row {
		grid-template-columns: 1fr;
	}

	.omx-stat {
		display: flex;
		align-items: baseline;
		gap: 0.6rem;
		padding: 0.7rem 0.85rem;
	}

	.omx-stat strong {
		font-size: 1.25rem;
	}

	.omx-stat span {
		margin-top: 0;
	}

	.omx-brief-card li {
		flex-direction: column;
		gap: 0.25rem;
	}

	.omx-brief-card li b {
		min-width: 0;
	}

	.omx-eyebrow,
	.oseka-kicker {
		font-size: 0.72rem;
	}

	.omx-actions {
		gap: 0.6rem;
		margin-top: 1.4rem;
	}

	.omx-btn,
	.wp-block-button.omx-btn .wp-block-button__link {
		font-size: 0.95rem;
		min-height: 46px;
		padding: 0.78rem 1rem;
	}

	.omx-form input,
	.omx-form select,
	.omx-form textarea {
		font-size: 16px;
		padding: 0.78rem 0.85rem;
	}

	.omx-contact-methods strong {
		font-size: 1rem;
		word-break: break-word;
	}

	.oseka-portfolio-card__body h3,
	.omx-project-body h3 {
		font-size: 1.08rem;
	}
}

@media (max-width: 420px) {
	.omx-wrap {
		padding-inline: 14px;
	}

	.omx-page h1 {
		font-size: 1.85rem;
	}

	.omx-page h2 {
		font-size: 1.5rem;
	}

	.omx-hero::after,
	.oseka-hero::after {
		opacity: 0.4;
	}
}

/* ---------------------------------------------------------
   3.0.7 — Premium upgrade modules
   --------------------------------------------------------- */

/* Typography refinement — Inter stylistic alternates */
body {
	font-feature-settings: "ss01", "cv11";
	font-optical-sizing: auto;
}

.omx-page h1,
.omx-page h2,
.omx-page h3,
.oseka-article-hero .wp-block-post-title,
.wp-block-site-title a,
.oseka-brand {
	font-feature-settings: "ss01", "cv11";
}

/* Scroll-trigger reveal */
.oseka-js [data-omx-reveal] {
	opacity: 0;
	transform: translateY(24px);
	transition: opacity 720ms cubic-bezier(0.2, 0.7, 0.2, 1), transform 720ms cubic-bezier(0.2, 0.7, 0.2, 1);
	will-change: opacity, transform;
}

.oseka-js [data-omx-reveal].is-revealed {
	opacity: 1;
	transform: none;
}

@media (prefers-reduced-motion: reduce) {
	.oseka-js [data-omx-reveal] {
		opacity: 1;
		transform: none;
		transition: none;
	}
}

/* Micro-interactions — magnetic CTA + subtle red glow on primary */
.omx-btn-primary,
.oseka-header-cta .wp-block-button__link {
	box-shadow: 0 8px 24px rgba(215, 38, 79, 0);
	transition: background 220ms ease, box-shadow 280ms ease, transform 220ms ease;
}

.omx-btn-primary:hover,
.oseka-header-cta .wp-block-button__link:hover {
	box-shadow: 0 14px 36px rgba(215, 38, 79, 0.35);
}

.omx-card,
.omx-project-card,
.omx-hub-card {
	transition: border-color 220ms ease, transform 280ms ease, box-shadow 280ms ease, background-color 280ms ease;
}

.omx-card:hover {
	background-color: #fffafb;
}

.omx-faq details {
	transition: border-color 220ms ease, box-shadow 220ms ease;
}

.omx-faq details[open] {
	border-color: rgba(215, 38, 79, 0.4);
	box-shadow: 0 12px 36px rgba(7, 8, 11, 0.08);
}

/* TOC removed in 3.0.9 per design feedback. Element hidden if cached. */
.omx-toc { display: none !important; }

/* Performance badge */
.omx-perf-badge {
	background: linear-gradient(135deg, #fff, #fff7f8);
	border: 1px solid var(--omx-line);
	border-radius: var(--omx-radius);
	box-shadow: 0 12px 36px rgba(7, 8, 11, 0.08);
	display: grid;
	gap: 0;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	margin-top: clamp(1.5rem, 3vw, 2.5rem);
	overflow: hidden;
}

.omx-perf-badge__cell {
	border-right: 1px solid var(--omx-line);
	padding: 1rem 1.1rem;
	text-align: center;
}

.omx-perf-badge__cell:last-child {
	border-right: 0;
}

.omx-perf-badge__cell strong {
	color: var(--omx-red);
	display: block;
	font-family: var(--font-display), var(--omx-font);
	font-size: clamp(1.4rem, 2.4vw, 1.85rem);
	font-weight: 900;
	line-height: 1;
}

.omx-perf-badge__cell span {
	color: var(--omx-muted);
	display: block;
	font-size: 0.78rem;
	font-weight: 750;
	letter-spacing: 0.04em;
	margin-top: 0.45rem;
	text-transform: uppercase;
}

@media (max-width: 720px) {
	.omx-perf-badge {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
	.omx-perf-badge__cell:nth-child(2) {
		border-right: 0;
	}
	.omx-perf-badge__cell:nth-child(1),
	.omx-perf-badge__cell:nth-child(2) {
		border-bottom: 1px solid var(--omx-line);
	}
}

/* Reviews carousel */
.omx-reviews-section {
	overflow: hidden;
}

.omx-rating-summary {
	align-items: center;
	display: flex;
	gap: 1rem;
	margin-top: 1rem;
}

.omx-stars {
	color: #f5b425;
	font-size: 1.4rem;
	letter-spacing: 0.08em;
	line-height: 1;
}

.omx-rating-text {
	color: var(--omx-ink);
	font-weight: 750;
	margin: 0;
}

.omx-rating-text strong {
	color: var(--omx-ink);
	font-weight: 900;
}

.omx-reviews-carousel {
	margin-top: clamp(1.5rem, 3vw, 2rem);
	position: relative;
}

.omx-reviews-track {
	display: grid;
	gap: 1rem;
	grid-auto-columns: minmax(280px, 1fr);
	grid-auto-flow: column;
	overflow-x: auto;
	padding-block: 0.5rem;
	padding-inline: 0.25rem;
	scroll-behavior: smooth;
	scroll-padding: 1rem;
	scroll-snap-type: x mandatory;
	scrollbar-width: none;
}

.omx-reviews-track::-webkit-scrollbar {
	display: none;
}

@media (min-width: 720px) {
	.omx-reviews-track {
		grid-auto-columns: minmax(360px, 1fr);
	}
}

@media (min-width: 1100px) {
	.omx-reviews-track {
		grid-auto-columns: minmax(0, calc((100% - 2rem) / 3));
	}
}

.omx-review-card {
	background: #fff;
	border: 1px solid var(--omx-line);
	border-radius: var(--omx-radius);
	box-shadow: 0 14px 42px rgba(7, 8, 11, 0.08);
	display: flex;
	flex-direction: column;
	gap: 1rem;
	padding: 1.5rem;
	scroll-snap-align: start;
}

.omx-review-stars {
	color: #f5b425;
	font-size: 1.05rem;
	letter-spacing: 0.06em;
	line-height: 1;
}

.omx-review-text {
	color: var(--omx-ink);
	font-size: 1rem;
	line-height: 1.65;
	margin: 0;
}

.omx-review-meta {
	border-top: 1px solid var(--omx-line);
	display: grid;
	gap: 0.2rem;
	margin-top: auto;
	padding-top: 1rem;
}

.omx-review-meta strong {
	color: var(--omx-ink);
	font-weight: 900;
}

.omx-review-meta span {
	color: var(--omx-muted);
	font-size: 0.9rem;
}

.omx-review-meta small {
	color: var(--omx-red);
	font-size: 0.78rem;
	font-weight: 850;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.omx-reviews-controls {
	display: flex;
	gap: 0.6rem;
	justify-content: flex-end;
	margin-top: 1rem;
}

.omx-reviews-controls button {
	background: #fff;
	border: 1px solid var(--omx-line);
	border-radius: 999px;
	color: var(--omx-ink);
	cursor: pointer;
	font-size: 1rem;
	height: 44px;
	transition: background 180ms ease, border-color 180ms ease, color 180ms ease;
	width: 44px;
}

.omx-reviews-controls button:hover {
	background: var(--omx-red);
	border-color: var(--omx-red);
	color: #fff;
}

/* Comparison table */
.omx-comparison-table-wrap {
	-webkit-overflow-scrolling: touch;
	background: #fff;
	border: 1px solid var(--omx-line);
	border-radius: var(--omx-radius);
	box-shadow: 0 14px 42px rgba(7, 8, 11, 0.08);
	margin-top: clamp(1.5rem, 3vw, 2rem);
	overflow-x: auto;
}

.omx-comparison-table {
	border-collapse: separate;
	border-spacing: 0;
	min-width: 720px;
	width: 100%;
}

.omx-comparison-table thead th {
	background: var(--omx-ink);
	color: #fff;
	font-size: 0.84rem;
	font-weight: 900;
	letter-spacing: 0.04em;
	padding: 0.95rem 1rem;
	text-align: left;
	text-transform: uppercase;
}

.omx-comparison-table thead th:last-child {
	background: linear-gradient(135deg, var(--omx-red), var(--omx-red-dark));
	color: #fff;
}

.omx-comparison-table tbody th,
.omx-comparison-table tbody td {
	border-bottom: 1px solid var(--omx-line);
	font-size: 0.95rem;
	padding: 0.9rem 1rem;
	vertical-align: top;
}

.omx-comparison-table tbody th {
	color: var(--omx-ink);
	font-weight: 850;
	text-align: left;
}

.omx-comparison-table tbody tr:last-child th,
.omx-comparison-table tbody tr:last-child td {
	border-bottom: 0;
}

.omx-cmp-neg {
	color: #8a3a3a;
}

.omx-cmp-warn {
	color: #8a6a26;
}

.omx-cmp-pos {
	background: rgba(215, 38, 79, 0.06);
	color: var(--omx-ink);
	font-weight: 750;
}

.omx-cmp-pos::before {
	color: var(--omx-red);
	content: "\2713  ";
	font-weight: 900;
}

/* Local trust block */
.omx-local-trust-section {
	background: linear-gradient(180deg, #fff, var(--omx-mist-gray, #eceef1));
}

.omx-local-trust-grid {
	align-items: center;
	display: grid;
	gap: clamp(1.5rem, 4vw, 3rem);
	grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
}

@media (max-width: 900px) {
	.omx-local-trust-grid {
		grid-template-columns: 1fr;
	}
}

.omx-founder-card {
	align-items: center;
	background: #fff;
	border: 1px solid var(--omx-line);
	border-radius: var(--omx-radius);
	box-shadow: 0 14px 42px rgba(7, 8, 11, 0.08);
	display: flex;
	gap: 1rem;
	margin: 1.5rem 0;
	padding: 1rem 1.2rem;
}

.omx-founder-photo {
	border-radius: 50%;
	flex-shrink: 0;
	height: 84px;
	object-fit: cover;
	width: 84px;
}

.omx-founder-meta strong {
	color: var(--omx-ink);
	display: block;
	font-size: 1.08rem;
	font-weight: 900;
}

.omx-founder-meta span {
	color: var(--omx-muted);
	display: block;
	font-size: 0.92rem;
	margin-top: 0.15rem;
}

.omx-founder-meta small {
	color: var(--omx-red);
	display: block;
	font-size: 0.78rem;
	font-weight: 850;
	letter-spacing: 0.04em;
	margin-top: 0.3rem;
	text-transform: uppercase;
}

.omx-local-trust-map {
	align-items: center;
	background:
		radial-gradient(circle at 30% 30%, rgba(215, 38, 79, 0.18), transparent 40%),
		linear-gradient(135deg, #1a1d24, #07080b);
	border-radius: var(--omx-radius);
	box-shadow: 0 24px 72px rgba(7, 8, 11, 0.22);
	color: #fff;
	display: grid;
	gap: 1rem;
	min-height: 280px;
	padding: clamp(1.5rem, 3vw, 2.4rem);
	place-content: center;
	text-align: center;
	text-decoration: none;
	transition: transform 260ms ease, box-shadow 260ms ease;
}

.omx-local-trust-map:hover {
	box-shadow: 0 28px 84px rgba(215, 38, 79, 0.28);
	transform: translateY(-4px);
}

.omx-map-pin {
	color: var(--omx-red);
	font-size: 2.4rem;
	line-height: 1;
}

.omx-map-meta strong {
	color: #fff;
	display: block;
	font-family: var(--font-display), var(--omx-font);
	font-size: clamp(1.2rem, 2vw, 1.5rem);
	font-weight: 900;
	margin-top: 0.25rem;
}

.omx-map-meta span {
	color: rgba(255, 255, 255, 0.78);
	display: block;
	font-size: 0.95rem;
	margin-top: 0.4rem;
}

.omx-map-meta small {
	color: var(--omx-red);
	display: block;
	font-size: 0.82rem;
	font-weight: 900;
	letter-spacing: 0.04em;
	margin-top: 0.8rem;
	text-transform: uppercase;
}

.omx-map-meta .omx-eyebrow {
	color: var(--omx-red);
}

@media (max-width: 600px) {
	.omx-toc {
		display: none;
	}
	.omx-perf-badge__cell strong {
		font-size: 1.25rem;
	}
	.omx-founder-card {
		flex-direction: column;
		text-align: center;
	}
}

/* ---------------------------------------------------------
   3.0.9 layout safety — clean overflow + grid collapse
   --------------------------------------------------------- */

*,
*::before,
*::after {
	box-sizing: border-box;
}

html,
body {
	overflow-x: hidden;
}

body {
	overflow-x: clip;
}

.omx-page {
	box-sizing: border-box;
	max-width: 100%;
	overflow-x: clip;
	width: 100%;
}

.omx-wrap {
	box-sizing: border-box;
	max-width: min(var(--omx-wrap), 100%);
	width: 100%;
}

.omx-page img,
.omx-page svg,
.omx-page video,
.omx-page iframe {
	max-width: 100%;
}

/* Two-panel layout collapse earlier to avoid 360px min-col overflow */
@media (max-width: 960px) {
	.omx-hero-grid,
	.omx-service-hero,
	.omx-split,
	.omx-two-panel,
	.omx-contact-grid,
	.omx-final-box,
	.omx-local-trust-grid,
	.omx-image-led,
	.omx-image-led-reverse,
	.oseka-image-led {
		grid-template-columns: 1fr !important;
	}
}

/* Reviews carousel — proper snap + viewport-safe sizing */
.omx-reviews-section {
	overflow: hidden;
	position: relative;
}

.omx-reviews-carousel {
	margin-inline: 0;
	max-width: 100%;
	overflow: hidden;
	position: relative;
}

.omx-reviews-track {
	-webkit-overflow-scrolling: touch;
	scroll-padding-inline-start: 0;
}

.omx-review-card {
	min-width: 0;
}

@media (max-width: 720px) {
	.omx-reviews-track {
		grid-auto-columns: 86%;
		gap: 0.75rem;
		padding-inline: 0;
	}
	.omx-review-card {
		padding: 1.25rem;
	}
	.omx-review-text {
		font-size: 0.96rem;
	}
}

/* Reviews fade hint on right edge to suggest swipe (desktop+tablet) */
@media (min-width: 721px) {
	.omx-reviews-carousel::after {
		background: linear-gradient(90deg, rgba(244, 244, 244, 0), var(--omx-soft));
		content: "";
		height: calc(100% - 60px);
		pointer-events: none;
		position: absolute;
		right: 0;
		top: 0;
		width: 60px;
		z-index: 1;
	}
}

/* Comparison table — stacked card layout on mobile, scrollable table on desktop */
.omx-comparison-table-wrap {
	overflow: visible;
}

@media (min-width: 761px) {
	.omx-comparison-table-wrap {
		overflow-x: auto;
	}
	.omx-comparison-table {
		min-width: 720px;
	}
}

@media (max-width: 760px) {
	.omx-comparison-table-wrap {
		background: transparent;
		border: 0;
		box-shadow: none;
		overflow: visible;
	}
	.omx-comparison-table {
		display: block;
		min-width: 0;
		width: 100%;
	}
	.omx-comparison-table thead {
		display: none;
	}
	.omx-comparison-table tbody {
		display: grid;
		gap: 0.85rem;
	}
	.omx-comparison-table tbody tr {
		background: #fff;
		border: 1px solid var(--omx-line);
		border-radius: var(--omx-radius);
		box-shadow: 0 12px 36px rgba(7, 8, 11, 0.06);
		display: grid;
		gap: 0;
		padding: 0.95rem 1.1rem;
	}
	.omx-comparison-table tbody th,
	.omx-comparison-table tbody td {
		border: 0;
		display: block;
		font-size: 0.92rem;
		padding: 0.5rem 0;
		position: relative;
	}
	.omx-comparison-table tbody th {
		border-bottom: 1px solid var(--omx-line);
		color: var(--omx-ink);
		font-size: 1rem;
		font-weight: 900;
		margin-bottom: 0.5rem;
		padding-bottom: 0.7rem;
	}
	.omx-comparison-table tbody td::before {
		color: var(--omx-muted);
		content: attr(data-label);
		display: block;
		font-size: 0.7rem;
		font-weight: 900;
		letter-spacing: 0.04em;
		margin-bottom: 0.2rem;
		text-transform: uppercase;
	}
	.omx-cmp-neg::before { color: #b14747; }
	.omx-cmp-warn::before { color: #b18a47; }
	.omx-cmp-pos {
		background: rgba(215, 38, 79, 0.06);
		border-radius: 6px;
		margin-top: 0.4rem;
		padding: 0.65rem 0.75rem !important;
	}
	.omx-cmp-pos::before {
		color: var(--omx-red);
		content: attr(data-label);
	}
	.omx-cmp-pos::after {
		color: var(--omx-red);
		content: " \2713";
		font-weight: 900;
	}
}

/* Local trust map — better mobile sizing */
@media (max-width: 600px) {
	.omx-local-trust-map {
		min-height: 200px;
		padding: 1.5rem;
	}
	.omx-map-pin {
		font-size: 1.8rem;
	}
}

/* Final box mobile alignment fix */
@media (max-width: 960px) {
	.omx-final-box {
		text-align: left;
	}
	.omx-final-box .omx-actions {
		align-items: stretch;
		flex-direction: column;
	}
}

/* TOC overflow safety — wrap long item lists on tablet */
.omx-toc-list {
	max-width: 100%;
	overflow: hidden;
}

/* Section dividers tighter on mobile to reduce scroll fatigue */
@media (max-width: 600px) {
	.omx-section,
	.omx-final {
		padding-block: clamp(2.4rem, 6vw, 3.6rem);
	}
	.omx-perf-badge {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		margin-top: 1.4rem;
	}
	.omx-perf-badge__cell:nth-child(odd) {
		border-right: 1px solid var(--omx-line);
	}
	.omx-perf-badge__cell:nth-child(2) {
		border-right: 0;
	}
	.omx-perf-badge__cell:nth-child(1),
	.omx-perf-badge__cell:nth-child(2) {
		border-bottom: 1px solid var(--omx-line);
	}
}
