/*
Theme Name: Child Theme
Theme URI: https://elementor.com/hello-theme/?utm_source=wp-themes&utm_campaign=theme-uri&utm_medium=wp-dash
Template: hello-elementor
Author: ITPER PL
Author URI: https://itper.pl/realizacje
Tags: accessibility-ready,flexible-header,custom-colors,custom-menu,custom-logo,featured-images,rtl-language-support,threaded-comments,translation-ready
Version: 3.4.5.1766655803
Updated: 2025-12-25 10:43:23

*/

/* Daj tę klasę na rodzica (kontener z 2 kolumnami), np. "widget-home-row" */
.widget-home-row{
  display:flex;
  gap:24px;
}
.widget-home-row > .e-con,
.widget-home-row > .elementor-element{
  flex:1 1 0;
  min-width:0;
}

.widget-home{
  background:#fff;
  border-radius:32px;
  padding:32px;
  box-shadow:
    0 14px 40px rgba(0,0,0,.14),
    0 4px 14px rgba(0,0,0,.08);

  transition: box-shadow .25s ease, transform .25s ease;
  box-sizing: border-box;
}

.widget-home:hover{
  box-shadow:
    0 20px 55px rgba(0,0,0,.18),
    0 6px 18px rgba(0,0,0,.10);
  transform: translateY(-2px);
}

.pb-marquee{
    --pb-radius: 28px;
    --pb-gap: 18px;
    --pb-height: 320px;
    --pb-speed: 26s;
    --pb-border: rgba(0,0,0,.06);
    --pb-shadow: 0 18px 40px rgba(0,0,0,.10);
    --pb-shadow-hover: 0 26px 60px rgba(0,0,0,.16);
    --pb-bg: #fff;
    --pb-soft: rgba(0,0,0,.04);
  }

  .pb-marquee__mask{
    background: var(--pb-bg);
    border: 1px solid var(--pb-border);
    border-radius: var(--pb-radius);
    box-shadow: var(--pb-shadow);
    overflow: hidden;
    position: relative;
    padding: 14px;
  }

  .pb-marquee__mask::before,
  .pb-marquee__mask::after{
    content:"";
    position:absolute;
    top:0;
    width:64px;
    height:100%;
    z-index:2;
    pointer-events:none;
  }
  .pb-marquee__mask::before{
    left:0;
    background: linear-gradient(to right, var(--pb-bg), rgba(255,255,255,0));
  }
  .pb-marquee__mask::after{
    right:0;
    background: linear-gradient(to left, var(--pb-bg), rgba(255,255,255,0));
  }

  .pb-marquee__track{
    display:flex;
    align-items:center;
    gap: var(--pb-gap);
    width: max-content;
    will-change: transform;
    animation: pbMarquee var(--pb-speed) linear infinite;
  }

  .pb-marquee__item{
    flex: 0 0 auto;
    display:block;
    height: var(--pb-height);
    width: calc(var(--pb-height) * 1.45); 
    border-radius: calc(var(--pb-radius) - 6px);
    overflow:hidden;
    background: var(--pb-soft);
    border: 1px solid var(--pb-border);
    transform: translateZ(0);
    transition: transform .25s ease, box-shadow .25s ease, filter .25s ease;
    box-shadow: 0 10px 22px rgba(0,0,0,.08);
  }

  .pb-marquee__item img{
    width:100%;
    height:100%;
    object-fit: cover;
    display:block;
  }

  .pb-marquee__item:hover{
    transform: translateY(-3px) scale(1.01);
    box-shadow: var(--pb-shadow-hover);
    filter: saturate(1.03) contrast(1.02);
  }

  .pb-marquee__mask:hover .pb-marquee__track{
    animation-play-state: paused;
  }

  @keyframes pbMarquee{
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); } 
  }

  @media (max-width: 767px){
    .pb-marquee{
      --pb-height: 160px;
      --pb-gap: 12px;
      --pb-radius: 22px;
      --pb-speed: 22s;
    }
    .pb-marquee__mask{ padding: 10px; }
    .pb-marquee__mask::before,
    .pb-marquee__mask::after{ width: 44px; }
  }

  @media (prefers-reduced-motion: reduce){
    .pb-marquee__track{ animation: none; }
  }

