/*=======================================================
Studio
=======================================================*/

/*共有設定--------------------タイトル*/
.content-header {
    max-width: 1000px;
    margin: auto;
    padding-bottom: 20px;
}

.content-header h2.studio-ttl {
    font-family: 'Trirong', serif;
    font-size: 64px;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 64px;
    text-indent: 0;
    color: rgba(46, 43, 42, 0.25);
}

.content-header h2.studio-ttl span {
    font-family: 'Zen Kaku Gothic Antique', sans-serif;
    font-size: 20px;
    font-weight: 500;
    letter-spacing: 0.1em;
    line-height: 30px;
    text-indent: 0;
    color: rgba(46, 43, 42, 1);
    display: block;
    margin-top: 10px;
}

.content-header h2.studio-ttl span small {
    display: inline-block;
    margin-left: 10px;
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.1em;
    line-height: 26px;
    text-indent: 0;
    color: rgba(46, 43, 42, 1);
}


@media (max-width:767px) {
    .content-header {
        padding-bottom: 0px;
        padding-left: 4px;
    }

    .content-header h2.studio-ttl {
        font-family: 'Trirong', serif;
        font-size: 34px;
        font-weight: 500;
        letter-spacing: 0.05em;
        line-height: 37.4px;
        text-indent: 0;
        padding-left: 0.2em;
    }

    .content-header h2.studio-ttl span {
        margin-top: 10px;
        margin-left: -0.5em;
    }

    .content-header h2.studio-ttl span small {
        display: inline-block;
        margin-left: 10px;
        padding-top: 8px;
        /*font*/
        color: rgba(46, 43, 42, 1);
        font-size: 13px;
        font-weight: 500;
        letter-spacing: 0.1em;
        line-height: 19.5px;
        text-indent: 0;
    }
}

/*本文*/
.content-wrap .inner-content .content-group p {
    margin-bottom: 1.8em;
    /*font*/
    font-family: 'Zen Kaku Gothic Antique', sans-serif;
    font-size: 14px;
    font-weight: 400;
    letter-spacing: 0.05em;
    line-height: 28px;
    text-indent: 0;
}

@media (max-width:767px) {
    .content-wrap .inner-content .content-group p {
        margin-bottom: 1.5em;
        /*font*/
        font-size: 13px;
        font-weight: 400;
        letter-spacing: 0.05em;
        line-height: 26px;
        text-indent: 0;
    }
}


/*共有設定--------------------スライド*/

@media (min-width: 768px) {
    .slide {
        position: static;
        padding-top: 65px;
    }
}

@media (max-width:767px) {
    #sec2 {
        position: relative;
        overflow: visible;
    }

    .slide {
        position: absolute;
        left: -10px;
        right: -10px;
        bottom: 40px;
        width: calc(100% + 20px);
    }



}

/* swiper*/

.swiper .swiper-slide {
    padding: 0 10px;
    font-weight: 300;
    font-size: 0.75rem;

}

.swiper .swiper-slide img {
    margin-bottom: 1em;
}


.swiper .swiper-slide b {
    display: block !important;
    font-size: 1rem;
    font-family: 'Trirong', 'Georgia', serif;
}

@media (min-width: 768px) {

    /* ナビゲーション矢印を非表示 */
    .swiper-button-next,
    .swiper-button-prev {
        display: none !important;
    }

    /* ページネーションドットを非表示 */
    .swiper-pagination {
        display: none !important;
    }
}


