/* =========================================================================
   GeneratePress Zaplecze — main.css  (G1a — wlasciciel kanonicznych tokenow)
   Motyw: GOLD / NOIR (ciemny, kinowy). Caly serwis ciemny — zasada inwersji.
   Tokeny :root definiowane WYLACZNIE tutaj; woocommerce-gold.css i bloki
   korzystaja z nich przez var() i NIGDY ich nie redefiniuja.
   ========================================================================= */

:root {
	/* ---- KANONICZNE TOKENY GOLD (zrodlo prawdy) ---- */
	--bg: #16130F;
	--bg2: #1C1813;
	--card: #211C15;
	--ink: #0F0C08;
	--ink2: #0A0806;
	--accent: #C9A86A;
	--accent-h: #D8BD86;
	--text: #F2EAD9;
	--body: #A89E8B;
	--muted: #8C8472;
	--line: rgba(201, 168, 106, .16);
	--line-2: rgba(201, 168, 106, .30);
	--film-hole: rgba(201, 168, 106, .5);
	--cta-glow: rgba(201, 168, 106, .20);
	--text-on-accent: #16130F;
	--status-ok: #86C06A;
	--status-rented: #E08C82;
	--r-card: 16px;
	--r-input: 10px;
	--r-sm: 8px;
	--r-pill: 30px;
	--maxw: 1240px;
	--shadow-card: 0 16px 32px rgba(0, 0, 0, .5);
	--shadow-lg: 0 30px 70px rgba(20, 18, 15, .34);
	--glow-cta: 0 14px 30px rgba(201, 168, 106, .24);
	--fontD: "Cormorant Garamond", Georgia, "Times New Roman", serif;
	--fontB: "Archivo", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	--fontM: "Space Mono", ui-monospace, "Courier New", monospace;

	/* ---- ALIASY LEGACY (na wypadek odwolan spoza tego pliku) ----
	   Mapuja stare nazwy na nowe tokeny Gold, by zadna reguła z patternow/
	   functions.php/Woo nie odwolala sie do nieistniejacej zmiennej. */
	--gpz-ink: var(--bg);
	--gpz-ink-soft: var(--bg2);
	--gpz-paper: var(--text);
	--gpz-paper-2: var(--body);
	--gpz-brass: var(--accent);
	--gpz-brass-bright: var(--accent-h);
	--gpz-brass-dark: var(--accent);
	--gpz-oxblood: var(--status-rented);
	--gpz-oxblood-bright: var(--status-rented);
	--gpz-muted: var(--muted);
	--gpz-line: var(--line);
	--gpz-white: var(--card);
	--gpz-radius: var(--r-card);
	--gpz-maxw: var(--maxw);
	--gpz-shadow: var(--shadow-card);
	--gpz-shadow-sm: 0 8px 18px rgba(0, 0, 0, .4);
	--gpz-font-display: var(--fontD);
	--gpz-font-body: var(--fontB);
}

/* Utility: zlocenie frazy w naglowkach (== --accent-h) */
.gpz-gold { color: #d8bd86; }

/* ---------- Baza ---------- */
html { overflow-x: clip; } /* full-bleed 100vw bez poziomego scrolla; nie psuje sticky-header */
body {
	font-family: var(--fontB);
	color: var(--body);
	background-color: var(--bg);
	background: var(--bg);
	font-size: 1.05rem;
	line-height: 1.65;
	overflow-x: clip; /* domyka full-bleed: zeruje ~8px resztkowego scrolla (szer. paska pionowego); sticky-header dziala dalej */
}

h1, h2, h3, h4, h5, h6,
.entry-title, .woocommerce-loop-product__title, .product_title {
	font-family: var(--fontD);
	font-weight: 600;
	line-height: 1.14;
	color: var(--text);
	letter-spacing: 0.005em;
}
/* H1 — Cormorant mixed-case (BEZ uppercase), wieksza skala, waga 600 */
h1, .entry-title {
	font-size: clamp(2.4rem, 1.7rem + 3vw, 3.9rem);
	font-weight: 600;
	letter-spacing: -0.01em;
	text-transform: none;
}
h2 { font-size: clamp(1.7rem, 1.3rem + 1.7vw, 2.6rem); }
h3 { font-size: clamp(1.3rem, 1.05rem + 0.9vw, 1.7rem); }

a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-h); }

/* ---------- Przyciski (GP + WC + bloki) ---------- */
.button,
button.button,
.wp-block-button__link,
.woocommerce a.button,
.woocommerce button.button,
input[type="submit"] {
	display: inline-block;
	font-family: var(--fontB);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	font-size: 0.92rem;
	line-height: 1.2;
	padding: 0.85em 1.6em;
	border: 0;
	border-radius: var(--r-pill);
	background-color: var(--accent);
	color: var(--text-on-accent);
	cursor: pointer;
	box-shadow: var(--glow-cta);
	transition: background-color 0.18s ease, color 0.18s ease, transform 0.12s ease, box-shadow 0.18s ease;
}
.button:hover,
button.button:hover,
.wp-block-button__link:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
input[type="submit"]:hover {
	background-color: var(--accent-h);
	color: var(--text-on-accent);
}
.button:active { transform: translateY(1px); }

.gpz-btn-outline,
.is-style-outline .wp-block-button__link {
	background: transparent;
	color: var(--accent);
	box-shadow: inset 0 0 0 1.5px var(--accent);
}
.gpz-btn-outline:hover,
.is-style-outline .wp-block-button__link:hover {
	background: var(--accent);
	color: var(--text-on-accent);
	box-shadow: inset 0 0 0 1.5px var(--accent);
}

/* ---------- Naglowek (sticky, ciemny pasek bg2) ---------- */
.site-header {
	/* Półprzezroczysty pasek z rozmyciem (wg makiety) — tło bg2 z alfa + blur. */
	background-color: rgba(28, 24, 19, 0.86);
	background: rgba(28, 24, 19, 0.86);
	-webkit-backdrop-filter: blur(8px) saturate(140%);
	backdrop-filter: blur(8px) saturate(140%);
	color: var(--text);
	border-bottom: 1px solid var(--line);
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.28);
	position: sticky;
	top: 0;
	z-index: 100;
}
/* Wnętrze nagłówka: logo z lewej, nav + CTA z prawej, wyrównane w pionie.
   Nav wypełnia całą szerokość po logo, by menu + szukajka + CTA zmieściły się
   w jednym wierszu (bez kurczenia menu, które wymuszałoby zawijanie). */
.site-header .inside-header {
	display: flex;
	align-items: center;
	gap: 24px;
}
.site-header .inside-header > .site-branding-container { flex: 0 0 auto; }
.site-header .inside-header > .main-navigation.sub-menu-right {
	flex: 1 1 auto;
	min-width: 0;
}
.site-header .main-title a,
.site-header .site-title a {
	color: var(--text);
	font-family: var(--fontB);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.18em;
}
.site-header .site-description {
	color: var(--accent);
	font-family: var(--fontM);
	letter-spacing: 0.14em;
	text-transform: uppercase;
	font-size: 0.7rem;
}

