/* =============================================================================
   Pure-OX Theme — assets/css/main.css
   Component styles, layout modules, and page-specific patterns.
   Design tokens are defined in style.css :root block.
   ============================================================================= */

/* =============================================================================
   GLOBAL TYPOGRAPHY
   ============================================================================= */

h1, h2, h3, h4, h5, h6 { color: var(--color-heading); }

/* =============================================================================
   SITE HEADER
   ============================================================================= */

.site-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	height: var(--header-height);
	z-index: var(--z-sticky);
	background: var(--color-white);
	border-bottom: 1px solid var(--color-border);
	transition: box-shadow var(--transition-base);
	contain: layout style;
}

/* Scrolled state — JS adds .is-scrolled / .scrolled when page scrolls > 80px */
.site-header.is-scrolled,
.site-header.scrolled {
	background: var(--color-white);
	box-shadow: 0 4px 24px rgba(10, 31, 67, 0.08);
}

.site-header.scrolled .site-header__inner {
	height: 68px;
}

/* ── Inner layout ───────────────────────────────────────────── */
.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 100%;
	gap: 40px;
}

/* ── Brand / Logo ──────────────────────────────────────────── */
.site-header__brand { flex-shrink: 0; }

/* Uploaded custom logo */
.site-header__logo a      { display: block; }
.site-header__logo img    { height: 44px; width: auto; display: block; }

/* Text logo */
.site-header__brand-link {
	display: flex;
	align-items: center;
	gap: 10px;
	text-decoration: none;
}

/* Gem SVG mark */
.site-header__gem {
	display: flex;
	align-items: center;
	flex-shrink: 0;
}

/* Brand wordmark */
.site-header__wordmark {
	font-size: 22px;
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	letter-spacing: -0.04em;
	line-height: 1;
}

.site-header__wordmark-dash {
	color: var(--color-red);
}

/* ── Primary Navigation (desktop) ─────────────────────────── */
.site-header__nav {
	flex: 1;
	display: flex;
	justify-content: center;
}

.nav-menu {
	display: flex;
	align-items: center;
	list-style: none;
	padding: 0;
	margin: 0;
	gap: 2px;
}

.nav-menu > li { position: relative; }

.nav-link {
	display: flex;
	align-items: center;
	gap: 5px;
	padding: 8px 16px;
	font-size: 17px;
	font-weight: var(--font-weight-semibold);
	color: var(--color-nav-text, #111318);
	text-decoration: none;
	border-radius: var(--radius-sm);
	transition: color 0.2s ease, background-color 0.2s ease;
	white-space: nowrap;
	position: relative;
}

/* Top-level items get an underline slide-in indicator */
.nav-menu > li > .nav-link::after {
	content: '';
	position: absolute;
	bottom: 3px;
	left: 14px;
	right: 14px;
	height: 2px;
	background: var(--color-red);
	border-radius: 1px;
	transform: scaleX(0);
	transform-origin: center;
	transition: transform var(--transition-fast);
}

.nav-menu > li > .nav-link:hover::after,
.nav-menu > .current-menu-item > .nav-link::after,
.nav-menu > .current-menu-ancestor > .nav-link::after {
	transform: scaleX(1);
}

.nav-link:hover,
.nav-link:focus-visible {
	color: var(--color-accent);
	background-color: rgba(0, 180, 216, 0.06);
	text-decoration: none;
}

.current-menu-item > .nav-link,
.current-menu-ancestor > .nav-link {
	color: var(--color-red);
}

/* Chevron for parent items */
.nav-link__chevron {
	display: flex;
	align-items: center;
	transition: transform var(--transition-fast);
	color: var(--color-text-light);
}

.has-children:hover > .nav-link .nav-link__chevron,
.has-children:focus-within > .nav-link .nav-link__chevron {
	transform: rotate(180deg);
	color: var(--color-accent);
}

/* ── Sub-menus ─────────────────────────────────────────────── */
.sub-menu {
	position: absolute;
	top: 100%;           /* flush with parent — no physical gap */
	left: 0;
	min-width: 220px;
	background: var(--color-white);
	border-radius: var(--radius-md);
	box-shadow: 0 8px 32px rgba(10, 31, 67, 0.12);
	border: 1px solid var(--color-border);
	list-style: none;
	padding: 6px;
	padding-top: 12px;   /* visual breathing room above first item */
	margin: 0;
	opacity: 0;
	visibility: hidden;
	transform: translateY(-4px);
	transition: opacity var(--transition-base),
	            visibility var(--transition-base),
	            transform var(--transition-base);
	z-index: var(--z-dropdown);
	pointer-events: none;
}

.has-children:hover > .sub-menu,
.has-children:focus-within > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
	pointer-events: auto;
}

.sub-menu .nav-link {
	color: var(--color-text);
	padding: 9px 14px;
	font-size: var(--fs-sm);
	border-radius: var(--radius-xs);
	font-weight: var(--font-weight-medium);
}

.sub-menu .nav-link:hover,
.sub-menu .current-menu-item > .nav-link {
	color: var(--color-red);
	background-color: rgba(220, 43, 28, 0.06);
}

/* ── Header Actions ────────────────────────────────────────── */
.site-header__actions {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-shrink: 0;
}

/* Search toggle */
.site-header__search-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	border: none;
	background: transparent;
	color: var(--color-text-muted);
	border-radius: var(--radius-sm);
	cursor: pointer;
	transition: color 0.2s ease, background-color 0.2s ease;
}

.site-header__search-btn:hover {
	color: var(--color-primary);
	background-color: var(--color-bg-light);
}

/* CTA button */
.site-header__cta {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 10px 20px;
	background-color: var(--color-red);
	color: var(--color-white);
	font-family: var(--font-primary);
	font-size: var(--fs-sm);
	font-weight: var(--font-weight-bold);
	letter-spacing: 0.02em;
	text-decoration: none;
	border-radius: var(--radius-pill);
	transition: background-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
	white-space: nowrap;
}

.site-header__cta:hover,
.site-header__cta:focus-visible {
	background-color: var(--color-red-dark);
	box-shadow: 0 8px 24px rgba(220, 43, 28, 0.35);
	color: var(--color-white);
	text-decoration: none;
	transform: translateY(-1px);
}

/* Material Symbol arrow inside CTA */
.site-header__cta-icon {
	font-size: 18px;
	font-variation-settings: 'FILL' 0, 'wght' 600;
	line-height: 1;
	transition: transform 0.2s ease;
}

.site-header__cta:hover .site-header__cta-icon {
	transform: translateX(3px);
}

/* ── Hamburger — hidden on desktop (≥1024px) ───────────────── */
.site-header__hamburger {
	display: none;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 5px;
	width: 44px;
	height: 44px;
	padding: 10px;
	border: 1.5px solid var(--color-border-medium);
	background: transparent;
	border-radius: var(--radius-sm);
	cursor: pointer;
	transition: border-color 0.2s ease, background-color 0.2s ease;
}

.site-header__hamburger:hover {
	border-color: var(--color-primary);
	background-color: var(--color-bg-light);
}

.hamburger-bar {
	display: block;
	width: 18px;
	height: 2px;
	background: var(--color-primary);
	border-radius: 2px;
	transition: transform var(--transition-base), opacity var(--transition-base), width var(--transition-base);
}

/* Hamburger morphs into × when .is-active is set by JS on the button */
.site-header__hamburger.is-active .hamburger-bar:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}
.site-header__hamburger.is-active .hamburger-bar:nth-child(2) {
	opacity: 0;
	transform: scaleX(0);
}
.site-header__hamburger.is-active .hamburger-bar:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

/* ── Inline Search Panel ───────────────────────────────────── */
.site-header__search-panel {
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	background: var(--color-white);
	border-top: 1px solid var(--color-border);
	border-bottom: 1px solid var(--color-border);
	box-shadow: 0 8px 24px rgba(10, 31, 67, 0.08);
	padding: 16px 0;
	z-index: var(--z-dropdown);
}

.site-header__search-form {
	display: flex;
	gap: 10px;
}

.site-header__search-input {
	flex: 1;
	padding: 11px 16px;
	font-family: var(--font-primary);
	font-size: var(--fs-body);
	color: var(--color-text);
	background: var(--color-bg-light);
	border: 1.5px solid var(--color-border-medium);
	border-radius: var(--radius-sm);
	outline: none;
	transition: border-color 0.2s ease;
}

.site-header__search-input:focus {
	border-color: var(--color-accent);
	background: var(--color-white);
}

.site-header__search-submit {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 11px 18px;
	background: var(--color-primary);
	color: var(--color-white);
	border: none;
	border-radius: var(--radius-sm);
	cursor: pointer;
	transition: background-color 0.2s ease;
}

.site-header__search-submit:hover { background: rgba(10, 31, 67, 0.88); }

/* Header is always white — no transparent-over-hero effect */

/* ── Mobile Drawer ─────────────────────────────────────────── */
.mobile-drawer {
	position: fixed;
	top: 0;
	right: 0;
	width: min(360px, 100vw);
	height: 100dvh;
	background: var(--color-white);
	z-index: calc(var(--z-sticky) + 10);
	display: flex;
	flex-direction: column;
	transform: translateX(100%);
	transition: transform var(--transition-base);
	box-shadow: -8px 0 48px rgba(10, 31, 67, 0.14);
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	/* Hidden from AT when closed */
	visibility: hidden;
}

.mobile-drawer.is-open {
	transform: translateX(0);
	visibility: visible;
}

/* Drawer header bar */
.mobile-drawer__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0 20px;
	height: var(--header-height);
	border-bottom: 1px solid var(--color-border);
	flex-shrink: 0;
}

/* Drawer logo */
.mobile-drawer__logo { text-decoration: none; }

.mobile-drawer__logo img { height: 36px; width: auto; }

.mobile-drawer__wordmark {
	font-size: 20px;
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	letter-spacing: -0.04em;
}

.mobile-drawer__wordmark span { color: var(--color-red); }

/* Close × button */
.mobile-drawer__close {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border: 1.5px solid var(--color-border-medium);
	background: transparent;
	border-radius: var(--radius-sm);
	color: var(--color-primary);
	cursor: pointer;
	transition: background-color 0.2s ease, border-color 0.2s ease;
}

.mobile-drawer__close:hover {
	background: var(--color-bg-light);
	border-color: var(--color-primary);
}

/* Drawer nav */
.mobile-drawer__nav { flex: 1; padding: 8px 12px; }

.mobile-nav-menu {
	list-style: none;
	padding: 0;
	margin: 0;
}

.mobile-nav-menu li { border-bottom: 1px solid var(--color-border); }
.mobile-nav-menu li:last-child { border-bottom: none; }

.mobile-nav-menu .nav-link {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 14px 12px;
	font-size: var(--fs-body);
	font-weight: var(--font-weight-semibold);
	color: var(--color-primary);
	border-radius: var(--radius-xs);
	width: 100%;
}

.mobile-nav-menu .current-menu-item > .nav-link {
	color: var(--color-red);
	background-color: rgba(220, 43, 28, 0.06);
}

.mobile-nav-menu .nav-link:hover {
	color: var(--color-accent);
	background-color: rgba(0, 180, 216, 0.06);
}

/* Drawer sub-menus */
.mobile-nav-menu .sub-menu {
	position: static;
	opacity: 1;
	visibility: visible;
	transform: none;
	box-shadow: none;
	border: none;
	background: var(--color-bg-light);
	border-radius: var(--radius-sm);
	margin: 4px 0 8px;
	display: none;
	padding: 4px 0;
	pointer-events: auto;
}

.mobile-nav-menu .has-children.is-open > .sub-menu { display: block; }

.mobile-nav-menu .sub-menu .nav-link {
	padding: 10px 20px;
	font-size: var(--fs-sm);
	font-weight: var(--font-weight-medium);
	color: var(--color-text-muted);
}

/* Drawer footer */
.mobile-drawer__footer {
	padding: 20px;
	border-top: 1px solid var(--color-border);
	display: flex;
	flex-direction: column;
	gap: 12px;
	flex-shrink: 0;
}

.mobile-drawer__cta {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	padding: 13px 20px;
	font-size: 15px;
}

.mobile-drawer__phone {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	font-size: var(--fs-sm);
	font-weight: var(--font-weight-medium);
	color: var(--color-text-muted);
	text-decoration: none;
	padding: 8px;
	border-radius: var(--radius-sm);
	transition: color 0.2s ease;
}

.mobile-drawer__phone:hover { color: var(--color-accent); text-decoration: none; }

/* ── Overlay backdrop ──────────────────────────────────────── */
.mobile-nav-overlay {
	position: fixed;
	inset: 0;
	background: rgba(10, 31, 67, 0.55);
	backdrop-filter: blur(2px);
	-webkit-backdrop-filter: blur(2px);
	z-index: calc(var(--z-sticky) + 9);
	opacity: 0;
	visibility: hidden;
	transition: opacity var(--transition-base), visibility var(--transition-base);
}

.mobile-nav-overlay.is-visible {
	opacity: 1;
	visibility: visible;
}

/* =============================================================================
   SITE CONTENT WRAPPER
   ============================================================================= */

.site-content-wrapper {
	padding-top: var(--header-height);
	min-height: calc(100vh - var(--header-height));
}

/* =============================================================================
   PAGE HERO
   ============================================================================= */

.page-hero {
	padding-block: 80px 64px;
}

.page-hero__inner {
	max-width: 800px;
}

.page-hero__title {
	font-size: var(--fs-h1);
	font-weight: var(--font-weight-bold);
	line-height: var(--lh-tight);
	color: var(--color-white);
	margin-top: 16px;
	margin-bottom: 0;
}

.page-hero__subtitle {
	font-size: var(--fs-body-lg);
	color: rgba(255, 255, 255, 0.8);
	margin-top: 16px;
	margin-bottom: 0;
}

/* Archive count */
.archive-count {
	margin-top: 12px;
	font-size: var(--fs-sm);
	opacity: 0.7;
}

/* =============================================================================
   HOME HERO
   ============================================================================= */

.home-hero {
	padding-block: 100px 80px;
	min-height: 90vh;
	display: flex;
	align-items: center;
}

.home-hero__inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	align-items: center;
	gap: 64px;
}

.home-hero__badge { margin-bottom: 20px; }

.home-hero__title {
	font-size: clamp(40px, 5vw, 72px);
	font-weight: var(--font-weight-bold);
	line-height: 1.08;
	color: var(--color-white);
	margin-bottom: 24px;
}

.home-hero__subtitle {
	font-size: var(--fs-body-lg);
	color: rgba(255, 255, 255, 0.8);
	line-height: var(--lh-body);
	margin-bottom: 36px;
}

.home-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
}

/* Hero stats grid */
.home-hero__stats {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px;
}

.hero-stat {
	background: rgba(255, 255, 255, 0.07);
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: var(--radius-md);
	padding: 28px 24px;
	text-align: center;
}

.hero-stat__value {
	display: block;
	font-size: clamp(32px, 3vw, 44px);
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	line-height: 1;
	margin-bottom: 8px;
}

.hero-stat__label {
	font-size: var(--fs-sm);
	color: rgba(255, 255, 255, 0.7);
	font-weight: var(--font-weight-medium);
}

/* =============================================================================
   BREADCRUMBS
   ============================================================================= */

.breadcrumbs {
	margin-bottom: 16px;
}

.breadcrumbs__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	list-style: none;
	padding: 0;
	margin: 0;
	gap: 6px;
}

.breadcrumbs__item { display: flex; align-items: center; }

.breadcrumbs__link {
	font-size: var(--fs-xs);
	font-weight: var(--font-weight-medium);
	color: rgba(255, 255, 255, 0.78);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.breadcrumbs__link:hover { color: var(--color-red); text-decoration: none; }

.breadcrumbs__current {
	font-size: var(--fs-xs);
	color: var(--color-red);
	font-weight: var(--font-weight-medium);
}

.breadcrumbs__separator {
	font-size: var(--fs-xs);
	color: rgba(255, 255, 255, 0.35);
}

/* =============================================================================
   POSTS GRID
   ============================================================================= */

.posts-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--gap-md);
}

/* Post Card */
.post-card {
	display: flex;
	flex-direction: column;
}

