.awb-menu__open-nav-submenu_mobile {
  position: relative !important;
  width: 40px !important;
  height: 40px !important;
  background: transparent !important;
  border: none !important;
  cursor: pointer !important;
  padding: 0 !important;
  margin-left: -10px !important;
}

.awb-menu__open-nav-submenu_mobile::after {
  content: '' !important;
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) rotate(0deg) !important;
  width: 0 !important;
  height: 0 !important;
  border-left: 8px solid transparent !important;
  border-right: 8px solid transparent !important;
  border-top: 10px solid #fff !important;
  transition: transform 0.3s ease, border-top-color 0.3s ease !important;
}

.awb-menu__sub-ul .awb-menu__open-nav-submenu_mobile::after {
  border-top: 10px solid #fff !important;
}

.awb-menu__open-nav-submenu_mobile:hover::after {
  border-top-color: #999 !important;
}

.awb-menu__sub-ul .awb-menu__open-nav-submenu_mobile:hover::after {
  border-top-color: #333 !important;
}

.awb-menu__open-nav-submenu_mobile[aria-expanded="true"]::after {
  transform: translate(-50%, -50%) rotate(180deg) !important;
  border-top-color: #fff !important;
}

.awb-menu__sub-ul .awb-menu__open-nav-submenu_mobile[aria-expanded="true"]::after {
  border-top-color: #fff !important;
}

.awb-menu__sub-li:has(.awb-menu__open-nav-submenu_mobile[aria-expanded="true"]) {
  background-color: rgba(240, 240, 240, 0.2) !important;
}

@media (max-width: 800px) {
  /*
     * Dodaje grubą, czarną linię na dole rozwiniętej listy podkategorii.
    */

  .awb-menu__sub-li:has(.awb-menu__open-nav-submenu_mobile[aria-expanded="true"]) > .awb-menu__sub-ul {
    border-bottom: 4px solid #000000 !important;
    padding-bottom: 0px !important;
    /* Dodaje trochę odstępu między ostatnim elementem a linią */
    margin-bottom: 0px !important;
    /* Dodaje odstęp pod linią, przed następną kategorią */
  }
}

@media (max-width: 800px) {
  .awb-menu__open-nav-submenu_mobile {
    width: 50px !important;
    height: 50px !important;
    margin-left: -15px !important;
  }

  .awb-menu__open-nav-submenu_mobile::after {
    border-left: 10px solid transparent !important;
    border-right: 10px solid transparent !important;
    border-top: 12px solid #fff !important;
  }

  .awb-menu__sub-ul .awb-menu__open-nav-submenu_mobile::after {
    border-top: 12px solid #000 !important;
  }
}