@media (max-width:767px) {

    .swiper {
        overflow: visible;
    }

    .swiper .swiper-slide {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        align-items: center;
    }

    .swiper .swiper-slide img {
        max-width: 100%;
        height: auto;
        display: block;
    }

    .swiper .swiper-slide span {
        display: block;
        width: 100%;
        text-align: left !important;
    }



    /* 左右スライドにデフォルトで透過 */
    .swiper-slide-next,
    .swiper-slide-prev {
        opacity: 0.5 !important;
    }

    /* 共通設定：矢印アイコン非表示 */
    .swiper .swiper-button-next::after,
    .swiper .swiper-button-prev::after {
        display: none;
    }

    /* 左矢印（prev） */
    .swiper .swiper-button-prev {
        width: 26px;
        /* 必要に応じて調整 */
        height: 52px;
        background: url('../images/home/btn_arrow_left.png') no-repeat center center;
        background-size: contain;
    }

    /* 右矢印（next） */
    .swiper .swiper-button-next {
        width: 26px;
        /* 必要に応じて調整 */
        height: 52px;
        background: url('../images/home/btn_arrow_right.png') no-repeat center center;
        background-size: contain;
    }

    /* デフォルトのドットを線に変更 */
    .swiper .swiper-pagination-bullet {
        width: 16px;
        height: 2px;
        border-radius: 0;
        /* 角を丸くしない */
        background: #ffffff;
        /* 未アクティブ状態の色 */
        opacity: 1;
        /* Swiperはデフォルトでopacity: 0.2 */
        margin: 0 4px !important;
        /* 両側の余白 */
    }

    /* アクティブなページ（現在のスライド） */
    .swiper .swiper-pagination-bullet-active {
        background: #000;
        /* アクティブ時の色 */
        width: 32px;
        height: 2px;
    }

    .swiper .swiper-pagination {
        position: absolute;
        bottom: 70px;
        /* 下から20px（画像に重ねたい場合に調整） */
        left: 25%;
        z-index: 100;
        /* スライドより前面に表示 */
        padding-bottom: 10px;
        margin-left: -100px;
    }

}

/*****/



/* +++++++++++++++++++++++++++++++++++++++++ sec1 */
/* common.cssに設定 */

/*view2*/

#sec1 .hero.view2 {
    padding: 120px 20px;
}

#sec1 .hero.view2 .content-wrap .inner-content {
    display: flex;
    justify-content: space-between;
}

#sec1 .hero.view2 .content-wrap .inner-content .content-group {
    flex: 1;
    max-width: 600px;
}

#sec1 .hero.view2 .content-wrap .inner-content .content-group h2{
    margin-bottom: 0.3em;
}

#sec1 .hero.view2 p {
    font-size: 14px;
    font-weight: 400;
    letter-spacing: 0.05em;
    line-height: 30.8px;
    text-indent: 0;
}

#sec1 .hero.view2 p:last-child {
    margin-bottom: 0;
}

#sec1 .hero.view2 .content-wrap .inner-content .local {
    max-width: 280px;
    width: 100%;
    margin-left: 20px;
}

#sec1 .hero.view2 .content-wrap .inner-content .local ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

#sec1 .hero.view2 .content-wrap .inner-content .local ul li {
    border-left: thin solid #2E2B2A;
    padding: 3px 0 0 12px;
    margin-bottom: 25px;
}

#sec1 .hero.view2 .content-wrap .inner-content .local ul li a {
    display: block;
    font-family: 'Zen Kaku Gothic Antique', sans-serif;
    font-size: 14px;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: normal;
    text-indent: 0;
    background-image: url(../images/common/icon_arrow_BD.svg);
    background-repeat: no-repeat;
    background-position: calc(100% - 20px) center;
}

#sec1 .hero.view2 .content-wrap .inner-content .local ul li a small {
    font-family: 'REM', sans-serif;
    font-size: 12px;
    font-weight: 300;
    letter-spacing: 0.05em;
    line-height: normal;
    text-indent: 0;
    color: #AAA19E;
    display: block;
    margin-left: 0.5rem;
}


@media (max-width:767px) {
    #sec1 .hero.view2 {
        padding: 80px 0px 60px 0px;
    }

    #sec1 .hero.view2 h2 {
        font-size: 30px !important;
    }

    #sec1 .hero.view2 .content-wrap {
        padding: 0 24px;
    }

    #sec1 .hero.view2 .content-wrap .inner-content {
        display: block;
    }

    #sec1 .hero.view2 p {
        font-size: 13px;
        font-weight: 400;
        letter-spacing: 0.05em;
        line-height: 32.5px;
        text-indent: 0;
        margin-bottom: 1.8rem;
    }

    #sec1 .hero.view2 .content-wrap .inner-content .local {
        margin-left: auto;
        margin-right: auto;
        margin-top: 40px;
    }

}

