:root {
	--langit-primary: #58afff;
	--langit-secondary: #0f172a;
	--langit-accent: #38bdf8;
	--langit-background: #f8fafc;
	--langit-surface: #ffffff;
	--langit-text: #0f172a;
	--langit-muted: #475569;
	--langit-border: #e2e8f0;
	--langit-shadow: 0 20px 50px rgba(15, 23, 42, 0.04), 0 4px 12px rgba(15, 23, 42, 0.015);
	--langit-card-radius: 20px;
	--langit-card-shadow: 0 16px 40px -10px rgba(15, 23, 42, 0.045), 0 1px 3px rgba(15, 23, 42, 0.01);
	--langit-card-shadow-hover: 0 32px 64px -12px rgba(15, 23, 42, 0.1), 0 1px 3px rgba(15, 23, 42, 0.02);
	--langit-media-radius: 20px;
	--langit-font-sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	--langit-container: 1380px;
	--langit-container-wide: 1380px;
	--langit-container-reading: 850px;
	--langit-gutter: 1.5rem;
	--langit-radius: 12px;
	--langit-header-height: 72px;
	--langit-header-scrolled-height: 56px;
	--langit-space-xs: clamp(0.5rem, 0.45rem + 0.25vw, 0.75rem);
	--langit-space-sm: clamp(0.75rem, 0.65rem + 0.5vw, 1rem);
	--langit-space-md: clamp(1rem, 0.8rem + 1vw, 1.5rem);
	--langit-space-lg: clamp(1.75rem, 1.3rem + 2vw, 3rem);
	--langit-space-xl: clamp(3rem, 2rem + 4vw, 6rem);
	--langit-transition-smooth: 0.5s cubic-bezier(0.16, 1, 0.3, 1);
	--langit-transition-fast: 0.25s cubic-bezier(0.16, 1, 0.3, 1);
	--langit-glass-border: rgba(255, 255, 255, 0.08);
	--langit-glass-bg: rgba(255, 255, 255, 0.7);
}

@media (max-width: 430px) {
	:root {
		--langit-gutter: 1rem;
		--langit-space-xl: clamp(2.25rem, 1.9rem + 1.75vw, 3rem);
	}
}

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

html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
	background: var(--langit-background);
	color: var(--langit-text);
	font-family: var(--langit-font-sans);
	font-size: 1rem;
	line-height: 1.75;
	text-rendering: optimizeLegibility;
	-webkit-font-smoothing: antialiased;
}

body.has-open-menu {
	overflow: hidden;
}

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

iframe,
embed,
object {
	max-width: 100%;
}

a {
	color: var(--langit-secondary);
	text-decoration-thickness: 0.08em;
	text-underline-offset: 0.18em;
}

a:hover,
a:focus {
	color: var(--langit-primary);
}

h1,
h2,
h3,
h4,
h5,
h6 {
	margin: 0 0 0.5em;
	color: var(--langit-secondary);
	font-weight: 800;
	line-height: 1.15;
	letter-spacing: -0.015em;
	overflow-wrap: anywhere;
}

h1 {
	font-size: clamp(2rem, 1.5rem + 2vw, 3.8rem);
	letter-spacing: -0.025em;
	line-height: 1.1;
}

h2 {
	font-size: clamp(1.5rem, 1.25rem + 1vw, 2.5rem);
	letter-spacing: -0.02em;
	line-height: 1.2;
}

h3 {
	font-size: clamp(1.25rem, 1.1rem + 0.75vw, 1.75rem);
	letter-spacing: -0.01em;
	line-height: 1.25;
}

p {
	margin: 0 0 1.5rem;
}

ul,
ol {
	margin-top: 0;
}

:focus-visible {
	outline: 3px solid rgba(88, 175, 255, 0.55);
	outline-offset: 3px;
}