.pb-marquee .pb-marquee__item{
  padding: 0 !important;
  line-height: 0 !important;
}

.pb-marquee .pb-marquee__item > img{
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}

/* =========================================================
   pierogi-bydgoszcz.pl – sekcja treści (karta)
   Klasa na sekcji/kontenerze: bg-p
   ========================================================= */

.bg-p{
  background: #ffffff;
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 32px;

  padding: 28px;

  box-shadow: 0 18px 45px rgba(0,0,0,.14);
}

@media (max-width: 1024px){
  .bg-p{
    padding: 24px;
  }
}

@media (max-width: 767px){
  .bg-p{
    padding: 20px;
    border-radius: 26px;
  }
}

.pierogi-loop-carousel .swiper,
.pierogi-loop-carousel .swiper-wrapper{
  overflow: visible !important;
}

.pierogi-loop-carousel .swiper-slide{
  overflow: visible !important;
}

.pierogi-loop-carousel{
  padding: 26px 18px;
}

.pierogi-loop-carousel .elementor-widget-container,
.pierogi-loop-carousel .elementor-loop-container{
  overflow: visible !important;
}

html, body{
  overflow-x: hidden !important;
  max-width: 100% !important;
}

body{
  position: relative;
}

/* Dlaczego warto – pierogi-bydgoszcz.pl */
.why-us-pierogi {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}

.why-us-pierogi li {
  background: #ffffff;
  border-radius: 24px;
  padding: 28px 22px;
  text-align: center;
  box-shadow: 0 14px 34px rgba(0,0,0,0.08);
  transition: transform .25s ease, box-shadow .25s ease;
}

.why-us-pierogi li:hover {
  transform: translateY(-4px);
  box-shadow: 0 22px 48px rgba(0,0,0,0.12);
}

.why-us-pierogi img {
  max-width: 88px;
  height: auto;
  margin-bottom: 18px;
}

.why-us-pierogi strong {
  display: block;
  font-size: 18px;
  line-height: 1.3;
  margin-bottom: 8px;
  color: #1f1f1f;
}

.why-us-pierogi br {
  display: none;
}

.why-us-pierogi li {
  font-size: 15px;
  line-height: 1.6;
  color: #5b5b5b;
}

/* Tablet */
@media (max-width: 1024px) {
  .why-us-pierogi {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Mobile */
@media (max-width: 640px) {
  .why-us-pierogi {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .why-us-pierogi li {
    padding: 22px 18px;
    border-radius: 20px;
  }

  .why-us-pierogi img {
    max-width: 72px;
  }
}

/* =========================================================
   pierogi-bydgoszcz.pl – kafelki B2B (pod 6 obrazków)
   ========================================================= */

.why-us-pierogi--b2b{
  align-items: stretch;
}

.why-us-pierogi--b2b .why-us-pierogi__card{
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,.06);
  box-sizing: border-box;
}

.why-us-pierogi--b2b img{
  width: 96px;
  max-width: 96px;
  height: 96px;
  object-fit: contain;
  margin: 0 auto 16px;
  display: block;
  filter: saturate(1.02);
}

.why-us-pierogi--b2b strong{
  font-size: 18px;
  line-height: 1.25;
  margin-bottom: 10px;
}

.why-us-pierogi--b2b .why-us-pierogi__card{
  font-size: 15px;
  line-height: 1.65;
  color: #5b5b5b;
}

.why-us-pierogi--b2b .why-us-pierogi__card::after{
  content:"";
  position:absolute;
  inset:-40%;
  background: radial-gradient(circle at 30% 20%, rgba(0,0,0,.06), transparent 55%);
  opacity: 0;
  transition: opacity .25s ease;
  pointer-events:none;
}

.why-us-pierogi--b2b .why-us-pierogi__card:hover::after{
  opacity: 1;
}
@media (max-width: 1024px){
  .why-us-pierogi--b2b img{
    width: 88px;
    max-width: 88px;
    height: 88px;
  }
}
@media (max-width: 640px){
  .why-us-pierogi--b2b img{
    width: 76px;
    max-width: 76px;
    height: 76px;
    margin-bottom: 14px;
  }
  .why-us-pierogi--b2b strong{
    font-size: 17px;
  }
}

/* ==============================
   O NAS – sekcja z radius
   ============================== */

.o-nas-section {
  position: relative;
  overflow: hidden;
  border-radius: 32px;
}

.o-nas-section::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.45);
  opacity: 0;
  transition: opacity 0.8s ease;
  z-index: 1;
  border-radius: inherit;
}

