/* =========================================================================
   ADDCOM THEME — MAIN STYLES
   Corporate B2B IT Services | Navy + Accent Blue | Inter / Manrope
   ========================================================================= */

/* --- Design Tokens -------------------------------------------------------- */
:root {
	/* Palette — refined corporate, not startup-purple */
	--color-navy:         #0a2540;  /* primary dark — headlines, footer */
	--color-navy-deep:    #061a30;  /* deepest navy */
	--color-ink:          #1a2332;  /* body copy */
	--color-slate:        #4a5568;  /* secondary text */
	--color-mist:         #718096;  /* muted text */
	--color-accent:       #0070d2;  /* primary action blue */
	--color-accent-dark:  #005ba8;  /* hover */
	--color-accent-soft:  #e6f0fa;  /* tint backgrounds */
	--color-line:         #e2e8f0;  /* hairlines */
	--color-bg:           #ffffff;
	--color-bg-alt:       #f5f7fa;  /* section bands */
	--color-bg-deep:      #eef2f7;
	--color-success:      #2f855a;
	--color-warning:      #d97706;

	/* Typography */
	--font-display: 'Manrope', 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
	--font-body:    'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

	/* Scale (fluid) */
	--fs-xs:   0.75rem;
	--fs-sm:   0.875rem;
	--fs-base: 1rem;
	--fs-lg:   1.125rem;
	--fs-xl:   clamp(1.25rem, 1.1rem + 0.6vw, 1.5rem);
	--fs-2xl:  clamp(1.5rem, 1.3rem + 1vw, 2rem);
	--fs-3xl:  clamp(1.875rem, 1.5rem + 1.6vw, 2.75rem);
	--fs-4xl:  clamp(2.25rem, 1.8rem + 2.2vw, 3.75rem);
	--fs-5xl:  clamp(2.75rem, 2rem + 3vw, 4.5rem);

	/* Spacing */
	--sp-1: 0.25rem;
	--sp-2: 0.5rem;
	--sp-3: 0.75rem;
	--sp-4: 1rem;
	--sp-5: 1.5rem;
	--sp-6: 2rem;
	--sp-7: 2.5rem;
	--sp-8: 3rem;
	--sp-10: 4rem;
	--sp-12: 5rem;
	--sp-16: 7rem;

	/* Layout */
	--container: 1280px;
	--container-sm: 960px;
	--radius-sm: 6px;
	--radius: 10px;
	--radius-lg: 18px;
	--shadow-sm: 0 1px 2px rgba(10, 37, 64, 0.04), 0 1px 3px rgba(10, 37, 64, 0.06);
	--shadow:    0 4px 12px rgba(10, 37, 64, 0.06), 0 2px 4px rgba(10, 37, 64, 0.04);
	--shadow-lg: 0 20px 40px rgba(10, 37, 64, 0.10), 0 8px 16px rgba(10, 37, 64, 0.06);

	/* Motion */
	--ease: cubic-bezier(0.4, 0, 0.2, 1);
	--ease-out: cubic-bezier(0.16, 1, 0.3, 1);
	--dur-fast: 150ms;
	--dur: 260ms;
	--dur-slow: 500ms;
}