.post-card__image {
	aspect-ratio: 4/3;
	overflow: hidden;
}

.post-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--transition-slow);
}

.post-card:hover .post-card__img {
	transform: scale(1.04);
}

.post-card__body {
	padding: 28px;
	display: flex;
	flex-direction: column;
	flex: 1;
}

.post-card__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	margin-bottom: 12px;
}

.post-card__date {
	font-size: var(--fs-xs);
	color: var(--color-text-light);
}

.post-card__title {
	font-size: 20px;
	font-weight: var(--font-weight-bold);
	line-height: 1.3;
	margin-bottom: 12px;
}

.post-card__title a {
	color: var(--color-primary);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.post-card__title a:hover { color: var(--color-accent); }

.post-card__excerpt {
	font-size: var(--fs-sm);
	color: var(--color-text-muted);
	line-height: 1.6;
	flex: 1;
	margin-bottom: 20px;
}

.post-card__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding-top: 16px;
	border-top: 1px solid var(--color-border);
	margin-top: auto;
}

.post-card__author {
	display: flex;
	align-items: center;
	gap: 8px;
}

.post-card__avatar {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	object-fit: cover;
}

.post-card__author-name {
	font-size: var(--fs-xs);
	font-weight: var(--font-weight-medium);
	color: var(--color-text-muted);
}

.post-card__read-more {
	font-size: var(--fs-xs);
	font-weight: var(--font-weight-bold);
	color: var(--color-red);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.post-card__read-more:hover { color: var(--color-accent-dark); }

/* =============================================================================
   POST SINGLE / ARTICLE PROSE
   ============================================================================= */

.post-hero {
	padding-block: 80px 60px;
}

.post-hero__cats {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 16px;
}

.post-hero__title {
	font-size: clamp(28px, 4vw, 52px);
	font-weight: var(--font-weight-bold);
	line-height: 1.12;
	color: var(--color-white);
	margin-bottom: 20px;
}

.post-hero__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 16px;
}

.post-meta-item {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: var(--fs-sm);
	color: rgba(255, 255, 255, 0.75);
}

.post-author__avatar {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	object-fit: cover;
}

.post-featured-image {
	margin-bottom: -40px;
	position: relative;
	z-index: 2;
}

.post-featured-image__img {
	width: 100%;
	height: 480px;
	object-fit: cover;
	border-radius: var(--radius-lg);
}

/* Prose styles for article content */
.prose {
	padding-top: 60px;
}

.prose .entry-content {
	font-size: var(--fs-body-lg);
	color: var(--color-text-muted);
	line-height: var(--lh-body);
}

.prose .entry-content h2 {
	font-size: clamp(22px, 2.5vw, 30px);
	margin-top: 2.5em;
	margin-bottom: 0.75em;
}

.prose .entry-content h3 {
	font-size: clamp(18px, 2vw, 24px);
	margin-top: 2em;
	margin-bottom: 0.6em;
}

.prose .entry-content p { margin-bottom: 1.4em; }

.prose .entry-content ul,
.prose .entry-content ol {
	margin-bottom: 1.4em;
}

/* Custom cyan dot bullet for prose unordered lists */
.prose .entry-content ul {
	list-style: none;
	padding-left: 0;
}

.prose .entry-content ul > li {
	position: relative;
	padding-left: 20px;
}

.prose .entry-content ul > li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0.62em;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--color-red);
}

.prose .entry-content ol {
	padding-left: 1.5em;
}

.prose .entry-content ol > li::marker {
	color: var(--color-red);
	font-weight: 700;
}

.prose .entry-content li { margin-bottom: 0.6em; }

.prose .entry-content img {
	border-radius: var(--radius-md);
	margin-block: 2em;
}

.prose .entry-content blockquote {
	margin-block: 2em;
}

/* Post Footer: tags + share */
.post-footer {
	margin-top: 48px;
	padding-top: 32px;
	border-top: 1px solid var(--color-border);
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 20px;
}

.post-tags { display: flex; align-items: center; flex-wrap: wrap; gap: 8px; }
.post-tags__label,
.post-share__label {
	font-size: var(--fs-sm);
	font-weight: var(--font-weight-semibold);
	color: var(--color-text-muted);
}

.post-tags__list {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	list-style: none;
	padding: 0;
	margin: 0;
}

.post-tags__list a {
	display: inline-block;
	padding: 4px 12px;
	background: var(--color-bg-light);
	border-radius: var(--radius-pill);
	font-size: var(--fs-xs);
	color: var(--color-text-muted);
	text-decoration: none;
	transition: background-color var(--transition-fast), color var(--transition-fast);
}

.post-tags__list a:hover {
	background: var(--color-red);
	color: var(--color-white);
}

.post-share { display: flex; align-items: center; gap: 12px; }
.post-share__links { display: flex; gap: 8px; }

.post-share__btn {
	display: inline-block;
	padding: 6px 16px;
	border-radius: var(--radius-pill);
	font-size: var(--fs-xs);
	font-weight: var(--font-weight-bold);
	text-decoration: none;
	transition: opacity var(--transition-fast);
}

.post-share__btn:hover { opacity: 0.85; text-decoration: none; }
.post-share__btn--linkedin { background: #0a66c2; color: var(--color-white); }
.post-share__btn--twitter  { background: #1d9bf0; color: var(--color-white); }

/* Author box */
.author-box {
	display: flex;
	align-items: flex-start;
	gap: 24px;
	padding: var(--card-p);
	margin-top: 48px;
}

.author-box__avatar {
	width: 80px;
	height: 80px;
	border-radius: 50%;
	object-fit: cover;
	flex-shrink: 0;
}

.author-box__name {
	font-size: var(--fs-h5);
	margin-bottom: 6px;
}

.author-box__name a {
	color: var(--color-primary);
	text-decoration: none;
}

.author-box__bio {
	font-size: var(--fs-sm);
	color: var(--color-text-muted);
	margin: 0;
}

/* Post navigation */
.post-navigation {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 32px;
	margin-top: 48px;
	padding-top: 32px;
	border-top: 1px solid var(--color-border);
}

.post-navigation__next { text-align: right; }

.post-navigation__label {
	display: block;
	font-size: var(--fs-xs);
	font-weight: var(--font-weight-bold);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--color-red);
	margin-bottom: 6px;
}

.post-navigation__link {
	font-size: 15px;
	font-weight: var(--font-weight-semibold);
	color: var(--color-primary);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.post-navigation__link:hover { color: var(--color-red); }

/* =============================================================================
   DIVISIONS / SERVICES CARDS
   ============================================================================= */

.divisions-grid { margin-top: 48px; }

.division-card {
	padding: var(--card-p);
	display: flex;
	flex-direction: column;
}

.division-card__icon {
	color: var(--color-red);
	margin-bottom: 20px;
	line-height: 1;
}

.division-card__title {
	font-size: 20px;
	margin-bottom: 12px;
}

.division-card__desc {
	font-size: var(--fs-sm);
	color: var(--color-text-muted);
	line-height: 1.65;
	flex: 1;
	margin-bottom: 20px;
}

.division-card__link {
	font-size: var(--fs-sm);
	font-weight: var(--font-weight-bold);
	color: var(--color-red);
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 4px;
	transition: gap var(--transition-fast), color var(--transition-fast);
}

.division-card__link:hover {
	gap: 8px;
	color: var(--color-accent-dark);
	text-decoration: none;
}

/* =============================================================================
   PROJECT CARDS
   ============================================================================= */

.projects-grid  { margin-top: 48px; }
.portfolio-grid { margin-top: 0; }

.project-card { display: flex; flex-direction: column; }

.project-card__image {
	aspect-ratio: 16/10;
	overflow: hidden;
}

.project-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--transition-slow);
}

.project-card:hover .project-card__img { transform: scale(1.04); }

.project-card__body {
	padding: 24px;
	display: flex;
	flex-direction: column;
	flex: 1;
}

.project-card__cats {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin-bottom: 12px;
}

.project-card__title {
	font-size: 18px;
	font-weight: var(--font-weight-bold);
	margin-bottom: 8px;
}

.project-card__title a {
	color: var(--color-primary);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.project-card__title a:hover { color: var(--color-accent); }

.project-card__excerpt {
	font-size: var(--fs-sm);
	color: var(--color-text-muted);
	line-height: 1.6;
	flex: 1;
	margin-bottom: 16px;
}

.project-card__cta {
	font-size: var(--fs-xs);
	font-weight: var(--font-weight-bold);
	color: var(--color-accent);
	text-decoration: none;
	margin-top: auto;
	transition: color var(--transition-fast);
}

.project-card__cta:hover { color: var(--color-accent-dark); }

/* Section CTA */
.section-cta { margin-top: 48px; }

/* =============================================================================
   TESTIMONIAL CARDS
   ============================================================================= */

.testimonials-grid { margin-top: 48px; }

.testimonial-card {
	padding: 32px;
	display: flex;
	flex-direction: column;
}

.testimonial-card__stars {
	display: flex;
	gap: 3px;
	margin-bottom: 16px;
}

.star--filled { color: #f59e0b; }
.star--empty  { color: var(--color-border-medium); }

.testimonial-card__text {
	font-size: var(--fs-body-lg);
	font-style: italic;
	color: var(--color-text);
	line-height: 1.65;
	flex: 1;
	margin-bottom: 24px;
}

.testimonial-card__footer {
	display: flex;
	align-items: center;
	gap: 14px;
	border-top: 1px solid var(--color-border);
	padding-top: 20px;
	margin-top: auto;
}

.testimonial-card .post-thumbnail,
.testimonial-card img {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	object-fit: cover;
	flex-shrink: 0;
}

.testimonial-card__author { display: flex; flex-direction: column; gap: 2px; }

.testimonial-card__name {
	font-size: 15px;
	font-weight: var(--font-weight-bold);
	color: var(--color-heading);
	font-style: normal;
}

.testimonial-card__role,
.testimonial-card__company {
	font-size: var(--fs-xs);
	color: var(--color-text-muted);
}

/* =============================================================================
   TEAM CARDS
   ============================================================================= */

.team-grid  { margin-top: 48px; }

.team-card  {
	text-align: center;
	overflow: hidden;
}

.team-card__photo {
	aspect-ratio: 1;
	overflow: hidden;
}

.team-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--transition-slow);
}

.team-card:hover .team-card__img { transform: scale(1.04); }

.team-card__body {
	padding: 24px 20px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 6px;
}

.team-card__name {
	font-size: 18px;
	margin-bottom: 0;
}

.team-card__role {
	font-size: var(--fs-sm);
	color: var(--color-text-muted);
	margin: 0;
}

.team-card__dept { margin-top: 4px; }

.team-card__linkedin {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin-top: 12px;
	font-size: var(--fs-xs);
	font-weight: var(--font-weight-semibold);
	color: #0a66c2;
	text-decoration: none;
	transition: opacity var(--transition-fast);
}

.team-card__linkedin:hover { opacity: 0.8; text-decoration: none; }

/* =============================================================================
   CTA STRIP
   ============================================================================= */

.cta-strip {
	padding-block: 64px;
}

.cta-strip__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 40px;
	flex-wrap: wrap;
}

.cta-strip__title {
	font-size: clamp(22px, 2.8vw, 32px);
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	margin-bottom: 8px;
}

.cta-strip__subtitle {
	font-size: var(--fs-body);
	color: rgba(255, 255, 255, 0.85);
	margin: 0;
}

.cta-strip__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	flex-shrink: 0;
}

/* =============================================================================
   SITE FOOTER
   ============================================================================= */

/* Restore antialiased smoothing on dark-background sections so white text
   stays crisp (grayscale AA looks better for light-on-dark) */
.site-footer,
.split-hero,
.why-section,
.cta-banner,
.industries-bar,
.pf-hero,
.about-inner-hero,
.portfolio-single-hero {
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.site-footer {
	background: var(--color-primary);
	color: rgba(255, 255, 255, 0.8);
}

.footer-main { padding-block: 80px 0; }

.footer-grid {
	display: grid;
	grid-template-columns: 1.5fr 1fr 1fr 1fr;
	gap: 48px;
	margin-bottom: 80px;
}

/* Brand Column */
.footer-col--brand {}

.footer-logo { margin-bottom: 32px; }

.footer-logo__img {
	height: 48px;
	width: auto;
	filter: brightness(0) invert(1);
}

/* Text logo (fallback when no custom logo is uploaded) */
.footer-logo__brand-link {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	text-decoration: none;
}

.footer-logo__gem {
	display: flex;
	align-items: center;
	flex-shrink: 0;
}

.footer-logo__wordmark {
	font-size: 22px;
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	letter-spacing: -0.04em;
	line-height: 1;
}

.footer-logo__wordmark-dash { color: var(--color-red); }

.footer-tagline {
	font-size: var(--fs-sm);
	color: rgba(255, 255, 255, 0.72);
	line-height: 1.7;
	margin-bottom: 24px;
}

.footer-certifications {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 24px;
}

.certification-badge {
	display: inline-block;
	font-size: 11px;
	font-weight: var(--font-weight-bold);
	letter-spacing: 0.05em;
	padding: 4px 10px;
	border: 1px solid rgba(255, 255, 255, 0.25);
	border-radius: var(--radius-pill);
	color: rgba(255, 255, 255, 0.8);
}

.footer-social {
	display: flex;
	gap: 10px;
}

.footer-social__link {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.05);
	color: var(--color-white);
	text-decoration: none;
	transition: background-color var(--transition-fast);
}

.footer-social__link .material-symbols-outlined {
	font-size: 18px;
}

.footer-social__link:hover {
	background-color: var(--color-red);
	color: var(--color-white);
	text-decoration: none;
}

/* Menu columns */
.footer-heading {
	font-size: 18px;
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	margin: 0 0 32px;
}