/* Nawigacja — tło przezroczyste (półprzezroczysty pasek nagłówka prześwituje przez blur). */
.main-navigation {
	background-color: transparent;
	background: transparent;
}
/* Menu + szukajka + CTA w jednym wierszu, dosunięte do prawej (bez zawijania CTA). */
.main-navigation .inside-navigation {
	flex-wrap: nowrap;
	justify-content: flex-end;
	gap: 14px;
}
/* Menu nie kurczy się i nie zawija pozycji (inaczej rośnie do 2 rzędów). */
.main-navigation .inside-navigation .main-nav { flex: 0 0 auto; }
.main-navigation .inside-navigation .main-nav > ul { flex-wrap: nowrap; }
/* Linki top-level: kolor wg makiety (--body), bez złotej „pigułki";
   hover/aktywne → złoto (--accent). Domyślny kolor nav to --text (rule wcześniej),
   więc nadpisujemy go bez !important. */
.main-navigation .main-nav ul li a {
	font-family: var(--fontB);
	text-transform: none;
	letter-spacing: 0.02em;
	font-weight: 500;
	font-size: 13.5px;
	color: var(--body);
	transition: color .25s ease, background-color .25s ease;
}
.main-navigation .menu-toggle { color: var(--text); }

/* Hover/aktywne (top-level): złoty tekst, bez tła pigułki. !important pokonuje
   dziedziczony dynamiczny CSS GP (specyficzność 0,4,3 na hover). */
.main-navigation .main-nav ul li:hover > a,
.main-navigation .main-nav ul li:focus > a,
.main-navigation .main-nav ul li.sfHover > a,
.main-navigation .main-nav ul li[class*="current-menu-"] > a {
	color: var(--accent) !important;
	background-color: transparent !important;
}

/* Rozwijane menu: zaokrąglone ciemne panele z kropką-bulletem; bez kresek między pozycjami. */
.main-navigation .main-nav ul ul,
.main-navigation ul.sub-menu {
	background-color: var(--card);
	border: 1px solid var(--line-2);
	border-radius: 18px;
	box-shadow: var(--shadow-lg);
	padding: 14px;
}
.main-navigation .main-nav ul ul li a {
	color: var(--body);
	background-color: transparent;
	border-top: 0;
	border-radius: 9px;
	font-size: 12.5px;
	line-height: 1.2;
	padding: 8px 12px 8px 24px;
	position: relative;
}
.main-navigation .main-nav ul ul li a::before {
	content: "";
	position: absolute;
	left: 11px;
	top: 50%;
	transform: translateY(-50%);
	width: 4px;
	height: 4px;
	border-radius: 50%;
	background: var(--accent);
	opacity: 0.6;
	transition: opacity .25s ease;
}
.main-navigation .main-nav ul ul li:hover > a,
.main-navigation .main-nav ul ul li:focus > a,
.main-navigation .main-nav ul ul li.sfHover > a,
.main-navigation .main-nav ul ul li[class*="current-menu-"] > a {
	color: var(--text) !important;
	background-color: rgba(201, 168, 106, 0.12) !important;
}
.main-navigation .main-nav ul ul li:hover > a::before,
.main-navigation .main-nav ul ul li.sfHover > a::before,
.main-navigation .main-nav ul ul li[class*="current-menu-"] > a::before {
	opacity: 1;
}

/* „Katalog": panel 3-kolumnowy (24 pozycje, flow w dół kolumny — alfabet).
   max-width chroni przed wyjściem poza viewport na węższych ekranach. */
.main-navigation .main-nav ul li.gpz-cat-mega > ul.sub-menu {
	column-count: 3;
	column-gap: 6px;
	width: 708px;
	max-width: calc(100vw - 32px);
}
.main-navigation .main-nav ul li.gpz-cat-mega > ul.sub-menu > li {
	width: 224px;
	display: block;
	break-inside: avoid;
}
/* „Epoki": panel 2-kolumnowy (8 pozycji). Klasa gpz-epoch-mega nadana pozycji menu. */
.main-navigation .main-nav ul li.gpz-epoch-mega > ul.sub-menu {
	column-count: 2;
	column-gap: 6px;
	width: 420px;
	max-width: calc(100vw - 32px);
}
.main-navigation .main-nav ul li.gpz-epoch-mega > ul.sub-menu > li {
	width: 190px;
	display: block;
	break-inside: avoid;
}

/* ---------- Stopka (najciemniejsza, ink2) ---------- */
.site-footer,
.site-info {
	background-color: var(--ink2);
	background: var(--ink2);
	color: var(--body);
}
.site-footer a, .site-info a { color: var(--accent); }
.site-footer a:hover, .site-info a:hover { color: var(--text); }
.footer-widgets {
	background-color: var(--ink2);
	background: var(--ink2);
	color: var(--body);
	padding-block: 2.5rem;
}
.footer-widgets .widget-title { color: var(--accent); font-family: var(--fontD); }

.gpz-footer-cols {
	background-color: var(--ink2);
	background: var(--ink2);
	max-width: var(--maxw);
	margin: 0 auto;
	padding: 2.6rem 20px 1.4rem;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 1.8rem;
}
.gpz-footer-col { background: var(--ink2); }
.gpz-footer-col .widget-title {
	font-family: var(--fontD);
	font-weight: 600;
	text-transform: none;
	letter-spacing: 0.01em;
	font-size: 1.25rem;
	color: var(--accent);
	margin-bottom: 0.6rem;
}
.gpz-footer-col p { color: var(--body); font-size: 0.95rem; margin: 0; }
.gpz-footer-col a { color: var(--accent); }
.gpz-footer-col a:hover { color: var(--text); }

/* ---------- Sekcje pomocnicze (patterns) ---------- */
.gpz-section {
	background-color: var(--bg);
	background: var(--bg);
	padding-block: clamp(2.8rem, 1.8rem + 4.5vw, 6rem);
	/* Full-bleed: wyrwanie z kontenera 1200px GP na pelen viewport */
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
}
.gpz-section h1, .gpz-section h2, .gpz-section h3 { color: var(--text); }
.gpz-section p { color: var(--body); }
/* Szeroka tresc (siatki, alignwide) do 1280px, wysrodkowana; 24px gutter na waskich ekranach.
   Naglowki/akapity (contentSize ~760px) bez zmian — wezsza tresc zostaje wysrodkowana przez GP. */
.gpz-section .alignwide,
.gpz-section .gpz-cat-grid,
.gpz-section .gpz-epoch-grid {
	max-width: min(1280px, 100% - 48px);
	margin-left: auto;
	margin-right: auto;
}
/* Alternacja ciemnosci */
.gpz-section--paper2 {
	background-color: var(--bg2);
	background: var(--bg2);
}

