.fs28 {
    font-size: 5.33vw
}

.fs29 {
    font-size: 5.41vw
}

.fs30 {
    font-size: 4vw
}

.fs32 {
    font-size: 4.27vw
}

.fs36 {
    font-size: 7.06vw
}

.fs40 {
    font-size: 7.6vw
}

.fs44 {
    font-size: 8.21vw
}

.fs52 {
    font-size: 9.71vw
}

.fs69 {
    font-size: 12.88vw
}

.fs72 {
    font-size: 13vw
}

@media screen and (min-width: 768px) {
    .fs29 {
        font-size: 29px
    }

    .fs32 {
        font-size: 32px
    }

    .fs36 {
        font-size: 36px
    }

    .fs40 {
        font-size: 40px
    }

    .fs44 {
        font-size: 44px
    }

    .fs52 {
        font-size: 52px
    }

    .fs69 {
        font-size: 69px
    }

    .fs72 {
        font-size: 72px
    }
}

#sec1 {
    position: relative;
    z-index: 1;
    margin-top: 18.5vw;
    padding-bottom: 29.5vw
}

#sec1 .deco {
    position: absolute;
    bottom: -35vw;
    left: 0;
    width: 100%;
    z-index: -1
}

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

#sec1 .wrap {
    padding: 0
}

#sec1 h2 {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: flex-start;
    margin: 0 5% -20.5vw 9%
}

#sec1 h2 span {
    display: block
}

#sec1 h2 span:nth-child(1) {
    background: url("../img/shared/bg2.jpg") repeat center;
    color: #fff;
    word-break: keep-all;
    padding: 8.3vw 0 5vw;
    font-size: 8.21vw;
    line-height: 1.25;
    letter-spacing: .1em
}

#sec1 h2 span:nth-child(2) {
    flex: 1
}

#sec1 h2 span:nth-child(3) {
    margin: 48vw 0 0 -3.7%;
    font-size: 13.44vw;
    line-height: 1;
    letter-spacing: 0
}

#sec1 h3 {
    position: relative;
    z-index: 1;
    width: 70.8%;
    margin: -7.3vw 0 0 auto
}

#sec1 h3 span {
    position: relative;
    z-index: 1;
    display: block;
    padding: 2.5vw 0 0 4vw;
    font-size: 9.71vw;
    line-height: 1;
    letter-spacing: .1em
}

#sec1 h3 span::before {
    content: "";
    position: absolute;
    background: #fffaf0;
    inset: 0;
    z-index: -1
}

#sec1 h3 span small {
    font-size: 8.21vw;
    letter-spacing: .1em
}

#sec1 h3 span:nth-child(1) {
    margin: 0 7.5% 2.4vw 0
}

#sec1 h3 span:nth-child(2) {
    position: relative
}

#sec1 h3 span:nth-child(2)::after {
    content: "";
    position: absolute;
    background: #000;
    height: 1px;
    top: 8.4vw;
    left: 50%;
    right: 0
}

#sec1 .txt {
    margin: 9vw 5% 0
}

@media screen and (min-width: 768px) {
    #sec1 {
        margin-top: 0;
        padding: 80px 0 110px
    }

    #sec1 .deco {
        bottom: -132px;
        width: auto
    }

    #sec1 .bg {
        width: auto
    }

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

    #sec1 h2 {
        width: -moz-fit-content;
        width: fit-content;
        margin: 0 174px 0 auto
    }

    #sec1 h2 span {
        display: block
    }

    #sec1 h2 span:nth-child(1) {
        padding: 45px 0 26px;
        font-size: 44px;
        line-height: 55px
    }

    #sec1 h2 span:nth-child(2) {
        margin: 194px -22px 0 28px
    }

    #sec1 h2 span:nth-child(3) {
        margin: 419px 0 0 0;
        font-size: 72px
    }

    #sec1 .photo {
        top: 91px;
        left: calc(-50vw + 50%);
        right: 500px;
        height: 692px
    }

    #sec1 h3 {
        width: 561px;
        margin: 45px 0 0 auto
    }

    #sec1 h3 span {
        padding: 14px 0 2px 22px;
        font-size: 52px
    }

    #sec1 h3 span small {
        font-size: 44px
    }

    #sec1 h3 span:nth-child(1) {
        width: 351px;
        margin: 0
    }

    #sec1 h3 span:nth-child(2) {
        width: 332px;
        margin: 12px 0 0 auto
    }

    #sec1 h3 span:nth-child(2)::before {
        right: calc(-50vw + 50%)
    }

    #sec1 h3 span:nth-child(2)::after {
        top: 44px;
        left: 190px;
        right: calc(-50vw + 50%)
    }

    #sec1 .txt {
        text-align: center;
        margin: 168px 0 0
    }
}

