/*
Theme Name: Senapi Art
Theme URI: https://senapiart.pl
Author: Senapi Art / Damian
Description: Autorski motyw dla pracowni figurek Senapi Art. Dark fantasy / horror estetyka. Zbudowany na WooCommerce + Carbon Fields.
Version: 0.1.0
Requires at least: 6.5
Tested up to: 6.9
Requires PHP: 8.1
License: GPL v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: senapiart
Tags: woocommerce, one-page, dark, custom
*/

/* ═══════════════════ TOKENS ═══════════════════ */
:root {
	--bg: #060505;
	--bg-1: #0c0a0a;
	--bg-2: #15110f;
	--line: #1f1916;
	--ink: #ece5d4;
	--ink-2: #b9b0a0;
	--ink-3: #7a7268;
	--ink-4: #4a4540;
	--blood: #a8121f;
	--blood-deep: #5e0a13;
	--bone: #d9c89c;
	--gold: #b89765;

	--topbar-h: 84px;
	--pad-x: clamp(20px, 4vw, 48px);
}

/* ═══════════════════ RESET ═══════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; scroll-padding-top: var(--topbar-h); }
body {
	background: var(--bg);
	color: var(--ink);
	font-family: 'Inter', system-ui, sans-serif;
	font-weight: 300;
	font-size: 16px;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	overflow-x: hidden;
}
::selection { background: var(--blood); color: var(--ink); }
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }

/* Film grain overlay */
body::before {
	content: "";
	position: fixed; inset: 0;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.12 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
	opacity: .5;
	mix-blend-mode: overlay;
	pointer-events: none;
	z-index: 99;
}

