/* style.css — pełny (Twoja wersja + fallback :target) */

/* style.css
   =========================================================
   Minimalistyczny styl kliniczny (mobile-first)
   Bez zewnętrznych fontów: system-ui

   Zasady „ultra-higieny”:
   - Jedno źródło prawdy dla tokenów (kolory/odstępy/radiusy)
   - Sekcje komponentów ułożone logicznie (base → layout → components → overrides)
   - Breakpointy na końcu, rosnąco (wyjątek: „mid widths” jako świadomy override)
   - Minimalizacja duplikacji przez zmienne (tam gdzie ma sens)
   ========================================================= */

/* =========================
   0) TOKENS
   ========================= */
:root {
  /* Color system */
  --bg: #F6F4EF;
  --panel: #FFFFFF;

  --text: #141A1A;
  --muted: #4B5756;

  --border: rgba(20, 26, 26, 0.12);
  --shadow: 0 8px 28px rgba(20, 26, 26, 0.08);

  --accent: #0F3B35;
  --accent-2: #0B2C27;

  /* Radii */
  --radius: 16px;
  --radius-sm: 12px;
  --radius-focus: 8px;

  /* Inputs / buttons */
  --radius-input: 14px;
  --radius-pill: 999px;

  /* Focus ring */
  --focus-ring: 3px solid rgba(15, 59, 53, 0.35);
  --focus-offset: 2px;

  /* Layout */
  --max: 1120px;
  --container-pad: 2rem;

  /* Sticky header offset dla przewijania do kotwic (#...) */
  --sticky-offset: 84px;

  /* Spacing scale (używane selektywnie) */
  --s-1: 0.25rem;
  --s-2: 0.5rem;
  --s-3: 0.75rem;
  --s-4: 1rem;
  --s-5: 1.25rem;
  --s-6: 1.5rem;
  --s-7: 2.25rem;

  /* HERO “Najważniejsze w skrócie” (desktop grid) */
  --hq-gutter: 1.1rem;
  --hq-gap: 0.35rem;
  --hq-mingap: 3ch;
  --hq-dot: 0.36em;
  --hq-dot-shift: -0.06em;
  --hq-sep-margin: 0.85rem;

  /* O MNIE — proporcje podane jako WYSOKOŚĆ:SZEROKOŚĆ
     (CSS aspect-ratio = SZEROKOŚĆ / WYSOKOŚĆ) */
  --about-ar-mobile: 4 / 3;       /* 3:4 (H:W) -> 4/3 (W/H) */
  --about-ar-desktop: 28 / 25;    /* 25:28 (H:W) -> 28/25 (W/H) */

  /* O MNIE — easy tweak */
  --about-pos-mobile: 50% 36%;
  --about-pos-desktop: 50% 34%;
}

/* =========================
   1) BASE / RESET
   ========================= */
* { box-sizing: border-box; }

html {
  /* MOMENTARNIE: bez smooth-scroll */
  scroll-behavior: auto;
  scroll-padding-top: var(--sticky-offset);
}

/* Fallback, gdy przeglądarka zrobi natywny skok do #... (bez JS) */
:target { scroll-margin-top: var(--sticky-offset); }

/* Fallback: gdy przeglądarka wykona natywny skok do #... */
section[id], main[id] { scroll-margin-top: var(--sticky-offset); }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}

body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, "Noto Sans", "Liberation Sans", sans-serif;
  line-height: 1.55;
  text-rendering: optimizeLegibility;
}

img { max-width: 100%; height: auto; display: block; }

a {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 0.18em;
}
a:hover { color: var(--accent-2); }

a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible {
  outline: var(--focus-ring);
  outline-offset: var(--focus-offset);
  border-radius: var(--radius-focus);
}

code {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size: 0.95em;
  background: rgba(20, 26, 26, 0.06);
  padding: 0.1em 0.35em;
  border-radius: var(--radius-focus);
}

/* =========================
   2) PRIMITIVES / LAYOUT
   ========================= */
