/**
 * Area single — (City × Service) landing page.
 *
 * Class prefix `.cy-` follows the source HTML mockup. Scoped under
 * .site-main--area-single.
 */

/* =============================================================
   HERO  (.cy-hero — distinct from global .page-hero)
   ============================================================= */
.cy-hero-wrapper {
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 100px;
}
.cy-hero {
	width: 100%;
	min-height: 480px;
	border-radius: var(--radius-xl);
	overflow: hidden;
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 60px 80px;
	text-align: center;
}
.cy-hero-bg { position: absolute; inset: 0; }
.cy-hero-bg img { width: 100%; height: 100%; object-fit: cover; }
.cy-hero-bg::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(to bottom, rgba(0,0,0,.45), rgba(8,50,92,.78));
}
.cy-hero-bg--placeholder {
	background: linear-gradient(135deg, var(--color-blue-1), var(--color-primary-blue));
}
.cy-hero-content {
	position: relative;
	z-index: 1;
	max-width: 880px;
}
.cy-hero-sub {
	font-size: 18px;
	line-height: 26px;
	color: var(--color-grey-2);
	margin-bottom: 12px;
	text-shadow: 0 4px 12px rgba(0,0,0,.18);
}
.cy-hero-title {
	font-size: 56px;
	line-height: 64px;
	font-weight: var(--fw-semibold);
	color: var(--color-grey-0);
	text-shadow: 0 4px 12px rgba(0,0,0,.18);
}
.cy-hero-title-near {
	color: var(--color-primary-green);
	display: inline-block;
	margin-left: 4px;
}
.cy-hero-actions {
	display: flex;
	gap: 8px;
	justify-content: center;
	margin-top: 24px;
	flex-wrap: wrap;
}
.cy-hero-btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	height: 54px;
	padding: 16px 24px;
	border-radius: var(--radius-xl);
	font-size: 17px;
	line-height: 1;
	font-weight: var(--fw-semibold);
	white-space: nowrap;
	text-decoration: none;
	border: 1px solid transparent;
	cursor: pointer;
	transition: background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
}
.cy-hero-btn svg { width: 20px; height: 20px; }
.cy-hero-btn--solid { background: var(--color-grey-0); color: var(--color-primary-blue); }
.cy-hero-btn--solid:hover { background: var(--color-grey-2); }
.cy-hero-btn--ghost { background: transparent; color: var(--color-grey-0); border-color: var(--color-grey-0); }
.cy-hero-btn--ghost:hover { background: rgba(255,255,255,.12); }


/* =============================================================
   INTRO
   ============================================================= */
.cy-intro {
	max-width: 1440px;
	margin: 80px auto 0;
	padding: 0 100px;
}
.cy-intro-inner { max-width: 880px; margin: 0 auto; }
.cy-intro-title {
	font-size: 30px;
	line-height: 38px;
	font-weight: var(--fw-semibold);
	color: var(--color-blue-4);
}
.cy-intro-body {
	margin-top: 18px;
	font-size: 18px;
	line-height: 28px;
	color: var(--color-grey-7);
}
.cy-intro-body p + p { margin-top: 14px; }


/* =============================================================
   SERVICE CARD + INFO COL
   ============================================================= */
.cy-svc-row {
	max-width: 1440px;
	margin: 80px auto 0;
	padding: 0 100px;
}
.cy-svc-row-inner {
	display: flex;
	gap: 24px;
	align-items: flex-start;
}
.cy-svc-card {
	flex: 1;
	min-width: 0;
	background: linear-gradient(135deg, var(--color-blue-1), var(--color-blue-2));
	border-radius: var(--radius-xl);
	overflow: hidden;
	color: var(--color-grey-0);
	display: flex;
	flex-direction: column;
}
.cy-svc-img { width: 100%; height: 280px; overflow: hidden; }
.cy-svc-img img { width: 100%; height: 100%; object-fit: cover; }
.cy-svc-body { padding: 28px 32px 32px; }
.cy-svc-title {
	font-size: 28px;
	line-height: 36px;
	font-weight: var(--fw-semibold);
	color: var(--color-grey-0);
	margin-bottom: 16px;
}
.cy-svc-title span { color: var(--color-primary-green); margin-left: 4px; }
.cy-svc-desc {
	font-size: 17px;
	line-height: 26px;
	color: var(--color-grey-2);
	margin-bottom: 20px;
}
.cy-svc-badges {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
	margin-bottom: 24px;
}
.cy-svc-badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 14px;
	border-radius: var(--radius-xl);
	background: rgba(255,255,255,.10);
	border: 1px solid rgba(255,255,255,.22);
	font-size: 14px;
	line-height: 18px;
	color: var(--color-grey-0);
}
.cy-svc-badge svg { width: 14px; height: 14px; color: var(--color-primary-green); }

