/* ============================================================
   MAIN.CSS - Full design system (loaded async)
   ============================================================ */

/* ── Section Wrapper ────────────────────────────────────────── */

.ag-section {
	padding: var(--space-4xl) 0;
}

.ag-section--navy {
	background: var(--navy);
	color: var(--white);
}

.ag-section--ivory {
	background: var(--ivory);
}

.ag-section--white {
	background: var(--white);
}

.ag-section__header {
	text-align: center;
	max-width: 680px;
	margin: 0 auto var(--space-3xl);
}

.ag-section__eyebrow {
	display: inline-block;
	font-size: var(--text-sm);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--crimson);
	margin-bottom: var(--space-sm);
}

.ag-section--navy .ag-section__eyebrow {
	color: #E85A7E;
}

.ag-section__title {
	font-family: var(--font-display);
	font-size: var(--text-4xl);
	font-weight: 800;
	line-height: 1.15;
	color: var(--navy);
	margin-bottom: var(--space-md);
}

.ag-section--navy .ag-section__title {
	color: var(--white);
}

.ag-section__subtitle {
	font-size: var(--text-lg);
	color: var(--silver);
	line-height: 1.6;
}

.ag-section--navy .ag-section__subtitle {
	color: var(--silver-light);
}

/* ── Typography ─────────────────────────────────────────────── */

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-display);
	font-weight: 700;
	line-height: 1.2;
	color: var(--navy);
}

h1 { font-size: var(--text-5xl); }
h2 { font-size: var(--text-4xl); }
h3 { font-size: var(--text-3xl); }
h4 { font-size: var(--text-2xl); }

p {
	margin-bottom: var(--space-md);
	line-height: 1.7;
}

/* ── Cards (shared) ─────────────────────────────────────────── */

.ag-card {
	background: var(--white);
	border-radius: var(--radius-lg);
	overflow: hidden;
	transition: transform var(--duration) var(--ease), box-shadow var(--duration) var(--ease);
}

.ag-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.1);
}

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

.ag-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s var(--ease);
}

.ag-card:hover .ag-card__image img {
	transform: scale(1.05);
}

.ag-card__body {
	padding: var(--space-lg);
}

.ag-card__title {
	font-size: var(--text-xl);
	margin-bottom: var(--space-sm);
}

.ag-card__text {
	font-size: var(--text-sm);
	color: var(--silver);
	line-height: 1.6;
	margin-bottom: var(--space-md);
}

.ag-card__link {
	font-size: var(--text-sm);
	font-weight: 600;
	color: var(--crimson);
	display: inline-flex;
	align-items: center;
	gap: var(--space-xs);
	transition: gap var(--duration) var(--ease);
}

.ag-card__link:hover {
	gap: var(--space-sm);
}

.ag-card__link svg {
	width: 16px;
	height: 16px;
}

/* ── Service Card ───────────────────────────────────────────── */

.ag-service-card {
	display: flex;
	flex-direction: column;
	background: var(--white);
	border-radius: var(--radius-lg);
	padding: var(--space-xl);
	border: 1px solid var(--border);
	transition: transform var(--duration) var(--ease), box-shadow var(--duration) var(--ease), border-color var(--duration) var(--ease);
}

.ag-service-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.08);
	border-color: var(--crimson);
}

.ag-service-card__icon {
	width: 48px;
	height: 48px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--ivory);
	border-radius: var(--radius);
	margin-bottom: var(--space-md);
	color: var(--crimson);
}

.ag-service-card__title {
	font-family: var(--font-display);
	font-size: var(--text-xl);
	font-weight: 700;
	margin-bottom: var(--space-sm);
	color: var(--navy);
}

.ag-service-card__text {
	font-size: var(--text-sm);
	color: var(--silver);
	line-height: 1.6;
	flex-grow: 1;
	margin-bottom: var(--space-md);
}

.ag-service-card__link {
	font-size: var(--text-sm);
	font-weight: 600;
	color: var(--crimson);
	display: inline-flex;
	align-items: center;
	gap: var(--space-xs);
}

/* ── Sector Card ────────────────────────────────────────────── */

.ag-sector-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	padding: var(--space-xl);
	background: rgba(255, 255, 255, 0.05);
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: var(--radius-lg);
	transition: background var(--duration) var(--ease), border-color var(--duration) var(--ease);
}

.ag-sector-card:hover {
	background: rgba(255, 255, 255, 0.1);
	border-color: var(--crimson);
}

.ag-sector-card__icon {
	width: 56px;
	height: 56px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: var(--space-md);
	color: var(--crimson);
}

.ag-sector-card__title {
	font-family: var(--font-display);
	font-size: var(--text-lg);
	font-weight: 700;
	color: var(--white);
	margin-bottom: var(--space-xs);
}

.ag-sector-card__desc {
	font-size: var(--text-sm);
	color: var(--silver-light);
	line-height: 1.5;
	opacity: 0.75;
}

/* ── Grid Layouts ───────────────────────────────────────────── */

.ag-grid {
	display: grid;
	gap: var(--space-xl);
}

.ag-grid--2 {
	grid-template-columns: 1fr;
}

.ag-grid--3 {
	grid-template-columns: 1fr;
}

