@charset 'UTF-8';

.p-carousel-simple {
    position: relative;
    margin-bottom: 36px;
    padding: 24px 17px 32px;
    min-height: 405px;
    z-index: 3;
}
.p-carousel-simple:before {
    position: absolute;
    top: 0;
    left: -15px;
    background: url(/img/carousel-feature/carousel_simple_bg_sp.webp) no-repeat center / cover;
    width: 100vw;
    height: 100%;
    content: '';
    z-index: -1;
}
.p-carousel-simple .p-carousel-simple__title {
    text-align: center;
    color: #fff;
    font-size: 18px;
    line-height: 31px;
    letter-spacing: 0;
    font-weight: bold;
}
.p-carousel-simple .p-carousel-simple__logo {
    width: 100px;
    margin: auto;
}
.p-carousel-simple .p-carousel-simple__logo img {
    display: block;
    width: 100%;
    height: auto;
}
.p-carousel-simple .p-carousel-simple__contents {
    margin-top: 20px;
}
@media only screen and (min-width: 1024px) {
    .p-carousel-simple {
        padding: 24px 32px 32px;
        min-height: 335px;
        background: url(/img/carousel-feature/carousel_simple_bg.webp) no-repeat center / cover;
    }
    .p-carousel-simple:before {
        display: none;
    }
}


.p-carousel-plate {
    position: relative;
    margin: 24px 0;
    padding: 24px 0;
    z-index: 3;
}
.p-carousel-plate:before {
    position: absolute;
    top: 0;
    left: -15px;
    content: '';
    width: 100vw;
    height: 100%;
    background: url(/img/carousel-feature/carousel_plate_bg_sp.webp) no-repeat center / cover;
    z-index: -1;
}
@media only screen and (min-width: 1024px) {
    .p-carousel-plate {
        padding: 24px 32px;
        min-height: 234px;
        background: url(/img/carousel-feature/carousel_plate_bg01.webp) no-repeat center / cover;
    }
    .p-carousel-plate:before {
        display: none;
    }
}
.p-carousel-plate .p-carousel-plate__title {
    text-align: center;
    color: #fff;
    font-size: 18px;
    line-height: 31px;
    letter-spacing: 0;
    font-weight: bold;
}
.p-carousel-plate .p-carousel-plate__logo {
    width: 100px;
    margin: auto;
}
.p-carousel-plate .p-carousel-plate__logo img {
    display: block;
    width: 100%;
    height: auto;
}
.p-carousel-plate .p-carousel-plate__contents {
    position: relative;
    display: grid;
    grid-template-columns: 100%;
    gap:16px 0;
    max-width: 345px;
    width: 100%;
    margin: 14px auto 0;
    padding-bottom: 24px;
}
@media only screen and (min-width: 1024px) {
    .p-carousel-plate .p-carousel-plate__contents {
        max-width: 100%;
        margin-top: 20px;
        display: grid;
        grid-template-columns: 220px auto;
        gap: 0 24px;
        padding-bottom: 0;
    }
}
.p-carousel-plate__copy + .p-carousel-plate__text01 {
    margin-top: 12px;
}
.p-carousel-plate__text01 + .p-carousel-plate__text02 {
    margin-top: 8px;
}
.p-carousel-plate .p-carousel-plate__copy p{
    font-size: 16px;
    line-height: 20px;
    letter-spacing: .05em;
    color: #fff;
    font-weight: bold;
}
.p-carousel-plate .p-carousel-plate__text01 p {
    font-size: 14px;
    line-height: 20px;
    letter-spacing: .05em;
    color: #D3D3D3;
    font-weight: bold;
}
.p-carousel-plate .p-carousel-plate__text02 p {
    font-size: 13px;
    line-height: 20px;
    letter-spacing: .05em;
    color: #D3D3D3;
    font-weight: 400;
}
.p-carousel-plate__link {
    margin-top: 18px;
    display: flex;
    justify-content: center;
}
@media only screen and (min-width: 1024px) {
    .p-carousel-plate__link {
        margin-top: 12px;
        justify-content: flex-start;
    }
}
a.c-viewing-btn {
    position: relative;
    padding: 10.5px 5px;
    display: block;
    text-align: center;
    width: 220px;
    font-size: 15px;
    line-height: 21px;
    letter-spacing: .001em;
    font-weight: bold;
    border-radius: 4px;
    background: #fff;
    color: #001C50;
}
a.c-viewing-btn:before {
    position: absolute;
    right: 12px;
    top: 50%;
    width: 8px;
    height: 8px;
    content: "";
    transform: translateY(-50%) rotate(45deg);
    border-top: 2px solid #001C50;
    border-right: 2px solid #001C50;
    background: 0px 0px;
}
.on-demand-slider .on-demand-slider__item {
    aspect-ratio: 1/1;
}
.on-demand-slider .on-demand-slider__item img {
    display: block;
    width:  100%;
    height: 100%;
    object-fit: cover;
    margin: 0 auto;
}
@media only screen and (min-width: 1024px) {
    .on-demand-slider .on-demand-slider__item img {
        width: 100%;
    }
}
.on-demand-slider {
    max-width: 310px;
    width: 100%;
    margin: auto;
}