@media (max-width: 768px) {
  /* Główny kontener kolumny */

  .fusion-layout-column.fusion_builder_column_1_1 {
    margin-left: 15px !important;
    margin-right: 15px !important;
    width: calc(100% - 30px) !important;
    --awb-spacing-left-small: 0 !important;
    --awb-spacing-right-small: 0 !important;
  }

  .fusion-search-element {
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  .fusion-search-form {
    width: 100% !important;
  }

  .fusion-search-form-content {
    width: 100% !important;
    display: flex !important;
    flex-direction: row !important;
  }

  .fusion-search-field {
    flex: 1 !important;
    width: auto !important;
  }

  .fusion-search-field label {
    display: block;
    width: 100%;
  }

  .fusion-search-field input[type="search"].s {
    width: 100% !important;
    box-sizing: border-box;
    margin: 0;
    padding-right: 30px !important;
    -webkit-appearance: searchfield;
  }

  .fusion-search-field input[type="search"].s::-webkit-search-cancel-button {
    -webkit-appearance: searchfield-cancel-button !important;
    display: block !important;
    width: 20px !important;
    height: 20px !important;
    margin: 0 5px 0 0 !important;
    position: relative !important;
    right: 0 !important;
    cursor: pointer !important;
  }

  .fusion-search-field {
    overflow: visible !important;
    position: relative !important;
  }

  .fusion-search-button {
    width: auto !important;
    flex-shrink: 0 !important;
  }

  .fusion-search-submit {
    height: 75px;
    border-radius: 0;
  }
}

/* Ukrycie samej ikony koszyka w efekcie rollover na produktach */

.fusion-add-to-cart-rollover {
  display: none !important;
}

@media (max-width: 800px) {
  /* --- NOWY, POPRAWIONY STYL DLA GŁÓWNYCH KATEGORII W MENU MOBILNYM --- */

  /* 1. Ustawiamy styl dla całego "przycisku" kategorii (biała ramka, czarne tło i odstęp) */

  #mobile-menu-wrap .awb-menu__main-ul > .awb-menu__sub-li {
    border: 1px solid #FFFFFF !important;
    /* Biała ramka wokół całego elementu */
    border-radius: 5px !important;
    /* Opcjonalnie: zaokrąglone rogi */
    margin-bottom: 8px !important;
    /* Odstęp pomiędzy kategoriami */
    background-color: #000000 !important;
    /* Czarne tło dla całego elementu */
  }

  /* 2. Ustawiamy styl dla samego tekstu wewnątrz przycisku */

  #mobile-menu-wrap .awb-menu__main-ul > .awb-menu__sub-li > .awb-menu__main-a {
    background-color: #000000 !important;
    /* Upewniamy się, że tło linku też jest czarne */
    color: #FFFFFF !important;
    /* Biały tekst */
  }

  /* 3. Upewniamy się, że strzałki są białe */

  #mobile-menu-wrap .awb-menu__main-ul > .awb-menu__sub-li .awb-menu__open-nav-submenu_mobile::after {
    border-top-color: #FFFFFF !important;
  }

  /* 4. Upewniamy się, że strzałki po rozwinięciu też są białe */

  #mobile-menu-wrap .awb-menu__main-ul > .awb-menu__sub-li .awb-menu__open-nav-submenu_mobile[aria-expanded="true"]::after {
    border-top-color: #FFFFFF !important;
  }

  /* 5. Usuwamy domyślną dolną kreskę, aby nie kolidowała z nową, pełną ramką */

  .awb-menu__main-ul > .awb-menu__sub-li:not(:last-child) > .awb-menu__main-a {
    border-bottom: none !important;
  }
}

@media (max-width: 800px) {
  /* --- NOWY KOD: Ustawia WSZYSTKIE strzałki w menu na kolor biały --- */

  /* 1. Ustawia domyślny kolor strzałek na biały (na wszystkich poziomach) */

  .awb-menu__open-nav-submenu_mobile::after {
    border-top-color: #FFFFFF !important;
  }

  /* 2. Upewnia się, że strzałki w podmenu TEŻ są białe (nadpisuje regułę, która robiła je czarnymi) */

  .awb-menu__sub-ul .awb-menu__open-nav-submenu_mobile::after {
    border-top-color: #FFFFFF !important;
  }

  /* 3. Upewnia się, że strzałki po rozwinięciu (skierowane w górę) też są białe */

  .awb-menu__open-nav-submenu_mobile[aria-expanded="true"]::after {
    border-top-color: #FFFFFF !important;
  }

  /* 4. Upewnia się, że strzałki po rozwinięciu w podmenu też są białe */

  .awb-menu__sub-ul .awb-menu__open-nav-submenu_mobile[aria-expanded="true"]::after {
    border-top-color: #FFFFFF !important;
  }
}

@media (max-width: 800px) {
  /* --- NOWY KOD: Usunięcie białych linii oddzielających w podkategoriach --- */

  /* Celujemy we wszystkie elementy listy () wewnątrz dowolnego podmenu i usuwamy ich dolną ramkę */

  .awb-menu__sub-ul .awb-menu__sub-li {
    border-bottom: none !important;
  }

  /* Dodatkowo usuwamy górną ramkę, na wypadek gdyby motyw jej używał */

  .awb-menu__sub-ul .awb-menu__sub-li {
    border-top: none !important;
  }
}

@media (max-width: 800px) {
  /* --- NOWY KOD: Biała linia na dole rozwiniętej listy podkategorii --- */

  .awb-menu__sub-li:has(.awb-menu__open-nav-submenu_mobile[aria-expanded="true"]) > .awb-menu__sub-ul {
    border-bottom: 1px solid #FFFFFF !important;
    /* Cienka, biała linia na dole */
    padding-bottom: 1px !important;
    /* Odstęp między ostatnim elementem a linią */
    margin-bottom: 1px !important;
    /* Odstęp od linii do następnej kategorii */
  }
}

