/*
Theme Name: Elysioom
Theme URI: https://elysioom.sopee.net
Description: Custom bilingual theme aligned with Elysioom brandbook (14.09) and Canva (PDF + „Witryna internetowa” HTML).
Author: Sopee
Version: 2.1.6
Text Domain: elysioom
Requires at least: 6.0
Tested up to: 6.9
Requires PHP: 8.0
*/

@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500&family=Roboto+Mono:wght@400&family=Space+Grotesk:wght@300;400;700&display=swap');

:root {
  /* Szerokość slajdu Canva / PDF: 1024,5 pt × (96/72) = 1366 px — jeden układ odniesienia */
  --design-slide-ratio: calc(1024.5 / 576);
  --site-width: 1366px;
  --site-pad-inline: 48px;
  /* Brandbook Elysioom 14.09 — kolory podstawowe (+ RGB z dokumentu) */
  --brand-red: #B84B55;
  --brand-green: #448C7B;
  --brand-graphite: #22282C;
  --brand-gray: #4F5355;
  --brand-light: #DDDDDD;
  --brand-brown: #949081;
  --brand-blue: #608293;

  /* Tints (derived / neutral) */
  --tint-white: #FFFFFF;
  --tint-black: #000000;
  --tint-white-rgb: 255, 255, 255;

  /* Króje: Space Grotesk (nagłówki), Roboto (tekst), Roboto Mono (detal + CTA obrys — Canva) */
  --font-heading: 'Space Grotesk', sans-serif;
  --font-body: 'Roboto', sans-serif;
  --font-detail: 'Roboto Mono', monospace;
  /* Przyciski obrys: Canva — Roboto Mono ~17,33 px, tracking 65 (‰→em), leading 0,94 */
  --font-outline-cta: var(--font-detail);
  --outline-button-font-size: 17.333px;
  --outline-button-track: 0.065em;
  --outline-button-lh: 0.94;
  /* Górne menu: Canva Space Grotesk ~14,67 px, tracking 60, leading 1,15 */
  --nav-top-font-size: 14.67px;
  --nav-top-track: 0.06em;
  --nav-top-lh: 1.15;
  --nav-link-color: rgba(255, 255, 255, 0.72);
  --nav-link-color-hover: var(--tint-white);
  --nav-link-accent: var(--brand-red);
  --nav-link-underline: 2px;
  --nav-link-transition: 0.24s ease;
  --nav-active-weight: 500;
  --lang-toggle-font-size: calc(var(--nav-top-font-size) * 0.5);
  --lang-toggle-track: 0.14em;

  /*
   * Typografia z brandbooka (pt → px przy 96dpi, ok. ×1,333).
   * H1: 47/61/90 | H2: 33/39 | H3 (Roboto): 38/50/90 | Akapit: 18/33/40 | Detail: 15/23/140
   */
  --bb-weight-heading: 400;
  --bb-h1-size: 47px;
  --bb-h1-lh: 1.298;
  --bb-h1-track: 0.09em;
  --bb-h2-size: 33px;
  --bb-h2-lh: 1.182;
  --bb-h2-track: 0;
  --bb-h3-size: 38px;
  --bb-h3-lh: 1.316;
  --bb-h3-track: 0.09em;
  --bb-body-size: 18px;
  --bb-body-lh: 1.833;
  --bb-body-track: 0.04em;
  --bb-detail-size: 15px;
  --bb-detail-lh: 1.533;
  --bb-detail-track: 0.14em;
  /* Linki tekstowe poza kafelkami (bannery, panele) */
  --text-cta-track: 0.22em;
  --text-cta-size: var(--bb-detail-size);
  --text-cta-lh: var(--bb-detail-lh);
  /* Linki ze strzałką w kafelkach / splitach — brandbook: Roboto, tracking 217, interlinia 0,94 (rozmiar: --tile-cta-size, domyślnie 16px) */
  --tile-cta-font: var(--font-body);
  --tile-cta-size: 16px;
  --tile-cta-track: 0.217em;
  --tile-cta-lh: 0.94;
  --tile-cta-gap: 0.5em;
  --tile-cta-arrow-ratio: 0.68;

  /* Tytuł hero podstron „slajd 1” (Canva: O nas, Wiedza — Space Grotesk 40, tracking 115, interlinia 2) */
  --inner-hero-title-size: 40px;
  --inner-hero-title-track: 0.115em;
  --inner-hero-title-lh: 2;

  /* Tytuł hero (Canva „Witryna internetowa” Home + slajdy wewnętrzne): Space Grotesk 40 px, tracking 115, interlinia 2 */
  --hero-title-size: var(--inner-hero-title-size);
  /* Home hero — mniejszy tytuł (uwagi klienta 05/2026) */
  --home-hero-title-size: clamp(28px, 2.8vw, 34px);
  --hero-title-track: 0.115em; /* Canva „115” */
  --hero-title-lh: 2;          /* Canva „2000”‰ → 2 */
  /* Większy margines bloku hero (tekst + CTA) od lewej/prawej i od dołu — ponad standard .site-limit */
  --hero-content-pad-inline: clamp(28px, 2.2vw + 20px, 62px);
  --hero-content-pad-bottom: 122px;
  /* Przesunięcie kadru tła hero w górę (wartość ujemna = w górę o 20px) */
  --hero-bg-y-nudge: -20px;

  /* Tytuły 3 kart na Home — Canva Witryna: Space Grotesk ~26,67 px, tracking 115, interlinia 2 */
  --feature-card-title-size: 26.667px;
  --feature-card-title-track: 0.115em;
  --feature-card-title-lh: 2;

  /* Treść w splitach / kafelkach — Canva (eksport www): Roboto ~13,33 px, tracking 91, interlinia 2 */
  --split-tile-body-size: 13.333px;
  --split-tile-body-track: 0.091em;
  --split-tile-body-lh: 2;
  --split-tile-body-color: #22282c;
  --split-tile-body-gap: 1em;
  --split-tile-cta-pad-top: clamp(42px, 3.85vw, 58px);
  --split-tile-cta-max-width: 252px;

  /* Nagłówek h2 w kafelkach / splitach (Canva: Space Grotesk 22 pt → 29,333 px, tracking 170, interlinia 1.4) */
  --split-light-title-font: 'Space Grotesk', sans-serif;
  --split-light-title-size: 29.333px;
  --split-light-title-color: var(--brand-graphite);
  --split-light-title-track: 0.17em;
  --split-light-title-lh: 1.4;
  --split-light-title-weight: 400;

  /* Nagłówek dark showroom / kolumna ciemna (Canva: Space Grotesk 22 pt → 29,333 px, #ECECEC, tracking 170) */
  --dark-showroom-title-font: 'Space Grotesk', sans-serif;
  --dark-showroom-title-size: 29.333px;
  --dark-showroom-title-color: #ececec;
  --dark-showroom-title-track: 0.17em;
  --dark-showroom-title-lh: 1.4;
  --dark-showroom-title-weight: 400;

  /* Akapit dark showroom / kolumna ciemna (Canva: Roboto ~13,33 px, #ECECEC, tracking 91, interlinia 2) */
  --dark-showroom-body-font: 'Roboto', sans-serif;
  --dark-showroom-body-size: 13.333px;
  --dark-showroom-body-color: #ececec;
  --dark-showroom-body-track: 0.091em;
  --dark-showroom-body-lh: 2;

  /* Split jasny — tło kolumny tekstu (Canva / PDF Home) */
  --split-light-bg: #ececec;
  /* „Wybrane Realizacje” — Canva Home Witryna: Space Grotesk 40 px, tracking 142, #ececec */
  --realizacje-banner-title-size: clamp(28px, 3vw, 40px);
  --realizacje-banner-title-track: 0.142em;
  --realizacje-banner-title-lh: 1.4;
  --realizacje-banner-title-weight: 300;
  /* Ramka siatki realizacji (ciemny gutter jak w PDF) */
  --realizacje-gallery-frame-bg: #1c1e21;
  /* „Audio szyte na miarę” — kolumna ciemna (PDF) */
  --split-dark-feature-title-size: 29.333px;
  --split-dark-feature-title-track: 0.17em;
  --split-dark-feature-title-lh: 1.4;
  --split-dark-feature-title-weight: 400;

  /* Theme tokens */
  --bg-dark: var(--brand-graphite);
  --bg-soft: var(--brand-light);
  /* Intro home = tło jasnego splitu (PDF #ECECEC) */
  --bg-home-intro: var(--split-light-bg);
  /* Akcent podziału kolumn — niebieski marki (zamiast obcej purpury) */
  --home-split-divider: rgba(96, 130, 147, 0.5);
  --text-main: var(--brand-graphite);
  --text-muted: var(--brand-gray);
  --line-light: rgba(255, 255, 255, 0.65);
  --line-dark: rgba(37, 44, 51, 0.3);
  --radius-pill: 999px;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { overflow-x: clip; }
body {
  font-family: var(--font-body);
  background: var(--tint-white);
  color: var(--text-main);
  font-size: var(--bb-body-size);
  line-height: var(--bb-body-lh);
  letter-spacing: var(--bb-body-track);
  font-weight: 400;
  overflow-x: clip;
}
a { color: inherit; text-decoration: none; }
.site-shell { min-height: 100vh; overflow-x: clip; }
.site-main { display: block; }
.site-limit { width: min(100%, var(--site-width)); margin: 0 auto; padding: 0 var(--site-pad-inline); }

h1, h2, h4, h5, h6 { font-family: var(--font-heading); font-weight: var(--bb-weight-heading); }
/* Headline 3 w brandbooku: Roboto */
h3 { font-family: var(--font-body); font-weight: 400; }

.site-header { position: fixed; top: 0; left: 0; right: 0; z-index: 40; border-bottom: 0; overflow: visible; transition: background 0.35s ease, box-shadow 0.35s ease; }
.site-header::before { content: ""; position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(12,12,12,.52), rgba(12,12,12,.1)); backdrop-filter: blur(2px); transition: opacity 0.35s ease; }
.site-header.is-scrolled { background: var(--brand-graphite); box-shadow: 0 2px 18px rgba(0,0,0,.28); }
.site-header.is-scrolled::before { opacity: 0; }
/* Biała linia pod paskiem — na całą szerokość viewportu (bez insetu od paddingu wewnętrznego) */
.site-header::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  background: rgba(255, 255, 255, 0.68);
  pointer-events: none;
  z-index: 2;
}
.site-header__inner {
  min-height: 86px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  position: relative;
  overflow: visible;
  width: 100%;
  max-width: none;
  margin: 0;
  padding-left: var(--site-pad-inline);
  padding-right: var(--site-pad-inline);
}
.site-brand { display: inline-flex; align-items: center; flex: 0 0 auto; }
.site-logo { width: 246px; max-width: 100%; height: auto; display: block; }
.site-header__nav { display: flex; align-items: center; gap: 16px; flex: 0 0 auto; justify-content: flex-start; padding-top: 6px; }
.site-nav ul { list-style: none; display: flex; align-items: center; gap: 24px; margin: 0; padding: 0; }
.site-nav .menu { position: relative; }
.site-nav a {
  font-family: 'Space Grotesk', sans-serif;
  font-size: var(--nav-top-font-size);
  font-weight: 400;
  font-synthesis: none;
  letter-spacing: var(--nav-top-track);
  line-height: var(--nav-top-lh);
  text-transform: uppercase;
  text-decoration: none;
  transition:
    color var(--nav-link-transition),
    opacity var(--nav-link-transition);
}
/* Górne menu — hover i aktywna strona */
.site-nav .menu > li:not(.menu-item-language) > a {
  position: relative;
  display: inline-block;
  color: var(--nav-link-color);
  border-bottom: none;
  transition:
    color var(--nav-link-transition),
    opacity var(--nav-link-transition);
}
.site-nav .menu > li:not(.menu-item-language) > a:hover,
.site-nav .menu > li:not(.menu-item-language) > a:focus-visible {
  color: var(--nav-link-color-hover);
  outline: none;
}
.site-nav .menu > .current-menu-item > a,
.site-nav .menu > .current-menu-ancestor > a,
.site-nav .menu > li.menu-item-has-children.current-menu-item > a,
.site-nav .menu > li.menu-item-has-children.current-menu-ancestor > a,
.site-nav .menu > li:not(.menu-item-language) > a[aria-current="page"] {
  color: var(--nav-link-color-hover);
  font-weight: var(--nav-active-weight);
  letter-spacing: var(--nav-top-track);
}
.site-nav li { position: relative; }
.site-nav .menu > .menu-item-language {
  margin-left: 6px;
  align-self: center;
  transform: translateY(-2px);
}
.site-nav .menu > .menu-item-language .lang-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0;
  padding: 4px 7px;
  border: 1px solid rgba(255, 255, 255, .24);
  border-radius: 999px;
  background: rgba(255, 255, 255, .05);
  font-family: var(--font-detail);
  font-size: var(--lang-toggle-font-size);
  font-weight: 400;
  letter-spacing: var(--lang-toggle-track);
  line-height: 1;
  text-transform: uppercase;
  white-space: nowrap;
}
.site-nav .menu > .menu-item-language .lang-toggle__item {
  display: inline-block;
  padding: 2px 4px;
  color: var(--tint-white);
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  letter-spacing: inherit;
  line-height: inherit;
  text-transform: inherit;
  opacity: .42;
  transition: opacity .2s ease, color .2s ease;
}
.site-nav .menu > .menu-item-language a.lang-toggle__item:hover,
.site-nav .menu > .menu-item-language a.lang-toggle__item:focus-visible {
  opacity: .88;
  text-decoration: none;
}
.site-nav .menu > .menu-item-language .lang-toggle__item.is-active {
  opacity: 1;
  font-weight: 500;
}
.site-nav .menu > .menu-item-language .lang-toggle__sep {
  display: inline-block;
  padding: 0 1px;
  color: rgba(255, 255, 255, .34);
  font-family: inherit;
  font-size: inherit;
  line-height: 1;
  user-select: none;
}
.site-nav .menu > li { padding-bottom: 0; margin-bottom: 0; }
.site-nav .menu > .menu-item-has-children > a { padding-right: 0; }
/* Otwarty dropdown — podkreślenie rodzica zostaje widoczne */
.site-nav .menu > li.menu-item-has-children:hover > a,
.site-nav .menu > li.menu-item-has-children:focus-within > a {
  color: var(--nav-link-color-hover);
}

/* Desktop: czerwony akcent na białej linii pod paskiem (nie pod tekstem linku) */
@media (min-width: 1025px) {
  .site-header__inner {
    align-items: stretch;
  }

  .site-brand,
  .menu-toggle {
    align-self: center;
  }

  .site-header__nav {
    align-self: stretch;
    padding-top: 0;
    align-items: center;
  }

  .site-nav .menu {
    height: 100%;
    align-items: center;
  }

  .site-nav .menu > li:not(.menu-item-language) {
    display: flex;
    align-items: center;
    align-self: stretch;
  }

  .site-nav .menu > li:not(.menu-item-language)::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 2px;
    background: var(--nav-link-accent);
    opacity: 0;
    transform: scaleX(0.35);
    transform-origin: center bottom;
    transition:
      opacity var(--nav-link-transition),
      transform var(--nav-link-transition);
    z-index: 3;
    pointer-events: none;
  }

  .site-nav .menu > li:not(.menu-item-language):hover::after,
  .site-nav .menu > li:not(.menu-item-language):focus-within::after,
  .site-nav .menu > .current-menu-item:not(.menu-item-language)::after,
  .site-nav .menu > .current-menu-ancestor:not(.menu-item-language)::after,
  .site-nav .menu > li:not(.menu-item-language):has(> a[aria-current="page"])::after {
    opacity: 1;
    transform: scaleX(1);
  }
}
.site-nav .sub-menu {
  position: absolute;
  top: 100%;
  left: 0;
  transform: none;
  width: max-content;
  min-width: 0;
  max-width: min(520px, calc(100vw - 56px));
  display: none;
  flex-direction: column;
  flex-wrap: nowrap;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 8px;
  padding: 12px 14px;
  border: 1px solid rgba(196, 170, 142, .24);
  border-radius: 8px;
  background: rgba(74, 59, 47, .74);
  backdrop-filter: blur(5px);
  z-index: 60;
}
.site-nav .sub-menu li { width: auto; display: inline-flex; align-items: center; gap: 8px; }
.site-nav .sub-menu li::before {
  content: "·";
  color: rgba(255,255,255,.8);
  font-size: 14px;
  line-height: 1;
}
.site-nav .sub-menu li::after { display: none; }
.site-nav .sub-menu a {
  position: relative;
  display: inline-flex;
  width: auto;
  padding: 0 0 2px;
  color: rgba(255, 255, 255, 0.82);
  font-size: var(--nav-top-font-size);
  letter-spacing: var(--nav-top-track);
  line-height: var(--nav-top-lh);
  text-align: left;
  border: 0;
  border-radius: 0;
  white-space: nowrap;
}
.site-nav .sub-menu a::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  background: var(--nav-link-accent);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform var(--nav-link-transition);
  opacity: 0.75;
}
.site-nav .sub-menu a:hover,
.site-nav .sub-menu a:focus-visible {
  color: var(--nav-link-color-hover);
  opacity: 1;
  outline: none;
}
.site-nav .sub-menu a:hover::after,
.site-nav .sub-menu a:focus-visible::after {
  transform: scaleX(1);
}
.site-nav .sub-menu .current-menu-item > a,
.site-nav .sub-menu a[aria-current="page"] {
  color: var(--nav-link-color-hover);
  font-weight: var(--nav-active-weight);
  letter-spacing: var(--nav-top-track);
}
.site-nav .sub-menu .current-menu-item > a::after,
.site-nav .sub-menu a[aria-current="page"]::after {
  transform: scaleX(1);
  opacity: 1;
}
.site-nav .menu > li.menu-item-has-children:hover > .sub-menu,
.site-nav .menu > li.menu-item-has-children:focus-within > .sub-menu {
  display: none;
}
.menu-toggle {
  display: none;
  width: 42px;
  height: 42px;
  border: 1px solid rgba(255,255,255,.55);
  background: rgba(20,24,30,.45);
  border-radius: 10px;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 5px;
  padding: 0;
}
.menu-toggle span {
  width: 18px;
  height: 1.5px;
  background: var(--tint-white);
  display: block;
}

.hero { min-height: 100vh; position: relative; background-color: var(--brand-graphite); background-image: var(--hero-image); background-size: cover; background-position: var(--hero-bg-position, center calc(50% + var(--hero-bg-y-nudge))); background-repeat: no-repeat; display: flex; align-items: flex-end; }
.hero-overlay { position: absolute; inset: 0; z-index: 1; background: transparent; pointer-events: none; }
/* Home hero (PDF): delikatny gradient od dołu dla czytelności białego tekstu */
.page-key-home .hero-home .hero-overlay {
  background: linear-gradient(to top, rgba(0, 0, 0, 0.52) 0%, rgba(0, 0, 0, 0.2) 36%, transparent 68%);
}
.hero-content.site-limit {
  position: relative;
  z-index: 2;
  color: var(--tint-white);
  width: 100%;
  box-sizing: border-box;
  padding: 0 var(--hero-content-pad-inline) var(--hero-content-pad-bottom);
}
.hero h1 { margin: 0; font-family: 'Space Grotesk', sans-serif; font-weight: 300; letter-spacing: var(--hero-title-track); line-height: var(--hero-title-lh); font-size: var(--hero-title-size); max-width: 980px; text-transform: none; color: #fff; }
.hero-subline { margin-top: 18px; max-width: 980px; color: rgba(255,255,255,.95); font-family: var(--font-detail); font-size: var(--bb-detail-size); line-height: var(--bb-detail-lh); letter-spacing: var(--bb-detail-track); text-transform: uppercase; }

.hero-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
  gap: 30px;
}

.hero-row__left {
  position: relative;
  border-bottom: none;
  padding-bottom: 20px;
}