.cy-svc-btns { display: flex; gap: 8px; flex-wrap: wrap; }
.cy-svc-btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	height: 48px;
	padding: 14px 22px;
	border-radius: var(--radius-xl);
	font-size: 16px;
	line-height: 1;
	font-weight: var(--fw-semibold);
	text-decoration: none;
	border: 1px solid transparent;
	transition: background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
}
.cy-svc-btn--solid { background: var(--color-grey-0); color: var(--color-primary-blue); }
.cy-svc-btn--solid:hover { background: var(--color-grey-2); }
.cy-svc-btn--ghost { background: transparent; color: var(--color-grey-0); border-color: rgba(255,255,255,.35); }
.cy-svc-btn--ghost:hover { background: rgba(255,255,255,.10); }
.cy-svc-btn svg { width: 18px; height: 18px; }

.cy-svc-landing-link {
	margin-top: 16px;
	font-size: 14px;
}
.cy-svc-landing-link a {
	color: var(--color-grey-2);
	text-decoration: underline;
	text-underline-offset: 3px;
}
.cy-svc-landing-link a:hover { color: var(--color-grey-0); }

.cy-info-col {
	width: 380px;
	flex-shrink: 0;
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.cy-info-card {
	background: var(--color-grey-0);
	border-radius: var(--radius-lg);
	padding: 18px 24px;
	display: flex;
	gap: 14px;
	align-items: flex-start;
	border: 1px solid var(--color-grey-2);
	box-shadow: 0 4px 12px rgba(0,0,0,.02);
}
.cy-info-icon {
	width: 44px;
	height: 44px;
	border-radius: var(--radius-full);
	background: rgba(11,69,128,.08);
	color: var(--color-primary-blue);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.cy-info-icon svg { width: 18px; height: 18px; }
.cy-info-label {
	font-size: 15px;
	line-height: 22px;
	font-weight: var(--fw-semibold);
	color: var(--color-primary-blue);
}
.cy-info-text {
	font-size: 15px;
	line-height: 22px;
	color: var(--color-grey-8, #343A40);
	margin-top: 2px;
}
.cy-info-text a { color: var(--color-primary-blue); text-decoration: none; }
.cy-info-text a:hover { text-decoration: underline; }


/* =============================================================
   WHY  (dark overlay)
   ============================================================= */
.cy-why {
	margin-top: 100px;
	position: relative;
	overflow: hidden;
	padding: 80px 0;
}
.cy-why-bg { position: absolute; inset: 0; z-index: 0; }
.cy-why-bg img { width: 100%; height: 100%; object-fit: cover; }
.cy-why-bg::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(to bottom, rgba(0,0,0,.78), rgba(8,50,92,.82));
}
.cy-why::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, var(--color-blue-1), var(--color-primary-blue));
	z-index: -1;
}
.cy-why-inner {
	position: relative;
	z-index: 1;
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 100px;
}
.cy-why-title {
	font-size: 32px;
	line-height: 40px;
	font-weight: var(--fw-semibold);
	color: var(--color-grey-0);
	font-style: italic;
	max-width: 600px;
	margin-bottom: 32px;
	text-shadow: 0 4px 12px rgba(0,0,0,.18);
}
.cy-why-grid {
	list-style: none;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
}
.cy-why-card {
	background: var(--color-grey-0);
	border-radius: var(--radius-lg);
	padding: 24px;
}
.cy-why-icon {
	width: 48px;
	height: 48px;
	border-radius: var(--radius-full);
	background: rgba(0,176,161,.12);
	color: var(--color-primary-green);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 16px;
}
.cy-why-icon svg { width: 22px; height: 22px; }
.cy-why-card-title {
	font-size: 19px;
	line-height: 26px;
	font-weight: var(--fw-semibold);
	color: var(--color-blue-4);
	margin-bottom: 8px;
}
.cy-why-card-desc {
	font-size: 16px;
	line-height: 24px;
	color: var(--color-grey-7);
}