.on-demand-slider .slick-prev,
.on-demand-slider .slick-next {
    position: absolute;
    top: 50%;
    width: 32px; /* 丸の直径 */
    height: 32px;
    border: 1px solid #999; /* 枠線色 */
    border-radius: 50%;
    background: #fff;
    transform: translateY(-50%);
    cursor: pointer;
}
.on-demand-slider .slick-prev:hover,
.on-demand-slider .slick-next:hover,
.on-demand-slider .slick-prev:active,
.on-demand-slider .slick-next:active,
.on-demand-slider .slick-prev:focus,
.on-demand-slider .slick-next:focus {
    background: #fff;
    border: 1px solid  #2F51AF;
}
.on-demand-slider .slick-prev:hover:before,
.on-demand-slider .slick-next:hover:before,
.on-demand-slider .slick-prev:active:before,
.on-demand-slider .slick-next:active:before,
.on-demand-slider .slick-prev:focus:before,
.on-demand-slider .slick-next:focus:before,
.on-demand-slider .slick-prev:hover:after,
.on-demand-slider .slick-next:hover:after,
.on-demand-slider .slick-prev:active:after,
.on-demand-slider .slick-next:active:after,
.on-demand-slider .slick-prev:focus:after,
.on-demand-slider .slick-next:focus:after{
    border-top: 2px solid #2F51AF;
    border-right: 2px solid #2F51AF;
}

.on-demand-slider .slick-prev::after,
.on-demand-slider .slick-next::after {
    display: none;
}
.on-demand-slider .slick-prev::before,
.on-demand-slider .slick-next::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 55%;
    width: 8px; /* 矢印の幅 */
    height: 8px; /* 矢印の高さ */
    border-top: 2px solid #999;
    border-right: 2px solid #999;
    transform: translate(-50%, -50%) rotate(225deg);
    background: transparent;
}
.on-demand-slider .slick-next::before {
    left: 49%;
    transform: translate(-50%, -50%) rotate(45deg);
}
.on-demand-slider .slick-prev {
    left: -16px;
}
.on-demand-slider .slick-next {
    right: -16px;
}

.on-demand-slider02 {
    position: static;
}
@media only screen and (min-width: 1024px) {
    .on-demand-slider02 {
        position: relative;
    }
}
.on-demand-slider02 .on-demand-slider02__item img {
    display: block;
    max-width: 345px;
    width: 100%;
    height: auto;
    margin: 0 auto;
    border-radius: 4px;
}
@media only screen and (min-width: 1024px) {
    .on-demand-slider02 .on-demand-slider02__item img {
        width: 220px;
    }
}
.on-demand-slider02 .slick-dots button {
    background: #fff;
    width: 10px;
    height: 10px;
}
.on-demand-slider02 .slick-dots li {
    width: 10px;
    height: 10px;
    margin: 0 4px;
}

.on-demand-slider02 .slick-dots li.slick-active button {
    background: #D50417;
    border: 1px solid #D50417 !important;
}
.on-demand-slider02 .slick-dots {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: 20px;
    display: flex;
    justify-content: center;
}
@media only screen and (min-width: 1024px) {
    .on-demand-slider02 .slick-dots {
        margin: 20px 0 0;
        position: static;
        transform: translateX(0%);

    }
}
/*
記事内カルーセル追加
 */
.column__list>li.column__item--press--full {
    width: 100%;
}

.p-detail .p-carousel-plate:before {
    left: 0;
}