/* Poprawki dla urządzeń mobilnych i desktop - Fix dla niedziałających przycisków */

/* Uniwersalne poprawki dla wszystkich urządzeń */
.dsn-btn,
.dsn-btn-shape,
.button,
.dsn-btn a,
.dsn-btn-shape a,
.dsn-btn .button {
    pointer-events: auto !important;
    cursor: pointer !important;
    z-index: 999 !important;
    position: relative !important;
}

/* ===== POPRAWKI DLA OBRAZÓW NA MOBILNYCH ===== */
/* Fix dla problemu z niewyświetlającymi się obrazami na urządzeniach mobilnych */

/* Wyłączenie lazy loading na kluczowych obrazach */
@media only screen and (max-width: 991px) {
    /* Bezpośrednie ładowanie kluczowych obrazów */
    .box-img img,
    .custom-logo,
    .cover-bg-img,
    img[loading="lazy"] {
        loading: auto !important;
    }
    
    /* Zapewnienie właściwego wyświetlania obrazów - bardzo selektywne */
    img[loading="lazy"]:not(.preloader img):not(.logo img) {
        opacity: 1 !important;
        visibility: visible !important;
    }
    
    /* Poprawka dla background images */
    .box-image-bg,
    .dsn-bg-section,
    .bg-container {
        background-size: cover !important;
        background-position: center !important;
        background-repeat: no-repeat !important;
        min-height: 200px !important;
    }
    
    /* Poprawka dla obrazów w sekcji hero - minimalna ingerencja */
    .box-img img[src*="profilowe"] {
        opacity: 1 !important;
        visibility: visible !important;
    }
    
    /* Zapewnienie że obrazy nie są ukrywane przez CSS - tylko niezbędne */
    .box-img img[src*="profilowe"],
    .cover-bg-img {
        visibility: visible !important;
        opacity: 1 !important;
    }
    
    /* Poprawka dla obrazów portfolio */
    .dsn-item-post .box-image-bg,
    .dsn-item-post .cover-bg-img {
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
    }
    
    /* Wyłączenie problematycznych transform na obrazach */
    .dsn-swiper-parallax-transform {
        transform: none !important;
    }
    
    /* Poprawka dla animacji obrazów - tylko dla lazy loaded */
    .dsn-animate img[loading="lazy"],
    .dsn-up img[loading="lazy"],
    .dsn-fill img[loading="lazy"] {
        animation: none !important;
        transform: none !important;
        opacity: 1 !important;
        visibility: visible !important;
    }
}

/* ===== POPRAWKI ROZMIARÓW PRZYCISKÓW MEXDOT ===== */
/* Przywrócenie oryginalnych rozmiarów przycisków template Mexdot */

/* Główne struktury przycisków */
.dsn-btn-shape {
    display: flex !important;
    align-items: center !important;
    min-height: 50px !important;
    border-radius: 0 !important;
    overflow: visible !important;
}

/* Główny element przycisku */
.dsn-btn-shape .button {
    padding: 15px 25px !important;
    min-height: 50px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    line-height: 1.2 !important;
    border: none !important;
    text-decoration: none !important;
    transition: all 0.3s ease !important;
}

