/* --- Podstawowe Ustawienia --- */
:root{
  --primary-color:#313b5b;
  --accent-color:#f59e0b;
  --text-color-light:#f0f2f5;
  --text-color-dark:#333;
  --background-color:#ffffff;
  --background-gray:#f4f4f7;
  --font-family:Arial, sans-serif;
  --max-width:1200px;

  /* Dostępność */
  --base-font-size:16px;
  --large-font-size:18px;
  --xlarge-font-size:20px;
  --contrast-text:#000;
  --contrast-bg:#fff;
}

/* Reset + bazowe */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth; font-size:var(--base-font-size);}
body{
  font-family:var(--font-family);
  background-color:var(--background-color);
  color:var(--text-color-dark);
  line-height:1.7;
  font-size:inherit;
  transition:font-size .3s ease, background-color .3s ease, color .3s ease;
  padding-top:136px; /* sticky header offset */
}
img{max-width:100%;height:auto;display:block}
.container{max-width:var(--max-width);margin:0 auto;padding:0 1.5rem}
.fullbleed{max-width:none;width:100%;padding:0;margin:0}

h2{
  font-size:2rem;font-weight:bold;color:var(--primary-color);
  text-align:center;margin-bottom:2.5rem;position:relative;padding-bottom:.75rem;
}
h2::after{
  content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);
  width:60px;height:4px;background-color:var(--accent-color);
}
h3{font-size:1.5rem;font-weight:bold;color:var(--primary-color);margin-bottom:1rem}
section{padding:4rem 0}

/* --- Wrapper 100vh --- */
.hero-wrapper{display:flex;flex-direction:column}

/* --- Nagłówek (sticky) --- */
.main-header{
  background-color:rgba(255,255,255,.95);
  padding:1rem 1.5rem;
  position:fixed;top:0;left:0;width:100%;z-index:1000;
  backdrop-filter:blur(8px);
  box-shadow:0 2px 10px rgba(0,0,0,.08);
  border-bottom:4px solid var(--accent-color);
}
.header-content{display:flex;justify-content:space-between;align-items:center;max-width:var(--max-width);margin:0 auto}
.logo{display:flex;align-items:center;gap:.5rem;font-weight:bold;font-size:1.5rem;color:var(--primary-color);text-decoration:none}
.logo-img{height:100px;width:auto}
.logo-text{display:none}

/* --- Nawigacja z animowanym podkreśleniem --- */
.main-nav{display:none}
.nav-links{list-style:none;display:flex;flex-direction:column;align-items:center}
.nav-links a{
  position:relative;display:block;padding:1rem;text-align:center;
  color:var(--primary-color);text-decoration:none;font-weight:bold;font-size:1.125rem; /* skaluje się z html (rem) */
  transition:color .3s ease;
}
.nav-links a:hover{color:var(--accent-color)}
/* linia pod linkiem */
.nav-links a::after{
  content:'';position:absolute;left:0;right:0;bottom:.35rem;margin:0 auto;
  width:0;height:3px;background:var(--accent-color);transition:width .25s ease-in-out;
}
.nav-links a:hover::after{width:100%}
/* aktywna zakładka */
.nav-links a[aria-current="page"]{color:var(--primary-color)}
.nav-links a[aria-current="page"]::after{width:100%}

.hamburger{display:flex;flex-direction:column;justify-content:space-around;width:2rem;height:2rem;background:transparent;border:none;cursor:pointer;padding:0}
.hamburger span{width:2rem;height:3px;background:var(--primary-color);border-radius:10px}

/* Po-obrazek pod headerem (tylko Home) */
.after-header-image{background-color:var(--background-gray);padding:0;position:relative;z-index:1;box-shadow:0 2px 5px rgba(0,0,0,.05)}
.after-header-image .fullbleed{max-width:none}
.kpo-logo-header{width:100%;height:auto;max-width:none;display:block}

