: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: 1180px;
	--langit-container-wide: 1320px;
	--langit-gutter: 1.5rem;
	--langit-radius: 12px;
	--langit-header-height: 72px;
	--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 {
	overflow-x: hidden;
	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;
	overflow-x: hidden;
	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;
	overflow-x: clip;
}

.container,
.u-container,
.site-header__inner,
.site-footer__inner,
.entry-content > * {
	width: min(100% - (var(--langit-gutter) * 2), var(--langit-container));
	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: clean white with a faint sky-blue radial warmth top-right */
.home-section--company {
	background:
		radial-gradient(ellipse at 94% 0%, rgba(88, 175, 255, 0.1), transparent 46%),
		var(--langit-surface);
}

/* Services: blueprint-grid tint — enterprise technical texture */
.home-section--services {
	background:
		linear-gradient(180deg, rgba(232, 244, 255, 0.86), rgba(241, 248, 255, 0.96)),
		#eef7ff;
	position: relative;
	isolation: isolate;
}

.home-section--services::before {
	position: absolute;
	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: 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;
}

/* Projects / Team / FAQ / Certifications: cool slate — depth after dark navy Industry */
.home-section--projects,
.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;
}

/* Trust/Stats: pure white — intentional lightness after cool-slate projects */
.home-section--trust {
	background: var(--langit-surface);
}

/* 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);
}

/* ─────────────────────────────────────────────────────────────────────────────
   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(248, 250, 252, 0.98);
	border-bottom: 1px solid rgba(219, 228, 238, 0.82);
	transition: background-color 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}

.site-header.is-scrolled {
	border-bottom-color: rgba(203, 213, 225, 0.95);
	background: rgba(248, 250, 252, 0.96);
	box-shadow: 0 10px 28px rgba(15, 23, 42, 0.08);
}

.site-header__inner {
	display: flex;
	min-height: var(--langit-header-height);
	align-items: center;
	justify-content: space-between;
	gap: var(--langit-space-sm);
}

.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;
}

.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;
}

.site-title a {
	color: var(--langit-secondary);
	text-decoration: none;
	overflow-wrap: anywhere;
}

.site-description {
	display: none;
	margin: 0.2rem 0 0;
	color: var(--langit-muted);
	font-size: 0.86rem;
	line-height: 1.25;
}

.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;
	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;
}

.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--home {
	display: grid;
	min-height: 100vh;
	padding-block: calc(var(--langit-header-height) + clamp(2rem, 5vw, 4.5rem)) clamp(3rem, 7vw, 6rem);
	align-items: center;
	background: #06111f;
	overflow: hidden;
	border-bottom: 0;
	color: rgba(255, 255, 255, 0.84);
	isolation: isolate;
}

.hero--home + .section {
	position: relative;
}

.hero--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.4), transparent);
	content: "";
	transform: translateX(-50%);
}

.hero--home::before,
.hero--home::after {
	position: absolute;
	inset: 0;
	z-index: -1;
	content: "";
	pointer-events: none;
}

.hero--home::before {
	background:
		radial-gradient(circle at 20% 35%, rgba(56, 189, 248, 0.22), transparent 45%),
		radial-gradient(circle at 80% 80%, rgba(88, 175, 255, 0.08), transparent 50%),
		linear-gradient(90deg, rgba(6, 17, 31, var(--langit-hero-overlay-opacity, 0.84)) 0%, rgba(6, 17, 31, 0.82) 35%, rgba(6, 17, 31, 0.5) 75%, rgba(6, 17, 31, 0.2) 100%),
		linear-gradient(180deg, rgba(6, 17, 31, 0.15) 0%, rgba(6, 17, 31, 0.88) 100%);
}

.hero--home::after {
	background:
		linear-gradient(90deg, rgba(56, 189, 248, 0.06) 1px, transparent 1px),
		linear-gradient(rgba(56, 189, 248, 0.06) 1px, transparent 1px);
	background-size: 64px 64px;
	mask-image: radial-gradient(circle at 20% 35%, black 20%, rgba(0, 0, 0, 0.3) 60%, transparent 100%);
	opacity: 0.85;
}

.hero-backgrounds {
	position: absolute;
	inset: 0;
	z-index: -2;
	background: #06111f;
}

.hero-backgrounds__image {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	opacity: 0;
	transform: scale(1.035);
	transition: opacity 1200ms var(--langit-transition-smooth), transform 6800ms var(--langit-transition-smooth);
}

.hero-backgrounds__image.is-active {
	opacity: 1;
	transform: scale(1);
}

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

.hero__content {
	max-width: 760px;
}

.hero--home .hero-grid {
	position: relative;
	z-index: 1;
	width: min(100% - (var(--langit-gutter) * 2), var(--langit-container-wide));
	grid-template-columns: minmax(0, 720px) minmax(12rem, 1fr);
}

.hero--home .hero__content {
	max-width: 720px;
	padding: clamp(0.2rem, 0.6vw, 0.6rem) 0;
}

.hero--home .section-eyebrow {
	width: max-content;
	max-width: 100%;
	padding: 0.5rem 1rem;
	border: 1px solid rgba(88, 175, 255, 0.25);
	border-radius: 999px;
	background: rgba(88, 175, 255, 0.08);
	box-shadow: 0 10px 30px rgba(15, 23, 42, 0.2);
	color: #bde4ff;
	backdrop-filter: blur(16px);
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.16em;
	text-transform: uppercase;
}

.hero--home h1 {
	margin-bottom: 0;
	color: #ffffff;
	font-size: clamp(2.2rem, 1.4rem + 2.5vw, 4.2rem);
	line-height: 1.05;
	letter-spacing: -0.035em;
	text-wrap: balance;
	word-break: normal;
	overflow-wrap: anywhere;
	hyphens: auto;
}

/* Ensure dynamic titles wrap gracefully without hard breaks */
.hero-title {
	display: block;
	width: 100%;
	max-width: 100%;
	text-wrap: balance;
	-webkit-text-size-adjust: 100%;
	-webkit-font-smoothing: antialiased;
}