/* ═══════════════════ PHOTO SLOT SYSTEM ═══════════════════ */
.ps-hint {
	position: absolute; inset: 10px;
	border: 1px dashed rgba(184,151,101,.18);
	background: #000;
	display: flex; flex-direction: column;
	align-items: center; justify-content: center;
	gap: 10px; padding: 14px;
	text-align: center;
	z-index: 4;
	transition: border-color .3s ease, background-color .3s ease;
}
.ps-hint:hover { border-color: rgba(168,18,31,.45); background: #050202; }
.ps-icon { width: 28px; height: 28px; color: var(--gold); opacity: .45; }
.ps-label {
	font-family: 'Cinzel', serif;
	font-size: 10px;
	font-weight: 500;
	letter-spacing: .28em;
	text-transform: uppercase;
	color: var(--ink-3);
	line-height: 1.3;
}
.ps-path {
	font-family: 'JetBrains Mono', monospace;
	font-size: 9px;
	letter-spacing: .04em;
	color: var(--blood);
	opacity: .8;
	word-break: break-all;
	line-height: 1.4;
}
.tile:has(img) .ps-hint,
.mini-fig:has(img) .ps-hint,
.feature:has(img) .ps-hint,
.pracownia-img:has(img) .ps-hint,
.product:has(img) .ps-hint,
.showroom-img:has(img) .ps-hint { display: none; }

/* ═══════════════════ TOPBAR ═══════════════════ */
.topbar {
	position: fixed; top: 0; left: 0; right: 0;
	z-index: 50;
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: 24px;
	padding: 16px var(--pad-x);
	background: rgba(14,11,10,.96);
	backdrop-filter: blur(10px);
	border-bottom: 1px solid var(--line);
	min-height: var(--topbar-h);
}
.brand { display: flex; align-items: center; justify-self: start; }
.brand img {
	height: 52px; width: auto;
	transition: transform .35s ease, filter .35s ease;
	filter: drop-shadow(0 2px 10px rgba(0,0,0,.6));
}
.brand:hover img { transform: scale(1.04); filter: drop-shadow(0 0 18px rgba(168,18,31,.35)); }

nav.primary { display: flex; gap: 32px; align-items: center; justify-self: center; }
nav.primary a {
	font-family: 'Cinzel', serif;
	font-size: 11px;
	font-weight: 500;
	letter-spacing: .28em;
	text-transform: uppercase;
	color: var(--ink-2);
	position: relative;
	padding: 6px 0;
	transition: color .25s ease;
}
nav.primary a:hover { color: var(--ink); }
nav.primary a::after {
	content: ""; position: absolute; bottom: 0; left: 50%; transform: translateX(-50%);
	width: 0; height: 1px; background: var(--blood);
	transition: width .35s ease;
}
nav.primary a:hover::after { width: 100%; }

.socials { display: flex; align-items: center; gap: 4px; justify-self: end; }
.socials a {
	width: 38px; height: 38px;
	display: inline-flex; align-items: center; justify-content: center;
	color: var(--ink-2);
	border: 1px solid transparent;
	transition: color .25s ease, border-color .25s ease, background-color .25s ease, transform .25s ease;
}
.socials a:hover {
	color: var(--ink);
	border-color: var(--blood);
	background: rgba(168,18,31,.15);
	transform: translateY(-1px);
}
.socials svg { width: 18px; height: 18px; }

.menu-toggle {
	display: none;
	background: transparent; border: 1px solid var(--line);
	color: var(--ink-2);
	width: 38px; height: 38px;
	align-items: center; justify-content: center;
}
.menu-toggle svg { width: 20px; height: 20px; }

/* ═══════════════════ HERO ═══════════════════ */
.hero {
	position: relative;
	height: 100vh;
	min-height: 760px;            /* fallback dla niskich laptopów */
	display: grid;
	grid-template-rows: auto 1fr auto;  /* marks | row (5+center+5) | scroll */
	gap: 0;
	overflow: hidden;
	padding: calc(var(--topbar-h) + 72px) var(--pad-x) 24px;
	isolation: isolate;
}
.hero::before {
	content: ""; position: absolute; inset: 0;
	background:
		radial-gradient(ellipse at center, transparent 35%, rgba(0,0,0,.85) 100%),
		radial-gradient(ellipse at 30% 40%, rgba(168,18,31,.08), transparent 50%);
	z-index: 1;
	pointer-events: none;
}

/* Pasek nad tytułem */
.hero-marks {
	position: relative;
	z-index: 4;
	display: flex; align-items: center; justify-content: center; gap: 18px;
	color: var(--ink-3);
	font-family: 'Cinzel', serif;
	font-size: 10px;
	letter-spacing: .35em;
	text-transform: uppercase;
	white-space: nowrap;
	margin-bottom: 18px;
}
.hero-marks .dot { width: 4px; height: 4px; background: var(--blood); border-radius: 50%; }

/* Tytuł — w środkowej kolumnie, wysoko (nad feature image) */
.hero-titles {
	position: relative;
	z-index: 3;
	text-align: center;
	display: flex; flex-direction: column; align-items: center;
	gap: 14px;
	margin-bottom: 24px;
}
.hero-title {
	font-family: 'Cinzel', serif;
	font-weight: 900;
	letter-spacing: .16em;
	font-size: clamp(32px, 4.4vw, 64px);
	line-height: .95;
	text-transform: uppercase;
	color: var(--ink);
	text-shadow: 0 4px 30px rgba(0,0,0,.85);
}
.hero-title .sub {
	display: block;
	font-family: 'Cinzel', serif;
	font-weight: 500;
	font-size: clamp(11px, 0.95vw, 16px);
	letter-spacing: .55em;
	color: var(--blood);
	margin-top: 8px;
}
.hero-tagline {
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	font-size: clamp(14px, 1.05vw, 17px);
	color: var(--gold);
	max-width: 480px;
	line-height: 1.4;
}

/* Wiersz ze slotami: 4 lewa | tytuł+feature | 4 prawa */
.hero-row {
	position: relative;
	z-index: 2;
	display: grid;
	grid-template-columns: 1fr minmax(380px, 1fr) 1fr;
	align-items: stretch;
	gap: 0;
	min-height: 0;
}

.hero-side {
	position: relative;
	width: 100%;
	height: 100%;
	min-height: 0;
}

.mini-fig {
	position: relative;
	height: auto;
	aspect-ratio: 3/4;
	overflow: hidden;
	background: #000;
	filter: brightness(.88) saturate(.95);
	transition: filter .35s ease, transform .35s ease, z-index 0s ease .2s;
	z-index: 1;
	flex: 0 0 auto;
}
.mini-fig img { width: 100%; height: 100%; object-fit: cover; transition: transform .35s ease; }
.mini-fig::after {
	content: ""; position: absolute; inset: 0;
	background: linear-gradient(180deg, transparent 45%, rgba(6,5,5,.58) 100%),
				radial-gradient(ellipse at center, transparent 58%, rgba(0,0,0,.35));
	pointer-events: none;
	z-index: 2;
}
.mini-fig:hover {
	filter: brightness(.96) saturate(1);
	transition-delay: 0s;
}

/* ─── Niestandardowy układ slotów (desktop, ≥1101px) ───
   Każdy slot ma absolute position z własnym top/left/right + rotate.
   3 sloty po stronie, asymetrycznie. */

.hero-side .mini-fig { position: absolute; }

/* LEWA: górne delikatnie mniejsze, dolne większe; bliżej środka. */
.hero-side.left .mini-fig:nth-child(1) {
	width: clamp(146px, 14.2vw, 236px);
	top: 5%;
	right: -11%;
	transform: rotate(-5deg);
	z-index: 1;
}
.hero-side.left .mini-fig:nth-child(2) {
	width: clamp(136px, 13.2vw, 218px);
	top: 22%;
	right: 11%;
	transform: rotate(4deg);
	z-index: 2;
}
.hero-side.left .mini-fig:nth-child(3) {
	width: clamp(188px, 18.6vw, 304px);
	top: 42%;
	right: -16%;
	transform: rotate(-2deg);
	z-index: 3;
}
.hero-side.left .mini-fig:nth-child(4) {
	width: clamp(178px, 17.4vw, 292px);
	top: 64%;
	right: 8%;
	transform: rotate(6deg);
	z-index: 4;
}

/* PRAWA: analogicznie — dół większy i nad warstwami z góry. */
.hero-side.right .mini-fig:nth-child(1) {
	width: clamp(144px, 14vw, 232px);
	top: 6%;
	left: -11%;
	transform: rotate(4deg);
	z-index: 1;
}
.hero-side.right .mini-fig:nth-child(2) {
	width: clamp(134px, 13vw, 214px);
	top: 24%;
	left: 10%;
	transform: rotate(-5deg);
	z-index: 2;
}
.hero-side.right .mini-fig:nth-child(3) {
	width: clamp(190px, 18.8vw, 308px);
	top: 44%;
	left: -16%;
	transform: rotate(3deg);
	z-index: 3;
}
.hero-side.right .mini-fig:nth-child(4) {
	width: clamp(176px, 17.2vw, 288px);
	top: 66%;
	left: 9%;
	transform: rotate(-4deg);
	z-index: 4;
}

/* Hover bez zmian warstw i bez ruchu — tylko subtelna korekta koloru. */
.hero-side .mini-fig:hover {
	filter: brightness(.99) saturate(1.01);
}

/* Cutout — PNG bez tła. Transparent + brak overlaya + brak filtra ciemniejącego. */
.mini-fig.cutout {
	background: transparent;
	filter: none;
	overflow: visible;
}
.mini-fig.cutout::after { display: none; }
.mini-fig.cutout img { object-fit: contain; padding: 0; }
.mini-fig.cutout:hover {
	filter: drop-shadow(0 0 6px rgba(168,18,31,.16));
}

/* Środkowy slot — tytuł na górze, feature image pod nim */
.hero-center {
	position: relative;
	display: flex; flex-direction: column;
	align-items: center;
	justify-content: flex-start;
	height: 100%;
	min-height: 0;
	gap: 16px;
}
.feature {
	position: relative;
	width: clamp(268px, 29vw, 430px);
	aspect-ratio: 3/4;
	overflow: hidden;
	background: #000;
	box-shadow:
		0 40px 80px -20px rgba(0,0,0,.9),
		0 0 100px -10px rgba(168,18,31,.18);
	transition: filter .35s ease, transform .35s ease, box-shadow .35s ease;
	flex: 0 0 auto;
}
.feature img { width: 100%; height: 100%; object-fit: cover; transition: transform .35s ease; }
.feature::before {
	content: ""; position: absolute; inset: 0;
	background: linear-gradient(180deg, transparent 50%, rgba(6,5,5,.55) 100%);
	z-index: 2;
	pointer-events: none;
}
.feature::after {
	content: ""; position: absolute; inset: 0;
	border: 1px solid rgba(184,151,101,.18);
	pointer-events: none;
	z-index: 3;
}
.feature:hover {
	transform: none;
	filter: brightness(.99) saturate(1.01);
}
.feature.cutout {
	background: transparent;
	box-shadow: none;
	overflow: visible;
}
.feature.cutout img {
	object-fit: contain;
	transform: scale(1.32);
	transform-origin: center 62%;
	padding: 0;
	background: transparent;
}
.feature.cutout picture { background: transparent; }
.feature.cutout::before,
.feature.cutout::after { display: none; }
.feature.cutout:hover {
	transform: none;
	filter: none;
}

.hero-scroll {
	position: relative;
	z-index: 4;
	display: flex; flex-direction: column; align-items: center; gap: 6px;
	color: var(--ink-3);
	font-family: 'Cinzel', serif;
	font-size: 10px;
	letter-spacing: .4em;
	text-transform: uppercase;
	margin-top: 8px;
	justify-self: center;
}
.hero-scroll .line {
	width: 1px; height: 32px;
	background: linear-gradient(to bottom, transparent, var(--blood));
	animation: pulse 2.6s ease-in-out infinite;
}
@keyframes pulse {
	0%, 100% { opacity: .3; transform: scaleY(.6); }
	50% { opacity: 1; transform: scaleY(1); }
}

/* ═══════════════════ SECTION CHROME ═══════════════════ */
.section {
	padding: 140px var(--pad-x);
	position: relative;
}
.section-head {
	display: flex; flex-direction: column; align-items: center; gap: 14px;
	text-align: center;
	margin-bottom: 80px;
}
.eyebrow {
	font-family: 'Cinzel', serif;
	font-size: 11px;
	letter-spacing: .5em;
	text-transform: uppercase;
	color: var(--blood);
	display: flex; align-items: center; gap: 16px;
}
.eyebrow::before, .eyebrow::after {
	content: ""; width: 28px; height: 1px; background: var(--blood-deep);
}
.section-title {
	font-family: 'Cinzel', serif;
	font-weight: 700;
	font-size: clamp(34px, 4.5vw, 64px);
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--ink);
}
.section-sub {
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	font-size: clamp(16px, 1.2vw, 20px);
	color: var(--gold);
	max-width: 680px;
	line-height: 1.5;
}

