@charset "UTF-8";


html {
    scroll-behavior: smooth;
}

*, *::before, *::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

/* PC(768) */

@media (min-width: 768px) {
    body {
        width: 100%;
        background-color: #333;
        font-size: 16px;
        font-family: "Shippori Mincho", serif;
        font-optical-sizing: auto;
        font-weight: 400;
        font-style: normal;
        line-height: 180%;
        color:#edece7;
    }

    .pc_br{
        display: none;
    }

    /* ヒーローイメージ */
    .main-visual{
        width: 100%;
        max-width: 1920px;
        margin:0 auto;
    }
    .main-visual h1{
        width: 100%;
    }
    .main-visual h1 img{
        display: block;
        width: 100%;
    }

    /* about */
    .about{
        width: 100%;
        max-width: 1920px;
        margin:0 auto; 
        position: relative;
        overflow: hidden;
    }
    .about .bg-photo {
        width: 100%;
        height: auto;
        display: block;
    }
    .about-content {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        width: 90%;
        max-width: 800px;
        
        text-shadow: 0 2px 8px rgba(0, 0, 0, 0.7);
        z-index: 2;
    }
    .about-content h2{
        margin: 0 0 2rem;
        text-align: center;
        font-size: 2rem;
        font-weight: 600;

    }
    .about-content p{
        text-align: center;
        font-weight: 400;
        line-height: 260%;
        
    }
    .about .dash{
        display: inline-block;
        transform: scaleX(2);
        transform-origin: left center;
        margin-right: 1em;
    }

    /* movie */
    .movie{
        width: 100%;
        max-width: 1920px;
        margin:0 auto; 
        position: relative;
        overflow: hidden;

        background-color: #4f5862; 
        background-image: url("images/aki_back01.webp");
        background-repeat: no-repeat;
        background-position: right bottom; 
        background-size: 20% auto;

        padding: 100px 0 120px;
    }
    .movie-content {
        margin: 0 auto;
        width: 90%;
        max-width: 600px;
        z-index: 2;
    }
    .movie-content h2{
        margin: 0 0 4rem;
        text-align: center;
        font-size: 3rem;
        font-weight: 600;
    }
    .movie-content .movie-box{
        width: 100%;
        max-width: 600px;
        margin: 0 auto;
    }
    .movie-content .movie-box img{
        display: block;
        width: 100%;
        height: auto;
    }

    /* aki_ph */
    .aki_ph{
        width: 100%;
        max-width: 1920px;
        margin:0 auto; 
    }
    .aki_ph img{
        display: block;
        width: 100%;
    }

    /* cast */
    .cast{
        width: 100%;
        max-width: 1920px;
        margin:0 auto; 
        position: relative;
        overflow: hidden;

        background-color: #dc8b22; 
        background-image: url("images/aki_back02.webp");
        background-repeat: no-repeat;
        background-position: right bottom; 
        background-size: 20% auto;

        padding: 120px 0;
    }
    .cast-content{
        margin: 0 auto;
        width: 90%;
        max-width: 700px;
        z-index: 2;
    }
    .cast-content h2{
        margin: 0 0 4.5rem;
        text-align: center;
        font-size: 3rem;
        font-weight: 600;
    }
    .profile-content{
        width: 100%;
        margin: 0 auto;
        display: flex;
        justify-content: center;
        gap:2rem;
    }
    .profile-content img{
        display: block;
        width:365px;
    }
    .profile_box{
        width: 50%;
    }
    .profile_name{
        font-size: 1.6rem;
        font-weight: 400;
        line-height: 110%;
        margin-bottom: 1rem;
    }
    .name_katakana{
        font-size: 1rem;
    }
    .name_alphabet{
        font-size: 0.8rem;
        font-family: "Noto Sans JP", sans-serif;
    }
    .profile_text{
        font-weight: 400;
        line-height: 180%;
        font-family: "Noto Sans JP", sans-serif;
    }

    /* trip */
    .trip{
        width: 100%;
        max-width: 1920px;
        margin:0 auto; 
        position: relative;
        overflow: hidden;
    }
    .trip .bg-photo {
        width: 100%;
        height: auto;
        display: block;
    }
    .trip-content {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        width: 90%;
        max-width: 800px;
        
        text-shadow: 0 2px 8px rgba(0, 0, 0, 0.7);
        z-index: 2;
    }
    .trip-content h2{
        margin: 0 0 4rem;
        text-align: center;
        font-size: 3rem;
        font-weight: 600;

    }
    .trip-content p{
        text-align: center;
        font-weight: 400;
        line-height: 260%;
        letter-spacing: 0.08em;
        
    }
    .trip .dash{
        display: inline-block;
        transform: scaleX(2);
        transform-origin: left center;
        margin-right: 1em;
    }


    /* フッター */
    footer{
        width: 100%;
        max-width: 1920px;
        margin:0 auto;
        padding:5rem 0;
        background-color: #222;
    }
    footer img{
        display: block;
        width: 180px;
        margin: 0 auto 0.6rem;
    }
    footer p{
        width: 100%;
        text-align: center;
        font-size: 0.6rem;
        font-weight: 300;
        line-height: 180%;
    }

    /* AOS */
    .about .aos-wrapper,
    .trip .aos-wrapper {
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        z-index: 2;
        
        display: flex;
        flex-direction: column;
    }


}


