#sec1 {
    position: relative;
    padding-top: 47vw
}

#sec1::before {
    content: "";
    position: absolute;
    background: rgba(255, 255, 255, .33);
    box-shadow: 3px 3px 30px rgba(0, 0, 0, .1);
    top: 47vw;
    bottom: -23.5vw;
    left: 0;
    width: 45%;
    z-index: -1
}

#sec1 .wrap {
    padding: 0
}

#sec1 .set1 .box-parallax {
    z-index: 1;
    height: 156vw
}

#sec1 .set1 .box-parallax h2 {
    position: absolute;
    top: -31vw;
    right: 4%;
    z-index: 1
}

#sec1 .set1 .box-parallax h2 * {
    letter-spacing: .12em
}

#sec1 .set1 .box-parallax h2 span {
    display: block;
    color: #fff;
    font-size: 6.6vw;
    line-height: 1.7
}

#sec1 .set1 .box-parallax h2 span i {
    color: #2c2920
}

#sec1 .set1 .box-parallax h2 span:nth-child(1) i {
    font-size: 10.56vw
}

#sec1 .set1 .box-parallax h2 span:nth-child(1) i small {
    font-size: 6.6vw
}

#sec1 .set1 .box-parallax h2 span:nth-child(2) {
    margin-top: 16vw
}

#sec1 .set2 {
    position: relative
}

#sec1 .set2 h3 {
    position: absolute;
    top: 0;
    left: 8%;
    padding-top: 31vw;
    color: #2c2920;
    font-size: 6.6vw;
    line-height: 1;
    letter-spacing: .12em
}

#sec1 .set2 h3::before {
    content: "";
    position: absolute;
    background: #aea793;
    width: 1px;
    height: 26vw;
    top: 0;
    left: 50%;
    transform: translateX(-50%)
}

#sec1 .set2 .txt li:nth-child(1) {
    padding: 24.5vw 7.5% 0 29.5%
}

#sec1 .set2 .txt li:nth-child(2) {
    margin: 9vw 8% 0
}

#sec1 .set3 .txt {
    margin: 10vw 7% 0
}

#sec1 .set3 .photo {
    margin: 22vw 45% 0 14.5%
}

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

    #sec1::before {
        top: 662px;
        bottom: 182px;
        width: calc(50% - 83px)
    }

    #sec1 .wrap {
        padding: 0
    }

    #sec1 .set1 {
        margin-left: -50px
    }

    #sec1 .set1 .box-parallax {
        height: 640px
    }

    #sec1 .set1 .box-parallax .img-parallax {
        right: calc(-50vw + 50% - 30px)
    }

    #sec1 .set1 .box-parallax h2 {
        top: 180px;
        left: 117px;
        right: auto
    }

    #sec1 .set1 .box-parallax h2 span {
        font-size: 30px;
        line-height: 60px
    }

    #sec1 .set1 .box-parallax h2 span i {
        color: #fff
    }

    #sec1 .set1 .box-parallax h2 span:nth-child(1) i {
        font-size: 48px
    }

    #sec1 .set1 .box-parallax h2 span:nth-child(1) i small {
        font-size: 30px
    }

    #sec1 .set1 .box-parallax h2 span:nth-child(2) {
        margin: 0 0 0 157px
    }

    #sec1 .set2 {
        display: flex
    }

    #sec1 .set2 h3 {
        position: relative;
        inset: 0;
        margin: 0 128px 0 134px;
        padding-top: 192px;
        font-size: 30px
    }

    #sec1 .set2 h3::before {
        height: 168px
    }

    #sec1 .set2 .txt {
        margin-top: 143px
    }

    #sec1 .set2 .txt li:nth-child(1) {
        padding: 0
    }

    #sec1 .set2 .txt li:nth-child(2) {
        margin: 0
    }

    #sec1 .set3 {
        display: flex;
        justify-content: flex-end
    }

    #sec1 .set3 .txt {
        order: 2;
        margin: 81px 31px 0 0
    }

    #sec1 .set3 .photo {
        order: 1;
        margin: 170px 122px 0 0
    }
}

