/*
Theme Name: Słupca ON
Theme URI: https://slupcaon.pl
Author: Słupca ON
Author URI: https://slupcaon.pl
Description: Niezależny portal informacyjny powiatu słupeckiego. Motyw zaprojektowany z myślą o szybkości, responsywności i SEO.
Version: 2.3.5
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: slupcaon
Tags: news, portal, one-column, custom-menu, featured-images, translation-ready
*/

/* === RESET & VARIABLES === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --black:#0a0a0a;
  --white:#f7f6f2;
  --red:#d42b2b;
  --grey:#8a8a85;
  --light:#eeecea;
  --card:#ffffff;
  --border:#e0deda;
  --font-display:'Bebas Neue',sans-serif;
  --font-body:'Familjen Grotesk',sans-serif;
  /* Globalny limit szerokości treści — jeden punkt do zmiany dla całej strony */
  --max-content:1280px;
}
html{scroll-behavior:smooth;overflow-x:clip}
body{font-family:var(--font-body);background:var(--white);color:var(--black);overflow-x:clip;font-size:16px;line-height:1.5}

/* Fallback dla Safari < 16 — overflow-x:clip nie wspierane, ale overflow:hidden zostawimy w body żeby zatrzymać poziome wystawanie. position:sticky w sidebarze zostanie złamany w starym Safari, ale nic strasznego — sidebar przewinie się normalnie. */
@supports not (overflow-x: clip) {
  html, body { overflow-x: hidden; }
}

/* Defensywny global — żaden img/video/iframe nie może wystawać poza viewport */
img, video, iframe, embed, object {
  max-width: 100%;
}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--white)}
::-webkit-scrollbar-thumb{background:var(--black)}

