/**/
:root {
    --mainColor-red: #E50053;
    --color-key-secondary: #FAF3E6;
    --color-sub-gray: #F7F7F6;
    --color-key-gold: #BE9B3E;
    --color-key-gorl-dark: #634904;
}

/* --------------------------------------------
    l-main内　表示順
    PC版＝上部にパンくずリスト表示
    SP版＝最下部にパンくずリスト表示
-------------------------------------------- */
.l-main {
    display: flex;
    flex-direction: column;
}

@media (max-width: 1023px) {
    .l-main nav {
        order: 999;
    }
}

/* --------------------------------------------
    container
-------------------------------------------- */
.l-main .container {
    max-width: 1080px;
    width: 100%;
    margin: 0 auto;
    padding: 32px 24px;
    box-sizing: border-box;
}

@media (max-width: 1023px) {
    .l-main .container {
        padding: 20px 0;
    }
}

/* --------------------------------------------
    container article
-------------------------------------------- */

.l-main article {
    display: flex;
    flex-direction: column;
    gap: 32px;
}

/**/
@media (min-width: 1024px) {
    .margin-t-hd {
        margin: 10.5rem;
    }
}

@media (max-width: 1023px) {
    .margin-t-hd {
        margin: 12rem;
    }
}

/**/
.container {
    margin: auto;
    color: #333333;
    padding: 0;
    max-width: 1080px;
}

@media (max-width: 578px) {
    .container {
        max-width: 100% !important;
        margin: 0;
    }
}

/*PC版・SP版で表示と非表示を切り替える*/
.container .pc {
    display: none;
}

.container .sp {
    display: none;
}

@media (min-width: 1024px) {
    .container .pc {
        display: block;
    }
}

@media (max-width: 1023px) {
    .container .sp {
        display: block;
    }
}

/*max-width設定*/
.max_w_1000 {
    max-width: 1000px;
    margin: 0 auto;
}

.max_w_1052 {
    max-width: 1052px;
}

/* .max_w_1080{
    max-width:1080px !important;
    margin:0 auto;
} */

/*h2*/
.container h2 {
    font-size: 24px;
    font-weight: 700;
    padding: 7px;
    text-align: center;
    color: var(--mainColor-red) !important;
    width: calc(100% - 64px);
    margin: 0 auto;
}

.container h2.mainColor {
    border-bottom: 3px solid var(--mainColor-red) !important;
}

@media (max-width: 1023px) {
    .container h2 {
        font-size: 24px;
        width: calc(100% - 32px);
    }
}


/* --- 

pickUpArea

--- */
.movie_caption {
    text-align: center;
    margin-top: 60px;
    margin-bottom: 20px;
}

