/* ==========================================================================
   wp-overrides.css — drobne korekty integracji z WordPress.
   Ładowane po site.css i app.css. Tu trafia tylko to, czego nie ma
   w statycznych arkuszach, a wynika z osadzenia treści w WP.
   ========================================================================== */

/* Ujednolicony nagłówek (topbar + nav) jest wspólny dla wszystkich stron.
   Strony wewnętrzne potrzebują odstępu, by treść nie chowała się pod nawigacją. */
.page .inner-main,
.blog .inner-main {
  padding-top: 32px;
  padding-bottom: 96px;
  background: var(--bone, #c9ddec);
}
/* Gutter boczny treści podstron — odtwarza statyczne `main.wrap{padding:0 36px}`.
   Bez tego listy bez własnego paddingu (news-grid, articles-grid, results-list,
   category-filter, years-jump) dotykałyby krawędzi ekranu. */
.inner-main > .wrap {
  max-width: 1100px;
  padding-left: 36px;
  padding-right: 36px;
}
.inner-main.inner-main--wide > .wrap {
  max-width: 1280px;
}
@media (max-width: 600px) {
  .inner-main > .wrap {
    padding-left: 22px;
    padding-right: 22px;
  }
}

/* Breadcrumbs: pozwól zawijać długie tytuły (inaczej overflow poziomy na mobile). */
.breadcrumbs {
  flex-wrap: wrap;
  gap: 6px;
}

/* Treść Gutenberga w artykułach/stronach — szerokość czytelna. */
.entry-content,
.page-article-body {
  font-size: 18px;
  line-height: 1.75;
  color: var(--navy-700, #24405f);
}
.entry-content > * + *,
.page-article-body > * + * {
  margin-top: 1.25em;
}
.entry-content h2,
.page-article-body h2 {
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(26px, 3.4vw, 34px);
  color: var(--navy-900, #0e1f35);
  margin-top: 1.6em;
  line-height: 1.2;
}
.entry-content h3,
.page-article-body h3 {
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(22px, 2.6vw, 26px);
  color: var(--navy-900, #0e1f35);
  margin-top: 1.4em;
}
.entry-content a,
.page-article-body a {
  color: var(--gold, #4e8ebb);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.entry-content ul,
.entry-content ol,
.page-article-body ul,
.page-article-body ol {
  padding-left: 1.4em;
}
.entry-content li + li,
.page-article-body li + li {
  margin-top: 0.4em;
}
.entry-content img,
.page-article-body img {
  max-width: 100%;
  height: auto;
  border-radius: 10px;
}

/* Podpisy obrazów / WordPress caption. */
.wp-caption,
figure.wp-block-image {
  max-width: 100%;
}
.wp-caption-text,
.wp-element-caption {
  font-size: 14px;
  color: var(--navy-700, #24405f);
  opacity: 0.8;
  margin-top: 8px;
  text-align: center;
}

/* Wyrównania bloków. */
.alignwide { max-width: 1100px; }
.alignfull { max-width: 100%; }
.aligncenter { margin-left: auto; margin-right: auto; }

/* Galeria WP w treści. */
.wp-block-gallery { gap: 14px; }

/* Sticky header offset dla kotwic (#donate itd.) przy wejściu z innej strony. */
:target { scroll-margin-top: 120px; }

/* ── Korekty poziomego overflow na mobile (wykryte testem Edge headless) ── */

/* Nakładka galerii „Dom” ma right:-30px — przy 1-kolumnowym układzie (≤900)
   wystawała poza ekran. Dosuwamy ją do krawędzi kontenera. */
@media (max-width: 900px) {
  .project-art-overlay { right: 0; }
}

/* Siatka partnerów to repeat(4,1fr) bez collapse'u — na wąskich ekranach
   4 kolumny nie mieściły treści. 2 kolumny na mobile. */
@media (max-width: 600px) {
  .partners-grid { grid-template-columns: repeat(2, 1fr); }
  .partner-card { padding-left: 16px; padding-right: 16px; }
  .partner-card:nth-child(2n) { border-right: none; }
  .partner-card:nth-child(-n+2) { border-bottom: 1px solid var(--line); }
}

/* Pasek nawigacji (nav-compact z linkiem „Jak pomóc") miał minimalną szerokość
   ~447px — na 414–447px (iPhone 414/428/430) wychodził poza ekran. Link „Jak
   pomóc" jest dostępny w menu (hamburger), więc chowamy go wcześniej. */
@media (max-width: 480px) {
  .nav-compact-help { display: none; }
}

/* Siatka „w liczbach” (impact) zostaje 2-kolumnowa do 760px, ale poniżej ~370px
   dwie kolumny się nie mieściły (overflow na 320/360px). Składamy do 1 kolumny. */
@media (max-width: 380px) {
  .impact-grid { grid-template-columns: 1fr; }
  .impact-grid > div {
    border-right: none;
    border-bottom: 1px solid var(--line);
  }
  .impact-grid > div:last-child { border-bottom: none; }
}

/* Stan „brak treści” na archiwach. */
.empty-state {
  text-align: center;
  padding: 60px 20px;
  color: var(--navy-700, #24405f);
}

/* Dostępność: ukrycie wizualne tekstu dla czytników ekranu (kanon WP). */
.screen-reader-text {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  height: 1px;
  width: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  position: absolute !important;
  word-wrap: normal !important;
}
.screen-reader-text:focus {
  background-color: #fff;
  border-radius: 3px;
  box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
  clip: auto !important;
  clip-path: none;
  color: var(--navy-900, #0e1f35);
  display: block;
  font-size: 0.9rem;
  font-weight: 700;
  height: auto;
  left: 6px;
  line-height: normal;
  padding: 14px 22px;
  text-decoration: none;
  top: 6px;
  width: auto;
  z-index: 100000;
}

/* Skip-link — widoczny dopiero po nakierowaniu klawiaturą. */
.skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  z-index: 100000;
}

/* Komunikaty admin/edytor — bez wpływu na front. */