.awb-menu__sub-ul .awb-menu__sub-li {
  border-bottom: none !important;
}

/* Dodatkowo usuwamy górną ramkę, na wypadek gdyby motyw jej używał */

.awb-menu__sub-ul .awb-menu__sub-li {
  border-top: none !important;
}

.awb-menu__sub-li:has(.awb-menu__open-nav-submenu_mobile[aria-expanded="true"]) > .awb-menu__sub-ul {
  border-bottom: 1px solid #FFFFFF !important;
  /* Cienka, biała linia na dole */
  padding-bottom: 1px !important;
  /* Odstęp między ostatnim elementem a linią */
  margin-bottom: 1px !important;
  /* Odstęp od linii do następnej kategorii */
}

/* Ukrycie panelu sterowania lightboxem w produktach WooCommerce (Avada) */

.single-product .pswp__ui {
  display: none !important;
}

@media (max-width: 800px) {
  .ilightbox-toolbar {
    display: none !important;
  }
}

/* --- Poprawki dla wtyczki "Product Gallery Slider" na motywie Avada --- */

/* 1. Naprawia problem z uciętym i powiększonym zdjęciem (zoom) */

.wpgs-main-gallery .slick-slide img {
  width: 100% !important;
  height: auto !important;
  object-fit: contain !important;
  /* To jest kluczowa reguła, która dopasowuje obraz do ramki */
}

/* 2. Naprawia problem znikającej prawej strzałki */

.wpgs-gallery-wrapper {
  overflow: visible !important;
  /* Pozwala strzałce "wyjść" poza niewidzialną granicę kontenera */
}

/* --- Wymusza widoczność przycisku zamknięcia lightboxa Avady --- */

#ilightbox-container #ilightbox-toolbar .ilightbox-button.ilightbox-button-close {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  position: absolute !important;
  top: 15px !important;
  /* Odległość od góry */
  right: 15px !important;
  /* Odległość od prawej */
  background: rgba(0,0,0,0.5) !important;
  /* Ciemne tło dla lepszej widoczności */
  border-radius: 50% !important;
  /* Kółko */
  width: 30px !important;
  height: 30px !important;
  line-height: 30px !important;
  /* Wyśrodkowanie ikony X */
  font-size: 18px !important;
  color: #fff !important;
  /* Kolor ikony X */
  text-align: center !important;
}

.ilightbox-holder .ilightbox-thumbnails {
  display: flex !important;
  position: absolute !important;
  bottom: 20px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  gap: 10px !important;
}

@media (max-width: 480px) {
  /* Scrollbar dla miniaturek */

  .my-custom-lightbox .lightbox-thumbnails::-webkit-scrollbar {
    height: 6px;
  }

  .my-custom-lightbox .lightbox-thumbnails::-webkit-scrollbar-track {
    background: rgba(255,255,255,0.1);
    border-radius: 3px;
  }

  .my-custom-lightbox .lightbox-thumbnails::-webkit-scrollbar-thumb {
    background: rgba(255,255,255,0.3);
    border-radius: 3px;
  }

  /* Podstawowe style lightbox */

  .my-custom-lightbox {
    padding: 15px !important;
  }

  .my-custom-lightbox .lightbox-content {
    max-width: 85% !important;
    max-height: 65% !important;
  }

  /* Przyciski nawigacji */

  .my-custom-lightbox .lightbox-prev,
  .my-custom-lightbox .lightbox-next {
    width: 45px !important;
    height: 45px !important;
    font-size: 22px !important;
    left: -50px !important;
    /* Zapewniamy że przyciski są kliklne */
    pointer-events: auto !important;
    touch-action: manipulation !important;
  }

  .my-custom-lightbox .lightbox-next {
    right: -50px !important;
    left: auto !important;
  }

  /* Licznik */

  .my-custom-lightbox .lightbox-counter {
    bottom: 90px !important;
    font-size: 12px !important;
    padding: 6px 12px !important;
  }

  /* Miniaturki */

  .my-custom-lightbox .lightbox-thumbnails {
    bottom: 25px !important;
    max-width: 95vw !important;
    gap: 6px !important;
    /* Zapewniamy że miniaturki są klikalne */
    pointer-events: auto !important;
  }

  .my-custom-lightbox .lightbox-thumb {
    width: 55px !important;
    height: 55px !important;
    /* Zapewniamy że każda miniaturka jest klikalna */
    pointer-events: auto !important;
    touch-action: manipulation !important;
    cursor: pointer !important;
  }

  /* Aktywne stany tylko dla dotyku - bez hover */

  .my-custom-lightbox .lightbox-prev:active,
  .my-custom-lightbox .lightbox-next:active {
    background: rgba(255,255,255,0.8) !important;
    transform: translateY(-50%) scale(0.95) !important;
  }

  .my-custom-lightbox .lightbox-thumb:active {
    transform: scale(0.95) !important;
    opacity: 0.8 !important;
  }
}