#sec2 .wrap {
    padding: 0 0 87.5vw
}

#sec2 h2 {
    position: relative;
    margin: -18vw 8% 0 auto;
    padding: 16.5vw 6% 0 0;
    color: #2c2920;
    line-height: 1.8666666667;
    letter-spacing: .12em;
    width: 5.6em;
}

#sec2 h2::before {
    content: "";
    position: absolute;
    background: #aea793;
    top: 0;
    right: 0;
    height: 41.5vw;
    width: 1px
}

#sec2 h2 span {
    margin-top: 22vw
}

#sec2 .photo {
    position: absolute;
    z-index: -1;
    transform: translateY(-10%);
    transition: transform 0.6s linear
}

#sec2 .photo .inner {
    position: absolute;
    inset: 0;
    transform: scale(0.6, 0.6);
    transform-origin: bottom center;
    -webkit-mask-position: -100% 0%;
    mask-position: -100% 0%;
    -webkit-mask-size: 200% 200%;
    mask-size: 200% 200%;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-image: linear-gradient(to right, black 0%, black 50%, transparent 50%, transparent 100%);
    mask-image: linear-gradient(to right, black 0%, black 50%, transparent 50%, transparent 100%);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    transition: transform 0.6s linear, -webkit-mask-position 0.6s linear;
    transition: transform 0.6s linear, mask-position 0.6s linear;
    transition: transform 0.6s linear, mask-position 0.6s linear, -webkit-mask-position 0.6s linear
}

#sec2 .photo .inner img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover
}

#sec2 .photo1 {
    top: 64vw;
    left: 4.5%;
    right: 31%;
    height: 43vw
}

#sec2 .photo2 {
    top: 121.5vw;
    left: 45.5%;
    right: 0;
    height: 34vw
}

#sec2 .photo3 {
    top: 134vw;
    left: 0;
    right: 59.5%;
    height: 32.5vw
}

#sec2 .txt {
    margin: 126.5vw 8% 0 22.5%
}

#sec2 .photo4 {
    bottom: 33.5vw;
    left: 10.5%;
    right: 59%;
    height: 43.5vw
}

#sec2 .photo5 {
    bottom: 21vw;
    left: 48%;
    right: 22%;
    height: 43.5vw
}

@media screen and (min-width: 768px) {
    #sec2 .wrap {
        padding: 0 0 1180px
    }

    #sec2 h2 {
        margin: -119px 96px 0 auto;
        padding: 76px 27px 0 0;
    }

    #sec2 h2::before {
        top: 0;
        height: 189px
    }

    #sec2 h2 span {
        margin-top: 101px
    }

    #sec2 .photo {
        transition: transform 1.2s linear
    }

    #sec2 .photo1 {
        top: 311px;
        left: -100px;
        right: calc(50% - 21px);
        height: 416px
    }

    #sec2 .photo2 {
        top: 700px;
        right: -250px;
        left: auto;
        width: 526px;
        height: 329px
    }

    #sec2 .photo3 {
        top: auto;
        bottom: 362px;
        left: auto;
        right: 51px;
        width: 311px;
        height: 311px
    }

    #sec2 .txt {
        height: 215px;
        margin: 124px 83px 0 auto
    }

    #sec2 .photo4 {
        bottom: 505px;
        left: -250px;
        right: auto;
        width: 426px;
        height: 296px
    }

    #sec2 .photo5 {
        bottom: 161px;
        left: 111px;
        right: auto;
        width: 291px;
        height: 418px
    }
}

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

    #sec2 .photo4 {
        left: calc(-50vw + 50%)
    }
}

@media screen and (min-width: 768px)and (max-width: 1200px) {
    #sec2 .photo1 {
        left: calc(-50vw + 50%)
    }
}

#sec3 .wrap {
    padding: 0 0 25vw
}

#sec3 .wrap::before {
    content: "";
    position: absolute;
    background: rgba(255, 255, 255, .33);
    box-shadow: 3px 3px 30px rgba(0, 0, 0, .1);
    top: 0;
    bottom: 0;
    left: 0;
    right: 8%;
    z-index: -2
}