.pickUpArea {
    background: linear-gradient(to bottom, #F3EBD4 0%, #F3EBD4 49%, #D9C793 100%);
    padding: 6rem 10rem;
    display: flex;
    gap: 20px;
}

.pickUpArea .video-thumb {
    max-width: 500px;
}

.pickUpArea .discription {
    position: relative;
}

.pickUpArea h2 {
    font-size: 30px;
    font-weight: 700;
}

.pickUpArea h2.pc {
    display: block;
}

.pickUpArea h2.sp,
.mdl-txt-top-btn .sp {
    display: none;
}

.pickUpArea h3 {
    font-size: 24px;
    font-weight: 700;
    line-height: 1.7;
    margin-bottom: 20px;
}

.pickUpArea ul {
    display: flex;
    gap: 5px;
    flex-wrap: wrap;
    margin-bottom: 20px;
}

.pickUpArea li {
    border: 1px solid #7A6733;
    color: #7A6733;
    background: #FFF;
    border-radius: 20px;
    padding: 5px 9px;
    line-height: 1;
    font-size: 14px;
}

.pickUpArea .read-more-btn {
    border: none;
    background: none;
    color: #fff;
    font-size: 16px;
    position: absolute;
    bottom: 3px;
    right: 0px;
}

.pickUpArea .read-more-btn.is-open {
    bottom: -25px;
}

.pickUpArea:has(.is-open) {
    padding-bottom: calc(6rem + 5px);
}

@media (max-width: 1023px) {
    .movie_caption {
        text-align: left;
        padding: 0 10px;
        margin-top: 20px;
        font-size: 16px;
        letter-spacing: 2px;
    }

    .pickUpArea {
        padding: 30px;
        display: block;
    }

    .pickUpArea h2.sp,
    .mdl-txt-top-btn .sp {
        display: block;
        text-align: center;
        margin-bottom: 15px;
    }

    .pickUpArea h2.pc {
        display: none;
    }

    .pickUpArea h3,
    .pickUpArea ul {
        margin-bottom: 10px;
    }

    .pickUpArea h3 {
        font-size: 18px;
    }

    .pickUpArea p {
        font-size: 16px;
    }
}


/* --- 

rankingArea

--- */
.rankingArea h3 {
    font-size: 24px;
    font-weight: 700;
    text-align: center;
    padding-top: 10px;
}

.rankingArea h3 span {
    color: var(--mainColor-red) !important;
}

.rankingArea .slide {
    position: relative;
    padding-top: 60px !important;
}

.rankingArea .slide:after {
    content: '';
    position: absolute;
    top: -3px;
    margin: auto;
    width: 100%;
    height: 100%;
    background-image: url('../img/movie/rank1.svg');
    z-index: 1;
    pointer-events: none;
}

.rankingArea .slide.second:after {
    background-image: url('../img/movie/rank2.svg');
}

.rankingArea .slide.third:after {
    background-image: url('../img/movie/rank3.svg');
}


/*スライダー ページ内共通*/
.slider-track {
    display: flex;
    transition: transform 0.5s ease;
}

.slide {
    flex: 0 0 calc(100% / 3);
}

@media (max-width:1023px) {
    .slide {
        flex: 0 0 100%;
    }
}

.container section.slide-hidden {
    display: none;
}

.container section {
    display: block;
}

.rankingArea.slide-hidden {
    display: block !important;
}

.container .slider-container {
    margin: 0 auto;
    position: relative;
    padding: 20px 10px 0;
    overflow: hidden;
}

@media (max-width: 1023px) {
    .rankingArea h3 {
        width: calc(100% - 32px);
        padding-top: 20px;
        margin: 0 auto;
    }

    .container .slider-container {
        padding: 15px 0;
    }
}

.container .slider-wrapper {
    position: relative;
    overflow: hidden;
}

.container .slider-track {
    display: flex;
    align-items: stretch;
    transition: transform 0.4s ease;
    box-sizing: border-box;
}

.container .slide {
    width: calc(100% / 3);
    padding: 0 14px 10px 0;
    flex-shrink: 0;
}

.container .slide p.video-title {
    line-height: 1.4;
    min-height: 45px;
}

.container .slide ul {
    float: right;
}

.container .slide li {
    border: 1px solid #7A6733;
    color: #7A6733;
    background: #FFF;
    border-radius: 20px;
    padding: 5px 9px;
    line-height: 1;
    white-space: nowrap;
    width: fit-content;
    float: left;
    margin: 0 4px 5px 0;
    font-size: 14px;
}

@media (max-width: 1023px) {
    .container .slide {
        width: 100%;
        padding: 0 0 0 12px;
    }

    .container .slide li {
        font-size: 12px;
    }

    .container .slider-track {
        width: 80%;
    }
}

.container .slide-content {
    background: white;
    border-radius: 12px;
    padding: 12px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
    text-decoration: none;
    color: inherit;
    display: flex;
    flex-direction: column;
    transition: transform 0.2s, box-shadow 0.2s;
    height: 100%;
    width: 100%;
}

.container .man {
    color: #5E92E1;
}

.container .woman {
    color: #E24557;
}

.container .man .user-icon {
    fill: #5E92E1;
}

.container .woman .user-icon {
    fill: #e74c3c;
}

.container .arrow {
    position: absolute;
    top: 37%;
    transform: translateY(-50%);
    padding: 0 !important;
    background: white;
    border: none;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 0 4px rgba(0, 0, 0, 0.1);
    z-index: 1;
    transition: background 0.2s;
    font-size: 20px;
    color: #000;
}

@media (min-width: 1024px) {
    .container .arrow:hover {
        background: #f5f5f5;
    }
}

.container .arrow:disabled {
    opacity: 0;
    cursor: not-allowed;
}

.container .rankingArea .arrow:disabled {
    display: none !important;
}

.container .arrow-left {
    left: 5px;
}

.container .arrow-right {
    right: 5px;
}

@media (max-width: 1023px) {

    .container .arrow {
        width: 42px;
        height: 42px;
    }

    .container .pagination {
        margin-top: 24px;
    }
}

.container .dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #ccc;
    border: none;
    cursor: pointer;
    padding: 0;
    transition: background 0.3s;
}

.container .dot.active {
    background: #333;
}

.container .dot:hover {
    background: #999;
}

/* 動画スライダー（1スライド表示） */
.movies .slider-container {
    padding-top: 0;
    padding-bottom: 0;
}

.movies .slider-wrapper {
    overflow: hidden;
    position: relative;
}

.movies .slider-track {
    display: flex;
    align-items: stretch;
    transition: transform 0.4s ease;
    width: 100%;
}