.container {
  width: min(var(--max), calc(100% - var(--container-pad)));
  margin: 0 auto;
}

.divider {
  height: 1px;
  background: var(--border);
  margin: var(--s-4) 0;
}

.small { font-size: 0.98rem; color: var(--muted); }
.micro { font-size: 0.92rem; color: var(--muted); }

.two-col { display: grid; gap: var(--s-4); }
.grid-5 { display: grid; gap: 0.85rem; }

.section { padding: var(--s-7) 0; }
.section.alt {
  background: rgba(255, 255, 255, 0.45);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}

/* Minimalne utility (usuwa inline style z HTML) */
.mt-5 { margin-top: var(--s-5); }

/* Skip link */
.skip-link {
  position: absolute;
  left: -999px;
  top: 0;
  background: var(--panel);
  color: var(--text);
  padding: var(--s-3) var(--s-4);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow);
  z-index: 9999;
}
.skip-link:focus { left: var(--s-4); top: var(--s-4); }

/* =========================
   3) HEADER / BRAND / NAV
   ========================= */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(246, 244, 239, 0.88);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-3);
  padding: 0.85rem 0;
  flex-wrap: nowrap;
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
  text-decoration: none;
  color: var(--text);
}
.brand:hover { color: var(--text); }

/* Logo (SVG) */
.brand.site-brand {
  display: inline-flex;
  align-items: center;
  line-height: 0;
}
.brand.site-brand img.brand-logo {
  display: block;
  height: 72px;
  width: auto;
}

/* Nav (mobile) */
.nav-toggle {
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 44px;
  height: 44px;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: var(--radius-input);
  padding: 0;
  cursor: pointer;
}
.nav-toggle-bar {
  width: 18px;
  height: 2px;
  background: var(--text);
  margin: 0 auto;
  border-radius: 3px;
  opacity: 0.85;
}

.site-nav {
  position: absolute;
  right: 1rem;
  top: 68px;
  width: min(420px, calc(100% - 2rem));
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 0.65rem;
  display: none;
}
.site-nav.is-open { display: block; }

.site-nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.2rem;
}

.site-nav a {
  display: inline-flex;
  width: 100%;
  padding: 0.65rem 0.75rem;
  border-radius: var(--radius-sm);
  text-decoration: none;
  color: var(--text);
}
.site-nav a:hover {
  background: rgba(15, 59, 53, 0.06);
  color: var(--text);
}
.site-nav .nav-cta {
  margin-top: 0.25rem;
  background: rgba(15, 59, 53, 0.08);
  border: 1px solid rgba(15, 59, 53, 0.16);
}

/* NAV: telefon w poziomie (tylko dotyk) -> pokazuj wersję desktopową (bez hamburgera) */
@media (hover: none) and (pointer: coarse) and (orientation: landscape) and (min-width: 720px) and (max-width: 1079px) {
  .nav-toggle { display: none; }

  .site-nav {
    position: static;
    display: block;
    width: auto;
    background: transparent;
    border: none;
    box-shadow: none;
    padding: 0;
  }

  .site-nav ul {
    display: flex;
    gap: .25rem;
    align-items: center;
    flex-wrap: wrap;
    justify-content: flex-end;
  }

  .site-nav a {
    width: auto;
    padding: .45rem .6rem;
    white-space: nowrap;
  }

  .site-nav .nav-cta { background: rgba(15,59,53,.1); }
}

/* =========================
   4) TYPO
   ========================= */
h1 {
  margin: 0 0 0.75rem;
  font-size: clamp(1.55rem, 2.6vw, 2.15rem);
  line-height: 1.2;
  letter-spacing: -0.01em;
}

h2 {
  margin: 0 0 var(--s-4);
  font-size: 1.35rem;
  letter-spacing: -0.01em;
}

.h3 { margin: 0 0 var(--s-2); font-size: 1.05rem; }

