/*
Theme Name: ZaQuadownia
Theme URI: https://zaquadownia.pl
Author: ZaQuadownia
Description: Blokowy (FSE) motyw wypożyczalni quadów. Ciemny, terenowy styl z pomarańczowym akcentem.
Version: 0.1.0
Requires at least: 6.5
Tested up to: 6.5
Requires PHP: 8.0
Text Domain: zaquadownia
*/

/* (Karuzela quadów i karty — pełne style w sekcji „Nasz garaż" na końcu pliku.) */

/* Oferta (blok quady): pełnoszerokie tło sekcji, ale treść trzyma się contentSize jak reszta strony */
.wp-block-zaquadownia-quady > * {
	max-width: var(--wp--style--global--content-size, 1280px);
	margin-left: auto;
	margin-right: auto;
}

/* --- Responsywność --- */
@media (max-width: 781px) {
	h1, h2 { word-break: break-word; }
}

/* --- Dostępność: widoczny focus --- */
a:focus-visible,
button:focus-visible,
.wp-block-button__link:focus-visible {
	outline: 3px solid var(--wp--preset--color--primary);
	outline-offset: 2px;
}

/* === Buttony: jednolity system — warianty filled (domyślny) + outline, asymetryczne rogi === */
.wp-block-button__link {
	border: 2px solid transparent;
	border-radius: 0 !important;   /* ostre rogi (bez zaokrągleń) */
	transition: background-color .2s ease, color .2s ease, border-color .2s ease, transform .15s ease;
}
.wp-block-button__link:hover { transform: translateY(-2px); }
/* Filled (domyślny): tło pomarańcz + jasny tekst — kolory z theme.json, tu tylko spójna ramka */
.wp-block-button:not(.is-style-outline):not(.is-style-zq-arrow) > .wp-block-button__link { border-color: transparent; }
/* Outline: zachowuje wariant wizualny (przyciemnione tło + pomarańczowa ramka),
   ale WSZYSTKIE wymiary/odstępy/padding bierze ze wspólnego systemu (tak jak primary). */
.is-style-outline > .wp-block-button__link {
	background-color: rgba(18, 15, 13, .55) !important;
	border-color: var(--wp--preset--color--primary) !important;
	color: var(--wp--preset--color--contrast) !important;
	padding: 12px 0.9rem !important;   /* zrównaj z primary — WP core daje outline em-owy padding; 12px = 57px wysokości */
}
.is-style-outline > .wp-block-button__link:hover {
	background-color: var(--wp--preset--color--primary) !important;
	border-color: var(--wp--preset--color--primary) !important;
	color: var(--wp--preset--color--contrast) !important;
}

/* Płynne przewijanie do kotwic z menu (uwzględnia sticky header) */
html { scroll-behavior: smooth; }
/* Bezpiecznik: żadna sekcja/element nie powoduje poziomego scrolla całej strony (zwł. mobile). */
html, body { overflow-x: clip; max-width: 100%; }
img { max-width: 100%; height: auto; }
:target { scroll-margin-top: 90px; }

/* --- Logo (jasne, na ciemnym/przezroczystym headerze) — Desktop-1 --- */
.zq-logo-lockup { position: relative; display: inline-flex; align-items: center; isolation: isolate; }
.zq-logo { position: relative; z-index: 1; display: inline-flex; margin: 0; text-decoration: none; line-height: 0; }
/* Kryjący ciemny podkład pod CAŁYM logo — żeby nic nie przebijało (np. teksty sekcji
   pod dolną częścią logo). Krawędzie zmiękczone maską, by nie był twardym prostokątem. */
.zq-logo-lockup::before {
	content: ""; position: absolute; z-index: -1; pointer-events: none;
	/* podkład logo: pod linią nagłówka (z-index -1 w isolowanym lockupie), ale nad treścią sekcji.
	   logo (img) wystaje ~54px poniżej swojego boxa (margin-bottom:-54px) — stąd bottom -62px. */
	top: -10px; left: -12px; right: -10px; bottom: -62px;
	background: var(--wp--preset--color--base);
	border-radius: 14px;
	/* miękka poświata w kolorze tła — rozmywa krawędź prostokąta, by nie był „pudełkiem" */
	box-shadow: 0 0 22px 14px var(--wp--preset--color--base);
}
.zq-logo__img { height: 152px; width: auto; display: block; margin-bottom: -54px; filter: drop-shadow(0 2px 8px rgba(0, 0, 0, .55)); }
/* Załamana linia NALEŻĄCA DO LOGO (osobna od reszty headera):
   pozioma pod logo → załamanie → ukos w górę-prawo. Własny SVG, nie pełna linia headera. */
.zq-logo-line {
	position: absolute; left: -2rem; bottom: -60px;   /* -2rem = wybicie poza padding headera, do krawędzi ekranu */
	width: 287px; height: 170px;
	pointer-events: none; overflow: visible; z-index: 0;
	/* Animacja „rysowania" od lewej: najpierw pozioma, potem ukos w górę */
	-webkit-clip-path: inset(0 100% 0 0); clip-path: inset(0 100% 0 0);
	animation: zq-logoline-draw .9s cubic-bezier(.6, 0, .25, 1) .15s forwards;
}
@keyframes zq-logoline-draw { to { -webkit-clip-path: inset(0 0 0 0); clip-path: inset(0 0 0 0); } }
@media (prefers-reduced-motion: reduce) {
	.zq-logo-line { animation: none; -webkit-clip-path: none; clip-path: none; }
}
.zq-logo-line__h { stroke: var(--wp--preset--color--primary); stroke-width: 3px; }   /* pozioma — równa */
.zq-logo-line__d { fill: var(--wp--preset--color--primary); }                          /* ukos — klin wygasający (Line 8) */

/* (REZERWUJ TERMIN korzysta teraz ze wspólnego systemu buttonów — bez osobnego wyłomu.) */

/* --- WOW: wideo-hero --- */
.zq-hero { margin-top: -96px; position: relative; overflow: hidden; display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-start; min-height: 100vh !important; min-height: 100svh !important; }
.zq-hero > .wp-block-cover__background,
.zq-hero > .wp-block-cover__image-background,
.zq-hero__video { position: absolute; inset: 0; width: 100%; height: 100%; }
.zq-hero > .wp-block-cover__image-background { object-fit: cover; z-index: 0; }
.zq-hero > .wp-block-cover__background { z-index: 1; }
.zq-hero__video { object-fit: cover; z-index: 0; opacity: 0; transition: opacity .7s ease; }
.zq-hero__video.is-playing { opacity: 1; }
/* Hero top-anchored: stały, gwarantowany odstęp od góry, który zawsze omija logo
   (logo wystaje ~54px przez ujemny margin-bottom). Skaluje się z wysokością okna. */
.zq-hero > .wp-block-cover__inner-container { position: relative; z-index: 2; padding-top: clamp(190px, 21vh, 250px); padding-bottom: clamp(5rem, 11vh, 8rem); width: 100%; }
/* Mobile: mniejszy odstęp eyebrow od headera + przyciski hero dociśnięte do dołu.
   MUSI być po regule desktopowej powyżej — media query nie dodaje specyficzności, decyduje kolejność. */
@media (max-width: 781px) {
	.zq-hero > .wp-block-cover__inner-container {
		padding-top: clamp(102px, 13vh, 130px); padding-bottom: clamp(3.5rem, 8vh, 5rem);
		flex: 1; display: flex; flex-direction: column;
	}
	.zq-hero .wp-block-buttons { margin-top: auto; }
}

/* --- WOW: nagłówek przezroczysty nad hero + solidny po scrollu --- */
header.wp-block-group {
	z-index: 200; /* nad treścią sekcji: karty coverflow mają z-index do 100, strzałki 150 */
	transition: padding .3s ease, background-color .3s ease, box-shadow .3s ease;
}
header.zq-header--over-hero:not(.zq-header--solid) {
	background: linear-gradient(to bottom, rgba(20, 17, 15, .55) 0%, rgba(20, 17, 15, .12) 55%, rgba(20, 17, 15, 0) 100%) !important;
}
header.zq-header--solid {
	/* solidne tło po zescrollowaniu — logo/nawigacja zawsze czytelne, nic nie przebija.
	   UWAGA: bez backdrop-filter — tworzyłby containing block dla position:fixed i psuł
	   pełnoekranowy overlay hamburgera (menu zakrywało tylko pasek headera). */
	background-color: rgba(16, 13, 11, .96) !important;
	padding-top: .6rem !important;
	padding-bottom: .6rem !important;
	box-shadow: 0 6px 24px rgba(0, 0, 0, .45);
}
/* Strona główna: nagłówek jako przezroczysta narzutka NA hero (poza flow),
   hero startuje od samej góry i przebija przez header. */
body.home header.wp-block-group {
	position: fixed !important;
	top: 0 !important; left: 0; right: 0; width: 100%;
}
body.home .zq-hero { margin-top: 0 !important; }
body.home main { margin-top: 0 !important; }

/* --- WOW: odsłanianie sekcji przy scrollu --- */
.zq-reveal {
	opacity: 0;
	transform: translateY(28px);
	transition: opacity .7s ease, transform .7s ease;
}
.zq-reveal.is-visible { opacity: 1; transform: none; }
@media ( prefers-reduced-motion: reduce ) {
	.zq-reveal { opacity: 1; transform: none; transition: none; }
	.zq-hero__video { transition: none; }
}

/* (Mikrointerakcje kart przeniesione do sekcji „Nasz garaż".) */

/* --- WOW: galeria (hover + masonry) --- */
.zq-gallery img { transition: transform .4s ease, filter .4s ease; }
.zq-gallery img:hover { transform: scale(1.04); filter: brightness(1.08); }
.zq-masonry { columns: 4 280px; column-gap: 10px; }
.zq-masonry img { width: 100%; margin: 0 0 10px; border-radius: 8px; display: block; break-inside: avoid; }
@media ( max-width: 600px ) { .zq-masonry { columns: 2 140px; } }

/* --- WOW: lightbox --- */
.zq-lightbox { position: fixed; inset: 0; z-index: 1000; display: none; align-items: center; justify-content: center; background: rgba(10, 8, 7, .92); }
.zq-lightbox.is-open { display: flex; }
.zq-lightbox img { max-width: 90vw; max-height: 86vh; border-radius: 8px; box-shadow: 0 20px 60px rgba(0, 0, 0, .6); }
.zq-lightbox .zq-lb__close, .zq-lightbox .zq-lb__nav { position: absolute; background: transparent; color: var(--wp--preset--color--contrast); border: none; cursor: pointer; font-size: 2.6rem; line-height: 1; padding: .3rem .8rem; }
.zq-lightbox .zq-lb__close { top: 1rem; right: 1.2rem; }
.zq-lightbox .zq-lb__nav { top: 50%; transform: translateY(-50%); }
.zq-lightbox .zq-lb__prev { left: .5rem; }
.zq-lightbox .zq-lb__next { right: .5rem; }
.zq-lightbox .zq-lb__close:hover, .zq-lightbox .zq-lb__nav:hover { color: var(--wp--preset--color--primary); }

/* --- WOW: liczniki --- */
.zq-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; text-align: center; }
.zq-stat { display: flex; flex-direction: column; align-items: center; }
.zq-stat__num { font-family: var(--wp--preset--font-family--display); font-size: clamp(2.6rem, 6vw, 4rem); line-height: 1; color: var(--wp--preset--color--primary); }
.zq-stat__star { color: var(--wp--preset--color--primary); font-size: 1.3rem; }
.zq-stat__label { color: var(--wp--preset--color--muted); text-transform: uppercase; letter-spacing: .08em; font-size: .85rem; margin-top: .4rem; }
@media ( max-width: 600px ) { .zq-stats { grid-template-columns: repeat(2, 1fr); gap: 2rem; } }

/* --- WOW: pasek CTA na mobile --- */
.zq-cta-mobile { display: none; }
@media ( max-width: 768px ) {
	.zq-cta-mobile { display: flex; position: fixed; left: 0; right: 0; bottom: 0; z-index: 60; background: var(--wp--preset--color--base-2); border-top: 1px solid rgba(245, 241, 234, .14); transform: translateZ(0); padding-bottom: env(safe-area-inset-bottom); }
	.zq-cta-mobile__btn { flex: 1; min-width: 0; display: flex; align-items: center; justify-content: center; gap: .3em; padding: .8rem .25rem; font-weight: 700; font-size: .82rem; line-height: 1; white-space: nowrap; text-decoration: none; background: var(--wp--preset--color--base-2); color: var(--wp--preset--color--contrast); border-left: 1px solid rgba(245, 241, 234, .1); }
	.zq-cta-mobile__btn:first-child { border-left: 0; }
	.zq-cta-mobile__btn--primary { background: var(--wp--preset--color--primary); }
	body { padding-bottom: 56px; }
}

/* --- WOW: mocniejszy overlay hero (czytelność tekstu na każdej klatce) --- */
.zq-hero .wp-block-cover__background {
	background: linear-gradient(90deg, rgba(20, 17, 15, .96) 0%, rgba(20, 17, 15, .80) 38%, rgba(20, 17, 15, .48) 72%, rgba(20, 17, 15, .30) 100%) !important;
}
.zq-hero .wp-block-cover__inner-container :is( h1, h2, p ) { text-shadow: 0 2px 16px rgba(0, 0, 0, .5); }

/* (Stary baner wideo .zq-akcja usunięty — sekcja „Zobacz nas w akcji" jest na końcu pliku.) */

/* --- FIX: nagłówek na mobile (telefon nie zawija się w „kulę"; telefon+social chowamy, bo są w pasku CTA) --- */
header.wp-block-group .wp-block-button__link { white-space: nowrap; }
@media ( max-width: 781px ) {
	header.wp-block-group .wp-block-buttons,
	header.wp-block-group .wp-block-social-links { display: none; }
}

/* --- FIX: hamburger menu (mobile) — własny, 3-kreskowy ikon --- */
.wp-block-navigation__responsive-container-open,
.wp-block-navigation__responsive-container-close { color: var(--wp--preset--color--contrast); }
.wp-block-navigation__responsive-container-close svg { width: 1.8rem; height: 1.8rem; fill: currentColor; }
.wp-block-navigation__responsive-container-open {
	width: 46px; height: 40px; padding: 0; border: 1px solid rgba(245, 241, 234, .35); border-radius: 8px;
	display: inline-flex; align-items: center; justify-content: center;
}
.wp-block-navigation__responsive-container-open svg { display: none; }
.wp-block-navigation__responsive-container-open::before {
	content: ""; width: 24px; height: 2px; background: currentColor;
	box-shadow: 0 -7px 0 currentColor, 0 7px 0 currentColor;
}
/* Rozwinięte menu na mobile: pełnoekranowy, kryjący overlay + czytelne, duże linki */
.wp-block-navigation__responsive-container.is-menu-open {
	position: fixed !important; inset: 0 !important;
	background-color: var(--wp--preset--color--base) !important;
	z-index: 100001 !important;
}
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item a {
	color: var(--wp--preset--color--contrast); font-size: 1.4rem;
}
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-close { color: var(--wp--preset--color--contrast); }

/* --- FIX: tabela cennika (ciemny styl zamiast jasnych pasów is-style-stripes) --- */
.zq-cennik { margin: 1.5rem 0 0; }
.zq-cennik table { width: 100%; border-collapse: collapse; color: var(--wp--preset--color--contrast); }
.zq-cennik th, .zq-cennik td { padding: .75rem .6rem; text-align: center; border: 0; border-bottom: 1px solid rgba(245, 241, 234, .1); }
.zq-cennik thead th { color: var(--wp--preset--color--primary); text-transform: uppercase; letter-spacing: .04em; font-size: .82rem; border-bottom: 2px solid var(--wp--preset--color--primary); }
.zq-cennik tbody tr:nth-child(odd) td { background: rgba(245, 241, 234, .04); }
.zq-cennik th:first-child, .zq-cennik td:first-child { text-align: left; font-weight: 700; }
.zq-cennik tbody td:not(:first-child) { font-weight: 700; }
.zq-cennik figcaption { margin-top: .8rem; text-align: center; color: var(--wp--preset--color--muted); font-size: .85rem; }
@media ( max-width: 480px ) {
	.zq-cennik th, .zq-cennik td { padding: .6rem .3rem; font-size: .9rem; }
	.zq-cennik thead th { font-size: .72rem; }
}