/*****/


/* +++++++++++++++++++++++++++++++++++++++++ sec2 */

#Studio #sec2 {
    width: 100%;
    overflow-x: visible;
    margin-bottom: 100px;
}

@media (max-width:767px) {
    #Studio #sec2 {
        margin-bottom: 50px;
    }
}

/* +++++++++++++++++++++++++++++++++++++++++ garden */

#Studio #sec2 .garden {
    width: 100%;
    margin: auto;
    padding: 0 20px;
}

#Studio #sec2 .garden .content-wrap {
    background-image: url(../images/common/bg_noise_G.png);
    padding: 80px 20px;
    margin: auto;
}


#Studio #sec2 .garden .content-wrap .inner-content {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin: auto;
}

#Studio #sec2 .garden .content-wrap .inner-content .thumbnail {
    position: relative;
    flex: 1;
    margin-left: -220px;
    /* はみ出す量を調整 */
    flex-shrink: 0;
    /* サムネイルが縮まないようにする */
}

#Studio #sec2 .garden .content-wrap .inner-content .thumbnail img {
    width: 720px;
    /* 必要に応じて調整 */
    height: 480px !important;
    display: block;
    aspect-ratio: 48 / 35;
}

#Studio #sec2 .garden .content-wrap .inner-content .content-group {
    width: 400px;
    min-width: 400px;
    height: 480px;
    margin-left: 100px;
    position: relative;
}




/*details*/

#Studio #sec2 .garden .content-wrap .inner-content .content-group .details {
    position: absolute;
    bottom: 0;
}

#Studio #sec2 .garden .content-wrap .inner-content .content-group .details dl {
    display: flex;
    border-top: thin solid #AAA19E;
    padding: 20px 0 0 10px;
}

#Studio #sec2 .garden .content-wrap .inner-content .content-group .details dt {
    width: 90px;
    color: #7E7977;
    font-family: 'Trirong', serif;
    font-size: 14px;
    font-weight: 500;
    letter-spacing: normal;
    line-height: 24px;
    text-indent: 0;
    white-space: nowrap;
}

#Studio #sec2 .garden .content-wrap .inner-content .content-group .details dl dd {
    padding: 0 0 0 10px;
}

#Studio #sec2 .garden .content-wrap .inner-content .content-group .details dl dd ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

#Studio #sec2 .garden .content-wrap .inner-content .content-group .details dl dd ul li {
    font-family: 'Zen Kaku Gothic Antique', sans-serif;
    font-size: 13px;
    font-weight: 400;
    letter-spacing: 0.05em;
    line-height: 20.8px;
    text-indent: 0;
    color: #7E7977;
    display: flex;
    margin-bottom: 1em;
}

#Studio #sec2 .garden .content-wrap .inner-content .content-group .details dl dd ul li:last-child {
    margin-bottom: 0;
}

#Studio #sec2 .garden .content-wrap .inner-content .content-group .details dl dd ul li span {
    display: inline-block;
}


@media (max-width:1199px) {
    #Studio #sec2 .garden .content-wrap .inner-content .thumbnail {
        position: relative;
        width: 640px;
        margin-left: -100px;
        /* はみ出す量を調整 */
    }

    #Studio #sec2 .garden .content-wrap .inner-content .thumbnail img {
        width: 100%;
        height: auto!important;
    }

}

/*****/

@media (max-width:991px) {
    #Studio #sec2 .garden .content-wrap .inner-content .content-group {
        margin-left: 50px;
    }

}

/*****/