.o-nas-section.is-visible::after {
  opacity: 1;
}

/* ==============================
   Elementy tekstowe
   ============================== */

.o-nas {
  position: relative;
  z-index: 2;
  opacity: 0;
  transform: translateY(60px);
  transition:
    opacity 0.8s ease,
    transform 0.8s ease;
}

.o-nas.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.o-nas:nth-child(1) { transition-delay: 0.15s; }
.o-nas:nth-child(2) { transition-delay: 0.3s; }
.o-nas:nth-child(3) { transition-delay: 0.45s; }

/* =========================================================
   PIEROGI-BYDGOSZCZ.PL — HEADER SCROLL (CLEAN, NO HOVER BLOCK)
   Klasa na kontenerze headera: pb-header
   JS dodaje: is-compact, is-hidden, is-shown
   JS dodaje na body: pb-overlay
========================================================= */

body.pb-overlay::before{
  content:"";
  position: fixed;
  inset: 0;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: 9990;
  pointer-events: none;
  opacity: 1;
  transition: opacity .22s ease;
}

@media (hover: none), (pointer: coarse){
  body.pb-overlay::before{ display:none !important; }
}

body{
  padding-top: var(--pb-header-h, 0px);
}

.pb-header{
  position: fixed !important;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 9999 !important;

  background: #fff;
  overflow: visible !important;

  --pb-x: 0px;
  --pb-y: 0%;
  transform: translate3d(var(--pb-x), var(--pb-y), 0);

  opacity: 1;
  transition:
    transform .26s ease,
    opacity .26s ease,
    width .55s cubic-bezier(.22,1,.36,1),
    left .55s cubic-bezier(.22,1,.36,1),
    margin-top .55s cubic-bezier(.22,1,.36,1),
    border-radius .55s cubic-bezier(.22,1,.36,1),
    box-shadow .55s cubic-bezier(.22,1,.36,1);
}

.pb-header.is-compact{
  width: 1300px;
  left: 50%;
  --pb-x: -50%;
  margin-top: 16px;
  border-radius: 22px;
  box-shadow: 0 18px 55px rgba(0,0,0,.14);
}

@media (max-width: 1360px){
  .pb-header.is-compact{
    width: calc(100% - 24px);
  }
}

.pb-header.is-hidden{
  --pb-y: -120%;
  opacity: 0;
  pointer-events: none;
}

