    :root {
      --text: #eef3fb;
      --muted: #b2bfd3;
      --accent: #7ea0d8;
      --accent-2: #5f78b6;
      /* Tło: baza jak w kadrach (granat) + lekki błękit / lawenda ze zdjęć */
      --bg-base: #07101c;
      --bg-base-rgb: 7, 16, 28;
      --bg-mid: #0a1828;
      --bg-soft: #102438;
      --bg-accent-wash: rgba(126, 160, 216, 0.14);
      --bg-accent-wash-2: rgba(95, 120, 182, 0.11);
      --bg-slate-mist: rgba(154, 167, 187, 0.09);
      /* Ciepły akcent — widoczny pomarańcz przy ciemnym tle (jak złota godzina) */
      --bg-amber-wash: rgba(212, 118, 72, 0.11);
      --bg-amber-soft: rgba(255, 186, 130, 0.055);
      --bg-amber-deep: rgba(165, 72, 38, 0.06);
      --bg-orange-glow: rgba(230, 125, 65, 0.28);
      --bg-orange-mid: rgba(200, 95, 48, 0.2);
      --bg-sky-glow: rgba(140, 175, 228, 0.22);
      --bg-navy-deep: #0a1e32;
      --bg-navy-mid: #12324e;
      /* Mikroszum — wyższa częstotliwość + więcej oktaw = drobniejsze „ziarno”, płynniejsze przejścia wizualnie */
      --bg-noise-svg: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='1.15' numOctaves='5' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
      --shadow: 0 20px 60px rgba(0, 0, 0, 0.35);
      --radius-xl: 28px;
      --radius-lg: 22px;
      --radius-md: 18px;
      --container: 1240px;
      /* Advent Pro — grubości 200–600 (+ kursywa), import z Google Fonts (head HTML) */
      --font-sans: "Advent Pro", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
      --font-script: "Caveat", "Advent Pro", cursive;
      --font-weight-display: 200; /* główny tytuł hero — Extra Light */
      --font-weight-body: 300; /* tekst ciągły — Light, czytelniej niż 200 */
      --font-weight-title-sm: 500; /* mniejsze nagłówki (h3, intro) */
      --font-weight-heading: 600; /* h1, h2, duże tytuły kafelków */
      --font-weight-emphasis: 500; /* strong, wyróżnienia w tekście */
      --font-weight-ui: 600; /* CTA, zakładki, eyebrow, marka w headerze */
      /* Pionowy rytm strony — jedna skala odstępów między sekcjami i blokami */
      --section-pad-y: clamp(72px, 9vw, 96px);
      --section-block-gap: clamp(40px, 5.5vw, 52px);
      --section-head-spacing: clamp(28px, 4vw, 40px);
      --micro-cta-pad-y: clamp(22px, 3.2vw, 32px);
      --micro-cta-pad-y-tight: clamp(18px, 2.6vw, 26px);
      --micro-cta-margin-y: clamp(14px, 2.2vw, 24px);

      /*
       * Typografia — jedna skala (fluid clamp), hierarchia jak w UX WCAG-oriented:
       * body ≥ ~15px, wyraźny kontrast rozmiarów (hero > sekcja > karta > pomocniczy).
       * vw zapewnia płynną responsywność (mały / średni / duży / bardzo duży ekran); max w clamp ogranicza gigantyzm na ultrawide.
       */
      --leading-none: 1;
      --leading-tight: 1.15;
      --leading-snug: 1.35;
      --leading-normal: 1.5;
      --leading-relaxed: 1.55;
      --leading-loose: 1.65;

      --text-caption: clamp(0.6875rem, 0.62rem + 0.22vw, 0.78125rem);
      --text-eyebrow: clamp(0.75rem, 0.68rem + 0.28vw, 0.8125rem);
      --text-small: clamp(0.8125rem, 0.76rem + 0.28vw, 0.875rem);
      --text-ui-sm: clamp(0.8125rem, 0.74rem + 0.32vw, 0.875rem);
      --text-body-sm: clamp(0.875rem, 0.82rem + 0.28vw, 0.9375rem);
      --text-ui: clamp(0.875rem, 0.8rem + 0.38vw, 0.9375rem);
      --text-body: clamp(0.9375rem, 0.88rem + 0.32vw, 1.0625rem);
      --text-lead: clamp(1rem, 0.9rem + 0.42vw, 1.125rem);
      --text-subtitle: clamp(1.0625rem, 0.96rem + 0.42vw, 1.1875rem);
      --text-card-title: clamp(1.0625rem, 0.97rem + 0.38vw, 1.125rem);
      --text-title: clamp(1.125rem, 1rem + 0.48vw, 1.3125rem);
      --text-section: clamp(1.625rem, 1.28rem + 1.05vw, 2.0625rem);
      --text-intro: clamp(1.875rem, 1.45rem + 1.5vw, 2.5rem);
      --text-page-hero: clamp(2rem, 1.52rem + 1.55vw, 2.75rem);
      --text-hero: clamp(2.55rem, 1.15rem + 6.8vw, 4.75rem);
      --text-hero-lead: clamp(1.02rem, 0.9rem + 0.42vw, 1.1875rem);
      --text-display-num: clamp(1.75rem, 1.28rem + 2.2vw, 2.65rem);
      --text-process-label: clamp(0.9375rem, 0.85rem + 0.38vw, 1.0625rem);
      --text-process-body: clamp(0.9375rem, 0.88rem + 0.3vw, 1.0625rem);
      --text-stat: clamp(1.125rem, 0.98rem + 0.85vw, 1.4375rem);
      --text-quote: clamp(1.125rem, 1rem + 0.65vw, 1.3125rem);
      --text-quote-feature: clamp(1.15rem, 1rem + 0.95vw, 1.45rem);
      --text-watermark: clamp(2.25rem, 1.15rem + 4.8vw, 4rem);
      --text-tile-display: clamp(1.5rem, 1.15rem + 1.65vw, 2.125rem);
      --text-tile-meta: clamp(0.8125rem, 0.74rem + 0.35vw, 0.9375rem);
      /* Czerń + granat/niebieski — sekcja „O mnie” i strona galerii */
      --page-bg-about-dark:
        radial-gradient(ellipse 95% 72% at 100% 0%, rgba(120, 165, 228, 0.2), transparent 58%),
        radial-gradient(ellipse 80% 60% at 0% 100%, rgba(14, 40, 68, 0.92), transparent 55%),
        radial-gradient(ellipse 55% 45% at 50% 40%, rgba(30, 70, 120, 0.22), transparent 65%),
        linear-gradient(198deg, #020203 0%, #050810 42%, #030305 100%);
    }

    * { box-sizing: border-box; }

    .visually-hidden {
      position: absolute;
      width: 1px;
      height: 1px;
      padding: 0;
      margin: -1px;
      overflow: hidden;
      clip: rect(0, 0, 0, 0);
      clip-path: inset(50%);
      white-space: nowrap;
      border: 0;
    }
    html {
      /* Kotwice z nav (#usługi, #kontakt…) — skok od razu, bez „sunącego” scrolla przy przeklikiwaniu */
      scroll-behavior: auto;
      background-color: var(--bg-base);
      /* ~+30% całej typografii opartej na rem (tokeny --text-* i większość layoutu) */
      font-size: 130%;
    }
    body {
      margin: 0;
      font-family: var(--font-sans);
      font-weight: var(--font-weight-body);
      color: var(--text);
      /* Jeszcze dłuższe zaniki radiali + bardzo gęsty główny gradient + szum w ::after */
      background:
        radial-gradient(
          ellipse 130% 100% at 12% 8%,
          rgba(140, 175, 228, 0.24) 0%,
          rgba(140, 175, 228, 0.19) 9%,
          rgba(140, 175, 228, 0.12) 20%,
          rgba(140, 175, 228, 0.06) 32%,
          rgba(140, 175, 228, 0.025) 44%,
          rgba(140, 175, 228, 0.008) 54%,
          transparent 68%
        ),
        radial-gradient(
          ellipse 100% 85% at 88% 14%,
          rgba(230, 125, 65, 0.26) 0%,
          rgba(230, 125, 65, 0.18) 11%,
          rgba(230, 125, 65, 0.1) 24%,
          rgba(230, 125, 65, 0.04) 38%,
          rgba(230, 125, 65, 0.012) 48%,
          transparent 62%
        ),
        radial-gradient(
          ellipse 95% 75% at 42% 20%,
          rgba(200, 95, 48, 0.2) 0%,
          rgba(200, 95, 48, 0.13) 14%,
          rgba(200, 95, 48, 0.06) 30%,
          rgba(200, 95, 48, 0.02) 42%,
          rgba(200, 95, 48, 0.006) 52%,
          transparent 64%
        ),
        radial-gradient(
          ellipse 115% 90% at 92% 82%,
          rgba(230, 125, 65, 0.14) 0%,
          rgba(230, 125, 65, 0.09) 16%,
          rgba(230, 125, 65, 0.035) 34%,
          rgba(230, 125, 65, 0.01) 46%,
          transparent 60%
        ),
        radial-gradient(
          ellipse 90% 75% at 78% 22%,
          rgba(126, 160, 216, 0.16) 0%,
          rgba(126, 160, 216, 0.1) 13%,
          rgba(126, 160, 216, 0.045) 28%,
          rgba(126, 160, 216, 0.015) 40%,
          rgba(126, 160, 216, 0.004) 50%,
          transparent 62%
        ),
        radial-gradient(
          ellipse 95% 90% at 8% 72%,
          rgba(95, 120, 182, 0.13) 0%,
          rgba(95, 120, 182, 0.085) 14%,
          rgba(95, 120, 182, 0.035) 30%,
          rgba(95, 120, 182, 0.012) 42%,
          rgba(95, 120, 182, 0.003) 52%,
          transparent 64%
        ),
        linear-gradient(
          128deg,
          #060e18 0%,
          #06111c 2%,
          #071420 4%,
          #071724 5.5%,
          #081a28 7%,
          #091c2d 8.5%,
          var(--bg-navy-deep) 10%,
          #0c2339 11%,
          #0f2840 12%,
          #153651 13%,
          #1a4a62 14%,
          #18435c 15.25%,
          #173d55 15.5%,
          #153751 16.25%,
          var(--bg-navy-mid) 17%,
          #16334f 18%,
          #1a3650 19%,
          #1c3851 20%,
          #1e3a52 21%,
          #213645 22%,
          #253238 23%,
          #282c2a 24%,
          #2c261c 25%,
          #30271e 26%,
          #352820 27%,
          #39291d 28%,
          #3d2a1a 29%,
          #362d29 30%,
          #2f3038 31%,
          #253144 32.5%,
          #1a3350 34%,
          #19334d 35.5%,
          #17324a 37%,
          #163249 38.5%,
          #153248 40%,
          #162d41 41.25%,
          #172838 42.5%,
          #192a3b 43.75%,
          #1a2c3e 45%,
          #1e262d 46.25%,
          #221f1c 47.5%,
          #26201a 48.75%,
          #2a2118 50%,
          #2e2219 51.25%,
          #332419 52.5%,
          #382719 53.75%,
          #3d2a1a 55%,
          #37281d 56.25%,
          #312622 57.5%,
          #2b241f 58.75%,
          #2a221c 60%,
          #252729 62.5%,
          #1f2c3a 65%,
          #1a2c3d 67.5%,
          #152a40 70%,
          #12273b 73%,
          #102436 76%,
          #0d2134 79%,
          var(--bg-navy-deep) 82%,
          #0a1b2b 86%,
          #0a1624 90%,
          #081320 95%,
          #07101c 100%
        ),
        linear-gradient(
          52deg,
          rgba(7, 16, 28, 0.5) 0%,
          rgba(18, 20, 25, 0.41) 3%,
          rgba(28, 24, 22, 0.32) 6%,
          rgba(39, 30, 24, 0.26) 9%,
          rgba(50, 36, 26, 0.2) 12%,
          rgba(45, 34, 27, 0.14) 16%,
          rgba(40, 32, 28, 0.08) 20%,
          rgba(22, 24, 28, 0.03) 24%,
          transparent 28%,
          transparent 52%,
          rgba(30, 28, 26, 0.06) 56%,
          rgba(38, 30, 26, 0.12) 60%,
          rgba(42, 31, 24, 0.21) 64%,
          rgba(45, 32, 22, 0.3) 68%,
          rgba(36, 27, 21, 0.34) 76%,
          rgba(26, 22, 20, 0.38) 84%,
          rgba(16, 19, 24, 0.43) 92%,
          rgba(7, 16, 28, 0.48) 100%
        );
      background-color: var(--bg-base);
      min-height: 100vh;
      font-size: var(--text-body);
      line-height: var(--leading-loose);
    }

    strong,
    b {
      font-weight: var(--font-weight-emphasis);
    }

    body::before {
      content: "";
      position: fixed;
      inset: 0;
      pointer-events: none;
      /* Pionowy film — więcej przystanków = mniej „schodków” koloru */
      background: linear-gradient(
        180deg,
        rgba(126, 160, 216, 0.045) 0%,
        rgba(126, 160, 216, 0.032) 6%,
        rgba(126, 160, 216, 0.02) 12%,
        rgba(126, 160, 216, 0.012) 17%,
        rgba(126, 160, 216, 0.008) 22%,
        rgba(126, 160, 216, 0.003) 27%,
        transparent 32%,
        transparent 62%,
        rgba(var(--bg-base-rgb), 0.015) 66%,
        rgba(var(--bg-base-rgb), 0.04) 74%,
        rgba(var(--bg-base-rgb), 0.065) 81%,
        rgba(var(--bg-base-rgb), 0.09) 88%,
        rgba(var(--bg-base-rgb), 0.11) 94%,
        rgba(var(--bg-base-rgb), 0.13) 100%
      );
      z-index: -1;
    }

    /* Szum rozmywa różnice między sąsiednimi odcieniami — anty-banding (jak ziarno na kliszy) */
    body::after {
      content: "";
      position: fixed;
      inset: 0;
      pointer-events: none;
      z-index: -1;
      opacity: 0.048;
      mix-blend-mode: overlay;
      background-image: var(--bg-noise-svg);
      background-repeat: repeat;
      background-size: 256px 256px;
    }

    a { color: inherit; text-decoration: none; }
    img { display: block; max-width: 100%; }

    .container {
      width: min(calc(100% - 32px), var(--container));
      margin: 0 auto;
    }

    .site-header {
      position: sticky;
      top: 0;
      /* Nad treścią hero i dockiem kontaktu (60–65), żeby hamburger był zawsze klikalny */
      z-index: 80;
      isolation: isolate;
      backdrop-filter: blur(18px);
      background: rgba(6, 11, 19, 0.42);
      border-bottom: 1px solid rgba(255, 255, 255, 0.05);
      /* Bez overflow-x tutaj: inaczej przycinany jest cały stacking context nagłówka i na mobile
         nie widać pełnego .nav-backdrop ani panelu .nav (position:fixed, ale potomek headera). */
      max-width: 100%;
    }

    .site-header__inner {
      display: flex;
      align-items: center;
      flex-wrap: nowrap;
      gap: 12px 16px;
      min-height: 78px;
      min-width: 0;
      max-width: 100%;
    }

    /* Lewa strona paska: PL·EN (tekst, bez ramek) + logo */
    .site-header__start {
      order: 1;
      display: flex;
      align-items: center;
      gap: clamp(10px, 2vw, 18px);
      min-width: 0;
      flex: 0 1 auto;
    }

    /* Prawy górny róg: Facebook · Instagram · menu (mobile) */
    .site-header__trailing {
      order: 3;
      display: flex;
      align-items: center;
      gap: 8px;
      flex-shrink: 0;
      margin-left: auto;
    }

    /*
     * Kolejność w rzędzie nagłówka musi być twarda: PL·EN + marka (1) → linki (2) → social / hamburger (3).
     * Jeśli <nav> nie dostanie order (np. stary cache), ma domyślne 0 i wyląduje PRZED .site-header__start — jak na zrzucie z podstron.
     */
    .site-header .site-header__inner > .site-header__start {
      order: 1;
    }

    .site-header #main-nav {
      order: 2;
    }

    .site-header .site-header__inner > .site-header__trailing {
      order: 3;
    }

    .lang-switch {
      display: inline-flex;
      align-items: center;
      gap: 0;
      margin: 0;
      padding: 0;
      border: none;
      background: transparent;
      flex-shrink: 0;
    }

    .lang-switch__sep {
      color: rgba(255, 255, 255, 0.32);
      font-size: var(--text-caption);
      font-weight: 300;
      padding: 0 4px;
      user-select: none;
      pointer-events: none;
      line-height: 1;
    }

    .lang-switch__btn {
      appearance: none;
      cursor: pointer;
      font-family: inherit;
      font-size: var(--text-caption);
      font-weight: var(--font-weight-ui);
      letter-spacing: 0.12em;
      text-transform: uppercase;
      padding: 4px 0;
      margin: 0;
      border: none;
      border-radius: 0;
      color: rgba(178, 191, 211, 0.88);
      background: transparent;
      transition: color 0.2s ease;
    }

    .lang-switch__btn:hover {
      color: #fff;
    }

    .lang-switch__btn--active {
      color: #fff;
      font-weight: 600;
      background: transparent;
    }

    .lang-switch__btn:focus-visible {
      outline: 2px solid rgba(126, 160, 216, 0.85);
      outline-offset: 3px;
      border-radius: 2px;
    }

    .brand {
      display: flex;
      align-items: center;
      gap: 14px;
      min-width: 0;
      flex-shrink: 1;
    }

    .brand-copy {
      min-width: 0;
    }

    .brand-mark {
      flex-shrink: 0;
      width: 44px;
      height: 44px;
      border-radius: 14px;
      background: linear-gradient(160deg, rgba(126, 160, 216, 0.35), rgba(95, 120, 182, 0.2));
      border: 1px solid rgba(255, 255, 255, 0.12);
      box-shadow: inset 0 1px 1px rgba(255, 255, 255, 0.15), 0 12px 30px rgba(76, 103, 170, 0.28);
      position: relative;
      overflow: hidden;
    }

    .brand-mark img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
      border-radius: inherit;
    }

    .brand-copy strong {
      display: block;
      font-family: var(--font-script);
      font-size: clamp(1.05rem, 2.4vw, 1.35rem);
      font-weight: 600;
      letter-spacing: 0.02em;
      line-height: 1;
      text-transform: none;
      transform: rotate(-1.5deg);
      text-shadow: 0 6px 22px rgba(0, 0, 0, 0.28);
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }

    .brand-copy span {
      display: block;
      font-size: var(--text-body-sm);
      color: var(--muted);
      letter-spacing: 0.14em;
      text-transform: uppercase;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }

    .nav {
      order: 2;
      flex: 1 1 auto;
      justify-content: flex-end;
      display: flex;
      align-items: center;
      gap: clamp(10px, 1.8vw, 22px);
      flex-wrap: nowrap;
      min-width: 0;
    }

    .nav a {
      color: #d8e2f2;
      font-size: var(--text-ui);
      font-weight: var(--font-weight-ui);
      letter-spacing: 0.1em;
      text-transform: uppercase;
      transition: 0.25s ease;
      white-space: nowrap;
    }

    .nav a:hover { color: white; }

    .nav-cta {
      padding: 12px 18px;
      border-radius: 999px;
      font-weight: var(--font-weight-ui);
      background: linear-gradient(135deg, rgba(126,160,216,0.2), rgba(95,120,182,0.3));
      border: 1px solid rgba(126,160,216,0.28);
      box-shadow: 0 8px 24px rgba(64, 90, 147, 0.18);
    }

    .nav-cta--whatsapp-icon {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 40px;
      height: 40px;
      padding: 0;
      border-radius: 10px;
      color: #e8f0fc;
    }

    .nav-cta--whatsapp-icon:hover {
      color: #fff;
      background: linear-gradient(135deg, rgba(37, 211, 102, 0.14), rgba(95, 120, 182, 0.32));
      border-color: rgba(37, 211, 102, 0.32);
    }

    .nav-cta__icon {
      width: 20px;
      height: 20px;
      display: block;
    }

    .site-header__trailing .nav__social {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      margin: 0;
      padding: 0;
      border: none;
    }

    .nav__social-link {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 40px;
      height: 40px;
      border-radius: 10px;
      color: #c5d4ea;
      background: rgba(255, 255, 255, 0.06);
      border: 1px solid rgba(255, 255, 255, 0.1);
      transition:
        color 0.2s ease,
        background 0.2s ease,
        border-color 0.2s ease,
        transform 0.2s ease;
    }

    .nav__social-link:hover {
      color: #fff;
      background: rgba(126, 160, 216, 0.2);
      border-color: rgba(126, 160, 216, 0.35);
      transform: translateY(-1px);
    }

    .nav__social-link:focus-visible {
      outline: 2px solid rgba(126, 160, 216, 0.75);
      outline-offset: 2px;
    }

    .nav__social-icon {
      width: 18px;
      height: 18px;
      display: block;
    }

    .nav__social-icon--glyph {
      width: 17px;
      height: 17px;
    }

    .nav__social-link--fb:hover {
      color: #6ca0ff;
      background: rgba(88, 140, 255, 0.12);
      border-color: rgba(108, 160, 255, 0.42);
    }

    .nav__social-link--ig:hover {
      color: #f08cba;
      background: rgba(240, 140, 186, 0.1);
      border-color: rgba(240, 140, 186, 0.38);
    }

    /* Przycisk menu mobilnego — tylko ≤820px */
    .nav-toggle {
      display: none;
      flex-shrink: 0;
      align-items: center;
      justify-content: center;
      width: 48px;
      height: 48px;
      margin: 0;
      padding: 0;
      border: 1px solid rgba(255, 255, 255, 0.14);
      border-radius: 14px;
      background: rgba(255, 255, 255, 0.06);
      color: #e8eef9;
      cursor: pointer;
      position: relative;
      z-index: 2;
      -webkit-tap-highlight-color: transparent;
      touch-action: manipulation;
      transition:
        background 0.2s ease,
        border-color 0.2s ease,
        color 0.2s ease;
    }

    .nav-toggle:hover {
      background: rgba(126, 160, 216, 0.15);
      border-color: rgba(126, 160, 216, 0.35);
      color: #fff;
    }

    .nav-toggle:focus-visible {
      outline: 2px solid rgba(126, 160, 216, 0.85);
      outline-offset: 3px;
    }

    .nav-toggle__icon {
      display: flex;
      flex-direction: column;
      justify-content: center;
      gap: 5px;
      width: 22px;
      height: 18px;
    }

    .nav-toggle__line {
      display: block;
      height: 2px;
      width: 100%;
      background: currentColor;
      border-radius: 1px;
      transition:
        transform 0.3s ease,
        opacity 0.25s ease;
      transform-origin: center;
    }

    .site-header.is-menu-open .nav-toggle__line:nth-child(1) {
      transform: translateY(7px) rotate(45deg);
    }

    .site-header.is-menu-open .nav-toggle__line:nth-child(2) {
      opacity: 0;
      transform: scaleX(0);
    }

    .site-header.is-menu-open .nav-toggle__line:nth-child(3) {
      transform: translateY(-7px) rotate(-45deg);
    }

    .nav-backdrop {
      display: none;
    }

    body.podwiatr-nav-open {
      overflow: hidden;
    }

    section {
      padding: var(--section-pad-y) 0;
    }

    /* Pełna szerokość pasa kontaktu (jak #proces), bez perforacji — tylko cienkie linie */
    #kontakt {
      padding-left: 0;
      padding-right: 0;
    }

    /* --- Hero cinematic: pełna szerokość, zdjęcie + gradient lewy --- */
    .hero--cinematic {
      position: relative;
      min-height: 100vh;
      min-height: 100dvh;
      padding: 0;
      margin: 0;
      display: flex;
      align-items: center;
      overflow: hidden;
    }

    .hero__media {
      position: absolute;
      inset: 0;
      z-index: 0;
    }

    .hero__img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: 68% 45%;
      transform: scale(1.02);
      animation: heroKen 18s ease-in-out infinite alternate;
    }

    @keyframes heroKen {
      from { transform: scale(1.02) translate(0, 0); }
      to { transform: scale(1.08) translate(-1.2%, -0.6%); }
    }

    .hero__scrim {
      position: absolute;
      inset: 0;
      z-index: 1;
      pointer-events: none;
      background:
        linear-gradient(
          100deg,
          #070d16 0%,
          rgba(7, 13, 22, 0.94) 14%,
          rgba(10, 18, 31, 0.72) 28%,
          rgba(12, 22, 38, 0.38) 44%,
          rgba(14, 24, 40, 0.14) 58%,
          transparent 74%
        ),
        linear-gradient(
          180deg,
          rgba(4, 8, 14, 0.55) 0%,
          transparent 32%,
          transparent 58%,
          rgba(4, 8, 14, 0.45) 100%
        ),
        radial-gradient(ellipse 90% 80% at 0% 50%, rgba(7, 13, 22, 0.55), transparent 55%);
    }

    .hero__grain {
      position: absolute;
      inset: 0;
      z-index: 2;
      pointer-events: none;
      opacity: 0.07;
      mix-blend-mode: overlay;
      background-image: var(--bg-noise-svg);
    }

    .hero__inner {
      position: relative;
      z-index: 3;
      width: min(calc(100% - 40px), var(--container));
      margin: 0 auto;
      padding: clamp(100px, 14vh, 140px) 0 clamp(48px, 8vh, 72px);
      display: grid;
      align-items: center;
      min-height: min(100vh, 100dvh);
    }

    .hero__copy {
      max-width: min(52ch, 100%);
      padding-right: clamp(12px, 4vw, 48px);
    }

    .hero__title {
      font-family: var(--font-sans);
      font-weight: var(--font-weight-display);
      font-size: var(--text-hero);
      line-height: 0.98;
      letter-spacing: -0.03em;
      margin: 0;
      max-width: 14ch;
      color: #f4f7fd;
      text-shadow: 0 2px 48px rgba(0, 0, 0, 0.45);
    }

    .hero__title em {
      font-style: italic;
      color: #c8d8f4;
      font-weight: var(--font-weight-display);
    }

    .hero__lead {
      margin: 20px 0 0;
      font-size: var(--text-hero-lead);
      line-height: var(--leading-normal);
      font-weight: var(--font-weight-body);
      color: rgba(232, 238, 249, 0.92);
      max-width: 42ch;
      text-shadow: 0 2px 24px rgba(0, 0, 0, 0.4);
    }

    .hero-actions--hero {
      margin-top: 28px;
      margin-bottom: 0;
    }

    .hero__trust {
      margin: 18px 0 0;
      font-size: var(--text-small);
      line-height: 1.45;
      color: rgba(200, 214, 235, 0.82);
      max-width: 40ch;
      letter-spacing: 0.02em;
    }

    .hero__copy > * {
      opacity: 0;
      animation: heroIn 1.1s cubic-bezier(0.22, 1, 0.36, 1) forwards;
    }

    .hero__copy .hero__title {
      animation-delay: 0.12s;
    }

    .hero__copy .hero__lead {
      animation-delay: 0.28s;
    }

    .hero__copy .hero-actions--hero {
      animation-delay: 0.42s;
    }

    .hero__copy .hero__trust {
      animation-delay: 0.54s;
    }

    /* Sekcja proces — konwersja, czytelny flow + zdjęcia */
    .section-convert {
      padding: var(--section-pad-y) 0;
      border-top: 1px solid rgba(255, 255, 255, 0.06);
      background:
        radial-gradient(ellipse 70% 50% at 20% 0%, rgba(126, 160, 216, 0.08), transparent 55%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.02), transparent 50%);
    }

    @keyframes processAmbientDrift {
      0%,
      100% {
        transform: translate(0, 0) scale(1);
        opacity: 0.6;
      }
      50% {
        transform: translate(2.5%, -1.5%) scale(1.04);
        opacity: 0.85;
      }
    }

    .process-section {
      position: relative;
      overflow: hidden;
      content-visibility: auto;
      contain-intrinsic-size: auto 800px;
    }

    .process-section__ambient {
      pointer-events: none;
      position: absolute;
      inset: -35% -25% -25%;
      z-index: 0;
      background:
        radial-gradient(ellipse 58% 48% at 12% 28%, rgba(126, 160, 216, 0.24), transparent 58%),
        radial-gradient(ellipse 52% 44% at 88% 72%, rgba(95, 120, 182, 0.2), transparent 56%);
    }

    html.podwiatr-motion-on .process-section__ambient {
      animation: processAmbientDrift 16s ease-in-out infinite;
    }

    html.podwiatr-reduced-motion .process-section__ambient {
      animation: none;
      opacity: 0.55;
    }

    .process-section__inner {
      position: relative;
      z-index: 1;
    }

    .process-section__head {
      text-align: center;
      max-width: 40rem;
      margin: 0 auto var(--section-head-spacing);
    }

    .process-section__head .section-kicker {
      margin-bottom: 12px;
    }

    .process-section__title {
      font-family: var(--font-sans);
      font-weight: var(--font-weight-heading);
      font-size: var(--text-section);
      line-height: 1.02;
      margin: 0 0 16px;
      letter-spacing: -0.02em;
    }

    .process-section__lead {
      margin: 0 0 22px;
      font-size: var(--text-lead);
      line-height: 1.52;
      color: rgba(210, 222, 242, 0.92);
    }

    .process-section__gallery-link {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      font-size: var(--text-ui-sm);
      font-weight: var(--font-weight-ui);
      letter-spacing: 0.14em;
      text-transform: uppercase;
      padding-bottom: 3px;
      transition: transform 0.28s cubic-bezier(0.22, 1, 0.36, 1);
    }

    .process-section__gallery-link:hover {
      transform: translateY(-2px);
    }

    /* Pas kliszy + kontakt — domyślnie bez 100vw (na telefonie 100vw + calc(50%-50vw) psuje szerokość dokumentu i robi „drugi ekran”). Pełny bleed tylko od 901px → osobny blok niżej. */
    .process-flow-band,
    .contact-band {
      position: relative;
      width: 100%;
      max-width: none;
      margin-left: 0;
      margin-right: 0;
      margin-bottom: var(--section-block-gap);
      padding: 0;
      isolation: isolate;
      background: #1c2c42;
    }

    @media (min-width: 901px) {
      .process-flow-band,
      .contact-band {
        width: 100vw;
        max-width: 100vw;
        margin-left: calc(50% - 50vw);
        margin-right: calc(50% - 50vw);
      }
    }

    .process-flow-band {
      --process-band-sprocket-h: clamp(16px, 2.5vw, 21px);
      --process-film-strip: #d8e2f2;
      --process-sprocket-tile: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='18' viewBox='0 0 24 18'%3E%3Crect fill='%23d8e2f2' width='24' height='18'/%3E%3Crect fill='%232a3548' x='8' y='5' width='7' height='8' rx='1'/%3E%3C/svg%3E");
      --process-rail-w: clamp(12px, 2.4vw, 20px);
      --process-sprocket-rail-v: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='24' viewBox='0 0 14 24'%3E%3Crect fill='%23d8e2f2' width='14' height='24'/%3E%3Crect fill='%232a3548' x='3' y='8' width='8' height='8' rx='1'/%3E%3C/svg%3E");
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.09);
    }

    .contact-band {
      overflow: hidden;
      border-top: clamp(1px, 0.22vw, 3px) solid rgba(224, 234, 252, 0.26);
      border-bottom: clamp(1px, 0.22vw, 3px) solid rgba(224, 234, 252, 0.16);
    }

    /* Pełna szerokość: rozmyta scena rozpuszcza się w tło strony (--bg-base) po bokach */
    .contact-band::before {
      content: "";
      position: absolute;
      inset: -56px;
      z-index: 0;
      pointer-events: none;
      background-image: url("../images/sections/contact-lens-scene.png");
      background-size: cover;
      background-position: 50% 42%;
      filter: blur(38px) saturate(1.05) brightness(0.96);
      transform: scale(1.1);
      opacity: 0.88;
    }

    .contact-band::after {
      content: "";
      position: absolute;
      inset: 0;
      z-index: 1;
      pointer-events: none;
      background: linear-gradient(
        90deg,
        var(--bg-base) 0%,
        rgba(var(--bg-base-rgb), 0.82) 6%,
        rgba(var(--bg-base-rgb), 0.28) 18%,
        transparent 32%,
        transparent 68%,
        rgba(var(--bg-base-rgb), 0.28) 82%,
        rgba(var(--bg-base-rgb), 0.82) 94%,
        var(--bg-base) 100%
      );
    }

    .process-flow-band::before,
    .process-flow-band::after {
      content: "";
      position: absolute;
      left: 0;
      right: 0;
      height: var(--process-band-sprocket-h);
      z-index: 2;
      pointer-events: none;
      background-color: var(--process-film-strip);
      background-image: var(--process-sprocket-tile);
      background-size: 24px 100%;
      background-repeat: repeat-x;
    }

    .process-flow-band::before {
      top: 0;
      box-shadow:
        inset 0 -1px 0 rgba(0, 0, 0, 0.22),
        inset 0 1px 0 rgba(255, 255, 255, 0.35);
    }

    .process-flow-band::after {
      bottom: 0;
      box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.32),
        inset 0 -1px 0 rgba(0, 0, 0, 0.18);
    }

    .process-flow-band > .container {
      position: relative;
      z-index: 1;
      padding-top: calc(var(--process-band-sprocket-h) + clamp(8px, 1.2vw, 12px));
      padding-bottom: calc(var(--process-band-sprocket-h) + clamp(8px, 1.2vw, 12px));
    }

    .contact-band > .container {
      position: relative;
      z-index: 2;
      padding-top: clamp(22px, 4vw, 36px);
      padding-bottom: clamp(22px, 4vw, 36px);
    }

    .contact-band__inner {
      display: flex;
      flex-direction: column;
      align-items: center;
    }

    .process-flow {
      --pf-gap: clamp(22px, 2.85vw, 32px);
      --pf-line-w: clamp(4px, 0.42vw, 6px);
      --pf-line-pad: clamp(8px, 1.15vw, 12px);
      --pf-frame-line: linear-gradient(
        180deg,
        rgba(238, 244, 255, 0.58) 0%,
        rgba(148, 164, 198, 0.92) 18%,
        rgba(64, 82, 118, 0.96) 42%,
        rgba(28, 38, 58, 1) 100%
      );
      list-style: none;
      margin: 0;
      padding: 0;
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: var(--pf-gap);
    }

    /* Kafelek = „okno” klatki; overflow na dzieciach — żeby pionowe linie kliszy mogły wejść w połowę gapu */
    .process-flow__card {
      position: relative;
      z-index: 1;
      border-radius: 0;
      overflow: visible;
      border: 0;
      background: #0a0e16;
      box-shadow:
        0 22px 56px rgba(0, 0, 0, 0.42),
        inset 0 0 0 1px rgba(255, 255, 255, 0.05),
        inset 0 0 0 2px rgba(0, 0, 0, 0.35);
      transition:
        transform 0.5s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.5s ease;
    }

    html.podwiatr-motion-on .process-flow__card:hover {
      transform: translateY(-7px);
      box-shadow:
        0 32px 72px rgba(56, 78, 130, 0.38),
        inset 0 0 0 1px rgba(180, 200, 255, 0.12),
        inset 0 0 0 2px rgba(0, 0, 0, 0.3);
    }

    .process-flow__media {
      position: relative;
      aspect-ratio: 4 / 3;
      overflow: hidden;
      border-radius: 0;
      box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.06),
        inset 0 -1px 0 rgba(0, 0, 0, 0.4);
    }

    .process-flow__media img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      transition: transform 0.85s cubic-bezier(0.22, 1, 0.36, 1);
    }

    html.podwiatr-motion-on .process-flow__card:hover .process-flow__media img {
      transform: scale(1.08);
    }

    .process-flow__media::after {
      content: "";
      position: absolute;
      inset: 0;
      background: linear-gradient(185deg, transparent 32%, rgba(4, 10, 18, 0.88) 100%);
      pointer-events: none;
    }

    .process-flow__num {
      position: absolute;
      left: 14px;
      bottom: 10px;
      z-index: 2;
      font-family: var(--font-sans);
      font-size: var(--text-display-num);
      font-weight: var(--font-weight-heading);
      line-height: 1;
      color: rgba(255, 255, 255, 0.96);
      text-shadow: 0 6px 28px rgba(0, 0, 0, 0.5);
    }

    .process-flow__body {
      padding: 20px 20px 24px;
      border-radius: 0;
      background: linear-gradient(180deg, rgba(6, 10, 18, 0.98) 0%, rgba(8, 12, 20, 0.99) 100%);
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
    }

    .process-flow__card-title {
      margin: 0 0 10px;
      font-family: var(--font-sans);
      font-size: var(--text-process-label);
      font-weight: var(--font-weight-ui);
      letter-spacing: 0.06em;
      text-transform: uppercase;
      color: #f2f6fd;
    }

    .process-flow__card-text {
      margin: 0;
      font-size: var(--text-process-body);
      line-height: var(--leading-relaxed);
      color: rgba(205, 218, 238, 0.94);
    }

    /* Desktop / tablet: pionowe separatory (skraj + środek gapu). Wąski ekran: poniżej — poziome, ten sam układ w pionie. */
    @media (min-width: 1101px) {
      .process-flow__card::before {
        content: "";
        position: absolute;
        top: 0;
        bottom: 0;
        width: var(--pf-line-w);
        z-index: 4;
        pointer-events: none;
        background: var(--pf-frame-line);
        box-shadow: 1px 0 0 rgba(0, 0, 0, 0.22);
      }

      .process-flow__card:nth-child(1)::before {
        left: calc(-1 * var(--pf-line-pad));
        transform: none;
      }

      .process-flow__card:nth-child(n + 2)::before {
        left: calc(var(--pf-gap) / -2);
        transform: translateX(-50%);
      }

      .process-flow__card:nth-child(4)::after {
        content: "";
        position: absolute;
        top: 0;
        right: calc(-1 * var(--pf-line-pad));
        bottom: 0;
        width: var(--pf-line-w);
        z-index: 4;
        pointer-events: none;
        background: var(--pf-frame-line);
        box-shadow: -1px 0 0 rgba(0, 0, 0, 0.22);
      }
    }

    @media (max-width: 1100px) and (min-width: 641px) {
      .process-flow__card::before {
        content: "";
        position: absolute;
        top: 0;
        bottom: 0;
        width: var(--pf-line-w);
        z-index: 4;
        pointer-events: none;
        background: var(--pf-frame-line);
        box-shadow: 1px 0 0 rgba(0, 0, 0, 0.22);
      }

      .process-flow__card:nth-child(odd)::before {
        left: calc(-1 * var(--pf-line-pad));
        transform: none;
      }

      .process-flow__card:nth-child(even)::before {
        left: calc(var(--pf-gap) / -2);
        transform: translateX(-50%);
      }

      .process-flow__card:nth-child(even)::after {
        content: "";
        position: absolute;
        top: 0;
        right: calc(-1 * var(--pf-line-pad));
        bottom: 0;
        width: var(--pf-line-w);
        z-index: 4;
        pointer-events: none;
        background: var(--pf-frame-line);
        box-shadow: -1px 0 0 rgba(0, 0, 0, 0.22);
      }
    }

    .process-section__promise {
      box-sizing: border-box;
      max-width: 46rem;
      margin: 0 auto var(--section-block-gap);
      padding: clamp(20px, 3.5vw, 28px) clamp(22px, 4vw, 32px);
      text-align: center;
      font-size: var(--text-subtitle);
      line-height: var(--leading-relaxed);
      color: rgba(232, 240, 252, 0.96);
      border-radius: 0;
      border: 1px solid rgba(126, 160, 216, 0.26);
      background: linear-gradient(145deg, rgba(126, 160, 216, 0.12), rgba(14, 22, 38, 0.72));
      box-shadow: 0 16px 48px rgba(0, 0, 0, 0.28);
    }

    .process-section__promise strong {
      color: #fff;
      font-weight: var(--font-weight-ui);
    }

    .process-section__cta {
      justify-content: center;
      flex-wrap: wrap;
    }

    @media (max-width: 1100px) and (min-width: 641px) {
      .process-flow {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }
    }

    /* Wąski telefon: proces — boczne perforacje; kontakt — bez szyn, zwykły padding kontenera */
    @media (max-width: 640px) {
      .process-flow-band {
        --process-rail-w: clamp(16px, 5.2vw, 24px);
        --process-kernel-gap: clamp(10px, 3.2vw, 16px);
      }

      .process-flow-band::before,
      .process-flow-band::after {
        content: none !important;
        display: none !important;
        height: 0 !important;
        min-height: 0 !important;
        visibility: hidden !important;
        pointer-events: none !important;
      }

      .process-flow-band > .container {
        padding-top: clamp(14px, 3.5vw, 22px);
        padding-bottom: clamp(14px, 3.5vw, 22px);
        padding-left: calc(var(--process-rail-w) + var(--process-kernel-gap));
        padding-right: calc(var(--process-rail-w) + var(--process-kernel-gap));
      }

      .contact-band > .container {
        max-width: 100%;
        padding-top: clamp(14px, 3.5vw, 22px);
        padding-bottom: clamp(14px, 3.5vw, 22px);
      }

      .process-flow-band > .container::before,
      .process-flow-band > .container::after {
        content: "";
        position: absolute;
        top: 0;
        bottom: 0;
        width: var(--process-rail-w);
        z-index: 0;
        pointer-events: none;
        background-color: var(--process-film-strip);
        background-image: var(--process-sprocket-rail-v);
        background-size: var(--process-rail-w) 24px;
        background-repeat: repeat-y;
      }

      .process-flow-band > .container::before {
        left: 0;
        background-position: left top;
      }

      .process-flow-band > .container::after {
        right: 0;
        background-position: right top;
      }

      .process-flow {
        grid-template-columns: 1fr;
        max-width: min(100%, 21.25rem);
        margin-inline: auto;
        --pf-gap: clamp(18px, 4.5vw, 26px);
      }

      /* Poziome linie kliszy = to samo co na desktopie, ale oś pionowa: góra pierwszej karty, środek odstępów między rzędami, dół ostatniej */
      .process-flow__card::before {
        content: "";
        position: absolute;
        left: 0;
        right: 0;
        width: auto;
        height: var(--pf-line-w);
        z-index: 4;
        pointer-events: none;
        background: var(--pf-frame-line);
        box-shadow: 0 1px 0 rgba(0, 0, 0, 0.22);
      }

      .process-flow__card:first-child::before {
        top: calc(-1 * var(--pf-line-pad));
        transform: none;
      }

      .process-flow__card:not(:first-child)::before {
        top: calc(var(--pf-gap) / -2);
        transform: translateY(-50%);
      }

      .process-flow__card:last-child::after {
        content: "";
        position: absolute;
        left: 0;
        right: 0;
        width: auto;
        height: var(--pf-line-w);
        bottom: calc(-1 * var(--pf-line-pad));
        top: auto;
        z-index: 4;
        pointer-events: none;
        background: var(--pf-frame-line);
        box-shadow: 0 -1px 0 rgba(0, 0, 0, 0.22);
      }
    }

    /* Intro: treść w „taśmie” paneli + sticky portret — czytelna hierarchia */
    .section-intro {
      padding: var(--section-pad-y) 0;
      border-top: 1px solid rgba(255, 255, 255, 0.06);
      background:
        radial-gradient(ellipse 80% 55% at 12% 18%, rgba(126, 160, 216, 0.09), transparent 58%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.025), transparent 48%);
      overflow: visible;
    }

    .section-intro__shell {
      display: block;
    }

    .section-intro__main {
      min-width: 0;
      display: flex;
      flex-direction: column;
      gap: clamp(28px, 4vw, 40px);
    }

    .section-intro__lead {
      margin: 0;
      padding: 0 0 8px;
      border-bottom: 1px solid rgba(255, 255, 255, 0.07);
    }

    .section-intro__eyebrow {
      margin-bottom: 14px;
    }

    .section-intro__title {
      font-family: var(--font-sans);
      font-size: var(--text-intro);
      font-weight: var(--font-weight-heading);
      line-height: 1.04;
      letter-spacing: -0.03em;
      margin: 0 0 16px;
      max-width: min(100%, 22ch);
    }

    .section-intro__hook {
      font-size: var(--text-lead);
      line-height: var(--leading-relaxed);
      color: rgba(228, 236, 250, 0.95);
      max-width: 42ch;
      margin: 0 0 24px;
      letter-spacing: 0.01em;
    }

    .section-intro .section-intro__actions {
      margin: 0;
      flex-wrap: wrap;
      gap: 12px 16px;
    }

    .section-intro__panel {
      padding: clamp(20px, 3vw, 26px) clamp(22px, 3.2vw, 28px);
      border-radius: 20px;
      border: 1px solid rgba(255, 255, 255, 0.1);
      background: linear-gradient(155deg, rgba(255, 255, 255, 0.055), rgba(6, 12, 22, 0.45));
      box-shadow: 0 18px 48px rgba(0, 0, 0, 0.28);
    }

    .section-intro__panel-kicker {
      margin: 0 0 18px;
      font-size: var(--text-caption);
      font-weight: var(--font-weight-ui);
      letter-spacing: 0.2em;
      text-transform: uppercase;
      color: #a8bddc;
    }

    .section-intro__panel--reach .section-intro__split {
      margin-bottom: 0;
    }

    .section-intro__pillars {
      list-style: none;
      margin: 0;
      padding: 0;
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: clamp(14px, 2vw, 20px);
    }

    .section-intro__pillar {
      padding: 18px 16px 20px;
      border-radius: 14px;
      border: 1px solid rgba(255, 255, 255, 0.08);
      background: rgba(4, 10, 20, 0.35);
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
    }

    .section-intro__pillar-kicker {
      display: block;
      font-size: var(--text-caption);
      letter-spacing: 0.2em;
      color: var(--accent);
      margin-bottom: 10px;
      text-transform: uppercase;
    }

    .section-intro__pillar-title {
      display: block;
      font-weight: var(--font-weight-ui);
      color: #f2f6fc;
      font-size: var(--text-title);
      margin-bottom: 8px;
      letter-spacing: 0.02em;
      line-height: 1.25;
    }

    .section-intro__pillar-text {
      display: block;
      font-size: var(--text-body-sm);
      line-height: var(--leading-normal);
      color: rgba(190, 204, 228, 0.92);
    }

    .section-intro__split {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: clamp(14px, 2vw, 18px);
      margin: 0 0 22px;
    }

    .section-intro__split-card {
      padding: 18px 18px 20px;
      border-radius: 14px;
      border: 1px solid rgba(255, 255, 255, 0.1);
      background: rgba(255, 255, 255, 0.04);
    }

    .section-intro__split-card--accent {
      border-color: rgba(126, 160, 216, 0.4);
      background: linear-gradient(145deg, rgba(126, 160, 216, 0.16), rgba(7, 16, 28, 0.5));
      box-shadow: 0 12px 36px rgba(76, 103, 170, 0.18);
    }

    .section-intro__split-label {
      display: block;
      font-size: var(--text-caption);
      letter-spacing: 0.16em;
      text-transform: uppercase;
      color: rgba(180, 196, 222, 0.85);
      margin-bottom: 8px;
    }

    .section-intro__split-lead {
      margin: 0 0 8px;
      font-size: var(--text-title);
      font-weight: var(--font-weight-title-sm);
      color: #f6f8fd;
      line-height: 1.2;
    }

    .section-intro__split-note {
      margin: 0;
      font-size: var(--text-body-sm);
      line-height: 1.5;
      color: rgba(190, 204, 228, 0.9);
    }

    .section-intro__panel--reach .section-intro__stats {
      margin: 0;
      padding: 20px 0 0;
      border: none;
      border-top: 1px solid rgba(255, 255, 255, 0.1);
      max-width: none;
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 8px 12px;
    }

    .section-intro__stat {
      text-align: center;
      padding: 10px 8px;
      border-radius: 12px;
      background: rgba(0, 0, 0, 0.15);
    }

    .section-intro__stat-value {
      display: block;
      font-size: var(--text-stat);
      font-weight: var(--font-weight-ui);
      color: #c5d8f5;
      letter-spacing: 0.04em;
      line-height: 1.15;
    }

    .section-intro__stat-label {
      display: block;
      font-size: var(--text-caption);
      text-transform: uppercase;
      letter-spacing: 0.08em;
      color: rgba(170, 188, 218, 0.88);
      margin-top: 8px;
      line-height: 1.35;
    }

    .section-intro .quote--feature.section-intro__quote {
      margin: 0;
      max-width: none;
      padding: clamp(22px, 3vw, 30px) clamp(24px, 3.5vw, 36px);
      border: 1px solid rgba(126, 160, 216, 0.22);
      border-left: 4px solid rgba(126, 160, 216, 0.65);
      background: linear-gradient(105deg, rgba(126, 160, 216, 0.12), rgba(8, 14, 26, 0.65));
      border-radius: 18px;
      box-shadow: 0 20px 56px rgba(0, 0, 0, 0.25);
    }

    .section-intro .quote--feature.section-intro__quote p {
      margin: 0 0 14px;
      font-size: var(--text-quote-feature);
      font-style: italic;
      font-weight: var(--font-weight-display);
      line-height: 1.45;
      color: #e8eef9;
      max-width: 36ch;
    }

    .section-intro .quote--feature.section-intro__quote footer {
      font-size: var(--text-small);
      color: rgba(180, 196, 222, 0.9);
      letter-spacing: 0.03em;
      line-height: 1.45;
    }

    .section-intro__panel--highlights .intro-highlights--compact {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 0;
      max-width: none;
      margin: 0;
    }

    .section-intro__panel--highlights .intro-highlights--compact .intro-highlight {
      padding: 16px 20px 18px;
      margin: 0;
      border-radius: 0;
      border: none;
      background: transparent;
      box-shadow: none;
      border-left: 1px solid rgba(255, 255, 255, 0.1);
    }

    .section-intro__panel--highlights .intro-highlights--compact .intro-highlight:first-child {
      border-left: none;
      padding-left: 0;
    }

    .section-intro__panel--highlights .intro-highlights--compact .intro-highlight strong {
      font-size: var(--text-ui);
      margin-bottom: 8px;
    }

    .section-intro__panel--highlights .intro-highlights--compact .intro-highlight span {
      font-size: var(--text-body-sm);
      line-height: 1.48;
    }

    .section-intro__photo {
      margin: 0;
      position: sticky;
      top: 92px;
      justify-self: end;
      width: 100%;
      max-width: min(100%, 400px);
      padding: 0;
      z-index: 1;
    }

    .section-intro__photo-visual {
      position: relative;
      width: 100%;
      aspect-ratio: 4 / 5;
      max-height: min(70vh, 640px);
      border-radius: var(--radius-xl);
      overflow: hidden;
      box-shadow:
        0 28px 70px rgba(0, 0, 0, 0.45),
        0 0 0 1px rgba(255, 255, 255, 0.09),
        inset 0 1px 0 rgba(255, 255, 255, 0.14);
      background: linear-gradient(160deg, rgba(126, 160, 216, 0.15), rgba(7, 16, 28, 0.5));
    }

    /* Delikatna „szklana” poświata po lewej krawędzi kadru — stapia portret z tłem sekcji */
    .section-intro__photo-visual::after {
      content: "";
      position: absolute;
      inset: 0;
      pointer-events: none;
      z-index: 2;
      background: linear-gradient(
        100deg,
        rgba(7, 16, 28, 0.88) 0%,
        rgba(7, 16, 28, 0.35) 22%,
        rgba(7, 16, 28, 0.06) 40%,
        transparent 52%
      );
    }

    .section-intro__photo-visual img {
      width: 100%;
      height: 100%;
      display: block;
      object-fit: cover;
      object-position: 58% 20%;
      transform: scale(1.07);
      transform-origin: 65% 28%;
      position: relative;
      z-index: 0;
      -webkit-mask-image: linear-gradient(
        to left,
        #000 0%,
        #000 48%,
        rgba(0, 0, 0, 0.55) 72%,
        rgba(0, 0, 0, 0.12) 90%,
        transparent 100%
      );
      mask-image: linear-gradient(
        to left,
        #000 0%,
        #000 48%,
        rgba(0, 0, 0, 0.55) 72%,
        rgba(0, 0, 0, 0.12) 90%,
        transparent 100%
      );
      -webkit-mask-repeat: no-repeat;
      mask-repeat: no-repeat;
      -webkit-mask-size: 100% 100%;
      mask-size: 100% 100%;
    }

    .section-intro__caption {
      position: static;
      margin: 14px 0 0;
      font-size: var(--text-small);
      color: var(--muted);
      letter-spacing: 0.06em;
      text-transform: uppercase;
      text-align: right;
      line-height: 1.4;
      max-width: none;
      text-shadow: none;
      pointer-events: none;
    }

    /*
     * Wartość / „O mnie” v2: przewodnia czerń + „odwrócone” światła — granat i niebieski
     * (jak editorial na czarnym, a nie jasny wash ze strony głównej).
     */
    .about-v2 {
      position: relative;
      color: var(--text);
      border-top: 1px solid rgba(126, 160, 216, 0.12);
      background: var(--page-bg-about-dark);
    }

    .about-v2-hero {
      position: relative;
      overflow: hidden;
    }

    .about-v2-hero__visual {
      position: relative;
      min-height: min(78vh, 720px);
      max-height: min(88vh, 900px);
    }

    .about-v2-hero__media {
      position: absolute;
      inset: 0;
      overflow: hidden;
    }

    .about-v2-hero__img-stack {
      position: absolute;
      inset: 0;
      overflow: hidden;
      transform-origin: 50% 42%;
    }

    .about-v2-hero__img {
      width: 100%;
      height: 100%;
      display: block;
      object-fit: cover;
      object-position: 50% 42%;
      transform-origin: 50% 42%;
    }

    /* Pełny kolor w centrum (~60% „kolorowości” całości dzięki mieszance z warstwą mono na brzegach). */
    .about-v2-hero__img--color {
      filter: contrast(1.04) saturate(1.02) brightness(0.98);
    }

    /* Czarno-biała warstwa widoczna głównie przy krawędziach — maska radialna. */
    .about-v2-hero__img--mono {
      position: absolute;
      inset: 0;
      pointer-events: none;
      filter: grayscale(1) contrast(1.07) brightness(0.93);
      -webkit-mask-image: radial-gradient(
        ellipse 72% 64% at 50% 42%,
        rgba(0, 0, 0, 0) 0%,
        rgba(0, 0, 0, 0) 30%,
        rgba(0, 0, 0, 0.38) 52%,
        rgba(0, 0, 0, 0.82) 100%
      );
      mask-image: radial-gradient(
        ellipse 72% 64% at 50% 42%,
        rgba(0, 0, 0, 0) 0%,
        rgba(0, 0, 0, 0) 30%,
        rgba(0, 0, 0, 0.38) 52%,
        rgba(0, 0, 0, 0.82) 100%
      );
      -webkit-mask-repeat: no-repeat;
      mask-repeat: no-repeat;
      -webkit-mask-size: 100% 100%;
      mask-size: 100% 100%;
    }

    .about-v2-hero__grain {
      position: absolute;
      inset: 0;
      pointer-events: none;
      z-index: 2;
      opacity: 0.09;
      mix-blend-mode: overlay;
      background-image: var(--bg-noise-svg);
      background-size: 220px 220px;
    }

    .about-v2-hero__scrim {
      position: absolute;
      inset: 0;
      z-index: 1;
      pointer-events: none;
      background:
        linear-gradient(105deg, rgba(2, 6, 12, 0.5) 0%, transparent 42%),
        linear-gradient(
          180deg,
          rgba(4, 8, 14, 0.25) 0%,
          rgba(12, 36, 62, 0.42) 48%,
          rgba(2, 4, 10, 0.88) 100%
        );
    }

    .about-v2-hero__content {
      position: relative;
      z-index: 3;
      max-width: min(100%, 640px);
      margin: clamp(-72px, -10vw, -40px) auto 0;
      padding: 0 0 clamp(48px, 7vw, 72px);
      text-align: left;
    }

    .about-v2-hero__lead {
      margin: 0 0 22px;
      font-family: var(--font-sans);
      font-size: clamp(1.35rem, 3.8vw, 2.15rem);
      font-weight: var(--font-weight-display);
      line-height: 1.18;
      letter-spacing: -0.02em;
      color: #fff;
      text-shadow: 0 18px 48px rgba(0, 0, 0, 0.45);
    }

    h1.about-v2-hero__lead {
      font-weight: var(--font-weight-display);
    }

    .about-v2-hero__quote {
      margin: 0 0 28px;
      padding: 0 0 0 18px;
      border-left: 3px solid rgba(126, 160, 216, 0.55);
    }

    .about-v2-hero__quote p {
      margin: 0;
      font-size: clamp(1.05rem, 2.2vw, 1.35rem);
      font-style: italic;
      font-weight: var(--font-weight-display);
      line-height: 1.5;
      color: rgba(236, 241, 252, 0.94);
    }

    .about-v2-hero__sign {
      margin: 0 0 12px;
      font-family: var(--font-script);
      font-size: clamp(2.5rem, 6vw, 3.25rem);
      font-weight: 600;
      line-height: 1;
      color: rgba(255, 255, 255, 0.92);
      transform: rotate(-1.5deg);
      text-shadow: 0 12px 40px rgba(0, 0, 0, 0.35);
    }

    .about-v2-hero__bio {
      margin: 0;
      font-size: var(--text-caption);
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: rgba(180, 196, 220, 0.75);
      line-height: 1.5;
    }

    /* Strona główna — ten sam schemat co „O mnie”: zdjęcie (kolor + mono na brzegach) + blok tekstu w kontenerze */
    .home-hero-v2.about-v2 {
      padding: 0;
      margin: 0;
      border-top: none;
    }

    .about-v2-hero--home .about-v2-hero__visual {
      min-height: min(80vh, 760px);
      max-height: min(90vh, 920px);
    }

    .about-v2-hero--home .about-v2-hero__img,
    .about-v2-hero--home .about-v2-hero__img-stack {
      object-position: 68% 45%;
      transform-origin: 68% 45%;
    }

    /* Wyrównanie „centrum” maski mono do kadru portretu zimowego (jak poprzedni hero cinematic). */
    .about-v2-hero--home .about-v2-hero__img--mono {
      -webkit-mask-image: radial-gradient(
        ellipse 72% 64% at 68% 45%,
        rgba(0, 0, 0, 0) 0%,
        rgba(0, 0, 0, 0) 30%,
        rgba(0, 0, 0, 0.38) 52%,
        rgba(0, 0, 0, 0.82) 100%
      );
      mask-image: radial-gradient(
        ellipse 72% 64% at 68% 45%,
        rgba(0, 0, 0, 0) 0%,
        rgba(0, 0, 0, 0) 30%,
        rgba(0, 0, 0, 0.38) 52%,
        rgba(0, 0, 0, 0.82) 100%
      );
    }

    .about-v2-hero--home .about-v2-hero__content {
      max-width: min(100%, 680px);
    }

    /* Hero strony głównej — editorial / luxury / minimal (Apple-adjacent) */
    .home-hero-editorial .about-v2-hero--home .about-v2-hero__content.home-hero-editorial__shell {
      max-width: min(100%, 780px);
      padding: 0 0 clamp(36px, 6vw, 56px);
      margin-top: clamp(-68px, -9vw, -38px);
    }

    .home-hero-editorial .about-v2-hero__scrim.home-hero-editorial__scrim {
      background:
        linear-gradient(112deg, rgba(3, 8, 16, 0.48) 0%, rgba(4, 10, 20, 0.12) 44%, transparent 62%),
        linear-gradient(180deg, rgba(4, 10, 18, 0.18) 0%, rgba(8, 20, 36, 0.38) 52%, rgba(2, 4, 10, 0.9) 100%);
    }

    .home-hero-editorial__title {
      margin: clamp(12px, 2vw, 22px) 0 clamp(30px, 4.5vw, 44px);
      max-width: 26ch;
      font-family: var(--font-sans);
      font-size: clamp(1.65rem, 4.5vw, 2.85rem);
      font-weight: var(--font-weight-display);
      line-height: 1.1;
      letter-spacing: -0.038em;
      color: #f6f8fd;
      text-shadow: 0 28px 64px rgba(0, 0, 0, 0.38);
    }

    @supports (text-wrap: pretty) {
      .home-hero-editorial__title {
        text-wrap: pretty;
      }
    }

    .home-hero-trust {
      display: grid;
      gap: 0;
      margin: 0 0 clamp(32px, 5vw, 44px);
      padding: 0;
      list-style: none;
    }

    .home-hero-trust__item {
      margin: 0;
      padding: 14px 0 14px 18px;
      border-left: 1px solid rgba(126, 160, 216, 0.42);
      font-size: 0.8125rem;
      line-height: 1.45;
      letter-spacing: 0.035em;
      color: rgba(228, 236, 250, 0.84);
    }

    @media (min-width: 700px) {
      .home-hero-trust {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: clamp(10px, 2vw, 24px);
      }

      .home-hero-trust__item {
        padding: 12px 0 0 18px;
        border-left: 1px solid rgba(126, 160, 216, 0.42);
        border-bottom: none;
        min-height: 3.25rem;
      }
    }

    @media (max-width: 699px) {
      .home-hero-trust__item {
        border-left: none;
        border-bottom: 1px solid rgba(255, 255, 255, 0.07);
        padding-left: 0;
      }

      .home-hero-trust__item:last-child {
        border-bottom: none;
      }
    }

    .home-hero-contact {
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      justify-content: flex-start;
      gap: 12px 18px;
    }

    .home-hero-contact__actions {
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      gap: 10px;
      flex: 0 1 auto;
      min-width: 0;
    }

    .home-hero-contact__tel-wrap {
      display: inline-flex;
    }

    .home-hero-btn {
      min-height: 44px;
      padding-inline: 18px;
      border-radius: 999px;
      font-size: var(--text-ui-sm);
      letter-spacing: 0.07em;
    }

    .home-hero-btn .hero__cta-icon {
      width: 18px;
      height: 18px;
    }

    .home-hero-btn--ig.button--glass {
      border-color: rgba(255, 255, 255, 0.16);
      background: rgba(255, 255, 255, 0.045);
    }

    .home-hero-gallery {
      display: inline-flex;
      align-items: center;
      align-self: center;
      min-height: 44px;
      margin: 0;
      padding: 8px 10px 10px;
      font-size: 0.72rem;
      font-weight: 500;
      letter-spacing: 0.2em;
      text-transform: uppercase;
    }

    .home-hero-gallery.text-link--editorial {
      color: rgba(255, 255, 255, 0.46);
      border-bottom-color: rgba(255, 255, 255, 0.16);
    }

    .home-hero-gallery.text-link--editorial:hover {
      color: rgba(255, 255, 255, 0.88);
      border-bottom-color: rgba(255, 255, 255, 0.32);
    }

    /* „Przewiń” w przepływie dokumentu — wyśrodkowane w kolumnie hero, odstęp od CTA zamiast nakładki na dół sekcji */
    .home-hero-scroll {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 10px;
      width: 100%;
      margin-top: clamp(36px, 5.5vw, 56px);
      margin-bottom: 0;
      padding-top: clamp(8px, 1.5vw, 14px);
      color: rgba(255, 255, 255, 0.45);
      font-size: var(--text-caption);
      letter-spacing: 0.28em;
      text-transform: uppercase;
      pointer-events: none;
    }

    .home-hero-scroll .hero__scroll-line {
      flex-shrink: 0;
    }

    @media (max-width: 560px) {
      .home-hero-contact {
        flex-direction: column;
        align-items: stretch;
      }

      .home-hero-contact__actions {
        justify-content: flex-start;
      }

      .home-hero-gallery {
        align-self: center;
        margin-top: 4px;
      }

      .home-hero-scroll {
        margin-top: clamp(28px, 8vw, 40px);
      }
    }

    @media (min-width: 561px) {
      .home-hero-gallery {
        margin-left: clamp(12px, 2.4vw, 28px);
      }
    }

    .about-v2-band {
      padding: clamp(48px, 7vw, 72px) 0;
      border-top: 1px solid rgba(100, 140, 200, 0.1);
      background:
        radial-gradient(ellipse 75% 55% at 15% 0%, rgba(126, 160, 216, 0.12), transparent 58%),
        radial-gradient(ellipse 60% 50% at 85% 100%, rgba(8, 28, 48, 0.75), transparent 52%),
        linear-gradient(180deg, rgba(4, 8, 14, 0.65), rgba(2, 3, 6, 0.92));
    }

    .about-v2-band__inner {
      max-width: min(100%, 920px);
      margin: 0 auto;
    }

    .about-v2-client {
      margin: 0 0 clamp(32px, 4vw, 44px);
      font-size: var(--text-lead);
      line-height: var(--leading-relaxed);
      color: rgba(220, 230, 248, 0.95);
      max-width: 58ch;
    }

    .about-v2-micros {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: clamp(18px, 2.5vw, 28px);
    }

    .about-v2-micro {
      padding: clamp(18px, 2.5vw, 22px) 0 0;
      border-top: 1px solid rgba(255, 255, 255, 0.1);
    }

    .about-v2-micro__title {
      margin: 0 0 10px;
      font-size: var(--text-ui-sm);
      font-weight: var(--font-weight-ui);
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: #e8eef8;
    }

    .about-v2-micro__text {
      margin: 0;
      font-size: var(--text-body-sm);
      line-height: 1.58;
      color: var(--muted);
    }

    .about-v2-fears {
      padding: clamp(44px, 6vw, 64px) 0;
      border-top: 1px solid rgba(100, 140, 200, 0.09);
      background:
        radial-gradient(ellipse 85% 75% at 50% 0%, rgba(110, 150, 215, 0.14), transparent 58%),
        radial-gradient(ellipse 50% 45% at 0% 90%, rgba(16, 42, 72, 0.85), transparent 50%),
        linear-gradient(180deg, #030408 0%, #05070c 100%);
    }

    .about-v2-fears__inner {
      max-width: min(100%, 720px);
      margin: 0 auto;
    }

    .about-v2-fears__head {
      margin-bottom: clamp(22px, 3vw, 30px);
    }

    .about-v2-fears__kicker {
      margin: 0 0 8px;
      font-size: var(--text-caption);
      font-weight: var(--font-weight-ui);
      letter-spacing: 0.2em;
      text-transform: uppercase;
      color: rgba(168, 189, 220, 0.88);
    }

    .about-v2-fears__title {
      margin: 0;
      font-size: var(--text-title);
      font-weight: var(--font-weight-heading);
      line-height: 1.2;
      letter-spacing: -0.01em;
    }

    .about-v2-fears__list {
      list-style: none;
      margin: 0;
      padding: 0;
      display: flex;
      flex-direction: column;
      gap: clamp(20px, 2.5vw, 26px);
    }

    .about-v2-fear__q {
      margin: 0 0 8px;
      font-size: var(--text-body);
      font-weight: var(--font-weight-ui);
      color: #f0f4fc;
      line-height: 1.45;
    }

    .about-v2-fear__a {
      margin: 0;
      font-size: var(--text-body-sm);
      line-height: 1.6;
      color: var(--muted);
      max-width: 56ch;
    }

    .about-v2-cta {
      padding: clamp(44px, 6vw, 64px) 0 clamp(56px, 8vw, 80px);
      border-top: 1px solid rgba(126, 160, 216, 0.14);
      background:
        radial-gradient(ellipse 100% 90% at 75% 0%, rgba(130, 170, 230, 0.18), transparent 55%),
        radial-gradient(ellipse 55% 50% at 10% 100%, rgba(20, 55, 90, 0.55), transparent 48%),
        linear-gradient(185deg, #020305 0%, #060a12 55%, #020203 100%);
    }

    .about-v2-cta__inner {
      max-width: min(100%, 720px);
      margin: 0 auto;
      text-align: center;
    }

    .about-v2-cta__head {
      margin-bottom: 22px;
    }

    .about-v2-cta__kicker {
      margin: 0 0 8px;
      font-size: var(--text-caption);
      font-weight: var(--font-weight-ui);
      letter-spacing: 0.2em;
      text-transform: uppercase;
      color: rgba(180, 200, 232, 0.9);
    }

    .about-v2-cta__lead {
      margin: 0;
      font-size: var(--text-body);
      color: rgba(210, 222, 244, 0.92);
    }

    .about-v2-cta__actions {
      justify-content: center;
      margin-top: 8px;
      margin-bottom: 0;
    }

    .about-v2-cta__btn-ghost {
      border-color: rgba(255, 255, 255, 0.22);
      color: rgba(248, 250, 255, 0.96);
    }

    .about-v2-cta__ig.hero__ig-cta {
      min-height: 52px;
    }

    .about-v2-cta__fineprint {
      margin: 20px 0 0;
      font-size: var(--text-body-sm);
      color: rgba(170, 188, 214, 0.85);
    }

    .about-v2-cta__link {
      color: rgba(200, 218, 248, 0.95);
      text-decoration: underline;
      text-underline-offset: 3px;
    }

    .about-v2-cta__link:hover {
      color: #fff;
    }

    .about-v2-cta__dot {
      margin: 0 8px;
      opacity: 0.5;
    }

    @media (max-width: 820px) {
      .about-v2-micros {
        grid-template-columns: 1fr;
      }

      .about-v2-micro {
        padding-top: 16px;
      }
    }

    @media (prefers-reduced-motion: no-preference) {
      html.podwiatr-motion-on .about-v2-hero__img-stack {
        animation: aboutV2Ken 28s ease-in-out infinite alternate;
      }
    }

    @keyframes aboutV2Ken {
      from {
        transform: scale(1.05) translate(0, 0);
      }
      to {
        transform: scale(1.12) translate(0.6%, -1.2%);
      }
    }

    .intro-highlights {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 14px;
      max-width: 620px;
    }

    .intro-highlight {
      padding: 16px 18px;
      border-radius: var(--radius-md);
      background: linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.025));
      border: 1px solid rgba(255, 255, 255, 0.08);
      box-shadow: 0 12px 36px rgba(0, 0, 0, 0.22);
    }

    .intro-highlight strong {
      display: block;
      font-size: var(--text-body);
      font-weight: var(--font-weight-ui);
      margin-bottom: 6px;
      color: #e8eef9;
      letter-spacing: 0.02em;
    }

    .intro-highlight span {
      color: var(--muted);
      font-size: var(--text-body-sm);
      line-height: 1.45;
    }

    @keyframes heroIn {
      from {
        opacity: 0;
        transform: translateY(28px);
      }
      to {
        opacity: 1;
        transform: translateY(0);
      }
    }

    .hero__scroll {
      position: absolute;
      bottom: 28px;
      left: 50%;
      transform: translateX(-50%);
      z-index: 4;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 10px;
      color: rgba(255, 255, 255, 0.45);
      font-size: var(--text-caption);
      letter-spacing: 0.28em;
      text-transform: uppercase;
      pointer-events: none;
    }

    .hero__scroll-line {
      width: 1px;
      height: 48px;
      background: linear-gradient(to bottom, rgba(255, 255, 255, 0.5), transparent);
      animation: heroScroll 2.2s ease-in-out infinite;
    }

    @keyframes heroScroll {
      0%, 100% { opacity: 0.35; transform: scaleY(0.85); transform-origin: top; }
      50% { opacity: 1; transform: scaleY(1); }
    }

    .eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      padding: 10px 14px;
      border-radius: 999px;
      border: 1px solid rgba(255,255,255,0.08);
      background: rgba(255,255,255,0.03);
      color: #dbe6f6;
      font-size: var(--text-ui-sm);
      font-weight: var(--font-weight-ui);
      letter-spacing: 0.06em;
      text-transform: uppercase;
      margin-bottom: 18px;
    }

    .eyebrow::before {
      content: "";
      width: 8px;
      height: 8px;
      border-radius: 50%;
      background: linear-gradient(135deg, #c7d7ff, #7ea0d8);
      box-shadow: 0 0 16px rgba(126,160,216,0.8);
    }

    h1, h2, h3, p { margin-top: 0; }

    h1 {
      font-family: var(--font-sans);
      font-weight: var(--font-weight-heading);
      font-size: var(--text-page-hero);
      line-height: 1.08;
      letter-spacing: -0.02em;
      margin-bottom: 16px;
    }

    .quote {
      padding: 18px 20px;
      border-left: 3px solid rgba(126,160,216,0.48);
      background: rgba(255,255,255,0.03);
      border-radius: 0 18px 18px 0;
      color: #dce5f4;
      max-width: 58ch;
      margin-bottom: var(--section-head-spacing);
    }

    .hero-actions {
      display: flex;
      gap: 14px;
      flex-wrap: wrap;
      margin-bottom: var(--section-head-spacing);
    }

    .button {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      min-height: 52px;
      padding: 0 22px;
      border-radius: 999px;
      font-size: var(--text-ui);
      font-weight: var(--font-weight-ui);
      transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
      border: 1px solid transparent;
    }

    .button:hover { transform: translateY(-2px); }

    .button--primary {
      background: linear-gradient(135deg, #7ea0d8, #5f78b6);
      color: #07101c;
      box-shadow: 0 16px 34px rgba(95,120,182,0.28);
    }

    .button--secondary {
      background: rgba(255,255,255,0.03);
      border-color: rgba(255,255,255,0.1);
      color: #edf3fb;
    }

    .button:focus-visible {
      outline: 2px solid rgba(180, 205, 255, 0.95);
      outline-offset: 3px;
    }

    .button:focus:not(:focus-visible) {
      outline: none;
    }

    .button:active {
      transform: translateY(0) scale(0.98);
      transition-duration: 0.12s;
    }

    .button:disabled,
    .button.button--loading {
      cursor: wait;
      opacity: 0.88;
      pointer-events: none;
      transform: none;
    }

    .button--primary:active {
      box-shadow: 0 10px 26px rgba(95, 120, 182, 0.32);
    }

    .button--secondary:active {
      background: rgba(255, 255, 255, 0.07);
    }

    .nav-cta:focus-visible {
      outline: 2px solid rgba(180, 205, 255, 0.9);
      outline-offset: 3px;
    }

    .nav-cta:active {
      transform: scale(0.97);
    }

    /* Formularz: focus, błędy, baner demo, status */
    .form-feedback {
      min-height: 0;
      margin: 0 0 14px;
      font-size: var(--text-body-sm);
      line-height: 1.5;
      color: rgba(200, 220, 248, 0.92);
    }

    .form-feedback:not(:empty) {
      padding: 12px 14px;
      border-radius: 14px;
      border: 1px solid rgba(126, 160, 216, 0.28);
      background: rgba(126, 160, 216, 0.08);
    }

    .form-feedback:empty {
      margin: 0;
      padding: 0;
      min-height: 0;
      border: none;
      background: none;
    }

    .form-banner--demo {
      margin: 0 0 18px;
      padding: 12px 16px;
      font-size: var(--text-body-sm);
      line-height: 1.45;
      color: rgba(210, 222, 242, 0.9);
      border-radius: 14px;
      border: 1px dashed rgba(126, 160, 216, 0.35);
      background: rgba(255, 255, 255, 0.03);
    }

    .form-banner--demo strong {
      color: #e8eef9;
      font-weight: var(--font-weight-ui);
    }

    .field--error input,
    .field--error textarea,
    .field--error select {
      border-color: rgba(255, 120, 140, 0.45);
      box-shadow: 0 0 0 1px rgba(255, 120, 140, 0.15);
    }

    .field__error {
      margin: 6px 0 0;
      font-size: var(--text-small);
      line-height: 1.4;
      color: #ffb4c0;
    }

    .field__error[hidden] {
      margin: 0;
    }

    .field:focus-within label {
      color: #eef3fb;
    }

    input:focus-visible,
    textarea:focus-visible,
    select:focus-visible {
      border-color: rgba(126, 160, 216, 0.55);
      box-shadow:
        0 0 0 3px rgba(126, 160, 216, 0.18),
        0 12px 32px rgba(0, 0, 0, 0.25);
    }

    select {
      appearance: none;
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23b2bfd3' d='M1 1.5L6 6l5-4.5'/%3E%3C/svg%3E");
      background-repeat: no-repeat;
      background-position: right 16px center;
      padding-right: 40px;
    }

    #contact-form.form--demo-sent .form-grid {
      opacity: 0.65;
      pointer-events: none;
    }

    #contact-form.form--demo-sent #contact-submit {
      opacity: 0.5;
    }

    /* Kotwice: sticky header nie zasłania tytułu sekcji */
    main section[id] {
      scroll-margin-top: clamp(88px, 12vh, 108px);
    }

    /* Galeria: stan ładowania + pusty stan */
    .portrait-marquee--loading .portrait-marquee__viewport {
      position: relative;
    }

    .portrait-marquee--loading .portrait-marquee__track {
      opacity: 0.35;
      transition: opacity 0.45s ease;
    }

    .portrait-marquee:not(.portrait-marquee--loading) .portrait-marquee__track {
      opacity: 1;
      transition: opacity 0.5s ease;
    }

    .portrait-marquee--loading .portrait-marquee__viewport::after {
      content: "";
      position: absolute;
      inset: 0;
      border-radius: inherit;
      pointer-events: none;
      z-index: 5;
      background: linear-gradient(
        105deg,
        transparent 0%,
        rgba(255, 255, 255, 0.07) 45%,
        transparent 90%
      );
      background-size: 220% 100%;
      animation: podwiatrShimmer 1.35s ease-in-out infinite;
    }

    @keyframes podwiatrShimmer {
      0% {
        background-position: 100% 0;
      }
      100% {
        background-position: -120% 0;
      }
    }

    .hero-actions--tight-top {
      margin-top: 8px;
    }

    .hero-actions--form-footer {
      margin-top: 22px;
      margin-bottom: 0;
    }

    /* --- Kontakt: formularz + karta --- */
    #contact-form {
      display: flex;
      flex-direction: column;
      align-items: stretch;
    }

    #contact-form-inner {
      position: relative;
      display: flex;
      flex-direction: column;
      gap: 0;
    }

    .form-config-hint {
      margin: 0 0 18px;
      padding: 12px 14px;
      font-size: var(--text-body-sm);
      line-height: 1.5;
      color: rgba(255, 214, 180, 0.95);
      border-radius: 14px;
      border: 1px dashed rgba(230, 160, 110, 0.45);
      background: rgba(230, 140, 80, 0.09);
    }

    .form-config-hint code {
      font-size: 0.88em;
      padding: 0.15em 0.45em;
      border-radius: 6px;
      background: rgba(0, 0, 0, 0.35);
      border: 1px solid rgba(255, 255, 255, 0.08);
    }

    .form-honeypot-input {
      position: absolute;
      width: 1px;
      height: 1px;
      padding: 0;
      margin: -1px;
      overflow: hidden;
      clip: rect(0, 0, 0, 0);
      white-space: nowrap;
      border: 0;
    }

    .form-success-panel {
      margin: 0 0 20px;
      padding: 20px 22px;
      border-radius: var(--radius-md);
      border: 1px solid rgba(126, 160, 216, 0.38);
      background: linear-gradient(
        165deg,
        rgba(126, 160, 216, 0.14),
        rgba(126, 160, 216, 0.06)
      );
    }

    .form-success-panel h3 {
      margin: 0 0 14px;
      font-size: var(--text-title);
      font-weight: var(--font-weight-title-sm);
      color: #eef3fb;
      line-height: 1.3;
    }

    .form-success-panel__list {
      margin: 0;
      padding: 0 0 0 1.2rem;
      display: grid;
      gap: 12px;
      color: rgba(200, 214, 235, 0.92);
      font-size: var(--text-body-sm);
      line-height: 1.55;
    }

    .form-success-panel__list a {
      color: #b8cff5;
      text-decoration: underline;
      text-underline-offset: 3px;
    }

    .form-success-panel__list a:hover {
      color: #dce8ff;
    }

    .form-note {
      margin: 18px 0 0;
      max-width: 62ch;
      line-height: 1.55;
      font-size: var(--text-body-sm);
    }

    /* Kontakt: tło sceny na całym pasie; formularz = wyśrodkowany obiektyw (elipsa z treści) */
    /* Cały formularz = „obiektyw”: elipsa z treści (border-radius 50% + wysokość z layoutu — bez scrolla w środku) */
    #contact-form.contact-form-panel {
      --lens-bg-x: 48%;
      --lens-bg-y: 40%;
      --lens-optic-x: 50%;
      --lens-optic-y: 38%;
      position: relative;
      z-index: 0;
      width: 100%;
      max-width: min(100%, 48rem);
      margin: 0 auto;
      padding: clamp(20px, 4.5vw, 42px) clamp(22px, 5vw, 46px);
      border: none;
      border-radius: 50%;
      background: transparent;
      box-shadow:
        inset 0 0 48px rgba(0, 0, 0, 0.22),
        0 16px 48px rgba(0, 0, 0, 0.3);
      overflow: visible;
      isolation: isolate;
    }

    #contact-form.contact-form-panel > * {
      position: relative;
      z-index: 2;
    }

    #contact-form.contact-form-panel::before {
      content: "";
      position: absolute;
      inset: 0;
      z-index: 0;
      pointer-events: none;
      border-radius: inherit;
      background-image: url("../images/sections/contact-lens-scene.png");
      background-size: cover;
      background-position: var(--lens-bg-x) var(--lens-bg-y);
      transform: rotate(180deg) scale(1.06);
      opacity: 1;
    }

    #contact-form.contact-form-panel::after {
      content: "";
      position: absolute;
      inset: 0;
      z-index: 1;
      pointer-events: none;
      border-radius: inherit;
      background: linear-gradient(
        168deg,
        rgba(6, 10, 18, 0.32) 0%,
        rgba(4, 8, 14, 0.36) 48%,
        rgba(6, 10, 18, 0.3) 100%
      );
      box-shadow: inset 0 0 56px rgba(0, 0, 0, 0.2);
    }

    #contact-form.contact-form-panel label {
      font-size: var(--text-caption);
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: rgba(216, 226, 242, 0.88);
    }

    #contact-form.contact-form-panel .contact-lens label {
      text-shadow: 0 1px 10px rgba(0, 0, 0, 0.72);
    }

    #contact-form.contact-form-panel input,
    #contact-form.contact-form-panel textarea,
    #contact-form.contact-form-panel select {
      border-radius: 10px;
      border: 1px solid rgba(255, 255, 255, 0.11);
      background: rgba(5, 9, 16, 0.94);
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.035);
    }

    #contact-form.contact-form-panel .form-feedback:not(:empty) {
      border-radius: 5px;
    }

    #contact-form.contact-form-panel .form-success-panel {
      border-radius: 5px;
    }

    #contact-form.contact-form-panel .form-config-hint {
      border-radius: 5px;
    }

    /* --- Obiektyw: 3 kroki, animacja pierścieni + dial --- */
    .contact-lens {
      --lens-accent: rgba(126, 160, 216, 0.55);
      /* --lens-bg-* i --lens-optic-*: na #contact-form (tło ::before formularza + pierścienie). */
      max-width: 100%;
      margin: 0 auto;
    }

    .contact-lens__body {
      position: relative;
      padding: clamp(4px, 1.2vw, 12px) 0;
      isolation: isolate;
    }

    .contact-lens__rings {
      position: absolute;
      inset: 0;
      z-index: 2;
      pointer-events: none;
    }

    .contact-lens__ring {
      position: absolute;
      left: var(--lens-optic-x);
      top: var(--lens-optic-y);
      border-radius: 50%;
      transform: translate(-50%, -50%);
      border: 1px solid rgba(216, 226, 242, 0.14);
      transition:
        transform 0.7s cubic-bezier(0.22, 1, 0.36, 1),
        opacity 0.45s ease,
        border-color 0.45s ease,
        box-shadow 0.45s ease;
    }

    /* Rant „lufy” — drobne znaczniki jak na pierścieniu ostrości */
    .contact-lens__ring--outer::before {
      content: "";
      position: absolute;
      inset: -6px;
      border-radius: 50%;
      opacity: 0.4;
      pointer-events: none;
      background: repeating-conic-gradient(
        from 2deg,
        transparent 0deg 6.5deg,
        rgba(255, 255, 255, 0.18) 6.5deg 7.2deg
      );
      mask: radial-gradient(farthest-side, transparent calc(100% - 6px), #000 calc(100% - 1px));
      -webkit-mask: radial-gradient(farthest-side, transparent calc(100% - 6px), #000 calc(100% - 1px));
    }

    /* Cienka obwódka w tonacji złotych styków z tyłu obiektywu (jak na ref. zdjęciu) */
    .contact-lens__ring--outer::after {
      content: "";
      position: absolute;
      inset: 7%;
      border-radius: 50%;
      pointer-events: none;
      box-shadow: inset 0 0 0 0.5px rgba(200, 168, 88, 0.18);
    }

    .contact-lens__ring--outer {
      width: 98%;
      max-width: none;
      aspect-ratio: 1;
      opacity: 0.88;
      transform: translate(-50%, -50%) rotate(0deg) scale(1);
      box-shadow:
        0 0 44px rgba(126, 160, 216, 0.14),
        inset 0 0 32px rgba(0, 0, 0, 0.28),
        0 0 0 1px rgba(0, 0, 0, 0.35);
    }

    .contact-lens__ring--inner {
      width: 86%;
      max-width: none;
      aspect-ratio: 1;
      border-color: rgba(216, 226, 242, 0.16);
      opacity: 0.72;
      transform: translate(-50%, -50%) rotate(0deg);
      box-shadow:
        0 0 28px rgba(140, 175, 228, 0.12),
        inset 0 0 22px rgba(0, 0, 0, 0.2);
    }

    .contact-lens[data-step="2"] .contact-lens__ring--outer {
      transform: translate(-50%, -50%) rotate(108deg) scale(1.03);
      border-color: rgba(216, 226, 242, 0.22);
    }

    .contact-lens[data-step="3"] .contact-lens__ring--outer {
      transform: translate(-50%, -50%) rotate(216deg) scale(1.06);
      border-color: rgba(180, 200, 255, 0.26);
      box-shadow:
        0 0 56px rgba(126, 160, 216, 0.22),
        inset 0 0 38px rgba(0, 0, 0, 0.22),
        0 0 0 1px rgba(0, 0, 0, 0.3);
    }

    .contact-lens[data-step="2"] .contact-lens__ring--inner,
    .contact-lens[data-step="3"] .contact-lens__ring--inner {
      transform: translate(-50%, -50%) rotate(-54deg);
      opacity: 0.82;
    }

    /* „Styki” / bagnet — akcent jak tylna ścianka obiektywu na zdjęciu tła */
    .contact-lens__breech {
      position: absolute;
      left: var(--lens-optic-x);
      top: var(--lens-optic-y);
      transform: translate(-50%, -50%);
      width: 76%;
      max-width: none;
      aspect-ratio: 1;
      pointer-events: none;
      border-radius: 50%;
    }

    .contact-lens__breech::before {
      content: "";
      position: absolute;
      inset: 0;
      border-radius: 50%;
      opacity: 0.85;
      background:
        radial-gradient(ellipse 10% 7% at 18% 86%, rgba(218, 184, 96, 0.9), transparent 62%),
        radial-gradient(ellipse 10% 7% at 32% 91%, rgba(232, 198, 110, 0.88), transparent 62%),
        radial-gradient(ellipse 9% 7% at 46% 94%, rgba(245, 210, 120, 0.92), transparent 58%),
        radial-gradient(ellipse 10% 7% at 60% 93%, rgba(232, 198, 110, 0.88), transparent 62%),
        radial-gradient(ellipse 10% 7% at 74% 89%, rgba(218, 184, 96, 0.9), transparent 62%),
        radial-gradient(ellipse 55% 22% at 50% 96%, rgba(30, 24, 14, 0.45), transparent 72%);
    }

    .contact-lens__flare {
      position: absolute;
      left: var(--lens-optic-x);
      top: var(--lens-optic-y);
      width: 42%;
      height: 26%;
      transform: translate(-50%, -50%);
      border-radius: 50%;
      background:
        radial-gradient(ellipse at 28% 38%, rgba(255, 255, 255, 0.16), transparent 58%),
        radial-gradient(ellipse at 62% 55%, rgba(140, 185, 235, 0.12), transparent 52%);
      opacity: 0.72;
      transition: opacity 0.5s ease;
    }

    .contact-lens[data-step="3"] .contact-lens__flare {
      opacity: 0.95;
    }

    /* Wewnętrzny układ (tło i obrys obiektywu są na #contact-form) */
    .contact-lens__viewport {
      position: relative;
      z-index: 2;
      display: flex;
      flex-direction: column;
      box-sizing: border-box;
      width: 100%;
      max-width: 100%;
      margin-inline: 0;
      border-radius: 0;
      padding: clamp(10px, 2.2vw, 18px) clamp(2px, 1vw, 10px) clamp(12px, 2.2vw, 20px);
      background: transparent;
      border: none;
      box-shadow: none;
      overflow: visible;
    }

    .contact-lens__viewport > .contact-lens__rings {
      z-index: 2;
    }

    .contact-lens__viewport > *:not(.visually-hidden):not(.contact-lens__rings) {
      position: relative;
      z-index: 3;
    }

    .contact-lens__dial {
      list-style: none;
      margin: 0 0 16px;
      padding: 0;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: clamp(10px, 2.5vw, 18px);
      flex-shrink: 0;
    }

    /* Wszystkie kroki w jednej komórce — wysokość = najwyższy krok; bez wewnętrznego scrolla */
    .contact-lens__steps-stack {
      display: grid;
      grid-template-columns: minmax(0, 1fr);
      grid-template-rows: auto;
      flex: 1 1 auto;
      align-self: stretch;
      min-width: 0;
      min-height: 0;
    }

    .contact-lens-step {
      grid-area: 1 / 1;
      align-self: stretch;
      display: flex;
      flex-direction: column;
      min-height: 0;
      visibility: hidden;
      pointer-events: none;
      z-index: 0;
      animation: none;
    }

    .contact-lens-step--active {
      visibility: visible;
      pointer-events: auto;
      z-index: 1;
      animation: contactLensStepIn 0.42s cubic-bezier(0.22, 1, 0.36, 1) both;
    }

    .contact-lens__dial-item {
      width: 2.1rem;
      height: 2.1rem;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      font-family: var(--font-sans);
      font-size: var(--text-small);
      font-weight: var(--font-weight-ui);
      letter-spacing: 0.02em;
      color: rgba(180, 195, 220, 0.45);
      border: 1px solid rgba(255, 255, 255, 0.1);
      background: rgba(0, 0, 0, 0.25);
      transition:
        color 0.35s ease,
        border-color 0.35s ease,
        background 0.35s ease,
        transform 0.4s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.4s ease;
    }

    .contact-lens__dial-item.is-active {
      color: #f4f7fd;
      border-color: rgba(180, 200, 255, 0.55);
      background: rgba(126, 160, 216, 0.18);
      transform: scale(1.12);
      box-shadow: 0 0 20px rgba(126, 160, 216, 0.35);
    }

    .contact-lens__dial-item.is-done {
      color: rgba(216, 226, 242, 0.88);
      border-color: rgba(216, 226, 242, 0.28);
      background: rgba(255, 255, 255, 0.06);
    }

    @keyframes contactLensStepIn {
      from {
        opacity: 0;
        transform: translateY(10px);
      }
      to {
        opacity: 1;
        transform: translateY(0);
      }
    }

    .contact-lens-step__title {
      margin: 0 0 8px;
      font-family: var(--font-sans);
      font-size: var(--text-process-label);
      font-weight: var(--font-weight-ui);
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: #f6f9ff;
      text-shadow: 0 1px 14px rgba(0, 0, 0, 0.75), 0 0 1px rgba(0, 0, 0, 0.9);
    }

    .contact-lens-step__lede {
      margin: 0 0 18px;
      font-size: var(--text-lead);
      line-height: 1.48;
      color: rgba(235, 240, 250, 0.96);
      max-width: 44ch;
      text-shadow: 0 1px 12px rgba(0, 0, 0, 0.7);
    }

    .contact-lens-step__fields {
      display: flex;
      flex-direction: column;
      gap: 14px;
    }

    .contact-lens-step__hint {
      margin-top: 6px;
      font-size: var(--text-small);
      max-width: none;
      text-shadow: 0 1px 8px rgba(0, 0, 0, 0.65);
    }

    .contact-lens-step__actions {
      margin-top: auto;
      padding-top: 20px;
      display: flex;
      justify-content: flex-end;
      flex-wrap: wrap;
      gap: 12px;
      flex-shrink: 0;
    }

    .contact-lens-step__actions--split {
      justify-content: space-between;
    }

    .contact-lens__turnstile-host {
      margin-top: 14px;
      min-height: 0;
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      gap: 8px;
    }

    .form-note--lens {
      margin-top: 16px;
      margin-bottom: 0;
      font-size: var(--text-small);
      line-height: 1.45;
      max-width: none;
      text-shadow: 0 1px 8px rgba(0, 0, 0, 0.65);
    }

    @media (prefers-reduced-motion: reduce) {
      .contact-lens__ring,
      .contact-lens__ring--outer::before,
      .contact-lens__ring--outer::after,
      .contact-lens__flare,
      .contact-lens__dial-item {
        transition: none !important;
      }

      #contact-form.contact-form-panel::before {
        transform: rotate(180deg) scale(1.04);
      }

      .contact-lens-step--active {
        animation: none !important;
      }

      .contact-lens[data-step="1"] .contact-lens__ring--outer,
      .contact-lens[data-step="2"] .contact-lens__ring--outer,
      .contact-lens[data-step="3"] .contact-lens__ring--outer {
        transform: translate(-50%, -50%) rotate(0deg) scale(1);
      }

      .contact-lens[data-step="2"] .contact-lens__ring--inner,
      .contact-lens[data-step="3"] .contact-lens__ring--inner {
        transform: translate(-50%, -50%) rotate(0deg);
      }
    }

    /* Pasek CTA między sekcjami — wcześniej bez stylów (domyślne marginesy <p>) */
    .micro-cta-bar {
      margin: var(--micro-cta-margin-y) 0;
      padding: var(--micro-cta-pad-y) 0;
      background: linear-gradient(
        180deg,
        rgba(126, 160, 216, 0.07) 0%,
        rgba(126, 160, 216, 0.02) 55%,
        transparent 100%
      );
      border-top: 1px solid rgba(255, 255, 255, 0.07);
      border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    }

    .micro-cta-bar__text {
      margin: 0;
      max-width: 62ch;
      color: rgba(210, 222, 240, 0.93);
      font-size: var(--text-body-sm);
      line-height: 1.55;
    }

    .micro-cta-bar__text a {
      text-decoration: underline;
      text-underline-offset: 3px;
      color: #b8cff5;
    }

    .micro-cta-bar__text a:hover {
      color: #dce8ff;
    }

    .micro-cta-bar__inner--cta-buttons {
      display: flex;
      flex-direction: column;
      align-items: center;
      text-align: center;
      gap: clamp(18px, 2.8vw, 24px);
    }

    .micro-cta-bar__hint {
      margin: 0;
      max-width: 36ch;
      color: rgba(218, 228, 246, 0.94);
      font-size: var(--text-body);
      line-height: 1.62;
      letter-spacing: 0.01em;
    }

    .micro-cta-bar__btn-wrap {
      display: flex;
      justify-content: center;
      width: 100%;
    }

    .micro-cta-bar__btn-wrap .button {
      width: auto;
      max-width: min(100%, 22rem);
      text-align: center;
    }

    .micro-cta-bar--tight {
      padding: var(--micro-cta-pad-y-tight) 0;
    }

    .micro-cta-bar--in-section {
      margin-top: 22px;
      padding: 18px 0 0;
      background: transparent;
      border-top: 1px solid rgba(255, 255, 255, 0.08);
      border-bottom: none;
    }

    .stats {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 14px;
      max-width: 560px;
    }

    .stat {
      padding: 18px;
      border-radius: var(--radius-md);
      background: linear-gradient(180deg, rgba(255,255,255,0.055), rgba(255,255,255,0.025));
      border: 1px solid rgba(255,255,255,0.08);
      box-shadow: var(--shadow);
    }

    .stat strong {
      display: block;
      font-size: var(--text-stat);
      font-weight: var(--font-weight-heading);
      margin-bottom: 2px;
    }

    .stat span {
      color: var(--muted);
      font-size: var(--text-body-sm);
    }

    .section-head {
      display: flex;
      align-items: flex-end;
      justify-content: space-between;
      gap: 20px;
      margin-bottom: var(--section-head-spacing);
      flex-wrap: wrap;
    }

    .section-kicker {
      color: #ced8ea;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      font-size: var(--text-eyebrow);
      font-weight: var(--font-weight-ui);
      margin-bottom: 12px;
    }

    h2 {
      font-family: var(--font-sans);
      font-weight: var(--font-weight-heading);
      font-size: var(--text-section);
      line-height: 1.12;
      letter-spacing: -0.02em;
      margin-bottom: 12px;
    }

    h3 {
      font-family: var(--font-sans);
      font-weight: var(--font-weight-title-sm);
      font-size: var(--text-card-title);
      line-height: var(--leading-snug);
    }

    .section-subtitle {
      max-width: 60ch;
      color: var(--muted);
      font-size: var(--text-subtitle);
      line-height: var(--leading-relaxed);
    }

    .section-subtitle a {
      color: var(--accent);
      text-decoration: underline;
      text-underline-offset: 2px;
    }

    .section-subtitle a:hover {
      color: #a8c0ec;
    }

    /* W akapicie usług: ten sam rytm co linki z akcentem strony (bez „pastełowego” kontrastu). */
    .section-subtitle a.text-link--editorial {
      color: #dce4f0;
      font-weight: var(--font-weight-ui);
      text-decoration: none;
      border-bottom: 1px solid rgba(126, 160, 216, 0.42);
      padding-bottom: 0.12em;
      transition:
        color 0.2s ease,
        border-color 0.2s ease;
    }

    .section-subtitle a.text-link--editorial:hover {
      color: var(--accent);
      border-bottom-color: rgba(126, 160, 216, 0.78);
    }

    .section-subtitle a.text-link--editorial:focus-visible {
      outline: 2px solid rgba(126, 160, 216, 0.65);
      outline-offset: 3px;
      border-radius: 2px;
    }

    .text-link--editorial {
      color: rgba(222, 211, 193, 0.94);
      text-decoration: none;
      border-bottom: 1px solid rgba(222, 211, 193, 0.36);
      padding-bottom: 1px;
      transition: color 0.25s ease, border-color 0.25s ease, opacity 0.25s ease;
    }

    .text-link--editorial:hover {
      color: #f3ece2;
      border-bottom-color: rgba(243, 236, 226, 0.72);
    }

    .text-link--editorial:focus-visible {
      outline: 1px solid rgba(243, 236, 226, 0.5);
      outline-offset: 3px;
    }

    .section-subtitle code {
      font-size: 0.92em;
      padding: 0.12em 0.4em;
      border-radius: 6px;
      background: rgba(255, 255, 255, 0.07);
      border: 1px solid rgba(255, 255, 255, 0.1);
      font-family: ui-monospace, "Cascadia Code", Consolas, monospace;
    }

    /* Sekcja SEO / „dla kogo” — treść widoczna, naturalne frazy kluczowe */
    .section-target {
      padding: var(--section-pad-y) 0;
      border-top: 1px solid rgba(255, 255, 255, 0.06);
      background:
        radial-gradient(ellipse 55% 40% at 15% 0%, rgba(126, 160, 216, 0.08), transparent 50%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.02), transparent 45%);
    }

    .section-target__priority {
      margin-bottom: 18px;
      padding: 16px 18px;
      border-radius: var(--radius-lg);
      border: 1px solid rgba(126, 160, 216, 0.28);
      background: rgba(126, 160, 216, 0.08);
      max-width: 62ch;
    }

    .section-target__lead {
      margin-bottom: 16px;
    }

    .section-target__list-intro {
      margin-bottom: 12px;
      color: #e8eef8;
    }

    .section-target__audience {
      margin: 0 0 22px;
      padding-left: 1.25rem;
      max-width: 62ch;
      color: var(--muted);
      line-height: 1.65;
    }

    .section-target__audience li {
      margin-bottom: 10px;
    }

    .section-target__audience li:last-child {
      margin-bottom: 0;
    }

    .section-target__note {
      margin-bottom: 0;
      padding-top: 8px;
      border-top: 1px solid rgba(255, 255, 255, 0.08);
      max-width: 62ch;
    }

    .about-grid {
      display: grid;
      grid-template-columns: 1.15fr 0.85fr;
      gap: 28px;
    }

    .panel {
      background: linear-gradient(180deg, rgba(255,255,255,0.055), rgba(255,255,255,0.03));
      border: 1px solid rgba(255,255,255,0.08);
      border-radius: var(--radius-xl);
      padding: 28px;
      box-shadow: var(--shadow);
    }

    .panel > h3:first-child {
      margin-top: 0;
    }

    .about-copy p,
    .highlight p,
    .about-card p,
    .section-subtitle,
    .form-note,
    .field-hint {
      color: var(--muted);
    }

    .field-hint {
      margin: 8px 0 0;
      font-size: var(--text-small);
      line-height: 1.45;
      max-width: 52ch;
    }

    /* Podpowiedź pod polem (nie nad) — czytelniejszy rytm */
    .field--full .field-hint {
      margin-top: 6px;
    }

    .section-target__quote {
      margin: 22px 0 20px;
    }

    .section-target__quote p {
      margin: 0 0 10px;
      font-size: var(--text-quote);
      font-style: italic;
      font-weight: var(--font-weight-display);
      line-height: 1.45;
      color: #dce6f8;
    }

    .section-target__quote footer {
      font-size: var(--text-small);
      color: var(--muted);
      letter-spacing: 0.03em;
    }

    /* --- FAQ: nagłówek + akordeony --- */
    .faq-section {
      position: relative;
      overflow: hidden;
      content-visibility: auto;
      contain-intrinsic-size: auto 600px;
    }

    @keyframes faqAmbientShift {
      0%,
      100% {
        opacity: 0.75;
        transform: translate(0, 0);
      }
      50% {
        opacity: 1;
        transform: translate(-2.5%, 1.5%);
      }
    }

    .faq-section__glow {
      pointer-events: none;
      position: absolute;
      inset: -25% -20% auto;
      height: 60%;
      z-index: 0;
      background: radial-gradient(ellipse 68% 85% at 72% -5%, rgba(126, 160, 216, 0.14), transparent 62%);
    }

    html.podwiatr-motion-on .faq-section__glow {
      animation: faqAmbientShift 20s ease-in-out infinite;
    }

    html.podwiatr-reduced-motion .faq-section__glow {
      animation: none;
      opacity: 0.7;
    }

    .faq-section__container {
      position: relative;
      z-index: 1;
      max-width: min(100%, 720px);
      margin-inline: auto;
    }

    .faq-section__intro {
      text-align: center;
      margin-bottom: var(--section-head-spacing);
    }

    .faq-section__title {
      font-family: var(--font-sans);
      font-size: var(--text-section);
      font-weight: var(--font-weight-heading);
      line-height: 1.05;
      letter-spacing: -0.03em;
      margin: 0 0 14px;
    }

    .faq-section__lead {
      margin: 0 auto;
      max-width: 40ch;
      font-size: var(--text-lead);
      line-height: 1.52;
      color: rgba(212, 224, 244, 0.96);
    }

    .faq-section__lead .text-link--editorial {
      color: rgba(188, 209, 246, 0.95);
      border-bottom-color: rgba(184, 207, 245, 0.45);
    }

    .faq-section__lead .text-link--editorial:hover {
      color: #e8f0ff;
      border-bottom-color: rgba(232, 240, 255, 0.72);
    }

    .faq-section__list {
      display: flex;
      flex-direction: column;
      gap: 12px;
    }

    .faq-item {
      border-radius: 0;
      border: 1px solid rgba(255, 255, 255, 0.1);
      background: linear-gradient(168deg, rgba(255, 255, 255, 0.065), rgba(5, 11, 20, 0.78));
      box-shadow: 0 14px 42px rgba(0, 0, 0, 0.26);
      overflow: hidden;
      transition:
        border-color 0.3s ease,
        box-shadow 0.35s ease;
    }

    .faq-item:hover {
      border-color: rgba(126, 160, 216, 0.24);
    }

    .faq-item[open] {
      border-color: rgba(126, 160, 216, 0.38);
      box-shadow: 0 20px 54px rgba(48, 72, 124, 0.28);
    }

    .faq-item summary {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 18px;
      padding: 17px 20px 17px 22px;
      cursor: pointer;
      list-style: none;
      font-size: var(--text-title);
      font-weight: var(--font-weight-ui);
      line-height: 1.38;
      color: #f2f6fd;
      letter-spacing: 0.015em;
    }

    .faq-item summary::marker {
      content: "";
    }

    .faq-item summary::-webkit-details-marker {
      display: none;
    }

    .faq-item summary::after {
      content: "";
      flex-shrink: 0;
      width: 10px;
      height: 10px;
      margin-top: 2px;
      border-right: 2px solid rgba(186, 206, 236, 0.9);
      border-bottom: 2px solid rgba(186, 206, 236, 0.9);
      transform: rotate(-45deg) translateY(-1px);
      transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1);
    }

    .faq-item[open] summary::after {
      transform: rotate(45deg) translateY(3px);
    }

    .faq-item summary:focus {
      outline: none;
    }

    .faq-item summary:focus-visible {
      outline: 2px solid rgba(126, 160, 216, 0.9);
      outline-offset: 3px;
      border-radius: 0;
    }

    .faq-item__answer {
      padding: 0 22px;
      border-top: 1px solid rgba(255, 255, 255, 0.08);
    }

    .faq-item__answer p {
      margin: 0;
      padding: 16px 0 20px;
      font-size: var(--text-body);
      line-height: 1.58;
      color: rgba(202, 216, 238, 0.95);
    }

    .faq-item__answer p strong {
      color: #eef3fb;
      font-weight: var(--font-weight-ui);
    }

    .faq-section__footer-cta {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 18px;
      margin-top: var(--section-head-spacing);
      padding: 22px 26px;
      text-align: center;
      border-radius: 0;
      border: 1px solid rgba(126, 160, 216, 0.24);
      background: linear-gradient(128deg, rgba(126, 160, 216, 0.11), rgba(8, 15, 28, 0.72));
      box-shadow: 0 16px 48px rgba(0, 0, 0, 0.24);
    }

    .faq-section__footer-text {
      margin: 0;
      max-width: 36ch;
      font-size: var(--text-body);
      line-height: 1.62;
      letter-spacing: 0.01em;
      color: rgba(218, 228, 246, 0.94);
    }

    .faq-section__footer-cta .micro-cta-bar__btn-wrap {
      justify-content: center;
    }

    .faq-section__footer-cta .micro-cta-bar__btn-wrap .button {
      width: auto;
      max-width: min(100%, 22rem);
    }

    .highlight-list {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 14px;
      margin-top: var(--section-head-spacing);
    }

    .highlight {
      padding: 18px;
      border-radius: 18px;
      background: rgba(255,255,255,0.03);
      border: 1px solid rgba(255,255,255,0.06);
    }

    .about-side {
      display: grid;
      gap: 18px;
    }

    /* Napis „VOGUE” w tle karty (styl redakcyjny, nie oficjalny logotyp) — opacity min. 50% */
    .about-card--vogue {
      position: relative;
      overflow: hidden;
    }

    .about-card--vogue::before {
      content: "VOGUE";
      position: absolute;
      right: 4%;
      bottom: 8%;
      font-family: var(--font-sans);
      font-weight: var(--font-weight-display);
      font-size: var(--text-watermark);
      letter-spacing: 0.18em;
      line-height: 0.85;
      color: rgba(255, 255, 255, 0.5);
      pointer-events: none;
      z-index: 0;
      transform: rotate(-6deg);
      user-select: none;
    }

    .about-card--vogue h3,
    .about-card--vogue p {
      position: relative;
      z-index: 1;
    }

    /* --- Karuzele portretów: 3 kadry, szybszy rytm (~1 s, płynne przejście ~0,375 s) --- */
    .portrait-marquee + .portrait-marquee {
      padding-top: var(--section-block-gap);
    }
    .portrait-marquee {
      padding: var(--section-pad-y) 0;
      overflow: hidden;
    }

    .portrait-marquee__intro {
      margin-bottom: var(--section-head-spacing);
    }

    .portrait-marquee__intro h2 {
      margin-bottom: 12px;
    }

    .portrait-marquee__stage {
      position: relative;
      width: min(calc(100% - 32px), var(--container));
      margin: 0 auto;
    }

    .portrait-marquee__stage::before,
    .portrait-marquee__stage::after {
      content: "";
      position: absolute;
      top: 0;
      bottom: 56px;
      width: clamp(48px, 8vw, 100px);
      z-index: 2;
      pointer-events: none;
    }

    .portrait-marquee__stage::before {
      left: 0;
      background: linear-gradient(90deg, rgba(7, 16, 28, 1) 0%, rgba(7, 16, 28, 0) 100%);
    }

    .portrait-marquee__stage::after {
      right: 0;
      background: linear-gradient(270deg, rgba(7, 16, 28, 1) 0%, rgba(7, 16, 28, 0) 100%);
    }

    /* Nawigacja karuzeli — nad gradientami krawędzi (::before/::after z-index 2) */
    .portrait-marquee__nav-btn {
      position: absolute;
      top: 50%;
      z-index: 4;
      transform: translateY(-50%);
      width: 48px;
      height: 48px;
      padding: 0;
      display: flex;
      align-items: center;
      justify-content: center;
      border: 1px solid rgba(255, 255, 255, 0.14);
      border-radius: 50%;
      background: rgba(7, 16, 28, 0.65);
      color: rgba(238, 243, 251, 0.95);
      cursor: pointer;
      box-shadow: 0 8px 28px rgba(0, 0, 0, 0.35);
      backdrop-filter: blur(12px);
      -webkit-backdrop-filter: blur(12px);
      transition:
        background 0.25s ease,
        border-color 0.25s ease,
        color 0.25s ease,
        box-shadow 0.25s ease,
        transform 0.2s ease;
    }

    .portrait-marquee__nav-btn:hover {
      background: rgba(18, 32, 52, 0.82);
      border-color: rgba(126, 160, 216, 0.45);
      color: #fff;
      box-shadow: 0 12px 36px rgba(0, 0, 0, 0.4), 0 0 0 1px rgba(126, 160, 216, 0.2);
    }

    .portrait-marquee__nav-btn:active {
      transform: translateY(-50%) scale(0.96);
    }

    .portrait-marquee__nav-btn:focus-visible {
      outline: 2px solid rgba(126, 160, 216, 0.85);
      outline-offset: 3px;
    }

    .portrait-marquee__nav-btn--prev {
      left: clamp(10px, 3vw, 22px);
    }

    .portrait-marquee__nav-btn--next {
      right: clamp(10px, 3vw, 22px);
    }

    .portrait-marquee__nav-icon {
      width: 28px;
      height: 28px;
      display: block;
      margin: 0 -2px;
    }

    .portrait-marquee__nav-btn[hidden] {
      display: none;
    }

    .portrait-marquee__viewport {
      width: 100%;
      overflow: hidden;
      border-radius: 0;
      margin: 0 auto;
      mask-image: linear-gradient(90deg, transparent 0%, black 2%, black 98%, transparent 100%);
      -webkit-mask-image: linear-gradient(90deg, transparent 0%, black 2%, black 98%, transparent 100%);
      touch-action: pan-y;
      cursor: grab;
      user-select: none;
      -webkit-user-select: none;
    }

    .portrait-marquee__viewport.portrait-marquee__viewport--dragging {
      cursor: grabbing;
    }

    .portrait-marquee__track {
      display: flex;
      align-items: stretch;
      gap: var(--marquee-gap, 18px);
      will-change: transform;
    }

    .portrait-marquee__slide {
      flex: 0 0 auto;
      position: relative;
      border-radius: 0;
      overflow: hidden;
      aspect-ratio: 3 / 4;
      box-shadow:
        0 24px 48px rgba(0, 0, 0, 0.35),
        inset 0 0 0 1px rgba(255, 255, 255, 0.08);
      background: rgba(255, 255, 255, 0.04);
    }

    .portrait-marquee__slide img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
      filter: brightness(0.88) saturate(0.96);
      transition: filter 0.45s ease;
      pointer-events: none;
      -webkit-user-drag: none;
      user-select: none;
    }

    .portrait-marquee__slide:hover img {
      transform: scale(1.04);
      filter: brightness(0.96) saturate(1.02);
    }

    .portrait-marquee__progress {
      display: flex;
      justify-content: center;
      gap: 8px;
      margin-top: 28px;
      flex-wrap: wrap;
    }

    .portrait-marquee__dot {
      width: 7px;
      height: 7px;
      border-radius: 50%;
      background: rgba(255, 255, 255, 0.18);
      border: 1px solid rgba(255, 255, 255, 0.12);
      transition: transform 0.35s ease, background 0.35s ease;
    }

    .portrait-marquee__dot--active {
      background: linear-gradient(135deg, var(--accent), var(--accent-2));
      transform: scale(1.35);
      box-shadow: 0 0 16px rgba(126, 160, 216, 0.45);
    }

    .portrait-marquee--paused .portrait-marquee__track {
      transition: none !important;
    }

    @media (max-width: 560px) {
      .portrait-marquee__stage::before,
      .portrait-marquee__stage::after {
        width: 28px;
        bottom: 44px;
      }

      .portrait-marquee__nav-btn {
        width: 44px;
        height: 44px;
      }

      .portrait-marquee__nav-btn--prev {
        left: 6px;
      }

      .portrait-marquee__nav-btn--next {
        right: 6px;
      }

      .portrait-marquee__nav-icon {
        width: 26px;
        height: 26px;
      }
    }

    .contact-grid {
      display: grid;
      grid-template-columns: 0.9fr 1.1fr;
      gap: 28px;
    }

    .contact-list {
      list-style: none;
      margin: 14px 0 0;
      padding: 0;
      display: grid;
      gap: 12px;
    }

    .contact-list li {
      padding: 16px 18px;
      border-radius: 18px;
      border: 1px solid rgba(255,255,255,0.06);
      background: rgba(255,255,255,0.03);
    }

    .contact-list strong {
      display: block;
      color: #eef3fb;
      margin-bottom: 6px;
      font-size: var(--text-body-sm);
    }

    .form-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 18px 20px;
    }

    .field,
    .field--full {
      display: grid;
      gap: 10px;
    }

    .field--full { grid-column: 1 / -1; }

    label {
      font-size: var(--text-body-sm);
      font-weight: var(--font-weight-ui);
      color: #d7e1f1;
    }

    input,
    textarea,
    select {
      width: 100%;
      border: 1px solid rgba(255,255,255,0.1);
      background: rgba(7, 14, 24, 0.8);
      color: var(--text);
      border-radius: 16px;
      padding: 15px 16px;
      font: inherit;
      outline: none;
    }

    textarea { min-height: 150px; resize: vertical; }

    .footer {
      padding: clamp(40px, 5vw, 52px) 0 clamp(48px, 7vw, 64px);
      color: #c1ccde;
    }

    .footer__inner {
      display: flex;
      flex-direction: column;
      gap: clamp(22px, 4vw, 30px);
      padding-top: 20px;
      border-top: 1px solid rgba(255,255,255,0.08);
    }

    .footer__top {
      display: grid;
      grid-template-columns: minmax(200px, 260px) minmax(0, 1fr) auto;
      gap: clamp(22px, 4vw, 36px);
      align-items: start;
    }

    .footer__nav {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: clamp(18px, 3vw, 28px);
    }

    .footer__nav-title {
      font-size: 0.6875rem;
      letter-spacing: 0.11em;
      text-transform: uppercase;
      color: #8699b5;
      margin-bottom: 10px;
      font-weight: var(--font-weight-emphasis);
    }

    .footer__nav-list {
      list-style: none;
      margin: 0;
      padding: 0;
      display: flex;
      flex-direction: column;
      gap: 7px;
    }

    .footer__nav-link {
      color: #c1ccde;
      text-decoration: none;
      font-size: 0.9375rem;
      line-height: 1.35;
      border-bottom: 1px solid transparent;
      width: fit-content;
      max-width: 100%;
      transition:
        color 0.2s ease,
        border-color 0.2s ease;
    }

    .footer__nav-link:hover {
      color: #eef3fb;
      border-bottom-color: rgba(126, 160, 216, 0.42);
    }

    .footer__nav-link:focus-visible {
      outline: 2px solid rgba(126, 160, 216, 0.75);
      outline-offset: 3px;
      border-radius: 4px;
    }

    .footer__rights {
      display: block;
      margin: 0;
    }

    .footer small { color: #9eacc1; }

    .footer small strong {
      color: #c5d2e6;
      font-weight: var(--font-weight-emphasis);
    }

    .footer__contact-nowrap {
      display: inline;
    }

    .footer__contact-dot {
      display: inline;
      margin: 0 0.2em;
      color: #7d8ca3;
      font-weight: normal;
      user-select: none;
    }

    .footer__contact-chip {
      display: inline;
      color: #c5d2e6;
      font-weight: var(--font-weight-emphasis);
      text-decoration: none;
      border-bottom: 1px solid rgba(126, 160, 216, 0.38);
      padding-bottom: 1px;
      transition:
        color 0.2s ease,
        border-color 0.2s ease;
    }

    .footer__contact-chip:hover {
      color: #eef3fb;
      border-bottom-color: rgba(156, 184, 236, 0.62);
    }

    .footer__contact-chip:focus-visible {
      outline: 2px solid rgba(126, 160, 216, 0.75);
      outline-offset: 2px;
      border-radius: 4px;
    }

    .footer__contact-chip--tel {
      white-space: nowrap;
    }

    .footer__social {
      display: flex;
      align-items: center;
      gap: 6px;
    }

    .footer__social-link {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 44px;
      height: 44px;
      border-radius: 12px;
      color: #b8c6dc;
      background: rgba(255, 255, 255, 0.05);
      border: 1px solid rgba(255, 255, 255, 0.1);
      transition:
        color 0.25s ease,
        background 0.25s ease,
        border-color 0.25s ease,
        transform 0.2s ease;
    }

    .footer__social-link:hover {
      color: #fff;
      background: rgba(126, 160, 216, 0.18);
      border-color: rgba(126, 160, 216, 0.4);
      transform: translateY(-2px);
    }

    .footer__social-link--fb:hover {
      color: #8eb6ff;
      background: rgba(88, 140, 255, 0.14);
      border-color: rgba(108, 160, 255, 0.45);
    }

    .footer__social-link--ig:hover {
      color: #f5b0d4;
      background: rgba(240, 140, 186, 0.12);
      border-color: rgba(240, 140, 186, 0.4);
    }

    .footer__social-link:focus-visible {
      outline: 2px solid rgba(126, 160, 216, 0.75);
      outline-offset: 3px;
    }

    .footer__social-icon {
      width: 22px;
      height: 22px;
      display: block;
    }

    .footer__social-icon--glyph {
      width: 20px;
      height: 20px;
    }

    @media (max-width: 960px) {
      .footer__top {
        grid-template-columns: 1fr;
      }

      .footer__nav {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }
    }

    @media (max-width: 520px) {
      .footer__nav {
        grid-template-columns: 1fr;
      }
    }

    @media (max-width: 1140px) {
      .about-grid,
      .contact-grid {
        grid-template-columns: 1fr;
        gap: clamp(22px, 4vw, 28px);
      }
      .section-intro__title {
        max-width: none;
      }
      .section-intro__hook {
        max-width: none;
      }
      .section-intro__pillars {
        grid-template-columns: 1fr;
      }
      .section-intro__split {
        grid-template-columns: 1fr;
      }
      .section-intro__panel--highlights .intro-highlights--compact {
        grid-template-columns: 1fr;
      }
      .section-intro__panel--highlights .intro-highlights--compact .intro-highlight {
        border-left: none;
        border-top: 1px solid rgba(255, 255, 255, 0.1);
        padding: 18px 0 0;
      }
      .section-intro__panel--highlights .intro-highlights--compact .intro-highlight:first-child {
        border-top: none;
        padding-top: 0;
      }
    }

    @media (max-width: 720px) {
      .section-intro__stats {
        grid-template-columns: 1fr;
        text-align: center;
      }
      .section-intro__stat {
        padding: 12px 8px;
        border-bottom: 1px solid rgba(255, 255, 255, 0.06);
      }
      .section-intro__stat:last-child {
        border-bottom: none;
      }
    }

    @media (max-width: 820px) {
      .nav-toggle {
        display: inline-flex;
      }

      .nav-backdrop {
        display: block;
        position: fixed;
        inset: 0;
        z-index: 90;
        background: rgba(4, 8, 14, 0.62);
        backdrop-filter: blur(6px);
        -webkit-backdrop-filter: blur(6px);
        opacity: 0;
        pointer-events: none;
        transition: opacity 0.3s ease;
      }

      .site-header.is-menu-open .nav-backdrop {
        opacity: 1;
        pointer-events: auto;
      }

      /*
       * backdrop-filter na headerze tworzy w Safari/Chrome „przedłużony” containing block dla
       * position:fixed — potomek .nav miał wtedy wysokość paska (~78px), nie cały ekran; widać było
       * tylko skrawek (np. sam przycisk WhatsApp). backdrop na mobilkach wyłączamy; tło nieco cięższe.
       */
      .site-header {
        z-index: 100;
        backdrop-filter: none;
        -webkit-backdrop-filter: none;
        background: rgba(6, 11, 19, 0.82);
      }

      /*
       * Jedna linia nagłówka jak na telefonie: logo + PL|EN + hamburger.
       * Ten sam próg co drawer — wiele telefonów ma viewport >560px (np. iPhone 14 ~390 CSS px ale zoom/DPR bywa inny w WebView).
       */
      .site-header .brand-copy {
        display: none !important;
      }
      .site-header .brand {
        gap: 0;
      }
      .site-header .site-header__trailing .nav__social {
        display: none !important;
      }

      .site-header__start .lang-switch__btn {
        padding: 8px 2px;
      }

      .site-header .site-header__inner {
        gap: 10px 12px;
        /* Oddech od prawej (hamburger / safe area iPhone); bez tego końcówka bywa „ucięta” */
        padding-right: max(14px, env(safe-area-inset-right, 0px));
      }

      /*
       * Landingi SEO: .nav jest position:fixed — czasem nie „trzyma” środka w flexie jak na index.
       * margin-right:auto na lewym klastrze (PL·EN + logo) = ten sam układ co strona główna: w lewo marka, w prawo hamburger.
       */
      .seo-landing .site-header__start {
        margin-right: auto;
      }

      /* Zamknięty drawer nie przechwytuje dotyku na części ekranu (iOS / WebView) */
      .site-header:not(.is-menu-open) .nav {
        pointer-events: none;
      }

      .site-header.is-menu-open .nav {
        pointer-events: auto;
      }

      .nav {
        position: fixed;
        top: 0;
        right: 0;
        bottom: 0;
        z-index: 95;
        width: min(100%, 320px);
        max-width: 100%;
        margin: 0;
        padding: calc(78px + env(safe-area-inset-top, 0px)) 20px 28px;
        flex-direction: column;
        flex-wrap: nowrap;
        align-items: stretch;
        gap: 0;
        background: linear-gradient(165deg, rgba(12, 20, 34, 0.98), rgba(6, 11, 19, 0.99));
        border-left: 1px solid rgba(255, 255, 255, 0.08);
        box-shadow: -24px 0 60px rgba(0, 0, 0, 0.45);
        transform: translateX(100%);
        transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1);
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
      }

      .site-header.is-menu-open .nav {
        transform: translateX(0);
      }

      .nav a {
        padding: 14px 4px;
        border-bottom: 1px solid rgba(255, 255, 255, 0.06);
        font-size: var(--text-body);
        white-space: normal;
      }

      .nav a:last-of-type {
        border-bottom: 1px solid rgba(255, 255, 255, 0.06);
      }

      .nav-cta {
        margin-top: 12px;
        text-align: center;
        justify-content: center;
      }

      .nav-cta--whatsapp-icon {
        margin-left: auto;
        margin-right: auto;
      }

      .stats,
      .intro-highlights:not(.intro-highlights--compact),
      .highlight-list,
      .form-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
      .intro-highlights--compact {
        grid-template-columns: 1fr;
      }
      .hero__img {
        object-position: 58% 42%;
        animation: none;
        transform: none;
      }
      .hero__scrim {
        background:
          linear-gradient(
            105deg,
            #070d16 0%,
            rgba(7, 13, 22, 0.9) 22%,
            rgba(10, 18, 31, 0.55) 48%,
            rgba(12, 22, 38, 0.22) 68%,
            transparent 88%
          ),
          linear-gradient(180deg, rgba(4, 8, 14, 0.65) 0%, transparent 36%, rgba(4, 8, 14, 0.55) 100%);
      }
      .hero__title {
        max-width: 16ch;
      }
    }

    @media (max-width: 560px) {
      .container { width: min(calc(100% - 22px), var(--container)); }
      .site-header__inner {
        min-height: 72px;
      }
      .hero--cinematic .hero__inner {
        padding-top: 92px;
        align-items: flex-end;
        padding-bottom: 56px;
      }
      .hero__copy {
        padding-right: 0;
        max-width: 100%;
      }
      .hero__title {
        max-width: none;
        font-size: var(--text-hero);
      }
      .stats,
      .intro-highlights,
      .highlight-list,
      .form-grid { grid-template-columns: 1fr; }
      .panel { padding: 22px; }
      .hero-actions { flex-direction: column; align-items: stretch; }
      .button { width: 100%; }
      .hero__scroll {
        bottom: 16px;
      }
    }

    @media (prefers-reduced-motion: reduce) {
      .portrait-marquee--loading .portrait-marquee__viewport::after {
        animation: none !important;
        opacity: 0.4;
      }

      .gallery-page__empty {
        animation: none !important;
        opacity: 1;
        transform: none;
      }

      .button:active {
        transform: none;
      }

      .nav {
        transition: none !important;
      }

      .nav-backdrop {
        transition: none !important;
      }

      .nav-toggle__line {
        transition: none !important;
      }

      .hero__img {
        animation: none;
        transform: none;
      }
      .hero__copy > * {
        animation: none;
        opacity: 1;
        transform: none;
      }
      .hero__scroll-line {
        animation: none;
      }

      .process-section__ambient {
        animation: none !important;
      }

      .faq-section__glow {
        animation: none !important;
      }

      .process-flow__card:hover {
        transform: none !important;
      }

      .process-flow__card:hover .process-flow__media img {
        transform: none !important;
      }

      .portrait-marquee__slide:hover img {
        transform: none;
      }
      .portfolio-showcase__rivers,
      .portfolio-showcase__river-col {
        animation: none !important;
      }

      .portfolio-showcase__tile:hover,
      .portfolio-showcase__tile:focus-visible {
        transform: none;
      }
      [data-reveal],
      [data-reveal].is-revealed {
        opacity: 1 !important;
        filter: none !important;
      }
      [data-reveal="block"],
      [data-reveal="block"].is-revealed {
        transform: none !important;
      }
      [data-reveal="focus"] .section-intro__photo-visual,
      [data-reveal="focus"] .section-intro__caption,
      [data-reveal="focus"] .about-v2-hero__media {
        opacity: 1 !important;
        transform: none !important;
        filter: none !important;
      }
      .gallery-page .portrait-marquee__stage {
        animation: none !important;
        opacity: 1 !important;
        transform: none !important;
      }
    }

    html.podwiatr-reduced-motion [data-reveal="tile"] {
      opacity: 1 !important;
      filter: none !important;
    }

    /* --- Ściana kategorii (strona główna) — bento + „rzeki” zdjęć zamiast wielu karuzel --- */
    .portfolio-showcase {
      padding: var(--section-pad-y) 0;
      overflow: hidden;
      border-top: 1px solid rgba(255, 255, 255, 0.06);
      content-visibility: auto;
      contain-intrinsic-size: auto 900px;
      background:
        radial-gradient(ellipse 70% 50% at 80% 0%, rgba(126, 160, 216, 0.12), transparent 55%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.03), transparent 40%);
    }

    /* Nagłówek na pełną szerokość kontenera — nie wąski słupek; linia oddziela intro od bento */
    .portfolio-showcase__head {
      width: 100%;
      max-width: none;
      margin-bottom: clamp(26px, 3.8vw, 38px);
      padding-bottom: clamp(22px, 3.2vw, 34px);
      border-bottom: 1px solid rgba(255, 255, 255, 0.09);
      box-shadow: 0 1px 0 rgba(0, 0, 0, 0.22);
    }

    .portfolio-showcase__head .section-kicker {
      margin-bottom: 10px;
    }

    .portfolio-showcase__head h2 {
      margin-bottom: 14px;
      line-height: 1.04;
    }

    .portfolio-showcase__head .section-subtitle {
      max-width: min(72ch, 100%);
      margin: 0;
      line-height: 1.58;
      color: rgba(210, 222, 242, 0.94);
    }

    .portfolio-showcase__head .hero-actions {
      margin-bottom: 0;
    }

    @media (min-width: 880px) {
      .portfolio-showcase__head {
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto;
        grid-template-rows: auto auto minmax(0, auto);
        column-gap: clamp(28px, 4.5vw, 56px);
        row-gap: 0;
        align-items: start;
      }

      .portfolio-showcase__head .section-kicker {
        grid-column: 1;
        grid-row: 1;
      }

      .portfolio-showcase__head h2 {
        grid-column: 1;
        grid-row: 2;
      }

      .portfolio-showcase__head .section-subtitle {
        grid-column: 1;
        grid-row: 3;
        padding-top: 6px;
      }

      .portfolio-showcase__head .hero-actions {
        grid-column: 2;
        grid-row: 2 / -1;
        align-self: end;
        justify-content: flex-end;
        margin-top: 0;
      }
    }

    @media (max-width: 879px) {
      .portfolio-showcase__head .hero-actions {
        margin-top: 18px;
      }
    }

    .portfolio-showcase__bento {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 20px;
      align-items: stretch;
    }

    /*
     * Kafelki portfolio — kształt:
     * TYMCZASOWO kwadrat (aspect-ratio). Powrót do wyższych prostokątów: usuń
     * `aspect-ratio` + `min-height: 0`, ustaw z powrotem np. `min-height: 400px`.
     */
    .portfolio-showcase__tile {
      position: relative;
      display: flex;
      flex-direction: column;
      justify-content: flex-end;
      aspect-ratio: 1 / 1;
      min-height: 0;
      padding: 36px 32px 32px;
      border-radius: var(--radius-lg);
      overflow: hidden;
      text-decoration: none;
      color: #f4f7fd;
      border: 0;
      box-shadow: 0 20px 48px rgba(0, 0, 0, 0.42);
      background-size: cover;
      background-position: center;
      transform: none;
      transition:
        transform 0.45s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.45s ease;
    }

    .portfolio-showcase__tile:hover,
    .portfolio-showcase__tile:focus-visible {
      transform: rotate(-1.15deg) scale(1.03) translateY(-5px);
      z-index: 3;
      box-shadow: 0 28px 64px rgba(0, 0, 0, 0.52);
      outline: none;
    }

    .portfolio-showcase__tile::before {
      content: "";
      position: absolute;
      inset: 0;
      background: linear-gradient(
        165deg,
        rgba(6, 11, 19, 0.15) 0%,
        rgba(6, 11, 19, 0.55) 45%,
        rgba(4, 8, 14, 0.92) 100%
      );
      z-index: 0;
      transition: opacity 0.4s ease;
    }

    .portfolio-showcase__tile:hover::before,
    .portfolio-showcase__tile:focus-visible::before {
      opacity: 0.92;
    }

    .portfolio-showcase__tile strong {
      position: relative;
      z-index: 1;
      font-family: var(--font-sans);
      font-size: var(--text-tile-display);
      font-weight: var(--font-weight-heading);
      letter-spacing: -0.02em;
      display: block;
      margin-bottom: 8px;
    }

    .portfolio-showcase__tile span {
      position: relative;
      z-index: 1;
      font-size: var(--text-tile-meta);
      font-weight: var(--font-weight-body);
      letter-spacing: 0.06em;
      text-transform: uppercase;
      color: rgba(220, 230, 248, 0.75);
    }

    /* Tła kafelków ze zdjęciami: ładowane przez js/lazy-tile-bg.js (data-tile-bg w index.html) */
    .portfolio-showcase__tile[data-tile-bg] {
      background-image: none;
      background-color: rgba(10, 24, 40, 0.92);
    }

    /* Ósmy slot — CTA do kontaktu (konwersja) */
    .portfolio-showcase__tile--cta {
      background-image: none;
      background: linear-gradient(
        145deg,
        rgba(95, 120, 182, 0.35) 0%,
        rgba(18, 28, 48, 0.95) 45%,
        rgba(7, 16, 28, 0.92) 100%
      );
      border: 0;
      box-shadow: 0 22px 52px rgba(0, 0, 0, 0.45);
    }

    .portfolio-showcase__tile--cta:hover,
    .portfolio-showcase__tile--cta:focus-visible {
      box-shadow: 0 30px 68px rgba(0, 0, 0, 0.55);
    }

    .portfolio-showcase__tile--cta strong {
      color: #f0f4fc;
    }

    .portfolio-showcase__tile--cta span {
      color: rgba(220, 232, 250, 0.88);
    }

    .portfolio-showcase__rivers {
      margin-top: var(--section-block-gap);
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 10px;
      max-height: 560px;
      overflow: hidden;
      position: relative;
      mask-image: linear-gradient(to bottom, transparent 0%, black 8%, black 92%, transparent 100%);
      -webkit-mask-image: linear-gradient(to bottom, transparent 0%, black 8%, black 92%, transparent 100%);
    }

    .portfolio-showcase__river-wrap {
      overflow: hidden;
      border-radius: 0;
      border: 1px solid rgba(255, 255, 255, 0.06);
      background: rgba(0, 0, 0, 0.2);
    }

    .portfolio-showcase__river-col {
      display: flex;
      flex-direction: column;
      gap: 10px;
      animation: portfolioRiver 38s linear infinite;
      will-change: transform;
    }

    .portfolio-showcase__river-col--b {
      animation-duration: 48s;
      animation-delay: -12s;
    }

    .portfolio-showcase__river-col--c {
      animation-duration: 42s;
      animation-delay: -6s;
    }

    @keyframes portfolioRiver {
      from { transform: translateY(0); }
      to { transform: translateY(-50%); }
    }

    .portfolio-showcase__river-cell {
      aspect-ratio: 3 / 4;
      border-radius: 0;
      overflow: hidden;
      flex-shrink: 0;
      box-shadow: 0 12px 28px rgba(0, 0, 0, 0.35);
    }

    .portfolio-showcase__river-cell img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
      filter: brightness(0.88) saturate(0.95);
    }

    @media (max-width: 960px) {
      .portfolio-showcase__bento {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }
    }

    @media (max-width: 620px) {
      .portfolio-showcase__bento {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }
      .portfolio-showcase__tile {
        padding: 24px 20px 20px;
      }
      .portfolio-showcase__rivers {
        grid-template-columns: 1fr;
        max-height: 400px;
      }
    }

    @media (max-width: 420px) {
      .portfolio-showcase__bento {
        grid-template-columns: 1fr;
      }
    }

    /* --- Strona galerii: zakładki + jedna karuzela --- */
    html:has(main.gallery-page) {
      background-color: #020203;
    }

    body:has(main.gallery-page) {
      background: var(--page-bg-about-dark);
      background-color: #020203;
    }

    body:has(main.gallery-page)::before {
      background: linear-gradient(
        180deg,
        rgba(126, 160, 216, 0.055) 0%,
        transparent 42%,
        transparent 100%
      );
    }

    body:has(main.gallery-page)::after {
      opacity: 0.056;
    }

    .gallery-page {
      padding-top: var(--section-pad-y);
      padding-bottom: 0;
    }

    .gallery-page__toolbar {
      display: flex;
      flex-direction: column;
      align-items: center;
      width: 100%;
    }

    .gallery-page__empty {
      margin: 0;
      padding: 48px 24px;
      text-align: center;
      color: rgba(200, 214, 235, 0.75);
      font-size: var(--text-body);
      line-height: 1.5;
      max-width: 36ch;
      margin-left: auto;
      margin-right: auto;
      animation: podwiatrEmptyIn 0.6s ease forwards;
    }

    @keyframes podwiatrEmptyIn {
      from {
        opacity: 0;
        transform: translateY(6px);
      }
      to {
        opacity: 1;
        transform: translateY(0);
      }
    }

    .gallery-tabs {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      margin-bottom: var(--section-block-gap);
      justify-content: center;
      padding: 6px;
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.04);
      border: 1px solid rgba(255, 255, 255, 0.08);
      /* Kotwica przewijania przy zmianie kategorii — pod sticky header */
      scroll-margin-top: 92px;
      width: fit-content;
      max-width: 100%;
    }

    .gallery-tabs button {
      appearance: none;
      font: inherit;
      cursor: pointer;
      border: none;
      padding: 12px 18px;
      border-radius: 999px;
      color: #c5d2e6;
      background: transparent;
      transition: color 0.25s ease, background 0.25s ease, box-shadow 0.25s ease;
      font-size: var(--text-body-sm);
      font-weight: var(--font-weight-ui);
      letter-spacing: 0.04em;
      text-transform: uppercase;
    }

    .gallery-tabs button:hover {
      color: #fff;
      background: rgba(255, 255, 255, 0.06);
    }

    .gallery-tabs button[aria-selected="true"] {
      color: #07101c;
      background: linear-gradient(135deg, #7ea0d8, #5f78b6);
      box-shadow: 0 8px 24px rgba(95, 120, 182, 0.35);
    }

    .gallery-tabs button:focus-visible {
      outline: 2px solid rgba(126, 160, 216, 0.7);
      outline-offset: 2px;
    }

    .gallery-tabs button:active {
      transform: scale(0.97);
    }

    .gallery-page .portrait-marquee {
      padding-top: var(--section-block-gap);
      padding-bottom: var(--section-pad-y);
    }

    .gallery-page .portrait-marquee + .portrait-marquee {
      padding-top: var(--section-block-gap);
    }

    /* Galeria: stała wysokość pasa (JS), szerokość 1–3 kafle; proporcje zdjęcia — object-fit: contain (bez skoku układu przy zmianie slajdu) */
    .gallery-page .portrait-marquee__track {
      align-items: stretch;
    }

    .gallery-page .portrait-marquee__slide {
      aspect-ratio: unset;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
      border-radius: 0;
      background: transparent;
      box-shadow: none;
    }

    .gallery-page .portrait-marquee__slide img {
      width: 100%;
      height: 100%;
      max-width: 100%;
      max-height: 100%;
      object-fit: contain;
      object-position: center center;
    }

    /* Krawędzie: miękki fade w kolor strony (jak tło), nie nachodzi na pasek kropek */
    .gallery-page .portrait-marquee__stage::before,
    .gallery-page .portrait-marquee__stage::after {
      bottom: clamp(48px, 10vw, 64px);
      width: min(56px, 10vw);
      background: linear-gradient(
        90deg,
        rgb(var(--bg-base-rgb)) 0%,
        rgba(var(--bg-base-rgb), 0.55) 45%,
        transparent 100%
      );
    }

    .gallery-page .portrait-marquee__stage::after {
      background: linear-gradient(
        270deg,
        rgb(var(--bg-base-rgb)) 0%,
        rgba(var(--bg-base-rgb), 0.55) 45%,
        transparent 100%
      );
    }

    .gallery-page .portrait-marquee__viewport {
      mask-image: none;
      -webkit-mask-image: none;
    }

    .gallery-page .portrait-marquee__nav-btn {
      border-radius: 10px;
    }

    /* --- Scroll reveal: spokojne wejście w kadr (js/motion-reveal.js) --- */
    :root {
      --reveal-duration: 0.78s;
      --reveal-ease: cubic-bezier(0.22, 1, 0.36, 1);
    }

    html.podwiatr-motion-on [data-reveal="block"] {
      transition:
        opacity var(--reveal-duration) var(--reveal-ease),
        transform var(--reveal-duration) var(--reveal-ease),
        box-shadow 0.45s ease,
        border-color 0.35s ease;
    }

    html.podwiatr-motion-on [data-reveal="block"]:not(.is-revealed) {
      opacity: 0;
      transform: translateY(1.05rem);
    }

    html.podwiatr-motion-on [data-reveal="block"].is-revealed {
      opacity: 1;
      transform: translateY(0);
    }

    html.podwiatr-motion-on .process-flow .process-flow__card[data-reveal="block"]:not(.is-revealed) {
      transform: translateY(1.45rem);
    }

    html.podwiatr-motion-on .process-flow .process-flow__card[data-reveal="block"] {
      transition-duration: 0.88s;
    }

    html.podwiatr-motion-on .process-flow .process-flow__card[data-reveal="block"]:nth-child(1) {
      transition-delay: 0.04s;
    }
    html.podwiatr-motion-on .process-flow .process-flow__card[data-reveal="block"]:nth-child(2) {
      transition-delay: 0.1s;
    }
    html.podwiatr-motion-on .process-flow .process-flow__card[data-reveal="block"]:nth-child(3) {
      transition-delay: 0.16s;
    }
    html.podwiatr-motion-on .process-flow .process-flow__card[data-reveal="block"]:nth-child(4) {
      transition-delay: 0.22s;
    }

    html.podwiatr-motion-on .faq-section__list > .faq-item[data-reveal="block"]:nth-child(1) {
      transition-delay: 0.03s;
    }
    html.podwiatr-motion-on .faq-section__list > .faq-item[data-reveal="block"]:nth-child(2) {
      transition-delay: 0.07s;
    }
    html.podwiatr-motion-on .faq-section__list > .faq-item[data-reveal="block"]:nth-child(3) {
      transition-delay: 0.11s;
    }
    html.podwiatr-motion-on .faq-section__list > .faq-item[data-reveal="block"]:nth-child(4) {
      transition-delay: 0.15s;
    }
    html.podwiatr-motion-on .faq-section__list > .faq-item[data-reveal="block"]:nth-child(5) {
      transition-delay: 0.19s;
    }
    html.podwiatr-motion-on .faq-section__list > .faq-item[data-reveal="block"]:nth-child(6) {
      transition-delay: 0.23s;
    }

    html.podwiatr-motion-on .why-list > .why-item[data-reveal="block"]:nth-child(1) {
      transition-delay: 0.03s;
    }
    html.podwiatr-motion-on .why-list > .why-item[data-reveal="block"]:nth-child(2) {
      transition-delay: 0.07s;
    }
    html.podwiatr-motion-on .why-list > .why-item[data-reveal="block"]:nth-child(3) {
      transition-delay: 0.11s;
    }
    html.podwiatr-motion-on .why-list > .why-item[data-reveal="block"]:nth-child(4) {
      transition-delay: 0.15s;
    }
    html.podwiatr-motion-on .why-list > .why-item[data-reveal="block"]:nth-child(5) {
      transition-delay: 0.19s;
    }
    html.podwiatr-motion-on .why-list > .why-item[data-reveal="block"]:nth-child(6) {
      transition-delay: 0.23s;
    }
    html.podwiatr-motion-on .why-list > .why-item[data-reveal="block"]:nth-child(7) {
      transition-delay: 0.27s;
    }

    /* Kafelki: odsłona jak „włączanie światła”; obrót tylko przy hover (poza reduced-motion) */
    .portfolio-showcase__tile[data-reveal="tile"] {
      transition:
        opacity 0.88s var(--reveal-ease),
        filter 1.05s ease,
        transform 0.45s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.45s ease;
    }

    html.podwiatr-motion-on .portfolio-showcase__tile[data-reveal="tile"]:not(.is-revealed) {
      opacity: 0;
      filter: brightness(0.52) saturate(0.88);
    }

    html.podwiatr-motion-on .portfolio-showcase__tile[data-reveal="tile"].is-revealed {
      opacity: 1;
      filter: none;
    }

    .portfolio-showcase__bento .portfolio-showcase__tile[data-reveal="tile"]:nth-child(1) {
      transition-delay: 0.03s;
    }
    .portfolio-showcase__bento .portfolio-showcase__tile[data-reveal="tile"]:nth-child(2) {
      transition-delay: 0.07s;
    }
    .portfolio-showcase__bento .portfolio-showcase__tile[data-reveal="tile"]:nth-child(3) {
      transition-delay: 0.11s;
    }
    .portfolio-showcase__bento .portfolio-showcase__tile[data-reveal="tile"]:nth-child(4) {
      transition-delay: 0.15s;
    }
    .portfolio-showcase__bento .portfolio-showcase__tile[data-reveal="tile"]:nth-child(5) {
      transition-delay: 0.19s;
    }
    .portfolio-showcase__bento .portfolio-showcase__tile[data-reveal="tile"]:nth-child(6) {
      transition-delay: 0.23s;
    }
    .portfolio-showcase__bento .portfolio-showcase__tile[data-reveal="tile"]:nth-child(7) {
      transition-delay: 0.27s;
    }
    .portfolio-showcase__bento .portfolio-showcase__tile[data-reveal="tile"]:nth-child(8) {
      transition-delay: 0.31s;
    }

    .section-intro__photo-visual,
    .section-intro__caption,
    .about-v2-hero__media {
      transition:
        opacity 0.92s var(--reveal-ease),
        transform 0.95s var(--reveal-ease),
        filter 1.05s ease;
    }

    html.podwiatr-motion-on [data-reveal="focus"]:not(.is-revealed) .section-intro__photo-visual,
    html.podwiatr-motion-on [data-reveal="focus"]:not(.is-revealed) .about-v2-hero__media {
      opacity: 0;
      transform: scale(0.96) translateY(14px);
      filter: blur(5px);
    }

    html.podwiatr-motion-on [data-reveal="focus"].is-revealed .section-intro__photo-visual,
    html.podwiatr-motion-on [data-reveal="focus"].is-revealed .about-v2-hero__media {
      opacity: 1;
      transform: scale(1) translateY(0);
      filter: blur(0);
    }

    html.podwiatr-motion-on [data-reveal="focus"]:not(.is-revealed) .section-intro__caption {
      opacity: 0;
      transform: translateY(10px);
    }

    html.podwiatr-motion-on [data-reveal="focus"].is-revealed .section-intro__caption {
      opacity: 1;
      transform: translateY(0);
      transition-delay: 0.12s;
    }

    .section-intro__main > [data-reveal="block"]:nth-child(1) {
      transition-delay: 0.02s;
    }
    .section-intro__main > [data-reveal="block"]:nth-child(2) {
      transition-delay: 0.08s;
    }
    .section-intro__main > [data-reveal="block"]:nth-child(3) {
      transition-delay: 0.14s;
    }
    .section-intro__main > [data-reveal="block"]:nth-child(4) {
      transition-delay: 0.2s;
    }
    .section-intro__main > [data-reveal="block"]:nth-child(5) {
      transition-delay: 0.26s;
    }

    .highlight-list .highlight[data-reveal="block"]:nth-child(1) {
      transition-delay: 0.05s;
    }
    .highlight-list .highlight[data-reveal="block"]:nth-child(2) {
      transition-delay: 0.11s;
    }
    .highlight-list .highlight[data-reveal="block"]:nth-child(3) {
      transition-delay: 0.17s;
    }
    .highlight-list .highlight[data-reveal="block"]:nth-child(4) {
      transition-delay: 0.23s;
    }

    .about-side .about-card[data-reveal="block"]:nth-child(1) {
      transition-delay: 0.06s;
    }
    .about-side .about-card[data-reveal="block"]:nth-child(2) {
      transition-delay: 0.14s;
    }
    .about-side .about-card[data-reveal="block"]:nth-child(3) {
      transition-delay: 0.22s;
    }

    #contact-form.contact-form-panel[data-reveal="block"] {
      transition-delay: 0.06s;
    }

    .section-head > div > [data-reveal="block"]:nth-child(1) {
      transition-delay: 0.02s;
    }
    .section-head > div > [data-reveal="block"]:nth-child(2) {
      transition-delay: 0.08s;
    }
    .section-head > div > [data-reveal="block"]:nth-child(3) {
      transition-delay: 0.14s;
    }
    .section-head > div > [data-reveal="block"]:nth-child(4) {
      transition-delay: 0.2s;
    }
    .section-head > div > [data-reveal="block"]:nth-child(5) {
      transition-delay: 0.26s;
    }
    .section-head > div > [data-reveal="block"]:nth-child(6) {
      transition-delay: 0.32s;
    }
    .section-head > div > [data-reveal="block"]:nth-child(7) {
      transition-delay: 0.38s;
    }

    .portfolio-showcase__head > [data-reveal="block"]:nth-child(1) {
      transition-delay: 0.02s;
    }
    .portfolio-showcase__head > [data-reveal="block"]:nth-child(2) {
      transition-delay: 0.08s;
    }
    .portfolio-showcase__head > [data-reveal="block"]:nth-child(3) {
      transition-delay: 0.14s;
    }
    .portfolio-showcase__head > [data-reveal="block"]:nth-child(4) {
      transition-delay: 0.2s;
    }

    /* Nowoczesny, cichy akcent na linkach w treści */
    html.podwiatr-motion-on .section-subtitle a,
    html.podwiatr-motion-on .section-intro__hook a {
      background-image: linear-gradient(
        90deg,
        rgba(126, 160, 216, 0.45),
        rgba(126, 160, 216, 0.85)
      );
      background-size: 0% 1px;
      background-repeat: no-repeat;
      background-position: 0 100%;
      transition: background-size 0.45s var(--reveal-ease);
    }

    html.podwiatr-motion-on .section-subtitle a:hover,
    html.podwiatr-motion-on .section-intro__hook a:hover {
      background-size: 100% 1px;
    }

    html.podwiatr-motion-on .section-subtitle a.text-link--editorial {
      background-image: none;
      transition:
        color 0.2s ease,
        border-color 0.2s ease;
    }

    html.podwiatr-motion-on .section-subtitle a.text-link--editorial:hover {
      background-size: 0;
    }

    /* Przyciski: lekki „lift” z błękitnym odblaskiem */
    html.podwiatr-motion-on .button {
      transition:
        transform 0.35s var(--reveal-ease),
        box-shadow 0.4s ease,
        border-color 0.3s ease,
        filter 0.35s ease;
    }

    html.podwiatr-motion-on .button:hover {
      filter: brightness(1.06);
    }

    html.podwiatr-motion-on .button--primary:hover {
      box-shadow: 0 18px 42px rgba(95, 120, 182, 0.42), 0 0 0 1px rgba(200, 220, 255, 0.12);
    }

    /* Karuzela główna: delikatne wejście po załadowaniu strony */
    html.podwiatr-motion-on .gallery-page .portrait-marquee__stage {
      opacity: 0;
      transform: translateY(12px);
      animation: galleryStageIn 0.95s var(--reveal-ease) 0.15s forwards;
    }

    @keyframes galleryStageIn {
      to {
        opacity: 1;
        transform: translateY(0);
      }
    }

    /* --- 404 (lekka strona błędu, spójna z tłem witryny) --- */
    .page-404-body {
      min-height: 100vh;
      display: flex;
      align-items: center;
      justify-content: center;
      padding: clamp(24px, 5vw, 48px);
    }

    .page-404 {
      max-width: 36rem;
      margin: 0 auto;
      text-align: center;
    }

    .page-404__brand {
      margin: 0 0 1.25rem;
      font-family: var(--font-script);
      font-size: clamp(1.35rem, 4vw, 1.85rem);
      font-weight: 600;
      letter-spacing: 0.02em;
      text-transform: none;
      transform: rotate(-1.5deg);
    }

    .page-404__brand a {
      color: var(--accent);
      text-decoration: none;
    }

    .page-404__brand a:hover {
      color: #b8cff5;
    }

    .page-404__title {
      margin: 0 0 0.75rem;
      font-size: var(--text-title);
      font-weight: var(--font-weight-ui);
      letter-spacing: 0.06em;
      color: #f6f9ff;
    }

    .page-404__lede {
      margin: 0 0 1.75rem;
      line-height: 1.55;
      color: rgba(210, 222, 240, 0.92);
      font-size: var(--text-body-sm);
    }

    .page-404__nav {
      display: flex;
      flex-wrap: wrap;
      gap: 12px;
      justify-content: center;
    }

    /* --- Strona główna: konwersja, usługi, kontakt premium, dock --- */
    .hero-actions--center {
      justify-content: center;
    }

    .hero-actions--triple {
      gap: 12px;
    }

    /* Wąski tablet / telefon poziomo — trzy pełne CTA obok siebie potrafią dać poziomy scroll (długi tekst PL/EN) */
    @media (max-width: 720px) {
      .hero-actions--triple {
        flex-direction: column;
        align-items: stretch;
      }

      .hero-actions--triple > .button,
      .hero-actions--triple > span {
        width: 100%;
        max-width: 100%;
      }

      .hero-actions--triple > span .button {
        width: 100%;
        box-sizing: border-box;
      }
    }

    .hero__subcta {
      margin: 18px 0 0;
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      gap: 10px;
    }

    .hero__ig-cta {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      min-height: 46px;
      padding: 0 20px;
      font-size: var(--text-ui-sm);
      letter-spacing: 0.04em;
      text-decoration: none;
    }

    .hero__cta-icon {
      width: 20px;
      height: 20px;
      flex-shrink: 0;
      opacity: 0.95;
    }

    .hero__copy .hero__subcta {
      opacity: 0;
      animation: heroIn 1.1s cubic-bezier(0.22, 1, 0.36, 1) forwards;
      animation-delay: 0.56s;
    }

    .hero__copy .hero__trust--fast {
      animation-delay: 0.66s;
    }

    .button--glass {
      background: rgba(255, 255, 255, 0.04);
      border-color: rgba(255, 255, 255, 0.14);
      backdrop-filter: blur(10px);
      -webkit-backdrop-filter: blur(10px);
      box-shadow: 0 12px 36px rgba(0, 0, 0, 0.22);
    }

    .button--ghost {
      background: transparent;
      border: 1px solid rgba(255, 255, 255, 0.22);
      color: rgba(236, 241, 252, 0.96);
    }

    .button--ghost:hover {
      background: rgba(255, 255, 255, 0.06);
      border-color: rgba(255, 255, 255, 0.32);
    }

    .button--whatsapp-premium {
      background: linear-gradient(135deg, rgba(255, 255, 255, 0.14), rgba(126, 160, 216, 0.42));
      color: #f4f7fd;
      border: 1px solid rgba(255, 255, 255, 0.16);
      box-shadow:
        0 14px 38px rgba(0, 0, 0, 0.35),
        inset 0 1px 0 rgba(255, 255, 255, 0.12);
    }

    .button--whatsapp-premium:hover {
      filter: brightness(1.08);
    }

    .button.is-disabled {
      opacity: 0.45;
      pointer-events: none;
      cursor: not-allowed;
      transform: none;
      box-shadow: none;
    }

    .trust-strip {
      border-top: 1px solid rgba(255, 255, 255, 0.07);
      border-bottom: 1px solid rgba(255, 255, 255, 0.06);
      background: linear-gradient(
        90deg,
        rgba(255, 255, 255, 0.03),
        rgba(126, 160, 216, 0.06),
        rgba(255, 255, 255, 0.03)
      );
      padding: 14px 0;
    }

    .trust-strip__inner {
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      justify-content: center;
      gap: 10px 18px;
      font-size: var(--text-body-sm);
      letter-spacing: 0.04em;
      text-transform: uppercase;
      color: rgba(200, 214, 235, 0.88);
      text-align: center;
    }

    .trust-strip__inner strong {
      font-weight: var(--font-weight-ui);
      color: rgba(236, 241, 252, 0.96);
    }

    .trust-strip__dot {
      width: 4px;
      height: 4px;
      border-radius: 50%;
      background: rgba(126, 160, 216, 0.65);
      display: inline-block;
      vertical-align: middle;
    }

    .trust-strip--lux {
      padding: 20px 0;
      border-top: 1px solid rgba(255, 255, 255, 0.05);
      border-bottom: 1px solid rgba(255, 255, 255, 0.04);
      background: linear-gradient(180deg, rgba(5, 11, 19, 0.92), rgba(5, 11, 19, 0.72));
    }

    .trust-strip--lux .trust-strip__inner {
      letter-spacing: 0.16em;
      text-transform: uppercase;
      font-size: var(--text-small);
      color: rgba(176, 192, 218, 0.72);
      gap: 14px 20px;
    }

    .trust-strip__stack {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: clamp(12px, 2.2vw, 18px);
    }

    /* Keyword chips (SEO) — pasek pod hero, ostre krawędzie (bez zaokrągleń) */
    .trust-strip-chips.home-hero-chips,
    .home-hero-chips--services {
      display: flex;
      flex-wrap: wrap;
      justify-content: center;
      gap: 8px 12px;
      width: 100%;
      max-width: 56rem;
      margin: 0;
      padding: 0 0 clamp(10px, 1.8vw, 14px);
      list-style: none;
      border-bottom: 1px solid rgba(255, 255, 255, 0.07);
    }

    .home-hero-chips--services {
      margin-top: 12px;
      padding-bottom: 0;
      border-bottom: 0;
      max-width: 60rem;
    }

    .home-hero-chips__item {
      margin: 0;
    }

    .home-hero-chip {
      display: inline-flex;
      align-items: center;
      min-height: 32px;
      padding: 7px 14px;
      font-size: 0.6875rem;
      font-weight: 500;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: rgba(198, 210, 232, 0.88);
      border: 1px solid rgba(255, 255, 255, 0.12);
      border-radius: 0;
      background: rgba(255, 255, 255, 0.04);
      backdrop-filter: blur(10px);
      -webkit-backdrop-filter: blur(10px);
      box-shadow: none;
      text-decoration: none;
      transition: border-color 0.25s ease, background 0.25s ease, color 0.25s ease;
    }

    a.home-hero-chip:hover {
      border-color: rgba(126, 160, 216, 0.5);
      background: rgba(126, 160, 216, 0.14);
      color: #fff;
    }

    /* --- Editorial pod hero: emocja → lokal (premium / cinematic) --- */
    .editorial-post-hero {
      position: relative;
    }

    .editorial-glass {
      backdrop-filter: blur(18px);
      -webkit-backdrop-filter: blur(18px);
      background: linear-gradient(150deg, rgba(14, 26, 42, 0.58), rgba(7, 16, 28, 0.82));
      border: 1px solid rgba(255, 255, 255, 0.1);
      border-radius: 0;
      box-shadow:
        0 32px 90px rgba(0, 0, 0, 0.5),
        inset 0 1px 0 rgba(255, 255, 255, 0.06);
    }

    .editorial-comfort {
      padding: clamp(64px, 11vw, 132px) 0 clamp(56px, 9vw, 100px);
      content-visibility: auto;
      contain-intrinsic-size: auto 640px;
      border-top: 1px solid rgba(255, 255, 255, 0.04);
      background:
        radial-gradient(ellipse 55% 42% at 12% 18%, rgba(126, 160, 216, 0.09), transparent 58%),
        radial-gradient(ellipse 48% 38% at 92% 88%, rgba(230, 125, 65, 0.05), transparent 55%);
    }

    .editorial-comfort__grid {
      display: grid;
      grid-template-columns: minmax(0, 1fr) minmax(0, 1.12fr);
      gap: clamp(28px, 5vw, 56px);
      align-items: center;
    }

    .editorial-comfort__copy {
      max-width: 38rem;
      padding-right: clamp(0px, 2vw, 12px);
    }

    .editorial-comfort__preface {
      margin: 0 0 14px;
      font-size: var(--text-caption);
      font-weight: var(--font-weight-ui);
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: rgba(126, 160, 216, 0.88);
    }

    .editorial-comfort__quote {
      margin: 0 0 clamp(18px, 3vw, 26px);
      font-family: var(--font-sans);
      font-style: italic;
      font-weight: 500;
      font-size: clamp(1.5rem, 3.6vw, 2.35rem);
      line-height: 1.18;
      letter-spacing: -0.02em;
      color: rgba(244, 247, 253, 0.98);
    }

    .editorial-comfort__title {
      margin: 0 0 16px;
      font-family: var(--font-sans);
      font-weight: var(--font-weight-heading);
      font-size: clamp(1.7rem, 4vw, 2.65rem);
      line-height: 1.06;
      letter-spacing: -0.03em;
      color: #f4f7fd;
    }

    .editorial-comfort__lede {
      margin: 0;
      max-width: 36ch;
      font-size: var(--text-body);
      line-height: 1.68;
      color: rgba(198, 212, 234, 0.88);
    }

    .editorial-comfort__figure {
      margin: 0;
    }

    .editorial-comfort__frame {
      border-radius: 0;
      overflow: hidden;
      border: 1px solid rgba(255, 255, 255, 0.09);
      box-shadow:
        0 44px 110px rgba(0, 0, 0, 0.55),
        inset 0 0 0 1px rgba(255, 255, 255, 0.04);
      aspect-ratio: 4 / 5;
      max-height: min(88vh, 900px);
      width: 100%;
    }

    .editorial-comfort__img {
      display: block;
      width: 100%;
      height: 100%;
      object-fit: cover;
      /* Twarz w dolnej lewej części oryginału — nie centrujemy kadru */
      object-position: 26% 72%;
      transform: translate3d(0, var(--img-parallax-y, 0px), 0) scale(1.02);
      transform-origin: 26% 72%;
      transition: none;
      will-change: transform;
    }

    html.podwiatr-motion-on .editorial-comfort__figure:hover .editorial-comfort__img {
      transform: translate3d(0, var(--img-parallax-y, 0px), 0) scale(1.06);
      transition: transform 1.05s var(--reveal-ease);
    }

    @media (min-width: 901px) {
      .editorial-comfort__figure {
        margin-left: clamp(8px, 2.5vw, 40px);
      }
    }

    @media (max-width: 900px) {
      .editorial-comfort__grid {
        grid-template-columns: 1fr;
      }

      .editorial-comfort__figure {
        order: -1;
      }

      .editorial-comfort__copy {
        max-width: none;
        padding-right: 0;
      }

      .editorial-comfort__lede {
        max-width: none;
      }
    }

    /* Zdjęcie na pełną szerokość; szklany pasek tekstu dopiero pod kadrem (nie nakładka). */
    .editorial-local {
      position: relative;
      display: flex;
      flex-direction: column;
      content-visibility: auto;
      contain-intrinsic-size: auto 640px;
      border-top: 1px solid rgba(255, 255, 255, 0.05);
    }

    .editorial-local__media {
      position: relative;
      width: 100%;
      overflow: hidden;
      background: var(--bg-base);
      min-height: clamp(380px, 76vh, 720px);
    }

    /* Ultra-szeroki viewport: wyższy pas zdjęcia — cover bez ucinania twarzy */
    @media (min-width: 901px) {
      .editorial-local__media {
        min-height: clamp(460px, min(76vh, 42vw), 780px);
      }
    }

    .editorial-local__img {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      /*
       * images/sections/strona-glowna-wojewodztwo.jpg — twarz w górnej części kadru; na szerokim ekranie
       * cover obcina górę przy wyśrodkowaniu — kotwiczymy do góry + lekko w lewo (profil).
       */
      object-position: 24% 18%;
      transform: translate3d(0, var(--img-parallax-y, 0px), 0) scale(1.04);
      transform-origin: 24% 18%;
      transition: none;
      will-change: transform;
    }

    html.podwiatr-motion-on .editorial-local:hover .editorial-local__img {
      /* Bez efektu "zoom on hover" - obraz ma pozostac statyczny przy najechaniu. */
      transform: translate3d(0, var(--img-parallax-y, 0px), 0) scale(1.04);
      transition: none;
    }

    .editorial-local__grain {
      pointer-events: none;
      position: absolute;
      inset: 0;
      opacity: 0.06;
      background-image: var(--bg-noise-svg);
      mix-blend-mode: overlay;
    }

    /* Jak pasek pod hero: trust-strip--lux + chipy + linia z kropką */
    .editorial-local__trust {
      flex-shrink: 0;
      width: 100%;
    }

    @media (max-width: 600px) {
      .editorial-local__img {
        /* Wąski ekran — inny stosunek boków; nadal trzymaj górę kadru z twarzą */
        object-position: 22% 26%;
        transform-origin: 22% 26%;
      }
    }

    @media (prefers-reduced-motion: reduce) {
      .editorial-comfort__img,
      .editorial-local__img {
        --img-parallax-y: 0px !important;
        transform: none !important;
        transition: none !important;
        will-change: auto;
      }
    }

    html.podwiatr-reduced-motion .editorial-comfort__figure:hover .editorial-comfort__img,
    html.podwiatr-reduced-motion .editorial-local:hover .editorial-local__img {
      transform: none;
    }

    .services-section {
      padding: var(--section-pad-y) 0;
      overflow: hidden;
      border-top: 1px solid rgba(255, 255, 255, 0.05);
      content-visibility: auto;
      contain-intrinsic-size: auto 1400px;
      background:
        radial-gradient(ellipse 70% 55% at 80% 0%, rgba(126, 160, 216, 0.07), transparent 52%),
        radial-gradient(ellipse 55% 45% at 12% 80%, rgba(230, 125, 65, 0.06), transparent 55%);
    }

    /* „Rzeki” pod siatką usług — ten sam układ co w portfolio-showcase, bez drugiej sekcji */
    .services-section .services-section__rivers {
      margin-top: clamp(28px, 4vw, var(--section-block-gap));
    }

    .services-section .services-section__head.section-head {
      flex-direction: column;
      align-items: center;
      text-align: center;
      gap: 0;
    }

    .services-section__title,
    .why-section__title,
    .testimonials-section__title,
    .contact-premium__title {
      font-family: var(--font-sans);
      font-weight: var(--font-weight-heading);
      font-size: var(--text-section);
      letter-spacing: -0.02em;
      line-height: 1.08;
      margin: 0 0 12px;
      color: #f4f7fd;
    }

    .services-section__sub {
      max-width: 62ch;
      margin-left: auto;
      margin-right: auto;
    }

    .services-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(min(100%, 300px), 1fr));
      gap: clamp(18px, 3vw, 26px);
      margin-top: clamp(40px, 5.5vw, 56px);
    }

    .services-grid__also-heading {
      grid-column: 1 / -1;
      margin: clamp(10px, 2.5vw, 18px) 0 2px;
      padding: 0 2px;
    }

    .services-grid__also-title {
      margin: 0;
      font-size: var(--text-ui-sm);
      font-weight: var(--font-weight-ui);
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: rgba(170, 192, 228, 0.88);
    }

    /* Domyślnie wężej: 3 filary; od „sm” — 3 filary + 3 kafle pod „Również”; pełna lista po „Zobacz więcej”.
       W siatce jest pełnoszeroki wiersz nagłówka (child 4) — liczenie nth-child uwzględnia go przy ukrywaniu. */
    .services-grid-wrap--collapsible:not(.is-expanded) .services-grid .service-card:nth-child(n + 4) {
      display: none;
    }

    @media (max-width: 639px) {
      .services-grid-wrap--collapsible:not(.is-expanded) .services-grid__also-heading {
        display: none;
      }
    }

    @media (min-width: 640px) {
      .services-grid-wrap--collapsible:not(.is-expanded) .services-grid .service-card:nth-child(n + 4) {
        display: flex;
      }

      .services-grid-wrap--collapsible:not(.is-expanded) .services-grid .service-card:nth-child(n + 8) {
        display: none;
      }
    }

    .services-grid-wrap--collapsible.is-expanded + .services-grid-expand {
      display: none;
    }

    .services-grid-expand {
      display: flex;
      justify-content: center;
      margin-top: clamp(22px, 4vw, 36px);
    }

    .services-grid-expand__btn {
      max-width: 100%;
    }

    .service-card {
      display: flex;
      flex-direction: column;
      border-radius: var(--radius-lg);
      overflow: hidden;
      border: 1px solid rgba(255, 255, 255, 0.08);
      background: rgba(7, 16, 28, 0.55);
      box-shadow: 0 18px 48px rgba(0, 0, 0, 0.28);
      transition:
        border-color 0.35s ease,
        transform 0.35s ease,
        box-shadow 0.35s ease;
    }

    /* Sekcja Oferta — ostre kąty, większy obszar zdjęcia niż domyślne 4:3 */
    .services-section .service-card {
      border-radius: 0;
    }

    .services-section .service-card__visual {
      aspect-ratio: 1 / 1;
    }

    .service-card:hover {
      border-color: rgba(126, 160, 216, 0.28);
      transform: translateY(-3px);
      box-shadow: 0 22px 56px rgba(0, 0, 0, 0.34), 0 0 0 1px rgba(126, 160, 216, 0.12);
    }

    .service-card.service-card--pillar {
      border-color: rgba(126, 160, 216, 0.22);
      box-shadow:
        0 18px 48px rgba(0, 0, 0, 0.28),
        inset 0 0 0 1px rgba(126, 160, 216, 0.09);
    }

    .service-card.service-card--pillar:hover {
      border-color: rgba(146, 178, 228, 0.38);
      box-shadow:
        0 22px 56px rgba(0, 0, 0, 0.34),
        inset 0 0 0 1px rgba(126, 160, 216, 0.14),
        0 0 0 1px rgba(126, 160, 216, 0.12);
    }

    .service-card.service-card--also {
      opacity: 0.97;
    }

    .service-card__visual {
      display: block;
      aspect-ratio: 4 / 3;
      overflow: hidden;
      background: rgba(255, 255, 255, 0.04);
    }

    .service-card__visual img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
      filter: saturate(0.96) brightness(0.93);
      transition:
        transform 0.55s ease,
        filter 0.45s ease;
    }

    .service-card:hover .service-card__visual img {
      transform: scale(1.04);
      filter: saturate(1.02) brightness(0.98);
    }

    .service-card__body {
      padding: 18px 20px 20px;
      display: flex;
      flex-direction: column;
      gap: 10px;
      flex: 1;
    }

    .service-card__title {
      margin: 0;
      font-size: var(--text-card-title);
      font-weight: var(--font-weight-title-sm);
      color: #eef3fb;
      letter-spacing: -0.01em;
    }

    .service-card__desc {
      margin: 0;
      flex: 1;
      font-size: var(--text-body-sm);
      line-height: 1.55;
      color: rgba(200, 214, 235, 0.9);
    }

    .service-card__cta {
      align-self: flex-start;
      margin-top: 4px;
      font-size: var(--text-ui-sm);
      font-weight: var(--font-weight-ui);
      letter-spacing: 0.06em;
      text-transform: uppercase;
      color: rgba(180, 205, 255, 0.98);
      text-decoration: none;
      border-bottom: 1px solid rgba(126, 160, 216, 0.35);
      padding-bottom: 2px;
      transition: color 0.25s ease, border-color 0.25s ease;
    }

    .service-card__cta:hover {
      color: #fff;
      border-color: rgba(200, 220, 255, 0.65);
    }

    .services-section__cta {
      margin-top: clamp(36px, 5vw, 48px);
      gap: 14px;
    }

    .why-section {
      padding: var(--section-pad-y) 0;
      border-top: 1px solid rgba(255, 255, 255, 0.06);
      content-visibility: auto;
      contain-intrinsic-size: auto 700px;
      background:
        radial-gradient(ellipse 65% 50% at 18% 0%, rgba(126, 160, 216, 0.07), transparent 55%),
        radial-gradient(ellipse 55% 42% at 88% 100%, rgba(230, 125, 65, 0.05), transparent 52%);
    }

    /* Lista korzyści (skanowalna, jedna kolumna — NN/g: spójna hierarchia, krótkie akapity) */
    .why-list {
      list-style: none;
      margin: var(--section-head-spacing) auto 0;
      padding: 0;
      max-width: 38rem;
    }

    .why-item {
      display: flex;
      gap: clamp(16px, 3.5vw, 24px);
      padding: clamp(18px, 3vw, 22px) 0;
      border-bottom: 1px solid rgba(255, 255, 255, 0.08);
      align-items: flex-start;
    }

    .why-item:first-child {
      padding-top: 0;
    }

    .why-item:last-child {
      border-bottom: none;
      padding-bottom: 0;
    }

    .why-item__index {
      flex: 0 0 auto;
      width: 2.5rem;
      font-family: var(--font-sans);
      font-size: var(--text-caption);
      font-weight: var(--font-weight-ui);
      letter-spacing: 0.12em;
      line-height: 1.4;
      color: rgba(126, 160, 216, 0.95);
      padding-top: 0.2em;
    }

    .why-item__body {
      flex: 1;
      min-width: 0;
    }

    .why-item__title {
      margin: 0 0 8px;
      font-size: var(--text-title);
      font-weight: var(--font-weight-ui);
      line-height: var(--leading-snug);
      color: #f4f7fd;
      letter-spacing: -0.01em;
    }

    .why-item__text {
      margin: 0;
      font-size: var(--text-body-sm);
      line-height: var(--leading-relaxed);
      color: rgba(195, 210, 232, 0.92);
      max-width: 52ch;
    }

    .testimonials-section {
      padding: var(--section-pad-y) 0;
      border-top: 1px solid rgba(255, 255, 255, 0.06);
      content-visibility: auto;
      contain-intrinsic-size: auto 480px;
    }

    .testimonials-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(min(100%, 300px), 1fr));
      gap: 18px;
      margin-top: var(--section-head-spacing);
    }

    .testimonial-card {
      margin: 0;
      padding: 22px 24px;
      border-radius: 0;
      border: 1px solid rgba(255, 255, 255, 0.08);
      background: rgba(10, 22, 38, 0.65);
      box-shadow: 0 14px 36px rgba(0, 0, 0, 0.26);
    }

    .testimonial-card__quote {
      margin: 0;
      font-size: var(--text-body-sm);
      line-height: 1.55;
      color: rgba(228, 236, 252, 0.94);
      font-style: italic;
    }

    .testimonial-card__quote p {
      margin: 0;
    }

    .testimonial-card__meta {
      display: flex;
      flex-direction: column;
      align-items: flex-start;
      gap: 6px;
      margin-top: 14px;
    }

    .testimonial-card__who {
      font-size: var(--text-body-sm);
      font-weight: var(--font-weight-ui);
      letter-spacing: 0.02em;
      text-transform: none;
      color: rgba(228, 236, 252, 0.94);
    }

    .testimonial-card__detail {
      font-size: var(--text-small);
      letter-spacing: 0.06em;
      text-transform: uppercase;
      color: rgba(160, 178, 208, 0.85);
    }

    .contact-premium {
      padding: clamp(72px, 10vw, 110px) 0 clamp(96px, 12vw, 120px);
      border-top: 1px solid rgba(255, 255, 255, 0.06);
      content-visibility: auto;
      contain-intrinsic-size: auto 720px;
      background:
        radial-gradient(ellipse 70% 55% at 80% 0%, rgba(126, 160, 216, 0.09), transparent 52%),
        radial-gradient(ellipse 60% 50% at 12% 85%, rgba(230, 125, 65, 0.06), transparent 55%),
        radial-gradient(ellipse 90% 70% at 50% 120%, rgba(95, 120, 182, 0.08), transparent 50%),
        linear-gradient(180deg, rgba(5, 11, 19, 0.98) 0%, var(--bg-base) 72%, #050a12 100%);
    }

    .contact-premium__inner {
      max-width: 720px;
      margin: 0 auto;
      text-align: center;
    }

    .contact-premium__lead {
      font-size: var(--text-lead);
      line-height: 1.55;
      color: rgba(210, 222, 242, 0.94);
      margin: 0 0 12px;
    }

    .contact-premium__note {
      margin: 0 0 28px;
      font-size: var(--text-body-sm);
      color: rgba(175, 192, 222, 0.88);
      line-height: 1.5;
    }

    .contact-premium__channels {
      display: flex;
      flex-direction: column;
      gap: 12px;
      align-items: stretch;
    }

    .contact-channel {
      display: flex;
      align-items: center;
      justify-content: center;
      min-height: 54px;
      padding: 0 22px;
      border-radius: 0;
      font-weight: var(--font-weight-ui);
      font-size: var(--text-ui);
      text-decoration: none;
      border: 1px solid rgba(255, 255, 255, 0.12);
      background: rgba(255, 255, 255, 0.04);
      color: #f4f7fd;
      transition:
        background 0.3s ease,
        border-color 0.3s ease,
        transform 0.25s ease;
      backdrop-filter: blur(14px);
      -webkit-backdrop-filter: blur(14px);
    }

    .contact-channel:hover {
      background: rgba(255, 255, 255, 0.08);
      border-color: rgba(126, 160, 216, 0.35);
      transform: translateY(-2px);
    }

    .contact-channel--whatsapp {
      background: linear-gradient(135deg, rgba(255, 255, 255, 0.12), rgba(126, 160, 216, 0.38));
      border-color: rgba(255, 255, 255, 0.18);
    }

    .contact-channel__sub {
      margin-left: 8px;
      font-size: var(--text-body-sm);
      font-weight: var(--font-weight-body);
      opacity: 0.85;
    }

    .contact-dock {
      position: fixed;
      right: max(16px, env(safe-area-inset-right, 0px));
      bottom: max(22px, env(safe-area-inset-bottom, 0px));
      z-index: 60;
      opacity: 0;
      visibility: hidden;
      transform: translateY(14px);
      transition:
        opacity 0.45s ease,
        transform 0.5s cubic-bezier(0.22, 1, 0.36, 1),
        visibility 0.45s;
      pointer-events: none;
    }

    .contact-dock.contact-dock--visible {
      opacity: 1;
      visibility: visible;
      transform: translateY(0);
      pointer-events: auto;
    }

    .contact-dock__inner {
      display: flex;
      align-items: center;
      gap: 10px;
      padding: 10px 12px;
      border-radius: 999px;
      border: 1px solid rgba(126, 160, 216, 0.45);
      background:
        linear-gradient(
          152deg,
          rgba(255, 255, 255, 0.98) 0%,
          rgba(244, 248, 255, 0.95) 38%,
          rgba(228, 236, 252, 0.97) 100%
        );
      box-shadow:
        0 14px 42px rgba(12, 32, 58, 0.2),
        0 2px 14px rgba(126, 160, 216, 0.18),
        inset 0 1px 0 rgba(255, 255, 255, 0.9);
      backdrop-filter: blur(20px) saturate(1.1);
      -webkit-backdrop-filter: blur(20px) saturate(1.1);
    }

    .contact-dock__btn {
      width: 46px;
      height: 46px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      color: #1a2d4a;
      border: 1px solid rgba(95, 120, 182, 0.38);
      background: rgba(255, 255, 255, 0.78);
      transition:
        background 0.28s ease,
        border-color 0.28s ease,
        color 0.28s ease,
        transform 0.22s ease;
    }

    .contact-dock__btn:hover {
      background: rgba(220, 232, 255, 0.95);
      border-color: rgba(95, 120, 182, 0.58);
      color: #0f1a2c;
      transform: translateY(-2px);
    }

    .contact-dock__btn--wa {
      background: linear-gradient(145deg, rgba(210, 224, 255, 0.98), rgba(155, 185, 235, 0.9));
      border-color: rgba(95, 120, 182, 0.48);
      color: #15263d;
    }

    .contact-dock__icon {
      width: 22px;
      height: 22px;
      display: block;
    }

    .contact-mobile-bar {
      display: none;
      position: fixed;
      left: 0;
      right: 0;
      bottom: 0;
      /* Nad treścią i stopką; pod drawerem nawigacji (z-index 95) i backdropem */
      z-index: 88;
      box-sizing: border-box;
      width: 100%;
      max-width: 100%;
      min-width: 0;
      padding: 8px max(10px, env(safe-area-inset-left, 0px)) max(10px, env(safe-area-inset-bottom, 0px))
        max(10px, env(safe-area-inset-right, 0px));
      gap: clamp(8px, 3.5vw, 14px);
      flex-direction: row;
      flex-wrap: nowrap;
      align-items: center;
      justify-content: center;
      border-top: 1px solid rgba(255, 255, 255, 0.06);
      background:
        linear-gradient(180deg, transparent 0%, rgba(7, 16, 28, 0.55) 22%, rgba(5, 10, 18, 0.94) 100%),
        radial-gradient(ellipse 120% 90% at 50% 100%, rgba(126, 160, 216, 0.1), transparent 62%),
        radial-gradient(ellipse 80% 60% at 20% 100%, rgba(230, 125, 65, 0.05), transparent 55%);
      backdrop-filter: blur(16px) saturate(1.1);
      -webkit-backdrop-filter: blur(16px) saturate(1.1);
      -webkit-tap-highlight-color: transparent;
    }

    .contact-mobile-bar__slot {
      flex: 0 0 auto;
      display: flex;
      min-width: 0;
      justify-content: center;
    }

    .contact-mobile-bar__slot[hidden] {
      display: none;
    }

    .contact-mobile-bar__btn {
      box-sizing: border-box;
      flex: 0 0 auto;
      width: 44px;
      height: 44px;
      min-width: 44px;
      min-height: 44px;
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 0;
      border-radius: 50%;
      text-decoration: none;
      color: rgba(236, 241, 252, 0.96);
      border: 1px solid rgba(255, 255, 255, 0.12);
      background: rgba(12, 22, 38, 0.72);
      touch-action: manipulation;
      transition:
        background 0.25s ease,
        border-color 0.25s ease,
        transform 0.2s ease;
    }

    .contact-mobile-bar__icon {
      width: 22px;
      height: 22px;
      display: block;
      flex-shrink: 0;
    }

    .contact-mobile-bar__btn:active {
      transform: scale(0.98);
    }

    .contact-mobile-bar__btn--wa {
      background: linear-gradient(135deg, rgba(126, 160, 216, 0.35), rgba(95, 120, 182, 0.42));
      border-color: rgba(255, 255, 255, 0.2);
    }

    .contact-mobile-bar__btn--ig {
      border-color: rgba(126, 160, 216, 0.28);
    }

    @media (min-width: 901px) {
      .contact-mobile-bar {
        display: none !important;
      }
    }

    @media (max-width: 900px) {
      .contact-dock {
        display: none !important;
      }

      .contact-mobile-bar {
        display: flex;
      }

      /* Miejsce na pasek (ikony w kółkach) + safe area — treść nie wchodzi pod bar */
      body.has-contact-dock {
        padding-bottom: calc(18px + 44px + max(12px, env(safe-area-inset-bottom, 0px)));
      }

      /* Otwarte menu: pasek chowamy, żeby nie kolidował z drawerem */
      .site-header.is-menu-open ~ .contact-mobile-bar {
        visibility: hidden;
        pointer-events: none;
        opacity: 0;
        transition:
          opacity 0.2s ease,
          visibility 0.2s ease;
      }

      /* Tylko html — overflow-x na body potrafi złamać sticky header (nested overflow). */
      html {
        overflow-x: hidden;
      }
    }

    /* Galeria: większy rytm i „premium” kadrowanie karuzeli */
    .gallery-page {
      --marquee-gap: clamp(20px, 3vw, 32px);
    }

    .gallery-page .portrait-marquee__slide img {
      filter: brightness(0.92) saturate(0.98);
    }

    .gallery-page .portrait-marquee__slide:hover img {
      transform: none;
      filter: brightness(0.97) saturate(1.02);
    }

    .gallery-page .portrait-marquee__stage {
      width: min(calc(100% - 24px), var(--container));
    }

    @media (prefers-reduced-motion: reduce) {
      .contact-dock {
        transition: none;
      }

      .contact-dock.contact-dock--visible {
        transition: none;
      }

      .service-card:hover {
        transform: none;
      }
    }

    @media print {
      .portfolio-showcase,
      .editorial-comfort,
      .editorial-local,
      .services-section,
      .why-section,
      .process-section,
      .testimonials-section,
      .faq-section,
      .contact-premium {
        content-visibility: visible;
      }
    }

    /* Strona główna (index): ostre krawędzie na przyciskach i chrome nagłówka/stópki — inne podstrony bez zmian */
    .page-home .home-hero-btn,
    .page-home .button {
      border-radius: 0;
    }

    .page-home .brand-mark {
      border-radius: 0;
    }

    .page-home .nav__social-link {
      border-radius: 0;
    }

    .page-home .nav-toggle {
      border-radius: 0;
    }

    .page-home .nav-cta {
      border-radius: 0;
    }

    .page-home .nav-cta--whatsapp-icon {
      border-radius: 0;
    }

    .page-home .footer__social-link {
      border-radius: 0;
    }

    .seo-landing {
      min-height: 100vh;
    }

    /*
     * Landingi SEO: na szerokim ekranie prostszy układ rzędu linków.
     * Reguły tylko od 821px — poniżej tego progu obowiązuje ten sam drawer co na stronie głównej
     * (wcześniej position:static na .nav psuło menu mobilne).
     */
    @media (min-width: 821px) {
      /* Ten sam model co index: flex-start + środek rośnie (flex:1), .site-header__trailing z margin-left:auto trzyma prawą stronę. */
      .seo-landing .site-header__inner {
        min-height: 78px;
        justify-content: flex-start;
        gap: 14px 18px;
      }

      .seo-landing .brand {
        flex: 0 1 auto;
      }

      .seo-landing .nav {
        order: 2;
        flex: 1 1 auto;
        min-width: 0;
        justify-content: flex-end;
        gap: clamp(12px, 2vw, 20px);
        position: static;
        transform: none;
        width: auto;
        padding: 0;
        border: 0;
        box-shadow: none;
        background: transparent;
        overflow: visible;
      }

      .seo-landing .nav a {
        padding: 0;
        border: 0;
        white-space: nowrap;
      }
    }

    .seo-service-page {
      position: relative;
      background:
        radial-gradient(67% 54% at 10% 10%, rgba(92, 129, 183, 0.24) 0%, rgba(92, 129, 183, 0.1) 42%, transparent 86%),
        radial-gradient(64% 51% at 88% 86%, rgba(205, 140, 82, 0.2) 0%, rgba(205, 140, 82, 0.08) 40%, transparent 86%),
        #131418;
      color: #f1ede7;
    }

    .seo-service-page::before {
      content: "";
      position: fixed;
      inset: -24vh -20vw;
      pointer-events: none;
      z-index: -1;
      background:
        radial-gradient(93% 74% at 12% 8%, rgba(88, 122, 171, 0.16), transparent 86%),
        radial-gradient(83% 74% at 88% 90%, rgba(198, 138, 78, 0.14), transparent 86%);
      opacity: 0.9;
    }

    .seo-service-page .site-header {
      background: rgba(19, 20, 24, 0.78);
      border-bottom-color: rgba(255, 255, 255, 0.1);
      backdrop-filter: blur(6px);
      -webkit-backdrop-filter: blur(6px);
    }

    /* Na wąskim ekranie wyłączamy blur na headerze — inaczej (jak na index) psuje się drawer .nav (fixed w WebKit). */
    @media (max-width: 820px) {
      .seo-service-page .site-header {
        backdrop-filter: none;
        -webkit-backdrop-filter: none;
      }
    }

    .seo-service-page .nav a,
    .seo-service-page .brand-copy span {
      color: rgba(241, 237, 231, 0.9);
    }

    .seo-service-page .button--secondary.button--glass {
      border-color: rgba(255, 255, 255, 0.22);
      background: rgba(255, 255, 255, 0.05);
      color: rgba(245, 241, 235, 0.94);
    }

    .seo-service-hero {
      padding: clamp(34px, 7vw, 94px) 0 clamp(30px, 6vw, 72px);
    }

    .seo-service-hero__grid {
      display: grid;
      grid-template-columns: minmax(0, 1fr) minmax(320px, 0.88fr);
      gap: clamp(24px, 4vw, 64px);
      align-items: center;
    }

    .seo-service-hero__eyebrow {
      margin: 0 0 14px;
      text-transform: uppercase;
      letter-spacing: 0.14em;
      font-size: var(--text-caption);
      color: rgba(211, 197, 176, 0.9);
    }

    .seo-service-hero h1 {
      margin: 0;
      font-size: clamp(2.25rem, 6.2vw, 5rem);
      line-height: 0.96;
      letter-spacing: -0.03em;
      color: #f8f3ec;
      max-width: 12ch;
    }

    .seo-service-hero__lead {
      margin: clamp(18px, 2.8vw, 28px) 0 0;
      max-width: 52ch;
      color: rgba(234, 228, 219, 0.85);
      font-size: clamp(1rem, 1.6vw, 1.12rem);
      line-height: 1.78;
    }

    .seo-service-hero__actions {
      margin-top: clamp(20px, 3.4vw, 36px);
      display: flex;
      flex-wrap: wrap;
      gap: 10px 12px;
    }

    .seo-service-hero__badge {
      margin-top: clamp(18px, 3vw, 30px);
      display: inline-flex;
      align-items: center;
      min-height: 36px;
      padding: 7px 14px;
      border: 1px solid rgba(228, 218, 202, 0.24);
      background: rgba(236, 226, 210, 0.08);
      color: rgba(244, 237, 228, 0.92);
      font-size: var(--text-caption);
      letter-spacing: 0.1em;
      text-transform: uppercase;
    }

    .seo-service-hero__media {
      margin: 0;
      justify-self: end;
      width: min(100%, 600px);
      aspect-ratio: 4 / 5;
      min-height: clamp(360px, 54vw, 760px);
      overflow: hidden;
      border: 1px solid rgba(240, 230, 216, 0.18);
      box-shadow: 0 26px 70px rgba(0, 0, 0, 0.42);
      transform: translateY(clamp(0px, 1vw, 8px));
    }

    .seo-service-hero__media img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: 50% 28%;
      display: block;
    }

    .seo-service-emotion {
      padding: clamp(56px, 9vw, 132px) 0;
    }

    .seo-service-emotion h2 {
      margin: 0;
      max-width: 10.5ch;
      font-size: clamp(2rem, 7vw, 5.5rem);
      line-height: 0.95;
      letter-spacing: -0.035em;
      color: #faf5ee;
    }

    .seo-service-emotion p {
      margin: clamp(22px, 3vw, 34px) 0 0;
      max-width: 56ch;
      color: rgba(231, 223, 213, 0.84);
      font-size: clamp(1rem, 1.4vw, 1.08rem);
      line-height: 1.82;
    }

    .seo-service-curated {
      padding: clamp(12px, 2vw, 28px) 0 clamp(58px, 8vw, 118px);
    }

    .seo-service-curated h2,
    .seo-service-forwho h2,
    .seo-service-process h2,
    .seo-service-faq h2 {
      margin: 0 0 clamp(18px, 2.8vw, 28px);
      font-size: clamp(1.35rem, 2.2vw, 2rem);
      letter-spacing: -0.01em;
      color: #f5f0e8;
    }

    .seo-service-curated__grid {
      display: grid;
      grid-template-columns: minmax(0, 1.3fr) minmax(0, 0.7fr);
      grid-template-areas:
        "large smallA"
        "large smallB"
        "vert vert";
      gap: clamp(12px, 1.8vw, 20px);
    }

    .seo-service-curated__item {
      margin: 0;
      border: 1px solid rgba(255, 255, 255, 0.14);
      overflow: hidden;
      min-height: 200px;
      background: rgba(255, 255, 255, 0.02);
    }

    .seo-service-curated__item img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: 50% 36%;
      display: block;
      transform: scale(1.001);
      transition: transform 0.6s ease, opacity 0.45s ease;
    }

    .seo-service-curated__item:hover img {
      transform: scale(1.05);
      opacity: 0.96;
    }

    .seo-service-curated__item--large {
      grid-area: large;
      min-height: clamp(360px, 44vw, 620px);
    }

    .seo-service-curated__item--small-a {
      grid-area: smallA;
      min-height: clamp(178px, 21vw, 295px);
    }

    .seo-service-curated__item--small-b {
      grid-area: smallB;
      min-height: clamp(178px, 21vw, 295px);
    }

    .seo-service-curated__item--vertical {
      grid-area: vert;
      justify-self: end;
      width: min(100%, 360px);
      min-height: clamp(300px, 38vw, 560px);
    }

    .seo-service-curated__item--large img {
      object-position: 50% 30%;
    }

    .seo-service-curated__item--small-a img {
      object-position: 50% 24%;
    }

    .seo-service-curated__item--small-b img {
      object-position: 50% 26%;
    }

    .seo-service-curated__item--vertical img {
      object-position: 50% 20%;
    }

    .seo-service-forwho {
      padding: clamp(18px, 2.5vw, 36px) 0 clamp(58px, 8vw, 112px);
    }

    .seo-service-forwho__list {
      margin: 0;
      padding: 0;
      list-style: none;
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 12px;
    }

    .seo-service-forwho__list li {
      padding: clamp(16px, 2.2vw, 22px);
      border: 1px solid rgba(255, 255, 255, 0.13);
      background: rgba(241, 229, 213, 0.03);
      color: rgba(236, 228, 217, 0.88);
      line-height: 1.72;
    }

    .seo-service-process {
      padding: clamp(16px, 2.8vw, 40px) 0 clamp(60px, 8vw, 116px);
    }

    .seo-service-process__list {
      margin: 0;
      padding: 0;
      list-style: none;
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: clamp(14px, 2vw, 18px);
    }

    .seo-service-process__list li {
      position: relative;
      min-height: 184px;
      padding: 24px 20px 20px;
      border: 1px solid rgba(255, 255, 255, 0.11);
      background: rgba(248, 240, 230, 0.02);
      overflow: hidden;
      isolation: isolate;
    }

    .seo-service-process__num {
      position: absolute;
      right: 10px;
      top: -16px;
      z-index: -1;
      font-size: clamp(3rem, 8vw, 6.2rem);
      line-height: 1;
      color: rgba(255, 255, 255, 0.06);
      font-weight: 300;
      letter-spacing: -0.03em;
    }

    .seo-service-process h3 {
      margin: 0;
      font-size: clamp(1.1rem, 1.8vw, 1.35rem);
      font-weight: 500;
      color: #f5efe7;
    }

    .seo-service-process p {
      margin: 12px 0 0;
      color: rgba(229, 220, 209, 0.82);
      line-height: 1.76;
    }

    .seo-service-testimonial {
      min-height: clamp(44vh, 54vh, 66vh);
      display: grid;
      align-items: center;
      padding: clamp(52px, 10vw, 130px) 0;
      background: linear-gradient(180deg, rgba(18, 19, 23, 0.78), rgba(11, 12, 16, 0.96));
      border-top: 1px solid rgba(255, 255, 255, 0.08);
      border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    }

    .seo-service-testimonial blockquote {
      margin: 0;
      max-width: 26ch;
      font-size: clamp(1.5rem, 4.1vw, 3.3rem);
      line-height: 1.18;
      letter-spacing: -0.025em;
      color: rgba(250, 245, 238, 0.96);
    }

    .seo-service-faq {
      padding: clamp(58px, 8vw, 110px) 0;
    }

    .seo-service-faq details {
      border-top: 1px solid rgba(255, 255, 255, 0.18);
      padding: 14px 0;
    }

    .seo-service-faq details:last-child {
      border-bottom: 1px solid rgba(255, 255, 255, 0.18);
    }

    .seo-service-faq summary {
      cursor: pointer;
      list-style: none;
      font-size: clamp(1rem, 1.45vw, 1.1rem);
      letter-spacing: 0.01em;
      color: rgba(244, 237, 227, 0.96);
      padding-right: 20px;
    }

    .seo-service-faq summary::-webkit-details-marker {
      display: none;
    }

    .seo-service-faq p {
      margin: 10px 0 0;
      max-width: 62ch;
      color: rgba(229, 221, 210, 0.84);
      line-height: 1.72;
    }

    .seo-service-final-cta {
      position: relative;
      min-height: clamp(52vh, 62vh, 76vh);
      display: grid;
      align-items: center;
      overflow: hidden;
    }

    .seo-service-final-cta__bg,
    .seo-service-final-cta__bg::after {
      position: absolute;
      inset: 0;
    }

    .seo-service-final-cta__bg img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: var(--seo-cta-focus, 50% 22%);
      display: block;
    }

    .seo-service-final-cta__bg::after {
      content: "";
      background: linear-gradient(180deg, rgba(12, 13, 16, 0.62), rgba(7, 8, 10, 0.9));
    }

    .seo-service-final-cta__content {
      position: relative;
      z-index: 1;
      padding: clamp(44px, 8vw, 100px) 0;
    }

    .seo-service-final-cta h2 {
      margin: 0;
      max-width: 17ch;
      font-size: clamp(1.6rem, 4.4vw, 3.4rem);
      line-height: 1.08;
      letter-spacing: -0.024em;
      color: #faf5ed;
    }

    .seo-service-final-cta__actions {
      margin-top: clamp(20px, 3vw, 34px);
      display: flex;
      flex-wrap: wrap;
      gap: 10px 12px;
    }

    @media (max-width: 980px) {
      .seo-service-hero__grid {
        grid-template-columns: 1fr;
      }

      .seo-service-hero__media {
        justify-self: stretch;
        width: 100%;
        max-width: 720px;
        aspect-ratio: 5 / 4;
        min-height: clamp(320px, 66vw, 620px);
      }

      .seo-service-hero__media img {
        object-position: 50% 24%;
      }

      .seo-service-curated__grid {
        grid-template-columns: 1fr 1fr;
        grid-template-areas:
          "large large"
          "smallA smallB"
          "vert vert";
      }

      .seo-service-curated__item--vertical {
        justify-self: start;
      }
    }

    @media (max-width: 760px) {
      .seo-service-hero {
        padding-top: 18px;
      }

      .seo-service-hero h1 {
        max-width: 100%;
      }

      .seo-service-hero__media {
        aspect-ratio: 1 / 1;
        min-height: clamp(280px, 88vw, 520px);
      }

      .seo-service-hero__media img {
        object-position: 50% 20%;
      }

      .seo-service-curated__grid {
        grid-template-columns: 1fr;
        grid-template-areas:
          "large"
          "smallA"
          "smallB"
          "vert";
      }

      .seo-service-curated__item--large,
      .seo-service-curated__item--small-a,
      .seo-service-curated__item--small-b,
      .seo-service-curated__item--vertical {
        width: 100%;
        min-height: 0;
        aspect-ratio: 4 / 5;
      }

      .seo-service-curated__item--vertical {
        justify-self: stretch;
      }

      .seo-service-forwho__list,
      .seo-service-process__list {
        grid-template-columns: 1fr;
      }

      .seo-service-testimonial blockquote {
        max-width: 100%;
      }

      .seo-service-final-cta {
        min-height: 60vh;
      }
    }

    @media (min-width: 1440px) {
      .seo-service-hero__media {
        width: min(100%, 680px);
        aspect-ratio: 3 / 4;
        min-height: clamp(520px, 42vw, 860px);
      }

      .seo-service-hero__media img {
        object-position: 50% 26%;
      }
    }

    /* Polityka prywatności — cicha, czytelna kolumna editorial */
    .page-legal {
      min-height: 100vh;
      background:
        radial-gradient(68% 42% at 10% 0%, rgba(92, 129, 183, 0.1) 0%, transparent 52%),
        radial-gradient(50% 36% at 92% 8%, rgba(126, 160, 216, 0.06) 0%, transparent 48%),
        #070d16;
    }

    .legal-page {
      padding: clamp(44px, 9vw, 100px) 0 clamp(72px, 12vw, 120px);
    }

    .legal-page__wrap {
      max-width: 38rem;
      margin: 0 auto;
    }

    .legal-page__eyebrow {
      margin: 0 0 10px;
      font-size: var(--text-caption);
      letter-spacing: 0.18em;
      text-transform: uppercase;
      color: rgba(216, 226, 242, 0.42);
      font-weight: var(--font-weight-ui);
    }

    .legal-page__title {
      margin: 0 0 clamp(18px, 2.8vw, 26px);
      font-size: clamp(1.65rem, 3.6vw, 2.2rem);
      font-weight: 500;
      letter-spacing: -0.025em;
      line-height: 1.1;
      color: #f2f6fd;
    }

    .legal-page__lead {
      margin: 0 0 clamp(36px, 5.5vw, 52px);
      font-size: var(--text-body);
      line-height: 1.72;
      color: rgba(216, 226, 242, 0.78);
    }

    .legal-page__section {
      margin-top: clamp(24px, 3.5vw, 32px);
      padding-top: clamp(20px, 3vw, 28px);
      border-top: 1px solid rgba(255, 255, 255, 0.055);
    }

    .legal-page__section h2 {
      margin: 0 0 10px;
      font-size: var(--text-ui);
      font-weight: var(--font-weight-ui);
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: rgba(232, 240, 252, 0.86);
    }

    .legal-page__section p {
      margin: 0;
      font-size: var(--text-body-sm);
      line-height: 1.78;
      color: rgba(198, 208, 226, 0.76);
    }

    .legal-page__section p + p {
      margin-top: 0.75em;
    }

    .legal-page__footnote {
      margin-top: clamp(32px, 5vw, 44px);
      font-size: var(--text-caption);
      line-height: 1.55;
      color: rgba(178, 191, 211, 0.5);
      letter-spacing: 0.03em;
    }

    .footer__nav-link--legal {
      opacity: 0.76;
    }

    .footer__nav-link--legal:hover {
      opacity: 1;
    }