.footer-menu {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.footer-menu li a {
	font-size: var(--fs-sm);
	color: rgba(255, 255, 255, 0.78);
	text-decoration: none;
	transition: color var(--transition-fast);
	display: inline-block;
}

.footer-menu li a:hover {
	color: var(--color-red);
	text-decoration: none;
}

/* Address column */
.footer-address {
	font-style: normal;
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.footer-address__item {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	font-size: var(--fs-sm);
	color: rgba(255, 255, 255, 0.78);
	line-height: 1.5;
}

.footer-address__icon {
	color: var(--color-accent);
	font-size: 20px;
	flex-shrink: 0;
	margin-top: 1px;
}

.footer-address__item a {
	color: rgba(255, 255, 255, 0.78);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.footer-address__item a:hover { color: var(--color-red); }

/* Footer bottom bar */
.footer-bottom {
	border-top: 1px solid rgba(255, 255, 255, 0.05);
	padding-top: 40px;
	padding-bottom: 40px;
}

.footer-bottom__copy {
	font-size: 13px;
	color: rgba(255, 255, 255, 0.55);
	margin: 0;
	text-align: center;
}

/* =============================================================================
   SEARCH RESULTS
   ============================================================================= */

.search-results-grid {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.search-result-item {
	display: flex;
	align-items: center;
	gap: 24px;
	padding: 24px;
	background: var(--color-white);
	border-radius: var(--radius-md);
	transition: box-shadow var(--transition-base);
}

.search-result-item:hover {
	box-shadow: var(--shadow-sm);
}

.search-result-item__content { flex: 1; }

.search-result-item__type { margin-bottom: 8px; }

.search-result-item__title {
	font-size: 20px;
	font-weight: var(--font-weight-bold);
	margin-bottom: 6px;
}

.search-result-item__title a {
	color: var(--color-primary);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.search-result-item__title a:hover { color: var(--color-red); }

.search-result-item__meta {
	font-size: var(--fs-xs);
	color: var(--color-text-light);
	margin-bottom: 8px;
}

.search-result-item__excerpt p {
	font-size: var(--fs-sm);
	color: var(--color-text-muted);
	margin-bottom: 8px;
}

.search-result-item__link {
	font-size: var(--fs-xs);
	font-weight: var(--font-weight-bold);
	color: var(--color-accent);
	text-decoration: none;
}

.search-result-item__thumb {
	width: 120px;
	height: 90px;
	flex-shrink: 0;
	border-radius: var(--radius-sm);
	overflow: hidden;
}

.search-result-item__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* Search hero form */
.search-hero-form {
	display: flex;
	gap: 12px;
	margin-top: 24px;
	max-width: 600px;
}

.search-hero-form__input {
	flex: 1;
	padding: 14px 20px;
	font-family: var(--font-primary);
	font-size: var(--fs-body);
	color: var(--color-text);
	background: rgba(255, 255, 255, 0.12);
	border: 1.5px solid rgba(255, 255, 255, 0.25);
	border-radius: var(--radius-sm);
	color: var(--color-white);
	outline: none;
	transition: border-color var(--transition-fast);
}

.search-hero-form__input::placeholder { color: rgba(255, 255, 255, 0.5); }
.search-hero-form__input:focus { border-color: var(--color-accent); }

/* =============================================================================
   404 PAGE
   ============================================================================= */

.site-main--404 { min-height: 80vh; display: flex; align-items: center; }

.error-404-section { width: 100%; padding-block: 80px; }

.error-404__inner { padding: 40px 0; }

.error-404__graphic {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 16px;
	margin-bottom: 32px;
}

.error-404__number {
	font-size: clamp(80px, 12vw, 140px);
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	line-height: 1;
	opacity: 0.9;
}

.error-404__icon { color: var(--color-accent); }

.error-404__title {
	font-size: clamp(24px, 3vw, 40px);
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	margin-bottom: 16px;
}

.error-404__message {
	font-size: var(--fs-body-lg);
	color: rgba(255, 255, 255, 0.75);
	max-width: 540px;
	margin: 0 auto 32px;
	line-height: 1.7;
}

.error-404__search { margin-bottom: 28px; max-width: 480px; margin-inline: auto; }

.error-404__search-form {
	display: flex;
	gap: 12px;
}

.error-404__search-input {
	flex: 1;
	padding: 13px 18px;
	font-family: var(--font-primary);
	font-size: var(--fs-body);
	border: none;
	border-radius: var(--radius-sm);
	outline: none;
	color: var(--color-text);
}

.error-404__links {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 16px;
	margin-bottom: 32px;
}

.error-404__suggestions { margin-top: 20px; }

.error-404__suggestions-label {
	font-size: var(--fs-sm);
	color: rgba(255, 255, 255, 0.78);
	margin-bottom: 12px;
}

.error-404__suggestions-list {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 12px;
	list-style: none;
	padding: 0;
	margin: 0;
}

.error-404__suggestions-list a {
	font-size: var(--fs-sm);
	color: var(--color-accent);
	text-decoration: underline;
}

/* =============================================================================
   NO RESULTS
   ============================================================================= */

.no-results {
	padding: 80px 0;
}

.no-results__inner {
	max-width: 480px;
	margin-inline: auto;
}

.no-results__icon {
	color: var(--color-border-medium);
	margin-bottom: 24px;
}

.no-results__title {
	font-size: clamp(22px, 2.5vw, 28px);
	margin-bottom: 12px;
}

.no-results__message {
	color: var(--color-text-muted);
	margin-bottom: 28px;
}

.no-results__search { margin-bottom: 24px; }

.no-results__actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 12px;
}

/* =============================================================================
   PAGINATION
   ============================================================================= */

.posts-pagination { padding-top: 48px; }

.pagination ul {
	display: flex;
	align-items: center;
	justify-content: center;
	list-style: none;
	padding: 0;
	margin: 0;
	gap: 8px;
}

/* =============================================================================
   PAGE CONTENT (standard WP page)
   ============================================================================= */

.page-content .entry-content {
	padding-block: 64px;
}

.page-featured-image {
	width: 100%;
	max-height: 520px;
	overflow: hidden;
}

.page-featured-image__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* =============================================================================
   CUSTOM ELEMENTOR WIDGETS
   ============================================================================= */

/* Stat counter widget */
.pureox-stat {
	text-align: center;
}

.pureox-stat__row {
	display: flex;
	align-items: baseline;
	justify-content: center;
	gap: 2px;
	line-height: 1;
}

.pureox-stat__prefix,
.pureox-stat__suffix {
	font-size: 0.55em;
	font-weight: var(--font-weight-bold);
	color: var(--color-accent);
}

.pureox-stat__value {
	font-size: clamp(36px, 4vw, 56px);
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	line-height: 1;
	font-variant-numeric: tabular-nums;
}

.pureox-stat__label {
	font-size: var(--fs-sm);
	color: rgba(255, 255, 255, 0.7);
	margin-top: 8px;
	letter-spacing: 0.02em;
}

/* CTA banner widget */
.pureox-cta-banner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 32px;
	flex-wrap: wrap;
}

.pureox-cta-banner__title {
	font-size: clamp(22px, 2.5vw, 30px);
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	margin-bottom: 8px;
}

.pureox-cta-banner__description {
	color: rgba(255, 255, 255, 0.8);
	margin: 0;
}

/* =============================================================================
   HOME PAGE — SECTION 1: SPLIT HERO
   ============================================================================= */

.split-hero {
	position: relative;
	height: 100vh;
	min-height: 640px;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
}

/* ── Dual background panels ──────────────────────────────────────── */

.split-hero__panels {
	position: absolute;
	inset: 0;
	display: flex;
}

.split-hero__panel {
	flex: 0 0 50%;
	width: 50%;
	position: relative;
	overflow: hidden;
}

/* Scalable bg div — scales independently so overflow:hidden clips it */
.split-hero__panel-bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center center;
	transition: transform 0.7s ease;
}

.split-hero__panel:hover .split-hero__panel-bg {
	transform: scale(1.1);
}

/* Photo backgrounds — positioned so the subject faces the center divide */
.split-hero__panel--left .split-hero__panel-bg {
	background-image: url('../images/hero-oxygen.jpg');
	background-position: right center;
}

.split-hero__panel--right .split-hero__panel-bg {
	background-image: url('../images/hero-steel.jpg');
	background-position: left center;
}

/* Tinted overlays */
.split-hero__panel-overlay {
	position: absolute;
	inset: 0;
	pointer-events: none;
}

.split-hero__panel-overlay--left {
	background: linear-gradient(to right,
		rgba(10, 31, 67, 0.85) 0%,
		rgba(10, 31, 67, 0.45) 50%,
		rgba(10, 31, 67, 0.6) 100%);
}

.split-hero__panel-overlay--right {
	background: linear-gradient(to left,
		rgba(10, 31, 67, 0.85) 0%,
		rgba(10, 31, 67, 0.45) 50%,
		rgba(10, 31, 67, 0.6) 100%);
}

/* ── Centered content overlay ─────────────────────────────────────── */

.split-hero__body {
	position: relative;
	z-index: 30;
	width: 100%;
	display: flex;
	justify-content: center;
	padding: 0 var(--container-px, 24px);
}

.split-hero__content {
	max-width: 900px;
	width: 100%;
	text-align: center;
}

/* Certification badge — pill eyebrow style */
.split-hero__badge {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 6px 16px 6px 10px;
	background: rgba(0, 180, 216, 0.15);
	border: 1px solid rgba(0, 180, 216, 0.4);
	color: var(--color-accent);
	font-size: var(--fs-label);
	font-weight: var(--font-weight-bold);
	letter-spacing: 0.16em;
	text-transform: uppercase;
	border-radius: var(--radius-pill);
	margin-bottom: 28px;
}

.split-hero__badge::before {
	content: '';
	width: 6px;
	height: 6px;
	background: var(--color-red);
	border-radius: 50%;
	flex-shrink: 0;
}

/* H1 headline */
.split-hero__title {
	font-size: var(--fs-h1);
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	line-height: var(--lh-tight);
	letter-spacing: -0.02em;
	margin: 0 0 20px;
	text-shadow: 0 2px 16px rgba(0, 0, 0, 0.35);
}

.split-hero__title-cyan {
	color: var(--color-accent);
}

.split-hero__title-line2 {
	display: block;
}

/* Subtitle */
.split-hero__subtitle {
	font-size: var(--fs-body-lg);
	color: rgba(255, 255, 255, 0.88);
	line-height: var(--lh-body);
	margin: 0 0 36px;
	max-width: 640px;
	margin-left: auto;
	margin-right: auto;
}

/* CTA buttons row */
.split-hero__actions {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	gap: 14px;
}

.split-hero__btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 15px 30px;
	border-radius: var(--radius-pill);
	font-size: var(--fs-body);
	font-weight: var(--font-weight-bold);
	text-decoration: none;
	transition: background-color var(--transition-fast), opacity var(--transition-fast),
	            box-shadow var(--transition-fast), transform var(--transition-fast);
}

.split-hero__btn .material-symbols-outlined {
	font-size: 20px;
	font-variation-settings: 'FILL' 1, 'wght' 400, 'GRAD' 0, 'opsz' 24;
}

.split-hero__btn--cyan {
	background: var(--color-accent);
	color: var(--color-white);
	box-shadow: 0 8px 32px rgba(0, 180, 216, 0.4);
}

.split-hero__btn--cyan:hover {
	background: var(--color-accent-dark);
	color: var(--color-white);
	box-shadow: 0 12px 40px rgba(0, 180, 216, 0.5);
	transform: translateY(-2px);
}

.split-hero__btn--white {
	background: var(--color-red);
	color: var(--color-white);
	border: 1.5px solid var(--color-red);
}

.split-hero__btn--white:hover {
	background: var(--color-red-dark);
	border-color: var(--color-red-dark);
	color: var(--color-white);
	box-shadow: 0 12px 40px rgba(220, 43, 28, 0.45);
	transform: translateY(-2px);
}

/* ── Hero trust/stats strip ─────────────────────────────────── */
.split-hero__trust {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0;
	margin-top: 56px;
	padding-top: 32px;
	border-top: 1px solid rgba(255, 255, 255, 0.1);
	flex-wrap: wrap;
}

.split-hero__trust-item {
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 0 28px;
	border-right: 1px solid rgba(255, 255, 255, 0.12);
}

.split-hero__trust-item:last-child {
	border-right: none;
}

.split-hero__trust-val {
	font-size: clamp(26px, 3vw, 36px);
	font-weight: var(--font-weight-bold);
	color: var(--color-accent);
	line-height: 1;
	margin-bottom: 5px;
	letter-spacing: -0.02em;
}

.split-hero__trust-lbl {
	font-size: var(--fs-sm);
	color: rgba(255, 255, 255, 0.75);
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	text-align: center;
}

/* =============================================================================
   HOME PAGE — SECTION 2: INDUSTRIES SERVED BAR
   ============================================================================= */

.industries-bar {
	background: var(--color-bg-dark);
	padding: 40px 0;
	border-top: 1px solid rgba(255, 255, 255, 0.04);
}

.industries-bar__inner {
	display: flex;
	align-items: center;
	gap: 0;
	flex-wrap: nowrap;
}

/* "Trusted across" label on the left */
.industries-bar__heading {
	font-size: var(--fs-xs);
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	background: var(--color-red);
	border: 1px solid var(--color-red);
	border-radius: var(--radius-pill);
	padding: 5px 16px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	margin-right: 32px;
	white-space: nowrap;
	flex-shrink: 0;
}

.industries-bar__items {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex: 1;
	flex-wrap: nowrap;
	gap: 0;
}

.industries-bar__item {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 8px 16px;
	border-right: 1px solid rgba(255, 255, 255, 0.07);
	transition: opacity var(--transition-base);
	cursor: default;
	flex: 1;
	justify-content: center;
}

.industries-bar__item:last-child {
	border-right: none;
}

.industries-bar__item:hover {
	opacity: 1;
}

.industries-bar__icon {
	color: var(--color-red);
	font-size: 22px;
	font-variation-settings: 'FILL' 1, 'wght' 300, 'GRAD' 0, 'opsz' 24;
}

.industries-bar__label {
	color: rgba(255, 255, 255, 0.8);
	font-size: var(--fs-sm);
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	white-space: nowrap;
}

/* =============================================================================
   HOME PAGE — SECTION 3: SPECIALIZED ENGINEERING DIVISIONS
   ============================================================================= */

.divisions-showcase {
	padding: 96px 0;
	background-color: var(--color-bg-light);
	/* Blueprint dot pattern */
	background-image: radial-gradient(var(--color-primary) 0.5px, transparent 0.5px);
	background-size: 20px 20px;
	background-position: 0 0;
	position: relative;
}

/* Reduce dot opacity by layering a semi-transparent overlay */
.divisions-showcase::before {
	content: '';
	position: absolute;
	inset: 0;
	background: rgba(246, 247, 248, 0.95);
	pointer-events: none;
}

.divisions-showcase > .container { position: relative; }

/* ── Section header ──────────────────────────────────────────────── */

.divisions-showcase__header {
	text-align: center;
	margin-bottom: 64px;
}

.divisions-showcase__heading {
	font-size: var(--fs-h2);
	font-weight: var(--font-weight-bold);
	color: var(--color-heading);
	letter-spacing: -0.02em;
	margin: 16px 0 20px;
}

.divisions-showcase__sub {
	font-size: var(--fs-body-lg);
	color: var(--color-text);
	margin: 0;
	max-width: 560px;
	line-height: var(--lh-body);
	margin-left: auto;
	margin-right: auto;
}

/* ── Division blocks (full-width stacked) ────────────────────────── */

.division-block {
	margin-bottom: 80px;
}

.division-block:last-child {
	margin-bottom: 0;
}

/* ── Featured division card ──────────────────────────────────────── */

.division-featured-card {
	background: var(--color-white);
	border-radius: 16px;
	border: 1px solid rgba(10, 31, 67, 0.05);
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.08);
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

/* Image area */
.division-featured-card__image {
	position: relative;
	height: 256px;
	overflow: hidden;
}

.division-featured-card__image-bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	transition: transform 0.6s ease;
}

.division-featured-card:hover .division-featured-card__image-bg {
	transform: scale(1.05);
}

/* Photo backgrounds — overlays provide the colour tint */
.division-featured-card__image-bg--oxygen {
	background-image: url('../images/division-oxygen.jpg');
}

.division-featured-card__image-bg--steel {
	background-image: url('../images/division-steel.jpg');
}

/* Colour overlays */
.division-featured-card__image-overlay {
	position: absolute;
	inset: 0;
	pointer-events: none;
}

.division-featured-card__image-overlay--cyan {
	background: rgba(0, 180, 216, 0.2);
}

.division-featured-card__image-overlay--navy {
	background: rgba(10, 31, 67, 0.2);
}

/* Bottom-left title group */
.division-featured-card__image-title {
	position: absolute;
	bottom: 24px;
	left: 24px;
	display: flex;
	align-items: center;
	gap: 14px;
	z-index: 2;
}