/* --- Sekcja Hero --- */
.hero{
  flex:1 1 auto;min-height:0;background-size:cover;background-position:center;
  display:flex;align-items:center;justify-content:center;text-align:center;padding:1.5rem;position:relative;
}
.hero-overlay{position:absolute;inset:0;background-color:rgba(10,25,47,.5)}
.hero-text{position:relative;z-index:2}
.hero h1{font-size:3rem;color:#fff;text-shadow:2px 2px 8px rgba(0,0,0,.7);font-weight:bold}

/* --- Galeria (Projekt) --- */
.gallery-section{background:#fff}
.gallery{display:flex;flex-direction:column;gap:3rem}
.gallery-item{display:flex;align-items:center;gap:2rem}
.gallery-item.reverse{flex-direction:row-reverse}
.gallery-image{flex:1}
.gallery-image img{width:100%;height:auto;border-radius:8px;box-shadow:0 4px 20px rgba(0,0,0,.1)}
.gallery-text{flex:1;text-align:left}
.gallery-text p{font-size:1rem;line-height:1.6;color:#555}

/* --- Home: Galeria jako Grid (tylko na index.html) --- */
.gallery-grid .gallery{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
  gap:2rem;
}
.gallery-grid .gallery-item,
.gallery-grid .gallery-item.reverse{
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:1rem;
  background:#fff;
  border-radius:8px;
  overflow:hidden;
  box-shadow:0 4px 20px rgba(0,0,0,.1);
  transition:transform .3s ease, box-shadow .3s ease;
}
.gallery-grid .gallery-item:hover{
  transform:translateY(-4px);
  box-shadow:0 10px 25px rgba(49,59,91,.2);
}
.gallery-grid .gallery-image{flex:unset}
.gallery-grid .gallery-image img{
  width:100%;
  height:200px;
  object-fit:cover;
  border-radius:0;
  box-shadow:none;
}
.gallery-grid .gallery-text{
  flex:unset;
  text-align:left;
  padding:0 1.25rem 1.25rem;
}

/* --- Sekcje treści --- */
.content-section{text-align:center}
.content-section.gray-bg{background-color:var(--background-gray)}
.content-section article{margin:0 auto 3rem;max-width:800px;text-align:left}
.content-section p{margin-bottom:1rem;color:#555}
.content-image{margin:2rem auto;max-width:900px}
.content-image img{border-radius:8px;box-shadow:0 4px 20px rgba(0,0,0,.1)}
.articles-grid{display:grid;gap:2rem}
.news-card{background:#fff;border-radius:8px;box-shadow:0 4px 20px rgba(0,0,0,.1);text-align:left;overflow:hidden;transition:transform .3s ease, box-shadow .3s ease}
.news-card:hover{transform:translateY(-5px);box-shadow:0 10px 25px rgba(49,59,91,.2)}
.news-card img{width:100%;height:200px;object-fit:cover}
.news-content{padding:1.5rem}
.btn-more{display:inline-block;padding:.6rem 1.5rem;border:2px solid var(--primary-color);color:var(--primary-color);text-decoration:none;border-radius:5px;transition:background-color .3s,color .3s;font-weight:bold;margin-top:1rem}
.btn-more:hover{background-color:var(--primary-color);color:#fff}

/* --- Kontakt --- */
.contact-section{background-size:cover;background-position:center;position:relative;padding:6rem 0}
.contact-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:rgba(49,59,91,.85)}
.contact-container{position:relative;z-index:2;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center}
.contact-section h2,.contact-section p{color:#fff}
.contact-section h2::after{background-color:#fff}
.contact-email{font-size:1.5rem;font-weight:bold;margin-top:1rem;text-decoration:none;color:#fff;border-bottom:2px solid var(--accent-color);padding-bottom:5px}
.contact-email:hover{color:var(--accent-color)}

/* --- Stopka (bez obrazka z logotypami) --- */
.main-footer{padding:2rem 0;background:var(--primary-color);color:#fff;margin-top:2rem}
.footer-content{max-width:var(--max-width);margin:0 auto;display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:1rem;padding:0 1.5rem}
.social-links a{color:#fff;transition:color .3s}
.social-links a:hover{color:var(--accent-color)}

.footer-text{font-weight:500}
.social-links a{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px}
.social-links a svg{width:24px;height:24px}

/* --- Panel Dostępności --- */
.accessibility-panel{position:fixed;top:0;right:-320px;width:320px;height:100%;background-color:var(--background-color);box-shadow:-5px 0 15px rgba(0,0,0,.2);z-index:1001;transition:right .4s ease-in-out;border-left:3px solid var(--accent-color);overflow-y:auto;font-size:16px}
.accessibility-panel.visible{right:0}
.panel-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background-color:var(--primary-color);color:var(--text-color-light)}
.panel-header h3{color:var(--text-color-light);margin:0;font-size:1.2em}
.close-button{background:none;border:none;color:var(--text-color-light);font-size:2em;cursor:pointer;line-height:1;opacity:.8;transition:opacity .3s ease}
.close-button:hover{opacity:1}
.panel-content{padding:1.5rem}
.option-group{margin-bottom:2rem}
.option-group h4{margin-bottom:1rem;color:var(--primary-color);border-bottom:1px solid #eee;padding-bottom:.5rem;font-size:1.1em}
.button-group{display:flex;gap:.5rem;flex-wrap:wrap}
.button-group button{flex-grow:1;padding:.75rem;border:1px solid var(--primary-color);background:var(--background-color);color:var(--primary-color);font-weight:bold;cursor:pointer;transition:background-color .3s,color .3s,border-color .3s;min-width:80px}
.button-group button:hover{background-color:var(--primary-color);color:var(--text-color-light)}
/* Zmiana rozmiaru czcionki – na elemencie root, aby rem skalował cały tekst */
html.font-large{font-size:var(--large-font-size)}
html.font-xlarge{font-size:var(--xlarge-font-size)}
/* Zachowanie zgodności, gdy klasa była wcześniej dodawana do body */
body.font-large{font-size:var(--large-font-size)}
body.font-xlarge{font-size:var(--xlarge-font-size)}
body.high-contrast{background-color:var(--contrast-bg)!important;color:var(--contrast-text)!important}
body.high-contrast .main-header,body.high-contrast .accessibility-panel{background-color:var(--contrast-bg)!important}
body.high-contrast .main-header{border-bottom-color:var(--contrast-text)!important}
body.high-contrast .main-nav a,body.high-contrast .main-nav button{color:var(--contrast-text)!important}
body.high-contrast .main-nav a:hover,body.high-contrast .main-nav button:hover{color:var(--primary-color)!important}
body.high-contrast .hamburger span{background-color:var(--contrast-text)!important}
body.high-contrast h1,body.high-contrast h2,body.high-contrast h3,body.high-contrast p,body.high-contrast .logo,body.high-contrast .news-content p,body.high-contrast .btn-more,body.high-contrast .contact-form label{color:var(--contrast-text)!important}
body.high-contrast h2::after{background-color:var(--contrast-text)!important}
body.high-contrast .btn-more{border-color:var(--contrast-text)!important}
body.high-contrast .btn-more:hover{background-color:var(--contrast-text)!important;color:var(--contrast-bg)!important}
body.high-contrast .contact-section{background-image:none!important;background-color:#333!important}
body.high-contrast .contact-overlay{background-color:rgba(0,0,0,.7)!important}
body.high-contrast .contact-section h2,body.high-contrast .contact-section p{color:var(--contrast-bg)!important}
body.high-contrast .accessibility-panel{border-left-color:var(--contrast-text)!important}
body.high-contrast .panel-header{background-color:var(--contrast-text)!important}
body.high-contrast .panel-header h3,body.high-contrast .close-button{color:var(--contrast-bg)!important}
body.high-contrast .option-group h4{color:var(--contrast-text)!important;border-bottom-color:var(--contrast-text)!important}
/* tryb negatywny */
body.negative-contrast{filter:invert(100%);background-color:#fff}
/* W negatywie nie odwracamy ponownie nagłówka, aby menu też było w negatywie */
body.negative-contrast img:not(.logo-img):not(.accessibility-icon),body.negative-contrast .hero-overlay,body.negative-contrast .contact-section{filter:invert(100%)}

/* Focusy i redukcja ruchu */
:focus-visible{outline:3px solid var(--accent-color);outline-offset:2px}
@media (prefers-reduced-motion:reduce){
  *{transition:none!important;scroll-behavior:auto!important}
}

/* --- Media Queries --- */
@media (min-width:768px){
  h2{font-size:2.5rem}
  .hamburger{display:none}
  .main-nav{display:flex;align-items:center}
  .nav-links{flex-direction:row;gap:2rem;align-items:center}
  .nav-links a{padding:0;font-size:1rem}
  .logo-img{height:100px}
  .logo-text{display:none}
  .main-header{
    padding-bottom: 1.25rem; /* możesz podbić do 1.5rem jeśli chcesz jeszcze niżej */
    overflow: visible;       /* na wszelki wypadek */
  }
  .nav-links a::after{
    bottom: -10px;  /* „kapkę” niżej – zmień np. na -12px, jeśli ma być jeszcze niżej */
  }
}

/* Przycisk dostępności – tylko ikona, bez ramki */
.accessibility-icon-button{
  appearance:none;
  -webkit-appearance:none;
  background:transparent;
  border:none;
  box-shadow:none;
  padding:0;
  margin:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:44px;   /* wygodny obszar klikalny */
  height:44px;  /* bez prostokątnej „piguły” */
  border-radius:50%;
  line-height:0;
  cursor:pointer;
}
.accessibility-icon-button img{
  display:block;
  width:36px;
  height:36px;
}

/* Dla dostępności – widoczny, okrągły focus tylko przy klawiaturze */
.accessibility-icon-button:focus-visible{
  outline:3px solid var(--accent-color);
  outline-offset:2px;
  border-radius:50%;
}


/* --- Strona aktualności (pojedyncza) --- */
.article-hero{position:relative;min-height:40vh;background-image:var(--article-hero-image);background-size:cover;background-position:center;display:flex;align-items:flex-end}
.article-hero-overlay{position:absolute;inset:0;background:linear-gradient(to top, rgba(10,25,47,.65) 0%, rgba(10,25,47,0) 65%)}
.article-hero-inner{position:relative;z-index:1;padding:2rem 1.5rem 2.5rem;width:100%}
.article-title{color:#fff;font-size:clamp(1.75rem,3.5vw,3rem);line-height:1.2;text-shadow:0 3px 16px rgba(0,0,0,.35);margin:0}
.article-main{padding:3rem 0 4rem}
.article-content{font-size:1rem;line-height:1.8;color:#444}
.article-figure{margin:0 0 1rem 0}
.article-figure img{display:block;max-width:100%;height:auto;border-radius:8px;box-shadow:0 4px 18px rgba(0,0,0,.08)}
.article-figure figcaption{font-size:.9rem;color:#777;margin-top:.5rem}
.float-right{float:right;width:min(45%,520px);margin:0 0 1rem 1.5rem}
.article-source a{border-bottom:2px solid var(--accent-color);text-decoration:none;color:var(--primary-color);font-weight:bold}
.article-author{margin-top:.25rem;color:#666}
@media (max-width:768px){
  .gallery-item,.gallery-item.reverse{flex-direction:column;text-align:center}
  .gallery-text{text-align:center}
  .float-right{float:none;width:100%;margin:0 0 1rem 0}
  .article-main{padding:2rem 0 3rem}
}
.content-section ul,
.content-section ol{ margin:0 0 1rem 1.25rem }
.content-section li{ margin-bottom:.5rem }


/* --- Niski banner hero dla podstron --- */
.page-hero{
  position:relative;
  background-image:var(--page-hero-image);
  background-size:cover;
  background-position:center;
  min-height:300px;                /* niski pasek */
  display:flex;
  align-items:center;
}
.page-hero-overlay{
  position:absolute; inset:0;
  background:linear-gradient(to bottom, rgba(0,0,0,.45), rgba(0,0,0,.35));
}
.page-hero-inner{
   position:relative; z-index:1;
  width:100%;
  /* zostawiamy poziomy padding z .container, ustawiamy tylko góra/dół */
  padding-top:1.75rem;
  padding-bottom:1.75rem;
}
.page-hero h1{
  color:#fff; margin:0 auto 3rem;
  max-width: 800px;
  font-size:clamp(1.4rem, 2.4vw, 2.25rem);
  line-height:1.2;
  text-shadow:0 2px 10px rgba(0,0,0,.35);
}
/* ===== Globalne listy w treści ===== */
.content-section ul,
.content-section ol,
.article-content ul,
.article-content ol{
  margin: 0 0 1.25rem 0;   /* odstęp pod listą */
  padding-left: 1.25rem;   /* wcięcie markerów/liczb */
  list-style-position: outside;
}

.content-section li,
.article-content li{
  margin: .4rem 0;         /* odstępy między pozycjami */
  line-height: 1.7;
}

/* Czytelne markery dla list wypunktowanych */
.content-section ul{ list-style-type: disc; }
.article-content  ul{ list-style-type: disc; }

.content-section ul li::marker,
.article-content  ul li::marker{
  color: var(--accent-color);
}

/* Numeracja dla list numerowanych */
.content-section ol{ list-style-type: decimal; }
.article-content  ol{ list-style-type: decimal; }

/* Podlisty: mniejszy odstęp nad */
.content-section li ul,
.content-section li ol,
.article-content  li ul,
.article-content  li ol{
  margin-top: .35rem;
}

/* Wysoki kontrast – markery zawsze czytelne */
body.high-contrast .content-section ul li::marker,
body.high-contrast .article-content  ul li::marker{
  color: var(--contrast-text) !important;
}

/* [opcjonalnie] Lista z kolumną czasu (np. agenda):
   dodaj klasę .time-list do <ul>/<ol>, gdy chcesz wyrównać godziny. */
.time-list > li > strong{
  display:inline-block;
  min-width:12ch;          /* szerokość „kolumny” na godziny */
  font-weight:700;
}
@media (max-width:520px){
  .time-list > li > strong{
    display:block; min-width:0; margin-bottom:.15rem;
  }
}