/* H1 – hierarchia przez układ */
.hero h1 .h1-main { display: block; }
.hero h1 .h1-sub {
  display: block;
  margin-top: 0.2em;
  font-size: 0.85em;
  font-weight: 600;
  letter-spacing: 0.01em;
}
/* Separator semantyczny (SEO), niewidoczny wizualnie */
.h1-sep { display: none; }

/* =========================
   5) HERO
   ========================= */
.hero { padding: var(--s-7) 0 var(--s-6); }
.hero-grid { display: grid; gap: var(--s-5); }

.hero-right {
  display: grid;
  gap: var(--s-5);
  align-items: start;
}

.kicker {
  margin: -0.15rem 0 0.85rem;
  color: var(--muted);
  font-weight: 600;
}

.lead {
  margin: 0 0 var(--s-4);
  color: var(--muted);
  max-width: 65ch;
}

.pill-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
  margin: var(--s-4) 0 var(--s-1);
}

/* Wymusza nową linię w .pill-row (flex-wrap) */
.pill-break{
  flex: 0 0 100%;
  height: 0;
  margin: .15rem 0 0;
}

.pill {
  font-size: 0.9rem;
  padding: 0.35rem 0.55rem;
  border-radius: var(--radius-pill);
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.55);
  color: rgba(20, 26, 26, 0.92);
}

.pill-accent {
  background: rgba(15, 59, 53, 0.08);
  border-color: rgba(15, 59, 53, 0.18);
}

.cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  align-items: center;
  margin: 1.15rem 0 0.75rem;
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-2);
  padding: 0.7rem 1rem;
  border-radius: var(--radius-pill);
  border: 1px solid var(--border);
  text-decoration: none;
  font-weight: 600;
  font-size: 0.98rem;
  cursor: pointer;
  background: rgba(255, 255, 255, 0.7);
  color: var(--text);
}
.button:hover { background: rgba(255, 255, 255, 0.95); }

.button.primary {
  background: var(--accent);
  border-color: rgba(15, 59, 53, 0.22);
  color: #fff;
}
.button.primary:hover { background: var(--accent-2); }

.button.subtle { background: transparent; }

/* =========================
   6) CARDS / CONTENT BLOCKS
   ========================= */
.card {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: var(--s-4);
  box-shadow: 0 1px 0 rgba(20, 26, 26, 0.03);
}

.card-title {
  margin: 0 0 0.75rem;
  font-size: 1.05rem;
}

.card.soft { background: rgba(255, 255, 255, 0.65); }

.card.highlight {
  background: rgba(15, 59, 53, 0.06);
  border-color: rgba(15, 59, 53, 0.16);
}

.checklist, .bullets {
  margin: var(--s-2) 0 0;
  padding-left: 1.1rem;
}
.checklist li, .bullets li { margin: 0.25rem 0; }

.note {
  margin: var(--s-5) 0 0;
  padding: 0.9rem 1rem;
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.55);
  border: 1px solid var(--border);
  color: rgba(20, 26, 26, 0.9);
}

/* =========================
   7) PHOTO
   ========================= */
.photo-frame {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.55);
  overflow: hidden;
  box-shadow: 0 1px 0 rgba(20, 26, 26, 0.03);
}

/* HERO: bez regresji */
.hero-photo .photo-frame { aspect-ratio: 4 / 5; }
.hero-photo .photo-frame > img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  aspect-ratio: 4 / 5;
}

/* O MNIE: stałe proporcje niezależne od copy (mobile-first) */
#o-mnie .photo-frame { aspect-ratio: var(--about-ar-mobile); }

/* Gdy wstawisz <picture> + <img>, to img ma wypełniać ramkę */
#o-mnie .photo-frame picture { display: block; width: 100%; height: 100%; }
#o-mnie .photo-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: var(--about-pos-mobile);
}

/* Placeholder nie może narzucać min-height, bo zepsuje aspect-ratio w „O mnie” */
#o-mnie .photo-placeholder { min-height: 0; }