#sec3 .photo-deco {
    position: absolute;
    top: 4vw;
    left: 56%;
    right: -7%;
    z-index: 1
}

#sec3 .group-txt {
    padding: 27.5vw 23% 0 11.5%
}

#sec3 .group-txt .ttl-shared {
    display: flex;
    align-items: center;
    -moz-column-gap: 9vw;
    column-gap: 9vw
}

#sec3 .group-txt .txt {
    margin-top: 22.5vw
}

#sec3 .group-photo {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    row-gap: 2vw;
    margin-top: 18vw
}

#sec3 .group-photo li {
    width: 49vw
}

#sec3 .group-photo li:nth-child(2) {
    margin-top: 12vw
}

#sec3 .group-photo li:nth-child(3) {
    margin-top: -12vw
}

@media screen and (min-width: 768px) {
    #sec3 .wrap {
        display: flex;
        align-items: flex-end;
        max-width: 1340px;
        padding: 0 0 150px
    }

    #sec3 .wrap::before {
        right: calc(-50vw + 50%);
        left: 145px
    }

    #sec3 .photo-deco {
        top: -108px;
        left: auto;
        right: -12px
    }

    #sec3 .group-txt {
        order: 2;
        padding: 279px 85px 19px
    }

    #sec3 .group-txt .ttl-shared {
        -moz-column-gap: 40px;
        column-gap: 40px
    }

    #sec3 .group-txt .txt {
        width: 265px;
        margin-top: 102px
    }

    #sec3 .group-photo {
        order: 1;
        flex: 1;
        max-width: 860px;
        row-gap: 20px;
        margin-top: 150px
    }

    #sec3 .group-photo li {
        width: calc(50% - 10px)
    }

    #sec3 .group-photo li:nth-child(2) {
        margin-top: 0
    }

    #sec3 .group-photo li:nth-child(3) {
        margin-top: 0
    }
}

@media screen and (min-width: 768px)and (max-width: 1200px) {
    #sec3 .group-txt {
        padding-left: 50px;
        padding-right: 50px
    }
}

#sec4 {
    background: url("../img/index/sec4_deco_sp.png") no-repeat left top/67%;
    padding: 82.5vw 0 24.5vw
}

#sec4 .ttl-shared span {
    text-align: center
}

#sec4 .ttl-shared span.en {
    margin-top: 7vw
}

#sec4 .wrap {
    padding: 0
}

#sec4 .set1 .ttl {
    position: relative;
    margin: 0 8%
}

#sec4 .set1 .ttl::before,
#sec4 .set1 .ttl:after {
    content: "";
    position: absolute;
    background: #aea793;
    height: 1px;
    width: 26.5vw;
    top: 50%;
    transform: translateY(-50%)
}

#sec4 .set1 .ttl::before {
    left: 0
}

#sec4 .set1 .ttl:after {
    right: 0
}

#sec4 .set1 .ttl h2 {
    text-align: center;
    margin: 0 auto;
    color: #2c2920;
    line-height: 1.8666666667;
    letter-spacing: .12em;
   display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
        height: 7.5em;
}

#sec4 .set1 .txt {
    text-align: center;
    margin-top: 14.5vw
}

#sec4 .set1 .txt li:nth-child(2) {
    margin-top: 14.5vw
}

#sec4 .set1 .txt li:nth-child(3) {
    margin-top: 10.5vw
}

#sec4 .set2 {
    padding-top: 39vw
}

#sec4 .set2 .group-txt .name-price {
    text-align: center;
    line-height: 1.5
}

#sec4 .set2 .group-txt .name-price * {
    color: #2c2920;
    letter-spacing: .12em
}

#sec4 .set2 .group-txt .name-price dd {
    margin-top: 7vw
}

#sec4 .set2 .group-txt .menu {
        margin: 13.5vw auto 0;
  display: flex;
  flex-wrap: wrap;
}

#sec4 .set2 .group-txt .menu ul {
    border-top: 1px solid #d9d2c5;
    display: flex;
    flex-direction: column;
    justify-content: center;
    row-gap: 1.5vw;
    margin: 0 auto;
    min-height: 91px;
    padding: 5vw 5vw 6vw
}

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