/* === NAV === */
.site-nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;padding:0 32px;height:56px;background:var(--black);border-bottom:2px solid var(--red)}
.logo{font-family:var(--font-display);font-size:2rem;letter-spacing:.06em;color:var(--white);text-decoration:none;display:flex;align-items:baseline;gap:2px}
.logo-city{color:#fff;font-size:1.1rem;letter-spacing:.15em;align-self:center;margin-right:4px;font-family:var(--font-body);font-weight:700}
.logo em{color:var(--red);font-style:normal}

.nav-links{display:flex;gap:0;list-style:none;align-items:stretch;height:56px}
.nav-links li{list-style:none;position:relative;display:flex;align-items:stretch}
.nav-links a{display:flex;align-items:center;padding:0 16px;height:56px;line-height:1.2;color:rgba(247,246,242,.45);font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;border-left:1px solid rgba(255,255,255,.06);transition:color .2s,background .2s;gap:6px}
.nav-links a:hover,.nav-links .current-menu-item>a,.nav-links .current_page_item>a,.nav-links a.active{color:var(--white);background:rgba(255,255,255,.04)}
.nav-links .has-mega>a:hover,.nav-links .has-mega.is-open>a{color:var(--white);background:rgba(255,255,255,.06)}
.nav-links .mega-caret{font-size:.6rem;opacity:.6;transition:transform .2s}
.nav-links .has-mega.is-open .mega-caret{transform:rotate(180deg)}

/* Submenu (poziom 2 — zwykłe dropdown) */
.nav-links .sub-menu{position:absolute;top:56px;left:0;min-width:220px;background:#111;border:1px solid rgba(255,255,255,.08);border-top:2px solid var(--red);padding:6px 0;display:none;z-index:210;list-style:none}
.nav-links li:hover>.sub-menu,.nav-links li.is-open>.sub-menu{display:block}
.nav-links .sub-menu a{height:auto;padding:10px 16px;border-left:none;font-size:.72rem;color:rgba(247,246,242,.65);white-space:nowrap}
.nav-links .sub-menu a:hover{background:rgba(255,255,255,.06);color:var(--white)}

/* === PRZYCISK „WŁĄCZ MIASTO" / „ZMIEŃ GMINĘ" === */
.nav-city-btn{display:inline-flex;align-items:center;gap:10px;padding:8px 18px;background:var(--red);color:#fff;font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;text-decoration:none;border:1px solid var(--red);transition:background .2s,transform .15s,border-color .2s;font-family:inherit;line-height:1;white-space:nowrap}
.nav-city-btn:hover{background:#b82020;transform:translateY(-1px)}
.nav-city-btn .ncb-name{color:#fff;font-weight:800;letter-spacing:.04em;text-transform:none;font-size:.82rem}
.nav-city-btn .ncb-action{opacity:.85;font-weight:700;font-size:.66rem}
.nav-city-btn.is-active{background:transparent;border-color:rgba(255,255,255,.25)}
.nav-city-btn.is-active:hover{background:rgba(255,255,255,.06);border-color:var(--red)}
.nav-city-btn.is-active .ncb-name{color:#fff}
.nav-city-btn.is-active .ncb-action{color:rgba(255,255,255,.55);text-decoration:none;display:inline-flex;align-items:center;gap:8px}
.nav-city-btn.is-active .ncb-action::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--red);box-shadow:0 0 0 0 rgba(212,43,43,.7);animation:nav-city-pulse 2s infinite;flex:0 0 auto}
@keyframes nav-city-pulse{0%{box-shadow:0 0 0 0 rgba(212,43,43,.6)}70%{box-shadow:0 0 0 8px rgba(212,43,43,0)}100%{box-shadow:0 0 0 0 rgba(212,43,43,0)}}

/* Stary nav-claim — fallback gdyby się gdzieś jeszcze pojawił */
.nav-claim{font-size:.68rem;color:rgba(247,246,242,.25);letter-spacing:.15em;text-transform:uppercase;font-style:italic}

/* === MEGA-MENU (podgląd newsów z kategorii) === */
.mega-panel{position:fixed;top:56px;left:0;right:0;background:#0d0d0d;border-top:2px solid var(--red);box-shadow:0 20px 60px rgba(0,0,0,.35);z-index:190;opacity:0;visibility:hidden;transform:translateY(-8px);transition:opacity .2s,transform .2s,visibility 0s .2s;max-height:0;overflow:hidden}
.mega-panel.is-open{opacity:1;visibility:visible;transform:translateY(0);transition:opacity .2s,transform .2s,visibility 0s 0s;max-height:500px}
.mega-panel-inner{max-width:var(--max-content);margin:0 auto;padding:28px 32px;min-height:180px}
.mega-loading{color:rgba(255,255,255,.3);font-size:.8rem;letter-spacing:.08em;text-transform:uppercase}
.mega-grid{display:grid;grid-template-columns:repeat(3,1fr) auto;gap:24px;align-items:stretch}
.mega-item{display:flex;flex-direction:column;text-decoration:none;background:rgba(255,255,255,.03);transition:background .2s,transform .2s}
.mega-item:hover{background:rgba(255,255,255,.06);transform:translateY(-2px)}
.mega-thumb{aspect-ratio:16/9;background:rgba(255,255,255,.05) center/cover no-repeat;position:relative;display:flex;align-items:center;justify-content:center}
.mega-thumb-fallback{font-family:var(--font-display);font-size:2rem;color:rgba(255,255,255,.1);letter-spacing:.1em}
.mega-body{padding:14px 16px 16px}
.mega-cat{font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;color:var(--red);font-weight:700;margin-bottom:6px}
.mega-title{font-size:.88rem;line-height:1.35;color:var(--white);font-weight:600}
.mega-date{font-size:.68rem;color:rgba(255,255,255,.35);margin-top:8px;letter-spacing:.05em}
.mega-all{align-self:stretch;display:flex;align-items:center;justify-content:center;padding:0 28px;background:var(--red);color:#fff;font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;transition:background .2s}
.mega-all:hover{background:#b82020}
.mega-empty{color:rgba(255,255,255,.4);font-size:.82rem;padding:20px 0}

/* Mobile menu toggle */
.menu-toggle{display:none;background:none;border:none;color:var(--white);font-size:1.5rem;cursor:pointer;padding:8px}

/* === TICKER === */
.ticker-bar{margin-top:0;background:var(--red);overflow:hidden;padding:9px 0;white-space:nowrap;border-bottom:1px solid rgba(0,0,0,.15)}
.ticker-inner{display:inline-block;animation:tickerMove 90s linear infinite;font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#fff}
.ticker-inner span{margin:0 48px}
.ticker-inner span::before{content:"▶";margin-right:10px;opacity:.6;font-size:.6rem}
@keyframes tickerMove{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* === HERO === */
/* Defensywne: pusty h1 (np. wstrzyknięty przez plugin SEO) nie zajmuje miejsca */
h1:empty{display:none !important;margin:0 !important;padding:0 !important}

.hero{background:var(--black);padding:100px 32px 64px;position:relative;overflow:hidden;
  /* Pełnoekranowe hero — minus nav (56px) + manifest (~46px) + ticker (~36px)
     żeby cały ciemny obszar (hero + manifest + ticker) zmieścił się w jednym viewporcie */
  min-height:calc(100vh - 138px);display:flex;flex-direction:column;justify-content:center}

/* Animowane ON-y w tle (z zapowiedzi) */
.hero-floaters{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
/* iOS Safari/Chrome bug fix: duże fonty z animacją transformacji renderują się
   dwukrotnie z lekkim przesunięciem (artefakt warstw kompozytora).
   Naprawiamy: -webkit-text-stroke:0 + antialiased + translate3d w keyframes
   + backface-visibility:hidden — wymusza pojedynczy pass renderingu na GPU. */
.hero-floaters .float-on{
    position:absolute;
    font-family:var(--font-display);
    color:rgba(255,255,255,.025);
    letter-spacing:-.02em;
    line-height:.82;
    user-select:none;
    font-weight:900;
    transition:color .4s;
    -webkit-text-stroke:0;
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing:grayscale;
    -webkit-text-size-adjust:100%;
    text-rendering:optimizeLegibility;
    backface-visibility:hidden;
    -webkit-backface-visibility:hidden;
    transform:translate3d(0,0,0);
    -webkit-transform:translate3d(0,0,0);
}
.hero-floaters .f1{top:-12%;right:-8%;font-size:60vh;animation:hero-drift-1 9s ease-in-out infinite}
.hero-floaters .f2{top:30%;left:-10%;font-size:30vh;color:rgba(255,255,255,.022);animation:hero-drift-2 7s ease-in-out infinite}
.hero-floaters .f3{bottom:-15%;right:30%;font-size:24vh;color:rgba(255,255,255,.02);animation:hero-drift-3 10s ease-in-out infinite}
.hero-floaters .f4{top:8%;left:48%;font-size:12vh;color:rgba(255,255,255,.018);animation:hero-drift-4 6s ease-in-out infinite}
@keyframes hero-drift-1{0%,100%{transform:translate3d(0,0,0) scale(1) rotate(0)}50%{transform:translate3d(-3%,2.5%,0) scale(1.05) rotate(-.8deg)}}
@keyframes hero-drift-2{0%,100%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(5%,-3%,0) scale(.93)}}
@keyframes hero-drift-3{0%,100%{transform:translate3d(0,0,0) scale(1) rotate(0)}50%{transform:translate3d(-3%,-5%,0) scale(1.12) rotate(1.5deg)}}
@keyframes hero-drift-4{0%,100%{transform:translate3d(0,0,0) scale(1)}25%{transform:translate3d(2%,3%,0) scale(1.18)}75%{transform:translate3d(-3%,-2%,0) scale(.86)}}

/* Podczas hover na newsie ON-y stają się jaśniejsze, zostają WIDOCZNE NA grafice */
.hero.is-news-hover .hero-floaters{z-index:2}
.hero.is-news-hover .hero-floaters .float-on{color:rgba(255,255,255,.08)}
.hero.is-news-hover .hero-floaters .f1{color:rgba(255,255,255,.09)}

/* Tło hero z newsem (na hover w liście) */
.hero-news-bg{position:absolute;inset:0;opacity:0;transition:opacity .5s ease;pointer-events:none;z-index:0}
.hero-news-bg.is-active{opacity:1}
.hero-news-bg .hnb-image{position:absolute;inset:0;background-position:center;background-size:cover;background-repeat:no-repeat;-webkit-mask-image:radial-gradient(circle at center,black 30%,transparent 75%);mask-image:radial-gradient(circle at center,black 30%,transparent 75%);transform:scale(1.05);transition:transform .8s ease;filter:brightness(.8) contrast(.95)}
.hero-news-bg.is-active .hnb-image{transform:scale(1)}
.hero-news-bg .hnb-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.4) 0%,rgba(0,0,0,.65) 100%);mix-blend-mode:multiply}

.hero-inner{max-width:var(--max-content);margin:0 auto;display:grid;grid-template-columns:1fr 380px;gap:80px;align-items:start;position:relative;z-index:2;padding-top:8px}
.hero.hero-mode-news .hero-inner{grid-template-columns:1fr 540px;gap:80px}
.hero-tag{font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:20px;display:flex;align-items:center;gap:10px}
.hero-tag::before{content:'';width:28px;height:2px;background:var(--red);display:block}
.hero h1{font-family:var(--font-display);font-size:clamp(4.5rem,11vw,11rem);line-height:.92;letter-spacing:.02em;color:var(--white);margin-bottom:28px}
.hero h1 .hero-on{color:var(--red)}

/* Dynamiczna nazwa miasta:
   - city-old (przekreślone „SŁUPCA") jest pozycjonowana absolutnie nad city-new
     żeby NIE dodawała wysokości do tytułu — hero ma identyczną wysokość
     niezależnie czy gmina jest wybrana czy nie.
*/
.hero h1{position:relative}
.hero h1 .city-old{position:absolute;top:-1.1em;left:0;color:rgba(255,255,255,.35);text-decoration:line-through;text-decoration-color:var(--red);text-decoration-thickness:5px;font-size:.42em;line-height:1;letter-spacing:.04em;font-weight:inherit}
.hero h1 .city-new{display:block;color:#fff;font-size:.95em;line-height:.92;margin:0}
.hero h1 .hero-on{color:var(--red)}
.hero h1 .hero-on-inline{display:block;line-height:.92;margin-top:.05em}

.hero-claim{font-size:1.1rem;font-weight:400;color:rgba(247,246,242,.45);line-height:1.65;margin-bottom:36px;max-width:460px}
.hero-claim strong{color:rgba(247,246,242,.8);font-weight:600}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap}
.btn-red{background:var(--red);color:#fff;padding:13px 28px;font-size:.86rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;text-decoration:none;transition:transform .15s,background .2s;display:inline-block}
.btn-red:hover{background:#b82020;transform:translateY(-2px)}
.btn-outline{border:1.5px solid rgba(247,246,242,.2);color:rgba(247,246,242,.55);padding:13px 28px;font-size:.86rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;text-decoration:none;transition:border-color .2s,color .2s;display:inline-block}
.btn-outline:hover{border-color:var(--white);color:var(--white)}
.hero-stats{display:flex;flex-direction:column;gap:2px}
.hstat{background:rgba(255,255,255,.04);border-left:3px solid rgba(212,43,43,.35);padding:22px 24px;transition:border-color .2s,background .2s;cursor:default}
.hstat:hover{border-color:var(--red);background:rgba(255,255,255,.07)}
.hstat-num{font-family:var(--font-display);font-size:2.8rem;color:var(--white);line-height:1;letter-spacing:.04em}
.hstat-num sup{font-size:1.1rem;color:var(--red)}
.hstat-label{font-size:.72rem;color:rgba(247,246,242,.35);letter-spacing:.06em;text-transform:uppercase;margin-top:4px}

/* Hero — NEWS MODE (nowa domyślna prawa kolumna) */
.hero-news{display:flex;flex-direction:column;gap:2px;min-width:0}
.hero-news-label{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-size:1.2rem;letter-spacing:.06em;text-transform:uppercase;color:#fff;margin-bottom:14px;padding-left:4px;font-weight:400}
.hero-news-label .hnl-accent{color:var(--red)}
.hero-news-label .hnl-cat{font-family:var(--font-body);font-size:.62rem;letter-spacing:.18em;color:rgba(255,255,255,.4);font-weight:700;margin-left:auto}
.hero-news-label .live-dot{width:9px;height:9px;border-radius:50%;background:#fff;box-shadow:0 0 0 0 rgba(230,57,70,.7);animation:live-pulse 2s infinite;flex:0 0 auto}
@keyframes live-pulse{0%{box-shadow:0 0 0 0 rgba(230,57,70,.6)}70%{box-shadow:0 0 0 12px rgba(230,57,70,0)}100%{box-shadow:0 0 0 0 rgba(230,57,70,0)}}

.hero-news-list{list-style:none;display:flex;flex-direction:column;gap:2px;padding:0;min-width:0}
.hero-news-item{list-style:none;min-width:0}
.hero-news-item a{display:flex;gap:14px;background:rgba(255,255,255,.03);padding:16px 18px;border-left:3px solid rgba(212,43,43,.35);transition:background .2s,border-color .2s,transform .15s;text-decoration:none;min-width:0}
.hero-news-item a:hover,
.hero-news-item.is-active a{background:rgba(255,255,255,.1);border-left-color:var(--red);transform:translateX(3px)}
.hero-news-item .hnum{font-family:var(--font-display);font-size:1.4rem;color:var(--red);line-height:1;min-width:28px;padding-top:2px;letter-spacing:.04em;flex:0 0 auto}
.hero-news-item .hbody{display:flex;flex-direction:column;gap:3px;flex:1 1 auto;min-width:0;overflow:hidden}
.hero-news-item .hcat{font-size:.6rem;color:var(--red);text-transform:uppercase;letter-spacing:.15em;font-weight:700}
.hero-news-item .htitle{font-size:.88rem;color:rgba(255,255,255,.88);font-weight:600;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-wrap:break-word;overflow-wrap:break-word}
.hero-news-item a:hover .htitle,
.hero-news-item.is-active .htitle{color:#fff}
.hero-mode-none .hero-inner{grid-template-columns:1fr;max-width:820px}

/* === SECTIONS === */
.section{padding:72px 32px}
.section-inner{max-width:var(--max-content);margin:0 auto}
.sec-header{margin-bottom:48px;display:flex;align-items:flex-end;justify-content:space-between;gap:24px}
.sec-eyebrow{font-size:.68rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:10px;display:flex;align-items:center;gap:8px}
.sec-eyebrow::before{content:'';width:20px;height:2px;background:var(--red);display:block}
.sec-title{font-family:var(--font-display);font-size:clamp(2rem,4vw,3.2rem);letter-spacing:.03em;line-height:1;color:var(--black)}
.sec-more{font-size:.76rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--grey);text-decoration:none;white-space:nowrap;border-bottom:1px solid transparent;transition:color .2s,border-color .2s;padding-bottom:2px}
.sec-more:hover{color:var(--black);border-color:var(--black)}

/* === MANIFEST === */
.manifest{background:var(--light);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:36px 32px;text-align:center}
.manifest-inner{max-width:800px;margin:0 auto}
.manifest-title{font-family:var(--font-display);font-size:clamp(1.6rem,3vw,2.2rem);letter-spacing:.04em;color:var(--black);margin-bottom:16px}
.manifest-title span{color:var(--red)}
.manifest-rules{display:flex;justify-content:center;gap:32px;flex-wrap:wrap}
.manifest-rule{font-size:.76rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--grey);display:flex;align-items:center;gap:7px}
.manifest-rule::before{content:'✓';color:var(--red)}

/* === MANIFEST BAR (kompaktowy, jednolinijkowy) === */
.manifest-bar{background:var(--black);color:#fff;border-bottom:2px solid var(--red)}
.manifest-bar-inner{max-width:var(--max-content);margin:0 auto;padding:13px 40px;display:flex;align-items:center;gap:24px;flex-wrap:wrap;font-size:.82rem}
.manifest-bar .mb-title{font-family:var(--font-body);font-weight:700;letter-spacing:.02em;color:#fff;white-space:nowrap}
.manifest-bar .mb-title span{color:var(--red)}
.manifest-bar .mb-sep{color:var(--red);flex:0 0 auto;font-weight:700;font-size:1.1em;line-height:1;padding:0 4px}
.manifest-bar .mb-rules{color:rgba(255,255,255,.6);font-size:.76rem;letter-spacing:.04em;flex:1 1 auto;min-width:0}
@media(max-width:700px){
  .manifest-bar-inner{padding:10px 16px;font-size:.76rem;gap:8px}
  .manifest-bar .mb-sep{display:none}
  .manifest-bar .mb-rules{flex-basis:100%;font-size:.7rem}
}

/* === CO DZIŚ ON === */
#codzis{background:var(--white);border-top:1px solid var(--border);padding-bottom:0}
.codzis-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);max-width:var(--max-content);margin:0 auto}
.codzis-item{background:var(--white);padding:28px 24px;display:flex;gap:18px;align-items:flex-start;cursor:pointer;transition:background .2s,color .2s;position:relative;overflow:hidden;text-decoration:none;color:inherit;isolation:isolate;min-height:130px}
.codzis-item .codzis-bg{position:absolute;inset:0;background:var(--thumb,none) center/cover no-repeat;opacity:0;transition:opacity .35s;z-index:-2}
.codzis-item::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,.75) 0%,rgba(10,10,10,.92) 100%);opacity:0;transition:opacity .35s;z-index:-1;pointer-events:none}
.codzis-item.has-thumb:hover .codzis-bg,.codzis-item.has-thumb:focus-visible .codzis-bg{opacity:1}
.codzis-item.has-thumb:hover::before,.codzis-item.has-thumb:focus-visible::before{opacity:1}
.codzis-item:not(.has-thumb):hover{background:var(--light)}
.codzis-item.has-thumb:hover,.codzis-item.has-thumb:focus-visible{color:var(--white)}
.codzis-item.has-thumb:hover .codzis-num{color:#fff}
.codzis-item.has-thumb:hover .codzis-text{color:#fff}
.codzis-item.has-thumb:hover .codzis-tag{color:#fff}
.codzis-item.has-thumb:hover .codzis-city{color:rgba(255,255,255,.6)}
.codzis-num{font-family:var(--font-display);font-size:3.5rem;line-height:1;color:var(--border);min-width:48px;transition:color .2s;z-index:1}
.codzis-item:hover .codzis-num{color:var(--red)}
.codzis-content{flex:1;min-width:0;z-index:1}
.codzis-tag{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--red);margin-bottom:5px;transition:color .2s}
.codzis-text{font-size:.92rem;font-weight:600;line-height:1.4;color:var(--black);transition:color .2s}
.codzis-city{font-size:.74rem;color:var(--grey);margin-top:6px;transition:color .2s}
.codzis-placeholder{background:var(--light);cursor:default}

/* === AKTUALNOŚCI — slider + lista z miniaturami === */
#aktualnosci{background:var(--light)}
.news-grid{display:grid;grid-template-columns:1.8fr 1fr;gap:24px}

/* Slider (lewa strona) */
.news-slider{position:relative;background:var(--black);overflow:hidden;min-height:460px;display:block}
.news-slide{position:absolute;inset:0;opacity:0;visibility:hidden;transition:opacity .6s ease;display:flex;align-items:flex-end;text-decoration:none;color:var(--white)}
.news-slide.is-active{opacity:1;visibility:visible;z-index:2}
.news-slide-bg{position:absolute;inset:0;background:center/cover no-repeat;z-index:0}
.news-slide-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,.25) 0%,rgba(10,10,10,.85) 100%);z-index:1}
.news-slide-content{position:relative;z-index:2;padding:40px;width:100%}
.news-slide::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--red);z-index:3}
.news-feat-cat{font-size:.68rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--red);margin-bottom:14px}
.news-feat-title{font-family:var(--font-display);font-size:clamp(1.7rem,2.5vw,2.3rem);letter-spacing:.02em;line-height:1.1;color:var(--white);margin-bottom:14px;text-shadow:0 2px 12px rgba(0,0,0,.4)}
.news-feat-excerpt{font-size:.88rem;color:rgba(247,246,242,.85);line-height:1.6;max-width:580px}
.news-feat-meta{margin-top:16px;font-size:.7rem;color:rgba(247,246,242,.55);letter-spacing:.05em;display:flex;gap:16px;flex-wrap:wrap}
.news-feat-link{margin-top:20px;display:inline-flex;align-items:center;gap:8px;color:var(--white);font-size:.8rem;font-weight:700;text-decoration:none;letter-spacing:.06em;text-transform:uppercase;transition:gap .2s,color .2s}
.news-slide:hover .news-feat-link{gap:14px;color:var(--red)}

/* Kontrolki slidera */
.news-slider-controls{position:absolute;bottom:14px;right:16px;z-index:5;display:flex;align-items:center;gap:10px;background:rgba(10,10,10,.5);backdrop-filter:blur(4px);padding:6px 10px;border-radius:0}
.nsc-btn{background:none;border:none;color:#fff;font-size:1.4rem;line-height:1;cursor:pointer;padding:4px 8px;opacity:.7;transition:opacity .2s}
.nsc-btn:hover{opacity:1}
.nsc-dots{display:flex;gap:6px}
.nsc-dot{width:8px;height:8px;background:rgba(255,255,255,.4);border:none;cursor:pointer;padding:0;transition:background .2s,width .2s;border-radius:0}
.nsc-dot.is-active{background:var(--red);width:20px}

/* Prawa lista — z miniaturkami */
.news-side{display:flex;flex-direction:column;gap:2px}
.news-small{background:var(--card);cursor:pointer;transition:background .2s,transform .15s;border-left:3px solid transparent;display:grid;grid-template-columns:88px 1fr;gap:0;text-decoration:none;min-height:84px}
.news-small:hover{background:var(--white);border-left-color:var(--red);transform:translateX(3px)}
.news-small.is-active{border-left-color:var(--red);background:var(--white)}
.ns-thumb{background:var(--light) center/cover no-repeat;display:block}
.ns-thumb-fallback{display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:1.4rem;color:var(--border);letter-spacing:.12em;background:var(--light)}
.ns-body{padding:12px 14px;display:flex;flex-direction:column;justify-content:center;min-width:0}
.ns-cat{font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--red);margin-bottom:4px}
.ns-title{font-size:.85rem;font-weight:600;line-height:1.35;color:var(--black);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ns-meta{font-size:.68rem;color:var(--grey);margin-top:4px}

/* === ON TŁUMACZY === */
#ontlumaczy{background:var(--black)}
#ontlumaczy .sec-title{color:var(--white)}
#ontlumaczy .sec-eyebrow{color:var(--red)}
.tl-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:rgba(255,255,255,.04)}
.tl-card{background:var(--black);padding:36px 28px;cursor:pointer;transition:background .2s;border-top:2px solid transparent;display:block;text-decoration:none}
.tl-card:hover{background:rgba(255,255,255,.06);border-top-color:var(--red)}
.tl-icon{font-size:1.5rem;margin-bottom:16px}
.tl-name{font-family:var(--font-display);font-size:1.4rem;letter-spacing:.04em;color:var(--white);margin-bottom:10px}
.tl-desc{font-size:.82rem;color:rgba(247,246,242,.35);line-height:1.65}
.tl-count{margin-top:18px;font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--red);display:flex;align-items:center;gap:6px}
.tl-count::before{content:'';width:12px;height:1px;background:var(--red)}

.tl-featured{grid-column:span 3;background:rgba(212,43,43,.08);border-top:2px solid var(--red);padding:32px 28px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:40px;align-items:center}
.tl-featured-title{font-family:var(--font-display);font-size:1.6rem;letter-spacing:.04em;color:var(--white);margin-top:8px}
.tl-featured-title span{color:var(--red)}
.tl-featured-label{font-size:.68rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:rgba(247,246,242,.3)}
.tl-featured-desc{font-size:.84rem;color:rgba(247,246,242,.45);line-height:1.65}
.tl-sample{background:rgba(255,255,255,.04);padding:20px;border-left:2px solid var(--red)}
.tl-sample-q{font-size:.72rem;color:rgba(247,246,242,.3);margin-bottom:8px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.tl-sample-a{font-size:.86rem;color:rgba(247,246,242,.65);line-height:1.5}

/* === ON SPRAWDZA === */
#onsprawdza{background:var(--light);border-top:1px solid var(--border)}
.sprawdza-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:var(--border)}
.sprawdza-card{background:var(--white);cursor:pointer;transition:background .15s;text-decoration:none;display:block;overflow:hidden}
.sprawdza-card:hover{background:var(--light)}
.sprawdza-card:not(.has-thumb) .sc-content{padding:30px 26px}
.sprawdza-card.has-thumb{display:grid;grid-template-columns:160px 1fr;gap:0;align-items:stretch}
.sprawdza-card.has-thumb .sc-thumb{background:var(--light) center/cover no-repeat;min-height:100%}
.sprawdza-card.has-thumb .sc-content{padding:24px 26px;min-width:0}
.sc-status{display:inline-flex;align-items:center;gap:6px;font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 12px;margin-bottom:14px}
.sc-status.fail{background:rgba(212,43,43,.08);color:var(--red)}
.sc-status.ok{background:rgba(40,140,60,.08);color:#258c3c}
.sc-status.pending{background:rgba(180,120,0,.08);color:#b47800}
.sc-status::before{content:'●';font-size:.55rem}
.sc-title{font-size:.98rem;font-weight:700;line-height:1.4;margin-bottom:10px;color:var(--black)}
.sc-body{font-size:.83rem;color:var(--grey);line-height:1.6}
.sc-meta{margin-top:14px;font-size:.7rem;color:rgba(0,0,0,.3);display:flex;gap:16px;flex-wrap:wrap}

/* === GMINY === */
#gminy{background:var(--white);border-top:1px solid var(--border)}
.gminy-layout{display:grid;grid-template-columns:1fr 310px;gap:36px}
.gminy-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;background:var(--border)}
.gmina-tile{background:var(--white);padding:18px 14px;text-align:center;cursor:pointer;transition:background .15s,color .15s;position:relative}
.gmina-tile::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:0;height:2px;background:var(--red);transition:width .2s}
.gmina-tile:hover,.gmina-tile.active{background:var(--black);color:var(--white)}
.gmina-tile:hover::after,.gmina-tile.active::after{width:80%}
.gmina-tile.city{background:var(--red);color:#fff}
.gmina-tile.city:hover{background:#b82020}
.gt-name{font-size:.8rem;font-weight:700;letter-spacing:.03em}
.gt-type{font-size:.62rem;opacity:.5;margin-top:3px}
.gmina-panel{background:var(--light);padding:26px}
.gp-name{font-family:var(--font-display);font-size:1.8rem;letter-spacing:.04em;color:var(--black);margin-bottom:3px}
.gp-type{font-size:.72rem;color:var(--grey);margin-bottom:18px;text-transform:uppercase;letter-spacing:.1em}
.gp-stat{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--border);font-size:.82rem}
.gp-stat:last-of-type{border:none}
.gp-stat-key{color:var(--grey)}
.gp-stat-val{font-weight:700;color:var(--black)}
.gp-link{display:block;margin-top:18px;background:var(--black);color:#fff;text-align:center;padding:11px;font-size:.76rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;transition:background .2s}
.gp-link:hover{background:var(--red)}

/* === INFORMACJE === */
#informacje{background:var(--black)}
#informacje .sec-title{color:var(--white)}
#informacje .sec-eyebrow{color:var(--red)}
.info-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;background:rgba(255,255,255,.06)}
.info-card{background:var(--black);padding:30px 22px;transition:background .2s;cursor:pointer;border-bottom:2px solid transparent}
.info-card:hover{background:rgba(255,255,255,.05);border-bottom-color:var(--red)}
.ic-icon{font-size:1.4rem;margin-bottom:14px}
.ic-title{font-family:var(--font-display);font-size:1.2rem;letter-spacing:.04em;color:var(--white);margin-bottom:10px}
.ic-text{font-size:.78rem;color:rgba(247,246,242,.32);line-height:1.6}
.ic-link{display:inline-block;margin-top:14px;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--red);text-decoration:none}

/* === KONTAKTY === */
#kontakty{background:var(--white);border-top:1px solid var(--border)}
.kontakty-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.kont-card{border:1px solid var(--border);transition:box-shadow .2s,transform .2s}
.kont-card:hover{box-shadow:0 12px 40px rgba(0,0,0,.08);transform:translateY(-3px)}
.kont-header{background:var(--black);padding:20px 22px;display:flex;gap:14px;align-items:center}
.kont-icon{font-size:1.3rem}
.kont-hname{font-family:var(--font-display);font-size:1.1rem;letter-spacing:.04em;color:var(--white)}
.kont-htype{font-size:.68rem;color:rgba(247,246,242,.3);margin-top:3px;letter-spacing:.08em;text-transform:uppercase}
.kont-body{padding:20px 22px;background:var(--card)}
.kont-row{display:flex;gap:12px;padding:9px 0;border-bottom:1px solid var(--border);font-size:.82rem;align-items:center}
.kont-row:last-child{border:none}
.kont-row-ico{color:var(--grey);min-width:16px}
.kont-btn{display:block;margin-top:18px;background:var(--black);color:#fff;text-align:center;padding:11px;font-size:.76rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;transition:background .2s}
.kont-btn:hover{background:var(--red)}

/* === PARTNER CTA === */
.partner-cta{background:var(--red);padding:64px 32px;text-align:center}
.pcta-inner{max-width:680px;margin:0 auto}
.pcta-eyebrow{font-size:.68rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:12px}
.pcta-title{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.5rem);letter-spacing:.04em;color:#fff;line-height:1;margin-bottom:14px}
.pcta-sub{font-size:.92rem;color:rgba(255,255,255,.65);margin-bottom:30px;line-height:1.6}
.pcta-packages{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-bottom:28px;max-width:840px;margin-left:auto;margin-right:auto;text-align:left}
.pcta-pkg{background:rgba(0,0,0,.2);padding:20px}
.pcta-pkg-name{font-family:var(--font-display);font-size:1.3rem;letter-spacing:.06em;color:#fff}
.pcta-pkg-price{font-size:1.4rem;font-weight:700;color:#fff;margin:6px 0 4px}
.pcta-pkg-price span{font-size:.82rem;font-weight:400;opacity:.55}
.pcta-pkg-desc{font-size:.75rem;color:rgba(255,255,255,.5);line-height:1.5}
.btn-white{background:#fff;color:var(--red);padding:14px 36px;font-size:.88rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;display:inline-block;transition:transform .15s}
.btn-white:hover{transform:translateY(-2px)}

/* === FOOTER === */
.site-footer{background:var(--black);padding:56px 32px 28px;border-top:2px solid var(--red)}
.foot-inner{max-width:var(--max-content);margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.07)}
.foot-brand .logo{font-size:2.4rem;margin-bottom:14px;display:inline-block}
.foot-brand p{font-size:.8rem;color:rgba(247,246,242,.32);line-height:1.7;max-width:280px}
.foot-brand .claim{color:rgba(247,246,242,.14);font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;margin-top:10px;font-style:italic}
.foot-col h4{font-size:.68rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:rgba(247,246,242,.28);margin-bottom:16px}
.foot-col ul{list-style:none}
.foot-col li{margin-bottom:10px}
.foot-col a{font-size:.8rem;color:rgba(247,246,242,.38);text-decoration:none;transition:color .2s}
.foot-col a:hover{color:var(--white)}
.foot-bottom{max-width:var(--max-content);margin:22px auto 0;display:flex;justify-content:space-between;font-size:.72rem;color:rgba(247,246,242,.18);flex-wrap:wrap;gap:8px}
.foot-bottom a{color:rgba(247,246,242,.18);text-decoration:none}

/* === ANIMATIONS === */
@keyframes fadeInUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
.ani{opacity:0;transform:translateY(28px)}
.ani.visible{opacity:1;transform:translateY(0);transition:opacity .65s ease,transform .65s ease}
.ani-d1{transition-delay:.1s}
.ani-d2{transition-delay:.2s}
.ani-d3{transition-delay:.3s}

/* === SINGLE POST === */
.single-post-wrapper{margin-top:56px;padding:48px 32px;max-width:800px;margin-left:auto;margin-right:auto;min-width:0}
.single-post-wrapper .entry-meta{font-size:.72rem;color:var(--grey);letter-spacing:.08em;text-transform:uppercase;margin-bottom:16px;display:flex;gap:16px;flex-wrap:wrap;min-width:0;max-width:100%}
.single-post-wrapper .entry-meta > *{min-width:0;max-width:100%;overflow-wrap:anywhere;word-wrap:break-word}
.single-post-wrapper .entry-title{font-family:var(--font-display);font-size:clamp(2.2rem,5vw,3.5rem);letter-spacing:.02em;line-height:1.05;color:var(--black);margin-bottom:24px;overflow-wrap:break-word;word-wrap:break-word;hyphens:auto}
.single-post-wrapper .entry-content{font-size:1rem;line-height:1.75;color:var(--black);max-width:100%;min-width:0;overflow-wrap:break-word;word-wrap:break-word}
.single-post-wrapper .entry-content p{margin-bottom:1.4em}
.single-post-wrapper .entry-content h2,.single-post-wrapper .entry-content h3{font-family:var(--font-display);letter-spacing:.03em;margin:2em 0 .8em;overflow-wrap:break-word;word-wrap:break-word}
.single-post-wrapper .entry-content img{margin:2em 0;max-width:100%;height:auto}
.single-post-wrapper .entry-content iframe,.single-post-wrapper .entry-content video,.single-post-wrapper .entry-content embed{max-width:100%;height:auto}
.single-post-wrapper .entry-content figure{margin-left:0;margin-right:0;max-width:100%}
.single-post-wrapper .entry-content table{display:block;max-width:100%;overflow-x:auto}
.single-post-wrapper .entry-content pre{max-width:100%;overflow-x:auto;white-space:pre-wrap}
.single-post-wrapper .post-thumbnail{width:100%;max-width:100%;height:auto;margin-bottom:32px}

/* === SHARE BUTTONS — okrągłe ikony nachodzące na zdjęcie === */
.post-thumbnail-wrap{position:relative;margin-bottom:48px}
.post-thumbnail-wrap .post-thumbnail{margin-bottom:0}
.post-share{
    position:absolute;
    bottom:-22px;
    left:24px;
    display:flex;
    gap:8px;
    z-index:5;
    flex-wrap:wrap;
}
.post-share-no-thumb{margin:0 0 32px}
.post-share-no-thumb .post-share{position:static;left:auto;bottom:auto;justify-content:flex-start}
.ps-btn{
    position:relative;
    display:flex;
    align-items:center;
    justify-content:center;
    width:44px;
    height:44px;
    background:#fff;
    border-radius:50%;
    box-shadow:0 4px 16px rgba(0,0,0,.18);
    color:#333;
    text-decoration:none;
    transition:transform .2s ease,background .2s ease,color .2s ease,box-shadow .2s ease;
    cursor:pointer;
    border:0;
    flex:0 0 auto;
}
.ps-btn svg{width:20px;height:20px;display:block}
.ps-btn:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.25)}
.ps-btn-facebook:hover{background:#1877F2;color:#fff}
.ps-btn-x:hover{background:#000;color:#fff}
.ps-btn-whatsapp:hover{background:#25D366;color:#fff}
.ps-btn-copy:hover{background:var(--red);color:#fff}

/* Tooltip z nazwą sieci */
.ps-tooltip{
    position:absolute;
    bottom:calc(100% + 8px);
    left:50%;
    transform:translateX(-50%) translateY(4px);
    background:#0a0a0a;
    color:#fff;
    font-size:.7rem;
    font-weight:600;
    letter-spacing:.04em;
    padding:6px 10px;
    border-radius:4px;
    white-space:nowrap;
    opacity:0;
    pointer-events:none;
    transition:opacity .2s ease,transform .2s ease;
}
.ps-tooltip::after{
    content:'';
    position:absolute;
    top:100%;
    left:50%;
    transform:translateX(-50%);
    border:5px solid transparent;
    border-top-color:#0a0a0a;
}
.ps-btn:hover .ps-tooltip{opacity:1;transform:translateX(-50%) translateY(0)}

/* "Skopiowano!" — krótki feedback po kliknięciu copy */
.ps-copied{
    position:absolute;
    bottom:calc(100% + 8px);
    left:50%;
    transform:translateX(-50%);
    background:var(--red);
    color:#fff;
    font-size:.7rem;
    font-weight:700;
    letter-spacing:.04em;
    padding:6px 10px;
    border-radius:4px;
    white-space:nowrap;
    z-index:10;
}
.ps-copied[hidden]{display:none}

/* === SCROLL-TO-TOP — okrągły przycisk z pierścieniem postępu === */
.slup-scrolltop{
    position:fixed;
    right:24px;
    bottom:24px;
    width:48px;
    height:48px;
    padding:0;
    border:0;
    background:transparent;
    cursor:pointer;
    z-index:200;
    opacity:0;
    transform:translateY(12px) scale(.9);
    transition:opacity .25s ease,transform .25s ease;
    pointer-events:none;
}
.slup-scrolltop.is-visible{
    opacity:1;
    transform:translateY(0) scale(1);
    pointer-events:auto;
}
.slup-scrolltop[hidden]{display:none}

/* Pierścień postępu — conic-gradient czerwony do "--progress", reszta przezroczysta.
   W środku „dziurka" (mask) o szerokości pasującej do 2px obwódki. */
.slup-scrolltop .ss-progress{
    position:absolute;
    inset:0;
    border-radius:50%;
    background:conic-gradient(var(--red) calc(var(--scroll-progress, 0) * 1deg), rgba(255,255,255,.18) 0);
    -webkit-mask:radial-gradient(circle, transparent 19px, #000 20px);
            mask:radial-gradient(circle, transparent 19px, #000 20px);
    pointer-events:none;
}

/* Czarne tło + biała strzałka w środku pierścienia */
.slup-scrolltop::after{
    content:'';
    position:absolute;
    inset:3px;
    border-radius:50%;
    background:#0a0a0a;
    box-shadow:0 4px 16px rgba(0,0,0,.3);
    transition:background .2s ease,box-shadow .2s ease;
}
.slup-scrolltop:hover::after{
    background:var(--red);
    box-shadow:0 6px 20px rgba(212,43,43,.4);
}
.slup-scrolltop .ss-arrow{
    position:relative;
    z-index:1;
    width:18px;
    height:18px;
    color:#fff;
    transition:transform .2s ease;
}
.slup-scrolltop:hover .ss-arrow{transform:translateY(-2px)}

@media (max-width:600px){
    .slup-scrolltop{right:16px;bottom:16px;width:44px;height:44px}
    .slup-scrolltop .ss-progress{
        -webkit-mask:radial-gradient(circle, transparent 17px, #000 18px);
                mask:radial-gradient(circle, transparent 17px, #000 18px);
    }
    .slup-scrolltop .ss-arrow{width:16px;height:16px}
}

@media (prefers-reduced-motion: reduce){
    .slup-scrolltop{transition:opacity .15s ease}
    .slup-scrolltop:hover .ss-arrow{transform:none}
}

/* === ARCHIVE / CATEGORY === */
.archive-wrapper{margin-top:56px;padding:48px 32px}
.archive-wrapper .section-inner{max-width:var(--max-content);margin:0 auto}
.archive-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:32px}
.archive-card{background:var(--card);border:1px solid var(--border);transition:box-shadow .2s,transform .2s;text-decoration:none;display:block}
.archive-card:hover{box-shadow:0 8px 30px rgba(0,0,0,.06);transform:translateY(-3px)}
.archive-card .card-thumb{width:100%;height:200px;object-fit:cover}
.archive-card .card-body{padding:20px}
.archive-card .card-cat{font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--red);margin-bottom:6px}
.archive-card .card-title{font-size:.95rem;font-weight:700;line-height:1.35;color:var(--black);margin-bottom:8px}
.archive-card .card-excerpt{font-size:.82rem;color:var(--grey);line-height:1.55}
.archive-card .card-meta{font-size:.7rem;color:rgba(0,0,0,.3);margin-top:10px}

/* === PAGINATION === */
.pagination{display:flex;justify-content:center;gap:8px;margin-top:48px}

/* === INFINITE SCROLL ARCHIVE === */
.archive-loader{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:14px;
    padding:48px 16px;
    color:var(--grey);
    font-size:.85rem;
    letter-spacing:.04em;
    opacity:0;
    transition:opacity .3s ease;
}
.archive-loader.is-loading{opacity:1}
.al-spinner{
    width:22px;
    height:22px;
    border:2px solid rgba(212,43,43,.18);
    border-top-color:var(--red);
    border-radius:50%;
    animation:al-spin .8s linear infinite;
}
@keyframes al-spin{to{transform:rotate(360deg)}}
.archive-load-more{
    display:block;
    margin:32px auto 0;
    padding:14px 32px;
    background:var(--red);
    color:#fff;
    border:none;
    font-family:inherit;
    font-size:.85rem;
    font-weight:700;
    letter-spacing:.08em;
    text-transform:uppercase;
    cursor:pointer;
    transition:background .2s,transform .15s;
}
.archive-load-more:hover{background:#b82020;transform:translateY(-2px)}
.archive-end{
    text-align:center;
    padding:48px 16px;
    color:var(--grey);
    font-size:.78rem;
    letter-spacing:.18em;
    text-transform:uppercase;
}
.archive-end::before,
.archive-end::after{
    content:'·';
    margin:0 14px;
    color:var(--red);
}
.pagination a,.pagination span{padding:8px 14px;font-size:.8rem;font-weight:600;background:var(--card);border:1px solid var(--border);color:var(--black);transition:all .2s}
.pagination a:hover{background:var(--black);color:var(--white)}
.pagination .current{background:var(--red);color:#fff;border-color:var(--red)}

/* === SEKCJE DYNAMICZNE === */
.section-dynamic{padding:72px 32px}
.section-dynamic .section-inner{max-width:var(--max-content);margin:0 auto}
.section-dynamic .sec-subtitle{font-size:.88rem;color:var(--grey);margin-top:8px;max-width:600px;line-height:1.55}

/* Warianty tła */
.section-dynamic.bg-default{background:var(--white)}
.section-dynamic.bg-light{background:var(--light);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.section-dynamic.bg-dark{background:var(--black)}
.section-dynamic.bg-dark .sec-title,.section-dynamic.bg-dark .dyn-card-title,.section-dynamic.bg-dark .dyn-feat-title,.section-dynamic.bg-dark .dyn-side-title,.section-dynamic.bg-dark .dcn-title,.section-dynamic.bg-dark .dyn-slide-title{color:var(--white)}
.section-dynamic.bg-dark .sec-eyebrow{color:var(--red)}
.section-dynamic.bg-dark .sec-subtitle{color:rgba(247,246,242,.55)}
.section-dynamic.bg-dark .dyn-card{background:rgba(255,255,255,.04);color:rgba(247,246,242,.85)}
.section-dynamic.bg-dark .dyn-card:hover{background:rgba(255,255,255,.07)}
.section-dynamic.bg-dark .dyn-card-excerpt,.section-dynamic.bg-dark .dyn-meta{color:rgba(247,246,242,.5)}
.section-dynamic.bg-dark .sec-more{color:rgba(247,246,242,.4)}
.section-dynamic.bg-dark .sec-more:hover{color:var(--white);border-color:var(--white)}
.section-dynamic.bg-dark .dyn-compact-item a{background:rgba(255,255,255,.04)}
.section-dynamic.bg-dark .dyn-compact-item a:hover{background:rgba(255,255,255,.08)}
.section-dynamic.bg-dark .dcn-title{color:var(--white)}

.section-dynamic.bg-red{background:var(--red)}
.section-dynamic.bg-red .sec-title,.section-dynamic.bg-red .dyn-card-title,.section-dynamic.bg-red .dyn-feat-title,.section-dynamic.bg-red .dyn-side-title,.section-dynamic.bg-red .dcn-title,.section-dynamic.bg-red .dyn-slide-title{color:#fff}
.section-dynamic.bg-red .sec-eyebrow{color:rgba(255,255,255,.75)}
.section-dynamic.bg-red .sec-eyebrow::before{background:#fff}
.section-dynamic.bg-red .sec-subtitle{color:rgba(255,255,255,.75)}
.section-dynamic.bg-red .dyn-cat{color:#fff;opacity:.85}
.section-dynamic.bg-red .dyn-card{background:rgba(0,0,0,.15);color:rgba(255,255,255,.92)}
.section-dynamic.bg-red .dyn-card:hover{background:rgba(0,0,0,.25)}
.section-dynamic.bg-red .dyn-card-excerpt,.section-dynamic.bg-red .dyn-meta{color:rgba(255,255,255,.7)}
.section-dynamic.bg-red .sec-more{color:rgba(255,255,255,.85)}
.section-dynamic.bg-red .sec-more:hover{color:#fff;border-color:#fff}
.section-dynamic.bg-red .dyn-compact-item a{background:rgba(0,0,0,.15)}
.section-dynamic.bg-red .dyn-compact-item a:hover{background:rgba(0,0,0,.25)}

/* Grid 3/4 kolumny */
.dyn-grid{display:grid;gap:2px;background:var(--border)}
.dyn-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.dyn-grid.cols-4{grid-template-columns:repeat(4,1fr)}
.section-dynamic.bg-dark .dyn-grid,.section-dynamic.bg-red .dyn-grid{background:transparent;gap:12px}
.dyn-card{background:var(--white);padding:0;text-decoration:none;color:inherit;display:flex;flex-direction:column;transition:background .2s,transform .15s,box-shadow .2s}
.dyn-card:hover{transform:translateY(-2px)}
.dyn-card.has-thumb .dyn-card-body{padding-top:14px}
.dyn-card-thumb{width:100%;aspect-ratio:16/10;background:var(--light) center/cover no-repeat}
.dyn-card-body{padding:18px 20px}
.dyn-cat{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--red);font-weight:700;margin-bottom:6px}
.dyn-card-title{font-size:.95rem;font-weight:700;line-height:1.35;color:var(--black);margin-bottom:8px}
.dyn-card-excerpt{font-size:.8rem;color:var(--grey);line-height:1.55}
.dyn-meta{font-size:.68rem;color:rgba(0,0,0,.35);margin-top:8px;letter-spacing:.03em}

/* Feature (1 duży + N bocznych — count decyduje o liczbie bocznych) */
.dyn-feature{display:grid;grid-template-columns:1.6fr 1fr;gap:24px;align-items:stretch}
.dyn-feat-main{position:relative;min-height:430px;display:flex;align-items:flex-end;background:var(--black);text-decoration:none;color:var(--white);overflow:hidden;transition:transform .2s}
.dyn-feat-main:hover{transform:translateY(-2px)}
.dyn-feat-bg{position:absolute;inset:0;background:center/cover no-repeat;z-index:0;transition:opacity .35s ease,background-image .35s ease}
.dyn-feat-main::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,.2) 0%,rgba(10,10,10,.88) 100%);z-index:1}
.dyn-feat-main::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--red);z-index:2}
.dyn-feat-body{position:relative;z-index:2;padding:36px}
.dyn-feat-title{font-family:var(--font-display);font-size:clamp(1.6rem,2.4vw,2.2rem);letter-spacing:.02em;line-height:1.12;color:#fff;margin:8px 0 10px;text-shadow:0 2px 12px rgba(0,0,0,.4)}
.dyn-feat-excerpt{font-size:.86rem;color:rgba(255,255,255,.85);line-height:1.55;max-width:560px}
.dyn-feat-side{display:flex;flex-direction:column;gap:2px}
.dyn-side-card{background:var(--white);padding:0;text-decoration:none;color:inherit;display:grid;grid-template-columns:100px 1fr;transition:background .2s,transform .15s,border-color .2s;min-height:96px;border-left:3px solid transparent}
.dyn-side-card:hover{background:var(--light);transform:translateX(3px);border-left-color:var(--red)}
.dyn-side-card.is-active{background:var(--light);border-left-color:var(--red)}
.dyn-side-thumb{background:var(--light) center/cover no-repeat}
.dyn-side-body{padding:12px 14px;display:flex;flex-direction:column;justify-content:center;min-width:0}
.dyn-side-title{font-size:.85rem;font-weight:700;line-height:1.35;color:var(--black);margin:3px 0 4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* Slider (dynamiczny) */
.dyn-slider{position:relative;min-height:420px;background:var(--black);overflow:hidden}
.dyn-slide{position:absolute;inset:0;opacity:0;visibility:hidden;transition:opacity .6s;display:flex;align-items:flex-end;text-decoration:none;color:#fff}
.dyn-slide.is-active{opacity:1;visibility:visible;z-index:2}
.dyn-slide-bg{position:absolute;inset:0;background:center/cover no-repeat;z-index:0}
.dyn-slide::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,.2) 0%,rgba(10,10,10,.88) 100%);z-index:1}
.dyn-slide-body{position:relative;z-index:2;padding:40px;width:100%}
.dyn-slide-title{font-family:var(--font-display);font-size:clamp(1.6rem,2.4vw,2.3rem);letter-spacing:.02em;line-height:1.12;color:#fff;margin:8px 0 8px}
.dyn-slider-dots{position:absolute;bottom:14px;right:16px;z-index:5;display:flex;gap:6px;background:rgba(10,10,10,.5);padding:8px 12px}
.dsd-dot{width:8px;height:8px;background:rgba(255,255,255,.4);border:none;cursor:pointer;padding:0;transition:background .2s,width .2s}
.dsd-dot.is-active{background:var(--red);width:20px}

/* Compact list */
.dyn-compact{list-style:none;display:flex;flex-direction:column;gap:2px}
.dyn-compact-item{list-style:none}
.dyn-compact-item a{display:grid;grid-template-columns:80px 1fr;background:var(--white);text-decoration:none;color:inherit;transition:background .2s,transform .15s;min-height:72px}
.dyn-compact-item a:hover{background:var(--light);transform:translateX(3px)}
.dcn-thumb{background:var(--light) center/cover no-repeat}
.dcn-body{padding:12px 16px;display:flex;flex-direction:column;justify-content:center;min-width:0}
.dcn-title{font-size:.88rem;font-weight:600;line-height:1.4;color:var(--black);margin:3px 0 3px}

/* === GMINY — dodatki do istniejącego === */
.gmina-tile{cursor:pointer}
.gmina-panel .gp-link[target="_blank"]::after{content:' ↗';opacity:.6}

/* === SIDEBAR LAYOUTS === */
.layout-wrap{margin-top:56px;padding:48px 32px;display:block;max-width:1260px;margin-left:auto;margin-right:auto}
.layout-wrap.layout-full .single-post-wrapper{max-width:1100px;margin:0 auto;padding:0}
.layout-wrap.layout-narrow .single-post-wrapper{max-width:800px;margin:0 auto;padding:0}
.layout-wrap.layout-sidebar-right,.layout-wrap.layout-sidebar-left{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:48px;align-items:flex-start}
.layout-wrap.layout-sidebar-left{grid-template-columns:300px minmax(0,1fr)}
.layout-wrap.layout-sidebar-right .single-post-wrapper,.layout-wrap.layout-sidebar-left .single-post-wrapper{max-width:none;padding:0;margin:0}
.sidebar{position:sticky;top:76px;align-self:start;padding:0;display:flex;flex-direction:column;gap:20px}
.sidebar.is-no-sticky{position:static}
.sidebar .widget{background:var(--white);border:1px solid var(--border);padding:22px 22px 18px;margin:0;position:relative}
.sidebar .widget::before{content:'';position:absolute;top:0;left:0;width:36px;height:2px;background:var(--red)}
.sidebar .widget-title{font-family:var(--font-display);font-size:1.1rem;letter-spacing:.06em;margin-bottom:16px;color:var(--black);text-transform:uppercase;line-height:1}

/* Listy w widgetach (ostatnie wpisy, kategorie, archiwum, strony, meta, nav_menu) */
.sidebar .widget ul{list-style:none;padding:0;margin:0}
.sidebar .widget li{padding:10px 0;border-bottom:1px solid var(--border);font-size:.84rem;line-height:1.4;display:flex;align-items:center;gap:10px}
.sidebar .widget li:last-child{border:none;padding-bottom:0}
.sidebar .widget li::before{content:'›';color:var(--red);font-weight:700;font-size:.95rem;flex:0 0 auto}
.sidebar .widget a{color:var(--black);text-decoration:none;transition:color .15s;flex:1;min-width:0}
.sidebar .widget a:hover{color:var(--red)}
.sidebar .widget .post-date,.sidebar .widget .rss-date,.sidebar .widget .comment-author-link{color:var(--grey);font-size:.72rem}
.sidebar .widget li .children{margin-left:12px;border-top:1px solid var(--border);margin-top:10px;padding-top:6px;flex:1 1 100%}
.sidebar .widget li .children li{padding:6px 0;font-size:.78rem}
.sidebar .widget li .cat-count,.sidebar .widget li .count{color:var(--grey);font-size:.7rem;margin-left:auto;background:var(--light);padding:2px 8px;border-radius:10px}

/* Wyszukiwarka i formularze */
.sidebar .widget form{display:flex;gap:6px}
.sidebar .widget .search-field,.sidebar .widget input[type="search"],.sidebar .widget input[type="text"]{flex:1;padding:8px 10px;font-size:.82rem;border:1px solid var(--border);background:var(--white);font-family:inherit}
.sidebar .widget .search-submit,.sidebar .widget input[type="submit"],.sidebar .widget button[type="submit"]{background:var(--red);color:#fff;border:none;padding:8px 14px;font-size:.76rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:background .15s;font-family:inherit}
.sidebar .widget .search-submit:hover,.sidebar .widget input[type="submit"]:hover,.sidebar .widget button[type="submit"]:hover{background:#b82020}

/* Chmura tagów */
.sidebar .widget .tagcloud{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.sidebar .widget .tagcloud a{font-size:.75rem !important;padding:5px 10px;border:1px solid var(--border);background:var(--light);color:var(--black);transition:background .15s,border-color .15s;flex:0 0 auto}
.sidebar .widget .tagcloud a:hover{background:var(--red);border-color:var(--red);color:#fff}

.sidebar .widget img{max-width:100%;height:auto;display:block;margin:4px 0}
.sidebar .widget select{width:100%;padding:8px 10px;font-size:.82rem;border:1px solid var(--border);background:var(--white);font-family:inherit}
.em-cat{color:var(--red);text-decoration:none}
.em-cat:hover{text-decoration:underline}

/* === BREADCRUMBS === */
.slup-breadcrumbs{padding:18px 0 10px;margin-bottom:8px;border-bottom:1px solid var(--border)}
.slup-bc-list{list-style:none;display:flex;flex-wrap:wrap;align-items:center;gap:6px;padding:0;margin:0;font-size:.74rem;letter-spacing:.04em}
.slup-bc-item{list-style:none;display:flex;align-items:center;gap:6px}
.slup-bc-item::after{content:'›';color:var(--grey);margin-left:6px;font-weight:700}
.slup-bc-item:last-child::after{display:none}
.slup-bc-item a{color:var(--grey);text-decoration:none;transition:color .15s;text-transform:uppercase;font-weight:600}
.slup-bc-item a:hover{color:var(--red)}
.slup-bc-item.is-current span{color:var(--black);font-weight:600;text-transform:none;letter-spacing:.01em;font-size:.76rem}

/* === TAGI POD WPISEM === */
.entry-tags{margin:32px 0 24px;padding:20px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);display:flex;align-items:center;flex-wrap:wrap;gap:8px}
.et-label{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--grey);margin-right:4px}
.et-tag{display:inline-block;padding:6px 12px;background:var(--light);border:1px solid var(--border);font-size:.78rem;color:var(--black);text-decoration:none;transition:all .15s;letter-spacing:.01em}
.et-tag:hover{background:var(--red);border-color:var(--red);color:#fff}

/* === NAWIGACJA PREV/NEXT === */
.entry-nav{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:24px 0 8px}
.entry-nav > a,.entry-nav > span{display:flex;flex-direction:column;gap:6px;padding:16px 18px;background:var(--white);border:1px solid var(--border);text-decoration:none;transition:background .15s,transform .15s,border-color .15s;min-height:80px}
.entry-nav a:hover{background:var(--light);border-color:var(--red);transform:translateY(-2px)}
.entry-nav .en-dir{font-size:.68rem;color:var(--red);font-weight:700;letter-spacing:.12em;text-transform:uppercase}
.entry-nav .en-title{font-size:.88rem;font-weight:600;color:var(--black);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.entry-nav .en-next{text-align:right}

/* === POWIĄZANE NEWSY (pod wpisem) === */
.related-posts{margin-top:64px;padding-top:48px;border-top:1px solid var(--border)}
.related-posts .sec-header{margin-bottom:24px}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.related-more-wrap{margin-top:28px;text-align:center}
.related-more-wrap .btn-red{cursor:pointer;border:none;font-family:inherit}
.related-more-wrap .btn-red[disabled]{opacity:.4;cursor:not-allowed}

/* === MOBILE MEGA-MENU === */
.nav-links.open .sub-menu{position:static;display:block;border:none;border-top:1px solid rgba(255,255,255,.06);padding:0;background:rgba(0,0,0,.35)}
.nav-links.open .sub-menu a{padding-left:40px;font-size:.7rem}

/* === FILTR LOKALNY — pasek statusu === */
.local-bar{background:#0a0a0a;border-bottom:1px solid var(--red);color:#fff}
.local-bar-inner{max-width:var(--max-content);margin:0 auto;padding:10px 32px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.lb-eyebrow{font-size:.68rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--red)}
.lb-name{font-family:var(--font-display);font-size:1.1rem;letter-spacing:.04em;color:#fff}
.lb-desc{font-size:.78rem;color:rgba(255,255,255,.55);font-style:italic;flex:1}
.lb-reset{margin-left:auto;background:transparent;border:1px solid rgba(255,255,255,.25);color:rgba(255,255,255,.7);font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:6px 14px;cursor:pointer;transition:border-color .2s,color .2s,background .2s;font-family:inherit}
.lb-reset:hover{border-color:var(--red);color:#fff;background:var(--red)}

/* === GMINY — dodatki: opis + przycisk lokalny === */
.gmina-panel .gp-desc{margin-top:14px;margin-bottom:14px;font-size:.82rem;color:var(--grey);line-height:1.6;border-left:2px solid var(--border);padding-left:12px}
.gmina-panel .gp-actions{display:flex;flex-direction:column;gap:8px;margin-top:14px}
.gp-local-btn{background:var(--red);color:#fff;border:none;padding:11px 14px;font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:background .2s,transform .15s;font-family:inherit}
.gp-local-btn:hover{background:#b82020;transform:translateY(-1px)}
.gp-local-btn.is-active{background:#258c3c}
.gp-local-btn.is-active:hover{background:#1c6d2e}
.gp-local-btn[disabled]{opacity:.5;cursor:wait}
.gmina-tile.is-local-active{box-shadow:inset 0 0 0 2px var(--red);position:relative}
.gmina-tile.is-local-active::before{content:'★';position:absolute;top:4px;right:6px;color:var(--red);font-size:.7rem}
.gmina-tile.is-local-active.city::before{color:#fff}

/* === WIDGETY === */
.slup-widget{padding:0;margin-bottom:24px}
.slup-widget .slupw-head{margin-bottom:14px}
.slup-widget .slupw-eyebrow{font-size:.62rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--red);margin-bottom:4px;display:flex;align-items:center;gap:8px}
.slup-widget .slupw-eyebrow::before{content:'';width:18px;height:2px;background:var(--red);display:block}
.slup-widget .slupw-title{font-family:var(--font-display);font-size:1.4rem;letter-spacing:.04em;line-height:1;color:var(--black)}
.slup-widget .slupw-list{list-style:none;display:flex;flex-direction:column;gap:2px;padding:0;margin:0}
.slup-widget .slupw-item{list-style:none;padding:0;border:none}
.slup-widget .slupw-item a{display:grid;grid-template-columns:1fr;gap:0;padding:12px 14px;background:rgba(0,0,0,.02);text-decoration:none;transition:background .2s,transform .15s;border-left:3px solid transparent}
.slup-widget .slupw-item a:hover{background:rgba(0,0,0,.05);border-left-color:var(--red);transform:translateX(3px)}
.slup-widget .slupw-cat{font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;color:var(--red);font-weight:700;margin-bottom:4px;display:block}
.slup-widget .slupw-itemtitle{font-size:.86rem;font-weight:600;line-height:1.35;color:var(--black);display:block}
.slup-widget .slupw-excerpt{font-size:.76rem;color:var(--grey);line-height:1.55;margin-top:4px;display:block}
.slup-widget .slupw-date{font-size:.66rem;color:var(--grey);margin-top:6px;display:block;letter-spacing:.03em}

/* Wariant z miniaturą */
.slup-widget .slupw-item a:has(.slupw-thumb){grid-template-columns:72px 1fr;gap:12px;align-items:start}
.slup-widget .slupw-thumb{display:block;width:72px;height:54px;background:var(--light) center/cover no-repeat}
.slup-widget .slupw-body{min-width:0}

/* Styl ciemny */
.slup-widget.slup-style-dark{background:var(--black);padding:20px;color:#fff}
.slup-widget.slup-style-dark .slupw-title{color:#fff}
.slup-widget.slup-style-dark .slupw-item a{background:rgba(255,255,255,.04)}
.slup-widget.slup-style-dark .slupw-item a:hover{background:rgba(255,255,255,.08)}
.slup-widget.slup-style-dark .slupw-itemtitle{color:#fff}
.slup-widget.slup-style-dark .slupw-excerpt{color:rgba(255,255,255,.5)}
.slup-widget.slup-style-dark .slupw-date{color:rgba(255,255,255,.4)}
.slup-widget.slup-style-dark .slupw-thumb{background-color:rgba(255,255,255,.06)}

/* Widget Sprawdza */
.slup-widget-sprawdza .slupw-sprawdza-list{display:flex;flex-direction:column;gap:2px}
.slup-widget-sprawdza .slupw-sprawdza-card{display:block;padding:16px 18px;background:rgba(0,0,0,.02);text-decoration:none;transition:background .2s;border-left:3px solid transparent}
.slup-widget-sprawdza .slupw-sprawdza-card:hover{background:rgba(0,0,0,.05);border-left-color:var(--red)}
.slup-widget-sprawdza .slupw-sprawdza-card.has-thumb{display:grid;grid-template-columns:72px 1fr;gap:12px;align-items:center;padding:10px 12px}
.slup-widget-sprawdza .slupw-sprawdza-thumb{width:72px;height:54px;background:var(--light) center/cover no-repeat;display:block}
.slup-widget-sprawdza .slupw-sprawdza-body{display:flex;flex-direction:column;gap:6px;min-width:0}
.slup-widget-sprawdza .slupw-sprawdza-title{font-size:.88rem;font-weight:700;line-height:1.35;color:var(--black)}
.slup-widget-sprawdza .slupw-sprawdza-date{font-size:.68rem;color:var(--grey)}
.slup-widget-sprawdza.slup-style-dark{background:var(--black);padding:20px}
.slup-widget-sprawdza.slup-style-dark .slupw-sprawdza-card{background:rgba(255,255,255,.04)}
.slup-widget-sprawdza.slup-style-dark .slupw-sprawdza-card:hover{background:rgba(255,255,255,.08)}
.slup-widget-sprawdza.slup-style-dark .slupw-sprawdza-title{color:#fff}
.slup-widget-sprawdza.slup-style-dark .slupw-sprawdza-date{color:rgba(255,255,255,.45)}
.slup-widget-sprawdza.slup-style-dark .slupw-title{color:#fff}

@media(max-width:960px){
  .hero-inner,
  .hero.hero-mode-news .hero-inner{grid-template-columns:1fr;gap:36px}
  .hero-stats{flex-direction:row;flex-wrap:wrap}
  .hstat{flex:1;min-width:130px}
  .hero-news-list{gap:2px}
  /* Pozwól tytułom newsów rozwijać się na tyle linii ile potrzeba — nie ucinaj */
  .hero-news-item .hbody{overflow:visible}
  .hero-news-item .htitle{display:block;-webkit-line-clamp:unset;overflow:visible;white-space:normal}
  /* Hero background — na tablecie zdjęcie wypełnia sekcję, pozycja do góry */
  .hero-news-bg .hnb-image{
    background-size:cover;
    background-position:center top;
    -webkit-mask-image:none;
            mask-image:none;
  }
  /* Overlay z gradientem góra/dół zaciemniającym brzegi (środek jasny) */
  .hero-news-bg .hnb-overlay{
    background:linear-gradient(180deg,
      rgba(10,10,10,.95) 0%,
      rgba(10,10,10,.45) 28%,
      rgba(10,10,10,.45) 72%,
      rgba(10,10,10,.95) 100%
    );
    mix-blend-mode:normal;
  }
  .codzis-grid{grid-template-columns:1fr}
  .news-grid{grid-template-columns:1fr}
  .news-slider{min-height:360px}
  .tl-strip{grid-template-columns:1fr}
  .tl-featured{grid-column:auto;grid-template-columns:1fr}
  .sprawdza-grid,.info-cards,.kontakty-grid{grid-template-columns:1fr}
  .foot-inner{grid-template-columns:1fr 1fr}
  .pcta-packages{grid-template-columns:repeat(2,1fr)}
  .nav-claim{display:none}
  .nav-links{display:none}
  .menu-toggle{display:block}
  .nav-links.open{display:flex;flex-direction:column;position:absolute;top:56px;left:0;right:0;background:var(--black);border-top:1px solid rgba(255,255,255,.06);height:auto;max-height:calc(100vh - 56px);overflow-y:auto;align-items:stretch}
  .nav-links.open li{flex-direction:column;align-items:stretch;height:auto}
  .nav-links.open a{height:48px;line-height:1.2;border-left:none;border-bottom:1px solid rgba(255,255,255,.06)}
  .mega-panel{display:none !important}
  .gminy-layout{grid-template-columns:1fr}
  .gminy-grid{grid-template-columns:repeat(3,1fr)}
  .archive-grid{grid-template-columns:1fr 1fr}
  .dyn-grid.cols-3,.dyn-grid.cols-4{grid-template-columns:repeat(2,1fr)}
  .dyn-feature{grid-template-columns:1fr}
  .dyn-feat-main{min-height:340px}
  .dyn-slider{min-height:340px}
  .layout-wrap.layout-sidebar-right,.layout-wrap.layout-sidebar-left{grid-template-columns:1fr}
  .sidebar{position:static;margin-top:48px}
  .related-grid{grid-template-columns:1fr 1fr}
}

@media(max-width:600px){
  /* === NUCLEAR OVERFLOW GUARD — wszystkie podstawowe kontenery zatrzymują wystawanie === */
  main, article, section, aside, .layout-wrap, .single-post-wrapper, .archive-wrapper{
    max-width:100vw;
    overflow-x:hidden;
    box-sizing:border-box;
  }
  /* Zezwól na rozciąganie tylko tym, które celowo używają overflow-x dla scrolla wewnątrz (tabele, breadcrumbs) */
  .entry-content table,
  .entry-content pre,
  .slup-breadcrumbs{overflow-x:auto}

  /* === UJEDNOLICONY MOBILE PADDING — 16px po bokach wszędzie === */
  .hero{padding:48px 16px 40px;min-height:auto;display:block;max-width:100vw}
  .hero-inner{max-width:100%}
  .hero-news,.hero-news-list{max-width:100%}

  /* Hero background image — na mobile zdjęcie wypełnia sekcję, pozycja do góry,
     gradient góra/dół zaciemnia brzegi żeby nie było widać końców obrazka */
  .hero-news-bg .hnb-image{
    background-size:cover;
    background-position:center top;
    -webkit-mask-image:none;
            mask-image:none;
  }
  .hero-news-bg .hnb-overlay{
    background:linear-gradient(180deg,
      rgba(10,10,10,.95) 0%,
      rgba(10,10,10,.45) 25%,
      rgba(10,10,10,.45) 75%,
      rgba(10,10,10,.95) 100%
    );
    mix-blend-mode:normal;
  }

  .section,.section-dynamic{padding:48px 16px}
  .layout-wrap{padding:32px 16px;margin-top:48px;overflow-x:hidden;max-width:100vw;box-sizing:border-box}
  .archive-wrapper{padding:32px 16px;margin-top:48px}
  .site-nav{padding:0 16px}
  .manifest-bar-inner{padding:13px 16px}

  /* === DEFENSYWNY OVERFLOW GUARD — wszystko trzyma się ekranu === */
  /* single-post-wrapper na mobile: zero wewnętrznego paddingu, layout-wrap zarządza odstępami
     PLUS twardy overflow-x: hidden żeby zablokować WSZELKIE potencjalne wystawanie z dziedziczonej treści */
  .single-post-wrapper{
    max-width:100% !important;
    min-width:0;
    padding:0 !important;
    margin-top:0 !important;
    overflow-x:hidden;
    overflow-wrap:break-word;
    word-wrap:break-word;
    box-sizing:border-box;
  }
  .post-thumbnail-wrap{max-width:100%;overflow:visible}
  .post-share{max-width:calc(100% - 16px)}
  .entry-meta{max-width:100%;flex-wrap:wrap}
  .entry-tags{max-width:100%;flex-wrap:wrap;display:flex;gap:6px}
  .et-tag{max-width:100%;word-break:break-word}
  .entry-nav .en-title{max-width:100%;overflow:hidden}
  .related-grid{max-width:100%}
  .related-grid .archive-card{max-width:100%;min-width:0}
  .related-grid .archive-card .card-thumb{max-width:100%}
  .related-grid .archive-card .card-title{overflow-wrap:break-word;word-wrap:break-word;hyphens:auto}
  .entry-content{max-width:100%;min-width:0;overflow-wrap:break-word;word-wrap:break-word}
  .entry-content > *{max-width:100%}
  .entry-content img,
  .entry-content iframe,
  .entry-content video,
  .entry-content embed,
  .entry-content figure,
  .entry-content table,
  .entry-content pre{max-width:100%;height:auto}
  .entry-content figure{margin-left:0;margin-right:0}
  .entry-content iframe{width:100%}
  .entry-content table{display:block;overflow-x:auto;white-space:nowrap}
  .entry-content pre{overflow-x:auto;white-space:pre-wrap}
  .post-thumbnail{max-width:100%;height:auto}

  /* Tytuły, breadcrumbs, tagi */
  .entry-title{font-size:1.8rem;word-wrap:break-word;overflow-wrap:break-word;hyphens:auto}
  .entry-nav{grid-template-columns:1fr}
  .entry-nav .en-next{text-align:left}
  .entry-tags{padding:16px 0}
  .et-tag{max-width:100%;overflow:hidden;text-overflow:ellipsis}
  .slup-breadcrumbs{
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    max-width:100vw;
    box-sizing:border-box;
  }
  .slup-bc-list{flex-wrap:nowrap;white-space:nowrap}
  /* Ukryj ostatni okruszek (tytuł aktualnej strony) — i tak jest jako <h1> niżej.
     Przedostatni okruszek (rodzic kategoria) staje się efektywnym ostatnim → bez separatora. */
  .slup-bc-item.is-current{display:none}
  .slup-bc-item:nth-last-child(2)::after{display:none}

  /* Sidebar — pełna szerokość na mobile, bez sztywnych 300px kolumn */
  .sidebar{position:static;margin-top:32px;max-width:100%}
  .sidebar .widget{padding:18px 16px}

  /* Karty archiwum */
  .archive-card .card-thumb{height:auto;aspect-ratio:16/9}
  .pcta-packages{grid-template-columns:1fr}

  /* Share buttons — wycentrowane, ciaśniej */
  .post-share{left:50%;transform:translateX(-50%);bottom:-20px;gap:6px}
  .ps-btn{width:40px;height:40px}
  .ps-btn svg{width:18px;height:18px}

  /* Grids — wszystkie pojedyncze kolumny */
  .archive-grid{grid-template-columns:1fr}
  .gminy-grid{grid-template-columns:repeat(2,1fr)}
  .foot-inner{grid-template-columns:1fr}
  .dyn-grid.cols-3,.dyn-grid.cols-4{grid-template-columns:1fr}
  .dyn-side-card{grid-template-columns:80px 1fr}
  .news-small{grid-template-columns:72px 1fr}
  .related-grid{grid-template-columns:1fr}
  .news-slide-content,.dyn-feat-body,.dyn-slide-body{padding:24px 16px}
  .news-feat-title,.dyn-feat-title,.dyn-slide-title{font-size:1.4rem}
  .sprawdza-card.has-thumb{grid-template-columns:1fr}
  .sprawdza-card.has-thumb .sc-thumb{min-height:180px}
}

/* === WP ALIGNMENT === */
.alignleft{float:left;margin-right:1.5em;margin-bottom:1em}
.alignright{float:right;margin-left:1.5em;margin-bottom:1em}
.aligncenter{display:block;margin:0 auto 1em}
.wp-caption{max-width:100%}
.wp-caption-text{font-size:.75rem;color:var(--grey);margin-top:4px}
.screen-reader-text{clip:rect(1px,1px,1px,1px);height:1px;overflow:hidden;position:absolute!important;width:1px}