.ag-grid--4 {
	grid-template-columns: 1fr;
}

@media (min-width: 480px) {
	.ag-grid--4 {
		grid-template-columns: 1fr 1fr;
	}
}

@media (min-width: 640px) {
	.ag-grid--2 {
		grid-template-columns: repeat(2, 1fr);
	}
	.ag-grid--3 {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.ag-grid--3 {
		grid-template-columns: repeat(3, 1fr);
	}
	.ag-grid--4 {
		grid-template-columns: repeat(4, 1fr);
	}
}

/* ── Process Steps ──────────────────────────────────────────── */

.ag-process {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-xl);
	counter-reset: step;
}

@media (min-width: 768px) {
	.ag-process {
		grid-template-columns: repeat(3, 1fr);
		gap: var(--space-2xl);
	}
}

.ag-process__step {
	position: relative;
	text-align: center;
	counter-increment: step;
}

.ag-process__number {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 64px;
	height: 64px;
	background: var(--crimson);
	color: var(--white);
	font-family: var(--font-display);
	font-size: var(--text-2xl);
	font-weight: 800;
	border-radius: 50%;
	margin-bottom: var(--space-lg);
}

.ag-process__title {
	font-family: var(--font-display);
	font-size: var(--text-2xl);
	font-weight: 700;
	margin-bottom: var(--space-sm);
}

.ag-process__text {
	font-size: var(--text-sm);
	color: var(--silver);
	line-height: 1.6;
	max-width: 320px;
	margin: 0 auto;
}

/* Connector line between steps (desktop) */
@media (min-width: 768px) {
	.ag-process__step:not(:last-child)::after {
		content: '';
		position: absolute;
		top: 32px;
		right: -16%;
		width: 32%;
		height: 2px;
		background: var(--border);
	}
}

/* ── Stats ──────────────────────────────────────────────────── */

.ag-stats {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-xl);
	text-align: center;
}

@media (min-width: 768px) {
	.ag-stats {
		grid-template-columns: repeat(4, 1fr);
	}
}

.ag-stats__item {
	padding: var(--space-lg);
}

.ag-stats__number {
	font-family: var(--font-display);
	font-size: var(--text-5xl);
	font-weight: 800;
	color: var(--white);
	line-height: 1;
	margin-bottom: var(--space-sm);
}

.ag-stats__label {
	font-size: var(--text-sm);
	color: var(--silver-light);
	font-weight: 500;
}

/* ── Accordion (values + FAQ) ───────────────────────────────── */

.ag-accordion {
	max-width: 760px;
	margin: 0 auto;
}

.ag-accordion__item {
	border-bottom: 1px solid var(--border);
}

.ag-section--navy .ag-accordion__item {
	border-color: rgba(255, 255, 255, 0.1);
}

.ag-accordion__trigger {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	padding: var(--space-lg) 0;
	text-align: left;
	font-family: var(--font-display);
	font-size: var(--text-xl);
	font-weight: 700;
	color: var(--navy);
	gap: var(--space-md);
}

.ag-section--navy .ag-accordion__trigger {
	color: var(--white);
}

.ag-accordion__icon {
	flex-shrink: 0;
	width: 24px;
	height: 24px;
	transition: transform var(--duration) var(--ease);
}

.ag-accordion__trigger[aria-expanded="true"] .ag-accordion__icon {
	transform: rotate(45deg);
}

.ag-accordion__content {
	overflow: hidden;
	max-height: 0;
	transition: max-height 0.4s var(--ease);
}

.ag-accordion__content[data-open="true"] {
	max-height: 500px;
}

.ag-accordion__body {
	padding-bottom: var(--space-lg);
	font-size: var(--text-base);
	color: var(--silver);
	line-height: 1.7;
}

.ag-section--navy .ag-accordion__body {
	color: var(--silver-light);
}

/* ── Testimonials ───────────────────────────────────────────── */

.ag-testimonial {
	background: var(--white);
	border-radius: var(--radius-lg);
	padding: var(--space-xl);
	border: 1px solid var(--border);
}

.ag-testimonial__quote {
	font-size: var(--text-base);
	line-height: 1.7;
	color: var(--navy-text);
	margin-bottom: var(--space-lg);
	font-style: italic;
}

.ag-testimonial__author {
	font-weight: 600;
	font-size: var(--text-sm);
	color: var(--navy);
}

.ag-testimonial__role {
	font-size: var(--text-sm);
	color: var(--silver);
}

/* ── Team Card ──────────────────────────────────────────────── */

.ag-team-card {
	text-align: center;
}

.ag-team-card__image {
	width: 120px;
	height: 120px;
	border-radius: 50%;
	overflow: hidden;
	margin: 0 auto var(--space-md);
	background: var(--ivory);
}

@media (min-width: 640px) {
	.ag-team-card__image {
		width: 160px;
		height: 160px;
	}
}

.ag-team-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.ag-team-card__name {
	font-family: var(--font-display);
	font-size: var(--text-xl);
	font-weight: 700;
	margin-bottom: var(--space-xs);
}

.ag-team-card__role {
	font-size: var(--text-sm);
	color: var(--silver);
}

