.card-img .ratio-box {
    position: relative;
    overflow: hidden;
}

.card-img .ratio-box img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;

    object-fit: cover;
    object-position: center;

    transform: scale(1);
    transition: transform 0.6s ease;
}

/* Hover Effekt */
.grid-item:hover .ratio-box img {
    transform: scale(1.08);
}

.grid-item .ratio-box::after {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0);
    transition: background 0.4s ease;
}

.grid-item:hover .ratio-box::after {
    background: rgba(0,0,0,0.1);
}

/* Pfeile generell */
.swiper-button-next,
.swiper-button-prev {
    width: 36px;
    height: 36px;
    background: rgba(255,255,255,0);
    border-radius: 50%;
    backdrop-filter: blur(4px);

    transition: all 0.3s ease;
}

.swiper-button-next, .swiper-button-prev {color:white; width: 24px;    height: 24px;}

/*.swiper-button-next, .swiper-button-prev {
    ::slotted(svg), svg {

        fill: white;

    }
}*/

/* Pfeil-Icons kleiner */
/*.swiper-button-next::after,
.swiper-button-prev::after {
    font-size: 14px;
    font-weight: bold;
    color: #000;
}*/

/* Position etwas nach innen */
.swiper-button-prev {
    left: 10px;
}

.swiper-button-next {
    right: 10px;
}

/* Hover Effekt */
.grid-item:hover .swiper-button-next,
.grid-item:hover .swiper-button-prev {
    background: rgba(255,255,255,0);
    transform: scale(1);
}

.swiper-button-next,
.swiper-button-prev {
    opacity: 0;
}

.grid-item:hover .swiper-button-next,
.grid-item:hover .swiper-button-prev {
    opacity: 1;
}


/* Zoom Icon Overlay */
.ratio-box {
    position: relative;
    overflow: hidden;
}

.ratio-box svg.zoom-icon {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) scale(0.8);

    width: 28px;
    height: 28px;

    stroke: #fff;
    stroke-width: 2;
    fill: none;

    opacity: 0;
    z-index: 2;

    transition: all 0.3s ease;
}

.grid-item:hover .ratio-box svg.zoom-icon {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
}

/* SVG darf keine Events blockieren */
.zoom-icon {
    pointer-events: none;
}

/* GANZ wichtig: auch Pseudo-Elemente deaktivieren */
.ratio-box::before,
.ratio-box::after {
    pointer-events: none;
}

/* Cursor wieder erzwingen */
.my-slider img {
    cursor: pointer;
}

/* sichtbar bei Hover */
.grid-item:hover .ratio-box::before {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
}

.my-slider img {
    cursor: pointer;
}


.swiper-lightbox {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.9);
     z-index: 999999;

    display: flex;
    align-items: center;   /* vertikal zentrieren */
    justify-content: center;
    padding: 80px 20px;    /* Abstand oben/unten */
    box-sizing: border-box;
}
.swiper-lightbox {
    opacity: 0;
    transition: opacity 0.3s ease;
}

.swiper-lightbox.active {
    opacity: 1;
}

.swiper-lightbox-inner {
   position: relative;
    width: 100%;
    max-width: 1000px;
}

.swiper-lightbox-inner {
    transform: scale(0.95);
    transition: transform 0.3s ease;
}

.swiper-lightbox.active .swiper-lightbox-inner {
    transform: scale(1);
}

.swiper-lightbox img {
    position: relative;
    z-index: 1; /* wichtig */
    width: 100%;
    height: auto;
    max-height: 75vh;
    object-fit: contain;

}

.swiper-lightbox .swiper-button-next,
.swiper-lightbox .swiper-button-prev {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
	opacity: 1;

    z-index: 9999; /* maximal hochziehen */

    width: 32px;
    height: 32px;

    background: rgba(0,0,0,0);
    border-radius: 50%;

    display: flex;
    align-items: center;
    justify-content: center;
}

/* SVG Farbe erzwingen */
.swiper-lightbox .swiper-button-next svg,
.swiper-lightbox .swiper-button-prev svg {
    fill: #fff !important;
    color: #fff !important;
}

/* Pfeilgröße */
.swiper-lightbox .swiper-button-next::after,
.swiper-lightbox .swiper-button-prev::after {
    font-size: 18px;
}

.lightbox-close {
    position: absolute;
    top: -10px;
    right: -10px;

    z-index: 30; /* über allem */

    color: #fff;
    font-size: 32px;
    cursor: pointer;
}