.pb-header.is-shown{
  --pb-y: 0%;
  opacity: 1;
  pointer-events: auto;
}
.pb-header{ will-change: width, left, transform, opacity; }
.pb-header{ transition: transform .26s ease, opacity .26s ease, width .55s cubic-bezier(.22,1,.36,1), left .55s cubic-bezier(.22,1,.36,1), margin-top .55s cubic-bezier(.22,1,.36,1), border-radius .55s cubic-bezier(.22,1,.36,1), box-shadow .55s cubic-bezier(.22,1,.36,1) !important; }

  .pbk-wrap{
    --pbk-red:#e53935;
    --pbk-text:#111;
    --pbk-muted:rgba(17,17,17,.62);
    --pbk-line:rgba(17,17,17,.10);
    --pbk-soft:rgba(17,17,17,.05);

    --pbk-radius: 26px;
    --pbk-shadow: 0 18px 46px rgba(0,0,0,.10);

    background:#fff;
    color:var(--pbk-text);
    max-width: 980px;
    margin: 0 auto;
    padding: 14px 14px 6px;

    border: 1px solid rgba(17,17,17,.10);
    border-radius: var(--pbk-radius);
    box-shadow: var(--pbk-shadow);
  }

  .pbk-nav{
    padding: 2px 2px 14px;
    border-bottom: 1px solid var(--pbk-line);
    margin-bottom: 6px;
  }
  .pbk-nav__title{
    font-weight: 800;
    letter-spacing: .2px;
    font-size: 16px;
    margin: 0 0 10px;
    padding: 0 6px;
  }
  .pbk-nav__title::before{
    content:"";
    display:inline-block;
    width: 10px; height: 10px;
    border-radius: 999px;
    background: var(--pbk-red);
    margin-right: 10px;
    transform: translateY(1px);
  }
  .pbk-nav__links{
    display:flex;
    flex-wrap:wrap;
    gap: 8px;
    padding: 0 6px;
  }
  .pbk-nav__links a{
    text-decoration:none;
    color: var(--pbk-text);
    font-size: 13px;
    padding: 8px 10px;
    border: 1px solid var(--pbk-line);
    border-radius: 999px;
    background:#fff;
    transition: transform .16s ease, border-color .16s ease, background .16s ease;
  }
  .pbk-nav__links a:hover{
    transform: translateY(-1px);
    border-color: rgba(229,57,53,.35);
    background: rgba(229,57,53,.06);
  }

  .pbk-section{ padding: 0 6px; }

  .pbk-row{
    display:flex;
    align-items:center;
    justify-content: space-between;
    gap: 12px;

    text-decoration:none;
    color: var(--pbk-text);

    padding: 16px 12px;
    border-bottom: 1px solid var(--pbk-line);
    background:#fff;
    transition: background .16s ease, transform .16s ease;
  }

  .pbk-section:first-of-type .pbk-row{
    border-top-left-radius: 18px;
    border-top-right-radius: 18px;
  }
  .pbk-section:last-of-type .pbk-row{
    border-bottom-left-radius: 18px;
    border-bottom-right-radius: 18px;
    border-bottom: 0;
  }

  .pbk-row:hover{
    background: var(--pbk-soft);
    transform: translateY(-1px);
  }

  .pbk-name{ font-weight: 750; font-size: 16px; letter-spacing: .15px; }
  .pbk-arrow{ color: var(--pbk-muted); font-weight: 900; }

  .pbk-pill{
    margin-left: auto;
    margin-right: 8px;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .35px;
    color: var(--pbk-red);
    border: 1px solid rgba(229,57,53,.30);
    background: rgba(229,57,53,.06);
    padding: 4px 8px;
    border-radius: 999px;
  }

  .pbk-reveal{ opacity:0; transform: translateY(-14px); }
  .pbk-reveal.is-in{ animation: pbkDrop .55s cubic-bezier(.2,.9,.2,1) forwards; }
  @keyframes pbkDrop{
    0%   { opacity:0; transform: translateY(-14px); }
    70%  { opacity:1; transform: translateY(2px); }
    100% { opacity:1; transform: translateY(0); }
  }

  @media (prefers-reduced-motion: reduce){
    .pbk-reveal{ opacity:1; transform:none; }
    .pbk-reveal.is-in{ animation:none; }
    .pbk-row, .pbk-nav__links a{ transition:none; }
  }

.pbk-row.pbk-flash{
  border-bottom-color: rgba(229,57,53,.25);
  animation: pbkFlash 1.05s ease-in-out 1;
}

