#sec1 .bg {
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    z-index: -1
}

#sec1 .bg::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    z-index: 1;
    background: #a98f47;
    width: 3vw
}

#sec1 h2 {
    text-align: center;
    padding: 7vw 0;
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: .28em;
}

#sec1 .photo-1 {
    margin-top: 10vw
}

#sec1 .txt {
    margin-top: 8vw
}

#sec1 .txt li+li {
    margin-top: 3vw
}

#sec1 .box {
    position: relative;
    background: #000;
    color: #fff;
    margin: 10vw -8%;
}

#sec1 .box .txt-en1 {
    position: absolute;
    top: 5vw;
    left: 5%;
    right: 0;
    z-index: 1;
    font-size: 4vw;
    font-weight: 500;
    line-height: calc(60 / 26);
    letter-spacing: 0.22em;
}

#sec1 .box .txt-en2 {
    padding: 10vw 6%;
}

@media screen and (min-width: 768px) {
    #sec1 {
        padding-bottom: 182px
    }

    #sec1 .wrap {
        max-width: 1354px;
        padding: 0 30px
    }

    #sec1 .bg {
        right: calc(-50vw + 50%);
        left: 390px;
        height: 570px
    }

    #sec1 .bg::before {
        left: -40px;
        width: 40px
    }

    #sec1 h2 {
        text-align: left;
        width: -moz-fit-content;
        width: fit-content;
        margin-left: calc(50% + 38px);
        padding: 130px 0 0
    }

    #sec1 .photo-1 {
        margin-top: -22px
    }

    #sec1 .txt {
        width: 497px;
        margin: 63px 0 0 17px
    }

    #sec1 .txt li+li {
        margin-top: 0
    }

    #sec1 .box {
        position: absolute;
        bottom: 0;
        right: -73px;
        left: 50%;
        margin: 0;
    }

    #sec1 .box .txt-en1 {
        top: 48px;
        left: 60px;
        font-size: 26px;
    }

    #sec1 .box .photo img {
        width: 100%;
    }

    #sec1 .box .txt-en2 {
        padding: 41px 61px 57px;
    }

    @media screen and (min-width: 768px) and (max-width: 1500px) {
        #sec1 .box {
            right: calc(-50vw + 50%);
        }
    }

    @media screen and (min-width: 768px) and (max-width: 1300px) {
        #sec1 .box .txt-en1 {
            top: calc((48 / 1300) * 100vw);
            left: calc((60 / 1300) * 100vw);
            font-size: calc((26 / 1300) * 100vw);
        }

        #sec1 .box .txt-en2 {
            padding: calc((41 / 1300) * 100vw) calc((30 / 1300) * 100vw) calc((57 / 1300) * 100vw);
            font-size: calc((16 / 1300) * 100vw);
            line-height: calc(36 / 16);
        }
    }
}

#sec2 .set1 {
    position: relative;
    z-index: 1;
    padding: 15vw 0
}

#sec2 .set1::before {
    content: "";
    position: absolute;
    top: 75vw;
    bottom: 0;
    left: 0;
    z-index: -1;
    background: #a98f47;
    width: 10%
}

#sec2 .set1 .deco-txt {
    position: absolute;
    top: 9vw;
    left: 0;
    width: 10%;
    z-index: -1
}

#sec2 .set1 h2 span {
    display: block;
    font-weight: 500;
    line-height: 2
}

#sec2 .set1 h2 span.en {
    letter-spacing: .28em
}

#sec2 .set1 h2 span.jp {
    letter-spacing: .2em
}

#sec2 .set1 .price {
    margin-top: 5vw;
    font-weight: 500;
    letter-spacing: .28em
}

#sec2 .set1 .price small {
    letter-spacing: .28em
}

#sec2 .set1 .note {
    margin-top: 2vw
}

#sec2 .set1 .box-shared {
    margin-top: 10vw
}

#sec2 .set1 h3 {
    padding-top: 10vw;
    font-weight: 500;
    line-height: 1.6425
}

#sec2 .set1 h3 span {
    display: block;
    letter-spacing: .28em
}

#sec2 .set1 h3 span:nth-child(2) {
    text-align: center
}

#sec2 .set1 h3 span:nth-child(3) {
    text-align: right
}

#sec2 .set1 .group-photo {
    margin-top: 10vw
}

#sec2 .set1 .group-photo li+li {
    margin-top: 5vw
}

#sec2 .set1 .txt {
    margin-top: 8vw
}