#sec2 {
    position: relative;
    z-index: 2
}

#sec2 .wrap {
    padding: 0
}

#sec2 .photo {
    margin: 0 -1% 0 10.4%
}

#sec2 .bg {
    position: absolute;
    inset: 35vw 0 0;
    z-index: -1
}

#sec2 .bg::before {
    content: "";
    position: absolute;
    inset: 2.67vw 0;
    z-index: 1;
    border-top: 1px solid #ccc;
    border-bottom: 1px solid #ccc
}

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

#sec2 h2 {
    position: relative;
    z-index: 1;
    padding: 10vw 0 0 4%
}

#sec2 h2::before {
    content: "";
    position: absolute;
    top: -7vw;
    left: 0;
    z-index: -1;
    background: url("../img/shared/bg2.jpg") repeat center;
    width: 35.73vw;
    height: 37.6vw
}

#sec2 h2 * {
    letter-spacing: .1em
}

#sec2 h2 span {
    display: block;
    color: #fff;
    line-height: 1
}

#sec2 h2 span:nth-child(1) {
    display: flex;
    align-items: flex-end;
    gap: 1%
}

#sec2 h2 span:nth-child(1) i {
    display: block;
    background: #fffaf0;
    color: #000;
    padding: 2.6vw 3.7% .5vw 3.9%;
    letter-spacing: .02em
}

#sec2 h2 span:nth-child(2) {
    margin: 5vw 0 0 10.5%
}

#sec2 .txt {
    color: #fff;
    padding: 8vw 5% 24vw
}

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

    #sec2 .photo {
        margin: 0;
        top: 0;
        left: 341px;
        right: calc(-50vw + 50%);
        height: 570px
    }

    #sec2 .bg {
        inset: 132px 0 0 calc(-50vw + 50%)
    }

    #sec2 .bg::before {
        border-right: 1px solid #ccc;
        inset: 20px 20px 20px 0
    }

    #sec2 h2 {
        padding: 307px 0 0 99px
    }

    #sec2 h2::before {
        top: 234px;
        left: 7px;
        width: 248px;
        height: 282px
    }

    #sec2 h2 span:nth-child(1) {
        gap: 8px
    }

    #sec2 h2 span:nth-child(1) i {
        padding: 14px 19px 2px 20px
    }

    #sec2 h2 span:nth-child(2) {
        margin: 26px 0 0 116px
    }

    #sec2 .txt {
        width: -moz-fit-content;
        width: fit-content;
        margin: 0 auto;
        padding: 198px 0 119px 151px
    }
}

#sec3 {
    position: relative;
    background: url("../img/index/sec3_bg_sp.png") no-repeat center bottom/100%;
    padding: 21vw 0 15vw
}

#sec3 .deco {
    position: absolute;
    top: 0;
    right: 0;
    z-index: -1;
    width: 100%
}

#sec3 .wrap {
    padding: 0
}

#sec3 h2 {
    position: relative;
    font-size: 10.47vw;
    line-height: 1.25;
    letter-spacing: .1em
}

#sec3 h2 .fs1 {
    font-size: 7.89vw
}

#sec3 h2 .fs2 {
    font-size: 6.67vw
}

#sec3 h2 span {
    letter-spacing: .1em
}

#sec3 h2 .deco-ttl {
    position: absolute;
    top: 8vw;
    left: 5%;
    right: 3%;
    z-index: -1
}

#sec3 .txt {
    margin: 7vw 5% 0
}

#sec3 .group-link {
    margin: 8.5vw 4% 0
}