/* Linia pod tytułem hero: 70% szer., od lewej krawędzi ekranu (tekst bez zmian) */
body:not(.page-key-home) .hero-row__left::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: calc(-1 * var(--hero-content-pad-inline) - max(0px, (100vw - var(--site-width)) / 2));
  width: 70%;
  height: 1px;
  background: rgba(255, 255, 255, 0.7);
}

.page-key-cinema-halls .hero-row__left::after {
  left: calc(-1 * var(--hero-content-pad-inline) - max(0px, (100vw - var(--site-width)) / 2) - 6px);
}

.layout-knowledge-canva .knowledge-canva-hero .hero-row__left::after {
  left: calc(-1 * (var(--kc-ref) * 64.83 / var(--kc-pdf-w)) - max(0px, (100vw - min(var(--site-width), var(--kc-ref))) / 2));
}

.hero-row__right {
  padding-bottom: 8px;
}

.outline-button { margin-top: 28px; display: inline-flex; align-items: center; justify-content: center; gap: 12px; border: 1px solid rgba(var(--tint-white-rgb), .85); border-radius: var(--radius-pill); color: var(--tint-white); padding: 14px 40px; text-transform: uppercase; letter-spacing: var(--outline-button-track); font-family: var(--font-outline-cta); font-size: var(--outline-button-font-size); line-height: var(--outline-button-lh); font-weight: 400; transition: background .25s ease, transform .25s ease; }
.outline-button:hover { background: rgba(255,255,255,.12); transform: translateY(-2px); }
.outline-button.is-small { padding: 12px 24px; width: 100%; }
.button-arrow { font-size: 1.42em; line-height: 1; }

.dark-showroom { background: var(--bg-dark); }
.dark-showroom__header { padding-top: 74px; padding-bottom: 56px; }
.dark-showroom__header h2 {
  margin: 0;
  font-family: var(--dark-showroom-title-font);
  font-size: var(--dark-showroom-title-size);
  font-weight: var(--dark-showroom-title-weight);
  line-height: var(--dark-showroom-title-lh);
  letter-spacing: var(--dark-showroom-title-track);
  color: var(--dark-showroom-title-color);
}
.dark-showroom__header h2::after {
  content: "";
  display: block;
  width: 52px;
  height: 1px;
  background: color-mix(in srgb, var(--dark-showroom-title-color) 42%, transparent);
  margin-top: 28px;
}
.dark-showroom__header p {
  margin: 28px 0 0;
  max-width: 820px;
  font-family: var(--dark-showroom-body-font);
  font-size: var(--dark-showroom-body-size);
  line-height: var(--dark-showroom-body-lh);
  letter-spacing: var(--dark-showroom-body-track);
  color: var(--dark-showroom-body-color);
}
.dark-showroom__photos {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0;
  width: 100%;
  line-height: 0;
  font-size: 0;
}
.dark-showroom__photo {
  position: relative;
  overflow: hidden;
  margin: 0;
  padding: 0;
  min-height: 0;
  aspect-ratio: 16 / 10;
}
.dark-showroom__photo img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
  margin: 0;
  padding: 0;
  border: 0;
}
.dark-grid { background: var(--bg-dark); padding: 74px 0; }
.cards-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 26px; }
.feature-card { min-height: 620px; border: 1px solid rgba(255,255,255,.28); position: relative; overflow: hidden; display: flex; align-items: flex-end; background: var(--brand-graphite); }
.feature-card__media {
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image: var(--card-image);
  background-size: var(--card-media-bg-size, cover);
  background-position: var(--card-media-bg-pos, center);
  transform: scale(1);
  filter: grayscale(1) saturate(.8);
  -webkit-filter: grayscale(1) saturate(.8);
  transition: transform .45s ease, filter .45s ease, -webkit-filter .45s ease;
}
.feature-card:hover .feature-card__media,
.feature-card:focus-within .feature-card__media {
  transform: scale(1.04);
  filter: grayscale(0) saturate(1);
  -webkit-filter: grayscale(0) saturate(1);
}
/* Para zdjęć BW + kolor (dom: fotki 2/3, 4/5, 6/7) */
.feature-card--bw-color .feature-card__media {
  filter: none;
  -webkit-filter: none;
}
.feature-card--bw-color .feature-card__media::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image: var(--card-image-hover);
  background-size: var(--card-media-bg-size, cover);
  background-position: var(--card-media-bg-pos, 50% 48%);
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 0.55s cubic-bezier(0.25, 0.46, 0.45, 0.94), transform 0.55s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  pointer-events: none;
}
.feature-card--bw-color:hover .feature-card__media::after,
.feature-card--bw-color:focus-within .feature-card__media::after {
  opacity: 1;
}
.feature-card--bw-color:hover .feature-card__media,
.feature-card--bw-color:focus-within .feature-card__media {
  filter: none;
  -webkit-filter: none;
  transform: scale(1.06);
}
.feature-card__overlay { position: absolute; inset: 0; z-index: 1; background: linear-gradient(to top, rgba(0,0,0,.72), rgba(0,0,0,.18) 55%); }
.feature-card__body { position: relative; z-index: 2; color: var(--tint-white); width: 100%; padding: 28px; }
.feature-card h3 { margin: 0 0 14px; font-family: 'Space Grotesk', sans-serif; font-size: var(--feature-card-title-size); line-height: var(--feature-card-title-lh); font-weight: var(--bb-weight-heading); letter-spacing: var(--feature-card-title-track); }
.feature-card p { margin: 0 0 20px; color: rgba(255,255,255,.9); font-family: var(--font-body); letter-spacing: var(--bb-body-track); font-size: var(--bb-detail-size); line-height: var(--bb-detail-lh); }

.split { padding: 0; }
.split__inner { display: grid; grid-template-columns: 1fr 1fr; min-height: min(48vw, 900px); }
.split__inner--reverse .split__copy { order: 2; }
.split__inner--reverse .split__media { order: 1; }
.split__copy { background: var(--bg-soft); padding: clamp(40px, 4.5vw, 48px) clamp(40px, 4vw, 48px); display: flex; flex-direction: column; justify-content: flex-start; align-items: stretch; }
.split__copy--wide { grid-column: 1 / -1; }
.split__copy h2 { margin: 0 0 28px; font-size: var(--bb-h1-size); font-weight: var(--bb-weight-heading); line-height: var(--bb-h1-lh); letter-spacing: var(--bb-h1-track); }
.split__copy p { margin: 0; color: var(--text-muted); font-family: var(--font-body); font-size: var(--bb-body-size); line-height: var(--bb-body-lh); letter-spacing: var(--bb-body-track); }
/* Kontakt: tekst w mozaice = Canva 13,33 px (nie brandbook 18 px) */
.page-key-contact .contact-mosaic .split__copy p,
.page-key-contact .contact-detail__intro,
.page-key-contact .contact-detail__label,
.page-key-contact .contact-detail__block p {
  font-family: 'Roboto', sans-serif;
  font-size: var(--contact-body-size, 13.333px);
  letter-spacing: var(--contact-body-track, 0.091em);
  color: var(--split-tile-body-color);
  font-weight: 400;
}
.page-key-contact .contact-mosaic .split__copy p,
.page-key-contact .contact-detail__intro {
  line-height: var(--contact-body-lh, 2);
}
.page-key-contact .contact-detail__block p {
  line-height: 1.5;
}
.page-key-contact .split-dark.split__copy p,
.page-key-contact .split-dark .split__copy p {
  color: #ffffff;
}
.copy-list { margin: 30px 0 0; padding: 0; list-style: none; }
.copy-list li { position: relative; padding-left: 20px; margin-top: 12px; font-family: var(--font-body); letter-spacing: var(--bb-body-track); color: var(--text-main); font-size: var(--bb-body-size); line-height: var(--bb-body-lh); }
.copy-list li::before { content: "-"; position: absolute; left: 0; }
.split__media { min-height: 400px; overflow: hidden; }
.split__media img,
.split__media video.split__video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: var(--split-media-obj-pos, center center);
  display: block;
  transform: scale(var(--split-media-zoom, 1));
  transform-origin: var(--split-media-origin, center center);
}
.split-dark .split__copy { background: var(--bg-dark); }
.split-dark .split__copy h2 {
  margin: 0 0 28px;
  color: var(--dark-showroom-title-color);
  font-family: var(--dark-showroom-title-font);
  font-size: var(--dark-showroom-title-size);
  font-weight: var(--dark-showroom-title-weight);
  line-height: var(--dark-showroom-title-lh);
  letter-spacing: var(--dark-showroom-title-track);
  text-align: left;
  text-wrap: balance;
}
.split-dark .split__copy p, .split-dark .copy-list li { color: rgba(255,255,255,.78); }
.split.split-light .split__copy h2 {
  margin: 0 0 28px;
  color: var(--split-light-title-color);
  font-family: var(--split-light-title-font);
  font-size: var(--split-light-title-size);
  font-weight: var(--split-light-title-weight);
  letter-spacing: var(--split-light-title-track);
  line-height: var(--split-light-title-lh);
  text-align: left;
}
.split-light .split__copy h2::after { content: ""; display: block; width: 52px; height: 2px; background: var(--split-light-title-color); margin-top: 24px; opacity: .7; }
/* Jasny split jak w Canvie: treść od góry bloku, wyrównanie do lewej */
.split.split-light .split__copy {
  justify-content: flex-start;
  align-items: stretch;
  text-align: left;
  background: var(--split-light-bg);
}
.split.split-light .split__copy p {
  margin: 0;
  color: var(--split-tile-body-color);
  font-family: 'Roboto', sans-serif;
  font-size: var(--split-tile-body-size);
  font-weight: 400;
  line-height: var(--split-tile-body-lh);
  letter-spacing: var(--split-tile-body-track);
  text-align: left;
}
.split.split-light .split__copy p + p { margin-top: var(--split-tile-body-gap); }
.split.split-light .split__copy .copy-list { margin: var(--split-tile-body-gap) 0 0; padding: 0; list-style: none; }
.split.split-light .split__copy .copy-list li + li { margin-top: var(--split-tile-body-gap); }
.split-dark .split__copy p {
  margin: 0;
  font-family: var(--dark-showroom-body-font);
  font-size: var(--dark-showroom-body-size);
  line-height: var(--dark-showroom-body-lh);
  letter-spacing: var(--dark-showroom-body-track);
  color: var(--dark-showroom-body-color);
  text-align: left;
}
.split-dark .split__copy p + p { margin-top: var(--split-tile-body-gap); }
.split-dark .split__copy .copy-list { margin: var(--split-tile-body-gap) 0 0; padding: 0; list-style: none; }
.split-dark .split__copy .copy-list li {
  font-family: var(--dark-showroom-body-font);
  font-size: var(--dark-showroom-body-size);
  line-height: var(--dark-showroom-body-lh);
  letter-spacing: var(--dark-showroom-body-track);
  color: var(--dark-showroom-body-color);
}
.split-dark .split__copy .copy-list li + li { margin-top: var(--split-tile-body-gap); }
.split.split-light .split__copy--wide.entry-content,
.split.split-light .split__copy--wide.entry-content p,
.split.split-light .split__copy--wide.entry-content li {
  color: var(--split-tile-body-color);
  font-family: 'Roboto', sans-serif;
  font-size: var(--split-tile-body-size);
  font-weight: 400;
  line-height: var(--split-tile-body-lh);
  letter-spacing: var(--split-tile-body-track);
  text-align: left;
}
.split.split-light .split__copy .copy-list li {
  color: var(--split-tile-body-color);
  font-family: 'Roboto', sans-serif;
  font-size: var(--split-tile-body-size);
  font-weight: 400;
  line-height: var(--split-tile-body-lh);
  letter-spacing: var(--split-tile-body-track);
  text-align: left;
}
/* Linki CTA w splitach / szablonach — zawsze po prawej, szerokie przerwy między literami */
.inline-cta,
.checker-story-block__cta,
.editorial-panel__cta,
.realizacje-gallery__footer-cta,
.split-extra-block .inline-cta--extra {
  margin-top: auto;
  padding-top: var(--split-tile-cta-pad-top, clamp(32px, 3.5vw, 42px));
  margin-left: auto;
  margin-right: 0;
  align-self: flex-end;
  width: auto;
  max-width: 100%;
  text-align: right;
}
.inline-cta a,
.checker-story-block__cta a,
.editorial-panel__cta a,
.realizacje-gallery__footer-cta-link,
.split-extra-block .inline-cta--extra a {
  display: inline-flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: flex-end;
  column-gap: var(--tile-cta-gap);
  row-gap: 0;
  width: fit-content;
  max-width: 100%;
  font-family: var(--tile-cta-font);
  font-size: var(--tile-cta-size);
  line-height: var(--tile-cta-lh);
  letter-spacing: var(--tile-cta-track);
  text-transform: none;
  font-weight: 400;
  color: var(--text-main);
  text-decoration: none;
}
.checker-story-block__cta span[aria-hidden="true"],
.editorial-panel__cta span[aria-hidden="true"],
.realizacje-gallery__footer-cta-link span[aria-hidden="true"] {
  flex: 0 0 auto;
  flex-shrink: 0;
  margin: 0;
  position: static;
  top: auto;
}
.split-dark .inline-cta a,
.checker-story-block__copy--dark .checker-story-block__cta a,
.split-extra-block .inline-cta--extra a {
  color: rgba(255, 255, 255, 0.92);
}

/* === Linki ze strzałką w kafelkach (globalnie: Roboto Mono 10px / 217 / 0,94 / gap 4) === */
.split__copy .inline-cta a,
.split__copy .split-extra-block .inline-cta--extra a,
.split__copy .inline-cta a.split-tile-cta-link,
.split__copy .inline-cta a.soundwall-cta-link {
  display: inline-flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: flex-end;
  gap: var(--tile-cta-gap);
  width: fit-content;
  max-width: 100%;
  font-family: var(--tile-cta-font);
  font-size: var(--tile-cta-size);
  line-height: var(--tile-cta-lh);
  letter-spacing: var(--tile-cta-track);
  font-weight: 400;
  text-transform: none;
  text-decoration: none;
  text-align: right;
  white-space: normal;
}
.split-light .split__copy .inline-cta a,
.split-light .split__copy .split-extra-block .inline-cta--extra a {
  color: var(--split-tile-body-color);
}
.split-dark .split__copy .inline-cta a,
.split-dark .split__copy .split-extra-block .inline-cta--extra a {
  color: var(--dark-showroom-body-color);
}
.split__copy .inline-cta .split-tile-cta-link__text,
.split__copy .inline-cta .soundwall-cta-link__text,
.split__copy .split-extra-block .inline-cta--extra .split-tile-cta-link__text,
.split__copy .split-extra-block .inline-cta--extra .soundwall-cta-link__text {
  display: block;
  flex: 0 1 auto;
  min-width: 0;
  text-align: center;
  width: max-content;
  max-width: min(100%, var(--split-tile-cta-max-width));
  margin-left: auto;
  font-family: var(--tile-cta-font);
  font-size: var(--tile-cta-size);
  line-height: var(--tile-cta-lh);
  letter-spacing: var(--tile-cta-track);
}
.split__copy .inline-cta .split-tile-cta-link__line,
.split__copy .inline-cta .soundwall-cta-link__line,
.split__copy .split-extra-block .inline-cta--extra .split-tile-cta-link__line,
.split__copy .split-extra-block .inline-cta--extra .soundwall-cta-link__line {
  display: block;
  white-space: nowrap;
  text-align: center;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
  letter-spacing: inherit;
  padding-inline-end: 0;
}
.split__copy .inline-cta .split-tile-cta-link__line + .split-tile-cta-link__line,
.split__copy .inline-cta .soundwall-cta-link__line + .soundwall-cta-link__line,
.split__copy .split-extra-block .inline-cta--extra .split-tile-cta-link__line + .split-tile-cta-link__line,
.split__copy .split-extra-block .inline-cta--extra .soundwall-cta-link__line + .soundwall-cta-link__line {
  margin-top: 0;
}
.split__copy .inline-cta .split-tile-cta-link__arrow,
.split__copy .inline-cta .soundwall-cta-link__arrow,
.split__copy .split-extra-block .inline-cta--extra .split-tile-cta-link__arrow,
.split__copy .split-extra-block .inline-cta--extra .soundwall-cta-link__arrow,
.split__copy .inline-cta a > span[aria-hidden="true"] {
  flex: 0 0 auto;
  flex-shrink: 0;
  margin: 0;
  padding: 0;
  position: static;
  top: auto;
  align-self: center;
}

/* Wybrane Realizacje banner (PDF: naturalna fotografia, tytuł góra-lewo, Space Grotesk) */
.realizacje-banner { position: relative; overflow: hidden; display: flex; align-items: flex-start; }
.realizacje-banner__bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 42%;
  display: block;
  filter: brightness(0.94) contrast(1.02) saturate(0.92);
}
.realizacje-banner__inner {
  position: relative;
  z-index: 2;
  width: 100%;
  min-height: clamp(480px, 56.25vw, 860px);
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  padding-top: clamp(72px, 8.5vw, 116px);
  padding-bottom: clamp(48px, 5vw, 88px);
}
.realizacje-banner__title {
  margin: 0;
  max-width: 22ch;
  color: rgba(255, 255, 255, 0.98);
  font-family: 'Space Grotesk', sans-serif;
  font-weight: var(--realizacje-banner-title-weight);
  font-size: var(--realizacje-banner-title-size);
  letter-spacing: var(--realizacje-banner-title-track);
  line-height: var(--realizacje-banner-title-lh);
  text-align: left;
  text-transform: none;
}

/* Realizacje gallery grid (PDF: ciemna ramka, cienki gutter, wyższe kadry) */
.realizacje-gallery { background: var(--realizacje-gallery-frame-bg); }
.realizacje-gallery__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3px; background: var(--realizacje-gallery-frame-bg); }
.realizacje-gallery__item { position: relative; overflow: hidden; background: var(--realizacje-gallery-frame-bg); }
.realizacje-gallery__item img {
  width: 100%;
  height: clamp(300px, 34vw, 620px);
  object-fit: cover;
  object-position: center center;
  display: block;
  transition: transform .55s ease;
}
.realizacje-gallery__item:hover img { transform: scale(1.03); }
.realizacje-gallery__cta-wrap {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
  padding: 28px 32px;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.55) 0%, transparent 55%);
}
.realizacje-gallery__cta-link {
  color: rgba(255, 255, 255, 0.92);
  font-family: var(--tile-cta-font);
  font-size: var(--tile-cta-size);
  line-height: var(--tile-cta-lh);
  letter-spacing: var(--tile-cta-track);
  text-transform: none;
  display: inline-flex;
  align-items: flex-end;
  gap: var(--tile-cta-gap);
  text-decoration: none;
  transition: opacity 0.2s ease;
}
.realizacje-gallery__cta-link:hover { opacity: 0.78; }

/* PDF plansza 8: link „zobacz więcej…” — dół-lewo, małe litery, ciemny tekst na jasnym fragmencie zdjęcia */
.page-key-home .realizacje-gallery__cta-wrap {
  justify-content: flex-end;
  align-items: flex-end;
  padding: clamp(20px, 3vw, 40px) clamp(18px, 2.5vw, 36px);
  background: linear-gradient(to top, rgba(255, 255, 255, 0.22) 0%, transparent 42%);
}
.page-key-home .realizacje-gallery__cta-link {
  font-family: var(--tile-cta-font);
  font-size: var(--tile-cta-size);
  line-height: var(--tile-cta-lh);
  letter-spacing: var(--tile-cta-track);
  color: #1a1d20;
  text-transform: none;
  font-weight: 400;
  text-decoration: none;
}
.page-key-home .realizacje-gallery__cta-link span[aria-hidden="true"] {
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
  letter-spacing: inherit;
}
.page-key-home .realizacje-banner__title {
  color: #ececec;
}
.section-title { margin: 0 0 28px; letter-spacing: var(--bb-h1-track); font-size: var(--bb-h1-size); font-weight: var(--bb-weight-heading); line-height: var(--bb-h1-lh); }
.section-title--light { color: var(--tint-white); }
.entry-content p { margin-top: 14px; }