#sec2 .set2 {
    margin-top: 10vw
}

#sec2 .set2 .ttl h3 {
    border-top: 1px solid #000;
    border-bottom: 1px solid #000;
    padding: 15vw 0;
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: .28em
}

#sec2 .set2 .photo {
    position: relative;
    margin-top: 10vw
}

#sec2 .set2 .photo dt {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1
}

#sec2 .set3 {
    padding: 5vw 0 15vw
}

#sec2 .set3 .group-photo li+li {
    margin-top: 5vw
}

#sec2 .set-add {
    background: url("../img/english/sec2_bg.jpg") repeat center;
    color: #fff;
    padding-bottom: 20vw;
}

#sec2 .set-add .inner {
    position: relative;
    padding: 0 6.67%;
}

#sec2 .set-add .txt-en {
    position: absolute;
    top: 0;
    right: 5%;
    z-index: 1;
    background: url("../img/english/sec2_deco_ttl.png") no-repeat center bottom/auto 100%;
    color: #000;
    padding: 10vw 6% 20vw 7%;
}

#sec2 .set-add .txt-en span {
    font-size: 5.5vw;
    font-weight: 500;
    line-height: 1;
    letter-spacing: .22em
}

#sec2 .set-add .txt-en2 {
    position: absolute;
    top: 10vw;
    left: 4%;
    z-index: 1;
    font-size: 3.2vw;
    font-weight: 500;
    line-height: 2;
    letter-spacing: 0.22em;
}

#sec2 .set-add .bg-img {
    margin: 0 -46% 0 -35%
}

#sec2 .set-add .txt-add {
    margin-top: 10vw;
}


#sec2 .set-add2 {
    background: #8a6600;
    color: #fff;
}

#sec2 .set-add2 {
    padding-bottom: 10vw;
}

#sec2 .set-add2 h3 {
    font-weight: 500;
    line-height: 2;
    letter-spacing: .28em
}

#sec2 .set-add2 .price {
    line-height: 2;
    letter-spacing: .28em
}

#sec2 .set-add2 .price small {
    letter-spacing: .28em
}

#sec2 .set-add2 .note {
    margin-top: 5vw
}

#sec2 .set-add2 .menu {
    margin-top: 5vw
}

#sec2 .set-add2 .menu dl {
    border-bottom: 1px dashed rgba(255, 255, 255, .6);
    padding: 3vw 0;
    font-weight: 500;
    line-height: 1.6
}

#sec2 .set-add2 .menu dl * {
    letter-spacing: .28em
}

#sec2 .set-add2 .menu dl dd {
    margin-top: 1vw;
    text-align: right
}

#sec2 .set-add2 .box-shared {
    border: none;
    padding: 0;
    margin-top: 7vw
}

#sec2 .set-add2 .wrap {
    border-bottom: 1px solid rgba(255, 255, 255, .6);
    padding-bottom: 7vw;
}

#sec2 .set-add2 .slider {
    position: relative;
    margin-top: 10vw;
}

#sec2 .set-add2 .slider .wrap {
    border: none;
}

#sec2 .set-add2 .sec3-thumb {
    position: relative;
    z-index: 1;
    padding: 4vw;
    margin-top: 5vw
}

#sec2 .set-add2 .sec3-thumb::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    background: #fff;
    border-radius: 10px
}

#sec2 .set-add2 .sec3-thumb .slick-list {
    overflow: visible
}

#sec2 .set-add2 .sec3-thumb .slick-track {
    transform: none !important;
    width: 100% !important
}

#sec2 .set-add2 .sec3-thumb .slick-slide {
    position: relative;
    width: 100%
}

#sec2 .set-add2 .sec3-thumb .slick-slide+.slick-slide {
    margin-top: 6vw
}

#sec2 .set-add2 .sec3-thumb .slick-slide .item {
    position: relative;
    display: flex !important;
    justify-content: center;
    align-items: center;
    text-align: center;
    background: #a98f47;
    border-radius: 10px;
    height: 15vw
}

#sec2 .set-add2 .sec3-thumb .slick-slide .item::before {
    content: "";
    position: absolute;
    inset: -2vw -2vw -2vw -4vw;
    z-index: -1;
    background: #8a6600;
    border-radius: 0 10px 10px 0;
    opacity: 0;
    transition: .3s
}

#sec2 .set-add2 .sec3-thumb .slick-slide .item::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    background: #fff;
    width: 5vw;
    height: 1px
}