#sec3 .group-link li a {
    position: relative;
    display: block
}

#sec3 .group-link li a::before {
    content: "";
    position: absolute;
    inset: 1.33vw 1.33vw 8.5vw;
    z-index: 1;
    border: 1px solid rgba(204, 204, 204, .45)
}

#sec3 .group-link li a h3 {
    position: relative;
    z-index: 2;
    margin-top: -8.5vw;
    color: #fff;
    font-size: 10.27vw;
    line-height: 1;
    letter-spacing: .1em
}

#sec3 .group-link li a .arrow {
    position: relative;
    z-index: 2;
    width: 18.5%;
    margin: 3vw auto 0
}

#sec3 .group-link li+li {
    margin-top: 3vw
}

@media screen and (min-width: 768px) {
    #sec3 {
        background-image: url("../img/index/sec3_bg_pc.png");
        padding: 102px 0 117px
    }

    #sec3 .deco {
        top: -239px;
        width: auto
    }

    #sec3 .wrap {
        max-width: 1480px;
        padding: 0 30px
    }

    #sec3 h2 {
        font-size: 69px
    }

    #sec3 h2 .fs1 {
        font-size: 52px
    }

    #sec3 h2 .fs2 {
        font-size: 44px
    }

    #sec3 h2 .deco-ttl {
        top: 50px;
        left: calc(50% + 12px);
        right: 0;
        transform: translateX(-50%)
    }

    #sec3 .txt {
        text-align: center;
        margin: 58px 0 0
    }

    #sec3 .group-link {
        display: flex;
        justify-content: space-between;
        margin: 67px 0 0
    }

    #sec3 .group-link li {
        width: 48.5915492958%
    }

    #sec3 .group-link li a::before {
        inset: 10px 10px 65px
    }

    #sec3 .group-link li a h3 {
        margin-top: -62px;
        font-size: 77px
    }

    #sec3 .group-link li a .arrow {
        width: -moz-fit-content;
        width: fit-content;
        margin-top: 21px
    }

    #sec3 .group-link li+li {
        margin-top: 0
    }
}

@media screen and (min-width: 768px)and (max-width: 1500px) {
    #sec3 .group-link li a h3 {
        margin-top: -4.1333333333vw;
        font-size: 5.1333333333vw
    }
}

#sec4 {
    color: #fff
}

#sec4 .top {
    position: relative
}

#sec4 .top .sub-txt {
    position: absolute;
    top: 13vw;
    left: 0;
    right: 0;
    z-index: 1;
    background: url("../img/index/sec4_deco_ttl.png") no-repeat center bottom/100%;
    width: 70.13%;
    margin: 0 auto;
    padding-bottom: 6vw;
    font-size: 5.41vw;
    line-height: 1;
    letter-spacing: .1em
}

#sec4 .top .sub-txt span {
    font-size: 6.72vw;
    letter-spacing: .1em
}

#sec4 .bot {
    position: relative;
    z-index: 1;
    padding: 15vw 5.33% 18vw
}

#sec4 .bot .bg {
    position: absolute;
    inset: 0;
    z-index: -1
}

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

#sec4 .bot h2 {
    text-align: center;
    line-height: 1.44;
    letter-spacing: .1em
}

#sec4 .bot h2 span {
    letter-spacing: .1em
}

#sec4 .bot .txt {
    margin-top: 6vw
}

#sec4 .bot .btn-shared {
    margin: 7.5vw 3% 0
}

@media screen and (min-width: 768px) {
    #sec4 {
        background: url("../img/index/sec4_bg_pc.jpg") no-repeat center/cover;
        padding: 20px
    }

    #sec4 .box {
        background: rgba(40, 36, 25, .6);
        width: 630px;
        margin-left: auto;
        padding: 109px 0 103px
    }

    #sec4 .top .sub-txt {
        position: unset;
        width: 376px;
        padding-bottom: 35px;
        font-size: 29px
    }

    #sec4 .top .sub-txt span {
        font-size: 36px
    }

    #sec4 .bot {
        padding: 8px 0 0
    }

    #sec4 .bot .txt {
        width: 477px;
        margin: 43px auto 0
    }

    #sec4 .bot .btn-shared {
        margin: 33px auto 0
    }
}