/* ── Trust Bar ──────────────────────────────────────────────── */

.ag-trust-bar {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: var(--space-3xl);
	padding: var(--space-2xl) 0;
}

.ag-trust-bar__link {
	display: inline-block;
	transition: opacity var(--duration) var(--ease);
}

.ag-trust-bar__link:hover {
	opacity: 0.7;
}

.ag-trust-bar__item {
	height: 70px;
	width: auto;
}

@media (max-width: 768px) {
	.ag-trust-bar {
		gap: var(--space-xl);
	}
	.ag-trust-bar__item {
		height: 50px;
	}
}

@media (max-width: 480px) {
	.ag-trust-bar__item {
		height: 40px;
	}
}

/* ── Accreditation Strip (above footer) ───────────────────── */

.ag-accreditation {
	background: var(--ivory);
	padding: var(--space-3xl) 0;
	border-top: 1px solid var(--border);
}

.ag-accreditation__inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: var(--space-3xl);
}

.ag-accreditation__logo {
	height: 80px;
	width: auto;
	transition: opacity var(--duration) var(--ease);
}

.ag-accreditation a:hover .ag-accreditation__logo {
	opacity: 0.7;
}

@media (max-width: 768px) {
	.ag-accreditation__logo {
		height: 60px;
	}
	.ag-accreditation__inner {
		gap: var(--space-xl);
	}
}

@media (max-width: 480px) {
	.ag-accreditation__logo {
		height: 45px;
	}
}

/* ── CTA Banner ─────────────────────────────────────────────── */

.ag-cta-banner {
	padding: var(--space-3xl) 0;
}

.ag-cta-banner__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-2xl);
	align-items: start;
}

@media (min-width: 768px) {
	.ag-cta-banner__grid {
		grid-template-columns: 1fr 1fr;
		gap: var(--space-3xl);
	}
}

.ag-cta-banner__copy {
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.ag-cta-banner__title {
	font-family: var(--font-display);
	font-size: var(--text-4xl);
	font-weight: 800;
	margin-bottom: var(--space-md);
	color: var(--white);
}

.ag-cta-banner__text {
	font-size: var(--text-lg);
	opacity: 0.9;
	margin-bottom: var(--space-xl);
}

.ag-cta-banner__phone {
	font-size: var(--text-lg);
	color: var(--silver-light);
}

.ag-cta-banner__phone a {
	color: var(--white);
	font-weight: 600;
	text-decoration: underline;
	text-underline-offset: 3px;
}

.ag-cta-banner__phone a:hover {
	color: var(--crimson);
}

/* Form on dark bg within CTA banner */
.ag-cta-banner__form .ff-el-input--label label {
	color: var(--silver-light) !important;
}

.ag-cta-banner__form .ff-el-form-control {
	background: rgba(255, 255, 255, 0.08) !important;
	border-color: rgba(255, 255, 255, 0.15) !important;
	color: var(--white) !important;
}

.ag-cta-banner__form .ff-el-form-control::placeholder {
	color: rgba(255, 255, 255, 0.4) !important;
}

.ag-cta-banner__form .ff-el-form-control:focus {
	border-color: var(--crimson) !important;
	box-shadow: 0 0 0 3px rgba(203, 1, 61, 0.2) !important;
}

.ag-cta-banner__form .ff-btn-submit {
	background: var(--crimson) !important;
	border-color: var(--crimson) !important;
	width: 100% !important;
}

.ag-cta-banner__form .ff-btn-submit:hover {
	background: transparent !important;
	border-color: var(--white) !important;
	color: var(--white) !important;
}

.ag-cta-banner__form .ff-custom_html h4 span,
.ag-cta-banner__form .ff-custom_html h5 span,
.ag-cta-banner__form .ff-custom_html p span {
	color: var(--white) !important;
}

.ag-cta-banner__form .ff-message-success {
	background: rgba(16, 185, 129, 0.15) !important;
	border-color: rgba(16, 185, 129, 0.3) !important;
	color: #d1fae5 !important;
}

.ag-cta-banner .ag-btn--outline {
	border-color: rgba(255, 255, 255, 0.5);
}

.ag-cta-banner .ag-btn--outline:hover {
	background: rgba(255, 255, 255, 0.15);
	border-color: var(--white);
}

/* ── Pre-Footer CTA ─────────────────────────────────────────── */

.ag-pre-footer {
	background: var(--navy);
	color: var(--white);
	padding: var(--space-4xl) 0;
}

.ag-pre-footer__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-3xl);
}

@media (min-width: 768px) {
	.ag-pre-footer__grid {
		grid-template-columns: 1fr 1fr;
		gap: var(--space-4xl);
	}
}

.ag-pre-footer__title {
	font-family: var(--font-display);
	font-size: var(--text-3xl);
	font-weight: 800;
	margin-bottom: var(--space-sm);
	color: var(--white);
}

.ag-pre-footer__promise {
	font-size: var(--text-base);
	color: rgba(255, 255, 255, 0.55);
	margin-bottom: var(--space-xl);
	line-height: 1.6;
}

.ag-pre-footer__detail {
	display: flex;
	align-items: flex-start;
	gap: var(--space-md);
	margin-bottom: var(--space-md);
}