.hero-title__line {
	display: inline;
}

.hero--home .lede {
	max-width: 62ch;
	color: rgba(226, 232, 240, 0.9);
	font-size: clamp(1.05rem, 0.98rem + 0.45vw, 1.35rem);
	line-height: 1.8;
	font-weight: 400;
}

.hero--home .cluster {
	gap: 0.8rem;
}

.hero--home .button {
	min-height: 3.1rem;
	padding-inline: 1.35rem;
	border-radius: var(--langit-radius);
	box-shadow: 0 16px 34px rgba(88, 175, 255, 0.15);
	font-weight: 750;
	letter-spacing: -0.01em;
	transition: var(--langit-transition-smooth);
}

.hero--home .button:hover,
.hero--home .button:focus {
	transform: translateY(-2px);
	box-shadow: 0 20px 40px rgba(88, 175, 255, 0.25);
}

.hero--home .button--ghost {
	border: 1px solid rgba(255, 255, 255, 0.2);
	background: rgba(255, 255, 255, 0.03);
	box-shadow: none;
	color: #ffffff;
	backdrop-filter: blur(12px);
}

.hero--home .button--ghost:hover,
.hero--home .button--ghost:focus {
	border-color: var(--langit-primary);
	background: rgba(88, 175, 255, 0.1);
	color: #ffffff;
	transform: translateY(-2px);
}

#services {
	scroll-margin-top: calc(var(--langit-header-height) + 1rem);
}

.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.05rem;
	padding: clamp(1.55rem, 1.25rem + 1vw, 2.25rem);
	border-color: rgba(148, 163, 184, 0.32);
	border-radius: 24px;
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.98) 0%, rgba(248, 252, 255, 0.96) 58%, rgba(237, 247, 255, 0.92) 100%),
		#ffffff;
	box-shadow: 0 18px 46px rgba(15, 23, 42, 0.08);
	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.4), rgba(88, 175, 255, 0) 42%),
		radial-gradient(circle at 12% 8%, rgba(88, 175, 255, 0.14), transparent 34%);
	opacity: 0.62;
	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.08) 1px, transparent 1px),
		linear-gradient(90deg, rgba(88, 175, 255, 0.06) 1px, transparent 1px);
	background-size: 28px 28px;
	mask-image: linear-gradient(135deg, rgba(0, 0, 0, 0.5), transparent 48%);
	opacity: 0.36;
	pointer-events: none;
}

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

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

