/* UV-DTF Homepage v0.18.0 — namespace .uvdtf-home__* + .uvdtf-pagehead__* + .uvdtf-footer__* */

/* Smooth scroll to anchors + offset for sticky header */
html { scroll-behavior: smooth; }
#contact { scroll-margin-top: 100px; }

/* ===== Hide XStore default footer (we render our own) ===== */
.prefooter,
.et-footers-wrapper,
body > footer.footer.text-color-dark,
.site-footer-wrapper,
.copyrights-wrapper {
	display: none !important;
}

/* ===== Site Footer (rendered by class-footer.php) ===== */
.uvdtf-footer {
	background: linear-gradient(180deg, #1e1b4b 0%, #0f172a 100%);
	color: rgba(255,255,255,.85);
	padding: 56px 0 0;
	margin-top: 60px;
	font-size: 15px;
	line-height: 1.6;
}
.uvdtf-footer * { box-sizing: border-box; }
.uvdtf-footer__container {
	max-width: 1240px;
	margin: 0 auto;
	padding: 0 20px;
}
.uvdtf-footer__grid {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1.2fr 1.2fr;
	gap: 40px;
	padding-bottom: 40px;
	border-bottom: 1px solid rgba(255,255,255,.1);
}
.uvdtf-footer__col h4,
.uvdtf-footer__heading {
	color: #fff;
	font-size: 14px;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	margin: 0 0 18px;
}
.uvdtf-footer__logo-link {
	display: inline-flex;
	align-items: center;
	gap: 14px;
	text-decoration: none !important;
	margin: 0 0 18px;
	color: #fff !important;
}
.uvdtf-footer__logo-img {
	width: 80px;
	height: 80px;
	display: block;
	flex-shrink: 0;
	/* Інверсія: темно-фіолетове лого хедера → світле на темному фоні футера */
	filter: invert(1) hue-rotate(180deg) brightness(1.6);
}
.uvdtf-footer__logo-text {
	font-size: 24px;
	font-weight: 800;
	color: #fff;
	line-height: 1;
	letter-spacing: -.01em;
}
.uvdtf-footer__logo-text small {
	display: block;
	margin-top: 6px;
	font-size: 13px;
	font-weight: 600;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: rgba(255,255,255,.7);
}
.uvdtf-footer__social {
	display: flex;
	gap: 10px;
	margin-top: 18px;
}
.uvdtf-footer__social a {
	width: 40px;
	height: 40px;
	display: grid;
	place-items: center;
	background: rgba(255,255,255,.08);
	border: 1px solid rgba(255,255,255,.14);
	border-radius: 50%;
	color: #fff !important;
	text-decoration: none !important;
	transition: background .15s ease, transform .15s ease, border-color .15s ease;
}
.uvdtf-footer__social a:hover {
	background: linear-gradient(135deg, #6d28d9, #9333ea);
	border-color: transparent;
	transform: translateY(-2px);
	color: #fff !important;
}
.uvdtf-footer__social svg { display: block; }
.uvdtf-footer__desc {
	color: rgba(255,255,255,.7);
	margin: 0 0 20px;
	font-size: 14px;
}
.uvdtf-footer__messengers {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
.uvdtf-footer__messengers a {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 14px;
	background: rgba(255,255,255,.08);
	border: 1px solid rgba(255,255,255,.12);
	border-radius: 99px;
	color: #fff !important;
	font-size: 13px;
	font-weight: 600;
	text-decoration: none !important;
	transition: background .12s ease, border-color .12s ease;
}
.uvdtf-footer__messengers a:hover {
	background: rgba(255,255,255,.16);
	border-color: rgba(255,255,255,.25);
}
.uvdtf-footer__messengers svg {
	color: #fbbf24;
	flex-shrink: 0;
}
.uvdtf-footer__links {
	list-style: none;
	padding: 0;
	margin: 0;
}
.uvdtf-footer__links li {
	margin: 0 0 10px;
}
.uvdtf-footer__links a {
	color: rgba(255,255,255,.75) !important;
	text-decoration: none !important;
	font-size: 14px;
	transition: color .12s ease;
}
.uvdtf-footer__links a:hover {
	color: #fbbf24 !important;
}
.uvdtf-footer__contacts {
	list-style: none;
	padding: 0;
	margin: 0;
}
.uvdtf-footer__contacts li {
	margin: 0 0 14px;
}
.uvdtf-footer__contact-label {
	display: block;
	color: rgba(255,255,255,.5);
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .04em;
	margin-bottom: 2px;
}
.uvdtf-footer__contacts a {
	color: #fff !important;
	text-decoration: none !important;
	font-weight: 600;
	font-size: 15px;
	transition: color .12s ease;
}
.uvdtf-footer__contacts a:hover {
	color: #fbbf24 !important;
}
.uvdtf-footer__address {
	font-style: normal;
	color: #fff;
	margin: 0 0 14px;
	font-size: 14px;
	line-height: 1.55;
}
.uvdtf-footer__hours {
	color: rgba(255,255,255,.75);
	font-size: 14px;
	margin: 0;
}
.uvdtf-footer__hours strong { color: #fff; }
.uvdtf-footer__hours small {
	color: rgba(255,255,255,.55);
	display: block;
	margin-bottom: 6px;
}
.uvdtf-footer__bottom {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	justify-content: space-between;
	align-items: center;
	padding: 22px 0;
	font-size: 13px;
	color: rgba(255,255,255,.5);
}
.uvdtf-footer__copyright { margin: 0; }
.uvdtf-footer__legal {
	margin: 0;
	display: flex;
	gap: 10px;
	align-items: center;
	flex-wrap: wrap;
}
.uvdtf-footer__legal a {
	color: rgba(255,255,255,.65) !important;
	text-decoration: none !important;
	font-size: 13px;
}
.uvdtf-footer__legal a:hover { color: #fff !important; }
.uvdtf-footer__legal span { color: rgba(255,255,255,.3); }

@media (max-width: 900px) {
	.uvdtf-footer__grid { grid-template-columns: 1fr 1fr; gap: 32px; }
	.uvdtf-footer__col--brand { grid-column: 1 / -1; }
}
@media (max-width: 560px) {
	.uvdtf-footer__grid { grid-template-columns: 1fr; gap: 28px; }
	.uvdtf-footer__bottom { flex-direction: column; text-align: center; }
}



/* ===== Page Header (UV-DTF, DTF inner pages) ===== */
.uvdtf-pagehead {
	max-width: 1240px;
	margin: 0 auto 32px;
	padding: 32px 16px 8px;
	text-align: center;
}
.uvdtf-pagehead__eyebrow {
	display: inline-block;
	background: linear-gradient(135deg, #6d28d9 0%, #9333ea 100%);
	color: #fff;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	padding: 5px 12px;
	border-radius: 99px;
	margin: 0 0 14px;
}
.uvdtf-pagehead__title {
	font-size: clamp(26px, 3.8vw, 42px);
	font-weight: 800;
	line-height: 1.15;
	letter-spacing: -.01em;
	margin: 0 0 12px;
	color: #0f172a;
}
.uvdtf-pagehead__sub {
	font-size: clamp(15px, 1.6vw, 17px);
	color: #64748b;
	max-width: 760px;
	margin: 0 auto;
	line-height: 1.55;
}
@media (max-width: 600px) {
	.uvdtf-pagehead { padding: 20px 16px 4px; margin-bottom: 24px; }
}

.uvdtf-home {
	--uh-primary: #6d28d9;
	--uh-primary-dark: #5b21b6;
	--uh-accent: #f59e0b;
	--uh-accent-hover: #d97706;
	--uh-text: #0f172a;
	--uh-text-muted: #64748b;
	--uh-bg: #f8fafc;
	--uh-bg-alt: #ffffff;
	--uh-border: #e5e7eb;
	--uh-radius: 14px;
	--uh-radius-sm: 10px;
	--uh-shadow: 0 4px 24px rgba(15, 23, 42, 0.06);
	--uh-shadow-lg: 0 10px 40px rgba(109, 40, 217, 0.12);
	color: var(--uh-text);
	line-height: 1.55;
	font-size: 16px;
}
.uvdtf-home * { box-sizing: border-box; }
.uvdtf-home h1, .uvdtf-home h2, .uvdtf-home h3 {
	color: var(--uh-text);
	line-height: 1.2;
	margin: 0 0 .6em;
	font-weight: 700;
}
.uvdtf-home h2 { font-size: clamp(24px, 3vw, 34px); }
.uvdtf-home h3 { font-size: clamp(18px, 2vw, 22px); }
.uvdtf-home p  { margin: 0 0 1em; color: var(--uh-text); }
.uvdtf-home a  { color: var(--uh-primary); text-decoration: none; }
.uvdtf-home a:hover { text-decoration: underline; }

.uvdtf-home__section {
	padding: 64px 0;
}
.uvdtf-home__section--alt { background: var(--uh-bg); }
.uvdtf-home__container {
	max-width: 1180px;
	margin: 0 auto;
	padding: 0 20px;
}
.uvdtf-home__eyebrow {
	color: var(--uh-primary);
	font-weight: 600;
	font-size: 13px;
	text-transform: uppercase;
	letter-spacing: .08em;
	margin: 0 0 8px;
}
.uvdtf-home__lead {
	color: var(--uh-text-muted);
	font-size: 17px;
	max-width: 720px;
}
.uvdtf-home__section-head {
	text-align: center;
	max-width: 760px;
	margin: 0 auto 40px;
}
.uvdtf-home__section-head .uvdtf-home__lead { margin: 0 auto; }

/* ===== HERO ===== */
.uvdtf-home__hero {
	position: relative;
	background:
		radial-gradient(60% 80% at 90% 10%, rgba(245, 158, 11, .15), transparent 60%),
		linear-gradient(135deg, #faf5ff 0%, #ede9fe 100%);
	padding: 72px 0 80px;
	overflow: hidden;
}
.uvdtf-home__hero-grid {
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: 56px;
	align-items: center;
}
.uvdtf-home__hero h1 {
	font-size: clamp(30px, 4vw, 48px);
	line-height: 1.1;
	margin: 0 0 16px;
	font-weight: 800;
	letter-spacing: -.01em;
}
.uvdtf-home__hero h1 mark {
	background: linear-gradient(120deg, #f59e0b 0%, #fbbf24 100%);
	color: #fff;
	padding: 0 .25em;
	border-radius: 6px;
}
.uvdtf-home__hero-sub {
	font-size: 18px;
	color: var(--uh-text-muted);
	margin: 0 0 28px;
	max-width: 540px;
}
.uvdtf-home__cta-row {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin: 0 0 28px;
}
.uvdtf-home__btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 14px 26px;
	border-radius: var(--uh-radius);
	font-weight: 600;
	font-size: 16px;
	text-decoration: none !important;
	transition: transform .12s ease, box-shadow .12s ease, background .12s ease;
	border: none;
	cursor: pointer;
	line-height: 1;
}
.uvdtf-home__btn--primary {
	background: linear-gradient(135deg, var(--uh-primary) 0%, #9333ea 100%);
	color: #fff !important;
	box-shadow: 0 6px 20px rgba(109, 40, 217, .35);
}
.uvdtf-home__btn--primary:hover {
	transform: translateY(-2px);
	box-shadow: 0 10px 28px rgba(109, 40, 217, .45);
	color: #fff !important;
}
.uvdtf-home__btn--secondary {
	background: #fff;
	color: var(--uh-primary) !important;
	border: 2px solid var(--uh-primary);
}
.uvdtf-home__btn--secondary:hover {
	background: var(--uh-primary);
	color: #fff !important;
	transform: translateY(-2px);
}
.uvdtf-home__btn--accent {
	background: linear-gradient(135deg, var(--uh-accent), #fb923c);
	color: #fff !important;
	box-shadow: 0 6px 20px rgba(245, 158, 11, .35);
}
.uvdtf-home__btn--accent:hover {
	transform: translateY(-2px);
	color: #fff !important;
}

.uvdtf-home__trust {
	display: flex;
	flex-wrap: wrap;
	gap: 28px;
}
.uvdtf-home__trust-item {
	font-size: 14px;
	color: var(--uh-text-muted);
	display: flex;
	align-items: center;
	gap: 8px;
}
.uvdtf-home__trust-item strong {
	color: var(--uh-text);
	font-size: 20px;
	font-weight: 700;
}
.uvdtf-home__trust-icon {
	width: 22px;
	height: 22px;
	color: var(--uh-primary);
	flex-shrink: 0;
}

.uvdtf-home__hero-visual {
	position: relative;
	min-height: 360px;
}
.uvdtf-home__hero-img {
	width: 100%;
	border-radius: 24px;
	box-shadow: var(--uh-shadow-lg);
	display: block;
	aspect-ratio: 4 / 3;
	object-fit: cover;
	background: #f3e8ff;
}
.uvdtf-home__hero-badge {
	position: absolute;
	background: #fff;
	border-radius: var(--uh-radius);
	box-shadow: var(--uh-shadow);
	padding: 14px 18px;
	display: flex;
	align-items: center;
	gap: 12px;
	font-size: 14px;
	font-weight: 600;
}
.uvdtf-home__hero-badge--tl { top: -14px; left: -14px; }
.uvdtf-home__hero-badge--br { bottom: -14px; right: -14px; }
.uvdtf-home__hero-badge-icon {
	width: 36px; height: 36px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--uh-primary), #9333ea);
	color: #fff;
	display: grid; place-items: center;
	font-size: 18px;
}

/* ===== SERVICES (2 cards) ===== */
.uvdtf-home__services-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px;
}
.uvdtf-home__service {
	background: #fff;
	border: 1px solid var(--uh-border);
	border-radius: var(--uh-radius);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: transform .15s ease, box-shadow .15s ease;
}
.uvdtf-home__service:hover {
	transform: translateY(-4px);
	box-shadow: var(--uh-shadow-lg);
	border-color: var(--uh-primary);
}
.uvdtf-home__service-media {
	aspect-ratio: 16 / 10;
	background: #f3e8ff;
	position: relative;
	overflow: hidden;
}
.uvdtf-home__service-media img {
	width: 100%; height: 100%; object-fit: cover;
}

/* === Slider for service cards (auto-rotate + dots) ===
   Простий: будь-який <div class="uvdtf-slider"> з кількома <img> всередині
   стає авто-каруселлю. Додавати фото — просто додавай нові <img> у код. */
.uvdtf-slider {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	overflow: hidden;
}
.uvdtf-slider img {
	position: absolute;
	inset: 0;
	width: 100% !important;
	height: 100% !important;
	object-fit: cover;
	opacity: 0;
	transition: opacity 0.7s ease;
}
.uvdtf-slider img.is-active { opacity: 1; }
.uvdtf-slider img:first-child { opacity: 1; }  /* fallback if JS not loaded */
.uvdtf-slider__dots {
	position: absolute;
	bottom: 12px;
	left: 0;
	right: 0;
	display: flex;
	justify-content: center;
	gap: 6px;
	z-index: 3;
	pointer-events: none;
}
.uvdtf-slider__dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.55);
	border: 1px solid rgba(0, 0, 0, 0.15);
	cursor: pointer;
	padding: 0;
	transition: background 0.2s ease, transform 0.2s ease;
	pointer-events: auto;
}
.uvdtf-slider__dot:hover { transform: scale(1.2); }
.uvdtf-slider__dot.is-active {
	background: #fff;
	box-shadow: 0 0 0 2px rgba(124, 58, 237, 0.6);
}
.uvdtf-slider__nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 3;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.85);
	border: 0;
	color: #4c1d95;
	font-size: 18px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	transition: opacity 0.2s ease, background 0.2s ease;
}
.uvdtf-slider:hover .uvdtf-slider__nav { opacity: 1; }
.uvdtf-slider__nav:hover { background: #fff; }
.uvdtf-slider__nav--prev { left: 10px; }
.uvdtf-slider__nav--next { right: 10px; }
@media (max-width: 600px) {
	.uvdtf-slider__nav { display: none; }
}
.uvdtf-home__service-tag {
	position: absolute;
	top: 16px; left: 16px;
	background: rgba(255,255,255,.95);
	backdrop-filter: blur(6px);
	border-radius: 99px;
	padding: 6px 14px;
	font-size: 12px;
	font-weight: 700;
	color: var(--uh-primary);
	text-transform: uppercase;
	letter-spacing: .04em;
}
.uvdtf-home__service-body {
	padding: 24px;
	flex-grow: 1;
	display: flex;
	flex-direction: column;
}
.uvdtf-home__service h3 { margin-bottom: 8px; }
.uvdtf-home__service-desc {
	color: var(--uh-text-muted);
	margin-bottom: 16px;
}
.uvdtf-home__service-list {
	list-style: none;
	padding: 0;
	margin: 0 0 20px;
}
.uvdtf-home__service-list li {
	padding: 6px 0 6px 28px;
	position: relative;
	font-size: 15px;
}
.uvdtf-home__service-list li::before {
	content: "";
	position: absolute;
	left: 0; top: 12px;
	width: 18px; height: 18px;
	background: var(--uh-primary);
	mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='currentColor' d='M9 16.17 4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z'/></svg>") no-repeat center / contain;
}
.uvdtf-home__service-price {
	margin-top: auto;
	padding-top: 16px;
	border-top: 1px solid var(--uh-border);
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 12px;
}
.uvdtf-home__service-price-value {
	font-size: 22px;
	font-weight: 700;
	color: var(--uh-text);
}
.uvdtf-home__service-price-value span {
	font-size: 13px;
	font-weight: 500;
	color: var(--uh-text-muted);
}

/* ===== WHY (4 features) ===== */
.uvdtf-home__why-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 20px;
}
.uvdtf-home__feature {
	background: #fff;
	border: 1px solid var(--uh-border);
	border-radius: var(--uh-radius);
	padding: 24px;
	text-align: center;
	transition: transform .15s ease, border-color .15s ease;
}
.uvdtf-home__feature:hover {
	transform: translateY(-2px);
	border-color: var(--uh-primary);
}
.uvdtf-home__feature-icon {
	width: 56px; height: 56px;
	margin: 0 auto 14px;
	border-radius: 16px;
	display: grid; place-items: center;
	background: linear-gradient(135deg, #f3e8ff, #ede9fe);
	color: var(--uh-primary);
	font-size: 26px;
}
.uvdtf-home__feature h3 {
	font-size: 17px;
	margin-bottom: 8px;
}
.uvdtf-home__feature p {
	color: var(--uh-text-muted);
	font-size: 14px;
	margin: 0;
}

/* ===== COMPARE TABLE ===== */
.uvdtf-home__compare {
	background: #fff;
	border: 1px solid var(--uh-border);
	border-radius: var(--uh-radius);
	box-shadow: var(--uh-shadow);
	overflow: hidden;
	font-size: 15px;
	line-height: 1.5;
}
.uvdtf-home__compare-row {
	display: grid;
	grid-template-columns: minmax(140px, 24%) 1fr 1fr;
	align-items: stretch;
	border-bottom: 1px solid var(--uh-border);
}
.uvdtf-home__compare-row:last-child { border-bottom: 0; }
.uvdtf-home__compare-row > div {
	padding: 14px 18px;
	text-align: left;
	color: var(--uh-text);
	word-wrap: break-word;
	overflow-wrap: break-word;
	display: flex;
	align-items: center;
}
.uvdtf-home__compare-row--head > div {
	padding: 16px 18px;
	font-weight: 700;
	color: #fff;
	justify-content: center;
	text-align: center;
	font-size: 15px;
	letter-spacing: .02em;
}
.uvdtf-home__compare-row--head > div:nth-child(1) {
	background: #0f172a;
}
.uvdtf-home__compare-row--head > div:nth-child(2),
.uvdtf-home__compare-row--head > div:nth-child(3) {
	background: linear-gradient(135deg, var(--uh-primary) 0%, #9333ea 100%);
}
.uvdtf-home__compare-row--head > div:nth-child(2) {
	border-right: 1px solid rgba(255,255,255,.18);
}
.uvdtf-home__compare-label {
	font-weight: 600;
	background: var(--uh-bg);
	color: var(--uh-text);
}

/* ===== PROCESS (4 steps) ===== */
.uvdtf-home__steps {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 24px;
	position: relative;
}
.uvdtf-home__step {
	background: #fff;
	border: 1px solid var(--uh-border);
	border-radius: var(--uh-radius);
	padding: 28px 22px;
	text-align: center;
	position: relative;
}
.uvdtf-home__step-num {
	width: 44px; height: 44px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--uh-primary), #9333ea);
	color: #fff;
	font-weight: 700;
	font-size: 18px;
	display: grid; place-items: center;
	margin: 0 auto 14px;
	box-shadow: 0 4px 14px rgba(109, 40, 217, .3);
}
.uvdtf-home__step h3 {
	font-size: 17px;
	margin-bottom: 8px;
}
.uvdtf-home__step p {
	color: var(--uh-text-muted);
	font-size: 14px;
	margin: 0;
}

/* ===== GALLERY (mosaic) ===== */
.uvdtf-home__gallery {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 12px;
}
.uvdtf-home__gallery-item {
	aspect-ratio: 1;
	overflow: hidden;
	border-radius: var(--uh-radius-sm);
	position: relative;
	background: #f3e8ff;
}
.uvdtf-home__gallery-item img {
	width: 100%; height: 100%; object-fit: cover;
	transition: transform .3s ease;
}
.uvdtf-home__gallery-item:hover img { transform: scale(1.05); }
.uvdtf-home__gallery-item--lg {
	grid-column: span 2;
	grid-row: span 2;
	aspect-ratio: 1;
}

/* ===== FAQ (mini) ===== */
.uvdtf-home__faq-list {
	max-width: 820px;
	margin: 0 auto;
}
.uvdtf-home__faq-item {
	background: #fff;
	border: 1px solid var(--uh-border);
	border-radius: var(--uh-radius-sm);
	margin-bottom: 12px;
	overflow: hidden;
}
.uvdtf-home__faq-item[open] {
	border-color: var(--uh-primary);
	box-shadow: var(--uh-shadow);
}
.uvdtf-home__faq-item summary {
	padding: 18px 24px;
	cursor: pointer;
	font-weight: 600;
	color: var(--uh-text);
	font-size: 16px;
	position: relative;
	list-style: none;
	padding-right: 50px;
}
.uvdtf-home__faq-item summary::-webkit-details-marker { display: none; }
.uvdtf-home__faq-item summary::after {
	content: "+";
	position: absolute;
	right: 20px; top: 50%;
	transform: translateY(-50%);
	width: 28px; height: 28px;
	background: var(--uh-bg);
	border-radius: 50%;
	color: var(--uh-primary);
	font-size: 20px;
	font-weight: 700;
	display: grid; place-items: center;
	transition: transform .15s ease;
}
.uvdtf-home__faq-item[open] summary::after {
	content: "−";
	background: var(--uh-primary);
	color: #fff;
}
.uvdtf-home__faq-body {
	padding: 0 24px 20px;
	color: var(--uh-text-muted);
	font-size: 15px;
	line-height: 1.6;
}
.uvdtf-home__faq-body :last-child { margin-bottom: 0; }

/* ===== CONTACTS ===== */
.uvdtf-home__contacts {
	background: linear-gradient(135deg, #1e1b4b 0%, #4c1d95 100%);
	color: #fff;
	border-radius: var(--uh-radius);
	padding: 48px;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px;
}
.uvdtf-home__contacts h2 {
	color: #fff;
	font-size: clamp(24px, 3vw, 30px);
}
.uvdtf-home__contacts p { color: rgba(255,255,255,.85); }
.uvdtf-home__contacts-list {
	list-style: none;
	padding: 0;
	margin: 20px 0 0;
}
.uvdtf-home__contacts-list li {
	padding: 10px 0 10px 36px;
	position: relative;
	color: rgba(255,255,255,.95);
}
.uvdtf-home__contacts-list li a {
	color: #fcd34d !important;
	font-weight: 600;
}
.uvdtf-home__contacts-list li a:hover {
	color: #fbbf24 !important;
}
.uvdtf-home__contacts-list-icon {
	position: absolute;
	left: 0; top: 12px;
	width: 22px; height: 22px;
	color: #fbbf24;
}
.uvdtf-home__messengers {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
	margin-top: 16px;
}
.uvdtf-home__messengers a {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 18px;
	background: rgba(255,255,255,.1);
	border: 1px solid rgba(255,255,255,.2);
	border-radius: 99px;
	color: #fff !important;
	font-size: 14px;
	font-weight: 600;
	transition: background .12s ease;
}
.uvdtf-home__messengers a:hover {
	background: rgba(255,255,255,.2);
	text-decoration: none;
}

/* ===== RESPONSIVE ===== */
@media (max-width: 900px) {
	.uvdtf-home__hero-grid { grid-template-columns: 1fr; gap: 36px; }
	.uvdtf-home__hero-visual { min-height: 0; }
	.uvdtf-home__services-grid { grid-template-columns: 1fr; }
	.uvdtf-home__why-grid { grid-template-columns: repeat(2, 1fr); }
	.uvdtf-home__steps { grid-template-columns: repeat(2, 1fr); }
	.uvdtf-home__gallery { grid-template-columns: repeat(3, 1fr); }
	.uvdtf-home__gallery-item--lg { grid-column: span 2; grid-row: span 2; }
	.uvdtf-home__contacts { grid-template-columns: 1fr; padding: 32px 24px; }
	.uvdtf-home__compare { font-size: 14px; }
	.uvdtf-home__compare-row { grid-template-columns: minmax(110px, 30%) 1fr 1fr; }
	.uvdtf-home__compare-row > div { padding: 12px 14px; }
}
@media (max-width: 560px) {
	.uvdtf-home__compare-row { grid-template-columns: 1fr 1fr; }
	.uvdtf-home__compare-row .uvdtf-home__compare-label {
		grid-column: 1 / -1;
		background: var(--uh-primary);
		color: #fff;
		justify-content: center;
		text-align: center;
		font-weight: 700;
	}
	.uvdtf-home__compare-row--head { grid-template-columns: 1fr 1fr; }
	.uvdtf-home__compare-row--head > div:nth-child(1) { display: none; }
}
@media (max-width: 560px) {
	.uvdtf-home__section { padding: 48px 0; }
	.uvdtf-home__why-grid { grid-template-columns: 1fr; }
	.uvdtf-home__steps { grid-template-columns: 1fr; }
	.uvdtf-home__gallery { grid-template-columns: repeat(2, 1fr); }
	.uvdtf-home__hero-badge { padding: 10px 14px; font-size: 13px; }
	.uvdtf-home__hero-badge-icon { width: 30px; height: 30px; font-size: 15px; }
	.uvdtf-home__btn { width: 100%; justify-content: center; }
	.uvdtf-home__cta-row { flex-direction: column; }
}

/* === ZSU support banner — bright ribbon ================================== */
.uvdtf-home__zsu {
	position: relative;
	padding: 36px 0;
	background: linear-gradient(90deg, #0057b7 0%, #0057b7 50%, #ffd700 50%, #ffd700 100%);
	overflow: hidden;
	box-shadow: inset 0 6px 14px rgba(0,0,0,0.12), inset 0 -6px 14px rgba(0,0,0,0.12);
}
.uvdtf-home__zsu::before,
.uvdtf-home__zsu::after {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	height: 6px;
	background: repeating-linear-gradient(
		45deg,
		#ffd700 0 14px,
		#0057b7 14px 28px
	);
}
.uvdtf-home__zsu::before { top: 0; }
.uvdtf-home__zsu::after  { bottom: 0; }
.uvdtf-home__zsu-card {
	position: relative;
	display: flex;
	align-items: center;
	gap: 22px;
	padding: 22px 28px;
	background: rgba(0,0,0,0.78);
	border-radius: 16px;
	color: #fff;
	box-shadow: 0 10px 30px rgba(0,0,0,0.35);
	border: 2px solid #ffd700;
}
.uvdtf-home__zsu-flag {
	font-size: 3em;
	line-height: 1;
	flex-shrink: 0;
	animation: uvdtfZsuPulse 2.4s ease-in-out infinite;
	text-shadow: 0 0 18px rgba(255, 215, 0, 0.55);
}
.uvdtf-home__zsu-logo {
	width: 80px;
	height: auto;
	flex-shrink: 0;
	display: block;
	filter: drop-shadow(0 0 14px rgba(255, 215, 0, 0.55));
	animation: uvdtfZsuPulse 2.4s ease-in-out infinite;
}
@keyframes uvdtfZsuPulse {
	0%, 100% { transform: scale(1); }
	50%      { transform: scale(1.12); }
}
.uvdtf-home__zsu-text {
	flex: 1;
	min-width: 0;
}
.uvdtf-home__zsu-text strong {
	display: block;
	font-size: 1.45em;
	line-height: 1.2;
	margin-bottom: 6px;
	color: #ffd700;
	letter-spacing: 0.2px;
}
.uvdtf-home__zsu-text p {
	margin: 0;
	font-size: 1em;
	color: #fff;
	opacity: 0.95;
	line-height: 1.5;
}
.uvdtf-home__zsu .uvdtf-home__btn--primary {
	background: #0057b7;
	color: #fff;
	border-color: #0057b7;
	font-weight: 700;
	flex-shrink: 0;
	box-shadow: 0 0 0 0 rgba(0, 87, 183, 0.85);
	animation: uvdtfZsuGlow 2.4s ease-in-out infinite;
}
@keyframes uvdtfZsuGlow {
	0%, 100% { box-shadow: 0 0 0 0 rgba(0, 87, 183, 0.85); }
	50%      { box-shadow: 0 0 0 16px rgba(0, 87, 183, 0); }
}
.uvdtf-home__zsu .uvdtf-home__btn--primary:hover {
	background: #003a87;
	color: #ffd700;
	border-color: #003a87;
	animation: none;
	transform: translateY(-1px);
}
@media (max-width: 800px) {
	.uvdtf-home__zsu { padding: 28px 0; }
	.uvdtf-home__zsu-card {
		flex-direction: column;
		text-align: center;
		gap: 14px;
		padding: 20px 16px;
	}
	.uvdtf-home__zsu-text strong { font-size: 1.2em; }
	.uvdtf-home__zsu .uvdtf-home__btn--primary { width: 100%; }
}
@media (prefers-reduced-motion: reduce) {
	.uvdtf-home__zsu-flag,
	.uvdtf-home__zsu-logo,
	.uvdtf-home__zsu .uvdtf-home__btn--primary { animation: none; }
}