#sec4 .set3 {
    padding: 32.5vw 4% 0
}

#sec4 .set3 .group-photo {
    display: flex;
    justify-content: space-between;
    margin-top: 15vw;
    -moz-column-gap: 4.5vw;
    column-gap: 4.5vw
}

#sec4 .set4 {
    padding: 32vw 8.5% 0
}

#sec4 .set4 .ttl-shared span.jp {
    margin: 0 auto;
    display: flex;
    align-items: center;
    width: 100%;
        height: 2.5em;
}

#sec4 .set4 .ttl-shared span.en {
    margin-top: 3.5vw
}

#sec4 .set4 .box {
    margin-top: 13.5vw
}

#sec4 .set4 .box .note {
    text-align: center;
    margin-top: 2.5vw
}

#sec4 .set5 .group-photo li:nth-child(1) {
    margin: 28vw 29% 0 -1%
}

#sec4 .set5 .group-photo li:nth-child(2) {
    margin: 4vw -38.5% 0 2.5%
}

@media screen and (min-width: 768px) {
    #sec4 {
        background-size: auto;
        padding: 492px 0 152px
    }

    #sec4 .ttl-shared span {
        text-align: center
    }

    #sec4 .ttl-shared span.en {
        margin-top: 32px
    }

    #sec4 .wrap {
        max-width: 1340px
    }

    #sec4 .set1 .ttl {
        width: 580px;
        margin: 0 auto
    }

    #sec4 .set1 .ttl::before,
    #sec4 .set1 .ttl:after {
        width: 190px
    }

    #sec4 .set1 .txt {
        margin-top: 78px
    }

    #sec4 .set1 .txt li:nth-child(2) {
        margin-top: 66px
    }

    #sec4 .set1 .txt li:nth-child(3) {
        margin-top: 24px
    }

    #sec4 .set2 {
        display: flex;
        justify-content: space-between;
        padding-top: 164px;
        max-width: 1312px;
        margin: 0 auto
    }

    #sec4 .set2 .group-txt {
        width: 268px;
        margin: 0 105px
    }

    #sec4 .set2 .group-txt .name-price dt {
        margin: 0 auto;
                display: flex;
        justify-content: center;
        align-items: center;
        width: 100%;
    }

    #sec4 .set2 .group-txt .name-price dd {
        margin-top: 28px
    }

    #sec4 .set2 .group-txt .menu {
        margin-top: 64px;
    }

    #sec4 .set2 .group-txt .menu ul {
        row-gap: 4px;
        width: 100%;
        min-height: auto;
        padding: 25px 0 34px
    }

    #sec4 .set2 .photo {
        flex: 1;
        max-width: 788px;
        height: 510px;
        margin: 23px 0 0
    }

    #sec4 .set3 {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 185px 0 0
    }

    #sec4 .set3 .ttl-shared {
        order: 2;
        margin: 0 86px
    }

    #sec4 .set3 .group-photo {
        max-width: 1008px;
        order: 1;
        margin: 0;
        -moz-column-gap: 39px;
        column-gap: 39px
    }

    #sec4 .set4 {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 200px 0 0 0
    }

    #sec4 .set4 .ttl-shared {
        margin: 0 165px
    }

    #sec4 .set4 .ttl-shared span.en {
        margin-top: 18px
    }

    #sec4 .set4 .box {
        max-width: 920px;
        flex: 1;
        position: relative;
        margin: 0 -11px 0 0
    }

    #sec4 .set4 .box .photo {
        height: 688px
    }

    #sec4 .set4 .box .note {
        position: absolute;
        bottom: 6px;
        left: 21px;
        z-index: 1;
        text-align: left;
        margin-top: 0
    }
   

    #sec4 .set5 .group-photo li:nth-child(1) {
        margin: 150px 0 0 0
    }

    #sec4 .set5 .group-photo li:nth-child(2) {
        margin: -140px 0 0 402px
    }
}