/* ═══════════════════ GALERIA ═══════════════════ */
#galeria {
	background: linear-gradient(to bottom, var(--bg) 0%, var(--bg-1) 30%, var(--bg) 100%);
}
.gallery-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 18px;
	max-width: 1480px;
	margin: 0 auto;
}
.tile {
	position: relative;
	overflow: hidden;
	background: #000;
	cursor: pointer;
	aspect-ratio: 1 / 1;
}
.tile img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform .9s cubic-bezier(.2,.7,.3,1), filter .6s ease;
	filter: brightness(.85) saturate(.95);
}
.tile:hover img { transform: scale(1.06); filter: brightness(1) saturate(1.05); }
.tile::after {
	content: ""; position: absolute; inset: 0;
	pointer-events: none;
	box-shadow: inset 0 0 0 1px rgba(184,151,101,.06);
	background: linear-gradient(180deg, transparent 55%, rgba(6,5,5,.92) 100%);
	transition: box-shadow .4s ease;
	z-index: 2;
}
.tile:hover::after {
	box-shadow: inset 0 0 0 1px rgba(168,18,31,.5), inset 0 0 60px rgba(168,18,31,.18);
}
.tile .meta {
	position: absolute; bottom: 0; left: 0; right: 0;
	padding: 22px 24px;
	z-index: 3;
	display: flex; align-items: end; justify-content: space-between;
	gap: 16px;
}
.tile .name {
	font-family: 'Cinzel', serif;
	font-weight: 700;
	font-size: 17px;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--ink);
	text-shadow: 0 2px 12px rgba(0,0,0,.9);
}
.tile .scale {
	font-family: 'Inter', sans-serif;
	font-size: 10px;
	letter-spacing: .3em;
	text-transform: uppercase;
	color: var(--ink-3);
	border-top: 1px solid var(--blood-deep);
	padding-top: 6px;
	white-space: nowrap;
}
.tile .tag {
	position: absolute; top: 16px; left: 16px;
	z-index: 3;
	font-family: 'Cinzel', serif;
	font-size: 9px;
	letter-spacing: .35em;
	text-transform: uppercase;
	color: var(--ink);
	background: rgba(168,18,31,.85);
	padding: 5px 10px;
}
.tile:not(:has(img))::after,
.tile:not(:has(img)) .meta,
.tile:not(:has(img)) .tag { display: none; }

.gallery-foot { display: flex; justify-content: center; margin-top: 80px; }
.cta {
	font-family: 'Cinzel', serif;
	font-size: 11px;
	letter-spacing: .35em;
	text-transform: uppercase;
	padding: 18px 38px;
	border: 1px solid var(--blood);
	color: var(--ink);
	background: transparent;
	transition: all .3s ease;
	display: inline-flex; align-items: center; gap: 14px;
}
.cta:hover {
	background: var(--blood);
	box-shadow: 0 0 32px rgba(168,18,31,.4);
	letter-spacing: .42em;
}
.cta .arr { transition: transform .3s ease; }
.cta:hover .arr { transform: translateX(4px); }

/* ═══════════════════ FILTRY GALERII/SKLEPU ═══════════════════ */
.senapi-filters {
	display: flex;
	flex-wrap: wrap;
	gap: 18px 24px;
	align-items: end;
	justify-content: center;
	max-width: 1280px;
	margin: 0 auto 50px;
	padding: 18px 24px;
	border: 1px solid var(--line);
	background: var(--bg-1);
}
.senapi-filter {
	display: flex; flex-direction: column;
	gap: 6px;
	min-width: 180px;
}
.senapi-filter-label {
	font-family: 'Cinzel', serif;
	font-size: 10px;
	letter-spacing: .35em;
	text-transform: uppercase;
	color: var(--blood);
}
.senapi-filter select {
	background: var(--bg);
	border: 1px solid var(--line);
	color: var(--ink);
	padding: 10px 14px;
	font-family: 'Inter', sans-serif;
	font-size: 13px;
	min-width: 180px;
}
.senapi-filter select:focus { outline: none; border-color: var(--blood); }
.senapi-filter-clear {
	font-family: 'Cinzel', serif;
	font-size: 10px;
	letter-spacing: .3em;
	text-transform: uppercase;
	color: var(--ink-3);
	border-bottom: 1px solid var(--ink-4);
	padding-bottom: 2px;
	transition: color .25s ease, border-color .25s ease;
	align-self: end;
}
.senapi-filter-clear:hover { color: var(--ink); border-color: var(--blood); }

.senapi-pagination {
	display: flex; justify-content: center; gap: 8px;
	margin-top: 60px;
	font-family: 'Cinzel', serif;
	font-size: 11px;
	letter-spacing: .25em;
	text-transform: uppercase;
}
.senapi-pagination a,
.senapi-pagination span {
	padding: 10px 14px;
	border: 1px solid var(--line);
	color: var(--ink-2);
	transition: color .25s ease, border-color .25s ease, background-color .25s ease;
}
.senapi-pagination a:hover { color: var(--ink); border-color: var(--blood); }
.senapi-pagination .current { background: var(--blood); border-color: var(--blood); color: var(--ink); }

.senapi-empty {
	text-align: center;
	padding: 60px 20px;
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	font-size: 20px;
	color: var(--gold);
}

/* Portfolio-only mark (zamiast ceny na single i tilach) */
.senapi-portfolio-mark {
	font-family: 'Cinzel', serif;
	font-size: 11px;
	letter-spacing: .3em;
	text-transform: uppercase;
	color: var(--gold);
}