/* Tekst przycisku */
.dsn-btn-shape .title-btn {
    font-size: 14px !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    white-space: nowrap !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* Ikona przycisku */
.dsn-btn-shape .icon {
    min-width: 50px !important;
    min-height: 50px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
}

.dsn-btn-shape .icon svg {
    width: 16px !important;
    height: 16px !important;
    fill: currentColor !important;
}

/* Większe przyciski dla głównych CTA */
.dsn-btn-shape.mt-30 .button {
    padding: 18px 30px !important;
    min-height: 55px !important;
    font-size: 15px !important;
}

.dsn-btn-shape.mt-30 .icon {
    min-width: 55px !important;
    min-height: 55px !important;
}

.dsn-btn-shape.mt-30 .title-btn {
    font-size: 15px !important;
}

/* Zapewnienie że elementy bg-load nie blokują interakcji */
.bg-load,
.dsn-svg-transition,
.preloader .bg-load,
.preloader .dsn-svg-transition {
    pointer-events: none !important;
}

/* Poprawka dla kontenerów przycisków */
.dsn-btn-shape,
.dsn-def-btn,
.dsn-normal-btn,
.dsn-default-btn {
    pointer-events: auto !important;
    z-index: 998 !important;
}

/* Poprawki dla desktop */
@media only screen and (min-width: 992px) {
    /* Zapewnienie działania przycisków na desktop */
    .dsn-btn,
    .dsn-btn-shape,
    .button,
    .dsn-btn a,
    .dsn-btn-shape a,
    .dsn-btn .button {
        pointer-events: auto !important;
        cursor: pointer !important;
        z-index: 999 !important;
        position: relative !important;
    }
    
    /* Zapewnienie że elementy bg-load nie blokują interakcji */
    .bg-load,
    .dsn-svg-transition,
    .preloader,
    .preloader * {
        pointer-events: none !important;
    }
    
    /* Poprawka dla kontenerów przycisków */
    .dsn-btn-shape,
    .dsn-def-btn,
    .dsn-normal-btn,
    .dsn-default-btn {
        pointer-events: auto !important;
        z-index: 998 !important;
    }
    
    /* Poprawka dla ikon w przyciskach */
    .dsn-btn-shape .icon {
        pointer-events: auto !important;
        z-index: 999 !important;
    }
    
    /* Zapewnienie że overlay nie blokuje przycisków */
    .p-relative .dsn-btn,
    .p-relative .dsn-btn-shape {
        z-index: 1000 !important;
    }
    
    /* Poprawka dla pinned-scroll elementów */
    .pinned-scroll .dsn-btn,
    .pinned-scroll .dsn-btn-shape {
        position: relative !important;
        z-index: 1001 !important;
    }
    
    /* Dodatkowe bezpieczeństwo dla linków w przyciskach */
    .dsn-btn a,
    .dsn-btn-shape a,
    .button {
        display: block !important;
        width: 100% !important;
        height: 100% !important;
        text-decoration: none !important;
        color: inherit !important;
    }
    
    /* Poprawka dla animowanych tekstów */
    .title-btn[data-animate-text] {
        pointer-events: auto !important;
    }
    
    /* Dodatkowe zabezpieczenie dla kontenerów */
    .container .dsn-btn,
    .dsn-container .dsn-btn,
    .container .dsn-btn-shape,
    .dsn-container .dsn-btn-shape {
        position: relative !important;
        z-index: 999 !important;
    }
}

/* Podstawowe poprawki dla przycisków na mobilnych */
@media only screen and (max-width: 991px) {
    
    /* Wyłączenie niestandardowego kursora na mobilnych */
    #dsn_cursor,
    #dsn_cursor_inner {
        display: none !important;
        pointer-events: none !important;
    }
    
    /* ===== MOBILNE POPRAWKI ROZMIARÓW PRZYCISKÓW ===== */
    /* Lepsze rozmiary przycisków na urządzeniach mobilnych */
    
    .dsn-btn-shape {
        min-height: 45px !important;
        width: 100% !important;
        max-width: 280px !important;
        margin: 0 auto !important;
    }
    
    .dsn-btn-shape .button {
        padding: 12px 20px !important;
        min-height: 45px !important;
        font-size: 13px !important;
        flex: 1 !important;
    }
    
    .dsn-btn-shape .icon {
        min-width: 45px !important;
        min-height: 45px !important;
    }
    
    .dsn-btn-shape .title-btn {
        font-size: 13px !important;
    }
    
    /* Większe przyciski CTA na mobile */
    .dsn-btn-shape.mt-30 {
        min-height: 50px !important;
        max-width: 320px !important;
    }
    
    .dsn-btn-shape.mt-30 .button {
        padding: 14px 25px !important;
        min-height: 50px !important;
        font-size: 14px !important;
    }
    
    .dsn-btn-shape.mt-30 .icon {
        min-width: 50px !important;
        min-height: 50px !important;
    }
    
    .dsn-btn-shape.mt-30 .title-btn {
        font-size: 14px !important;
    }
    
    /* Zapewnienie działania przycisków */
    .dsn-btn,
    .dsn-btn-shape,
    .button,
    .dsn-btn a,
    .dsn-btn-shape a,
    .dsn-btn .button {
        pointer-events: auto !important;
        cursor: pointer !important;
        z-index: 999 !important;
        position: relative !important;
        touch-action: manipulation !important;
        -webkit-tap-highlight-color: rgba(0,0,0,0.1) !important;
    }
    
    /* Uproszczenie animacji przycisków dla lepszej wydajności */
    .dsn-btn-shape {
        filter: none !important;
        transition: all 0.2s ease !important;
    }
    
    .dsn-btn-shape .icon {
        transition: all 0.2s ease !important;
    }
    
    /* Zapewnienie że elementy bg-load nie blokują interakcji */
    .bg-load,
    .dsn-svg-transition,
    .preloader,
    .preloader * {
        pointer-events: none !important;
    }
    
    /* Poprawka dla kontenerów przycisków */
    .dsn-btn-shape,
    .dsn-def-btn,
    .dsn-normal-btn,
    .dsn-default-btn {
        pointer-events: auto !important;
        z-index: 998 !important;
    }
    
    /* Zwiększenie obszaru kliknięcia */
    .dsn-btn-shape .button {
        min-height: 44px !important;
        padding: 12px 25px !important;
    }
    
    /* Poprawka dla ikon w przyciskach */
    .dsn-btn-shape .icon {
        pointer-events: auto !important;
        z-index: 999 !important;
        min-width: 44px !important;
        min-height: 44px !important;
    }
    
    /* Zapewnienie że overlay nie blokuje przycisków */
    .p-relative .dsn-btn,
    .p-relative .dsn-btn-shape {
        z-index: 1000 !important;
    }
    
    /* Poprawka dla pinned-scroll elementów */
    .pinned-scroll .dsn-btn,
    .pinned-scroll .dsn-btn-shape {
        position: relative !important;
        z-index: 1001 !important;
    }
    
    /* Poprawka dla sekcji z overflow hidden */
    .over-hidden {
        overflow: visible !important;
    }
    
    /* Dodatkowe bezpieczeństwo dla linków w przyciskach */
    .dsn-btn a,
    .dsn-btn-shape a,
    .button {
        display: block !important;
        width: 100% !important;
        height: 100% !important;
        text-decoration: none !important;
        color: inherit !important;
    }
    
    /* Poprawka dla animowanych tekstów */
    .title-btn[data-animate-text] {
        pointer-events: auto !important;
    }
    
    /* Wyłączenie problematycznych efektów parallax na mobilnych */
    .dsn-parallax-hover,
    .dsn-hero-parallax-title,
    .dsn-hero-parallax-img {
        transform: none !important;
        transition: none !important;
    }
    
    /* Dodatkowe zabezpieczenie dla kontenerów */
    .container .dsn-btn,
    .dsn-container .dsn-btn,
    .container .dsn-btn-shape,
    .dsn-container .dsn-btn-shape {
        position: relative !important;
        z-index: 999 !important;
    }
}

