/* =============================================================
   Promo Page — desktop styles (one-off Cowboys promotion)
   Scoped under .promo-page; mobile rules to follow in a later pass.
   ============================================================= */

/* ----- Break out of Avada's content width on this template -----
   Avada renders the page inside:
     #main  (padding: 0 30px via html:not(.avada-has-site-width-percent) #main, specificity 0,1,1,1)
       └ .fusion-row  (max-width: var(--site_width))
           └ #content  (body.has-sidebar #content { width: calc(100% - 29% - 80px) })
   Tying on specificity (0,1,1,1) loses to Avada because its dynamic CSS
   loads after our promo.css. Prefix `html` everywhere → (0,1,1,2) wins. */
html body.page-template-template-promo #main,
html body.page-template-template-promo-php #main {
	padding: 0;
	max-width: none;
}
html body.page-template-template-promo #main > .fusion-row,
html body.page-template-template-promo-php #main > .fusion-row {
	max-width: none;
	padding: 0;
	margin: 0;
	width: 100%;
}
html body.page-template-template-promo #content,
html body.page-template-template-promo-php #content,
html body.page-template-template-promo #content > article,
html body.page-template-template-promo-php #content > article {
	width: 100%;
	max-width: none;
	margin: 0;
	padding: 0;
	float: none;
}

/* Hide Avada's Page Title Bar on this template — promo is a clean landing page. */
html body.page-template-template-promo .avada-page-titlebar-wrapper,
html body.page-template-template-promo-php .avada-page-titlebar-wrapper {
	display: none;
}

/* Hide Avada's fixed-bottom mobile CTA bar (it shows the site's general
   header phone number and competes with our promo's primary CTA). */
html body.page-template-template-promo .fusion-fullwidth.fixed-bottom,
html body.page-template-template-promo-php .fusion-fullwidth.fixed-bottom {
	display: none;
}

/* ----- Heading typography overrides -----
   Avada's `#main .post h2, #main h2, ...` rule (specificity 0,1,0,1)
   forces all headings to Work Sans 400 via Theme Options. Worse, Avada
   doesn't load Inter at all — only Work Sans — so our `font-family: 'Inter'`
   was silently falling through to the fallback. Inter is now loaded via the
   child theme's `avada-child-promo-fonts` enqueue. These rules are
   `#content.promo-page .promo-X` (specificity 0,1,2,0) which beats Avada's
   0,1,0,1 (more classes at tied ID). */
#content.promo-page .promo-value__title,
#content.promo-page .promo-services__title,
#content.promo-page .promo-location__title {
	font-family: 'Inter', 'Work Sans', Arial, Helvetica, sans-serif;
	font-weight: 700;
	font-size: 48px;
	line-height: 1.15;
	letter-spacing: normal;
	text-transform: none;
	color: var(--p-card);
	text-align: center;
	margin: 0;
	padding: 0;
}
#content.promo-page .promo-value__title    { margin-bottom: 56px; }
#content.promo-page .promo-services__title { margin-bottom: 24px; }
#content.promo-page .promo-location__title { margin-bottom: 80px; }

#content.promo-page .promo-terms__title {
	font-family: 'Inter', 'Work Sans', Arial, Helvetica, sans-serif;
	font-weight: 700;
	font-size: 25px;
	line-height: 1.3;
	letter-spacing: 1px;
	text-transform: uppercase;
	color: var(--p-text-faint);
	margin: 0;
	padding: 0;
}

#content.promo-page .promo-service__name {
	font-family: 'Inter', 'Work Sans', Arial, Helvetica, sans-serif;
	font-weight: 700;
	font-size: 32px;
	line-height: 1.05;
	letter-spacing: 2.8px;
	text-transform: uppercase;
	color: var(--p-orange);
	margin: 8px 0 0;
	padding: 0;
}