/* ═══════════════════ LIGHTBOX ═══════════════════ */
.senapi-lightbox {
	position: fixed; inset: 0;
	z-index: 1000;
	background: rgba(6, 5, 5, .96);
	display: none;
	align-items: center;
	justify-content: center;
	padding: 40px;
	backdrop-filter: blur(8px);
}
.senapi-lightbox.is-open { display: flex; }
.senapi-lightbox__close {
	position: absolute;
	top: 18px; right: 18px;
	width: 44px; height: 44px;
	background: transparent;
	border: 1px solid var(--line);
	color: var(--ink);
	font-size: 26px;
	line-height: 1;
	cursor: pointer;
	transition: border-color .25s, background .25s;
}
.senapi-lightbox__close:hover { border-color: var(--blood); background: rgba(168, 18, 31, .15); }
.senapi-lightbox__nav {
	width: 56px; height: 56px;
	background: transparent;
	border: 1px solid var(--line);
	color: var(--ink-2);
	font-size: 32px;
	line-height: 1;
	cursor: pointer;
	transition: border-color .25s, color .25s, background .25s;
	flex-shrink: 0;
}
.senapi-lightbox__nav:hover { border-color: var(--blood); color: var(--ink); background: rgba(168, 18, 31, .15); }
.senapi-lightbox__stage {
	display: flex; flex-direction: column;
	align-items: center;
	gap: 18px;
	max-width: calc(100% - 160px);
	max-height: 100%;
}
.senapi-lightbox__img {
	max-width: 100%;
	max-height: 75vh;
	object-fit: contain;
	border: 1px solid var(--line);
}
.senapi-lightbox__caption { text-align: center; max-width: 720px; }
.senapi-lightbox__name {
	font-family: 'Cinzel', serif;
	font-weight: 700;
	font-size: 22px;
	letter-spacing: .15em;
	text-transform: uppercase;
	color: var(--ink);
	margin-bottom: 6px;
}
.senapi-lightbox__meta {
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	letter-spacing: .3em;
	text-transform: uppercase;
	color: var(--ink-3);
	margin-bottom: 14px;
}
.senapi-lightbox__link {
	display: inline-block;
	font-family: 'Cinzel', serif;
	font-size: 11px;
	letter-spacing: .3em;
	text-transform: uppercase;
	color: var(--blood);
	border-bottom: 1px solid var(--blood-deep);
	padding-bottom: 4px;
	transition: color .25s, border-color .25s;
}
.senapi-lightbox__link:hover { color: var(--ink); border-color: var(--blood); }

@media (max-width: 760px) {
	.senapi-lightbox {
		padding: 12px 8px 18px;
	}
	.senapi-lightbox__close {
		top: 10px;
		right: 10px;
		width: 40px;
		height: 40px;
	}
	.senapi-lightbox__stage {
		width: 96vw;
		max-width: 96vw;
		gap: 10px;
	}
	.senapi-lightbox__img {
		max-width: 96vw;
		max-height: 78svh;
	}
	.senapi-lightbox__nav {
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
		width: 40px;
		height: 40px;
		font-size: 24px;
		z-index: 2;
	}
	.senapi-lightbox__prev { left: 8px; }
	.senapi-lightbox__next { right: 8px; }
}

/* ═══════════════════ SCROLL REVEALS ═══════════════════ */
.senapi-reveal {
	opacity: 0;
	transform: translateY(24px);
	transition: opacity .8s cubic-bezier(.2, .7, .3, 1), transform .8s cubic-bezier(.2, .7, .3, 1);
	will-change: opacity, transform;
}
.senapi-reveal.in-view {
	opacity: 1;
	transform: none;
}
@media (prefers-reduced-motion: reduce) {
	.senapi-reveal { transition: none; opacity: 1; transform: none; }
}

/* ═══════════════════ SINGLE FIGURKA ═══════════════════ */
.senapi-single-figurka {
	max-width: 1280px;
	margin: 0 auto;
	padding-top: 40px;
}
.senapi-single-grid {
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: 70px;
	align-items: start;
	margin-bottom: 80px;
}
@media (max-width: 1000px) {
	.senapi-single-grid { grid-template-columns: 1fr; gap: 40px; }
}

.senapi-single-main-image {
	position: relative;
	aspect-ratio: 3/4;
	overflow: hidden;
	background: #000;
	border: 1px solid var(--line);
}
.senapi-single-main-link { display: block; width: 100%; height: 100%; cursor: zoom-in; }
.senapi-single-main-image img {
	width: 100%; height: 100%;
	object-fit: cover;
}
.senapi-single-main-image .stamp {
	position: absolute;
	top: 50%; left: 50%;
	transform: translate(-50%, -50%) rotate(-12deg);
	font-family: 'Cinzel', serif;
	font-weight: 700;
	font-size: 22px;
	letter-spacing: .5em;
	color: var(--blood);
	border: 3px solid var(--blood);
	padding: 14px 26px;
	background: rgba(6, 5, 5, .7);
	text-transform: uppercase;
}
.senapi-single-thumbs {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 8px;
	margin-top: 12px;
}
.senapi-single-thumb {
	display: block;
	aspect-ratio: 1;
	overflow: hidden;
	background: #000;
	border: 1px solid var(--line);
	opacity: .8;
	transition: opacity .25s ease, border-color .25s ease;
}
.senapi-single-thumb:hover { opacity: 1; border-color: var(--blood); }
.senapi-single-thumb img { width: 100%; height: 100%; object-fit: cover; }

.senapi-klimat-tag {
	display: inline-block;
	font-family: 'Cinzel', serif;
	font-size: 10px;
	letter-spacing: .35em;
	text-transform: uppercase;
	color: var(--ink);
	background: var(--blood);
	padding: 6px 12px;
	margin-bottom: 18px;
}
.senapi-single-title {
	font-family: 'Cinzel', serif;
	font-weight: 700;
	font-size: clamp(28px, 3.4vw, 48px);
	letter-spacing: .12em;
	text-transform: uppercase;
	margin-bottom: 8px;
}
.senapi-single-scale {
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	letter-spacing: .3em;
	text-transform: uppercase;
	color: var(--ink-3);
	border-top: 1px solid var(--blood-deep);
	padding-top: 8px;
	display: inline-block;
	margin-bottom: 26px;
}
.senapi-single-status {
	padding: 16px 0;
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
	margin-bottom: 22px;
}
.senapi-price {
	font-family: 'Cinzel', serif;
	font-size: 28px;
	font-weight: 500;
	color: var(--ink);
}
.senapi-price .woocommerce-Price-currencySymbol { color: var(--gold); margin-left: 4px; }
.senapi-sold-mark {
	font-family: 'Cinzel', serif;
	font-size: 13px;
	letter-spacing: .25em;
	text-transform: uppercase;
	color: var(--blood);
}
.senapi-single-shortdesc {
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	font-size: 18px;
	color: var(--gold);
	line-height: 1.5;
	margin-bottom: 24px;
}
.senapi-single-cta { margin-bottom: 24px; }
.senapi-single-cta .single_add_to_cart_button,
.senapi-single-cta button[name="add-to-cart"] {
	background: var(--blood);
	color: var(--ink);
	border: none;
	padding: 16px 36px;
	font-family: 'Cinzel', serif;
	font-size: 11px;
	letter-spacing: .4em;
	text-transform: uppercase;
	cursor: pointer;
	transition: all .25s ease;
}
.senapi-single-cta .single_add_to_cart_button:hover {
	background: var(--blood-deep);
	box-shadow: 0 0 32px rgba(168, 18, 31, .4);
	letter-spacing: .5em;
}
.senapi-single-cta .quantity {
	display: inline-block;
	margin-right: 8px;
}
.senapi-single-cta .quantity input {
	background: var(--bg);
	border: 1px solid var(--line);
	color: var(--ink);
	padding: 14px 12px;
	font-family: 'Inter', sans-serif;
	width: 64px;
	text-align: center;
}
.senapi-single-meta-extra {
	display: flex; gap: 14px; align-items: baseline;
	font-family: 'Cinzel', serif;
	font-size: 11px;
	letter-spacing: .3em;
	text-transform: uppercase;
}
.senapi-single-meta-extra .label { color: var(--blood); }
.senapi-single-meta-extra span:not(.label) { color: var(--ink-2); }