/* PASEK CTA przed stopka — wg spec landing (perforacja tasmy + glow zloty) */
.gpz-section--dark {
	background-color: var(--ink);
	background: var(--ink);
	color: var(--text);
	position: relative;
	overflow: hidden;
}
.gpz-section--dark h1,
.gpz-section--dark h2,
.gpz-section--dark h3 { color: var(--text); }
.gpz-section--dark p { color: var(--text); }
/* Pozioma perforacja tasmy: gora i dol */
.gpz-section--dark::before,
.gpz-section--dark::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	height: 6px;
	background: repeating-linear-gradient(to right, var(--film-hole) 0 12px, transparent 12px 30px);
	opacity: 0.55;
	z-index: 0;
	pointer-events: none;
}
.gpz-section--dark::before { top: 16px; }
.gpz-section--dark::after { bottom: 16px; }
/* Zlota poswiata (rozmyte kolo) w prawym gornym rogu */
.gpz-section--dark > * { position: relative; z-index: 1; }
.gpz-section--dark .wp-block-group__inner-wrapper { position: relative; z-index: 1; }
/* Glow: rozmyte zlote kolo w prawym gornym rogu (bez dodatkowego markupu).
   Realizowane jako warstwa ::after byloby zajete przez perforacje, wiec uzywamy
   background-image radial-gradient na samej sekcji + opcjonalny .gpz-cta-glow-bg. */
.gpz-section--dark {
	background-image: radial-gradient(360px 360px at calc(100% - 60px) -40px, var(--cta-glow), transparent 70%);
}
.gpz-section--dark .gpz-cta-glow-bg {
	position: absolute;
	width: 360px;
	height: 360px;
	border-radius: 50%;
	background: var(--cta-glow);
	filter: blur(80px);
	top: -120px;
	right: -60px;
	pointer-events: none;
	z-index: 0;
}

.gpz-eyebrow {
	font-family: var(--fontM);
	text-transform: uppercase;
	letter-spacing: 0.18em;
	font-size: 0.78rem;
	font-weight: 700;
	color: var(--accent);
	margin-bottom: 0.4rem;
}
/* Ciemne sekcje CTA / hero — jasniejsze zloto na bardzo ciemnym tle */
.gpz-section--dark .gpz-eyebrow,
.gpz-hero-cover .gpz-eyebrow,
.gpz-hero .gpz-eyebrow { color: var(--accent-h); }

/* ---------- Hero (stare .gpz-hero + nowe .gpz-hero-cover) ---------- */
.gpz-hero {
	position: relative;
	color: var(--text);
	background-color: var(--bg);
	background-size: cover;
	background-position: center;
	padding-block: clamp(3.5rem, 2rem + 8vw, 8rem);
	overflow: hidden;
}
.gpz-hero::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(15, 12, 8, 0.55) 0%, rgba(15, 12, 8, 0.88) 100%);
	z-index: 0;
}
.gpz-hero > * { position: relative; z-index: 1; }
.gpz-hero h1 { color: var(--text); text-shadow: 0 2px 16px rgba(0, 0, 0, 0.5); }
.gpz-hero .gpz-hero-lead {
	font-size: clamp(1.05rem, 0.95rem + 0.6vw, 1.35rem);
	max-width: 46ch;
	color: var(--body);
}

/* Hero cover (wp:cover ze zdjeciem + overlay ink) */
.gpz-hero-cover { color: var(--text); }
.gpz-hero-cover .wp-block-cover__background,
.gpz-hero-cover .wp-block-cover__gradient-background {
	background-color: var(--ink) !important;
}
.gpz-hero-cover h1 {
	color: var(--text);
	font-family: var(--fontD);
	text-shadow: 0 2px 16px rgba(0, 0, 0, 0.5);
}
.gpz-hero-cover .gpz-hero-lead { color: var(--text); }

/* Strona glowna: hero przylega do naglowka (bez bialej karty kontenera GP) */
.home #content.site-content,
.home .site-content { padding: 0 !important; }
.home .content-area .inside-article,
.home .content-area article,
.home .content-area .entry-content {
	padding: 0 !important;
	margin: 0 !important;
	border: 0 !important;
	box-shadow: none !important;
	background: none !important;
}
.home .entry-header,
.home .page-header { display: none !important; }
.home .entry-content > .alignfull:first-child { margin-top: 0 !important; }

/* Tytul witryny w naglowku (gdy bez logo graficznego) */
.site-header .site-title { font-size: clamp(1.4rem, 1.1rem + 1vw, 2rem); }

/* Pasek „tasmy filmowej" (akcent zloto + perforacja) */
.gpz-filmstrip {
	height: 14px;
	background:
		repeating-linear-gradient(90deg, var(--ink) 0 10px, transparent 10px 26px),
		var(--accent);
	background-blend-mode: normal;
	-webkit-mask: repeating-linear-gradient(90deg, #000 0 14px, transparent 14px 28px);
	        mask: repeating-linear-gradient(90deg, #000 0 14px, transparent 14px 28px);
}

/* =========================================================================
   Komponenty Gold — kafelki kategorii i epok (markup wg kontraktu G1c)
   ========================================================================= */

/* (4) KATEGORIE — [gpz_categories] -> .gpz-cat-grid > a.cat-tile */
.gpz-cat-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 20px;
}
.cat-tile {
	display: flex;
	flex-direction: column;
	gap: 22px;
	background: var(--card);
	border: 1px solid var(--line);
	border-radius: var(--r-card);
	padding: 26px 24px;
	text-decoration: none;
	box-shadow: var(--shadow-card);
	transition: transform .45s cubic-bezier(.2, .75, .25, 1), box-shadow .45s ease, border-color .3s ease;
}
.cat-tile__ic {
	width: 54px;
	height: 54px;
	border-radius: 50%;
	border: 1.5px solid var(--line);
	display: grid;
	place-items: center;
	color: var(--accent);
	flex: 0 0 auto;
	transition: background .4s ease, color .4s ease, border-color .4s ease;
}
.cat-tile__ic svg {
	width: 24px;
	height: 24px;
	color: var(--accent);
	transition: color .4s ease;
}
.cat-tile__main {
	display: flex;
	flex-direction: column;
	gap: 14px;
	flex: 1;
	justify-content: space-between;
}
.cat-tile__title {
	font-family: var(--fontD);
	font-weight: 600;
	font-size: 1.25rem;
	line-height: 1.25;
	color: var(--text);
	margin: 0;
	text-wrap: balance;
}
.cat-tile__meta {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
}
.cat-tile__count {
	font-family: var(--fontM);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--muted);
}
.cat-go {
	color: var(--accent);
	display: inline-flex;
	font-size: 1.05rem;
	line-height: 1;
	opacity: 0;
	transform: translateX(-7px);
	transition: opacity .4s ease, transform .4s ease;
}
/* HOVER kafelka kategorii */
.cat-tile:hover {
	transform: translateY(-7px);
	box-shadow: var(--shadow-lg);
	border-color: var(--line-2);
}
.cat-tile:hover .cat-tile__ic {
	background: var(--accent);
	border-color: var(--accent);
	color: var(--text-on-accent);
}
.cat-tile:hover .cat-tile__ic svg { color: var(--text-on-accent); }
.cat-tile:hover .cat-go { opacity: 1; transform: translateX(0); }