/* ----- Tokens (page-scoped) ----- */
.promo-page {
	--p-bg-deep:      #0a1a3b;
	--p-bg-darker:    #08163a;
	--p-bg-vignette:  #05102d;
	--p-card:         #333645; /* matches Avada --awb-color7 */
	--p-orange:       #ffaa06; /* matches Avada --awb-color4 */
	--p-orange-hi:    #ffc24a;
	--p-orange-lo:    #cc6c00;
	--p-red:          #b91c1c;
	--p-terms-bg:     #071330;
	--p-section-gray: #f4f4f4;
	--p-warn-text:    #0c2b47;
	--p-text-white:   #ffffff;
	--p-text-muted:   rgba(255, 255, 255, 0.75);
	--p-text-faint:   rgba(255, 255, 255, 0.4);
	--p-text-faint-3: rgba(255, 255, 255, 0.3);

	--p-container:    1200px;
	--p-pad-x:        clamp(20px, 4vw, 72px);

	color: var(--p-card);
	font-family: 'Inter', 'Work Sans', Arial, Helvetica, sans-serif;
	line-height: 1.4;
}

/* ----- Reset Avada's wrappers within scope ----- */
.promo-page,
.promo-page .promo-page__article,
.promo-page .promo-page__article > * {
	margin: 0;
	max-width: none;
}
.promo-page .promo-page__article {
	padding: 0;
	background: var(--p-text-white);
}
.promo-page section {
	width: 100%;
}
.promo-page * { box-sizing: border-box; }
.promo-page h1,
.promo-page h2,
.promo-page h3,
.promo-page h4,
.promo-page ul {
	margin: 0;
	padding: 0;
}
.promo-page p { margin: 0; }
.promo-page ul[role="list"] { list-style: none; }
.promo-page a { color: inherit; text-decoration: none; }


/* =============================================================
   HERO
   ============================================================= */
.promo-hero {
	position: relative;
	overflow: hidden;
	background: var(--p-bg-deep);
	color: var(--p-text-white);
	min-height: 545px;
	isolation: isolate;
	/* Match the structural pattern of every other section: horizontal padding
	   lives on the section, the inner is just a max-width centered box.
	   This keeps hero copy aligned with value/services/terms content. */
	padding: 0 var(--p-pad-x);
}
.promo-hero__media { position: absolute; inset: 0; z-index: 0; }
.promo-hero__image {
	position: absolute; inset: 0;
	background-color: var(--p-bg-darker);
	background-position: right center;
	background-size: cover;
	background-repeat: no-repeat;
}
.promo-hero__veil {
	position: absolute; inset: 0;
	background:
		linear-gradient(to bottom, rgba(8,22,58,0.85) 0%, rgba(8,22,58,0) 30%),
		linear-gradient(to top,    rgba(8,22,58,0.98) 0%, rgba(8,22,58,0.7) 35%, rgba(8,22,58,0) 60%),
		linear-gradient(90deg, var(--p-bg-vignette) 0%, var(--p-bg-vignette) 42%, rgba(16,52,147,0) 73%);
}

.promo-hero__inner {
	position: relative; z-index: 1;
	display: flex;
	flex-direction: column;
	max-width: var(--p-container);
	min-height: 545px;
	margin: 0 auto;
	padding: 60px 0;
}

.promo-hero__stars {
	font-size: 60px;
	color: var(--p-orange);
	text-align: center;
	letter-spacing: 8px;
	line-height: 1;
	margin-bottom: 24px;
}

