/* Service Center Directory Pro — minimal responsive layout */
.scd-wrap {
	max-width: 960px;
	margin: 0 auto;
	padding: 1rem 1.25rem 3rem;
	font-family: system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
	line-height: 1.5;
	color: #1a1a1a;
}

.scd-header .scd-h1 {
	font-size: clamp(1.35rem, 2.5vw, 1.75rem);
	margin: 0 0 0.5rem;
}

.scd-intro {
	margin: 0 0 1.25rem;
	color: #444;
}

.scd-filters {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
	gap: 0.75rem;
	align-items: end;
	margin-bottom: 1rem;
	padding: 1rem;
	background: #f6f7f9;
	border-radius: 8px;
}

.scd-field span {
	display: block;
	font-size: 0.8rem;
	font-weight: 600;
	margin-bottom: 0.25rem;
}

.scd-field select,
.scd-field input[type="search"] {
	width: 100%;
	padding: 0.45rem 0.5rem;
	border: 1px solid #ccc;
	border-radius: 6px;
	font: inherit;
}

.scd-btn {
	padding: 0.55rem 1rem;
	border: 0;
	border-radius: 6px;
	background: #1e3a5f;
	color: #fff;
	font-weight: 600;
	cursor: pointer;
}

.scd-count {
	font-size: 0.95rem;
	color: #555;
}

.scd-list {
	list-style: none;
	margin: 1rem 0 0;
	padding: 0;
	display: grid;
	gap: 1rem;
}

.scd-card {
	display: grid;
	grid-template-columns: 150px minmax(0, 1fr);
	gap: 1rem 1.25rem;
	align-items: start;
	border: 1px solid #e2e4e8;
	border-radius: 8px;
	padding: 1rem;
	background: #fff;
}

.scd-card__media {
	flex-shrink: 0;
	width: 150px;
	min-width: 0;
}

.scd-card__thumb {
	display: block;
	line-height: 0;
	width: 150px;
	height: 150px;
	overflow: hidden;
	border-radius: 8px;
	border: 1px solid #e2e4e8;
}

.scd-card__thumb .scd-card__img {
	display: block;
	width: 150px;
	height: 150px;
	object-fit: cover;
}