/* =============================================================
   WHAT'S INCLUDED
   ============================================================= */
.cy-inc {
	max-width: 1440px;
	margin: 100px auto 0;
	padding: 0 100px;
}
.cy-inc-inner { max-width: 1100px; margin: 0 auto; }
.cy-inc-title {
	font-size: 32px;
	line-height: 40px;
	font-weight: var(--fw-semibold);
	color: var(--color-blue-4);
	margin-bottom: 12px;
}
.cy-inc-sub {
	font-size: 18px;
	line-height: 26px;
	color: var(--color-grey-7);
	margin-bottom: 28px;
	max-width: 720px;
}
.cy-inc-grid {
	list-style: none;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 14px;
}
.cy-inc-card {
	background: var(--color-grey-0);
	border-radius: var(--radius-lg);
	padding: 18px 24px;
	display: flex;
	gap: 14px;
	align-items: flex-start;
	border: 1px solid var(--color-grey-2);
}
.cy-inc-check {
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background: rgba(0,176,161,.14);
	color: var(--color-primary-green);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.cy-inc-check svg { width: 16px; height: 16px; }
.cy-inc-text {
	font-size: 17px;
	line-height: 24px;
	color: var(--color-grey-9);
}


/* =============================================================
   TRUST BLOCK
   ============================================================= */
.cy-trust {
	max-width: 1440px;
	margin: 100px auto 0;
	padding: 0 100px;
}
.cy-trust-inner {
	max-width: 920px;
	margin: 0 auto;
	background: var(--color-grey-0);
	border-radius: var(--radius-xl);
	padding: 40px 48px;
	border: 1px solid var(--color-grey-2);
	box-shadow: 0 4px 16px rgba(11,69,128,.05);
}
.cy-trust-title {
	font-size: 28px;
	line-height: 36px;
	font-weight: var(--fw-semibold);
	color: var(--color-blue-4);
	text-align: center;
	margin-bottom: 24px;
}
.cy-trust-body {
	font-size: 17px;
	line-height: 28px;
	color: var(--color-grey-7);
}
.cy-trust-body p + p { margin-top: 14px; }
.cy-trust-body ul, .cy-trust-body ol { padding-left: 22px; margin-top: 10px; }
.cy-trust-body li { margin-top: 8px; list-style: disc; }
.cy-trust-body h3 {
	font-size: 19px;
	line-height: 26px;
	font-weight: var(--fw-semibold);
	color: var(--color-blue-4);
	margin-top: 18px;
}


/* =============================================================
   FAQ (uses global .faq-item / .faq-question / .is-open)
   ============================================================= */
.cy-faq {
	max-width: 1440px;
	margin: 100px auto 0;
	padding: 0 100px;
}
.cy-faq-inner { max-width: 880px; margin: 0 auto; }
.cy-faq-header { text-align: center; margin-bottom: 28px; }
.cy-faq-title {
	font-size: 30px;
	line-height: 38px;
	font-weight: var(--fw-semibold);
	color: var(--color-blue-4);
}
.cy-faq-list { display: flex; flex-direction: column; gap: 12px; }
.cy-faq-list .faq-item {
	background: var(--color-grey-0);
	border: 1px solid var(--color-grey-2);
	border-radius: var(--radius-lg);
	overflow: hidden;
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.cy-faq-list .faq-item.is-open {
	border-color: var(--color-primary-blue);
	box-shadow: 0 4px 14px rgba(11,69,128,.08);
}
.cy-faq-list .faq-question {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	width: 100%;
	padding: 20px 24px;
	background: none;
	border: none;
	cursor: pointer;
	text-align: left;
	font-family: inherit;
}
.cy-faq-list .faq-question:focus-visible {
	outline: 2px solid var(--color-primary-blue);
	outline-offset: -2px;
}
.cy-faq-list .faq-q-text {
	font-size: 18px;
	line-height: 26px;
	font-weight: var(--fw-semibold);
	color: var(--color-blue-4);
	flex: 1;
}
.cy-faq-list .faq-q-icon {
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background: var(--color-grey-1);
	color: var(--color-primary-blue);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	transition: transform .3s ease;
}
.cy-faq-list .faq-q-icon svg { width: 16px; height: 16px; }
.cy-faq-list .faq-item.is-open .faq-q-icon { transform: rotate(180deg); }
.cy-faq-list .faq-answer {
	max-height: 0;
	overflow: hidden;
	transition: max-height .45s cubic-bezier(.4,0,.2,1), padding .35s ease;
	padding: 0 24px;
}
.cy-faq-list .faq-item.is-open .faq-answer {
	max-height: 500px;
	padding: 0 24px 24px;
}
.cy-faq-list .faq-answer p {
	font-size: 16px;
	line-height: 26px;
	color: var(--color-grey-7);
}


/* =============================================================
   OTHER SERVICES (overlapping cards layout)
   ============================================================= */
.cy-other {
	max-width: 1440px;
	margin: 100px auto 0;
	padding: 0 100px;
}
.cy-other-header { text-align: center; margin-bottom: 32px; }
.cy-other-title {
	font-size: 30px;
	line-height: 38px;
	font-weight: var(--fw-semibold);
	color: var(--color-blue-4);
}
.cy-other-sub {
	margin-top: 10px;
	font-size: 17px;
	line-height: 24px;
	color: var(--color-grey-7);
}
.cy-other-grid {
	list-style: none;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
}
.cy-oc {
	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);
}
.cy-oc:hover { transform: translateY(-2px); box-shadow: 0 8px 22px rgba(11,69,128,.10); }
.cy-oc-img { width: 100%; height: 200px; overflow: hidden; background: var(--color-grey-2); }
.cy-oc-img img { width: 100%; height: 100%; object-fit: cover; }
.cy-oc-body { padding: 20px 24px 24px; display: flex; flex-direction: column; gap: 12px; flex: 1; }
.cy-oc-tag {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	font-weight: var(--fw-semibold);
	color: var(--color-primary-blue);
	text-transform: uppercase;
	letter-spacing: .5px;
}
.cy-oc-tag svg { width: 14px; height: 14px; }
.cy-oc-title {
	font-size: 20px;
	line-height: 26px;
	font-weight: var(--fw-semibold);
	color: var(--color-blue-4);
}
.cy-oc-checks { display: flex; flex-direction: column; gap: 8px; }
.cy-oc-check {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	font-size: 14px;
	line-height: 20px;
	color: var(--color-grey-8, #343A40);
}
.cy-oc-check svg { width: 18px; height: 18px; flex-shrink: 0; margin-top: 1px; color: var(--color-primary-blue); }
.cy-oc-check-text { flex: 1; }
.cy-oc-link {
	margin-top: auto;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 15px;
	line-height: 1;
	font-weight: var(--fw-semibold);
	color: var(--color-primary-blue);
	text-decoration: none;
}
.cy-oc-link svg { width: 16px; height: 16px; }
.cy-oc-link:hover { color: var(--color-blue-n3); }


/* =============================================================
   MAP + DIRECTIONS
   ============================================================= */
.cy-map-dir {
	max-width: 1440px;
	margin: 100px auto 0;
	padding: 0 100px;
}
.cy-map-dir-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);
}
.cy-map-dir-header { padding: 28px 32px 20px; text-align: center; }
.cy-map-dir-title {
	font-size: 26px;
	line-height: 34px;
	font-weight: var(--fw-semibold);
	color: var(--color-blue-4);
}
.cy-map-dir-sub { margin-top: 8px; font-size: 16px; line-height: 24px; color: var(--color-grey-7); }
.cy-map-dir-frame { width: 100%; height: 380px; background: var(--color-grey-2); }
.cy-map-dir-frame iframe { display: block; }
.cy-map-dir-actions {
	display: flex;
	gap: 12px;
	justify-content: center;
	padding: 20px 32px 28px;
}