#sec5 {
    background: url("../img/index/sec5_deco_sp.png") no-repeat left top/100%;
    padding-top: 2.67vw
}

#sec5 .set1 .wrap {
    border: 1px solid #bfaa83;
    border-bottom: none;
    border-radius: 25px 25px 0 0;
    margin: 0 2.67%;
    padding: 16.5vw 0 9.5vw
}

#sec5 .set1 .wrap::before {
    content: "";
    position: absolute;
    inset: 2px 2px 0;
    border: 2px solid #bfaa83;
    border-radius: 22.5px 22.5px 0 0;
    border-bottom: none
}

#sec5 .set1 h2 {
    display: flex;
    justify-content: center;
    align-items: flex-end;
    background: url("../img/index/sec5_deco_ttl.png") no-repeat center bottom/100%;
    padding-bottom: 2.3vw;
    margin: 0 1.5px;
    line-height: 1;
    letter-spacing: .1em
}

#sec5 .set1 h2 span {
    letter-spacing: .1em
}

#sec5 .set1 h2 img {
    width: 15vw;
    margin: 0 2vw 0 1.5vw
}

#sec5 .set1 .txt {
    margin: 8vw 5% 0
}

#sec5 .set2 .group-link li a {
    position: relative;
    display: block
}

#sec5 .set2 .group-link li a::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    border: 2.67vw solid rgba(255, 250, 240, .5)
}

#sec5 .set2 .group-link li a:after {
    content: "";
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: 2;
    background: url("../img/shared/bg2.jpg") repeat center;
    width: 30.5%;
    height: 27.5vw;
    -webkit-clip-path: polygon(100% 0, 0% 100%, 100% 100%);
    clip-path: polygon(100% 0, 0% 100%, 100% 100%)
}

#sec5 .set2 .group-link li a .photo img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover
}

#sec5 .set2 .group-link li a .name-price {
    position: absolute;
    bottom: 7vw;
    left: 7%;
    z-index: 3;
    color: #fff;
    line-height: 1.5;
    letter-spacing: .1em
}

#sec5 .set2 .group-link li a .name-price * {
    letter-spacing: .1em
}

#sec5 .set2 .group-link li a .name-price dd {
    margin-left: 3%
}

#sec5 .set2 .group-link li a .name-price dd small {
    margin-left: 2%
}

#sec5 .set2 .group-link li a .sub-txt {
    position: absolute;
    bottom: 7.5vw;
    right: 16.5%;
    z-index: 3;
    background: #fffaf0;
    width: 36.27%;
    border-radius: 11px;
    text-align: center;
    font-size: 3.73vw;
    line-height: 1.5357142857;
    letter-spacing: .1em
}

#sec5 .set2 .group-link li a .arrow {
    position: absolute;
    bottom: 7vw;
    right: 7%;
    z-index: 3;
    width: 8%
}

#sec5 .set3 .wrap {
    border: 1px solid #bfaa83;
    border-top: none;
    border-radius: 0 0 25px 25px;
    margin: 0 2.67%;
    padding: 10.5vw 5.33% 26vw
}

#sec5 .set3 .wrap::before {
    content: "";
    position: absolute;
    inset: 0 2px 2px;
    border: 1.5px solid #bfaa83;
    border-top: none;
    border-radius: 0 0 22.5px 22.5px
}

#sec5 .set3 h3 {
    position: relative;
    width: -moz-fit-content;
    width: fit-content;
    border-bottom: 1px solid #000;
    margin: 0 auto;
    padding-bottom: 3.5vw;
    line-height: 1;
    letter-spacing: .1em
}

#sec5 .set3 h3::before {
    content: "";
    position: absolute;
    bottom: 3px;
    left: 0;
    background: #000;
    width: 100%;
    height: 1px
}

#sec5 .set3 .txt {
    margin-top: 5.5vw
}

#sec5 .set3 .btn-popup {
    margin-top: 9vw
}

#sec5 .set3 .btn-popup a::before {
    display: none
}