.scd-card__placeholder {
	width: 150px;
	height: 150px;
	flex-shrink: 0;
	border-radius: 8px;
	background: linear-gradient(145deg, #eef1f5, #e2e6ec);
	border: 1px dashed #cfd6df;
}

.scd-card__body {
	min-width: 0;
}

.scd-card__headline {
	margin: 0 0 0.35rem;
	font-size: clamp(0.95rem, 2vw, 1.05rem);
	line-height: 1.35;
	color: #111;
}

.scd-card__headline strong {
	font-weight: 700;
}

.scd-card__title-link {
	color: inherit;
	text-decoration: none;
}

.scd-card__title-link:hover {
	text-decoration: underline;
	color: #0b57d0;
}

.scd-card__title-link:focus-visible {
	outline: 2px solid #0b57d0;
	outline-offset: 2px;
	border-radius: 2px;
}

.scd-card__badges {
	display: flex;
	flex-wrap: wrap;
	gap: 0.35rem;
	margin: 0 0 0.5rem;
}

.scd-card__badge {
	display: inline-block;
	font-size: 0.68rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	padding: 0.25rem 0.55rem;
	border-radius: 4px;
	line-height: 1.2;
}

.scd-card__badge--official {
	background: #e8f5e9;
	color: #1b5e20;
	border: 1px solid #a5d6a7;
}

.scd-card__badge--third-party {
	background: #fff3e0;
	color: #bf360c;
	border: 1px solid #ffcc80;
}

.scd-card__meta {
	margin: 0 0 0.5rem;
	color: #555;
	font-size: 0.9rem;
}

.scd-card__addr {
	margin: 0 0 0.5rem;
	color: #333;
	font-size: 0.95rem;
}

.scd-card__more {
	margin: 0.75rem 0 0;
	max-width: 50%;
}

.scd-card__more-link {
	display: inline-block;
	font-weight: 600;
	font-size: 0.95rem;
	color: #0b57d0;
	text-decoration: none;
	border-bottom: 1px solid transparent;
}

.scd-card__more-link:hover,
.scd-card__more-link:focus {
	text-decoration: none;
	border-bottom-color: #0b57d0;
}

@media (max-width: 640px) {
	.scd-wrap {
		padding-top: 0.75rem;
		padding-bottom: 2rem;
		padding-left: max(0.5rem, env(safe-area-inset-left, 0px));
		padding-right: max(0.5rem, env(safe-area-inset-right, 0px));
	}

	.scd-filters {
		padding: 0.65rem 0.55rem;
		gap: 0.6rem;
	}

	.scd-browse-nav {
		padding: 0.7rem 0.55rem;
	}

	.scd-card {
		grid-template-columns: 1fr;
		padding: 0.75rem 0.6rem;
		gap: 0.75rem;
	}

	.scd-card__media {
		width: 100%;
		max-width: 150px;
	}

	.scd-card__thumb,
	.scd-card__placeholder {
		width: 150px;
		height: 150px;
	}

	.scd-card__more {
		max-width: 100%;
	}

	.scd-breadcrumbs__list {
		padding: 0.45rem 0.55rem;
		border-radius: 8px;
	}

	.scd-count--brand-city {
		padding: 0.65rem 0.55rem;
	}

	.scd-related--brand-city {
		padding: 0.85rem 0.6rem;
		border-radius: 10px;
	}

	.scd-brand-city__prose {
		padding: 0.85rem 0.6rem;
		border-radius: 10px;
	}

	.scd-brand-city__meta-list {
		padding: 0.75rem 0.55rem;
	}

	.scd-brand-city__bullets {
		padding-left: 1.05rem;
	}

	.scd-brand-country-states__list {
		grid-template-columns: 1fr;
	}

	.scd-brand-city__disclaimer {
		padding: 0.75rem 0.55rem;
		border-radius: 8px;
	}

	.scd-brand-city__filters {
		padding: 0.85rem 0.6rem;
		border-radius: 10px;
	}

	.scd-single__table th,
	.scd-single__table td {
		padding: 0.55rem 0.5rem;
	}

	.scd-single__disclaimer {
		padding: 0.75rem 0.55rem;
		border-radius: 8px;
	}

	.scd-single__cat-list {
		padding-left: 1.05rem;
	}

	.scd-feedback-cta {
		padding: 0.75rem 0.6rem;
	}

	.scd-comments__item {
		padding: 0.75rem 0.55rem;
	}

	.scd-captcha {
		padding: 0.75rem 0.55rem;
	}

	.scd-related__list {
		padding-left: 1rem;
	}
}

/* Single hero image: flex keeps centre even when prose uses text-align: justify */
.scd-brand-city__prose > .scd-single__figure {
	display: flex;
	flex-direction: column;
	align-items: center;
	width: 100%;
	margin: 0 auto 1.25rem;
	text-align: center;
}

.scd-single__figure {
	margin: 0 auto 1.25rem;
	text-align: center;
}

.scd-single__image {
	margin: 0;
	display: block;
	line-height: 0;
}

.scd-single__img {
	width: 300px;
	max-width: min(300px, 100%);
	height: auto;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	border-radius: 8px;
	border: 1px solid #e2e4e8;
	display: block;
	box-sizing: border-box;
	margin: 0 auto;
	flex-shrink: 0;
}

.scd-single__hours {
	white-space: normal;
	line-height: 1.55;
}

.scd-pagination {
	margin: 1.5rem 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.35rem;
}

.scd-page {
	display: inline-block;
	padding: 0.35rem 0.65rem;
	border-radius: 6px;
	border: 1px solid #ccc;
	text-decoration: none;
	color: #1a1a1a;
}

.scd-page.is-current {
	background: #1e3a5f;
	color: #fff;
	border-color: #1e3a5f;
}

.scd-page.scd-page--gap {
	border: none;
	background: transparent;
	padding: 0.35rem 0.2rem;
	color: #5f6368;
	pointer-events: none;
}

.scd-related__list--three {
	grid-template-columns: repeat(3, 1fr);
}

@media (max-width: 900px) {
	.scd-related__list--three {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 520px) {
	.scd-related__list--three {
		grid-template-columns: 1fr;
	}
}

.scd-hub-link__anchor {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0.2rem;
	padding: 0.45rem 0;
	text-decoration: none;
	color: inherit;
}

.scd-hub-link__name {
	font-weight: 600;
	color: #0b57d0;
	font-size: 0.98rem;
}

.scd-hub-link__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 0.25rem 0.4rem;
}

.scd-hub-link__num {
	font-size: 1.08rem;
	font-weight: 800;
	color: #0b57d0;
	letter-spacing: -0.02em;
}

.scd-hub-link__count {
	font-size: 0.82rem;
	font-weight: 500;
	color: #3c4043;
	line-height: 1.35;
}

.scd-hub-link__anchor:hover .scd-hub-link__name,
.scd-hub-link__anchor:focus .scd-hub-link__name {
	text-decoration: underline;
}

.scd-related {
	margin-top: 2rem;
	padding-top: 1rem;
	border-top: 1px solid #e2e4e8;
}

.scd-related__title {
	font-size: 1.1rem;
	margin: 0 0 0.5rem;
}

.scd-related__list {
	margin: 0;
	padding-left: 1.1rem;
}

.scd-dl {
	display: grid;
	grid-template-columns: 140px 1fr;
	gap: 0.5rem 1rem;
	margin: 1rem 0;
}

.scd-dl dt {
	font-weight: 600;
	margin: 0;
}

.scd-dl dd {
	margin: 0;
}

.scd-back a {
	color: #0b57d0;
}

/* Hub / browse */
.scd-browse-nav {
	margin-bottom: 1.5rem;
	padding: 1rem;
	background: #f0f4fa;
	border-radius: 8px;
	border: 1px solid #e2e4e8;
}

.scd-browse-nav__title {
	margin: 0 0 0.75rem;
	font-size: 1rem;
}

.scd-browse-nav__grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 1rem;
}

