/*
Theme Name: OSP Szewce Child
Template: twentytwentyfive
Version: 2.0
Text Domain: osp-szewce-child
*/

:root{
  --osp-red:#D11F2A;
  --osp-dark:#111317;
  --osp-gold:#D6B15A;
  --osp-white:#F6F7F9;
  --osp-muted:#A9B0BA;
  --osp-radius:18px;
}

/* STATUS BAR */
.osp-status{position:sticky;top:0;z-index:9999;padding:10px 14px;color:#fff;border-bottom:1px solid rgba(255,255,255,.08)}
.osp-status__inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:10px;justify-content:center;text-align:center}
.osp-status__dot{width:10px;height:10px;border-radius:999px;box-shadow:0 0 0 6px rgba(255,255,255,.06)}
.osp-status__label{font-weight:800;letter-spacing:.3px}
.osp-status__note{color:rgba(255,255,255,.82);font-weight:700}
.osp-status--ready{background:linear-gradient(90deg,#0f4d2f,#157a47)}
.osp-status--ready .osp-status__dot{background:#22c55e}
.osp-status--action{background:linear-gradient(90deg,#7a1218,#d11f2a)}
.osp-status--action .osp-status__dot{background:#ff3b30}

/* Header */
.osp-header{background:rgba(246,247,249,.92);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid rgba(17,19,23,.10)}
.osp-nav a{text-decoration:none!important;font-weight:800;letter-spacing:.3px;text-transform:uppercase;font-size:13px;color:var(--osp-dark)!important;padding:10px 10px;border-radius:999px}
.osp-nav a:hover{background:rgba(209,31,42,.08);color:var(--osp-red)!important}

/* HERO */
.osp-hero .wp-block-cover__inner-container{max-width:1200px;margin:0 auto;padding:clamp(34px,6vw,84px) 16px}
.osp-hero h1{color:#fff;font-weight:700;line-height:1.08;font-size:clamp(34px,6vw,68px);margin-bottom:12px}
.osp-hero p{color:rgba(255,255,255,.88);font-weight:600;max-width:62ch;font-size:clamp(15px,2.2vw,18px)}
.osp-btn-row a{text-decoration:none!important;font-weight:800;border-radius:999px!important;padding:12px 18px!important}
.osp-btn-primary{background:var(--osp-red)!important;color:#fff!important;border:1px solid rgba(0,0,0,0)!important}
.osp-btn-ghost{background:rgba(255,255,255,.92)!important;color:var(--osp-dark)!important;border:1px solid rgba(0,0,0,.06)!important}

/* Counter */
.osp-counter{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media(min-width:900px){.osp-counter{grid-template-columns:repeat(4,1fr)}}
.osp-counter__item{background:var(--osp-dark);color:#fff;border-radius:var(--osp-radius);padding:16px 16px 14px;border:1px solid rgba(255,255,255,.08)}
.osp-counter__num{font-family:Oswald,system-ui,sans-serif;font-size:34px;line-height:1}
.osp-counter__label{margin-top:6px;color:rgba(255,255,255,.78);font-weight:700}

/* Sections & cards */
.osp-section{padding:clamp(26px,4vw,56px) 16px}
.osp-wrap{max-width:1200px;margin:0 auto}
.osp-card{background:#fff;border-radius:var(--osp-radius);padding:16px;border:1px solid rgba(17,19,23,.10);box-shadow:0 12px 40px rgba(17,19,23,.08)}
.osp-kicker{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;background:rgba(209,31,42,.10);color:var(--osp-red);font-weight:900;font-size:12px;text-transform:uppercase;letter-spacing:.3px}
.osp-grid-3{display:grid;gap:12px}
@media(min-width:900px){.osp-grid-3{grid-template-columns:repeat(3,1fr)}}

/* Footer */
.osp-footer{
  background:var(--osp-dark);
  color:rgba(255,255,255,.86);
  padding:22px 16px;
  font-size:16px;
  line-height:1.55;
}
.osp-footer .osp-wrap{max-width:1200px;margin:0 auto;}
.osp-footer a{
  color:var(--osp-gold)!important;
  text-decoration:none;
  font-weight:700;
  font-size:inherit;
}
.osp-footer a:hover{text-decoration:underline}

/* Footer – 3 kolumny (lewa / środek / prawa) + kompakt */
.osp-footer{padding:26px 16px 18px}
.osp-footer__inner{
  margin:0;
  display:grid;
  grid-template-columns:1.2fr .9fr 1.1fr;
  gap:28px;
  align-items:start;
}
.osp-footer__col > *{margin-top:0}

.osp-footer__title{
  margin:0 0 10px;
  font-size:34px;
  line-height:1.15;
  font-weight:800;
  letter-spacing:.2px;
  color:var(--osp-gold);
}

.osp-footer__text{
  margin:0;
  font-size:15px;
  line-height:1.6;
  max-width:62ch;
  color:rgba(255,255,255,.80);
}

.osp-footer__heading{
  margin:4px 0 12px;
  font-size:13px;
  font-weight:800;
  letter-spacing:.10em;
  text-transform:uppercase;
  color:rgba(255,255,255,.92);
}

.osp-footer__list{
  margin:0;
  padding-left:18px;
}
.osp-footer__list li{margin:10px 0}
.osp-footer__list li::marker{color:rgba(255,255,255,.55)}

/* ŚRODEK – Na skróty (centruj kolumnę, ale lista czytelnie do lewej) */
.osp-footer__links{justify-self:center}
.osp-footer__links .osp-footer__list{display:inline-block;text-align:left}

/* PRAWO – kontakt */
.osp-footer__contact{justify-self:end;text-align:right}
.osp-footer__contact-html{font-size:16px;line-height:1.6}
.osp-footer__contact-html p{margin:0 0 8px}
.osp-footer__contact-html p:last-child{margin-bottom:0}
.osp-footer__contact-html strong{font-weight:800;color:rgba(255,255,255,.92)}

.osp-footer__sep{margin:16px 0;border:none;border-top:1px solid rgba(255,255,255,.16)}
.osp-footer__copy{margin:0;font-size:13px;color:rgba(255,255,255,.70)}

@media (max-width: 900px){
  .osp-footer{padding:22px 16px 14px}
  .osp-footer__inner{grid-template-columns:1fr;gap:16px}
  .osp-footer__contact{justify-self:start;text-align:left}
  .osp-footer__links{justify-self:start}
  .osp-footer__links .osp-footer__list{display:block}
  .osp-footer__title{font-size:28px}
}


/* ===== MAPA (WP Go Maps) ===== */
.osp-map-wrap{
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 18px 60px rgba(0,0,0,.22);
}
.osp-map-wrap .wpgmza_map{
  border-radius: 18px;
}


/* ===== KAFELKI WP (lista wpisów) ===== */
.osp-post-grid{display:grid;grid-template-columns:1fr;gap:14px;margin-top:16px;}
@media(min-width:720px){.osp-post-grid{grid-template-columns:repeat(2,1fr);}}
@media(min-width:1024px){.osp-post-grid{grid-template-columns:repeat(3,1fr);}}
.osp-post-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.10);border-radius:18px;overflow:hidden;box-shadow:0 18px 60px rgba(0,0,0,.18);} 
.osp-post-card__link{display:block;color:inherit;text-decoration:none;}
.osp-post-card__thumb img{display:block;width:100%;height:220px;object-fit:cover;}
.osp-post-card__body{padding:14px 14px 16px;}
.osp-post-card__title{margin:0 0 6px;font-weight:800;letter-spacing:.2px;}
.osp-post-card__meta{opacity:.75;font-weight:700;font-size:12px;margin-bottom:10px;}
.osp-post-card__excerpt{opacity:.92;line-height:1.45;}
.osp-post-card:hover{transform:translateY(-2px);transition:.18s ease;box-shadow:0 26px 80px rgba(0,0,0,.24);} 


/* ===== Strażacka nawigacja (czerwień) ===== */
.osp-header{position:sticky;top:0;z-index:999;background:linear-gradient(180deg,#b10d12,#8c0b10);border-bottom:1px solid rgba(255,255,255,.12);box-shadow:0 18px 60px rgba(0,0,0,.20);}
.osp-nav{max-width:1200px;margin:0 auto;padding:14px 18px;}
.osp-nav__inner{display:flex;align-items:center;justify-content:space-between;gap:16px;}
.osp-nav__left,.osp-nav__right{display:flex;gap:18px;align-items:center;flex:1;}
.osp-nav__left{justify-content:flex-end;}
.osp-nav__right{justify-content:flex-start;}
.osp-nav a{color:#fff;text-decoration:none;font-weight:800;letter-spacing:.04em;text-transform:uppercase;font-size:13px;opacity:.95;}
.osp-nav a:hover{opacity:1;text-decoration:underline;}
.osp-nav__logo{flex:0 0 auto;display:flex;align-items:center;justify-content:center;padding:6px 10px;border-radius:14px;background:rgba(0,0,0,.18);border:1px solid rgba(255,255,255,.18);}
.osp-nav__logo img{height:44px;width:auto;display:block;filter:drop-shadow(0 10px 20px rgba(0,0,0,.35));}
.osp-nav__burger{display:none;appearance:none;border:0;background:transparent;width:44px;height:44px;border-radius:12px;cursor:pointer;position:relative;}
.osp-nav__burger span{display:block;height:2px;background:#fff;border-radius:2px;margin:6px 8px;}
.osp-nav__mobile{margin-top:12px;padding:12px;border-radius:16px;background:rgba(0,0,0,.18);border:1px solid rgba(255,255,255,.18);display:grid;grid-template-columns:1fr;gap:10px;}
.osp-nav__mobile a{padding:10px 12px;border-radius:12px;background:rgba(255,255,255,.08);}
@media (max-width: 980px){
  .osp-nav__left,.osp-nav__right{display:none;}
  .osp-nav__burger{display:block;}
  .osp-nav__logo img{height:40px;}
}

/* ===== Licznik – ładny grid ===== */
.osp-counter{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:12px;margin-top:16px}
.osp-counter__item{background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:14px 12px;text-align:center}
.osp-counter__item--total{grid-column:span 2}
.osp-counter__num{font-size:28px;font-weight:900;letter-spacing:-.02em;color:#fff}
.osp-counter__label{font-size:12px;opacity:.9;color:#fff;text-transform:uppercase;letter-spacing:.05em}
@media (max-width: 980px){
  .osp-counter{grid-template-columns:repeat(2,minmax(0,1fr));}
  .osp-counter__item--total{grid-column:span 2}
}


/* ===== Top menu (kolor stopki / ciemny) ===== */
.osp-header--dark{position:sticky;top:0;z-index:999;background:#0b0f14;border-bottom:1px solid rgba(255,255,255,.08);}
.osp-topnav{max-width:1200px;margin:0 auto;padding:14px 18px;}
.osp-topnav__inner{display:flex;align-items:center;justify-content:space-between;gap:16px;}
.osp-topnav__links{display:flex;gap:18px;align-items:center;flex:1;justify-content:center;}
.osp-topnav__links:first-child{justify-content:flex-end;}
.osp-topnav__links:last-child{justify-content:flex-start;}
.osp-topnav a{color:#f5d36a;text-decoration:none;font-weight:900;letter-spacing:.05em;text-transform:uppercase;font-size:13px;}
.osp-topnav a:hover{color:#fff;text-decoration:underline;}
.osp-topnav__logo{flex:0 0 auto;display:flex;align-items:center;justify-content:center;padding:6px 10px;border-radius:14px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);}
.osp-topnav__logo img{height:44px;width:auto;display:block;filter:drop-shadow(0 10px 20px rgba(0,0,0,.35));border-radius:8px;}
@media (max-width: 980px){
  .osp-topnav__inner{flex-wrap:wrap;justify-content:center}
  .osp-topnav__links{flex:0 0 100%;justify-content:center;flex-wrap:wrap}
  .osp-topnav__logo{order:-1}
}

/* ===== Dropdown (Działalność / O nas) – styl jak na screenach ===== */
.osp-topnav__dropdown{position:relative;display:inline-flex;align-items:center;}
.osp-topnav__dropdown-trigger{display:inline-flex;align-items:center;gap:6px;}
.osp-topnav__caret{font-size:12px;line-height:1;opacity:.85;}

.osp-topnav__dropdown-menu{
  position:absolute;
  top:calc(100% + 10px);
  left:0;
  min-width:280px;
  background:#fff;
  border:1px solid rgba(0,0,0,.10);
  border-radius:14px;
  box-shadow:0 18px 60px rgba(0,0,0,.18);
  padding:10px;
  display:none;
  z-index:9999;
}

/* Hover na desktop + fokus na mobile */
.osp-topnav__dropdown:hover .osp-topnav__dropdown-menu,
.osp-topnav__dropdown:focus-within .osp-topnav__dropdown-menu{
  display:block;
}

.osp-dd-item{
  display:flex;
  align-items:center;
  gap:12px;
  padding:10px 12px;
  border-radius:12px;
  text-decoration:none !important;
  font-weight:800;
  letter-spacing:.2px;
  text-transform:none;
  font-size:15px;
  color:#1b1f2a !important;
}
.osp-dd-item:hover{
  background:#f3f5f7;
}
.osp-dd-ico{
  width:26px;
  min-width:26px;
  display:inline-flex;
  justify-content:center;
  color:#8a9099;
  opacity:.95;
  font-size:18px;
  line-height:1;
}
.osp-dd-text{display:inline-block;}

@media (max-width: 980px){
  .osp-topnav__dropdown-menu{position:static;min-width:unset;width:100%;margin-top:10px;}
}

/* ===== Mapa ===== */
.osp-map{height:420px;border-radius:18px;overflow:hidden;border:1px solid rgba(0,0,0,.12);}
.osp-map-wrap{background:#fff;border-radius:20px;padding:12px;box-shadow:0 14px 40px rgba(0,0,0,.10);}

/* ===== Licznik ===== */
.osp-counter{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:12px;margin-top:16px}
.osp-counter__item{background:#0b0f14;border:1px solid rgba(255,255,255,.10);border-radius:16px;padding:14px 12px;text-align:center}
.osp-counter__item--total{grid-column:span 2}
.osp-counter__num{font-size:28px;font-weight:900;letter-spacing:-.02em;color:#fff}
.osp-counter__label{font-size:12px;opacity:.9;color:#f5d36a;text-transform:uppercase;letter-spacing:.05em}
@media (max-width: 980px){
  .osp-counter{grid-template-columns:repeat(2,minmax(0,1fr));}
  .osp-counter__item--total{grid-column:span 2}
}



/* Galeria – pokazuj całe zdjęcie (bez przycinania) */
.osp-gallery-grid .osp-post-card__thumb img{
  object-fit: contain;
  background: rgba(0,0,0,.06);
}

/* Widok tylko zdjęć */
.osp-gallery-only{padding:24px 0 60px;}
.osp-gallery-only__title{margin:0 0 8px;font-weight:900;letter-spacing:.2px;}
.osp-gallery-only__back{margin:0 0 18px;}
.osp-gallery-only__back a{text-decoration:none;font-weight:700;}
.osp-photos{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;}
@media (max-width: 900px){.osp-photos{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media (max-width: 560px){.osp-photos{grid-template-columns:1fr;}}
.osp-photo{display:block;border-radius:16px;overflow:hidden;border:1px solid rgba(0,0,0,.08);background:#fff;}
.osp-photo img{display:block;width:100%;height:auto;}


/* ===== HOTFIX: licznik akcji w jednej linii ===== */
.osp-counter{
  display:flex !important;
  flex-wrap:nowrap !important;
  gap:12px !important;
  align-items:stretch;
  justify-content:space-between;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
}
.osp-counter__item{
  flex:1 0 170px;
  min-width:170px;
}
@media(min-width:900px){
  .osp-counter{overflow-x:visible}
  .osp-counter__item{min-width:0;flex:1 1 0}
}


/* === FIX: remove white gap between header (menu) and hero on front page === */
html, body { margin-top: 0 !important; padding-top: 0 !important; }

/* =========================================================
   MOBILE-FIRST PRO: hamburger, hero, licznik (responsive)
   ========================================================= */

/* ----- Header / hamburger ----- */
.osp-nav-toggle{
  display:none;
  appearance:none;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  border-radius:14px;
  height:44px;
  width:44px;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  flex:0 0 auto;
  position:relative;
  z-index:10001;
  touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;
}
.osp-nav-toggle__bars{
  width:18px;
  height:12px;
  position:relative;
  display:block;
}
.osp-nav-toggle__bars::before,
.osp-nav-toggle__bars::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  height:2px;
  background:#f5d36a;
  border-radius:2px;
  opacity:.95;
}
.osp-nav-toggle__bars::before{top:1px;box-shadow:0 4px 0 #f5d36a, 0 8px 0 #f5d36a;}
.osp-nav-toggle:focus{outline:2px solid rgba(245,211,106,.55);outline-offset:2px;}

/* Drawer */
.osp-mobile-nav{
  /* IMPORTANT: drawer must NOT sit above the header when closed.
     We hard-disable it by default and enable only with .is-open (set by JS).
     This avoids mobile cases where an invisible layer steals taps. */
  display:none;
  position:fixed;
  inset:0;
  z-index:10000;
}

/* Only when opened */
.osp-mobile-nav.is-open{display:block;}

.osp-mobile-nav.is-open{display:block;}
.osp-mobile-nav__overlay{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.55);
  backdrop-filter:saturate(130%) blur(2px);
}
.osp-mobile-nav__panel{
  position:absolute;
  top:0;
  right:0;
  height:100%;
  width:min(92vw, 420px);
  background:#0b0f14;
  border-left:1px solid rgba(255,255,255,.10);
  box-shadow:-24px 0 70px rgba(0,0,0,.55);
  padding:18px 16px 22px;
  display:flex;
  flex-direction:column;
}
.osp-mobile-nav__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding-bottom:14px;
  border-bottom:1px solid rgba(255,255,255,.10);
}
.osp-mobile-nav__brand{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
}
.osp-mobile-nav__brand img{height:40px;width:auto;border-radius:10px;}
.osp-mobile-nav__close{
  appearance:none;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:#fff;
  border-radius:14px;
  height:40px;
  width:40px;
  cursor:pointer;
}
.osp-mobile-nav__links{
  padding-top:14px;
  display:grid;
  gap:10px;
  overflow:auto;
}
.osp-mobile-nav__links > a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 12px;
  border-radius:14px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  text-decoration:none;
  color:#fff;
  font-weight:800;
  letter-spacing:.02em;
}
.osp-mobile-nav__links > a:active{transform:translateY(1px);}

/* Accordion in drawer (no-JS) */
.osp-acc{border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.04);border-radius:16px;overflow:hidden;}
.osp-acc__check{position:absolute;opacity:0;pointer-events:none;}
.osp-acc__trigger{
  width:100%;
  text-align:left;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:12px 12px;
  background:transparent;
  border:0;
  color:#fff;
  font-weight:900;
  cursor:pointer;
  user-select:none;
}
.osp-acc__caret{opacity:.85;transition:transform .2s ease;}
.osp-acc__panel{padding:8px 12px 12px;display:none;gap:8px;}
.osp-acc__check:checked ~ .osp-acc__panel{display:grid;}
.osp-acc__check:checked ~ .osp-acc__trigger .osp-acc__caret{transform:rotate(180deg);}
.osp-acc__panel a{
  padding:10px 10px;
  border-radius:12px;
  background:rgba(255,255,255,.06);
}

/* When drawer open: lock page scroll */
html.osp-nav-open,
html.osp-nav-open body{overflow:hidden;}

@media (max-width: 980px){
  .osp-nav-toggle{display:inline-flex !important;}
  .osp-topnav__links{display:none;}
  .osp-topnav__inner{justify-content:space-between;}
}

/* Hidden attribute is still respected as an extra safety net */
.osp-mobile-nav[hidden]{display:none !important;}

/* ----- Hero: czytelne na telefonach ----- */
.osp-hero .wp-block-cover__inner-container{max-width:980px;}
.osp-hero h1{line-height:1.04;letter-spacing:-.02em;font-weight:900;font-size:clamp(32px, 5.2vw, 56px);}
.osp-hero p{max-width:52ch;font-size:clamp(15px, 2.2vw, 18px);opacity:.95;}

@media (max-width: 720px){
  /* Na telefonach nie robimy "gigantycznego" hero i unikamy ucinania kadru */
  .osp-hero{min-height:62vh !important;}
  .osp-hero .wp-block-cover__inner-container{padding:0 14px;}
  .osp-hero h1{font-size:clamp(28px, 8.2vw, 40px);}
  .osp-btn-row{width:100%;}
  .osp-btn-row .wp-block-button__link{width:100%;text-align:center;}
  .osp-hero .wp-block-cover__image-background{object-position:center center;}
}

/* Małe telefony: hero ma nadal wypełniać cały obszar (cover), tylko poprawiamy "kadr" */
@media (max-width: 520px){
  .osp-hero{min-height:58vh !important;}
  .osp-hero .wp-block-cover__image-background{object-fit:cover;object-position:center 35%;}
}

/* ----- Licznik: stabilny grid, bez przewijania ----- */
.osp-counter{
  display:grid !important;
  grid-template-columns:repeat(6, minmax(0, 1fr)) !important;
  gap:12px !important;
  overflow:visible !important;
}
.osp-counter__item{min-width:0 !important;}

@media (max-width: 980px){
  .osp-counter{grid-template-columns:repeat(2, minmax(0, 1fr)) !important;}
  /* Zmniejsz licznik, żeby nie zajmował pół ekranu */
  .osp-counter__item{padding:10px 10px !important;}
  .osp-counter__num{font-size:20px !important;}
  .osp-counter__label{font-size:10px !important;}
}

/* Jeszcze mniejszy licznik na telefonach */
@media (max-width: 520px){
  .osp-counter{gap:8px !important;}
  .osp-counter__item{padding:6px 6px !important;border-radius:14px !important;}
  .osp-counter__num{font-size:16px !important;}
  .osp-counter__label{font-size:8px !important;letter-spacing:.04em !important;}
}

/* Mobile nav: upewnij się, że hamburger jest zawsze klikalny i nic go nie przykrywa */
.osp-header--dark{z-index:20000 !important;}
.osp-topnav{position:relative;}
@media (max-width: 980px){
  .osp-topnav__inner{flex-wrap:nowrap !important;}
  .osp-topnav__logo{order:0 !important;}
  .osp-nav-toggle{pointer-events:auto !important;z-index:20001 !important;}
}

@media (max-width: 420px){
  .osp-counter{gap:6px !important;}
  .osp-counter__item{padding:6px 6px !important;}
  .osp-counter__num{font-size:15px !important;}
  .osp-counter__label{font-size:8px !important;}
}
.wp-site-blocks { padding-top: 0 !important; }
.wp-site-blocks > header { margin-block-start: 0 !important; margin-block-end: 0 !important; }
.wp-site-blocks > header + * { margin-block-start: 0 !important; }
header.wp-block-template-part { margin: 0 !important; }

/* If a spacer/separator sneaks in right after header, hide it */
.wp-site-blocks > header + .wp-block-spacer,
.wp-site-blocks > header + .wp-block-separator { display:none !important; }

/* Cover hero safety */
.wp-site-blocks > header + .wp-block-cover { margin-top:0 !important; }



/* === WESPRZYJ NAS (DONATE) === */
.osp-donate{
  padding: clamp(28px, 4vw, 56px) 0;
  background: radial-gradient(1000px 420px at 10% 0%, rgba(255, 199, 0, 0.10), transparent 60%),
              radial-gradient(900px 380px at 90% 20%, rgba(255, 255, 255, 0.06), transparent 55%),
              linear-gradient(180deg, rgba(0,0,0,0.70), var(--osp-dark));
  border-top: 1px solid rgba(255,255,255,0.08);
}
.osp-donate__inner{
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 18px;
}
.osp-donate h2{
  color: #fff;
  margin: 0 0 10px;
  letter-spacing: 0.5px;
}
.osp-donate p{
  color: rgba(255,255,255,0.82);
}
.osp-donate__cols{
  margin-top: 18px;
  gap: 18px;
}
.osp-donate__card{
  background: rgba(13, 17, 23, 0.72);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 18px;
  padding: 18px 18px 16px;
  box-shadow: 0 18px 40px rgba(0,0,0,0.35);
  backdrop-filter: blur(10px);
}
.osp-donate__label{
  margin: 0 0 10px;
  color: rgba(255, 199, 0, 0.95);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  font-size: 12px;
}
.osp-donate__iban{
  margin: 0;
  color: #fff;
  font-weight: 800;
  font-size: 20px;
  letter-spacing: 1px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.10);
  padding: 12px 14px;
  border-radius: 14px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  word-break: break-word;
}
.osp-donate__hint{
  margin: 10px 0 0;
  font-size: 12px;
  opacity: 0.75;
}
.osp-donate__small{
  margin: 10px 0 0;
  font-size: 13px;
  opacity: 0.9;
}
@media (max-width: 720px){
  .osp-donate__iban{ font-size: 18px; }
}



/* === Smooth transition between "Wesprzyj nas" and footer + remove white gap === */
.osp-donate{
  margin-block-end: 0 !important;
  padding-bottom: 0 !important;
  border-bottom: 0 !important;
}
.osp-donate::after{
  content: "";
  display: block;
  height: 48px;
  background: linear-gradient(180deg, rgba(17,19,23,0), var(--osp-dark));
}
.wp-block-template-part footer,
footer.osp-footer,
.osp-footer{
  margin-block-start: 0 !important;
}
/* Block theme sometimes inserts gap/margins between blocks */
.wp-site-blocks > .osp-donate + .wp-block-template-part,
.wp-site-blocks > .osp-donate + footer{
  margin-top: 0 !important;
  padding-top: 0 !important;
}


/* Remiza marker (emoji) */
.osp-remiza-divicon{
  background: rgba(200, 30, 30, .95);
  border: 2px solid rgba(255,255,255,.9);
  border-radius: 999px;
  box-shadow: 0 10px 22px rgba(0,0,0,.25);
  display: flex;
  align-items: center;
  justify-content: center;
}
.osp-remiza-emoji{
  font-size: 22px;
  line-height: 1;
  filter: drop-shadow(0 2px 3px rgba(0,0,0,.35));
}


.osp-remiza-icon{background:transparent;}
.osp-remiza-emoji--big{font-size:36px; line-height:1; filter: drop-shadow(0 3px 4px rgba(0,0,0,.45));}
/* ===== Mobile: klik w logo/menu zawsze działa ===== */
@media (max-width: 980px){
  /* Sticky bywa "nieklikalne" na części telefonów, gdy sekcje poniżej tworzą własne warstwy (cover/overlay). */
  header.osp-header--dark{
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    z-index: 999999 !important;
    transform: translateZ(0);
    pointer-events: auto !important;
    isolation: isolate;
  }

  .osp-topnav,
  .osp-topnav__inner{pointer-events:auto !important;}

  /* Zrób miejsce pod fixed header */
  .wp-site-blocks{
    padding-top: 78px !important;
  }

  /* Menu/Logo zawsze łapie dotyk */
  .osp-topnav__logo,
  .osp-nav-toggle{
    pointer-events: auto !important;
    touch-action: manipulation;
  }
}

/* Ensure hero/cover never creates an invisible click-layer above the fixed header */
.wp-block-cover{position:relative;z-index:0;}

/* Cover/overlay: tło NIE może przechwytywać dotyku nad headerem */
.wp-block-cover__background,
.wp-block-cover__image-background,
.wp-block-cover__gradient-background{
  pointer-events: none !important;
}
/* Ale treść w hero ma być klikalna */
.wp-block-cover__inner-container{
  pointer-events: auto !important;
}


/* ===== Mobile nav (NO-JS, 100% reliable) ===== */
.osp-nav-check{
  position:absolute;
  width:1px;height:1px;
  opacity:0;
  pointer-events:none;
}

/* Drawer default hidden; shown via checkbox state */
.osp-mobile-nav{ display:none; }
.osp-nav-check:checked ~ .osp-mobile-nav{ display:block !important; }

/* Prevent any "hidden" attribute UA styles from interfering */
.osp-mobile-nav[hidden]{ display:none !important; }

/* When open: lock background scrolling (best-effort, no JS) */
@supports selector(html:has(.osp-nav-check:checked)){
  html:has(.osp-nav-check:checked){ overflow:hidden; }
}

/* Ensure header + toggle are always clickable on iOS */
.osp-header{
  position:fixed;
  top:0; left:0; right:0;
  z-index:20000;
  isolation:isolate;
}
body{ padding-top:72px; }
@media (max-width:900px){
  body{ padding-top:72px; }
  .osp-nav-toggle{ display:inline-flex !important; pointer-events:auto !important; touch-action:manipulation; }
}



/* ===== Mobile Header & Drawer FIX (no-JS menu, iOS-safe) ===== */
.osp-topnav__spacer{display:none;}
@media (max-width: 980px){
  /* Stabilny header: hamburger - logo (center) - spacer */
  .osp-header--dark{
    position:fixed;
    top:0;
    left:0;
    right:0;
    z-index:100000;
    background:#0b0f14;
    border-bottom:1px solid rgba(255,255,255,.10);
    padding-top: env(safe-area-inset-top);
  }
  .osp-topnav{
    padding:10px 12px;
  }
  .osp-topnav__inner{
    display:grid !important;
    grid-template-columns: 52px 1fr 52px;
    align-items:center;
    gap:10px;
    justify-content:unset;
    flex-wrap:nowrap;
  }
  /* Ukryj desktopowe linki w headerze na mobile */
  .osp-topnav__links,
  .osp-topnav__right{
    display:none !important;
  }
  .osp-topnav__spacer{
    display:block;
    width:44px;
    height:44px;
    justify-self:end;
  }

  /* Hamburger klikalny zawsze */
  .osp-nav-toggle{
    width:44px;
    height:44px;
    display:flex !important;
    align-items:center;
    justify-content:center;
    border-radius:14px;
    background: rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.12);
    z-index:100001;
    pointer-events:auto;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
  }

  .osp-topnav__logo{
    justify-self:center;
    margin:0 !important;
    order:0 !important;
  }
  .osp-topnav__logo img{
    height:42px;
  }

  /* Drawer full-screen, not cut */
  .osp-mobile-nav{
    position:fixed;
    inset:0;
    display:none;
    z-index:99999;
  }
  .osp-nav-check:checked ~ .osp-mobile-nav{
    display:block;
  }
  .osp-mobile-nav__overlay{
    position:absolute;
    inset:0;
    background: rgba(0,0,0,.55);
  }
  .osp-mobile-nav__panel{
    position:absolute;
    inset:0;
    background:#0b0f14;
    padding: calc(76px + env(safe-area-inset-top)) 18px 22px;
    overflow-y:auto;
    -webkit-overflow-scrolling: touch;
  }
  .osp-mobile-nav__top{
    position:fixed;
    top: env(safe-area-inset-top);
    left:0;
    right:0;
    height:64px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding: 10px 12px;
    z-index:100000;
    background: linear-gradient(to bottom, rgba(11,15,20,.98), rgba(11,15,20,.85));
    backdrop-filter: blur(10px);
    border-bottom: 1px solid rgba(255,255,255,.08);
  }
  .osp-mobile-nav__close{
    width:44px;
    height:44px;
    border-radius:14px;
    display:flex;
    align-items:center;
    justify-content:center;
    background: rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.12);
    color:#fff;
    font-size:22px;
  }
  .osp-mobile-nav__links a{
    display:block;
    padding:14px 6px;
    font-size:18px;
    color:#fff;
    text-decoration:none;
  }
  .osp-mobile-nav__links a:active{
    opacity:.8;
  }

  /* content below fixed header */
  body{
    padding-top: calc(64px + env(safe-area-inset-top));
  }
}




/* ===== MOBILE MENU: większe i bardziej "listowe" (więcej pozycji widocznych) ===== */
@media (max-width: 980px){
  /* Drawer zajmuje pełną szerokość ekranu */
  .osp-mobile-nav__panel{
    width:100vw !important;
    max-width:100vw !important;
    height:100dvh !important;
    min-height:100vh !important;
    border-left:0 !important;
    /* Nie zmniejszamy górnego paddingu, bo mamy stały pasek u góry (top bar).
       Inaczej menu wygląda na „ucięte”. */
    padding: calc(76px + env(safe-area-inset-top)) 14px 18px !important;
    overflow-y:auto !important;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
  }

  /* Mniej "kart", więcej listy – żeby zmieścić więcej zakładek */
  .osp-mobile-nav__links{
    display:flex !important;
    flex-direction:column !important;
    gap:4px !important;
    overflow-y:auto !important;
    padding-bottom:10px !important;
  }

  .osp-mobile-nav__links > a{
    padding:10px 10px !important;
    border-radius:10px !important;
    background:rgba(255,255,255,.04) !important;
    border:1px solid rgba(255,255,255,.08) !important;
    font-size:16px !important;
    font-weight:700 !important;
  }

  .osp-acc{ border-radius:10px !important; }

  .osp-acc__trigger{
    padding:10px 10px !important;
    font-size:16px !important;
    font-weight:700 !important;
  }

  .osp-acc__panel{
    padding:6px 10px 10px !important;
    gap:4px !important;
  }

  .osp-acc__panel a{
    padding:9px 10px !important;
    border-radius:10px !important;
    background:rgba(255,255,255,.03) !important;
    font-size:15px !important;
    font-weight:600 !important;
  }
}

/* Bardzo małe ekrany – jeszcze ciaśniej */
@media (max-width: 420px){
  .osp-mobile-nav__panel{padding: calc(76px + env(safe-area-inset-top)) 12px 16px !important;}
  .osp-mobile-nav__links > a{padding:10px 10px !important; font-size:15px !important;}
  .osp-acc__trigger{padding:10px 10px !important; font-size:15px !important;}
  .osp-acc__panel a{padding:8px 9px !important; font-size:14px !important;}
}