.ag-pre-footer__detail-icon {
	flex-shrink: 0;
	width: 20px;
	height: 20px;
	margin-top: 2px;
	color: var(--crimson);
}

.ag-pre-footer__detail-text {
	font-size: var(--text-base);
	color: var(--silver-light);
}

.ag-pre-footer__detail-text a {
	color: var(--white);
	text-decoration: underline;
	text-underline-offset: 2px;
}

.ag-pre-footer__map {
	width: 100%;
	aspect-ratio: 16 / 9;
	border-radius: var(--radius);
	overflow: hidden;
	background: var(--navy-light);
	cursor: pointer;
}

.ag-pre-footer__map iframe {
	width: 100%;
	height: 100%;
	border: 0;
}

.ag-pre-footer__map-placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	color: var(--silver-light);
	font-size: var(--text-sm);
}

/* ── Footer ─────────────────────────────────────────────────── */

.ag-footer {
	background: var(--navy);
	color: var(--silver-light);
	padding: var(--space-3xl) 0 var(--space-xl);
}

.ag-footer__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-2xl);
	margin-bottom: var(--space-3xl);
}

@media (min-width: 640px) {
	.ag-footer__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.ag-footer__grid {
		grid-template-columns: 2fr 1fr 1fr 1fr;
	}
}

.ag-footer__logo {
	height: 50px;
	width: auto;
	margin-bottom: var(--space-md);
	filter: brightness(0) invert(1);
}

.ag-footer__brand {
	font-family: var(--font-display);
	font-weight: 800;
	font-size: var(--text-xl);
	color: var(--white);
	margin-bottom: var(--space-sm);
}

.ag-footer__about {
	font-size: var(--text-sm);
	line-height: 1.6;
	max-width: 300px;
}

.ag-footer__hours {
	font-size: var(--text-xs);
	color: var(--silver-light);
	margin-top: var(--space-md);
}

.ag-footer__heading--sub {
	margin-top: var(--space-xl);
}

.ag-footer__regulatory {
	display: block;
	font-size: var(--text-xs);
	color: var(--silver-light);
	margin-top: var(--space-xs);
}

.ag-footer__bottom-left {
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
}

.ag-footer__heading {
	font-family: var(--font-display);
	font-size: var(--text-base);
	font-weight: 700;
	color: var(--white);
	margin-bottom: var(--space-md);
}

.ag-footer__links {
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
}

.ag-footer__links a {
	font-size: var(--text-sm);
	color: var(--silver-light);
	transition: color var(--duration) var(--ease);
}

.ag-footer__links a:hover {
	color: var(--white);
}

.ag-footer__bottom {
	padding-top: var(--space-xl);
	border-top: 1px solid rgba(255, 255, 255, 0.1);
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: var(--space-md);
	font-size: var(--text-xs);
}

.ag-footer__bottom a {
	color: var(--silver-light);
	transition: color var(--duration) var(--ease);
}

.ag-footer__bottom a:hover {
	color: var(--white);
}

/* ── Mobile Sticky Bar ──────────────────────────────────────── */

.ag-mobile-bar {
	display: flex;
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 900;
	background: var(--white);
	box-shadow: 0 -2px 8px rgba(0, 0, 0, 0.1);
	padding: var(--space-sm) var(--gutter);
	gap: var(--space-sm);
	width: 100%;
	box-sizing: border-box;
}

.ag-mobile-bar__btn {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-xs);
	padding: var(--space-md);
	font-size: var(--text-sm);
	font-weight: 600;
	border-radius: var(--radius);
	min-width: 0;
}

.ag-mobile-bar__btn--call {
	background: var(--navy);
	color: var(--white);
}

.ag-mobile-bar__btn--cta {
	background: var(--crimson);
	color: var(--white);
}

@media (min-width: 1024px) {
	.ag-mobile-bar {
		display: none;
	}
}

/* ── Cookie Consent ─────────────────────────────────────────── */

.ag-cookie {
	position: fixed;
	bottom: 80px;
	left: var(--gutter);
	right: var(--gutter);
	z-index: 800;
	background: var(--navy);
	color: var(--white);
	padding: var(--space-lg);
	border-radius: var(--radius-lg);
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.2);
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--space-md);
	max-width: 600px;
}

@media (min-width: 1024px) {
	.ag-cookie {
		bottom: var(--space-lg);
		left: var(--gutter);
		right: auto;
	}
}

.ag-cookie__text {
	flex: 1;
	font-size: var(--text-sm);
	line-height: 1.5;
	min-width: 200px;
}

.ag-cookie__text a {
	color: var(--white);
	text-decoration: underline;
}

.ag-cookie__accept {
	padding: var(--space-sm) var(--space-lg);
	background: var(--crimson);
	color: var(--white);
	font-weight: 600;
	font-size: var(--text-sm);
	border-radius: var(--radius);
	white-space: nowrap;
}

/* ── Post Content ───────────────────────────────────────────── */

.ag-content {
	padding: var(--space-3xl) 0;
}

.ag-content__body {
	max-width: var(--container-narrow);
}

.ag-content__body h2 {
	margin-top: var(--space-2xl);
	margin-bottom: var(--space-md);
	font-size: var(--text-3xl);
}