.promo-hero__copy {
	max-width: 660px;
	margin-top: auto;
	margin-bottom: auto;
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.promo-hero__pre {
	font-family: 'Inter', sans-serif;
	font-weight: 600;
	font-size: 30px;
	line-height: 1;
	letter-spacing: 1px;
	text-transform: uppercase;
	color: var(--p-text-white);
}

.promo-hero__team {
	font-family: 'Inter', sans-serif;
	font-weight: 700;
	font-size: clamp(60px, 7vw, 86px);
	line-height: 0.9;
	letter-spacing: -1px;
	text-transform: uppercase;
	color: var(--p-text-white);
	text-shadow: 0 0 60px rgba(30, 80, 200, 0.4);
}

.promo-hero__sub {
	font-family: 'Inter', sans-serif;
	font-weight: 700;
	font-size: 40px;
	line-height: 1;
	letter-spacing: 1px;
	text-transform: uppercase;
	color: var(--p-text-white);
	margin: 6px 0 14px;
}

.promo-hero__highlight {
	/* Figma: red bar is `shrink-0` (sized to content + padding), left-aligned
	   inside the copy column. */
	align-self: flex-start;
	background: var(--p-red);
	color: var(--p-text-white);
	padding: 30px;
	font-family: 'Work Sans', sans-serif;
	font-weight: 700;
	font-size: 22px;
	line-height: normal;
	letter-spacing: 1px;
	text-transform: uppercase;
}

.promo-hero__free {
	font-family: 'Inter', sans-serif;
	font-weight: 700;
	font-size: clamp(72px, 8vw, 100px);
	line-height: 0.88;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: var(--p-orange);
	text-shadow: 3px 3px 0 rgba(0, 0, 0, 0.4);
	margin: 12px 0 18px;
}

.promo-hero__features {
	display: flex;
	flex-wrap: wrap;
	gap: 25px;
	margin: 4px 0 16px;
}
.promo-hero__features li {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-family: 'Work Sans', sans-serif;
	font-weight: 600;
	font-size: 13px;
	line-height: 1.2;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	color: var(--p-text-muted);
}
.promo-hero__check {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 20px;
	height: 20px;
	border-radius: 3px;
	background: var(--p-orange);
	color: var(--p-text-white);
}
.promo-hero__check svg { width: 12px; height: 12px; }

.promo-hero__limited {
	font-family: 'Inter', sans-serif;
	font-weight: 600;
	font-size: 14px;
	letter-spacing: 3px;
	text-transform: uppercase;
	color: var(--p-orange);
}

.promo-hero__badge {
	/* Anchored to the bottom-right of .promo-hero__inner (the 1200px main
	   content container). right:0 / bottom:0 align the badge's right and
	   bottom edges with the right and bottom edges of the main content. */
	position: absolute;
	right: 0;
	bottom: 60px;
	width: 129px;
	height: 129px;
	border-radius: 50%;
	background: #0d2051;
	border: 3px solid #f5a623;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 14px;
	text-align: center;
	z-index: 2;
}
.promo-hero__badge-tag {
	font-family: 'Inter', sans-serif;
	font-weight: 700;
	font-size: 11.5px;
	letter-spacing: 2.15px;
	text-transform: uppercase;
	color: #f5a623;
}
.promo-hero__badge-text {
	font-family: 'Inter', sans-serif;
	font-weight: 700;
	font-size: 20px;
	line-height: 1.1;
	text-transform: uppercase;
	color: var(--p-text-white);
	margin: 4px 0;
}
.promo-hero__badge-stars {
	font-size: 11.5px;
	letter-spacing: 2.86px;
	color: #f5a623;
}


/* =============================================================
   VALUE GRID — "Secure Your Spot. Secure Your Home."
   ============================================================= */
.promo-value {
	background: var(--p-section-gray);
	padding: 74px var(--p-pad-x) 80px;
}
.promo-value__inner {
	max-width: var(--p-container);
	margin: 0 auto;
}
.promo-value__title {
	font-family: 'Inter', sans-serif;
	font-weight: 700;
	font-size: 48px;
	line-height: 1.1;
	color: var(--p-card);
	text-align: center;
	margin-bottom: 40px;
}
.promo-value__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 30px;
}
.promo-value__card {
	display: flex;
	align-items: center;
	gap: 32px;
	padding: 28px 30px;
	min-height: 150px;
	background: var(--p-card);
	color: var(--p-text-white);
}
.promo-value__icon {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 66px;
	height: 66px;
	border-radius: 9px;
	background: var(--p-orange);
	color: var(--p-text-white);
}
.promo-value__icon svg { width: 36px; height: 36px; }
.promo-value__card p {
	font-family: 'Work Sans', sans-serif;
	font-weight: 400;
	font-size: 25px;
	line-height: 1.3;
	color: var(--p-text-white);
}
.promo-value__card p strong { font-weight: 600; }


/* =============================================================
   SERVICES — "We Specialize In"
   ============================================================= */