/* FAQ subpages */
.page-key-faq .page-faq__body .split__inner,
.page-key-faq .page-faq__cta .split__inner {
  min-height: 0;
  aspect-ratio: auto;
  max-height: none;
  grid-template-columns: 1fr;
}
.page-key-faq .page-faq__body .split__inner {
  padding-top: clamp(48px, 5vw, 72px);
  padding-bottom: clamp(56px, 6vw, 88px);
}
.page-key-faq .page-faq__body .split__copy {
  overflow: visible;
}
.page-key-faq .page-faq__content {
  max-width: 52rem;
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}
.page-key-faq .faq-intro {
  margin: 0 0 clamp(32px, 3.5vw, 48px);
  max-width: 36em;
  font-family: var(--split-light-title-font);
  font-size: clamp(22px, 2.2vw, 30px);
  font-weight: var(--split-light-title-weight);
  line-height: 1.3;
  letter-spacing: var(--split-light-title-track);
  color: var(--split-tile-title-color);
}
.page-key-faq .faq-accordion {
  display: flex;
  flex-direction: column;
  gap: 0;
  border-top: 1px solid rgba(0, 0, 0, 0.12);
}
.page-key-faq .faq-item {
  border-bottom: 1px solid rgba(0, 0, 0, 0.12);
}
.page-key-faq .faq-item__summary {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1.25rem;
  padding: clamp(18px, 2vw, 24px) 0;
  cursor: pointer;
  list-style: none;
  transition: color 0.2s ease;
}
.page-key-faq .faq-item__summary::-webkit-details-marker { display: none; }
.page-key-faq .faq-item__summary::after {
  content: "+";
  flex-shrink: 0;
  font-family: var(--font-body);
  font-size: 1.5rem;
  font-weight: 300;
  line-height: 1;
  color: var(--split-tile-title-color);
  transition: transform 0.2s ease;
}
.page-key-faq .faq-item[open] .faq-item__summary::after {
  content: "−";
}
.page-key-faq .faq-item__question {
  font-family: var(--split-light-title-font);
  font-size: clamp(18px, 1.65vw, 22px);
  font-weight: var(--split-light-title-weight);
  line-height: 1.35;
  letter-spacing: var(--split-light-title-track);
  color: var(--split-tile-title-color);
  max-width: 40em;
}
.page-key-faq .faq-item__answer {
  padding: 0 0 clamp(22px, 2.5vw, 32px);
  max-width: 46em;
}
.page-key-faq .faq-item__answer p:first-child { margin-top: 0; }
.page-key-faq .faq-item__answer p + p,
.page-key-faq .faq-item__answer p + ul,
.page-key-faq .faq-item__answer p + .faq-subhead,
.page-key-faq .faq-item__answer ul + p,
.page-key-faq .faq-item__answer .faq-subhead + p {
  margin-top: var(--split-tile-body-gap);
}
.page-key-faq .faq-item__answer p,
.page-key-faq .faq-item__answer li {
  color: var(--split-tile-body-color);
  font-family: 'Roboto', sans-serif;
  font-size: var(--split-tile-body-size);
  font-weight: 400;
  line-height: var(--split-tile-body-lh);
  letter-spacing: var(--split-tile-body-track);
}
.page-key-faq .faq-item__answer .copy-list {
  margin: var(--split-tile-body-gap) 0 0;
  padding: 0;
  list-style: none;
}
.page-key-faq .faq-item__answer .copy-list li {
  position: relative;
  padding-left: 1rem;
  margin: 0;
}
.page-key-faq .faq-item__answer .copy-list li + li {
  margin-top: 0.55em;
}
.page-key-faq .faq-item__answer .copy-list li::before {
  content: "–";
  position: absolute;
  left: 0;
  top: 0;
}
.page-key-faq .faq-item__answer .copy-list li strong {
  font-weight: 600;
  color: var(--split-tile-title-color);
}
.page-key-faq .faq-item__summary:hover .faq-item__question,
.page-key-faq .faq-item__summary:focus-visible .faq-item__question {
  color: var(--brand-green);
}
.page-key-faq .faq-item__summary:focus-visible {
  outline: 2px solid var(--brand-green);
  outline-offset: 4px;
}
.page-key-faq .faq-item[open] .faq-item__summary {
  padding-bottom: clamp(12px, 1.5vw, 16px);
}
.page-key-faq .faq-item[open] .faq-item__question {
  color: var(--split-tile-title-color);
}
.page-key-faq .faq-subhead {
  margin: clamp(20px, 2vw, 28px) 0 clamp(10px, 1.2vw, 14px);
  font-family: var(--split-light-title-font);
  font-size: clamp(16px, 1.4vw, 18px);
  font-weight: var(--split-light-title-weight);
  letter-spacing: var(--split-light-title-track);
  color: var(--split-tile-title-color);
}
.page-key-faq .faq-variant-list li strong {
  font-weight: 600;
  color: var(--split-tile-title-color);
}
.page-key-faq .faq-size-list {
  margin: 0 0 var(--split-tile-body-gap);
  padding: 0;
  list-style: none;
}
.page-key-faq .faq-size-list li {
  display: grid;
  grid-template-columns: 4.5rem 1fr;
  gap: 0.75rem 1.25rem;
  padding: 0.35rem 0;
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}
.page-key-faq .faq-size-list__label {
  font-weight: 500;
  color: var(--split-tile-title-color);
}
.page-key-faq .page-faq__cta .split__copy { max-width: 36em; }
.page-key-faq .page-faq__cta .split__copy h2 { max-width: 20ch; }

/* Optional page templates */
.layout-immersive .hero-inner { min-height: 92vh; }
.layout-immersive .split__copy { background: rgba(232,232,232,.96); }

.layout-showcase .split__inner { min-height: min(42vw, 760px); }
.layout-showcase .split__copy h2 {
  font-family: var(--split-light-title-font);
  font-size: var(--split-light-title-size);
  font-weight: var(--split-light-title-weight);
  line-height: var(--split-light-title-lh);
  letter-spacing: var(--split-light-title-track);
}
.layout-showcase .split-dark .split__copy { background: var(--brand-graphite); }

.layout-atelier .hero-inner { min-height: 88vh; background-position: center calc(25% + var(--hero-bg-y-nudge)); }
.layout-atelier .split__copy { background: var(--brand-graphite); color: rgba(var(--tint-white-rgb), .92); }
.layout-atelier .split__copy p,
.layout-atelier .copy-list li { color: rgba(255,255,255,.84); }

.checker-intro { padding: 96px 0 54px; background: var(--brand-light); }
.checker-intro__inner { max-width: 980px; }
.checker-intro__eyebrow { margin: 0 0 14px; font-family: var(--font-detail); letter-spacing: var(--bb-detail-track); text-transform: uppercase; font-size: var(--bb-detail-size); line-height: var(--bb-detail-lh); color: var(--text-muted); }
.checker-intro__title { margin: 0 0 18px; font-size: var(--bb-h1-size); line-height: var(--bb-h1-lh); font-weight: var(--bb-weight-heading); letter-spacing: var(--bb-h1-track); }
.checker-intro__text { margin: 0; font-family: var(--font-body); font-size: var(--bb-body-size); line-height: var(--bb-body-lh); letter-spacing: var(--bb-body-track); color: var(--text-muted); }

.checkerboard-story { padding: 0 0 94px; background: var(--brand-light); }
.checkerboard-story__stack { width: 100%; padding: 0; }
.checkerboard-story--contrast { background: var(--brand-graphite); }
.checker-story-block { display: grid; grid-template-columns: 1fr 1fr; min-height: clamp(620px, 52vw, 980px); }
.checker-story-block + .checker-story-block { margin-top: 0; }
.checker-story-block.is-reverse { grid-template-columns: 1fr 1fr; }
.checker-story-block.is-reverse .checker-story-block__media { order: 2; }
.checker-story-block.is-reverse .checker-story-block__copy { order: 1; }
.checker-story-block__media { min-height: 100%; }
.checker-story-block__media img { width: 100%; height: 100%; display: block; object-fit: cover; }
.checker-story-block__copy { padding: clamp(46px, 5.1vw, 110px) clamp(40px, 4.4vw, 96px); display: flex; flex-direction: column; justify-content: flex-start; background: var(--brand-light); }
.checker-story-block__copy--light { background: var(--brand-light); color: var(--text-main); }
.checker-story-block__copy--dark { background: var(--brand-graphite); color: rgba(var(--tint-white-rgb), .94); }
.checker-story-block__index { margin: 0 0 18px; font-family: var(--font-detail); letter-spacing: var(--bb-detail-track); font-size: var(--bb-detail-size); line-height: var(--bb-detail-lh); color: var(--text-muted); }
.checker-story-block__copy--dark .checker-story-block__index { color: rgba(var(--tint-white-rgb), .58); }
.checker-story-block__copy h2 { margin: 0 0 34px; font-size: var(--bb-h1-size); line-height: var(--bb-h1-lh); font-weight: var(--bb-weight-heading); letter-spacing: var(--bb-h1-track); text-wrap: balance; }
.checker-story-block__copy p { margin: 0; font-family: var(--font-body); font-size: var(--bb-body-size); line-height: var(--bb-body-lh); letter-spacing: var(--bb-body-track); color: var(--text-muted); }
.checker-story-block__copy--dark p { color: rgba(var(--tint-white-rgb), .84); }
.checker-story-block__cta { padding-top: clamp(36px, 4vw, 48px); }
.checker-story-block__cta a { color: inherit; }
.layout-checkerboard-story .entry-content { background: var(--tint-white); }

.editorial-panels { padding: 0 0 110px; background: var(--brand-light); }
.editorial-panels__stack { width: 100%; display: grid; gap: 0; }
.editorial-panel { display: grid; grid-template-columns: minmax(0, 1.15fr) minmax(320px, .85fr); gap: 0; align-items: stretch; }
.editorial-panel.is-reverse { grid-template-columns: minmax(320px, .85fr) minmax(0, 1.15fr); }
.editorial-panel.is-reverse .editorial-panel__media { order: 2; }
.editorial-panel.is-reverse .editorial-panel__copy { order: 1; }
.editorial-panel__media img { width: 100%; height: 100%; display: block; object-fit: cover; min-height: 620px; }
.editorial-panel__copy { background: var(--tint-white); padding: clamp(40px, 4.2vw, 82px); display: flex; flex-direction: column; justify-content: center; }
.editorial-panel__meta { margin: 0 0 18px; font-family: var(--font-detail); letter-spacing: var(--bb-detail-track); text-transform: uppercase; font-size: var(--bb-detail-size); line-height: var(--bb-detail-lh); color: var(--text-muted); }
.editorial-panel__copy h2 { margin: 0 0 26px; font-size: var(--bb-h2-size); line-height: var(--bb-h2-lh); font-weight: var(--bb-weight-heading); letter-spacing: var(--bb-h2-track); }
.editorial-panel__copy p { margin: 0; font-family: var(--font-body); color: var(--text-muted); font-size: var(--bb-body-size); line-height: var(--bb-body-lh); letter-spacing: var(--bb-body-track); }
.editorial-panel__cta {
  margin-top: auto;
  padding-top: 34px;
}
.editorial-panel__cta a { color: var(--text-main); }

/* Sale kinowe — hero i kafelki 1:1 jak w eksporcie Canvy (szerokość rzędu : wysokość = 2:1) */
.page-key-cinema-halls .hero-inner {
  min-height: min(84vh, 768px);
  background-size: cover;
  /* hero-kino-sale-kinowe.png — kadr jak w makiecie Canva (zrzut ekranu) */
  background-position: var(--hero-bg-position, center calc(50% + var(--hero-bg-y-nudge))) !important;
}
.page-key-cinema-halls .hero-content { padding-bottom: 94px; }
.page-key-cinema-halls .hero h1 {
  max-width: 700px;
  font-family: var(--font-heading);
  font-weight: 300;
  font-size: var(--inner-hero-title-size);
  line-height: var(--inner-hero-title-lh);
  letter-spacing: var(--inner-hero-title-track);
}
.page-key-cinema-halls .hero-subline { display: none; }
.page-key-cinema-halls .hero-row { gap: 24px; }
.page-key-cinema-halls .hero-row__left {
  padding: 0 28px 14px;
  margin-left: 6px;
}
.page-key-cinema-halls .hero-row__right { padding: 0 12px 8px 0; }
.page-key-cinema-halls .hero-row__right .outline-button {
  min-width: clamp(200px, 17vw, 280px);
  justify-content: space-between;
  padding: 8px 14px;
  letter-spacing: var(--outline-button-track);
}