/* --- Reset / Base --------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
	margin: 0;
	font-family: var(--font-body);
	font-size: var(--fs-base);
	line-height: 1.65;
	color: var(--color-ink);
	background: var(--color-bg);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: var(--color-accent); text-decoration: none; transition: color var(--dur-fast) var(--ease); }
a:hover { color: var(--color-accent-dark); }

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-display);
	color: var(--color-navy);
	font-weight: 700;
	line-height: 1.15;
	letter-spacing: -0.02em;
	margin: 0 0 0.6em;
}
h1 { font-size: var(--fs-5xl); letter-spacing: -0.035em; }
h2 { font-size: var(--fs-4xl); letter-spacing: -0.03em; }
h3 { font-size: var(--fs-3xl); }
h4 { font-size: var(--fs-2xl); }
h5 { font-size: var(--fs-xl); }
h6 { font-size: var(--fs-lg); }

p { margin: 0 0 1.2em; }
ul, ol { padding-left: 1.2em; }
blockquote {
	border-left: 3px solid var(--color-accent);
	padding-left: var(--sp-5);
	margin: var(--sp-6) 0;
	font-size: var(--fs-lg);
	color: var(--color-slate);
	font-style: italic;
}

/* Accessibility */
.screen-reader-text {
	position: absolute !important;
	clip: rect(1px,1px,1px,1px);
	width: 1px; height: 1px;
	overflow: hidden;
	padding: 0; border: 0;
}
.skip-link {
	position: absolute; top: -100px; left: 0;
	background: var(--color-navy); color: #fff;
	padding: var(--sp-3) var(--sp-5);
	z-index: 1000; font-weight: 600;
}
.skip-link:focus { top: 0; color: #fff; }

:focus-visible {
	outline: 2px solid var(--color-accent);
	outline-offset: 3px;
	border-radius: 2px;
}

/* --- Container ------------------------------------------------------------ */
.container {
	width: 100%;
	max-width: var(--container);
	margin: 0 auto;
	padding: 0 var(--sp-5);
}
.container--sm { max-width: var(--container-sm); }

/* --- Buttons -------------------------------------------------------------- */
.btn {
	display: inline-flex;
	align-items: center;
	gap: var(--sp-2);
	padding: 0.9rem 1.8rem;
	font-family: var(--font-display);
	font-size: var(--fs-sm);
	font-weight: 600;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	border-radius: var(--radius-sm);
	border: 2px solid transparent;
	cursor: pointer;
	transition: all var(--dur) var(--ease);
	text-decoration: none;
	line-height: 1;
	white-space: nowrap;
}
.btn--primary {
	background: var(--color-accent);
	color: #fff;
}
.btn--primary:hover {
	background: var(--color-accent-dark);
	color: #fff;
	transform: translateY(-1px);
	box-shadow: var(--shadow-lg);
}
.btn--navy {
	background: var(--color-navy);
	color: #fff;
}
.btn--navy:hover { background: var(--color-navy-deep); color: #fff; }
.btn--outline {
	background: transparent;
	color: var(--color-navy);
	border-color: var(--color-navy);
}
.btn--outline:hover { background: var(--color-navy); color: #fff; }
.btn--ghost {
	background: transparent;
	color: var(--color-accent);
	padding: 0.5rem 0;
	border: 0;
	text-transform: none;
	letter-spacing: 0;
	font-size: var(--fs-base);
}
.btn--ghost::after {
	content: '→';
	transition: transform var(--dur) var(--ease);
}
.btn--ghost:hover::after { transform: translateX(4px); }

.btn--arrow::after {
	content: '→';
	margin-left: 0.3em;
	transition: transform var(--dur) var(--ease);
}
.btn--arrow:hover::after { transform: translateX(3px); }

/* --- Utility bar (topmost strip) ----------------------------------------- */
.utility-bar {
	background: var(--color-navy-deep);
	color: #fff;
	font-size: var(--fs-sm);
	padding: var(--sp-2) 0;
}
.utility-bar__inner {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	gap: var(--sp-6);
	flex-wrap: wrap;
}
.utility-bar a {
	color: #fff;
	opacity: 0.85;
	transition: opacity var(--dur-fast) var(--ease);
}
.utility-bar a:hover { opacity: 1; color: #fff; }
.utility-bar__item {
	display: inline-flex;
	align-items: center;
	gap: var(--sp-2);
}
.utility-bar__label {
	font-weight: 600;
	text-transform: uppercase;
	font-size: var(--fs-xs);
	letter-spacing: 0.08em;
	opacity: 0.7;
}

/* --- Header --------------------------------------------------------------- */
.site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background: #fff;
	border-bottom: 1px solid var(--color-line);
	transition: box-shadow var(--dur) var(--ease);
}
.site-header.is-scrolled { box-shadow: var(--shadow); }
.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--sp-6);
	min-height: 80px;
	padding: var(--sp-3) var(--sp-5);
	max-width: var(--container);
	margin: 0 auto;
}
.site-logo img { max-height: 56px; width: auto; }
.site-logo__text {
	font-family: var(--font-display);
	font-size: 1.5rem;
	font-weight: 800;
	color: var(--color-navy);
	letter-spacing: -0.02em;
}

/* --- Primary Nav ---------------------------------------------------------- */
.primary-nav { display: none; }
@media (min-width: 1024px) {
	.primary-nav { display: block; }
	.primary-nav > ul {
		display: flex;
		list-style: none;
		margin: 0; padding: 0;
		gap: var(--sp-2);
	}
	.primary-nav > ul > li {
		position: relative;
	}
	.primary-nav > ul > li > a {
		display: block;
		padding: var(--sp-4) var(--sp-4);
		font-family: var(--font-display);
		font-weight: 600;
		font-size: var(--fs-sm);
		color: var(--color-navy);
		text-transform: uppercase;
		letter-spacing: 0.04em;
		position: relative;
	}
	.primary-nav > ul > li > a::after {
		content: '';
		position: absolute;
		left: var(--sp-4); right: var(--sp-4);
		bottom: 0.75rem;
		height: 2px;
		background: var(--color-accent);
		transform: scaleX(0);
		transform-origin: left;
		transition: transform var(--dur) var(--ease);
	}
	.primary-nav > ul > li:hover > a::after,
	.primary-nav > ul > li.current-menu-item > a::after { transform: scaleX(1); }

	/* Dropdown */
	.primary-nav .sub-menu {
		position: absolute;
		top: 100%;
		left: 0;
		min-width: 260px;
		background: #fff;
		border-radius: var(--radius);
		box-shadow: var(--shadow-lg);
		padding: var(--sp-3);
		list-style: none;
		margin: 0;
		opacity: 0;
		visibility: hidden;
		transform: translateY(8px);
		transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease), visibility 0s var(--dur);
		z-index: 50;
		border: 1px solid var(--color-line);
	}
	.primary-nav li:hover > .sub-menu,
	.primary-nav li:focus-within > .sub-menu {
		opacity: 1;
		visibility: visible;
		transform: translateY(0);
		transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease), visibility 0s 0s;
	}
	.primary-nav .sub-menu a {
		display: block;
		padding: var(--sp-3) var(--sp-4);
		color: var(--color-ink);
		border-radius: var(--radius-sm);
		font-size: var(--fs-sm);
		font-weight: 500;
		transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
	}
	.primary-nav .sub-menu a:hover {
		background: var(--color-accent-soft);
		color: var(--color-accent-dark);
	}
	/* Nested dropdown (e.g. Document Solutions) */
	.primary-nav .sub-menu .sub-menu {
		left: 100%;
		top: 0;
	}
	.primary-nav .sub-menu li {
		position: relative;
	}
	.primary-nav .sub-menu li.menu-item-has-children > a::after {
		content: '›';
		float: right;
		opacity: 0.6;
	}
}