#sec2 .set-add2 .sec3-thumb .slick-slide .item .txt-en {
    position: absolute;
    top: 1vw;
    left: 1vw;
    line-height: 1;
    letter-spacing: .03em
}

#sec2 .set-add2 .sec3-thumb .slick-slide .item .txt-jp {
    line-height: 1.5;
    font-weight: 500;
    letter-spacing: .28em
}

#sec2 .set-add2 .sec3-thumb .slick-slide:last-child .txt-jp {
    letter-spacing: .06em
}

#sec2 .set-add2 .sec3-thumb .slick-current .item {
    background: #a68a3d
}

#sec2 .set-add2 .sec3-thumb .slick-current .item::before {
    opacity: 1
}

@media screen and (max-width: 767px) {
    #sec2 .set1 .wrap>* {
        margin-left: 8%
    }

    #sec2 .set-add2 .wrap>* {
        margin-left: 0;
    }

    #sec2 .set-add2 .fs16 {
        font-size: 3vw
    }

    #sec2 .set-add2 .fs18 {
        font-size: 3.27vw
    }
}

@media screen and (min-width: 768px) {
    #sec2 .set1 {
        padding: 136px 0 86px
    }

    #sec2 .set1::before {
        top: 793px;
        width: 113px
    }

    #sec2 .set1 .deco-txt {
        top: 43px;
        width: auto
    }

    #sec2 .set1 .wrap {
        max-width: 1100px;
        padding-bottom: 0;
    }

    #sec2 .set1 h2 span.jp {
        margin-top: -5px
    }

    #sec2 .set1 .price {
        margin-top: 11px
    }

    #sec2 .set1 .note {
        margin-top: -2px
    }

    #sec2 .set1 .box-shared {
        padding-bottom: 43px;
        margin-top: 25px
    }

    #sec2 .set1 .box-shared .list {
        max-width: 970px;
        margin: 19px auto 0
    }

    #sec2 .set1 .box-shared .list ul {
        width: calc(50% - 20px);
        padding-left: 0
    }

    #sec2 .set1 h3 {
        max-width: 800px;
        padding-top: 0;
        margin: 38px auto 0
    }

    #sec2 .set1 .group-photo {
        display: flex;
        justify-content: space-between;
        margin-top: 35px
    }

    #sec2 .set1 .group-photo li {
        width: calc(50% - 30px)
    }

    #sec2 .set1 .group-photo li+li {
        margin-top: 0
    }

    #sec2 .set1 .txt {
        text-align: center;
        margin-top: 52px
    }

    #sec2 .set2 {
        margin-top: 0
    }

    #sec2 .set2 .wrap {
        display: flex;
        align-items: center;
        justify-content: space-between;
        max-width: 100%
    }

    #sec2 .set2 .ttl {
        order: 2;
        width: calc(50% - 28px);
        padding: 0 30px
    }

    #sec2 .set2 .ttl h3 {
        max-width: 485px;
        margin: 0 auto;
        padding: 118px 0;
        font-size: 26px;
        line-height: 2;
    }

    #sec2 .set2 .photo {
        order: 1;
        width: calc(50% + 28px);
        margin-top: 0
    }

    #sec2 .set2 .photo dd {
        height: 599px
    }

    #sec2 .set3 {
        padding: 61px 30px 120px
    }

    #sec2 .set3 .wrap {
        max-width: 1300px
    }

    #sec2 .set3 .group-photo {
        display: flex;
        justify-content: space-between
    }

    #sec2 .set3 .group-photo li {
        width: 30.7692307692%
    }

    #sec2 .set3 .group-photo li+li {
        margin-top: 0
    }

    #sec2 .set-add {
        padding-bottom: 109px;
        margin: 50px 0 0
    }

    #sec2 .set-add .inner {
        max-width: 1100px;
        margin: 0 auto;
        padding: 0;
    }

    #sec2 .set-add .txt-en {
        right: 49px;
        padding: 88px 48px 40px 61px;
        height: 441px
    }

    #sec2 .set-add .txt-en2 {
        top: 198px;
        left: 50px;
        font-size: 30px;
    }

    #sec2 .set-add .txt-en span {
        font-size: 40px
    }

    #sec2 .set-add .bg-img {
        margin: 0 -200px;
        height: 686px
    }

    #sec2 .set-add .bg-img img {
        width: 100%;
        height: 100%;
        -o-object-fit: cover;
        object-fit: cover
    }

    #sec2 .set-add .txt-add {
        text-align: center;
        margin-top: 71px
    }

    #sec2 .set-add2 {
        padding: 42px 0 60px
    }

    #sec2 .set-add2 .note {
        margin: 22px 0 -32px
    }

    #sec2 .set-add2 .price {
        margin-top: 5px
    }

    #sec2 .set-add2 .menu {
        max-width: 712px;
        margin: 30px auto 0
    }

    #sec2 .set-add2 .menu dl {
        display: flex;
        align-items: flex-end;
        justify-content: space-between;
        padding: 10px 0 10px 6px;
        line-height: 30px
    }

    #sec2 .set-add2 .menu dl dd {
        margin-top: 0
    }

    #sec2 .set-add2 .box-shared {
        margin-top: 52px
    }

    #sec2 .set-add2 .slider {
        margin: 200px 0
    }

    #sec2 .set-add2 .slider .wrap {
        max-width: 1300px
    }

    #sec2 .set-add2 .slider .ttl {
        width: 580px;
        margin: 0 0 38px auto
    }

    #sec2 .set-add2 .slider .sec3-main {
        position: absolute;
        top: -98px;
        left: calc(50% - 50vw);
        right: 512px
    }

    #sec2 .set-add2 .slider .sec3-main .slick-dots {
        display: flex !important;
        justify-content: flex-end;
        gap: 8px;
        margin-top: 8px
    }

    #sec2 .set-add2 .slider .sec3-main .slick-dots li {
        position: relative;
        width: 115px;
        height: 90px;
        transition: .3s
    }

    #sec2 .set-add2 .slider .sec3-main .slick-dots li::before {
        content: "";
        position: absolute;
        inset: 0;
        z-index: 1;
        background: rgba(0, 0, 0, .6);
        transition: .3s
    }

    #sec2 .set-add2 .slider .sec3-main .slick-dots li button {
        cursor: pointer;
        border: none;
        border-radius: unset;
        outline: none;
        display: block;
        width: 100%;
        height: 100%;
        font-size: 0;
        transition: .3s
    }

    #sec2 .set-add2 .slider .sec3-main .slick-dots li:nth-child(1) button {
        background: url("../img/english/sec3_js1.jpg") no-repeat center/cover
    }

    #sec2 .set-add2 .slider .sec3-main .slick-dots li:nth-child(2) button {
        background: url("../img/english/sec3_js2.jpg") no-repeat center/cover
    }

    #sec2 .set-add2 .slider .sec3-main .slick-dots li:nth-child(3) button {
        background: url("../img/english/sec3_js3.jpg") no-repeat center/cover
    }

    #sec2 .set-add2 .slider .sec3-main .slick-dots li.slick-active::before {
        opacity: 0
    }

    #sec2 .set-add2 .slider .sec3-main .item {
        height: 599px
    }

    #sec2 .set-add2 .slider .sec3-thumb {
        width: 473px;
        margin-left: auto;
        padding: 58px 29px
    }

    #sec2 .set-add2 .slider .sec3-thumb::before {
        right: calc(-50vw + 50%)
    }

    #sec2 .set-add2 .slider .sec3-thumb .slick-slide {
        cursor: pointer;
        width: 500px;
        transition: .3s
    }

    #sec2 .set-add2 .slider .sec3-thumb .slick-slide+.slick-slide {
        margin-top: 65px
    }

    #sec2 .set-add2 .slider .sec3-thumb .slick-slide .item {
        height: 85px
    }

    #sec2 .set-add2 .slider .sec3-thumb .slick-slide .item::before {
        inset: -30px
    }

    #sec2 .set-add2 .slider .sec3-thumb .slick-slide .item::after {
        width: 40px
    }

    #sec2 .set-add2 .slider .sec3-thumb .slick-slide .item .txt-en {
        top: 8px;
        left: 13px
    }
}