/* Splity na pełną szerokość — bez białych marginesów po bokach (Canva 1366 wewnątrz, nie obok body) */
.page-key-cinema-halls .split {
  width: 100%;
  max-width: 100%;
}
.page-key-cinema-halls .split .site-limit {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
}
.page-key-cinema-halls .split__inner {
  width: 100%;
  max-width: none;
}
.page-key-cinema-halls .split__media {
  min-height: 100%;
  overflow: hidden;
}
.page-key-cinema-halls .split__media img,
.page-key-cinema-halls .split__media video.split__video {
  width: 100%;
  height: 100%;
  min-height: 100%;
  display: block;
}
@media (min-width: 901px) {
  .page-key-cinema-halls .split__inner {
    min-height: 0;
    aspect-ratio: 2 / 1;
    max-height: none;
  }
  .page-key-cinema-halls .split__copy {
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
}
.page-key-cinema-halls .split-index-1 .split__copy { order: 1; }
.page-key-cinema-halls .split-index-1 .split__media { order: 2; }
.page-key-cinema-halls .split-index-2 .split__copy { order: 2; }
.page-key-cinema-halls .split-index-2 .split__media { order: 1; }
.page-key-cinema-halls .split-index-3 .split__copy { order: 1; }
.page-key-cinema-halls .split-index-3 .split__media { order: 2; }
.page-key-cinema-halls .split-index-4 .split__copy { order: 1; }
.page-key-cinema-halls .split-index-4 .split__media { order: 2; }
.page-key-cinema-halls .split-index-5 .split__copy { order: 2; }
.page-key-cinema-halls .split-index-5 .split__media { order: 1; }
.page-key-cinema-halls .split-index-6 .split__copy { order: 1; }
.page-key-cinema-halls .split-index-6 .split__media { order: 2; }
.page-key-cinema-halls .split-index-7 .split__copy { order: 2; }
.page-key-cinema-halls .split-index-7 .split__media { order: 1; }
.page-key-cinema-halls .split-index-8 .split__copy { order: 1; }
.page-key-cinema-halls .split-index-8 .split__media { order: 2; }
/* Scalony kafelek: dwa bloki tekstu (Canva) + jedno zdjęcie po prawej */
.page-key-cinema-halls .split--dual-copy .split__inner {
  min-height: min(96vw, 1800px);
}
.page-key-cinema-halls .split__copy--dual {
  display: flex;
  flex-direction: column;
  gap: clamp(36px, 3.5vw, 56px);
  justify-content: stretch;
}
.page-key-cinema-halls .split-tile-panel {
  display: flex;
  flex-direction: column;
  flex: 1 1 0;
  min-height: 0;
}
.page-key-cinema-halls .split-tile-panel h2 {
  margin: 0 0 28px;
}
.page-key-cinema-halls .split-tile-panel .inline-cta {
  margin-top: auto;
  margin-left: auto;
  margin-right: 0;
  align-self: flex-end;
}
.page-key-cinema-halls .split--dual-copy .split__media {
  align-self: stretch;
}
.page-key-cinema-halls .split--dual-copy .split__media img {
  min-height: 100%;
  height: 100%;
}
.page-key-cinema-halls .split__copy { padding: clamp(52px, 4.6vw, 78px) clamp(40px, 3.6vw, 66px); justify-content: flex-start; }
/* Jasny kafel: nagłówek i akapit jak w Canvie (Space Grotesk 22 pt / Roboto ~13,33) */
.page-key-cinema-halls .split-light .split__copy h2 {
  margin: 0 0 28px;
  padding-bottom: 0;
  border-bottom: 0;
  font-family: var(--split-light-title-font);
  font-size: var(--split-light-title-size);
  font-weight: var(--split-light-title-weight);
  line-height: var(--split-light-title-lh);
  letter-spacing: var(--split-light-title-track);
  color: var(--split-light-title-color);
  text-wrap: balance;
}
.page-key-cinema-halls .split-light .split__copy h2::after { display: none; }
.page-key-cinema-halls .split-dark .split__copy h2 {
  margin: 0 0 28px;
  padding-bottom: 0;
  border-bottom: 0;
  font-family: var(--dark-showroom-title-font);
  font-size: var(--dark-showroom-title-size);
  font-weight: var(--dark-showroom-title-weight);
  line-height: var(--dark-showroom-title-lh);
  letter-spacing: var(--dark-showroom-title-track);
  color: var(--dark-showroom-title-color);
  text-wrap: balance;
}
.page-key-cinema-halls .split-dark .split__copy h2::after { display: none; }
.page-key-cinema-halls .split-dark .split__copy p {
  font-family: var(--dark-showroom-body-font);
  font-size: var(--dark-showroom-body-size);
  line-height: var(--dark-showroom-body-lh);
  letter-spacing: var(--dark-showroom-body-track);
  color: var(--dark-showroom-body-color);
  max-width: 100%;
}
.page-key-cinema-halls .split-dark .split__copy { background: var(--brand-graphite); }
.page-key-cinema-halls .split-light .split__copy { background: var(--split-light-bg); }
.page-key-cinema-halls .split__media img { object-fit: cover; object-position: center center; }
/* Kadrowanie per slajd PDF (split-index = kolejność sekcji na /kino-sale/) */
.page-key-cinema-halls .split-index-1 .split-media-cinema-halls-01 img { object-position: 52% 38%; }
.page-key-cinema-halls .split-index-2 .split-media-cinema-halls-02 img { object-position: 48% 42%; }
.page-key-cinema-halls .split-index-3 .split-media-cinema-halls-03 img { object-position: 45% 40%; }
.page-key-cinema-halls .split-index-4 .split-media-cinema-halls-04 img { object-position: 55% 46%; }
.page-key-cinema-halls .split-index-5 .split-media-cinema-halls-05 img { object-position: 50% 34%; }
.page-key-cinema-halls .split-index-6 .split-media-cinema-halls-06 img { object-position: 50% 42%; }
.page-key-cinema-halls .split-index-7 .split-media-cinema-halls-fotele img { object-position: 42% 50%; }
.page-key-cinema-halls .split-index-8 .split-media-cinema-halls-02 img { object-position: 44% 38%; }
.page-key-cinema-halls .split-index-8 .split__copy > p { margin-top: var(--split-tile-body-gap); }
.page-key-cinema-halls .split-index-8 .split-extra-block + p { margin-top: var(--split-tile-body-gap); }
.page-key-cinema-halls .inline-cta { padding-top: var(--split-tile-cta-pad-top); }
.page-key-cinema-halls .copy-list {
  margin: var(--split-tile-body-gap) 0 0;
  padding: 0;
  list-style: none;
}
.page-key-cinema-halls .copy-list li {
  position: relative;
  padding-left: 14px;
  margin: 0;
}
.page-key-cinema-halls .copy-list li + li { margin-top: var(--split-tile-body-gap); }
.page-key-cinema-halls .copy-list li::before {
  content: "•";
  position: absolute;
  left: 0;
  top: 0;
}
.page-key-cinema-halls .split-light .copy-list li {
  font-family: 'Roboto', sans-serif;
  font-size: var(--split-tile-body-size);
  line-height: var(--split-tile-body-lh);
  letter-spacing: var(--split-tile-body-track);
  color: var(--split-tile-body-color);
}
.page-key-cinema-halls .split-dark .copy-list li {
  font-family: var(--dark-showroom-body-font);
  font-size: var(--dark-showroom-body-size);
  line-height: var(--dark-showroom-body-lh);
  letter-spacing: var(--dark-showroom-body-track);
  color: var(--dark-showroom-body-color);
}
.page-key-cinema-halls .split-index-8 .split-extra-block { margin-top: 0; }
.page-key-cinema-halls .split-index-8 .split-extra-block .inline-cta--extra {
  padding-top: clamp(18px, 1.8vw, 28px);
}
.page-key-cinema-halls .split-dark .split-extra-block p {
  font-family: var(--dark-showroom-body-font);
  font-size: var(--dark-showroom-body-size);
  line-height: var(--dark-showroom-body-lh);
  letter-spacing: var(--dark-showroom-body-track);
  color: var(--dark-showroom-body-color);
}
.page-key-cinema-halls .split-extra-block { margin-top: clamp(20px, 2.2vw, 36px); }
.page-key-cinema-halls .split-extra-block .inline-cta--extra { padding-top: clamp(20px, 2.2vw, 28px); }

.page-key-home .hero-home {
  min-height: min(100vh, 860px);
  background-position: 48% calc(60% + var(--hero-bg-y-nudge));
  background-size: 115% auto;
}
.page-key-home .hero-content { padding-bottom: 84px; }
.page-key-home .hero-row__left {
  border-bottom: none;
  padding-bottom: 12px;
}
.page-key-home .hero h1 {
  max-width: 760px;
  font-size: var(--home-hero-title-size);
  font-weight: 300;
  letter-spacing: var(--inner-hero-title-track);
  line-height: var(--inner-hero-title-lh);
  text-wrap: balance;
}
.page-key-home .hero-subline { display: none; }
.page-key-home .hero-row__right .outline-button {
  min-width: clamp(180px, 15vw, 230px);
  justify-content: space-between;
  padding: 6px 18px;
  font-family: 'Roboto Mono', monospace;
  font-size: 13.333px;
  font-weight: 400;
  letter-spacing: var(--outline-button-track);
  line-height: var(--outline-button-lh);
  border-color: rgba(255, 255, 255, 0.76);
}

/* Home feature cards: desktop = fixed pixel size, centered (no fluid scaling); mobile = stack below 1024px */
@media (min-width: 1025px) {
  .page-key-home .dark-grid { background: var(--brand-graphite); padding: 72px 0 88px; }
  .page-key-home .dark-grid .site-limit { width: 100%; max-width: none; margin: 0 auto; padding: 0 var(--site-pad-inline); }
  .page-key-home .cards-grid {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: stretch;
    gap: 14px;
    margin: 0 auto;
  }
  .page-key-home .feature-card {
    flex: 0 0 auto;
    width: 410px;
    height: 615px;
    min-height: 0;
    max-height: none;
    aspect-ratio: unset;
    border: none;
    border-radius: 0;
  }
  .page-key-home .feature-card__body {
    padding: 32px 24px 36px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .page-key-home .feature-card h3 {
    margin: 0 0 18px;
    text-transform: none;
    max-width: 22ch;
  }
}

.page-key-home .feature-card:not(.feature-card--bw-color) .feature-card__media {
  background-position: 50% 48%;
  background-size: cover;
  transform: scale(1);
  filter: grayscale(1) saturate(0.8);
  -webkit-filter: grayscale(1) saturate(0.8);
  transition: transform 0.55s cubic-bezier(0.25, 0.46, 0.45, 0.94), filter 0.55s ease, -webkit-filter 0.55s ease;
}
.page-key-home .feature-card:not(.feature-card--bw-color):hover .feature-card__media,
.page-key-home .feature-card:not(.feature-card--bw-color):focus-within .feature-card__media {
  transform: scale(1.06);
  filter: grayscale(0) saturate(1);
  -webkit-filter: grayscale(0) saturate(1);
}
.page-key-home .feature-card--bw-color .feature-card__media,
.page-key-home .feature-card--bw-color .feature-card__media::after {
  background-position: 50% 48%;
  background-size: cover;
  transform: scale(1);
  transform-origin: center center;
  transition: transform 0.55s cubic-bezier(0.25, 0.46, 0.45, 0.94), opacity 0.55s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.page-key-home .feature-card--bw-color:hover .feature-card__media,
.page-key-home .feature-card--bw-color:focus-within .feature-card__media,
.page-key-home .feature-card--bw-color:hover .feature-card__media::after,
.page-key-home .feature-card--bw-color:focus-within .feature-card__media::after {
  transform: scale(1.04);
}
.page-key-home .feature-card__overlay {
  background: linear-gradient(
    to top,
    rgba(0, 0, 0, 0.88) 0%,
    rgba(0, 0, 0, 0.78) 22%,
    rgba(0, 0, 0, 0.45) 38%,
    rgba(0, 0, 0, 0.12) 55%,
    transparent 72%
  );
}
/* Home: splity od krawędzi do krawędzi (bez 100vw — unika białych pasów od scrollbara) */
.page-key-home .split.split--bleed {
  width: 100%;
  max-width: 100%;
  margin-left: 0;
  margin-right: 0;
}
.page-key-home .split.split--bleed .split__inner {
  width: 100%;
  max-width: none;
}

.page-key-home .split-light .split__inner {
  gap: 0;
}
.page-key-home .split-light .split__copy {
  border-right: 1px solid var(--home-split-divider);
  padding: clamp(56px, 5.5vw, 72px) clamp(48px, 4.5vw, 64px);
}
.page-key-home .split-light .split__media {
  min-height: 100%;
  overflow: hidden;
  background: var(--split-light-bg);
}
.page-key-home .split-light .split__media img {
  object-position: 50% 48%;
}
/* Home intro: tytuł „Dźwięk pięknie…” — Canva Witryna: Space Grotesk ~37,33 px, #608293, tracking 170 */
.page-key-home .split-light .split__copy h2 {
  color: var(--brand-blue);
  font-size: 37.334px;
  font-weight: 400;
  letter-spacing: 0.17em;
  line-height: 1.4;
  margin-bottom: clamp(40px, 3.5vw, 48px);
}
.page-key-home .split-light .split__copy h2::after {
  width: 52px;
  height: 1px;
  margin-top: 22px;
  opacity: 0.88;
  background: var(--brand-blue);
}
/* „Audio szyte na miarę” — pełnoszeroki pasek z linkiem (Canva: slajd 9) */
.page-key-home .split.split-dark--home-feature.split--bleed {
  display: flex;
  flex-direction: column;
  background: var(--brand-graphite);
}
.page-key-home .home-feature__cta-bar {
  flex: 0 0 auto;
  width: 100%;
  box-sizing: border-box;
  background: var(--brand-graphite);
  border-top: 1px solid rgba(255, 255, 255, 0.24);
  padding: clamp(28px, 3.2vw, 44px) clamp(48px, 4.5vw, 64px);
  min-height: clamp(72px, 8vw, 108px);
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
.page-key-home .home-feature__cta-link.split-tile-cta-link {
  color: rgba(236, 236, 236, 0.92);
  text-transform: none;
}
.page-key-home .home-feature__cta-link.split-tile-cta-link:hover {
  opacity: 0.78;
}
.page-key-home .split-dark--home-feature .split__inner {
  flex: 1 1 auto;
  width: 100%;
  min-height: min(48vw, 900px);
}
.page-key-home .split-dark--home-feature .split__copy {
  background: var(--brand-graphite);
  justify-content: flex-start;
  align-items: flex-start;
  min-height: 0;
  padding: clamp(40px, 4.2vw, 56px) clamp(48px, 4.5vw, 64px) clamp(56px, 5.5vw, 72px);
  text-align: left;
}
.page-key-home .split-dark--home-feature .split__copy h2 {
  margin: 0;
  width: 100%;
  max-width: 16ch;
  color: rgba(255, 255, 255, 0.98);
  font-family: 'Space Grotesk', sans-serif;
  font-size: 37.334px;
  font-weight: var(--split-dark-feature-title-weight);
  letter-spacing: 0.142em;
  line-height: var(--split-dark-feature-title-lh);
  text-align: left;
  text-transform: none;
}
.page-key-home .split-dark--home-feature .split__copy h2::after {
  content: "";
  display: block;
  width: min(100%, 420px);
  height: 1px;
  background: rgba(255, 255, 255, 0.48);
  margin: clamp(22px, 2.4vw, 30px) 0 0;
}
.page-key-home .split-dark--home-feature .split__copy > p {
  margin: clamp(32px, 3.2vw, 42px) 0 0;
  width: 100%;
  max-width: min(100%, 520px);
  text-align: left;
  font-family: var(--dark-showroom-body-font);
  font-size: var(--dark-showroom-body-size);
  line-height: var(--dark-showroom-body-lh);
  letter-spacing: var(--dark-showroom-body-track);
  color: var(--dark-showroom-body-color);
}
.page-key-home .split-dark--home-feature .inline-cta {
  width: 100%;
  max-width: min(100%, 520px);
  margin: clamp(24px, 2.5vw, 32px) 0 0;
  padding-top: 0;
  align-self: flex-start;
  text-align: right;
}
.page-key-home .split-dark--home-feature .inline-cta a,
.page-key-home .split-dark--home-feature .inline-cta .split-tile-cta-link,
.page-key-home .split-dark--home-feature .inline-cta .split-tile-cta-link__text,
.page-key-home .split-dark--home-feature .inline-cta .split-tile-cta-link__line {
  font-family: var(--tile-cta-font);
  font-size: var(--tile-cta-size);
  line-height: var(--tile-cta-lh);
  letter-spacing: var(--tile-cta-track);
  color: var(--dark-showroom-body-color);
  text-transform: none;
}
.page-key-home .split-dark--home-feature .inline-cta .split-tile-cta-link__arrow {
  color: var(--dark-showroom-body-color);
}
.page-key-home .split-light .split__copy .inline-cta a,
.page-key-home .split-light .split__copy .inline-cta .split-tile-cta-link,
.page-key-home .split-light .split__copy .inline-cta .split-tile-cta-link__text,
.page-key-home .split-light .split__copy .inline-cta .split-tile-cta-link__line {
  color: var(--split-tile-body-color);
}
.page-key-home .split-light .split__copy .inline-cta .split-tile-cta-link__arrow {
  color: var(--split-tile-body-color);
}
.page-key-home .feature-card .outline-button.is-small {
  font-family: 'Roboto Mono', monospace;
  font-size: 13.333px;
  letter-spacing: var(--outline-button-track);
  text-transform: uppercase;
}
/* „Audio szyte na miarę” — fotki/18: pełne wypełnienie kolumny, bez białego pasa po prawej */
.page-key-home .split.split-dark--home-feature.split--bleed .split__media {
  position: relative;
  min-height: min(48vw, 900px);
  overflow: hidden;
  background: var(--brand-graphite);
}
.page-key-home .split.split-dark--home-feature.split--bleed .split__media img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 46%;
}

/* „Doświadcz dźwięku” — Canva Home Witryna: Space Grotesk 40 px, tracking 142, #ececec (token globalny zostaje dla innych stron) */
.page-key-home .dark-showroom__header h2 {
  font-size: 40px;
  letter-spacing: 0.142em;
  line-height: 1.4;
}
/* Showroom: dwa zdjęcia bez szczeliny, ta sama wysokość i linia góry/dołu */
.page-key-home .dark-showroom__photos {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0;
  align-items: stretch;
}
.page-key-home .dark-showroom__photo {
  aspect-ratio: 16 / 10;
  min-height: clamp(280px, 31.25vw, 600px);
  background: var(--bg-dark);
}
.page-key-home .dark-showroom__photo + .dark-showroom__photo {
  border-left: 1px solid rgba(0, 0, 0, 0.35);
}
.page-key-home .dark-showroom__photo img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 48%;
}
.page-key-home .dark-showroom__photo--1 img {
  object-position: 50% 44%;
}
.page-key-home .dark-showroom__photo--2 img {
  object-position: 50% 46%;
}

/* Delikatny pasek między showroom a banerem realizacji */
.page-key-home .dark-showroom {
  border-bottom: 1px solid rgba(255, 255, 255, 0.14);
  box-shadow: 0 6px 0 0 rgba(28, 30, 33, 0.92);
}
.page-key-home .realizacje-banner {
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: inset 0 8px 0 0 rgba(42, 46, 50, 0.65);
}

/* Galeria realizacji — cienka linia między zdjęciami (jak na /realizacje/) */
.page-key-home .realizacje-gallery {
  padding: 0;
}
.page-key-home .realizacje-gallery__inner.site-limit {
  width: 100%;
  max-width: none;
  padding-left: 0;
  padding-right: 0;
}
.page-key-home .realizacje-gallery__grid {
  gap: 2px;
}
.page-key-home .realizacje-gallery__item {
  aspect-ratio: auto;
  overflow: hidden;
  background: var(--realizacje-gallery-frame-bg);
}
.page-key-home .realizacje-gallery__item img {
  width: 100%;
  height: clamp(280px, 32vw, 580px);
  min-height: 0;
  object-fit: cover;
  object-position: 50% 48%;
  display: block;
  transition: none;
}
/* Kafelek z fotki/12.png (TV) */
.page-key-home .realizacje-gallery__item:nth-child(1) img {
  object-position: 50% 48%;
}
/* Kafelek z fotki/16.png (głośnik + TV) */
.page-key-home .realizacje-gallery__item:nth-child(5) img {
  object-position: 48% 50%;
}
.page-key-home .realizacje-gallery__item:nth-child(6) img {
  object-position: 50% 48%;
}
.page-key-home .realizacje-gallery__item:hover img {
  transform: none;
}
.page-key-home .realizacje-gallery__footer-cta {
  background: var(--realizacje-gallery-frame-bg);
  padding: clamp(22px, 3vw, 36px) var(--site-pad-inline);
  text-align: right;
}
.page-key-home .realizacje-gallery__footer-cta-link {
  font-family: var(--tile-cta-font);
  font-size: var(--tile-cta-size);
  line-height: var(--tile-cta-lh);
  letter-spacing: var(--tile-cta-track);
  color: #ececec;
  text-transform: none;
  font-weight: 400;
  transition: opacity 0.2s ease;
}
.page-key-home .realizacje-gallery__footer-cta-link:hover {
  opacity: 0.78;
}

.page-key-cinema .hero-inner,
.page-key-living-room-cinema .hero-inner,
.page-key-soundwall .hero-inner,
.page-key-knowledge .hero-inner,
.page-key-projects .hero-inner {
  background-position: center calc(40% + var(--hero-bg-y-nudge));
}
.page-key-contact .hero-inner {
  background-position: var(--hero-bg-position, 24% calc(58% - 5px));
}

.page-key-cinema .split__copy h2,
.page-key-soundwall .split__copy h2,
.page-key-knowledge .split__copy h2,
.page-key-projects .split__copy h2,
.page-key-contact .split__copy h2 {
  border-bottom: 0;
  padding-bottom: 0;
}

/* Podstrony: nagłówki sekcji w splitach — jak Canva (Space Grotesk 22 pt, tracking 170), nie H2 brandbook */
.page-key-cinema .split__copy h2,
.page-key-soundwall .split__copy h2,
.page-key-knowledge .split__copy h2,
.page-key-projects .split__copy h2 {
  margin: 0 0 28px;
  font-family: var(--split-light-title-font);
  font-size: var(--split-light-title-size);
  font-weight: var(--split-light-title-weight);
  letter-spacing: var(--split-light-title-track);
  line-height: var(--split-light-title-lh);
}

.page-key-cinema .hero-row__right .outline-button,
.page-key-living-room-cinema .hero-row__right .outline-button,
.page-key-soundwall .hero-row__right .outline-button,
.page-key-knowledge .hero-row__right .outline-button,
.page-key-projects .hero-row__right .outline-button {
  min-width: clamp(200px, 17vw, 280px);
  justify-content: space-between;
  padding: 8px 14px;
  letter-spacing: var(--outline-button-track);
}

/* Hero z krótkim tytułem (Canva slajd 1: Kino, Kino w salonie, Soundwall, Audio, Realizacje, Kontakt; Wiedza poza szablonem Canva) */
.page-key-cinema .hero-inner h1,
.page-key-living-room-cinema .hero-inner h1,
.page-key-soundwall .hero-inner h1,
.page-key-audio .hero-inner h1,
.page-key-projects .hero-inner h1,
.page-key-contact .hero-inner h1,
.page-key-knowledge .hero-inner:not(.knowledge-canva-hero) h1 {
  font-size: var(--inner-hero-title-size);
  line-height: var(--inner-hero-title-lh);
  letter-spacing: var(--inner-hero-title-track);
}

/* ================================================
   Kontakt – Canva / PDF 1024.5×576 pt (≈ 1366×768): kafelki 16:9, typografia jak tokeny Canva
   Nagłówki splitów z „Witryna internetowa” Kontakt: Space Grotesk ~37,33 px, tracking 142 (Showroom #fff; architekci #22282c)
   ================================================ */
.page-key-contact {
  /* Canva Kontakt @1366×768 — tokeny z eksportu HTML */
  --contact-split-height: min(calc(100vw * 576 / 1024.5), 768px);
  --contact-pad-x: clamp(52px, 5.62vw, 77px);
  --contact-pad-x-detail: clamp(48px, 4.95vw, 68px);
  --contact-body-size: 13.333px;
  --contact-body-lh: 2;
  --contact-body-track: 0.091em;
  --contact-link-size: 16px;
  --contact-link-lh: 2.2;
  --contact-h2-size: 37.334px;
  --contact-h2-track: 0.142em;
  --contact-h2-lh: 1.4;
  --contact-text-max: min(100%, 539px);
}
.page-key-contact .hero-inner {
  min-height: var(--contact-split-height);
  background-position: var(--hero-bg-position, 24% calc(58% - 5px));
}
.page-key-contact .hero-content {
  padding-bottom: clamp(56px, 5.2vw, 72px);
}
.page-key-contact .hero-inner h1 {
  font-size: 40px;
  line-height: 2;
  letter-spacing: 0.115em;
  font-weight: 400;
}
.page-key-contact .hero-subline { display: none; }
.page-key-contact .hero-row__right .outline-button {
  min-width: 230px;
  justify-content: space-between;
  padding: 7px 18px;
  font-size: 17.333px;
  letter-spacing: 0.065em;
  line-height: 1.4;
}

/* Siatka 2×3 — wspólne linie poziome/pionowe jak w Canva (bez osobnych <section> na rząd) */
.page-key-contact .contact-mosaic {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: repeat(3, var(--contact-split-height));
  width: 100%;
  margin: 0;
  padding: 0;
}
.page-key-contact .contact-mosaic__cell {
  min-width: 0;
  min-height: 0;
  margin: 0;
  overflow: hidden;
}
.page-key-contact .contact-mosaic__cell--media-1 { grid-area: 1 / 1; }
.page-key-contact .contact-mosaic__cell--copy-1 { grid-area: 1 / 2; }
.page-key-contact .contact-mosaic__cell--copy-2 { grid-area: 2 / 1; }
.page-key-contact .contact-mosaic__cell--media-2 { grid-area: 2 / 2; }
.page-key-contact .contact-mosaic__cell--copy-3 { grid-area: 3 / 1; }
.page-key-contact .contact-mosaic__cell--media-3 { grid-area: 3 / 2; }

.page-key-contact .contact-mosaic__cell.split__copy {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  text-align: left;
  height: 100%;
  box-sizing: border-box;
}
.page-key-contact .contact-mosaic__cell.split__media {
  position: relative;
  height: 100%;
  min-height: 0;
  padding: 0;
}
/* Kafelki: .split-light i .split__copy na tym samym elemencie (mozaika) */
.page-key-contact .contact-mosaic__cell.split__copy.split-light,
.page-key-contact .split-light.split__copy {
  background-color: #ececec;
  color: #22282c;
}
.page-key-contact .contact-mosaic__cell.split__copy.split-dark,
.page-key-contact .split-dark.split__copy {
  background-color: #22282c;
  color: #ffffff;
}

/* Sekcja 1 — dane kontaktowe (Canva: inset ~68 px, góra ~44 px) */
.page-key-contact .contact-mosaic__cell--copy-1 {
  padding: clamp(40px, 3.22vw, 44px) var(--contact-pad-x-detail) clamp(36px, 3vw, 44px);
}
/* Sekcja 2 — Showroom (PDF: tytuł y=145 px, inset x=77) */
.page-key-contact .contact-mosaic__cell--copy-2 {
  padding: clamp(100px, 10.76vw, 147px) var(--contact-pad-x) clamp(40px, 3.5vw, 48px);
}
/* Sekcja 3 — architekci (PDF: tytuł y=109 px, inset x=77) */
.page-key-contact .contact-mosaic__cell--copy-3 {
  padding: clamp(72px, 7.98vw, 109px) var(--contact-pad-x) clamp(40px, 3.5vw, 48px);
}

.page-key-contact .split__copy h2 {
  margin: 0;
  max-width: var(--contact-text-max);
  font-family: 'Space Grotesk', sans-serif;
  font-size: var(--contact-h2-size);
  font-weight: 400;
  letter-spacing: var(--contact-h2-track);
  line-height: var(--contact-h2-lh);
  color: var(--split-light-title-color);
}
.page-key-contact .split-dark.split__copy h2,
.page-key-contact .contact-mosaic__cell.split-dark.split__copy h2 {
  color: #ffffff;
}
.page-key-contact .contact-mosaic__cell--copy-2 h2 {
  margin-bottom: clamp(28px, 4.03vw, 55px);
}
.page-key-contact .contact-mosaic__cell--copy-3 h2 {
  line-height: 1.28;
  margin-bottom: clamp(26px, 3.59vw, 49px);
}
.page-key-contact .split-light.split__copy h2::after,
.page-key-contact .split-dark.split__copy h2::after { display: none; }

.page-key-contact .split-light.split__copy p,
.page-key-contact .split-light.split__copy .copy-list li,
.page-key-contact .split-dark.split__copy p,
.page-key-contact .split-dark.split__copy .copy-list li,
.page-key-contact .contact-mosaic__cell.split-light.split__copy p,
.page-key-contact .contact-mosaic__cell.split-light.split__copy .copy-list li,
.page-key-contact .contact-mosaic__cell.split-dark.split__copy p,
.page-key-contact .contact-mosaic__cell.split-dark.split__copy .copy-list li {
  margin: 0;
  max-width: var(--contact-text-max);
  font-family: 'Roboto', sans-serif;
  font-size: var(--contact-body-size);
  line-height: var(--contact-body-lh);
  letter-spacing: var(--contact-body-track);
  font-weight: 400;
  text-align: left;
}
.page-key-contact .split-light.split__copy p,
.page-key-contact .split-light.split__copy .copy-list li,
.page-key-contact .contact-mosaic__cell.split-light.split__copy p,
.page-key-contact .contact-mosaic__cell.split-light.split__copy .copy-list li {
  color: #22282c;
}
.page-key-contact .split-dark.split__copy p,
.page-key-contact .split-dark.split__copy .copy-list li,
.page-key-contact .contact-mosaic__cell.split-dark.split__copy p,
.page-key-contact .contact-mosaic__cell.split-dark.split__copy .copy-list li {
  color: #ffffff;
}
.page-key-contact .split__copy > p + p { margin-top: 0; }
.page-key-contact .contact-mosaic__cell--copy-2 .showroom-copy {
  white-space: pre-wrap;
  max-width: min(490.189px, 100%);
  line-height: 2;
  letter-spacing: 0.091em;
}
.page-key-contact .contact-mosaic__cell--copy-3 > p:first-of-type {
  margin-bottom: clamp(20px, 2.71vw, 37px);
}
.page-key-contact .contact-mosaic__cell--copy-3 > p + p:not(:nth-of-type(2)) {
  margin-top: 0;
}
.page-key-contact .contact-mosaic__cell.split__media img,
.page-key-contact .contact-mosaic__cell.split__media video.split__video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: none;
}
.page-key-contact .contact-mosaic__cell--media-1.split__media--contact-media-info img {
  object-position: 33% 46%;
}
.page-key-contact .contact-mosaic__cell--media-2.split__media--contact-media-showroom img {
  object-position: 56% 50%;
}
.page-key-contact .contact-mosaic__cell--media-3.split__media--contact-media-architects img {
  object-position: 48% 52%;
  transform: none;
}

/* Lista „Dostarczamy” – znaki • jak w PDF (nie myślnik) */
.page-key-contact .contact-mosaic__cell--copy-3 .copy-list {
  margin: clamp(8px, 0.81vw, 11px) 0 clamp(20px, 2.71vw, 37px);
}
.page-key-contact .contact-mosaic__cell--copy-3 .copy-list li {
  line-height: 1.154;
  padding-left: 14px;
}
.page-key-contact .contact-mosaic__cell--copy-3 .copy-list li + li {
  margin-top: clamp(8px, 0.81vw, 11px);
}
.page-key-contact .contact-mosaic__cell--copy-3 .copy-list li::before {
  content: "•";
  left: 0;
  font-weight: 400;
}

/* Sekcja 1 — kolumna danych kontaktowych (Canva: body 13,33 / linki 16) */
.contact-detail {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  width: 100%;
  max-width: var(--contact-text-max);
  margin: 0;
}
.contact-detail__group {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  width: 100%;
  margin: 0;
}
.contact-detail__intro-group {
  gap: 0;
  margin-bottom: clamp(14px, 1.6vw, 18px);
}
.contact-detail__intro-group .contact-detail__intro + .contact-detail__intro {
  margin-top: 0.65em;
}
.contact-detail__rows {
  gap: 4px;
  margin-bottom: clamp(22px, 2.6vw, 30px);
}
.contact-detail__blocks {
  gap: clamp(10px, 1.2vw, 14px);
}
.contact-detail__intro,
.contact-detail__label {
  margin: 0;
  font-family: 'Roboto', sans-serif;
  font-size: var(--contact-body-size);
  line-height: var(--contact-body-lh);
  letter-spacing: var(--contact-body-track);
  color: var(--split-tile-body-color);
  font-weight: 400;
}
.contact-detail__block p,
.contact-detail__heading {
  margin: 0;
  font-family: 'Roboto', sans-serif;
  font-size: var(--contact-body-size);
  line-height: 1.5;
  letter-spacing: var(--contact-body-track);
  color: var(--split-tile-body-color);
  font-weight: 400;
}
.contact-detail__heading {
  font-weight: 700;
}
.contact-detail__block {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
  width: 100%;
}
.contact-detail__block p + p {
  margin-top: 0;
}
.contact-detail__row {
  margin: 0;
  display: grid;
  grid-template-columns: 25px minmax(0, 1fr);
  align-items: center;
  column-gap: clamp(10px, 1.1vw, 14px);
  width: 100%;
}
.contact-detail__row--phones,
.contact-detail__row--wa {
  align-items: start;
}
.contact-detail__phone-lines {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
  min-width: 0;
}
.contact-detail__phone-line {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 8px 12px;
}
.contact-detail__phone-line + .contact-detail__phone-line {
  margin-top: 0.35em;
}
.contact-detail__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  color: #22282c;
}
.contact-detail__icon svg {
  width: 24px;
  height: 24px;
  display: block;
}
.contact-detail__icon--wa { color: var(--brand-green); }
.contact-detail__label {
  flex: 0 0 auto;
  min-width: 48px;
}
.contact-detail__link {
  font-family: var(--tile-cta-font);
  font-size: var(--tile-cta-size);
  line-height: var(--tile-cta-lh);
  letter-spacing: var(--tile-cta-track);
  font-weight: 400;
  color: var(--split-tile-body-color);
  text-decoration: none;
  transition: opacity 0.2s ease;
}
.contact-detail__link:hover {
  opacity: 0.82;
  text-decoration: none;
}