/* (4) EPOKI — [gpz_epochs] -> .gpz-epoch-grid > a.epoch-tile */
.gpz-epoch-grid {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 14px;
}
.gpz-epoch-grid .epoch-tile:nth-last-child(-n+2) {
	grid-column: span 3; /* PRL i Wspolczesne — kazdy na szerokosc 3 kolumn (rzad 2) */
}
.epoch-tile {
	display: block;
	background: var(--card);
	border: 1px solid var(--line);
	border-radius: var(--r-card);
	padding: 24px 22px;
	text-align: left;
	text-decoration: none;
	color: var(--text);
	box-shadow: var(--shadow-card);
	transition: transform .45s cubic-bezier(.2, .75, .25, 1), color .4s ease, background .4s ease, border-color .3s ease, box-shadow .4s ease;
}
.epoch-tile__tick {
	display: block;
	width: 28px;
	height: 3px;
	background: var(--accent);
	border-radius: 2px;
	margin-bottom: 18px;
	transition: background .4s ease;
}
.epoch-tile__year {
	display: block;
	font-family: var(--fontB);
	font-weight: 600;
	font-size: 11px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--muted);
	margin-bottom: 9px;
	transition: color .4s ease;
}
.epoch-tile__name {
	display: block;
	font-family: var(--fontD);
	font-weight: 700;
	font-size: 23px;
	line-height: 1.05;
	color: inherit;
}
.epoch-tile:hover {
	transform: translateY(-6px);
	background: var(--ink);
	color: var(--text);
	border-color: var(--line-2);
	box-shadow: var(--shadow-lg);
}
.epoch-tile:hover .epoch-tile__tick { background: var(--accent-h); }
.epoch-tile:hover .epoch-tile__year { color: var(--accent-h); }

/* =========================================================================
   WooCommerce — katalog (centralny element)
   ========================================================================= */

/* Siatka kart */
.woocommerce ul.products,
.woocommerce-page ul.products {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: 1.6rem;
	margin: 0;
	padding: 0;
}
.woocommerce ul.products::before,
.woocommerce ul.products::after { content: none; }

.woocommerce ul.products li.product {
	width: auto !important;
	margin: 0 !important;
	float: none !important;
	background: var(--card);
	border: 1px solid var(--line);
	border-radius: var(--r-card);
	box-shadow: var(--gpz-shadow-sm);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: box-shadow 0.25s ease, transform 0.18s ease, border-color 0.25s ease;
}
.woocommerce ul.products li.product:hover {
	box-shadow: var(--shadow-card);
	transform: translateY(-4px);
	border-color: var(--line-2);
}

.woocommerce ul.products li.product a img {
	margin: 0;
	width: 100%;
	aspect-ratio: 4 / 3;
	object-fit: cover;
	display: block;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-size: 1.05rem;
	color: var(--text);
	padding: 0.8rem 1rem 0.2rem;
	line-height: 1.25;
}
.woocommerce ul.products li.product .price { display: none; } /* tryb katalogu */

.gpz-loop-availability {
	display: inline-block;
	margin: 0 1rem;
	font-size: 0.72rem;
	font-family: var(--fontM);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--accent);
}

/* Sygnatura (nr indeksu) na kartach w petli */
.gpz-loop-sku {
	display: block;
	margin: 0.2rem 1rem 0;
	font-size: 0.72rem;
	font-family: var(--fontM);
	letter-spacing: 0.04em;
	color: var(--muted);
}
.gpz-loop-sku .gpz-loop-sku-l {
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--accent);
	margin-right: 0.25rem;
}

/* CTA w petli — przyklejone do dolu karty */
.woocommerce ul.products li.product .gpz-cta--loop {
	margin: auto 1rem 1rem;
	text-align: center;
	font-size: 0.85rem;
}

/* Karta produktu (single) */
.woocommerce div.product .product_title {
	color: var(--text);
	margin-bottom: 0.4rem;
}
.woocommerce div.product .woocommerce-product-details__short-description {
	font-size: 1.12rem;
	color: var(--body);
	background: var(--card);
	border-left: 3px solid var(--accent);
	padding: 0.9rem 1rem;
	border-radius: 0 var(--r-input) var(--r-input) 0;
	margin-bottom: 1.4rem;
}
.woocommerce div.product .product_meta {
	font-size: 0.9rem;
	color: var(--muted);
	border-top: 1px solid var(--line);
	padding-top: 1rem;
}
.woocommerce div.product .product_meta a { color: var(--accent); }

/* CTA box (single) */
.gpz-cta-box {
	margin: 1.4rem 0;
	padding: 1.4rem;
	background: var(--card);
	border: 1px solid var(--line);
	border-radius: var(--r-card);
}
.gpz-cta-box .gpz-cta { margin: 0 0.6rem 0.6rem 0; }
.gpz-cta--phone {
	background: var(--accent);
	color: var(--text-on-accent);
}
.gpz-cta--phone:hover {
	background: var(--accent-h);
	color: var(--text-on-accent);
}
.gpz-cta-note { font-size: 0.9rem; color: var(--muted); margin: 0.4rem 0 0; }

/* Dostepnosc (single) */
.woocommerce div.product .stock.gpz-available,
.stock.gpz-available { color: var(--status-ok); font-weight: 600; }
.woocommerce div.product .stock.gpz-rented,
.stock.gpz-rented { color: var(--status-rented); font-weight: 600; }

/* Breadcrumb */
.woocommerce .woocommerce-breadcrumb {
	font-family: var(--fontM);
	font-size: 0.8rem;
	color: var(--muted);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	margin-bottom: 1.4rem;
}
.woocommerce .woocommerce-breadcrumb a { color: var(--accent); }

/* Naglowek archiwum kategorii */
.woocommerce .woocommerce-products-header__title,
.woocommerce .page-title {
	color: var(--text);
	font-size: clamp(1.9rem, 1.4rem + 2vw, 3rem);
}
.term-description { color: var(--body); max-width: 70ch; margin-bottom: 1.6rem; }

/* Sortowanie / wyniki */
.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering { color: var(--muted); font-size: 0.85rem; }
.woocommerce .woocommerce-ordering select {
	background: var(--bg2);
	color: var(--text);
	border: 1px solid var(--line);
	border-radius: var(--r-input);
	padding: 0.4em 0.6em;
}

/* Licznik kategorii — usun zolte tlo <mark> i wkomponuj w karty */
.woocommerce mark,
.woocommerce ul.products li.product-category mark.count,
mark.count {
	background: transparent;
	color: var(--muted);
	font-weight: 400;
}
.woocommerce ul.products li.product-category {
	background: var(--card);
	border: 1px solid var(--line);
	border-radius: var(--r-card);
}
.woocommerce ul.products li.product-category .woocommerce-loop-category__title .count {
	display: block;
	font-family: var(--fontM);
	font-size: 0.74rem;
	color: var(--muted);
	letter-spacing: 0.08em;
	text-transform: uppercase;
}
.woocommerce ul.products li.product-category a img { aspect-ratio: 4 / 3; object-fit: cover; }
.woocommerce ul.products li.product-category .woocommerce-loop-category__title {
	font-family: var(--fontD);
	color: var(--text);
	padding: 0.8rem 1rem 1rem;
}