#sec5 .set3 .btn-popup a:after {
    content: "";
    position: absolute;
    top: 50%;
    right: 18px;
    transform: translateY(-50%);
    background: url("../img/shared/icon_plus.png") no-repeat center/100%;
    width: 34.5px;
    height: 34.5px
}

@media screen and (max-width: 767px) {
    #sec5 .set1 .fs44 {
        font-size: 6.98vw
    }

    #sec5 .set1 .fs52 {
        font-size: 8.25vw
    }

    #sec5 .set2 .fs52 {
        font-size: 6.93vw
    }

    #sec5 .set2 .fs44 {
        font-size: 5.87vw
    }

    #sec5 .set2 .fs32 {
        font-size: 4.27vw
    }
}

@media screen and (min-width: 768px) {
    #sec5 {
        background: url("../img/index/sec5_deco_pc.png") no-repeat left top/auto;
        padding-top: 49px
    }

    #sec5 .set1 {
        padding: 0 30px
    }

    #sec5 .set1 .wrap {
        max-width: 1400px;
        margin: 0 auto;
        border-radius: 50px 50px 0 0;
        padding: 99px 0 18px
    }

    #sec5 .set1 .wrap::before {
        inset: 4px 4px 0;
        border-width: 3px;
        border-radius: 45px 45px 0 0
    }

    #sec5 .set1 h2 {
        width: 582px;
        margin: 0 auto;
        padding-bottom: 17px
    }

    #sec5 .set1 h2 img {
        width: auto;
        margin: 0 12px 0 9px
    }

    #sec5 .set1 .txt {
        text-align: center;
        margin: 53px 0 0
    }

    #sec5 .set1 .txt li+li {
        margin-top: 40px
    }

    #sec5 .set2 .group-link {
        display: flex;
        justify-content: space-between
    }

    #sec5 .set2 .group-link li {
        width: calc(50% - 5px)
    }

    #sec5 .set2 .group-link li a::before {
        display: none
    }

    #sec5 .set2 .group-link li a:after {
        width: 126px;
        height: 126px
    }

    #sec5 .set2 .group-link li a .photo {
        height: 640px
    }

    #sec5 .set2 .group-link li a .photo img {
        width: 100%;
        height: 100%;
        -o-object-fit: cover;
        object-fit: cover
    }

    #sec5 .set2 .group-link li a .name-price {
        bottom: 29px;
        left: 0;
        right: 0;
        text-align: center;
        line-height: 1.4
    }

    #sec5 .set2 .group-link li a .name-price dd {
        margin: 0
    }

    #sec5 .set2 .group-link li a .name-price dd small {
        margin-left: 10px
    }

    #sec5 .set2 .group-link li a .arrow {
        bottom: 38px;
        right: 40px;
        width: 34px
    }

    #sec5 .set3 {
        padding: 0 30px
    }

    #sec5 .set3 .wrap {
        max-width: 1400px;
        margin: 0 auto;
        border-radius: 0 0 50px 50px;
        padding: 99px 0 142px
    }

    #sec5 .set3 .wrap::before {
        inset: 0 4px 4px;
        border-width: 3px;
        border-radius: 0 0 45px 45px
    }

    #sec5 .set3 .lead {
        display: flex;
        align-items: center;
        gap: 65px;
        max-width: 1000px;
        margin: 0 auto
    }

    #sec5 .set3 h3 {
        display: flex;
        justify-content: center;
        align-items: center;
        width: 416px;
        height: 130px;
        border-bottom: none;
        border-right: 1px solid #000;
        margin: 0;
        padding: 0
    }

    #sec5 .set3 h3::before {
        inset: 0 4px 0 auto;
        width: 1px;
        height: 100%
    }

    #sec5 .set3 .txt {
        margin-top: 0
    }

    #sec5 .set3 .menu {
        display: flex !important;
        justify-content: space-between;
        max-width: 1000px;
        margin: 39px auto 0
    }

    #sec5 .set3 .menu .col {
        width: calc(50% - 18.5px)
    }

    #sec5 .set3 .menu .col dl {
        display: flex;
        justify-content: space-between;
        border-bottom: 1px solid rgba(234, 211, 178, .6);
        padding: 14px 0 15px;
        line-height: 30px
    }

    #sec5 .set3 .menu .col dl * {
        letter-spacing: .1em
    }
}