/* Poprawki dla bardzo małych ekranów */
@media only screen and (max-width: 480px) {
    .dsn-btn-shape .button {
        font-size: 12px !important;
        padding: 10px 20px !important;
    }
    
    .dsn-btn-shape .icon {
        width: 35px !important;
        height: 35px !important;
    }
}

/* ===== SPECJALNE POPRAWKI DLA PRZYCISKÓW SKLEPU ===== */
/* Przyciski w sklep.html powinny być spójne z resztą strony */

.dsn-item-post .dsn-btn-shape {
    min-height: 40px !important;
    max-width: none !important;
    width: auto !important;
    margin: 0 !important;
}

.dsn-item-post .dsn-btn-shape .button {
    padding: 10px 20px !important;
    min-height: 40px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
}

.dsn-item-post .dsn-btn-shape .icon {
    min-width: 40px !important;
    min-height: 40px !important;
}

.dsn-item-post .dsn-btn-shape .title-btn {
    font-size: 12px !important;
    font-weight: 600 !important;
}

.dsn-item-post .dsn-btn-shape .icon svg {
    width: 14px !important;
    height: 14px !important;
}

/* Responsywne poprawki dla przycisków w sklepie */
@media only screen and (max-width: 991px) {
    .dsn-item-post .dsn-btn-shape {
        min-height: 38px !important;
        width: 100% !important;
        max-width: 140px !important;
        justify-content: center !important;
    }
    
    .dsn-item-post .dsn-btn-shape .button {
        padding: 8px 15px !important;
        min-height: 38px !important;
        font-size: 11px !important;
        flex: 1 !important;
    }
    
    .dsn-item-post .dsn-btn-shape .icon {
        min-width: 38px !important;
        min-height: 38px !important;
    }
    
    .dsn-item-post .dsn-btn-shape .title-btn {
        font-size: 11px !important;
    }
}

/* Debugowanie - tymczasowe obramowanie przycisków (usuń po testach) */
/*
@media only screen and (max-width: 991px) {
    .dsn-btn,
    .dsn-btn-shape {
        border: 2px solid red !important;
    }
}
*/ 