/* Icon container */
.division-featured-card__icon-wrap {
	width: 48px;
	height: 48px;
	border-radius: 8px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.division-featured-card__icon-wrap--cyan {
	background: var(--color-accent);
}

.division-featured-card__icon-wrap--navy {
	background: var(--color-primary);
}

.division-featured-card__icon-wrap .material-symbols-outlined {
	color: var(--color-white);
	font-size: 24px;
}

.division-featured-card__image-heading {
	font-size: var(--fs-h3);
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	margin: 0;
	text-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
}

/* Content area */
.division-featured-card__body {
	padding: 44px;
	display: flex;
	flex-direction: column;
	flex: 1;
	gap: 0;
}

.division-featured-card__desc {
	font-size: var(--fs-body-lg);
	color: var(--color-text);
	line-height: var(--lh-body);
	margin: 0 0 32px;
	font-weight: var(--font-weight-medium);
}

/* Feature list */
.division-featured-card__features {
	list-style: none;
	padding: 0;
	margin: 0 0 32px;
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.division-featured-card__feature {
	display: flex;
	align-items: center;
	gap: 12px;
	font-size: var(--fs-body);
	font-weight: var(--font-weight-semibold);
	line-height: 1.6;
	color: var(--color-primary);
}

.division-featured-card__feature .material-symbols-outlined {
	font-size: 22px;
	flex-shrink: 0;
}

.division-featured-card__feature--cyan .material-symbols-outlined {
	color: var(--color-accent);
}

.division-featured-card__feature--navy .material-symbols-outlined {
	color: var(--color-primary);
}

/* CTA link at bottom of card */
.division-featured-card__cta {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: var(--fs-body);
	font-weight: var(--font-weight-bold);
	text-decoration: none;
	margin-top: auto;
	transition: gap var(--transition-fast);
}

.division-featured-card__cta:hover {
	gap: 12px;
}

.division-featured-card__cta .material-symbols-outlined {
	font-size: 20px;
	transition: inherit;
}

.division-featured-card__cta--cyan {
	color: var(--color-red);
}

.division-featured-card__cta--navy {
	color: var(--color-red);
}

/* ── Horizontal (wide) modifier — image left / body right ─────────── */

.division-featured-card--wide {
	flex-direction: row;
}

.division-featured-card--wide .division-featured-card__image {
	flex: 0 0 42%;
	height: auto;
	min-height: 300px;
}

.division-featured-card--wide .division-featured-card__body {
	flex: 1;
}

/* Reversed variant — image on right */
.division-featured-card--wide-reverse {
	flex-direction: row-reverse;
}

/* ── Service mini-card grid ──────────────────────────────────────── */

.div-services-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	margin-top: 28px;
}

/* ── Service mini-card ───────────────────────────────────────────── */

.svc-mini-card {
	background: var(--color-white);
	border-radius: var(--radius-md);
	padding: 32px 28px;
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
	border: 1px solid rgba(10, 31, 67, 0.07);
	display: flex;
	flex-direction: column;
	gap: 12px;
	transition: box-shadow 0.25s ease, transform 0.25s ease;
}

.svc-mini-card:hover {
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.11);
	transform: translateY(-3px);
}

.svc-mini-card__icon-wrap {
	width: 56px;
	height: 56px;
	border-radius: var(--radius-md);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	margin-bottom: 4px;
}

.svc-mini-card--cyan .svc-mini-card__icon-wrap {
	background: var(--color-accent-light);
}

.svc-mini-card--navy .svc-mini-card__icon-wrap {
	background: rgba(220, 43, 28, 0.08);
}

.svc-mini-card__icon {
	font-size: 32px;
	font-variation-settings: 'FILL' 1, 'wght' 300, 'GRAD' 0, 'opsz' 40;
}

.svc-mini-card--cyan .svc-mini-card__icon {
	color: var(--color-accent);
}

.svc-mini-card--navy .svc-mini-card__icon {
	color: var(--color-red);
}

.svc-mini-card__title {
	font-size: var(--fs-h5);
	font-weight: var(--font-weight-bold);
	color: var(--color-heading);
	margin: 0;
	line-height: 1.3;
	letter-spacing: -0.01em;
}

.svc-mini-card__desc {
	font-size: var(--fs-body);
	font-weight: var(--font-weight-medium);
	color: var(--color-text-muted);
	line-height: var(--lh-body);
	margin: 0;
	flex: 1;
}

.svc-mini-card__features {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 5px;
	border-top: 1px solid var(--color-border);
	padding-top: 12px;
	margin-top: auto;
}

.svc-mini-card__feature {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: var(--fs-body);
	font-weight: var(--font-weight-medium);
	line-height: 1.55;
	color: var(--color-text);
}

.svc-mini-card--cyan .svc-mini-card__feature .material-symbols-outlined {
	color: var(--color-accent);
	font-size: 18px;
}

.svc-mini-card--navy .svc-mini-card__feature .material-symbols-outlined {
	color: var(--color-red);
	font-size: 18px;
}

/* =============================================================================
   HOME PAGE — SECTION 4: WHY CHOOSE PURE-OX
   ============================================================================= */

.why-section {
	background: var(--color-primary);
	padding: 96px 0;
	color: var(--color-white);
}

/* ── Row 1: heading (left) + description (right) ───────────────────────── */

.why-section__top {
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: 64px;
	align-items: center;
	margin-bottom: 56px;
}

.why-section__intro { }

.why-section__heading {
	font-size: var(--fs-h2);
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	line-height: var(--lh-tight);
	letter-spacing: -0.02em;
	margin: 16px 0 0;
}

.why-section__para {
	font-size: var(--fs-body-lg);
	color: rgba(255, 255, 255, 0.82);
	line-height: var(--lh-body);
	margin: 0;
}

/* ── Row 2: 4-stat horizontal strip ───────────────────────────────────── */

.why-stats {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0;
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: var(--radius-md);
	margin-bottom: 40px;
	overflow: hidden;
}

.why-stat {
	padding: 32px 28px;
	border-right: 1px solid rgba(255, 255, 255, 0.1);
	background: rgba(255, 255, 255, 0.03);
	transition: background var(--transition-fast);
}

.why-stat:last-child { border-right: none; }

.why-stat:hover { background: rgba(255, 255, 255, 0.06); }

.why-stat__counter {
	display: flex;
	align-items: baseline;
	gap: 0;
	line-height: 1;
	margin-bottom: 8px;
}

.why-stat__number {
	font-size: clamp(36px, 3.5vw, 52px);
	font-weight: var(--font-weight-bold);
	color: var(--color-accent);
	letter-spacing: -0.02em;
}

.why-stat__suffix {
	font-size: clamp(24px, 2.5vw, 36px);
	font-weight: var(--font-weight-bold);
	color: var(--color-accent);
}

.why-stat__label {
	display: block;
	font-size: var(--fs-sm);
	font-weight: var(--font-weight-semibold);
	color: rgba(255, 255, 255, 0.75);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	line-height: 1.4;
}

/* ── Row 3: 3 feature cards full width ────────────────────────────────── */

.why-features {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
}

.why-card {
	padding: 36px 32px;
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-top: 3px solid rgba(255, 255, 255, 0.08);
	border-radius: var(--radius-md);
	background: rgba(255, 255, 255, 0.02);
	transition: background var(--transition-fast), border-top-color var(--transition-base);
}

.why-card:hover {
	background: rgba(255, 255, 255, 0.05);
	border-top-color: var(--color-accent);
}

.why-card__icon {
	font-size: 44px;
	color: var(--color-accent);
	display: block;
	font-variation-settings: 'FILL' 1, 'wght' 300, 'GRAD' 0, 'opsz' 48;
}

.why-card__title {
	font-size: var(--fs-h4);
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	margin: 20px 0 14px;
	letter-spacing: -0.01em;
}

.why-card__body {
	font-size: var(--fs-body);
	font-weight: var(--font-weight-medium);
	color: rgba(255, 255, 255, 0.82);
	line-height: var(--lh-body);
	margin: 0;
}

/* =============================================================================
   HOME PAGE — SECTION 5: FEATURED PROJECTS
   ============================================================================= */

.projects-showcase {
	background: var(--color-white);
	padding: 96px 0;
}

/* Header row: title left, link right */
.projects-showcase__header {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 24px;
	margin-bottom: 40px;
}

.projects-showcase__heading {
	font-size: var(--fs-h2);
	font-weight: var(--font-weight-bold);
	color: var(--color-heading);
	letter-spacing: -0.02em;
	margin: 16px 0 8px;
}

.projects-showcase__sub {
	font-size: var(--fs-body);
	color: var(--color-text-muted);
	margin: 0;
	line-height: var(--lh-body);
}

.projects-showcase__view-all {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 10px 20px;
	font-size: var(--fs-sm);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	text-decoration: none;
	border: 1.5px solid var(--color-border-medium);
	border-radius: var(--radius-pill);
	white-space: nowrap;
	flex-shrink: 0;
	transition: background var(--transition-fast), border-color var(--transition-fast),
	            color var(--transition-fast);
}

.projects-showcase__view-all:hover {
	background: var(--color-primary);
	border-color: var(--color-primary);
	color: var(--color-white);
	text-decoration: none;
}

/* Project grid */
.projects-showcase__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 32px;
}

/* Image overlay card */
.project-image-card {
	border-radius: var(--radius-lg);
	overflow: hidden;
	aspect-ratio: 4/5;
	min-height: 380px;
	position: relative;
}

.project-image-card__link {
	display: block;
	height: 100%;
	position: relative;
	text-decoration: none;
}

/* Scalable background */
.project-image-card__bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	transition: transform 0.5s ease;
}

.project-image-card:hover .project-image-card__bg {
	transform: scale(1.1);
}

/* Photo backgrounds for placeholder project cards */
.project-image-card__bg--steel {
	background-image: url('../images/project-steel.jpg');
}

.project-image-card__bg--oxygen {
	background-image: url('../images/project-oxygen.jpg');
}

.project-image-card__bg--fabrication {
	background-image: url('../images/project-fabrication.jpg');
}

/* Dark gradient overlay (bottom to top) */
.project-image-card__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(10, 31, 67, 0.8) 0%, transparent 60%);
	pointer-events: none;
}

/* Text content */
.project-image-card__body {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 32px;
}

.project-image-card__tag {
	display: block;
	font-size: var(--fs-xs);
	font-weight: var(--font-weight-bold);
	color: var(--color-accent);
	letter-spacing: 0.14em;
	text-transform: uppercase;
	margin-bottom: 8px;
}

.project-image-card__title {
	font-size: var(--fs-h4);
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	margin: 0 0 8px;
	line-height: 1.25;
	letter-spacing: -0.01em;
}

.project-image-card__location {
	display: flex;
	align-items: center;
	gap: 4px;
	font-size: var(--fs-sm);
	font-weight: var(--font-weight-medium);
	color: rgba(255, 255, 255, 0.75);
}

.project-image-card__location .material-symbols-outlined {
	font-size: 18px;
}

/* =============================================================================
   HOME PAGE — SECTION 6: CTA BANNER
   ============================================================================= */

.cta-banner-section {
	background: var(--color-bg-light);
	padding: 80px 0;
}

.cta-banner-wrap {
	max-width: 960px;
	margin: 0 auto;
}

.cta-banner {
	background: var(--color-primary);
	border-radius: 24px;
	padding: 80px;
	text-align: center;
	position: relative;
	overflow: hidden;
}

/* Blueprint dot overlay inside the card */
.cta-banner::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image: radial-gradient(rgba(255, 255, 255, 0.15) 0.5px, transparent 0.5px);
	background-size: 20px 20px;
	opacity: 0.6;
	pointer-events: none;
}

.cta-banner > * { position: relative; }

.cta-banner__heading {
	font-size: var(--fs-h2);
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	letter-spacing: -0.02em;
	line-height: var(--lh-tight);
	margin: 16px 0 20px;
}

.cta-banner__text {
	font-size: var(--fs-body-lg);
	color: rgba(255, 255, 255, 0.7);
	line-height: var(--lh-body);
	max-width: 600px;
	margin: 0 auto 40px;
}

.cta-banner__actions {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	gap: 16px;
}

.cta-banner__btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 16px 40px;
	border-radius: var(--radius-md);
	font-size: var(--fs-body-lg);
	font-weight: var(--font-weight-bold);
	text-decoration: none;
	transition: background var(--transition-fast), border-color var(--transition-fast);
	cursor: pointer;
}

.cta-banner__btn .material-symbols-outlined {
	font-size: 22px;
}

.cta-banner__btn--primary {
	background: var(--color-red);
	color: var(--color-white);
	border: 2px solid transparent;
}

.cta-banner__btn--primary:hover {
	background: var(--color-red-dark);
	color: var(--color-white);
	box-shadow: 0 8px 28px rgba(220, 43, 28, 0.4);
}

.cta-banner__btn--ghost {
	background: transparent;
	color: var(--color-white);
	border: 2px solid rgba(255, 255, 255, 0.2);
}

.cta-banner__btn--ghost:hover {
	background: rgba(255, 255, 255, 0.1);
	border-color: rgba(255, 255, 255, 0.4);
	color: var(--color-white);
}

/* =============================================================================
   UTILITY ANIMATIONS (used via JS class toggles)
   ============================================================================= */

.fade-in-up {
	opacity: 0;
	transform: translateY(24px);
	transition: opacity 0.6s ease, transform 0.6s ease;
}

.fade-in-up.is-visible {
	opacity: 1;
	transform: translateY(0);
}

.fade-in {
	opacity: 0;
	transition: opacity 0.6s ease;
}

.fade-in.is-visible { opacity: 1; }

/* .pureox-animate — spec-compliant scroll reveal system.
   JS adds .animated when the element enters the viewport.
   Elements are auto-tagged by autoApplyPureoxAnimate() in animations.js.
   Respects prefers-reduced-motion (JS skips observer and adds .animated immediately). */
.pureox-animate {
	opacity: 0;
	transform: translateY(30px);
	transition: opacity 0.6s ease, transform 0.6s ease;
}

.pureox-animate.animated {
	opacity: 1;
	transform: translateY(0);
}

/* Stagger children */
.stagger-children > *:nth-child(1)  { transition-delay: 0s; }
.stagger-children > *:nth-child(2)  { transition-delay: 0.1s; }
.stagger-children > *:nth-child(3)  { transition-delay: 0.2s; }
.stagger-children > *:nth-child(4)  { transition-delay: 0.3s; }
.stagger-children > *:nth-child(5)  { transition-delay: 0.4s; }
.stagger-children > *:nth-child(6)  { transition-delay: 0.5s; }

/* =============================================================================
   COMMENTS
   ============================================================================= */

.comment-list { list-style: none; padding: 0; }
.comment-list .comment { margin-bottom: 32px; }
.comment-author-avatar { border-radius: 50%; }

.comment-form label { display: block; margin-bottom: 4px; font-weight: var(--font-weight-semibold); }
.comment-form input,
.comment-form textarea {
	width: 100%;
	padding: 10px 14px;
	font-family: var(--font-primary);
	border: 1.5px solid var(--color-border-medium);
	border-radius: var(--radius-sm);
	outline: none;
	transition: border-color var(--transition-fast);
}
.comment-form input:focus,
.comment-form textarea:focus { border-color: var(--color-accent); }
.comment-form textarea { min-height: 120px; resize: vertical; }

#submit {
	display: inline-block;
	padding: 12px 28px;
	background: var(--color-red);
	color: var(--color-white);
	font-family: var(--font-primary);
	font-weight: var(--font-weight-bold);
	border: none;
	border-radius: var(--radius-sm);
	cursor: pointer;
	transition: background-color var(--transition-fast);
}

#submit:hover { background-color: var(--color-accent-dark); }

/* =============================================================================
   ABOUT US PAGE
   ============================================================================= */

/* Reusable eyebrow label (uppercase accent label above section headings) */
.section-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: var(--fs-label);
	font-weight: var(--font-weight-bold);
	color: var(--color-accent);
	letter-spacing: 0.18em;
	text-transform: uppercase;
	margin-bottom: 20px;
	background: rgba(0, 180, 216, 0.1);
	border: 1px solid rgba(0, 180, 216, 0.25);
	padding: 5px 14px 5px 10px;
	border-radius: var(--radius-pill);
	line-height: 1.4;
}

/* Accent dot prefix inside the pill */
.section-eyebrow::before {
	content: '';
	display: inline-block;
	width: 6px;
	height: 6px;
	background: var(--color-red);
	border-radius: 50%;
	flex-shrink: 0;
}

/* On dark backgrounds — white pill */
.bg-primary .section-eyebrow,
[class*="bg-primary"] .section-eyebrow,
.why-section .section-eyebrow,
.cta-banner .section-eyebrow {
	color: rgba(255, 255, 255, 0.95);
	background: rgba(255, 255, 255, 0.12);
	border-color: rgba(255, 255, 255, 0.2);
}

.bg-primary .section-eyebrow::before,
[class*="bg-primary"] .section-eyebrow::before,
.why-section .section-eyebrow::before,
.cta-banner .section-eyebrow::before {
	background: var(--color-red);
}

/* Light background section modifier */
.section--light { background-color: var(--color-bg-light); }

/* ── Section 1: Hero Banner ─────────────────────────────────────────── */

.about-hero {
	position: relative;
	height: 500px;
	overflow: hidden;
	background-color: var(--color-primary);
	display: flex;
	align-items: flex-end;
}

/* Full-bleed background image (set via CSS custom property from PHP) */
.about-hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image: var(--about-hero-img, none);
	background-size: cover;
	background-position: center;
	opacity: 0.5;
	z-index: 1;
}

