/*==============================================================
modal-contents
==============================================================*/
.modal-contents {
    display: none;
}

.pagemodal-bg,
.pagemodal-bg * {
    box-sizing: border-box;
}

.pagemodal-bg {
    width: 100dvw;
    height: 100dvh;
    padding: min(4em, 15vw) min(4em, 5vw) min(4em, 10vw);
    position: fixed;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.8);
    overflow-y: scroll;
    z-index: 8001;
    display: none;
    cursor: pointer;
}

@media screen and (max-width: 768px) {
    .pagemodal-bg {
        padding: 140px min(4em, 5vw) min(2em, 10vw);
    }
}

.pagemodal-bg .close-btn {
    --border-color: #fff;
    width: min(3em, 15vw);
    height: min(3em, 15vw);
    display: grid;
    place-items: center;
    cursor: pointer;
    pointer-events: auto;
    position: fixed;
    right: min(.5em, 3vw);
    top: min(.5em, 3vw);
    z-index: 8003;
}

@media screen and (max-width: 768px) {
    .pagemodal-bg .close-btn {
        top: 90px;
    }
}

.pagemodal-bg .close-btn::before,
.pagemodal-bg .close-btn::after {
    content: "";
    width: 70%;
    position: absolute;
    left: 50%;
    top: 50%;
    border-top: solid 3px var(--border-color);
    transform: translate(-50%, -50%) rotate(45deg);
}

.pagemodal-bg .close-btn::after {
    transform: translate(-50%, -50%) rotate(-45deg);
}

.pagemodal {
    width: min(1200px, 100%);
    margin: 0px auto;
    min-height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    overflow: unset;
    cursor: default;
    pointer-events: none;
    position: relative;
    z-index: 8002;
}

.pagemodal-inner {
    width: 100%;
    margin: 0px auto;
    padding: min(3em, 8vw) min(3em, 5vw);
    border-radius: .5em;
    background-color: #fff;
    box-shadow: rgba(30, 30, 30, 0.4) 0px 0px 3px 0px;
    position: relative;
    pointer-events: auto;
}

.pagemodal img,
.pagemodal video,
.pagemodal iframe {
    max-width: 100%;
    height: auto;
    vertical-align: top;
}

.pagemodal video,
.pagemodal iframe {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* image */
.type-image .pagemodal {
    width: min(900px, 100%);
}

.type-image .pagemodal-inner {
    padding: 1em;
}


/* video, youtube */
.type-video,
.type-youtube {
    --ratio-w: 16;
    --ratio-h: 9;
    height: 100%;
    padding: 0;
}

.type-video .pagemodal,
.type-youtube .pagemodal {
    height: 100%;
}

.type-video .pagemodal-inner,
.type-youtube .pagemodal-inner {
    width: min(90%, calc(90dvh * (var(--ratio-w) / var(--ratio-h))));
    max-width: 100%;
    aspect-ratio: var(--ratio-w) / var(--ratio-h);
    padding: 0;
    background-color: transparent;
    position: absolute;
    top: 50%;
    left: 50%;
    translate: -50% -50%;
}

/* vertical-mov */
.vertical-mov {
    --ratio-w: 9;
    --ratio-h: 16;
}


html.pagemodal-open {
    overflow: clip;
    width: 100%;
    height: 100%;
}