@media screen and (min-width: 768px)and (max-width: 1400px) {
    #sec2 .set1 {
        padding-left: 150px;
        padding-right: 30px
    }

    #sec2 .set-add {
        margin-left: -150px;
        margin-right: -30px;
    }
}

#sec3 {
    background: #8a6600;
    color: #fff;
    padding: 10vw 0 15vw
}

#sec3 h2 {
    font-weight: 500;
    line-height: 2;
    letter-spacing: .2em
}

#sec3 .note-lead {
    margin: 5vw 0;
    letter-spacing: .15em
}

#sec3 .set {
    border-top: 1px solid rgba(255, 255, 255, .6);
    padding: 10vw 0
}

#sec3 .set h3 {
    font-weight: 500;
    line-height: 2;
    letter-spacing: .28em
}

#sec3 .set .price {
    line-height: 2;
    letter-spacing: .28em
}

#sec3 .set .price small {
    letter-spacing: .28em
}

#sec3 .set .note {
    margin-top: 5vw
}

#sec3 .set .menu {
    margin-top: 5vw
}

#sec3 .set .menu dl {
    border-bottom: 1px dashed rgba(255, 255, 255, .6);
    padding: 3vw 0;
    font-weight: 500;
    line-height: 1.6
}

#sec3 .set .menu dl * {
    letter-spacing: .28em
}