.photo-placeholder {
  height: 100%;
  min-height: 260px;
  display: grid;
  place-content: center;
  text-align: center;
  padding: var(--s-5);
  color: rgba(20, 26, 26, 0.88);
}
.photo-placeholder p { margin: 0.15rem 0; }

/* =========================
   8) TILES / ABOUT / PRICING
   ========================= */
.tile {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: var(--s-4);
}
.tile p { margin: 0; color: var(--muted); }

.about-grid { display: grid; gap: var(--s-4); }

/* NOWE: prawa kolumna „O mnie” jako flex */
.about-photo { min-width: 0; }
.about-copy {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  min-width: 0;
}

/* FIX: usuń domyślne marginesy <p> w „O mnie” */
.about-copy p { margin: 0; }

.about-cards {
  display: grid;
  gap: 0.85rem;
  margin-top: var(--s-4);
}

.price-list {
  list-style: none;
  padding: 0;
  margin: 0.75rem 0 0;
  display: grid;
  gap: 0.6rem;
}

.price-list li {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--s-4);
  padding: 0.6rem 0.7rem;
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.6);
  border: 1px solid var(--border);
}
.price-list span { color: rgba(20, 26, 26, 0.92); }

/* =========================
   9) CONTACT
   ========================= */
.contact-grid { display: grid; gap: var(--s-4); }

.contact-form {
  display: grid;
  gap: 0.85rem;
  margin-top: 0.75rem;
}

label {
  display: grid;
  gap: 0.35rem;
  font-weight: 600;
  font-size: 0.95rem;
}

input, textarea {
  width: 100%;
  border-radius: var(--radius-input);
  border: 1px solid var(--border);
  padding: 0.7rem 0.85rem;
  font: inherit;
  background: rgba(255, 255, 255, 0.9);
  color: var(--text);
}

textarea { resize: vertical; min-height: 140px; }

.form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  align-items: center;
  margin-top: 0.25rem;
}

/* =========================
   10) MAP
   ========================= */
.map-wrap { margin-top: 0.75rem; }

.map-figure {
  margin: 0;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.55);
  box-shadow: 0 1px 0 rgba(20, 26, 26, 0.03);
}

.map-figure a {
  display: block;
  text-decoration: none;
  border-radius: calc(var(--radius) - 1px);
  overflow: hidden;
  position: relative;
}

.map-figure img {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  transform: translateZ(0);
  filter: contrast(1.06) saturate(1.02);
}

@media (prefers-reduced-motion: no-preference) {
  .map-figure img { transition: transform 0.22s ease, filter 0.22s ease; }
  .map-figure a:hover img {
    transform: scale(1.01);
    filter: contrast(1.09) saturate(1.04);
  }
}

.map-figure a:focus-visible {
  outline: var(--focus-ring);
  outline-offset: 3px;
  border-radius: var(--radius);
}

.map-figure figcaption {
  padding: 0.55rem 0.75rem;
  border-top: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.6);
}

.map-placeholder {
  padding: var(--s-4);
  text-align: center;
}

/* =========================
   11) FOOTER / NOSCRIPT
   ========================= */
.site-footer {
  padding: var(--s-5) 0 2rem;
  border-top: 1px solid var(--border);
}

.footer-inner {
  display: grid;
  gap: 0.35rem;
}

.noscript {
  margin: var(--s-4) auto var(--s-6);
  padding: var(--s-4);
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
}

/* =========================
   12) HERO: “Najważniejsze w skrócie”
   Mobile-first: normalna lista (disc)
   Desktop: wspólny grid (min-width: 1040px)
   ========================= */
.hero-split { margin: var(--s-5) 0 var(--s-5); }
.hero-outro { margin: 0.6rem 0 0; max-width: 65ch; }

/* Mobile / domyślnie */
.hero-quick .quick-list,
.hero-quick .quick-meta {
  margin: 0.35rem 0 0;
  padding-left: 1.1rem;
  list-style: disc;
  list-style-position: outside;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--hq-gap);
}

.hero-quick .quick-meta { margin-top: 0.65rem; }