@media screen and (min-width: 768px)and (max-width: 1500px) {
    #sec4 .set5 .group-photo li img {
        width: 100%
    }

    #sec4 .set5 .group-photo li:nth-child(1) {
        width: 42.4666666667vw;
        margin: 10vw 0 0 0
    }

    #sec4 .set5 .group-photo li:nth-child(2) {
        width: 67.8666666667vw;
        margin: -9.3333333333vw 0 0 26.8vw
    }
}

#sec5 {
    padding-bottom: 40vw
}

#sec5 .set1 .ttl-shared {
    width: -moz-fit-content;
    width: fit-content;
    padding: 17vw 0 100vw 3%
}

#sec5 .set1 .ttl-shared span.jp {
    word-break: keep-all;
    color: #fff;
    margin: 0 auto;
    line-height: 1.6;
     display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
        height: 4.5em;
}

#sec5 .set1 .ttl-shared span.en {
    margin-top: 7.5vw
}

#sec5 .set2 .wrap {
    padding: 0
}

#sec5 .set2 .photo1 {
    margin: 13.5vw 16% 0 0
}

#sec5 .set2 .txt {
    margin: 11vw 8% 0
}

#sec5 .set2 .group-photo li:nth-child(1) {
    margin: 11vw 4% 0 33.5%
}

#sec5 .set2 .group-photo li:nth-child(2) {
    margin: 3.5vw 34% 0 4%
}

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

    #sec5 .set1 {
        margin: 0 50px
    }

    #sec5 .set1 .ttl-shared {
        padding: 133px 0 349px 192px
    }

    #sec5 .set1 .ttl-shared span.en {
        margin-top: 33px
    }

    #sec5 .set2 {
        position: relative;
        max-width: 1500px;
        margin: 0 auto
    }

    #sec5 .set2 .wrap {
        position: unset;
        max-width: 1200px;
        padding: 0
    }

    #sec5 .set2 .photo1 {
        margin: 0;
        top: 100px;
        left: 0;
        right: calc(50% + 120px);
        height: 333px
    }

    #sec5 .set2 .txt {
        width: 544px;
        padding-top: 168px;
        margin: 0 55px 0 auto
    }

    #sec5 .set2 .group-photo {
        display: flex;
        justify-content: flex-end;
        margin: 96px -50px 0 0
    }

    #sec5 .set2 .group-photo li:nth-child(1) {
        order: 2;
        margin: 0
    }

    #sec5 .set2 .group-photo li:nth-child(2) {
        order: 1;
        margin: 150px 20px 0 0
    }
}

@media screen and (min-width: 768px)and (max-width: 1300px) {
    #sec5 .set2 .group-photo {
        margin-right: calc(-50vw + 50%)
    }
}

@media screen and (min-width: 768px)and (max-width: 1080px) {
    #sec5 .set2 .photo1 {
        right: 652px
    }
}

#sec6 {
    background: url("../img/shared/bg1.jpg") repeat center;
    padding: 21vw 0
}

#sec6 h2 {
    position: relative;
    color: #2c2920;
    text-align: center;
    letter-spacing: .12em
}

#sec6 h2::before {
    content: "";
    position: absolute;
    background: #aea793;
    top: 50%;
    width: 33%;
    height: 1px;
    left: -6%;
    transform: translateY(-50%)
}

#sec6 .txt {
    margin: 10.5vw 5% 0
}

#sec6 .group-photo {
    display: flex;
    align-items: flex-end;
    -moz-column-gap: 4.5vw;
    column-gap: 4.5vw;
    margin-top: 7vw
}

@media screen and (min-width: 768px) {
    #sec6 {
        padding: 136px 0 100px
    }

    #sec6 .wrap {
        max-width: 1156px
    }

    #sec6 h2 {
        text-align: left;
        padding-left: 80px
    }

    #sec6 h2::before {
        width: auto;
        right: calc(100% - 43px);
        left: calc(-50vw + 50%)
    }

    #sec6 .txt {
        position: relative;
        z-index: 1;
        margin: 68px 0 0 80px
    }

    #sec6 .group-photo {
        justify-content: flex-end;
        -moz-column-gap: 40px;
        column-gap: 40px;
        margin-top: -145px
    }
}