/* Kontakt — CTA w kafelkach jak na pozostałych podstronach */
.page-key-contact .contact-mosaic .split__copy .inline-cta a.split-tile-cta-link {
  font-family: var(--tile-cta-font);
  font-size: var(--tile-cta-size);
  line-height: var(--tile-cta-lh);
  letter-spacing: var(--tile-cta-track);
  font-weight: 400;
  text-decoration: none;
}
.page-key-contact .contact-mosaic .split-light .split__copy .inline-cta a.split-tile-cta-link {
  color: var(--split-tile-body-color);
}
.page-key-contact .contact-mosaic .split-dark .split__copy .inline-cta a.split-tile-cta-link {
  color: var(--dark-showroom-body-color);
}

@media (max-width: 1280px) {
  .page-key-contact .hero-inner { min-height: min(calc(100vw * 576 / 1024.5), 720px); }
  .page-key-contact .contact-mosaic {
    grid-template-rows: repeat(3, min(calc(100vw * 576 / 1024.5), 720px));
  }
  .page-key-contact .contact-mosaic__cell--copy-1 { padding: 38px 44px 36px; }
  .page-key-contact .contact-mosaic__cell--copy-2 { padding: 88px 52px 40px; }
  .page-key-contact .contact-mosaic__cell--copy-3 { padding: 64px 52px 40px; }
  .page-key-contact .contact-mosaic__cell h2 { font-size: clamp(28px, 3.2vw, 37.334px); }
}
@media (max-width: 980px) {
  .page-key-contact .hero-inner { min-height: min(56vw, 520px); }
  .page-key-contact .contact-mosaic {
    grid-template-columns: 1fr;
    grid-template-rows: repeat(6, min(56vw, 520px));
  }
  .page-key-contact .contact-mosaic__cell--media-1 { grid-area: 1 / 1; }
  .page-key-contact .contact-mosaic__cell--copy-1 { grid-area: 2 / 1; }
  .page-key-contact .contact-mosaic__cell--copy-2 { grid-area: 3 / 1; }
  .page-key-contact .contact-mosaic__cell--media-2 { grid-area: 4 / 1; }
  .page-key-contact .contact-mosaic__cell--copy-3 { grid-area: 5 / 1; }
  .page-key-contact .contact-mosaic__cell--media-3 { grid-area: 6 / 1; }
  .page-key-contact .contact-mosaic__cell--copy-1,
  .page-key-contact .contact-mosaic__cell--copy-2,
  .page-key-contact .contact-mosaic__cell--copy-3 {
    padding: 32px 28px 36px;
  }
  .page-key-contact .contact-mosaic__cell--copy-2 { padding-top: 48px; }
  .page-key-contact .contact-mosaic__cell--copy-3 { padding-top: 40px; }
  .page-key-contact .split__copy h2 { margin-bottom: 20px; font-size: clamp(24px, 4.5vw, 32px); }
  .page-key-contact .split-light .split__copy p,
  .page-key-contact .split-light .split__copy .copy-list li,
  .page-key-contact .split-dark .split__copy p,
  .page-key-contact .split-dark .split__copy .copy-list li,
  .contact-detail__intro,
  .contact-detail__block p,
  .contact-detail__heading,
  .contact-detail__label {
    font-size: 13.333px;
  }
  .contact-detail__link { font-size: var(--tile-cta-size); line-height: var(--tile-cta-lh); }
  .contact-detail__rows { margin-bottom: 32px; }
}
@media (max-width: 640px) {
  .page-key-contact .hero-inner { min-height: 340px; }
  .page-key-contact .contact-mosaic {
    grid-template-rows: repeat(6, min(72vw, 480px));
  }
  .page-key-contact .contact-mosaic__cell--copy-1,
  .page-key-contact .contact-mosaic__cell--copy-2,
  .page-key-contact .contact-mosaic__cell--copy-3 {
    padding: 24px 20px 28px;
  }
  .page-key-contact .contact-mosaic__cell--copy-2 { padding-top: 36px; }
  .page-key-contact .contact-mosaic__cell h2 { font-size: clamp(22px, 6vw, 28px); margin-bottom: 16px; }
  .contact-detail__icon,
  .contact-detail__icon svg { width: 22px; height: 22px; }
  .contact-detail__row { grid-template-columns: 26px minmax(0, 1fr); }
  .contact-detail__link { font-size: var(--tile-cta-size); }
}

/* ================================================
   O nas – Canva PDF 1024.5×576 pt (kafelki 1:1 z eksportu)
   ================================================ */
.page-key-about .hero-inner {
  min-height: max(280px, min(58vh, calc(100vw * 576 / 1024.5)));
  background-position: center calc(42% + var(--hero-bg-y-nudge));
  background-size: cover;
}
.page-key-about .hero-content {
  padding-bottom: 72px;
}
.page-key-about .hero-row {
  gap: 24px;
}
.page-key-about .hero-subline {
  display: none;
}
.page-key-about .hero-row__left {
  padding: 0 0 14px;
}
.page-key-about .hero h1 {
  font-size: var(--inner-hero-title-size);
  font-weight: 300;
  letter-spacing: var(--inner-hero-title-track);
  line-height: var(--inner-hero-title-lh);
}
.page-key-about .hero-row__right .outline-button {
  min-width: clamp(200px, 20vw, 288px);
  justify-content: space-between;
  letter-spacing: var(--outline-button-track);
  padding: 8px 16px;
}

.page-key-about .split .site-limit {
  width: 100%;
  max-width: 100%;
  margin: 0 auto;
  padding: 0;
}
@media (min-width: 901px) {
  .page-key-about .split__inner {
    min-height: 0;
    aspect-ratio: 1024.5 / 576;
    max-height: none;
  }
  .page-key-about .split__copy {
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
}
.page-key-about .split__copy {
  padding: clamp(52px, 4.6vw, 78px) clamp(40px, 3.6vw, 66px);
  justify-content: flex-start;
}
.page-key-about .split__copy p + p {
  margin-top: 0.65em;
}
.page-key-about .split-light .split__copy {
  background: var(--split-light-bg);
}
.page-key-about .split-dark .split__copy {
  background: var(--brand-graphite);
}

.page-key-about .split-light .split__copy h2 {
  margin: 0 0 28px;
  padding-bottom: 0;
  border-bottom: 0;
  font-family: var(--split-light-title-font);
  font-size: var(--split-light-title-size);
  font-weight: var(--split-light-title-weight);
  line-height: var(--split-light-title-lh);
  letter-spacing: var(--split-light-title-track);
  color: var(--split-light-title-color);
  text-wrap: balance;
}
.page-key-about .split-light .split__copy h2::after {
  content: "";
  display: block;
  width: 52px;
  height: 2px;
  background: var(--split-light-title-color);
  margin-top: 24px;
  opacity: 0.35;
}
.page-key-about .split-dark .split__copy h2 {
  margin: 0 0 28px;
  padding-bottom: 0;
  border-bottom: 0;
  font-family: var(--dark-showroom-title-font);
  font-size: var(--dark-showroom-title-size);
  font-weight: var(--dark-showroom-title-weight);
  line-height: var(--dark-showroom-title-lh);
  letter-spacing: var(--dark-showroom-title-track);
  color: var(--dark-showroom-title-color);
  text-wrap: balance;
}
.page-key-about .split-dark .split__copy h2::after {
  display: none;
}
.page-key-about .split-dark .split__copy p {
  font-family: var(--dark-showroom-body-font);
  font-size: var(--dark-showroom-body-size);
  line-height: var(--dark-showroom-body-lh);
  letter-spacing: var(--dark-showroom-body-track);
  color: var(--dark-showroom-body-color);
  max-width: 100%;
}
.page-key-about .split-dark .split__copy p strong {
  font-weight: 500;
  color: #fff;
}
.page-key-about .split-light .split__copy .inline-cta {
  margin-top: clamp(20px, 2.2vw, 32px);
}
.page-key-about .split-dark .copy-list li {
  font-family: var(--dark-showroom-body-font);
  font-size: var(--dark-showroom-body-size);
  line-height: var(--dark-showroom-body-lh);
  letter-spacing: var(--dark-showroom-body-track);
  color: var(--dark-showroom-body-color);
}

.page-key-about .split__media {
  min-height: 0;
  height: 100%;
  overflow: hidden;
}
.page-key-about .split__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Kadrowanie per slajd (kolejność = PDF / Canva) */
.page-key-about .split-index-1.split-media-about-media .split__media img {
  object-position: 48% 42%;
}
.page-key-about .split-index-2.split-media-about-cinema .split__media img {
  object-position: 50% 48%;
}
.page-key-about .split-index-3.split-media-about-cinema .split__media img {
  object-position: 52% 45%;
}
.page-key-about .split-index-4.split-media-about-swatches .split__media img {
  object-position: 50% 44%;
}
.page-key-about .split-index-5.split-media-about-swatches .split__media img {
  object-position: 48% 50%;
}
.page-key-about .split-index-6.split-media-about-modern .split__media img {
  object-position: 50% 62%;
}
.page-key-about .split-index-7.split-media-about-modern .split__media img {
  object-position: 50% 58%;
}

@media (max-width: 1280px) {
  .page-key-about .hero-inner {
    min-height: max(260px, min(52vh, calc(100vw * 576 / 1024.5)));
  }
  .page-key-about .hero-content {
    padding-bottom: 64px;
  }
  .page-key-about .split__copy {
    padding: 48px 42px 40px;
  }
}

@media (max-width: 980px) {
  .page-key-about .hero-inner {
    min-height: 420px;
    background-position: center calc(40% + var(--hero-bg-y-nudge));
  }
  .page-key-about .hero-content {
    padding-bottom: 60px;
  }
  .page-key-about .split__inner {
    height: auto;
    min-height: 0;
    aspect-ratio: auto;
  }
  .page-key-about .split__media {
    min-height: min(72vw, 420px);
    height: auto;
  }
  .page-key-about .split__media img {
    min-height: min(72vw, 420px);
  }
  .page-key-about .split__copy {
    padding: 30px 26px;
  }
}

/* ================================================
   Kino w Salonie (Soundwall – Canva PDF 1024.5×576)
   ================================================ */
.kino-soundwall-canva-layout .hero-inner {
  min-height: min(86vh, 820px);
  background-position: center calc(44% + var(--hero-bg-y-nudge));
  background-size: cover;
}
.kino-soundwall-canva-layout .hero-content { padding-bottom: 94px; }
.kino-soundwall-canva-layout .hero-subline {
  display: block;
  margin: 0.35em 0 0;
  font-family: var(--font-body);
  font-size: clamp(13px, 1.1vw, 15px);
  letter-spacing: 0.04em;
  color: rgba(236, 236, 236, 0.92);
  max-width: 28em;
}
.kino-soundwall-canva-layout .hero-row { gap: 24px; }
.kino-soundwall-canva-layout .hero-row__left {
  padding: 0 0 14px;
}
.kino-soundwall-canva-layout .hero-row__right { padding: 0 12px 8px 0; }

/* Splity na pełną szerokość — bez białych marginesów po bokach */
.kino-soundwall-canva-layout .split {
  width: 100%;
  max-width: 100%;
}
.kino-soundwall-canva-layout .split .site-limit {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
}
.kino-soundwall-canva-layout .split__inner {
  width: 100%;
  max-width: none;
}
@media (min-width: 901px) {
  .kino-soundwall-canva-layout .split__inner {
    aspect-ratio: auto;
    min-height: min(calc(100vw * 576 / 1024.5), 900px);
    height: auto;
  }
  .kino-soundwall-canva-layout .split__copy,
  .kino-soundwall-canva-layout .split__media {
    min-height: min(calc(100vw * 576 / 1024.5), 900px);
  }
  .kino-soundwall-canva-layout .split__copy {
    overflow: visible;
    z-index: 1;
  }
}
/* Canva Soundwall PDF — wcięcia i rytm kolumny tekstu (slajd 1024,5×576) */
.kino-soundwall-canva-layout {
  --soundwall-copy-pad-y: clamp(56px, 5.15vw, 82px);
  --soundwall-copy-pad-x: clamp(44px, 4.05vw, 68px);
  --soundwall-h2-mb: clamp(22px, 2vw, 30px);
  --soundwall-body-gap: 0.85em;
  --soundwall-cta-pad-top: clamp(42px, 3.85vw, 58px);
  --soundwall-extra-gap: clamp(30px, 2.9vw, 46px);
  --soundwall-extra-cta-pad: clamp(14px, 1.35vw, 22px);
}
.kino-soundwall-canva-layout .split__copy {
  padding: var(--soundwall-copy-pad-y) var(--soundwall-copy-pad-x);
  justify-content: flex-start;
  min-height: 100%;
}
.kino-soundwall-canva-layout .split__copy p + p { margin-top: var(--soundwall-body-gap); }
.kino-soundwall-canva-layout .split-light .split__copy p {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--split-tile-body-size);
  line-height: var(--split-tile-body-lh);
  letter-spacing: var(--split-tile-body-track);
  color: var(--split-tile-body-color);
  text-align: left;
}
.kino-soundwall-canva-layout .split-light .split__copy p + p {
  margin-top: var(--soundwall-body-gap);
}
.kino-soundwall-canva-layout .split-light .split__copy { background: var(--split-light-bg); }
.kino-soundwall-canva-layout .split-dark .split__copy { background: var(--brand-graphite); }

