/**
 * Service Areas archive (and city taxonomy archive).
 *
 * Scoped under .site-main--areas. .page-hero-*, .breadcrumb-*,
 * .cta-section come from global.css.
 */

/* =============================================================
   ARCHIVE INTRO
   ============================================================= */
.ar-intro {
	max-width: 1440px;
	margin: 100px auto 0;
	padding: 0 100px;
}
.ar-intro-inner {
	max-width: 880px;
	margin: 0 auto;
	text-align: center;
}
.ar-intro-title {
	font-size: 32px;
	line-height: 40px;
	font-weight: var(--fw-semibold);
	color: var(--color-blue-4);
}
.ar-intro-body {
	margin-top: 16px;
	font-size: 18px;
	line-height: 28px;
	color: var(--color-grey-7);
}
.ar-intro-body p + p { margin-top: 14px; }


/* =============================================================
   ARCHIVE MAP
   ============================================================= */
.ar-map {
	max-width: 1440px;
	margin: 100px auto 0;
	padding: 0 100px;
}
.ar-map-inner {
	background: var(--color-grey-0);
	border-radius: var(--radius-xl);
	overflow: hidden;
	border: 1px solid var(--color-grey-2);
	box-shadow: 0 4px 20px rgba(11,69,128,.05);
}
.ar-map-header {
	padding: 32px 36px 20px;
	text-align: center;
}
.ar-map-title {
	font-size: 28px;
	line-height: 36px;
	font-weight: var(--fw-semibold);
	color: var(--color-blue-4);
}
.ar-map-sub {
	margin-top: 8px;
	font-size: 16px;
	line-height: 24px;
	color: var(--color-grey-7);
}
.ar-map-frame {
	width: 100%;
	height: 420px;
	background: var(--color-grey-2);
}
.ar-map-frame iframe { display: block; }


/* =============================================================
   ARCHIVE — CITY CARDS
   ============================================================= */
.ar-cities {
	max-width: 1440px;
	margin: 100px auto 0;
	padding: 0 100px;
}
.ar-cities-header { text-align: center; margin-bottom: 36px; }
.ar-cities-title {
	font-size: 32px;
	line-height: 40px;
	font-weight: var(--fw-semibold);
	color: var(--color-blue-4);
}
.ar-cities-sub {
	margin-top: 12px;
	font-size: 18px;
	line-height: 26px;
	color: var(--color-grey-7);
}
.ar-cities-grid {
	list-style: none;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
}
.ar-city-card {
	background: var(--color-grey-0);
	border-radius: var(--radius-xl);
	overflow: hidden;
	border: 1px solid var(--color-grey-2);
	box-shadow: 0 4px 12px rgba(0,0,0,.04);
	display: flex;
	flex-direction: column;
	transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}
.ar-city-card:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 22px rgba(11,69,128,.10);
}
.ar-city-img {
	width: 100%;
	height: 220px;
	background: var(--color-grey-2);
	overflow: hidden;
}
.ar-city-img img { width: 100%; height: 100%; object-fit: cover; }
.ar-city-img-placeholder {
	width: 100%;
	height: 100%;
	background: linear-gradient(135deg, var(--color-primary-blue), var(--color-blue-1));
}
.ar-city-body { padding: 24px; display: flex; flex-direction: column; gap: 12px; flex: 1; }
.ar-city-name {
	font-size: 24px;
	line-height: 30px;
	font-weight: var(--fw-semibold);
	color: var(--color-blue-4);
}
.ar-city-desc {
	font-size: 15px;
	line-height: 22px;
	color: var(--color-grey-7);
}
.ar-city-info {
	display: flex;
	flex-direction: column;
	gap: 8px;
	margin-top: 4px;
}
.ar-city-info-item {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 15px;
	line-height: 22px;
	color: var(--color-primary-blue);
}
.ar-city-info-item svg { width: 18px; height: 18px; flex-shrink: 0; }
.ar-city-link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 16px;
	line-height: 1;
	font-weight: var(--fw-semibold);
	color: var(--color-primary-blue);
	padding: 10px 0 0;
	margin-top: auto;
	text-decoration: none;
	transition: color var(--transition-fast);
}
.ar-city-link:hover { color: var(--color-blue-n3); }
.ar-city-link svg { width: 18px; height: 18px; }