/* Bardzo małe telefony - 360px i mniej */

@media (max-width: 360px) {
  .my-custom-lightbox .lightbox-content {
    max-width: 90% !important;
    max-height: 60% !important;
  }

  .my-custom-lightbox .lightbox-prev,
  .my-custom-lightbox .lightbox-next {
    width: 40px !important;
    height: 40px !important;
    font-size: 20px !important;
  }

  .my-custom-lightbox .lightbox-prev {
    left: 5px !important;
  }

  .my-custom-lightbox .lightbox-next {
    right: 5px !important;
  }

  .my-custom-lightbox .lightbox-thumb {
    width: 45px !important;
    height: 45px !important;
  }

  .my-custom-lightbox .lightbox-thumbnails {
    gap: 6px !important;
    padding: 8px 10px !important;
    bottom: 15px !important;
  }

  .my-custom-lightbox .lightbox-counter {
    bottom: 70px !important;
    font-size: 11px !important;
    padding: 5px 10px !important;
  }
}

/* Hover tylko dla urządzeń NON-touch (desktop) */

@media (hover: hover) and (pointer: fine) {
  .my-custom-lightbox .lightbox-close:hover {
    background: rgba(255,255,255,1) !important;
    transform: scale(1.1) !important;
  }

  .my-custom-lightbox .lightbox-prev:hover,
  .my-custom-lightbox .lightbox-next:hover {
    background: rgba(255,255,255,1) !important;
    transform: translateY(-50%) scale(1.1) !important;
    box-shadow: 0 6px 20px rgba(0,0,0,0.4) !important;
  }

  .my-custom-lightbox .lightbox-thumb:hover {
    transform: scale(1.1) !important;
    border-color: rgba(255,255,255,0.6) !important;
    box-shadow: 0 4px 12px rgba(0,0,0,0.5) !important;
  }
}

/*
 * Eksperymentalna próba zmiany koloru przycisku "x" na biały 
 * w polach wyszukiwania na przeglądarkach WebKit.
*/

input[type="search"]::-webkit-search-cancel-button {
  filter: invert(1) brightness(2) grayscale(1);
}

#alg_currency_select.alg_currency_select {
  /* Ustawienie zerowego promienia zaokrąglenia */
  border-radius: 0 !important;
}

/* WAŻNE: W zależności od dokładnej struktury HTML wtyczki, 
  może być konieczna modyfikacja elementu wewnątrz selecta (np. samego  lub ) */

#alg_currency_select.alg_currency_select select {
  border-radius: 0 !important;
}

/* Możesz też spróbować usunąć domyślne style tła i cienia, aby był czysty */

#alg_currency_select.alg_currency_select {
  box-shadow: none !important;
  padding: 5px 10px !important;
  /* Dostosuj padding, jeśli jest potrzebny */
}

#alg_currency_select.alg_currency_select select {
  /* Ustawienie zerowego promienia zaokrąglenia */
  border-radius: 0 !important;
}

/*
 * Ukrywa zduplikowane powiadomienia blokowe WooCommerce (Avada),
 * zostawiając tylko pierwsze z nich.
*/