.promo-services {
	background: var(--p-text-white);
	padding: 60px var(--p-pad-x) 80px;
}
.promo-services__inner {
	max-width: var(--p-container);
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 36px;
}
.promo-services__title {
	font-family: 'Inter', sans-serif;
	font-weight: 700;
	font-size: 48px;
	line-height: 1.1;
	color: var(--p-card);
	text-align: center;
}
.promo-services__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 34px;
	width: 100%;
}
.promo-service {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 18px;
	padding: 33px 28px;
	min-height: 398px;
	background: var(--p-card);
	border: 3px solid var(--p-card);
	border-radius: 17px;
	text-align: center;
}
.promo-service__body {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 20px;
	width: 100%;
}
.promo-service__icon {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100px;
	height: 100px;
	border-radius: 50%;
	background: var(--p-orange);
	color: var(--p-text-white);
}
.promo-service__icon svg,
.promo-service__icon img {
	display: block;
	width: auto;
	height: auto;
	max-width: 60px;
	max-height: 50px;
}
.promo-service__name {
	font-family: 'Inter', sans-serif;
	font-weight: 700;
	font-size: 32px;
	line-height: 1.05;
	letter-spacing: 2.8px;
	text-transform: uppercase;
	color: var(--p-orange);
	margin-top: 8px;
}
.promo-service__desc {
	font-family: 'Work Sans', sans-serif;
	font-weight: 400;
	font-size: 25px;
	line-height: 1.3;
	color: var(--p-text-white);
}

.promo-services__warn {
	font-family: 'Work Sans', sans-serif;
	font-weight: 400;
	font-size: 25px;
	color: var(--p-warn-text);
	text-align: center;
}
.promo-services__warn-icon { margin-right: 6px; filter: saturate(0.85); }

.promo-cta {
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	gap: 10px;
	padding: 60px clamp(40px, 10vw, 120px) 48px;
	border-radius: 9px;
	background: var(--p-orange);
	color: var(--p-card);
	text-align: center;
	transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.promo-cta:hover,
.promo-cta:focus-visible {
	background: var(--p-orange-hi);
	transform: translateY(-2px);
	box-shadow: 0 12px 30px rgba(0, 0, 0, 0.18);
	outline: none;
	text-decoration: none;
}
.promo-cta__line {
	font-family: 'Inter', sans-serif;
	font-weight: 500;
	font-size: 32px;
	line-height: 1.5;
	color: var(--p-card);
}
.promo-cta__phone {
	display: inline-flex;
	align-items: center;
	gap: 15px;
}
.promo-cta__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 45px;
	color: var(--p-text-white);
}
.promo-cta__icon svg { width: 100%; height: 100%; }
.promo-cta__num {
	font-family: 'Work Sans', sans-serif;
	font-weight: 600;
	font-size: 54px;
	line-height: 1;
	letter-spacing: 3px;
	text-transform: uppercase;
	color: var(--p-text-white);
}

.promo-services__area {
	font-family: 'Work Sans', sans-serif;
	font-weight: 400;
	font-size: 25px;
	color: var(--p-card);
	text-align: center;
}


/* =============================================================
   TERMS
   ============================================================= */
.promo-terms {
	background: var(--p-terms-bg);
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	padding: 36px var(--p-pad-x) 36px;
}
.promo-terms__inner {
	max-width: var(--p-container);
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 28px;
	text-align: center;
}
.promo-terms__title {
	font-family: 'Inter', sans-serif;
	font-weight: 700;
	font-size: 25px;
	line-height: 1.3;
	letter-spacing: 1px;
	text-transform: uppercase;
	color: var(--p-text-faint);
}
.promo-terms__body {
	max-width: 1010px;
	font-family: 'Work Sans', sans-serif;
	font-weight: 400;
	font-size: 17px;
	line-height: 1.5;
	color: var(--p-text-faint-3);
}

.promo-divider {
	height: 12px;
	background: var(--p-red);
}


/* =============================================================
   LOCATION
   ============================================================= */
.promo-location {
	background: var(--p-text-white);
	padding-top: 60px;
}
.promo-location__title {
	font-family: 'Inter', sans-serif;
	font-weight: 700;
	font-size: 48px;
	line-height: 1.1;
	color: var(--p-card);
	text-align: center;
	margin-bottom: 70px;
}
.promo-location__map {
	position: relative;
	width: 100%;
	height: 543px;
	background: #f0f0f0;
}
.promo-location__map iframe {
	display: block;
	width: 100%;
	height: 100%;
	border: 0;
}


/* =============================================================
   RESPONSIVE
   Breakpoints: ≤1280 (gentle scale), ≤1024 (tablet),
                ≤768 (mobile), ≤480 (small phone)
   ============================================================= */

/* ----- ≤ 1280px : gentle scale-down ----- */
@media (max-width: 1280px) {
	.promo-hero__team { font-size: clamp(56px, 6.6vw, 80px); }
	.promo-hero__free { font-size: clamp(64px, 7.6vw, 92px); }
}