.header-actions {
	display: flex;
	align-items: center;
	gap: var(--sp-3);
}

/* Mobile toggle */
.nav-toggle {
	display: inline-flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: 44px; height: 44px;
	background: transparent;
	border: 0;
	cursor: pointer;
	gap: 5px;
}
.nav-toggle span {
	display: block;
	width: 22px;
	height: 2px;
	background: var(--color-navy);
	transition: transform var(--dur) var(--ease), opacity var(--dur) var(--ease);
}
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

@media (min-width: 1024px) { .nav-toggle { display: none; } }

/* Mobile menu panel */
.mobile-menu {
	position: fixed;
	top: 0; right: 0;
	height: 100vh;
	width: min(400px, 90vw);
	background: #fff;
	box-shadow: var(--shadow-lg);
	transform: translateX(100%);
	transition: transform var(--dur-slow) var(--ease-out);
	z-index: 200;
	overflow-y: auto;
	padding: var(--sp-6) var(--sp-5);
}
.mobile-menu.is-open { transform: translateX(0); }
.mobile-menu__backdrop {
	position: fixed; inset: 0;
	background: rgba(10, 37, 64, 0.5);
	opacity: 0;
	visibility: hidden;
	transition: opacity var(--dur) var(--ease), visibility 0s var(--dur);
	z-index: 150;
}
.mobile-menu__backdrop.is-open {
	opacity: 1;
	visibility: visible;
	transition: opacity var(--dur) var(--ease), visibility 0s 0s;
}
.mobile-menu ul { list-style: none; padding: 0; margin: 0; }
.mobile-menu a {
	display: block;
	padding: var(--sp-3) 0;
	color: var(--color-navy);
	font-weight: 600;
	border-bottom: 1px solid var(--color-line);
}
.mobile-menu .sub-menu {
	padding-left: var(--sp-4);
	font-size: var(--fs-sm);
}
.mobile-menu .sub-menu a { font-weight: 500; color: var(--color-slate); }
.mobile-menu__close {
	position: absolute; top: 1rem; right: 1rem;
	background: none; border: 0; font-size: 1.5rem;
	width: 44px; height: 44px; cursor: pointer;
	color: var(--color-navy);
}

/* =========================================================================
   SECTIONS & LAYOUT
   ========================================================================= */