.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: #506174;
	display: -webkit-box;
	font-size: 0.95rem;
	line-height: 1.62;
	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: 4rem;
	height: 4rem;
	padding: 0.76rem;
	border-radius: 18px;
	background:
		linear-gradient(145deg, rgba(255, 255, 255, 0.96), rgba(232, 244, 255, 0.9)),
		#f8fbff;
	border-color: 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);
}

.card:hover .service-card__icon,
.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.58);
	box-shadow: 0 28px 62px rgba(15, 23, 42, 0.13), 0 0 0 1px rgba(88, 175, 255, 0.08);
	transform: translateY(-6px);
}

.service-card:hover .service-card__icon {
	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);
}

.service-card .button--ghost,
.service-card .button--outline {
	margin-top: 0.35rem;
	color: #0f3658;
	font-size: 0.9rem;
	letter-spacing: 0;
}

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

.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);
}

.contact-card {
	display: grid;
	align-content: start;
	gap: 0.55rem;
	min-width: 0;
	padding: clamp(0.9rem, 1.5vw, 1.15rem);
}

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

.contact-card h3 {
	font-size: clamp(0.98rem, 0.93rem + 0.25vw, 1.12rem);
	line-height: 1.25;
	word-break: normal;
	overflow-wrap: break-word;
	hyphens: manual;
}

.contact-card p {
	line-height: 1.65;
	overflow-wrap: normal;
}

.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;
}

.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);
}

.contact-info-grid--enterprise {
	gap: clamp(0.85rem, 1.25vw, var(--langit-space-sm));
}

.contact-card--wide {
	grid-column: 1 / -1;
}

.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;
}

.post-card__media img,
.post-card__media span {
	display: block;
	width: 100%;
	aspect-ratio: 16 / 9;
	object-fit: cover;
	transition: transform 1.2s var(--langit-transition-smooth);
}

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

.post-card__media span {
	position: relative;
	background-image: url("../images/langit-blog-placeholder.svg");
	background-position: center;
	background-size: cover;
}

.post-card__media span::after {
	display: none;
	position: absolute;
	inset: 50% auto auto 50%;
	width: 3rem;
	height: 3rem;
	border-radius: var(--langit-radius);
	background: linear-gradient(135deg, var(--langit-primary), var(--langit-accent));
	content: "";
	transform: translate(-50%, -50%);
}

.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__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 p {
	margin-bottom: 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-hero {
	padding-block: var(--langit-space-lg);
}

.single-hero__content,
.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__logo {
	display: inline-flex;
	width: clamp(4.5rem, 4rem + 2vw, 5.5rem);
	margin-bottom: 0.85rem;
}

.site-footer__logo img,
.site-footer__logo-image {
	width: 100%;
	height: auto;
	aspect-ratio: 1;
	object-fit: contain;
}

.site-footer__brand h2 {
	margin-bottom: 0.5rem;
	font-size: clamp(1.6rem, 1.35rem + 1vw, 2.25rem);
	font-weight: 850;
	letter-spacing: -0.02em;
}

.site-footer__company {
	margin-bottom: 0.85rem;
	color: var(--langit-primary);
	font-weight: 800;
	font-size: 0.9rem;
	letter-spacing: 0.05em;
	text-transform: uppercase;
}

.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);
}

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) {
	.hero--home {
		/* compact, premium mobile hero with balanced breathing */
		padding-block: calc(var(--langit-header-height) + 1rem) 1.25rem;
		min-height: 60vh;
		align-items: center;
		--langit-hero-overlay-opacity: 0.94;
	}

	.hero--home::before {
		background:
			linear-gradient(90deg, rgba(6, 17, 31, 0.9) 0%, rgba(6, 17, 31, 0.82) 52%, rgba(6, 17, 31, 0.68) 100%),
			linear-gradient(180deg, rgba(6, 17, 31, 0.52), rgba(6, 17, 31, 0.86));
	}

	.hero--home .hero-grid {
		grid-template-columns: 1fr;
	}

	.hero--home h1 {
		/* allow natural wrapping on mobile by removing tiny ch cap */
		max-width: 40ch;
		font-size: clamp(1.6rem, 6.2vw, 2.4rem);
		line-height: 1.12;
	}

	.hero--home .lede {
		font-size: 0.98rem;
		line-height: 1.6;
		max-width: calc(100% - 2rem);
		margin-bottom: 1rem;
	}

	.hero--home .cluster {
		align-items: stretch;
	}

	/* Stack CTA buttons on mobile and reduce visual weight */
	.hero--home .cluster {
		flex-direction: column;
		align-items: stretch;
		width: 100%;
		gap: 0.75rem;
	}

	.hero--home .cluster .button,
	.hero--home .cluster .wp-block-button__link {
		width: 100%;
		min-height: 3rem;
		padding-inline: 0.9rem;
		font-size: 0.95rem;
	}

	.button,
	.wp-block-button__link,
	button,
	input[type="submit"] {
		width: 100%;
	}

	.hero-backgrounds__image {
		object-position: center 28%;
		transform: scale(1.02);
		filter: contrast(0.9) saturate(0.8) brightness(0.9);
	}

	/* make content block more centered and comfortable on narrow screens */
	.hero__content {
		max-width: min(calc(100% - 2rem), 640px);
		margin-inline: auto;
		padding-inline: 0.5rem;
	}

	.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;
	}

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

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

	.site-description {
		display: block;
	}

	.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));
	}
}