#sec3 .set .menu dl dd {
    margin-top: 1vw;
    text-align: right
}

#sec3 .set .box-shared {
    border: none;
    padding: 0;
    margin-top: 7vw
}

#sec3 .set2 {
    border-bottom: 1px solid rgba(255, 255, 255, .6)
}

#sec3 .set3 {
    border-top: none;
    border-bottom: 1px solid rgba(255, 255, 255, .6)
}

@media screen and (max-width: 767px) {
    #sec3 .slider .fs16 {
        font-size: 3vw
    }

    #sec3 .slider .fs18 {
        font-size: 3.27vw
    }
}

@media screen and (min-width: 768px) {
    #sec3 {
        padding: 90px 0 120px
    }

    #sec3 .wrap {
        max-width: 1100px
    }

    #sec3 .note-lead {
        margin: 13px 0 16px
    }

    #sec3 .set {
        padding: 42px 0 41px
    }

    #sec3 .set .note {
        margin: 22px 0 -32px
    }

    #sec3 .set .price {
        margin-top: 5px
    }

    #sec3 .set .menu {
        max-width: 712px;
        margin: 30px auto 0
    }

    #sec3 .set .menu dl {
        display: flex;
        align-items: flex-end;
        justify-content: space-between;
        padding: 10px 0 10px 6px;
        line-height: 30px
    }

    #sec3 .set .menu dl dd {
        margin-top: 0
    }

    #sec3 .set .box-shared {
        margin-top: 52px
    }

    #sec3 .set2 {
        padding: 54px 0 46px
    }
}

#sec4 .set1 {
    position: relative
}

#sec4 .set1 .bg {
    height: 50vw
}

#sec4 .set1 .bg img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover
}

#sec4 .set1 .deco-txt {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1
}

#sec4 .set1 h2 {
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    z-index: 1;
    transform: translateY(-50%);
    color: #fff;
    font-weight: 500;
    line-height: 1;
    letter-spacing: .2em
}

#sec4 .set2 {
    position: relative;
    z-index: 1;
    padding: 10vw 0 15vw
}

#sec4 .set2::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    z-index: -1;
    width: 8%;
    background: #8a6600
}

#sec4 .set2 .bg {
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: -1;
    width: 40%
}

#sec4 .set2 .group-txt {
    margin: 10vw 0 0 8%
}

#sec4 .set2 .group-txt h3 {
    text-align: center;
    line-height: 1;
    font-weight: 500;
    letter-spacing: .2em
}

#sec4 .set2 .group-txt .txt {
    margin-top: 8vw
}

#sec4 .set2 .photo {
    margin: 8vw 0 0 8%
}

#sec4 .set3 {
    position: relative;
    z-index: 1;
    padding: 15vw 0
}

#sec4 .set3::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    width: 8%;
    background: #a98f47;
    z-index: -2
}

#sec4 .set3 .deco-txt {
    position: absolute;
    top: 10vw;
    right: 0;
    z-index: -1;
    width: 12%
}

#sec4 .set3 .group-txt {
    margin-right: 8%
}

#sec4 .set3 .group-txt h3 {
    text-align: center;
    font-weight: 500;
    line-height: 2.1333333333;
    letter-spacing: .2em
}

#sec4 .set3 .group-txt .txt {
    margin-top: 5vw
}

#sec4 .set3 .group-photo {
    margin: 10vw 8% 0 0
}

#sec4 .set3 .group-photo li+li {
    margin-top: 5vw
}

#sec4 .set3 .box {
    border: 5px solid #8a6600;
    margin: 10vw 8% 0 0
}

#sec4 .set3 .box .inner {
    border: 1px solid #000;
    padding: 10vw 5% 9vw
}

#sec4 .set3 .box h4 {
    margin-left: 4%;
    font-weight: 500;
    line-height: 1;
    letter-spacing: .15em
}