/* =============================================================
   BOOK FORM
   ============================================================= */
.cy-book {
	max-width: 1440px;
	margin: 100px auto 0;
	padding: 0 100px 100px;
}
.cy-book-inner {
	max-width: 920px;
	margin: 0 auto;
	background: var(--color-grey-0);
	border-radius: var(--radius-xl);
	padding: 40px 48px 44px;
	border: 1px solid var(--color-grey-2);
	box-shadow: 0 6px 24px rgba(11,69,128,.08);
}
.cy-book-header { margin-bottom: 24px; text-align: center; }
.cy-book-title {
	font-size: 28px;
	line-height: 36px;
	font-weight: var(--fw-semibold);
	color: var(--color-blue-4);
}
.cy-book-sub { margin-top: 8px; font-size: 16px; line-height: 24px; color: var(--color-grey-7); }
.cy-book-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}
.cy-book-field { display: flex; flex-direction: column; gap: 6px; }
.cy-book-field--full { grid-column: 1 / -1; }
.cy-book-label {
	font-size: 14px;
	line-height: 20px;
	font-weight: var(--fw-semibold);
	color: var(--color-grey-8, #343A40);
}
.cy-book-field input,
.cy-book-field select,
.cy-book-field textarea {
	font-family: inherit;
	font-size: 16px;
	line-height: 22px;
	color: var(--color-grey-9);
	padding: 12px 14px;
	border: 1px solid var(--color-grey-3);
	border-radius: 10px;
	background: var(--color-grey-1);
	transition: border-color var(--transition-fast), background var(--transition-fast);
}
.cy-book-field input:focus,
.cy-book-field select:focus,
.cy-book-field textarea:focus {
	outline: none;
	border-color: var(--color-primary-blue);
	background: var(--color-grey-0);
}
.cy-book-field input.has-error,
.cy-book-field select.has-error,
.cy-book-field textarea.has-error { border-color: #D14343; background: #FFF5F5; }
.cy-book-field textarea { resize: vertical; min-height: 88px; }

.cy-book-check {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	margin-top: 16px;
	font-size: 14px;
	line-height: 20px;
	color: var(--color-grey-7);
}
.cy-book-check input { margin-top: 4px; flex-shrink: 0; }
.cy-book-check a { color: var(--color-primary-blue); text-decoration: underline; }

.cy-book-actions { margin-top: 20px; }
.cy-book-submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	height: 50px;
	padding: 14px 32px;
	border-radius: var(--radius-xl);
	background: var(--color-primary-blue);
	color: var(--color-grey-0);
	font-size: 16px;
	line-height: 1;
	font-weight: var(--fw-semibold);
	border: none;
	cursor: pointer;
	transition: background var(--transition-fast);
}
.cy-book-submit:hover { background: var(--color-blue-n3); }
.cy-book-submit:disabled { opacity: .6; cursor: not-allowed; }
.cy-book-submit.is-loading { opacity: .7; }
.cy-book-submit.is-loading::after {
	content: '';
	width: 16px;
	height: 16px;
	border-radius: 50%;
	border: 2px solid rgba(255,255,255,.5);
	border-top-color: var(--color-grey-0);
	animation: cy-spin .8s linear infinite;
}
@keyframes cy-spin { to { transform: rotate(360deg); } }

.cy-book-feedback {
	margin-top: 16px;
	font-size: 15px;
	line-height: 22px;
	padding: 12px 16px;
	border-radius: 10px;
	display: none;
}
.cy-book-feedback.is-success {
	display: block;
	background: rgba(0,176,161,.10);
	color: #007D72;
	border: 1px solid rgba(0,176,161,.35);
}
.cy-book-feedback.is-error {
	display: block;
	background: #FFF5F5;
	color: #8C1F1F;
	border: 1px solid rgba(209,67,67,.4);
}
.field-error {
	font-size: 13px;
	color: #8C1F1F;
	margin-top: 4px;
}


/* =============================================================
   REDUCED MOTION
   ============================================================= */
@media (prefers-reduced-motion: reduce) {
	.cy-oc, .cy-faq-list .faq-q-icon, .cy-faq-list .faq-answer { transition: none !important; }
	.cy-book-submit.is-loading::after { animation: none; }
}


/* =============================================================
   RESPONSIVE — 1279
   ============================================================= */
@media (max-width: 1279px) {
	.cy-hero-wrapper,
	.cy-intro,
	.cy-svc-row,
	.cy-inc,
	.cy-trust,
	.cy-faq,
	.cy-other,
	.cy-map-dir,
	.cy-book { padding-left: 32px; padding-right: 32px; }
	.cy-why-inner { padding-left: 32px; padding-right: 32px; }
	.cy-hero { padding: 48px 32px; min-height: 420px; }
	.cy-hero-title { font-size: 44px; line-height: 52px; }
	.cy-info-col { width: 340px; }
	.cy-other-grid { grid-template-columns: repeat(2, 1fr); }
}


/* =============================================================
   RESPONSIVE — 991
   ============================================================= */
@media (max-width: 991px) {
	.cy-hero-wrapper { padding: 0 16px; }
	.cy-intro,
	.cy-svc-row,
	.cy-inc,
	.cy-trust,
	.cy-faq,
	.cy-other,
	.cy-map-dir,
	.cy-book { padding-left: 16px; padding-right: 16px; margin-top: 72px; }
	.cy-why { margin-top: 72px; padding: 60px 0; }
	.cy-why-inner { padding-left: 16px; padding-right: 16px; }
	.cy-book { padding-bottom: 64px; }

	.cy-hero { padding: 32px 20px; min-height: 380px; border-radius: var(--radius-lg); }
	.cy-hero-sub { font-size: 16px; line-height: 22px; }
	.cy-hero-title { font-size: 30px; line-height: 38px; }
	.cy-hero-actions { flex-direction: column; gap: 8px; }
	.cy-hero-btn { width: 100%; justify-content: center; height: 48px; font-size: 16px; }

	.cy-intro-title { font-size: 24px; line-height: 32px; }
	.cy-intro-body { font-size: 16px; line-height: 26px; }

	.cy-svc-row-inner { flex-direction: column; gap: 16px; }
	.cy-svc-img { height: 220px; }
	.cy-svc-body { padding: 24px; }
	.cy-svc-title { font-size: 22px; line-height: 30px; }
	.cy-svc-desc { font-size: 16px; line-height: 24px; }
	.cy-info-col { width: 100%; }

	.cy-why-title { font-size: 24px; line-height: 32px; }
	.cy-why-grid { grid-template-columns: 1fr; gap: 14px; }

	.cy-inc-title { font-size: 24px; line-height: 32px; }
	.cy-inc-grid { grid-template-columns: 1fr; }

	.cy-trust-inner { padding: 28px 24px; }
	.cy-trust-title { font-size: 22px; line-height: 30px; }
	.cy-trust-body { font-size: 16px; line-height: 26px; }

	.cy-faq-title { font-size: 24px; line-height: 32px; }
	.cy-faq-list .faq-question { padding: 16px 20px; }
	.cy-faq-list .faq-q-text { font-size: 16px; line-height: 24px; }
	.cy-faq-list .faq-item.is-open .faq-answer { padding: 0 20px 20px; }

	.cy-other-title { font-size: 24px; line-height: 32px; }
	.cy-other-grid { grid-template-columns: 1fr; }

	.cy-map-dir-title { font-size: 22px; line-height: 30px; }
	.cy-map-dir-frame { height: 320px; }

	.cy-book-inner { padding: 28px 20px; border-radius: var(--radius-lg); }
	.cy-book-title { font-size: 22px; line-height: 30px; }
	.cy-book-grid { grid-template-columns: 1fr; }
	.cy-book-submit { width: 100%; }
}


/* =============================================================
   RESPONSIVE — 575
   ============================================================= */
@media (max-width: 575px) {
	.cy-hero-wrapper { padding: 0 12px; }
	.cy-intro,
	.cy-svc-row,
	.cy-inc,
	.cy-trust,
	.cy-faq,
	.cy-other,
	.cy-map-dir,
	.cy-book { padding-left: 12px; padding-right: 12px; }
	.cy-why-inner { padding-left: 12px; padding-right: 12px; }
}