/* Kolejność kolumn jak na screenach PDF (zdjęcie | tekst lub tekst | zdjęcie) */
.kino-soundwall-canva-layout .split-index-1 .split__copy,
.kino-soundwall-canva-layout .split-index-4 .split__copy,
.kino-soundwall-canva-layout .split-index-6 .split__copy { order: 1; }
.kino-soundwall-canva-layout .split-index-1 .split__media,
.kino-soundwall-canva-layout .split-index-4 .split__media,
.kino-soundwall-canva-layout .split-index-6 .split__media { order: 2; }
/* Slajd 2: tekst lewo, zdjęcie prawo (jak PDF) */
.kino-soundwall-canva-layout .split-index-2 .split__copy { order: 1; }
.kino-soundwall-canva-layout .split-index-2 .split__media { order: 2; }
/* Slajdy 3 i 5: zdjęcie lewo, tekst prawo */
.kino-soundwall-canva-layout .split-index-3 .split__media,
.kino-soundwall-canva-layout .split-index-5 .split__media { order: 1; }
.kino-soundwall-canva-layout .split-index-3 .split__copy,
.kino-soundwall-canva-layout .split-index-5 .split__copy { order: 2; }

/* CTA — prawy dolny róg kolumny; tekst + strzałka jak w Canva (split-tile-cta-link i soundwall-cta-link) */
.kino-soundwall-canva-layout .split__copy .inline-cta,
.kino-soundwall-canva-layout .split__copy .split-extra-block .inline-cta--extra {
  margin-top: auto;
  margin-left: auto;
  margin-right: 0;
  align-self: flex-end;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  text-align: right;
  padding-top: var(--soundwall-cta-pad-top);
  padding-bottom: 4px;
  overflow: visible;
  position: relative;
  z-index: 2;
}
.kino-soundwall-canva-layout .split__copy .inline-cta a.split-tile-cta-link,
.kino-soundwall-canva-layout .split__copy .inline-cta a.soundwall-cta-link,
.kino-soundwall-canva-layout .split__copy .split-extra-block .inline-cta--extra a.split-tile-cta-link,
.kino-soundwall-canva-layout .split__copy .split-extra-block .inline-cta--extra a.soundwall-cta-link {
  max-width: 100%;
  margin-left: auto;
  flex-wrap: nowrap;
  align-items: center;
}
.kino-soundwall-canva-layout .split__copy .inline-cta .soundwall-cta-link__text,
.kino-soundwall-canva-layout .split__copy .inline-cta .split-tile-cta-link__text,
.kino-soundwall-canva-layout .split__copy .split-extra-block .inline-cta--extra .soundwall-cta-link__text,
.kino-soundwall-canva-layout .split__copy .split-extra-block .inline-cta--extra .split-tile-cta-link__text {
  display: block;
  text-align: center;
  width: max-content;
  max-width: min(100%, 300px);
  margin-left: auto;
}
.kino-soundwall-canva-layout .split-index-1 .soundwall-cta-link__text,
.kino-soundwall-canva-layout .split-index-1 .split-tile-cta-link__text { max-width: min(100%, 252px); }
.kino-soundwall-canva-layout .split-index-2 .soundwall-cta-link__text,
.kino-soundwall-canva-layout .split-index-2 .split-tile-cta-link__text { max-width: min(100%, 292px); }
.kino-soundwall-canva-layout .split-index-3 .soundwall-cta-link__text,
.kino-soundwall-canva-layout .split-index-3 .split-tile-cta-link__text { max-width: min(100%, 278px); }
.kino-soundwall-canva-layout .split-index-4 .soundwall-cta-link__text,
.kino-soundwall-canva-layout .split-index-4 .split-tile-cta-link__text { max-width: min(100%, 248px); }
.kino-soundwall-canva-layout .split-index-5 .soundwall-cta-link__text,
.kino-soundwall-canva-layout .split-index-5 .split-tile-cta-link__text { max-width: min(100%, 220px); }
.kino-soundwall-canva-layout .split-index-6 .soundwall-cta-link__text,
.kino-soundwall-canva-layout .split-index-6 .split-tile-cta-link__text { max-width: min(100%, 268px); }
.kino-soundwall-canva-layout .split__copy .inline-cta .soundwall-cta-link__line,
.kino-soundwall-canva-layout .split__copy .inline-cta .split-tile-cta-link__line,
.kino-soundwall-canva-layout .split__copy .split-extra-block .inline-cta--extra .soundwall-cta-link__line,
.kino-soundwall-canva-layout .split__copy .split-extra-block .inline-cta--extra .split-tile-cta-link__line {
  display: block;
  white-space: nowrap;
  text-align: center;
  padding-inline-end: 0;
}
.kino-soundwall-canva-layout .split__copy .inline-cta .soundwall-cta-link__line + .soundwall-cta-link__line,
.kino-soundwall-canva-layout .split__copy .inline-cta .split-tile-cta-link__line + .split-tile-cta-link__line,
.kino-soundwall-canva-layout .split__copy .split-extra-block .inline-cta--extra .soundwall-cta-link__line + .soundwall-cta-link__line,
.kino-soundwall-canva-layout .split__copy .split-extra-block .inline-cta--extra .split-tile-cta-link__line + .split-tile-cta-link__line {
  margin-top: 0;
}
.kino-soundwall-canva-layout .split__copy .inline-cta .soundwall-cta-link__arrow,
.kino-soundwall-canva-layout .split__copy .inline-cta .split-tile-cta-link__arrow,
.kino-soundwall-canva-layout .split__copy .split-extra-block .inline-cta--extra .soundwall-cta-link__arrow,
.kino-soundwall-canva-layout .split__copy .split-extra-block .inline-cta--extra .split-tile-cta-link__arrow {
  flex-shrink: 0;
  align-self: center;
}
.kino-soundwall-canva-layout .split-light .split__copy a.soundwall-cta-link,
.kino-soundwall-canva-layout .split-light .split__copy a.split-tile-cta-link {
  color: var(--split-tile-body-color);
}
.kino-soundwall-canva-layout .split-dark .split__copy a.soundwall-cta-link,
.kino-soundwall-canva-layout .split-dark .split__copy a.split-tile-cta-link {
  color: rgba(236, 236, 236, 0.95);
}
.kino-soundwall-canva-layout .split-index-6 .split__copy > .split-extra-block:first-of-type {
  margin-top: auto;
}
.kino-soundwall-canva-layout .split-extra-block {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}
.kino-soundwall-canva-layout .split-extra-block + .split-extra-block {
  margin-top: var(--soundwall-extra-gap);
}
.kino-soundwall-canva-layout .split-extra-block .inline-cta--extra {
  padding-top: var(--soundwall-extra-cta-pad);
  margin-left: auto;
  margin-right: 0;
  align-self: flex-end;
  width: auto;
}
.kino-soundwall-canva-layout .split-extra-block > p + .inline-cta--extra {
  padding-top: clamp(18px, 1.7vw, 26px);
}
.kino-soundwall-canva-layout .split-extra-block > p {
  font-family: var(--dark-showroom-body-font);
  font-size: var(--dark-showroom-body-size);
  line-height: var(--dark-showroom-body-lh);
  letter-spacing: var(--dark-showroom-body-track);
  color: var(--dark-showroom-body-color);
  margin: 0;
  text-align: left;
  align-self: stretch;
  width: 100%;
}
.kino-soundwall-canva-layout .split-index-6.split-dark .split-extra-block > p {
  font-size: 12px;
  line-height: 1.85;
  letter-spacing: 0.06em;
}

.kino-soundwall-canva-layout .split-light .split__copy h2 {
  margin: 0 0 var(--soundwall-h2-mb);
  padding-bottom: 0;
  border-bottom: 0;
  font-family: var(--split-light-title-font);
  font-size: var(--split-light-title-size);
  font-weight: var(--split-light-title-weight);
  line-height: var(--split-light-title-lh);
  letter-spacing: var(--split-light-title-track);
  color: var(--split-light-title-color);
  text-wrap: balance;
}
.kino-soundwall-canva-layout .split-light .split__copy h2::after {
  content: "";
  display: block;
  width: 52px;
  height: 2px;
  background: var(--split-light-title-color);
  margin-top: clamp(18px, 1.75vw, 24px);
  opacity: 0.7;
}
.kino-soundwall-canva-layout .split-dark .split__copy h2 {
  margin: 0 0 var(--soundwall-h2-mb);
  padding-bottom: 0;
  border-bottom: 0;
  font-family: var(--dark-showroom-title-font);
  font-size: var(--dark-showroom-title-size);
  font-weight: var(--dark-showroom-title-weight);
  line-height: var(--dark-showroom-title-lh);
  letter-spacing: var(--dark-showroom-title-track);
  color: var(--dark-showroom-title-color);
  text-wrap: balance;
  text-transform: none;
}
.kino-soundwall-canva-layout .split-dark .split__copy h2::after { display: none; }
.kino-soundwall-canva-layout .split-dark .split__copy p {
  font-family: var(--dark-showroom-body-font);
  font-size: var(--dark-showroom-body-size);
  line-height: var(--dark-showroom-body-lh);
  letter-spacing: var(--dark-showroom-body-track);
  color: var(--dark-showroom-body-color);
  max-width: 100%;
}
.kino-soundwall-canva-layout .split-index-6.split-dark .split__copy > p {
  font-size: 12px;
  line-height: 1.85;
  letter-spacing: 0.06em;
}

/* Slajd 1 Canva: wideo/obraz na pełną wysokość kolumny */
.kino-soundwall-canva-layout .split__media {
  min-height: 100%;
  overflow: hidden;
}
.kino-soundwall-canva-layout .split-index-1 .split__media {
  display: block;
  background: var(--brand-graphite);
}
.kino-soundwall-canva-layout .split-index-1.split-media-soundwall-intro-video .split__media video,
.kino-soundwall-canva-layout .split-index-1.split-media-soundwall-intro-video .split__media img {
  width: 100%;
  height: 100%;
  min-height: 100%;
  max-width: none;
  aspect-ratio: auto;
  object-fit: cover;
  object-position: 50% 44%;
  display: block;
}

/* Drugi render Canvy (hex / symetria) – inne kadry per slajd PDF */
.kino-soundwall-canva-layout .split-index-2.split-media-soundwall-media-alt .split__media img {
	object-position: 50% 34%;
}
.kino-soundwall-canva-layout .split-index-3.split-media-soundwall-mini .split__media img {
	object-position: 34% 48%;
}
.kino-soundwall-canva-layout .split-index-4.split-media-soundwall-trimless .split__media img {
	object-position: 52% 40%;
}
.kino-soundwall-canva-layout .split-index-5.split-media-soundwall-custom .split__media img {
	object-position: 56% 48%;
}
.kino-soundwall-canva-layout .split-index-6.split-media-soundwall-why .split__media img {
	object-position: 58% 56%;
	transform: scale(1.03);
}
.kino-soundwall-canva-layout .split-index-6 .split__media img {
  transform-origin: center center;
}

.kino-soundwall-canva-layout .split-extra-block { margin-top: 0; }

/* ================================================
   Audio w domu – Canva PDF (jak Kino w salonie: 1024.5×576, typografia tokenów)
   ================================================ */
.page-key-audio .hero-inner {
  min-height: min(86vh, 820px);
  background-position: center calc(44% + var(--hero-bg-y-nudge));
  background-size: cover;
}
.page-key-audio .hero-content { padding-bottom: 94px; }
.page-key-audio .hero-subline { display: none; }
.page-key-audio .hero-row { gap: 24px; }
.page-key-audio .hero-row__left {
  padding: 0 0 14px;
}
.page-key-audio .hero-row__right { padding: 0 12px 8px 0; }
.page-key-audio .hero-row__right .outline-button {
  min-width: clamp(200px, 18vw, 320px);
  justify-content: space-between;
  padding: 8px 16px;
  letter-spacing: var(--outline-button-track);
}

/* Splity na pełną szerokość — bez białych marginesów po bokach */
.page-key-audio .split {
  width: 100%;
  max-width: 100%;
}
.page-key-audio .split .site-limit {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
}
.page-key-audio .split__inner {
  width: 100%;
  max-width: none;
}
@media (min-width: 901px) {
  .page-key-audio .split__inner {
    min-height: 0;
    aspect-ratio: 1024.5 / 576;
    max-height: none;
  }
  .page-key-audio .split__copy {
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
}
.page-key-audio .split__copy {
  padding: clamp(52px, 4.6vw, 78px) clamp(40px, 3.6vw, 66px);
  justify-content: flex-start;
}
.page-key-audio .split__copy p + p { margin-top: 0.65em; }
.page-key-audio .split-light .split__copy { background: var(--split-light-bg); }
.page-key-audio .split-dark .split__copy { background: var(--brand-graphite); }

.page-key-audio .split-light .split__copy h2 {
  margin: 0 0 28px;
  padding-bottom: 0;
  border-bottom: 0;
  font-family: var(--split-light-title-font);
  font-size: var(--split-light-title-size);
  font-weight: var(--split-light-title-weight);
  line-height: var(--split-light-title-lh);
  letter-spacing: var(--split-light-title-track);
  color: var(--split-light-title-color);
  text-wrap: balance;
}
.page-key-audio .split-light .split__copy h2::after {
  content: "";
  display: block;
  width: 52px;
  height: 2px;
  background: var(--split-light-title-color);
  margin-top: 24px;
  opacity: 0.7;
}
.page-key-audio .split-dark .split__copy h2 {
  margin: 0 0 28px;
  padding-bottom: 0;
  border-bottom: 0;
  font-family: var(--dark-showroom-title-font);
  font-size: var(--dark-showroom-title-size);
  font-weight: var(--dark-showroom-title-weight);
  line-height: var(--dark-showroom-title-lh);
  letter-spacing: var(--dark-showroom-title-track);
  color: var(--dark-showroom-title-color);
  text-wrap: balance;
}
.page-key-audio .split-dark .split__copy h2::after { display: none; }
.page-key-audio .split-dark .split__copy p {
  font-family: var(--dark-showroom-body-font);
  font-size: var(--dark-showroom-body-size);
  line-height: var(--dark-showroom-body-lh);
  letter-spacing: var(--dark-showroom-body-track);
  color: var(--dark-showroom-body-color);
  max-width: 100%;
}

.page-key-audio .copy-list {
  margin: 0.65em 0 0;
  display: grid;
  gap: 0.35em;
}
.page-key-audio .split-light .copy-list li {
  color: var(--split-tile-body-color);
  font-family: 'Roboto', sans-serif;
  font-size: var(--split-tile-body-size);
  font-weight: 400;
  line-height: var(--split-tile-body-lh);
  letter-spacing: var(--split-tile-body-track);
  padding-left: 14px;
  margin-top: 0;
}
.page-key-audio .split-dark .copy-list li {
  color: var(--dark-showroom-body-color);
  font-family: var(--dark-showroom-body-font);
  font-size: var(--dark-showroom-body-size);
  line-height: var(--dark-showroom-body-lh);
  letter-spacing: var(--dark-showroom-body-track);
  padding-left: 14px;
  margin-top: 0;
}

.page-key-audio .split__media {
  min-height: 0;
  overflow: hidden;
}
.page-key-audio .split__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.page-key-audio .inline-cta { padding-top: clamp(28px, 3.2vw, 48px); }

.page-key-audio .split-extra-block { margin-top: clamp(28px, 3vw, 56px); }
.page-key-audio .split-extra-block p {
  font-family: 'Roboto', sans-serif;
  font-size: var(--split-tile-body-size);
  line-height: var(--split-tile-body-lh);
  letter-spacing: var(--split-tile-body-track);
  color: var(--split-tile-body-color);
  margin: 0;
}
.page-key-audio .inline-cta--extra {
  margin-top: 12px;
  padding-top: clamp(16px, 2vw, 24px);
}
.page-key-audio .split-index-1 .split__copy { order: 2; }
.page-key-audio .split-index-1 .split__media { order: 1; }
.page-key-audio .split-index-2 .split__copy,
.page-key-audio .split-index-3 .split__copy { order: 1; }
.page-key-audio .split-index-2 .split__media,
.page-key-audio .split-index-3 .split__media { order: 2; }
.page-key-audio .split-index-4 .split__copy { order: 2; }
.page-key-audio .split-index-4 .split__media { order: 1; }

.page-key-audio .split-index-1 .split__media img { object-position: 50% 52%; }
.page-key-audio .split-index-2 .split__media img { object-position: 50% 48%; }
.page-key-audio .split-index-3 .split__media img { object-position: 50% 44%; }
.page-key-audio .split-index-4 .split__media img { object-position: 50% 56%; }

.page-key-audio .split-index-2 .split__media {
  position: relative;
  overflow: hidden;
  background: transparent;
  filter: none;
}
.page-key-audio .split-index-2 .split__media::before,
.page-key-audio .split-index-2 .split__media::after { display: none; }

.page-key-audio .split-index-3 .split__copy h2 { max-width: 100%; }

.page-key-audio .split-index-4 .split__copy { justify-content: flex-start; }

/* ================================================
   Wiedza Canva 1:1 (PDF „Kopia – Wiedza”, 1024.5×576 pt)
   ================================================ */
.layout-knowledge-canva {
  /* Szerokość odniesienia = min(viewport, skala z PDF pt → px @96dpi) */
  --kc-ref: min(100vw, calc(1024.5 * 96px / 72));
  --kc-pdf-w: 1024.5;
  --kc-gap: 24.47;
  --kc-pad-x: 57.6;
  --kc-pad-foot: 309.15;
  --kc-tile-caption-h: 40%;
  --kc-tile-caption-bg: rgba(0, 0, 0, 0.62);
}

.layout-knowledge-canva .knowledge-canva-hero {
  /* Ramka 16:9 jak slajd Canvy */
  width: 100%;
  aspect-ratio: 1024.5 / 576;
  min-height: max(280px, min(72vh, calc(100vw * 576 / 1024.5)));
  background-size: cover;
  /* Kadrowanie dużego zdjęcia w PDF (środek pionowo ~26%) */
  background-position: 50% calc(26.2% - 50px + var(--hero-bg-y-nudge));
}

.layout-knowledge-canva .knowledge-canva-hero .hero-overlay {
  background: linear-gradient(
    to top,
    rgba(0, 0, 0, 0.48) 0%,
    rgba(0, 0, 0, 0.4) 14%,
    rgba(0, 0, 0, 0.16) 28%,
    transparent 44%
  );
}

.layout-knowledge-canva .site-header::before {
  background: linear-gradient(to bottom, rgba(10, 14, 20, 0.36), rgba(10, 14, 20, 0.08));
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.layout-knowledge-canva .knowledge-canva-hero .hero-content {
  max-width: min(var(--site-width), calc(1024.5 * 96px / 72));
  margin-inline: auto;
  /* Tytuł ~64.8 / 1024.5, CTA kończy się ~924 → ~9.8% od prawej krawędzi slajdu */
  padding-inline: calc(var(--kc-ref) * 64.83 / var(--kc-pdf-w)) calc(var(--kc-ref) * 100.5 / var(--kc-pdf-w));
  /* Dół slajdu: linia CTA ~504 / 576 od góry → ~72 pt nad dolną krawędzią */
  padding-bottom: calc(var(--kc-ref) * 72 / var(--kc-pdf-w));
}

.layout-knowledge-canva .knowledge-canva-hero .hero-row {
  grid-template-columns: minmax(0, 50%) auto;
  gap: calc(var(--kc-ref) * 20 / var(--kc-pdf-w));
  align-items: end;
}

.layout-knowledge-canva .knowledge-canva-hero .hero-row__left {
  padding-bottom: calc(var(--kc-ref) * 14 / var(--kc-pdf-w));
}

/* „Wiedza” — eksport Canva www: Space Grotesk 40 px, tracking 115, interlinia 2 (jak „O nas”) */
.layout-knowledge-canva .knowledge-canva-hero h1 {
  font-size: clamp(26px, calc(var(--kc-ref) * 40 / var(--kc-pdf-w)), 40px);
  line-height: var(--inner-hero-title-lh);
  letter-spacing: var(--inner-hero-title-track);
  font-weight: 300;
}

/* CTA hero — Canva: Roboto Mono ~17,33 px, tracking 65, uppercase (tekst w szablonie PL jest caps) */
.layout-knowledge-canva .knowledge-canva-hero .outline-button {
  margin-top: 0;
  min-width: clamp(180px, calc(var(--kc-ref) * 280 / var(--kc-pdf-w)), 300px);
  justify-content: space-between;
  padding: calc(var(--kc-ref) * 8 / var(--kc-pdf-w)) calc(var(--kc-ref) * 16 / var(--kc-pdf-w));
  font-family: var(--font-outline-cta);
  font-weight: 400;
  letter-spacing: var(--outline-button-track);
  line-height: var(--outline-button-lh);
  text-transform: uppercase;
  border-color: rgba(255, 255, 255, 0.74);
  color: rgba(235, 237, 236, 0.95);
  font-size: clamp(12px, calc(var(--kc-ref) * 17.333 / var(--kc-pdf-w)), 17.333px);
}

.knowledge-canva-grid {
  background: var(--brand-light);
  padding-top: calc(var(--kc-ref) * 57.6 / var(--kc-pdf-w));
  padding-bottom: calc(var(--kc-ref) * var(--kc-pad-foot) / var(--kc-pdf-w));
}

.knowledge-canva-grid__inner {
  box-sizing: border-box;
  width: 100%;
  max-width: min(100%, calc(1024.5 * 96px / 72));
  margin-inline: auto;
  padding-inline: calc(var(--kc-ref) * var(--kc-pad-x) / var(--kc-pdf-w));
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  column-gap: calc(var(--kc-ref) * var(--kc-gap) / var(--kc-pdf-w));
  row-gap: 0;
}

.knowledge-canva-card {
  position: relative;
  aspect-ratio: 1;
  width: 100%;
  overflow: hidden;
  background: var(--brand-graphite);
  display: block;
  color: inherit;
  text-decoration: none;
  cursor: pointer;
  transition: transform 0.22s ease, box-shadow 0.22s ease;
}

.knowledge-canva-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.18);
}