#sec4 .set3 .box .menu {
    margin-top: 8vw
}

#sec4 .set3 .box .menu li {
    text-align: center;
    line-height: 1;
    letter-spacing: .15em
}

#sec4 .set3 .box .menu li:nth-child(2) {
    position: relative;
    margin-top: 5vw;
    padding-top: 5vw
}

#sec4 .set3 .box .menu li:nth-child(2)::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    background: rgba(0, 0, 0, .5);
    width: 20%;
    height: 1px
}

#sec4 .set3 .box .note {
    margin-top: 8vw
}

@media screen and (max-width: 767px) {
    #sec4 .set1 h2 {
        font-size: 6vw
    }

    #sec4 .set2 .group-txt h3 {
        font-size: 5vw
    }
}

@media screen and (min-width: 767px) {
    #sec4 .set1 .bg {
        height: auto
    }

    #sec4 .set2 {
        padding: 110px 0 104px
    }

    #sec4 .set2::before {
        width: 50px
    }

    #sec4 .set2 .wrap {
        display: flex;
        justify-content: space-between;
        gap: 30px;
        max-width: 1330px;
        padding: 0 70px
    }

    #sec4 .set2 .bg {
        top: 0;
        bottom: auto;
        width: auto
    }

    #sec4 .set2 .group-txt {
        width: 575px;
        margin: 107px 0 0
    }

    #sec4 .set2 .group-txt h3 {
        text-align: left
    }

    #sec4 .set2 .group-txt .txt {
        margin-top: 80px
    }

    #sec4 .set2 .photo {
        flex: 1;
        max-width: 513px;
        height: 502px;
        margin: 0
    }

    #sec4 .set3 {
        padding: 0 0 109px
    }

    #sec4 .set3::before {
        top: 186px;
        width: 100px
    }

    #sec4 .set3 .wrap {
        max-width: 1350px
    }

    #sec4 .set3 .deco-txt {
        top: 290px;
        width: auto
    }

    #sec4 .set3 .group-txt {
        width: 426px;
        padding: 273px 0 313px;
        margin: 0px 175px 0 auto
    }

    #sec4 .set3 .group-txt h3 {
        text-align: left
    }

    #sec4 .set3 .group-txt .txt {
        margin-top: 166px
    }

    #sec4 .set3 .group-photo {
        position: absolute;
        top: 0;
        right: calc(50% + 29px);
        left: calc(-50vw + 50%);
        margin: 0
    }

    #sec4 .set3 .group-photo li {
        height: 502px
    }

    #sec4 .set3 .group-photo li+li {
        margin-top: 50px
    }

    #sec4 .set3 .box {
        max-width: 910px;
        margin: 103px auto 0
    }

    #sec4 .set3 .box .inner {
        padding: 39px 0 27px
    }

    #sec4 .set3 .box h4 {
        margin-left: 0
    }

    #sec4 .set3 .box .menu {
        position: relative;
        display: flex;
        justify-content: space-between;
        max-width: 569px;
        margin: 38px auto 0
    }

    #sec4 .set3 .box .menu::before {
        content: "";
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        background: rgba(0, 0, 0, .5);
        width: 1px;
        height: 30px
    }

    #sec4 .set3 .box .menu li {
        text-align: left
    }

    #sec4 .set3 .box .menu li:nth-child(2) {
        margin-top: 0;
        padding: 0 50px 0 0
    }

    #sec4 .set3 .box .menu li:nth-child(2)::before {
        display: none
    }

    #sec4 .set3 .box .note {
        text-align: center;
        margin-top: 38px;
        line-height: 28px
    }
}

@media screen and (min-width: 768px)and (max-width: 1250px) {
    #sec4 .set3 .group-photo {
        right: 646px
    }
}

#sec5 {
    padding-bottom: 15vw
}

#sec5 .set1 .photo {
    position: relative;
    margin: 0 -8%
}

#sec5 .set1 .photo dt {
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 1;
    width: 30%
}

#sec5 .set1 .group-txt {
    margin-top: 7vw
}

#sec5 .set1 .group-txt h2 {
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: .28em
}

#sec5 .set1 .group-txt .txt {
    margin-top: 5vw
}

#sec5 .set2 {
    margin-top: 10vw
}