#sec7 {
    box-shadow: 3px 3px 30px rgba(0, 0, 0, .1);
    padding: 19.5vw 0 17vw
}

#sec7 .photo2 {
    position: absolute;
    top: 18.5vw;
    left: 9.5%;
    right: -15.5%
}

#sec7 .group-txt .name-price {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    margin: 15.5vw 4% 0 12%;
    line-height: 1
}

#sec7 .group-txt .name-price * {
    color: #2c2920;
    letter-spacing: .12em
}

#sec7 .group-txt .name-price dd {
    margin-bottom: 5vw
}

#sec7 .group-txt .time {
    text-align: center;
    margin-top: 4vw
}

#sec7 .group-txt .txt {
    text-align: center;
    border-top: 1px solid #aea793;
    margin: 10vw 4% 0;
    padding-top: 9.5vw
}

@media screen and (max-width: 767px) {
    #sec7 .group-txt .name-price dd {
        position: relative;
        display: flex;
        height: -moz-fit-content;
        height: fit-content;
        -moz-column-gap: 15vw;
        column-gap: 15vw
    }

    #sec7 .group-txt .name-price dd::before {
        content: "";
        position: absolute;
        background: #2c2920;
        width: 1px;
        height: 4.5vw;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%)
    }
}

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

    #sec7 .wrap {
        max-width: 1130px
    }

    #sec7 .photo1 {
        top: 0;
        left: 470px;
        right: calc(-50vw + 50%);
        height: 416px
    }

    #sec7 .photo2 {
        top: 318px;
        left: -135px;
        right: 0
    }

    #sec7 .group-txt .name-price {
        display: block;
        width: 241px;
        padding-top: 41px;
        margin: 0 0 0 137px
    }

    #sec7 .group-txt .name-price dd {
        text-align: right;
        margin: -27px 0 0 0
    }

    #sec7 .group-txt .name-price dd span {
        display: block
    }

    #sec7 .group-txt .name-price dd span:nth-child(2) {
        margin-top: 28px
    }

    #sec7 .group-txt .time {
        text-align: left;
        margin: 68px 0 0 71px
    }

    #sec7 .group-txt .txt {
        position: relative;
        z-index: 1;
        text-align: left;
        border-top: none;
        width: -moz-fit-content;
        width: fit-content;
        margin: 126px 94px 0 auto;
        padding-top: 0
    }
}

#sec8 {
    padding: 36vw 4% 33vw
}

#sec8 .wrap {
    background: rgba(255, 255, 255, .33);
    box-shadow: 3px 3px 30px rgba(0, 0, 0, .1);
    padding: 23.5vw 4.5% 19.5vw
}

#sec8 .wrap::before {
    content: "";
    position: absolute;
    background: #aea793;
    width: 1px;
    height: 37vw;
    top: -18.5vw;
    left: 50%;
    transform: translateX(-50%)
}

#sec8 .set1 h2 {
    text-align: center;
    line-height: 1.5;
    letter-spacing: .12em
}

#sec8 .set1 .list {
    margin-top: 10vw;
}

#sec8 .set1 .list li {
    display: flex
}

#sec8 .set2 {
    border-top: 1px solid #aea793;
    margin-top: 16.5vw;
    padding-top: 17.5vw
}

#sec8 .set2 .cancel {
    margin-left: 5%
}

#sec8 .set2 .cancel h3 {
    color: #2c2920;
    line-height: 1.5;
    letter-spacing: .12em
}

#sec8 .set2 .cancel .txt {
    margin: 5.5vw 3% 0 0
}

#sec8 .set2 .contact .btn-tel {
    margin: 16vw 0 0 5%
}

#sec8 .set2 .contact .btn-tel dl {
    color: #2c2920;
    line-height: 1
}

#sec8 .set2 .contact .btn-tel dl * {
    letter-spacing: .12em
}

#sec8 .set2 .contact .btn-tel dl dt {
    font-size: 15px
}

#sec8 .set2 .contact .btn-tel dl dd {
    margin-top: 16px;
    font-size: 24.75px;
    font-weight: 400;
    letter-spacing: .06em
}