#sec6 {
    position: relative;
    z-index: 1;
    padding-top: 22vw
}

#sec6 .deco1 {
    position: absolute;
    top: -23.6vw;
    right: 0;
    width: 60.53%;
    z-index: -1
}

#sec6 .deco2 {
    position: absolute;
    top: -2.13vw;
    right: 0;
    width: 75.2%;
    z-index: -2
}

#sec6 .wrap {
    padding: 0
}

#sec6 h2 {
    position: relative;
    z-index: 2;
    background: #fffaf0;
    width: -moz-fit-content;
    width: fit-content;
    margin-left: 5.33%;
    padding: 3vw 2.3vw 0 3.5vw;
    line-height: 1;
    letter-spacing: .1em
}

#sec6 h2 span {
    margin: 0 -1.5vw 0 -1vw;
    letter-spacing: .1em
}

#sec6 .photo1 {
    position: relative;
    margin: -3.5vw 10% 0 0
}

#sec6 .photo1::before {
    content: "";
    position: absolute;
    inset: 28vw -2.2vw -2.2vw 9vw;
    z-index: -1;
    background: url("../img/shared/bg2.jpg") repeat center
}

#sec6 .group-txt {
    margin: 7vw 8% 0
}

#sec6 .group-txt h3 {
    width: -moz-fit-content;
    width: fit-content;
    margin: 0 auto 4.5vw;
    line-height: 1.89;
    letter-spacing: .1em
}

#sec6 .group-txt h3 span {
    margin-left: 20vw;
    letter-spacing: .1em
}

#sec6 .floor-map {
    margin: 6vw 8% 0
}

#sec6 .photo2 {
    position: relative;
    z-index: 2;
    margin: 0 3.5% 0 44%
}

#sec6 .photo3 {
    position: relative;
    z-index: 1;
    margin: -10.5vw 43.5% -11vw 4%
}

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

    #sec6 .deco1 {
        top: -157px;
        right: 0;
        width: auto
    }

    #sec6 .deco2 {
        top: -148px;
        width: auto
    }

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

    #sec6 h2 {
        margin: 0 281px 0 auto;
        padding: 15px 10px 1px 19px
    }

    #sec6 h2 span {
        margin: 0 -9px 0 -2px
    }

    #sec6 .photo1 {
        top: -90px;
        left: calc(-50vw + 50%);
        right: 600px;
        margin: 0;
        height: 514px
    }

    #sec6 .photo1::before {
        inset: 244px -20px -20px 81px
    }

    #sec6 .group-txt {
        width: 473px;
        margin: 33px 0 0 auto
    }

    #sec6 .group-txt h3 {
        margin: 0 0 39px;
        line-height: 55px
    }

    #sec6 .group-txt h3 span {
        margin-left: 106px
    }

    #sec6 .floor-map {
        max-width: 1000px;
        margin: -12px auto 0
    }

    #sec6 .photo2 {
        top: 601px;
        left: calc(50% + 170px);
        right: -90px;
        height: 384px;
        margin: 0
    }

    #sec6 .photo3 {
        text-align: center;
        margin: 10px 0 -221px 44px
    }

    #sec6 .bg {
        height: 337px;
        margin-left: calc(-50vw + 50%)
    }
}

@media screen and (min-width: 768px) and (max-width: 1360px){
    #sec6 .wrap{
        max-width: 90%;
        min-width: 1000px;
    }
}

#rss {
    padding: 10vw 0 21vw
}

#rss .lead {
    border-bottom: 1px solid #917f62;
    padding: 0 3% 3vw
}

#rss .lead .inner {
    display: flex;
    align-items: flex-end;
    justify-content: space-between
}

#rss .lead h2 {
    font-size: 6.91vw;
    line-height: 1;
    letter-spacing: .1em
}

#rss .lead .more a {
    position: relative;
    display: flex;
    align-items: center;
    gap: 2.67vw;
    font-size: 4.67vw;
    line-height: 1;
    letter-spacing: .16em
}