.senapi-single-h2 {
	font-family: 'Cinzel', serif;
	font-size: 22px;
	letter-spacing: .15em;
	text-transform: uppercase;
	color: var(--ink);
	margin-bottom: 22px;
	padding-bottom: 14px;
	border-bottom: 1px solid var(--line);
}
.senapi-single-description {
	font-family: 'Inter', sans-serif;
	font-size: 15px;
	line-height: 1.85;
	color: var(--ink-2);
}
.senapi-single-description--desktop {
	max-width: none;
	margin: 26px 0 0;
}
.senapi-single-description--mobile {
	max-width: 760px;
	margin: 0 auto 80px;
	display: none;
}
.senapi-single-description p { margin-bottom: 16px; }

@media (max-width: 1000px) {
	.senapi-single-description--desktop { display: none; }
	.senapi-single-description--mobile { display: block; }
}

.senapi-single-related { margin-bottom: 60px; }
.senapi-single-related .gallery-grid { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 760px) {
	.senapi-single-related .gallery-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ═══════════════════ PRACOWNIA ═══════════════════ */
#pracownia {
	background: var(--bg-1);
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
}
.pracownia-grid {
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: 80px;
	align-items: center;
	max-width: 1280px;
	margin: 0 auto;
}
.pracownia-text h2 {
	font-family: 'Cinzel', serif;
	font-weight: 700;
	font-size: clamp(30px, 3.4vw, 52px);
	letter-spacing: .12em;
	text-transform: uppercase;
	margin-bottom: 12px;
}
.pracownia-text .lead {
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	font-size: 22px;
	color: var(--gold);
	margin-bottom: 32px;
}
.pracownia-text p {
	font-family: 'Inter', sans-serif;
	font-size: 16px;
	line-height: 1.85;
	color: var(--ink-2);
	margin-bottom: 22px;
	max-width: 540px;
}
.pracownia-text .creds {
	display: flex; gap: 50px; margin-top: 40px;
	padding-top: 32px; border-top: 1px solid var(--line);
	flex-wrap: wrap;
}
.cred-num {
	font-family: 'Cinzel', serif;
	font-weight: 700;
	font-size: 32px;
	color: var(--blood);
	line-height: 1;
}
.cred-label {
	font-family: 'Cinzel', serif;
	font-size: 10px;
	letter-spacing: .3em;
	text-transform: uppercase;
	color: var(--ink-3);
	margin-top: 8px;
}
.pracownia-img {
	position: relative;
	aspect-ratio: 4/5;
	overflow: hidden;
	background: #000;
}
.pracownia-img img { width: 100%; height: 100%; object-fit: cover; filter: contrast(1.05) brightness(.85); }
.pracownia-img::before {
	content: ""; position: absolute; inset: 0;
	border: 1px solid var(--blood-deep);
	transform: translate(18px, 18px);
	z-index: 0;
}
.pracownia-img:not(:has(img))::before { transform: translate(14px, 14px); }
.pracownia-img::after {
	content: ""; position: absolute; inset: 0;
	background: linear-gradient(180deg, transparent 50%, rgba(6,5,5,.5));
	pointer-events: none;
	z-index: 2;
}
.pracownia-img:not(:has(img))::after { display: none; }

.pracownia-img.cutout {
	overflow: visible;
	background: transparent;
}
.pracownia-img.cutout::before,
.pracownia-img.cutout::after {
	display: none;
}
.pracownia-img.cutout img {
	object-fit: contain;
	filter: none;
}

/* ═══════════════════ KOMISJE ═══════════════════ */
#komisje { background: var(--bg); overflow: hidden; }
#komisje::before {
	content: ""; position: absolute; inset: 0;
	background-image: radial-gradient(ellipse at top, rgba(168,18,31,.05), transparent 60%);
	pointer-events: none;
}
.komisje-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	max-width: 1280px;
	margin: 0 auto;
}
.tier {
	position: relative;
	background: linear-gradient(180deg, var(--bg-1), var(--bg));
	border: 1px solid var(--line);
	padding: 48px 36px 40px;
	display: flex; flex-direction: column; gap: 18px;
	transition: all .35s ease;
}
.tier:hover {
	border-color: var(--blood-deep);
	transform: translateY(-4px);
	box-shadow: 0 30px 60px -20px rgba(168,18,31,.2);
}
.tier.featured {
	border-color: var(--blood);
	background: linear-gradient(180deg, var(--bg-2), var(--bg-1));
}
.tier.featured::before {
	content: "Najczęściej wybierane";
	position: absolute; top: -1px; right: 24px;
	background: var(--blood);
	color: var(--ink);
	font-family: 'Cinzel', serif;
	font-size: 9px;
	letter-spacing: .3em;
	text-transform: uppercase;
	padding: 6px 12px;
}
.tier-num {
	font-family: 'Cinzel', serif;
	font-size: 11px;
	letter-spacing: .4em;
	color: var(--blood);
}
.tier h3 {
	font-family: 'Cinzel', serif;
	font-weight: 700;
	font-size: 24px;
	letter-spacing: .12em;
	text-transform: uppercase;
}
.tier .desc {
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	color: var(--gold);
	font-size: 17px;
	line-height: 1.5;
	min-height: 78px;
}
.tier .price {
	font-family: 'Cinzel', serif;
	font-size: 28px;
	font-weight: 500;
	color: var(--ink);
	padding: 18px 0;
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
	display: flex; align-items: baseline; gap: 10px;
}
.tier .price .from { font-size: 11px; letter-spacing: .3em; color: var(--ink-3); }
.tier .price .zl { font-size: 18px; color: var(--ink-2); }
.tier ul {
	list-style: none;
	display: flex; flex-direction: column; gap: 12px;
	margin: 8px 0 18px;
	font-size: 14px;
	color: var(--ink-2);
}
.tier ul li { padding-left: 22px; position: relative; }
.tier ul li::before {
	content: "✦"; position: absolute; left: 0; top: 0;
	color: var(--blood); font-size: 10px;
}
.tier-btn {
	margin-top: auto;
	text-align: center;
	padding: 14px;
	border: 1px solid var(--line);
	font-family: 'Cinzel', serif;
	font-size: 11px;
	letter-spacing: .35em;
	text-transform: uppercase;
	color: var(--ink-2);
	cursor: pointer;
	transition: all .25s ease;
}
.tier-btn:hover {
	border-color: var(--blood);
	color: var(--ink);
	background: var(--blood-deep);
}
.tier.featured .tier-btn { background: var(--blood); border-color: var(--blood); color: var(--ink); }
.tier.featured .tier-btn:hover { background: transparent; box-shadow: 0 0 24px rgba(168,18,31,.4); }