.scd-browse-nav__grid a {
	font-weight: 600;
	text-decoration: none;
	color: #1e3a5f;
}

.scd-browse-nav__grid a:hover {
	text-decoration: underline;
}

.scd-browse-nav__hint {
	margin: 0.75rem 0 0;
	font-size: 0.9rem;
	color: #555;
}

.scd-pill-list {
	list-style: none;
	margin: 1rem 0 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.scd-pill-list li a {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	padding: 0.4rem 0.85rem;
	background: #fff;
	border: 1px solid #cfd6e6;
	border-radius: 999px;
	text-decoration: none;
	color: #1a1a1a;
	font-size: 0.95rem;
}

.scd-pill-list li a .scd-flag-pill {
	width: 1.2rem;
	height: 0.85rem;
	object-fit: cover;
	border-radius: 2px;
	flex-shrink: 0;
	box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.08);
}

.scd-pill-list li a:hover {
	border-color: #1e3a5f;
	color: #1e3a5f;
}

.scd-hub-links {
	list-style: none;
	margin: 1rem 0 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
}

.scd-btn--large {
	display: inline-block;
	padding: 0.65rem 1.25rem;
}

.scd-breadcrumb {
	font-size: 0.95rem;
	color: #444;
	margin: 0 0 1rem;
}

.scd-breadcrumb a {
	color: #0b57d0;
	text-decoration: none;
}

.scd-theme-wrap {
	max-width: 100%;
}

.scd-badges {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin: 0 0 0.75rem;
}

.scd-badge {
	display: inline-block;
	padding: 0.2rem 0.55rem;
	font-size: 0.75rem;
	font-weight: 600;
	border-radius: 4px;
	background: #e8eaed;
	color: #333;
}

.scd-badge--official {
	background: #e8f5e9;
	color: #1b5e20;
}

.scd-badge--third-party {
	background: #fff3e0;
	color: #e65100;
}

.scd-badge--service-centre {
	background: #e3f2fd;
	color: #0d47a1;
}

.scd-badge--store {
	background: #f3e5f5;
	color: #4a148c;
}

/* Brand + city archive: breadcrumbs + long-form */
.scd-breadcrumbs {
	margin: 0 0 1.5rem;
	font-size: 0.875rem;
	color: #3c4043;
}

.scd-breadcrumbs__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.35rem 0.25rem;
	list-style: none;
	margin: 0;
	padding: 0.55rem 0.85rem;
	background: linear-gradient(180deg, #f8f9fb 0%, #f1f3f6 100%);
	border: 1px solid #e1e4e8;
	border-radius: 10px;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}