@media (min-width: 431px) and (max-width: 900px) {
	.hero--home .hero-grid {
		grid-template-columns: 1fr;
	}

	.hero--home {
		/* compact cinematic tablet hero */
		padding-block: calc(var(--langit-header-height) + clamp(0.9rem, 2.6vw, 2.4rem));
		min-height: 74vh;
		align-items: center;
		--langit-hero-overlay-opacity: 0.9;
	}

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

	.hero--home .lede {
		max-width: 56ch;
		font-size: clamp(0.98rem, 0.9rem + 0.4vw, 1.1rem);
	}

	/* Make CTAs inline when space allows, otherwise wrap */
	.hero--home .cluster {
		flex-wrap: wrap;
		gap: 0.75rem;
	}

	/* slightly reduce CTA prominence on tablet */
	.hero--home .cluster .button,
	.hero--home .cluster .wp-block-button__link {
		min-height: 3rem;
		padding-inline: 1rem;
	}

	/* ensure content block breathes on tablet */
	.hero__content {
		max-width: min(720px, calc(100% - 3rem));
		margin-inline: auto;
		padding-inline: 1rem;
	}

	.hero-backgrounds__image {
		object-position: center 35%;
	}
}

@media (max-width: 700px) and (orientation: landscape) {
	.hero--home {
		padding-block: calc(var(--langit-header-height) + 0.45rem);
		min-height: 56vh;
		align-items: center;
	}

	.hero--home h1 {
		font-size: clamp(1.6rem, 5.5vw, 2.6rem);
		line-height: 1.06;
		max-width: 34ch;
	}

	.hero--home .lede {
		max-width: 54ch;
		font-size: 0.95rem;
	}

	.hero-backgrounds__image {
		object-position: center 28%;
	}
}

@media (min-width: 901px) {
	.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;
	}

	.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));
	}

	.hero--home .hero-grid {
		width: min(100% - (var(--langit-gutter) * 2), 1180px);
		grid-template-columns: minmax(0, 720px) minmax(12rem, 1fr);
		padding-inline: clamp(0.25rem, 0.8vw, 0.9rem) clamp(2rem, 5vw, 5.5rem);
	}

	.hero--home h1 {
		max-width: 55ch;
	}

	.hero--home .hero__content {
		max-width: 720px;
	}

	.hero--home .lede {
		max-width: 68ch;
	}

	.hero-title__line {
		display: block;
	}

	.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));
	}

	.coverage-grid,
	.industries-serve-grid {
		grid-template-columns: repeat(4, 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__inner {
		grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.6fr);
	}

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

	.site-footer__bottom-inner {
		grid-template-columns: minmax(0, 1fr) auto;
		align-items: center;
		text-align: left;
	}

	.footer-bottom-menu {
		justify-content: flex-end;
	}
}

@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,
	.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;
	}

}

@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;
	}
}