#sec8 .set2 .contact .btn-tel dl dd img {
    margin: -5px 7px 0 4px;
    width: 13.5px
}

#sec8 .set2 .contact .btn-tel .note {
    margin: 12px 0 0 2px;
    font-size: 11px;
    line-height: 16.5px;
    letter-spacing: .1em
}

#sec8 .set2 .contact .box {
    margin: 9.5vw 6% 0
}

#sec8 .set2 .contact .box .sub-ttl {
    color: #2c2920;
    font-size: 15px;
    letter-spacing: .12em
}

#sec8 .set2 .contact .box .group-link {
    margin-top: 3vw
}

#sec8 .set2 .contact .box .group-link li:nth-child(2) {
    margin-top: 3.5vw
}

#sec8 .set2 .contact .box .group-link li:nth-child(2) a {
    font-size: 16.5px;
    letter-spacing: .06em
}

@media screen and (min-width: 768px) {
    #sec8 {
        padding: 244px 30px 216px
    }

    #sec8 .wrap {
        max-width: 1300px;
        padding: 132px 30px 175px
    }

    #sec8 .wrap::before {
        height: 168px;
        top: -57px
    }

    #sec8 .set1 .list {
        max-width: 835px;
        margin: 83px auto 0
    }

    #sec8 .set1 .list li {
        display: flex
    }

    #sec8 .set1 .list li span {
        margin-right: 3px
    }

    #sec8 .set2 {
        display: flex;
        justify-content: center;
        max-width: 1000px;
        margin: 90px auto 0;
        -moz-column-gap: 106px;
        column-gap: 106px;
        padding-top: 90px
    }

    #sec8 .set2 .cancel {
        margin: 0;
        width: 476px;
    }

    #sec8 .set2 .cancel h3 {
        line-height: 1.5
    }

    #sec8 .set2 .cancel .txt {
        margin: 26px 0 0 4px
    }

    #sec8 .set2 .contact {
        margin: 5px 0 0
    }

    #sec8 .set2 .contact .btn-tel {
        margin: 0
    }

    #sec8 .set2 .contact .btn-tel dl dt {
        font-size: 18px
    }

    #sec8 .set2 .contact .btn-tel dl dd {
        margin-top: 22px;
        font-size: 30px
    }

    #sec8 .set2 .contact .btn-tel dl dd img {
        margin: -5px 8px 0 4px;
        width: 17px
    }

    #sec8 .set2 .contact .btn-tel .note {
        margin: 13px 0 0;
        font-size: 13px;
        line-height: 20px
    }

    #sec8 .set2 .contact .box {
        margin: 43px 0 0
    }

    #sec8 .set2 .contact .box .sub-ttl {
        font-size: 18px
    }

    #sec8 .set2 .contact .box .group-link {
        margin-top: 14px
    }

    #sec8 .set2 .contact .box .group-link li:nth-child(2) {
        margin-top: 17px
    }

    #sec8 .set2 .contact .box .group-link li:nth-child(2) a {
        font-size: 23px;
        letter-spacing: .06em
    }
}

#sec9 .wrap {
    padding: 0 8%
}

#sec9 .set1 {
    margin-top: 32.5vw
}

#sec9 .set1 h2 {
    color: #2c2920;
    letter-spacing: .12em
}

#sec9 .set1 .contact {
    position: relative;
    margin-top: 16vw;
    padding: 14vw 9%
}

#sec9 .set1 .contact::before {
    content: "";
    position: absolute;
    background: url("../img/shared/bg1.jpg") repeat center;
    top: 0;
    bottom: 0;
    left: 0;
    right: calc(-50vw + 50%);
    z-index: -1
}

#sec9 .set1 .contact .btn-tel dl {
    color: #2c2920;
    line-height: 1
}

#sec9 .set1 .contact .btn-tel dl dt {
    letter-spacing: .12em
}

#sec9 .set1 .contact .btn-tel dl dd {
    margin-top: 14px;
    font-size: 20.5px;
    letter-spacing: .06em
}

#sec9 .set1 .contact .btn-tel dl dd img {
    width: 11.5px;
    margin: -5px 6px 0 3px
}