@media (max-width:767px) {
    #Studio #sec2 .garden {
        padding: 0 10px;
    }

    #Studio #sec2 .garden .content-wrap {
        padding-top: 40px !important;
    }

    #Studio #sec2 .garden .content-wrap .inner-content {
        display: block;
    }

    #Studio #sec2 .garden .content-wrap .inner-content .thumbnail {
        margin-bottom: 32px;
        width: 100%;
        margin-left: -40px;
        width: calc(100% + 40px);
    }

    #Studio #sec2 .garden .content-wrap .inner-content .content-group {
        width: 90%;
        height: auto;
        min-width: auto;
        margin-left: auto;
        margin-right: auto;
    }



    #Studio #sec2 .garden .content-wrap .inner-content .content-group .details {
        position: static;
        bottom: 0;
        margin-top: 40px;
    }

    #Studio #sec2 .garden .content-wrap .inner-content .content-group .details dl {
        padding: 20px 0 0 0;
    }

    #Studio #sec2 .garden .content-wrap .inner-content .content-group .details dt {
        font-size: 13px;
        font-weight: 500;
        letter-spacing: 0;
        line-height: 23px;
    }

    #Studio #sec2 .garden .content-wrap .inner-content .content-group .btn-style1 {
        margin-top: 32px;
        /*ボタン上余白*/
    }

    #Studio #sec2 .garden .content-wrap {
        position: relative;
    }


    #Studio #sec2 .garden .content-wrap .inner-content .content-group .ttl-content01 {
        position: absolute;
        top: 40px;
        left: 40px;
        font-size: clamp(1.25rem, 5vw, 2rem);
    }
}

/*****/



/* +++++++++++++++++++++++++++++++++++++++++ sec3 */

#Studio #sec3 {
    width: 100%;
    overflow-x: visible;
    margin-bottom: 100px;
}

@media (max-width:767px) {
    #Studio #sec3 {
        margin-bottom: 50px;
    }
}

/* +++++++++++++++++++++++++++++++++++++++++ room */

#Studio #sec3 .room {
    width: 100%;
    margin: auto;
    padding: 0 20px;
}

#Studio #sec3 .room .content-wrap {
    background-image: url(../images/common/bg_noise_G.png);
    padding: 80px 20px;
    margin: auto;
}


#Studio #sec3 .room .content-wrap .inner-content {
    display: flex;
    flex-direction: row-reverse;
    /* ← 並び順を右→左に反転 */
    justify-content: space-between;
    align-items: flex-start;
    margin: auto;
}

#Studio #sec3 .room .content-wrap .inner-content .thumbnail {
    position: relative;
    flex: 1;
    margin-right: -220px;
    /* ← 左から右に反転 */
    flex-shrink: 0;
    /* サムネイルが縮まないようにする */
}

#Studio #sec3 .room .content-wrap .inner-content .thumbnail img {
    width: 720px;
    /* 必要に応じて調整 */
    height: 480px !important;
    display: block;
    aspect-ratio: 48 / 35;
}

#Studio #sec3 .room .content-wrap .inner-content .content-group {
    width: 400px;
    min-width: 400px;
    height: 480px;
    margin-right: 100px;
    /* ← 左から右に反転 */
    position: relative;
}




/*details*/

#Studio #sec3 .room .content-wrap .inner-content .content-group .details {
    position: absolute;
    bottom: 0;
}

#Studio #sec3 .room .content-wrap .inner-content .content-group .details dl {
    display: flex;
    border-top: thin solid #AAA19E;
    padding: 20px 0 0 10px;
}

#Studio #sec3 .room .content-wrap .inner-content .content-group .details dt {
    width: 90px;
    color: #7E7977;
    font-family: 'Trirong', serif;
    font-size: 14px;
    font-weight: 500;
    letter-spacing: normal;
    line-height: 24px;
    text-indent: 0;
    white-space: nowrap;
}

#Studio #sec3 .room .content-wrap .inner-content .content-group .details dl dd {
    padding: 0 0 0 10px;
}

#Studio #sec3 .room .content-wrap .inner-content .content-group .details dl dd ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