/* SP(767) スマホ*/

@media (max-width: 767.98px) {
    body {
        width: 100%;
        background-color: #333;
        font-size: 14px;
        font-family: "Shippori Mincho", serif;
        font-optical-sizing: auto;
        font-weight: 400;
        font-style: normal;
        line-height: 180%;
        color:#edece7;
    }

    .sp_br{
        display: none;
    }


    /* ヒーローイメージ */
    .main-visual{
        width: 100%;
        /* max-width: 1920px; */
        margin:0 auto;
    }
    .main-visual h1{
        width: 100%;
    }
    .main-visual h1 img{
        display: block;
        width: 100%;
    }

    /* about */
    .about{
        width: 100%;
        /* max-width: 1920px; */
        margin:0 auto; 
        position: relative;
        overflow: hidden;
    }
    .about .bg-photo {
        width: 100%;
        height: auto;
        display: block;
    }
    .about-content {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        width: 90%;
        max-width: 800px;
        
        text-shadow: 0 2px 8px rgba(0, 0, 0, 0.7);
        z-index: 2;
    }
    .about-content h2{
        margin: 0 0 1rem;
        text-align: center;
        font-size: 1.4rem;
        font-weight: 600;
        line-height: 105%;

    }
    .about-content p{
        text-align: center;
        font-weight: 400;
        line-height: 170%;
        font-size: 0.9rem;
        
    }
    .about .dash{
        display: inline-block;
        transform: scaleX(2);
        transform-origin: left center;
        margin-right: 1em;
    }

    /* movie */
    .movie{
        width: 100%;
        margin:0 auto; 
        position: relative;
        overflow: hidden;

        background-color: #4f5862; 
        background-image: url("images/aki_back01.webp");
        background-repeat: no-repeat;
        background-position: right bottom; 
        background-size: 50% auto;

        padding: 50px 0 60px;
    }
    .movie-content {
        margin: 0 auto;
        width: 90%;
        z-index: 2;
    }
    .movie-content h2{
        margin: 0 0 2.5rem;
        text-align: center;
        font-size: 2rem;
        font-weight: 600;
    }
    .movie-content .movie-box{
        width: 100%;
        /* max-width: 600px; */
        margin: 0 auto;
    }
    .movie-content .movie-box img{
        display: block;
        width: 100%;
        height: auto;
    }

    /* aki_ph */
    .aki_ph{
        width: 100%;
        /* max-width: 1920px; */
        margin:0 auto; 
    }
    .aki_ph img{
        display: block;
        width: 100%;
    }

    /* cast */
    .cast{
        width: 100%;
        /* max-width: 1920px; */
        margin:0 auto; 
        position: relative;
        overflow: hidden;

        background-color: #dc8b22; 
        background-image: url("images/aki_back02.webp");
        background-repeat: no-repeat;
        background-position: right bottom; 
        background-size: 50% auto;

        padding: 50px 0;
    }
    .cast-content{
        margin: 0 auto;
        width: 90%;
        max-width: 700px;
        z-index: 2;
    }
    .cast-content h2{
        margin: 0 0 3rem;
        text-align: center;
        font-size: 2rem;
        font-weight: 600;
    }
    .profile-content{
        width: 100%;
        margin: 0 auto;
        display: flex;
        flex-direction:column;
        justify-content: center;
        gap:1rem;
    }
    .profile-content img{
        display: block;
        width:250px;
        margin: 0 auto;
    }
    .profile_box{
        width: 80%;
        margin: 0 auto;
    }
    .profile_name{
        font-size: 1.6rem;
        font-weight: 400;
        line-height: 110%;
        margin-bottom: 1rem;
        text-align: center;
    }
    .name_katakana{
        font-size: 1rem;
    }
    .name_alphabet{
        font-size: 0.8rem;
        font-family: "Noto Sans JP", sans-serif;
    }
    .profile_text{
        font-weight: 400;
        line-height: 180%;
        font-family: "Noto Sans JP", sans-serif;
    }

    /* trip */
    .trip{
        width: 100%;
        /* max-width: 1920px; */
        margin:0 auto; 
        position: relative;
        overflow: hidden;
    }
    .trip .bg-photo {
        width: 100%;
        height: auto;
        display: block;
    }
    .trip-content {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        width: 90%;
        max-width: 800px;
        
        text-shadow: 0 2px 8px rgba(0, 0, 0, 0.7);
        z-index: 2;
    }
    .trip-content h2{
        margin: 0 0 2rem;
        text-align: center;
        font-size: 2rem;
        font-weight: 600;

    }
    .trip-content p{
        text-align: center;
        font-weight: 400;
        line-height: 220%;
        letter-spacing: 0.08em;
        
    }
    .trip .dash{
        display: inline-block;
        transform: scaleX(2);
        transform-origin: left center;
        margin-right: 1em;
    }


    /* フッター */
    footer{
        width: 100%;
        max-width: 1920px;
        padding:5rem 0;
        background-color: #222;
    }
    footer img{
        display: block;
        width: 180px;
        margin: 0 auto 0.6rem;
    }
    footer p{
        width: 80%;
        margin: 0 auto;
        text-align: center;
        font-size: 0.6rem;
        font-weight: 300;
        line-height: 180%;
    }

    /* AOS */
    .about .aos-wrapper,
    .trip .aos-wrapper {
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        z-index: 2;
        
        display: flex;
        flex-direction: column;
    }
}

    /* スライダー */
    /* gallery スライダー */
    .ep2_gallery{
        padding-top:4rem;
        padding-bottom:4rem;
        margin: 0 auto;
        background-color: #4f5862;
        margin-bottom: 0;
        padding-bottom: 0;
        overflow: hidden;
    }
    .gallery_container {
        width: 90%;
        max-width: 1000px;
        margin: 0 auto 4rem;
    }
    .gallery_slider img {
        width: 100%;
        height: auto;
        display: block;
    }
    .gallery_container .slick-dots{
        position: static;
        bottom: auto;
        margin-top: 14px;
    }
    .ep2_gallery .slick-dots li {
    display: inline-block;
    margin: 0 1px;
    }
    .gallery_slider .slick-slide {
        display: block;
        padding: 0 2px;
        box-sizing: border-box;
    }
    /* 非アクティブなドット */
    .ep2_gallery .slick-dots li button:before {
        color: #ccc;
        opacity: 0.5;
    }

    /* アクティブなドット */
    .ep2_gallery .slick-dots li.slick-active button:before {
        color: #ccc;
        opacity: 1;
    }

    /* ===== 矢印（デフォルト記号を消し、カスタム矢印を使用） ===== */

    /* デフォルト擬似要素を無効化（重なり防止） */
    .ep2_gallery .slick-prev:before,
    .ep2_gallery .slick-next:before{
    content:'';
    opacity:0;
    }

    /* カスタム矢印ボタン */
    .ep2_gallery .custom-prev,
    .ep2_gallery .custom-next{
    width:40px;
    height:40px;
    border:none;
    border-radius:50%;
    /* background:rgba(0,0,0,0); */
    color:#fff;
    font-size:24px;
    line-height:40px;
    text-align:center;
    cursor:pointer;
    opacity:.85;
    transition:background .3s, opacity .2s;
    z-index:10;
    }
    .ep2_gallery .custom-prev:hover,
    .ep2_gallery .custom-next:hover{
    /* background:rgba(0,0,0,.8); */
    opacity:1;
    }

    /* 矢印の位置 */
    .ep2_gallery .slick-prev{ left:-50px; }
    .ep2_gallery .slick-next{ right:-50px; }


    /* 告知動画 */
    /* ===== モーダルウィンドウの共通スタイル ===== */