.hero-quick .quick-list li,
.hero-quick .quick-meta li {
  display: list-item;
  line-height: 1.55;
  min-width: 0;
}

.hero-quick .quick-list li { color: var(--text); }
.hero-quick .quick-meta li { color: var(--muted); }

.hero-quick .quick-list li::marker,
.hero-quick .quick-meta li::marker {
  color: var(--text);
  font-size: 1em;
}

.hero-quick .quick-meta strong { color: var(--text); }

/* Separator w mobile (wewnątrz karty) */
.hero-quick .divider {
  margin-left: 1.1rem;
  margin-right: 1.1rem;
}

/* =========================
   13) REFS / DOC FLOW
   ========================= */
.refs { margin-top: 0.75rem; }
.refs summary { cursor: pointer; font-weight: 600; }
.refs .micro { margin: 0.4rem 0 0; }
.refs-list { margin: 0.5rem 0 0; padding-left: 1.25rem; }
.refs-list li { margin: 0.4rem 0; }
.refs a { white-space: nowrap; }
sup { font-size: 0.8em; }

/* Zasady współpracy: oddech */
.doc-flow .note { margin: var(--s-5) 0 var(--s-5); }
.doc-flow .note + .h3 { margin-top: 1.35rem; }
.doc-flow .bullets + .h3 { margin-top: 1.35rem; }

/* =========================================================
   14) BREAKPOINTS (rosnąco)
   ========================================================= */

/* Logo: mobile width guard */
@media (max-width: 480px) {
  .brand.site-brand img.brand-logo {
    max-width: calc(100vw - 96px);
  }
}

/* Desktop-ish layout */
@media (min-width: 860px) {
  .hero-grid {
    grid-template-columns: 0.9fr 1.1fr;
    align-items: stretch;
    gap: var(--s-5);
  }

  .hero-right { height: 100%; }

  .hero-copy {
    height: 100%;
    display: flex;
    flex-direction: column;
  }

  .hero-outro {
    margin-top: auto;
    padding-top: 1.05rem;
  }

  .two-col {
    grid-template-columns: 1.15fr 0.85fr;
    align-items: start;
  }

  .grid-5 { grid-template-columns: repeat(2, minmax(0, 1fr)); }

  .contact-grid {
    grid-template-columns: 1.05fr 0.95fr;
    align-items: start;
  }

  /* O MNIE: przełączenie AR + bezpieczny start kadru na desktop */
  #o-mnie .photo-frame { aspect-ratio: var(--about-ar-desktop); }
  #o-mnie .photo-frame img { object-position: var(--about-pos-desktop); }

  /* Placeholder może wypełniać ramkę (hero i o-mnie) */
  .photo-placeholder {
    height: 100%;
    min-height: 0;
  }
}

/* Mid widths: świadomy override hero-grid */
@media (min-width: 860px) and (max-width: 979px) {
  .hero-grid {
    grid-template-columns: 1fr;
    align-items: start;
  }

  .hero-right { height: auto; }

  .hero-copy {
    height: auto;
    display: block;
  }

  .hero-outro {
    margin-top: 0.35rem;
    padding-top: 0;
  }
}

/* ABOUT: touch + landscape -> 2 kolumny wcześniej */
@media (hover: none) and (pointer: coarse) and (orientation: landscape) and (min-width: 720px) {
  .about-grid {
    grid-template-columns: 0.9fr 1.1fr;
    align-items: stretch;
  }

  .about-copy { height: 100%; }
  .about-cards {
    margin-top: auto;
    grid-template-columns: repeat(auto-fit, minmax(min(220px, 100%), 1fr));
  }
}