#Studio #sec3 .room .content-wrap .inner-content .content-group .details dl dd ul li {
    font-family: 'Zen Kaku Gothic Antique', sans-serif;
    font-size: 13px;
    font-weight: 400;
    letter-spacing: 0.05em;
    line-height: 20.8px;
    text-indent: 0;
    color: #7E7977;
    display: flex;
    margin-bottom: 1em;
}

#Studio #sec3 .room .content-wrap .inner-content .content-group .details dl dd ul li:last-child {
    margin-bottom: 0;
}

#Studio #sec3 .room .content-wrap .inner-content .content-group .details dl dd ul li span {
    display: inline-block;
}


@media (max-width:1199px) {
    #Studio #sec3 .room .content-wrap .inner-content .thumbnail {
        position: relative;
        width: 640px;
        margin-right: -100px;
        /* はみ出す量を調整 */
    }

    #Studio #sec3 .room .content-wrap .inner-content .thumbnail img {
        width: 100%;
        height: auto!important;
    }

    

}

/*****/

@media (max-width:991px) {
    #Studio #sec3 .room .content-wrap .inner-content .content-group {
        margin-right: 50px;
    }

}

/*****/

@media (max-width:767px) {

    #Studio #sec3 .room {
        padding: 0 10px;
    }

    #Studio #sec3 .room .content-wrap {
        padding-top: 40px !important;
    }

    #Studio #sec3 .room .content-wrap .inner-content {
        display: block;
    }

    #Studio #sec3 .room .content-wrap .inner-content .thumbnail {
        margin-bottom: 32px;
        width: 100%;
        margin-right: -40px;
        margin-left: 0;
        width: calc(100% + 40px);
    }

    #Studio #sec3 .room .content-wrap .inner-content .content-group {
        width: 90%;
        height: auto;
        min-width: auto;
        margin-left: auto;
        margin-right: auto;
    }


    #Studio #sec3 .room .content-wrap .inner-content .content-group .details {
        position: static;
        bottom: 0;
        margin-top: 40px;
    }

    #Studio #sec3 .room .content-wrap .inner-content .content-group .details dl {
        padding: 20px 0 0 0;
    }

    #Studio #sec3 .room .content-wrap .inner-content .content-group .details dt {
        font-size: 13px;
        font-weight: 500;
        letter-spacing: 0;
        line-height: 23px;
    }

    #Studio #sec3 .room .content-wrap .inner-content .content-group .btn-style1 {
        margin-top: 32px;
        /*ボタン上余白*/
    }

    #Studio #sec3 .room .content-wrap {
        position: relative;
    }


    #Studio #sec3 .room .content-wrap .inner-content .content-group .ttl-content01 {
        position: absolute;
        top: 40px;
        left: 40px;
        font-size: clamp(1.25rem, 5vw, 2rem);
    }
}

/*****/


/* +++++++++++++++++++++++++++++++++++++++++ sec4 */

#Studio #sec4 {
    width: 100%;
    overflow-x: visible;
    margin-bottom: 0px;
}

@media (max-width:767px) {
    #Studio #sec4 {
        margin-bottom: 0px;
    }
}

/* +++++++++++++++++++++++++++++++++++++++++ cave */

#Studio #sec4 .cave {
    width: 100%;
    margin: auto;
    padding: 0 20px;
}

#Studio #sec4 .cave .content-wrap {
    background-image: url(../images/common/bg_noise_G.png);
    padding: 80px 20px;
    margin: auto;
}


#Studio #sec4 .cave .content-wrap .inner-content {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin: auto;
}

#Studio #sec4 .cave .content-wrap .inner-content .thumbnail {
    position: relative;
    flex: 1;
    margin-left: -220px;
    /* はみ出す量を調整 */
    flex-shrink: 0;
    /* サムネイルが縮まないようにする */
}

#Studio #sec4 .cave .content-wrap .inner-content .thumbnail img {
    width: 720px;
    /* 必要に応じて調整 */
    height: 480px !important;
    display: block;
    aspect-ratio: 48 / 35;
}