.screen-reader-text {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.site {
	min-width: 0;
}

.container,
.u-container,
.site-header__inner,
.site-footer__inner {
	width: min(100% - (var(--langit-gutter) * 2), var(--langit-container));
	margin-inline: auto;
}

.entry-content > * {
	width: min(100% - (var(--langit-gutter) * 2), var(--langit-container-reading));
	margin-inline: auto;
}

.container--wide,
.u-container--wide {
	width: min(100% - (var(--langit-gutter) * 2), var(--langit-container-wide));
	margin-inline: auto;
}

.alignwide {
	width: min(100% - (var(--langit-gutter) * 2), var(--langit-container-wide));
	max-width: var(--langit-container-wide);
}

.alignfull {
	width: 100%;
	max-width: none;
}

.section,
.u-section {
	padding-block: clamp(3rem, 2.1rem + 4.5vw, 6rem);
}

.section--surface,
.u-surface {
	background: var(--langit-surface);
}

/* Blueprint grid tint — subtle technical overlay for enterprise sections */
.section--blueprint {
	background:
		linear-gradient(180deg, rgba(238, 247, 255, 0.72), rgba(245, 250, 255, 0.9)),
		var(--langit-surface);
	position: relative;
	isolation: isolate;
}

.section--blueprint::before {
	position: absolute;
	inset: 0;
	background-image:
		linear-gradient(rgba(88, 175, 255, 0.045) 1px, transparent 1px),
		linear-gradient(90deg, rgba(88, 175, 255, 0.045) 1px, transparent 1px);
	background-position: center;
	background-size: 48px 48px;
	mask-image: linear-gradient(180deg, transparent 0%, #000 14%, #000 86%, transparent 100%);
	pointer-events: none;
	content: "";
	opacity: 0.5;
	z-index: 0;
}

.section--blueprint > * {
	position: relative;
	z-index: 1;
}

.section--navy-gradient {
	background: linear-gradient(180deg, #090f1d 0%, #050a14 100%);
	color: #ffffff;
}

.section--navy-gradient .section-heading h2 {
	color: #ffffff;
}

.section--navy-gradient .section-heading p {
	color: rgba(226, 232, 240, 0.85);
}

.section--compact,
.u-section--compact {
	padding-block: clamp(2.25rem, 1.6rem + 3vw, 4rem);
}

.home-section {
	position: relative;
	border-top: 1px solid rgba(203, 213, 225, 0.56);
}

.home-section:first-of-type {
	border-top: 0;
}

/*
 * Homepage — Section Background Rhythm
 * Hero (dark) → Company (white+glow) → Services (blueprint) →
 * Industry (dark navy) → Projects (cool slate) → Trust (white+separator) →
 * CTA (blueprint tint) → Footer (dark)
 */

/* Company intro: white to soft blue gradient */
.home-section--company {
	background: linear-gradient(180deg, #ffffff 0%, #f4f9ff 100%);
}

/* Trust/Stats: white background with subtle radial blue glow */
.home-section--trust {
	background:
		radial-gradient(circle at 50% 50%, rgba(88, 175, 255, 0.08), transparent 70%),
		#ffffff;
}

/* Services: soft blue gradient (#f8fbff → #eef5fc) — enterprise technical texture */
.home-section--services {
	background:
		linear-gradient(180deg, #f8fbff 0%, #eef5fc 100%);
	position: relative;
	isolation: isolate;
}

.home-section--services::before {
	position: absolute;
	inset: 0;
	background-image:
		linear-gradient(rgba(88, 175, 255, 0.03) 1px, transparent 1px),
		linear-gradient(90deg, rgba(88, 175, 255, 0.03) 1px, transparent 1px);
	background-position: center;
	background-size: 48px 48px;
	mask-image: linear-gradient(180deg, transparent 0%, #000 20%, #000 80%, transparent 100%);
	pointer-events: none;
	content: "";
	opacity: 0.55;
	z-index: 0;
}

.home-section--services > .container {
	position: relative;
	z-index: 1;
}

/* Industries We Serve: light blue-tinted background (#f4f8fc → #eef5fc) */
.home-section--industry {
	background: linear-gradient(180deg, #f4f8fc 0%, #eef5fc 100%);
}

/* Projects: white background (#ffffff → #f7fafc) */
.home-section--projects {
	background: linear-gradient(180deg, #ffffff 0%, #f7fafc 100%);
}

/* Team / FAQ / Certifications: cool slate */
.home-section--team,
.home-section--faq,
.home-section--certifications {
	background:
		linear-gradient(180deg, rgba(241, 245, 249, 0.96), rgba(248, 250, 252, 0.98)),
		#f1f5f9;
}

/* Testimonials / Downloads: clean neutral */
.home-section--testimonials,
.home-section--downloads {
	background:
		linear-gradient(180deg, rgba(248, 250, 252, 0.9), rgba(255, 255, 255, 0.98)),
		var(--langit-surface);
}

/* Elevated card shadows on tinted section backgrounds */
.home-section--services .card,
.home-section--projects .card,
.home-section--faq .card,
.home-section--certifications .card {
	box-shadow: 0 22px 54px rgba(15, 23, 42, 0.08);
}

.home-section--company::after,
.home-section--services::after,
.home-section--projects::after,
.home-section--trust::after {
	position: absolute;
	right: max(var(--langit-gutter), calc((100vw - var(--langit-container)) / 2));
	bottom: 0;
	width: min(18rem, 38vw);
	height: 1px;
	background: linear-gradient(90deg, transparent, rgba(88, 175, 255, 0.4));
	content: "";
}

.company-section,
.products-section {
	position: relative;
	overflow: hidden;
	border-top: 1px solid rgba(88, 175, 255, 0.16);
	isolation: isolate;
}

.company-section:first-of-type,
.products-section:first-of-type {
	border-top: 0;
}

.company-section > .container,
.products-section > .container {
	position: relative;
	z-index: 1;
}

.company-section::before,
.company-section::after,
.products-section::before,
.products-section::after {
	position: absolute;
	content: "";
	pointer-events: none;
}

/* Shared atmospheric gradient separator at the bottom of all sections */
.company-section::after,
.products-section::after {
	bottom: 0;
	left: 0;
	right: 0;
	height: 1px;
	background: linear-gradient(90deg, transparent, rgba(88, 175, 255, 0.22), transparent);
}

/*
 * Company & Products Page Section Background System
 *
 * Design Direction: Apple Enterprise / Modern Architectural Studio.
 * Light theme only. Layered gradients, radial refractions, blueprint spot grids,
 * glassmorphic overlays, and whitespace logic.
 *
 * Palette Flow:
 * 1. White-Steel:          #ffffff to #f4f8fc
 * 2. Blueprint-White:      #eef5fb to #e9f1f8
 * 3. Cool Slate:           #f8fbff to #eef5fb
 * 4. Operational Steel:    #f1f5f9 to #e9eef5
 * 5. Architectural Slate:  #e9f1f8 to #dde8f3
 */

/* =============================================================================
   COMPANY PAGE SECTIONS
   ============================================================================= */

/* ─────────────────────────────────────────────────────────────────────────────
   Overview — Clean White-Steel entry.
   Dual radial refractions bridge the exit from the dark Page Hero section.
───────────────────────────────────────────────────────────────────────────── */
.company-section--overview {
	background:
		radial-gradient(ellipse at 100% 0%, rgba(88, 175, 255, 0.14), transparent 50%),
		radial-gradient(ellipse at 0% 100%, rgba(88, 140, 200, 0.06), transparent 48%),
		linear-gradient(180deg, #ffffff 0%, #f4f8fc 100%);
	color: var(--langit-text);
}

/* Capability tag badges on white-steel background */
.company-section--overview .capability-item {
	border-color: rgba(88, 175, 255, 0.24);
	background: rgba(255, 255, 255, 0.85);
	color: var(--langit-secondary);
	box-shadow: 0 4px 10px -2px rgba(15, 23, 42, 0.03);
}

/* ─────────────────────────────────────────────────────────────────────────────
   Vision & Mission — Blueprint-White with a spot-masked structural grid.
   Spotlight masks keep the technical grid texture strictly inside a central pool.
───────────────────────────────────────────────────────────────────────────── */
.company-section--vision {
	background:
		radial-gradient(ellipse at 15% 0%, rgba(88, 175, 255, 0.12), transparent 44%),
		radial-gradient(ellipse at 85% 100%, rgba(56, 189, 248, 0.08), transparent 40%),
		linear-gradient(180deg, #eef5fb 0%, #e9f1f8 100%);
	color: var(--langit-text);
}

.company-section--vision::before {
	inset: 0;
	background-image:
		linear-gradient(rgba(88, 175, 255, 0.04) 1px, transparent 1px),
		linear-gradient(90deg, rgba(88, 175, 255, 0.04) 1px, transparent 1px);
	background-position: center;
	background-size: 48px 48px;
	mask-image: radial-gradient(circle at 50% 50%, #000 30%, transparent 80%);
	-webkit-mask-image: radial-gradient(circle at 50% 50%, #000 30%, transparent 80%);
	opacity: 0.8;
}

.company-section--vision .card {
	border-color: rgba(88, 175, 255, 0.2);
	background: var(--langit-surface);
	box-shadow: 0 16px 40px -10px rgba(15, 23, 42, 0.07);
}

.company-section--vision .mission-list {
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
	padding-left: 1.25rem;
}

.company-section--vision .mission-list li::marker {
	color: var(--langit-primary);
}

/* ─────────────────────────────────────────────────────────────────────────────
   Why Choose Us — Cool Slate atmosphere.
   Subtle radial glows make the clean white cards elevate as premium surfaces.
───────────────────────────────────────────────────────────────────────────── */
.company-section--why {
	background:
		radial-gradient(ellipse at 95% 15%, rgba(88, 175, 255, 0.1), transparent 44%),
		radial-gradient(ellipse at 5% 85%, rgba(88, 175, 255, 0.06), transparent 38%),
		linear-gradient(180deg, #f8fbff 0%, #eef5fb 100%);
	color: var(--langit-text);
}

.company-section--why .card {
	border-color: rgba(88, 175, 255, 0.2);
	background: var(--langit-surface);
	box-shadow: 0 18px 44px -10px rgba(15, 23, 42, 0.06);
}

.company-section--why .service-card__icon {
	border-color: rgba(88, 175, 255, 0.26);
	background: linear-gradient(135deg, rgba(88, 175, 255, 0.08), rgba(56, 189, 248, 0.04));
}

/* ─────────────────────────────────────────────────────────────────────────────
   Company Values — Operational Slate-Steel.
   Very clean, lightweight corporate tones with soft refractions.
───────────────────────────────────────────────────────────────────────────── */
.company-section--values {
	background:
		radial-gradient(ellipse at 80% 10%, rgba(88, 175, 255, 0.1), transparent 44%),
		linear-gradient(180deg, #f1f5f9 0%, #e9eef5 100%);
	color: var(--langit-text);
}

.company-section--values .card {
	border-color: rgba(88, 175, 255, 0.18);
	background: var(--langit-surface);
	box-shadow: 0 16px 40px -10px rgba(15, 23, 42, 0.06);
}

.company-section--values .service-card__icon {
	border-color: rgba(88, 175, 255, 0.24);
	background: linear-gradient(135deg, rgba(88, 175, 255, 0.08), rgba(56, 189, 248, 0.04));
}

/* ─────────────────────────────────────────────────────────────────────────────
   Operational Workflow — Architectural Slate with a masked workflow grid.
───────────────────────────────────────────────────────────────────────────── */
.company-section--workflow {
	background:
		radial-gradient(ellipse at 95% 8%, rgba(56, 189, 248, 0.1), transparent 40%),
		radial-gradient(ellipse at 5% 92%, rgba(88, 175, 255, 0.08), transparent 36%),
		linear-gradient(180deg, #e9f1f8 0%, #dde8f3 100%);
	color: var(--langit-text);
}

.company-section--workflow::before {
	inset: 0;
	background-image:
		linear-gradient(rgba(88, 175, 255, 0.04) 1px, transparent 1px),
		linear-gradient(90deg, rgba(88, 175, 255, 0.04) 1px, transparent 1px);
	background-position: center;
	background-size: 52px 52px;
	mask-image: linear-gradient(180deg, transparent 0%, #000 15%, #000 85%, transparent 100%);
	-webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 15%, #000 85%, transparent 100%);
	opacity: 0.7;
}

.company-section--workflow .process-card {
	border-color: rgba(88, 175, 255, 0.2);
	background: var(--langit-surface);
	box-shadow: 0 16px 40px -10px rgba(15, 23, 42, 0.06);
}

/* =============================================================================
   PRODUCTS PAGE SECTIONS
   ============================================================================= */

/* ─────────────────────────────────────────────────────────────────────────────
   CCTV & Security System — White-Steel.
───────────────────────────────────────────────────────────────────────────── */
.products-section--cctv {
	background:
		radial-gradient(ellipse at 95% 0%, rgba(88, 175, 255, 0.12), transparent 44%),
		radial-gradient(ellipse at 5% 100%, rgba(88, 175, 255, 0.05), transparent 40%),
		linear-gradient(180deg, #ffffff 0%, #f4f8fc 100%);
	color: var(--langit-text);
}

.products-section--cctv .card {
	border-color: rgba(88, 175, 255, 0.18);
	box-shadow: 0 16px 40px -10px rgba(15, 23, 42, 0.05);
}

/* ─────────────────────────────────────────────────────────────────────────────
   Networking Infrastructure — Blueprint-White with spotlight grid.
───────────────────────────────────────────────────────────────────────────── */
.products-section--networking {
	background:
		radial-gradient(ellipse at 15% 0%, rgba(88, 175, 255, 0.12), transparent 40%),
		radial-gradient(ellipse at 85% 100%, rgba(56, 189, 248, 0.08), transparent 36%),
		linear-gradient(180deg, #eef5fb 0%, #e9f1f8 100%);
	color: var(--langit-text);
}

.products-section--networking::before {
	inset: 0;
	background-image:
		linear-gradient(rgba(88, 175, 255, 0.04) 1px, transparent 1px),
		linear-gradient(90deg, rgba(88, 175, 255, 0.04) 1px, transparent 1px);
	background-position: center;
	background-size: 48px 48px;
	mask-image: radial-gradient(circle at 50% 50%, #000 30%, transparent 80%);
	-webkit-mask-image: radial-gradient(circle at 50% 50%, #000 30%, transparent 80%);
	opacity: 0.75;
}

.products-section--networking .card {
	border-color: rgba(88, 175, 255, 0.2);
	box-shadow: 0 16px 40px -10px rgba(15, 23, 42, 0.07);
}

/* ─────────────────────────────────────────────────────────────────────────────
   Fire Alarm System — Cool Slate atmosphere.
───────────────────────────────────────────────────────────────────────────── */
.products-section--fire-alarm {
	background:
		radial-gradient(ellipse at 95% 15%, rgba(88, 175, 255, 0.1), transparent 44%),
		radial-gradient(ellipse at 5% 85%, rgba(88, 175, 255, 0.06), transparent 38%),
		linear-gradient(180deg, #f8fbff 0%, #eef5fb 100%);
	color: var(--langit-text);
}

.products-section--fire-alarm .card {
	border-color: rgba(88, 175, 255, 0.18);
	box-shadow: 0 18px 44px -10px rgba(15, 23, 42, 0.06);
}

/* ─────────────────────────────────────────────────────────────────────────────
   Audio & Public Address — Operational Slate-Steel.
───────────────────────────────────────────────────────────────────────────── */
.products-section--audio {
	background:
		radial-gradient(ellipse at 80% 10%, rgba(88, 175, 255, 0.1), transparent 44%),
		linear-gradient(180deg, #f1f5f9 0%, #e9eef5 100%);
	color: var(--langit-text);
}

.products-section--audio .card {
	border-color: rgba(88, 175, 255, 0.18);
	box-shadow: 0 16px 40px -10px rgba(15, 23, 42, 0.06);
}

/* ─────────────────────────────────────────────────────────────────────────────
   LED & Digital Display — White-Steel.
───────────────────────────────────────────────────────────────────────────── */
.products-section--led-display {
	background:
		radial-gradient(ellipse at 95% 0%, rgba(88, 175, 255, 0.12), transparent 44%),
		radial-gradient(ellipse at 5% 100%, rgba(88, 175, 255, 0.05), transparent 40%),
		linear-gradient(180deg, #ffffff 0%, #f4f8fc 100%);
	color: var(--langit-text);
}

.products-section--led-display .card {
	border-color: rgba(88, 175, 255, 0.18);
	box-shadow: 0 16px 40px -10px rgba(15, 23, 42, 0.05);
}

/* ─────────────────────────────────────────────────────────────────────────────
   Mechanical Electrical — Architectural Slate with a masked sparse grid.
───────────────────────────────────────────────────────────────────────────── */
.products-section--electrical {
	background:
		radial-gradient(ellipse at 95% 8%, rgba(56, 189, 248, 0.1), transparent 40%),
		radial-gradient(ellipse at 5% 92%, rgba(88, 175, 255, 0.08), transparent 36%),
		linear-gradient(180deg, #e9f1f8 0%, #dde8f3 100%);
	color: var(--langit-text);
}

.products-section--electrical::before {
	inset: 0;
	background-image:
		linear-gradient(rgba(88, 175, 255, 0.035) 1px, transparent 1px),
		linear-gradient(90deg, rgba(88, 175, 255, 0.035) 1px, transparent 1px);
	background-position: center;
	background-size: 64px 64px;
	mask-image: radial-gradient(circle at 50% 50%, #000 30%, transparent 80%);
	-webkit-mask-image: radial-gradient(circle at 50% 50%, #000 30%, transparent 80%);
	opacity: 0.65;
}

.products-section--electrical .card {
	border-color: rgba(88, 175, 255, 0.2);
	box-shadow: 0 16px 40px -10px rgba(15, 23, 42, 0.07);
}

.grid,
.u-grid {
	display: grid;
	gap: var(--langit-space-md);
	grid-template-columns: 1fr;
}

.grid--auto,
.u-grid--auto {
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 17rem), 1fr));
}

.cluster,
.u-cluster {
	display: flex;
	flex-wrap: wrap;
	gap: var(--langit-space-sm);
	align-items: center;
}

.cluster .button {
	flex: 0 1 auto;
}

.stack > * + *,
.u-stack > * + * {
	margin-top: var(--langit-space-md);
}

.stack > .service-grid,
.stack > .coverage-grid,
.stack > .blog-grid,
.stack > .project-grid,
.stack > .trust-grid,
.stack > .team-grid,
.stack > .testimonial-grid,
.stack > .download-grid,
.stack > .certification-grid,
.stack > .faq-list {
	margin-top: var(--langit-space-lg);
}

.lede,
.text-lede {
	max-width: 64ch;
	color: var(--langit-muted);
	font-size: clamp(1.05rem, 1rem + 0.25vw, 1.2rem);
}

.section-heading {
	max-width: 720px;
}

.section-heading--center {
	margin-inline: auto;
	text-align: center;
}

.section-heading--center p {
	margin-inline: auto;
}

.section-heading h2 {
	margin-bottom: 0;
	line-height: 1.12;
	letter-spacing: -0.01em;
	text-wrap: balance;
}

.section-heading p {
	margin-top: 0.85rem;
	line-height: 1.75;
}

.section-eyebrow {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: max-content;
	max-width: 100%;
	margin-bottom: 0.85rem;
	padding: 0.46rem 0.95rem;
	border: 1px solid rgba(88, 175, 255, 0.22);
	border-radius: 999px;
	background: linear-gradient(135deg, rgba(255, 255, 255, 0.92), rgba(238, 247, 255, 0.86));
	box-shadow: 0 6px 16px -4px rgba(15, 23, 42, 0.04);
	color: #0d5ea6;
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	font-size: 0.7rem;
	font-weight: 800;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	line-height: 1;
}

/* Adapt to dark navy gradient background sections */
.section--navy-gradient .section-eyebrow {
	border-color: rgba(88, 175, 255, 0.26);
	background: linear-gradient(135deg, rgba(15, 23, 42, 0.5), rgba(88, 175, 255, 0.08));
	box-shadow: 0 6px 20px -4px rgba(0, 0, 0, 0.25);
	color: #bde4ff;
}

.button,
.wp-block-button__link,
button,
input[type="submit"] {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 3rem;
	padding: 0.75rem 1.5rem;
	border: 1px solid transparent;
	border-radius: var(--langit-radius);
	background: var(--langit-primary);
	color: var(--langit-secondary);
	font: inherit;
	font-weight: 750;
	line-height: 1;
	text-decoration: none;
	cursor: pointer;
	transition: background-color var(--langit-transition-fast), border-color var(--langit-transition-fast), color var(--langit-transition-fast), box-shadow var(--langit-transition-fast), transform var(--langit-transition-fast);
}

.button,
.wp-block-button__link {
	max-width: 100%;
	white-space: normal;
}

.button:hover,
.button:focus,
.wp-block-button__link:hover,
.wp-block-button__link:focus,
button:hover,
button:focus,
input[type="submit"]:hover,
input[type="submit"]:focus {
	background: var(--langit-accent);
	color: var(--langit-secondary);
	transform: translateY(-2px);
	box-shadow: 0 10px 24px rgba(88, 175, 255, 0.2);
}

.button--primary {
	background: var(--langit-primary);
	color: var(--langit-secondary);
}

.button--secondary {
	background: var(--langit-secondary);
	color: #ffffff;
}

.button--outline,
.button--ghost {
	background: transparent;
	border-color: var(--langit-border);
	color: var(--langit-secondary);
}

.button--outline:hover,
.button--outline:focus,
.button--ghost:hover,
.button--ghost:focus {
	border-color: rgba(88, 175, 255, 0.56);
	background: rgba(88, 175, 255, 0.08);
	box-shadow: 0 10px 24px rgba(88, 175, 255, 0.1);
	transform: translateY(-2px);
}

.button--cta {
	background: var(--langit-primary);
	box-shadow: 0 10px 24px rgba(88, 175, 255, 0.15);
	color: var(--langit-secondary);
}

.button__icon {
	display: inline-block;
	width: 1.15rem;
	height: 1.15rem;
	margin-right: 0.5rem;
	flex-shrink: 0;
	fill: currentColor;
	vertical-align: text-bottom;
	transition: transform var(--langit-transition-fast);
}

.button:hover .button__icon {
	transform: scale(1.08);
}

.card {
	position: relative;
	display: grid;
	align-content: start;
	gap: var(--langit-space-sm);
	height: 100%;
	min-width: 0;
	padding: clamp(1.5rem, 1.25rem + 1vw, 2.25rem);
	border: 1px solid rgba(226, 232, 240, 0.7);
	border-radius: var(--langit-card-radius);
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(248, 250, 252, 0.95) 100%);
	box-shadow: var(--langit-card-shadow);
	transition: border-color var(--langit-transition-smooth), box-shadow var(--langit-transition-smooth), transform var(--langit-transition-smooth), background-color var(--langit-transition-smooth);
}

.card:hover {
	border-color: rgba(88, 175, 255, 0.45);
	box-shadow: var(--langit-card-shadow-hover);
	transform: translateY(-5px);
}

.card:focus-within {
	border-color: rgba(88, 175, 255, 0.64);
	box-shadow: var(--langit-card-shadow-hover);
}

.card h3 {
	line-height: 1.22;
	font-weight: 750;
}

.card h3,
.card p {
	margin-bottom: 0;
}

.card__meta {
	color: var(--langit-primary);
	font-size: 0.78rem;
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.card .button--outline,
.card .button--ghost {
	width: auto;
	max-width: 100%;
	justify-self: start;
	align-self: end;
	min-height: auto;
	margin-top: 0.2rem;
	padding: 0.15rem 0;
	border: 0;
	border-radius: 0;
	background: transparent;
	box-shadow: none;
	color: var(--langit-secondary);
	font-weight: 850;
	transition: color var(--langit-transition-fast);
}

.card .button--outline::after,
.card .button--ghost::after {
	content: "→";
	margin-left: 0.4rem;
	color: var(--langit-primary);
	display: inline-block;
	transition: transform var(--langit-transition-fast);
}

.card .button--outline:hover,
.card .button--outline:focus,
.card .button--ghost:hover,
.card .button--ghost:focus {
	background: transparent;
	box-shadow: none;
	color: var(--langit-primary);
	transform: none;
}

.card:hover .button--outline::after,
.card:hover .button--ghost::after {
	transform: translateX(4px);
}

.site-header {
	position: sticky;
	top: 0;
	z-index: 50;
	background: rgba(255, 255, 255, 0.95);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	border-bottom: 1px solid rgba(219, 228, 238, 0.7);
	transition: 
		background-color 280ms cubic-bezier(0.4, 0, 0.2, 1), 
		backdrop-filter 280ms cubic-bezier(0.4, 0, 0.2, 1),
		-webkit-backdrop-filter 280ms cubic-bezier(0.4, 0, 0.2, 1),
		box-shadow 280ms cubic-bezier(0.4, 0, 0.2, 1), 
		border-color 280ms cubic-bezier(0.4, 0, 0.2, 1);
}

.site-header.is-scrolled {
	border-bottom-color: rgba(226, 232, 240, 0.8);
	background: rgba(255, 255, 255, 0.82);
	box-shadow: 
		0 4px 6px -1px rgba(15, 23, 42, 0.01),
		0 10px 15px -3px rgba(15, 23, 42, 0.03),
		0 0 0 1px rgba(15, 23, 42, 0.01);
}

.site-header__inner {
	display: flex;
	min-height: var(--langit-header-height);
	align-items: center;
	justify-content: space-between;
	gap: var(--langit-space-sm);
	transition: min-height 280ms cubic-bezier(0.4, 0, 0.2, 1);
}

.site-header.is-scrolled .site-header__inner {
	min-height: var(--langit-header-scrolled-height);
}

.site-branding {
	display: flex;
	min-width: 0;
	align-items: center;
	gap: 0.75rem;
}

.custom-logo-link,
.custom-logo {
	flex: 0 0 auto;
}

.custom-logo {
	width: auto;
	max-width: 9rem;
	max-height: 2.75rem;
	object-fit: contain;
	transition: max-height 280ms cubic-bezier(0.4, 0, 0.2, 1);
}

.site-header.is-scrolled .custom-logo {
	max-height: 2.15rem;
}

@media (min-width: 641px) {
	.site-header.is-scrolled .custom-logo {
		max-height: 2.35rem;
	}
}

.site-branding__text {
	min-width: 0;
}

.site-title {
	margin: 0;
	font-size: clamp(1.05rem, 0.98rem + 0.35vw, 1.25rem);
	font-weight: 850;
	line-height: 1.08;
}

.site-title a {
	display: block;
	max-width: 6.5rem;
	color: var(--langit-secondary);
	text-decoration: none;
	overflow-wrap: anywhere;
}

.main-navigation {
	display: flex;
	flex: 0 0 auto;
	align-items: center;
	justify-content: flex-end;
}

.menu-toggle {
	display: inline-flex;
	width: 2.75rem;
	height: 2.75rem;
	padding: 0;
	background: var(--langit-secondary);
	color: #ffffff;
	transition: background-color 160ms ease;
}

.menu-toggle__bar,
.menu-toggle__bar::before,
.menu-toggle__bar::after {
	display: block;
	width: 1.1rem;
	height: 2px;
	background: currentColor;
	content: "";
}

.menu-toggle__bar {
	position: relative;
	transition: background-color 160ms ease;
}

.menu-toggle__bar::before,
.menu-toggle__bar::after {
	position: absolute;
	left: 0;
	transition: top 160ms ease, transform 160ms ease;
}

.menu-toggle__bar::before {
	top: -0.38rem;
}

.menu-toggle__bar::after {
	top: 0.38rem;
}

.menu-toggle[aria-expanded="true"] .menu-toggle__bar {
	background: transparent;
}

.menu-toggle[aria-expanded="true"] .menu-toggle__bar::before {
	top: 0;
	transform: rotate(45deg);
}

.menu-toggle[aria-expanded="true"] .menu-toggle__bar::after {
	top: 0;
	transform: rotate(-45deg);
}

.primary-menu,
.footer-menu {
	display: flex;
	flex-wrap: wrap;
	gap: 0.35rem;
	align-items: center;
	margin: 0;
	padding: 0;
	list-style: none;
}

.primary-menu a,
.footer-menu a {
	position: relative;
	display: block;
	min-height: 2.75rem;
	padding: 0.72rem 0.9rem;
	border-radius: var(--langit-radius);
	color: var(--langit-secondary);
	font-weight: 700;
	text-decoration: none;
	transition: background-color 160ms ease, color 160ms ease, padding 280ms cubic-bezier(0.4, 0, 0.2, 1), min-height 280ms cubic-bezier(0.4, 0, 0.2, 1);
	overflow-wrap: anywhere;
}

.primary-menu a:hover,
.primary-menu a:focus,
.primary-menu .current-menu-item > a,
.primary-menu .current-menu-ancestor > a,
.primary-menu .current_page_item > a {
	background: rgba(88, 175, 255, 0.14);
}

.primary-menu {
	position: absolute;
	top: 100%;
	right: var(--langit-gutter);
	left: var(--langit-gutter);
	flex-direction: column;
	align-items: stretch;
	max-height: 0;
	overflow: hidden;
	padding: 0.65rem;
	border: 1px solid var(--langit-border);
	border-radius: var(--langit-radius);
	background: #ffffff;
	box-shadow: var(--langit-shadow);
	opacity: 0;
	pointer-events: none;
	transform: translateY(-0.35rem);
	transition: max-height 180ms ease, opacity 160ms ease, transform 160ms ease;
}

.primary-menu.is-open {
	max-height: calc(100vh - var(--langit-header-height) - 1rem);
	overflow-y: auto;
	overscroll-behavior: contain;
	opacity: 1;
	pointer-events: auto;
	transform: translateY(0);
}

@supports (height: 100dvh) {
	.primary-menu.is-open {
		max-height: calc(100dvh - var(--langit-header-height) - 1rem);
	}
}

.primary-menu .menu-item-has-children {
	position: relative;
}

.primary-menu .menu-item-has-children > a {
	padding-right: 3.15rem;
}

.submenu-toggle {
	position: absolute;
	top: 0.38rem;
	right: 0.35rem;
	display: inline-grid;
	width: 2rem;
	height: 2rem;
	min-height: 2rem;
	padding: 0;
	place-items: center;
	border: 1px solid rgba(88, 175, 255, 0.28);
	background: rgba(88, 175, 255, 0.12);
	color: var(--langit-secondary);
}

.submenu-toggle span {
	width: 0.45rem;
	height: 0.45rem;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: translateY(-12%) rotate(45deg);
	transition: transform 160ms ease;
}

.submenu-toggle[aria-expanded="true"] span {
	transform: translateY(12%) rotate(225deg);
}

.primary-menu .sub-menu {
	display: grid;
	gap: 0.15rem;
	max-height: 0;
	margin: 0;
	padding: 0 0.35rem;
	overflow: hidden;
	border: 1px solid var(--langit-border);
	border-radius: var(--langit-radius);
	background: var(--langit-background);
	list-style: none;
	opacity: 0;
	pointer-events: none;
	visibility: hidden;
	transition: max-height 220ms ease, margin-top 180ms ease, padding-block 180ms ease, opacity 180ms ease, visibility 180ms ease;
}

.primary-menu .is-submenu-open > .sub-menu {
	max-height: 42rem;
	margin-top: 0.2rem;
	padding-block: 0.35rem;
	opacity: 1;
	pointer-events: auto;
	visibility: visible;
}

.primary-menu .sub-menu a {
	min-height: 2.5rem;
	padding: 0.62rem 0.75rem;
	color: var(--langit-muted);
	font-size: 0.94rem;
}

.langit-mega-panel {
	gap: var(--langit-space-sm);
}

.langit-mega-group,
.langit-mega-cta {
	display: grid;
	gap: 0.35rem;
	min-width: 0;
}

.langit-mega-group__title {
	padding: 0.25rem 0.75rem;
	color: var(--langit-secondary);
	font-size: 0.78rem;
	font-weight: 850;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.langit-mega-list {
	display: grid;
	gap: 0.15rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

.langit-mega-cta a {
	display: grid;
	gap: 0.25rem;
	border: 1px solid rgba(88, 175, 255, 0.28);
	background: rgba(88, 175, 255, 0.12);
	color: var(--langit-secondary);
}

.langit-mega-cta span {
	color: var(--langit-muted);
	font-size: 0.84rem;
	font-weight: 500;
	line-height: 1.45;
}

.site-main {
	min-height: 55vh;
	overflow-x: clip;
}

.hero {
	position: relative;
	padding-block: clamp(3.5rem, 7vw, 7rem);
	background:
		linear-gradient(135deg, rgba(88, 175, 255, 0.16), rgba(56, 189, 248, 0.05) 42%, rgba(15, 23, 42, 0.04)),
		var(--langit-background);
	border-bottom: 1px solid var(--langit-border);
}

/* =============================================================================
   HERO V2 — Integrated Building Technology Partner
   Light premium theme · Architectural visual · 55/45 desktop split · 1440px
   ============================================================================= */

/* Custom property for the wider hero container */
:root {
	--langit-hero-v2-container: 1380px;
	--langit-hero-v2-gutter: max(1.5rem, 5vw);
}

/* ─── Section wrapper ───────────────────────────────────────────────────────── */
.hero--home.hero--v2 {
	position: relative;
	overflow: hidden;
	display: grid;
	grid-template-columns: 1fr;
	background:
		radial-gradient(circle 1000px at 70% 30%, rgba(214, 233, 253, 0.75) 0%, rgba(240, 247, 255, 0.2) 65%, transparent 100%),
		radial-gradient(ellipse 70% 50% at 20% 90%, rgba(56, 189, 248, 0.12), transparent),
		linear-gradient(172deg, #f9fbfd 0%, #edf4fb 45%, #d4e7f9 100%);
	border-bottom: 1px solid rgba(203, 213, 225, 0.45);
}

/* ─── Content Layer: max 1440px, centres content ─────────────────────────── */
.hero-v2__content-layer {
	display: grid;
	grid-template-columns: 1fr;
	width: min(100% - (var(--langit-gutter) * 2), var(--langit-hero-v2-container));
	margin-inline: auto;
	/* padding-block: header + top-space, bottom-space */
	padding-block:
		calc(var(--langit-header-height) + clamp(2.5rem, 5vw, 5rem))
		clamp(3rem, 5vw, 5rem);
	gap: clamp(2.5rem, 5vw, 4rem);
	align-items: center;
}

/* ─── Content Inner ────────────────────────────────────────────────────────── */
.hero-v2__content-inner {
	display: flex;
	flex-direction: column;
	/* Explicit gaps between each content element — premium spacing hierarchy */
	gap: 0;
	min-width: 0;
	max-width: 680px;
}

/* Badge → Headline spacing */
.hero-v2__badge {
	margin-bottom: clamp(1.5rem, 2.5vw, 2.25rem);
}

/* Headline → Description spacing */
.hero-v2__headline {
	margin-bottom: clamp(1.5rem, 2vw, 2rem);
}

/* Description → CTA spacing */
.hero-v2__description {
	margin-bottom: clamp(2.25rem, 3vw, 3rem);
}

/* Badge pill */
.hero-v2__badge {
	display: inline-flex;
	align-self: flex-start;
	align-items: center;
	gap: 0.55rem;
	padding: 0.44rem 1.1rem 0.56rem 0.75rem; /* asymmetric: compensates optical shift of uppercase text */
	border: 1px solid rgba(88, 175, 255, 0.3);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.88);
	box-shadow:
		0 2px 8px rgba(15, 23, 42, 0.06),
		0 0 0 1px rgba(88, 175, 255, 0.1) inset;
	color: #0a4d8c;
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	font-size: 0.67rem;
	font-weight: 800;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	line-height: 1;
}

/* Animated status dot */
.hero-v2__badge-dot {
	display: inline-block;
	flex-shrink: 0;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--langit-primary);
	position: relative;
}

.hero-v2__badge-dot::after {
	content: "";
	position: absolute;
	inset: -3px;
	border-radius: 50%;
	background: rgba(88, 175, 255, 0.25);
	animation: hero-badge-pulse 2.4s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

@keyframes hero-badge-pulse {
	0%, 100% { transform: scale(1); opacity: 1; }
	50%       { transform: scale(1.8); opacity: 0; }
}

/* Headline */
.hero-v2__headline {
	color: #071930; /* Deeper enterprise navy for high premium contrast */
	font-size: clamp(2.4rem, 1.8rem + 2.8vw, 5rem);
	font-weight: 800;
	line-height: 0.97;
	letter-spacing: -0.04em;
	text-wrap: balance;
	word-break: normal;
	overflow-wrap: anywhere;
}

/* Description */
.hero-v2__description {
	max-width: 60ch;
	color: var(--langit-muted);
	font-size: clamp(0.97rem, 0.9rem + 0.35vw, 1.15rem);
	line-height: 1.82;
	font-weight: 400;
}

/* CTA cluster */
.hero-v2__cta {
	margin-top: 0.35rem;
	gap: 0.85rem;
	flex-wrap: wrap;
	align-items: center;
}

/* Primary button — strong enterprise blue */
.hero-v2__cta .button--hero-primary {
	background: #0a64be; /* strong enterprise blue */
	color: #ffffff;
	border-color: #0a64be;
	min-height: 3rem;
	padding-inline: 1.65rem;
	font-weight: 800; /* stronger visual weight */
	letter-spacing: -0.01em;
	box-shadow: 
		0 1px 2px rgba(0, 0, 0, 0.05),
		0 8px 24px rgba(10, 100, 190, 0.3);
	transition: var(--langit-transition-smooth);
}

.hero-v2__cta .button--hero-primary:hover,
.hero-v2__cta .button--hero-primary:focus {
	background: #0052a3;
	border-color: #0052a3;
	transform: translateY(-2px);
	box-shadow: 
		0 1px 2px rgba(0, 0, 0, 0.05),
		0 12px 32px rgba(10, 100, 190, 0.45);
}

/* Secondary button — light outline */
.hero-v2__cta .button--hero-ghost {
	background: transparent;
	border: 1px solid rgba(255, 255, 255, 0.35); /* light outline */
	color: #ffffff;
	min-height: 3rem;
	padding-inline: 1.35rem;
	font-weight: 700;
	box-shadow: none;
	backdrop-filter: none;
	-webkit-backdrop-filter: none;
	transition: var(--langit-transition-smooth);
}

.hero-v2__cta .button--hero-ghost:hover,
.hero-v2__cta .button--hero-ghost:focus {
	background: rgba(255, 255, 255, 0.08);
	border-color: rgba(255, 255, 255, 0.65);
	color: #ffffff;
	transform: translateY(-2px);
	box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15);
}

/* ─── Background & Overlay Layer (Unified Canvas) ───────────────────────────── */
.hero-v2__bg-layer {
	grid-row: 2;
	grid-column: 1;
	position: relative;
	display: block;
	width: 100%;
	min-width: 0;
	overflow: hidden;
	z-index: 1;
	aspect-ratio: 16 / 10;
	max-height: 320px;
}

.hero-v2__bg-slides {
	position: relative;
	width: 100%;
	height: 100%;
	overflow: hidden;
}

.hero-v2__bg-slide {
	display: none;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center center;
}

.hero-v2__bg-slide--1 {
	display: block;
	opacity: 1;
}

.hero-v2__bg-overlay {
	position: absolute;
	inset: 0;
	background-image: 
		linear-gradient(rgba(88, 175, 255, 0.07) 1px, transparent 1px),
		linear-gradient(90deg, rgba(88, 175, 255, 0.07) 1px, transparent 1px);
	background-size: 24px 24px;
	mix-blend-mode: multiply;
	opacity: 0.11; /* subtle 10%-12% visibility */
	z-index: 2;
	pointer-events: none;
}

.hero-v2__bg-overlay::after {
	content: "";
	position: absolute;
	inset: 0;
	background: radial-gradient(circle at 75% 35%, rgba(56, 189, 248, 0.18), transparent 75%);
	pointer-events: none;
}

@keyframes hero-slideshow-fade {
	0%, 13.33% {
		opacity: 1;
	}
	16.67%, 96.67% {
		opacity: 0;
	}
	100% {
		opacity: 1;
	}
}

/* Desktop line break helper */
.hero-v2__desktop-br {
	display: none;
}

/* Bottom transition to next section */
.hero--v2 + .section,
.hero--v2 + .home-section {
	position: relative;
}

.hero--v2 + .section::before,
.hero--v2 + .home-section::before {
	position: absolute;
	top: 0;
	left: 50%;
	width: min(100% - (var(--langit-gutter) * 2), var(--langit-container));
	height: 1px;
	background: linear-gradient(90deg, transparent, rgba(88, 175, 255, 0.35), transparent);
	content: "";
	transform: translateX(-50%);
}

/* Utility: scroll anchor target offset */
#services {
	scroll-margin-top: calc(var(--langit-header-height) + 1rem);
}

/* ─── Legacy hero classes (unused in V2, kept for JS compatibility) ──────────── */
.hero-grid {
	display: grid;
	gap: var(--langit-space-lg);
	align-items: center;
}

.hero__content {
	max-width: 760px;
}

.hero__eyebrow {
	margin-bottom: 0.85rem;
	color: var(--langit-primary);
	font-size: 0.82rem;
	font-weight: 850;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}


.page-hero {
	padding-block: clamp(3.75rem, 7vw, 6.5rem);
	background:
		linear-gradient(135deg, rgba(88, 175, 255, 0.18), rgba(56, 189, 248, 0.06) 42%, rgba(15, 23, 42, 0.04)),
		var(--langit-background);
	border-bottom: 1px solid var(--langit-border);
}

.page-hero__content {
	max-width: 820px;
}

.hero-panel {
	position: relative;
	min-height: 18rem;
	overflow: hidden;
	border: 1px solid rgba(88, 175, 255, 0.38);
	border-radius: var(--langit-radius);
	background:
		linear-gradient(135deg, rgba(15, 23, 42, 0.94), rgba(15, 23, 42, 0.78)),
		linear-gradient(90deg, rgba(88, 175, 255, 0.15) 1px, transparent 1px),
		linear-gradient(rgba(88, 175, 255, 0.15) 1px, transparent 1px);
	background-size: auto, 34px 34px, 34px 34px;
	box-shadow: var(--langit-shadow);
}

.hero-panel--image {
	background: var(--langit-secondary);
}

.hero-panel--image picture,
.hero-panel--image img {
	display: block;
	width: 100%;
	height: 100%;
}

.hero-panel--image img {
	aspect-ratio: 16 / 10;
	object-fit: cover;
	opacity: 0.88;
}

.hero-panel--image::after {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(135deg, rgba(15, 23, 42, 0.18), rgba(88, 175, 255, 0.2)),
		linear-gradient(0deg, rgba(15, 23, 42, 0.22), transparent 52%);
	content: "";
}

.hero-panel__badge,
.system-card {
	position: absolute;
	display: grid;
	gap: 0.65rem;
	padding: 1rem;
	border: 1px solid rgba(88, 175, 255, 0.34);
	border-radius: var(--langit-radius);
	background: rgba(248, 250, 252, 0.94);
}

.hero-panel__badge {
	right: 8%;
	bottom: 10%;
	z-index: 1;
	width: min(58%, 16rem);
}

.system-card span {
	display: block;
	height: 0.8rem;
	border-radius: 999px;
	background: linear-gradient(90deg, var(--langit-primary), rgba(56, 189, 248, 0.32));
}

.system-card--main {
	right: 10%;
	bottom: 18%;
	width: min(72%, 21rem);
}

.system-card--small {
	top: 16%;
	left: 10%;
	width: min(48%, 14rem);
}

.hero-panel__badge span {
	display: block;
	height: 0.65rem;
	border-radius: 999px;
	background: linear-gradient(90deg, var(--langit-primary), rgba(56, 189, 248, 0.3));
}

.split-layout {
	display: grid;
	gap: var(--langit-space-lg);
	align-items: center;
}

.company-overview {
	display: grid;
	gap: var(--langit-space-lg);
	align-items: start;
}

.capability-list {
	display: grid;
	gap: 0.75rem;
}

.capability-item {
	padding: 0.9rem 1rem;
	border: 1px solid var(--langit-border);
	border-radius: var(--langit-radius);
	background: var(--langit-surface);
	color: var(--langit-secondary);
	font-weight: 750;
}

.image-placeholder,
.media-frame {
	overflow: hidden;
	border: 1px solid rgba(226, 232, 240, 0.8);
	border-radius: var(--langit-media-radius);
	background: #0f172a;
	box-shadow: 0 20px 40px -10px rgba(15, 23, 42, 0.08), 0 1px 3px rgba(15, 23, 42, 0.02);
	transition: transform var(--langit-transition-smooth), box-shadow var(--langit-transition-smooth);
}

.image-placeholder picture,
.image-placeholder img,
.media-frame picture,
.media-frame img {
	display: block;
	width: 100%;
}

.image-placeholder img,
.media-frame img {
	aspect-ratio: 16 / 9;
	height: 100%;
	object-fit: cover;
	transition: filter 1s var(--langit-transition-smooth), transform 1.2s var(--langit-transition-smooth);
}

.image-placeholder:hover img,
.media-frame:hover img {
	filter: saturate(1.02) contrast(1.02);
	transform: scale(1.04);
}

.aspect-16-9 {
	aspect-ratio: 16 / 9;
}

.aspect-4-3 {
	aspect-ratio: 4 / 3;
}

.aspect-square {
	aspect-ratio: 1;
}

.service-grid,
.products-grid,
.coverage-grid,
.legality-grid,
.team-grid,
.feature-grid,
.process-grid,
.contact-info-grid,
.trust-grid,
.testimonial-grid,
.client-grid,
.client-logo-grid,
.card-grid,
.why-choose-grid,
.company-values-grid,
.workflow-grid,
.industries-serve-grid {
	display: grid;
	gap: var(--langit-space-md);
	grid-template-columns: 1fr;
}

.service-card {
	isolation: isolate;
	overflow: hidden;
	display: grid;
	grid-template-rows: auto auto 1fr auto;
	align-content: start;
	gap: 1.15rem;
	padding: clamp(1.55rem, 1.25rem + 1vw, 2.25rem);
	border: 1px solid rgba(88, 175, 255, 0.15);
	border-radius: 24px;
	background:
		linear-gradient(135deg, #ffffff 0%, rgba(253, 254, 255, 0.98) 60%, rgba(246, 251, 255, 0.95) 100%),
		#ffffff;
	box-shadow:
		0 4px 6px -1px rgba(15, 23, 42, 0.02),
		0 12px 24px -4px rgba(15, 23, 42, 0.04),
		0 20px 48px -8px rgba(15, 23, 42, 0.03);
	transition:
		border-color var(--langit-transition-smooth),
		box-shadow var(--langit-transition-smooth),
		transform var(--langit-transition-smooth),
		background-color var(--langit-transition-smooth);
}

.service-card::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -1;
	border-radius: inherit;
	background:
		linear-gradient(90deg, rgba(88, 175, 255, 0.18), rgba(88, 175, 255, 0) 40%),
		radial-gradient(circle at 12% 8%, rgba(88, 175, 255, 0.08), transparent 30%);
	opacity: 0.28;
	pointer-events: none;
}

.service-card::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -1;
	border-radius: inherit;
	background-image:
		linear-gradient(rgba(88, 175, 255, 0.04) 1px, transparent 1px),
		linear-gradient(90deg, rgba(88, 175, 255, 0.03) 1px, transparent 1px);
	background-size: 32px 32px;
	mask-image: linear-gradient(135deg, rgba(0, 0, 0, 0.4), transparent 40%);
	opacity: 0.16;
	pointer-events: none;
}

.service-card h3,
.service-card p {
	margin-bottom: 0;
}

.service-card__body {
	display: grid;
	gap: 0.65rem;
}

.service-card h3 {
	max-width: 15rem;
	color: var(--langit-secondary);
	font-size: clamp(1.16rem, 1.04rem + 0.36vw, 1.36rem);
	letter-spacing: 0;
}

.service-card h3 a {
	color: inherit;
	text-decoration: none;
	transition: color var(--langit-transition-fast);
}

.service-card h3 a:hover,
.service-card h3 a:focus {
	color: var(--langit-primary);
}

.service-card p:not(.card__meta) {
	color: #5b697a;
	display: -webkit-box;
	font-size: 0.92rem;
	line-height: 1.65;
	overflow: hidden;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
}

.service-card .card__meta {
	align-self: start;
	width: fit-content;
	max-width: 100%;
	padding: 0.34rem 0.72rem;
	border: 1px solid rgba(88, 175, 255, 0.22);
	border-radius: 999px;
	background: rgba(88, 175, 255, 0.075);
	color: #1871b8;
	font-size: 0.68rem;
	line-height: 1.15;
	letter-spacing: 0.09em;
}

.service-card__icon,
.contact-card__icon,
.card-icon {
	width: 3.5rem;
	height: 3.5rem;
	padding: 0.65rem;
	border-radius: 16px;
	background: linear-gradient(135deg, rgba(88, 175, 255, 0.12), rgba(56, 189, 248, 0.05));
	border: 1px solid rgba(88, 175, 255, 0.25);
	box-shadow: 0 8px 20px rgba(88, 175, 255, 0.08);
	transition: border-color var(--langit-transition-fast), box-shadow var(--langit-transition-fast), transform var(--langit-transition-fast);
}

.service-card__icon {
	width: 3.25rem;
	height: 3.25rem;
	padding: 0.65rem;
	border-radius: 12px;
	background: rgba(241, 247, 255, 0.8);
	border: 1px solid rgba(88, 175, 255, 0.22);
	box-shadow:
		0 4px 10px rgba(15, 23, 42, 0.03),
		inset 0 1px 0 rgba(255, 255, 255, 0.9);
	transition:
		border-color var(--langit-transition-fast),
		box-shadow var(--langit-transition-fast),
		background-color var(--langit-transition-fast),
		transform var(--langit-transition-fast);
}

.card:hover .contact-card__icon,
.card:hover .card-icon {
	border-color: rgba(88, 175, 255, 0.55);
	box-shadow: 0 12px 28px rgba(88, 175, 255, 0.2);
	transform: scale(1.05);
}

.service-card:hover {
	border-color: rgba(88, 175, 255, 0.28);
	box-shadow:
		0 8px 12px -2px rgba(15, 23, 42, 0.03),
		0 20px 32px -4px rgba(15, 23, 42, 0.06),
		0 32px 64px -8px rgba(15, 23, 42, 0.05);
	transform: translateY(-4px);
}

.service-card:hover .service-card__icon {
	border-color: rgba(88, 175, 255, 0.45);
	background: rgba(235, 244, 255, 0.95);
	box-shadow:
		0 6px 14px rgba(88, 175, 255, 0.12),
		inset 0 1px 0 rgba(255, 255, 255, 0.95);
	transform: translateY(-1px);
}

.service-card .button--ghost,
.service-card .button--outline {
	margin-top: 0.5rem;
	color: var(--langit-secondary);
	font-size: 0.88rem;
	font-weight: 800;
	letter-spacing: 0.03em;
	text-transform: uppercase;
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
}

.service-card:hover .button--ghost,
.service-card:hover .button--outline {
	color: var(--langit-primary);
}

.service-card:hover .button--ghost::after,
.service-card:hover .button--outline::after {
	transform: translateX(5px);
}

.product-card.service-card {
	grid-template-rows: auto auto 1fr auto;
	gap: 1rem;
	padding: clamp(1.55rem, 1.25rem + 1vw, 2.25rem);
}

.product-card.service-card .product-card__visual {
	display: grid;
	place-items: center;
	width: 4rem;
	height: 4rem;
	padding: 0.78rem;
	overflow: hidden;
	border-radius: 18px;
	background:
		linear-gradient(145deg, rgba(255, 255, 255, 0.96), rgba(232, 244, 255, 0.9)),
		#f8fbff;
	border: 1px solid rgba(88, 175, 255, 0.32);
	box-shadow:
		0 18px 34px rgba(15, 23, 42, 0.11),
		inset 0 1px 0 rgba(255, 255, 255, 0.8);
	transition:
		border-color var(--langit-transition-fast),
		box-shadow var(--langit-transition-fast),
		transform var(--langit-transition-fast);
}

.product-card.service-card .product-card__visual img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.product-card.service-card:hover .product-card__visual {
	border-color: rgba(125, 199, 255, 0.72);
	box-shadow:
		0 20px 42px rgba(88, 175, 255, 0.22),
		inset 0 1px 0 rgba(255, 255, 255, 0.22);
	transform: translateY(-2px);
}

.related-services-section {
	background:
		linear-gradient(180deg, rgba(241, 248, 255, 0.96), rgba(248, 250, 252, 0.98)),
		var(--langit-background);
}

.related-service-grid {
	display: grid;
	gap: clamp(0.9rem, 1.4vw, 1.2rem);
	grid-template-columns: 1fr;
	align-items: stretch;
}

.related-service-card {
	position: relative;
	isolation: isolate;
	display: grid;
	grid-template-rows: auto auto 1fr auto;
	gap: 0.76rem;
	height: 100%;
	min-width: 0;
	overflow: hidden;
	padding: clamp(1.2rem, 1.08rem + 0.75vw, 1.55rem);
	border: 1px solid rgba(148, 163, 184, 0.32);
	border-radius: 20px;
	background:
		linear-gradient(145deg, rgba(255, 255, 255, 0.98), rgba(241, 248, 255, 0.94)),
		#ffffff;
	box-shadow: 0 16px 36px rgba(15, 23, 42, 0.07);
	transition:
		border-color var(--langit-transition-smooth),
		box-shadow var(--langit-transition-smooth),
		transform var(--langit-transition-smooth);
}

.related-service-card::before {
	content: "";
	position: absolute;
	inset: 0 auto auto 0;
	z-index: -1;
	width: 100%;
	height: 3px;
	background: linear-gradient(90deg, var(--langit-primary), rgba(88, 175, 255, 0));
	opacity: 0.82;
}

.related-service-card::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -1;
	background:
		radial-gradient(circle at 12% 0%, rgba(88, 175, 255, 0.13), transparent 34%),
		linear-gradient(rgba(88, 175, 255, 0.05) 1px, transparent 1px);
	background-size: auto, 24px 24px;
	opacity: 0.55;
	pointer-events: none;
}

.related-service-card__icon {
	display: grid;
	width: 3.25rem;
	height: 3.25rem;
	place-items: center;
	padding: 0.58rem;
	border: 1px solid rgba(88, 175, 255, 0.28);
	border-radius: 15px;
	background:
		linear-gradient(145deg, rgba(255, 255, 255, 0.96), rgba(232, 244, 255, 0.88)),
		#f8fbff;
	box-shadow:
		0 12px 24px rgba(15, 23, 42, 0.09),
		inset 0 1px 0 rgba(255, 255, 255, 0.84);
	transition:
		border-color var(--langit-transition-fast),
		box-shadow var(--langit-transition-fast),
		transform var(--langit-transition-fast);
}

.related-service-card__icon img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.related-service-card__meta {
	align-self: start;
	width: fit-content;
	max-width: 100%;
	margin-bottom: 0;
	padding: 0.3rem 0.66rem;
	border: 1px solid rgba(88, 175, 255, 0.2);
	border-radius: 999px;
	background: rgba(88, 175, 255, 0.075);
	color: #1871b8;
	font-size: 0.66rem;
	font-weight: 850;
	letter-spacing: 0.08em;
	line-height: 1.15;
	text-transform: uppercase;
}

.related-service-card__content {
	display: grid;
	align-content: start;
	gap: 0.5rem;
	min-width: 0;
}

.related-service-card h3,
.related-service-card p {
	margin-bottom: 0;
}

.related-service-card h3 {
	color: var(--langit-secondary);
	font-size: clamp(1.04rem, 0.98rem + 0.22vw, 1.18rem);
	line-height: 1.25;
}

.related-service-card h3 a {
	color: inherit;
	text-decoration: none;
	transition: color var(--langit-transition-fast);
}

.related-service-card__content p {
	display: -webkit-box;
	color: #536476;
	font-size: 0.91rem;
	line-height: 1.58;
	overflow: hidden;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
}

.related-service-card__link {
	align-self: end;
	justify-self: start;
	color: #0f3658;
	font-size: 0.88rem;
	font-weight: 850;
	text-decoration: none;
	transition: color var(--langit-transition-fast);
}

.related-service-card__link::after {
	content: "→";
	display: inline-block;
	margin-left: 0.38rem;
	color: var(--langit-primary);
	transition: transform var(--langit-transition-fast);
}

.related-service-card:hover,
.related-service-card:focus-within {
	border-color: rgba(88, 175, 255, 0.55);
	box-shadow: 0 22px 48px rgba(15, 23, 42, 0.11), 0 0 0 1px rgba(88, 175, 255, 0.08);
	transform: translateY(-4px);
}

.related-service-card:hover .related-service-card__icon,
.related-service-card:focus-within .related-service-card__icon {
	border-color: rgba(88, 175, 255, 0.62);
	box-shadow:
		0 16px 32px rgba(88, 175, 255, 0.18),
		inset 0 1px 0 rgba(255, 255, 255, 0.9);
	transform: translateY(-1px);
}

.related-service-card h3 a:hover,
.related-service-card h3 a:focus,
.related-service-card__link:hover,
.related-service-card__link:focus {
	color: var(--langit-primary);
}

.related-service-card:hover .related-service-card__link::after,
.related-service-card__link:focus::after {
	transform: translateX(4px);
}

.product-card {
	display: grid;
	grid-template-rows: auto auto minmax(4.65rem, 1fr) auto;
	gap: clamp(0.9rem, 1vw, 1.1rem);
	padding: 0;
	overflow: hidden;
	border-color: rgba(148, 163, 184, 0.34);
	border-radius: 22px;
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(248, 252, 255, 0.96)),
		#ffffff;
}

.product-card__media {
	display: block;
	overflow: hidden;
	border-radius: calc(var(--langit-card-radius) - 1px) calc(var(--langit-card-radius) - 1px) 0 0;
	background: #0f172a;
	aspect-ratio: 4 / 3;
}

.product-card__media img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 1.2s var(--langit-transition-smooth);
}

.product-card__fallback-icon {
	width: 48px;
	height: 48px;
	margin: auto;
	display: block;
	padding: 1.5rem;
}

.product-card:hover .product-card__media img {
	transform: scale(1.04);
}

.product-card__header,
.product-card__summary,
.product-card__actions {
	margin-inline: clamp(1.05rem, 0.9rem + 0.75vw, 1.45rem);
}

.product-card__header {
	display: grid;
	align-content: start;
	gap: 0.62rem;
}

.product-card__badge {
	display: inline-flex;
	align-items: center;
	align-self: start;
	min-height: 1.75rem;
	max-width: 100%;
	padding: 0.25rem 0.68rem;
	border: 1px solid rgba(88, 175, 255, 0.2);
	border-radius: 999px;
	background: rgba(88, 175, 255, 0.06);
	color: var(--langit-primary);
	font-size: 0.72rem;
	font-weight: 750;
	letter-spacing: 0.04em;
	line-height: 1.2;
	text-transform: uppercase;
	text-decoration: none;
	overflow-wrap: anywhere;
	width: fit-content;
}

.product-card__title {
	margin-bottom: 0;
	color: var(--langit-secondary);
	font-size: clamp(1.05rem, 1rem + 0.25vw, 1.22rem);
	font-weight: 750;
	line-height: 1.28;
}

.product-card__title a {
	color: inherit;
	text-decoration: none;
	transition: color var(--langit-transition-fast);
}

.product-card__title a:hover {
	color: var(--langit-primary);
}

.product-card__summary p {
	display: -webkit-box;
	margin-bottom: 0;
	color: var(--langit-muted);
	font-size: 0.91rem;
	line-height: 1.55;
	overflow: hidden;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
}

.product-card__actions {
	display: flex;
	gap: var(--langit-space-sm);
	align-self: end;
	margin-bottom: clamp(1.05rem, 0.9rem + 0.75vw, 1.45rem);
	flex-wrap: wrap;
}

.product-card__actions .button {
	flex: 1 1 auto;
	justify-content: center;
	width: 100%;
	min-height: 2.75rem;
	padding-inline: 1rem;
	font-size: 0.9rem;
}

.products-grid {
	--langit-product-grid-columns: 1;
	align-items: stretch;
	gap: clamp(1rem, 1.5vw, var(--langit-space-md));
	grid-template-columns: repeat(var(--langit-product-grid-columns), minmax(0, 1fr));
}

.coverage-card {
	--coverage-image: url("../images/industries/industry-industrial.webp");
	position: relative;
	display: grid;
	height: 100%;
	min-height: clamp(18rem, 24vw, 24rem);
	align-items: end;
	overflow: hidden;
	padding: clamp(1.5rem, 1.25rem + 1vw, 2.25rem);
	border: 1px solid rgba(88, 175, 255, 0.18);
	border-radius: var(--langit-card-radius);
	background: var(--langit-secondary);
	box-shadow: 0 24px 50px -10px rgba(6, 17, 31, 0.3);
	color: #ffffff;
	isolation: isolate;
	transition: border-color var(--langit-transition-smooth), box-shadow var(--langit-transition-smooth), transform var(--langit-transition-smooth);
}

.coverage-card::before,
.coverage-card::after {
	position: absolute;
	inset: 0;
	content: "";
	pointer-events: none;
	transition: opacity var(--langit-transition-smooth), transform 1.5s var(--langit-transition-smooth);
}

.coverage-card::before {
	z-index: 0;
	background: var(--coverage-image) center / cover no-repeat;
	transform: scale(1.025);
}

.coverage-card::after {
	z-index: 1;
	background:
		radial-gradient(circle at 80% 20%, rgba(56, 189, 248, 0.15), transparent 45%),
		radial-gradient(circle at 20% 80%, rgba(6, 17, 31, 0.95), transparent 60%),
		linear-gradient(180deg, rgba(6, 17, 31, 0.15) 0%, rgba(6, 17, 31, 0.92) 100%),
		linear-gradient(90deg, rgba(6, 17, 31, 0.82) 0%, rgba(6, 17, 31, 0.3) 50%, transparent 100%);
}

.coverage-card:hover {
	border-color: rgba(88, 175, 255, 0.45);
	box-shadow: 0 32px 64px -12px rgba(6, 17, 31, 0.45);
	transform: translateY(-5px);
}

.coverage-card:hover::before {
	transform: scale(1.06);
	filter: brightness(1.05) saturate(1.05);
}

.coverage-card:hover::after {
	opacity: 0.95;
}

.coverage-card--industrial {
	--coverage-image: url("../images/industries/industry-industrial.webp");
}

.coverage-card--commercial-building {
	--coverage-image: url("../images/industries/industry-commercial-building.webp");
}

.coverage-card--government {
	--coverage-image: url("../images/industries/industry-government.webp");
}

.coverage-card--residential {
	--coverage-image: url("../images/industries/industry-residential.webp");
}

.coverage-card__content {
	position: relative;
	z-index: 2;
	display: grid;
	gap: 0.7rem;
	max-width: 24rem;
}

.coverage-card__content::before {
	width: 2.25rem;
	height: 2px;
	border-radius: 999px;
	background: linear-gradient(90deg, var(--langit-primary), rgba(56, 189, 248, 0.2));
	content: "";
	transition: width var(--langit-transition-smooth);
}

.coverage-card:hover .coverage-card__content::before {
	width: 3.5rem;
}

.coverage-card h3 {
	margin-bottom: 0;
	color: #ffffff;
	font-size: clamp(1.25rem, 1.1rem + 0.75vw, 1.75rem);
	font-weight: 800;
	line-height: 1.15;
	letter-spacing: -0.02em;
	text-transform: none;
}

.coverage-card p {
	display: -webkit-box;
	margin-bottom: 0;
	overflow: hidden;
	color: rgba(226, 232, 240, 0.85);
	font-size: clamp(0.92rem, 0.88rem + 0.16vw, 1rem);
	line-height: 1.65;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
}

.solution-card {
	align-items: start;
	gap: 0.75rem;
}

.solution-card p {
	margin-bottom: 0;
	color: var(--langit-muted);
}

.vision-mission-grid {
	display: grid;
	gap: var(--langit-space-md);
}

.statement-card {
	align-content: start;
}

.statement-card p:last-child {
	margin-bottom: 0;
}

.statement-card--vision {
	background:
		linear-gradient(135deg, rgba(88, 175, 255, 0.16), rgba(255, 255, 255, 0.94)),
		var(--langit-surface);
}

.mission-list {
	display: grid;
	gap: 0.85rem;
	margin-bottom: 0;
	padding-left: 0;
	color: var(--langit-muted);
	list-style: none;
}

.mission-list li {
	position: relative;
	padding-left: 1.45rem;
}

.mission-list li::before {
	position: absolute;
	top: 0.55em;
	left: 0;
	width: 0.5rem;
	height: 0.5rem;
	border-radius: 999px;
	background: var(--langit-primary);
	box-shadow: 0 0 0 0.25rem rgba(88, 175, 255, 0.14);
	content: "";
}

.legality-card {
	display: grid;
	min-height: 10rem;
	place-items: center;
	padding: var(--langit-space-md);
	border: 1px solid var(--langit-border);
	border-radius: var(--langit-card-radius);
	background: var(--langit-surface);
	box-shadow: var(--langit-card-shadow);
	text-align: center;
}

.legality-card img,
.legality-card span {
	width: 3rem;
	height: 3rem;
	padding: 0.45rem;
	border-radius: var(--langit-radius);
	background:
		linear-gradient(135deg, rgba(88, 175, 255, 0.18), rgba(56, 189, 248, 0.08));
	border: 1px solid rgba(88, 175, 255, 0.28);
}

.legality-card h3,
.team-card h3,
.feature-card h3 {
	margin-bottom: 0;
}

.team-card,
.feature-card {
	display: grid;
	align-content: start;
	gap: 1rem;
}

.team-card p,
.feature-card p {
	margin-bottom: 0;
}

.team-card__visual {
	display: grid;
	place-items: center;
	aspect-ratio: 16 / 10;
	border-radius: var(--langit-radius);
	background:
		linear-gradient(135deg, rgba(15, 23, 42, 0.9), rgba(15, 23, 42, 0.72)),
		linear-gradient(90deg, rgba(88, 175, 255, 0.18) 1px, transparent 1px),
		linear-gradient(rgba(88, 175, 255, 0.18) 1px, transparent 1px);
	background-size: auto, 28px 28px, 28px 28px;
}

.team-card__visual img {
	width: 3.5rem;
	height: 3.5rem;
	padding: 0.55rem;
	border: 1px solid rgba(255, 255, 255, 0.42);
	border-radius: var(--langit-radius);
	background: rgba(248, 250, 252, 0.92);
	box-shadow: 0 14px 28px rgba(56, 189, 248, 0.22);
}

.team-card--profile .team-card__visual {
	overflow: hidden;
	text-decoration: none;
}

.team-card--profile .team-card__photo {
	width: 100%;
	height: 100%;
	padding: 0;
	border: 0;
	object-fit: cover;
}

.team-card--profile h3 a {
	color: inherit;
	text-decoration: none;
}

.team-card__role {
	color: var(--langit-secondary);
	font-weight: 750;
}

.process-card {
	position: relative;
	display: grid;
	align-content: start;
	gap: var(--langit-space-sm);
	height: 100%;
	min-width: 0;
	padding: clamp(1.5rem, 1.25rem + 1vw, 2.25rem);
	border: 1px solid rgba(226, 232, 240, 0.7);
	border-radius: var(--langit-card-radius);
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(248, 250, 252, 0.95) 100%);
	box-shadow: var(--langit-card-shadow);
	transition: border-color var(--langit-transition-smooth), box-shadow var(--langit-transition-smooth), transform var(--langit-transition-smooth), background-color var(--langit-transition-smooth);
}

.process-card:hover {
	border-color: rgba(88, 175, 255, 0.45);
	box-shadow: var(--langit-card-shadow-hover);
	transform: translateY(-5px);
}

.process-card span {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 2.75rem;
	height: 2.75rem;
	border-radius: 999px;
	background: linear-gradient(135deg, rgba(88, 175, 255, 0.12), rgba(56, 189, 248, 0.05));
	border: 1px solid rgba(88, 175, 255, 0.25);
	color: var(--langit-primary);
	font-size: 1rem;
	font-weight: 850;
	font-family: monospace, var(--langit-font-sans);
	box-shadow: 0 4px 12px rgba(88, 175, 255, 0.08);
	transition: border-color var(--langit-transition-fast), box-shadow var(--langit-transition-fast), transform var(--langit-transition-fast), background var(--langit-transition-fast);
}

.process-card:hover span {
	border-color: rgba(88, 175, 255, 0.55);
	box-shadow: 0 8px 20px rgba(88, 175, 255, 0.2);
	transform: scale(1.05);
	background: linear-gradient(135deg, rgba(88, 175, 255, 0.18), rgba(56, 189, 248, 0.08));
}

.process-card h3 {
	margin-bottom: 0;
	font-size: clamp(1.15rem, 1rem + 0.3vw, 1.35rem);
	font-weight: 750;
	line-height: 1.22;
}

.process-card p {
	margin-bottom: 0;
	color: var(--langit-muted);
}

/* ─── Compact Contact Bar ─────────────────────────────────────────────────── */
.contact-bar-section {
	padding-block: clamp(1.75rem, 4vh, 3rem);
	background: var(--langit-surface);
	border-bottom: 1px solid var(--langit-border);
}

.contact-bar {
	display: grid;
	gap: var(--langit-space-md) var(--langit-space-lg);
	align-items: center;
	grid-template-columns: 1.1fr 1.3fr 2.2fr auto; /* Desktop: Phone, Email, Address, CTA Buttons */
}

.contact-bar__item {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	min-width: 0;
}

.contact-bar__label {
	font-size: 0.72rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--langit-muted);
}

.contact-bar__value {
	font-size: 0.92rem;
	font-weight: 700;
	color: var(--langit-secondary);
	text-decoration: none;
	transition: color var(--langit-transition-smooth);
	word-break: break-word;
}

a.contact-bar__value:hover {
	color: var(--langit-primary);
}

.contact-bar__actions {
	display: flex;
	gap: 0.75rem;
	justify-content: flex-start;
	flex-wrap: wrap;
}

.contact-bar__actions .button {
	padding: 0.55rem 1.15rem;
	font-size: 0.82rem;
}

@media (max-width: 1024px) {
	.contact-bar {
		grid-template-columns: repeat(2, 1fr); /* Tablet: 2 columns */
		gap: var(--langit-space-md) var(--langit-space-lg);
	}
}

@media (max-width: 640px) {
	.contact-bar {
		grid-template-columns: 1fr; /* Mobile: 1 column */
		gap: 1.25rem;
	}
	
	.contact-bar__actions {
		flex-direction: column;
		width: 100%;
		gap: 0.65rem;
	}
	
	.contact-bar__actions .button {
		width: 100%;
		justify-content: center;
		text-align: center;
	}
}

.contact-form-layout {
	display: grid;
	gap: var(--langit-space-lg);
	align-items: start;
}

.contact-page-grid {
	display: grid;
	gap: var(--langit-space-lg);
	align-items: start;
	grid-template-columns: 1fr;
}

.contact-panel {
	display: grid;
	gap: var(--langit-space-md);
	min-width: 0;
	padding: clamp(1.1rem, 2.6vw, var(--langit-space-lg));
	border: 1px solid rgba(203, 213, 225, 0.78);
	border-radius: var(--langit-radius);
	background: var(--langit-surface);
	box-shadow: 0 18px 45px rgba(15, 23, 42, 0.06);
}

.contact-panel--form {
	position: relative;
	z-index: 1;
}

.contact-panel--info {
	width: 100%;
	max-width: 100%;
}

.contact-form-stack {
	display: grid;
	gap: var(--langit-space-md);
	min-width: 0;
}

.form-placeholder {
	padding: clamp(1.15rem, 2.4vw, var(--langit-space-lg));
	border: 1px solid var(--langit-border);
	border-radius: var(--langit-radius);
	background: var(--langit-surface);
	box-shadow: 0 1px 0 rgba(15, 23, 42, 0.04);
}

.form-placeholder__fields {
	display: grid;
	gap: 1rem;
	grid-template-columns: 1fr;
}

.contact-fallback-form label {
	display: grid;
	gap: 0.5rem;
	min-width: 0;
}

.contact-fallback-form label > span {
	color: var(--langit-secondary);
	font-size: 0.9rem;
	font-weight: 800;
}

.contact-form-honeypot {
	position: absolute;
	left: -9999px;
	visibility: hidden;
}

.contact-form-message {
	padding: 0.85rem 1rem;
	border: 1px solid var(--langit-border);
	border-radius: var(--langit-radius);
	font-weight: 750;
}

.contact-form-message--success {
	border-color: rgba(34, 197, 94, 0.38);
	background: rgba(34, 197, 94, 0.12);
	color: #166534;
}

.contact-form-message--error {
	border-color: rgba(239, 68, 68, 0.38);
	background: rgba(239, 68, 68, 0.1);
	color: #991b1b;
}

.quote-form-placeholder span,
.shortcode-placeholder {
	display: flex;
	min-height: 2.85rem;
	align-items: center;
	padding: 0.72rem 0.85rem;
	border: 1px solid var(--langit-border);
	border-radius: var(--langit-radius);
	background: var(--langit-background);
	color: var(--langit-muted);
	overflow-wrap: anywhere;
}

.form-placeholder__message {
	grid-column: 1 / -1;
	min-height: auto;
}

.quote-form-placeholder .form-placeholder__message {
	min-height: 8rem;
	align-items: flex-start;
}

.contact-fallback-form textarea,
.contact-form-panel textarea,
.contact-form-panel .ff-el-form-control textarea {
	min-height: clamp(12rem, 24vw, 16rem);
	line-height: 1.65;
}

.contact-fallback-form button {
	grid-column: 1 / -1;
	justify-self: start;
	margin-top: 0.25rem;
}

.shortcode-placeholder {
	margin-top: var(--langit-space-md);
	background: rgba(88, 175, 255, 0.12);
	color: var(--langit-secondary);
	font-weight: 800;
}

.contact-form-panel__shortcode {
	min-width: 0;
	pointer-events: auto;
}

.contact-form-panel .fluentform form,
.contact-form-panel .fluentform .frm-fluent-form {
	gap: 1rem;
}

.contact-form-panel .ff-el-group {
	margin-bottom: 0;
}

.contact-form-panel input,
.contact-form-panel textarea,
.contact-form-panel select {
	min-height: 3.05rem;
	position: relative;
	z-index: 1;
}

.quick-contact-card {
	display: grid;
	gap: 0.75rem;
	padding: var(--langit-space-md);
	border: 1px solid rgba(88, 175, 255, 0.38);
	border-radius: var(--langit-radius);
	background:
		linear-gradient(135deg, rgba(88, 175, 255, 0.16), rgba(255, 255, 255, 0.9)),
		var(--langit-surface);
}




.quick-contact-card h3,
.quick-contact-card p {
	margin-bottom: 0;
}

.quick-contact-card .button {
	width: max-content;
	max-width: 100%;
}

.quote-process-card,
.maintenance-flow-card {
	align-content: start;
}

.quote-process-list {
	display: grid;
	gap: 0.8rem;
	margin: 0;
	padding-left: 1.25rem;
	color: var(--langit-muted);
}

.quote-service-selector {
	display: grid;
	justify-items: center;
	gap: var(--langit-space-md);
}

.quote-service-grid,
.quote-support-grid,
.maintenance-plan-grid,
.maintenance-coverage-grid,
.maintenance-sla-grid {
	display: grid;
	gap: var(--langit-space-md);
	grid-template-columns: 1fr;
	width: 100%;
}

.quote-service-option {
	display: grid;
	grid-template-columns: auto minmax(0, 1fr);
	align-items: start;
	gap: 0.85rem;
	cursor: pointer;
}

.quote-service-option input {
	width: 1.15rem;
	height: 1.15rem;
	margin-top: 0.2rem;
	accent-color: var(--langit-primary);
}

.quote-service-option strong,
.quote-support-card h3,
.maintenance-plan-card h3,
.maintenance-coverage-card h3,
.maintenance-sla-card h3 {
	display: block;
	margin-bottom: 0.35rem;
	color: var(--langit-secondary);
	line-height: 1.25;
}

.quote-service-option small,
.quote-support-card p,
.maintenance-plan-card p,
.maintenance-coverage-card p,
.maintenance-sla-card p {
	color: var(--langit-muted);
	font-size: 0.95rem;
	line-height: 1.6;
}

.quote-support-card,
.maintenance-plan-card,
.maintenance-coverage-card,
.maintenance-sla-card {
	display: grid;
	align-content: start;
	gap: 0.4rem;
}

.quote-support-card h3,
.quote-support-card p,
.maintenance-plan-card h3,
.maintenance-plan-card p,
.maintenance-coverage-card h3,
.maintenance-coverage-card p,
.maintenance-sla-card h3,
.maintenance-sla-card p {
	margin-bottom: 0;
}

.maintenance-sla-card strong {
	color: var(--langit-primary);
	font-size: clamp(1.45rem, 4vw, 2.35rem);
	line-height: 1;
}

.quote-form-placeholder .form-placeholder__message {
	grid-column: 1 / -1;
}

.support-cta__actions {
	justify-content: center;
}

.cta-section {
	display: grid;
	gap: var(--langit-space-md);
	justify-items: center;
	padding: clamp(2.5rem, 2rem + 4vw, 4.5rem);
	border: 1px solid rgba(88, 175, 255, 0.22);
	border-radius: var(--langit-card-radius);
	background:
		linear-gradient(135deg, rgba(88, 175, 255, 0.06), rgba(56, 189, 248, 0.02)),
		rgba(255, 255, 255, 0.85);
	backdrop-filter: blur(20px);
	box-shadow: 0 30px 60px -15px rgba(15, 23, 42, 0.05), 0 1px 3px rgba(15, 23, 42, 0.01);
	text-align: center;
	transition: border-color var(--langit-transition-smooth), box-shadow var(--langit-transition-smooth);
}

.cta-section:hover {
	border-color: rgba(88, 175, 255, 0.4);
	box-shadow: 0 40px 80px -20px rgba(15, 23, 42, 0.1);
}

.cta-section__content,
.cta-section__actions {
	margin-inline: auto;
}

.cta-section p {
	max-width: 60ch;
}

.cta-section__actions {
	display: grid;
	justify-items: center;
	gap: var(--langit-space-sm);
}

.cta-section--contact,
.cta-section--consultation {
	border-color: rgba(88, 175, 255, 0.35);
}

.inquiry-section__form {
	width: min(100%, 34rem);
	padding: var(--langit-space-sm);
	border: 1px solid var(--langit-border);
	border-radius: var(--langit-radius);
	background: var(--langit-background);
	text-align: left;
}

.entry-header {
	padding-block: var(--langit-space-xl) var(--langit-space-lg);
	background: var(--langit-surface);
	border-bottom: 1px solid var(--langit-border);
}

.entry-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 1rem;
	color: var(--langit-muted);
	font-size: 0.92rem;
}

.entry-meta a {
	color: inherit;
}

.entry-content {
	padding-block: var(--langit-space-lg);
}

.entry-content > .alignfull {
	width: 100%;
}

.blog-layout {
	display: grid;
	gap: var(--langit-space-lg);
	padding-block: var(--langit-space-xl);
	align-items: start;
}

.blog-layout--single {
	padding-top: var(--langit-space-lg);
}

.blog-layout--listing {
	display: block;
}

.blog-content {
	min-width: 0;
}

.blog-grid {
	display: grid;
	gap: var(--langit-space-md);
	grid-template-columns: 1fr;
}

.blog-grid > .section {
	grid-column: 1 / -1;
	padding-block: 0;
}

.featured-article {
	display: grid;
	gap: var(--langit-space-sm);
	margin-bottom: var(--langit-space-lg);
}

.post-card {
	display: grid;
	grid-template-rows: auto auto 1fr auto;
	gap: var(--langit-space-sm);
	height: 100%;
	padding: 0;
	overflow: hidden;
	background: var(--langit-surface);
	border: 1px solid rgba(226, 232, 240, 0.7);
	border-radius: var(--langit-card-radius);
	box-shadow: var(--langit-card-shadow);
	transition: border-color var(--langit-transition-smooth), box-shadow var(--langit-transition-smooth), transform var(--langit-transition-smooth);
}

.post-card:hover {
	border-color: rgba(88, 175, 255, 0.45);
	box-shadow: var(--langit-card-shadow-hover);
	transform: translateY(-5px);
}

.post-card__media {
	display: block;
	overflow: hidden;
	border-radius: calc(var(--langit-card-radius) - 1px) calc(var(--langit-card-radius) - 1px) 0 0;
	background: #0f172a;
	transform: translateZ(0);
	isolation: isolate;
}

.post-card__media img,
.post-card__media span {
	display: block;
	width: 100%;
	height: auto;
	aspect-ratio: 16 / 9;
	object-fit: cover;
	transition: transform 1.2s var(--langit-transition-smooth);
	border-top-left-radius: calc(var(--langit-card-radius) - 1px);
	border-top-right-radius: calc(var(--langit-card-radius) - 1px);
}

.post-card:hover .post-card__media img,
.post-card:hover .post-card__media span {
	transform: scale(1.04);
}



.post-card__header,
.post-card .entry-summary,
.post-card .read-more-link {
	margin-inline: clamp(1.5rem, 1.25rem + 1vw, 2.25rem);
}

.post-card__header {
	display: grid;
	gap: 0.65rem;
}

.post-card .read-more-link {
	margin-bottom: clamp(1.5rem, 1.25rem + 1vw, 2.25rem);
	font-weight: 850;
	text-decoration: none;
	color: var(--langit-secondary);
	transition: color var(--langit-transition-fast);
}

.post-card:hover .read-more-link {
	color: var(--langit-primary);
}

.post-card .read-more-link::after {
	content: "→";
	margin-left: 0.4rem;
	color: var(--langit-primary);
	display: inline-block;
	transition: transform var(--langit-transition-fast);
}

.post-card:hover .read-more-link::after {
	transform: translateX(4px);
}

.post-card__term,
.tag-list a,
.tag-cloud a {
	display: inline-flex;
	align-items: center;
	min-height: 1.75rem;
	padding: 0.25rem 0.75rem;
	border: 1px solid rgba(88, 175, 255, 0.2);
	border-radius: 999px;
	background: rgba(88, 175, 255, 0.06);
	color: var(--langit-primary);
	font-size: 0.72rem;
	font-weight: 750;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	text-decoration: none;
}

.post-card__term a {
	color: inherit;
	text-decoration: none;
}

.post-card__term {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: auto;
	max-width: fit-content;
	justify-self: start;
	align-self: start;
	padding: 6px 12px;
	border-radius: 999px;
	min-height: unset;
}

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

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

.post-card .entry-summary {
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.post-card .entry-summary p {
	display: inline;
	margin: 0;
	color: var(--langit-muted);
}

.trust-card {
	display: grid;
	align-content: start;
	gap: 0.85rem;
	border: 1px solid rgba(226, 232, 240, 0.8);
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(248, 250, 252, 0.95) 100%);
}

.trust-card strong {
	color: var(--langit-primary);
	font-size: clamp(2.5rem, 8vw, 3.75rem);
	font-weight: 850;
	letter-spacing: -0.04em;
	line-height: 1;
	background: linear-gradient(135deg, var(--langit-primary) 0%, var(--langit-accent) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	display: block;
}

.trust-card h3,
.trust-card p {
	margin-bottom: 0;
}

.trust-card p {
	color: var(--langit-muted);
}

.testimonial-card {
	display: grid;
	align-content: start;
	gap: var(--langit-space-sm);
}

.testimonial-card__header {
	display: flex;
	gap: 0.85rem;
	align-items: flex-start;
}

.testimonial-card__logo,
.client-logo-item {
	display: grid;
	place-items: center;
	border: 1px solid var(--langit-border);
	border-radius: var(--langit-card-radius);
	background: var(--langit-background);
}

.testimonial-card__logo {
	flex: 0 0 3.25rem;
	width: 3.25rem;
	height: 3.25rem;
	overflow: hidden;
}

.testimonial-card__logo img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	padding: 0.35rem;
}

.testimonial-card h3,
.testimonial-card blockquote,
.testimonial-card blockquote p,
.testimonial-card__meta,
.testimonial-card__rating {
	margin-bottom: 0;
}

.testimonial-card blockquote {
	color: var(--langit-text);
	line-height: 1.75;
}

.testimonial-card__meta {
	color: var(--langit-muted);
	font-size: 0.92rem;
}

.testimonial-card__rating {
	width: max-content;
	padding: 0.35rem 0.65rem;
	border-radius: 999px;
	background: rgba(88, 175, 255, 0.14);
	color: var(--langit-secondary);
	font-size: 0.82rem;
	font-weight: 850;
}

.faq-layout,
.faq-list {
	display: grid;
	gap: var(--langit-space-md);
}

.faq-item {
	height: auto;
	padding: 0;
	overflow: hidden;
}

.faq-item summary {
	position: relative;
	display: grid;
	gap: 0.45rem;
	min-height: 3.5rem;
	padding: var(--langit-space-md);
	padding-right: calc(var(--langit-space-md) + 2.25rem);
	cursor: pointer;
	list-style: none;
}

.faq-item summary::-webkit-details-marker {
	display: none;
}

.faq-item summary::after {
	position: absolute;
	top: 50%;
	right: var(--langit-space-md);
	display: grid;
	width: 1.75rem;
	height: 1.75rem;
	place-items: center;
	border: 1px solid rgba(88, 175, 255, 0.35);
	border-radius: 999px;
	background: rgba(88, 175, 255, 0.12);
	color: var(--langit-secondary);
	content: "+";
	font-size: 1.2rem;
	font-weight: 750;
	line-height: 1;
	transform: translateY(-50%);
}

.faq-item[open] summary::after {
	content: "-";
}

.faq-item summary strong {
	color: var(--langit-secondary);
	font-size: clamp(1rem, 0.95rem + 0.22vw, 1.18rem);
	line-height: 1.35;
}

.faq-item__content {
	padding: 0 var(--langit-space-md) var(--langit-space-md);
	color: var(--langit-muted);
}

.faq-item__content > *:last-child {
	margin-bottom: 0;
}

.download-grid,
.certification-grid {
	display: grid;
	gap: var(--langit-space-md);
	grid-template-columns: 1fr;
}

.download-card,
.certification-card {
	display: grid;
	gap: var(--langit-space-md);
	padding: var(--langit-space-sm);
}

.download-card__cover,
.download-preview,
.certification-card__cover,
.certification-preview {
	display: grid;
	place-items: center;
	overflow: hidden;
	aspect-ratio: 4 / 3;
	border: 1px solid var(--langit-border);
	border-radius: 14px;
	background:
		linear-gradient(135deg, rgba(15, 23, 42, 0.9), rgba(15, 23, 42, 0.72)),
		linear-gradient(90deg, rgba(88, 175, 255, 0.18) 1px, transparent 1px),
		linear-gradient(rgba(88, 175, 255, 0.18) 1px, transparent 1px);
	background-size: auto, 28px 28px, 28px 28px;
	color: #ffffff;
	text-decoration: none;
}

.download-card__cover img,
.download-preview img,
.certification-card__cover img,
.certification-preview img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.download-card__cover span,
.download-preview span,
.certification-card__cover span,
.certification-preview span {
	padding: 0.55rem 0.75rem;
	border: 1px solid rgba(255, 255, 255, 0.42);
	border-radius: 999px;
	background: rgba(248, 250, 252, 0.92);
	color: var(--langit-secondary);
	font-size: 0.82rem;
	font-weight: 850;
}

.download-card__body,
.download-panel,
.certification-card__body,
.certification-panel {
	display: grid;
	align-content: start;
	gap: 1rem;
}

.download-card h3,
.download-card p,
.download-panel h2,
.certification-card h3,
.certification-card p,
.certification-panel h2 {
	margin-bottom: 0;
}

.download-card h3 a,
.certification-card h3 a {
	color: inherit;
	text-decoration: none;
}

.download-card__meta,
.certification-card__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.download-card__meta span,
.download-meta-list dd,
.certification-card__meta span,
.certification-meta-list dd {
	width: max-content;
	max-width: 100%;
	padding: 0.35rem 0.65rem;
	border-radius: 999px;
	background: rgba(88, 175, 255, 0.14);
	color: var(--langit-secondary);
	font-size: 0.82rem;
	font-weight: 800;
}

.download-detail-grid,
.certification-detail-grid {
	display: grid;
	gap: var(--langit-space-lg);
	align-items: start;
}

.download-preview,
.certification-preview {
	min-height: 16rem;
	padding: 0;
}

.download-meta-list,
.certification-meta-list {
	display: grid;
	gap: 0.85rem;
	margin: 0;
}

.download-meta-list div,
.certification-meta-list div {
	display: grid;
	gap: 0.35rem;
}

.download-meta-list dt,
.certification-meta-list dt {
	color: var(--langit-muted);
	font-size: 0.82rem;
	font-weight: 750;
}

.download-meta-list dd,
.certification-meta-list dd {
	margin: 0;
}

.client-logo-title {
	margin-bottom: 0;
	text-align: center;
}

.client-logo-grid {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.client-logo-item {
	min-height: 5rem;
	padding: var(--langit-space-sm);
	color: var(--langit-secondary);
	font-weight: 850;
	box-shadow: 0 10px 30px rgba(15, 23, 42, 0.045);
	text-align: center;
	text-decoration: none;
}

.client-logo-item img {
	max-width: 100%;
	max-height: 3.25rem;
	object-fit: contain;
}

.client-logo-item span {
	overflow-wrap: anywhere;
}

.client-logo-item--link {
	transition: border-color 180ms ease, box-shadow 180ms ease, transform 180ms ease;
}

.client-logo-item--link:hover,
.client-logo-item--link:focus-visible {
	border-color: rgba(88, 175, 255, 0.48);
	box-shadow: var(--langit-shadow);
	transform: translateY(-2px);
}

.client-logo-item--sector {
	position: relative;
	min-height: 7rem;
	overflow: hidden;
	padding: var(--langit-space-sm);
	border-color: rgba(88, 175, 255, 0.22);
	background: var(--langit-secondary);
	color: #ffffff;
	isolation: isolate;
}

.client-logo-item--sector::before,
.client-logo-item--sector::after {
	position: absolute;
	inset: 0;
	content: "";
	pointer-events: none;
}

.client-logo-item--sector::before {
	z-index: 0;
	background: var(--client-image) center / cover no-repeat;
	transform: scale(1.02);
	transition: transform 360ms ease;
}

.client-logo-item--sector::after {
	z-index: 1;
	background:
		linear-gradient(180deg, rgba(7, 17, 32, 0.18), rgba(7, 17, 32, 0.86)),
		radial-gradient(circle at 20% 20%, rgba(88, 175, 255, 0.28), transparent 34%);
}

.client-logo-item--sector:hover::before,
.client-logo-item--sector:focus-visible::before {
	transform: scale(1.06);
}

.client-logo-item--sector span {
	position: relative;
	z-index: 2;
	color: #ffffff;
	text-shadow: 0 2px 14px rgba(0, 0, 0, 0.28);
}

.client-card {
	display: grid;
	gap: var(--langit-space-sm);
	padding: var(--langit-space-sm);
}

.client-card--sector {
	min-width: 0;
	padding: 0;
	overflow: hidden;
	border: 1px solid rgba(88, 175, 255, 0.22);
	border-radius: var(--langit-card-radius);
	background: var(--langit-secondary);
	box-shadow: 0 24px 60px rgba(15, 23, 42, 0.13);
	transition: border-color 240ms ease, box-shadow 240ms ease, transform 240ms ease;
}

.client-card--sector:hover,
.client-card--sector:focus-within {
	border-color: rgba(88, 175, 255, 0.5);
	box-shadow: 0 30px 76px rgba(15, 23, 42, 0.2);
	transform: translateY(-3px);
}

.client-card__visual {
	position: relative;
	display: grid;
	min-height: clamp(17rem, 24vw, 23rem);
	align-items: end;
	overflow: hidden;
	padding: clamp(1.15rem, 1rem + 0.9vw, 1.75rem);
	color: #ffffff;
	text-decoration: none;
	isolation: isolate;
}

.client-card__visual::before,
.client-card__visual::after {
	position: absolute;
	inset: 0;
	content: "";
	pointer-events: none;
	transition: opacity 260ms ease, transform 420ms ease;
}

.client-card__visual::before {
	z-index: 0;
	background: var(--client-image) center / cover no-repeat;
	transform: scale(1.02);
}

.client-card__visual::after {
	z-index: 1;
	background:
		radial-gradient(circle at 20% 18%, rgba(88, 175, 255, 0.36), transparent 34%),
		linear-gradient(180deg, rgba(7, 17, 32, 0.08), rgba(7, 17, 32, 0.93)),
		linear-gradient(90deg, rgba(7, 17, 32, 0.82), rgba(7, 17, 32, 0.3));
}

.client-card--sector:hover .client-card__visual::before,
.client-card--sector:focus-within .client-card__visual::before {
	transform: scale(1.065);
}

.client-card--sector .client-card__body {
	position: relative;
	z-index: 2;
	max-width: 24rem;
}

.client-card--sector .client-card__body::before {
	width: 2.75rem;
	height: 3px;
	border-radius: 999px;
	background: linear-gradient(90deg, var(--langit-primary), rgba(56, 189, 248, 0.18));
	content: "";
}

.client-card--sector h3 {
	color: #ffffff;
	font-size: clamp(1.2rem, 1.05rem + 0.72vw, 1.75rem);
	line-height: 1.1;
}

.client-card--sector p {
	color: rgba(235, 246, 255, 0.84);
	line-height: 1.65;
}

.client-card--sector .post-card__term {
	border-color: rgba(88, 175, 255, 0.34);
	background: rgba(88, 175, 255, 0.14);
	color: #bde4ff;
}

.client-card--reference {
	position: relative;
	min-height: 100%;
	overflow: hidden;
	padding: 0;
	border: 1px solid rgba(148, 163, 184, 0.28);
	border-radius: var(--langit-card-radius);
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(241, 248, 255, 0.92)),
		var(--langit-surface);
	box-shadow: 0 18px 46px -20px rgba(15, 23, 42, 0.2);
	isolation: isolate;
	transition: border-color 220ms ease, box-shadow 220ms ease, transform 220ms ease;
}

.client-card--reference::before,
.client-card--reference::after {
	position: absolute;
	content: "";
	pointer-events: none;
}

.client-card--reference::before {
	inset: 0;
	z-index: 0;
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.98) 48%, rgba(255, 255, 255, 0.9)),
		var(--client-image) center / cover no-repeat;
	opacity: 0.98;
}

.client-card--reference::after {
	top: 0;
	right: 0;
	left: 0;
	z-index: 1;
	height: 3px;
	background: linear-gradient(90deg, var(--langit-primary), rgba(56, 189, 248, 0.12));
}

.client-card--reference:hover,
.client-card--reference:focus-within {
	border-color: rgba(88, 175, 255, 0.45);
	box-shadow: 0 28px 62px -24px rgba(15, 23, 42, 0.28);
	transform: translateY(-3px);
}

.client-card--reference .client-card__body {
	position: relative;
	z-index: 2;
	display: grid;
	min-height: 100%;
	align-content: start;
	gap: 0.85rem;
	padding: clamp(1.15rem, 1rem + 0.7vw, 1.65rem);
	color: var(--langit-text);
	text-decoration: none;
}

.client-card--reference h3 {
	margin-bottom: 0;
	color: var(--langit-secondary);
	font-size: clamp(1.05rem, 0.98rem + 0.28vw, 1.25rem);
	line-height: 1.3;
	letter-spacing: -0.01em;
}

.client-card--reference p {
	margin-bottom: 0;
	color: var(--langit-muted);
	font-size: 0.92rem;
	line-height: 1.55;
}

.client-card--reference .post-card__term {
	width: fit-content;
	max-width: 100%;
	border-color: rgba(88, 175, 255, 0.24);
	background: rgba(88, 175, 255, 0.1);
	color: #0f4c81;
}

.client-sector-archive {
	background:
		radial-gradient(circle at 12% 8%, rgba(88, 175, 255, 0.12), transparent 26rem),
		linear-gradient(180deg, rgba(241, 248, 255, 0.94), rgba(248, 250, 252, 0.99)),
		var(--langit-background);
}

.client-ecosystem-list {
	display: grid;
	gap: clamp(1.4rem, 1rem + 2vw, 2.4rem);
}

.client-ecosystem-card {
	--client-image: url("../images/industries/industry-industrial.webp");
	position: relative;
	display: grid;
	min-height: clamp(27rem, 34vw, 34rem);
	overflow: hidden;
	border: 1px solid rgba(88, 175, 255, 0.22);
	border-radius: calc(var(--langit-card-radius) + 4px);
	background:
		linear-gradient(135deg, rgba(8, 17, 31, 0.98), rgba(12, 25, 43, 0.96)),
		var(--langit-secondary);
	box-shadow: 0 34px 90px -34px rgba(15, 23, 42, 0.48);
	color: #ffffff;
	isolation: isolate;
	transition: border-color var(--langit-transition-smooth), box-shadow var(--langit-transition-smooth), transform var(--langit-transition-smooth);
}

.client-ecosystem-card::before,
.client-ecosystem-card::after {
	position: absolute;
	content: "";
	pointer-events: none;
}

.client-ecosystem-card::before {
	inset: 0;
	z-index: 0;
	background:
		linear-gradient(90deg, rgba(5, 10, 20, 0.92), rgba(5, 10, 20, 0.64) 46%, rgba(5, 10, 20, 0.28)),
		radial-gradient(circle at 20% 18%, rgba(88, 175, 255, 0.28), transparent 32rem),
		var(--client-image) center / cover no-repeat;
	transform: scale(1.01);
	transition: filter var(--langit-transition-smooth), transform 1.2s var(--langit-transition-smooth);
}

.client-ecosystem-card::after {
	inset: 0;
	z-index: 1;
	background-image:
		linear-gradient(rgba(88, 175, 255, 0.075) 1px, transparent 1px),
		linear-gradient(90deg, rgba(88, 175, 255, 0.075) 1px, transparent 1px),
		linear-gradient(180deg, transparent, rgba(5, 10, 20, 0.36));
	background-size: 38px 38px, 38px 38px, auto;
	mask-image: linear-gradient(90deg, rgba(0, 0, 0, 0.92), rgba(0, 0, 0, 0.42), transparent);
	opacity: 0.72;
}

.client-ecosystem-card:hover {
	border-color: rgba(88, 175, 255, 0.48);
	box-shadow: 0 42px 100px -34px rgba(15, 23, 42, 0.62);
	transform: translateY(-3px);
}

.client-ecosystem-card:hover::before {
	filter: saturate(1.06) contrast(1.04);
	transform: scale(1.035);
}

.client-ecosystem-card__visual,
.client-ecosystem-card__content {
	position: relative;
	z-index: 2;
}

.client-ecosystem-card__visual {
	display: none;
	align-items: end;
	min-height: 100%;
	padding: clamp(1.35rem, 1rem + 1.75vw, 2.4rem);
	border-right: 1px solid rgba(255, 255, 255, 0.1);
}

.client-ecosystem-card__visual span {
	width: fit-content;
	max-width: 100%;
	padding: 0.45rem 0.72rem;
	border: 1px solid rgba(255, 255, 255, 0.22);
	border-radius: 999px;
	background: rgba(15, 23, 42, 0.52);
	backdrop-filter: blur(16px);
	color: rgba(226, 232, 240, 0.9);
	font-size: 0.72rem;
	font-weight: 850;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.client-ecosystem-card__content {
	display: grid;
	align-content: center;
	gap: clamp(1.2rem, 1rem + 1vw, 1.8rem);
	padding: clamp(1.35rem, 1rem + 2.2vw, 3rem);
}

.client-ecosystem-card__header {
	display: grid;
	gap: 0.85rem;
	max-width: 48rem;
}

.client-ecosystem-card__header h2 {
	margin-bottom: 0;
	color: #ffffff;
	font-size: clamp(1.55rem, 1.2rem + 1.35vw, 2.65rem);
	line-height: 1.08;
	text-wrap: balance;
}

.client-ecosystem-card__header p:not(.section-eyebrow) {
	max-width: 62ch;
	margin-bottom: 0;
	color: rgba(226, 232, 240, 0.84);
}

.client-ecosystem-card__meta {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	width: fit-content;
	max-width: 100%;
	padding: 0.5rem 0.8rem;
	border: 1px solid rgba(88, 175, 255, 0.24);
	border-radius: 999px;
	background: rgba(88, 175, 255, 0.12);
	color: rgba(226, 232, 240, 0.86);
	font-size: 0.82rem;
	font-weight: 750;
}

.client-ecosystem-card__meta span {
	color: #ffffff;
	font-size: 1rem;
	font-weight: 900;
	line-height: 1;
}

.client-chip-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 0.55rem;
}

.client-chip {
	display: inline-flex;
	align-items: center;
	min-height: 2.3rem;
	max-width: 100%;
	padding: 0.5rem 0.72rem;
	border: 1px solid rgba(255, 255, 255, 0.14);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.09);
	backdrop-filter: blur(14px);
	color: rgba(248, 250, 252, 0.92);
	font-size: 0.85rem;
	font-weight: 760;
	line-height: 1.25;
	text-decoration: none;
	overflow-wrap: anywhere;
	transition: border-color var(--langit-transition-fast), background-color var(--langit-transition-fast), color var(--langit-transition-fast), transform var(--langit-transition-fast);
}

.client-chip:hover,
.client-chip:focus-visible {
	border-color: rgba(88, 175, 255, 0.48);
	background: rgba(88, 175, 255, 0.17);
	color: #ffffff;
	transform: translateY(-1px);
}

.client-card__logo,
.client-profile-card__logo {
	display: grid;
	place-items: center;
	overflow: hidden;
	border: 1px solid var(--langit-border);
	border-radius: var(--langit-radius);
	background: var(--langit-background);
	color: var(--langit-secondary);
	font-weight: 850;
	text-align: center;
	text-decoration: none;
}

.client-card__logo {
	min-height: 8rem;
	padding: var(--langit-space-md);
}

.client-card__logo img,
.client-profile-card__logo img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.client-card__logo span,
.client-profile-card__logo span {
	overflow-wrap: anywhere;
}

.client-card__body,
.client-panel {
	display: grid;
	align-content: start;
	gap: 0.85rem;
}

.client-card h3,
.client-card p {
	margin-bottom: 0;
}

.client-card h3 a {
	color: inherit;
	text-decoration: none;
}

.client-card__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	align-items: center;
}

.client-card__meta span,
.client-card__meta a,
.client-meta-list dd {
	width: max-content;
	max-width: 100%;
	padding: 0.35rem 0.65rem;
	border-radius: 999px;
	background: rgba(88, 175, 255, 0.14);
	color: var(--langit-secondary);
	font-size: 0.82rem;
	font-weight: 800;
}

.client-card__meta a {
	text-decoration: none;
}

.client-detail-grid {
	display: grid;
	gap: var(--langit-space-lg);
	align-items: start;
}

.client-profile-card {
	padding: var(--langit-space-sm);
}

.client-profile-card__logo {
	min-height: 13rem;
	padding: var(--langit-space-lg);
}

.client-profile-card__logo img {
	border-radius: calc(var(--langit-card-radius) - 4px);
	object-fit: cover;
}

.client-meta-list {
	display: grid;
	gap: 0.85rem;
	margin: 0;
}

.client-meta-list div {
	display: grid;
	gap: 0.35rem;
}

.client-meta-list dt {
	color: var(--langit-muted);
	font-size: 0.82rem;
	font-weight: 750;
}

.client-meta-list dd {
	margin: 0;
}

.search-form {
	display: flex;
	flex-wrap: wrap;
	gap: 0.65rem;
	max-width: 42rem;
}

.search-form label {
	flex: 1 1 15rem;
	min-width: 0;
}

.search-form .search-submit {
	flex: 0 0 auto;
}

.read-more-link {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	align-self: end;
	color: var(--langit-secondary);
	font-weight: 800;
	text-decoration: none;
	transition: color 180ms ease, gap 180ms ease;
}

.read-more-link::after {
	content: "→";
	color: var(--langit-primary);
	font-weight: 850;
}

.read-more-link:hover,
.read-more-link:focus {
	color: var(--langit-primary);
	gap: 0.55rem;
}

.pagination,
.posts-navigation,
.post-navigation {
	padding-block: var(--langit-space-md) var(--langit-space-xl);
}

.nav-links {
	display: grid;
	gap: var(--langit-space-sm);
}

.nav-links a {
	display: block;
	padding: var(--langit-space-sm);
	border: 1px solid var(--langit-border);
	border-radius: var(--langit-radius);
	background: var(--langit-surface);
	text-decoration: none;
}

.page-numbers {
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

.page-numbers a,
.page-numbers span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.75rem;
	min-height: 2.75rem;
	padding: 0.65rem 0.85rem;
	border: 1px solid var(--langit-border);
	border-radius: var(--langit-radius-sm);
	background: var(--langit-surface);
	color: var(--langit-ink);
	font-weight: 800;
	text-decoration: none;
}

.page-numbers .current,
.page-numbers a:hover,
.page-numbers a:focus {
	border-color: rgba(88, 175, 255, 0.45);
	background: var(--langit-primary);
	color: #ffffff;
}

.nav-subtitle {
	display: block;
	color: var(--langit-primary);
	font-size: 0.78rem;
	font-weight: 850;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

.nav-title {
	display: block;
	margin-top: 0.25rem;
	color: var(--langit-secondary);
	font-weight: 800;
}

.blog-sidebar {
	display: grid;
	gap: var(--langit-space-md);
}

.blog-widget {
	padding: var(--langit-space-md);
	border: 1px solid var(--langit-border);
	border-radius: var(--langit-radius);
	background: var(--langit-surface);
}

.blog-widget__title {
	margin-bottom: 0.85rem;
	font-size: 1.08rem;
}

.blog-widget ul {
	display: grid;
	gap: 0.55rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

.blog-widget a {
	text-decoration: none;
}

.tag-cloud {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	padding-left: 0;
	list-style: none;
}

.blog-widget--cta {
	background:
		linear-gradient(135deg, rgba(88, 175, 255, 0.18), rgba(255, 255, 255, 0.95)),
		var(--langit-surface);
}

.tag-cloud span {
	display: inline-flex;
	align-items: center;
	min-height: 2rem;
	padding: 0.35rem 0.65rem;
	border: 1px solid rgba(88, 175, 255, 0.28);
	border-radius: 999px;
	background:
		linear-gradient(135deg, rgba(88, 175, 255, 0.18), rgba(255, 255, 255, 0.95)),
		var(--langit-surface);
	color: var(--langit-secondary);
	font-size: 0.82rem;
	font-weight: 750;
}

.single-content,
.single-footer,
.single-featured-image,
.related-posts {
	width: min(100%, 820px);
	margin-inline: auto;
}

.single-featured-image {
	margin-block: 0 var(--langit-space-lg);
	overflow: hidden;
	border-radius: var(--langit-radius);
	background: var(--langit-surface);
}

.team-profile-image {
	width: 100%;
	margin-block: 0;
}

.single-featured-image img {
	width: 100%;
	aspect-ratio: 16 / 9;
	object-fit: cover;
}

.single-content {
	padding-block: 0 var(--langit-space-lg);
}

.single-content > * {
	max-width: 100%;
}

.single-content p,
.single-content li {
	color: var(--langit-text);
	font-size: clamp(1rem, 0.98rem + 0.12vw, 1.08rem);
	line-height: 1.75;
}

.single-content img {
	border-radius: var(--langit-radius);
}

.single-content table {
	display: block;
	max-width: 100%;
	overflow-x: auto;
	border-collapse: collapse;
}

.project-detail-grid {
	display: grid;
	gap: var(--langit-space-lg);
	align-items: start;
}

.project-detail-card {
	align-content: start;
}

.project-meta-list {
	display: grid;
	gap: 0.85rem;
	margin: 0;
}

.project-meta-list div {
	display: grid;
	gap: 0.2rem;
	padding-bottom: 0.85rem;
	border-bottom: 1px solid var(--langit-border);
}

.project-meta-list div:last-child {
	padding-bottom: 0;
	border-bottom: 0;
}

.project-meta-list dt {
	color: var(--langit-muted);
	font-size: 0.78rem;
	font-weight: 850;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

.project-meta-list dd {
	margin: 0;
	color: var(--langit-secondary);
	font-weight: 750;
}

.project-content {
	width: 100%;
	padding-block: 0;
}

.project-content .wp-block-gallery {
	gap: var(--langit-space-sm);
}

.project-content .wp-block-gallery img {
	aspect-ratio: 16 / 10;
	object-fit: cover;
}

.single-footer {
	padding-bottom: var(--langit-space-lg);
}

.tag-list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	align-items: center;
}

.tag-list span {
	color: var(--langit-muted);
	font-weight: 800;
}

.related-posts {
	display: grid;
	gap: var(--langit-space-md);
	padding-block: var(--langit-space-lg) var(--langit-space-xl);
}

.footer-cta {
	background:
		linear-gradient(180deg, var(--langit-background), rgba(248, 250, 252, 0.94));
	padding-block: clamp(3rem, 2.1rem + 4.5vw, 6rem) var(--langit-space-lg);
}

.footer-cta__inner {
	display: grid;
	gap: var(--langit-space-md);
	justify-items: center;
	padding: clamp(1.6rem, 1.1rem + 2.5vw, 3rem);
	border: 1px solid rgba(88, 175, 255, 0.34);
	border-radius: var(--langit-card-radius);
	background:
		linear-gradient(135deg, rgba(88, 175, 255, 0.18), rgba(56, 189, 248, 0.06)),
		var(--langit-surface);
	box-shadow: 0 24px 60px rgba(15, 23, 42, 0.08);
	text-align: center;
}


.footer-cta h2 {
	max-width: 720px;
	margin-bottom: 0;
	line-height: 1.12;
	text-wrap: balance;
}

.footer-cta p {
	max-width: 760px;
	margin-bottom: 0;
	color: var(--langit-muted);
}

.site-footer {
	background:
		linear-gradient(180deg, #090f1d, #050a14),
		var(--langit-secondary);
	color: rgba(226, 232, 240, 0.75);
}

.site-footer__inner {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(2rem, 1.5rem + 3vw, 3.5rem);
	width: min(100% - (var(--langit-gutter) * 2), var(--langit-container));
	margin-inline: auto;
	padding-block: var(--langit-space-xl);
}

.site-footer__brand {
	max-width: 36rem;
}

.site-footer__company {
	margin-top: 0.25rem;
	margin-bottom: 1.15rem;
	color: #ffffff;
	font-size: 1.15rem;
	font-weight: 850;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	display: inline-flex;
	align-items: center;
	border-left: 3px solid var(--langit-primary);
	padding-left: 0.75rem;
	line-height: 1.1;
}

@media (max-width: 767px) {
	/* Hero V2 Mobile responsive (≤ 767px) - Stacked Layout */
	.hero--home.hero--v2,
	.hero-v2 {
		min-height: auto !important;
		display: flex !important;
		flex-direction: column !important;
		padding: 0 !important; /* Remove base hero padding to eliminate top navbar gap and bottom empty space */
		background: #030f23 !important; /* Premium dark navy background for stacked layout */
		border-bottom: 1px solid rgba(203, 213, 225, 0.1) !important;
	}

	.hero-v2__bg-layer {
		position: relative !important;
		width: 100% !important;
		height: 35vh !important; /* Occupies ~35% of viewport height */
		max-height: none !important;
		aspect-ratio: auto !important;
		z-index: 1 !important;
		display: block !important;
		overflow: hidden !important;
	}

	.hero-v2__bg-slides {
		position: absolute !important;
		inset: 0 !important;
		width: 100% !important;
		height: 100% !important;
		max-height: none !important;
	}

	.hero-v2__bg-slide {
		display: none !important; /* Hide other slides to preserve performance */
	}

	.hero-v2__bg-slide--1 {
		display: block !important;
		position: absolute !important;
		inset: 0 !important;
		width: 100% !important;
		height: 100% !important;
		object-fit: cover !important;
		object-position: right center !important; /* Focus on strongest visual building subject */
		opacity: 1 !important;
		animation: none !important;
		transform: none !important;
	}

	.hero--home.hero--v2 .hero-v2__bg-overlay,
	.hero-v2 .hero-v2__bg-overlay,
	.hero--home.hero--v2 .hero-v2__overlay,
	.hero-v2 .hero-v2__overlay {
		position: absolute !important;
		inset: 0 !important;
		background: linear-gradient(
			180deg,
			rgba(3, 15, 35, 0.35) 0%,
			rgba(3, 15, 35, 0.45) 50%,
			#030f23 100%
		) !important; /* Fades seamlessly to navy at the bottom to connect with the content card */
		mix-blend-mode: normal !important;
		opacity: 1 !important;
		z-index: 2 !important;
	}

	.hero-v2__bg-overlay::after,
	.hero-v2__overlay::after {
		content: none !important; /* Disable desktop horizontal white gradient */
	}

	.hero-v2__content-layer {
		position: relative !important;
		margin-top: -8.5rem !important; /* Pull content card up further to overlap bottom of the image and shift layout upward */
		background: linear-gradient(180deg, rgba(3, 15, 35, 0) 0%, rgba(3, 15, 35, 0.95) 3.5rem, #030f23 7rem) !important; /* Seamless fading transition */
		border-radius: 0 !important; /* Remove card outline to unify layout */
		padding-block: 0.5rem 4.5rem !important; /* Reduced top padding to bring text closer, expanded bottom padding to detach CTA from partners */
		padding-inline: 1.25rem !important; /* Prevent edge-to-edge text */
		gap: 1.25rem !important;
		grid-template-columns: 1fr !important;
		z-index: 10;
		box-sizing: border-box !important;
		width: 100% !important;
		box-shadow: none !important; /* Remove separation shadow */
	}

	.hero-v2__content-inner {
		max-width: 100% !important;
	}

	.hero--v2 .hero-v2__badge,
	.hero-v2 .hero-v2__badge {
		margin-bottom: 0.35rem !important; /* Reduced vertical spacing */
		background: rgba(255, 255, 255, 0.08) !important;
		border-color: rgba(255, 255, 255, 0.15) !important;
		color: #ffffff !important;
		box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15) !important;
	}

	.hero--v2 .hero-v2__badge-dot,
	.hero-v2 .hero-v2__badge-dot {
		background: #38bdf8 !important;
	}

	.hero--v2 .hero-v2__headline,
	.hero-v2 .hero-v2__headline,
	.hero-v2 .hero-v2__title,
	.hero--v2 .hero-v2__title {
		font-size: clamp(1.8rem, 7vw, 2.35rem) !important;
		line-height: 1.05 !important;
		margin-bottom: 0.35rem !important; /* Reduced vertical spacing */
		color: #ffffff !important;
	}

	.hero-v2__headline-line {
		display: inline !important;
		white-space: normal !important;
	}

	.hero-v2__headline-line:not(:last-child)::after {
		content: " " !important;
	}

	.hero--v2 .hero-v2__description,
	.hero-v2 .hero-v2__description {
		font-size: 0.92rem !important;
		line-height: 1.55 !important;
		margin-bottom: 0.75rem !important; /* Reduced vertical spacing */
		color: rgba(241, 245, 249, 0.85) !important;
		/* Limit description to exactly 3 lines with truncation */
		display: -webkit-box !important;
		-webkit-line-clamp: 3 !important;
		-webkit-box-orient: vertical !important;
		overflow: hidden !important;
		text-overflow: ellipsis !important;
	}

	.hero-v2__cta,
	.hero-v2__actions {
		flex-direction: column !important;
		align-items: stretch !important;
		width: 100% !important;
		gap: 0.5rem !important; /* Reduced spacing between stacked buttons */
		display: flex !important;
	}

	.hero-v2__cta .button--hero-primary,
	.hero-v2__cta .button--hero-ghost,
	.hero-v2__actions .button--hero-primary,
	.hero-v2__actions .button--hero-ghost {
		width: 100% !important;
		min-height: 2.75rem !important;
		padding-inline: 1rem !important;
		font-size: 0.92rem !important;
		display: flex !important;
		justify-content: center !important;
		align-items: center !important;
		text-align: center !important;
	}

	.home-section--partners,
	.home-section-partners {
		padding-top: 1rem !important; /* Draw Technology Partners section closer */
	}
}

.site-footer__brand p:not(.site-footer__company) {
	font-size: 0.92rem;
	line-height: 1.65;
	color: rgba(226, 232, 240, 0.65);
}

.site-footer__grid {
	display: grid;
	gap: var(--langit-space-lg);
	grid-template-columns: 1fr;
}

.footer-column h3 {
	margin-bottom: 1.25rem;
	color: #ffffff;
	font-size: 0.9rem;
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.site-footer h2,
.site-footer h3,
.site-footer a {
	color: #ffffff;
}

.site-footer a {
	text-decoration: none;
	transition: color var(--langit-transition-fast), transform var(--langit-transition-fast);
}

.site-footer a:hover,
.site-footer a:focus {
	color: var(--langit-primary);
}

.footer-menu,
.footer-bottom-menu {
	display: flex;
	flex-wrap: wrap;
	gap: 0.35rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

.footer-menu {
	flex-direction: column;
	align-items: flex-start;
}

.footer-menu a {
	display: inline-flex;
	align-items: center;
	min-height: 2.25rem;
	padding: 0.35rem 0;
	color: rgba(226, 232, 240, 0.72);
}

.footer-menu a:hover,
.footer-menu a:focus {
	transform: translateX(4px);
}

.site-footer__bottom {
	border-top: 1px solid rgba(226, 232, 240, 0.08);
}

.site-footer__bottom-inner {
	display: grid;
	gap: var(--langit-space-sm);
	width: min(100% - (var(--langit-gutter) * 2), var(--langit-container));
	margin-inline: auto;
	padding-block: 1.5rem;
	color: rgba(226, 232, 240, 0.55);
	font-size: 0.88rem;
	text-align: center;
}

.site-footer__bottom-inner p {
	margin-bottom: 0;
}

.footer-bottom-menu {
	justify-content: center;
}

.footer-bottom-menu a {
	display: block;
	min-height: 2rem;
	padding: 0.25rem 0.5rem;
	color: rgba(255, 255, 255, 0.7);
}

/* Footer column typography */
.site-footer__tagline {
	font-size: 0.92rem;
	line-height: 1.65;
	color: rgba(226, 232, 240, 0.62);
	margin-top: 0.65rem;
}

.site-footer__col-heading {
	margin-top: 0;
	margin-bottom: 1.25rem;
	color: #ffffff;
	font-size: 0.82rem;
	font-weight: 800;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

/* Footer detail DL list (contact + office columns) */
.site-footer__detail-list {
	display: flex;
	flex-direction: column;
	gap: 1.1rem;
	margin: 0;
	padding: 0;
}

.site-footer__detail-item {
	display: flex;
	flex-direction: column;
	gap: 0.22rem;
}

.site-footer__detail-item dt {
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.07em;
	text-transform: uppercase;
	color: rgba(226, 232, 240, 0.4);
}

.site-footer__detail-item dd {
	margin: 0;
	font-size: 0.88rem;
	line-height: 1.6;
	color: rgba(226, 232, 240, 0.78);
}

.site-footer__detail-item dd a {
	color: rgba(226, 232, 240, 0.78);
	text-decoration: none;
	transition: color var(--langit-transition-fast);
}

.site-footer__detail-item dd a:hover,
.site-footer__detail-item dd a:focus {
	color: var(--langit-primary);
}

input,
textarea,
select {
	width: 100%;
	min-height: 2.85rem;
	padding: 0.72rem 0.85rem;
	border: 1px solid var(--langit-border);
	border-radius: var(--langit-radius);
	background: #ffffff;
	color: var(--langit-text);
	font: inherit;
}

.quote-service-option input[type="checkbox"] {
	width: 1.15rem;
	min-height: auto;
	padding: 0;
}

label,
.fluentform label {
	display: grid;
	gap: 0.45rem;
	color: var(--langit-secondary);
	font-size: 0.94rem;
	font-weight: 750;
}

::placeholder {
	color: #718096;
	opacity: 1;
}

input:focus,
textarea:focus,
select:focus {
	border-color: rgba(88, 175, 255, 0.78);
	outline: 3px solid rgba(88, 175, 255, 0.2);
	outline-offset: 0;
}

textarea {
	min-height: 9rem;
	resize: vertical;
}

.form-grid,
.fluentform .ff-el-group {
	display: grid;
	gap: 0.55rem;
}

.fluentform form,
.fluentform .frm-fluent-form {
	display: grid;
	gap: var(--langit-space-sm);
}

@media (max-width: 430px) {
	.search-form .search-submit {
		flex-basis: 100%;
	}

	.menu-toggle {
		width: 2.65rem;
		height: 2.65rem;
	}

	.hero-panel {
		min-height: 15rem;
	}

	.card:not(.post-card),
	.blog-widget,
	.form-placeholder,
	.process-card,
	.coverage-card,
	.legality-card {
		padding: var(--langit-space-sm);
	}

	.footer-cta__inner,
	.cta-section {
		padding: var(--langit-space-md);
	}
}


@media (min-width: 641px) and (max-width: 900px) {
	.primary-menu .langit-menu-products > .sub-menu {
		width: min(17rem, 100%);
		min-width: 0;
		max-width: 17rem;
		margin-inline-left: auto;
		padding-inline: 0.3rem;
	}

	.primary-menu .langit-menu-products .sub-menu a {
		min-height: 2.25rem;
		padding: 0.5rem 0.6rem;
		font-size: 0.88rem;
	}

	.primary-menu .langit-menu-products.is-submenu-open > .sub-menu {
		margin-top: 0.15rem;
		padding-block: 0.3rem;
	}
}

@media (min-width: 641px) {
	:root {
		--langit-gutter: 2rem;
		--langit-header-height: 76px;
		--langit-header-scrolled-height: 60px;
	}

	/* Hero V2: tablet portrait min-height */
	.hero--home.hero--v2 {
		min-height: 75vh;
	}

	.site-header__inner {
		gap: var(--langit-space-md);
	}

	.custom-logo {
		max-width: 11rem;
		max-height: 3.25rem;
	}

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

	.service-grid,
	.products-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.products-grid {
		--langit-product-grid-columns: 2;
	}

	.related-service-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.quote-service-grid,
	.quote-support-grid,
	.maintenance-plan-grid,
	.maintenance-coverage-grid,
	.maintenance-sla-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.coverage-grid,
	.legality-grid,
	.team-grid,
	.feature-grid,
	.process-grid,
	.contact-info-grid,
	.trust-grid,
	.testimonial-grid,
	.client-grid,
	.site-footer__grid,
	.card-grid--2,
	.card-grid--3,
	.card-grid--4,
	.why-choose-grid,
	.company-values-grid,
	.workflow-grid,
	.industries-serve-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.client-logo-grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}

	.form-placeholder__fields {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.form-placeholder__message {
		grid-column: 1 / -1;
	}

	.blog-grid,
	.download-grid,
	.certification-grid,
	.blog-grid--related {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.nav-links {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

/* ─── Hero V2: Tablet responsive (768px – 1024px) ───────────────────────────── */
@media (min-width: 768px) and (max-width: 1024px) {
	.hero--home.hero--v2,
	.hero-v2 {
		min-height: 56vh !important; /* Shorter footprint so partners rise above or close to fold */
		display: flex !important;
		flex-direction: column !important;
		justify-content: center !important;
	}

	.hero-v2__content-layer {
		padding-block: calc(var(--langit-header-height) + 9rem) 0 !important; /* Shifted downward to center and rebalance spacing */
		padding-inline: clamp(4rem, 8vw, 6rem) !important; /* Target visual spacing: 64px–96px horizontal padding */
		gap: 1.5rem !important;
		grid-template-columns: 1fr !important;
		position: relative;
		z-index: 10;
		width: 100% !important;
		max-width: var(--langit-hero-v2-container, 1380px) !important;
		box-sizing: border-box !important;
	}

	.hero-v2__content-inner {
		max-width: 600px !important; /* Limited width to prevent oversized stretch */
	}

	.hero--v2 .hero-v2__badge,
	.hero-v2 .hero-v2__badge {
		margin-bottom: 0.5rem !important; /* Reduced vertical spacing */
		background: rgba(255, 255, 255, 0.08) !important;
		border-color: rgba(255, 255, 255, 0.15) !important;
		color: #ffffff !important;
		box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15) !important;
	}

	.hero--v2 .hero-v2__badge-dot,
	.hero-v2 .hero-v2__badge-dot {
		background: #38bdf8 !important;
	}

	.hero--v2 .hero-v2__headline,
	.hero-v2 .hero-v2__headline,
	.hero-v2 .hero-v2__title,
	.hero--v2 .hero-v2__title {
		font-size: clamp(2.1rem, 4.5vw, 3rem) !important; /* Intentionally smaller, balanced heading */
		line-height: 1.05 !important;
		margin-bottom: 1.15rem !important; /* Spacing above description (reunites headline and description) */
		color: #ffffff !important;
	}

	.hero-v2__headline-line {
		display: inline !important;
		white-space: normal !important;
	}

	.hero-v2__headline-line:not(:last-child)::after {
		content: " " !important;
	}

	.hero--v2 .hero-v2__description,
	.hero-v2 .hero-v2__description {
		font-size: 0.85rem !important;
		line-height: 1.4 !important;
		margin-bottom: 0.95rem !important; /* Spacing below description to keep CTA position unchanged */
		color: rgba(241, 245, 249, 0.85) !important;
		max-width: none !important;
	}

	.hero-v2__cta,
	.hero-v2__actions {
		margin-top: 0 !important; /* Remove global desktop margin-top */
		flex-wrap: wrap !important;
		gap: 0.75rem !important;
		display: flex !important;
	}

	.hero-v2__bg-layer {
		position: absolute !important;
		inset: 0 !important;
		width: 100% !important;
		height: 100% !important;
		max-height: none !important;
		aspect-ratio: auto !important;
		z-index: 1 !important;
	}

	.hero-v2__bg-slides {
		position: absolute !important;
		inset: 0 !important;
		width: 100% !important;
		height: 100% !important;
		max-height: none !important;
	}

	.hero-v2__bg-slide {
		display: none !important; /* Hide other slides to preserve performance */
	}

	.hero-v2__bg-slide--1 {
		display: block !important;
		position: absolute !important;
		inset: 0 !important;
		width: 100% !important;
		height: 100% !important;
		object-fit: cover !important;
		object-position: 80% center !important; /* Pushes architectural tower right to leave space for text */
		opacity: 1 !important;
		animation: none !important;
	}

	.hero--home.hero--v2 .hero-v2__bg-overlay,
	.hero-v2 .hero-v2__bg-overlay,
	.hero--home.hero--v2 .hero-v2__overlay,
	.hero-v2 .hero-v2__overlay {
		position: absolute !important;
		inset: 0 !important;
		background: linear-gradient(
			90deg,
			rgba(3, 15, 35, 0.90) 0%,
			rgba(3, 15, 35, 0.80) 45%,
			rgba(3, 15, 35, 0.40) 80%,
			rgba(3, 15, 35, 0.25) 100%
		) !important; /* Left-to-right fade overlay to balance text and building visually */
		mix-blend-mode: normal !important;
		opacity: 1 !important;
		z-index: 2 !important;
	}

	.hero-v2__bg-overlay::after,
	.hero-v2__overlay::after {
		content: none !important; /* Disable desktop white horizontal gradient on tablet */
	}

	.home-section--partners,
	.home-section-partners {
		padding-block: 1rem 1.25rem !important; /* Reduce spacing to bring partners closer */
	}
}

/* ─── Hero V2: Landscape mobile ────────────────────────────────────────────── */
@media (max-width: 700px) and (orientation: landscape) {
	.hero-v2__content-layer {
		padding-block: calc(var(--langit-header-height) + 0.75rem) 1.25rem;
	}

	.hero-v2__headline {
		font-size: clamp(1.8rem, 5vw, 2.6rem);
		line-height: 1.0;
	}

	.hero-v2__bg-layer {
		display: none; /* hide visual in landscape mobile to prioritize content */
	}
}


@media (min-width: 901px) {
	.site-header__inner {
		width: min(100% - (var(--langit-gutter) * 2), var(--langit-hero-v2-container, 1440px));
	}

	.menu-toggle {
		display: none;
	}

	.main-navigation {
		min-width: 0;
	}

	.primary-menu {
		position: static;
		flex-direction: row;
		align-items: center;
		max-height: none;
		overflow: visible;
		padding: 0;
		border: 0;
		background: transparent;
		box-shadow: none;
		opacity: 1;
		pointer-events: auto;
		transform: none;
		transition: none;
	}

	.primary-menu > li > a {
		white-space: nowrap;
	}

	.site-header.is-scrolled .primary-menu > li > a {
		padding-block: 0.45rem;
		min-height: 2.25rem;
	}

	.primary-menu .menu-item-has-children > a {
		padding-right: 1.8rem;
	}

	.submenu-toggle {
		display: none;
	}

	.primary-menu .menu-item-has-children > a::after {
		position: absolute;
		top: 50%;
		right: 0.65rem;
		width: 0.42rem;
		height: 0.42rem;
		border-right: 2px solid currentColor;
		border-bottom: 2px solid currentColor;
		content: "";
		transform: translateY(-65%) rotate(45deg);
	}

	.primary-menu .menu-item-has-children::after {
		position: absolute;
		top: 100%;
		right: 0;
		left: 0;
		display: block;
		height: 0.75rem;
		content: "";
	}

	.primary-menu .sub-menu {
		position: absolute;
		top: calc(100% + 0.55rem);
		left: 0;
		z-index: 60;
		width: min(18rem, calc(100vw - 2rem));
		max-height: none;
		margin: 0;
		padding: 0.55rem;
		overflow: visible;
		border: 1px solid rgba(203, 213, 225, 0.74);
		border-radius: 1rem;
		background: rgba(255, 255, 255, 0.96);
		box-shadow: 0 22px 55px rgba(15, 23, 42, 0.14), 0 1px 0 rgba(255, 255, 255, 0.86) inset;
		opacity: 0;
		pointer-events: none;
		transform: translateY(-0.25rem) scale(0.985);
		transform-origin: top left;
		visibility: hidden;
		transition: opacity 180ms ease, transform 180ms ease, visibility 180ms ease;
	}

	@supports (backdrop-filter: blur(12px)) {
		.primary-menu .sub-menu {
			backdrop-filter: blur(14px);
		}
	}

	.primary-menu .langit-mega-menu > .sub-menu {
		right: 0;
		left: auto;
		width: min(42rem, calc(100vw - 2rem));
		padding: var(--langit-space-sm);
	}

	.primary-menu .langit-mega-menu > .langit-mega-panel {
		grid-template-columns: repeat(2, minmax(0, 1fr)) minmax(13rem, 0.9fr);
		align-items: stretch;
	}

	.primary-menu > .langit-menu-products.menu-item-has-children > .sub-menu {
		right: auto;
		left: 0;
		width: fit-content;
		min-width: 16.25rem;
		max-width: min(20rem, calc(100vw - 2rem));
		box-sizing: border-box;
		padding: 0.5rem;
		gap: 0.18rem;
		grid-template-columns: 1fr;
	}

	.primary-menu .langit-menu-products .langit-mega-group {
		display: contents;
	}

	.primary-menu .langit-menu-products .langit-mega-group__title {
		padding: 0.36rem 0.58rem 0.14rem;
		color: var(--langit-muted);
		font-size: 0.66rem;
		letter-spacing: 0.08em;
	}

	.primary-menu .langit-menu-products .langit-mega-list {
		gap: 0.08rem;
	}

	.primary-menu .langit-menu-products .sub-menu a {
		min-height: 2.22rem;
		padding: 0.5rem 0.58rem;
		border-radius: 0.78rem;
		color: var(--langit-secondary);
		font-size: 0.87rem;
		font-weight: 780;
		line-height: 1.25;
		white-space: nowrap;
		transition: background-color 160ms ease, color 160ms ease, transform 160ms ease;
	}

	.primary-menu .langit-menu-products .sub-menu a:hover,
	.primary-menu .langit-menu-products .sub-menu a:focus {
		background: linear-gradient(135deg, rgba(88, 175, 255, 0.16), rgba(56, 189, 248, 0.08));
		color: var(--langit-secondary);
		transform: translateX(2px);
	}

	.primary-menu .langit-mega-cta a {
		height: 100%;
		align-content: center;
		padding: var(--langit-space-sm);
	}

	.primary-menu .langit-menu-products .langit-mega-cta a {
		min-height: auto;
		margin-top: 0.28rem;
		padding: 0.62rem 0.68rem;
		border: 1px solid rgba(88, 175, 255, 0.24);
		background: linear-gradient(135deg, rgba(88, 175, 255, 0.15), rgba(56, 189, 248, 0.07));
		white-space: normal;
	}

	.primary-menu .langit-menu-products .langit-mega-cta span {
		font-size: 0.78rem;
		line-height: 1.35;
	}

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

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

	.page-hero {
		min-height: 380px;
		display: flex;
		flex-direction: column;
		justify-content: center;
		padding-block: 3rem;
		box-sizing: border-box;
	}

	/* ─── Hero V2: Desktop layout ───────────────────────────────────────────── */
	.hero--home.hero--v2 {
		min-height: 80vh; /* Increased Hero height to 80vh on desktop */
		padding-block: 0;
		position: relative;
		display: flex;
		flex-direction: column;
		justify-content: flex-start;
		background: #07182E;
	}

	.hero-v2__content-layer {
		display: flex;
		align-items: flex-start;
		width: 100%;
		max-width: var(--langit-hero-v2-container);
		margin-inline: auto;
		padding-block: calc(var(--langit-header-height) + clamp(6rem, 13vh, 8.5rem)) 0;
		position: relative;
		z-index: 10;
		flex-grow: 1;
	}

	@media (min-height: 800px) {
		.hero-v2__content-layer {
			padding-block: calc(var(--langit-header-height) + clamp(8.5rem, 17vh, 11rem)) 0;
		}
	}

	@media (max-height: 780px) {
		.hero-v2__content-layer {
			padding-block: calc(var(--langit-header-height) + clamp(4rem, 8vh, 5.5rem)) 0;
		}
		.hero-v2__content-inner {
			padding: 0;
		}
	}

	.hero-v2__content-inner {
		max-width: 720px;
		width: 100%;
		background: none;
		backdrop-filter: none;
		-webkit-backdrop-filter: none;
		border: none;
		border-radius: 0;
		padding: 0;
		box-sizing: border-box;
	}

	.hero-v2__badge {
		margin-bottom: 0.25rem;
	}

	.hero-v2__headline {
		font-size: clamp(3.5rem, 5vw, 5rem);
		line-height: 0.95;
		font-weight: 800;
		margin-bottom: 0.5rem;
	}

	.hero-v2__description {
		margin-bottom: 0.75rem;
	}

	.hero-v2__desktop-br {
		display: inline;
	}

	/* Sized typography control to prevent premature wrapping */
	.hero-v2__headline-line {
		display: inline-block;
		white-space: nowrap;
	}

	.hero-v2__bg-layer {
		grid-row: auto;
		grid-column: auto;
		position: absolute;
		inset: 0;
		width: 100%;
		height: 100%;
		max-height: none;
		aspect-ratio: auto;
		z-index: 1;
		display: block;
	}

	.hero-v2__bg-slides {
		position: absolute;
		inset: 0;
		width: 100%;
		height: 100%;
		z-index: 1;
	}

	.hero-v2__bg-slide {
		display: block;
		position: absolute;
		inset: 0;
		width: 100%;
		height: 100%;
		object-fit: cover;
		object-position: center center;
		opacity: 0;
		animation: hero-slideshow-fade 60s linear infinite;
	}

	.hero-v2__bg-slide--1 {
		animation-delay: 0s;
	}

	.hero-v2__bg-slide--2 {
		animation-delay: -50s;
	}

	.hero-v2__bg-slide--3 {
		animation-delay: -40s;
	}

	.hero-v2__bg-slide--4 {
		animation-delay: -30s;
	}

	.hero-v2__bg-slide--5 {
		animation-delay: -20s;
	}

	.hero-v2__bg-slide--6 {
		animation-delay: -10s;
	}

	.hero-v2__bg-overlay {
		background: linear-gradient(
			90deg,
			rgba(3, 15, 35, 0.88) 0%,
			rgba(3, 15, 35, 0.80) 35%,
			rgba(3, 15, 35, 0.60) 65%,
			rgba(3, 15, 35, 0.35) 100%
		);
		mix-blend-mode: normal;
		opacity: 1;
	}

	.hero-v2__bg-overlay::before {
		content: "";
		position: absolute;
		inset: 0;
		background-image: 
			linear-gradient(rgba(255, 255, 255, 0.035) 1px, transparent 1px),
			linear-gradient(90deg, rgba(255, 255, 255, 0.035) 1px, transparent 1px);
		background-size: 96px 96px;
		-webkit-mask-image: linear-gradient(90deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0.25) 45%, rgba(255, 255, 255, 0) 80%);
		mask-image: linear-gradient(90deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0.25) 45%, rgba(255, 255, 255, 0) 80%);
		pointer-events: none;
		z-index: 1;
	}

	.hero-v2__bg-overlay::after {
		display: none;
	}

	.hero--v2 .hero-v2__headline {
		color: #ffffff;
	}

	.hero--v2 .hero-v2__description {
		color: rgba(241, 245, 249, 0.85);
	}

	.hero--v2 .hero-v2__badge {
		background: rgba(255, 255, 255, 0.08);
		border-color: rgba(255, 255, 255, 0.15);
		color: #ffffff;
		box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
	}

	.hero--v2 .hero-v2__badge-dot {
		background: #38bdf8;
	}

	.hero--v2 .hero-v2__badge-dot::after {
		background: rgba(56, 189, 248, 0.35);
	}

	.hero-grid,
	.split-layout,
	.company-overview,
	.contact-form-layout {
		grid-template-columns: minmax(0, 1fr) minmax(18rem, 0.78fr);
	}

	.cta-section--split {
		grid-template-columns: minmax(0, 1.2fr) auto;
		align-items: center;
		justify-items: start;
		text-align: left;
	}

	.cta-section--split .cta-section__content,
	.cta-section--split .cta-section__actions {
		margin-inline: 0;
	}

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

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

	.products-grid {
		--langit-product-grid-columns: 3;
		grid-template-columns: repeat(var(--langit-product-grid-columns), minmax(0, 1fr));
	}

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

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

	.client-grid--references {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}

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

	.industries-serve-grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}

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

	.vision-mission-grid {
		grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
	}

	.team-grid,
	.why-choose-grid,
	.company-values-grid,
	.workflow-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.legality-grid,
	.feature-grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}

	.process-grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}

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

	.quote-support-grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}

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

	.maintenance-coverage-grid,
	.maintenance-sla-grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}

	.trust-grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}

	.contact-info-grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}

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

	.client-logo-grid {
		grid-template-columns: repeat(6, minmax(0, 1fr));
	}

	.blog-layout {
		grid-template-columns: minmax(0, 1fr) minmax(16rem, 19rem);
	}

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

	.blog-layout--listing .blog-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

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

	.download-detail-grid,
	.certification-detail-grid {
		grid-template-columns: minmax(0, 0.95fr) minmax(16rem, 0.55fr);
	}

	.featured-article .post-card {
		grid-template-columns: minmax(0, 0.9fr) minmax(0, 1fr);
		grid-template-rows: auto auto 1fr;
	}

	.featured-article .post-card__media {
		grid-row: 1 / -1;
	}

	.featured-article .post-card__media img,
	.featured-article .post-card__media span {
		height: 100%;
		min-height: 18rem;
	}

	.project-detail-grid {
		grid-template-columns: minmax(16rem, 0.8fr) minmax(0, 1.4fr);
	}

	.client-detail-grid {
		grid-template-columns: minmax(16rem, 0.72fr) minmax(0, 1.28fr);
	}

	.site-footer__bottom-inner {
		text-align: center;
	}

}

@media (min-width: 901px) and (max-width: 1024px) {
	/* tablet-large: treat as tablet, not desktop fullscreen */
	.hero--home {
		min-height: 75vh;
		padding-block: calc(var(--langit-header-height) + clamp(0.9rem, 2.6vw, 2.4rem));
		align-items: center;
		--langit-hero-overlay-opacity: 0.9;
	}

	.hero__content {
		max-width: min(720px, calc(100% - 3rem));
		margin-inline: auto;
		padding-inline: 1rem;
	}

	.hero--home h1 {
		max-width: 40ch;
		font-size: clamp(1.9rem, 2.8vw, 3.6rem);
		line-height: 1.04;
	}

	.hero-grid,
	.split-layout,
	.company-overview,
	.contact-form-layout,
	.contact-page-grid,
	.blog-layout,
	.download-detail-grid,
	.certification-detail-grid,
	.client-detail-grid,
	.project-detail-grid,
	.site-footer__inner {
		grid-template-columns: 1fr;
	}

	.products-grid {
		--langit-product-grid-columns: 2;
		grid-template-columns: repeat(var(--langit-product-grid-columns), minmax(0, 1fr));
	}

	.coverage-grid,
	.legality-grid,
	.feature-grid,
	.process-grid,
	.contact-info-grid,
	.site-footer__grid,
	.card-grid--3,
	.card-grid--4,
	.why-choose-grid,
	.company-values-grid,
	.workflow-grid,
	.industries-serve-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.service-grid,
	.team-grid,
	.client-grid,
	.download-grid,
	.certification-grid,
	.quote-service-grid,
	.quote-support-grid,
	.maintenance-plan-grid,
	.maintenance-coverage-grid,
	.maintenance-sla-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.related-service-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.featured-article .post-card {
		grid-template-columns: 1fr;
	}

}

/* legacy enterprise grid — retained for fallback compatibility */
@media (min-width: 901px) {
	.contact-info-grid--enterprise {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (min-width: 1025px) {
	.contact-info-grid--enterprise {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}
}

@media (max-width: 640px) {
	.contact-info-grid--enterprise {
		grid-template-columns: 1fr;
	}

	.contact-card--wide {
		grid-column: auto;
	}

	.contact-page-actions .button {
		width: 100%;
	}
}

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

/* ==========================================================================
   B2B TRUST, INDUSTRY, AND LEAD GENERATION ENHANCEMENTS
   ========================================================================== */

/* 1. Technology Partners Section */
/* 1. Technology Partners Brand Colors */
.partner-logo-item--hikvision:hover { color: #E60012; }
.partner-logo-item--dahua:hover { color: #E20015; }
.partner-logo-item--uniview:hover { color: #0060FF; }
.partner-logo-item--mikrotik:hover { color: #0056B3; }
.partner-logo-item--ubiquiti:hover { color: #005CFC; }
.partner-logo-item--toa:hover { color: #000000; }
.partner-logo-item--bosch:hover { color: #DE0000; }
.partner-logo-item--honeywell:hover { color: #DE0000; }
.partner-logo-item--schneider-electric:hover { color: #3DCD58; }
.partner-logo-item--ruijie:hover { color: #003399; }
.partner-logo-item--zkteco:hover { color: #00A356; }
.partner-logo-item--inter-m:hover { color: #C00000; }
.partner-logo-item--yamaha:hover { color: #002C93; }
.partner-logo-item--techma:hover { color: #E30613; }



/* 2. Industries We Serve SVG Icons */
.coverage-card__icon {
	width: 2.75rem;
	height: 2.75rem;
	color: var(--langit-primary);
	margin-bottom: var(--langit-space-xs);
	transition: transform var(--langit-transition-smooth), color var(--langit-transition-smooth);
}

.coverage-card:hover .coverage-card__icon {
	transform: translateY(-2px) scale(1.05);
	color: var(--langit-secondary);
}

/* Fix Project Card Category Pill Stretching */
.project-card .post-card__term,
.project-card__category,
.project-category,
.project-card .category-pill {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: auto !important;
	max-width: fit-content !important;
	flex: 0 0 auto !important;
	align-self: flex-start !important;
	justify-self: start !important;
}

/* 3. Project Cards Metadata Badges */
.project-card__industry-row,
.project-card__systems-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--langit-space-xs);
	margin-bottom: var(--langit-space-xs);
	font-size: 0.88rem;
}

.project-card__meta-label {
	font-weight: 600;
	color: #4a5568;
	min-width: 6.5rem;
}

.project-card__systems-list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.35rem;
	align-items: center;
}

.badge {
	display: inline-flex;
	align-items: center;
	padding: 0.2rem 0.6rem;
	border-radius: 9999px;
	font-size: 0.78rem;
	font-weight: 600;
	line-height: 1;
	text-transform: capitalize;
}

.badge--industry {
	background-color: rgba(88, 175, 255, 0.08);
	border: 1px solid rgba(88, 175, 255, 0.24);
	color: #0c63c5;
}

.badge--system {
	background-color: rgba(16, 185, 129, 0.06);
	border: 1px solid rgba(16, 185, 129, 0.22);
	color: #047857;
}

.badge__check {
	margin-right: 0.25rem;
	font-weight: 700;
}


/* 4. Service Detail Scope Checklist */
.service-scope-section {
	border-top: 1px solid rgba(226, 232, 240, 0.75);
	border-bottom: 1px solid rgba(226, 232, 240, 0.75);
	background-color: rgba(248, 250, 252, 0.5);
	padding-block: var(--langit-space-xl);
}

.scope-checklist {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--langit-space-md);
	margin-top: var(--langit-space-lg);
}

@media (min-width: 641px) {
	.scope-checklist {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (min-width: 901px) {
	.scope-checklist {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

.checklist-item {
	display: flex;
	align-items: flex-start;
	gap: var(--langit-space-sm);
	padding: var(--langit-space-md);
	background: #ffffff;
	border: 1px solid rgba(226, 232, 240, 0.75);
	border-radius: var(--langit-card-radius);
	box-shadow: var(--langit-card-shadow);
	transition: transform var(--langit-transition-smooth), border-color var(--langit-transition-smooth), box-shadow var(--langit-transition-smooth);
}

.checklist-item:hover {
	transform: translateY(-2px);
	border-color: rgba(16, 185, 129, 0.4);
	box-shadow: 0 8px 24px -6px rgba(16, 185, 129, 0.08);
}

.checklist-item__num {
	font-size: 1.5rem;
	font-weight: 800;
	line-height: 1;
	background: linear-gradient(135deg, var(--langit-primary), var(--langit-secondary));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	opacity: 0.9;
}

.checklist-item__content {
	display: grid;
	gap: 0.25rem;
}

.checklist-item__title {
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--langit-secondary);
	margin: 0;
	line-height: 1.25;
}

.checklist-item__check {
	font-size: 0.78rem;
	font-weight: 600;
	color: #10b981;
	display: inline-flex;
	align-items: center;
	gap: 0.2rem;
}


/* 5. Footer 3-Column Layout System */

/* Mobile: all columns stacked */
.site-footer__inner {
	grid-template-columns: 1fr;
	align-items: start;
}

.site-footer__col {
	display: flex;
	flex-direction: column;
}

/* Tablet (≥ 600px): company full-width, contact + office side-by-side */
@media (min-width: 600px) {
	.site-footer__inner {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: clamp(1.5rem, 3vw, 2.5rem) clamp(2rem, 4vw, 4rem);
	}

	.site-footer__col--company {
		grid-column: 1 / -1;
	}
}

/* Desktop (≥ 901px): 3-column grid — Company 50%, Contact 20%, Office 30% */
@media (min-width: 901px) {
	.site-footer__inner {
		grid-template-columns: minmax(0, 5fr) minmax(0, 2fr) minmax(0, 3fr);
		gap: clamp(1rem, 2vw, 1.5rem) clamp(2.5rem, 4vw, 5rem);
	}

	.site-footer__col--company {
		grid-column: auto;
	}

	.site-footer__col--company .site-footer__tagline {
		max-width: 36ch;
	}
}

/* Homepage slugs (from sanitize_title of homepage industry_items) */
.coverage-card--manufacturing {
	--coverage-image: url("../images/industries/industry-manufacturing-industry.webp");
}
.coverage-card--warehouse-logistics {
	--coverage-image: url("../images/industries/industry-warehouse-logistics.webp");
}
.coverage-card--commercial-building {
	--coverage-image: url("../images/industries/industry-commercial-building.webp");
}
.coverage-card--government {
	--coverage-image: url("../images/industries/industry-government.webp");
}
.coverage-card--education {
	--coverage-image: url("../images/industries/industry-education.webp");
}
.coverage-card--healthcare {
	--coverage-image: url("../images/industries/industry-healthcare.webp");
}

/* Company page slugs (from sanitize_title of company page industry list) */
.coverage-card--manufacturing-industry {
	--coverage-image: url("../images/industries/industry-manufacturing-industry.webp");
}
.coverage-card--automotive-industry {
	--coverage-image: url("../images/industries/industry-automotive-industry.webp");
}
.coverage-card--warehouse-logistics {
	--coverage-image: url("../images/industries/industry-warehouse-logistics.webp");
}
.coverage-card--commercial-building {
	--coverage-image: url("../images/industries/industry-commercial-building.webp");
}
.coverage-card--healthcare-facilities {
	--coverage-image: url("../images/industries/industry-healthcare-facilities.webp");
}
.coverage-card--hospitality-residential {
	--coverage-image: url("../images/industries/industry-hospitality-residential.webp");
}
.coverage-card--government-public-sector {
	--coverage-image: url("../images/industries/industry-government-public-sector.webp");
}
.coverage-card--education-facilities {
	--coverage-image: url("../images/industries/industry-education-facilities.webp");
}

/* 7. Industries We Serve Headline Desktop Layout */
@media (min-width: 901px) {
	.section-heading--industry {
		max-width: 960px !important;
	}
	.section-heading--industry h2 {
		max-width: none !important;
		text-wrap: wrap !important;
		margin-inline: auto;
	}
}

/* 8. Footer bottom bar — single centered line (no secondary nav) */
.site-footer__bottom-inner {
	grid-template-columns: 1fr;
	text-align: center;
}

/* Helper utility for explicit responsive line breaks */
.desktop-only {
	display: none;
}

@media (min-width: 901px) {
	.desktop-only {
		display: inline;
	}
}

/* ==========================================================================
   9. PRODUCT CATEGORY NAVIGATION STYLES
   ========================================================================== */
.product-nav-section {
	position: sticky;
	top: var(--langit-header-height, 72px);
	z-index: 99;
	background: rgba(255, 255, 255, 0.95);
	backdrop-filter: blur(12px);
	border-bottom: 1px solid rgba(88, 175, 255, 0.12);
	padding-block: 0.85rem !important;
	box-shadow: 0 4px 16px -4px rgba(15, 23, 42, 0.04);
	transition: top 0.3s ease;
}

@media (min-width: 901px) {
	.product-nav-section {
		top: var(--langit-header-height, 76px);
	}
}

.site-header.is-scrolled ~ .site-main .product-nav-section {
	top: var(--langit-header-scrolled-height, 56px);
}

@media (min-width: 901px) {
	.site-header.is-scrolled ~ .site-main .product-nav-section {
		top: var(--langit-header-scrolled-height, 60px);
	}
}

.product-category-nav {
	width: 100%;
}

.product-category-nav__list {
	display: flex;
	flex-wrap: nowrap;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	gap: 0.75rem;
	padding-inline: 1rem;
	padding-block: 0.25rem;
	scrollbar-width: none;
}

.product-category-nav__list::-webkit-scrollbar {
	display: none;
}

.product-category-nav__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	white-space: nowrap;
	padding: 0.5rem 1.15rem;
	border: 1px solid rgba(88, 175, 255, 0.18);
	border-radius: 999px;
	background: linear-gradient(135deg, rgba(255, 255, 255, 0.95), rgba(240, 248, 255, 0.9));
	box-shadow: 0 4px 8px -2px rgba(15, 23, 42, 0.02);
	color: var(--langit-muted);
	font-size: 0.85rem;
	font-weight: 800;
	letter-spacing: 0.03em;
	text-transform: uppercase;
	text-decoration: none;
	cursor: pointer;
	transition: all 0.25s cubic-bezier(0.16, 1, 0.3, 1);
}

.product-category-nav__link:hover {
	border-color: rgba(88, 175, 255, 0.5);
	color: var(--langit-primary);
	transform: translateY(-1px);
	box-shadow: 0 6px 12px -2px rgba(88, 175, 255, 0.12);
}

.product-category-nav__link:active {
	transform: translateY(0);
}

.product-category-nav__link.is-active {
	background: var(--langit-primary);
	border-color: var(--langit-primary);
	color: #ffffff;
	box-shadow: 0 4px 12px rgba(88, 175, 255, 0.28);
}

@media (min-width: 901px) {
	.product-category-nav__list {
		flex-wrap: wrap;
		justify-content: center;
		padding-inline: 0;
		gap: 0.85rem;
	}
	
	.product-category-nav__link {
		font-size: 0.88rem;
		padding: 0.55rem 1.35rem;
	}
}

/* ─── Dedicated Section: Technology Partners ────────────────────────────────── */
.home-section--partners {
	position: relative;
	background: #ffffff;
	border-top: 1px solid rgba(226, 232, 240, 0.6);
	border-bottom: 1px solid rgba(226, 232, 240, 0.6);
	padding-top: clamp(20px, 2.5vh, 24px); /* Reduced top padding for tight connection to Hero */
	padding-bottom: clamp(20px, 3vh, 30px);
	margin-top: 0;
	z-index: 10;
	overflow: hidden;
}

.partners-container {
	width: min(100% - (var(--langit-gutter) * 2), var(--langit-hero-v2-container));
	margin-inline: auto;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.partners-title {
	font-size: clamp(10px, 0.8vw, 11px); /* Subtle label styling */
	font-weight: 700;
	letter-spacing: 0.26em; /* Elegant letter-spacing (0.22em - 0.30em) */
	text-transform: uppercase;
	color: #64748b; /* slate-500 */
	margin-top: 0; /* Prevent browser default margin from pushing title down */
	margin-bottom: clamp(12px, 1.5vh, 18px);
	text-align: center;
	opacity: 0.7;
}

.partners-marquee {
	position: relative;
	overflow: hidden;
	width: 100%;
	/* Gradient mask fades on both sides for premium SaaS-style horizontal fade */
	mask-image: linear-gradient(to right, transparent 0%, #000 12%, #000 88%, transparent 100%);
	-webkit-mask-image: linear-gradient(to right, transparent 0%, #000 12%, #000 88%, transparent 100%);
}

.partners-marquee__track {
	display: flex;
	align-items: center;
	width: max-content;
	gap: 0; /* Gap is managed via item padding-right to prevent any loop jumps */
	animation: partners-marquee-scroll 36s linear infinite;
	will-change: transform;
}

/* Pause animation on hover */
.partners-marquee:hover .partners-marquee__track {
	animation-play-state: paused;
}

.partners-marquee .partner-logo-item {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: clamp(120px, 12vw, 150px); /* Generous width for proportional scaling */
	height: clamp(30px, 4.5vh, 36px); /* Desktop logo height: 30-36px */
	background: none !important;
	border: none !important;
	box-shadow: none !important;
	border-radius: 0 !important;
	padding: 0 !important;
	color: #64748b; /* monochrome by default */
	opacity: 0.70; /* 70% default opacity (65-75%) */
	filter: grayscale(100%);
	transition: all 400ms cubic-bezier(0.16, 1, 0.3, 1); /* 400ms transition */
	padding-right: clamp(56px, 5vw, 80px); /* Increased spacing gap */
	box-sizing: content-box;
}

.partners-marquee .partner-logo-item:hover {
	opacity: 1 !important;
	filter: grayscale(0%) !important;
}

.partners-marquee .partner-logo-item svg {
	max-height: 100% !important;
	width: 100% !important;
	height: auto !important;
}

@keyframes partners-marquee-scroll {
	0% {
		transform: translateX(0);
	}
	100% {
		transform: translateX(-50%); /* infinite seamless translation */
	}
}

/* =============================================================================
   INNER PAGE HERO OPTIMIZATION
   Minimalist B2B design system alignment · Tighter hierarchy
   ============================================================================= */

/* Spacing and heights */
.page-hero {
	padding-top: 48px !important;
	padding-bottom: 48px !important;
	min-height: 0 !important;
	display: block !important;
}

@media (min-width: 768px) {
	.page-hero {
		padding-top: 64px !important;
		padding-bottom: 64px !important;
	}
}

@media (min-width: 1025px) {
	.page-hero {
		padding-top: 72px !important;
		padding-bottom: 72px !important;
	}
}

/* Typography scale and groupings */
.page-hero h1 {
	font-size: 40px !important;
	line-height: 1.1 !important;
	font-weight: 800 !important;
	letter-spacing: -0.025em !important;
	margin-top: 0 !important;
	margin-bottom: 20px !important;
}

.page-hero h1:last-child {
	margin-bottom: 0 !important;
}

.page-hero .section-eyebrow {
	margin-top: 0 !important;
	margin-bottom: 16px !important;
}

.page-hero .lede {
	font-size: 16px !important;
	line-height: 1.7 !important;
	max-width: 720px !important;
	margin-top: 0 !important;
	margin-bottom: 0 !important;
}

@media (min-width: 768px) {
	.page-hero h1 {
		font-size: 48px !important;
	}
	.page-hero .lede {
		font-size: 18px !important;
	}
}

@media (min-width: 1025px) {
	.page-hero h1 {
		font-size: 56px !important;
		line-height: 1.05 !important;
	}
	.page-hero .lede {
		font-size: 20px !important;
	}
}

/* Treat eyebrow, headline, and description as one visual group */
.page-hero .stack > * + * {
	margin-top: 0 !important;
}

/* Transition to next content section */
.page-hero + .section,
.page-hero + .blog-layout,
.page-hero + .product-nav-section,
.page-hero + * > .section:first-child,
.page-hero + * > .blog-layout:first-child {
	padding-top: clamp(2rem, 3.5vw, 3.5rem) !important;
}

/* Grid alignment and left-align logic */
.page-hero__content {
	width: min(100% - (var(--langit-gutter) * 2), var(--langit-container)) !important;
	max-width: var(--langit-container) !important;
}

.page-hero .container {
	display: flex !important;
	flex-direction: column !important;
	align-items: flex-start !important;
	text-align: left !important;
}

/* Base mobile width: 100% */
.page-hero .container > * {
	width: 100% !important;
	max-width: 100% !important;
}

/* Eyebrow badge compact pill styling (does not stretch) */
.page-hero .section-eyebrow {
	width: auto !important;
	width: fit-content !important;
	display: inline-flex !important;
}

/* Tablet viewports: max-width around 720px / description 720px */
@media (min-width: 768px) {
	.page-hero .container > * {
		max-width: 720px !important;
	}
	.page-hero .lede {
		max-width: 720px !important;
	}
}

/* Desktop viewports: max-width ~920px / description ~750px */
@media (min-width: 1025px) {
	.page-hero .container > * {
		max-width: 920px !important;
	}
	.page-hero .lede {
		max-width: 750px !important;
	}
}

/* =============================================================================
   SINGLE SERVICE & SINGLE PROJECT LAYOUT ALIGNMENT
   Align layouts with the global site container boundaries
   ============================================================================= */

/* Single Hero Metadata Row & Breadcrumb Style */
.single-hero__meta-row {
	display: inline-flex !important;
	align-items: center !important;
	flex-wrap: wrap !important;
	gap: 12px !important;
	margin-top: 0 !important;
	margin-bottom: 16px !important;
}

.single-hero__meta-row > * {
	margin: 0 !important;
}

.single-hero__breadcrumb-eyebrow,
.single-hero__breadcrumb-separator,
.single-hero__breadcrumb-category {
	font-size: 14px !important;
	font-weight: 600 !important;
	letter-spacing: 0.08em !important;
	color: var(--langit-muted, #718096) !important;
	display: inline-flex !important;
	align-items: center !important;
}

.single-hero__breadcrumb-eyebrow {
	text-transform: uppercase !important;
}

.single-hero__breadcrumb-category {
	text-transform: none !important;
}

.single-hero__breadcrumb-category a {
	color: inherit !important;
	text-decoration: none !important;
	transition: color 150ms ease !important;
}

.single-hero__breadcrumb-category a:hover {
	color: var(--langit-primary, #0a64be) !important;
}

.single-service .single-hero__content .single-hero__meta-row + h1,
.single-project .single-hero__content .single-hero__meta-row + h1 {
	margin-top: 0 !important;
}

/* Content layout expansion (Featured Image, Content block, Footer) */
.single-service .single-featured-image,
.single-project .single-featured-image,
.single-service .single-footer,
.single-project .single-footer,
.single-service .related-posts,
.single-project .related-posts {
	width: min(100% - (var(--langit-gutter) * 2), var(--langit-container)) !important;
	max-width: var(--langit-container) !important;
	margin-inline: auto !important;
}

.single-service .single-featured-image img,
.single-project .single-featured-image img {
	width: 100% !important;
	height: auto !important;
	object-fit: cover !important;
}

/* Remove narrow constraints on the core text contents */
.single-service .single-content {
	width: min(100% - (var(--langit-gutter) * 2), var(--langit-container)) !important;
	max-width: var(--langit-container) !important;
}

.single-project .single-content {
	width: 100% !important;
	max-width: 100% !important;
}

/* Single Service Two-Column Grid Layout */
.single-service-grid {
	width: min(100% - (var(--langit-gutter) * 2), var(--langit-container)) !important;
	max-width: var(--langit-container) !important;
	margin-inline: auto !important;
	margin-top: 80px !important;
	margin-bottom: 80px !important;
}

/* On Desktop: 2-column grid when image is present */
@media (min-width: 1025px) {
	.single-service-grid.has-image {
		display: grid !important;
		grid-template-columns: 1fr 1.4fr !important;
		gap: 48px !important;
		align-items: start !important;
	}
}

/* Tablet & Mobile: stack vertically */
@media (max-width: 1024px) {
	.single-service-grid.has-image {
		display: flex !important;
		flex-direction: column !important;
		gap: 40px !important;
	}
}

/* Image styling within the grid */
.single-service-grid__image {
	width: 100% !important;
}

.single-service-grid__image .single-featured-image {
	width: 100% !important;
	max-width: 100% !important;
	margin: 0 !important;
	border-radius: var(--langit-radius, 16px) !important;
	overflow: hidden !important;
}

.single-service-grid__image .single-featured-image img {
	width: 100% !important;
	height: auto !important;
	aspect-ratio: 4 / 3 !important;
	object-fit: cover !important;
	display: block !important;
}

/* Content styling within the grid */
.single-service-grid__content {
	width: 100% !important;
	max-width: 100% !important;
	margin: 0 !important;
}

.single-service-grid__content > *:first-child {
	margin-top: 0 !important;
}

/* ── Project Overview Section (full-width card above image/description) ── */
.project-overview-section {
	width: min(100% - (var(--langit-gutter) * 2), var(--langit-container)) !important;
	max-width: var(--langit-container) !important;
	margin-inline: auto !important;
	margin-top: 72px !important;
	margin-bottom: 0 !important;
}

/* Horizontal layout for the overview card */
.project-detail-card--horizontal {
	padding: 2rem 2.5rem !important;
}

.project-meta-list--horizontal {
	display: grid !important;
	gap: 0 !important;
	margin: 0 !important;
	margin-top: 1rem !important;
}

/* Desktop: multi-column horizontal layout */
@media (min-width: 1025px) {
	.project-meta-list--horizontal {
		grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)) !important;
		gap: 0 !important;
	}

	.project-meta-list--horizontal > div,
	.project-meta-list--horizontal > .project-meta-list__systems {
		border-bottom: 0 !important;
		border-right: 1px solid var(--langit-border) !important;
		padding: 0.5rem 1.5rem 0.5rem 0 !important;
		margin-right: 1.5rem !important;
	}

	.project-meta-list--horizontal > div:last-child,
	.project-meta-list--horizontal > .project-meta-list__systems:last-child {
		border-right: 0 !important;
		padding-right: 0 !important;
		margin-right: 0 !important;
	}
}

/* Mobile: vertical stack */
@media (max-width: 1024px) {
	.project-meta-list--horizontal > div,
	.project-meta-list--horizontal > .project-meta-list__systems {
		padding-bottom: 0.85rem !important;
		border-bottom: 1px solid var(--langit-border) !important;
	}

	.project-meta-list--horizontal > div:last-child,
	.project-meta-list--horizontal > .project-meta-list__systems:last-child {
		padding-bottom: 0 !important;
		border-bottom: 0 !important;
	}
}

/* ── Single Project Two-Column Grid Layout (image + description) ── */
.single-project-grid {
	width: min(100% - (var(--langit-gutter) * 2), var(--langit-container)) !important;
	max-width: var(--langit-container) !important;
	margin-inline: auto !important;
	margin-top: 48px !important;
	margin-bottom: 80px !important;
}

/* On Desktop: 2-column grid when image is present */
@media (min-width: 1025px) {
	.single-project-grid.has-image {
		display: grid !important;
		grid-template-columns: 1fr 1.22fr !important; /* 45% image / 55% content */
		gap: 48px !important;
		align-items: start !important;
	}
}

/* Tablet & Mobile: stack vertically */
@media (max-width: 1024px) {
	.single-project-grid.has-image {
		display: flex !important;
		flex-direction: column !important;
		gap: 40px !important;
	}
}

/* Image styling within the grid */
.single-project-grid__image {
	width: 100% !important;
}

.single-project-grid__image .single-featured-image {
	width: 100% !important;
	max-width: 100% !important;
	margin: 0 !important;
	border-radius: var(--langit-radius, 16px) !important;
	overflow: hidden !important;
}

.single-project-grid__image .single-featured-image img {
	width: 100% !important;
	height: auto !important;
	aspect-ratio: 4 / 3 !important;
	object-fit: cover !important;
	display: block !important;
}

/* Content styling within the grid */
.single-project-grid__content {
	width: 100% !important;
	max-width: 100% !important;
	margin: 0 !important;
	display: flex !important;
	flex-direction: column !important;
	gap: 40px !important; /* Spacing between description and overview card */
}

.single-project-grid__content > *:first-child {
	margin-top: 0 !important;
}

.single-project-grid__content .project-description-wrapper .section-eyebrow {
	margin-top: 0 !important;
}



/* Premium Delivery Process / Methodology layout refinements */
.single-service .checklist-item {
	padding: 1.5rem 1.25rem !important;
	align-items: stretch !important;
}

.single-service .checklist-item__desc {
	font-size: 0.88rem !important;
	line-height: 1.5 !important;
	color: #5b697a !important;
	margin-block: 0.25rem 0.5rem !important;
}

/* Project Overview Systems Implemented tags styling */
.project-overview-tags {
	display: flex !important;
	flex-wrap: wrap !important;
	gap: 0.35rem !important;
	margin-top: 0.25rem !important;
}

.project-tag {
	display: inline-flex !important;
	align-items: center !important;
	font-size: 0.76rem !important;
	font-weight: 700 !important;
	color: var(--langit-primary) !important;
	background: rgba(10, 100, 190, 0.06) !important;
	border: 1px solid rgba(10, 100, 190, 0.12) !important;
	border-radius: 999px !important;
	padding: 0.2rem 0.6rem !important;
	line-height: 1.2 !important;
	transition: all var(--langit-transition-smooth) !important;
}

.project-tag:hover {
	background: rgba(10, 100, 190, 0.1) !important;
	border-color: rgba(10, 100, 190, 0.25) !important;
}

/* Reduce visual dominance of related services on single project pages */
.single-project .service-grid {
	gap: var(--langit-space-md) !important;
}

.single-project .service-card {
	padding: 1.25rem !important;
	gap: 0.75rem !important;
	border-radius: 16px !important;
	min-height: auto !important;
}

.single-project .service-card__icon {
	width: 2.5rem !important;
	height: 2.5rem !important;
	padding: 0.5rem !important;
	border-radius: 12px !important;
}

.single-project .service-card h3 {
	font-size: 1.05rem !important;
}

.single-project .service-card p:not(.card__meta) {
	font-size: 0.88rem !important;
	line-height: 1.5 !important;
}

.single-project .service-card .button {
	padding-block: 0.4rem !important;
	font-size: 0.8rem !important;
}

/* =============================================================================
   SINGLE SERVICE & SINGLE PROJECT — VISUAL BACKGROUND RHYTHM
   Pattern: Hero (#F5FAFF) → Main Content (#FFFFFF) → Secondary (#F8FAFD)
            → Related Services (#FFFFFF) → CTA (#EAF5FF) → Footer (dark navy)
   Principle: Background contrast + spacing as section dividers — no thick borders.
   ============================================================================= */

/* ── Token definitions ── */
:root {
	--langit-bg-hero:      #F5FAFF;   /* Soft blue-white — hero zone     */
	--langit-bg-white:     #FFFFFF;   /* Pure white — primary content    */
	--langit-bg-subtle:    #F8FAFD;   /* Very light grey-blue — secondary */
	--langit-bg-cta:       #EAF5FF;   /* Light blue wash — CTA           */
}

/* ── 1. HERO — #F5FAFF ── */
.single-service .single-hero,
.single-project .single-hero {
	background: var(--langit-bg-hero) !important;
}

/* ── 2. MAIN CONTENT — #FFFFFF ── */
/* Service: image+description grid   |   Project: overview card + image+description grid */
.single-service .single-service-grid,
.single-project .project-overview-section,
.single-project .single-project-grid {
	background: var(--langit-bg-white) !important;
}

/* Extend white band fully edge-to-edge behind the contained columns */
.single-service article,
.single-project article {
	background: var(--langit-bg-white) !important;
}

/* Override the article bg: hero still needs its own colour */
.single-service .single-hero,
.single-project .single-hero {
	background: var(--langit-bg-hero) !important;
	position: relative;
	z-index: 0;
}

/* ── 3. SECONDARY CONTENT — #F8FAFD ── */
/* Service: Methodology / Delivery Process section */
.single-service .service-scope-section {
	background: var(--langit-bg-subtle) !important;
}

/* Project: Related Services (replaces section--surface) */
.single-project .section.section--surface {
	background: var(--langit-bg-subtle) !important;
}

/* ── 4. RELATED SERVICES (Service page) — #FFFFFF ── */
/* Keeps the rhythm: Methodology (#F8FAFD) → Related (#FFFFFF) → CTA (#EAF5FF) */
.single-service .related-services-section {
	background: var(--langit-bg-white) !important;
}

/* ── 5. CTA SECTION WRAPPER — #EAF5FF ── */
/* The <section class="section ..."> that wraps the cta-section panel */
.single-service article > .section:last-of-type,
.single-project article > .section:last-of-type {
	background: var(--langit-bg-cta) !important;
}

/* Soften the cta-section panel itself so it reads as inset on the blue wash */
.single-service article > .section:last-of-type .cta-section,
.single-project article > .section:last-of-type .cta-section {
	background:
		linear-gradient(135deg, rgba(255,255,255,0.72), rgba(255,255,255,0.5)) !important;
	border-color: rgba(88, 175, 255, 0.28) !important;
	box-shadow: 0 8px 32px rgba(10, 80, 180, 0.06) !important;
}

/* ── Section padding: give each zone breathing room ── */

/* Generous padding on secondary-colour bands */
.single-service .service-scope-section,
.single-project .section.section--surface {
	padding-block: clamp(3rem, 2rem + 4vw, 5.5rem) !important;
}

/* CTA wrapper breathing room */
.single-service article > .section:last-of-type,
.single-project article > .section:last-of-type {
	padding-block: clamp(3rem, 2rem + 4vw, 5rem) !important;
}

/* ── Responsive: consistent on tablet & mobile ── */
@media (max-width: 768px) {
	.single-service .service-scope-section,
	.single-project .section.section--surface {
		padding-block: 2.5rem !important;
	}

	.single-service article > .section:last-of-type,
	.single-project article > .section:last-of-type {
		padding-block: 2.5rem !important;
	}
}

/* ==========================================================================
   BLOG CARD RESPONSIVE REFINEMENT
   ========================================================================== */

/* 1. Grid layout responsive behavior */
.blog-grid {
	display: grid !important;
	grid-template-columns: 1fr !important;
	gap: 20px !important;
}

@media (min-width: 768px) {
	.blog-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
		gap: 24px !important;
	}
}

@media (min-width: 1200px) {
	.blog-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
		gap: 32px !important;
	}
}

/* Specifying override for listing context */
.blog-layout--listing .blog-grid,
.blog-grid:not(.project-grid) {
	display: grid !important;
	grid-template-columns: 1fr !important;
	gap: 20px !important;
}

@media (min-width: 768px) {
	.blog-layout--listing .blog-grid,
	.blog-grid:not(.project-grid) {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
		gap: 24px !important;
	}
}

@media (min-width: 1200px) {
	.blog-layout--listing .blog-grid,
	.blog-grid:not(.project-grid) {
		grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
		gap: 32px !important;
	}
}

/* 2. Card layout: Flexbox-column & Equal Height */
.blog-grid:not(.project-grid) .post-card {
	display: flex !important;
	flex-direction: column !important;
	gap: 0 !important;
	height: 100% !important;
	padding: 0 !important;
	box-sizing: border-box !important;
}

/* 3. Image aspect ratio & object-fit */
.blog-grid:not(.project-grid) .post-card__media {
	width: 100% !important;
	aspect-ratio: 16 / 9 !important;
	flex-shrink: 0 !important;
}

.blog-grid:not(.project-grid) .post-card__media img {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover !important;
}

/* 4. Card Content: Spacing & order */
.blog-grid:not(.project-grid) .post-card__header {
	display: flex !important;
	flex-direction: column !important;
	gap: 0 !important;
	margin-top: var(--langit-space-sm) !important;
	margin-bottom: 12px !important;
}

/* Category Badge + Date row */
.blog-grid:not(.project-grid) .post-card__meta-row {
	display: flex !important;
	align-items: center !important;
	gap: 12px !important;
	margin-inline: clamp(1.5rem, 1.25rem + 1vw, 2.25rem) !important;
	margin-top: 0 !important;
	margin-bottom: 20px !important;
}

.blog-grid:not(.project-grid) .post-card .post-card__term,
.blog-grid:not(.project-grid) .post-card .post-card__term a {
	font-size: 11px !important;
	font-weight: 600 !important;
	letter-spacing: .08em !important;
	text-transform: uppercase !important;
}

.blog-grid:not(.project-grid) .post-card .entry-meta {
	font-size: 13px !important;
	font-weight: 500 !important;
	color: var(--langit-muted) !important;
	margin-bottom: 0 !important;
}

/* Title -> Excerpt */
.blog-grid:not(.project-grid) .post-card__title,
.blog-grid:not(.project-grid) .blog-card-title {
	margin-top: 0 !important;
	margin-bottom: 0 !important;
	font-size: 24px !important;
	line-height: 1.25 !important;
	font-weight: 700 !important;
	display: -webkit-box !important;
	-webkit-line-clamp: 2 !important;
	-webkit-box-orient: vertical !important;
	overflow: hidden !important;
	text-overflow: ellipsis !important;
}

/* Excerpt clamping & responsive */
.blog-grid:not(.project-grid) .post-card .entry-summary,
.blog-grid:not(.project-grid) .blog-card-excerpt {
	margin-top: 0 !important;
	margin-bottom: 12px !important;
	font-size: 15px !important;
	line-height: 1.7 !important;
	display: -webkit-box !important;
	-webkit-line-clamp: 3 !important;
	-webkit-box-orient: vertical !important;
	overflow: hidden !important;
}

.blog-grid:not(.project-grid) .post-card .entry-summary p,
.blog-grid:not(.project-grid) .blog-card-excerpt p {
	display: inline !important;
	margin: 0 !important;
	font-size: inherit !important;
	line-height: inherit !important;
}

/* Responsive Overrides */
@media (max-width: 1024px) {
	.blog-grid:not(.project-grid) .post-card__title,
	.blog-grid:not(.project-grid) .blog-card-title {
		font-size: 22px !important;
	}
}

@media (max-width: 768px) {
	.blog-grid:not(.project-grid) .post-card__title,
	.blog-grid:not(.project-grid) .blog-card-title {
		font-size: 20px !important;
	}

	.blog-grid:not(.project-grid) .post-card .entry-summary,
	.blog-grid:not(.project-grid) .blog-card-excerpt {
		font-size: 14px !important;
		line-height: 1.6 !important;
		-webkit-line-clamp: 2 !important;
	}
}

/* Read More is pushed to the bottom of the card */
.blog-grid:not(.project-grid) .post-card .read-more-link {
	margin-top: auto !important;
}

/* =============================================================================
   BLOG DETAIL TYPOGRAPHY & LAYOUT REFINEMENT
   Only applicable on standard Blog Detail Pages (.single-post)
   ============================================================================= */

:root {
	--container-width: var(--langit-container);
}

/* 1. Required Container Classes alignment */
.blog-single-container,
.single-post-container,
.article-container {
	max-width: var(--container-width);
	margin: 0 auto;
	padding-left: 0;
	padding-right: 0;
}

/* Scope to standard blog detail page to remove offsets/indentation and align content with global layouts */
.single-post .blog-single-container,
.single-post .single-post-container,
.single-post .article-container {
	max-width: 100% !important;
	margin-left: 0 !important;
	margin-right: auto !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
}

/* Single Post Grid Layout: 70% article column + 30% sidebar with 64px gap */
.single-post .blog-layout--single {
	display: grid !important;
	grid-template-columns: 7fr 3fr !important;
	gap: 64px !important;
}

@media (max-width: 1024px) {
	.single-post .blog-layout--single {
		grid-template-columns: 1fr !important;
		gap: 40px !important;
	}
}

.single-post .article-header,
.single-post .blog-post-header {
	max-width: 100% !important;
	width: 100% !important;
	margin-left: 0 !important;
	margin-right: auto !important;
}

.single-post .single-hero__content {
	max-width: 100% !important;
	width: 100% !important;
	margin-left: 0 !important;
	margin-right: auto !important;
}

/* 2. Visual Hierarchy Spacing */

/* Title -> Meta (12px) */
.single-post .entry-title,
.single-post .blog-post-title,
.single-post .single-post-title {
	margin-top: 0 !important;
	margin-bottom: 12px !important;
	font-size: 44px !important;
	line-height: 1.15 !important;
	font-weight: 800 !important;
	letter-spacing: -0.03em !important;
	color: var(--langit-secondary, #0f172a) !important;
	width: 80% !important;
	max-width: 80% !important;
	margin-right: auto !important;
}

/* Meta -> Featured Image (24px) */
.single-post .single-hero .entry-meta {
	margin-top: 0 !important;
	margin-bottom: 24px !important;
	display: flex !important;
	align-items: center !important;
	flex-wrap: wrap !important;
	gap: 8px !important;
}

.single-post .single-hero .entry-meta,
.single-post .single-hero .entry-meta * {
	font-size: 14px !important;
	font-weight: 500 !important;
	color: var(--langit-muted, #718096) !important;
}

.single-post .single-hero .entry-meta a {
	color: inherit !important;
	text-decoration: none !important;
	background: none !important;
	border: none !important;
	padding: 0 !important;
	margin: 0 !important;
	font-weight: 500 !important;
}

.single-post .single-hero .entry-meta a:hover {
	color: var(--langit-primary, #0088cc) !important;
}

.single-post .single-hero .entry-meta .meta-separator {
	color: var(--langit-border, #e2e8f0) !important;
	font-weight: 400 !important;
	margin-inline: 4px !important;
}

/* Title -> Featured Image (28px) */
.single-post .single-hero {
	margin-top: 0 !important;
	margin-bottom: 28px !important;
	padding-bottom: 0 !important;
}

/* Featured Image styling & size (width follows content area, 32px margin bottom to content) */
.single-post .single-featured-image {
	width: 100% !important;
	max-width: 100% !important;
	margin-left: 0 !important;
	margin-right: auto !important;
	margin-top: 0 !important;
	margin-bottom: 32px !important;
	border-radius: var(--langit-radius, 16px) !important;
	overflow: hidden !important;
}

.single-post .single-featured-image img {
	width: 100% !important;
	height: auto !important;
	object-fit: cover !important;
	border-radius: var(--langit-radius, 16px) !important;
}

/* Align single content and footer to fill the available article column (zero offset/whitespace) */
.single-post .single-content,
.single-post .single-footer {
	margin-left: 0 !important;
	margin-right: auto !important;
	max-width: 100% !important;
	width: 100% !important;
}

/* Align direct children of post content block (paragraphs, lists, etc.) to 100% width and left align */
.single-post .entry-content > * {
	width: 100% !important;
	max-width: 100% !important;
	margin-left: 0 !important;
	margin-right: auto !important;
}

/* 3. Article Content Typography Scale */
.single-post .single-content p,
.single-post .single-content li {
	font-size: 18px !important;
	line-height: 1.9 !important;
	color: var(--langit-text, #334155) !important;
}

/* Responsive Overrides for Title and Content text sizes */
@media (max-width: 1024px) {
	.single-post .entry-title,
	.single-post .blog-post-title,
	.single-post .single-post-title {
		font-size: 36px !important;
		width: 90% !important;
		max-width: 90% !important;
	}

	.single-post .single-content p,
	.single-post .single-content li {
		font-size: 17px !important;
	}
}

@media (max-width: 768px) {
	.single-post .entry-title,
	.single-post .blog-post-title,
	.single-post .single-post-title {
		font-size: 28px !important;
		width: 100% !important;
		max-width: 100% !important;
	}

	.single-post .single-content p,
	.single-post .single-content li {
		font-size: 16px !important;
	}
}

/* ==========================================================================
   RELATED POSTS SECTION REFINEMENT
   ========================================================================== */

/* Remove default width constraints for related posts container to allow full width section */
.related-posts-section {
	width: 100% !important;
	max-width: 100% !important;
	margin: 0 !important;
	padding-block: var(--langit-space-xl) !important;
}

/* Ensure Related Posts cards adapt height and avoid fixed tall proportions */
.related-posts-section .post-card {
	height: auto !important;
}

/* ==========================================================================
   BLOG SIDEBAR TYPOGRAPHY & STYLE REFINEMENT
   ========================================================================== */

/* 1. Widget Card Spacing/Padding */
.blog-sidebar .blog-widget,
.blog-sidebar .widget {
	padding: 20px !important;
	border: 1px solid var(--langit-border, #e2e8f0) !important;
	border-radius: var(--langit-card-radius, var(--langit-radius, 12px)) !important;
	background: var(--langit-surface, #ffffff) !important;
	box-sizing: border-box !important;
}

/* 2. Widget Titles typography */
.blog-sidebar .blog-widget__title,
.blog-sidebar .widget-title,
.blog-sidebar .widgettitle,
.blog-sidebar .wp-block-search__label,
.blog-sidebar h1,
.blog-sidebar h2,
.blog-sidebar h3,
.blog-sidebar h4,
.blog-sidebar h5,
.blog-sidebar h6,
.blog-sidebar .wp-block-heading {
	font-size: 16px !important;
	line-height: 1.3 !important;
	font-weight: 700 !important;
	margin-top: 0 !important;
	margin-bottom: 12px !important;
	color: var(--langit-secondary, #0f172a) !important;
	letter-spacing: -0.01em !important;
}

/* 3. Widget Content (Recent Posts, Recent Comments, Categories, etc.) */
.blog-sidebar .blog-widget ul,
.blog-sidebar .blog-widget ol,
.blog-sidebar .widget ul,
.blog-sidebar .widget ol,
.blog-sidebar ul,
.blog-sidebar ol {
	display: grid !important;
	gap: 8px !important;
	margin: 0 !important;
	padding: 0 !important;
	list-style: none !important;
}

.blog-sidebar .blog-widget li,
.blog-sidebar .blog-widget p,
.blog-sidebar .blog-widget a,
.blog-sidebar .widget li,
.blog-sidebar .widget p,
.blog-sidebar .widget a,
.blog-sidebar li,
.blog-sidebar p,
.blog-sidebar a {
	font-size: 14px !important;
	line-height: 1.7 !important;
	margin: 0 !important;
}

.blog-sidebar .blog-widget li a,
.blog-sidebar .blog-widget li h1,
.blog-sidebar .blog-widget li h2,
.blog-sidebar .blog-widget li h3,
.blog-sidebar .blog-widget li h4,
.blog-sidebar .blog-widget li h5,
.blog-sidebar .blog-widget li h6,
.blog-sidebar .widget li a,
.blog-sidebar .widget li h1,
.blog-sidebar .widget li h2,
.blog-sidebar .widget li h3,
.blog-sidebar .widget li h4,
.blog-sidebar .widget li h5,
.blog-sidebar .widget li h6,
.blog-sidebar li a,
.blog-sidebar li h1,
.blog-sidebar li h2,
.blog-sidebar li h3,
.blog-sidebar li h4,
.blog-sidebar li h5,
.blog-sidebar li h6 {
	font-size: 14px !important;
	line-height: 1.7 !important;
	font-weight: 600 !important;
	text-decoration: none !important;
	color: var(--langit-secondary, #0f172a) !important;
}

.blog-sidebar .blog-widget li a:hover,
.blog-sidebar .widget li a:hover,
.blog-sidebar li a:hover {
	color: var(--langit-primary, #0088cc) !important;
}

/* 4. Search Widget size and proportion */
.blog-sidebar .widget_search .blog-widget__title,
.blog-sidebar .widget_search .widget-title,
.blog-sidebar .widget_search h1,
.blog-sidebar .widget_search h2,
.blog-sidebar .widget_search h3,
.blog-sidebar .widget_search h4,
.blog-sidebar .widget_search h5,
.blog-sidebar .widget_search h6,
.blog-sidebar .widget_search .wp-block-heading,
.blog-sidebar .wp-block-search .blog-widget__title,
.blog-sidebar .wp-block-search .widget-title,
.blog-sidebar .wp-block-search h1,
.blog-sidebar .wp-block-search h2,
.blog-sidebar .wp-block-search h3,
.blog-sidebar .wp-block-search h4,
.blog-sidebar .wp-block-search h5,
.blog-sidebar .wp-block-search h6,
.blog-sidebar .wp-block-search .wp-block-heading,
.blog-sidebar .wp-block-search__label {
	display: none !important;
}

.blog-sidebar .search-form,
.blog-sidebar .wp-block-search {
	display: flex !important;
	align-items: center !important;
	gap: 12px !important;
	max-width: 100% !important;
	width: 100% !important;
	flex-wrap: wrap !important;
}

.blog-sidebar .wp-block-search__inside-wrapper {
	display: flex !important;
	width: 100% !important;
	gap: 12px !important;
	flex-wrap: wrap !important;
}

.blog-sidebar .search-form label {
	margin: 0 !important;
	flex: 1 1 auto !important;
	display: block !important;
}

.blog-sidebar .search-form .search-field,
.blog-sidebar .wp-block-search__input {
	height: 44px !important;
	min-height: 44px !important;
	padding: 8px 12px !important;
	font-size: 14px !important;
	border-radius: var(--langit-radius-sm, 6px) !important;
	border: 1px solid var(--langit-border, #e2e8f0) !important;
	background: var(--langit-background, #f8fafc) !important;
	box-sizing: border-box !important;
	color: var(--langit-ink, #0f172a) !important;
	width: auto !important;
	flex: 1 1 auto !important;
	min-width: 0 !important;
}

.blog-sidebar .search-form .search-submit,
.blog-sidebar .wp-block-search__button {
	height: 44px !important;
	min-height: 44px !important;
	padding: 8px 16px !important;
	font-size: 14px !important;
	border-radius: var(--langit-radius-sm, 6px) !important;
	margin-top: 0 !important;
	background: var(--langit-primary, #0088cc) !important;
	color: #ffffff !important;
	border: none !important;
	font-weight: 700 !important;
	cursor: pointer !important;
	transition: background-color 150ms ease !important;
	flex: 0 0 auto !important;
}

.blog-sidebar .search-form .search-submit:hover,
.blog-sidebar .wp-block-search__button:hover {
	background: var(--langit-primary-hover, #0077b3) !important;
}

@media (max-width: 480px) {
	.blog-sidebar .search-form,
	.blog-sidebar .wp-block-search__inside-wrapper {
		flex-direction: column !important;
		align-items: stretch !important;
	}
	.blog-sidebar .search-form .search-submit,
	.blog-sidebar .wp-block-search__button {
		width: 100% !important;
		flex: 1 1 auto !important;
	}
	.blog-sidebar .search-form .search-field,
	.blog-sidebar .wp-block-search__input {
		width: 100% !important;
		flex: 1 1 auto !important;
	}
}

/* ==========================================================================
   SEARCH RESULTS PAGE SPECIFIC STYLING
   ========================================================================== */

/* 1. Hide Search Widget/Block in Sidebar on Search Results page */
.search-results .blog-sidebar .widget_search,
.search-results .blog-sidebar .wp-block-search {
	display: none !important;
}

/* 2. Horizontal Search Form in Search Page Hero */
.search-results .page-hero .search-form {
	display: flex !important;
	align-items: center !important;
	gap: 12px !important;
	width: 100% !important;
	max-width: 500px !important;
	margin-top: 16px !important;
}

.search-results .page-hero .search-form .search-field {
	height: 44px !important;
	min-height: 44px !important;
	padding: 8px 12px !important;
	font-size: 14px !important;
	border-radius: var(--langit-radius-sm, 6px) !important;
	border: 1px solid var(--langit-border, #e2e8f0) !important;
	background: var(--langit-surface, #ffffff) !important;
	color: var(--langit-ink, #0f172a) !important;
	width: auto !important;
	flex: 1 1 auto !important;
	min-width: 0 !important;
}

.search-results .page-hero .search-form .search-submit {
	height: 44px !important;
	min-height: 44px !important;
	padding: 8px 20px !important;
	font-size: 14px !important;
	border-radius: var(--langit-radius-sm, 6px) !important;
	background: var(--langit-primary, #0088cc) !important;
	color: #ffffff !important;
	border: none !important;
	font-weight: 700 !important;
	cursor: pointer !important;
	transition: background-color 150ms ease !important;
	flex: 0 0 auto !important;
}

.search-results .page-hero .search-form .search-submit:hover {
	background: var(--langit-primary-hover, #0077b3) !important;
}

/* 3. Reduce search page hero height */
.search-results .page-hero {
	padding-top: 32px !important;
	padding-bottom: 32px !important;
}

@media (min-width: 768px) {
	.search-results .page-hero {
		padding-top: 40px !important;
		padding-bottom: 40px !important;
	}
}

@media (min-width: 1025px) {
	.search-results .page-hero {
		padding-top: 48px !important;
		padding-bottom: 48px !important;
	}
}

/* 4. Hero Search Form Wrapper (max-width 640px, horizontal flex, no overflow) */
.search-results .search-hero-form-wrapper {
	max-width: 640px !important;
	width: 100% !important;
	margin-left: 0 !important;
	margin-right: auto !important;
	box-sizing: border-box !important;
}

.search-results .search-hero-form-wrapper .search-form {
	display: flex !important;
	align-items: center !important;
	gap: 12px !important;
	width: 100% !important;
	box-sizing: border-box !important;
}

.search-results .search-hero-form-wrapper .search-form label {
	margin: 0 !important;
	flex: 1 1 auto !important;
	display: block !important;
	max-width: 100% !important;
}

.search-results .search-hero-form-wrapper .search-form .search-field {
	height: 44px !important;
	min-height: 44px !important;
	padding: 8px 12px !important;
	font-size: 14px !important;
	border-radius: var(--langit-radius-sm, 6px) !important;
	border: 1px solid var(--langit-border, #e2e8f0) !important;
	background: var(--langit-surface, #ffffff) !important;
	box-sizing: border-box !important;
	color: var(--langit-ink, #0f172a) !important;
	width: auto !important;
	flex: 1 1 auto !important;
	min-width: 0 !important;
	max-width: 100% !important;
}

.search-results .search-hero-form-wrapper .search-form .search-submit {
	height: 44px !important;
	min-height: 44px !important;
	padding: 8px 20px !important;
	font-size: 14px !important;
	border-radius: var(--langit-radius-sm, 6px) !important;
	background: var(--langit-primary, #0088cc) !important;
	color: #ffffff !important;
	border: none !important;
	font-weight: 700 !important;
	cursor: pointer !important;
	transition: background-color 150ms ease !important;
	flex: 0 0 auto !important;
	box-sizing: border-box !important;
}

.search-results .search-hero-form-wrapper .search-form .search-submit:hover {
	background: var(--langit-primary-hover, #0077b3) !important;
}

@media (max-width: 480px) {
	.search-results .search-hero-form-wrapper .search-form {
		flex-direction: column !important;
		align-items: stretch !important;
	}
	.search-results .search-hero-form-wrapper .search-form .search-submit {
		width: 100% !important;
		flex: 1 1 auto !important;
	}
}

/* ==========================================================================
   SIDEBAR DAFTAR ISI BLOG WIDGET
   ========================================================================== */

/* 1. Desktop Sticky Behavior (top: 120px) */
@media (min-width: 1025px) {
	.blog-sidebar .widget_blog_toc {
		position: sticky !important;
		top: 120px !important;
		z-index: 10 !important;
	}
}

/* 2. Styling content layout matching other widgets */
.blog-sidebar .widget_blog_toc ul {
	display: grid !important;
	gap: 10px !important;
	margin: 0 !important;
	padding: 0 !important;
	list-style: none !important;
}

.blog-sidebar .widget_blog_toc li {
	position: relative !important;
	padding-left: 14px !important;
	font-size: 14px !important;
	line-height: 1.4 !important;
}

.blog-sidebar .widget_blog_toc li::before {
	content: "•" !important;
	position: absolute !important;
	left: 0 !important;
	top: 0 !important;
	color: var(--langit-primary, #0088cc) !important;
	font-weight: bold !important;
}

.blog-sidebar .widget_blog_toc a {
	color: var(--langit-secondary, #0f172a) !important;
	text-decoration: none !important;
	transition: color 0.2s ease !important;
}

.blog-sidebar .widget_blog_toc a:hover {
	color: var(--langit-primary, #0088cc) !important;
}

.blog-sidebar .widget_blog_toc li.active-toc-post a {
	color: var(--langit-primary, #0088cc) !important;
	font-weight: 600 !important;
}

.blog-sidebar .widget_blog_toc li.active-toc-post::before {
	color: var(--langit-primary, #0088cc) !important;
}