@media screen and (min-width: 768px) {
    #sec5 {
        padding-bottom: 129px
    }

    #sec5 .wrap {
        max-width: 1300px
    }

    #sec5 .set1 {
        display: flex
    }

    #sec5 .set1 .photo {
        order: 2;
        flex: 1;
        margin: 0 calc(-50vw + 50%) 0 0
    }

    #sec5 .set1 .photo dt {
        width: auto
    }

    #sec5 .set1 .photo dd {
        height: 560px
    }

    #sec5 .set1 .group-txt {
        order: 1;
        margin: 170px 55px 0 54px
    }

    #sec5 .set1 .group-txt .txt {
        margin-top: 53px
    }

    #sec5 .set2 {
        max-width: 1100px;
        margin: 89px auto 0
    }

    #sec5 .set2 .box-shared {
        padding: 39px 0 24px
    }

    #sec5 .set2 .box-shared .list {
        margin-top: 39px
    }
}

#sec6 .set1 {
    height: 70vw
}

#sec6 .set2 {
    position: relative;
    z-index: 1;
    padding: 15vw 0
}

#sec6 .set2::before {
    content: "";
    position: absolute;
    top: 244px;
    left: 0;
    background: #a98f47;
    width: 8%;
    height: 120vw;
    z-index: -2;
}

#sec6 .set2 .bg {
    position: absolute;
    top: 0vw;
    left: 68%;
    transform: translateX(-50%);
    z-index: -1;
    width: 65%
}

#sec6 .set2 .row1 h2 {
    font-weight: 500;
    line-height: 1;
    letter-spacing: .28em
}

#sec6 .set2 .row1 .note {
    margin-top: 5vw
}

#sec6 .set2 .row1 .photo {
    margin-top: 10vw
}

#sec6 .set2 .row2 {
    margin-top: 24vw
}

#sec6 .set2 .row2 .txt {
    margin-top: 7vw
}

@media screen and (min-width: 768px) {
    #sec6 .set1 {
        height: 455px
    }

    #sec6 .set2 {
        padding: 171px 0 96px
    }

    #sec6 .set2::before {
        width: 114px;
        height: 84%
    }

    #sec6 .set2 .bg {
        left: 0;
        transform: unset;
        width: auto
    }

    #sec6 .set2 .wrap {
        max-width: 1360px;
        padding: 0 30px
    }

    #sec6 .set2 .row1 {
        max-width: 804px;
        margin-left: auto
    }

    #sec6 .set2 .row1 .note {
        margin-top: 17px
    }

    #sec6 .set2 .row1 .photo {
        margin-top: 141px
    }

    #sec6 .set2 .row2 {
        display: flex;
        justify-content: space-between;
        max-width: 1100px;
        margin: 97px 0 0 auto
    }

    #sec6 .set2 .row2 .txt {
        width: 492px;
        margin: 92px 67px 0 29px
    }
}

#sec7 {
    position: relative;
    z-index: 1;
    padding: 15vw 0
}

#sec7 .deco-txt {
    position: absolute;
    top: 0;
    left: 0;
    width: 15%;
    z-index: -1
}

#sec7 h2 {
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: .2em
}

#sec7 .sec7-slider {
    position: relative;
    margin-top: 10vw
}

#sec7 .sec7-main .item .group-txt {
    margin-top: 35vw
}

#sec7 .sec7-main .item .group-txt h3 {
    border-bottom: 1px solid #000;
    font-weight: 500;
    line-height: 1.3;
    letter-spacing: .2em
}

#sec7 .sec7-main .item .group-txt .txt {
    margin-top: 5vw
}

#sec7 .sec7-thumb {
    position: absolute;
    top: 80vw;
    left: 0;
    right: 0
}

#sec7 .sec7-thumb .slick-track {
    display: flex !important;
    justify-content: center;
    width: 100% !important;
    transform: none !important
}

#sec7 .sec7-thumb .slick-slide {
    position: relative;
    width: 31vw;
    margin: 0 1vw
}

#sec7 .sec7-thumb .slick-slide::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    background: rgba(0, 0, 0, .6);
    transition: .3s
}

#sec7 .sec7-thumb .slick-current::before {
    opacity: 0
}

#sec7 .floor-map {
    margin-top: 10vw
}