.movies .slide {
    width: 100%;
    padding: 0 5px;
    flex-shrink: 0;
    display: flex;
    box-sizing: border-box;
}

@media (max-width: 1023px) {
    .movies .slide {
        width: 100%;
        min-width: 100%;
        flex-direction: column;
        gap: 10px;
    }
}

.movies .slide-content {
    background: white;
    border-radius: 12px;
    padding: 20px;
    text-decoration: none;
    color: inherit;
    display: flex;
    flex-direction: column;
    gap: 12px;
    height: 100%;
    width: 100%;
    box-shadow: 0 0 4px rgba(0, 0, 0, 0.1);
}

.movies .slider-container .arrow {
    top: calc(50% - 21px) !important;
}

.movies .slider-container .slide a,
.movies .slider-container .slide iframe {
    display: block;
    aspect-ratio: 16/9;
    overflow: hidden;
    width: 100%;
    height: auto;
}

.movies .slider-container .slide a img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 50% 50%;
}

/* ページネーション周り */
/* .movies*/
.pagination {
    margin-top: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    flex-direction: row;
}

/* .movies*/
.pagination .dots {
    display: flex;
    gap: 8px;
}

/* .movies*/
.dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    border: none;
    background: #ddd;
    padding: 0;
    cursor: pointer;
}

/* .movies*/
.dot.active {
    background: #333;
}

/* カウンター表示 */
/* .movies*/
.counter {
    font-size: 14px;
    color: #666;
}

/* 矢印ボタンの見た目調整（必要なら調整） */
/*.movies*/
.arrow {
    background: transparent;
    border: none;
    cursor: pointer;
    font-size: 18px;
    padding: 8px;
}

.customer-voice .counter {
    display: none;
}

/* サムネイル表示 */
.video-modal {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 99999;
}

.video-modal.is-open {
    display: flex;
    align-items: center;
}

.video-modal__overlay {
    position: absolute;
    inset: 0;
    background: rgba(17, 17, 17, 0.4);
}

.video-modal__content {
    position: relative;
    width: 90%;
    max-width: 960px;
    aspect-ratio: 16 / 9;
    margin: 10vh auto;
    background: #fff;
    padding: 35px 50px 20px;
    border-radius: 8px;
    object-fit: contain;
}

.video-modal__iframe,
.video-modal__iframe iframe {
    width: 100%;
    height: 100%;
}

.video-modal__close {
    position: absolute;
    top: 5px;
    right: 10px;
    font-size: 24px;
    color: #333;
    background: none;
    border: none;
    cursor: pointer;
}

.video-thumb {
    all: unset;
    cursor: pointer;
    text-align: center;
    font-weight: bold;
    position: relative;
    border: none;
    background: none;
    padding: 0;
    overflow: hidden;
}

.video-thumb img {
    width: 100%;
    box-sizing: border-box;
    border-radius: 8px;
    display: block;
}

.video-thumb::before {
    content: '';
    position: absolute;
    inset: 0;
    margin: auto;
    width: 70px;
    height: 50px;
    background: rgba(255, 0, 0, .8);
    border-radius: 14px;
    z-index: 2;
    transition: background .2s ease;
    pointer-events: none;
}

.pickUpArea .video-thumb::before {
    width: 108px;
    height: 76px;
}

.video-thumb::after {
    content: '';
    position: absolute;
    inset: 0;
    margin: auto;
    width: 0;
    height: 0;
    border-left: 18px solid #fff;
    border-top: 12px solid transparent;
    border-bottom: 12px solid transparent;
    z-index: 3;
}

.pickUpArea .video-thumb::after {
    border-left: 34px solid #fff;
    border-top: 22px solid transparent;
    border-bottom: 22px solid transparent;
}

.video-thumb:hover {
    cursor: pointer;
}

.video-thumb:hover img {
    transform: scale(1.1);
    transition: .2s ease;
}

.video-duration {
    position: absolute;
    right: 6px;
    bottom: 6px;
    background: rgba(0, 0, 0, .6);
    color: #fff;
    font-size: 12px;
    padding: 2px 6px;
    border-radius: 3px;
    pointer-events: none;
}

.pickUpArea .video-duration {
    font-size: 16px;
    padding: 3px 16px;
    bottom: 20px;
}

@media (max-width: 1023px) {
    .video-thumb {
        width: 100%;
    }

    .video-modal__content {
        padding: 0;
        height: 70%;
        max-width: 680px;
    }

    .video-modal__close {
        top: -25px;
        right: 5px;
        color: #fff;
    }

    .pickUpArea .video-thumb::before {
        width: 70px;
        height: 50px;
    }

    .pickUpArea .video-duration {
        bottom: 6px;
        padding: 2px 6px;
        font-size: 12px;
    }

    .pickUpArea .video-thumb::after {
        border-left: 18px solid #fff;
        border-top: 12px solid transparent;
        border-bottom: 12px solid transparent;
    }
}