/* Gradient: solid navy at bottom → transparent at top */
.about-hero::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, var(--color-primary) 0%, var(--color-primary) 60%, transparent 100%);
	z-index: 2;
}

.about-hero__content {
	position: relative;
	z-index: 20;
	padding-bottom: 64px;
}

.about-hero__breadcrumb { margin-bottom: 24px; }

.about-hero__breadcrumb-list {
	display: flex;
	align-items: center;
	gap: 8px;
	list-style: none;
	padding: 0;
	margin: 0;
	font-size: var(--fs-sm);
	font-weight: var(--font-weight-semibold);
	color: rgba(255, 255, 255, 0.7);
}

.about-hero__breadcrumb-sep { color: rgba(255, 255, 255, 0.5); }

.about-hero__breadcrumb-link {
	color: rgba(255, 255, 255, 0.7);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.about-hero__breadcrumb-link:hover { color: var(--color-white); }

.about-hero__heading {
	font-size: var(--fs-h1);
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	line-height: var(--lh-tight);
	max-width: 700px;
	margin-bottom: 0;
}

.about-hero__sub {
	font-size: var(--fs-body-lg);
	font-weight: var(--font-weight-light);
	color: rgba(255, 255, 255, 0.8);
	line-height: var(--lh-body);
	max-width: 600px;
	margin-top: 24px;
	margin-bottom: 0;
}

/* ── Section 2: Who We Are ──────────────────────────────────────────── */

.about-who__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 64px;
	align-items: start;
}

.about-who__heading {
	font-size: var(--fs-h2);
	font-weight: var(--font-weight-bold);
	color: var(--color-heading);
	line-height: var(--lh-tight);
	margin-bottom: 24px;
}

.about-who__body {
	font-size: var(--fs-body-lg);
	color: var(--color-text-muted);
	line-height: var(--lh-body);
	margin-bottom: 40px;
}

/* ISO Certification badge */
.about-iso-badge {
	display: flex;
	align-items: flex-start;
	gap: 16px;
	background: var(--color-accent-light);
	border: 1px solid var(--color-border-medium);
	border-radius: 12px;
	padding: 16px;
}

.about-iso-badge__icon {
	color: var(--color-primary);
	font-size: 32px;
	flex-shrink: 0;
	line-height: 1;
}

.about-iso-badge__title {
	font-size: var(--fs-body);
	font-weight: var(--font-weight-bold);
	color: var(--color-heading);
	margin-bottom: 4px;
}

.about-iso-badge__text {
	font-size: var(--fs-sm);
	color: var(--color-text-muted);
	line-height: 1.6;
	margin: 0;
}

/* Mission / Vision cards */
.about-mv-card {
	padding: 32px;
	border-radius: 16px;
	background: var(--color-bg-light);
	border-left: 4px solid var(--color-primary);
}

.about-mv-card--vision {
	border-left-color: var(--color-accent);
	margin-top: 32px;
}

.about-mv-card__header {
	display: flex;
	align-items: center;
	gap: 16px;
	margin-bottom: 16px;
}

.about-mv-card__icon-wrap {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 8px;
	flex-shrink: 0;
}

.about-mv-card__icon-wrap--primary {
	background: var(--color-primary);
	color: var(--color-white);
}

.about-mv-card__icon-wrap--blue {
	background: var(--color-accent);
	color: var(--color-white);
}

.about-mv-card__icon-wrap .material-symbols-outlined { font-size: 24px; }

.about-mv-card__title {
	font-size: 24px;
	font-weight: var(--font-weight-bold);
	color: var(--color-heading);
	margin-bottom: 0;
}

.about-mv-card__text {
	font-size: var(--fs-body);
	color: var(--color-text-muted);
	line-height: 1.7;
	margin: 0;
}

/* ── Section 3: Statistics / Numbers Bar ────────────────────────────── */

.about-stats {
	position: relative;
	overflow: hidden;
	background: var(--color-primary);
	padding-block: 80px;
}

.about-stats__dot-grid {
	position: absolute;
	inset: 0;
	background-image: radial-gradient(#ffffff 1px, transparent 1px);
	background-size: 40px 40px;
	opacity: 0.1;
	pointer-events: none;
}

.about-stats__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 48px;
	text-align: center;
}

.about-stats__cell {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
}

.about-stats__number {
	display: flex;
	align-items: baseline;
	gap: 2px;
	font-size: 56px;
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	letter-spacing: -0.02em;
	line-height: 1;
	font-variant-numeric: tabular-nums;
}

.about-stats__suffix {
	font-size: 0.6em;
	font-weight: var(--font-weight-bold);
}

.about-stats__label {
	font-size: 13px;
	font-weight: var(--font-weight-bold);
	color: rgba(255, 255, 255, 0.65);
	letter-spacing: 0.15em;
	text-transform: uppercase;
	margin: 0;
}

/* ── Section 4: Core Strengths ──────────────────────────────────────── */

.about-strengths__intro {
	max-width: 640px;
	margin-inline: auto;
	margin-bottom: 64px;
}

.about-strengths__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 32px;
}

.about-strength-card {
	background: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: 16px;
	padding: 32px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
	transition: border-color 0.2s ease;
}

.about-strength-card:hover { border-color: var(--color-accent); }

.about-strength-card__icon-wrap {
	width: 56px;
	height: 56px;
	border-radius: 12px;
	background: var(--color-accent-light);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 24px;
	transition: background-color 0.2s ease;
}

.about-strength-card:hover .about-strength-card__icon-wrap { background: var(--color-primary); }

.about-strength-card__icon {
	font-size: 28px;
	color: var(--color-primary);
	transition: color 0.2s ease;
}

.about-strength-card:hover .about-strength-card__icon { color: var(--color-white); }

.about-strength-card__title {
	font-size: 20px;
	font-weight: var(--font-weight-bold);
	color: var(--color-heading);
	margin-bottom: 12px;
}

.about-strength-card__body {
	font-size: var(--fs-sm);
	color: var(--color-text-muted);
	line-height: 1.7;
	margin: 0;
}

/* ── Section 5 (optional): Leadership ──────────────────────────────── */
/* Uses existing .team-grid and .team-card styles from main.css */

/* ── Section 6: CTA Card ────────────────────────────────────────────── */

.about-cta-card {
	position: relative;
	overflow: hidden;
	background: var(--color-primary);
	border-radius: 24px;
	padding: 80px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 48px;
}

.about-cta-card__blur {
	position: absolute;
	right: -80px;
	bottom: -80px;
	width: 320px;
	height: 320px;
	background: rgba(37, 99, 235, 0.2);
	border-radius: 50%;
	filter: blur(60px);
	pointer-events: none;
	z-index: 0;
}

.about-cta-card__text,
.about-cta-card__actions {
	position: relative;
	z-index: 10;
}

.about-cta-card__heading {
	font-size: 48px;
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	line-height: 1.1;
	margin-bottom: 24px;
}

.about-cta-card__sub {
	font-size: 18px;
	color: rgba(255, 255, 255, 0.7);
	line-height: 1.7;
	max-width: 520px;
	margin: 0;
}

.about-cta-card__actions {
	display: flex;
	flex-shrink: 0;
	gap: 16px;
}

.about-cta-card__btn {
	display: inline-block;
	padding: 16px 40px;
	border-radius: var(--radius-md);
	font-size: var(--fs-body-lg);
	font-weight: var(--font-weight-bold);
	text-decoration: none;
	white-space: nowrap;
	transition: background-color var(--transition-base), border-color var(--transition-base);
}

.about-cta-card__btn--primary {
	background: var(--color-white);
	color: var(--color-primary);
}

.about-cta-card__btn--primary:hover {
	background: var(--color-accent-light);
	text-decoration: none;
	color: var(--color-primary);
}

.about-cta-card__btn--outline {
	background: transparent;
	color: var(--color-white);
	border: 1px solid rgba(255, 255, 255, 0.3);
}

.about-cta-card__btn--outline:hover {
	background: rgba(255, 255, 255, 0.1);
	text-decoration: none;
	color: var(--color-white);
}

/* =============================================================================
   SERVICES & DIVISIONS PAGE
   ============================================================================= */

/* ── Section 1: Hero (2-column contained) ───────────────────────────── */

.services-hero {
	padding-top: var(--section-py);
	padding-bottom: 80px;
}

.services-hero__grid {
	display: flex;
	align-items: center;
	gap: 48px;
}

.services-hero__text { flex: 1; }

.services-hero__badge {
	display: inline-block;
	background: rgba(10, 31, 67, 0.1);
	color: var(--color-primary);
	font-size: var(--fs-label);
	font-weight: var(--font-weight-bold);
	letter-spacing: 0.15em;
	text-transform: uppercase;
	padding: 4px 12px;
	border-radius: var(--radius-pill);
	margin-bottom: 16px;
}

.services-hero__heading {
	font-size: var(--fs-h1);
	font-weight: var(--font-weight-bold);
	color: var(--color-heading);
	line-height: var(--lh-tight);
	letter-spacing: -0.02em;
	margin-bottom: 24px;
}

.services-hero__body {
	font-size: var(--fs-body-lg);
	color: var(--color-text);
	line-height: var(--lh-body);
	max-width: 520px;
	margin-bottom: 32px;
}

.services-hero__actions {
	display: flex;
	gap: 16px;
	flex-wrap: wrap;
}

.services-hero__btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 16px 32px;
	border-radius: 8px;
	font-size: var(--fs-body);
	font-weight: var(--font-weight-bold);
	text-decoration: none;
	transition: opacity 0.2s ease, border-color 0.2s ease;
}

.services-hero__btn--primary {
	background: var(--color-primary);
	color: var(--color-white);
}

.services-hero__btn--primary:hover {
	opacity: 0.9;
	color: var(--color-white);
	text-decoration: none;
}

.services-hero__btn--outline {
	background: transparent;
	color: var(--color-primary);
	border: 2px solid rgba(10, 31, 67, 0.2);
}

.services-hero__btn--outline:hover {
	border-color: var(--color-primary);
	text-decoration: none;
	color: var(--color-primary);
}

/* Right image card — 3-image crossfade slider */
.services-hero__image-card {
	flex: 0 0 50%;
	height: 400px;
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 25px 60px rgba(0, 0, 0, 0.2);
	position: relative;
	background-color: var(--color-primary);
}

/* Crossfade slides */
.services-hero__slide {
	position: absolute;
	inset: 0;
	opacity: 0;
	transition: opacity 0.8s ease;
	z-index: 0;
}

.services-hero__slide.is-active {
	opacity: 1;
	z-index: 1;
}

.services-hero__slide-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Dot navigation — top-right corner of card */
.services-hero__slide-dots {
	position: absolute;
	top: 16px;
	right: 16px;
	display: flex;
	gap: 7px;
	z-index: 10;
}

.services-hero__slide-dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	border: 1.5px solid rgba(255, 255, 255, 0.7);
	padding: 0;
	background: rgba(255, 255, 255, 0.25);
	cursor: pointer;
	transition: background 0.3s, transform 0.3s, border-color 0.3s;
}

.services-hero__slide-dot.is-active {
	background: var(--color-white);
	border-color: var(--color-white);
	transform: scale(1.25);
}

.services-hero__image-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to bottom, transparent 0%, rgba(10, 31, 67, 0.6) 100%);
	z-index: 2;
}

.services-hero__caption {
	position: absolute;
	bottom: 0;
	left: 0;
	padding: 24px;
	z-index: 10;
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.services-hero__caption-tag {
	font-size: 13px;
	font-weight: 500;
	color: rgba(255, 255, 255, 0.8);
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.services-hero__caption-title {
	font-size: 20px;
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
}

/* ── Section 2: Certifications Strip ────────────────────────────────── */

.services-certs { margin-bottom: 96px; }

.services-certs__grid {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 48px;
	list-style: none;
	padding: 0;
	margin: 0;
	opacity: 0.4;
	filter: grayscale(1);
	transition: opacity 0.3s ease, filter 0.3s ease;
}

.services-certs__grid:hover {
	opacity: 1;
	filter: grayscale(0);
}

.services-certs__item {
	display: flex;
	align-items: center;
	gap: 8px;
}

.services-certs__icon {
	font-size: 28px;
	color: var(--color-primary);
}

.services-certs__label {
	font-size: 20px;
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
}

/* ── Sections 3 & 4: Division sections ──────────────────────────────── */

.services-division { margin-bottom: 96px; }

.services-division__header {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 24px;
	border-left: 4px solid var(--color-primary);
	padding-left: 24px;
	margin-bottom: 48px;
}

.services-division__title {
	font-size: 32px;
	font-weight: var(--font-weight-bold);
	color: var(--color-heading);
	margin-bottom: 8px;
}

.services-division__caption {
	font-size: var(--fs-body);
	color: var(--color-text-muted);
	max-width: 480px;
	margin: 0;
}

.services-division__cta {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: var(--fs-body);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	text-decoration: none;
	white-space: nowrap;
	flex-shrink: 0;
	transition: gap 0.2s ease;
}

.services-division__cta:hover {
	text-decoration: none;
	color: var(--color-primary);
	gap: 10px;
}

.services-division__cta-arrow {
	font-size: 20px;
	transition: transform 0.2s ease;
}

.services-division__cta:hover .services-division__cta-arrow {
	transform: translateX(4px);
}

.services-division__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 32px;
}

/* ── Service cards (shared by both divisions) ────────────────────────── */

.service-card {
	background: var(--color-white);
	border: 1px solid rgba(10, 31, 67, 0.05);
	border-radius: 12px;
	padding: 32px;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.service-card:hover {
	border-color: rgba(10, 31, 67, 0.2);
	box-shadow: 0 20px 40px rgba(0, 0, 0, 0.08);
}

.service-card__icon-wrap {
	width: 56px;
	height: 56px;
	border-radius: 8px;
	background: rgba(10, 31, 67, 0.05);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 24px;
	transition: background-color 0.2s ease;
}

.service-card:hover .service-card__icon-wrap { background: var(--color-primary); }

.service-card__icon {
	font-size: 28px;
	color: var(--color-primary);
	transition: color 0.2s ease;
}

.service-card:hover .service-card__icon { color: var(--color-white); }

.service-card__title {
	font-size: 20px;
	font-weight: var(--font-weight-bold);
	color: var(--color-heading);
	margin-bottom: 12px;
}

.service-card__body {
	font-size: var(--fs-sm);
	font-weight: var(--font-weight-medium);
	color: var(--color-text);
	line-height: 1.7;
	margin-bottom: 24px;
}

.service-card__features {
	display: flex;
	flex-direction: column;
	gap: 8px;
	list-style: none;
	padding: 0;
	margin: 0;
}

.service-card__feature {
	display: flex;
	align-items: center;
	gap: 8px;
}

.service-card__check {
	font-size: var(--fs-body);
	color: var(--color-primary);
	flex-shrink: 0;
}

.service-card__feature span:last-child {
	font-size: var(--fs-sm);
	font-weight: var(--font-weight-semibold);
	line-height: 1.6;
	color: var(--color-text);
}

/* ── Section 5: Precision Process Timeline ───────────────────────────── */

.services-timeline { margin-bottom: 96px; }

.services-timeline__card {
	background: var(--color-white);
	border: 1px solid rgba(10, 31, 67, 0.05);
	border-radius: 16px;
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.04);
	padding: 64px 48px;
}

.services-timeline__header {
	text-align: center;
	margin-bottom: 64px;
}

.services-timeline__title {
	font-size: 32px;
	font-weight: var(--font-weight-bold);
	color: var(--color-heading);
	margin-bottom: 16px;
}

.services-timeline__sub {
	font-size: var(--fs-body);
	color: var(--color-text-muted);
	max-width: 600px;
	margin-inline: auto;
	line-height: 1.7;
	margin-bottom: 0;
}

.services-timeline__grid {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 16px;
	list-style: none;
	padding: 0;
	margin: 0;
	position: relative;
}

/* Horizontal connecting line (desktop only — hidden in responsive.css) */
.services-timeline__grid::before {
	content: '';
	position: absolute;
	top: 24px;
	left: 10%;
	right: 10%;
	height: 2px;
	background: rgba(10, 31, 67, 0.1);
	z-index: 0;
}

.services-timeline__step {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	position: relative;
	z-index: 10;
}

.services-timeline__circle {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background: var(--color-primary);
	color: var(--color-white);
	font-size: var(--fs-sm);
	font-weight: var(--font-weight-bold);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 16px;
	box-shadow: 0 0 0 8px var(--color-white), 0 8px 20px rgba(10, 31, 67, 0.3);
	position: relative;
	z-index: 10;
	flex-shrink: 0;
}

.services-timeline__step-title {
	font-size: 18px;
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	margin-bottom: 8px;
}

.services-timeline__step-desc {
	font-size: 13px;
	color: var(--color-text-muted);
	line-height: 1.7;
	margin: 0;
}

/* ── Section 6: CTA Banner ───────────────────────────────────────────── */

.services-cta { margin-bottom: 48px; }

.services-cta__card {
	position: relative;
	overflow: hidden;
	background: var(--color-primary);
	border-radius: 16px;
	padding: 80px;
	text-align: center;
	color: var(--color-white);
}

.services-cta__svg {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	color: var(--color-white);
	opacity: 0.1;
	pointer-events: none;
}

.services-cta__content {
	position: relative;
	z-index: 10;
}

.services-cta__heading {
	font-size: 48px;
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	line-height: 1.2;
	margin-bottom: 24px;
}

.services-cta__body {
	font-size: 18px;
	color: rgba(255, 255, 255, 0.7);
	line-height: 1.7;
	max-width: 600px;
	margin: 0 auto 40px;
}

.services-cta__actions {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 16px;
}

.services-cta__btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 16px 32px;
	border-radius: var(--radius-sm);
	font-size: var(--fs-body-lg);
	font-weight: var(--font-weight-bold);
	text-decoration: none;
	transition: background-color var(--transition-base);
}