/* --- Edytor: podgląd bloku Hero zbliżony do frontu --- */
.zq-hero-edit {
	position: relative; min-height: 70vh; display: flex; flex-direction: column; justify-content: center;
	padding: 3rem clamp(1rem, 6vw, 6rem);
	background-color: var(--wp--preset--color--base); background-size: cover; background-position: center;
	overflow: hidden; border-radius: 4px;
}
.zq-hero-edit::before {
	content: ""; position: absolute; inset: 0;
	background: linear-gradient(90deg, rgba(20, 17, 15, .92) 0%, rgba(20, 17, 15, .55) 50%, rgba(20, 17, 15, .2) 100%);
}
.zq-hero-edit > * { position: relative; z-index: 1; }
.zq-hero-edit__eyebrow { color: var(--wp--preset--color--primary) !important; text-transform: uppercase; letter-spacing: .2em; font-weight: 700; }
.zq-hero-edit__accent { color: var(--wp--preset--color--primary) !important; }

/* --- Detale z makiety: swash pod nadtytułem, kropki/podkreślenie w menu, linia pod nagłówkiem --- */
.zq-eyebrow { position: relative; display: inline-block; padding-bottom: 1rem; font-size: 24px !important; margin-bottom: 0 !important; }
/* Podkreślnik nadtytułu = Line 9 (falowana pomarańczowa kreska) — hero + sekcja „O nas" */
.zq-eyebrow::after {
	content: ""; position: absolute; left: 0; bottom: 0;
	width: 100%; height: 11px;
	background: url("assets/images/eyebrow-line.svg") no-repeat left center;
	background-size: 100% 100%;
	-webkit-clip-path: inset(0 100% 0 0); clip-path: inset(0 100% 0 0);
	animation: zq-swash-draw .8s cubic-bezier(.6, 0, .25, 1) .35s forwards;
}
/* Hero: rozmiary tekstów wg makiety — tytuł 150px (Eroded), nadtytuł i opis 24px */
.zq-hero h1.wp-block-heading,
.zq-hero h2.wp-block-heading { font-size: clamp(2.75rem, 13.5vw, 150px) !important; line-height: 0.95; }
.zq-hero h1.wp-block-heading { margin-top: 50px !important; }   /* 50px od nadtytułu do tytułu */
.zq-hero p.has-contrast-color { font-size: 24px !important; margin-bottom: 0 !important; }
.zq-hero p.has-contrast-color .zq-hl { color: var(--wp--preset--color--primary); }
/* 50px odstępu od opisu do sekcji z buttonami */
.zq-hero .wp-block-buttons { margin-top: 50px !important; }
@keyframes zq-swash-draw {
	to { -webkit-clip-path: inset(0 0 0 0); clip-path: inset(0 0 0 0); }
}
@media (prefers-reduced-motion: reduce) {
	.zq-eyebrow::after { animation: none; -webkit-clip-path: none; clip-path: none; }
}

/* Nawigacja: lekko przesunięta w prawo */
header .wp-block-navigation { margin-left: 3rem; }
/* Nawigacja: font itemów 24px */
header .wp-block-navigation-item__content { font-size: 24px; }
/* Pionowe pomarańczowe kreski (Line 5) — między pozycjami ORAZ na zewnętrznych krańcach (przed pierwszą, za ostatnią) */
header .wp-block-navigation-item::after,
header .wp-block-navigation-item:first-child::before {
	content: ""; display: inline-block; width: 1px; height: 55px;
	background: var(--wp--preset--color--primary); vertical-align: middle;
	transform-origin: center; transform: scaleY(0);
	animation: zq-sep-draw .45s cubic-bezier(.6, 0, .25, 1) forwards;
}
header .wp-block-navigation-item::after { margin-left: 1.5rem; }
header .wp-block-navigation-item:first-child::before { margin-right: 1.5rem; }
/* Kaskada — kreski wyrastają jedna po drugiej */
@keyframes zq-sep-draw { to { transform: scaleY(1); } }
header .wp-block-navigation-item:first-child::before { animation-delay: .15s; }
header .wp-block-navigation-item:nth-child(1)::after { animation-delay: .25s; }
header .wp-block-navigation-item:nth-child(2)::after { animation-delay: .35s; }
header .wp-block-navigation-item:nth-child(3)::after { animation-delay: .45s; }
header .wp-block-navigation-item:nth-child(4)::after { animation-delay: .55s; }
@media (prefers-reduced-motion: reduce) {
	header .wp-block-navigation-item::after,
	header .wp-block-navigation-item:first-child::before { animation: none; transform: scaleY(1); }
}

/* Ikony social w headerze: 40×40 */
header .wp-block-social-links { font-size: 40px; }
header .wp-block-social-links .wp-social-link,
header .wp-block-social-links .wp-block-social-link { width: 40px; height: 40px; }
header .wp-block-social-links .wp-social-link svg,
header .wp-block-social-links svg { width: 40px !important; height: 40px !important; display: block; }

/* 50px odstępu między przyciskiem REZERWUJ a ikonami social */
header .wp-block-group:has(> .wp-block-social-links) { gap: 50px !important; }

/* Header: skalowanie na węższych ekranach, żeby wszystko (w tym ikony social) mieściło się w jednym rzędzie */
@media (max-width: 1400px) {
	header .wp-block-navigation { margin-left: 0; }
	header .wp-block-group:has(> .wp-block-social-links) { gap: 22px !important; }
	header .wp-block-navigation-item__content { font-size: 19px; }
	header .wp-block-navigation-item::after,
	header .wp-block-navigation-item:first-child::before { height: 38px; margin-left: 1rem; }
	header .wp-block-navigation-item:first-child::before { margin-right: 1rem; }
	header .zq-btn-reserve .wp-block-button__link { font-size: 20px; padding: 0.4rem 0.8rem; }
	header .wp-block-social-links { font-size: 30px; }
	header .wp-block-social-links .wp-social-link { width: 30px; height: 30px; }
	header .wp-block-social-links svg { width: 30px !important; height: 30px !important; }
}
@media (max-width: 1120px) {
	header .zq-logo__img { height: 108px; }
	header .wp-block-navigation-item__content { font-size: 17px; }
	header .wp-block-navigation { gap: .9rem; }
}
/* === Header responsywny: menu jako hamburger ≤1100px (zamiast WP-owego 600px) === */
@media (max-width: 1100px) {
	header .wp-block-navigation__responsive-container-open:not(.always-shown) { display: flex !important; }
	header .wp-block-navigation__responsive-container:not(.is-menu-open) { display: none !important; }
	/* logo po lewej; REZERWUJ + hamburger razem po prawej */
	header > .wp-block-group { order: 8; margin-left: auto; }
	header .wp-block-navigation { order: 9; margin-left: 1rem !important; }
	header .wp-block-social-links { display: none !important; }
}
/* Overlay menu (otwarty hamburger): bez pionowych separatorów Line 5 (brzydkie w pionie) */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item::after,
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:first-child::before { display: none !important; }
/* Mobile: mniejsze logo, bez dekoracyjnej linii logo (za duża na wąski header) */
@media (max-width: 600px) {
	header .zq-logo__img { height: 78px; }
	.zq-logo-line { display: none; }
}

body:has(.zq-offer-hero),
body:has(.zq-contact-hero),
body:has(.zq-gallery-hero) {
	background: #000;
}

body:has(.zq-offer-hero) {
	--zq-offer-section-width: var(--wp--style--global--content-size, 1280px);
	--zq-offer-section-gutter: 1.25rem;
}

@media (width >= 600px) {
	body:has(.zq-offer-hero) {
		--zq-offer-section-gutter: 2rem;
	}
}

/* === Strona oferty: hero === */
.zq-offer-page-main {
	margin-top: 0;
	background: #000;
}
.zq-offer-hero {
	position: relative;
	isolation: isolate;
	min-height: 100svh;
	margin-top: -96px;
	background-color: #050505;
	background-position: center top;
	background-repeat: no-repeat;
	background-size: cover;
	overflow: hidden;
}
.zq-offer-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 0;
	background: linear-gradient(90deg, rgba(0, 0, 0, .9) 0%, rgba(0, 0, 0, .74) 34%, rgba(0, 0, 0, .32) 66%, rgba(0, 0, 0, .08) 100%);
	pointer-events: none;
}
.zq-offer-hero::after {
	content: "";
	position: absolute;
	inset: auto 0 0;
	z-index: 0;
	height: 30%;
	background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, .74) 100%);
	pointer-events: none;
}
.zq-offer-hero__inner {
	position: relative;
	z-index: 1;
	display: flex;
	align-items: flex-start;
	width: 100%;
	min-height: 100svh;
	box-sizing: border-box;
	padding: 12rem var(--zq-offer-section-gutter) 5rem;
}
.zq-offer-hero__content {
	width: min(100%, 48rem);
}
.zq-offer-hero .is-style-zq-eyebrow {
	margin-bottom: 2.375rem;
	font-size: 1.5rem;
}
.zq-offer-hero .is-style-zq-eyebrow::before {
	content: none;
	margin: 0;
}
.zq-offer-hero__title {
	margin: 0 0 2rem;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--display);
	font-size: 5rem;
	font-weight: 400;
	line-height: .98;
	letter-spacing: 0;
	text-transform: uppercase;
}
.zq-offer-hero__title mark {
	display: block;
	background: transparent;
	color: var(--wp--preset--color--primary);
}
.zq-offer-hero__title mark + br {
	display: none;
}
.zq-offer-hero__lead {
	max-width: 44rem;
	margin: 0;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 1.5rem;
	font-weight: 500;
	line-height: 1.35;
	text-shadow: 0 2px 12px rgba(0, 0, 0, .45);
}
.zq-offer-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin-top: 2.375rem;
}
.zq-offer-hero__button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: .75rem;
	min-height: 3.5rem;
	box-sizing: border-box;
	padding: .75rem 1.75rem;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 1;
	text-decoration: none;
	text-transform: uppercase;
	transition: background-color .2s ease, color .2s ease, translate .15s ease;
}
.zq-offer-hero__button:hover {
	color: var(--wp--preset--color--contrast);
	translate: 0 -2px;
}
.zq-offer-hero__button--primary {
	min-width: 15.5rem;
	background: var(--wp--preset--color--primary);
}
.zq-offer-hero__button--primary:hover {
	background: var(--wp--preset--color--primary-hover);
}
.zq-offer-hero__button--outline {
	border: 2px solid var(--wp--preset--color--primary);
	background: rgba(0, 0, 0, .24);
}
.zq-offer-hero__button--outline:hover {
	background: var(--wp--preset--color--primary);
}

@media (width >= 960px) {
	.zq-offer-hero__title {
		font-size: 7.5rem;
	}
}

@media (width >= 1200px) {
	.zq-offer-hero__title {
		font-size: 8.75rem;
	}
}

@media (width >= 1320px) {
	.zq-offer-hero__inner {
		width: var(--wp--style--global--content-size, 1280px);
		margin-inline: auto;
		padding-inline: 0;
	}
}

@media (width < 900px) {
	.zq-offer-hero {
		background-position: 58% top;
	}
	.zq-offer-hero::before {
		background: linear-gradient(90deg, rgba(0, 0, 0, .92) 0%, rgba(0, 0, 0, .74) 54%, rgba(0, 0, 0, .34) 100%);
	}
	.zq-offer-hero__inner {
		padding-top: 9rem;
	}
	.zq-offer-hero__content {
		width: min(100%, 42rem);
	}
}

@media (width < 600px) {
	.zq-offer-hero {
		margin-top: -76px;
	}
	.zq-offer-hero__inner {
		padding: 7.5rem var(--zq-offer-section-gutter) 3.5rem;
	}
	.zq-offer-hero .is-style-zq-eyebrow {
		margin-bottom: 1.75rem;
		font-size: 1.25rem;
	}
	.zq-offer-hero__title {
		margin-bottom: 1.5rem;
		font-size: 4rem;
	}
	.zq-offer-hero__lead {
		font-size: 1.25rem;
	}
	.zq-offer-hero__actions {
		gap: .75rem;
		margin-top: 2rem;
	}
	.zq-offer-hero__button {
		width: 100%;
		min-height: 3.25rem;
		font-size: 1.25rem;
	}
}

@media (prefers-reduced-motion: reduce) {
	.zq-offer-hero__button {
		transition-duration: 0ms;
	}
}

body:has(.zq-offer-hero) header.wp-block-group {
	position: fixed !important;
	top: 0 !important;
	left: 0;
	right: 0;
	width: 100%;
}
body:has(.zq-offer-hero) .zq-offer-hero {
	margin-top: 0;
}

body:has(.zq-offer-hero) :where(.zq-offer-info, .zq-offer-models, .zq-offer-rules, .zq-offer-contact) {
	margin-block-start: 0;
}

/* === Strona galerii: hero === */
.zq-gallery-page-main {
	margin-top: 0;
	background: #000;
}
.zq-gallery-hero {
	position: relative;
	isolation: isolate;
	min-height: 680px;
	margin-top: -96px;
	background-color: #050505;
	background-position: center top;
	background-repeat: no-repeat;
	background-size: cover;
	overflow: hidden;
}
.zq-gallery-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 0;
	background:
		linear-gradient(90deg, rgba(0, 0, 0, .88) 0%, rgba(0, 0, 0, .7) 31%, rgba(0, 0, 0, .25) 61%, rgba(0, 0, 0, .04) 100%),
		linear-gradient(180deg, rgba(0, 0, 0, .36) 0%, rgba(0, 0, 0, 0) 36%, rgba(0, 0, 0, .46) 100%);
	pointer-events: none;
}
.zq-gallery-hero__inner {
	position: relative;
	z-index: 1;
	display: flex;
	align-items: flex-start;
	width: 100%;
	min-height: 680px;
	box-sizing: border-box;
	padding: 13.25rem 2rem 4.5rem;
}
.zq-gallery-hero__content {
	width: min(100%, 40rem);
}
.zq-gallery-hero .is-style-zq-eyebrow {
	margin-bottom: 2rem;
	font-size: 1.5rem;
	letter-spacing: .22em;
}
.zq-gallery-hero .is-style-zq-eyebrow::before {
	content: none;
	margin: 0;
}
.zq-gallery-hero__title {
	margin: 0 0 1.875rem;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--display);
	font-size: 6rem;
	font-weight: 400;
	line-height: .85;
	letter-spacing: 0;
	text-transform: uppercase;
}
.zq-gallery-hero__lead {
	margin: 0;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 1.5rem;
	font-weight: 500;
	line-height: 1.25;
	text-shadow: 0 2px 12px rgba(0, 0, 0, .45);
}

@media (width >= 960px) {
	.zq-gallery-hero__title {
		font-size: 8.25rem;
	}
}

@media (width >= 1200px) {
	.zq-gallery-hero__title {
		font-size: 9.5rem;
	}
}

@media (width >= 1320px) {
	.zq-gallery-hero__inner {
		width: var(--wp--style--global--content-size, 1280px);
		margin-inline: auto;
		padding-inline: 0;
	}
}

@media (width < 900px) {
	.zq-gallery-hero {
		min-height: 620px;
		background-position: 59% top;
	}
	.zq-gallery-hero::before {
		background:
			linear-gradient(90deg, rgba(0, 0, 0, .9) 0%, rgba(0, 0, 0, .72) 52%, rgba(0, 0, 0, .26) 100%),
			linear-gradient(180deg, rgba(0, 0, 0, .3) 0%, rgba(0, 0, 0, 0) 42%, rgba(0, 0, 0, .56) 100%);
	}
	.zq-gallery-hero__inner {
		min-height: 620px;
		padding-top: 11rem;
	}
}

@media (width < 600px) {
	.zq-gallery-hero {
		min-height: 560px;
		margin-top: -76px;
		background-position: 61% top;
	}
	.zq-gallery-hero__inner {
		min-height: 560px;
		padding: 8.75rem 1.25rem 3.25rem;
	}
	.zq-gallery-hero .is-style-zq-eyebrow {
		margin-bottom: 1.5rem;
		font-size: 1.25rem;
	}
	.zq-gallery-hero__title {
		margin-bottom: 1.5rem;
		font-size: 4.125rem;
	}
	.zq-gallery-hero__lead {
		font-size: 1.25rem;
	}
}

body:has(.zq-gallery-hero) header.wp-block-group {
	position: fixed !important;
	top: 0 !important;
	left: 0;
	right: 0;
	width: 100%;
}
body:has(.zq-gallery-hero) .zq-gallery-hero {
	margin-top: 0;
}