.komisje-note {
	text-align: center;
	margin-top: 50px;
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	font-size: 16px;
	color: var(--gold);
	opacity: .7;
}

/* ═══════════════════ SKLEP ═══════════════════ */
#sklep {
	background: var(--bg-1);
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
}
.shop-banner {
	max-width: 1100px;
	margin: 0 auto 50px;
	text-align: center;
	padding: 40px 20px;
	border: 1px dashed var(--blood-deep);
	position: relative;
}
.shop-banner .label {
	position: absolute; top: -10px; left: 50%; transform: translateX(-50%);
	background: var(--bg-1);
	padding: 0 16px;
	font-family: 'Cinzel', serif;
	font-size: 10px;
	letter-spacing: .5em;
	color: var(--blood);
}
.shop-banner p {
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	font-size: 20px;
	color: var(--gold);
	max-width: 720px;
	margin: 0 auto;
	line-height: 1.5;
}
.shop-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 20px;
	max-width: 1280px;
	margin: 0 auto;
}
.product {
	position: relative;
	aspect-ratio: 3/4;
	background: #000;
	overflow: hidden;
	border: 1px solid var(--line);
}
.product img {
	width: 100%; height: 100%; object-fit: cover;
	filter: grayscale(.6) brightness(.55) blur(1.5px);
	transition: all .5s ease;
}
.product:hover img { filter: grayscale(.3) brightness(.7) blur(0); }
.product .overlay {
	position: absolute; inset: 0;
	display: flex; flex-direction: column; justify-content: end;
	padding: 22px;
	z-index: 2;
	background: linear-gradient(180deg, transparent 40%, rgba(6,5,5,.92) 100%);
	pointer-events: none;
}
.product .pname {
	font-family: 'Cinzel', serif;
	font-weight: 700;
	font-size: 16px;
	letter-spacing: .12em;
	text-transform: uppercase;
	margin-bottom: 6px;
}
.product .pstatus {
	font-family: 'Cinzel', serif;
	font-size: 9px;
	letter-spacing: .4em;
	color: var(--blood);
	text-transform: uppercase;
}
.product .stamp {
	position: absolute;
	top: 50%; left: 50%; transform: translate(-50%, -50%) rotate(-12deg);
	z-index: 3;
	font-family: 'Cinzel', serif;
	font-weight: 700;
	font-size: 14px;
	letter-spacing: .4em;
	color: var(--blood);
	border: 2px solid var(--blood);
	padding: 10px 18px;
	background: rgba(6,5,5,.6);
	text-transform: uppercase;
	opacity: .85;
}
.product:not(:has(img)) .overlay,
.product:not(:has(img)) .stamp { display: none; }

.shop-foot {
	text-align: center;
	margin-top: 50px;
	font-family: 'Cinzel', serif;
	font-size: 11px;
	letter-spacing: .3em;
	color: var(--ink-3);
	text-transform: uppercase;
}
.shop-foot strong { color: var(--blood); font-weight: 500; }

/* ═══════════════════ SKLEP — TEASER ═══════════════════ */
.senapi-sklep-section { overflow: hidden; }
.senapi-sklep-section .section-head .section-title { max-width: 880px; }

.senapi-sklep-atuty {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	max-width: 1080px;
	margin: 0 auto 60px;
}
.senapi-sklep-atut {
	position: relative;
	padding: 36px 28px;
	border: 1px solid var(--line);
	background: linear-gradient(180deg, var(--bg-1), var(--bg));
	text-align: center;
	transition: border-color .35s ease, transform .35s ease, box-shadow .35s ease;
}
.senapi-sklep-atut:hover {
	border-color: var(--blood-deep);
	transform: translateY(-3px);
	box-shadow: 0 30px 60px -20px rgba(168,18,31,.18);
}
.senapi-sklep-atut__icon {
	display: inline-flex;
	align-items: center; justify-content: center;
	width: 56px; height: 56px;
	border: 1px solid var(--blood-deep);
	color: var(--blood);
	font-family: 'Cinzel', serif;
	font-size: 24px;
	margin: 0 auto 18px;
}
.senapi-sklep-atut__title {
	font-family: 'Cinzel', serif;
	font-weight: 700;
	font-size: 18px;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--ink);
	margin-bottom: 10px;
}
.senapi-sklep-atut__desc {
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	color: var(--gold);
	font-size: 16px;
	line-height: 1.5;
}

.senapi-sklep-products-head {
	display: flex; align-items: end; justify-content: space-between;
	max-width: 1280px;
	margin: 0 auto 26px;
	padding-bottom: 14px;
	border-bottom: 1px solid var(--line);
}
.senapi-sklep-products-title {
	font-family: 'Cinzel', serif;
	font-size: 18px;
	letter-spacing: .25em;
	text-transform: uppercase;
	color: var(--ink);
}
.senapi-sklep-products-link {
	font-family: 'Cinzel', serif;
	font-size: 11px;
	letter-spacing: .3em;
	text-transform: uppercase;
	color: var(--blood);
	transition: color .25s ease;
}
.senapi-sklep-products-link:hover { color: var(--ink); }

.senapi-sklep-soon {
	max-width: 720px;
	margin: 0 auto 30px;
	padding: 60px 30px;
	text-align: center;
	border: 1px dashed var(--blood-deep);
	background: radial-gradient(ellipse at center, rgba(168,18,31,.06), transparent 70%);
	position: relative;
}
.senapi-sklep-soon::before,
.senapi-sklep-soon::after {
	content: ""; position: absolute;
	width: 28px; height: 28px;
	border: 1px solid var(--gold);
	opacity: .35;
}
.senapi-sklep-soon::before { top: -14px; left: -14px; border-right: none; border-bottom: none; }
.senapi-sklep-soon::after  { bottom: -14px; right: -14px; border-left: none; border-top: none; }

.senapi-sklep-soon__sigil {
	color: var(--blood);
	margin-bottom: 22px;
	animation: senapi-sigil-pulse 6s ease-in-out infinite;
}
@keyframes senapi-sigil-pulse {
	0%, 100% { transform: rotate(0deg); opacity: .9; }
	50% { transform: rotate(180deg); opacity: 1; }
}
.senapi-sklep-soon__line {
	font-family: 'Cinzel', serif;
	font-size: 14px;
	letter-spacing: .25em;
	text-transform: uppercase;
	color: var(--ink);
	margin-bottom: 12px;
}
.senapi-sklep-soon__line--small {
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	font-size: 18px;
	letter-spacing: .02em;
	text-transform: none;
	color: var(--gold);
	max-width: 540px;
	margin: 0 auto 32px;
	line-height: 1.5;
}