.services-cta__btn--primary {
	background: var(--color-white);
	color: var(--color-primary);
}

.services-cta__btn--primary:hover {
	background: rgba(255, 255, 255, 0.9);
	color: var(--color-primary);
	text-decoration: none;
}

.services-cta__btn--secondary {
	background: rgba(10, 31, 67, 0.2);
	color: var(--color-white);
	border: 1px solid rgba(255, 255, 255, 0.2);
}

.services-cta__btn--secondary:hover {
	background: rgba(10, 31, 67, 0.3);
	color: var(--color-white);
	text-decoration: none;
}

/* =============================================================================
   CONTACT PAGE — page-contact.php
   ============================================================================= */

/* ── Section 1 — Page Header ──────────────────────────────────────────────── */

.contact-header {
	position: relative;
	padding-top: 48px;
	padding-bottom: 64px;
	overflow: hidden;
}

/* ── Full-bleed hero image (when Customizer image is set) ── */
.contact-header--has-image {
	background-color: var(--color-primary);
	padding-top: 80px;
	padding-bottom: 100px;
}

/* Background photo layer */
.contact-header--has-image::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image: var(--contact-hero-img, none);
	background-size: cover;
	background-position: center;
	opacity: 0.45;
	z-index: 1;
}

/* Gradient overlay: navy at bottom → transparent at top */
.contact-header--has-image::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, var(--color-primary) 0%, var(--color-primary) 40%, transparent 100%);
	z-index: 2;
}

/* Content sits above overlays */
.contact-header--has-image .container {
	position: relative;
	z-index: 20;
}

/* White text when hero image is active */
.contact-header--has-image .contact-header__breadcrumb-list {
	color: rgba(255, 255, 255, 0.7);
}

.contact-header--has-image .contact-header__breadcrumb-link {
	color: rgba(255, 255, 255, 0.7);
}

.contact-header--has-image .contact-header__breadcrumb-link:hover {
	color: var(--color-white);
}

.contact-header--has-image .contact-header__breadcrumb-sep {
	color: rgba(255, 255, 255, 0.5);
}

.contact-header--has-image .contact-header__heading {
	color: var(--color-white);
}

.contact-header--has-image .contact-header__sub {
	color: rgba(255, 255, 255, 0.8);
}

.contact-header__breadcrumb-list {
	display: flex;
	align-items: center;
	gap: 8px;
	list-style: none;
	margin: 0 0 32px;
	padding: 0;
	font-size: var(--fs-sm);
}

.contact-header__breadcrumb-link {
	color: var(--color-text-muted);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.contact-header__breadcrumb-link:hover {
	color: var(--color-accent);
}

.contact-header__breadcrumb-sep {
	color: var(--color-border-medium);
}

.contact-header__heading {
	font-size: clamp(32px, 5vw, 56px);
	font-weight: var(--font-weight-bold);
	color: var(--color-heading);
	line-height: 1.15;
	margin-bottom: 20px;
	max-width: 700px;
}

.contact-header__sub {
	font-size: 18px;
	color: var(--color-text-muted);
	line-height: 1.7;
	max-width: 640px;
}

/* ── Section 2 — Form + Sidebar Grid ─────────────────────────────────────── */

.contact-grid {
	display: grid;
	grid-template-columns: minmax(0, 7fr) minmax(0, 5fr);
	gap: 40px;
	align-items: start;
}

/* ── Form Card ────────────────────────────────────────────────────────────── */

.contact-form-card {
	background: var(--color-white);
	border: 1px solid var(--color-border-light);
	border-radius: 16px;
	padding: 48px;
	box-shadow: var(--shadow-card);
}

.contact-form-card__heading {
	font-size: 28px;
	font-weight: var(--font-weight-bold);
	color: var(--color-heading);
	margin-bottom: 8px;
}

.contact-form-card__sub {
	font-size: var(--fs-sm);
	color: var(--color-text-muted);
	margin-bottom: 32px;
}

.contact-form__row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
	margin-bottom: 20px;
}

.contact-form__field {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.contact-form__field--full {
	margin-bottom: 24px;
}

.contact-form__label {
	font-size: var(--fs-sm);
	font-weight: var(--font-weight-semibold);
	color: var(--color-primary);
}

.contact-form__required {
	color: var(--color-accent);
	margin-left: 2px;
}

.contact-form__input,
.contact-form__select {
	width: 100%;
	background: var(--color-bg-light);
	border: 1.5px solid var(--color-border-medium);
	border-radius: 8px;
	padding: 14px 16px;
	font-family: var(--font-primary);
	font-size: 15px;
	color: var(--color-text);
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
	appearance: none;
	-webkit-appearance: none;
}

.contact-form__select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 14px center;
	padding-right: 44px;
	cursor: pointer;
}

.contact-form__input:focus,
.contact-form__select:focus {
	outline: none;
	border-color: var(--color-accent);
	box-shadow: 0 0 0 3px rgba(0, 180, 216, 0.15);
}

.contact-form__textarea {
	width: 100%;
	background: var(--color-bg-light);
	border: 1.5px solid var(--color-border-medium);
	border-radius: 8px;
	padding: 14px 16px;
	font-family: var(--font-primary);
	font-size: 15px;
	color: var(--color-text);
	resize: vertical;
	min-height: 150px;
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.contact-form__textarea:focus {
	outline: none;
	border-color: var(--color-accent);
	box-shadow: 0 0 0 3px rgba(0, 180, 216, 0.15);
}

.contact-form__submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	background-color: var(--color-red);
	color: var(--color-white);
	border: none;
	border-radius: var(--radius-sm);
	padding: 16px 40px;
	font-family: var(--font-primary);
	font-size: var(--fs-body);
	font-weight: var(--font-weight-bold);
	cursor: pointer;
	transition: background-color var(--transition-fast), transform var(--transition-fast),
	            box-shadow var(--transition-fast);
}

.contact-form__submit:hover {
	background-color: var(--color-red-dark);
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(220, 43, 28, 0.35);
}

.contact-form__submit:active {
	transform: translateY(0);
}

/* ── Success State ────────────────────────────────────────────────────────── */

.contact-success {
	text-align: center;
	padding: 48px 24px;
}

.contact-success__icon {
	font-size: 72px;
	color: var(--color-accent);
	display: block;
	margin-bottom: 24px;
	animation: pureox-success-pop 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275) both;
}

@keyframes pureox-success-pop {
	0%   { transform: scale(0);    opacity: 0; }
	70%  { transform: scale(1.15); opacity: 1; }
	100% { transform: scale(1);    opacity: 1; }
}

.contact-success__heading {
	font-size: var(--fs-h2);
	font-weight: var(--font-weight-bold);
	color: var(--color-heading);
	margin-bottom: 16px;
}

.contact-success__body {
	font-size: var(--fs-body);
	color: var(--color-text-muted);
	line-height: 1.7;
	max-width: 480px;
	margin: 0 auto 32px;
}

.contact-success__btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 14px 32px;
	background: var(--color-primary);
	color: var(--color-white);
	border-radius: 8px;
	font-weight: var(--font-weight-bold);
	text-decoration: none;
	transition: background-color var(--transition-fast);
}

.contact-success__btn:hover {
	background: color-mix(in srgb, var(--color-primary) 85%, transparent);
	color: var(--color-white);
	text-decoration: none;
}

/* ── Sidebar ──────────────────────────────────────────────────────────────── */

.contact-sidebar {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.contact-info-card {
	display: flex;
	align-items: flex-start;
	gap: 16px;
	background: var(--color-white);
	border: 1px solid var(--color-border-light);
	border-radius: 12px;
	padding: 20px;
	transition: box-shadow var(--transition-fast), transform var(--transition-fast);
}

.contact-info-card:hover {
	box-shadow: var(--shadow-md);
	transform: translateY(-2px);
}

.contact-info-card__icon-wrap {
	flex-shrink: 0;
	width: 44px;
	height: 44px;
	border-radius: 10px;
	background: rgba(10, 31, 67, 0.06);
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background var(--transition-fast);
}

.contact-info-card:hover .contact-info-card__icon-wrap {
	background: var(--color-primary);
}

.contact-info-card__icon {
	font-size: 22px;
	color: var(--color-primary);
	transition: color var(--transition-fast);
}

.contact-info-card:hover .contact-info-card__icon {
	color: var(--color-white);
}

.contact-info-card__title {
	font-size: 12px;
	font-weight: var(--font-weight-bold);
	color: var(--color-text-muted);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	margin-bottom: 4px;
}

.contact-info-card__value {
	display: block;
	font-size: 15px;
	font-weight: var(--font-weight-semibold);
	color: var(--color-primary);
	text-decoration: none;
	line-height: 1.4;
	transition: color var(--transition-fast);
}

a.contact-info-card__value:hover {
	color: var(--color-red);
}

.contact-info-card__note {
	font-size: 12px;
	color: var(--color-text-muted);
	margin-top: 2px;
}

/* Hours Card */

.contact-hours-card {
	background: var(--color-primary);
	border-radius: 12px;
	padding: 24px;
}

.contact-hours-card__header {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 20px;
}

.contact-hours-card__header .material-symbols-outlined {
	font-size: 22px;
	color: var(--color-red);
}

.contact-hours-card__title {
	font-size: var(--fs-body);
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
}

.contact-hours-card__list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.contact-hours-card__row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-size: var(--fs-sm);
	color: rgba(255, 255, 255, 0.8);
	padding: 10px 0;
	border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.contact-hours-card__row:last-child {
	padding-bottom: 0;
	border-bottom: none;
}

.contact-hours-card__row--closed span:last-child {
	color: #f87171;
	font-weight: var(--font-weight-semibold);
}

/* Sidebar image */

.contact-sidebar-img {
	border-radius: 12px;
	overflow: hidden;
	line-height: 0;
}

.contact-sidebar-img img {
	width: 100%;
	height: 200px;
	object-fit: cover;
	display: block;
}

/* ── Section 3 — Map ──────────────────────────────────────────────────────── */

.contact-map-section {
	margin-top: 80px;
}

.contact-map-section__inner {
	position: relative;
	height: 500px;
	overflow: hidden;
	background-color: var(--color-bg-light);
}

.contact-map-section__iframe,
.contact-map-section__img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	border: 0;
	display: block;
}

.contact-map-section__placeholder {
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, #dde3ea 0%, #c8d0db 100%);
}

/* Map pin + pulse */

.contact-map-pin {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 10;
	display: flex;
	align-items: center;
	justify-content: center;
}

.contact-map-pin__dot {
	display: block;
	width: 18px;
	height: 18px;
	background: var(--color-primary);
	border: 3px solid var(--color-white);
	border-radius: 50%;
	box-shadow: 0 2px 8px rgba(10, 31, 67, 0.4);
	position: relative;
	z-index: 2;
}

.contact-map-pin__pulse {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 18px;
	height: 18px;
	background: var(--color-primary);
	border-radius: 50%;
	animation: pureox-map-pulse 2s ease-out infinite;
	opacity: 0;
}

@keyframes pureox-map-pulse {
	0%   { transform: translate(-50%, -50%) scale(1);   opacity: 0.6; }
	100% { transform: translate(-50%, -50%) scale(3.5); opacity: 0;   }
}

/* Directions button */

.contact-map-section__actions {
	position: absolute;
	bottom: 24px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 20;
}

.contact-map-section__btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: var(--color-white);
	color: var(--color-primary);
	border-radius: 100px;
	padding: 12px 28px;
	font-family: var(--font-primary);
	font-size: 15px;
	font-weight: var(--font-weight-bold);
	text-decoration: none;
	white-space: nowrap;
	box-shadow: 0 4px 20px rgba(10, 31, 67, 0.2);
	transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.contact-map-section__btn:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 30px rgba(10, 31, 67, 0.3);
	color: var(--color-primary);
	text-decoration: none;
}

.contact-map-section__btn .material-symbols-outlined {
	font-size: 20px;
	color: var(--color-red);
}

/* ── Section 4: Supplier / Manufacturer Contact Card ─────────────── */

.supplier-contact-section {
	padding: 80px 0;
}

.supplier-contact-section__header {
	text-align: center;
	margin-bottom: 48px;
}

.supplier-contact-section__label {
	font-size: 13px;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--color-red);
	margin: 0 0 10px;
}

.supplier-contact-section__company {
	font-size: clamp(22px, 3.5vw, 34px);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	margin: 0;
}

.supplier-card {
	background: var(--color-white);
	border-radius: 16px;
	box-shadow: 0 4px 32px rgba(10, 31, 67, 0.08);
	border: 1px solid rgba(10, 31, 67, 0.07);
	overflow: hidden;
}

/* ── Factory addresses row ───────────────────────────────────────── */

.supplier-card__addresses {
	display: flex;
	flex-wrap: wrap;
	gap: 0;
	border-bottom: 1px solid var(--color-border);
}

.supplier-address {
	display: flex;
	align-items: flex-start;
	gap: 14px;
	padding: 28px 32px;
	flex: 1 1 220px;
	border-right: 1px solid var(--color-border);
}

.supplier-address:last-child {
	border-right: none;
}

.supplier-address__icon {
	color: var(--color-red);
	font-size: 24px;
	flex-shrink: 0;
	margin-top: 2px;
}

.supplier-address__label {
	display: block;
	font-size: 12px;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--color-red);
	margin-bottom: 6px;
}

.supplier-address__line {
	font-size: var(--fs-sm);
	color: var(--color-text);
	line-height: 1.6;
	margin: 0;
}

.supplier-address__link {
	font-size: var(--fs-sm);
	color: var(--color-primary);
	font-weight: var(--font-weight-semibold);
	text-decoration: none;
}

.supplier-address__link:hover {
	color: var(--color-red);
	text-decoration: underline;
}

/* ── Contact Persons ─────────────────────────────────────────────── */

.supplier-card__persons-wrap {
	padding: 36px 32px;
}

.supplier-card__persons-heading {
	font-size: 13px;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--color-primary);
	margin: 0 0 24px;
	padding-bottom: 12px;
	border-bottom: 2px solid var(--color-red);
	display: inline-block;
}

.supplier-persons-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
}

.supplier-person {
	background: var(--color-bg-light);
	border-radius: 12px;
	padding: 24px;
	border: 1px solid rgba(10, 31, 67, 0.06);
}