/* =========================================================================
   Responsywnosc
   ========================================================================= */
@media (max-width: 1024px) {
	.gpz-epoch-grid { grid-template-columns: repeat(3, 1fr); }
	.gpz-epoch-grid .epoch-tile:nth-last-child(-n+2) { grid-column: auto; } /* reset spanu z desktopu */
}
@media (max-width: 768px) {
	.woocommerce ul.products,
	.woocommerce-page ul.products { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 1rem; }
	.gpz-cat-grid { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 16px; }
}
@media (max-width: 560px) {
	.gpz-epoch-grid { grid-template-columns: repeat(2, 1fr); }
}

/* Stara siatka kategorii w patternach (zachowana dla kompatybilnosci, na ciemno).
   Uwaga: .gpz-cat-grid jest teraz siatka kafelkow .cat-tile (powyzej);
   ponizsza .gpz-cat-card to legacy wariant ze zdjeciem w tle. */
.gpz-cat-card {
	display: block;
	position: relative;
	border-radius: var(--r-card);
	overflow: hidden;
	min-height: 160px;
	background: var(--card);
	color: var(--text);
	box-shadow: var(--gpz-shadow-sm);
}
.gpz-cat-card span {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	padding: 0.8rem 1rem;
	font-family: var(--fontD);
	color: var(--text);
	letter-spacing: 0.02em;
	background: linear-gradient(0deg, rgba(15, 12, 8, 0.92), transparent);
}

/* ---------- Formularz zapytania ---------- */
.gpz-inquiry-form { max-width: 620px; }
.gpz-inquiry-form .gpz-field { margin-bottom: 1rem; }
.gpz-inquiry-form label {
	display: block;
	font-weight: 600;
	margin-bottom: 0.3rem;
	color: var(--text);
}
.gpz-inquiry-form input[type="text"],
.gpz-inquiry-form input[type="email"],
.gpz-inquiry-form input[type="tel"],
.gpz-inquiry-form textarea {
	width: 100%;
	padding: 0.85em 1em;
	border: 1px solid var(--line);
	border-radius: var(--r-input);
	background: var(--bg2);
	font: inherit;
	color: var(--text);
}
.gpz-inquiry-form input::placeholder,
.gpz-inquiry-form textarea::placeholder { color: var(--muted); }
.gpz-inquiry-form input:focus,
.gpz-inquiry-form textarea:focus {
	outline: 2px solid var(--accent);
	outline-offset: 0;
	border-color: var(--accent);
}
.gpz-inquiry-form .gpz-field--consent label { font-weight: 400; font-size: 0.9rem; color: var(--body); }
.gpz-inquiry-form .gpz-field--consent input { width: auto; margin-right: 0.4rem; }
.gpz-hp { position: absolute; left: -9999px; height: 0; overflow: hidden; }
.gpz-form-context {
	background: var(--card);
	border-left: 3px solid var(--accent);
	color: var(--body);
	padding: 0.7rem 1rem;
	margin-bottom: 1.2rem;
	border-radius: var(--r-input);
}
.gpz-form-notice { padding: 0.9rem 1.1rem; border-radius: var(--r-input); margin-bottom: 1.2rem; }
.gpz-form-notice--ok {
	background: rgba(134, 192, 106, .10);
	border: 1px solid var(--status-ok);
	color: var(--text);
}
.gpz-form-notice--err {
	background: rgba(224, 140, 130, .10);
	border: 1px solid var(--status-rented);
	color: var(--text);
}

/* ---------- Kontakt ---------- */
.gpz-contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; align-items: start; }
.gpz-contact-grid iframe { width: 100%; min-height: 340px; border: 0; border-radius: var(--r-card); }
@media (max-width: 768px) { .gpz-contact-grid { grid-template-columns: 1fr; } }
.gpz-nap p { margin: 0 0 0.4rem; color: var(--body); }
.gpz-nap .gpz-nap-label {
	font-family: var(--fontM);
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--accent);
	font-size: 0.78rem;
	margin-top: 1rem;
}

/* =========================================================================
   F8 — a11y / kontrast (zaktualizowane na ciemny motyw Gold)
   ========================================================================= */
/* Wszystkie sekcje sa ciemne — eyebrow/etykiety/dostepnosc w petli = zloto.
   (Nie ma juz jasnych sekcji, wiec --gpz-brass-dark = --accent.) */
.gpz-section .gpz-eyebrow,
.gpz-nap-label,
.gpz-nap .gpz-nap-label,
.gpz-loop-availability { color: var(--accent); }
/* Ciemne sekcje CTA / hero — jasniejszy akcent (lepszy kontrast na bardzo ciemnym) */
.gpz-section--dark .gpz-eyebrow,
.gpz-hero-cover .gpz-eyebrow { color: var(--accent-h); }
/* Hover linkow tresci */
.inside-article a:hover,
.entry-content a:hover,
.term-description a:hover,
.woocommerce-products-header a:hover,
.woocommerce-product-details__short-description a:hover { color: var(--accent-h); }
/* Widoczny fokus klawiaturą (zlote obramowanie na ciemnym tle) */
.inside-article a:focus-visible,
.entry-content a:focus-visible,
.term-description a:focus-visible,
a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
.cat-tile:focus-visible,
.epoch-tile:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

/* Dostepnosc na karcie glownego produktu */
.gpz-availability {
	font-family: var(--fontM);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-size: 0.78rem;
	font-weight: 700;
	margin: 0 0 0.6rem;
}
.gpz-available { color: var(--status-ok); }
.gpz-rented { color: var(--status-rented); }

/* =========================================================================
   R1 — Logo (jedyny branding), header CTA, hero 2-kol wg mockupu,
   feature/step, stopka 4-kolumnowa. Kontrakt klas: blocks-gold.php + page 2.
   ========================================================================= */

/* ---- Logo: pelny znak inline SVG jako JEDYNY branding (ukryj tytul GP) ---- */
.site-header .main-title,
.site-header .site-title,
.site-header .site-description { display: none !important; }
.gpz-logo-svg { display: inline-flex; align-items: center; line-height: 0; }
.gpz-logo-svg svg { height: 66px; width: auto; display: block; }
@media (max-width: 768px) {
	.gpz-logo-svg svg { height: 48px; }
}

/* ---- Header CTA „Zapytaj o wynajem" (generate_after_primary_menu) ---- */
.gpz-nav-cta {
	display: inline-flex;
	align-items: center;
	margin-left: 0;
	padding: 0.72em 1.2em;
	white-space: nowrap;
	flex: none;
	background: var(--accent);
	color: var(--text-on-accent);
	font-family: var(--fontB);
	font-weight: 600;
	font-size: 0.78rem;
	letter-spacing: 0.06em;
	text-transform: uppercase !important; /* !important: pokonuje dziedziczone text-transform:none z html/body (CTA = jedyny element nav wersalikami) */
	border-radius: var(--r-sm);
	box-shadow: var(--glow-cta);
	transition: background-color .18s ease, transform .12s ease;
}
/* !important: na stronach Woo reguly .woocommerce-page a maja wyzsza specyficznosc
   i kolorowaly tekst CTA na zloto (niewidoczny na zlotym tle). */