.scd-breadcrumbs__item {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	line-height: 1.35;
}

.scd-breadcrumbs__item + .scd-breadcrumbs__item::before {
	content: '';
	display: inline-block;
	width: 0.35rem;
	height: 0.35rem;
	border-right: 2px solid #9aa0a6;
	border-bottom: 2px solid #9aa0a6;
	transform: rotate(-45deg);
	margin-right: 0.4rem;
	margin-left: 0.1rem;
	vertical-align: middle;
	opacity: 0.85;
}

.scd-breadcrumbs__item a {
	color: #0b57d0;
	text-decoration: none;
	font-weight: 500;
}

.scd-breadcrumbs__item a:hover {
	text-decoration: underline;
	color: #0842a0;
}

.scd-breadcrumbs__item a:focus-visible {
	outline: 2px solid #0b57d0;
	outline-offset: 2px;
	border-radius: 2px;
}

.scd-breadcrumbs__current {
	font-weight: 700;
	color: #0d0d0d;
}

.scd-count--brand-city {
	margin: 0.75rem 0 1rem;
	padding: 0.85rem 1rem;
	background: #f0f7ff;
	border: 1px solid #c8d9f0;
	border-radius: 8px;
}

.scd-count--brand-city .scd-count__line {
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 0.35rem 0.5rem;
	font-size: 1.05rem;
}

.scd-count__num {
	font-size: 1.35rem;
	font-weight: 800;
	color: #0b57d0;
	letter-spacing: -0.02em;
}

.scd-count__label {
	font-weight: 600;
	color: #1a1a1a;
}