.senapi-sklep-cta-row {
	display: flex; gap: 16px; flex-wrap: wrap; justify-content: center;
	margin-top: 24px;
}
.senapi-cta--ghost {
	background: transparent;
	border-color: var(--line);
	color: var(--ink-2);
}
.senapi-cta--ghost:hover {
	background: var(--bg-1) !important;
	border-color: var(--gold) !important;
	color: var(--ink) !important;
	box-shadow: 0 0 24px rgba(184,151,101,.18) !important;
}

.senapi-sklep-foot {
	text-align: center;
	margin: 40px auto 0;
	max-width: 720px;
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	font-size: 15px;
	color: var(--ink-3);
}

@media (max-width: 1000px) {
	.senapi-sklep-atuty { grid-template-columns: 1fr; gap: 16px; max-width: 520px; }
	.senapi-sklep-products-head { flex-direction: column; align-items: flex-start; gap: 8px; }
}

/* ═══════════════════ SHOWROOM (już nieużywane — zostawiam style na wszelki wypadek) ═══════════════════ */
/* ═══════════════════ SHOWROOM ═══════════════════ */
#showroom {
	background: var(--bg);
	position: relative;
	overflow: hidden;
}
#showroom::before {
	content: "";
	position: absolute; top: 0; left: 50%; transform: translateX(-50%);
	width: 1px; height: 80px;
	background: linear-gradient(to bottom, transparent, var(--blood));
}
.showroom-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 70px;
	max-width: 1280px;
	margin: 0 auto;
	align-items: center;
}
.showroom-info { display: flex; flex-direction: column; gap: 0; }
.info-row {
	display: grid;
	grid-template-columns: 160px 1fr;
	gap: 24px;
	padding: 22px 0;
	border-top: 1px solid var(--line);
	align-items: baseline;
}
.info-row:last-of-type { border-bottom: 1px solid var(--line); }
.info-row .label {
	font-family: 'Cinzel', serif;
	font-size: 10px;
	letter-spacing: .35em;
	text-transform: uppercase;
	color: var(--blood);
}
.info-row .value {
	font-family: 'Inter', sans-serif;
	font-size: 15px;
	color: var(--ink);
	line-height: 1.6;
}
.info-row .value em {
	font-family: 'Cormorant Garamond', serif;
	color: var(--gold);
	font-size: 17px;
}
.info-row .value strong { color: var(--ink); font-weight: 500; }
.showroom-info .cta { margin-top: 40px; align-self: flex-start; }

.showroom-img {
	position: relative;
	aspect-ratio: 4/5;
	overflow: hidden;
	background: #000;
}
.showroom-img img { width: 100%; height: 100%; object-fit: cover; filter: contrast(1.05) brightness(.85); }
.showroom-img::before {
	content: ""; position: absolute; inset: 0;
	border: 1px solid var(--gold);
	opacity: .25;
	transform: translate(-18px, 18px);
	z-index: 0;
}
.showroom-img::after {
	content: ""; position: absolute; inset: 0;
	background: linear-gradient(180deg, transparent 50%, rgba(6,5,5,.5));
	pointer-events: none;
	z-index: 2;
}
.showroom-img:not(:has(img))::after { display: none; }

.map-strip {
	margin-top: 60px;
	padding: 22px;
	border: 1px solid var(--line);
	background: var(--bg-1);
	display: flex; align-items: center; justify-content: space-between;
	gap: 20px;
	flex-wrap: wrap;
}
.map-strip .left {
	display: flex; align-items: center; gap: 16px;
	font-family: 'Cinzel', serif;
	font-size: 11px;
	letter-spacing: .3em;
	text-transform: uppercase;
	color: var(--ink-2);
}
.map-strip .pin {
	width: 32px; height: 32px;
	border: 1px solid var(--blood-deep);
	color: var(--blood);
	display: inline-flex; align-items: center; justify-content: center;
}
.map-strip .right {
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	font-size: 16px;
	color: var(--gold);
}

/* ═══════════════════ KONTAKT ═══════════════════ */
#kontakt {
	background: var(--bg);
	padding-bottom: 100px;
}
.contact-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 80px;
	max-width: 1200px;
	margin: 0 auto;
}
.contact-info h3 {
	font-family: 'Cinzel', serif;
	font-weight: 700;
	font-size: 28px;
	letter-spacing: .12em;
	text-transform: uppercase;
	margin-bottom: 20px;
}
.contact-info .lead {
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	font-size: 20px;
	color: var(--gold);
	line-height: 1.5;
	margin-bottom: 40px;
}
.contact-list { list-style: none; display: flex; flex-direction: column; gap: 18px; }
.contact-list li {
	display: flex; align-items: center; gap: 18px;
	padding: 14px 0;
	border-bottom: 1px solid var(--line);
}
.contact-list .ico {
	width: 32px; height: 32px;
	display: flex; align-items: center; justify-content: center;
	border: 1px solid var(--blood-deep);
	color: var(--blood);
	flex-shrink: 0;
}
.contact-list .label {
	font-family: 'Cinzel', serif;
	font-size: 10px;
	letter-spacing: .3em;
	text-transform: uppercase;
	color: var(--ink-3);
	margin-bottom: 4px;
}
.contact-list .value { font-family: 'Inter', sans-serif; font-size: 15px; color: var(--ink); }