.section {
	padding: var(--sp-16) 0;
}
.section--sm { padding: var(--sp-10) 0; }
.section--tight { padding: var(--sp-8) 0; }
.section--alt { background: var(--color-bg-alt); }
.section--navy { background: var(--color-navy); color: #fff; }
.section--navy h1, .section--navy h2, .section--navy h3, .section--navy h4 { color: #fff; }

.eyebrow {
	display: inline-block;
	font-family: var(--font-display);
	font-size: var(--fs-sm);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: var(--color-accent);
	margin-bottom: var(--sp-3);
}
.section--navy .eyebrow { color: #60a5fa; }

.section-header {
	max-width: 820px;
	margin: 0 auto var(--sp-10);
	text-align: center;
}
.section-header--left { margin-left: 0; text-align: left; }
.section-header p {
	font-size: var(--fs-lg);
	color: var(--color-slate);
	margin-top: var(--sp-3);
}

/* =========================================================================
   HERO (Homepage)
   ========================================================================= */
.hero {
	position: relative;
	padding: var(--sp-16) 0 var(--sp-12);
	overflow: hidden;
	background: linear-gradient(180deg, #fff 0%, var(--color-bg-alt) 100%);
}
.hero::before {
	content: '';
	position: absolute;
	top: -100px; right: -200px;
	width: 700px; height: 700px;
	background: radial-gradient(circle, rgba(0, 112, 210, 0.08) 0%, transparent 65%);
	pointer-events: none;
}
.hero__inner {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--sp-8);
	align-items: center;
	position: relative;
	z-index: 2;
}
@media (min-width: 960px) {
	.hero__inner { grid-template-columns: 1.1fr 0.9fr; gap: var(--sp-12); }
}
.hero__title {
	font-size: var(--fs-5xl);
	line-height: 1.05;
	margin-bottom: var(--sp-5);
}
.hero__title em {
	font-style: normal;
	color: var(--color-accent);
	position: relative;
}
.hero__tagline {
	font-size: var(--fs-lg);
	color: var(--color-slate);
	margin-bottom: var(--sp-6);
	max-width: 540px;
}
.hero__ctas {
	display: flex;
	gap: var(--sp-3);
	flex-wrap: wrap;
}
.hero__image {
	position: relative;
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow-lg);
	aspect-ratio: 4 / 3;
}
.hero__image::after {
	content: '';
	position: absolute; inset: 0;
	background: linear-gradient(135deg, transparent 50%, rgba(10, 37, 64, 0.15));
}
.hero__image img {
	width: 100%; height: 100%;
	object-fit: cover;
}
.hero__badge {
	display: inline-flex;
	align-items: center;
	gap: var(--sp-2);
	padding: var(--sp-2) var(--sp-4);
	border-radius: 999px;
	background: rgba(0, 112, 210, 0.08);
	color: var(--color-accent-dark);
	font-size: var(--fs-sm);
	font-weight: 600;
	margin-bottom: var(--sp-5);
}
.hero__badge::before {
	content: '';
	width: 8px; height: 8px;
	border-radius: 50%;
	background: var(--color-accent);
	box-shadow: 0 0 0 4px rgba(0, 112, 210, 0.2);
}

/* Simpler inner-page hero */
.page-hero {
	background: var(--color-navy);
	color: #fff;
	padding: var(--sp-16) 0 var(--sp-10);
	position: relative;
	overflow: hidden;
}
.page-hero::before {
	content: '';
	position: absolute;
	top: -100px; left: -100px;
	width: 600px; height: 600px;
	background: radial-gradient(circle, rgba(0, 112, 210, 0.25) 0%, transparent 60%);
	pointer-events: none;
}
.page-hero__inner {
	position: relative; z-index: 2;
	max-width: 820px;
}
.page-hero__inner--grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--sp-8);
	max-width: none;
	align-items: center;
}
@media (min-width: 960px) {
	.page-hero__inner--grid { grid-template-columns: 1.2fr 1fr; }
}
.page-hero h1 { color: #fff; margin-bottom: var(--sp-4); }
.page-hero__subtitle {
	font-size: var(--fs-xl);
	color: rgba(255,255,255, 0.85);
	margin-bottom: var(--sp-6);
}
.page-hero__image {
	border-radius: var(--radius-lg);
	overflow: hidden;
	aspect-ratio: 4 / 3;
	box-shadow: 0 30px 60px rgba(0,0,0,0.3);
}
.page-hero__image img { width: 100%; height: 100%; object-fit: cover; }

/* =========================================================================
   SERVICE / FEATURE CARDS
   ========================================================================= */
.card-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: var(--sp-5);
}
.card-grid--2 { grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); }
.card-grid--3 {
	grid-template-columns: 1fr;
}
@media (min-width: 720px) {
	.card-grid--3 { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
	.card-grid--3 { grid-template-columns: repeat(3, 1fr); }
}

.service-card {
	background: #fff;
	border: 1px solid var(--color-line);
	border-radius: var(--radius-lg);
	padding: var(--sp-7) var(--sp-6);
	transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
	display: flex;
	flex-direction: column;
	text-decoration: none;
	color: inherit;
	position: relative;
	overflow: hidden;
}
.service-card::before {
	content: '';
	position: absolute;
	top: 0; left: 0;
	width: 100%;
	height: 4px;
	background: linear-gradient(90deg, var(--color-accent), var(--color-accent-dark));
	transform: scaleX(0);
	transform-origin: left;
	transition: transform var(--dur-slow) var(--ease-out);
}
.service-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-lg);
	border-color: var(--color-accent);
	color: inherit;
}
.service-card:hover::before { transform: scaleX(1); }
.service-card__icon {
	width: 56px; height: 56px;
	border-radius: var(--radius);
	background: var(--color-accent-soft);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: var(--sp-5);
	color: var(--color-accent);
	flex-shrink: 0;
}
.service-card__icon svg { width: 28px; height: 28px; }
.service-card__title {
	font-size: var(--fs-xl);
	margin-bottom: var(--sp-3);
}
.service-card__desc {
	color: var(--color-slate);
	margin-bottom: var(--sp-4);
	flex-grow: 1;
}
.service-card__link {
	font-family: var(--font-display);
	font-weight: 600;
	font-size: var(--fs-sm);
	color: var(--color-accent);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	display: inline-flex; align-items: center; gap: var(--sp-2);
}
.service-card__link::after {
	content: '→';
	transition: transform var(--dur) var(--ease);
}
.service-card:hover .service-card__link::after { transform: translateX(4px); }