.ag-content__body h3 {
	margin-top: var(--space-xl);
	margin-bottom: var(--space-md);
	font-size: var(--text-2xl);
}

.ag-content__body p {
	margin-bottom: var(--space-md);
	line-height: 1.8;
}

.ag-content__body ul,
.ag-content__body ol {
	margin-bottom: var(--space-md);
	padding-left: var(--space-xl);
}

.ag-content__body ul {
	list-style: disc;
}

.ag-content__body ol {
	list-style: decimal;
}

.ag-content__body li {
	margin-bottom: var(--space-sm);
	line-height: 1.7;
}

.ag-content__body a {
	color: var(--crimson);
	text-decoration: underline;
	text-underline-offset: 2px;
}

.ag-content__body a:hover {
	color: var(--crimson-dark);
}

.ag-content__body blockquote {
	border-left: 3px solid var(--crimson);
	padding: var(--space-md) var(--space-xl);
	margin: var(--space-xl) 0;
	background: var(--ivory);
	border-radius: 0 var(--radius) var(--radius) 0;
	font-style: italic;
	color: var(--silver);
}

.ag-content__body table {
	width: 100%;
	border-collapse: collapse;
	margin: var(--space-xl) 0;
}

.ag-content__body th,
.ag-content__body td {
	padding: var(--space-md);
	text-align: left;
	border-bottom: 1px solid var(--border);
}

.ag-content__body th {
	font-weight: 600;
	background: var(--ivory);
}

/* ── Blog Layout (single post) ──────────────────────────────── */

.ag-blog-layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-3xl);
}

@media (min-width: 1024px) {
	.ag-blog-layout {
		grid-template-columns: 1fr 340px;
	}
}

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

.ag-sidebar {
	display: flex;
	flex-direction: column;
	gap: var(--space-xl);
}

.ag-sidebar__card {
	background: var(--navy);
	color: var(--white);
	padding: var(--space-xl);
	border-radius: var(--radius-lg);
}

.ag-sidebar__card-title {
	font-family: var(--font-display);
	font-size: var(--text-xl);
	font-weight: 700;
	margin-bottom: var(--space-md);
	color: var(--white);
}

.ag-sidebar__card-text {
	font-size: var(--text-sm);
	color: var(--silver-light);
	line-height: 1.6;
	margin-bottom: var(--space-lg);
}

.ag-sidebar__card--light {
	background: var(--ivory);
	color: var(--navy);
}

.ag-sidebar__card--light .ag-sidebar__card-title {
	color: var(--navy);
	font-size: var(--text-lg);
}

.ag-sidebar__links {
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
}

.ag-sidebar__links a {
	font-size: var(--text-sm);
	color: var(--navy);
	padding: var(--space-xs) 0;
	border-bottom: 1px solid var(--border);
	transition: color var(--duration) var(--ease);
}

.ag-sidebar__links a:last-child {
	border-bottom: none;
}

.ag-sidebar__links a:hover {
	color: var(--crimson);
}

/* ── Post Meta ──────────────────────────────────────────────── */

.ag-post-meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--space-md);
	font-size: var(--text-sm);
	color: var(--silver);
	margin-bottom: var(--space-xl);
}

.ag-post-meta__date {
	display: flex;
	align-items: center;
	gap: var(--space-xs);
}

.ag-post-meta__category a {
	color: var(--crimson);
	font-weight: 600;
}

/* ── Pagination ─────────────────────────────────────────────── */

.ag-pagination {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: var(--space-sm);
	padding: var(--space-2xl) 0;
}

.ag-pagination a,
.ag-pagination span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 var(--space-sm);
	border-radius: var(--radius);
	font-size: var(--text-sm);
	font-weight: 500;
	transition: background var(--duration) var(--ease);
}

.ag-pagination a:hover {
	background: var(--ivory);
}

.ag-pagination .current {
	background: var(--crimson);
	color: var(--white);
}

/* ── 404 ────────────────────────────────────────────────────── */

.ag-404 {
	text-align: center;
	padding: var(--space-5xl) 0;
}

.ag-404__code {
	font-family: var(--font-display);
	font-size: clamp(6rem, 15vw, 12rem);
	font-weight: 800;
	color: var(--border);
	line-height: 1;
}

.ag-404__title {
	font-size: var(--text-3xl);
	margin-bottom: var(--space-md);
}

.ag-404__text {
	color: var(--silver);
	margin-bottom: var(--space-xl);
}

/* ── Scroll Reveal (JS controlled) ──────────────────────────── */

.ag-reveal {
	opacity: 0;
	transform: translateY(20px);
	transition: opacity 0.6s var(--ease), transform 0.6s var(--ease);
}

.ag-reveal--visible {
	opacity: 1;
	transform: translateY(0);
}

/* ── Difference Section ─────────────────────────────────────── */

.ag-difference__list {
	max-width: 680px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: var(--space-lg);
}

.ag-difference__item {
	display: flex;
	gap: var(--space-md);
	align-items: flex-start;
}

.ag-difference__check {
	flex-shrink: 0;
	width: 24px;
	height: 24px;
	color: var(--crimson);
	margin-top: 2px;
}