.supplier-person__name {
	font-size: 17px;
	font-weight: var(--font-weight-bold);
	color: var(--color-accent);
	margin: 0 0 4px;
}

.supplier-person__role {
	font-size: 13px;
	color: var(--color-text-light);
	margin: 0 0 16px;
}

.supplier-person__contacts {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.supplier-person__mob {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: var(--fs-sm);
	font-weight: var(--font-weight-semibold);
	color: var(--color-primary);
	text-decoration: none;
	transition: color 0.2s;
}

.supplier-person__mob:hover {
	color: var(--color-red);
}

.supplier-person__mob .material-symbols-outlined {
	font-size: 18px;
	color: var(--color-red);
	flex-shrink: 0;
}

/* =============================================================================
   PORTFOLIO PAGE — page-portfolio.php
   ============================================================================= */

/* ── Project Tag Color System ─────────────────────────────────────────────── */

.tag-badge {
	display: inline-block;
	font-size: 10px;
	font-weight: var(--font-weight-bold);
	text-transform: uppercase;
	letter-spacing: 0.16em;
	padding: 4px 12px;
	border-radius: 9999px;
	border: 1px solid;
	line-height: 1.4;
}

.tag-oxygen {
	background: rgba(0, 180, 216, 0.25);
	color: var(--color-accent);
	border-color: rgba(0, 180, 216, 0.4);
}

.tag-steel {
	background: rgba(255, 255, 255, 0.12);
	color: rgba(255, 255, 255, 0.85);
	border-color: rgba(255, 255, 255, 0.2);
}

.tag-fabrication {
	background: rgba(255, 180, 0, 0.15);
	color: #FFB400;
	border-color: rgba(255, 180, 0, 0.3);
}

.tag-peb {
	background: rgba(100, 200, 120, 0.15);
	color: #64C878;
	border-color: rgba(100, 200, 120, 0.3);
}

.tag-medical {
	background: rgba(239, 68, 68, 0.12);
	color: #EF4444;
	border-color: rgba(239, 68, 68, 0.25);
}

/* ── Section 1 — Dark Hero ────────────────────────────────────────────────── */

.pf-hero {
	position: relative;
	overflow: hidden;
	background: var(--color-primary);
	padding: 80px 0 72px;
}

.pf-hero__dot-grid {
	position: absolute;
	inset: 0;
	background-image: radial-gradient(rgba(255, 255, 255, 0.04) 1px, transparent 1px);
	background-size: 28px 28px;
	pointer-events: none;
}

.pf-hero__glow-orb {
	position: absolute;
	width: 500px;
	height: 500px;
	right: -120px;
	top: -120px;
	background: radial-gradient(circle, rgba(0, 180, 216, 0.12) 0%, transparent 70%);
	pointer-events: none;
}

.pf-hero__container {
	position: relative;
	z-index: 2;
}

.pf-hero__breadcrumb-list {
	display: flex;
	align-items: center;
	gap: 8px;
	list-style: none;
	margin: 0 0 40px;
	padding: 0;
	font-size: var(--fs-sm);
}

.pf-hero__breadcrumb-link {
	color: rgba(255, 255, 255, 0.72);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.pf-hero__breadcrumb-link:hover {
	color: rgba(255, 255, 255, 0.9);
}

.pf-hero__breadcrumb-sep {
	color: rgba(255, 255, 255, 0.3);
}

.pf-hero__breadcrumb-current {
	color: rgba(255, 255, 255, 0.85);
}

.pf-hero__grid {
	display: grid;
	grid-template-columns: 1fr auto;
	align-items: end;
	gap: 48px;
}

.pf-hero__badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: rgba(0, 180, 216, 0.15);
	border: 1px solid rgba(0, 180, 216, 0.3);
	color: var(--color-accent);
	font-size: 11px;
	font-weight: var(--font-weight-bold);
	text-transform: uppercase;
	letter-spacing: 0.18em;
	padding: 5px 14px;
	border-radius: 9999px;
	margin-bottom: 20px;
}

.pf-hero__badge-icon {
	font-size: var(--fs-sm);
}

.pf-hero__heading {
	font-size: var(--fs-h1);
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	line-height: var(--lh-tight);
	letter-spacing: -0.02em;
	margin-bottom: 24px;
}

.pf-hero__heading em {
	font-style: normal;
	color: var(--color-accent);
}

.pf-hero__sub {
	font-size: var(--fs-body-lg);
	color: var(--color-text-on-dark);
	line-height: var(--lh-body);
	max-width: 560px;
}

/* Hero stats (right column) */

.pf-hero__stats {
	display: flex;
	flex-direction: column;
	gap: 24px;
	align-self: end;
}

.pf-hero__stat {
	text-align: right;
}

.pf-hero__stat-num {
	display: block;
	font-size: 44px;
	font-weight: var(--font-weight-bold);
	color: var(--color-accent);
	line-height: 1;
}

.pf-hero__stat-label {
	font-size: 11px;
	font-weight: var(--font-weight-bold);
	color: rgba(255, 255, 255, 0.65);
	text-transform: uppercase;
	letter-spacing: 0.1em;
}

/* ── Section 2 — Sticky Filter Bar ───────────────────────────────────────── */

.pf-filter-bar {
	position: sticky;
	top: 80px;
	z-index: 50;
	background: var(--color-white);
	border-bottom: 1px solid rgba(10, 31, 67, 0.08);
	height: 72px;
	display: flex;
	align-items: center;
}

.pf-filter-bar__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
}

.pf-filter-tabs {
	display: flex;
	align-items: center;
	gap: 4px;
	flex-shrink: 0;
}

.pf-filter-tab {
	padding: 8px 20px;
	border-radius: 8px;
	font-family: var(--font-primary);
	font-size: var(--fs-sm);
	font-weight: var(--font-weight-bold);
	border: none;
	cursor: pointer;
	background: transparent;
	color: rgba(10, 31, 67, 0.6);
	transition: background-color var(--transition-fast), color var(--transition-fast);
	white-space: nowrap;
}

.pf-filter-tab:hover {
	background: var(--color-bg-light);
	color: var(--color-primary);
}

.pf-filter-tab.is-active {
	background: var(--color-primary);
	color: var(--color-white);
}

.pf-filter-bar__controls {
	display: flex;
	align-items: center;
	gap: 16px;
	flex-shrink: 0;
}

.pf-filter-count {
	font-size: 13px;
	color: rgba(10, 31, 67, 0.6);
	white-space: nowrap;
}

.pf-filter-count strong {
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
}

.pf-view-toggle {
	display: flex;
	gap: 4px;
}

.pf-view-btn {
	width: 36px;
	height: 36px;
	border-radius: 8px;
	border: 1px solid rgba(10, 31, 67, 0.08);
	background: transparent;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	color: rgba(10, 31, 67, 0.5);
	transition: background-color var(--transition-fast), color var(--transition-fast),
	            border-color var(--transition-fast);
}

.pf-view-btn:hover,
.pf-view-btn.is-active {
	background: var(--color-primary);
	color: var(--color-white);
	border-color: var(--color-primary);
}

.pf-view-btn .material-symbols-outlined {
	font-size: 20px;
}

/* ── Section 3 — Featured Project ────────────────────────────────────────── */

.pf-featured-wrap {
	padding-top: 60px;
	margin-bottom: 64px;
}

.pf-featured-label {
	display: flex;
	align-items: center;
	gap: 16px;
	margin-bottom: 24px;
	font-size: 11px;
	font-weight: var(--font-weight-bold);
	color: rgba(10, 31, 67, 0.4);
	text-transform: uppercase;
	letter-spacing: 0.12em;
}

.pf-featured-label__line {
	flex: 1;
	height: 1px;
	background: rgba(10, 31, 67, 0.1);
}

.pf-featured-card {
	position: relative;
	height: 500px;
	border-radius: 24px;
	overflow: hidden;
	background-color: var(--color-primary);
	background-image: var(--pf-featured-img, none);
	background-size: cover;
	background-position: center;
	transition: background-size 0.8s ease;
}

.pf-featured-card:hover {
	background-size: 104%;
}

.pf-featured-card__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(10, 31, 67, 0.92) 0%, rgba(10, 31, 67, 0.5) 55%, transparent 100%);
}

.pf-featured-card__badge {
	position: absolute;
	top: 32px;
	right: 32px;
	z-index: 3;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: var(--color-accent);
	color: var(--color-white);
	font-size: 11px;
	font-weight: var(--font-weight-bold);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	padding: 6px 16px;
	border-radius: 9999px;
}

.pf-featured-card__badge-icon {
	font-size: var(--fs-sm);
}

.pf-featured-card__content {
	position: absolute;
	bottom: 0;
	left: 0;
	padding: 48px;
	max-width: 620px;
	z-index: 2;
}

.pf-featured-card__tag {
	margin-bottom: 16px;
}

.pf-featured-card__heading {
	font-size: 36px;
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	line-height: 1.2;
	margin-bottom: 16px;
}

.pf-featured-card__desc {
	font-size: var(--fs-body);
	color: rgba(255, 255, 255, 0.7);
	line-height: 1.65;
	margin-bottom: 24px;
}

.pf-featured-card__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
}

.pf-featured-card__meta-item {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	color: rgba(255, 255, 255, 0.75);
}

.pf-featured-card__meta-icon {
	font-size: var(--fs-body);
	color: var(--color-accent);
}

.pf-featured-card__cta {
	position: absolute;
	bottom: 48px;
	right: 48px;
	z-index: 3;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: var(--color-white);
	color: var(--color-primary);
	border-radius: 10px;
	padding: 14px 28px;
	font-family: var(--font-primary);
	font-size: var(--fs-sm);
	font-weight: var(--font-weight-bold);
	text-decoration: none;
	transition: background-color var(--transition-fast), color var(--transition-fast),
	            transform var(--transition-fast);
}

.pf-featured-card__cta:hover {
	background: var(--color-accent);
	color: var(--color-white);
	transform: translateY(-2px);
	text-decoration: none;
}

/* ── Section 4 & 6 — Project Section Headers ─────────────────────────────── */

.pf-section__header {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 24px;
	margin-bottom: 32px;
}

.pf-section__title {
	font-size: 28px;
	font-weight: var(--font-weight-bold);
	color: var(--color-heading);
	margin-bottom: 8px;
}

.pf-section__sub {
	font-size: 15px;
	color: var(--color-text-muted);
	line-height: 1.6;
	max-width: 520px;
}

.pf-section__view-all {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: var(--fs-sm);
	font-weight: var(--font-weight-bold);
	color: var(--color-accent);
	text-decoration: none;
	white-space: nowrap;
	flex-shrink: 0;
	transition: gap var(--transition-fast);
}

.pf-section__view-all:hover {
	gap: 10px;
	text-decoration: none;
	color: var(--color-accent);
}

.pf-section__view-all .material-symbols-outlined {
	font-size: 18px;
}

/* ── Portfolio Grids ──────────────────────────────────────────────────────── */

.portfolio-grid {
	display: grid;
	gap: 28px;
}

.portfolio-grid--3 {
	grid-template-columns: repeat(3, 1fr);
}

.portfolio-grid--2 {
	grid-template-columns: repeat(2, 1fr);
}

/* ── Project Card ─────────────────────────────────────────────────────────── */

.project-card {
	display: flex;
	flex-direction: column;
	background: var(--color-white);
	border: 1px solid rgba(10, 31, 67, 0.08);
	border-radius: 16px;
	overflow: hidden;
	transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.project-card:hover {
	transform: translateY(-6px);
	box-shadow: 0 20px 60px rgba(10, 31, 67, 0.14);
}

/* Image area */

.project-card__img-wrap {
	position: relative;
	overflow: hidden;
	background: var(--color-primary);
	flex-shrink: 0;
}

.project-card__img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s ease;
}

.project-card:hover .project-card__img {
	transform: scale(1.08);
}

.project-card__img-placeholder {
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, var(--color-bg-dark) 0%, var(--color-primary) 60%, #081732 100%);
}

.project-card__img-placeholder::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image: radial-gradient(rgba(0, 180, 216, 0.06) 1px, transparent 1px);
	background-size: 20px 20px;
}

.project-card__img-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(10, 31, 67, 0.7) 0%, transparent 55%);
}

.project-card__img-bar {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 14px 16px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	z-index: 2;
}

.project-card__year {
	font-size: 11px;
	font-weight: var(--font-weight-bold);
	color: rgba(255, 255, 255, 0.72);
	letter-spacing: 0.05em;
}

/* Card body */

.project-card__body {
	padding: 24px;
	flex: 1;
	display: flex;
	flex-direction: column;
}

.project-card__title {
	font-size: 18px;
	font-weight: var(--font-weight-bold);
	color: var(--color-heading);
	line-height: 1.35;
	margin-bottom: 10px;
}

.project-card__desc {
	font-size: var(--fs-sm);
	color: var(--color-text);
	line-height: 1.65;
	flex: 1;
	margin-bottom: 20px;
}

/* Specs grid (2×2) */

.project-card__specs {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
	padding-top: 20px;
	border-top: 1px solid rgba(10, 31, 67, 0.08);
}