@keyframes pbkFlash{
  0%   { box-shadow: 0 0 0 rgba(0,0,0,0); background:#fff; transform: translateY(0); }
  12%  { box-shadow: 0 0 0 6px rgba(229,57,53,.12); background: rgba(229,57,53,.06); transform: translateY(-1px); }
  24%  { box-shadow: 0 0 0 rgba(0,0,0,0); background:#fff; transform: translateY(0); }

  38%  { box-shadow: 0 0 0 8px rgba(229,57,53,.10); background: rgba(229,57,53,.06); transform: translateY(-1px); }
  52%  { box-shadow: 0 0 0 rgba(0,0,0,0); background:#fff; transform: translateY(0); }

  70%  { box-shadow: 0 0 0 7px rgba(229,57,53,.10); background: rgba(229,57,53,.06); transform: translateY(-1px); }
  100% { box-shadow: 0 0 0 rgba(0,0,0,0); background:#fff; transform: translateY(0); }
}

.pbk-row.pbk-flash .pbk-arrow{
  animation: pbkArrowBlink 1.05s ease-in-out 1;
}

@keyframes pbkArrowBlink{
  0%, 100% { opacity: 1; transform: translateX(0); }
  15%      { opacity: .2; transform: translateX(3px); }
  30%      { opacity: 1; }
  45%      { opacity: .2; transform: translateX(3px); }
  60%      { opacity: 1; }
  75%      { opacity: .2; transform: translateX(3px); }
}

@media (prefers-reduced-motion: reduce){
  .pbk-row.pbk-flash,
  .pbk-row.pbk-flash .pbk-arrow{
    animation:none !important;
  }
}
.pbk-row.pbk-flash{
  border-radius: 18px;
  outline: 2px solid rgba(229,57,53,.20);
  outline-offset: -2px;
}

/* === PBN2: Statyczne menu kategorii pod headerem === */
.pbn2-nav{
  --red:#e53935;
  --text:#111;
  --line:rgba(17,17,17,.10);

  max-width: 1200px;
  margin: 12px auto 0;
  padding: 0 14px;
}

.pbn2-inner{
  background:#fff;
  border:1px solid var(--line);
  border-radius: 22px;
  box-shadow: 0 16px 44px rgba(0,0,0,.10);
  padding: 14px 14px 12px;
}

.pbn2-title{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:900;
  font-size:15px;
  margin-bottom:12px;
  user-select:none;
}

.pbn2-dot{
  width:10px;
  height:10px;
  border-radius:999px;
  background:var(--red);
  box-shadow:0 0 0 6px rgba(229,57,53,.12);
}

.pbn2-menu{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.pbn2-item{
  text-decoration:none;
  color:var(--text);
  font-size:13px;
  font-weight:700;
  letter-spacing:.12px;

  padding:8px 12px;
  border-radius:999px;
  border:1px solid var(--line);
  background:#fff;

  transition:transform .15s ease, background .15s ease, border-color .15s ease;
}

.pbn2-item:hover{
  transform:translateY(-1px);
  border-color:rgba(229,57,53,.30);
  background:rgba(229,57,53,.05);
}

.pbn2-item--all{
  border-color:rgba(229,57,53,.30);
  background:rgba(229,57,53,.06);
}

.pbn2-item--top{
  font-weight:800;
}

.pbn2-badge{
  margin-left:6px;
  font-size:11px;
  font-weight:900;
  color:var(--red);
  border:1px solid rgba(229,57,53,.30);
  background:rgba(229,57,53,.06);
  padding:3px 7px;
  border-radius:999px;
}

/* mobile */
@media (max-width: 520px){
  .pbn2-inner{ padding:12px; }
  .pbn2-item{ font-size:12.5px; padding:7px 11px; }
}

/* Pierogi-Bydgoszcz — Default list styling
   Cel: czysto, premium, białe tło + delikatny czerwony akcent
*/
:root{
  --pb-text: rgba(10,10,10,.88);
  --pb-muted: rgba(10,10,10,.62);
  --pb-border: rgba(0,0,0,.08);
  --pb-soft: rgba(0,0,0,.04);
  --pb-red: #b31217; /* delikatna czerwień (zmień, jeśli masz brand red) */
  --pb-radius: 14px;
  --pb-shadow: 0 10px 28px rgba(0,0,0,.08);
}

.entry-content ul,
.entry-content ol,
.elementor-widget-text-editor ul,
.elementor-widget-text-editor ol,
.elementor-widget-theme-post-content ul,
.elementor-widget-theme-post-content ol{
  color: var(--pb-text);
  margin: 16px 0;
  padding: 0;
  list-style: none;
}

/* „Karta” listy – działa przy listach używanych jako sekcje informacji */
.entry-content ul,
.elementor-widget-text-editor ul,
.elementor-widget-theme-post-content ul{
  background: #fff;
  border: 1px solid var(--pb-border);
  border-radius: var(--pb-radius);
  box-shadow: var(--pb-shadow);
  padding: 10px 12px;
}

/* Dla ol nie rób karty, tylko klasycznie z numeracją – ale elegancko */
.entry-content ol,
.elementor-widget-text-editor ol,
.elementor-widget-theme-post-content ol{
  counter-reset: pb-ol;
  padding-left: 0;
}

/* Elementy listy */
.entry-content li,
.elementor-widget-text-editor li,
.elementor-widget-theme-post-content li{
  position: relative;
  padding: 12px 10px 12px 36px;
  margin: 0;
  line-height: 1.55;
  border-bottom: 1px solid var(--pb-soft);
}

.entry-content li:last-child,
.elementor-widget-text-editor li:last-child,
.elementor-widget-theme-post-content li:last-child{
  border-bottom: 0;
}

/* Bullet dla UL: kropka + cienki ring */
.entry-content ul > li::before,
.elementor-widget-text-editor ul > li::before,
.elementor-widget-theme-post-content ul > li::before{
  content: "";
  position: absolute;
  left: 12px;
  top: 18px;
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: var(--pb-red);
  box-shadow:
    0 0 0 3px rgba(179,18,23,.10),
    0 6px 14px rgba(0,0,0,.10);
}

/* Numeracja dla OL: „badge” w czerwieni */
.entry-content ol > li,
.elementor-widget-text-editor ol > li,
.elementor-widget-theme-post-content ol > li{
  counter-increment: pb-ol;
  padding-left: 48px;
}

.entry-content ol > li::before,
.elementor-widget-text-editor ol > li::before,
.elementor-widget-theme-post-content ol > li::before{
  content: counter(pb-ol);
  position: absolute;
  left: 10px;
  top: 12px;
  width: 26px;
  height: 26px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  font-size: 13px;
  font-weight: 700;
  color: #fff;
  background: var(--pb-red);
  box-shadow: 0 8px 18px rgba(179,18,23,.22);
}

/* Linki w listach */
.entry-content li a,
.elementor-widget-text-editor li a,
.elementor-widget-theme-post-content li a{
  color: var(--pb-text);
  text-decoration: none;
  border-bottom: 1px solid rgba(179,18,23,.25);
  transition: .18s ease;
}

.entry-content li a:hover,
.elementor-widget-text-editor li a:hover,
.elementor-widget-theme-post-content li a:hover{
  color: var(--pb-red);
  border-bottom-color: rgba(179,18,23,.55);
}

/* Drobne teksty w listach */
.entry-content li small,
.elementor-widget-text-editor li small,
.elementor-widget-theme-post-content li small{
  color: var(--pb-muted);
}

/* Hover całego wiersza (subtelny) */
@media (hover:hover){
  .entry-content ul > li:hover,
  .elementor-widget-text-editor ul > li:hover,
  .elementor-widget-theme-post-content ul > li:hover{
    background: rgba(179,18,23,.03);
    border-radius: 10px;
  }
}

/* Mobile: ciaśniej */
@media (max-width: 767px){
  .entry-content ul,
  .elementor-widget-text-editor ul,
  .elementor-widget-theme-post-content ul{
    padding: 8px 10px;
  }

  .entry-content li,
  .elementor-widget-text-editor li,
  .elementor-widget-theme-post-content li{
    padding: 11px 10px 11px 34px;
  }

  .entry-content ul > li::before,
  .elementor-widget-text-editor ul > li::before,
  .elementor-widget-theme-post-content ul > li::before{
    left: 10px;
  }

  .entry-content ol > li{
    padding-left: 44px;
  }
}