@media (max-width: 739px) {
    .video-modal__content {
        height: auto;
        width: 100%;
        max-width: 560px;
    }

}


/* --------------------------------------------
    mainvisual
-------------------------------------------- */
.mainvisual {
    background: linear-gradient(to bottom, rgba(255, 208, 165, .4), rgba(255, 180, 191, .4));
}

.mainvisual.under_area {
    background: #FAF3E7;
    padding-inline: 20px;
}

.mainvisual__content {
    display: grid;
    gap: 8px;
    padding-block: 24px;
    background: none;
}

.mainvisual__title {
    color: var(--mainVisualColor);
    font-size: 24px;
    font-weight: 700;
    line-height: 1.5;
    text-align: center;
}

.mainvisual.under_area .mainvisual__title {
    color: var(--mainColor-red);
}

@media screen and (max-width: 768px) {
    .mainvisual__title {
        font-size: 20px;
    }
}

.mainvisual__icon {
    height: auto;
    margin-inline: auto;
    width: 50px;
}

.mainvisual__subLink {
    text-align: center;
    font-size: 18px;
    font-weight: 700;
    border-radius: 6px;
    border: 1px solid #fff;
    background: linear-gradient(to bottom, #E7325A, #D44D50);
    width: auto;
    margin: 0 auto;
    position: relative;
    width: 100%;
    max-width: 400px;
}

@media screen and (max-width: 768px) {
    .mainvisual__subLink {
        font-size: 14px;
    }
}

.mainvisual__subLink:hover {
    opacity: 0.9;
}

.mainvisual__subLink a {
    display: block;
    padding: 16px;
    color: #ffffff;
}

.mainvisual__subLink a img {
    width: 7px;
    height: 11px;
    margin: 0 auto auto 5px;
    vertical-align: baseline;
}

.mainvisual__subLink a:hover {
    color: #fff;
}


/* ---

カテゴリ

---*/
.filterPanel {
    width: 100%;
    border: 1px solid #CFB673;
    background: #fff;
    border-radius: 4px;
}

.filterPanel .icon {
    color: #CFB673;
    margin-top: 1px;
}

.accordion-toggle {
    width: 97%;
    margin: 0 auto;
    text-align: left;
    background: #FAF4E9;
    padding: 12px;
    border: none;
    cursor: pointer;
    font-weight: 700;
    display: flex;
    justify-content: space-between;
    font-size: 18px;
    color: #000;
}

.accordion-toggle:hover {
    background: #F3EBD4;
}

.accordion-toggle.first-toggle {
    background: #FFF;
}

.accordion-content {
    display: none;
    margin: 0 auto;
    width: 96%;
    padding: 5px 0;
}

.accordion-content .first {
    padding: 20px 0;
}

.accordion-item {
    width: 100%;
}

.accordion-item.active>.accordion-content {
    display: flex;
    flex-flow: wrap;
}

.accordion-content .accordion-content {
    gap: 10px;
    margin: 10px auto;
}

.filter-btn {
    width: fit-content;
    min-width: 90px;
    text-align: center;
    padding: 10px;
    background: #fff;
    border: 1px solid #CFB673;
    cursor: pointer;
    transition: 0.1s;
    border-radius: 5px;
    color: #000;
}

.filter-btn.active {
    color: #fff;
    background: linear-gradient(to left, #A98521, #CFB673);
    border: 1px solid #fff;
}

.accordion-item .btn-area {
    justify-content: center;
    margin-bottom: 20px;
    width: 100%;
    padding-top: 40px;
    text-align: center;
}

.accordion-item .btn-area button {
    border: 1px solid #e50053;
    background: #fff;
    color: #e50053;
    width: 50%;
    padding: 15px 0px;
    font-weight: 700;
    cursor: pointer;
    border-radius: 8px;
    font-size: 18px;
    position: relative;
}

.accordion-item .btn-area button:hover {
    background: #e50053;
    color: #fff;
}

.accordion-item .btn-area button .icon-arrow_right {
    position: absolute;
    right: 27px;
    top: 19px;
}

.movie_area .nothing {
    text-align: center;
    font-size: 18px;
    color: var(--mainColor-red);
    font-weight: 600;
    margin-bottom: 20px;
}

@media screen and (max-width: 768px) {
    .filterPanel {
        width: calc(100% - 32px);
        margin: 0 auto;
    }

    .accordion-item .btn-area button {
        width: 96%;
    }

    .movie_area .nothing {
        font-size: 14px;
    }
}

/* カテゴリ非表示 */
.slide.hidden {
    display: none;
}