.fusion-woo-notices-tb .wc-block-components-notice-banner.is-error:not(:first-of-type) {
  display: none !important;
}

.fusion-woo-notices-tb .wc-block-components-notice-banner.is-success:not(:first-of-type) {
  display: none !important;
}

/* To jest główne okienko (zamknięte) */

#alg_currency_select {
  background-color: #000000 !important;
  color: #FFFFFF !important;
  border: none !important;
  cursor: pointer !important;
  transition: color 0.3s ease !important;
  /* Usunąłem stąd overflow-y: hidden, 
       bo nie jest już potrzebne bez skryptu JavaScript */
}

/* Główne okienko po najechaniu myszką */

#alg_currency_select:hover {
  color: #BBBBBB !important;
  /* Zmienia kolor tekstu na lekko szary */
}

/* To są opcje na liście (po otwarciu) */

#alg_currency_select option {
  background-color: #000000 !important;
  color: #FFFFFF !important;
  /* DODANE: Kursor "rączki" także dla opcji na liście */
  cursor: pointer !important;
}

/* Opcja 3: Efekt uniesienia (cień/poświata) */

#toTop {
  background-color: #222222 !important;
  /* Bardzo ciemny szary */
  color: #ffffff !important;
  border-radius: 4px;
  /* Delikatna jasna poświata wokół przycisku */
  box-shadow: 0 4px 15px rgba(255, 255, 255, 0.15) !important;
}

#toTop:hover {
  background-color: #000000 !important;
  /* Poświata znika przy najechaniu (efekt wciśnięcia) */
  box-shadow: none !important;
  transition: all 0.3s ease;
}

/* ==================================================
   STYLIZACJA NOWYCH KOMUNIKATÓW WOOCOMMERCE BLOCKS
   ================================================== */

/* --- 1. KOMUNIKAT BŁĘDU (CZERWONY) --- */

/* Celujemy w klasę 'is-error' wewnątrz banera */

.wc-block-components-notice-banner.is-error,
.avada-woocommerce-error {
  background-color: #e03838 !important;
  /* Czerwone tło */
  border: none !important;
  margin-bottom: 20px !important;
}

/* Tekst wewnątrz błędu */

.wc-block-components-notice-banner.is-error .wc-block-components-notice-banner__content,
.wc-block-components-notice-banner.is-error .wc-notices-text,
.avada-woocommerce-error .wc-block-components-notice-banner__content {
  color: #ffffff !important;
  /* Biały tekst */
}

/* Ikonki wewnątrz błędu (zarówno czcionkowe 'i' jak i 'svg') */

.wc-block-components-notice-banner.is-error i,
.wc-block-components-notice-banner.is-error svg {
  color: #ffffff !important;
  fill: #ffffff !important;
}

/* --- 2. KOMUNIKAT SUKCESU (ZIELONY) --- */

/* Celujemy w klasę 'is-success' */

.wc-block-components-notice-banner.is-success {
  background-color: #28a745 !important;
  /* Zielone tło */
  border: none !important;
  margin-bottom: 20px !important;
}

/* Tekst wewnątrz sukcesu */

.wc-block-components-notice-banner.is-success .wc-block-components-notice-banner__content,
.wc-block-components-notice-banner.is-success .wc-notices-text {
  color: #ffffff !important;
  /* Biały tekst */
}

/* Ikonki wewnątrz sukcesu */

.wc-block-components-notice-banner.is-success i,
.wc-block-components-notice-banner.is-success svg {
  color: #ffffff !important;
  fill: #ffffff !important;
}

/* --- 3. KOMUNIKAT INFO (NIEBIESKI - Opcjonalnie) --- */

.wc-block-components-notice-banner.is-info {
  background-color: #17a2b8 !important;
  color: #ffffff !important;
}

.wc-block-components-notice-banner.is-info .wc-block-components-notice-banner__content {
  color: #ffffff !important;
}

/* Ukryj natychmiastowo standardowy napis 'Nic nie znalezione' w Avadzie */

.fusion-nothing-found {
  display: none !important;
}

/* === ZMNIEJSZONE STRZAŁKI (AWB Image) === */