.ag-difference__text {
	font-size: var(--text-lg);
	color: var(--silver-light);
	line-height: 1.6;
}

/* ── FluentForm overrides ───────────────────────────────────── */

/* Base form styles (light bg - contact page) */
.fluentform_wrapper {
	font-family: var(--font-body) !important;
}

.fluentform_wrapper .ff-el-group {
	margin-bottom: var(--space-md) !important;
}

.fluentform_wrapper .ff-el-input--label label {
	font-family: var(--font-body) !important;
	font-size: var(--text-sm) !important;
	font-weight: 600 !important;
	color: var(--navy) !important;
	margin-bottom: var(--space-xs) !important;
}

.fluentform_wrapper .ff-el-form-control {
	font-family: var(--font-body) !important;
	font-size: var(--text-base) !important;
	padding: var(--space-sm) var(--space-md) !important;
	border: 1px solid var(--border) !important;
	border-radius: var(--radius) !important;
	background: var(--white) !important;
	color: var(--navy-text) !important;
	transition: border-color 0.2s ease !important;
}

.fluentform_wrapper .ff-el-form-control:focus {
	border-color: var(--crimson) !important;
	outline: none !important;
	box-shadow: 0 0 0 3px rgba(203, 1, 61, 0.1) !important;
}

.fluentform_wrapper .ff-el-form-control::placeholder {
	color: var(--silver) !important;
}

.fluentform_wrapper textarea.ff-el-form-control {
	resize: vertical !important;
	min-height: 100px !important;
}

/* Name fields side by side */
.fluentform_wrapper .ff-t-container {
	display: flex !important;
	gap: var(--space-md) !important;
}

.fluentform_wrapper .ff-t-cell {
	flex: 1 !important;
}

/* Override Fluent Forms default blue */
:root {
	--fluentform-primary: #CB013D !important;
}

/* Submit button - max specificity to beat FF inline styles */
.fluentform_wrapper .ff-btn-submit,
.fluentform_wrapper .ff-btn-submit.ff_btn_style,
.fluentform_wrapper .ff_submit_btn_wrapper .ff-btn-submit:not(.ff_btn_no_style),
.ffs_custom_wrap .ff_submit_btn_wrapper .ff-btn-submit:not(.ff_btn_no_style),
form.fluent_form_4 .ff-btn-submit:not(.ff_btn_no_style) {
	font-family: var(--font-body) !important;
	font-size: var(--text-base) !important;
	font-weight: 600 !important;
	background: #CB013D !important;
	background-color: #CB013D !important;
	color: #ffffff !important;
	border: 2px solid #CB013D !important;
	padding: var(--space-md) var(--space-2xl) !important;
	border-radius: var(--radius) !important;
	cursor: pointer !important;
	transition: background 0.2s ease, color 0.2s ease !important;
	width: auto !important;
}

.fluentform_wrapper .ff-btn-submit:hover,
.fluentform_wrapper .ff-btn-submit.ff_btn_style:hover,
form.fluent_form_4 .ff-btn-submit:hover {
	background: transparent !important;
	background-color: transparent !important;
	color: #CB013D !important;
}

/* Custom HTML blocks within form */
.fluentform_wrapper .ff-custom_html h4,
.fluentform_wrapper .ff-custom_html h5 {
	font-family: var(--font-display) !important;
	line-height: 1.3 !important;
}

.fluentform_wrapper .ff-custom_html p {
	font-size: var(--text-base) !important;
	line-height: 1.6 !important;
}

/* Required asterisk */
.fluentform_wrapper .ff-el-is-required.asterisk-right label::after {
	color: var(--crimson) !important;
}

/* Error messages */
.fluentform_wrapper .error.text-danger {
	color: var(--crimson) !important;
	font-size: var(--text-sm) !important;
	margin-top: var(--space-xs) !important;
}

/* Success message */
.fluentform_wrapper .ff-message-success {
	background: rgba(16, 185, 129, 0.1) !important;
	border: 1px solid rgba(16, 185, 129, 0.3) !important;
	color: #065f46 !important;
	padding: var(--space-lg) !important;
	border-radius: var(--radius) !important;
	font-size: var(--text-base) !important;
}

/* Date picker */
.fluentform_wrapper .flatpickr-input {
	cursor: pointer !important;
}

/* Dark bg overrides (pre-footer) */
.ag-pre-footer .ff-el-input--label label {
	color: var(--silver-light) !important;
}

.ag-pre-footer .ff-el-form-control {
	background: rgba(255, 255, 255, 0.08) !important;
	border-color: rgba(255, 255, 255, 0.15) !important;
	color: var(--white) !important;
}

.ag-pre-footer .ff-el-form-control::placeholder {
	color: rgba(255, 255, 255, 0.4) !important;
}

.ag-pre-footer .ff-el-form-control:focus {
	border-color: var(--crimson) !important;
	box-shadow: 0 0 0 3px rgba(203, 1, 61, 0.2) !important;
}

.ag-pre-footer .ff-btn-submit {
	background: var(--crimson) !important;
	border-color: var(--crimson) !important;
}