/* === Strona galerii: filtrowana siatka === */
.zq-gallery-grid {
	position: relative;
	isolation: isolate;
	margin: 0;
	padding: 2.5rem 1.25rem 5rem;
	background: #000;
	overflow: hidden;
}
.zq-gallery-grid::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 0;
	background: url("assets/images/bg/bg-kontakt.webp") center top / cover no-repeat;
	opacity: .32;
	pointer-events: none;
}
.zq-gallery-grid__inner {
	position: relative;
	z-index: 1;
	max-width: 1280px;
	margin-inline: auto;
}
.zq-gallery-grid__tabs {
	display: flex;
	margin-bottom: 2.5rem;
	border: 1px solid rgba(129, 119, 119, .76);
	background: rgba(7, 7, 7, .92);
	overflow-x: auto;
	scrollbar-width: thin;
}
.zq-gallery-grid__tab {
	position: relative;
	display: inline-flex;
	flex: 0 0 12rem;
	align-items: center;
	justify-content: center;
	gap: .875rem;
	min-height: 4.25rem;
	border: 0;
	border-inline-end: 1px solid rgba(129, 119, 119, .76);
	background: transparent;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 1.125rem;
	font-weight: 700;
	line-height: 1;
	text-transform: uppercase;
	cursor: pointer;
	transition-property: color, background-color;
	transition-duration: .18s;
	transition-timing-function: ease;
}
.zq-gallery-grid__tab:last-child {
	border-inline-end: 0;
}
.zq-gallery-grid__tab:hover,
.zq-gallery-grid__tab:focus-visible {
	color: var(--wp--preset--color--primary);
}
.zq-gallery-grid__tab:focus-visible {
	outline: 2px solid var(--wp--preset--color--primary);
	outline-offset: -4px;
}
.zq-gallery-grid__tab.is-active {
	color: var(--wp--preset--color--primary);
	box-shadow: inset 0 0 0 1px var(--wp--preset--color--primary);
}
.zq-gallery-grid__tab-icon,
.zq-gallery-grid__icon {
	display: inline-flex;
	width: 2.125rem;
	height: 2.125rem;
	align-items: center;
	justify-content: center;
	color: currentColor;
}
.zq-gallery-grid__tab-icon svg {
	display: block;
	width: 100%;
	height: 100%;
	fill: currentColor;
}
.zq-gallery-grid__icon--none {
	display: none;
}
.zq-gallery-grid__items {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: 1.25rem;
}
.zq-gallery-grid__item {
	position: relative;
	display: block;
	aspect-ratio: 4 / 3;
	margin: 0;
	background: #d9d9d9;
	overflow: hidden;
	cursor: pointer;
}
.zq-gallery-grid__item img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition-property: scale, filter;
	transition-duration: .32s;
	transition-timing-function: ease;
}
.zq-gallery-grid__item:hover img {
	filter: brightness(1.08);
	scale: 1.04;
}
.zq-gallery-grid__item-placeholder {
	display: flex;
	width: 100%;
	height: 100%;
	align-items: center;
	justify-content: center;
	color: #111;
	font-family: var(--wp--preset--font-family--body);
	font-size: 1.125rem;
	font-weight: 700;
	text-transform: uppercase;
}
.zq-gallery-grid__item-meta {
	position: absolute;
	right: .75rem;
	bottom: .75rem;
	left: .75rem;
	display: flex;
	flex-wrap: wrap;
	gap: .375rem;
	pointer-events: none;
}
.zq-gallery-grid__item-badge {
	display: inline-flex;
	align-items: center;
	min-height: 1.75rem;
	padding: .375rem .5rem;
	background: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: .8125rem;
	font-weight: 700;
	line-height: 1;
	text-transform: uppercase;
}
.zq-gallery-grid__item-badge--empty {
	background: rgba(26, 26, 26, .92);
	color: rgba(245, 241, 234, .78);
}
.zq-gallery-grid__item[hidden],
.zq-gallery-grid__item.is-hidden-by-limit {
	display: none;
}
.zq-gallery-grid-editor-panel {
	margin-bottom: 1rem;
	border-bottom: 1px solid rgba(0, 0, 0, .12);
	padding-bottom: 1rem;
}
.zq-gallery-grid-editor-panel__title,
.zq-gallery-grid-editor-panel__label,
.zq-gallery-grid-editor-panel__summary {
	margin: 0 0 .75rem;
	font-weight: 700;
}
.zq-gallery-grid-editor-panel__summary {
	color: #575757;
	font-size: .8125rem;
	font-weight: 500;
}
.zq-gallery-grid-editor-panel__thumb {
	display: block;
	width: 100%;
	aspect-ratio: 4 / 3;
	margin: 0 0 .75rem;
	object-fit: cover;
}
.zq-editor-repeatable-panel {
	margin-bottom: 1rem;
	border-bottom: 1px solid rgba(0, 0, 0, .12);
	padding-bottom: 1rem;
}
.zq-editor-repeatable-panel__title {
	margin: 0 0 .75rem;
	font-weight: 700;
}
.zq-editor-repeatable-panel__actions {
	display: flex;
	flex-wrap: wrap;
	gap: .5rem;
}
.zq-gallery-grid__more-wrap {
	display: flex;
	justify-content: center;
	margin-top: 3.75rem;
}
.zq-gallery-grid__more {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 18rem;
	min-height: 3.875rem;
	border: 0;
	padding: .75rem 2rem;
	box-sizing: border-box;
	background: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 1.375rem;
	font-weight: 700;
	line-height: 1;
	text-transform: uppercase;
	cursor: pointer;
	transition-property: background-color, translate;
	transition-duration: .18s;
	transition-timing-function: ease;
}
.zq-gallery-grid__more:hover,
.zq-gallery-grid__more:focus-visible {
	background: var(--wp--preset--color--primary-hover);
	translate: 0 -2px;
}
.zq-gallery-grid__more:focus-visible {
	outline: 2px solid var(--wp--preset--color--contrast);
	outline-offset: 3px;
}
.zq-gallery-grid__more[hidden] {
	display: none;
}

@media (width >= 640px) {
	.zq-gallery-grid {
		padding-inline: 2rem;
	}
	.zq-gallery-grid__items {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 1.5rem;
	}
}