/* ----- ≤ 1024px : tablet ----- */
@media (max-width: 1024px) {
	.promo-page { --p-container: 100%; }

	/* Hero */
	.promo-hero { min-height: 480px; }
	.promo-hero__inner { min-height: 480px; padding: 50px 0; }
	.promo-hero__stars { font-size: 48px; letter-spacing: 6px; margin-bottom: 18px; }
	.promo-hero__pre { font-size: 24px; }
	.promo-hero__team { font-size: clamp(48px, 8vw, 70px); }
	.promo-hero__sub { font-size: clamp(28px, 4vw, 36px); margin: 4px 0 12px; }
	.promo-hero__highlight { font-size: 18px; padding: 10px 14px; }
	.promo-hero__free { font-size: clamp(56px, 9vw, 84px); margin: 10px 0 16px; }
	.promo-hero__copy { max-width: 60%; }
	.promo-hero__features { gap: 18px; }
	.promo-hero__features li { font-size: 12px; }
	.promo-hero__badge {
		width: 110px; height: 110px;
	}
	.promo-hero__badge-text { font-size: 18px; }

	/* Section titles */
	.promo-value__title,
	.promo-services__title,
	.promo-location__title { font-size: clamp(32px, 4.5vw, 42px); }

	/* Value */
	.promo-value { padding: 60px var(--p-pad-x); }
	.promo-value__title { margin-bottom: 32px; }
	.promo-value__grid { gap: 20px; }
	.promo-value__card { padding: 22px 24px; gap: 22px; min-height: auto; }
	.promo-value__icon { width: 56px; height: 56px; }
	.promo-value__icon svg { width: 30px; height: 30px; }
	.promo-value__card p { font-size: 18px; }

	/* Services */
	.promo-services { padding: 60px var(--p-pad-x); }
	.promo-services__inner { gap: 28px; }
	.promo-services__grid { gap: 22px; }
	.promo-service { padding: 28px 22px; min-height: auto; }
	.promo-service__icon { width: 84px; height: 84px; }
	.promo-service__icon svg { width: 42px; height: 42px; }
	.promo-service__name { font-size: 24px; letter-spacing: 1.8px; }
	.promo-service__desc { font-size: 18px; }

	/* CTA */
	.promo-cta { padding: 44px clamp(40px, 8vw, 80px) 36px; gap: 8px; }
	.promo-cta__line { font-size: 24px; line-height: 1.4; }
	.promo-cta__phone { gap: 12px; }
	.promo-cta__icon { width: 34px; height: 36px; }
	.promo-cta__num { font-size: 40px; letter-spacing: 2px; }

	.promo-services__warn,
	.promo-services__area { font-size: 18px; }

	/* Terms */
	.promo-terms__title { font-size: 20px; letter-spacing: 0.8px; }
	.promo-terms__body { font-size: 15px; }

	/* Location */
	.promo-location { padding-top: 50px; }
	.promo-location__title { margin-bottom: 40px; }
	.promo-location__map { height: 460px; }
}