.contact-form {
	display: flex; flex-direction: column; gap: 18px;
	padding: 40px;
	background: var(--bg-1);
	border: 1px solid var(--line);
}
.contact-form h3 {
	font-family: 'Cinzel', serif;
	font-weight: 700;
	font-size: 20px;
	letter-spacing: .15em;
	text-transform: uppercase;
	margin-bottom: 4px;
}
.contact-form .formline {
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	color: var(--gold);
	font-size: 15px;
	margin-bottom: 8px;
}
.field label {
	display: block;
	font-family: 'Cinzel', serif;
	font-size: 9px;
	letter-spacing: .35em;
	text-transform: uppercase;
	color: var(--ink-3);
	margin-bottom: 8px;
}
.field input, .field textarea, .field select {
	width: 100%;
	background: var(--bg);
	border: 1px solid var(--line);
	color: var(--ink);
	padding: 14px 16px;
	font-family: 'Inter', sans-serif;
	font-size: 14px;
	transition: border-color .25s ease;
}
.field input:focus, .field textarea:focus, .field select:focus { outline: none; border-color: var(--blood); }
.field textarea { min-height: 110px; resize: vertical; font-family: 'Inter', sans-serif; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.submit {
	background: var(--blood);
	color: var(--ink);
	border: none;
	padding: 16px;
	font-family: 'Cinzel', serif;
	font-size: 11px;
	letter-spacing: .4em;
	text-transform: uppercase;
	transition: all .25s ease;
	margin-top: 6px;
}
.submit:hover {
	background: var(--blood-deep);
	box-shadow: 0 0 32px rgba(168,18,31,.4);
	letter-spacing: .5em;
}

/* ═══════════════════ FOOTER ═══════════════════ */
footer {
	border-top: 1px solid var(--line);
	padding: 60px var(--pad-x) 36px;
	text-align: center;
	background: var(--bg);
}
.foot-logo { display: flex; align-items: center; justify-content: center; margin-bottom: 18px; }
.foot-logo img { height: 64px; width: auto; }
.foot-line {
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	color: var(--gold);
	font-size: 15px;
	margin-bottom: 26px;
}
.foot-cols {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 40px;
	max-width: 980px;
	margin: 0 auto 30px;
	padding: 30px 0;
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
	text-align: left;
}
.foot-col h4 {
	font-family: 'Cinzel', serif;
	font-size: 11px;
	letter-spacing: .35em;
	text-transform: uppercase;
	color: var(--blood);
	margin-bottom: 14px;
}
.foot-col ul { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.foot-col a, .foot-col .static {
	font-family: 'Inter', sans-serif;
	font-size: 13px;
	color: var(--ink-2);
	transition: color .25s ease;
}
.foot-col a:hover { color: var(--ink); }
.foot-meta {
	font-family: 'Cinzel', serif;
	font-size: 10px;
	letter-spacing: .3em;
	color: var(--ink-4);
	text-transform: uppercase;
	display: flex; align-items: center; justify-content: center; gap: 16px;
	flex-wrap: wrap;
}
.foot-meta .sep { color: var(--blood-deep); }

/* ═══════════════════ RESPONSIVE ═══════════════════ */
@media (max-width: 1100px) {
	.pracownia-grid { grid-template-columns: 1fr; gap: 50px; }
	.showroom-grid { grid-template-columns: 1fr; gap: 50px; }
	.komisje-grid { grid-template-columns: 1fr; max-width: 520px; }
	.shop-grid { grid-template-columns: repeat(2, 1fr); }
	.contact-grid { grid-template-columns: 1fr; gap: 50px; }
	.foot-cols { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 900px) {
	:root { --topbar-h: 70px; --pad-x: 18px; }
	.topbar { grid-template-columns: 1fr auto; gap: 12px; padding: 12px 18px; }
	nav.primary { display: none; }
	nav.primary.open {
		display: flex;
		position: absolute; top: 100%; left: 0; right: 0;
		flex-direction: column;
		gap: 0;
		background: rgba(8,6,5,.98);
		border-bottom: 1px solid var(--line);
		padding: 14px 18px 18px;
	}
	nav.primary.open a {
		width: 100%;
		padding: 12px 0;
		border-bottom: 1px solid var(--line);
		text-align: center;
	}
	nav.primary.open a:last-child { border-bottom: none; }
	.socials { gap: 2px; }
	.socials a { width: 34px; height: 34px; }
	.menu-toggle { display: inline-flex; }
	.brand img { height: 44px; }

	.hero {
		height: 100svh;
		min-height: 100svh;
		overflow: hidden;
		padding: calc(var(--topbar-h) + 18px) var(--pad-x) 20px;
	}
	.hero-marks { font-size: 8px; gap: 10px; margin-bottom: 8px; }
	.hero-title { font-size: clamp(42px, 12vw, 68px); letter-spacing: .1em; }
	.hero-titles { margin-bottom: 10px; gap: 10px; }
	.hero-tagline { font-size: 13px; max-width: 34ch; }

	/* Mobile collage: wszystkie 9 slotów w jednym widoku, blisko środka */
	.hero-row {
		position: relative;
		display: block;
		min-height: 72svh;
		padding-bottom: 28px;
	}
	.hero-center {
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -46%);
		z-index: 30;
		gap: 10px;
		width: min(88vw, 420px);
	}
	.feature { width: min(62vw, 320px); }
	.feature.cutout img { transform: scale(1.28); transform-origin: center 62%; }

	.hero-side {
		position: absolute !important;
		inset: 0;
		display: block !important;
		width: 100%;
		height: 100%;
		z-index: 20;
	}
	.hero-side .mini-fig {
		position: absolute !important;
		width: clamp(88px, 22vw, 136px) !important;
		top: auto;
		left: auto;
		right: auto;
		bottom: auto;
	}

	/* LEWA 1-4 */
	.hero-side.left .mini-fig:nth-child(1) { top: 27% !important; left: 7% !important;  width: clamp(96px, 24vw, 146px) !important; right: auto !important; transform: rotate(-9deg) !important; z-index: 21; }
	.hero-side.left .mini-fig:nth-child(2) { top: 44% !important; left: 10% !important; width: clamp(90px, 22vw, 138px) !important; right: auto !important; transform: rotate(6deg) !important;  z-index: 22; }
	.hero-side.left .mini-fig:nth-child(3) { top: 60% !important; left: 3% !important;  width: clamp(104px, 26vw, 156px) !important; right: auto !important; transform: rotate(-5deg) !important; z-index: 24; }
	.hero-side.left .mini-fig:nth-child(4) { top: 75% !important; left: 22% !important; width: clamp(102px, 25vw, 152px) !important; right: auto !important; transform: rotate(7deg) !important;  z-index: 27; }

	/* PRAWA 1-4 */
	.hero-side.right .mini-fig:nth-child(1) { top: 27% !important; right: 7% !important;  width: clamp(96px, 24vw, 146px) !important; left: auto !important; transform: rotate(8deg) !important;  z-index: 21; }
	.hero-side.right .mini-fig:nth-child(2) { top: 44% !important; right: 10% !important; width: clamp(90px, 22vw, 138px) !important; left: auto !important; transform: rotate(-7deg) !important; z-index: 22; }
	.hero-side.right .mini-fig:nth-child(3) { top: 60% !important; right: 3% !important;  width: clamp(104px, 26vw, 156px) !important; left: auto !important; transform: rotate(5deg) !important;  z-index: 24; }
	.hero-side.right .mini-fig:nth-child(4) { top: 75% !important; right: 21% !important; width: clamp(102px, 25vw, 152px) !important; left: auto !important; transform: rotate(-8deg) !important; z-index: 27; }

	.hero-scroll { margin-top: 0; }

	.section { padding: 90px var(--pad-x); }
	.section-head { margin-bottom: 50px; }
	.gallery-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
	.shop-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
	.info-row { grid-template-columns: 1fr; gap: 6px; padding: 16px 0; }
	.info-row .value em { font-size: 16px; }
	.map-strip { flex-direction: column; align-items: flex-start; gap: 14px; }
	.contact-form { padding: 24px; }
	.field-row { grid-template-columns: 1fr; }
	.foot-cols { grid-template-columns: 1fr; gap: 24px; text-align: center; }
	.foot-meta { gap: 10px; font-size: 9px; }
	.tile .name { font-size: 13px; letter-spacing: .1em; }
	.tile .scale { font-size: 8px; letter-spacing: .2em; }
	.tile .meta { padding: 14px 14px; }
	.hero-title { letter-spacing: .12em; }
}
@media (max-width: 420px) {
	.gallery-grid { grid-template-columns: 1fr; }
	.shop-grid { grid-template-columns: 1fr; }
}