.video_modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2000;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.4s, visibility 0.4s;
}

/* JSで .is-open クラスがついたら表示する */
.video_modal.is-open {
  opacity: 1;
  visibility: visible;
}

/* 背景の黒い半透明の敷物 */
.video_modal__overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.8);
  cursor: pointer;
}

/* モーダルの中身のコンテナ */
.video_modal__inner {
  position: relative;
  width: 90%;
  max-width: 800px;
  z-index: 10;
}

/* YouTubeを16:9でレスポンシブ固定するボックス（重要） */
.video_modal__box {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}

.video_modal__box .video_iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/* 閉じる「×」ボタン */
.video_modal__close {
  position: absolute;
  top: -40px;
  right: 0;
  background: none;
  border: none;
  color: #fff;
  font-size: 35px;
  cursor: pointer;
  line-height: 1;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 100;
}
.video_modal__close:hover {
  opacity: 0.7;
}

/* 
   スマホ用スライダーボタン
*/
@media (max-width: 767px) {

    .ep2_gallery .custom-prev,
    .ep2_gallery .custom-next {
        width: 36px !important;
        height: 36px !important;
        line-height: 32px !important;
        border-radius: 50% !important;
        background: rgba(0, 0, 0, 0.9) !important;
        padding: 0 !important;
    }

    .ep2_gallery .slick-prev {
        left: 8px !important;
    }
    
    .ep2_gallery .slick-next {
        right: 8px !important;
    }

    .ep2_gallery .slick-prev,
    .ep2_gallery .slick-next {
        z-index: 100;
        top: 50%;
        transform: translateY(-50%);
    }

    .video_modal .video_modal__overlay {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: rgba(0, 0, 0, 1) !important;
        cursor: pointer;
    }
}