.awb-pc-image__next,
.awb-pc-image__prev {
  /* 1. NOWE WYMIARY (Zmniejszone z 40px na 30px) */
  width: 30px !important;
  height: 30px !important;
  /* 2. MNIEJSZA IKONA (Dopasowana do tła) */
  font-size: 12px !important;
  /* 3. Reszta stylów (Centrowanie, Kolory, Kształt) */
  border-radius: 6px !important;
  /* Lekkie zaokrąglenie */
  background-color: #999999 !important;
  /* Szare tło */
  color: #ffffff !important;
  /* Biała strzałka */
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  line-height: 1 !important;
  border: none !important;
}

/* Precyzyjne centrowanie samej ikony */

.awb-pc-image__next i,
.awb-pc-image__prev i {
  margin: 0 !important;
  line-height: 0 !important;
}

/* === ZMNIEJSZONE STRZAŁKI (AWB Image) - KOLOR DOMYŚLNY === */

.awb-pc-image__next,
.awb-pc-image__prev {
  /* 1. WYMIARY (30px) */
  width: 30px !important;
  height: 30px !important;
  /* 2. IKONA */
  font-size: 12px !important;
  /* 3. KOLORYSTYKA (Dopasowana do FlexSlidera) */
  /* Zmieniamy szary (#999999) na półprzezroczysty czarny */
  background-color: rgba(0, 0, 0, 0.5) !important;
  color: #ffffff !important;
  /* Biała strzałka */
  /* 4. KSZTAŁT I CENTROWANIE */
  border-radius: 6px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  line-height: 1 !important;
  border: none !important;
}

/* Centrowanie ikony */

.awb-pc-image__next i,
.awb-pc-image__prev i {
  margin: 0 !important;
  line-height: 0 !important;
}

/* Opcjonalnie: Efekt po najechaniu myszką (żeby pociemniało jak w oryginale) */

.awb-pc-image__next:hover,
.awb-pc-image__prev:hover {
  background-color: rgba(0, 0, 0, 0.8) !important;
}

/* === ZMNIEJSZONE STRZAŁKI FLEXSLIDER (30px) === */

.flex-next,
.flex-prev {
  /* 1. NOWE WYMIARY (Zmniejszone z 40px na 30px) */
  width: 30px !important;
  height: 30px !important;
  /* 2. MNIEJSZA IKONA W ŚRODKU */
  /* Dopasowujemy wielkość znaku, żeby nie rozpychał małego tła */
  font-size: 12px !important;
  /* 3. KSZTAŁT I CENTROWANIE */
  border-radius: 6px !important;
  /* Lekkie zaokrąglenie */
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  /* Reset marginesów */
  padding: 0 !important;
  line-height: 1 !important;
}

/* Opcjonalnie: Jeśli chcesz, żeby też były szare jak tamte */

/*.flex-next, .flex-prev {
    background-color: #999999 !important;
    color: #ffffff !important;
}

/* === NAPRAWA GALERII: ZMNIEJSZENIE OBRAZKA WEWNĄTRZ === */

/* Targetujemy sam obrazek (img) wewnątrz slajdu */

.woocommerce-product-gallery__image img {
  /* 1. Zmniejszamy zdjęcie do 95% szerokości kontenera.
       To automatycznie tworzy 5% pustej przestrzeni (marginesu). */
  width: 95% !important;
  /* 2. Centrujemy zdjęcie w poziomie.
       Dzięki temu odstęp rozkłada się po równo z lewej i prawej (po 2.5%). */
  margin-left: auto !important;
  margin-right: auto !important;
  display: block !important;
  /* 3. Zapewniamy, że wysokość skaluje się proporcjonalnie */
  height: auto !important;
  /* Opcjonalnie: Jeśli zdjęcia mają cień, który ucina, można dodać margines wewnętrzny */
  /* padding: 2px !important; */
}

/* === CSS LIGHTBOX V6: POPRAWKA DESKTOP === */

/* Ukrycie oryginałów */

.ilightbox-overlay,
.ilightbox-loader,
.ilightbox-holder {
  display: none !important;
}

/* Kontener główny */

#my-mobile-lightbox {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.95);
  z-index: 2147483647;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

#my-mobile-lightbox.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

/* Główne zdjęcie (Mobile - domyślne) */