/* =============================================================
   CITY ARCHIVE (taxonomy-service_area_city.php)
   ============================================================= */
.ar-city-hero-badges {
	display: flex;
	gap: 8px;
	justify-content: center;
	margin-top: 16px;
	flex-wrap: wrap;
}
.ar-city-hero-badge {
	display: inline-flex;
	align-items: center;
	padding: 8px 16px;
	border-radius: var(--radius-full);
	background: rgba(255,255,255,.18);
	border: 1px solid rgba(255,255,255,.32);
	color: var(--color-grey-0);
	font-size: 15px;
	font-weight: var(--fw-medium);
}

.arc-intro {
	max-width: 1440px;
	margin: 80px auto 0;
	padding: 0 100px;
}
.arc-intro-inner {
	max-width: 880px;
	margin: 0 auto;
	text-align: center;
}
.arc-intro-title {
	font-size: 28px;
	line-height: 36px;
	font-weight: var(--fw-semibold);
	color: var(--color-blue-4);
}
.arc-intro-body {
	margin-top: 16px;
	font-size: 17px;
	line-height: 26px;
	color: var(--color-grey-7);
}
.arc-intro-body p + p { margin-top: 12px; }
.arc-intro-line {
	margin-top: 18px;
	font-size: 16px;
	line-height: 24px;
	color: var(--color-grey-9);
	padding: 12px 20px;
	background: rgba(0,176,161,.08);
	border-radius: var(--radius-lg);
	display: inline-block;
}

.arc-services {
	max-width: 1440px;
	margin: 80px auto 0;
	padding: 0 100px;
}
.arc-services-header { text-align: center; margin-bottom: 32px; }
.arc-services-title {
	font-size: 28px;
	line-height: 36px;
	font-weight: var(--fw-semibold);
	color: var(--color-blue-4);
}
.arc-services-sub {
	max-width: 720px;
	margin: 12px auto 0;
	font-size: 17px;
	line-height: 26px;
	color: var(--color-grey-7);
}
.arc-local-services {
	list-style: none;
	padding: 0;
	margin: 0 0 28px;
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 12px;
}
.arc-local-services a {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 56px;
	padding: 12px 14px;
	border-radius: var(--radius-lg);
	background: var(--color-grey-0);
	border: 1px solid var(--color-grey-2);
	color: var(--color-primary-blue);
	font-size: 15px;
	line-height: 21px;
	font-weight: var(--fw-semibold);
	text-align: center;
	text-decoration: none;
	transition: border-color var(--transition-fast), background var(--transition-fast), transform var(--transition-fast);
}
.arc-local-services a:hover {
	border-color: var(--color-primary-blue);
	background: var(--color-blue-n11);
	transform: translateY(-1px);
}
.arc-services-grid {
	list-style: none;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
}
.arc-svc-card {
	background: var(--color-grey-0);
	border-radius: var(--radius-xl);
	overflow: hidden;
	border: 1px solid var(--color-grey-2);
	box-shadow: 0 4px 12px rgba(0,0,0,.04);
	transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}