@media (width >= 960px) {
	.zq-gallery-grid {
		padding-block: 2.75rem 5.5rem;
	}
	.zq-gallery-grid__tabs {
		display: grid;
		grid-template-columns: repeat(5, minmax(0, 1fr));
		margin-bottom: 3.125rem;
		overflow: visible;
	}
	.zq-gallery-grid__tab {
		flex-basis: auto;
		min-width: 0;
		min-height: 4.375rem;
		font-size: 1.25rem;
	}
	.zq-gallery-grid__items {
		gap: 1.75rem 2.125rem;
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (width >= 1200px) {
	.zq-gallery-grid__items {
		padding-inline: 1rem;
	}
}

@media (prefers-reduced-motion: reduce) {
	.zq-gallery-grid__item img,
	.zq-gallery-grid__more,
	.zq-gallery-grid__tab {
		transition-duration: 0ms;
	}
	.zq-gallery-grid__item:hover img,
	.zq-gallery-grid__more:hover,
	.zq-gallery-grid__more:focus-visible {
		scale: 1;
		translate: 0;
	}
}

/* === Strona oferty: pasek informacji === */
.zq-offer-info {
	background: #000;
	box-sizing: border-box;
	padding-inline: var(--zq-offer-section-gutter);
}
.zq-offer-info__grid {
	display: grid;
	grid-template-columns: 1fr;
	width: 100%;
	max-width: var(--zq-offer-section-width);
	margin-inline: auto;
	box-sizing: border-box;
	border: 1px solid #817777;
	background: #1a1a1a;
}
.zq-offer-info__item {
	display: grid;
	grid-template-columns: 5.25rem minmax(0, 1fr);
	align-items: center;
	gap: 1.5rem;
	min-height: 13.5rem;
	box-sizing: border-box;
	padding: 2rem 1.5rem;
}
.zq-offer-info__item + .zq-offer-info__item {
	border-top: 1px solid #817777;
}
.zq-offer-info__icon {
	display: block;
	width: 5.25rem;
	height: 5.25rem;
	background-color: var(--wp--preset--color--primary);
}
.zq-offer-info__icon--driver-license {
	-webkit-mask: url("assets/images/icons/offer-driver-license.svg") center / contain no-repeat;
	mask: url("assets/images/icons/offer-driver-license.svg") center / contain no-repeat;
}
.zq-offer-info__icon--helmet {
	-webkit-mask: url("assets/images/icons/offer-helmet.svg") center / contain no-repeat;
	mask: url("assets/images/icons/offer-helmet.svg") center / contain no-repeat;
}
.zq-offer-info__icon--deposit {
	-webkit-mask: url("assets/images/icons/offer-deposit.svg") center / contain no-repeat;
	mask: url("assets/images/icons/offer-deposit.svg") center / contain no-repeat;
}
.zq-offer-info__icon--delivery {
	-webkit-mask: url("assets/images/icons/offer-delivery.svg") center / contain no-repeat;
	mask: url("assets/images/icons/offer-delivery.svg") center / contain no-repeat;
}
.zq-offer-info__body {
	min-width: 0;
}
.zq-offer-info__title {
	margin: 0 0 .75rem;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 1.875rem;
	font-weight: 700;
	line-height: 1;
	text-transform: uppercase;
}
.zq-offer-info__text {
	margin: 0;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 1.375rem;
	font-weight: 400;
	line-height: 1.35;
}

@media (width >= 640px) {
	.zq-offer-info__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
	.zq-offer-info__item:nth-child(2) {
		border-top: 0;
		border-left: 1px solid #817777;
	}
	.zq-offer-info__item:nth-child(4) {
		border-left: 1px solid #817777;
	}
}

@media (width >= 1200px) {
	.zq-offer-info__grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}
	.zq-offer-info__item {
		min-height: 14.75rem;
		padding: 2rem 1.5rem;
	}
	.zq-offer-info__item + .zq-offer-info__item {
		border-top: 0;
		border-left: 1px solid #817777;
	}
}

@media (width < 420px) {
	.zq-offer-info__item {
		grid-template-columns: 4rem minmax(0, 1fr);
		gap: 1rem;
		padding: 1.5rem 1rem;
	}
	.zq-offer-info__icon {
		width: 4rem;
		height: 4rem;
	}
	.zq-offer-info__title {
		font-size: 1.5rem;
	}
	.zq-offer-info__text {
		font-size: 1.125rem;
	}
}

/* === Strona oferty: modele i cennik === */
.zq-offer-models {
	background: #000;
	padding-block: 3.5rem 4.5rem;
	padding-inline: var(--zq-offer-section-gutter);
}
.zq-offer-models__inner {
	width: 100%;
	max-width: var(--zq-offer-section-width);
	margin-inline: auto;
}
.zq-offer-models__heading {
	position: relative;
	margin: 0 0 2.125rem;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 2.25rem;
	font-weight: 700;
	line-height: 1;
	text-align: center;
	text-transform: uppercase;
}
.zq-offer-models__heading::after {
	content: "";
	display: block;
	width: 3.75rem;
	height: .25rem;
	margin: .625rem auto 0;
	background: url("assets/images/offer-models-underline.svg") center / 100% 100% no-repeat;
}
.zq-offer-models__list {
	display: grid;
	gap: 1.5rem;
}
.zq-offer-model-card {
	display: grid;
	overflow: hidden;
	border: 1px solid rgba(129, 119, 119, .78);
	background: #1a1a1a;
}
.zq-offer-model-card__media {
	position: relative;
	aspect-ratio: 559 / 488;
	background: #0b0b0b;
}
.zq-offer-model-card__media img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.zq-offer-model-card__media-actions {
	position: absolute;
	inset-inline: 1rem;
	inset-block-end: 1rem;
	display: flex;
	flex-wrap: wrap;
	gap: .5rem;
	z-index: 1;
}
.zq-offer-model-card__media-actions .components-button {
	min-height: 2.5rem;
	box-shadow: 0 10px 24px rgba(0, 0, 0, .28);
}
.zq-offer-model-card__content {
	padding: 1.5rem;
	background: #1a1a1a;
}
.zq-offer-model-card__title {
	margin: 0;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 2rem;
	font-weight: 700;
	line-height: 1;
	text-transform: uppercase;
}
.zq-offer-model-card__title mark {
	padding: 0;
	background: transparent;
	color: var(--wp--preset--color--primary);
}
.zq-offer-model-card__power {
	margin: .75rem 0 0;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 1.25rem;
	font-weight: 400;
	line-height: 1;
	text-transform: uppercase;
}
.zq-offer-model-card__features {
	display: flex;
	flex-wrap: wrap;
	gap: .5rem .625rem;
	margin: 1rem 0 1.75rem;
	padding: 0;
	list-style: none;
}
.zq-offer-model-card__feature {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	min-height: 1.75rem;
	box-sizing: border-box;
	padding: .25rem .625rem;
	border: 1px solid rgba(129, 119, 119, .72);
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: .875rem;
	font-weight: 400;
	line-height: 1.05;
}
.zq-offer-model-card__feature span {
	display: block;
	flex: 0 0 auto;
	width: 1.125rem;
	height: 1.125rem;
	background-color: var(--wp--preset--color--primary);
	-webkit-mask: url("assets/images/icons/offer-check.svg") center / contain no-repeat;
	mask: url("assets/images/icons/offer-check.svg") center / contain no-repeat;
}
.zq-offer-model-card__feature strong {
	font-weight: 400;
}
.zq-offer-model-card__field-button.components-button {
	min-height: auto;
	padding: 0 .25rem;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: .8125rem;
	font-weight: 700;
	text-decoration: underline;
	text-transform: uppercase;
}
.zq-offer-model-card__add-field.components-button {
	margin: -1rem 0 1.5rem;
}
.zq-offer-model-card__prices {
	display: grid;
	grid-template-columns: 1fr;
	gap: .75rem;
}
.zq-offer-model-card__price {
	display: grid;
	align-content: center;
	justify-items: center;
	min-height: 8rem;
	box-sizing: border-box;
	padding: 1rem .75rem;
	border: 1px solid rgba(129, 119, 119, .78);
	text-align: center;
}
.zq-offer-model-card__price h4 {
	margin: 0 0 .5rem;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1;
	text-transform: uppercase;
}
.zq-offer-model-card__amount {
	margin: 0;
	color: var(--wp--preset--color--primary);
	font-family: var(--wp--preset--font-family--body);
	font-size: 3.5rem;
	font-weight: 700;
	line-height: .9;
}
.zq-offer-model-card__limit {
	margin: .625rem 0 0;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 1rem;
	font-weight: 400;
	line-height: 1;
}
.zq-offer-model-card__prices + .zq-offer-model-card__add-field.components-button {
	margin: .75rem 0 0;
}

@media (width >= 640px) {
	.zq-offer-model-card__prices {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (width >= 960px) {
	.zq-offer-models {
		padding-block: 4.5rem 5rem;
	}
	.zq-offer-model-card {
		grid-template-columns: minmax(0, .92fr) minmax(0, 1.28fr);
	}
	.zq-offer-model-card__media {
		min-height: 100%;
		aspect-ratio: auto;
	}
	.zq-offer-model-card__content {
		padding: 2rem;
	}
	.zq-offer-model-card__title {
		font-size: 2.125rem;
	}
	.zq-offer-model-card__power {
		font-size: 1.375rem;
	}
}

@media (width >= 1200px) {
	.zq-offer-model-card__content {
		padding: 2.125rem 2rem 1.5rem;
	}
	.zq-offer-model-card__title {
		font-size: 2.625rem;
	}
	.zq-offer-model-card__amount {
		font-size: 4.25rem;
	}
}

@media (width < 420px) {
	.zq-offer-model-card__content {
		padding: 1.25rem;
	}
	.zq-offer-model-card__title {
		font-size: 1.75rem;
	}
	.zq-offer-model-card__amount {
		font-size: 3rem;
	}
}

/* === Strona oferty: zasady wynajmu === */
.zq-offer-rules {
	background: #000;
	padding-block: 3.5rem 5rem;
	padding-inline: var(--zq-offer-section-gutter);
}
.zq-offer-rules__inner {
	width: 100%;
	max-width: var(--zq-offer-section-width);
	margin-inline: auto;
}
.zq-offer-rules__heading {
	position: relative;
	margin: 0 0 1.75rem;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 2.25rem;
	font-weight: 700;
	line-height: 1;
	text-align: center;
	text-transform: uppercase;
}
.zq-offer-rules__heading::after {
	content: "";
	display: block;
	width: 3.75rem;
	height: .25rem;
	margin: .625rem auto 0;
	background: url("assets/images/offer-models-underline.svg") center / 100% 100% no-repeat;
}
.zq-offer-rules__grid {
	display: grid;
	grid-template-columns: 1fr;
	border: 1px solid rgba(129, 119, 119, .78);
	background: #1a1a1a;
}
.zq-offer-rule {
	display: grid;
	grid-template-columns: 3.75rem minmax(0, 1fr);
	align-items: center;
	gap: 1.25rem;
	min-height: 11.75rem;
	box-sizing: border-box;
	padding: 1.75rem 1.5rem;
}
.zq-offer-rule + .zq-offer-rule {
	border-top: 1px solid rgba(129, 119, 119, .5);
}
.zq-offer-rule__icon {
	display: block;
	width: 3.5rem;
	height: 3.5rem;
	background-color: var(--wp--preset--color--primary);
}
.zq-offer-rule__icon--fuel {
	-webkit-mask: url("assets/images/icons/offer-rule-fuel.svg") center / contain no-repeat;
	mask: url("assets/images/icons/offer-rule-fuel.svg") center / contain no-repeat;
}
.zq-offer-rule__icon--water {
	-webkit-mask: url("assets/images/icons/offer-rule-water.svg") center / contain no-repeat;
	mask: url("assets/images/icons/offer-rule-water.svg") center / contain no-repeat;
}
.zq-offer-rule__icon--pin {
	-webkit-mask: url("assets/images/icons/offer-rule-pin.svg") center / contain no-repeat;
	mask: url("assets/images/icons/offer-rule-pin.svg") center / contain no-repeat;
}
.zq-offer-rule__icon--trailer {
	-webkit-mask: url("assets/images/icons/offer-rule-trailer.svg") center / contain no-repeat;
	mask: url("assets/images/icons/offer-rule-trailer.svg") center / contain no-repeat;
}
.zq-offer-rule__title {
	margin: 0 0 1.25rem;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1;
	text-transform: uppercase;
}
.zq-offer-rule__text {
	margin: 0;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 1rem;
	font-weight: 500;
	line-height: 1.38;
}
.zq-offer-rules__cta {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.75rem;
	align-items: center;
	margin-top: 3.5rem;
	box-sizing: border-box;
	padding: 2rem 1.5rem;
	border: 1px solid rgba(129, 119, 119, .78);
	background: #1a1a1a;
}
.zq-offer-rules__cta-heading {
	margin: 0;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 2rem;
	font-weight: 700;
	line-height: 1.1;
	text-transform: uppercase;
}
.zq-offer-rules__cta-text {
	margin: 0;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 1rem;
	font-weight: 500;
	line-height: 1.45;
}
.zq-offer-rules__cta-button {
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	min-height: 6.5rem;
	box-sizing: border-box;
	padding: 1rem 1.25rem;
	border: 2px solid var(--wp--preset--color--primary);
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 1.125rem;
	font-weight: 700;
	line-height: 1;
	text-align: center;
	text-decoration: none;
	text-transform: uppercase;
	transition: background-color .2s ease, translate .15s ease;
}
.zq-offer-rules__cta-button:hover {
	background: rgba(216, 92, 20, .14);
	color: var(--wp--preset--color--contrast);
	translate: 0 -2px;
}
.zq-offer-rules__cta-icon {
	display: block;
	width: 2.625rem;
	height: 2.625rem;
	background-color: var(--wp--preset--color--primary);
	-webkit-mask: url("assets/images/icons/offer-rule-phone.svg") center / contain no-repeat;
	mask: url("assets/images/icons/offer-rule-phone.svg") center / contain no-repeat;
}
.zq-offer-rules__heading--steps {
	margin-top: 3.75rem;
}
.zq-offer-rules__steps {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
	margin: 0;
	padding: 1.75rem 1.5rem;
	border: 1px solid rgba(129, 119, 119, .78);
	background: #1a1a1a;
	list-style: none;
}
.zq-offer-step {
	position: relative;
	display: grid;
	grid-template-columns: 4.75rem minmax(0, 1fr);
	align-items: center;
	gap: 1.25rem;
}
.zq-offer-step__num {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 4.75rem;
	height: 4.75rem;
	background: #000;
	color: var(--wp--preset--color--primary);
	font-family: var(--wp--preset--font-family--body);
	font-size: 3.25rem;
	font-weight: 700;
	line-height: 1;
}
.zq-offer-step__body {
	display: flex;
	flex-direction: column;
	gap: .875rem;
	min-width: 0;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 1rem;
	font-weight: 500;
	line-height: 1.35;
}
.zq-offer-step__body strong {
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1;
	text-transform: uppercase;
}

@media (width >= 640px) {
	.zq-offer-rules__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
	.zq-offer-rule:nth-child(2) {
		border-top: 0;
	}
	.zq-offer-rule:nth-child(2n) {
		border-left: 1px solid rgba(129, 119, 119, .5);
	}
	.zq-offer-rules__steps {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
	.zq-offer-step {
		grid-template-columns: 4.25rem minmax(0, 1fr);
	}
	.zq-offer-step__num {
		width: 4.25rem;
		height: 4.25rem;
		font-size: 2.75rem;
	}
}

@media (width >= 960px) {
	.zq-offer-rules {
		padding-block: 5rem 6rem;
	}
	.zq-offer-rules__grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}
	.zq-offer-rule {
		min-height: 12.75rem;
		padding: 1.75rem 1.25rem;
	}
	.zq-offer-rule + .zq-offer-rule {
		border-top: 0;
		border-left: 1px solid rgba(129, 119, 119, .5);
	}
	.zq-offer-rule__title {
		font-size: 1.125rem;
	}
	.zq-offer-rule__text {
		font-size: .875rem;
	}
	.zq-offer-rules__cta {
		grid-template-columns: minmax(0, 1.1fr) minmax(0, 1.15fr) 15rem;
		min-height: 12rem;
		padding: 2.25rem 4rem;
	}
	.zq-offer-rules__cta-heading {
		font-size: 2.75rem;
	}
	.zq-offer-rules__steps {
		gap: 3.5rem;
		padding: 3rem 2.75rem;
	}
	.zq-offer-step:not(:last-child)::after {
		content: "";
		position: absolute;
		top: 50%;
		right: -2.875rem;
		width: 2rem;
		height: 3.25rem;
		background-color: var(--wp--preset--color--primary);
		translate: 0 -50%;
		-webkit-mask: url("assets/images/icons/offer-rule-step-arrow.svg") center / contain no-repeat;
		mask: url("assets/images/icons/offer-rule-step-arrow.svg") center / contain no-repeat;
	}
}

@media (width >= 1200px) {
	.zq-offer-rule {
		grid-template-columns: 4.25rem minmax(0, 1fr);
		gap: 1.5rem;
		padding: 1.75rem 1.5rem;
	}
	.zq-offer-rule__title {
		font-size: 1.25rem;
	}
	.zq-offer-rule__text {
		font-size: 1rem;
	}
	.zq-offer-step__body strong {
		font-size: 1.375rem;
	}
}

@media (width < 420px) {
	.zq-offer-rules__heading {
		font-size: 2rem;
	}
	.zq-offer-rule {
		grid-template-columns: 3.25rem minmax(0, 1fr);
		padding: 1.5rem 1.25rem;
	}
	.zq-offer-rule__icon {
		width: 3rem;
		height: 3rem;
	}
	.zq-offer-rules__cta-heading {
		font-size: 1.75rem;
	}
	.zq-offer-rules__steps {
		padding: 1.5rem 1.25rem;
	}
	.zq-offer-step {
		grid-template-columns: 4rem minmax(0, 1fr);
	}
	.zq-offer-step__num {
		width: 4rem;
		height: 4rem;
		font-size: 2.625rem;
	}
}

@media (prefers-reduced-motion: reduce) {
	.zq-offer-rules__cta-button {
		transition-duration: 0ms;
	}
}

/* === Strona oferty: kontakt CTA === */
.zq-offer-contact {
	background: #000;
	padding-block: 0 5rem;
	padding-inline: var(--zq-offer-section-gutter);
}
.zq-offer-contact__inner {
	width: 100%;
	max-width: var(--zq-offer-section-width);
	margin-inline: auto;
}
.zq-offer-contact__heading {
	position: relative;
	margin: 0 0 1.75rem;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 2.25rem;
	font-weight: 700;
	line-height: 1;
	text-align: center;
	text-transform: uppercase;
}
.zq-offer-contact__heading::after {
	content: "";
	display: block;
	width: 3.75rem;
	height: .25rem;
	margin: .625rem auto 0;
	background: url("assets/images/offer-models-underline.svg") center / 100% 100% no-repeat;
}
.zq-offer-contact__panel {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.75rem;
	align-items: center;
	box-sizing: border-box;
	padding: 1.5rem;
	border: 1px solid rgba(129, 119, 119, .78);
	background: #1a1a1a;
}
.zq-offer-contact__intro-heading {
	max-width: 12ch;
	margin: 0;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 2rem;
	font-weight: 700;
	line-height: 1.05;
	text-transform: uppercase;
}
.zq-offer-contact__intro-heading::after {
	content: "";
	display: block;
	width: 3.75rem;
	height: .25rem;
	margin: .625rem 0 1rem;
	background: url("assets/images/offer-models-underline.svg") left center / 100% 100% no-repeat;
}

.zq-offer-models__heading::after,
.zq-offer-rules__heading::after,
.zq-offer-contact__heading::after,
.zq-offer-contact__intro-heading::after {
	transform-origin: center;
	scale: 0 1;
	animation: zq-offer-underline-draw .72s cubic-bezier(.6, 0, .25, 1) .15s forwards;
}

.zq-offer-contact__intro-heading::after {
	transform-origin: left center;
}

.zq-offer-underline-watch::after {
	animation: none;
}

.zq-offer-underline-watch.is-underline-visible::after {
	animation: zq-offer-underline-draw .72s cubic-bezier(.6, 0, .25, 1) forwards;
}

@keyframes zq-offer-underline-draw {
	to { scale: 1 1; }
}

@media (prefers-reduced-motion: reduce) {
	.zq-offer-models__heading::after,
	.zq-offer-rules__heading::after,
	.zq-offer-contact__heading::after,
	.zq-offer-contact__intro-heading::after,
	.zq-offer-underline-watch.is-underline-visible::after {
		animation: none;
		scale: 1 1;
	}
}
.zq-offer-contact__intro-text {
	max-width: 34ch;
	margin: 0;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 1rem;
	font-weight: 500;
	line-height: 1.35;
}
.zq-offer-contact__cards {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
}
.zq-offer-contact-card {
	display: grid;
	grid-template-columns: 3.25rem minmax(0, 1fr);
	align-items: center;
	gap: 1rem;
	min-height: 6.5rem;
	box-sizing: border-box;
	padding: 1rem 1.25rem;
	border: 1px solid var(--wp--preset--color--primary);
	color: var(--wp--preset--color--contrast);
	text-decoration: none;
	transition: background-color .2s ease, translate .15s ease;
}
.zq-offer-contact-card:hover {
	background: rgba(216, 92, 20, .12);
	color: var(--wp--preset--color--contrast);
	translate: 0 -2px;
}
.zq-offer-contact-card__icon {
	display: block;
	width: 2.875rem;
	height: 2.875rem;
	background-color: var(--wp--preset--color--contrast);
}
.zq-offer-contact-card__icon--phone {
	-webkit-mask: url("assets/images/icons/phone-call-filled.svg") center / contain no-repeat;
	mask: url("assets/images/icons/phone-call-filled.svg") center / contain no-repeat;
}
.zq-offer-contact-card__icon--mail {
	width: 3rem;
	height: 2.25rem;
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 384'%3E%3Cpath d='M48 0h416c26.5 0 48 21.5 48 48 0 15.1-7.1 29.3-19.2 38.4L275.2 249.6c-11.4 8.5-27 8.5-38.4 0L19.2 86.4C7.1 77.3 0 63.1 0 48 0 21.5 21.5 0 48 0Zm464 128v208c0 26.5-21.5 48-48 48H48c-26.5 0-48-21.5-48-48V128l217.6 163.2c22.8 17.1 54 17.1 76.8 0L512 128Z'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 384'%3E%3Cpath d='M48 0h416c26.5 0 48 21.5 48 48 0 15.1-7.1 29.3-19.2 38.4L275.2 249.6c-11.4 8.5-27 8.5-38.4 0L19.2 86.4C7.1 77.3 0 63.1 0 48 0 21.5 21.5 0 48 0Zm464 128v208c0 26.5-21.5 48-48 48H48c-26.5 0-48-21.5-48-48V128l217.6 163.2c22.8 17.1 54 17.1 76.8 0L512 128Z'/%3E%3C/svg%3E") center / contain no-repeat;
}
.zq-offer-contact-card__body {
	display: flex;
	flex-direction: column;
	gap: .25rem;
	min-width: 0;
	font-family: var(--wp--preset--font-family--body);
	line-height: 1;
	text-transform: uppercase;
}
.zq-offer-contact-card__body strong {
	color: var(--wp--preset--color--contrast);
	font-size: 1.375rem;
	font-weight: 700;
}
.zq-offer-contact-card__body span {
	color: var(--wp--preset--color--primary);
	font-size: 1.5rem;
	font-weight: 700;
	white-space: nowrap;
}
.zq-offer-contact-card--mail .zq-offer-contact-card__body span {
	font-size: 1rem;
	text-transform: none;
}

@media (width >= 640px) {
	.zq-offer-contact__cards {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
	.zq-offer-contact-card {
		grid-template-columns: 2.75rem minmax(0, 1fr);
		padding-inline: 1rem;
	}
	.zq-offer-contact-card__icon {
		width: 2.5rem;
		height: 2.5rem;
	}
	.zq-offer-contact-card__icon--mail {
		width: 2.75rem;
		height: 2rem;
	}
	.zq-offer-contact-card__body strong {
		font-size: 1.125rem;
	}
	.zq-offer-contact-card__body span {
		font-size: 1.25rem;
	}
	.zq-offer-contact-card--mail .zq-offer-contact-card__body span {
		font-size: .75rem;
	}
}

@media (width >= 960px) {
	.zq-offer-contact {
		padding-block: 0 6rem;
	}
	.zq-offer-contact__panel {
		grid-template-columns: minmax(18rem, .82fr) minmax(0, 1.9fr);
		gap: 3.25rem;
		min-height: 14rem;
		padding: 2rem 1.75rem;
	}
	.zq-offer-contact__intro-heading {
		font-size: 2.5rem;
	}
	.zq-offer-contact__cards {
		gap: 1.75rem;
	}
	.zq-offer-contact-card {
		min-height: 7.25rem;
	}
}

@media (width >= 1200px) {
	.zq-offer-contact__panel {
		grid-template-columns: minmax(20rem, .78fr) minmax(0, 1.8fr);
		padding: 2rem 2rem 2rem 1.5rem;
	}
	.zq-offer-contact__cards {
		gap: 1.875rem;
	}
	.zq-offer-contact-card {
		grid-template-columns: 3.25rem minmax(0, 1fr);
		padding: 1rem 1.25rem;
	}
	.zq-offer-contact-card__icon {
		width: 2.875rem;
		height: 2.875rem;
	}
	.zq-offer-contact-card__icon--mail {
		width: 3rem;
		height: 2.25rem;
	}
	.zq-offer-contact-card__body strong {
		font-size: 1.375rem;
	}
	.zq-offer-contact-card__body span {
		font-size: 1.5rem;
	}
	.zq-offer-contact-card--mail .zq-offer-contact-card__body span {
		font-size: .875rem;
	}
}

@media (width < 420px) {
	.zq-offer-contact__heading {
		font-size: 2rem;
	}
	.zq-offer-contact__panel {
		padding: 1.25rem;
	}
	.zq-offer-contact__intro-heading {
		font-size: 1.875rem;
	}
	.zq-offer-contact-card {
		grid-template-columns: 3rem minmax(0, 1fr);
		padding: 1rem;
	}
}

@media (prefers-reduced-motion: reduce) {
	.zq-offer-contact-card {
		transition-duration: 0ms;
	}
}

/* Aktywna pozycja menu */
header .wp-block-navigation-item.current-menu-item .wp-block-navigation-item__content,
body.home header .wp-block-navigation-item:first-child .wp-block-navigation-item__content,
body:has(.zq-offer-hero) header .wp-block-navigation-item__content[href="/oferta/"],
body:has(.zq-gallery-hero) header .wp-block-navigation-item__content[href="/galeria"],
body:has(.zq-contact-hero) header .wp-block-navigation-item__content[href="/kontakt"] {
	color: var(--wp--preset--color--primary);
}
/* Nawigacja: pomarańczowe podkreślenie (hover + aktywna) */
header .wp-block-navigation-item__content { position: relative; padding-bottom: 5px; }
header .wp-block-navigation-item__content::after {
	content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 2px;
	background: var(--wp--preset--color--primary);
	transform: scaleX(0); transform-origin: left; transition: transform .25s ease;
}
header .wp-block-navigation-item__content:hover::after,
header .wp-block-navigation-item.current-menu-item .wp-block-navigation-item__content::after,
body.home header .wp-block-navigation-item:first-child .wp-block-navigation-item__content::after,
body:has(.zq-offer-hero) header .wp-block-navigation-item__content[href="/oferta/"]::after,
body:has(.zq-gallery-hero) header .wp-block-navigation-item__content[href="/galeria"]::after,
body:has(.zq-contact-hero) header .wp-block-navigation-item__content[href="/kontakt"]::after { transform: scaleX(1); }

/* Pomarańczowa linia pod menu — zaczyna się przy ukosie logo (nie nachodzi na logo) i biegnie w prawo */
header.wp-block-group::after {
	content: ""; position: absolute; left: 228px; right: 0; bottom: 0; height: 4px; z-index: 3;
	background: url("assets/images/linia-pod-menu.svg") no-repeat;
	background-size: 100% 100%;
	transform: scaleX(0); transform-origin: left;
	animation: zq-underline-draw .9s cubic-bezier(.6, 0, .25, 1) .4s forwards;
}
@keyframes zq-underline-draw { to { transform: scaleX(1); } }
@media (prefers-reduced-motion: reduce) {
	header.wp-block-group::after { animation: none; transform: scaleX(1); }
}

/* === Sekcja „O nas" — styl przeniesiony na block-style'y zq-* (patrz niżej, Etap 1). === */

/* ============================================================
   BLOCK-STYLE'Y zq-* — konfigurowalne sekcje (Etap 1: o-nas).
   Natywne bloki WP stylowane jak dawne .zq-* (parytet wyglądu).
   ============================================================ */

/* Sekcja-kontener: overlay dla czytelności na grunge-tle */
.wp-block-group.is-style-zq-section { position: relative; isolation: isolate; }
.wp-block-group.is-style-zq-section > * { position: relative; z-index: 1; }
.wp-block-group.is-style-zq-section::before {
	content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
	background: linear-gradient(90deg, rgba(20, 17, 15, .55) 0%, rgba(20, 17, 15, .22) 55%, rgba(20, 17, 15, .6) 100%);
}

/* Sekcja „O nas": tło grunge + układ na pełną szerokość */
.zq-about.is-style-zq-section {
	background: var(--wp--preset--color--base-2) url("assets/images/bg/bg-onas.webp") center / cover no-repeat;
	padding: clamp(3rem, 7vw, 6.5rem) 0;
}
.zq-about > .wp-block-columns {
	width: 100%; max-width: none; margin: 0;
	padding-inline: 6vw 2rem;
	align-items: center;
}
.zq-about .wp-block-image { margin: 0; }
.zq-about .wp-block-image img { display: block; width: 100%; height: auto; }

/* Eyebrow: /// + uppercase pomarańczowy + swash (Line 9) */
.is-style-zq-eyebrow {
	position: relative; display: inline-block; padding-bottom: .9rem; margin: 0 0 1rem;
	font-family: var(--wp--preset--font-family--body); font-weight: 700;
	text-transform: uppercase; letter-spacing: .2em; color: var(--wp--preset--color--primary);
	font-size: 24px;
}
.is-style-zq-eyebrow::before { content: "///"; margin-right: .5em; letter-spacing: .05em; }
.is-style-zq-eyebrow::after {
	content: ""; position: absolute; left: 0; bottom: 0; width: 100%; height: 11px;
	background: url("assets/images/eyebrow-line.svg") no-repeat left center; background-size: 100% 100%;
	-webkit-clip-path: inset(0 100% 0 0); clip-path: inset(0 100% 0 0);
	animation: zq-swash-draw .8s cubic-bezier(.6, 0, .25, 1) .35s forwards;
}
@media (prefers-reduced-motion: reduce) {
	.is-style-zq-eyebrow::after { animation: none; -webkit-clip-path: none; clip-path: none; }
}

/* Tytuł display: font + pomarańczowe słowo (mark) jako blok. Rozmiary — per sekcja niżej. */
.is-style-zq-display {
	font-family: var(--wp--preset--font-family--display); text-transform: uppercase;
	line-height: .92; letter-spacing: .04em; margin: 0 0 1.6rem;
	color: var(--wp--preset--color--contrast);
}
.is-style-zq-display mark {
	color: var(--wp--preset--color--primary); background: transparent;
	display: block; line-height: .9;
}

/* — Sekcja „O nas": rozmiary/odstępy specyficzne — */
.zq-about .is-style-zq-eyebrow { margin-bottom: 50px; }
.zq-about .is-style-zq-display { font-size: clamp(2.75rem, 8.6vw, 110px); }
.zq-about .is-style-zq-display mark { font-size: clamp(4rem, 12.9vw, 165px); letter-spacing: .01em; }

/* Kreska (Line 10) */
.wp-block-separator.is-style-zq-line {
	border: 0; opacity: 1; height: 5px;
	/* !important bije core'ową regułę separatora (:not(.is-style-wide):not(.is-style-dots) — centruje i daje 100px) */
	width: 190px !important; max-width: none !important; margin: 1.6rem 0 !important;
	background: url("assets/images/line-10.svg") no-repeat left center; background-size: 100% 100%;
}

/* Lead-y w sekcji: 21px, #fff, line-height 1.7; pomarańczowe słowa = mark */
.is-style-zq-section p.has-lead-font-size { color: #fff; line-height: 1.7; margin: 0; }
.is-style-zq-section p.has-lead-font-size mark { color: var(--wp--preset--color--primary); background: transparent; }

/* CTA ghost + pomarańczowy box ze strzałką — na jednym natywnym buttonie */
.wp-block-button.is-style-zq-arrow { margin-top: 2.2rem; }
.is-style-zq-arrow .wp-block-button__link {
	position: relative; display: inline-flex; align-items: center; overflow: hidden; border-radius: 0;
	background-color: rgba(0, 0, 0, .35); border: 2px solid var(--wp--preset--color--primary); color: #fff;
	font-family: var(--wp--preset--font-family--body); font-weight: 700; text-transform: uppercase;
	line-height: 1; /* rozmiar/letter-spacing dziedziczone z domyślnego buttona (płynne, spójne z resztą) */
	/* padding-right = box strzałki + 1rem przerwy między tekstem a strzałką */
	padding: 12px calc(clamp(.7rem, 1.2vw, 1rem) * 2 + 30px + 1rem) 12px clamp(1.2rem, 2vw, 1.8rem);
	transition: transform .2s ease;
}
.is-style-zq-arrow .wp-block-button__link::after {
	content: ""; position: absolute; top: 0; right: 0; bottom: 0;
	width: calc(clamp(.7rem, 1.2vw, 1rem) * 2 + 30px);
	background-color: var(--wp--preset--color--primary);
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 5l7 7-7 7'/%3E%3C/svg%3E");
	background-repeat: no-repeat; background-position: center; background-size: 30px 30px;
}
.is-style-zq-arrow .wp-block-button__link:hover { transform: translateY(-2px); }
.is-style-zq-arrow .wp-block-button__link:hover::after { background-color: var(--wp--preset--color--primary-hover); }

/* Mobile: kolumny stackują (jak dawny grid 1fr), zdjęcie wyśrodkowane */
@media (max-width: 781px) {
	.zq-about > .wp-block-columns { padding: 0 1.5rem; }
	.zq-about .wp-block-image { max-width: 420px; margin-inline: auto; }
}

/* === Sekcja „Nasz garaż" — karuzela quadów === */
.zq-garaz { background: var(--wp--preset--color--base) url("assets/images/bg/bg-garaz.webp") center / cover no-repeat; padding: clamp(3rem, 7vw, 6.5rem) 0 clamp(2.5rem, 5vw, 4rem); overflow: hidden; }
.zq-garaz__inner { max-width: 1280px; margin: 0 auto; padding: 0 2rem; }
.zq-garaz__head { max-width: 760px; }
.zq-garaz__eyebrow {
	color: var(--wp--preset--color--primary); font-family: var(--wp--preset--font-family--body);
	font-weight: 700; text-transform: uppercase; letter-spacing: .2em;
}
.zq-garaz__slash { letter-spacing: .05em; margin-right: .4em; }
.zq-garaz__title {
	font-family: var(--wp--preset--font-family--display); text-transform: uppercase;
	line-height: .92; letter-spacing: .03em; margin: 2rem 0 1.3rem;
	font-size: clamp(2.5rem, 8.6vw, 110px); color: var(--wp--preset--color--contrast);
}
.zq-garaz__title .zq-hl { color: var(--wp--preset--color--primary); }
.zq-garaz__lead {
	font-family: var(--wp--preset--font-family--body); font-size: 21px; line-height: 1.65;
	color: #fff; margin: 0;
}
.zq-garaz__lead .zq-hl { color: var(--wp--preset--color--primary); }

/* Karuzela */
/* Karuzela wyrywa się z kontenera 1280px na pełną szerokość viewportu (karty wyjeżdżają poza ekran). */
.zq-karuzela { position: relative; margin-top: clamp(2rem, 4vw, 3.5rem); width: 100vw; left: 50%; margin-left: -50vw; }
.zq-karuzela__track {
	display: flex; gap: clamp(1rem, 2vw, 1.75rem); align-items: center;
	overflow-x: auto; scroll-snap-type: x mandatory; scrollbar-width: none; padding-bottom: .5rem;
}
.zq-karuzela__track::-webkit-scrollbar { display: none; }
.zq-karuzela__track.is-centered { justify-content: center; overflow-x: visible; }

/* Karta = oprawione zdjęcie (ramka w pliku PNG) + nakładka opisu. Coverflow: karty nachodzą na siebie. */
.zq-quad-card {
	position: relative; flex: 0 0 auto;
	width: clamp(300px, 35vw, 510px); margin: 0 clamp(-125px, -8.5vw, -72px);
	scroll-snap-align: center;
	opacity: .5; transform: scale(.87); transform-origin: center; cursor: pointer;
	transition: opacity .45s ease, transform .45s ease;
}
.zq-quad-card.is-active { opacity: 1; transform: scale(1); cursor: default; }
.zq-quad-card__photo { display: block; width: 100%; height: auto; }

/* Wyciemnienie dołu kadru — gradient maskowany kształtem zdjęcia (trzyma się skośnej ramki PNG). */
.zq-quad-card__shade {
	position: absolute; inset: 0; z-index: 1; pointer-events: none;
	/* Ciemno pod tekstem, ale wygaszone przed dolną ramką (~93%), by pomarańcz ramki był widoczny. */
	background: linear-gradient(to bottom, transparent 32%, rgba(8, 6, 5, .5) 58%, rgba(8, 6, 5, .85) 85%, rgba(8, 6, 5, .3) 91%, transparent 97%);
	-webkit-mask-size: 100% 100%; mask-size: 100% 100%;
	-webkit-mask-repeat: no-repeat; mask-repeat: no-repeat;
}

/* Nakładka opisu na zdjęciu — wcięta WEWNĄTRZ ramki PNG (ramka kończy się ~8.7% od krawędzi). */
.zq-quad-card__info {
	position: absolute; left: 12%; right: 12%; bottom: 13%; z-index: 2;
	text-shadow: 0 2px 10px rgba(0, 0, 0, .8);
}
.zq-quad-card__badge {
	margin: 0 0 .4rem; font-family: var(--wp--preset--font-family--body);
	font-weight: 700; text-transform: uppercase; letter-spacing: .22em;
	font-size: clamp(.7rem, 1.05vw, 15px); color: var(--wp--preset--color--primary);
}
.zq-quad-card__title {
	position: relative; margin: 0 0 .6rem; padding-bottom: .45rem;
	/* Oswald, nie Eroded — Eroded nie ma cyfr (renderuje ornament w miejscu numeru modelu). */
	font-family: var(--wp--preset--font-family--body); font-weight: 700; text-transform: uppercase;
	letter-spacing: .03em; line-height: 1.05; font-size: clamp(1.25rem, 1.97vw, 28px);
	color: var(--wp--preset--color--contrast);
}
.zq-quad-card__title::after {
	content: ""; position: absolute; left: 0; bottom: 0; width: 100%; height: 2px;
	background: linear-gradient(to right, var(--wp--preset--color--primary) 0 26%, rgba(245, 241, 234, .28) 26%);
}
/* Specy na całą szerokość opisu (rozstrzelone), większe ikony. */
.zq-quad-card__specs { list-style: none; margin: 0; padding: 0; width: 100%; display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: .45rem .4rem; }
.zq-quad-card__specs li { display: flex; align-items: center; gap: .4em; font-family: var(--wp--preset--font-family--body); font-weight: 600; text-transform: uppercase; letter-spacing: .01em; font-size: clamp(.78rem, 1.05vw, 15px); color: #fff; white-space: nowrap; }
.zq-quad-card__ico { width: clamp(22px, 2.25vw, 32px); height: clamp(22px, 2.25vw, 32px); color: var(--wp--preset--color--primary); flex: none; }

/* Strzałki — sam pomarańczowy chevron, bez tła (jak w projekcie).
   z-index PONAD kartami (aktywna karta ma z-index 100), inaczej karta przejmuje klik. */
.zq-karuzela__nav {
	position: absolute; top: 50%; transform: translateY(-50%); z-index: 150;
	width: clamp(34px, 3.2vw, 50px); height: clamp(34px, 3.2vw, 50px);
	border: none; padding: 0; background: none; cursor: pointer;
	color: var(--wp--preset--color--primary);
	display: flex; align-items: center; justify-content: center;
	transition: color .2s ease, opacity .2s ease, transform .2s ease;
}
.zq-karuzela__nav svg { width: 100%; height: 100%; display: block; filter: drop-shadow(0 2px 6px rgba(0, 0, 0, .55)); }
.zq-karuzela__nav--prev { left: clamp(12px, 4vw, 80px); }
.zq-karuzela__nav--next { right: clamp(12px, 4vw, 80px); }
.zq-karuzela__nav:hover { color: var(--wp--preset--color--primary-hover); transform: translateY(-50%) scale(1.12); }
.zq-karuzela__nav:disabled { opacity: .25; cursor: default; }

/* Kropki + licznik */
.zq-karuzela__footer { position: relative; z-index: 5; display: flex; align-items: center; justify-content: center; gap: 1.5rem; margin-top: clamp(.4rem, 1.2vw, 1rem); }
.zq-karuzela__dots { display: flex; gap: .6rem; }
.zq-karuzela__dot { width: 10px; height: 10px; border-radius: 50%; border: none; padding: 0; cursor: pointer; background: #d9d9d9; transition: background-color .2s ease, transform .2s ease; }
.zq-karuzela__dot.is-active { background: var(--wp--preset--color--primary); transform: scale(1.25); }
.zq-karuzela__counter { font-family: var(--wp--preset--font-family--body); font-weight: 700; letter-spacing: .1em; color: var(--wp--preset--color--muted); font-size: .95rem; }
@media (max-width: 781px) {
	/* Mobilny slider: BEZ wyrywania na 100vw (left/margin-left) — to wyrywanie na wąskich
	   ekranach rozjeżdżało pozycję i karta uciekała poza ekran. Karuzela zostaje w sekcji,
	   karta jest WĘŻSZA od toru (80% toru, nie 80vw), więc zawsze centruje się poprawnie.
	   Bez ujemnych marginesów (coverflow-nachodzenie). */
	.zq-karuzela { width: auto; left: auto; margin-left: 0; }
	.zq-karuzela__track { scroll-padding-inline: 10%; }
	.zq-quad-card { width: 80%; max-width: 420px; margin: 0; }
	.zq-karuzela__nav { width: 44px; height: 44px; font-size: 1.4rem; }
	.zq-karuzela__nav--prev { left: 2px; }
	.zq-karuzela__nav--next { right: 2px; }
}

/* === Sekcja „Oferta — Zobacz jak to działa" (natywne bloki) === */
.zq-oferta.is-style-zq-section {
	background-color: var(--wp--preset--color--base);
	background-image: url("assets/images/bg/bg-oferta.webp");
	background-size: cover; background-position: center; background-repeat: no-repeat;
	/* boczny padding jawnie — sekcja jest zagnieżdżona, więc nie dostaje root-paddingu (jak inne) */
	padding: clamp(3rem, 7vw, 6.5rem) clamp(1.5rem, 3vw, 2rem);
	overflow: hidden;
}
/* Tytuł + lead — rozmiary/odstępy oferty (eyebrow/CTA z block-styli zq-*) */
.zq-oferta .is-style-zq-display { font-size: clamp(2.75rem, 11vw, 150px); line-height: .9; letter-spacing: .02em; margin: 2rem 0 1.4rem; }
.zq-oferta .has-lead-font-size { margin: 0 0 2.2rem; max-width: 48ch; }
.zq-oferta__top .wp-block-image img { display: block; width: 100%; height: auto; }
/* Góra: tekst | zdjęcie — środek w pionie + odstęp do kart */
.zq-oferta__top { align-items: center; margin-bottom: clamp(2.5rem, 5vw, 4.5rem) !important; }

/* 3 karty cech — równa wysokość (natywne kolumny); octagon/Line 12 jak w makiecie */
.zq-oferta__features .wp-block-column { display: flex; }
.zq-oferta__feature {
	position: relative; --cut: 18px; text-align: center; width: 100%;
	--oct: polygon(var(--cut) 0, calc(100% - var(--cut)) 0, 100% var(--cut), 100% calc(100% - var(--cut)), calc(100% - var(--cut)) 100%, var(--cut) 100%, 0 calc(100% - var(--cut)), 0 var(--cut));
	clip-path: var(--oct);
	background: rgba(216, 92, 20, .4);
	padding: clamp(1.75rem, 3vw, 2.6rem) clamp(.9rem, 1.6vw, 1.35rem);
}
.zq-oferta__feature::before { content: ""; position: absolute; inset: 1.5px; z-index: 0; clip-path: var(--oct); background: #1a1714; }
.zq-oferta__feature > * { position: relative; z-index: 1; }
/* Stała wysokość ikony — klasa jest na <figure>, więc rozmiar idzie na img */
.zq-oferta__ico { margin: 0 auto 1.3rem; }
.zq-oferta__ico img { height: clamp(50px, 5vw, 64px); width: auto; display: block; margin: 0 auto; }
.zq-oferta__feature-title {
	font-family: var(--wp--preset--font-family--body); font-weight: 700; text-transform: uppercase;
	white-space: nowrap; letter-spacing: .02em; font-size: clamp(1.3rem, 2.35vw, 35px);
	color: var(--wp--preset--color--contrast); margin: 0 0 1.1rem;
}
.zq-oferta__feature-title::after {
	content: ""; display: block; height: 2px; width: 100%; margin: 1.1rem auto 0;
	background: linear-gradient(to right, #464646 0 38%, var(--wp--preset--color--primary) 38% 62%, #464646 62% 100%);
}
.zq-oferta__feature-text {
	font-family: var(--wp--preset--font-family--body); font-size: clamp(.95rem, 1.4vw, 20px);
	line-height: 1.55; color: #fff; margin: 0;
}
.zq-oferta__feature-text .zq-hl, .zq-oferta__feature-text mark { color: var(--wp--preset--color--primary); font-weight: 600; background: transparent; }

@media (max-width: 781px) {
	.zq-oferta__features .wp-block-column { display: block; }
}

/* === Sekcja „Zobacz nas w akcji" — mozaika + wideo === */
.zq-akcja {
	background-color: var(--wp--preset--color--base);
	background-image: url("assets/images/bg/bg-akcja.webp");
	background-size: cover; background-position: center; background-repeat: no-repeat;
	padding: clamp(3rem, 7vw, 6.5rem) 0;
}
.zq-akcja__inner { max-width: 1280px; margin: 0 auto; padding: 0 2rem; }
.zq-akcja__title {
	font-family: var(--wp--preset--font-family--display); text-transform: uppercase;
	text-align: center; line-height: .95; letter-spacing: .03em;
	font-size: clamp(2.5rem, 9vw, 110px); color: var(--wp--preset--color--contrast);
	margin: 0 0 clamp(2rem, 4vw, 3.5rem);
}
.zq-akcja__title .zq-hl { color: var(--wp--preset--color--primary); }

/* Mozaika 12-kolumnowa */
.zq-akcja__grid {
	display: grid; grid-template-columns: repeat(12, 1fr);
	grid-auto-rows: clamp(150px, 17vw, 235px);
	gap: clamp(.5rem, 1vw, 1rem);
}
.zq-akcja__tile {
	position: relative; overflow: hidden; margin: 0; padding: 0; border: none;
	background: #1a1714;
}
.zq-akcja__tile img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .5s ease; }
.zq-akcja__tile:hover img { transform: scale(1.05); }
.zq-akcja__tile--a { grid-column: span 5; }
.zq-akcja__tile--b { grid-column: span 4; }
.zq-akcja__tile--c { grid-column: span 3; }
.zq-akcja__tile--d { grid-column: span 2; }
.zq-akcja__tile--e { grid-column: span 2; }
.zq-akcja__tile--video { grid-column: span 3; }
.zq-akcja__tile--g { grid-column: span 5; }

/* Kafelek wideo */
.zq-akcja__tile--video { cursor: pointer; }
.zq-akcja__tile--video img { opacity: .5; }
.zq-akcja__video-overlay {
	position: absolute; inset: 0; z-index: 1;
	display: flex; flex-direction: column; align-items: center; justify-content: center; gap: .9rem;
	background: rgba(10, 8, 7, .3); transition: background-color .3s ease;
}
.zq-akcja__tile--video:hover .zq-akcja__video-overlay { background: rgba(10, 8, 7, .12); }
.zq-akcja__play { color: #fff; transition: transform .3s ease; }
.zq-akcja__tile--video:hover .zq-akcja__play { transform: scale(1.12); }
.zq-akcja__play-ico { width: clamp(48px, 5vw, 70px); height: auto; display: block; filter: drop-shadow(0 2px 8px rgba(0, 0, 0, .6)); }
.zq-akcja__video-label {
	position: relative; font-family: var(--wp--preset--font-family--body); font-weight: 700;
	text-transform: uppercase; letter-spacing: .04em; font-size: clamp(1.1rem, 2vw, 30px);
	color: #fff; padding-bottom: .6rem;
}
.zq-akcja__video-label::after { /* Line 15: krótka pomarańczowa kreska */
	content: ""; position: absolute; left: 50%; bottom: 0; transform: translateX(-50%);
	width: 59px; height: 2px; background: var(--wp--preset--color--primary);
}

/* CTA „Zobacz galerię" — firmowy WP button (primary, ostre rogi z jednolitego systemu) */
.zq-akcja__cta-wrap { display: flex; justify-content: center; margin-top: clamp(2rem, 4vw, 3.5rem); }

/* Lightbox wideo (własna nazwa .zq-vbox — by nie kolidować ze starym .zq-lightbox z wow.js) */
.zq-vbox {
	position: fixed; inset: 0; z-index: 9999;
	display: flex; align-items: center; justify-content: center;
	background: rgba(5, 4, 3, .92); padding: clamp(1rem, 4vw, 4rem);
}
.zq-vbox[hidden] { display: none; }
.zq-vbox__video { width: 100%; max-width: 1100px; max-height: 85vh; background: #000; }
.zq-vbox__close {
	position: absolute; top: clamp(1rem, 3vw, 2.5rem); right: clamp(1rem, 3vw, 2.5rem);
	width: 48px; height: 48px; border: none; background: none; color: #fff;
	font-size: 2.4rem; line-height: 1; cursor: pointer; transition: color .2s ease;
}
.zq-vbox__close:hover { color: var(--wp--preset--color--primary); }

@media (max-width: 860px) {
	.zq-akcja__grid { grid-template-columns: repeat(6, 1fr); grid-auto-rows: clamp(120px, 30vw, 200px); }
	.zq-akcja__tile--a, .zq-akcja__tile--g { grid-column: span 6; }
	.zq-akcja__tile--b, .zq-akcja__tile--c, .zq-akcja__tile--d,
	.zq-akcja__tile--e, .zq-akcja__tile--video { grid-column: span 3; }
}

/* === Sekcja „Opinie klientów — Ludzie mówią że warto" === */
.zq-opinie {
	background-color: var(--wp--preset--color--base);
	background-image: url("assets/images/bg/bg-opinie.webp");
	background-size: cover; background-position: center; background-repeat: no-repeat;
	padding: clamp(3rem, 7vw, 6.5rem) 0;
	overflow: hidden;
}
.zq-opinie__inner { max-width: 1280px; margin: 0 auto; padding: 0 2rem; }

/* Nagłówek: tytuł + karta Google */
.zq-opinie__head {
	display: flex; flex-direction: column; gap: clamp(1.75rem, 3.5vw, 2.75rem);
	margin-bottom: clamp(2.5rem, 5vw, 4rem);
}
/* Rząd: tytuł + karta Google wyśrodkowane WZGLĘDEM SIEBIE (eyebrow jest osobno, nad nim). */
.zq-opinie__headrow {
	display: flex; flex-wrap: wrap; justify-content: flex-start; align-items: center;
	gap: clamp(3rem, 7vw, 6.5rem);
}
.zq-opinie__eyebrow {
	align-self: flex-start; /* nie rozciągaj na całą szerokość — podkreślnik (::after width:100%) tylko pod tekstem */
	margin: 0; color: var(--wp--preset--color--primary); font-family: var(--wp--preset--font-family--body);
	font-weight: 700; text-transform: uppercase; letter-spacing: .2em;
}
.zq-opinie__slash { margin-right: .4em; }
.zq-opinie__title {
	font-family: var(--wp--preset--font-family--display); text-transform: uppercase;
	line-height: .9; letter-spacing: .02em; margin: 0;
	font-size: clamp(2.75rem, 10vw, 150px); color: var(--wp--preset--color--contrast);
}
.zq-opinie__title .zq-hl { color: var(--wp--preset--color--primary); display: block; }

/* Karta Google Rating */
/* Karta Google Rating — gotowe zdjęcie (link do profilu Google) */
.zq-opinie__rating { display: block; width: clamp(300px, 36vw, 420px); box-shadow: 0 14px 44px rgba(0, 0, 0, .45); border-radius: 14px; transition: transform .2s ease; }
.zq-opinie__rating:hover { transform: translateY(-3px); }
.zq-opinie__rating img { width: 100%; height: auto; display: block; border-radius: 14px; }
.zq-opinie__g { width: 1.5em; height: 1.5em; flex: none; display: block; }

/* Gwiazdki (pomarańczowe — brand) */
.zq-opinie__stars { display: inline-flex; align-items: center; gap: .15rem; }
.zq-opinie__star { width: clamp(20px, 2vw, 28px); height: auto; display: block; }

/* Karuzela opinii */
.zq-opinie__carousel { position: relative; }
.zq-opinie__track { display: flex; align-items: center; gap: clamp(1rem, 2vw, 1.75rem); overflow-x: auto; scroll-snap-type: x mandatory; scrollbar-width: none; padding-bottom: .5rem; }
.zq-opinie__track.is-centered { justify-content: center; overflow-x: visible; }
.zq-opinie__track::-webkit-scrollbar { display: none; }

/* Karta opinii — ośmiokąt (ścięte 4 rogi) + coverflow 3D jak slider quadów */
.zq-opinie-card {
	flex: 0 0 auto; box-sizing: border-box; width: clamp(300px, 30vw, 397px); aspect-ratio: 397 / 457.5; margin: 0 clamp(-22px, -1.2vw, -10px);
	scroll-snap-align: center; cursor: pointer;
	opacity: .62; transform-origin: center;
	/* Coverflow 3D: boczne karty lekko przekręcone (rotateY wg znakowanego offsetu z karuzela.js). */
	transform: perspective(1300px) rotateY(calc(var(--cf-offset, 0) * -19deg)) scale(.88);
	transition: opacity .5s ease, transform .55s cubic-bezier(.22, .61, .36, 1);
	will-change: transform;
	position: relative; --cut: 18px;
	--oct: polygon(var(--cut) 0, calc(100% - var(--cut)) 0, 100% var(--cut), 100% calc(100% - var(--cut)), calc(100% - var(--cut)) 100%, var(--cut) 100%, 0 calc(100% - var(--cut)), 0 var(--cut));
	clip-path: var(--oct);
	background: var(--wp--preset--color--primary);
	display: flex; flex-direction: column; padding: clamp(1.5rem, 2.4vw, 2rem);
}
.zq-opinie-card.is-active { opacity: 1; transform: perspective(1300px) rotateY(0deg) scale(1); cursor: default; }
.zq-opinie-card::before {
	content: ""; position: absolute; inset: 2px; z-index: 0; background: #1a1714; clip-path: var(--oct);
}
.zq-opinie-card > * { position: relative; z-index: 1; }
.zq-opinie-card__top { display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem; margin-bottom: .9rem; }
.zq-opinie-card__quote { width: clamp(40px, 4vw, 56px); height: auto; display: block; }
.zq-opinie-card__top .zq-opinie__stars { margin-top: .3rem; }
.zq-opinie-card__text { font-family: var(--wp--preset--font-family--body); font-size: clamp(1rem, 1.4vw, 20px); line-height: 1.6; color: #fff; margin: 0 0 1.2rem; flex: 1; }
.zq-opinie-card__rule { display: block; height: 2px; width: 100%; margin: 0 0 1.2rem; flex: none; /* Line 12: szara z pomarańczowym środkiem */
	background: linear-gradient(to right, #464646 0 38%, var(--wp--preset--color--primary) 38% 62%, #464646 62% 100%); }
.zq-opinie-card__foot { display: flex; align-items: center; gap: .75rem; }
.zq-opinie-card__avatar { width: 44px; height: 44px; border-radius: 50%; flex: none; background: var(--wp--preset--color--primary); color: #fff; display: flex; align-items: center; justify-content: center; font-family: var(--wp--preset--font-family--body); font-weight: 700; font-size: 1.15rem; text-transform: uppercase; }
.zq-opinie-card__meta { display: flex; flex-direction: column; line-height: 1.25; margin-right: auto; }
.zq-opinie-card__name { font-family: var(--wp--preset--font-family--body); font-weight: 700; font-size: clamp(1.15rem, 1.75vw, 25px); color: var(--wp--preset--color--contrast); }
.zq-opinie-card__when { font-size: clamp(.9rem, 1.4vw, 20px); color: var(--wp--preset--color--muted); }
.zq-opinie-card__foot .zq-opinie__g { width: 28px; height: 28px; }

/* Strzałki + kropki — z istniejącego slidera quadów (.zq-karuzela__nav / .zq-karuzela__dot). */
.zq-opinie__dots { display: flex; justify-content: center; gap: .6rem; margin-top: clamp(1.5rem, 3vw, 2.5rem); }

@media (max-width: 980px) {
	.zq-opinie-card { flex-basis: clamp(260px, 47%, 360px); }
}
@media (max-width: 600px) {
	.zq-opinie__head { flex-direction: column; }
	.zq-opinie__rating { width: 100%; }
	.zq-opinie-card { flex-basis: 84%; }
}

/* === Strona kontaktu: hero === */
.zq-contact-page-main {
	margin-top: 0;
	background: #000;
}
.zq-contact-hero {
	position: relative;
	isolation: isolate;
	min-height: 612px;
	background-color: var(--wp--preset--color--base);
	background-position: center top;
	background-repeat: no-repeat;
	background-size: cover;
	overflow: hidden;
}
.zq-contact-hero::after {
	content: "";
	position: absolute;
	inset: auto 0 0;
	z-index: 0;
	height: 38%;
	background: linear-gradient(180deg, rgba(20, 17, 15, 0) 0%, rgba(20, 17, 15, .7) 48%, rgba(20, 17, 15, .98) 100%);
	pointer-events: none;
}
.zq-contact-hero__inner {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	min-height: 612px;
	width: 100%;
	max-width: 1280px;
	margin: 0 auto;
	padding: 78px 2rem 26px;
	box-sizing: border-box;
}
.zq-contact-hero__content {
	max-width: 780px;
	margin-bottom: 50px;
}
.zq-contact-hero .is-style-zq-eyebrow {
	margin-bottom: 34px;
	font-size: 24px;
	letter-spacing: .2em;
}
.zq-contact-hero .is-style-zq-eyebrow::before {
	content: none;
	margin: 0;
}
.zq-contact-hero__title {
	margin: 0 0 28px;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--display);
	font-size: 150px;
	font-weight: 400;
	line-height: .9;
	letter-spacing: 0;
	text-transform: uppercase;
}
.zq-contact-hero__title mark {
	background: transparent;
	color: var(--wp--preset--color--primary);
}
.zq-contact-hero__lead {
	max-width: 760px;
	margin: 0;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 24px;
	font-weight: 500;
	line-height: 1.24;
	text-shadow: 0 2px 12px rgba(0, 0, 0, .45);
}
.zq-contact-cards {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
	margin: 0;
}
.zq-contact-card {
	display: grid;
	grid-template-columns: 64px minmax(0, 1fr);
	column-gap: 18px;
	align-items: stretch;
	min-height: 196px;
	padding: 24px 28px 11px;
	box-sizing: border-box;
	background: #1a1a1a;
	box-shadow: 0 18px 34px rgba(0, 0, 0, .24);
}
.zq-contact-card__icon {
	width: 64px;
	height: 64px;
	margin-top: 15px;
	align-self: start;
	object-fit: contain;
}
.zq-contact-card--mail {
	column-gap: 30px;
}
.zq-contact-card__mail-icon {
	width: 70px;
	height: 52px;
	margin-top: 15px;
	align-self: start;
	background-color: var(--wp--preset--color--primary);
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 384'%3E%3Cpath d='M48 0h416c26.5 0 48 21.5 48 48 0 15.1-7.1 29.3-19.2 38.4L275.2 249.6c-11.4 8.5-27 8.5-38.4 0L19.2 86.4C7.1 77.3 0 63.1 0 48 0 21.5 21.5 0 48 0Zm464 128v208c0 26.5-21.5 48-48 48H48c-26.5 0-48-21.5-48-48V128l217.6 163.2c22.8 17.1 54 17.1 76.8 0L512 128Z'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 384'%3E%3Cpath d='M48 0h416c26.5 0 48 21.5 48 48 0 15.1-7.1 29.3-19.2 38.4L275.2 249.6c-11.4 8.5-27 8.5-38.4 0L19.2 86.4C7.1 77.3 0 63.1 0 48 0 21.5 21.5 0 48 0Zm464 128v208c0 26.5-21.5 48-48 48H48c-26.5 0-48-21.5-48-48V128l217.6 163.2c22.8 17.1 54 17.1 76.8 0L512 128Z'/%3E%3C/svg%3E") center / contain no-repeat;
}
.zq-contact-card__main {
	display: flex;
	flex-direction: column;
	min-width: 0;
	height: 100%;
}
.zq-contact-card__name {
	margin: 0;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 50px;
	font-weight: 700;
	line-height: .9;
	letter-spacing: 0;
	text-transform: uppercase;
}
.zq-contact-card__phone,
.zq-contact-card__email {
	display: block;
	color: var(--wp--preset--color--primary);
	font-family: var(--wp--preset--font-family--body);
	font-weight: 700;
	text-decoration: none;
	text-transform: uppercase;
}
.zq-contact-card__phone {
	display: inline-block;
	margin-top: 4px;
	font-size: 50px;
	line-height: .9;
	letter-spacing: 0;
	transform: scaleX(.86);
	transform-origin: left center;
	white-space: nowrap;
}
.zq-contact-card__email {
	margin-top: 10px;
	font-size: 22px;
	line-height: 1;
	letter-spacing: 0;
}
.zq-contact-card__button {
	display: flex;
	align-items: center;
	justify-content: center;
	width: max-content;
	min-width: 165px;
	min-height: 43px;
	margin-top: auto;
	padding: 8px 18px;
	box-sizing: border-box;
	background: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 20px;
	font-weight: 700;
	line-height: 1;
	text-decoration: none;
	text-transform: uppercase;
	transition: background-color .2s ease, transform .15s ease;
}
.zq-contact-card__button:hover {
	background: var(--wp--preset--color--primary-hover);
	color: var(--wp--preset--color--contrast);
	transform: translateY(-2px);
}

@media (max-width: 1024px) {
	.zq-contact-hero,
	.zq-contact-hero__inner { min-height: 700px; }
	.zq-contact-hero__title { font-size: 122px; }
	.zq-contact-card {
		grid-template-columns: 58px minmax(0, 1fr);
		column-gap: 18px;
		padding-left: 26px;
		padding-right: 26px;
	}
	.zq-contact-card__icon { width: 58px; height: 58px; }
	.zq-contact-card--mail { column-gap: 24px; }
	.zq-contact-card__icon,
	.zq-contact-card__mail-icon { margin-top: 17px; }
	.zq-contact-card__mail-icon { width: 64px; height: 48px; }
	.zq-contact-card__name,
	.zq-contact-card__phone { font-size: 42px; }
}

@media (max-width: 900px) {
	.zq-contact-hero {
		min-height: auto;
		background-position: 62% top;
	}
	.zq-contact-hero::before {
		content: "";
		position: absolute;
		inset: 0;
		z-index: 0;
		background: linear-gradient(90deg, rgba(20, 17, 15, .92) 0%, rgba(20, 17, 15, .72) 48%, rgba(20, 17, 15, .36) 100%);
	}
	.zq-contact-hero__inner {
		min-height: auto;
		padding-top: 74px;
		padding-bottom: 34px;
	}
	.zq-contact-hero__content {
		max-width: 640px;
		margin-bottom: 38px;
	}
	.zq-contact-hero__title { font-size: 92px; }
	.zq-contact-cards { grid-template-columns: 1fr; }
	.zq-contact-card {
		min-height: 170px;
		max-width: 560px;
	}
	.zq-contact-card__phone { transform: none; }
	.zq-contact-card__button { margin-top: 18px; }
}

@media (max-width: 600px) {
	.zq-contact-hero__inner {
		padding: 52px 1.25rem 28px;
	}
	.zq-contact-hero .is-style-zq-eyebrow {
		margin-bottom: 28px;
		font-size: 20px;
	}
	.zq-contact-hero__title {
		margin-bottom: 22px;
		font-size: 64px;
	}
	.zq-contact-hero__lead {
		font-size: 20px;
		line-height: 1.35;
	}
	.zq-contact-card {
		grid-template-columns: 52px minmax(0, 1fr);
		column-gap: 16px;
		min-height: 158px;
		padding: 24px 20px 18px;
	}
	.zq-contact-card__icon { width: 52px; height: 52px; }
	.zq-contact-card--mail { column-gap: 22px; }
	.zq-contact-card__icon,
	.zq-contact-card__mail-icon { margin-top: 8px; }
	.zq-contact-card__mail-icon { width: 54px; height: 40px; }
	.zq-contact-card__name,
	.zq-contact-card__phone { font-size: 36px; }
	.zq-contact-card__button {
		min-width: 145px;
		min-height: 40px;
		font-size: 18px;
	}
}

/* === Strona kontaktu: formularz + kroki === */
.zq-contact-flow {
	position: relative;
	background: #000;
	padding: clamp(3.5rem, 7vw, 6.25rem) 2rem clamp(4.25rem, 8vw, 7rem);
}
.zq-contact-flow__inner {
	display: grid;
	grid-template-columns: minmax(0, 1.35fr) minmax(340px, .95fr);
	width: 100%;
	max-width: 1280px;
	margin: 0 auto;
	border: 1px solid rgba(245, 241, 234, .22);
	background: rgba(0, 0, 0, .66);
}
.zq-contact-flow__form-panel,
.zq-contact-flow__steps-panel {
	padding: clamp(2rem, 4.5vw, 4rem);
}
.zq-contact-flow__form-panel {
	border-right: 1px solid rgba(245, 241, 234, .22);
	background: linear-gradient(90deg, rgba(15, 15, 15, .9), rgba(15, 15, 15, .48));
}
.zq-contact-flow__heading {
	position: relative;
	margin: 0 0 28px;
	padding-bottom: 16px;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 45px;
	font-weight: 700;
	line-height: 1;
	letter-spacing: .02em;
	text-transform: uppercase;
}
.zq-contact-flow__heading::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 59px;
	height: 3px;
	background: url("assets/images/contact-heading-line.svg") left center / contain no-repeat;
}
.zq-contact-flow__copy {
	max-width: 62ch;
	margin: 0 0 34px;
	color: var(--wp--preset--color--contrast);
	font-size: 18px;
	font-weight: 500;
	line-height: 1.35;
}
.zq-contact-form {
	display: flex;
	flex-direction: column;
	gap: 18px;
}
.zq-contact-form__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 18px;
}
.zq-contact-form__field {
	width: 100%;
	min-height: 58px;
	border: 0;
	border-radius: 0;
	box-sizing: border-box;
	background: rgba(0, 0, 0, .72);
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 18px;
	font-weight: 400;
	line-height: 1.2;
	padding: 15px 18px;
}
.zq-contact-form__field::placeholder {
	color: rgba(245, 241, 234, .68);
	opacity: 1;
}
.zq-contact-form__message {
	min-height: 145px;
	resize: vertical;
}
.zq-contact-form__consent {
	display: flex;
	align-items: center;
	gap: 12px;
	color: var(--wp--preset--color--contrast);
	font-size: 14px;
	font-weight: 400;
	line-height: 1.25;
	cursor: pointer;
}
.zq-contact-form__consent input {
	appearance: none;
	width: 24px;
	height: 24px;
	margin: 0;
	flex: none;
	border: 1px solid rgba(245, 241, 234, .9);
	background: transparent;
	background-position: center;
	background-repeat: no-repeat;
	background-size: 15px 12px;
	cursor: pointer;
}
.zq-contact-form__consent input:checked {
	border-color: var(--wp--preset--color--primary);
	background-color: var(--wp--preset--color--primary);
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='14' viewBox='0 0 18 14' fill='none'%3E%3Cpath d='M2 7.2 6.4 11.5 16 2' stroke='%23fff' stroke-width='3' stroke-linecap='square' stroke-linejoin='miter'/%3E%3C/svg%3E");
}
.zq-contact-form__consent input:focus-visible {
	outline: 2px solid var(--wp--preset--color--primary);
	outline-offset: 3px;
}
.zq-contact-form__button {
	display: inline-flex;
	align-items: center;
	justify-content: space-between;
	gap: 28px;
	width: max-content;
	min-width: 285px;
	min-height: 58px;
	border: 0;
	border-radius: 0;
	margin-top: 10px;
	padding: 14px 26px;
	background: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--contrast);
	cursor: pointer;
	font-family: var(--wp--preset--font-family--body);
	font-size: 22px;
	font-weight: 700;
	line-height: 1;
	text-transform: uppercase;
}
.zq-contact-form-embed :where(.wpcf7-form, .wpforms-form, .fluentform form, .nf-form-content form, form) {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 18px;
}
.zq-contact-form-embed :where(p, .wpcf7-form-control-wrap, .wpforms-field, .ff-el-group, .nf-field-container) {
	margin: 0;
}
.zq-contact-form-embed :where(.wpcf7-form-control-wrap) {
	display: block;
}
.zq-contact-form-embed :where(p:has(textarea), p:has(input[type="checkbox"]), p:has(input[type="submit"]), p:has(button[type="submit"]), .wpforms-field-textarea, .wpforms-field-checkbox, .wpforms-submit-container, .ff-el-group:has(textarea), .ff-el-group:has(input[type="checkbox"]), .ff_submit_btn_wrapper, .nf-field-container:has(textarea), .nf-field-container:has(input[type="checkbox"]), .nf-field-container:has(input[type="submit"])) {
	grid-column: 1 / -1;
}
.zq-contact-form-embed :where(input:not([type="submit"]):not([type="checkbox"]):not([type="radio"]), textarea, select) {
	width: 100%;
	min-height: 58px;
	border: 0;
	border-radius: 0;
	box-sizing: border-box;
	background: rgba(0, 0, 0, .72);
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 1.125rem;
	font-weight: 400;
	line-height: 1.2;
	padding: 15px 18px;
}
.zq-contact-form-embed :where(input::placeholder, textarea::placeholder) {
	color: rgba(245, 241, 234, .68);
	opacity: 1;
}
.zq-contact-form-embed :where(textarea) {
	min-height: 145px;
	resize: vertical;
}
.zq-contact-form-embed :where(label, .wpforms-field-label, .ff-el-input--label label, .nf-field-label label) {
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 1rem;
	font-weight: 500;
	line-height: 1.25;
}
.zq-contact-form-embed :where(.wpcf7-list-item) {
	margin: 0;
}
.zq-contact-form-embed :where(input[type="checkbox"], input[type="radio"]) {
	width: 24px;
	height: 24px;
	margin: 0 12px 0 0;
	accent-color: var(--wp--preset--color--primary);
}
.zq-contact-form-embed :where(input[type="submit"], button[type="submit"], .wpforms-submit, .ff-btn-submit, .nf-element[type="button"]) {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: max-content;
	min-width: 285px;
	min-height: 58px;
	border: 0;
	border-radius: 0;
	margin-top: 10px;
	padding: 14px 26px;
	background: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--contrast);
	cursor: pointer;
	font-family: var(--wp--preset--font-family--body);
	font-size: 1.375rem;
	font-weight: 700;
	line-height: 1;
	text-transform: uppercase;
}
.zq-contact-form-embed :where(.wpcf7-response-output, .wpforms-confirmation-container-full, .ff-message-success, .nf-response-msg) {
	grid-column: 1 / -1;
	margin: 0;
	border: 1px solid rgba(245, 241, 234, .28);
	padding: 14px 18px;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 1rem;
	line-height: 1.35;
}
.zq-contact-form-embed__notice,
.zq-contact-form-embed--editor code {
	display: block;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 1rem;
	line-height: 1.35;
}
.zq-contact-form-embed--editor code {
	margin-top: 12px;
	padding: 15px 18px;
	background: rgba(0, 0, 0, .72);
	white-space: normal;
}
.zq-contact-steps {
	display: flex;
	flex-direction: column;
	gap: clamp(2.75rem, 5vw, 5rem);
	margin: 0;
	padding: 20px 0 0;
	list-style: none;
}
.zq-contact-step {
	display: grid;
	grid-template-columns: 86px minmax(0, 1fr);
	gap: 28px;
	align-items: start;
}
.zq-contact-step__num {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 86px;
	height: 86px;
	background: #1a1a1a;
	color: var(--wp--preset--color--primary);
	font-family: var(--wp--preset--font-family--body);
	font-size: 60px;
	font-weight: 700;
	line-height: 1;
}
.zq-contact-step__body {
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding-top: 2px;
	color: var(--wp--preset--color--contrast);
	font-size: 18px;
	font-weight: 500;
	line-height: 1.32;
}
.zq-contact-step__body strong {
	font-size: clamp(1.5rem, 2vw, 32px);
	line-height: 1;
	text-transform: uppercase;
}

@media (max-width: 980px) {
	.zq-contact-flow__inner {
		grid-template-columns: 1fr;
	}
	.zq-contact-flow__form-panel {
		border-right: 0;
		border-bottom: 1px solid rgba(245, 241, 234, .22);
	}
}

@media (max-width: 600px) {
	.zq-contact-flow {
		padding: 3rem 1.25rem 4rem;
	}
	.zq-contact-flow__form-panel,
	.zq-contact-flow__steps-panel {
		padding: 1.5rem;
	}
	.zq-contact-flow__heading {
		font-size: 32px;
	}
	.zq-contact-form__grid {
		grid-template-columns: 1fr;
	}
	.zq-contact-form__button {
		width: 100%;
		min-width: 0;
	}
	.zq-contact-form-embed :where(.wpcf7-form, .wpforms-form, .fluentform form, .nf-form-content form, form) {
		grid-template-columns: 1fr;
	}
	.zq-contact-form-embed :where(input[type="submit"], button[type="submit"], .wpforms-submit, .ff-btn-submit, .nf-element[type="button"]) {
		width: 100%;
		min-width: 0;
	}
	.zq-contact-step {
		grid-template-columns: 68px minmax(0, 1fr);
		gap: 18px;
	}
	.zq-contact-step__num {
		width: 68px;
		height: 68px;
		font-size: 48px;
	}
}

/* === Strona kontaktu: mapa === */
.zq-contact-map {
	background: #000;
	padding: 0 2rem clamp(4rem, 7vw, 6rem);
}
.zq-contact-map__inner {
	display: grid;
	grid-template-columns: minmax(300px, 380px) minmax(0, 1fr);
	width: 100%;
	max-width: 1280px;
	min-height: 430px;
	margin: 0 auto;
	border: 1px solid rgba(245, 241, 234, .22);
	background: #000;
}
.zq-contact-map__content {
	padding: clamp(2rem, 4vw, 3.25rem);
}
.zq-contact-map__heading {
	position: relative;
	margin: 0 0 28px;
	padding-bottom: 20px;
	color: var(--wp--preset--color--contrast);
	font-family: var(--wp--preset--font-family--body);
	font-size: 45px;
	font-weight: 700;
	line-height: 1;
	letter-spacing: .02em;
	text-transform: uppercase;
}
.zq-contact-map__heading::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 59px;
	height: 3px;
	background: url("assets/images/contact-heading-line.svg") left center / contain no-repeat;
}
.zq-contact-map__content p {
	max-width: 32ch;
	margin: 0 0 28px;
	color: var(--wp--preset--color--contrast);
	font-size: 18px;
	font-weight: 500;
	line-height: 1.35;
}
.zq-contact-map__socials {
	display: flex;
	align-items: center;
	gap: 32px;
	margin-top: 14px;
}
.zq-contact-map__social {
	display: block;
	width: 68px;
	height: 68px;
	background-color: var(--wp--preset--color--primary);
	transition: background-color .2s ease, transform .15s ease;
}
.zq-contact-map__social:hover {
	background-color: var(--wp--preset--color--primary-hover);
	transform: translateY(-2px);
}
.zq-contact-map__social--facebook {
	-webkit-mask: url("assets/images/icons/contact-facebook.svg") center / contain no-repeat;
	mask: url("assets/images/icons/contact-facebook.svg") center / contain no-repeat;
}
.zq-contact-map__social--instagram {
	-webkit-mask: url("assets/images/icons/contact-instagram.svg") center / contain no-repeat;
	mask: url("assets/images/icons/contact-instagram.svg") center / contain no-repeat;
}
.zq-contact-map__social--google {
	-webkit-mask: url("assets/images/icons/contact-google.svg") center / contain no-repeat;
	mask: url("assets/images/icons/contact-google.svg") center / contain no-repeat;
}
.zq-contact-map__frame {
	min-height: 430px;
	background: #111;
}
.zq-contact-map__frame iframe {
	display: block;
	width: 100%;
	height: 100%;
	min-height: 430px;
	border: 0;
	filter: saturate(.95) contrast(.95);
}

@media (max-width: 980px) {
	.zq-contact-map__inner {
		grid-template-columns: 1fr;
	}
	.zq-contact-map__frame,
	.zq-contact-map__frame iframe {
		min-height: 360px;
	}
}

@media (max-width: 600px) {
	.zq-contact-map {
		padding: 0 1.25rem 4rem;
	}
	.zq-contact-map__heading {
		font-size: 32px;
	}
	.zq-contact-map__socials {
		gap: 22px;
	}
	.zq-contact-map__social {
		width: 54px;
		height: 54px;
	}
}

/* === Sekcja „Kontakt — Gotowi na przygodę" === */
.zq-kontakt {
	position: relative;
	display: flex; align-items: center;
	min-height: clamp(480px, 54vw, 720px);
	background-color: var(--wp--preset--color--base);
	background-image: url("assets/images/bg/bg-kontakt.webp");
	background-size: cover; background-position: center; background-repeat: no-repeat;
	overflow: hidden;
}
/* Zdjęcie po lewej, pełny bleed, z ukośną prawą krawędzią */
.zq-kontakt__media {
	position: absolute; top: 0; bottom: 0; left: 0; margin: 0;  /* margin:0 — natywny figure.wp-block-image ma domyślny margines */
	z-index: 0; pointer-events: none;
}
/* Asset ma własną poszarpaną krawędź w kanale alfa — żadnego clip-path/gradientu.
   Wysokość = sekcja, szerokość auto: proporcja i krawędź zostają nietknięte. */
.zq-kontakt__media img { height: 100%; width: auto; display: block; }
.zq-kontakt__inner {
	position: relative; z-index: 1;
	width: 100%; max-width: 1320px; margin: 0 auto;
	padding: clamp(3rem, 6vw, 5rem) clamp(1.5rem, 3vw, 2.5rem);
	/* Kolumna 1 = rezerwa nad zdjęciem (szersza niż samo zdjęcie ~644px, by tekst nie najeżdżał na rozprysk). */
	display: grid; grid-template-columns: clamp(340px, 40vw, 600px) 1fr;
	gap: clamp(1.5rem, 3vw, 2.5rem); align-items: center;
}
.zq-kontakt__content { grid-column: 2; max-width: 840px; }

/* Eyebrow / tytuł / lead — block-style'y zq-* + rozmiary kontaktu */
.zq-kontakt .is-style-zq-eyebrow { margin-bottom: 0; }
.zq-kontakt .is-style-zq-display {
	font-size: clamp(2.75rem, 10vw, 150px); line-height: .9; letter-spacing: .02em;
	margin: clamp(1.25rem, 2.5vw, 2rem) 0 0;
}
.zq-kontakt .has-lead-font-size {
	color: #fff; line-height: 1.6; max-width: 46ch;
	margin: clamp(1.5rem, 3vw, 2.25rem) 0 clamp(2rem, 4vw, 2.75rem);
}

/* Przyciski: równa wysokość (wrapper flex → <a> wypełnia wysokość) */
.zq-kontakt__cta { display: flex; flex-wrap: wrap; align-items: center; gap: clamp(1rem, 2vw, 1.5rem); margin: 0; }
.zq-kontakt__cta .wp-block-button { flex: 0 0 auto; }  /* nie kurcz buttonów — ghost zachowuje ramkę, w razie ciasnoty zawijają się */
/* Równa wysokość obu buttonów (font 30px + padding stałe) — min-height zamiast kruchego stretch */
.zq-kontakt__cta .wp-block-button__link { min-height: 61px; display: inline-flex; align-items: center; }

/* CTA „Zadzwoń teraz" — filled + ikona telefonu po prawej (mask = kolor tekstu, biała) */
.is-style-zq-phone .wp-block-button__link {
	display: inline-flex; align-items: center; gap: .7em; line-height: 1;
	/* rozmiar/letter-spacing dziedziczone z domyślnego buttona — spójne ze wszystkimi przyciskami */
}
.is-style-zq-phone .wp-block-button__link::after {
	content: ""; width: 1.15em; height: 1.15em; flex: none; background-color: currentColor;
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512'%3E%3Cpath d='M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64 0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z'/%3E%3C/svg%3E") center / contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512'%3E%3Cpath d='M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64 0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z'/%3E%3C/svg%3E") center / contain no-repeat;
}

/* Tablet + mobile (≤1024): desktopowy układ (zdjęcie absolutne + tekst obok) jest za ciasny na
   tablecie — tekst nachodził na zdjęcie, zdjęcie szło full-bleed, buttony różnej szerokości.
   Stackujemy: treść na górze, zdjęcie pod nią (respektuje max-width + padding), buttony równej szer. */
@media (max-width: 1024px) {
	.zq-kontakt { display: flex; flex-direction: column; padding-bottom: clamp(3rem, 8vw, 4.5rem); }
	.zq-kontakt__inner { display: block; order: 1; }       /* treść na górze */
	.zq-kontakt__content { max-width: none; }
	.zq-kontakt__media {                                    /* zdjęcie na dole, w obrębie max-width + padding jak treść */
		position: relative; order: 2;
		width: 100%; max-width: 1320px; margin: 0 auto;
		padding: 0 clamp(1.5rem, 3vw, 2.5rem); box-sizing: border-box;
	}
	.zq-kontakt__media img { width: 100%; height: auto; }
	/* Buttony równej szerokości — jeden pod drugim, do 520px (spójny wygląd na tablecie i mobile) */
	.zq-kontakt__cta { flex-direction: column; align-items: stretch; max-width: 520px; }
	.zq-kontakt__cta .wp-block-button { flex: none; width: 100%; }
	.zq-kontakt__cta .wp-block-button__link { width: 100%; justify-content: center; }
}

/* === Stopka (footer) — makieta STOPKA, tło BLOTO === */
.zq-footer {
	position: relative; isolation: isolate;
	background-color: #1b1815;
	color: var(--wp--preset--color--contrast);
}
/* Tekstura BLOTO pod treścią: przyciemniona, ale z PODBITYM kontrastem, żeby grunge/brud
   był wyraźny. Welon (półprzezroczysta nakładka) spłaszczał detal — filtr go zachowuje. */
.zq-footer::before {
	content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
	background: url("assets/images/footer-bloto.webp") center / cover no-repeat;
	filter: brightness(.6) contrast(1.35);
}
.zq-footer__inner, .zq-footer__bottom { position: relative; z-index: 1; }
.zq-footer__inner {
	max-width: 1320px; margin: 0 auto;
	/* większy górny padding — żeby przyciemnienie separatora nie nachodziło na tytuły grup */
	padding: clamp(6rem, 9.5vw, 8.5rem) clamp(1.5rem, 3vw, 2.5rem) clamp(2.5rem, 5vw, 4rem);
	display: grid; grid-template-columns: minmax(180px, 300px) 0.85fr 1.5fr auto;
	gap: clamp(1.5rem, 3vw, 3rem); align-items: stretch;
}
.zq-footer__brand { display: flex; align-items: center; }
.zq-footer__logo { width: clamp(200px, 20vw, 300px); height: auto; display: block; }

/* Pionowe separatory między kolumnami tekstowymi */
.zq-footer__nav, .zq-footer__contact, .zq-footer__social {
	border-left: 1px solid rgba(245, 241, 234, .14);
	padding-left: clamp(1.5rem, 3vw, 3rem);
}

/* Nagłówki grup 30px — pomarańczowe, Oswald, wersaliki */
.zq-footer__heading {
	font-family: var(--wp--preset--font-family--body); font-weight: 700;
	font-size: clamp(1.4rem, 2.2vw, 30px); color: var(--wp--preset--color--primary);
	text-transform: uppercase; letter-spacing: .06em; margin: 0 0 clamp(1.1rem, 2vw, 1.6rem);
}

/* Linki / teksty 22px */
.zq-footer__links { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: clamp(.6rem, 1.2vw, 1rem); }
.zq-footer__links a {
	font-family: var(--wp--preset--font-family--body); font-size: clamp(1rem, 1.5vw, 22px);
	color: var(--wp--preset--color--contrast); text-decoration: none; transition: color .2s ease;
}
.zq-footer__links a:hover { color: var(--wp--preset--color--primary); }

.zq-footer__contact-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: clamp(.9rem, 1.6vw, 1.35rem); }
.zq-footer__contact-list li { display: flex; align-items: center; gap: .85rem; font-family: var(--wp--preset--font-family--body); font-size: clamp(1rem, 1.5vw, 22px); color: var(--wp--preset--color--contrast); }
.zq-footer__contact-list a { color: inherit; text-decoration: none; transition: color .2s ease; }
.zq-footer__contact-list a:hover { color: var(--wp--preset--color--primary); }
/* Ikony pozycji kontaktu — przez ::before (mask, pomarańczowe); ikona per klasa pozycji */
.zq-footer__contact-list li::before {
	content: ""; flex: none; width: clamp(20px, 1.6vw, 24px); height: clamp(20px, 1.6vw, 24px);
	background-color: var(--wp--preset--color--primary);
	-webkit-mask: var(--fc-ico) center / contain no-repeat; mask: var(--fc-ico) center / contain no-repeat;
}
.zq-fc--phone { --fc-ico: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512'%3E%3Cpath d='M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64 0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z'/%3E%3C/svg%3E"); }
.zq-fc--mail { --fc-ico: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512'%3E%3Cpath d='M48 64C21.5 64 0 85.5 0 112c0 15.1 7.1 29.3 19.2 38.4L236.8 313.6c11.4 8.5 27 8.5 38.4 0L492.8 150.4c12.1-9.1 19.2-23.3 19.2-38.4 0-26.5-21.5-48-48-48H48zM0 176V384c0 35.3 28.7 64 64 64H448c35.3 0 64-28.7 64-64V176L294.4 339.2c-22.8 17.1-54 17.1-76.8 0L0 176z'/%3E%3C/svg%3E"); }
.zq-fc--pin { --fc-ico: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 384 512'%3E%3Cpath d='M215.7 499.2C267 435 384 279.4 384 192 384 86 298 0 192 0S0 86 0 192c0 87.4 117 243 168.3 307.2 12.3 15.3 35.1 15.3 47.4 0zM192 128a64 64 0 1 1 0 128 64 64 0 1 1 0-128z'/%3E%3C/svg%3E"); }

/* Social = core/social-links — białe kółka z ciemnym glifem (edytowalne URL-e) */
.zq-footer__socials { display: flex; gap: .85rem; list-style: none; margin: 0; padding: 0; }
.zq-footer__socials .wp-social-link {
	width: 46px; height: 46px; border-radius: 50%; flex: none; margin: 0; padding: 0;
	background-color: #fff !important; color: #1a1714 !important;  /* color = currentColor glifu */
	display: inline-flex; align-items: center; justify-content: center;
	transition: transform .2s ease, background .2s ease;
}
.zq-footer__socials .wp-social-link > a { padding: 0; display: inline-flex; align-items: center; justify-content: center; width: 100%; height: 100%; }
/* !important bije core/social-links (ustawia fill na biały) — ciemny glif na białym kółku */
.zq-footer__socials .wp-social-link svg,
.zq-footer__socials .wp-social-link svg path { width: 22px; height: 22px; display: block; fill: #1a1714 !important; }
.zq-footer__socials .wp-social-link:hover { transform: translateY(-2px); background-color: var(--wp--preset--color--primary) !important; color: #fff !important; }
.zq-footer__socials .wp-social-link:hover svg, .zq-footer__socials .wp-social-link:hover svg path { fill: #fff !important; }

/* Dolny pasek: copyright + separatory */
.zq-footer__bottom {
	max-width: 1320px; margin: 0 auto;
	border-top: 1px solid rgba(245, 241, 234, .14);
	padding: clamp(1rem, 2vw, 1.5rem) clamp(1.5rem, 3vw, 2.5rem);
	display: flex; justify-content: center; align-items: center; flex-wrap: wrap;
	gap: clamp(1.25rem, 3vw, 2.5rem);
	font-family: var(--wp--preset--font-family--body); text-transform: uppercase;
	letter-spacing: .06em; font-size: clamp(.78rem, 1vw, .95rem); color: rgba(245, 241, 234, .6);
}
.zq-footer__bottom p { margin: 0; }
.zq-footer__bottom > *:not(:first-child) { border-left: 1px solid rgba(245, 241, 234, .18); padding-left: clamp(1.25rem, 3vw, 2.5rem); }
.zq-footer__bottom strong { color: var(--wp--preset--color--contrast); font-weight: 700; }

@media (max-width: 980px) {
	.zq-footer__inner { grid-template-columns: 1fr 1fr; gap: 2.5rem; }
	.zq-footer__brand { grid-column: 1 / -1; justify-content: flex-start; }
	.zq-footer__nav { border-left: 0; padding-left: 0; }
}
@media (max-width: 600px) {
	.zq-footer__inner { grid-template-columns: 1fr; }
	.zq-footer__brand { justify-content: center; }
	.zq-footer__nav, .zq-footer__contact, .zq-footer__social { border-left: 0; padding-left: 0; }
	.zq-footer__bottom { flex-direction: column; gap: .6rem; }
	.zq-footer__bottom > *:not(:first-child) { border-left: 0; padding-left: 0; }
}

/* === Separator sekcji — pędzlowa pomarańczowa kreska, „malowana" od lewej przy wejściu w kadr === */
.zq-divider {
	opacity: 1; transform: none; /* nadpisuje domyślny zq-reveal (fade+translateY) */
	display: block; position: relative; z-index: 3;
	width: 100%; max-width: 1280px;  /* spójnie z szerokością treści — niezależnie od kontekstu (stopka itd.) */
	/* Ujemny margines: separator wciąga się na STYK sekcji i leży na ich teksturze,
	   zamiast w pustym pasku tła strony między pełnoekranowymi sekcjami. */
	margin: clamp(-1.6rem, -2.4vw, -1.1rem) auto;
	height: clamp(16px, 2.2vw, 30px);
	/* pędzel = ::after, przyciemnienie styku = ::before */
}
/* Przyciemnienie pod/wokół separatora (pełna szerokość) — zmiękcza „przeskok"
   między teksturami sąsiednich sekcji; statyczne, zawsze obecne. */
.zq-divider::before {
	content: ""; position: absolute; z-index: 1; pointer-events: none;
	/* pasmo przesunięte głównie POD separator — nie nachodzi na treść nad nim (np. przyciski hero) */
	left: 50%; top: 50%; transform: translate(-50%, -25%);
	width: 100vw; height: clamp(120px, 16vw, 200px);
	background: linear-gradient(to bottom,
		transparent 0%,
		rgba(8, 6, 5, .5) 24%,
		rgba(8, 6, 5, .72) 40%,
		rgba(8, 6, 5, .5) 66%,
		transparent 100%);
}
/* Pędzel — na wierzchu przyciemnienia */
.zq-divider::after {
	content: ""; position: absolute; z-index: 2; inset: 0;
	background: url("assets/images/divider.webp") center / 100% 100% no-repeat;
}
/* „Malowanie" od lewej: klasę .zq-paint dodaje observer ZANIM separator wjedzie w kadr,
   więc reset do zaklipowania dzieje się poza ekranem → płynny paint, bez mignięcia. */
.zq-divider.zq-paint::after { animation: zq-paint .9s cubic-bezier(.6, 0, .25, 1) both; }
@keyframes zq-paint {
	from { -webkit-clip-path: inset(0 100% 0 0); clip-path: inset(0 100% 0 0); }
	to   { -webkit-clip-path: inset(0 0 0 0);    clip-path: inset(0 0 0 0); }
}
@media (prefers-reduced-motion: reduce) { .zq-divider.zq-paint::after { animation: none; } }
