/* ===========================================
   Bildergalerie Gallery Styles
   Uses Elementor global CSS variables
   =========================================== */

/* Fix horizontal scroll from long titles */
.category-bildergalerie h1,
.category-bildergalerie h2,
.category-bildergalerie .elementor-heading-title {
    word-wrap: break-word !important;
    overflow-wrap: break-word !important;
    hyphens: auto !important;
}

/* Elementor Gallery Widget */
.elementor-gallery__container { gap: 8px !important; }
.elementor-gallery-item { border-radius: 4px !important; overflow: hidden !important; transition: transform 0.3s ease, box-shadow 0.3s ease !important; }
.elementor-gallery-item:hover { transform: translateY(-4px) !important; box-shadow: 0 10px 30px rgba(0,0,0,0.2) !important; z-index: 10 !important; }
.e-gallery-image { transition: transform 0.4s ease, filter 0.3s ease !important; }
.elementor-gallery-item:hover .e-gallery-image { transform: scale(1.08) !important; filter: brightness(1.05) !important; }

/* Accent Bar on Hover - uses global accent color */
.elementor-gallery-item::after { content: "" !important; position: absolute !important; bottom: 0 !important; left: 0 !important; width: 100% !important; height: 4px !important; background: var(--e-global-color-accent) !important; transform: scaleX(0) !important; transform-origin: left !important; transition: transform 0.3s ease !important; z-index: 5 !important; }
.elementor-gallery-item:hover::after { transform: scaleX(1) !important; }

/* Overlay Gradient */
.elementor-gallery-item__overlay { background: linear-gradient(to top, rgba(0,0,0,0.5) 0%, transparent 60%) !important; opacity: 0 !important; transition: opacity 0.3s ease !important; }
.elementor-gallery-item:hover .elementor-gallery-item__overlay { opacity: 1 !important; }

/* Lightbox Enhancements - uses global colors */
.elementor-lightbox { background: rgba(0, 0, 0, 0.95) !important; }
.elementor-lightbox .swiper-slide img { border-radius: 4px !important; box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5) !important; }
.elementor-lightbox .elementor-swiper-button { background: var(--e-global-color-accent) !important; border-radius: 50% !important; width: 50px !important; height: 50px !important; }
.elementor-lightbox .elementor-swiper-button-prev { left: 30px !important; }
.elementor-lightbox .elementor-swiper-button-next { right: 30px !important; }
.elementor-lightbox .elementor-swiper-button i { color: var(--e-global-color-text) !important; }
.elementor-lightbox .elementor-swiper-button svg { fill: var(--e-global-color-text) !important; }
.elementor-lightbox .swiper-pagination-bullet-active { background: var(--e-global-color-accent) !important; }

/* Responsive */
@media (max-width: 767px) {
    .elementor-gallery-item:hover { transform: none !important; }
    .elementor-gallery-item::after { display: none !important; }

    /* Style navigation arrows on mobile - transparent with white arrows and shadow */
    .elementor-lightbox .elementor-swiper-button {
        background: transparent !important;
        width: 50px !important;
        height: 50px !important;
        border-radius: 50% !important;
    }
    .elementor-lightbox .elementor-swiper-button i,
    .elementor-lightbox .elementor-swiper-button svg {
        color: #fff !important;
        fill: #fff !important;
        text-shadow: 0 2px 8px rgba(0, 0, 0, 0.8) !important;
        filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.8)) !important;
        font-size: 28px !important;
    }
    .elementor-lightbox .elementor-swiper-button-prev {
        left: 10px !important;
    }
    .elementor-lightbox .elementor-swiper-button-next {
        right: 10px !important;
    }

    /* Swipe hint in German - centered on image, fades out */
    .elementor-lightbox .swiper-slide::after {
        content: "← Wischen →" !important;
        position: absolute !important;
        top: 50% !important;
        left: 50% !important;
        transform: translate(-50%, -50%) !important;
        background: rgba(0, 0, 0, 0.7) !important;
        color: #fff !important;
        padding: 12px 24px !important;
        border-radius: 25px !important;
        font-size: 16px !important;
        z-index: 10000 !important;
        pointer-events: none !important;
        animation: fadeOutHint 3s ease-in-out forwards !important;
        animation-delay: 1.5s !important;
    }

    @keyframes fadeOutHint {
        0% { opacity: 1; }
        100% { opacity: 0; }
    }
}