.arc-svc-card:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 20px rgba(11,69,128,.10);
}
.arc-svc-link { color: inherit; text-decoration: none; display: block; }
.arc-svc-img { width: 100%; height: 200px; background: var(--color-grey-2); overflow: hidden; }
.arc-svc-img img { width: 100%; height: 100%; object-fit: cover; }
.arc-svc-body { padding: 20px 24px; display: flex; flex-direction: column; gap: 8px; }
.arc-svc-tag {
	display: inline-block;
	font-size: 13px;
	font-weight: var(--fw-semibold);
	color: var(--color-primary-green);
	text-transform: uppercase;
	letter-spacing: .5px;
}
.arc-svc-name {
	font-size: 20px;
	line-height: 26px;
	font-weight: var(--fw-semibold);
	color: var(--color-blue-4);
}
.arc-svc-excerpt {
	font-size: 15px;
	line-height: 22px;
	color: var(--color-grey-7);
}
.arc-svc-cta {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin-top: 6px;
	font-size: 15px;
	line-height: 1;
	font-weight: var(--fw-semibold);
	color: var(--color-primary-blue);
	text-decoration: none;
}
.arc-svc-cta svg { width: 16px; height: 16px; }
.arc-svc-cta--solid {
	background: var(--color-primary-blue);
	color: var(--color-grey-0);
	padding: 12px 20px;
	border-radius: var(--radius-xl);
}
.arc-svc-cta--solid:hover { background: var(--color-blue-n3); }
.arc-services-empty {
	background: var(--color-grey-0);
	border: 1px dashed var(--color-grey-3);
	border-radius: var(--radius-xl);
	padding: 36px;
	text-align: center;
	color: var(--color-grey-7);
}
.arc-services-empty p { font-size: 17px; line-height: 26px; margin-bottom: 20px; }
.arc-services-empty-actions {
	display: flex;
	gap: 12px;
	justify-content: center;
	flex-wrap: wrap;
}

.arc-map {
	max-width: 1440px;
	margin: 80px auto 0;
	padding: 0 100px;
}
.arc-map-inner {
	background: var(--color-grey-0);
	border-radius: var(--radius-xl);
	overflow: hidden;
	border: 1px solid var(--color-grey-2);
	box-shadow: 0 4px 16px rgba(11,69,128,.05);
}
.arc-map-header { padding: 28px 32px 20px; text-align: center; }
.arc-map-title {
	font-size: 24px;
	line-height: 32px;
	font-weight: var(--fw-semibold);
	color: var(--color-blue-4);
}
.arc-map-sub { margin-top: 8px; font-size: 16px; line-height: 24px; color: var(--color-grey-7); }
.arc-map-frame { width: 100%; height: 360px; background: var(--color-grey-2); }
.arc-map-frame iframe { display: block; }
.arc-map-actions {
	display: flex;
	gap: 12px;
	justify-content: center;
	flex-wrap: wrap;
	padding: 20px 32px 28px;
}


/* =============================================================
   RESPONSIVE
   ============================================================= */
@media (max-width: 1279px) {
	.ar-intro,
	.ar-map,
	.ar-cities,
	.arc-intro,
	.arc-services,
	.arc-map { padding: 0 32px; }
}

@media (max-width: 991px) {
	.ar-intro,
	.ar-map,
	.ar-cities,
	.arc-intro,
	.arc-services,
	.arc-map {
		padding: 0 16px;
		margin-top: 72px;
	}
	.ar-intro-title,
	.ar-cities-title { font-size: 24px; line-height: 32px; }
	.ar-intro-body,
	.ar-cities-sub { font-size: 16px; line-height: 24px; }
	.ar-cities-grid { grid-template-columns: 1fr 1fr; gap: 16px; }
	.ar-city-name { font-size: 20px; line-height: 26px; }
	.ar-city-info-item { font-size: 14px; line-height: 20px; }
	.ar-map-frame { height: 340px; }
	.ar-map-title { font-size: 22px; line-height: 30px; }

	.arc-services-grid { grid-template-columns: 1fr; gap: 16px; }
	.arc-local-services { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.arc-intro-title { font-size: 22px; line-height: 30px; }
	.arc-map-frame { height: 320px; }
}

@media (max-width: 575px) {
	.ar-intro,
	.ar-map,
	.ar-cities,
	.arc-intro,
	.arc-services,
	.arc-map { padding: 0 12px; }
	.ar-cities-grid { grid-template-columns: 1fr; }
	.arc-local-services { grid-template-columns: 1fr; }
	.ar-city-img { height: 180px; }
}