#rss .lead .more a img {
    width: 3vw
}

#rss #feed {
    margin-top: 7vw
}

#rss #feed .item {
    display: flex;
    align-items: center;
    gap: 4.5%
}

#rss #feed .item .rss-img {
    width: 43%;
    height: 27.5vw
}

#rss #feed .item .rss-img span {
    width: 100% !important;
    height: 100% !important
}

#rss #feed .item .desc {
    flex: 1;
    line-height: 35px
}

#rss #feed .item+.item {
    margin-top: 2vw
}

@media screen and (min-width: 768px) {
    #rss {
        padding: 85px 0 105px
    }

    #rss .wrap {
        max-width: 1200px
    }

    #rss .lead {
        padding: 0 0 14px
    }

    #rss .lead .inner {
        max-width: 1000px;
        margin: 0 auto
    }

    #rss .lead h2 {
        font-size: 37px
    }

    #rss .lead .more a {
        gap: 13px;
        font-size: 20px
    }

    #rss .lead .more a img {
        width: 13px
    }

    #rss .lead .more a:hover {
        opacity: .8
    }

    #rss #feed {
        display: flex;
        justify-content: space-between;
        max-width: 1000px;
        margin: 30px auto 0
    }

    #rss #feed .item {
        width: 50%;
        gap: 20px
    }

    #rss #feed .item .rss-img {
        width: 250px;
        height: 180px
    }

    #rss #feed .item .desc {
        line-height: 40px
    }

    #rss #feed .item .desc dd a:hover {
        text-decoration: underline
    }

    #rss #feed .item+.item {
        margin-top: 0;
        padding-left: 27px
    }
}

#shopinfo {
    position: relative;
    background: url("../img/index/shopinfo_deco2_sp.png") no-repeat left top/100%;
    padding: 12vw 0 0
}

#shopinfo .deco {
    position: absolute;
    top: -16vw;
    left: 0;
    width: 54%
}

#shopinfo .logo dt {
    width: 20.5%;
    margin: 0 auto
}

#shopinfo .logo dd {
    margin-top: 4vw;
    text-align: center;
    font-size: 12px;
    line-height: 19px;
    letter-spacing: .04em
}

#shopinfo .row {
    margin-top: 6vw
}

#shopinfo .contact {
    background: url("../img/shared/bg2.jpg") repeat center;
    color: #fff;
    padding: 6.5vw 0 7vw
}

#shopinfo .contact .btn-tel {
    text-align: center
}

#shopinfo .contact .btn-tel dl {
    line-height: 1
}

#shopinfo .contact .btn-tel dl dt {
    font-size: 13px;
    letter-spacing: .16em
}

#shopinfo .contact .btn-tel dl dd {
    margin-top: 6px;
    font-size: 26px;
    letter-spacing: .1em
}

#shopinfo .contact .btn-tel dl dd span {
    position: relative;
    top: -4px
}

#shopinfo .contact .btn-tel dl dd img {
    width: 21.5px;
    margin: -7px 7px 0 0
}

#shopinfo .contact .btn-tel .note {
    margin-top: 8px;
    font-size: 11px;
    line-height: 13px;
    letter-spacing: .04em
}

#shopinfo .contact .btn-web {
    width: 78%;
    margin: 5vw auto 0
}

#shopinfo .info {
    margin-top: 8.5vw
}

#shopinfo .info dl {
    border-bottom: 1px solid #ead3b2;
    padding: 11px 0 8px;
    font-size: 13px;
    line-height: 19px
}

#shopinfo .cancel {
    border: 1px solid #9d9880;
    margin-top: 9vw;
    padding: 7vw 6%
}

#shopinfo .cancel dt {
    position: relative;
    text-align: center;
    padding-bottom: 4vw;
    font-size: 5.45vw;
    line-height: 1.32;
    letter-spacing: .1em
}

#shopinfo .cancel dt::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    background: #9d9880;
    width: 17vw;
    height: 1px
}

#shopinfo .cancel dd {
    margin-top: 5vw;
    font-size: 13px;
    line-height: 22px;
    letter-spacing: .1em
}