#mml-image {
  max-width: 100%;
  max-height: 75vh;
  object-fit: contain;
  touch-action: none;
  transform-origin: center center;
  transition: transform 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

/* Tarcza na oryginalnych zdjęciach */

.custom-gallery-shield {
  position: absolute !important;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 999 !important;
  cursor: pointer;
  background: transparent;
}

/* Przyciski nawigacji (Bez zmian wyglądu) */

.mml-nav {
  position: absolute;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 30px;
  height: 30px;
  background-color: rgba(0, 0, 0, 0.5);
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 2147483648;
  transition: opacity 0.2s ease;
}

.mml-nav::before {
  color: #fff;
  font-size: 20px;
  line-height: 1;
  font-family: sans-serif;
  padding-bottom: 2px;
}

.mml-prev {
  left: 10px;
}

.mml-prev::before {
  content: '‹';
}

.mml-next {
  right: 10px;
}

.mml-next::before {
  content: '›';
}

/* Zamknij */

.mml-close {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 40px;
  height: 40px;
  background: #fff;
  border-radius: 50%;
  color: #000;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  font-weight: bold;
  cursor: pointer;
  z-index: 2147483648;
}

/* Miniaturki */

.mml-thumbs-scroller {
  position: absolute;
  bottom: 20px;
  left: 0;
  width: 100%;
  height: 70px;
  display: flex;
  justify-content: center;
  z-index: 2147483648;
  padding: 0 10px;
  box-sizing: border-box;
  transition: opacity 0.2s ease;
}

.mml-thumbs-container {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  max-width: 100%;
  padding-bottom: 5px;
  scrollbar-width: none;
}

.mml-thumbs-container::-webkit-scrollbar {
  display: none;
}

.mml-thumb {
  width: 60px;
  height: 60px;
  flex-shrink: 0;
  border-radius: 6px;
  overflow: hidden;
  opacity: 0.5;
  transition: all 0.2s ease;
  border: 2px solid transparent;
}

.mml-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.mml-thumb.active-thumb {
  opacity: 1;
  border-color: #fff;
  transform: scale(1.1);
}

/* Licznik - Domyślny (Mobile) */

.mml-counter {
  position: absolute;
  bottom: 100px;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(255,255,255,0.2);
  color: #fff;
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 13px;
  pointer-events: none;
  transition: opacity 0.2s ease;
  z-index: 2147483648;
}

/* Ukrywanie interfejsu przy zoomie */

.ukryj-elementy {
  opacity: 0 !important;
  pointer-events: none !important;
}

/* ================================================= */

/* POPRAWKA DLA DESKTOPU (Ekrany powyżej 1024px) */

/* ================================================= */

@media (min-width: 1024px) {
  /* 1. Mniejsze zdjęcie */

  #mml-image {
    /* Odejmujemy aż 200px od wysokości ekranu - to dużo miejsca na pasek dolny */
    max-height: calc(100vh - 200px) !important;
    /* Przesuwamy zdjęcie lekko do góry, żeby optycznie było lepiej wyśrodkowane w dostępnej przestrzeni */
    margin-bottom: 20px;
  }

  /* 2. Licznik w lewym górnym rogu */

  .mml-counter {
    bottom: auto;
    top: 25px;
    left: 25px;
    transform: none;
    background: rgba(0, 0, 0, 0.6);
    font-size: 14px;
    padding: 6px 15px;
  }

  /* 3. Pasek miniatur stabilnie na dole */

  .mml-thumbs-scroller {
    bottom: 20px;
  }
}

/* Ukrycie etykiet w formularzu Avada - wersja "na twardo" */

.fusion-form label {
  display: none !important;
}

/* Dodatkowe zabezpieczenie dla konkretnych pól, które podałeś */

label[for="name_label"],
label[for="email_label"],
label[for="message_label"],
label[for="subject_label"] {
  display: none !important;
}

.payment_box.payment_method_pay_by_paynow_pl_blik {
  background-color: #ffffff !important;
}


.col-md-4.form-control-label {
   background-color: #ffffff !important;
}


.wc_payment_method.payment_method_pay_by_paynow_pl_pbl {
  background-color: #ffffff !important;
}