.knowledge-canva-card:focus-visible {
  outline: 2px solid var(--brand-red);
  outline-offset: 3px;
  z-index: 1;
}

.knowledge-canva-card img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.knowledge-canva-card__overlay {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  height: var(--kc-tile-caption-h);
  box-sizing: border-box;
  padding: 0 8%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--kc-tile-caption-bg);
  pointer-events: none;
  transition: background 0.22s ease;
}

.knowledge-canva-card:hover .knowledge-canva-card__overlay {
  background: rgba(0, 0, 0, 0.68);
}

/* Tekst na kafelku — Canva slajd 2: Roboto ~13,33 px, tracking 91, #fff, wyśrodkowany w pasie */
.knowledge-canva-card__overlay p {
  margin: 0;
  color: #fff;
  font-family: var(--font-body);
  font-size: clamp(11px, calc(var(--kc-ref) * 13.3333 / var(--kc-pdf-w)), 14px);
  line-height: 1.35;
  letter-spacing: var(--split-tile-body-track);
  font-weight: 400;
  text-align: center;
  white-space: normal;
}

/* Sekcja 2: multiroom z owalem */
.page-key-audio .split-index-2 .split__media {
  position: relative;
  overflow: hidden;
  background: transparent;
  filter: none;
}
.page-key-audio .split-index-2 .split__media img { opacity: 1; }
.page-key-audio .split-index-2 .split__media::before,
.page-key-audio .split-index-2 .split__media::after { display: none; }

/* Sekcja 3: pokoj odsluchowy */
.page-key-audio .split-index-3 .split__copy h2 { max-width: 96%; }
.page-key-audio .split-index-3 .split__media img { object-position: center 45%; }

/* Sekcja 4: audio na zamowienie + FAQ + kontakt */
.page-key-audio .split-index-4 .split__inner { min-height: clamp(720px, 56vw, 1110px); }
.page-key-audio .split-index-4 .split__copy { justify-content: flex-start; }
.page-key-audio .split-index-4 .split__copy p { max-width: 100%; }
.page-key-audio .split-index-4 .split__media img { object-position: center 58%; }

/* ================================================
   Realizacje Showcase – Project Blocks
   ================================================ */
.project-block {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 620px;
}
.project-block--light { background: var(--bg-soft); color: var(--text-main); }
.project-block--dark  { background: var(--bg-dark);  color: var(--tint-white); }

.project-block--reversed .project-block__media { order: 2; }
.project-block--reversed .project-block__copy  { order: 1; }