.gpz-nav-cta,
.gpz-nav-cta:hover,
.gpz-nav-cta:focus { color: var(--text-on-accent) !important; }
.gpz-nav-cta:hover { background: var(--accent-h); transform: translateY(-1px); }
@media (max-width: 768px) {
	.gpz-nav-cta { display: none; } /* na mobile CTA jest w hero i sekcji CTA */
}

/* ---- Wyszukiwarka rekwizytów w nawigacji (ikona lupy → rozwijany panel) ---- */
.gpz-nav-search {
	position: relative;
	display: inline-flex;
	align-items: center;
	margin-left: 0.9rem;
}
.gpz-nav-search__toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	color: var(--text);
	border: 1px solid var(--line);
	border-radius: var(--r-sm);
	background: transparent;
	cursor: pointer;
	list-style: none;
	transition: color .18s ease, border-color .18s ease, background-color .18s ease;
}
.gpz-nav-search__toggle::-webkit-details-marker { display: none; } /* usuń strzałkę <details> w WebKit */
.gpz-nav-search__toggle:hover,
.gpz-nav-search[open] .gpz-nav-search__toggle {
	color: var(--accent);
	border-color: var(--line-2);
	background: var(--bg2);
}
/* Panel z polem wyszukiwania (rozwijany pod ikoną, wyrównany do prawej) */
.gpz-nav-search__form {
	position: absolute;
	top: calc(100% + 10px);
	right: 0;
	z-index: 60;
	display: flex;
	align-items: center;
	gap: 6px;
	padding: 8px;
	width: min(320px, 78vw);
	background: var(--card);
	border: 1px solid var(--line-2);
	border-radius: var(--r-input);
	box-shadow: var(--shadow-card);
}
.gpz-nav-search__input {
	flex: 1 1 auto;
	min-width: 0;
	padding: 0.62em 0.8em;
	color: var(--text);
	background: var(--bg);
	border: 1px solid var(--line);
	border-radius: var(--r-sm);
	font-family: var(--fontB);
	font-size: 0.9rem;
}
.gpz-nav-search__input::placeholder { color: var(--muted); }
.gpz-nav-search__input:focus {
	outline: none;
	border-color: var(--accent);
}
.gpz-nav-search__submit {
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	color: var(--text-on-accent);
	background: var(--accent);
	border: none;
	border-radius: var(--r-sm);
	cursor: pointer;
	transition: background-color .18s ease;
}
.gpz-nav-search__submit:hover { background: var(--accent-h); }
@media (max-width: 768px) {
	.gpz-nav-search { display: none; } /* na mobile wyszukiwarka dostępna na archiwum katalogu */
}

/* ---- HERO 2-kolumnowy ([gpz_hero] w alignfull .gpz-hero-wrap) ---- */
.gpz-hero-wrap { margin: 0 !important; }
.gpz-hero2 { background: var(--bg); padding-block: clamp(2.6rem, 1.6rem + 4vw, 5.4rem); }
.gpz-hero2__inner {
	max-width: var(--maxw);
	margin: 0 auto;
	padding: 0 32px;
	display: flex;
	flex-wrap: wrap;
	gap: 60px;
	align-items: center;
	justify-content: space-between;
}
.gpz-hero2__text { flex: 1 1 460px; min-width: 290px; max-width: 640px; }
.gpz-hero2__eyebrow { display: flex; align-items: center; gap: 14px; margin-bottom: 24px; }
.gpz-hero2__eyebrow-line { width: 34px; height: 1.5px; background: var(--accent); display: inline-block; flex: none; }
.gpz-hero2__eyebrow-text {
	font-family: var(--fontB);
	font-weight: 600;
	font-size: 12px;
	letter-spacing: 0.26em;
	text-transform: uppercase;
	color: var(--accent-h);
}
.gpz-hero2__title {
	font-family: var(--fontD);
	font-weight: 700;
	font-size: clamp(2.9rem, 1.9rem + 4vw, 6rem);
	line-height: 0.98;
	letter-spacing: -0.015em;
	margin: 0;
	color: var(--text);
}
.gpz-hero2__title em { font-style: italic; font-weight: 700; color: var(--accent); }
.gpz-hero2__lead {
	font-family: var(--fontB);
	font-size: clamp(1rem, 0.95rem + 0.4vw, 1.15rem);
	line-height: 1.65;
	color: var(--body);
	max-width: 540px;
	margin: 28px 0 0;
}
.gpz-hero2__cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 36px; }
.gpz-hero2 .gpz-btn {
	display: inline-flex;
	align-items: center;
	gap: 9px;
	padding: 16px 28px;
	border-radius: var(--r-card);
	font-family: var(--fontB);
	font-weight: 600;
	font-size: 0.86rem;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	text-decoration: none;
	transition: transform .25s ease, background-color .25s ease, color .25s ease, border-color .25s ease;
}
.gpz-hero2 .gpz-btn svg { width: 17px; height: 17px; }
.gpz-hero2 .gpz-btn--primary { background: var(--accent); color: var(--text-on-accent); box-shadow: var(--shadow-card); }
.gpz-hero2 .gpz-btn--primary:hover { transform: scale(1.03); color: var(--text-on-accent); }
.gpz-hero2 .gpz-btn--ghost { background: transparent; color: var(--text); border: 1.5px solid var(--line-2); }
.gpz-hero2 .gpz-btn--ghost:hover { background: var(--text); color: var(--bg); border-color: var(--text); }

/* Pasek statystyk */
.gpz-hero-stats { display: flex; flex-wrap: wrap; align-items: center; margin-top: 48px; }
.gpz-hero-stat { padding: 0 28px; }
.gpz-hero-stat:first-child { padding-left: 0; }
.gpz-hero-stat__num { display: block; font-family: var(--fontD); font-weight: 700; font-size: 30px; line-height: 1; color: var(--text); }
.gpz-hero-stat__label { display: block; font-family: var(--fontB); font-weight: 600; font-size: 10.5px; line-height: 1.3; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted); margin-top: 7px; }
.gpz-hero-stat__sep { width: 1px; height: 42px; background: var(--line-2); flex: none; }