.project-card__spec-label {
	display: block;
	font-size: 10px;
	font-weight: var(--font-weight-bold);
	color: rgba(10, 31, 67, 0.4);
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.project-card__spec-value {
	display: block;
	font-size: 13px;
	font-weight: var(--font-weight-semibold);
	color: var(--color-primary);
	margin-top: 3px;
}

/* Card footer */

.project-card__footer {
	padding: 16px 24px;
	border-top: 1px solid rgba(10, 31, 67, 0.08);
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.project-card__location {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	color: var(--color-text-muted);
}

.project-card__loc-icon {
	font-size: 15px;
	color: var(--color-accent);
}

.project-card__arrow {
	width: 32px;
	height: 32px;
	border-radius: 8px;
	background: var(--color-bg-light);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-primary);
	text-decoration: none;
	transition: background-color var(--transition-fast), color var(--transition-fast);
	flex-shrink: 0;
}

.project-card__arrow:hover {
	background: var(--color-accent);
	color: var(--color-white);
}

.project-card__arrow .material-symbols-outlined {
	font-size: 18px;
}

/* List view mode */

.portfolio-grid--list .project-card {
	flex-direction: row;
}

.portfolio-grid--list .project-card__img-wrap {
	width: 240px;
	height: auto !important;
	flex-shrink: 0;
}

.portfolio-grid--list .project-card__footer {
	border-top: none;
	border-left: 1px solid rgba(10, 31, 67, 0.08);
	flex-direction: column;
	align-items: flex-end;
	justify-content: flex-end;
	padding: 24px;
	gap: 12px;
	min-width: 120px;
}

/* Filtering: hidden state */
.project-card.is-filtered-out,
.pf-featured-wrap.is-filtered-out,
[data-portfolio-group].is-filtered-out {
	display: none;
}

/* ── Section 5 — Metrics Band ─────────────────────────────────────────────── */

.pf-metrics .container {
	margin-bottom: 80px;
}

.pf-metrics__card {
	position: relative;
	overflow: hidden;
	background: var(--color-primary);
	border-radius: 24px;
	padding: 56px 64px;
}

.pf-metrics__dot-grid {
	position: absolute;
	inset: 0;
	background-image: radial-gradient(rgba(255, 255, 255, 0.04) 1px, transparent 1px);
	background-size: 28px 28px;
	pointer-events: none;
}

.pf-metrics__glow-orb {
	position: absolute;
	width: 400px;
	height: 400px;
	right: -100px;
	top: -100px;
	background: radial-gradient(circle, rgba(0, 180, 216, 0.15) 0%, transparent 70%);
	pointer-events: none;
}

.pf-metrics__grid {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 40px;
}

.pf-metrics__cell {
	text-align: center;
}

.pf-metrics__number {
	font-size: 56px;
	font-weight: var(--font-weight-bold);
	color: var(--color-accent);
	line-height: 1;
	margin-bottom: 12px;
	display: flex;
	align-items: baseline;
	justify-content: center;
}

.pf-metrics__suffix {
	font-size: 36px;
	font-weight: var(--font-weight-bold);
	color: var(--color-accent);
}

.pf-metrics__label {
	font-size: 13px;
	font-weight: var(--font-weight-semibold);
	color: rgba(255, 255, 255, 0.72);
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

/* ── Section 7 — Industries ───────────────────────────────────────────────── */

.pf-industries__grid {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 16px;
	margin-top: 32px;
}

.pf-industry-card {
	background: var(--color-white);
	border: 1px solid rgba(10, 31, 67, 0.08);
	border-radius: 12px;
	padding: 28px 20px;
	text-align: center;
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast),
	            transform var(--transition-fast);
}

.pf-industry-card:hover {
	border-color: var(--color-accent);
	box-shadow: 0 8px 32px rgba(0, 180, 216, 0.12);
	transform: translateY(-3px);
}

.pf-industry-card__icon-wrap {
	width: 52px;
	height: 52px;
	border-radius: 12px;
	background: var(--color-bg-light);
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 16px;
	transition: background-color var(--transition-fast), color var(--transition-fast);
}

.pf-industry-card:hover .pf-industry-card__icon-wrap {
	background: var(--color-primary);
}

.pf-industry-card__icon {
	font-size: 26px;
	color: var(--color-primary);
	transition: color var(--transition-fast);
}

.pf-industry-card:hover .pf-industry-card__icon {
	color: var(--color-white);
}

.pf-industry-card__name {
	font-size: 13px;
	font-weight: var(--font-weight-bold);
	color: var(--color-heading);
	margin-bottom: 4px;
}

.pf-industry-card__count {
	font-size: 11px;
	color: var(--color-text-muted);
}

/* ── Section 8 — Testimonial ──────────────────────────────────────────────── */

.pf-testi-card {
	background: var(--color-bg-light);
	border: 1px solid rgba(10, 31, 67, 0.08);
	border-radius: 24px;
	padding: 56px;
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 48px;
	align-items: start;
	margin-bottom: 80px;
}

.pf-testi-card__quotemark {
	font-family: var(--font-quote, Georgia, serif);
	font-size: 72px;
	color: var(--color-accent);
	line-height: 1;
	margin-bottom: 16px;
}

.pf-testi-card__blockquote {
	margin: 0;
}

.pf-testi-card__blockquote p {
	font-size: 22px;
	font-weight: 500;
	font-style: italic;
	color: var(--color-primary);
	line-height: 1.55;
	margin-bottom: 32px;
}

.pf-testi-card__author {
	display: flex;
	align-items: center;
	gap: 14px;
}

.pf-testi-card__avatar {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background: var(--color-primary);
	color: var(--color-white);
	font-size: var(--fs-body);
	font-weight: var(--font-weight-bold);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	overflow: hidden;
}

.pf-testi-card__avatar-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.pf-testi-card__name {
	display: block;
	font-size: 15px;
	font-weight: var(--font-weight-bold);
	color: var(--color-heading);
}

.pf-testi-card__role {
	font-size: 13px;
	color: var(--color-text-muted);
}

/* ISO cert card */

.pf-iso-card {
	background: var(--color-white);
	border: 1px solid rgba(10, 31, 67, 0.08);
	border-radius: 16px;
	padding: 32px;
	text-align: center;
	min-width: 220px;
}

.pf-iso-card__icon {
	font-size: 40px;
	color: var(--color-accent);
	display: block;
	margin-bottom: 16px;
}

.pf-iso-card__title {
	font-size: 20px;
	font-weight: var(--font-weight-bold);
	color: var(--color-heading);
	margin-bottom: 12px;
}

.pf-iso-card__sub {
	font-size: 13px;
	color: var(--color-text-muted);
	line-height: 1.6;
}

/* ── Section 9 — CTA Banner ───────────────────────────────────────────────── */

.pf-cta-card {
	position: relative;
	overflow: hidden;
	background: var(--color-primary);
	border-radius: 24px;
	padding: 72px 80px;
	text-align: center;
	color: var(--color-white);
	margin-bottom: 0;
}

.pf-cta-card__blur {
	position: absolute;
	width: 400px;
	height: 400px;
	background: radial-gradient(circle, rgba(0, 180, 216, 0.2) 0%, transparent 70%);
	top: -100px;
	right: -100px;
	pointer-events: none;
}

.pf-cta-card__eyebrow {
	color: var(--color-accent);
	margin-bottom: 16px;
}

.pf-cta-card__heading {
	font-size: clamp(28px, 3.5vw, 44px);
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	line-height: 1.2;
	margin-bottom: 20px;
}

.pf-cta-card__sub {
	font-size: 18px;
	color: rgba(255, 255, 255, 0.88);
	line-height: 1.7;
	max-width: 600px;
	margin: 0 auto 40px;
}

.pf-cta-card__actions {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 16px;
}

.pf-cta-card__btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 16px 36px;
	border-radius: var(--radius-sm);
	font-family: var(--font-primary);
	font-size: var(--fs-body-lg);
	font-weight: var(--font-weight-bold);
	text-decoration: none;
	transition: background-color var(--transition-fast), transform var(--transition-fast);
}

.pf-cta-card__btn--primary {
	background: var(--color-white);
	color: var(--color-primary);
}

.pf-cta-card__btn--primary:hover {
	background: rgba(255, 255, 255, 0.9);
	color: var(--color-primary);
	text-decoration: none;
	transform: translateY(-2px);
}

.pf-cta-card__btn--outline {
	background: transparent;
	color: var(--color-white);
	border: 2px solid rgba(255, 255, 255, 0.4);
}

.pf-cta-card__btn--outline:hover {
	border-color: var(--color-white);
	background: rgba(255, 255, 255, 0.1);
	color: var(--color-white);
	text-decoration: none;
}

/* =============================================================================
   HOME PAGE — CTA BANNER BACKGROUND IMAGE VARIANT
   ============================================================================= */

/* Photo layer behind the blueprint dots when a Customizer image is set */
.cta-banner--has-image::after {
	content: '';
	position: absolute;
	inset: 0;
	background-image: var(--home-cta-img, none);
	background-size: cover;
	background-position: center;
	opacity: 0.18;
	z-index: 0;
}

/* Lift blueprint dots above the photo */
.cta-banner--has-image::before { z-index: 1; }

/* Lift text content above both layers */
.cta-banner--has-image > * {
	position: relative;
	z-index: 2;
}

/* =============================================================================
   ABOUT INNER PAGES — page-about-inner.php (Mission, Quality, Director, Facilities)
   ============================================================================= */

/* ── Section 1 — Hero ──────────────────────────────────────────────────── */

.about-inner-hero {
	position: relative;
	height: 340px;
	overflow: hidden;
	background-color: var(--color-primary);
	display: flex;
	align-items: flex-end;
}

/* Background photo (reuses --about-hero-img from About Customizer setting) */
.about-inner-hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image: var(--about-hero-img, none);
	background-size: cover;
	background-position: center;
	opacity: 0.35;
	z-index: 1;
}

/* Gradient: solid navy bottom → transparent top */
.about-inner-hero::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, var(--color-primary) 0%, var(--color-primary) 45%, transparent 100%);
	z-index: 2;
}

.about-inner-hero__content {
	position: relative;
	z-index: 20;
	padding-bottom: 48px;
}

.about-inner-hero__breadcrumb { margin-bottom: 20px; }

.about-inner-hero__breadcrumb-list {
	display: flex;
	align-items: center;
	gap: 8px;
	list-style: none;
	padding: 0;
	margin: 0;
	font-size: 13px;
	font-weight: var(--font-weight-semibold);
	color: rgba(255, 255, 255, 0.78);
}

.about-inner-hero__breadcrumb-sep { color: rgba(255, 255, 255, 0.4); }

.about-inner-hero__breadcrumb-link {
	color: rgba(255, 255, 255, 0.78);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.about-inner-hero__breadcrumb-link:hover { color: var(--color-white); }

.about-inner-hero__heading {
	font-size: clamp(28px, 4vw, 48px);
	font-weight: var(--font-weight-bold);
	color: var(--color-white);
	line-height: 1.15;
	max-width: 700px;
	margin: 0;
}

.about-inner-hero__sub {
	font-size: 17px;
	font-weight: 300;
	color: rgba(255, 255, 255, 0.8);
	line-height: 1.7;
	max-width: 580px;
	margin-top: 16px;
	margin-bottom: 0;
}

/* ── Section 2 — Content ───────────────────────────────────────────────── */

.about-inner-content { padding: 80px 0; }

.about-inner-content__wrap {
	max-width: 860px;
	margin: 0 auto;
}

/* ── WP Editor (entry-content) typography ──────────────────────────────── */

.entry-content h2 {
	font-size: clamp(22px, 3vw, 32px);
	font-weight: var(--font-weight-bold);
	color: var(--color-primary);
	margin-top: 56px;
	margin-bottom: 20px;
	padding-bottom: 12px;
	border-bottom: 2px solid var(--color-accent);
	display: inline-block;
}

.entry-content h2:first-child { margin-top: 0; }

.entry-content h3 {
	font-size: clamp(18px, 2.5vw, 24px);
	font-weight: var(--font-weight-semibold);
	color: var(--color-primary);
	margin-top: 40px;
	margin-bottom: 16px;
}

.entry-content p {
	font-size: 17px;
	color: var(--color-text);
	line-height: 1.8;
	margin-bottom: 24px;
}

/* Unordered lists — custom cyan dot replaces browser disc */
.entry-content ul {
	list-style: none;
	padding-left: 0;
	margin-bottom: 28px;
}

.entry-content ul > li {
	position: relative;
	padding-left: 22px;
}

.entry-content ul > li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0.64em;
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: var(--color-accent);
	flex-shrink: 0;
}

/* Nested unordered lists — smaller dot, same colour */
.entry-content ul ul > li::before {
	width: 5px;
	height: 5px;
	top: 0.68em;
	background: var(--color-accent-dark, var(--color-accent));
	opacity: 0.65;
}

/* Ordered lists — keep numbers, accent colour */
.entry-content ol {
	padding-left: 24px;
	margin-bottom: 28px;
}

.entry-content ol > li::marker {
	color: var(--color-accent);
	font-weight: 700;
	font-size: 0.95em;
}

/* Shared li typography */
.entry-content li {
	font-size: var(--fs-body);
	color: var(--color-text);
	line-height: 1.85;
	margin-bottom: 12px;
}

.entry-content strong { color: var(--color-primary); }

.entry-content a {
	color: var(--color-accent);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
}

.entry-content a:hover { color: var(--color-accent-dark); }

/* =============================================================================
   SINGLE PORTFOLIO (single-portfolio.php)
   ============================================================================= */

.portfolio-single-hero {
	background: var(--color-primary);
	padding: 120px 0 60px;
	position: relative;
	overflow: hidden;
}

.portfolio-single-hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(circle at 70% 50%, rgba(0, 180, 216, 0.18) 0, transparent 60%);
	pointer-events: none;
}

.portfolio-single-hero__inner { position: relative; }

/* Breadcrumb */
.portfolio-single-hero__breadcrumb ol {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 4px 8px;
	list-style: none;
	padding: 0;
	margin: 0 0 28px;
	font-size: 13px;
}

.portfolio-single-hero__breadcrumb a {
	color: rgba(255, 255, 255, 0.78);
	transition: color var(--transition-base);
}

.portfolio-single-hero__breadcrumb a:hover { color: var(--color-white); }

.portfolio-single-hero__breadcrumb li[aria-hidden] {
	color: rgba(255, 255, 255, 0.35);
}

.portfolio-single-hero__breadcrumb [aria-current="page"] {
	color: rgba(255, 255, 255, 0.9);
}

/* Tag + year row */
.portfolio-single-hero__tag-row {
	display: flex;
	align-items: center;
	gap: 16px;
	margin-bottom: 20px;
}

.portfolio-single-hero__year {
	font-size: var(--fs-sm);
	font-weight: 500;
	color: rgba(255, 255, 255, 0.72);
}

/* Title */
.portfolio-single-hero__title {
	font-size: clamp(30px, 5vw, 52px);
	font-weight: 800;
	color: var(--color-white);
	line-height: 1.15;
	margin: 0 0 20px;
	max-width: 820px;
}

/* Location */
.portfolio-single-hero__location {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 15px;
	color: rgba(255, 255, 255, 0.82);
	margin: 0;
}

.portfolio-single-hero__location .material-symbols-outlined {
	font-size: 18px;
	color: var(--color-accent);
}

/* ── Featured image ────────────────────────────────────────────────── */

.portfolio-single-thumb {
	background: var(--color-primary);
	padding-bottom: 0;
}

.portfolio-single-thumb__img {
	width: 100%;
	max-height: 520px;
	object-fit: cover;
	display: block;
	border-radius: 12px 12px 0 0;
}

/* ── Meta band ─────────────────────────────────────────────────────── */

.portfolio-meta-band {
	background: var(--color-primary);
	padding: 0 0 64px;
}

.portfolio-meta-band__list {
	display: flex;
	flex-wrap: wrap;
	list-style: none;
	padding: 0;
	margin: 0;
	border-radius: 0 0 12px 12px;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-top: none;
	overflow: hidden;
}

.portfolio-meta-band__item {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	padding: 24px 28px;
	flex: 1;
	min-width: 160px;
	border-right: 1px solid rgba(255, 255, 255, 0.1);
}

.portfolio-meta-band__item:last-child { border-right: none; }

.portfolio-meta-band__icon {
	font-size: 22px;
	color: var(--color-accent);
	margin-top: 2px;
	flex-shrink: 0;
}

.portfolio-meta-band__label {
	display: block;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.68);
	margin-bottom: 4px;
}

.portfolio-meta-band__value {
	display: block;
	font-size: 15px;
	font-weight: 600;
	color: var(--color-white);
	margin: 0;
}

/* ── Content footer / back button ──────────────────────────────────── */

.portfolio-single-content__footer {
	margin-top: 48px;
	padding-top: 32px;
	border-top: 1px solid var(--color-border);
}

.portfolio-single-content__footer .btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

/* ── Related projects heading ──────────────────────────────────────── */

.portfolio-related__heading {
	font-size: clamp(22px, 3vw, 32px);
	font-weight: 700;
	color: var(--color-heading);
	margin: 0 0 40px;
}

/* =============================================================================
   SERVICES PAGE — FEATURED PROJECTS SLIDER (svc-projects)
   ============================================================================= */

.svc-projects {
	background: var(--color-bg-light);
	padding: 80px 0;
}

.svc-projects__header {
	text-align: center;
	margin-bottom: 48px;
}

.svc-projects__title {
	font-size: clamp(28px, 4vw, 40px);
	font-weight: 700;
	color: var(--color-heading);
	margin: 12px 0 16px;
}

.svc-projects__sub {
	font-size: 17px;
	color: var(--color-text-muted);
	max-width: 560px;
	margin: 0 auto;
	line-height: 1.65;
}

/* Slider core */
.svc-projects__slider { position: relative; }

.svc-projects__track-wrap { overflow: hidden; }

.svc-projects__track {
	display: flex;
	gap: 24px;
	transition: transform 0.42s cubic-bezier(0.25, 0.46, 0.45, 0.94);
	will-change: transform;
}

/* Slide width is set by JS; this is a visual fallback */
.svc-projects__slide { flex: none; }

/* Controls */
.svc-projects__controls {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 16px;
	margin-top: 36px;
}

.svc-projects__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	border: 2px solid var(--color-primary);
	background: transparent;
	color: var(--color-primary);
	cursor: pointer;
	flex-shrink: 0;
	transition: background var(--transition-base), color var(--transition-base);
}

.svc-projects__btn:hover:not(:disabled) {
	background: var(--color-primary);
	color: var(--color-white);
}

.svc-projects__btn:disabled {
	opacity: 0.3;
	cursor: not-allowed;
}

.svc-projects__dots {
	display: flex;
	align-items: center;
	gap: 8px;
}

.svc-projects__dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	border: none;
	padding: 0;
	background: var(--color-border);
	cursor: pointer;
	transition: background var(--transition-base), transform var(--transition-base);
}

.svc-projects__dot.is-active {
	background: var(--color-accent);
	transform: scale(1.5);
}

/* Footer CTA */
.svc-projects__footer {
	text-align: center;
	margin-top: 48px;
}

.svc-projects__footer .btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}