.ag-pre-footer .ff-btn-submit:hover {
	background: transparent !important;
	border-color: var(--white) !important;
	color: var(--white) !important;
}

.ag-pre-footer .ff-custom_html h4 span,
.ag-pre-footer .ff-custom_html h5 span,
.ag-pre-footer .ff-custom_html p span {
	color: var(--white) !important;
}

.ag-pre-footer .ff-message-success {
	background: rgba(16, 185, 129, 0.15) !important;
	border-color: rgba(16, 185, 129, 0.3) !important;
	color: #d1fae5 !important;
}

/* ── Dark-on-Dark Contrast Safety Net ───────────────────────── */

.ag-section--navy h1,
.ag-section--navy h2,
.ag-section--navy h3,
.ag-section--navy h4,
.ag-section--navy h5,
.ag-section--navy h6,
.ag-hero h1,
.ag-hero h2,
.ag-hero-banner h1,
.ag-hero-banner h2,
.ag-pre-footer h1,
.ag-pre-footer h2,
.ag-pre-footer h3,
.ag-footer h1,
.ag-footer h2,
.ag-footer h3,
.ag-footer h4,
.ag-sidebar__card h3,
.ag-sidebar__card h4,
.ag-mobile-overlay h1,
.ag-mobile-overlay h2,
.ag-mobile-overlay h3 {
	color: var(--white);
}

.ag-section--navy p,
.ag-section--navy li,
.ag-pre-footer p,
.ag-pre-footer li,
.ag-footer p,
.ag-footer li {
	color: var(--silver-light);
}

.ag-section--navy a:not(.ag-btn),
.ag-pre-footer a:not(.ag-btn),
.ag-footer a:not(.ag-btn) {
	color: var(--silver-light);
}

.ag-section--navy a:not(.ag-btn):hover,
.ag-pre-footer a:not(.ag-btn):hover,
.ag-footer a:not(.ag-btn):hover {
	color: var(--white);
}

/* ============================================================
   GOOGLE REVIEWS CAROUSEL
   ============================================================ */
.ag-reviews__badge {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.375rem 1rem;
	background: var(--white);
	border: 1px solid #D4A017;
	border-radius: 9999px;
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--navy-text);
	margin-bottom: var(--space-md);
}
.ag-reviews__badge-stars {
	color: #D4A017;
	font-size: 0.875rem;
	letter-spacing: 1px;
}

.ag-reviews__carousel {
	position: relative;
	display: flex;
	align-items: center;
	gap: var(--space-md);
}
.ag-reviews__track {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-lg);
	flex: 1;
	min-width: 0;
}

.ag-reviews__arrow {
	flex-shrink: 0;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	border: 1px solid var(--border);
	background: var(--white);
	color: var(--navy-text);
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: all 0.2s;
}
.ag-reviews__arrow:hover {
	border-color: var(--crimson);
	color: var(--crimson);
}

.ag-review-card {
	padding: var(--space-lg);
	border-radius: var(--radius);
	border: 1px solid var(--border);
	background: var(--white);
	transition: box-shadow 0.3s;
}
.ag-review-card:hover {
	box-shadow: 0 4px 20px rgba(15, 15, 48, 0.08);
}
.ag-review-card__stars {
	color: #D4A017;
	font-size: 0.875rem;
	letter-spacing: 1px;
	margin-bottom: var(--space-sm);
}
.ag-review-card__text {
	font-size: 0.9375rem;
	color: var(--silver);
	line-height: 1.6;
	margin-bottom: var(--space-md);
}
.ag-review-card__author {
	display: flex;
	align-items: center;
	gap: 0.75rem;
}
.ag-review-card__avatar {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: var(--ivory);
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	font-size: 0.875rem;
	color: var(--crimson);
	flex-shrink: 0;
}
.ag-review-card__avatar-img {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	object-fit: cover;
	flex-shrink: 0;
}
.ag-review-card__name {
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--navy-text);
}
.ag-review-card__date {
	font-size: 0.75rem;
	color: var(--silver);
}
.ag-review-card__source {
	display: flex;
	align-items: center;
	gap: 0.375rem;
	font-size: 0.6875rem;
	color: var(--silver);
	margin-top: 0.125rem;
}

.ag-reviews__dots {
	display: flex;
	justify-content: center;
	gap: 0.5rem;
	margin-top: var(--space-lg);
}
.ag-reviews__dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	border: 1px solid var(--border);
	background: transparent;
	cursor: pointer;
	padding: 0;
	transition: all 0.2s;
}
.ag-reviews__dot.active {
	background: var(--crimson);
	border-color: var(--crimson);
}
.ag-reviews__dot:hover {
	border-color: var(--crimson);
}

.ag-reviews__footer {
	text-align: center;
	margin-top: var(--space-lg);
}
.ag-reviews__read-all {
	font-size: 0.9375rem;
	font-weight: 600;
	color: var(--crimson);
}
.ag-reviews__read-all:hover {
	color: var(--navy);
}

@media (max-width: 768px) {
	.ag-reviews__track {
		grid-template-columns: 1fr;
	}
	.ag-reviews__arrow {
		display: none;
	}
	.ag-reviews__carousel {
		gap: 0;
	}
}

/* ── Team Card ─────────────────────────────────────────────── */