/* Karta „tasma filmowa" */
.gpz-hero-card {
	position: relative;
	flex: 0 1 400px;
	min-width: 286px;
	max-width: 420px;
	background: var(--ink);
	border-radius: var(--r-card);
	padding: 24px 32px 28px;
	box-shadow: var(--shadow-lg);
	transform: rotate(1.6deg);
	transition: transform .8s cubic-bezier(.2, .75, .25, 1);
}
.gpz-hero-card:hover { transform: rotate(0deg); }
.gpz-hero-card__perf {
	position: absolute;
	top: 20px;
	bottom: 20px;
	width: 6px;
	border-radius: 3px;
	background: repeating-linear-gradient(to bottom, var(--film-hole) 0 9px, transparent 9px 22px);
}
.gpz-hero-card__perf--l { left: 13px; }
.gpz-hero-card__perf--r { right: 13px; }
.gpz-hero-card__head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 18px; }
.gpz-hero-card__head span {
	font-family: var(--fontB);
	font-weight: 600;
	font-size: 9.5px;
	letter-spacing: 0.26em;
	text-transform: uppercase;
	color: rgba(242, 234, 217, .48);
}
.gpz-hero-card__nr { color: var(--accent-h) !important; letter-spacing: 0.22em !important; }
.gpz-hero-card__rows { display: flex; flex-direction: column; gap: 13px; }
.gpz-hero-card__row { display: flex; align-items: center; gap: 15px; background: var(--card); border-radius: 11px; padding: 15px 17px; }
.gpz-hero-card__ic {
	flex: none;
	width: 46px;
	height: 46px;
	border-radius: 50%;
	background: rgba(201, 168, 106, .14);
	color: var(--accent);
	display: flex;
	align-items: center;
	justify-content: center;
}
.gpz-hero-card__ic svg { width: 24px; height: 24px; }
.gpz-hero-card__meta { display: flex; flex-direction: column; gap: 5px; }
.gpz-hero-card__name { font-family: var(--fontB); font-weight: 600; font-size: 14.5px; line-height: 1.1; color: var(--text); }
.gpz-hero-card__epoch { font-family: var(--fontB); font-weight: 600; font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--accent); }
.gpz-hero-card__foot {
	text-align: center;
	font-family: var(--fontB);
	font-weight: 600;
	font-size: 9.5px;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	color: rgba(242, 234, 217, .48);
	margin-top: 18px;
}
@media (max-width: 900px) {
	.gpz-hero2__inner { gap: 40px; }
	.gpz-hero-card { flex: 1 1 100%; max-width: 460px; margin: 0 auto; transform: rotate(0deg); }
}

/* ---- „O rekwizytorni" — kolumny z gorna kreska 2px ---- */
.gpz-feature-col { border-top: 2px solid var(--text); padding-top: 30px !important; }
.gpz-feature-ic { display: inline-flex; width: 48px; height: 48px; align-items: center; justify-content: center; color: var(--accent); margin-bottom: 18px; }
.gpz-feature-ic svg { width: 30px; height: 30px; }
.gpz-feature-col h3 { font-family: var(--fontB); font-weight: 600; font-size: 1.18rem; line-height: 1.25; color: var(--text); margin: 0; }
.gpz-feature-col p { margin-top: 12px; }

/* ---- „Jak wynajac" — kroki z duzym kursywnym numerem 01–03 ---- */
.gpz-step { border-top: 2px solid var(--text); padding-top: 26px !important; }
.gpz-step__top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; }
.gpz-step__num { font-family: var(--fontD); font-weight: 800; font-style: italic; font-size: 56px; line-height: 0.8; color: var(--accent); }
.gpz-step__ic { color: var(--accent); opacity: 0.85; display: inline-flex; }
.gpz-step__ic svg { width: 30px; height: 30px; }
.gpz-step h3 { font-family: var(--fontB); font-weight: 600; font-size: 1.3rem; line-height: 1.25; color: var(--text); margin: 0; }
.gpz-step p { margin-top: 13px; }

/* ---- Stopka wg mockupu (4 kolumny + dolny pasek) ---- */
.gpz-foot-brand .gpz-foot-brandrow { display: flex; align-items: center; gap: 12px; margin-bottom: 18px; }
.gpz-foot-name { font-family: var(--fontB); font-weight: 700; font-size: 15px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--text); }
.gpz-foot-brand p { font-family: var(--fontB); font-size: 14px; line-height: 1.65; color: rgba(242, 234, 217, .48); max-width: 280px; margin: 0 0 18px; }
.gpz-foot-fb { display: inline-flex; align-items: center; gap: 9px; font-family: var(--fontB); font-weight: 600; font-size: 13px; color: var(--body); text-decoration: none; }
.gpz-foot-fb:hover { color: var(--text); }
.gpz-foot-head { font-family: var(--fontB); font-weight: 600; font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--accent); margin-bottom: 18px; }
.gpz-foot-list { display: flex; flex-direction: column; gap: 12px; font-family: var(--fontB); font-size: 14px; line-height: 1.4; }
.gpz-foot-list span { color: var(--body); }
.gpz-foot-list a { color: var(--body); text-decoration: none; }
.gpz-foot-list a:hover { color: var(--text); }
.gpz-foot-phones { display: flex; flex-direction: column; gap: 14px; }
.gpz-foot-phone { display: flex; justify-content: space-between; gap: 12px; font-family: var(--fontB); font-size: 14px; }
.gpz-foot-phone-label { color: rgba(242, 234, 217, .48); }
.gpz-foot-phone a { color: var(--text); text-decoration: none; white-space: nowrap; }
.gpz-foot-phone a:hover { color: var(--accent-h); }
.gpz-foot-bottom {
	max-width: var(--maxw);
	margin: 0.4rem auto 0;
	padding: 26px 20px 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 12px;
	border-top: 1px solid rgba(242, 234, 217, .12);
}
.gpz-foot-bottom span { font-family: var(--fontB); font-size: 12.5px; color: rgba(242, 234, 217, .48); }

/* Stara stopka GP: widget „Telefon" (duplikat numerow) + pasek „Built with GeneratePress".
   Zastapione wlasna stopka 4-kolumnowa (gpz-footer-cols + gpz-foot-bottom). */
.footer-widgets-container,
.site-info { display: none !important; }

/* Przyciski blokowe w sekcji CTA (ciemnej): GP nadpisuje .wp-block-button__link
   szarym tlem — wymuszamy zloto (primary) i ghost (outline) wg mockupu. */
.gpz-section--dark .wp-block-button:not(.is-style-outline) > .wp-block-button__link {
	background-color: var(--accent);
	color: var(--text-on-accent);
	box-shadow: var(--glow-cta);
}
.gpz-section--dark .wp-block-button:not(.is-style-outline) > .wp-block-button__link:hover {
	background-color: var(--accent-h);
	color: var(--text-on-accent);
}
.gpz-section--dark .wp-block-button.is-style-outline > .wp-block-button__link {
	background-color: transparent;
	color: var(--text);
	box-shadow: inset 0 0 0 1.5px var(--line-2);
}
.gpz-section--dark .wp-block-button.is-style-outline > .wp-block-button__link:hover {
	background-color: var(--text);
	color: var(--bg);
	box-shadow: inset 0 0 0 1.5px var(--text);
}
/* Przyciski dolnego CTA (blok .gpz-cta-actions) — mniejszy font wg ustalen */
.gpz-cta-actions .wp-block-button__link { font-size: 13.5px; }

/* Kontener tresci GP (separate-containers) na PODSTRONACH ma domyslnie biale tlo
   -> jasna „wyspa" na krawedziach. Przezroczysty, by przeswitywalo ciemne body.
   (.home ma osobne, mocniejsze reguly powyzej.) */
.inside-article,
.content-area .entry-content,
.woocommerce .inside-article {
	background-color: transparent !important;
	box-shadow: none !important;
}