/* Feature card with image cover (offerings grid) */
.offering-card {
	display: block;
	position: relative;
	border-radius: var(--radius-lg);
	overflow: hidden;
	aspect-ratio: 4 / 3;
	text-decoration: none;
	color: #fff;
	isolation: isolate;
}
.offering-card img {
	position: absolute; inset: 0;
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform var(--dur-slow) var(--ease);
}
.offering-card::after {
	content: '';
	position: absolute; inset: 0;
	background: linear-gradient(180deg, transparent 30%, rgba(10, 37, 64, 0.85) 100%);
	z-index: 1;
}
.offering-card:hover img { transform: scale(1.05); }
.offering-card:hover { color: #fff; }
.offering-card__title {
	position: absolute;
	bottom: 0; left: 0; right: 0;
	padding: var(--sp-6);
	color: #fff;
	font-family: var(--font-display);
	font-size: var(--fs-xl);
	font-weight: 700;
	z-index: 2;
}

/* =========================================================================
   HOW IT WORKS (Numbered Steps)
   ========================================================================= */
.steps {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: var(--sp-5);
	counter-reset: step;
}
.step {
	padding: var(--sp-6);
	background: #fff;
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-line);
	position: relative;
}
.step__number {
	font-family: var(--font-display);
	font-size: 3rem;
	font-weight: 800;
	color: var(--color-accent-soft);
	line-height: 1;
	margin-bottom: var(--sp-4);
	letter-spacing: -0.05em;
}
.step__title {
	font-size: var(--fs-lg);
	margin-bottom: var(--sp-2);
}
.step__desc { color: var(--color-slate); font-size: var(--fs-sm); margin: 0; }

/* =========================================================================
   ICON FEATURE GRID
   ========================================================================= */
.icon-features {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: var(--sp-6);
}
.icon-feature {
	text-align: left;
}
.icon-feature__icon {
	width: 64px; height: 64px;
	border-radius: var(--radius);
	background: var(--color-accent-soft);
	display: flex; align-items: center; justify-content: center;
	margin-bottom: var(--sp-4);
	color: var(--color-accent);
}
.icon-feature__icon img { max-width: 40px; max-height: 40px; }
.icon-feature__title {
	font-size: var(--fs-lg);
	margin-bottom: var(--sp-2);
}
.icon-feature__desc {
	color: var(--color-slate);
	font-size: var(--fs-base);
	margin: 0;
}

/* =========================================================================
   SPLIT CONTENT BLOCK (text + image alternating)
   ========================================================================= */
