/**
 * トップページ用 Swiper: オンライン診療の具体例 / 導入事例
 */

/* ========== オンライン診療の具体例 .lp_ex_list ========== */
.lp_ex_list.swiper .swiper-wrapper {
    max-width: fit-content;
    list-style: none;
    padding: 0;
    margin: 0 auto;

    @media (max-width: 1500px) {
        max-width: 100%;
    }
}

.lp_ex_list.swiper {
    display: block;
    width: 100%;
    padding: 0 30px;
    margin: 56px 0 0;
}

.lp_ex_list.swiper .swiper-slide {
    width: 344px;
    margin: 0;
    box-sizing: border-box;
}

@media (max-width: 768px) {
    .lp_ex_list.swiper {
        margin-top: 20px;
    }
    .lp_ex_list.swiper .swiper-slide {
        width: 85%;
        max-width: 400px;
    }
}

/* 768px以下：スライドをやめ、flex で縦並び */
.lp_ex_list.lp_ex_list--column .swiper-wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 16px;
    max-width: 100%;
}

.lp_ex_list.lp_ex_list--column .swiper-slide {
    width: 100%;
    max-width: 400px;
}

.lp_ex_list.lp_ex_list--column .lp_ex_list-bottom {
    display: none;
}

.lp_ex_list.swiper .inner {
    width: 100%;
    max-width: 344px;
    height: 100%;
}

/* スライダー下: prev ・ ドット ・ next を一列に */
.lp_ex_list-bottom {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 24px;
    margin: 24px auto 0;
}

.lp_ex_list.swiper .swiper-pagination {
    position: relative;
    width: fit-content;
    bottom: auto;
    margin: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 15px;
}

.lp_ex_list.swiper .swiper-pagination-bullet {
    width: 10px;
    height: 10px;
    margin: 0;
    background: #D9D9D9;
    border-radius: 50%;
    opacity: 1;
}

.lp_ex_list.swiper .swiper-pagination-bullet-active {
    background: #224E99;
}

.lp_ex_list.swiper .swiper-button-prev,
.lp_ex_list.swiper .swiper-button-next {
    position: static;
    font-size: 0;
    width: 40px;
    height: 40px;
    margin: 0;
    top: auto;
    right: auto;
    left: auto;
    transform: none;
    background-color: transparent;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
}

.lp_ex_list.swiper .swiper-button-prev {
    background-image: url("../img/lp/h1/prev.webp");
}

.lp_ex_list.swiper .swiper-button-next {
    background-image: url("../img/lp/h1/next.webp");
}

.lp_ex_list.swiper .swiper-button-prev::after,
.lp_ex_list.swiper .swiper-button-next::after {
    content: none;
}

/* 1500px以上：ループなし時、先頭・末尾でボタンを押せないように */
.lp_ex_list.swiper .swiper-button-prev.swiper-button-disabled,
.lp_ex_list.swiper .swiper-button-next.swiper-button-disabled {
    opacity: 0.35;
    cursor: not-allowed;
    pointer-events: none;
}

/* ========== 導入事例 .case_slide ========== */
.case_slide {
    padding: 0 30px;
}

.case_slide.swiper {
    width: 100%;
    overflow: hidden;
}

.case_slide--center.swiper {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.case_slide--center.swiper > .swiper-wrapper {
    flex: 0 0 auto;
}

.case_slide--center.swiper .swiper-pagination,
.case_slide--center.swiper .swiper-pagination-clickable.swiper-pagination-bullets.swiper-pagination-horizontal {
    display: none !important;
    visibility: hidden !important;
}

.case_slide--static.swiper {
    overflow: visible;
}

.case_slide--static.swiper .swiper-wrapper {
    display: flex;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: stretch;
    gap: 24px;
    max-width: 1080px;
    margin: 0 auto;
}

.case_slide--static.swiper .swiper-pagination,
.case_slide--static.swiper .swiper-button-prev,
.case_slide--static.swiper .swiper-button-next {
    display: none;
}

@media (max-width: 768px) {
    .case_slide--static.swiper .swiper-wrapper {
        flex-direction: column;
        align-items: center;
        gap: 16px;
    }
}

.case_slide.swiper .swiper-wrapper {
    align-items: stretch;
}

@media (min-width: 1081px) {
    .case_slide.swiper .swiper-wrapper {
        max-width: fit-content;
        margin: 0 auto;
    }
}

.case_slide.swiper .swiper-slide {
    width: 338px;
    box-sizing: border-box;
    height: auto;
}

@media (max-width: 768px) {
    .case_slide.swiper .swiper-slide {
        width: 85%;
        max-width: 400px;
    }
}

.case_slide.swiper .case_post-item {
    width: 100%;
    max-width: 343px;
    margin: 0;
    height: auto;
    display: flex;
    flex-direction: column;
    border-radius: 10px;
}

.case_slide.swiper .case_post-item .case_links {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.case_slide-bottom {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 24px;
    margin: 24px auto 0;
}

.case_slide.swiper .swiper-button-prev,
.case_slide.swiper .swiper-button-next {
    position: static;
    font-size: 0;
    width: 40px;
    height: 40px;
    margin: 0;
    top: auto;
    right: auto;
    left: auto;
    bottom: auto;
    background-color: transparent;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
}

.case_slide.swiper .swiper-button-prev {
    background-image: url("../img/lp/h1/prev.webp");
}

.case_slide.swiper .swiper-button-next {
    background-image: url("../img/lp/h1/next.webp");
}

.case_slide.swiper .swiper-button-prev::after,
.case_slide.swiper .swiper-button-next::after {
    content: none;
}

.case_slide.swiper .swiper-pagination {
    position: relative;
    width: fit-content;
    bottom: auto;
    margin: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 15px;
}

.case_slide.swiper .swiper-pagination-bullet {
    width: 10px;
    height: 10px;
    margin: 0;
    background: #D9D9D9;
    border-radius: 50%;
    opacity: 1;
}

.case_slide.swiper .swiper-pagination-bullet-active {
    background: #224E99;
}