/* =========================================================================
   Accordion „Czytaj wiecej" w opisie archiwum (kategorie /rekwizyty/,
   epoki /epoka/). JS-free: natywny <details>/<summary>. Markup z
   inc/archive-intro.php. Typografia dziedziczy z .term-description.
   ====================================================================== */
.gpz-readmore {
	margin-top: 0.4rem;
	margin-bottom: 1.6rem;
}
.gpz-readmore > summary {
	display: inline-flex;
	align-items: center;
	gap: 0.45em;
	cursor: pointer;
	list-style: none;
	color: var(--accent);
	font-weight: 600;
	letter-spacing: 0.01em;
	transition: color 0.15s ease;
}
.gpz-readmore > summary::-webkit-details-marker { display: none; }
/* Wlasny znacznik ▸ obracany w stanie [open]. */
.gpz-readmore > summary::before {
	content: "";
	width: 0.5em;
	height: 0.5em;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: rotate(-45deg);
	transition: transform 0.18s ease;
}
.gpz-readmore[open] > summary::before { transform: rotate(45deg); }
.gpz-readmore > summary:hover { color: var(--accent-h); }
.gpz-readmore > summary:focus-visible {
	outline: 2px solid var(--accent);
	outline-offset: 3px;
}
.gpz-readmore__body {
	color: var(--body);
	max-width: 70ch;
	margin-top: 0.9rem;
}
.gpz-readmore__body > p:last-child { margin-bottom: 0; }

/* ---- Interaktywny kadr „za kulisami”: lupa odsłaniająca sygnatury EKS ([gpz_reveal]) ---- */
.gpz-reveal-wrap { background: var(--bg); padding-top: 0; }
.gpz-reveal {
	position: relative;
	width: 100%;
	aspect-ratio: 1536 / 656;
	border-radius: var(--r-card);
	overflow: hidden;
	cursor: crosshair;
	background: #0c0a08;
	box-shadow: var(--shadow-lg);
	touch-action: none;
}
.gpz-reveal__base {
	position: absolute; inset: 0;
	width: 100%; height: 100%;
	object-fit: cover; display: block;
	user-select: none; -webkit-user-drag: none;
}
.gpz-reveal__lens {
	position: absolute; left: 50%; top: 50%;
	width: 0; height: 0;
	transform: translate(-50%, -50%);
	background-repeat: no-repeat;
	opacity: 0; pointer-events: none;
	-webkit-mask-image: radial-gradient(closest-side, #000 0 32%, rgba(0,0,0,.66) 54%, rgba(0,0,0,.26) 74%, rgba(0,0,0,.08) 90%, transparent 100%);
	        mask-image: radial-gradient(closest-side, #000 0 32%, rgba(0,0,0,.66) 54%, rgba(0,0,0,.26) 74%, rgba(0,0,0,.08) 90%, transparent 100%);
	will-change: width, height, left, top;
}
.gpz-reveal__hint {
	position: absolute; left: 50%; bottom: 18px;
	transform: translateX(-50%);
	display: inline-flex; align-items: center; gap: 9px;
	padding: 10px 17px;
	border-radius: var(--r-pill);
	background: rgba(12, 10, 8, .6);
	-webkit-backdrop-filter: blur(7px); backdrop-filter: blur(7px);
	border: 1px solid rgba(242, 234, 217, .18);
	font-family: var(--fontB); font-weight: 600; font-size: 11.5px; line-height: 1;
	letter-spacing: .03em; color: #F3EEE4; white-space: nowrap;
	transition: opacity .45s ease; pointer-events: none;
}
.gpz-reveal__hint svg { width: 15px; height: 15px; flex: none; }

/* ---- Strzałka w CTA nawigacji (wg makiety) ---- */
.gpz-nav-cta { gap: 8px; }
.gpz-nav-cta__arrow { flex: none; transition: transform .25s ease; }
.gpz-nav-cta:hover .gpz-nav-cta__arrow { transform: translateX(3px); }

/* =========================================================================
   Sekcja „Wyróżnione rekwizyty" ([gpz_featured]) — pozioma karuzela kart.
   Pełnoszerokościowa, ciemna (--ink). Wrapper na page 2: .gpz-featured-wrap.
   ========================================================================= */
.gpz-featured-wrap { margin: 0 !important; }
.gpz-featured {
	position: relative;
	overflow: hidden;
	background: var(--ink);
	background-image: radial-gradient(420px 420px at 88% -10%, var(--cta-glow), transparent 70%);
	padding-block: clamp(2.8rem, 1.8rem + 4.5vw, 6rem);
	/* full-bleed: wyrwanie z kontenera GP na pełen viewport */
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
}
.gpz-featured__inner {
	max-width: min(1280px, 100% - 48px);
	margin: 0 auto;
}
.gpz-featured__head { max-width: 620px; margin-bottom: 34px; }
.gpz-featured__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 11px;
	font-family: var(--fontB);
	font-weight: 600;
	font-size: 11.5px;
	letter-spacing: 0.26em;
	text-transform: uppercase;
	color: var(--accent-h);
	margin: 0;
}
.gpz-featured__eyebrow .gpz-eyebrow__tick {
	width: 30px;
	height: 1.5px;
	background: var(--accent);
	display: inline-block;
	flex: none;
}
.gpz-featured__title {
	font-family: var(--fontD);
	font-weight: 700;
	font-size: clamp(28px, 4vw, 48px);
	line-height: 1.04;
	letter-spacing: -0.01em;
	color: var(--text);
	margin: 16px 0 0;
}
.gpz-featured__title em { font-style: italic; color: var(--accent); }
.gpz-featured__lead {
	font-family: var(--fontB);
	font-weight: 400;
	font-size: 15px;
	line-height: 1.66;
	color: var(--body);
	max-width: 520px;
	margin: 14px 0 0;
}
/* Karuzela kart: te same karty `gpz-pcard` co w katalogu (content-product.php,
   styl w woocommerce-gold.css), ale ułożone w poziomy wiersz ze snapem zamiast
   siatki. Override grid z `.woocommerce ul.products` (specyficzność: 3 klasy). */
.gpz-featured__cards { width: auto; }
.gpz-featured ul.products.gpz-featrow {
	display: flex;
	grid-template-columns: none;
	gap: 20px;
	margin: 0;
	padding: 4px 0 18px;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scrollbar-width: thin;
	scrollbar-color: var(--line-2) transparent;
	-webkit-overflow-scrolling: touch;
}
.gpz-featured ul.products.gpz-featrow::-webkit-scrollbar { height: 8px; }
.gpz-featured ul.products.gpz-featrow::-webkit-scrollbar-track { background: transparent; }
.gpz-featured ul.products.gpz-featrow::-webkit-scrollbar-thumb { background: var(--line-2); border-radius: 8px; }
.gpz-featured ul.products.gpz-featrow li.product {
	flex: 0 0 270px;
	scroll-snap-align: start;
}
@media (max-width: 600px) {
	.gpz-featured ul.products.gpz-featrow li.product { flex-basis: 78vw; }
}