/* ABOUT: prawdziwy desktop — 2 kolumny */
@media (min-width: 1040px) {
  .about-grid {
    grid-template-columns: 0.9fr 1.1fr;
    align-items: stretch;
  }

  .about-copy { height: 100%; }

  .about-cards {
    margin-top: auto;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* HERO QUICK: desktop grid (source of truth) */
@media (min-width: 1040px) {
  :is(.card.hero-quick, .hero-quick .card) {
    display: grid;
    grid-template-columns:
      var(--hq-gutter)
      max-content minmax(var(--hq-mingap), 1fr)
      max-content minmax(var(--hq-mingap), 1fr)
      max-content
      var(--hq-gutter);
    row-gap: var(--hq-gap);

    align-content: start;
    align-items: start;
    justify-content: start;
    justify-items: start;
    grid-auto-rows: min-content;
  }

  :is(.card.hero-quick, .hero-quick .card) > :is(h2, h3, .card-title) {
    grid-column: 1 / -1;
    grid-row: 1;
  }

  :is(.card.hero-quick, .hero-quick .card) > .divider {
    display: block;
    height: 0;
    background: transparent;
    border-top: 1px solid var(--border);
    width: 100%;
    grid-column: 2 / -2;
    grid-row: 3;
    margin: var(--hq-sep-margin) 0;
    align-self: start;
    justify-self: stretch;
  }

  :is(.card.hero-quick, .hero-quick .card) :is(.quick-list, .quick-meta) {
    display: contents !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
  }

  :is(.card.hero-quick, .hero-quick .card) :is(.quick-list li, .quick-meta li) {
    display: flex;
    align-items: baseline;
    gap: 0.55rem;
    white-space: nowrap;
    line-height: 1.55;
    min-width: 0;

    justify-self: start;
    width: fit-content;
  }

  :is(.card.hero-quick, .hero-quick .card) :is(.quick-list li, .quick-meta li)::before {
    content: "";
    width: var(--hq-dot);
    height: var(--hq-dot);
    border-radius: 999px;
    background: var(--text) !important;
    flex: 0 0 auto;
    transform: translateY(var(--hq-dot-shift));
  }

  :is(.card.hero-quick, .hero-quick .card) .quick-list li { color: var(--text); }
  :is(.card.hero-quick, .hero-quick .card) .quick-meta li { color: var(--muted); }
  :is(.card.hero-quick, .hero-quick .card) .quick-meta strong { color: var(--text); }

  :is(.card.hero-quick, .hero-quick .card) .quick-list li:nth-child(1) { grid-column: 2; grid-row: 2; }
  :is(.card.hero-quick, .hero-quick .card) .quick-list li:nth-child(2) { grid-column: 4; grid-row: 2; }
  :is(.card.hero-quick, .hero-quick .card) .quick-list li:nth-child(3) { grid-column: 6; grid-row: 2; }

  :is(.card.hero-quick, .hero-quick .card) .quick-meta li:nth-child(1) { grid-column: 2; grid-row: 4; }
  :is(.card.hero-quick, .hero-quick .card) .quick-meta li:nth-child(2) { grid-column: 4; grid-row: 4; }
  :is(.card.hero-quick, .hero-quick .card) .quick-meta li:nth-child(3) { grid-column: 6; grid-row: 4; }

  :is(.card.hero-quick, .hero-quick .card) a { white-space: nowrap; }
}

/* NAV desktop: breakpoint “kiedy się mieści” */
@media (min-width: 1160px) {
  .nav-toggle { display: none; }

  .site-nav {
    position: static;
    display: block;
    width: auto;
    background: transparent;
    border: none;
    box-shadow: none;
    padding: 0;
    min-width: 0;
  }

  .site-nav ul {
    display: flex;
    gap: 0.25rem;
    align-items: center;
    flex-wrap: nowrap;
  }

  .site-nav a {
    width: auto;
    padding: 0.55rem 0.7rem;
    white-space: nowrap;
  }

  .site-nav .nav-cta { background: rgba(15,59,53,.1); margin-top: 0; }
}

/* CTA: mobile – oddech pod pill-row */
@media (max-width: 859px) {
  .pill-row + .cta-row {
    margin-top: 1.8rem;
  }
}

/* CTA: desktop – dociągnij do dołu kolumny */
@media (min-width: 860px) {
  .hero-copy .cta-row {
    margin-top: auto;
  }
}