#Studio #sec4 .cave .content-wrap .inner-content .content-group {
    width: 400px;
    min-width: 400px;
    height: 480px;
    margin-left: 100px;
    position: relative;
}



/*details*/

#Studio #sec4 .cave .content-wrap .inner-content .content-group .details {
    position: absolute;
    bottom: 0;
}

#Studio #sec4 .cave .content-wrap .inner-content .content-group .details dl {
    display: flex;
    border-top: thin solid #AAA19E;
    padding: 20px 0 0 10px;
}

#Studio #sec4 .cave .content-wrap .inner-content .content-group .details dt {
    width: 90px;
    color: #7E7977;
    font-family: 'Trirong', serif;
    font-size: 14px;
    font-weight: 500;
    letter-spacing: normal;
    line-height: 24px;
    text-indent: 0;
    white-space: nowrap;
}

#Studio #sec4 .cave .content-wrap .inner-content .content-group .details dl dd {
    padding: 0 0 0 10px;
}

#Studio #sec4 .cave .content-wrap .inner-content .content-group .details dl dd ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

#Studio #sec4 .cave .content-wrap .inner-content .content-group .details dl dd ul li {
    font-family: 'Zen Kaku Gothic Antique', sans-serif;
    font-size: 13px;
    font-weight: 400;
    letter-spacing: 0.05em;
    line-height: 20.8px;
    text-indent: 0;
    color: #7E7977;
    display: flex;
    margin-bottom: 1em;
}

#Studio #sec4 .cave .content-wrap .inner-content .content-group .details dl dd ul li:last-child {
    margin-bottom: 0;
}

#Studio #sec4 .cave .content-wrap .inner-content .content-group .details dl dd ul li span {
    display: inline-block;
}


@media (max-width:1199px) {
    #Studio #sec4 .cave .content-wrap .inner-content .thumbnail {
        position: relative;
        width: 640px;
        margin-left: -100px;
        /* はみ出す量を調整 */
    }
    #Studio #sec4 .cave .content-wrap .inner-content .thumbnail img {
        width: 100%;
        height: auto!important;
    }

}

/*****/

@media (max-width:991px) {
    #Studio #sec4 .cave .content-wrap .inner-content .content-group {
        margin-left: 50px;
    }

}

/*****/

@media (max-width:767px) {
    #Studio #sec4 .cave {
        padding: 0 10px;
    }

    #Studio #sec4 .cave .content-wrap {
        padding-top: 40px !important;
    }

    #Studio #sec4 .cave .content-wrap .inner-content {
        display: block;
    }

    #Studio #sec4 .cave .content-wrap .inner-content .thumbnail {
        margin-bottom: 32px;
        width: 100%;
        margin-left: -40px;
        width: calc(100% + 40px);
    }

    #Studio #sec4 .cave .content-wrap .inner-content .content-group {
        width: 90%;
        height: auto;
        min-width: auto;
        margin-left: auto;
        margin-right: auto;
    }


    #Studio #sec4 .cave .content-wrap .inner-content .content-group .details {
        position: static;
        bottom: 0;
        margin-top: 40px;
    }


    #Studio #sec4 .cave .content-wrap .inner-content .content-group .details dl {
        padding: 20px 0 0 0;
    }

    #Studio #sec4 .cave .content-wrap .inner-content .content-group .details dt {
        font-size: 13px;
        font-weight: 500;
        letter-spacing: 0;
        line-height: 23px;
    }

    #Studio #sec4 .cave .content-wrap .inner-content .content-group .btn-style1 {
        margin-top: 32px;
        /*ボタン上余白*/
    }

    #Studio #sec4 .cave .content-wrap {
        position: relative;
    }


    #Studio #sec4 .cave .content-wrap .inner-content .content-group .ttl-content01 {
        position: absolute;
        top: 40px;
        left: 40px;
        font-size: clamp(1.25rem, 5vw, 2rem);
    }
}

/*****/