#sec9 .set1 .contact .btn-tel .note {
    margin-top: 6px;
    font-size: 11px;
    line-height: 16.5px;
    letter-spacing: .1em
}

#sec9 .set1 .contact .box {
    margin-top: 10vw
}

#sec9 .set1 .contact .box .sub-ttl {
    color: #2c2920;
    letter-spacing: .12em
}

#sec9 .set1 .contact .box .group-link {
    margin-top: 1.5vw
}

#sec9 .set1 .contact .box .group-link li a {
    line-height: 36px
}

#sec9 .set1 .contact .box .group-link li a::before {
    max-width: 20px;
    width: 20px
}

#sec9 .set1 .contact .box .group-link li:nth-child(2) {
    margin-top: 3vw
}

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

#sec9 .set2 .col dl {
    border-bottom: 1px solid #d9d2c5;
    padding: 11px 0;
    line-height: 22px;
    letter-spacing: .06em
}

#sec9 .set3 {
    padding: 17vw 0 25vw
}

#sec9 .set3 .map {
    filter: grayscale(100%);
    height: 100vw
}

#sec9 .set3 .group-link {
    margin: 12vw 8% 0
}

@media screen and (max-width: 767px) {
    #sec9 .set1 .contact .btn-tel dl dt{
            font-size: 15px;
    }
    #sec9 .set1 .contact .btn-tel dl dd{
        font-size: 24.75px;
    font-weight: 400;
    letter-spacing: .06em;
    }
}


@media screen and (min-width: 768px) {
    #sec9 .bg {
        height: 660px
    }

    #sec9 .wrap {
        padding: 0
    }

    #sec9 .set1 {
        display: flex;
        margin-top: 166px
    }

    #sec9 .set1 h2 {
        margin: 52px 117px 0 22px
    }

    #sec9 .set1 .contact {
        display: flex;
        justify-content: center;
        -moz-column-gap: 20px;
        column-gap: 95px;
        flex: 1;
        padding: 60px 36px 60px 20px;
        margin-top: 0
    }

    #sec9 .set1 .contact .btn-tel dl dd {
        margin-top: 17px;
        font-size: 25px
    }

    #sec9 .set1 .contact .btn-tel dl dd img {
        width: 14px;
        margin: -4px 7px 0 4px
    }

    #sec9 .set1 .contact .btn-tel .note {
        margin-top: 9px;
        font-size: 13px;
        line-height: 20px
    }

    #sec9 .set1 .contact .box {
        margin-top: -11px
    }

    #sec9 .set1 .contact .box .group-link {
        margin-top: 7px
    }

    #sec9 .set1 .contact .box .group-link li {
        width: 220px
    }

    #sec9 .set1 .contact .box .group-link li a {
        line-height: 44px
    }

    #sec9 .set1 .contact .box .group-link li a::before {
        max-width: 25px;
        width: 25px
    }

    #sec9 .set1 .contact .box .group-link li:nth-child(2) {
        margin-top: 15px
    }

    #sec9 .set2 {
        display: flex;
        justify-content: space-between;
        -moz-column-gap: 24px;
        column-gap: 24px;
        margin: 78px 24px 0
    }

    #sec9 .set2 .col {
        max-width: 450px;
        width: 100%
    }

    #sec9 .set2 .col dl {
        padding: 12px 0 14px;
        line-height: 27px;
        letter-spacing: .1em
    }

    #sec9 .set3 {
        padding: 102px 0 163px
    }

    #sec9 .set3 .map {
        height: 500px
    }

    #sec9 .set3 .group-link {
        display: flex;
        justify-content: center;
        -moz-column-gap: 52px;
        column-gap: 52px;
        margin: 47px 0 0 0
    }

    #sec9 .set3 .group-link .btn-shared {
        width: 320px
    }

    #sec9 .set3 .group-link .btn-print {
        margin-top: 8px
    }

    #sec9 .set3 .group-link .btn-print a {
        color: #2c2920;
        text-decoration: underline;
        letter-spacing: .12em
    }

    #sec9 .set3 .group-link .btn-print a:hover {
        text-decoration: none
    }
}