.scd-related--brand-city {
	margin-top: 1.75rem;
	padding: 1.25rem 1.35rem;
	background: #fafbfc;
	border: 1px solid #e8eaed;
	border-radius: 12px;
	box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.scd-brand-city .scd-related--brand-city + .scd-related--brand-city {
	margin-top: 1rem;
}

.scd-related--brand-city .scd-related__title {
	font-size: 1.12rem;
	font-weight: 700;
	color: #0d1117;
	margin: 0 0 0.85rem;
	padding-bottom: 0.5rem;
	border-bottom: 1px solid #e2e6e9;
	letter-spacing: -0.01em;
}

.scd-related__list--columns {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: 0.45rem 1.25rem;
	margin: 0;
	padding-left: 0;
	list-style: none;
}

.scd-related__list--columns li {
	margin: 0;
	line-height: 1.45;
}

.scd-related__list--columns a {
	color: #0b57d0;
	text-decoration: none;
	font-weight: 500;
	font-size: 0.95rem;
}

.scd-related__list--columns a:hover {
	text-decoration: underline;
	color: #0842a0;
}

.scd-brand-city__prose .scd-list {
	margin-top: 0.5rem;
}

.scd-brand-city__prose .scd-pagination {
	margin-top: 1rem;
	margin-bottom: 0.25rem;
}

.scd-brand-city__prose .scd-related--near-me {
	margin-top: 1.85rem;
	margin-bottom: 1.75rem;
}

.scd-brand-city {
	padding-bottom: 2rem;
}

.scd-brand-city .scd-header {
	margin-bottom: 1rem;
}

.scd-brand-city .scd-header .scd-h1 {
	font-size: clamp(1.4rem, 2.8vw, 1.85rem);
	line-height: 1.25;
	letter-spacing: -0.02em;
	color: #0d1117;
}

.scd-brand-city__prose {
	margin-bottom: 1.75rem;
	padding: 1.35rem 1.4rem;
	background: #fff;
	border: 1px solid #e8eaed;
	border-radius: 12px;
	box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
	text-align: justify;
	text-justify: inter-word;
	hyphens: auto;
	line-height: 1.65;
	color: #2d3339;
}

.scd-brand-city__prose > p {
	margin: 0 0 1rem;
}

.scd-brand-city__lead {
	margin: 0 0 1.35rem;
	font-size: 1.04rem;
	line-height: 1.7;
	color: #2d3339;
}

.scd-brand-city__figure {
	margin: 0 auto 1.35rem;
	max-width: 320px;
	text-align: center;
}

.scd-brand-city__brand-img {
	display: inline-block;
	max-width: 100%;
	height: auto;
	border-radius: 12px;
	border: 1px solid #e8eaed;
	box-shadow: 0 2px 12px rgba(15, 23, 42, 0.08);
	vertical-align: middle;
}

.scd-brand-city__h2 {
	font-size: clamp(1.1rem, 2vw, 1.28rem);
	margin: 2.35rem 0 0.75rem;
	padding: 1rem 0 0.45rem;
	border-bottom: 2px solid #e8eaed;
	color: #0d1117;
	font-weight: 700;
	letter-spacing: -0.015em;
}

.scd-brand-city__h2:first-of-type {
	margin-top: 0.35rem;
	padding-top: 0.85rem;
}

.scd-brand-city__figure + .scd-brand-city__h2 {
	margin-top: 0.5rem;
	padding-top: 1.25rem;
}

.scd-brand-city__meta-list {
	list-style: none;
	padding: 1rem 1.15rem;
	margin: 0 0 1.25rem;
	background: linear-gradient(135deg, #f8fafc 0%, #f1f5f9 100%);
	border-radius: 10px;
	border: 1px solid #e2e8f0;
	border-left: 4px solid #0b57d0;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

.scd-brand-city__meta-list li {
	margin: 0.5rem 0;
	line-height: 1.5;
}

.scd-brand-city__meta-list strong {
	color: #1a1a1a;
}

.scd-brand-city__bullets {
	margin: 0 0 1.15rem;
	padding-left: 1.35rem;
}

.scd-brand-city__bullets li {
	margin: 0.4rem 0;
	line-height: 1.55;
	padding-left: 0.15rem;
}

.scd-brand-city__bullets li::marker {
	color: #0b57d0;
}

/* Brand + country hub: states with listing counts (after “Products covered”) */
.scd-brand-country-states {
	margin: 1.5rem 0 1.75rem;
	padding: 1rem 0 0;
	border-top: 1px solid #e8ecf1;
}

.scd-brand-country-states__list {
	list-style: none;
	margin: 0.75rem 0 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: 0.65rem 1.25rem;
}

.scd-brand-country-states__link {
	display: flex;
	flex-direction: column;
	gap: 0.2rem;
	padding: 0.65rem 0.85rem;
	text-decoration: none;
	color: inherit;
	background: #f8fafc;
	border: 1px solid #e2e8f0;
	border-radius: 10px;
	border-left: 3px solid #0b57d0;
	transition: background 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}

.scd-brand-country-states__link:hover,
.scd-brand-country-states__link:focus-visible {
	background: #fff;
	border-color: #c7d7eb;
	box-shadow: 0 2px 10px rgba(11, 87, 208, 0.08);
	outline: none;
}

.scd-brand-country-states__name {
	font-weight: 600;
	font-size: 1rem;
	color: #0d1117;
	line-height: 1.3;
}

.scd-brand-country-states__count {
	font-size: 0.88rem;
	color: #5c6570;
	line-height: 1.35;
}

.scd-brand-city__faq {
	margin: 0;
	padding: 0.5rem 0 0;
}

.scd-brand-city__faq dt {
	font-weight: 600;
	margin-top: 1rem;
	color: #0d1117;
	font-size: 0.98rem;
	line-height: 1.45;
}

.scd-brand-city__faq dt:first-child {
	margin-top: 0;
}

.scd-brand-city__faq dd {
	margin: 0.35rem 0 0;
	padding: 0 0 0.85rem;
	border-bottom: 1px solid #eef1f4;
	color: #3d454d;
	line-height: 1.6;
	font-size: 0.95rem;
}

.scd-brand-city__faq dd:last-of-type {
	border-bottom: 0;
	padding-bottom: 0;
}

.scd-brand-city__disclaimer {
	font-size: 0.9rem;
	line-height: 1.55;
	color: #4a4f55;
	margin-top: 1.35rem;
	padding: 1rem 1.15rem;
	background: #fffbf0;
	border: 1px solid #f0e4c4;
	border-radius: 10px;
	border-left: 4px solid #d4a012;
}

.scd-brand-city__filters {
	margin-top: 2rem;
	padding: 1.35rem 1.4rem;
	background: #fff;
	border: 1px solid #e8eaed;
	border-radius: 12px;
	box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
}

.scd-brand-city__filters .scd-brand-city__h2 {
	margin-top: 0;
}

.scd-single__table-wrap {
	width: 100%;
	max-width: 100%;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	margin: 0 0 1.25rem;
}

.scd-single__table-wrap--care .scd-single__table td,
.scd-single__table-wrap--care .scd-single__table th {
	word-break: break-word;
	overflow-wrap: anywhere;
	hyphens: auto;
}

.scd-single__table-wrap--care .scd-single__table a {
	word-break: break-all;
}

.scd-single__table {
	width: 100%;
	min-width: 0;
	border-collapse: collapse;
	margin: 0;
	font-size: 0.95rem;
}

.scd-single__table--care {
	table-layout: fixed;
}

.scd-single__table th,
.scd-single__table td {
	border: 1px solid #e2e8f0;
	padding: 0.75rem 0.85rem;
	text-align: left;
	vertical-align: top;
}

.scd-single__table th {
	width: 38%;
	max-width: 220px;
	background: #f8fafc;
	font-weight: 600;
	color: #1a1a1a;
}

.scd-single__table td {
	min-width: 0;
}

.scd-single__nearby {
	margin: 0 0 1.5rem;
}

.scd-single__nearby .scd-brand-city__h2 {
	margin-top: 0.5rem;
}

/* Nearby cards: show each centre’s listing photo (300px source) in a tidy tile */
.scd-single__nearby .scd-card {
	grid-template-columns: min(168px, 42vw) minmax(0, 1fr);
}

.scd-single__nearby .scd-card__media {
	width: min(168px, 42vw);
}

.scd-single__nearby .scd-card__thumb {
	position: relative;
	width: 100%;
	max-width: 168px;
	aspect-ratio: 1 / 1;
	overflow: hidden;
}

.scd-single__nearby .scd-card__thumb .scd-card__img,
.scd-single__nearby .scd-card__img--listing-photo {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.scd-single__nearby .scd-card__placeholder {
	width: 100%;
	max-width: 168px;
	aspect-ratio: 1 / 1;
	height: auto;
	margin: 0 auto;
}

.scd-single__map-ref {
	margin: 0 0 0.75rem;
	font-size: 0.95rem;
	line-height: 1.55;
}

.scd-single__map-embed {
	position: relative;
	width: 100%;
	margin: 0 0 1.5rem;
	border-radius: 10px;
	overflow: hidden;
	border: 1px solid #e2e8f0;
	line-height: 0;
	background: #f1f5f9;
}

.scd-single__map-embed iframe {
	width: 100%;
	height: min(400px, 58vw);
	display: block;
}

.scd-single__cat-list {
	margin: 0 0 1.25rem;
	padding-left: 1.35rem;
	line-height: 1.55;
}

.scd-single__cat-list li {
	margin: 0.35rem 0;
}

.scd-single__disclaimer {
	font-size: 0.9rem;
	line-height: 1.55;
	color: #4a4f55;
	margin-top: 0.5rem;
	padding: 1rem 1.15rem;
	background: #fffbf0;
	border: 1px solid #f0e4c4;
	border-radius: 10px;
	border-left: 4px solid #d4a012;
}

@media (max-width: 600px) {
	.scd-dl {
		grid-template-columns: 1fr;
	}

	.scd-single__table th {
		display: block;
		width: 100%;
		max-width: none;
	}

	.scd-single__table td {
		display: block;
		width: 100%;
		border-top: 0;
	}

	.scd-single__table-wrap--care .scd-single__table {
		font-size: 0.88rem;
	}

	.scd-single__table-wrap--care .scd-single__table th {
		padding-bottom: 0.35rem;
		border-bottom: 0;
	}

	.scd-single__table-wrap--care .scd-single__table td {
		padding-top: 0.35rem;
	}

	.scd-single__nearby .scd-card {
		grid-template-columns: 1fr;
		justify-items: stretch;
	}

	.scd-single__nearby .scd-card__media {
		width: 100%;
		max-width: 280px;
		margin: 0 auto;
	}

	.scd-single__nearby .scd-card__thumb {
		max-width: 280px;
		margin: 0 auto;
	}

	.scd-single__nearby .scd-card__placeholder {
		max-width: 280px;
		margin: 0 auto;
	}

	.scd-feedback-cta {
		flex-direction: column;
		align-items: stretch;
	}

	.scd-feedback-cta__link {
		width: 100%;
		text-align: center;
		justify-content: center;
		white-space: normal;
	}
}

/* —— Single: top CTA → complaints & feedback section —— */
.scd-feedback-cta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 0.85rem 1.25rem;
	margin: 0 0 1.5rem;
	padding: 1rem 1.2rem;
	background: linear-gradient(135deg, #f0f4fa 0%, #e8eef6 100%);
	border: 1px solid #c5d0e0;
	border-radius: 8px;
	box-shadow: 0 1px 2px rgba(30, 58, 95, 0.06);
}

.scd-feedback-cta__text {
	margin: 0;
	flex: 1 1 220px;
	font-size: 0.95rem;
	line-height: 1.5;
	color: #1a2a3d;
	font-weight: 500;
}

.scd-feedback-cta__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 auto;
	padding: 0.6rem 1.15rem;
	border-radius: 6px;
	background: #1e3a5f;
	color: #fff !important;
	font-weight: 600;
	font-size: 0.9rem;
	text-decoration: none;
	white-space: nowrap;
	border: 0;
	cursor: pointer;
	transition: background 0.15s ease, transform 0.1s ease;
}

.scd-feedback-cta__link:hover,
.scd-feedback-cta__link:focus {
	background: #152d4a;
	color: #fff !important;
	text-decoration: none;
	outline: none;
	box-shadow: 0 0 0 2px #fff, 0 0 0 4px #1e3a5f;
}

.scd-feedback-cta__link:active {
	transform: translateY(1px);
}

/* Anchor targets: room below fixed headers when jumping from CTA */
#scd-feedback,
#scd-feedback-form {
	scroll-margin-top: 1.5rem;
}

/* —— Single: moderated visitor comments —— */
.scd-comments {
	margin-top: 2.5rem;
	padding-top: 1.75rem;
	border-top: 1px solid rgba(0, 0, 0, 0.08);
}

.scd-comments__h2 {
	margin-top: 0;
}

.scd-comments__notice {
	padding: 0.85rem 1rem;
	border-radius: 6px;
	margin-bottom: 1.25rem;
	font-size: 0.95rem;
	line-height: 1.45;
}

.scd-comments__notice--success {
	background: #edfaef;
	border: 1px solid #c3e6cb;
	color: #1e4620;
}

.scd-comments__notice--error {
	background: #fdf2f2;
	border: 1px solid #f5c2c7;
	color: #58151c;
}

.scd-comments__total {
	font-weight: 600;
	margin: 0 0 0.25rem;
	color: #1d2327;
}

.scd-comments__list-title {
	font-size: 1.05rem;
	margin: 1.25rem 0 0.75rem;
	font-weight: 600;
	color: #1d2327;
}

.scd-comments__empty {
	margin: 0 0 1.5rem;
	color: #50575e;
	font-size: 0.95rem;
}

.scd-comments__list {
	list-style: none;
	margin: 0 0 2rem;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.scd-comments__item {
	background: #f6f7f9;
	border: 1px solid #dcdcde;
	border-radius: 8px;
	padding: 1rem 1.15rem;
}

.scd-comments__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 0.5rem 1rem;
	margin-bottom: 0.65rem;
}

.scd-comments__author {
	font-size: 1rem;
	color: #1d2327;
}

.scd-comments__time {
	font-size: 0.85rem;
	color: #646970;
	font-weight: normal;
}

.scd-comments__body {
	font-size: 0.95rem;
	line-height: 1.55;
	color: #2c3338;
	word-break: break-word;
}

.scd-comments__form-title {
	font-size: 1.05rem;
	margin: 0 0 1rem;
	font-weight: 600;
	color: #1d2327;
}

.scd-comments__hp {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
}

.scd-comments__field {
	margin: 0 0 1rem;
}

.scd-comments__field label {
	display: block;
	font-weight: 600;
	font-size: 0.9rem;
	margin-bottom: 0.35rem;
	color: #1d2327;
}

.scd-comments__req {
	color: #b32d2e;
	font-weight: 700;
}

.scd-comments__input,
.scd-comments__textarea {
	width: 100%;
	max-width: 36rem;
	box-sizing: border-box;
	padding: 0.55rem 0.65rem;
	border: 1px solid #8c8f94;
	border-radius: 4px;
	font-size: 1rem;
	font-family: inherit;
}

.scd-comments__textarea {
	min-height: 7rem;
	resize: vertical;
}

.scd-comments__actions {
	margin: 1.25rem 0 0;
}

.scd-comments__submit {
	display: inline-block;
	padding: 0.55rem 1.25rem;
	font-size: 1rem;
	font-weight: 600;
	color: #fff;
	background: #2271b1;
	border: none;
	border-radius: 4px;
	cursor: pointer;
}

.scd-comments__submit:hover,
.scd-comments__submit:focus {
	background: #135e96;
	color: #fff;
}

.scd-comments__submit:disabled {
	opacity: 0.55;
	cursor: not-allowed;
}

.scd-comments__submit:focus:not(:disabled) {
	outline: 2px solid #2271b1;
	outline-offset: 2px;
}

.scd-comments__intro {
	margin: 0 0 1.25rem;
	font-size: 0.95rem;
	line-height: 1.5;
	color: #50575e;
	max-width: 42rem;
}

.scd-captcha {
	margin: 1.25rem 0 0.5rem;
	padding: 1rem 1.1rem;
	background: #f0f6fc;
	border: 1px solid #c3d9ed;
	border-radius: 8px;
	max-width: 36rem;
}

.scd-captcha__label {
	display: block;
	font-weight: 600;
	font-size: 0.9rem;
	margin-bottom: 0.25rem;
	color: #1d2327;
}

.scd-captcha__help {
	display: block;
	font-size: 0.82rem;
	color: #50575e;
	margin-bottom: 0.65rem;
}

.scd-captcha__row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.75rem 1rem;
}

.scd-captcha__image {
	display: block;
	border: 1px solid #8c8f94;
	border-radius: 4px;
	background: #fff;
}

.scd-captcha__input {
	width: 8.5rem;
	box-sizing: border-box;
	padding: 0.55rem 0.65rem;
	border: 1px solid #8c8f94;
	border-radius: 4px;
	font-size: 1.1rem;
	font-family: ui-monospace, monospace;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.scd-captcha__refresh {
	margin: 0.65rem 0 0;
	font-size: 0.88rem;
}

.scd-captcha__reload {
	background: none;
	border: none;
	padding: 0;
	color: #2271b1;
	text-decoration: underline;
	cursor: pointer;
	font: inherit;
}

.scd-captcha__reload:hover,
.scd-captcha__reload:focus {
	color: #135e96;
}

@media (prefers-color-scheme: dark) {
	.scd-feedback-cta {
		background: linear-gradient(135deg, rgba(40, 55, 75, 0.9) 0%, rgba(30, 45, 65, 0.95) 100%);
		border-color: rgba(120, 160, 210, 0.35);
		box-shadow: none;
	}

	.scd-feedback-cta__text {
		color: #e8eaed;
	}

	.scd-comments {
		border-top-color: rgba(255, 255, 255, 0.12);
	}

	.scd-comments__item {
		background: rgba(255, 255, 255, 0.06);
		border-color: rgba(255, 255, 255, 0.12);
	}

	.scd-comments__total,
	.scd-comments__list-title,
	.scd-comments__form-title,
	.scd-comments__author {
		color: #f0f0f1;
	}

	.scd-comments__body,
	.scd-comments__empty {
		color: #c3c4c7;
	}

	.scd-comments__time {
		color: #a7aaad;
	}

	.scd-comments__input,
	.scd-comments__textarea {
		background: #1e1e1e;
		border-color: #50575e;
		color: #f0f0f1;
	}

	.scd-comments__intro,
	.scd-captcha__help {
		color: #c3c4c7;
	}

	.scd-captcha {
		background: rgba(30, 60, 90, 0.35);
		border-color: rgba(120, 170, 220, 0.35);
	}

	.scd-captcha__input {
		background: #1e1e1e;
		border-color: #50575e;
		color: #f0f0f1;
	}
}