.split {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--sp-8);
	align-items: center;
}
@media (min-width: 960px) {
	.split { grid-template-columns: 1fr 1fr; gap: var(--sp-10); }
	.split--reverse .split__media { order: -1; }
}
.split__content .eyebrow { margin-bottom: var(--sp-3); }
.split__media {
	border-radius: var(--radius-lg);
	overflow: hidden;
	aspect-ratio: 4 / 3;
	box-shadow: var(--shadow-lg);
	background: var(--color-bg-alt);
}
.split__media img { width: 100%; height: 100%; object-fit: cover; }

/* =========================================================================
   TESTIMONIAL CAROUSEL
   ========================================================================= */
.testimonial-slider {
	position: relative;
	padding: 0 var(--sp-5);
}
.testimonial-track {
	display: flex;
	gap: var(--sp-5);
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	padding-bottom: var(--sp-5);
	scrollbar-width: thin;
	scrollbar-color: var(--color-accent) transparent;
}
.testimonial-track::-webkit-scrollbar { height: 6px; }
.testimonial-track::-webkit-scrollbar-thumb { background: var(--color-accent); border-radius: 3px; }
.testimonial {
	min-width: min(500px, 90%);
	flex: 0 0 auto;
	background: #fff;
	border-radius: var(--radius-lg);
	padding: var(--sp-7);
	box-shadow: var(--shadow);
	scroll-snap-align: start;
	position: relative;
	border-top: 4px solid var(--color-accent);
}
.testimonial::before {
	content: '\201C';
	position: absolute;
	top: var(--sp-4); right: var(--sp-5);
	font-family: Georgia, serif;
	font-size: 5rem;
	line-height: 1;
	color: var(--color-accent-soft);
	font-weight: 700;
}
.testimonial__quote {
	font-size: var(--fs-lg);
	color: var(--color-ink);
	margin-bottom: var(--sp-5);
	position: relative;
	z-index: 2;
}
.testimonial__cite {
	display: flex;
	flex-direction: column;
	border-top: 1px solid var(--color-line);
	padding-top: var(--sp-4);
}
.testimonial__name {
	font-family: var(--font-display);
	font-weight: 700;
	color: var(--color-navy);
}
.testimonial__role {
	font-size: var(--fs-sm);
	color: var(--color-slate);
}

/* =========================================================================
   CLIENT LOGO GRID
   ========================================================================= */
.logo-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--sp-6);
	align-items: center;
	justify-items: center;
}
@media (min-width: 720px) { .logo-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 960px) { .logo-grid { grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 1200px) { .logo-grid { grid-template-columns: repeat(5, 1fr); } }
.logo-grid img {
	max-width: 160px;
	max-height: 70px;
	width: auto; height: auto;
	opacity: 0.7;
	filter: grayscale(100%);
	transition: opacity var(--dur) var(--ease), filter var(--dur) var(--ease);
}
.logo-grid img:hover { opacity: 1; filter: grayscale(0%); }

/* =========================================================================
   PILLARS (The Addcom Way - numbered value props)
   ========================================================================= */
.pillars {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: var(--sp-5);
	margin-top: var(--sp-8);
}
.pillar {
	padding: var(--sp-6);
	background: #fff;
	border-radius: var(--radius-lg);
	position: relative;
	border: 1px solid var(--color-line);
}
.pillar__number {
	font-family: var(--font-display);
	font-size: 2.5rem;
	font-weight: 800;
	color: var(--color-accent);
	line-height: 1;
	margin-bottom: var(--sp-4);
	display: inline-block;
	position: relative;
}
.pillar__number::after {
	content: '';
	display: block;
	width: 40px; height: 3px;
	background: var(--color-accent);
	margin-top: var(--sp-2);
}
.pillar__title {
	font-size: var(--fs-lg);
	margin-bottom: var(--sp-3);
}
.pillar__desc { color: var(--color-slate); font-size: var(--fs-sm); margin: 0; }

/* =========================================================================
   BENEFITS LIST (Why Invest)
   ========================================================================= */
.benefits {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: var(--sp-5);
}
.benefit {
	border-left: 3px solid var(--color-accent);
	padding: var(--sp-2) var(--sp-5);
}
.benefit__title {
	font-family: var(--font-display);
	font-weight: 700;
	color: var(--color-navy);
	margin-bottom: var(--sp-2);
	font-size: var(--fs-lg);
}
.benefit__desc { color: var(--color-slate); margin: 0; }

/* =========================================================================
   CTA BANNER
   ========================================================================= */
.cta-banner {
	position: relative;
	padding: var(--sp-12) 0;
	overflow: hidden;
	background: var(--color-navy);
	color: #fff;
}
.cta-banner::before {
	content: '';
	position: absolute; inset: 0;
	background:
		radial-gradient(circle at 80% 20%, rgba(0, 112, 210, 0.3) 0%, transparent 50%),
		radial-gradient(circle at 20% 80%, rgba(0, 112, 210, 0.2) 0%, transparent 50%);
	pointer-events: none;
}
.cta-banner__inner {
	position: relative; z-index: 2;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--sp-6);
	align-items: center;
}
@media (min-width: 840px) {
	.cta-banner__inner { grid-template-columns: 1fr auto; gap: var(--sp-10); }
}
.cta-banner h2 { color: #fff; margin-bottom: var(--sp-3); }
.cta-banner p { color: rgba(255,255,255,0.85); font-size: var(--fs-lg); margin: 0; }
.cta-banner .btn--primary { background: #fff; color: var(--color-navy); }
.cta-banner .btn--primary:hover { background: var(--color-accent-soft); color: var(--color-navy); }

/* =========================================================================
   BLOG / ARCHIVE
   ========================================================================= */
.post-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
	gap: var(--sp-6);
}
.post-card {
	background: #fff;
	border: 1px solid var(--color-line);
	border-radius: var(--radius-lg);
	overflow: hidden;
	transition: box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease);
	display: flex;
	flex-direction: column;
}
.post-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-3px); }
.post-card__thumb {
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: var(--color-bg-alt);
}
.post-card__thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--dur-slow) var(--ease); }
.post-card:hover .post-card__thumb img { transform: scale(1.04); }
.post-card__body { padding: var(--sp-6); flex-grow: 1; display: flex; flex-direction: column; }
.post-card__meta { font-size: var(--fs-sm); color: var(--color-mist); margin-bottom: var(--sp-3); }
.post-card__title {
	font-size: var(--fs-xl);
	margin-bottom: var(--sp-3);
}
.post-card__title a { color: var(--color-navy); }
.post-card__title a:hover { color: var(--color-accent); }
.post-card__excerpt { color: var(--color-slate); margin-bottom: var(--sp-4); flex-grow: 1; }

