html:has(.wtps-modal.is-open) {
    overflow: hidden;
}

.wtps-modal {
    position: fixed;
    inset: 0;
    display: none;
    align-items: center;
    justify-content: center;
    background: var(--modal-bgcolor);
    color: var(--modal-color);
    z-index: 1000;
    padding: var(--modal-padding);
    align-items: start;
    overflow-y: auto;
    
    &.is-open {
        display: flex;

        .wtps-modal-wrapper {
            display: block;
        }
    }

    &:not(.is-open) {
        display: none;

        .wtps-modal-wrapper {
            display: none;
        }
    }

}

.wtps-modal-wrapper {
    display: none;
    position: relative;
    width: min(var(--modal-container-width), 100%);
    min-height: var(--modal-container-minheight);
    height: var(--modal-container-height);
    border-radius: var(--modal-container-borderradius);
    margin: auto;
    overflow-y: auto;
}

.wtps-modal-container {
    color: var(--modal-container-color);
    background-color: var(--modal-container-bgcolor);
    padding: var(--modal-container-padding);
    height: 100%;
    overflow-y: auto;
}

[data-open-modal] {
    cursor: pointer;
}

.wtps-modal-button-close {
    position: var(--modal-close-btnposition);
    right: var(--modal-close-btnright);
    left: var(--modal-close-btnleft);
    top: var(--modal-close-btntop);
    bottom: var(--modal-close-btnbottom);
    background-color: var(--modal-close-bgcolor, var(--modal-color));
    color: var(--modal-close-color, var(--modal-bgcolor));
    padding: var(--modal-close-padding);
    display: var(--modal-close-display);
    z-index: 1;
    border-radius: var(--modal-close-borderradius);
    svg {
        fill: currentColor;
        width: var(--modal-close-iconsize);
        height: var(--modal-close-iconsize);
    }
}

.wtps-modal,
.wtps-modal-wrapper,
.wtps-modal-container {
  -ms-overflow-style: none; /* IE, Edge */
  scrollbar-width: none; /* Firefox */
}

.wtps-modal::-webkit-scrollbar,
.wtps-modal-wrapper::-webkit-scrollbar,
.wtps-modal-container::-webkit-scrollbar {
  width: 0;
  height: 0;
}

.wtps-modal.is-open {
    display: flex;
    opacity: 1;
    transition: display var(--modal-effect-duration) ease allow-discrete;
    transition-delay: var(--modal-effect-duration);
    
    @starting-style {
        opacity: 0;
    }
}

.wtps-modal {
    display: none;
    opacity: 0;
    transition: opacity var(--modal-effect-duration) ease,
        display var(--modal-effect-duration) ease allow-discrete;
    transition-delay: var(--modal-effect-duration);
}

/* Efecto zoom */
.wtps-modal:not([data-effect]),
.wtps-modal[data-effect="none"] {
    transition: none;
    .wtps-modal-wrapper {
        transition: none;
    }
    &.is-open {
        transition: none;
        .wtps-modal-wrapper {
            transition: none;
        }
    }
}

/* Efecto zoom */
.wtps-modal[data-effect="zoom"].is-open .wtps-modal-wrapper {
    scale: 1;
    transition: scale var(--modal-effect-duration) ease;

    @starting-style {
        scale: 0;
    }
}

.wtps-modal[data-effect="zoom"] .wtps-modal-wrapper {
    transition: scale var(--modal-effect-duration) ease,
        display var(--modal-effect-duration) ease allow-discrete;
    scale: 0;
}

/* Efecto fade */
.wtps-modal[data-effect="fade"].is-open .wtps-modal-wrapper {
    opacity: 1;
    transition: opacity var(--modal-effect-duration) ease;

    @starting-style {
        opacity: 0;
    }
}

.wtps-modal[data-effect="fade"] .wtps-modal-wrapper {
    transition: opacity var(--modal-effect-duration) ease,
        display var(--modal-effect-duration) ease allow-discrete;
    opacity: 0;
}

/* Efectos slide (arriba/abajo/izquierda/derecha) */
.wtps-modal[data-effect="slide-top"].is-open .wtps-modal-wrapper {
    transform: translateY(0);
    opacity: 1;
    transition: transform var(--modal-effect-duration) ease, opacity var(--modal-effect-duration) ease;
    @starting-style {
        transform: translateY(-20%);
        opacity: 0;
    }
}
.wtps-modal[data-effect="slide-top"] .wtps-modal-wrapper {
    transform: translateY(-20%);
    opacity: 0;
    transition: transform var(--modal-effect-duration) ease, opacity var(--modal-effect-duration) ease,
        display var(--modal-effect-duration) ease allow-discrete;
}

.wtps-modal[data-effect="slide-bottom"].is-open .wtps-modal-wrapper {
    transform: translateY(0);
    opacity: 1;
    transition: transform var(--modal-effect-duration) ease, opacity var(--modal-effect-duration) ease;
    @starting-style {
        transform: translateY(20%);
        opacity: 0;
    }
}
.wtps-modal[data-effect="slide-bottom"] .wtps-modal-wrapper {
    transform: translateY(20%);
    opacity: 0;
    transition: transform var(--modal-effect-duration) ease, opacity var(--modal-effect-duration) ease,
        display var(--modal-effect-duration) ease allow-discrete;
}

.wtps-modal[data-effect="slide-left"].is-open .wtps-modal-wrapper {
    transform: translateX(0);
    opacity: 1;
    transition: transform var(--modal-effect-duration) ease, opacity var(--modal-effect-duration) ease;
    @starting-style {
        transform: translateX(-20%);
        opacity: 0;
    }
}
.wtps-modal[data-effect="slide-left"] .wtps-modal-wrapper {
    transform: translateX(-20%);
    opacity: 0;
    transition: transform var(--modal-effect-duration) ease, opacity var(--modal-effect-duration) ease,
        display var(--modal-effect-duration) ease allow-discrete;
}

.wtps-modal[data-effect="slide-right"].is-open .wtps-modal-wrapper {
    transform: translateX(0);
    opacity: 1;
    transition: transform var(--modal-effect-duration) ease, opacity var(--modal-effect-duration) ease;
    @starting-style {
        transform: translateX(20%);
        opacity: 0;
    }
}
.wtps-modal[data-effect="slide-right"] .wtps-modal-wrapper {
    transform: translateX(20%);
    opacity: 0;
    transition: transform var(--modal-effect-duration) ease, opacity var(--modal-effect-duration) ease,
        display var(--modal-effect-duration) ease allow-discrete;
}