.ag-team-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	background: var(--white);
	border-radius: var(--radius-lg);
	padding: var(--space-2xl) var(--space-xl);
	border: 1px solid var(--border);
	transition: transform var(--duration) var(--ease), box-shadow var(--duration) var(--ease);
}

.ag-team-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.08);
}

.ag-team-card__avatar {
	width: 80px;
	height: 80px;
	border-radius: 50%;
	background: var(--navy);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: var(--space-md);
}

.ag-team-card__initials {
	font-family: var(--font-display);
	font-size: var(--text-xl);
	font-weight: 700;
	color: var(--white);
	letter-spacing: 0.02em;
}

.ag-team-card__name {
	font-family: var(--font-display);
	font-size: var(--text-lg);
	font-weight: 700;
	color: var(--navy);
	margin-bottom: var(--space-2xs);
}

.ag-team-card__role {
	font-size: var(--text-sm);
	font-weight: 600;
	color: var(--crimson);
	margin-bottom: var(--space-sm);
}

.ag-team-card__quals {
	font-weight: 400;
	color: var(--silver);
}

.ag-team-card__quals::before {
	content: " · ";
}

.ag-team-card__bio {
	font-size: var(--text-sm);
	color: var(--silver);
	line-height: 1.6;
}

/* ── Mobile Overlay ─────────────────────────────────────────── */

.ag-mobile-overlay {
	position: fixed;
	inset: 0;
	z-index: 2000;
	background: var(--navy);
	color: var(--white);
	overflow-y: auto;
	overflow-x: hidden;
	transform: translateX(100%);
	transition: transform var(--duration) var(--ease);
}

.ag-mobile-overlay[data-open="true"] {
	transform: translateX(0);
}

.ag-mobile-overlay__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--space-md) var(--gutter);
}

.ag-mobile-overlay__brand {
	font-family: var(--font-display);
	font-weight: 800;
	font-size: var(--text-xl);
}

.ag-mobile-overlay__logo {
	height: 36px;
	width: auto;
	filter: brightness(0) invert(1);
}

.ag-mobile-overlay__close {
	color: var(--white);
	padding: var(--space-xs);
}

.ag-mobile-overlay__nav {
	padding: var(--space-xl) var(--gutter);
}

.ag-mobile-overlay__menu {
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
}

.ag-mobile-overlay__menu > li > a,
.ag-mobile-overlay__accordion {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	padding: var(--space-md) 0;
	font-size: var(--text-lg);
	font-weight: 500;
	color: var(--white);
	border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.ag-mobile-overlay__chevron {
	transition: transform var(--duration) var(--ease);
}

.ag-mobile-overlay__accordion[aria-expanded="true"] .ag-mobile-overlay__chevron {
	transform: rotate(180deg);
}

.ag-mobile-overlay__sub {
	padding: var(--space-sm) 0 var(--space-md) var(--space-md);
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
}

.ag-mobile-overlay__sub a {
	display: block;
	padding: var(--space-sm) 0;
	font-size: var(--text-base);
	color: var(--silver-light);
	transition: color var(--duration) var(--ease);
}

.ag-mobile-overlay__sub a:hover {
	color: var(--white);
}

.ag-mobile-overlay__footer {
	padding: var(--space-xl) var(--gutter);
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

.ag-mobile-overlay__phone {
	font-size: var(--text-lg);
	color: var(--white);
	opacity: 0.9;
}

.ag-mobile-overlay__cta {
	display: inline-flex;
	justify-content: center;
	padding: var(--space-md) var(--space-xl);
	background: var(--crimson);
	color: var(--white);
	font-weight: 600;
	border-radius: var(--radius);
	text-align: center;
}

/* ── Keyboard Focus Indicators ─────────────────────────────── */

a:focus-visible,
button:focus-visible,
.ag-btn:focus-visible,
[role="button"]:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
	outline: 2px solid var(--crimson);
	outline-offset: 2px;
}

.ag-navbar__link:focus-visible {
	outline: 2px solid var(--crimson);
	outline-offset: 4px;
}

.ag-section--navy a:focus-visible,
.ag-section--navy button:focus-visible,
.ag-footer a:focus-visible,
.ag-pre-footer a:focus-visible,
.ag-mobile-overlay a:focus-visible,
.ag-mobile-overlay button:focus-visible {
	outline-color: var(--white);
}

.home .ag-header:not(.ag-header--scrolled) a:focus-visible,
.home .ag-header:not(.ag-header--scrolled) button:focus-visible {
	outline-color: var(--white);
}

/* ── Screen Reader Only ────────────────────────────────────── */

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

/* ── Search Form ───────────────────────────────────────────── */

.ag-search-form {
	display: flex;
	gap: var(--space-md);
	max-width: 600px;
	margin: 0 auto var(--space-2xl);
}

.ag-search-form__input {
	flex: 1;
	padding: var(--space-md) var(--space-lg);
	font-size: var(--text-base);
	font-family: var(--font-body);
	border: 1px solid var(--border);
	border-radius: var(--radius);
	color: var(--navy-text);
	background: var(--white);
}

.ag-search-form__input::placeholder {
	color: var(--silver);
}