/* ----- ≤ 768px : mobile ----- */
@media (max-width: 768px) {
	/* Hero — stack everything; photo-veil intensifies for legibility */
	.promo-hero { min-height: auto; }
	.promo-hero__veil {
		background:
			linear-gradient(to bottom, rgba(8,22,58,0.78) 0%, rgba(8,22,58,0.55) 100%),
			linear-gradient(90deg, rgba(8,22,58,0.85) 0%, rgba(8,22,58,0.5) 100%);
	}
	.promo-hero__inner {
		min-height: auto;
		padding: 44px 0 48px;
		gap: 0;
	}
	.promo-hero__stars { font-size: 38px; letter-spacing: 5px; margin-bottom: 14px; }
	.promo-hero__copy {
		max-width: 100%;
		margin-top: 0;
		margin-bottom: 0;
		gap: 4px;
	}
	.promo-hero__pre { font-size: 20px; }
	.promo-hero__team { font-size: clamp(44px, 12vw, 60px); line-height: 0.95; }
	.promo-hero__sub { font-size: clamp(22px, 5.5vw, 28px); margin: 4px 0 10px; }
	.promo-hero__highlight { font-size: 16px; padding: 9px 12px; }
	.promo-hero__free {
		font-size: clamp(52px, 14vw, 72px);
		margin: 10px 0 14px;
		text-shadow: 2px 2px 0 rgba(0,0,0,0.4);
	}
	.promo-hero__features {
		gap: 12px;
		flex-direction: column;
		align-items: flex-start;
		margin: 4px 0 14px;
	}
	.promo-hero__features li { font-size: 12px; }
	.promo-hero__limited { font-size: 12px; letter-spacing: 2px; }

	/* Badge moves below the copy as a static centered chip */
	.promo-hero__badge {
		position: static;
		transform: none;
		margin: 22px auto 0;
		width: 110px;
		height: 110px;
	}
	.promo-hero__badge-text { font-size: 18px; }

	/* Section titles */
	.promo-value__title,
	.promo-services__title,
	.promo-location__title { font-size: clamp(28px, 6vw, 36px); }

	/* Value — single column */
	.promo-value { padding: 44px var(--p-pad-x); }
	.promo-value__title { margin-bottom: 24px; }
	.promo-value__grid { grid-template-columns: 1fr; gap: 14px; }
	.promo-value__card { padding: 20px 18px; gap: 18px; }
	.promo-value__icon { width: 50px; height: 50px; border-radius: 7px; }
	.promo-value__icon svg { width: 28px; height: 28px; }
	.promo-value__card p { font-size: 16px; line-height: 1.4; }

	/* Services — single column, icon on left + stacked text on right */
	.promo-services { padding: 44px var(--p-pad-x); }
	.promo-services__inner { gap: 24px; }
	.promo-services__grid { grid-template-columns: 1fr; gap: 14px; }
	.promo-service {
		flex-direction: row;
		align-items: center;
		text-align: left;
		padding: 22px;
		gap: 18px;
		min-height: 0;
	}
	.promo-service__icon { width: 64px; height: 64px; flex-shrink: 0; }
	.promo-service__icon svg { width: 32px; height: 32px; }
	.promo-service__body {
		flex: 1 1 auto;
		min-width: 0;
		align-items: flex-start;
		gap: 6px;
		text-align: left;
	}
	.promo-service__name {
		font-size: 20px;
		letter-spacing: 1.2px;
		margin: 0;
		text-align: left;
	}
	.promo-service__desc { font-size: 16px; line-height: 1.4; text-align: left; }
	/* Drop the figma-driven line breaks — markup has a leading space so
	   words stay separated when the <br> is removed. */
	.promo-service br { display: none; }

	/* CTA — full-width on mobile */
	.promo-cta {
		display: flex;
		width: 100%;
		padding: 30px 24px 26px;
		gap: 6px;
	}
	.promo-cta__line { font-size: 18px; line-height: 1.35; }
	.promo-cta__phone { gap: 10px; }
	.promo-cta__icon { width: 26px; height: 28px; }
	.promo-cta__num { font-size: 28px; letter-spacing: 1px; }

	.promo-services__warn,
	.promo-services__area { font-size: 15px; line-height: 1.4; }

	/* Terms */
	.promo-terms { padding: 28px var(--p-pad-x); }
	.promo-terms__inner { gap: 16px; }
	.promo-terms__title { font-size: 16px; letter-spacing: 0.5px; line-height: 1.35; }
	.promo-terms__body { font-size: 13px; line-height: 1.55; }

	/* Divider */
	.promo-divider { height: 8px; }

	/* Location */
	.promo-location { padding-top: 40px; }
	.promo-location__title { margin-bottom: 28px; }
	.promo-location__map { height: 360px; }
}

/* ----- ≤ 480px : small phone ----- */
@media (max-width: 480px) {
	.promo-page { --p-pad-x: 18px; }
	.promo-hero__pre { font-size: 18px; }
	.promo-hero__team { font-size: clamp(40px, 13vw, 52px); }
	.promo-hero__sub { font-size: 20px; }
	.promo-hero__highlight { font-size: 14px; padding: 8px 11px; }
	.promo-hero__free { font-size: clamp(48px, 15vw, 60px); }

	.promo-service {
		flex-direction: column;
		text-align: center;
		gap: 14px;
	}
	.promo-service__body { align-items: center; text-align: center; }
	.promo-service__name,
	.promo-service__desc { text-align: center; }

	.promo-cta__line { font-size: 16px; }
	.promo-cta__num { font-size: 24px; }
	.promo-cta__icon { width: 22px; height: 24px; }

	.promo-location__map { height: 320px; }
}