/* Single post */
.single-post-content {
	max-width: 760px;
	margin: 0 auto;
	padding: var(--sp-10) var(--sp-5);
}
.single-post-content h2, .single-post-content h3, .single-post-content h4 { margin-top: 2em; }
.single-post-content figure { margin: var(--sp-6) 0; }

/* =========================================================================
   CONTACT FORM 7 STYLING
   ========================================================================= */
.wpcf7 form {
	display: grid;
	gap: var(--sp-5);
}
.wpcf7-form p { margin: 0; }
.wpcf7-form label {
	display: block;
	font-weight: 600;
	font-size: var(--fs-sm);
	margin-bottom: var(--sp-2);
	color: var(--color-navy);
}
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form input[type="url"],
.wpcf7-form textarea,
.wpcf7-form select {
	width: 100%;
	padding: 0.85rem 1rem;
	font-family: inherit;
	font-size: var(--fs-base);
	color: var(--color-ink);
	background: #fff;
	border: 1px solid var(--color-line);
	border-radius: var(--radius-sm);
	transition: border-color var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease);
}
.wpcf7-form input:focus,
.wpcf7-form textarea:focus,
.wpcf7-form select:focus {
	outline: none;
	border-color: var(--color-accent);
	box-shadow: 0 0 0 3px rgba(0, 112, 210, 0.15);
}
.wpcf7-form textarea { min-height: 140px; resize: vertical; }
.wpcf7-form input[type="submit"] {
	background: var(--color-accent);
	color: #fff;
	border: 0;
	padding: 1rem 2rem;
	font-family: var(--font-display);
	font-weight: 600;
	font-size: var(--fs-sm);
	letter-spacing: 0.04em;
	text-transform: uppercase;
	border-radius: var(--radius-sm);
	cursor: pointer;
	transition: background var(--dur) var(--ease), transform var(--dur) var(--ease);
	justify-self: start;
}
.wpcf7-form input[type="submit"]:hover { background: var(--color-accent-dark); transform: translateY(-1px); }
.wpcf7-not-valid-tip { color: #d32f2f; font-size: var(--fs-sm); margin-top: var(--sp-2); }
.wpcf7-response-output {
	border: 1px solid var(--color-line);
	padding: var(--sp-4);
	border-radius: var(--radius-sm);
	margin-top: var(--sp-4);
}

/* Two-column form row */
.wpcf7-form .form-row {
	display: grid;
	gap: var(--sp-4);
}
@media (min-width: 600px) {
	.wpcf7-form .form-row--2 { grid-template-columns: 1fr 1fr; }
}

/* =========================================================================
   FOOTER
   ========================================================================= */
.site-footer {
	background: var(--color-navy-deep);
	color: rgba(255,255,255,0.8);
	padding-top: var(--sp-12);
}
.site-footer h4, .site-footer h3 { color: #fff; font-size: var(--fs-lg); }
.site-footer a { color: rgba(255,255,255, 0.75); }
.site-footer a:hover { color: #fff; }
.footer-top {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--sp-8);
	padding-bottom: var(--sp-10);
	border-bottom: 1px solid rgba(255,255,255,0.1);
}
@media (min-width: 720px) { .footer-top { grid-template-columns: 1.5fr 1fr 1fr 1fr; } }
.footer-brand__logo { margin-bottom: var(--sp-4); max-width: 200px; }
.footer-brand__logo img { filter: brightness(0) invert(1); }
.footer-brand__tagline {
	color: rgba(255,255,255, 0.7);
	font-size: var(--fs-sm);
	margin-bottom: var(--sp-5);
	max-width: 340px;
}
.footer-brand__entities {
	font-size: var(--fs-xs);
	color: rgba(255,255,255, 0.55);
	line-height: 1.8;
}
.footer-brand__entities strong { color: rgba(255,255,255, 0.8); }

.footer-menu { list-style: none; padding: 0; margin: 0; }
.footer-menu li { margin-bottom: var(--sp-2); }
.footer-menu a { font-size: var(--fs-sm); }

.footer-contact {
	font-size: var(--fs-sm);
	line-height: 1.8;
}
.footer-contact__block {
	margin-bottom: var(--sp-4);
}
.footer-contact__label {
	display: block;
	color: rgba(255,255,255, 0.5);
	text-transform: uppercase;
	font-size: var(--fs-xs);
	letter-spacing: 0.08em;
	margin-bottom: 2px;
}

.footer-bottom {
	padding: var(--sp-5) 0;
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--sp-3);
	font-size: var(--fs-sm);
	color: rgba(255,255,255, 0.55);
}

/* =========================================================================
   BREADCRUMBS
   ========================================================================= */
.breadcrumbs {
	font-size: var(--fs-sm);
	color: var(--color-slate);
	padding: var(--sp-3) 0;
	background: var(--color-bg-alt);
	border-bottom: 1px solid var(--color-line);
}
.breadcrumbs a { color: var(--color-slate); }
.breadcrumbs a:hover { color: var(--color-accent); }
.breadcrumbs__separator { margin: 0 0.5em; opacity: 0.5; }
.breadcrumbs__current { color: var(--color-navy); font-weight: 600; }

/* =========================================================================
   SEARCH / 404
   ========================================================================= */
.page-404, .no-results {
	text-align: center;
	padding: var(--sp-16) var(--sp-5);
}
.page-404 h1 {
	font-size: 6rem;
	color: var(--color-accent);
	margin-bottom: var(--sp-4);
}

/* =========================================================================
   PAGINATION
   ========================================================================= */
.pagination {
	display: flex;
	justify-content: center;
	gap: var(--sp-2);
	margin: var(--sp-8) 0;
}
.pagination a, .pagination span {
	padding: 0.6rem 1rem;
	border: 1px solid var(--color-line);
	border-radius: var(--radius-sm);
	font-weight: 600;
	color: var(--color-navy);
}
.pagination a:hover { background: var(--color-accent-soft); border-color: var(--color-accent); }
.pagination .current { background: var(--color-navy); color: #fff; border-color: var(--color-navy); }

/* =========================================================================
   UTILITIES
   ========================================================================= */
.text-center { text-align: center; }
.text-muted { color: var(--color-slate); }
.mt-0 { margin-top: 0; } .mt-4 { margin-top: var(--sp-4); } .mt-6 { margin-top: var(--sp-6); } .mt-8 { margin-top: var(--sp-8); }
.mb-0 { margin-bottom: 0; } .mb-4 { margin-bottom: var(--sp-4); } .mb-6 { margin-bottom: var(--sp-6); } .mb-8 { margin-bottom: var(--sp-8); }

/* Fade-in on scroll */
.reveal {
	opacity: 0;
	transform: translateY(20px);
	transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out);
}
.reveal.is-visible {
	opacity: 1;
	transform: translateY(0);
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: 0.01ms !important;
		transition-duration: 0.01ms !important;
	}
	.reveal { opacity: 1; transform: none; }
}