.project-block__media {
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.project-block__media img {
  flex: 1;
  width: 100%;
  min-height: 0;
  object-fit: cover;
  display: block;
}

.project-block__copy {
  display: flex;
  align-items: center;
  padding: 60px 80px;
}
.project-block__lines {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.project-block__line {
  font-family: var(--font-body);
  font-size: var(--bb-h3-size);
  font-weight: 300;
  line-height: var(--bb-h3-lh);
  letter-spacing: var(--bb-h3-track);
}

/*
 * Realizacje (szablon Showcase) — typografia i kafle 1:1 z Canva „Kopia – Realizacje”:
 * slajd 1366×768, opisy Roboto 20 px, leading 2000‰, tracking 91‰; dwa kafle 350,24165×650,92957 px, gutter ~26,98 px;
 * jeden szeroki kadr 729,158×653,224 px; jasne tło #ececec / ciemne #22282c.
 */
.layout-realizacje-showcase.page-key-projects .hero-inner {
  min-height: min(calc(100vw * 768 / 1366), 768px);
  /* Odpowiednik przesunięcia kadru z Canva (fill −299 px na bok 1366) */
  background-position: 62% calc(44% + var(--hero-bg-y-nudge));
}
.layout-realizacje-showcase.page-key-projects .hero-inner h1 {
  font-size: var(--inner-hero-title-size);
  font-weight: 300;
  letter-spacing: var(--inner-hero-title-track);
  line-height: var(--inner-hero-title-lh);
}
.layout-realizacje-showcase.page-key-projects .hero-subline {
  display: none;
}
.layout-realizacje-showcase .project-block {
  min-height: 0;
  align-items: stretch;
}
.layout-realizacje-showcase .project-block--light {
  background: #ececec;
}
.layout-realizacje-showcase .project-block--dark {
  background: #22282c;
}
.layout-realizacje-showcase .project-block__media {
  align-self: stretch;
  min-height: clamp(320px, 48vw, 654px);
}
.layout-realizacje-showcase .project-block__media--duo {
  flex-direction: column;
  gap: 26.98px;
}
.layout-realizacje-showcase .project-block__media--duo img {
  flex: 1 1 0;
  width: 100%;
  min-height: 0;
  height: auto;
  aspect-ratio: auto;
  object-fit: cover;
}
.layout-realizacje-showcase .project-block__media--solo img {
  flex: 0 0 auto;
  width: 100%;
  min-height: 0;
  height: auto;
  aspect-ratio: 729.15843534 / 653.2240800092673;
  object-fit: cover;
}
.layout-realizacje-showcase .project-block__copy {
  padding: clamp(44px, 5vw, 80px) clamp(44px, 5.5vw, 88px);
}
.layout-realizacje-showcase .project-block__lines {
  gap: 0;
  max-width: 36em;
}
.layout-realizacje-showcase .project-block__line {
  font-family: var(--font-body);
  font-size: 20px;
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.091em;
}
.layout-realizacje-showcase .project-block--light .project-block__line {
  color: #000000;
}
.layout-realizacje-showcase .project-block--dark .project-block__line {
  color: #ffffff;
}

/* ================================================ */

.site-footer {
	background: #ececec;
	color: var(--text-main);
	border-top: 1px solid rgba(37, 44, 51, 0.08);
	/* Stopka: mniejsza skala przy tych samych krojach co brandbook (Roboto / Roboto Mono / Space Grotesk) */
	--footer-lead-size: 15px;
	--footer-lead-lh: 1.62;
	--footer-lead-track: var(--bb-body-track);
	--footer-detail-size: 12px;
	--footer-detail-lh: 1.35;
	--footer-detail-track: var(--bb-detail-track);
	--footer-title-size: clamp(28px, 2.4vw, 34px);
	--footer-title-lh: 1.22;
	--footer-title-track: 0.11em;
	--footer-col-size: 14px;
	--footer-col-lh: 1.55;
	--footer-col-h-size: 12px;
	--footer-rail: clamp(24px, 4vw, 48px);
	/* Wysokość bloku „Kontakt” + linia — nagłówki adresów zaczynają przy pierwszym wierszu kontaktu */
	--footer-address-offset: calc(
		(clamp(28px, 2.4vw, 34px) * var(--footer-title-lh)) + 10px + 1px + 22px
	);
}
.site-footer__cta.site-limit,
.site-footer__main.site-limit {
	padding-left: var(--site-pad-inline);
	padding-right: var(--site-pad-inline);
	max-width: min(100%, calc(var(--site-width) + 80px));
}
.site-footer__cta { padding-top: 40px; padding-bottom: 28px; }
.site-footer__cta-copy {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 22px;
	max-width: min(100%, 50%);
	width: 100%;
}
.site-footer__cta-copy p {
	margin: 0;
	max-width: 100%;
	font-family: var(--font-body);
	font-size: var(--footer-lead-size);
	line-height: var(--footer-lead-lh);
	letter-spacing: var(--footer-lead-track);
	color: var(--text-muted);
	font-weight: 400;
}
.site-footer__cta-link {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	padding-top: 0;
	margin-left: 0;
}
.site-footer__cta-link a {
	display: inline-flex;
	flex-direction: row;
	align-items: center;
	gap: 14px;
	font-family: var(--font-detail);
	font-size: var(--footer-detail-size);
	line-height: var(--footer-detail-lh);
	text-transform: uppercase;
	letter-spacing: var(--footer-detail-track);
	color: var(--text-main);
	font-weight: 400;
}
.site-footer__cta-lines {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	text-align: left;
	line-height: 1.15;
}
.site-footer__cta-line { display: block; }
.site-footer__cta-arrow {
	font-size: 1.45em;
	line-height: 1;
	font-weight: 300;
	margin-top: 2px;
}
.site-footer__main { padding-top: 56px; padding-bottom: 44px; }
.site-footer__column--contact .site-footer__heading {
	margin: 0 0 22px;
	padding: 0;
	border-bottom: none;
}
.site-footer__heading {
	margin: 0;
	padding: 0;
	border-bottom: none;
}
.site-footer__heading h2 {
	display: block;
	margin: 0;
	padding: 0 0 10px;
	border-bottom: none;
	color: rgba(96, 130, 147, 0.92);
	font-family: var(--font-heading);
	font-weight: var(--bb-weight-heading);
	font-size: var(--footer-title-size);
	letter-spacing: var(--footer-title-track);
	line-height: var(--footer-title-lh);
	text-transform: none;
}
.site-footer__heading-rule {
	display: block;
	width: clamp(8.75rem, 24vw, 11.5rem);
	max-width: 100%;
	height: 1px;
	background: rgba(96, 130, 147, 0.42);
}
.site-footer__grid {
	display: grid;
	grid-template-columns: minmax(168px, 1.15fr) repeat(4, minmax(0, 1fr));
	column-gap: clamp(28px, 3.8vw, 56px);
	row-gap: 0;
	align-items: start;
	width: 100%;
}
.site-footer__column {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 12px;
	min-width: 0;
	width: 100%;
}
.site-footer__column--contact {
	gap: 0;
}
.site-footer__column--contact .site-footer__contact-rows {
	margin-top: 0;
}
.site-footer__grid > .site-footer__column:not(.site-footer__column--contact) {
	padding-top: var(--footer-address-offset);
}
.site-footer__column-title,
.site-footer__column h3 {
	margin: 0;
	width: 100%;
	min-height: calc(var(--footer-col-h-size) * var(--footer-detail-lh));
	font-family: var(--font-detail);
	font-size: var(--footer-col-h-size);
	line-height: var(--footer-detail-lh);
	letter-spacing: var(--bb-detail-track);
	text-transform: uppercase;
	color: var(--text-main);
	font-weight: 400;
}
.site-footer__column-title--showroom {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 0.35em;
	text-transform: none;
	font-size: var(--footer-col-h-size);
}
.site-footer__column-title-strong {
	font-family: var(--font-detail);
	font-size: var(--footer-col-h-size);
	line-height: var(--footer-detail-lh);
	letter-spacing: var(--bb-detail-track);
	text-transform: uppercase;
	font-weight: 700;
	color: var(--text-main);
}
.site-footer__column-title-city {
	font-family: var(--font-detail);
	font-size: var(--footer-col-h-size);
	line-height: var(--footer-detail-lh);
	letter-spacing: var(--bb-detail-track);
	text-transform: uppercase;
	font-weight: 400;
	color: var(--text-main);
}
.site-footer__contact-rows,
.site-footer__address {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 12px;
	width: 100%;
	margin: 0;
}
.site-footer__column p,
.site-footer__column a {
	margin: 0;
	font-family: var(--font-body);
	font-size: var(--footer-col-size);
	line-height: var(--footer-col-lh);
	letter-spacing: var(--bb-body-track);
	color: var(--text-muted);
}
.site-footer__column--contact p,
.site-footer__column--contact a { font-size: var(--footer-col-size); }
.site-footer__contact-row {
	display: flex;
	align-items: center;
	gap: 10px;
	width: 100%;
	margin: 0;
}
.site-footer__contact-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.site-footer__contact-icon svg {
	display: block;
	vertical-align: middle;
}
.site-footer__contact-icon { display: flex; align-items: center; flex-shrink: 0; width: 15px; height: 15px; color: var(--brand-blue); }
.site-footer__contact-icon svg { width: 15px; height: 15px; }
.site-footer__contact-icon--wa { color: var(--brand-green); width: 16px; height: 16px; }
.site-footer__contact-icon--wa svg { width: 16px; height: 16px; }
.site-footer__social {
	margin-top: 20px;
	padding-top: 16px;
	border-top: 1px solid rgba(37, 44, 51, 0.1);
	width: 100%;
}
.site-footer__social-title {
	margin: 0 0 10px;
	font-family: var(--font-detail);
	font-size: 10px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--brand-gray);
}
.site-footer__social-links {
	display: flex;
	flex-wrap: wrap;
	gap: 8px 14px;
}
.site-footer__social-link {
	font-family: var(--font-heading);
	font-size: 11px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--brand-graphite);
	text-decoration: none;
	border-bottom: 1px solid transparent;
	transition: color 0.15s, border-color 0.15s;
}
.site-footer__social-link:hover {
	color: var(--brand-green);
	border-bottom-color: var(--brand-green);
}
.site-footer__legal { padding-top: 0; padding-bottom: 24px; display: flex; gap: 16px; justify-content: space-between; align-items: center; border-top: 1px solid rgba(37,44,51,.08); }
.site-footer__legal-links { display: flex; gap: 20px; flex-wrap: wrap; padding-top: 18px; }
.site-footer__legal-credit { padding-top: 18px; }
.site-footer__legal a,
.site-footer__legal-credit a {
	font-family: var(--font-detail);
	font-size: var(--footer-detail-size);
	line-height: var(--footer-detail-lh);
	letter-spacing: var(--footer-detail-track);
	color: rgba(34, 40, 44, 0.72);
	text-decoration: none;
	text-transform: none;
	font-weight: 400;
	transition: color 0.2s ease;
}
.site-footer__legal a:hover,
.site-footer__legal-credit a:hover {
	color: var(--brand-graphite);
}
.whatsapp-float {
  position: fixed;
  right: max(18px, env(safe-area-inset-right, 0px));
  bottom: max(22px, env(safe-area-inset-bottom, 0px));
  z-index: 250;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: #25d366;
  color: #fff;
  box-shadow: 0 4px 18px rgba(0, 0, 0, 0.28);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.whatsapp-float:hover {
  transform: scale(1.05);
  box-shadow: 0 6px 22px rgba(0, 0, 0, 0.32);
}
.whatsapp-float:focus-visible {
  outline: 2px solid #fff;
  outline-offset: 3px;
}

.cookie-banner {
  position: fixed;
  left: 18px;
  right: 18px;
  bottom: 18px;
  z-index: 300;
  display: none;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 16px;
  border: 1px solid rgba(255,255,255,.24);
  background: rgba(17,23,30,.95);
  color: var(--tint-white);
}
.cookie-banner.is-visible { display: flex; }
.cookie-banner p { margin: 0; font-size: 13px; letter-spacing: .03em; }
.cookie-banner__actions { display: flex; align-items: center; gap: 10px; }
.cookie-banner__actions a,
.cookie-banner__actions button {
  font-family: var(--font-detail);
  font-size: 12px;
  letter-spacing: .05em;
  color: var(--tint-white);
  background: transparent;
  border: 1px solid rgba(255,255,255,.35);
  padding: 8px 10px;
  cursor: pointer;
}

@media (max-width: 1280px) {
  .site-header__inner { min-height: 86px; padding-left: 28px; padding-right: 28px; }
  .site-nav ul { gap: 22px; }
}

@media (max-width: 1024px) {
  .site-limit { padding: 0 16px; }
  .site-header__inner { min-height: 74px; flex-direction: row; align-items: center; justify-content: space-between; gap: 12px; width: 100%; margin: 0; padding: 8px 16px; }
  .site-logo { width: 200px; }
  .menu-toggle { display: inline-flex; }
  .site-header__nav {
    position: fixed;
    top: 74px;
    left: 0;
    right: 0;
    display: none;
    width: 100%;
    padding: 10px 16px 14px;
    background: rgba(15,20,26,.96);
    border-top: 1px solid rgba(255,255,255,.15);
  }
  .nav-open .site-header__nav { display: block; }
  .site-nav { width: 100%; }
  .site-nav ul { width: 100%; gap: 0; overflow: visible; padding-bottom: 0; white-space: normal; }
  .site-nav .menu { flex-direction: column; align-items: stretch; }
  .site-nav .menu > li { width: 100%; padding: 0; margin: 0; border-top: 1px solid rgba(255,255,255,.12); }
  .site-nav .menu > li > a {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    padding: 10px 0;
    font-size: var(--nav-top-font-size);
  }
  /* Mobile: tylko pozycje jak w górnym pasku desktop — bez rozwijanych podmenu */
  .site-nav .sub-menu {
    display: none !important;
  }
  .site-nav .menu-item-has-children.is-open > .sub-menu {
    display: none !important;
  }
  .site-nav .menu > li:not(.menu-item-language) > a {
    padding-bottom: 8px;
    border-bottom: var(--nav-link-underline) solid transparent;
    transition:
      color var(--nav-link-transition),
      border-color var(--nav-link-transition);
  }
  .site-nav .menu > li:not(.menu-item-language) > a:hover,
  .site-nav .menu > li:not(.menu-item-language) > a:focus-visible {
    border-bottom-color: var(--nav-link-accent);
  }
  .site-nav .menu > .current-menu-item > a,
  .site-nav .menu > .current-menu-ancestor > a,
  .site-nav .menu > li:not(.menu-item-language) > a[aria-current="page"] {
    border-bottom-color: var(--nav-link-accent);
  }
  .site-nav .menu > li.menu-item-has-children:hover > a,
  .site-nav .menu > li.menu-item-has-children:focus-within > a {
    border-bottom-color: var(--nav-link-accent);
  }
  .site-nav .menu > .menu-item-language {
    margin-left: 0;
    padding: 12px 0 4px;
    display: flex;
    justify-content: flex-start;
  }
  .site-nav .menu > .menu-item-language .lang-toggle {
    padding: 5px 9px;
  }
  .hero-content { padding-bottom: 86px; }
  .hero-row { grid-template-columns: 1fr; gap: 10px; }
  .hero-row__right { padding-bottom: 0; }
  .outline-button { width: 100%; }
  .page-key-cinema .split__copy h2,
  .page-key-soundwall .split__copy h2,
  .page-key-knowledge .split__copy h2,
  .page-key-projects .split__copy h2 { font-size: clamp(22px, 4.5vw, 29.333px); letter-spacing: var(--split-light-title-track); }
  .page-key-about .split-light .split__copy h2 {
    font-size: clamp(22px, 5vw, 29.333px);
    letter-spacing: var(--split-light-title-track);
    line-height: var(--split-light-title-lh);
  }
  .page-key-about .split-dark .split__copy h2 {
    font-size: clamp(22px, 5vw, 29.333px);
    letter-spacing: var(--dark-showroom-title-track);
    line-height: var(--dark-showroom-title-lh);
  }
  .page-key-home .hero h1 { max-width: 100%; }
  .page-key-home .hero-row__right .outline-button { min-width: 0; padding: 8px 14px; letter-spacing: var(--outline-button-track); }
  .cards-grid { grid-template-columns: 1fr; }
  .feature-card { min-height: 500px; }
  .page-key-home .hero-home { min-height: 84vh; background-position: center calc(42% + var(--hero-bg-y-nudge)); }
  .page-key-home .dark-grid { background: var(--brand-graphite); padding: 40px 0 52px; }
  .page-key-home .dark-grid .site-limit { width: 100%; max-width: 100%; padding: 0 16px; }
  .page-key-home .cards-grid {
    display: grid;
    grid-template-columns: 1fr;
    justify-content: stretch;
    gap: 14px;
  }
  .page-key-home .feature-card {
    flex: none;
    width: 100%;
    max-width: none;
    height: auto;
    min-height: 0;
    aspect-ratio: 3 / 4;
    max-height: none;
    border: none;
    border-radius: 0;
  }
  .page-key-home .feature-card__body {
    padding: 22px 16px 22px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .page-key-home .feature-card h3 {
    margin: 0 0 14px;
    text-transform: none;
    max-width: 22ch;
  }
  .page-key-home .split-dark--home-feature .split__copy h2 {
    font-size: clamp(24px, 6vw, 37.334px);
    letter-spacing: 0.142em;
    line-height: var(--split-dark-feature-title-lh);
  }
  .page-key-home .home-feature__cta-bar {
    padding: clamp(22px, 5vw, 32px) clamp(24px, 5vw, 32px);
    min-height: clamp(60px, 14vw, 88px);
  }
  .page-key-home .split-dark--home-feature .split__copy {
    min-height: 0;
    padding: clamp(32px, 7vw, 44px) clamp(24px, 5vw, 32px) clamp(40px, 8vw, 56px);
  }
  .page-key-home .split-dark--home-feature .split__copy > p,
  .page-key-home .split-dark--home-feature .inline-cta {
    max-width: min(100%, 420px);
  }
  .page-key-home .split-light .inline-cta,
  .page-key-home .split-dark--home-feature .inline-cta {
    margin-top: clamp(24px, 2.5vw, 32px);
    align-self: flex-start;
  }
  .page-key-home .dark-showroom__photos {
    grid-template-columns: 1fr;
  }
  .page-key-home .dark-showroom__photo + .dark-showroom__photo {
    border-left: 0;
    border-top: 1px solid rgba(0, 0, 0, 0.35);
  }
  .page-key-home .dark-showroom__photo {
    aspect-ratio: 16 / 10;
    min-height: 0;
  }
  .split.split-light .split__copy h2 { font-size: clamp(22px, 5.2vw, 29.333px); letter-spacing: var(--split-light-title-track); line-height: var(--split-light-title-lh); }
  .realizacje-gallery__grid { grid-template-columns: 1fr; gap: 2px; }
  .realizacje-gallery__item img { height: clamp(260px, 58vw, 520px); }
  .page-key-home .realizacje-gallery__grid { grid-template-columns: 1fr; gap: 2px; }
  .page-key-home .realizacje-gallery__item { aspect-ratio: auto; }
  .page-key-home .realizacje-gallery__item img {
    width: 100%;
    height: clamp(240px, 56vw, 480px);
    min-height: 0;
  }
  .realizacje-gallery__cta-wrap { padding: 20px; }
  .realizacje-banner__inner { min-height: clamp(320px, 56.25vw, 560px); padding-top: clamp(56px, 10vw, 96px); }
  .realizacje-banner__title { font-size: clamp(22px, 5.5vw, 40px); letter-spacing: var(--realizacje-banner-title-track); line-height: var(--realizacje-banner-title-lh); }
  .checker-intro { padding: 72px 0 34px; }
  .project-block,
  .project-block--reversed { grid-template-columns: 1fr; min-height: auto; }
  .project-block--reversed .project-block__media,
  .project-block--reversed .project-block__copy { order: initial; }
  .project-block__media { min-height: 320px; }
  .layout-realizacje-showcase.page-key-projects .hero-inner {
    min-height: min(72vh, 560px);
    background-position: 58% calc(42% + var(--hero-bg-y-nudge));
  }
  .layout-realizacje-showcase .project-block__media--duo {
    flex-direction: column;
    gap: 20px;
  }
  .layout-realizacje-showcase .project-block__media--duo img {
    width: 100%;
    flex: 0 0 auto;
  }
  .layout-realizacje-showcase .project-block__media {
    min-height: 0;
  }
  .project-block__copy { padding: 44px 26px; }
  .project-block__line { font-size: 20px; }
  .checker-story-block,
  .checker-story-block.is-reverse { grid-template-columns: 1fr; }
  .checker-story-block.is-reverse .checker-story-block__media,
  .checker-story-block.is-reverse .checker-story-block__copy { order: initial; }
  .checker-story-block__copy { padding: 46px 26px; }
  .checker-story-block__copy h2 { font-size: 52px; letter-spacing: .08em; }
  .checker-story-block__copy p { max-width: 100%; line-height: 1.9; font-size: 15px; }
  .checker-story-block__cta { padding-top: 34px; }
  .editorial-panel,
  .editorial-panel.is-reverse { grid-template-columns: 1fr; gap: 0; }
  .editorial-panel.is-reverse .editorial-panel__media,
  .editorial-panel.is-reverse .editorial-panel__copy { order: initial; }
  .editorial-panel__media img { min-height: 380px; }
  .split__inner { grid-template-columns: 1fr; min-height: auto; }
  .split__inner--reverse .split__copy, .split__inner--reverse .split__media { order: initial; }
  .page-key-home .split-light .split__copy {
    border-right: none;
    border-bottom: 1px solid var(--home-split-divider);
  }
  .page-key-home .split-light .split__copy h2 {
    font-size: clamp(26px, 7vw, 37.334px);
  }
  .split__media { min-height: 350px; }
  .page-key-cinema-halls .hero-inner { min-height: 72vh; background-position: center calc(50% + var(--hero-bg-y-nudge)); }
  .page-key-cinema-halls .split .site-limit { padding: 0; }
  .page-key-cinema-halls .split__inner { aspect-ratio: auto; min-height: 0; }
  .page-key-cinema-halls .split__copy { padding: 40px 26px; overflow-y: visible; }
  .page-key-cinema-halls .split-index-1 .split__copy,
  .page-key-cinema-halls .split-index-2 .split__copy,
  .page-key-cinema-halls .split-index-3 .split__copy,
  .page-key-cinema-halls .split-index-4 .split__copy,
  .page-key-cinema-halls .split-index-5 .split__copy,
  .page-key-cinema-halls .split-index-6 .split__copy,
  .page-key-cinema-halls .split-index-7 .split__copy,
  .page-key-cinema-halls .split-index-8 .split__copy { order: initial; }
  .page-key-cinema-halls .split-index-1 .split__media,
  .page-key-cinema-halls .split-index-2 .split__media,
  .page-key-cinema-halls .split-index-3 .split__media,
  .page-key-cinema-halls .split-index-4 .split__media,
  .page-key-cinema-halls .split-index-5 .split__media,
  .page-key-cinema-halls .split-index-6 .split__media,
  .page-key-cinema-halls .split-index-7 .split__media,
  .page-key-cinema-halls .split-index-8 .split__media { order: initial; }
  .page-key-cinema-halls .split--dual-copy .split__inner { min-height: 0; }
  .page-key-cinema-halls .split__copy--dual { gap: 32px; }
  .page-key-cinema-halls .split-light .split__copy h2 { font-size: clamp(20px, 4.5vw, 29.333px); letter-spacing: var(--split-light-title-track); }
  .page-key-cinema-halls .split-dark .split__copy h2 { font-size: clamp(20px, 4.5vw, 29.333px); letter-spacing: var(--dark-showroom-title-track); }
  .page-key-cinema-halls .split-dark .split__copy p { font-size: 11px; line-height: var(--dark-showroom-body-lh); }
  .page-key-cinema-halls .inline-cta { padding-top: 28px; }
  .page-key-cinema-halls .hero-row__right .outline-button { min-width: 0; }
  .kino-soundwall-canva-layout .hero-inner { min-height: 72vh; background-position: center calc(46% + var(--hero-bg-y-nudge)); }
  .kino-soundwall-canva-layout .split .site-limit { padding: 0; }
  .kino-soundwall-canva-layout .split__inner { aspect-ratio: auto; min-height: 0; }
  .kino-soundwall-canva-layout {
    --soundwall-copy-pad-y: 40px;
    --soundwall-copy-pad-x: 26px;
    --soundwall-h2-mb: 22px;
    --soundwall-cta-pad-top: 32px;
    --soundwall-extra-gap: 28px;
    --soundwall-extra-cta-pad: 12px;
  }
  .kino-soundwall-canva-layout .split__copy { padding: var(--soundwall-copy-pad-y) var(--soundwall-copy-pad-x); overflow-y: visible; }
  .page-key-audio .hero-inner { min-height: 72vh; background-position: center calc(46% + var(--hero-bg-y-nudge)); }
  .page-key-audio .split .site-limit { padding: 0; }
  .page-key-audio .split__inner { aspect-ratio: auto; min-height: 0; }
  .page-key-audio .split__copy { padding: 40px 26px; overflow-y: visible; }
  .kino-soundwall-canva-layout .split-index-1 .split__copy,
  .kino-soundwall-canva-layout .split-index-2 .split__copy,
  .kino-soundwall-canva-layout .split-index-3 .split__copy,
  .kino-soundwall-canva-layout .split-index-4 .split__copy,
  .kino-soundwall-canva-layout .split-index-5 .split__copy,
  .kino-soundwall-canva-layout .split-index-6 .split__copy { order: initial; }
  .kino-soundwall-canva-layout .split-index-1 .split__media,
  .kino-soundwall-canva-layout .split-index-2 .split__media,
  .kino-soundwall-canva-layout .split-index-3 .split__media,
  .kino-soundwall-canva-layout .split-index-4 .split__media,
  .kino-soundwall-canva-layout .split-index-5 .split__media,
  .kino-soundwall-canva-layout .split-index-6 .split__media { order: initial; }
  .kino-soundwall-canva-layout .split-index-1 .split__media { display: block; }
  .kino-soundwall-canva-layout .split-index-1 .split__media img,
  .kino-soundwall-canva-layout .split-index-1 .split__media video.split__video {
    width: 100%;
    aspect-ratio: auto;
    max-height: none;
    transform: none;
  }
  .kino-soundwall-canva-layout .split-index-6 .split__media img {
    transform: none;
  }
  .kino-soundwall-canva-layout .split-light .split__copy h2 { font-size: clamp(20px, 4.5vw, 29.333px); letter-spacing: var(--split-light-title-track); }
  .kino-soundwall-canva-layout .split-dark .split__copy h2 { font-size: clamp(20px, 4.5vw, 29.333px); letter-spacing: var(--dark-showroom-title-track); }
  .kino-soundwall-canva-layout .split-light .split__copy p {
    font-size: 11px;
    line-height: var(--split-tile-body-lh);
    letter-spacing: var(--split-tile-body-track);
  }
  .kino-soundwall-canva-layout .split-dark .split__copy > p {
    font-size: 11px;
    line-height: var(--dark-showroom-body-lh);
    letter-spacing: var(--dark-showroom-body-track);
  }
  .kino-soundwall-canva-layout .split-index-6.split-dark .split__copy > p,
  .kino-soundwall-canva-layout .split-index-6.split-dark .split-extra-block > p {
    font-size: 12px;
    line-height: 1.85;
    letter-spacing: 0.06em;
  }
  .kino-soundwall-canva-layout .split__copy .inline-cta,
  .kino-soundwall-canva-layout .split__copy .split-extra-block .inline-cta--extra {
    padding-top: var(--soundwall-cta-pad-top);
  }
  .kino-soundwall-canva-layout .split-extra-block .inline-cta--extra {
    padding-top: var(--soundwall-extra-cta-pad);
  }
  .kino-soundwall-canva-layout .split-extra-block > p + .inline-cta--extra {
    padding-top: 18px;
  }
  .kino-soundwall-canva-layout .split__copy .inline-cta .soundwall-cta-link__text,
  .kino-soundwall-canva-layout .split__copy .inline-cta .split-tile-cta-link__text,
  .kino-soundwall-canva-layout .split__copy .split-extra-block .inline-cta--extra .soundwall-cta-link__text,
  .kino-soundwall-canva-layout .split__copy .split-extra-block .inline-cta--extra .split-tile-cta-link__text {
    width: max-content;
    max-width: 100%;
  }
  .kino-soundwall-canva-layout .split__copy .inline-cta .soundwall-cta-link__line,
  .kino-soundwall-canva-layout .split__copy .inline-cta .split-tile-cta-link__line,
  .kino-soundwall-canva-layout .split__copy .split-extra-block .inline-cta--extra .soundwall-cta-link__line,
  .kino-soundwall-canva-layout .split__copy .split-extra-block .inline-cta--extra .split-tile-cta-link__line {
    white-space: normal;
    text-align: center;
  }
  .kino-soundwall-canva-layout .split__copy .inline-cta a.soundwall-cta-link,
  .kino-soundwall-canva-layout .split__copy .inline-cta a.split-tile-cta-link,
  .kino-soundwall-canva-layout .split__copy .split-extra-block .inline-cta--extra a.soundwall-cta-link,
  .kino-soundwall-canva-layout .split__copy .split-extra-block .inline-cta--extra a.split-tile-cta-link {
    flex-wrap: wrap;
    max-width: 100%;
  }
  .kino-soundwall-canva-layout .hero-row__right .outline-button { min-width: 0; }
  .page-key-audio .hero-row__right .outline-button { min-width: 0; }
  .page-key-audio .split-light .split__copy h2 { font-size: clamp(20px, 4.5vw, 29.333px); letter-spacing: var(--split-light-title-track); }
  .page-key-audio .split-dark .split__copy h2 { font-size: clamp(20px, 4.5vw, 29.333px); letter-spacing: var(--dark-showroom-title-track); }
  .page-key-audio .split-dark .split__copy p { font-size: 11px; line-height: var(--dark-showroom-body-lh); letter-spacing: var(--dark-showroom-body-track); }
  .page-key-audio .split-index-1 .split__copy,
  .page-key-audio .split-index-2 .split__copy,
  .page-key-audio .split-index-3 .split__copy,
  .page-key-audio .split-index-4 .split__copy { order: initial; }
  .page-key-audio .split-index-1 .split__media,
  .page-key-audio .split-index-2 .split__media,
  .page-key-audio .split-index-3 .split__media,
  .page-key-audio .split-index-4 .split__media { order: initial; }
  .page-key-audio .split-light .inline-cta,
  .page-key-audio .split-dark .inline-cta { padding-top: 28px; }
  .page-key-audio .split-extra-block { margin-top: 34px; }
  .page-key-about .hero-inner {
    min-height: max(300px, min(56vh, calc(100vw * 576 / 1024.5)));
    background-position: center calc(44% + var(--hero-bg-y-nudge));
  }
  .page-key-about .hero-content { padding-bottom: 64px; }
  .page-key-about .hero-row__right .outline-button { min-width: 0; }
  .page-key-about .split__inner { height: auto; min-height: 0; aspect-ratio: auto; }
  .page-key-about .split__media { min-height: min(72vw, 420px); height: auto; }
  .page-key-about .split__media img { min-height: min(72vw, 420px); }
  .page-key-about .split__copy { padding: 28px 22px 26px; }
  .layout-knowledge-canva .knowledge-canva-hero {
    min-height: max(260px, min(56vh, calc(100vw * 576 / 1024.5)));
    background-position: 50% calc(30% - 50px + var(--hero-bg-y-nudge));
  }
  .layout-knowledge-canva .knowledge-canva-hero .hero-content {
    padding-inline: clamp(16px, 5.6vw, 48px);
    padding-bottom: clamp(48px, 12vw, 100px);
  }
  .layout-knowledge-canva .knowledge-canva-hero .hero-row {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  .layout-knowledge-canva .knowledge-canva-hero .hero-row__right .outline-button {
    min-width: 0;
    width: 100%;
    max-width: 100%;
  }
  .knowledge-canva-grid {
    padding-top: clamp(28px, 6vw, 56px);
    padding-bottom: clamp(40px, 18vw, 200px);
  }
  .knowledge-canva-grid__inner {
    grid-template-columns: 1fr;
    row-gap: calc(var(--kc-ref) * var(--kc-gap) / var(--kc-pdf-w));
    column-gap: 0;
  }
  .knowledge-canva-card__overlay {
    height: 38%;
    padding: 0 10%;
  }
  .knowledge-canva-card__overlay p {
    font-size: clamp(10px, 3.2vw, 13px);
  }
  .site-footer {
    --footer-rail: clamp(14px, 6vw, 64px);
    --footer-cta-shift: clamp(28px, 12vw, 140px);
  }
  .site-footer__cta.site-limit,
  .site-footer__main.site-limit {
    padding-left: calc(16px + var(--footer-rail));
    padding-right: 16px;
  }
  .site-footer__cta { padding-top: 36px; padding-bottom: 22px; }
  .site-footer__cta-copy { gap: 18px; max-width: 100%; }
  .site-footer__main { padding-top: 40px; padding-bottom: 32px; }
  .site-footer__column--contact .site-footer__heading { margin-bottom: 20px; }
  .site-footer__heading h2 { font-size: clamp(26px, 7vw, 30px); padding-bottom: 10px; }
  .site-footer__grid {
    grid-template-columns: 1fr;
    column-gap: 0;
    row-gap: 28px;
  }
  .site-footer__grid > .site-footer__column:not(.site-footer__column--contact) {
    padding-top: 0;
  }
  .site-footer__column { gap: 12px; }
  .site-footer__contact-rows,
  .site-footer__address { gap: 12px; }
  .site-footer__column p, .site-footer__column a { font-size: var(--footer-col-size); }
  .site-footer__languages { margin-top: 14px; }
  .site-footer__legal { padding-bottom: 24px; flex-wrap: wrap; }
  .cookie-banner { left: 12px; right: 12px; bottom: 12px; flex-direction: column; align-items: flex-start; }
}