#shopinfo .photo {
    margin: 7.5vw 9% 0
}

@media screen and (min-width: 768px) {
    #shopinfo {
        position: relative;
        z-index: 1;
        background: url("../img/index/shopinfo_deco2_pc.png") no-repeat left top/auto;
        padding: 79px 0 0
    }

    #shopinfo::before {
        content: "";
        position: absolute;
        top: 0;
        bottom: -247px;
        left: 0;
        right: 0;
        z-index: -1;
        background: url("../img/index/shopinfo_bg_pc.png") repeat-x left top/auto
    }

    #shopinfo .deco {
        top: -59px;
        width: auto
    }

    #shopinfo .logo dt {
        width: 111px
    }

    #shopinfo .logo dd {
        margin-top: 23px;
        font-size: 14px;
        line-height: 22px
    }

    #shopinfo .row {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        margin-top: 59px
    }

    #shopinfo .contact {
        width: 396px;
        padding: 27px 0 29px
    }

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

    #shopinfo .contact .btn-tel dl dd {
        margin-top: 7px;
        font-size: 30px
    }

    #shopinfo .contact .btn-tel dl dd img {
        width: 24px;
        margin: -8px 8px 0 0
    }

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

    #shopinfo .contact .btn-web {
        width: 300px;
        margin-top: 23px
    }

    #shopinfo .info {
        width: 510px;
        margin-top: -15px
    }

    #shopinfo .info dl {
        display: flex;
        padding: 10px 0 11px;
        font-size: 15px;
        line-height: 22px
    }

    #shopinfo .info dl dt {
        max-width: 117px;
        width: 100%;
        padding-left: 4px
    }

    #shopinfo .cancel {
        display: flex;
        align-items: center;
        margin-top: 51px;
        padding: 27px 0 28px 97px
    }

    #shopinfo .cancel dt {
        margin: 0 50px 0 0;
        padding: 0 45px 0 0;
        font-size: 23.36px;
        line-height: 30.94px
    }

    #shopinfo .cancel dt::before {
        top: 50%;
        bottom: auto;
        left: auto;
        right: 0;
        transform: translateY(-50%);
        width: 1px;
        height: 72px
    }

    #shopinfo .cancel dd {
        margin-top: 0;
        font-size: 15px;
        line-height: 25px
    }

    #shopinfo .photo {
        position: absolute;
        top: 630px;
        left: 0;
        margin: 0
    }
}

#gmap {
    padding: 8vw 0 23vw
}

#gmap .map {
    height: 100vw
}

#gmap .group-link {
    margin: 6vw 3% 0
}

@media screen and (min-width: 768px) {
    #gmap {
        padding: 50px 0 153px
    }

    #gmap .wrap {
        max-width: 1260px;
        padding: 0 30px
    }

    #gmap .map {
        height: 500px
    }

    #gmap .group-link {
        display: flex;
        justify-content: center;
        align-items: center;
        gap: 31px;
        margin: 38px 0 0
    }

    #gmap .group-link li:nth-child(1) {
        width: 173px
    }

    #gmap .group-link li:nth-child(1) a {
        position: relative;
        display: block;
        border-bottom: 1px solid #000;
        padding: 0 0 2px 9px;
        font-size: 15px;
        line-height: 22px;
        letter-spacing: .1em
    }

    #gmap .group-link li:nth-child(1) a:after {
        content: "";
        position: absolute;
        top: 3px;
        right: 9px;
        background: url("../img/shared/icon_print.png") no-repeat center/100%;
        width: 16px;
        height: 16px
    }

    #gmap .group-link li:nth-child(1) a:hover {
        border-color: rgba(0, 0, 0, 0)
    }
}

.remodal {
    background: #fffaf0
}

.remodal::before {
    display: none
}

.remodal .row .col .item dl {
    border-bottom: 1px solid rgba(234, 211, 178, .6)
}

.remodal .row .col .item dl dd {
    color: #000
}

.remodal .remodal-close-bot {
    color: #000;
    font-size: 17px;
    line-height: 1;
    letter-spacing: .1em
}

.remodal .remodal-close-bot span {
    left: -3px;
    margin: 0 auto 8px
}