/* ============================================================
   Pre-footer CTA strip
   ============================================================ */
.pre-footer {
	position: relative;
	background: linear-gradient(135deg, var(--brand-sky) 0%, #0e8ba9 100%);
	color: #fff;
	padding-block: var(--space-9);
	overflow: hidden;
	isolation: isolate;
}
/* decorative ::before removed — flat color background only */

.pre-footer__inner {
	position: relative;
	z-index: 1;
	display: grid;
	gap: var(--space-7);
	grid-template-columns: 1.2fr 1fr;
	align-items: center;
}
.pre-footer__text .eyebrow { color: var(--brand-ice); }
.pre-footer__heading {
	color: #fff;
	font-size: clamp(1.75rem, 4vw, 2.75rem);
	line-height: 1.15;
	margin-block-end: var(--space-3);
	letter-spacing: var(--tracking-tight);
}
.pre-footer__sub {
	color: rgba(255, 255, 255, 0.78);
	font-size: var(--fs-lead);
	margin: 0;
	max-width: 50ch;
}

.pre-footer__actions {
	display: flex;
	align-items: center;
	gap: var(--space-4);
	justify-self: end;
	flex-wrap: wrap;
}
.pre-footer__phone {
	display: flex;
	flex-direction: column;
	gap: 4px;
	padding: var(--space-4) var(--space-5);
	background: rgba(255, 255, 255, 0.08);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: var(--radius-lg);
	color: #fff;
	text-decoration: none;
	transition: all var(--t-base);
}
.pre-footer__phone:hover {
	color: #fff;
	background: rgba(255, 255, 255, 0.14);
	transform: translateY(-2px);
}
.pre-footer__phone-label {
	font-family: var(--font-num);
	font-size: 0.78rem;
	letter-spacing: var(--tracking-wide);
	text-transform: uppercase;
	color: var(--brand-ice);
}
.pre-footer__phone-num {
	font-family: var(--font-num);
	font-size: clamp(1.75rem, 3.2vw, 2.4rem);
	font-weight: 800;
	letter-spacing: 0.04em;
	background: linear-gradient(135deg, #ffffff 0%, var(--brand-ice) 100%);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}

@media (max-width: 820px) {
	.pre-footer__inner { grid-template-columns: 1fr; text-align: center; }
	.pre-footer__actions { justify-self: center; }
	.pre-footer__text .eyebrow { justify-content: center; }
}

/* ============================================================
   Site footer — clean cyan band with subtle decoration
   ============================================================ */
.site-footer {
	position: relative;
	background: linear-gradient(180deg, var(--brand-sky) 0%, #0f9fc4 100%);
	color: rgba(255, 255, 255, 0.92);
	padding-block: var(--space-7) var(--space-4);
	overflow: hidden;
	isolation: isolate;
}
.site-footer::before {
	content: '';
	position: absolute;
	inset-block-start: 0;
	inset-inline: 0;
	height: 1px;
	background: linear-gradient(90deg,
		transparent 0%,
		rgba(255, 255, 255, 0.6) 50%,
		transparent 100%);
}
.site-footer::after {
	content: '';
	position: absolute;
	inset-block-end: -120px;
	inset-inline-start: -120px;
	width: 320px;
	height: 320px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.12);
	filter: blur(80px);
	pointer-events: none;
	z-index: 0;
}
.site-footer a { color: inherit; transition: color var(--t-fast); }
.site-footer a:hover { color: #fff; }
.site-footer .container { position: relative; z-index: 1; }

/* ---------- Columns ---------- */
.site-footer__grid {
	display: grid;
	gap: var(--space-5);
	grid-template-columns: 1.2fr 1fr;
	align-items: center;
}
@media (max-width: 720px) {
	.site-footer__grid { grid-template-columns: 1fr; gap: var(--space-4); text-align: center; }
}

/* About column — centered logo + socials, no description text */
.site-footer__col--about {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: var(--space-4);
}
.site-footer__logo { display: flex; justify-content: center; }
.site-footer__logo img {
	max-height: 72px;
	width: auto;
	filter: brightness(0) invert(1);
}

.site-footer__title {
	color: #fff;
	font-family: var(--font-num);
	font-size: 0.82rem;
	letter-spacing: var(--tracking-wide);
	text-transform: uppercase;
	margin-block-end: var(--space-4);
	font-weight: 700;
	display: inline-flex;
	align-items: center;
	gap: 8px;
}
.site-footer__title::before {
	content: '';
	width: 20px;
	height: 2px;
	background: var(--g-sky);
}

.site-footer__links,
.site-footer__contact {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.site-footer__links a,
.site-footer__contact li { font-size: 0.93rem; }
.site-footer__contact li { display: flex; align-items: flex-start; gap: 10px; color: rgba(255, 255, 255, 0.75); }
.site-footer__contact a { font-weight: 500; }

.site-footer__socials {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	gap: var(--space-2);
	justify-content: center;
}
.site-footer__socials a {
	width: 38px; height: 38px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: rgba(255, 255, 255, 0.18);
	border: 1px solid rgba(255, 255, 255, 0.32);
	border-radius: var(--radius-pill);
	color: #fff;
	transition: all var(--t-base);
	font-size: 15px;
}
.site-footer__socials a:hover {
	background: #fff;
	color: var(--brand-sky);
	border-color: #fff;
	transform: translateY(-3px) scale(1.06);
}
.site-footer__socials a > span {
	margin: 0;
}

/* ============================================================
   Footer contact — soft glass card on cyan background
   ============================================================ */
.footer-contact {
	padding: var(--space-5) var(--space-5);
	background: rgba(255, 255, 255, 0.12);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	border: 1px solid rgba(255, 255, 255, 0.22);
	border-radius: var(--radius-lg);
	box-shadow: 0 12px 28px -16px rgba(0, 0, 0, 0.18);
}
.footer-contact__heading {
	color: #fff;
	font-size: 1.15rem;
	font-weight: 800;
	letter-spacing: var(--tracking-tight);
	margin: 0 0 var(--space-4);
	padding-block-end: var(--space-3);
	border-block-end: 1px solid rgba(255, 255, 255, 0.25);
}

.footer-contact__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}
.footer-contact__item {
	display: flex;
	gap: var(--space-3);
	align-items: center;
}
.footer-contact__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: 10px;
	background: rgba(255, 255, 255, 0.2);
	color: #fff;
	flex-shrink: 0;
	transition: background var(--t-fast);
}
.footer-contact__icon .icon { margin: 0; font-size: 16px; }
.footer-contact__item:hover .footer-contact__icon { background: rgba(255, 255, 255, 0.35); }
.footer-contact__body {
	display: flex;
	flex-direction: column;
	gap: 1px;
	min-width: 0;
}
.footer-contact__label {
	font-size: 0.7rem;
	letter-spacing: 0.04em;
	color: rgba(255, 255, 255, 0.78);
	font-weight: 600;
}
.footer-contact__link,
.footer-contact__text {
	color: #fff;
	font-weight: 700;
	font-size: 0.95rem;
	word-break: break-word;
}
.footer-contact__link:hover { color: rgba(255, 255, 255, 0.85); }
.footer-contact__link--big {
	font-size: 1.15rem;
	font-weight: 900;
	letter-spacing: 0.04em;
	color: #fff;
}

.footer-contact__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	width: 100%;
	padding: 8px 14px;
	background: var(--color-wa);
	color: #fff;
	border-radius: var(--radius-pill);
	font-weight: 700;
	font-size: 0.8rem;
	transition: background var(--t-base);
}
.footer-contact__cta:hover {
	background: #1ebe57;
	color: #fff;
}
.footer-contact__cta .icon { font-size: 14px; margin: 0; }

/* ============================================================
   Bottom bar — single centered copyright line on a deeper cyan
   ============================================================ */
.site-footer-bottom {
	background: #0c8aab;
	color: rgba(255, 255, 255, 0.85);
	padding-block: var(--space-3);
	font-size: 0.8rem;
	text-align: center;
}
.site-footer-bottom__text { margin: 0; letter-spacing: 0.01em; }

/* ============================================================
   Floating WhatsApp button
   ============================================================ */
.wa-float {
	position: fixed;
	inset-block-end: 24px;
	width: 58px;
	height: 58px;
	background: var(--color-wa);
	color: #fff;
	border-radius: var(--radius-pill);
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 12px 32px -8px rgba(37, 211, 102, 0.55);
	z-index: 40;
	transition: transform var(--t-base), box-shadow var(--t-base);
}
.wa-float::before {
	content: '';
	position: absolute;
	inset: -4px;
	border-radius: inherit;
	background: var(--color-wa);
	opacity: 0.35;
	animation: wa-pulse 2.4s var(--ease-in-out) infinite;
	z-index: -1;
}
@keyframes wa-pulse {
	0%   { transform: scale(1);   opacity: 0.45; }
	100% { transform: scale(1.5); opacity: 0; }
}
.wa-float:hover { color: #fff; transform: scale(1.08); }
.wa-float--end   { inset-inline-end: 24px; }
.wa-float--start { inset-inline-start: 24px; }
.wa-float .icon  { font-size: 30px; margin: 0; }

@media (prefers-reduced-motion: reduce) { .wa-float::before { animation: none; } }