@media screen and (min-width: 768px) {
    #sec7 {
        padding: 104px 0
    }

    #sec7 .deco-txt {
        position: absolute;
        top: 0;
        left: 0;
        width: 30%;
        z-index: -1
    }

    #sec7 .wrap {
        max-width: 1160px;
        padding: 0 30px
    }

    #sec7 .sec7-slider {
        margin-top: 95px
    }

    #sec7 .sec7-main {
        height: 600px
    }

    #sec7 .sec7-main .slick-list {
        overflow: visible
    }

    #sec7 .sec7-main .item .photo {
        position: absolute;
        top: 0;
        left: 550px;
        right: calc(-50vw + 50% + 50px);
        height: 600px
    }

    #sec7 .sec7-main .item .group-txt {
        width: 480px;
        padding-top: 86px;
        margin-top: 0
    }

    #sec7 .sec7-main .item .group-txt .txt {
        margin-top: 84px
    }

    #sec7 .sec7-thumb {
        position: absolute;
        top: 468px;
        left: 0;
        right: auto
    }

    #sec7 .sec7-thumb .slick-slide {
        cursor: pointer;
        width: 156px;
        margin: 0;
        transition: .3s
    }

    #sec7 .sec7-thumb .slick-slide+.slick-slide {
        margin-left: 9px
    }

    #sec7 .sec7-thumb .slick-slide:hover {
        opacity: .8
    }

    #sec7 .floor-map {
        text-align: center;
        margin-top: 113px
    }
}

#sec8 {
    background: #8a6600;
    color: #fff;
    padding: 15vw 0
}

#sec8 h2 {
    margin: 0 -3%;
    line-height: 1.5;
    font-weight: 500;
    letter-spacing: .2em
}

#sec8 .list {
    margin-top: 5vw
}

#sec8 .list li {
    display: flex
}

#sec8 .contact {
    border-top: 1px solid rgba(255, 255, 255, .5);
    border-bottom: 1px solid rgba(255, 255, 255, .5);
    margin-top: 8vw;
    padding: 8vw 0
}

#sec8 h3 {
    font-weight: 500;
    letter-spacing: .2em
}

#sec8 .btn-tel {
    margin-top: 5vw
}

#sec8 .btn-tel dl {
    text-align: center;
    line-height: 1
}

#sec8 .btn-tel dl dt {
    font-size: 32px;
    letter-spacing: .01em
}

#sec8 .btn-tel dl dt img {
    width: 13px;
    margin: -5px 5px 0 0
}

#sec8 .btn-tel dl dd {
    margin-top: 4px;
    font-size: 10px;
    font-weight: 500;
    letter-spacing: .2em
}

#sec8 .btn-shared {
    margin: 4vw 7% 0
}

@media screen and (min-width: 768px) {
    #sec8 {
        padding: 46px 0 89px
    }

    #sec8 h2 {
        margin: 0
    }

    #sec8 .list {
        max-width: 768px;
        margin: 46px auto 0
    }

    #sec8 .contact {
        max-width: 768px;
        margin: 47px auto 0;
        padding: 44px 0
    }

    #sec8 .btn-tel {
        margin-top: 29px
    }

    #sec8 .btn-tel dl dt {
        font-size: 38px
    }

    #sec8 .btn-tel dl dt img {
        width: 18px
    }

    #sec8 .btn-tel dl dd {
        margin-top: 10px;
        font-size: 12px
    }

    #sec8 .btn-shared {
        width: 300px;
        margin: 18px auto 0
    }

    #sec8 .btn-shared a {
        line-height: 54px
    }

    #sec8 .btn-shared a::before {
        width: 20px
    }
}

#menu-toggle .group-link li.btn-shared.sp a {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 9px
}

#menu-toggle .group-link li.btn-shared.sp a::before {
    position: static;
    top: auto;
    right: auto;
    transform: none;
    width: 17px;
    height: 17px;
    background: url("../img/shared/icon_language.png") no-repeat;
    background-size: 100%
}

#ft-bnr-fixed ul li {
    width: 25.0666666667%
}

#ft-bnr-fixed ul li:nth-child(2) {
    width: 50.1333333333%
}

.posirela {
    position: relative;
}

.takeout_deco {
    position: absolute;
    top: -50px;
    left: 0;
}

@media screen and (min-width: 768px) {
    .takeout_deco {
        position: absolute;
        top: -69px;
        left: 0;
    }

    .txt_left {
        text-align: left;
    }
}

@media screen and (max-width: 768px) {
    .txt_center {
        text-align: center;
        font-size: 16px;
    }

    .txt_left {
        text-align: left;
    }
}


.res_ttl {
    text-align: center;
    font-size: 18px;
    margin: 40px 0 0 0;
}

@media screen and (min-width: 768px) {
    .res_ttl {
        text-align: center;
        font-size: 20px;
        margin: 40px 0 0 0;
    }
}
