#rss {
    padding: 10vw 0 10vw;
    position: relative;
    z-index: 1
}

#rss .ttl {
    width: 45vw;
    margin: 0 auto;
    position: relative;
    z-index: 2
}

#rss .btn-more {
    position: absolute;
    top: 0;
    right: 4vw;
    z-index: 3
}

#rss .btn-more a {
    width: 18vw;
    height: 18vw;
    border: 4px solid #305b5c;
    font-size: 4vw;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 50%;
    flex-direction: column;
    line-height: 1.4
}

#rss .btn-more .icon {
    max-width: 2vw;
    height: auto
}

#rss #feed {
    background: url("../img/shared/bg1.jpg") repeat center top;
    box-sizing: border-box;
    padding: 15vw 3vw 7vw;
    margin-top: -10vw;
    position: relative
}

#rss .slick-arrow {
    position: absolute;
    top: 24vw;
    width: 12vw;
    height: 12vw;
    font-size: 0;
    z-index: 3
}

#rss .slick-arrow.slick-prev {
    left: 12vw;
    background: url("../img/shared/btn_prev.png") no-repeat center/100%
}

#rss .slick-arrow.slick-next {
    right: 12vw;
    background: url("../img/shared/btn_next.png") no-repeat center/100%
}

#rss .item {
    box-sizing: border-box;
    padding: 0 2vw;
    flex: 1
}

#rss .item a {
    text-decoration: none
}

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

#rss .item .photo {
    width: 100%;
    height: 30vw
}

#rss .item .photo span {
    display: block;
    width: 100% !important;
    height: 100% !important;
    background: url("../img/shared/no_img.jpg") no-repeat center/cover
}

#rss .item dl {
    line-height: 1.6666666667;
    margin-top: 10px
}

#rss .item dl dt {
    color: #2e595a;
    font-size: 12px
}

#sec1 {
    position: relative
}

#sec1 .wrap {
    padding: 0
}

#sec1 .ttl {
    margin: 0 auto;
    width: 90vw
}

#sec1 .gr-main {
    background: url("../img/index/sec1_img1.jpg") no-repeat center top/cover;
    color: #fff;
    position: relative;
    padding: 15vw 7vw 0;
    margin-top: 8vw;
    z-index: 1;
    box-sizing: border-box
}

#sec1 .gr-main::before {
    content: "";
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: 0;
    width: 1px;
    height: 10vw;
    background: #fff
}

#sec1 .gr-main::after {
    content: "";
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: 100%;
    width: 1px;
    height: 4vw;
    background: #000
}

#sec1 .gr-main .frame {
    --border-color: #fff;
    position: absolute;
    top: 7vw;
    right: 2vw;
    left: 2vw;
    bottom: 5vw;
    border: 1px solid var(--border-color);
    border-bottom: none;
    z-index: -1
}

#sec1 .gr-main .frame::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 97vw;
    transform: rotate(11.4deg);
    height: 1px;
    background: var(--border-color);
    transform-origin: left
}

#sec1 .gr-main .frame::after {
    content: "";
    position: absolute;
    top: calc(100% - 1px);
    right: -1px;
    height: 20vw;
    width: 1px;
    background: var(--border-color)
}

#sec1 .txt .bottom {
    display: block;
    margin-top: 3vw
}

#sec1 .btn-gr {
    margin-top: 5vw
}

#sec1 .txt-loop {
    margin-top: 7vw
}

#sec1 .txt-loop .item {
    padding: 0 2vw
}

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

#sec2::before {
    content: "";
    position: absolute;
    top: 0;
    left: 20vw;
    background: url("../img/index/sec2_deco1.png") no-repeat center top/100%;
    width: 80vw;
    height: 200vw;
    mix-blend-mode: hard-light
}

#sec2 .ttl {
    width: 30vw;
    margin: 0 0 0 auto
}

#sec2 .img-gr1 {
    position: absolute;
    top: 0;
    left: var(--padding-wrap);
    width: 55vw
}

#sec2 .img-gr1 .img-txt {
    position: absolute;
    top: 17vw;
    right: 2vw;
    width: 80%
}

#sec2 .txt {
    margin-top: 5vw
}

#sec2 .btn-shared {
    margin-top: 5vw
}

#sec2 .img-gr2 {
    position: relative;
    margin-top: 10vw;
    z-index: 1
}

#sec2 .photo2 {
    width: 60vw;
    margin: 0 0 0 10vw;
    position: relative;
    z-index: 1;
    display: inline-block
}

#sec2 .photo2::before {
    content: "";
    position: absolute;
    bottom: -15vw;
    right: -16vw;
    background: url("../img/shared/bg_deco.jpg") repeat center top;
    width: 25vw;
    height: 25vw;
    z-index: -1
}

#sec2 .photo3 {
    margin: 3vw 0 0 24vw;
    width: 58vw;
    position: relative;
    z-index: 2
}

#sec3 {
    color: #fff;
    margin-top: 10vw;
    position: relative;
    z-index: 1;
    padding-bottom: 15vw
}

#sec3::before {
    content: "";
    position: absolute;
    top: -20vw;
    left: 0;
    background: url("../img/index/sec3_deco1.png") no-repeat center top/100%;
    width: 50vw;
    height: 100vw
}

#sec3::after {
    content: "";
    position: absolute;
    bottom: 0;
    right: 0;
    background: url("../img/index/sec3_deco2.png") no-repeat center bottom/100%;
    width: 40vw;
    height: 100vw;
    z-index: -1
}

#sec3 .gr-top {
    position: relative;
    z-index: 1
}

#sec3 .gr-top::before {
    content: "";
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: -5vw;
    width: 1px;
    height: 15vw;
    background: #fff;
    z-index: 2
}

#sec3 .ttl {
    width: 65vw;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 2
}

#sec3 .frame {
    --border-color: #fff;
    position: absolute;
    top: 7vw;
    right: 4vw;
    left: 4vw;
    bottom: 5vw;
    border: 1px solid var(--border-color);
    border-top: none;
    z-index: 1;
    box-sizing: border-box
}

#sec3 .frame::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 87vw;
    transform: rotate(-9.4deg);
    height: 1px;
    background: var(--border-color);
    transform-origin: left
}

#sec3 .frame::after {
    content: "";
    position: absolute;
    bottom: calc(100% - 1px);
    right: -1px;
    height: 14vw;
    width: 1px;
    background: var(--border-color)
}

#sec3 .txt {
    margin-top: 5vw
}

#sec3 .btn-gr {
    margin-top: 5vw
}

#sec4 {
    position: relative;
    z-index: 3
}

#sec4 .slider-wrap {
    position: relative
}

#sec4 .slider-wrap::before {
    content: "";
    position: absolute;
    top: -8vw;
    right: -4vw;
    background: url("../img/shared/bg_deco.jpg") repeat center top;
    z-index: -1;
    width: 20vw;
    height: 20vw
}

#sec4 .slider-dots {
    display: flex;
    position: absolute;
    bottom: 4vw;
    right: 3vw;
    z-index: 2;
    gap: 4vw
}

#sec4 .slider-dots .dot-item {
    background: url("../img/shared/dot1.png") no-repeat center top/100%;
    width: 8vw;
    height: 8vw;
    opacity: .5;
    transition: .3s
}

#sec4 .slider-dots .dot-item.active {
    opacity: 1
}

#sec4 .sec4-slider {
    position: relative
}

#sec4 .sec4-slider .photo {
    position: relative;
    transition: .3s;
    width: 100%
}

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

#sec4 .sec4-slider .photo+.photo {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%
}

#sec4 .gr {
    margin-top: 5vw
}

#sec4 .ttl {
    margin: 0 auto
}

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

#sec4 .btn-shared {
    margin-top: 8vw
}

#sec5 {
    margin-top: 20vw;
    padding-bottom: 30vw
}

#sec5 .wrap {
    z-index: 1
}

#sec5 .img-gr {
    position: relative;
    width: 68vw;
    margin: 0 0 0 auto
}

#sec5 .img-gr::before {
    content: "";
    position: absolute;
    bottom: -33vw;
    left: -9vw;
    background: url(../img/shared/bg_deco.jpg) repeat center top;
    width: 63vw;
    height: 60vw;
    z-index: -1
}

#sec5 .ttl {
    position: absolute;
    top: 15vw;
    left: 5vw;
    width: 30vw
}

#sec5 .photo2 {
    width: 68vw;
    margin: 5vw 0 0;
    position: relative;
    z-index: 2
}

#sec5 .line-gr {
    position: absolute;
    top: 5vw;
    left: 0vw;
    z-index: -1;
    width: 95vw
}

#sec5 .date {
    color: #fff;
    position: absolute;
    bottom: 20vw;
    left: 54vw;
    font-size: 5vw
}

#shopinfo {
    padding: 10vw 0 0;
    position: relative;
    z-index: 1
}

#shopinfo::before {
    content: "";
    position: absolute;
    width: 280vw;
    top: 0;
    background: url("../img/index/shopinfo_bg.png") no-repeat center top/100%;
    height: 100%;
    left: -60vw;
    z-index: -1
}

#shopinfo .ttl {
    width: 40vw;
    margin: 0 auto
}

#shopinfo .logo {
    width: 46vw;
    margin: 8vw auto 0
}

#shopinfo .logo-txt {
    text-align: center;
    line-height: 1.8;
    font-size: 4vw;
    margin-top: 3vw
}

#shopinfo .tel-gr {
    text-align: center;
    margin-top: 4vw;
    line-height: 1.5
}

#shopinfo .tel-top {
    font-size: 4vw
}

#shopinfo .tel-main {
    font-size: 9vw
}

#shopinfo .tel-main .icon {
    max-width: 6vw
}

#shopinfo .btn-shared {
    margin-top: 4vw
}

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

#shopinfo .info dl {
    padding: 10px 0 10px;
    border-bottom: 1px solid currentColor;
    display: flex;
    line-height: 1.6666666667;
    text-align: left
}

#shopinfo .info dl .icon-map {
    max-width: 10px;
    margin-top: -1px;
    height: auto
}

#shopinfo .info dl dt {
    min-width: 90px;
    margin-right: 10px
}

#shopinfo .txt-gr {
    border: 5px solid #abacab;
    padding: 5vw 5vw 5vw;
    box-sizing: border-box
}

#shopinfo .txt-gr .top {
    display: block;
    text-align: center;
    font-size: 16px
}

#shopinfo .txt-gr .bottom {
    display: block;
    margin-top: 2vw
}

#shopinfo .sns-gr {
    justify-content: center;
    margin-top: 5vw
}

#gmap {
    margin-top: 10vw;
    padding-bottom: 10vw
}

#gmap .map {
    height: 480px;
    filter: grayscale(1)
}

#gmap .map iframe {
    width: 100%;
    height: 100%
}

#gmap .links {
    margin-top: 5vw
}

@media(min-width: 768px) {
    #rss {
        padding: 79px 0 0
    }

    #rss .ttl {
        width: auto;
        margin: 0;
        text-align: center
    }

    #rss .btn-more {
        right: 86px;
        top: 29px
    }

    #rss .btn-more a {
        width: 90px;
        height: 90px;
        font-size: 19px;
        box-sizing: border-box
    }

    #rss .btn-more .icon {
        max-width: 10px
    }

    #rss #feed {
        background: url("../img/shared/bg1.jpg") repeat center top;
        box-sizing: border-box;
        padding: 75px 80px 26px;
        margin: -47px 10px 0;
        position: relative;
        display: flex;
        gap: 68px
    }

    #rss .item {
        padding: 0 0
    }

    #rss .item a {
        text-decoration: none
    }

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

    #rss .item .photo {
        width: 100%;
        height: 139px
    }

    #rss .item dl {
        margin-top: 10px
    }

    #rss .item dl dt {
        font-size: 15px
    }

    #sec1 {
        padding: 118px 0 0
    }

    #sec1 .wrap {
        padding: 0;
        max-width: 100%;
        position: relative;
        z-index: 1
    }

    #sec1 .ttl {
        text-align: center;
        width: auto
    }

    #sec1 .gr-main {
        padding: 136px 10px 93px;
        margin-top: 56px;
        z-index: 1;
        box-sizing: border-box
    }

    #sec1 .gr-main::before {
        height: 93px
    }

    #sec1 .gr-main::after {
        height: 30px
    }

    #sec1 .gr-main .frame {
        top: 60px;
        right: 60px;
        left: 60px;
        bottom: 50px
    }

    #sec1 .gr-main .frame::before {
        width: 100.5%;
        transform: rotate(5.4deg)
    }

    #sec1 .gr-main .frame::after {
        right: -1px;
        height: 8.8vw
    }

    #sec1 .txt {
        text-align: center
    }

    #sec1 .txt .bottom {
        margin-top: 38px
    }

    #sec1 .btn-gr {
        margin-top: 39px
    }

    #sec1 .txt-loop {
        position: absolute;
        top: 0;
        right: 80px;
        width: 300px;
        height: 90%;
        overflow: hidden;
        margin: 0
    }

    #sec1 .txt-loop .item {
        padding: 0 0
    }

    #sec2 {
        padding: 206px 0 100px
    }

    #sec2::before {
        left: calc(50% - 52px);
        width: 625px;
        height: 831px;
        top: -19px
    }

    #sec2 .wrap {
        max-width: 1050px
    }

    #sec2 .ttl {
        width: auto;
        margin: 0 94px 0 auto;
        text-align: right
    }

    #sec2 .img-gr1 {
        left: 80px;
        width: auto;
        top: -43px
    }

    #sec2 .img-gr1 .img-txt {
        top: 130px;
        right: 34px;
        width: auto
    }

    #sec2 .txt-gr {
        margin: 117px 0 0 auto;
        max-width: 516px
    }

    #sec2 .txt {
        margin-top: 0
    }

    #sec2 .btn-shared {
        margin-top: 23px
    }

    #sec2 .img-gr2 {
        margin-top: 0;
        z-index: 1;
        position: absolute;
        top: 560px;
        left: -50px
    }

    #sec2 .photo2 {
        width: auto;
        margin: 0;
        position: relative
    }

    #sec2 .photo2::before {
        bottom: -120px;
        right: -112px;
        width: 199px;
        height: 177px
    }

    #sec2 .photo3 {
        margin: 28px 0 0 136px;
        width: auto;
        position: relative;
        z-index: 2
    }

    #sec3 {
        margin-top: 110px;
        padding: 0 20px 255px
    }

    #sec3::before {
        top: -100px;
        left: 0;
        background: url("../img/index/sec3_deco1.png") no-repeat center top/100%;
        width: 434px;
        height: 761px
    }

    #sec3::after {
        bottom: 0;
        right: 0;
        background: url("../img/index/sec3_deco2.png") no-repeat center bottom/100%;
        width: 274px;
        height: 553px;
        z-index: -1
    }

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

    #sec3 .gr-top {
        position: relative;
        z-index: 1
    }

    #sec3 .gr-top::before {
        top: -31px;
        width: 1px;
        height: 100px
    }

    #sec3 .ttl {
        width: auto;
        position: absolute;
        top: 53%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: 2;
        text-align: center;
        width: 80%
    }

    #sec3 .ttl img {
        max-width: 100%;
        height: auto
    }

    #sec3 .frame {
        top: 72px;
        right: 44px;
        left: 49px;
        bottom: 42px;
        box-sizing: border-box
    }

    #sec3 .frame::before {
        width: 100.6%;
        transform: rotate(-5.4deg)
    }

    #sec3 .frame::after {
        height: 106px
    }

    #sec3 .gr-bottom {
        margin: 36px auto 0;
        max-width: 1000px;
        box-sizing: border-box;
        padding: 0 10px;
        display: flex;
        align-items: flex-end
    }

    #sec3 .txt {
        margin-top: 0;
        max-width: 570px
    }

    #sec3 .btn-gr {
        margin: 0 0 11px 50px
    }

    #sec4 {
        padding: 0 20px
    }

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

    #sec4 .slider-wrap {
        position: relative;
        position: absolute;
        top: 0;
        left: calc(50% - 50vw);
        right: calc(50% - 36px)
    }

    #sec4 .slider-wrap::before {
        width: 151px;
        height: 136px;
        right: -76px;
        top: -64px
    }

    #sec4 .slider-dots {
        bottom: 28px;
        right: 36px;
        z-index: 2;
        gap: 16px
    }

    #sec4 .slider-dots .dot-item {
        width: 28px;
        height: 28px;
        cursor: pointer
    }

    #sec4 .slider-dots .dot-item:hover {
        opacity: .8
    }

    #sec4 .sec4-slider {
        position: relative
    }

    #sec4 .sec4-slider .photo {
        height: 672px
    }

    #sec4 .gr {
        margin: 0 0 0 auto;
        max-width: 500px;
        padding: 32px 0 0 0;
        text-align: center
    }

    #sec4 .ttl {
        width: auto;
        margin: 0 auto;
        text-align: center
    }

    #sec4 .ttl img {
        max-width: 100%;
        height: auto
    }

    #sec4 .txt {
        margin-top: 47px
    }

    #sec4 .btn-shared {
        margin-top: 43px
    }

    #sec5 {
        margin-top: 205px;
        padding-bottom: 140px
    }

    #sec5 .wrap {
        z-index: 1
    }

    #sec5 .img-gr {
        width: auto;
        margin: 0 0 0 calc(50% - 36px)
    }

    #sec5 .img-gr::before {
        bottom: -102px;
        left: -45px;
        width: 209px;
        height: 186px
    }

    #sec5 .ttl {
        top: 107px;
        left: 108px;
        width: auto
    }

    #sec5 .photo2 {
        width: auto;
        margin: 30px 0 0 calc(50% - 433px);
        position: relative;
        z-index: 2
    }

    #sec5 .line-gr {
        position: absolute;
        top: 54px;
        left: calc(50% - 267px);
        z-index: -1;
        width: auto
    }

    #sec5 .date {
        bottom: 259px;
        left: calc(50% + 260px);
        font-size: 30px
    }

    #shopinfo {
        padding: 196px 20px 0;
        position: relative;
        z-index: 1
    }

    #shopinfo::before {
        content: "";
        position: absolute;
        width: 100%;
        top: 0;
        height: 100%;
        left: 0;
        z-index: -1
    }

    #shopinfo .ttl {
        width: auto;
        margin: 0 auto;
        text-align: center
    }

    #shopinfo .logo {
        width: auto;
        margin: 74px auto 0;
        text-align: center
    }

    #shopinfo .logo-txt {
        font-size: 15px;
        margin-top: 16px;
        letter-spacing: .15em
    }

    #shopinfo .gr-top {
        display: flex;
        justify-content: center;
        gap: 63px;
        margin-top: 37px
    }

    #shopinfo .tel-gr {
        text-align: center;
        margin-top: 0;
        line-height: 1.5
    }

    #shopinfo .tel-top {
        font-size: 16px
    }

    #shopinfo .tel-main {
        font-size: 33px
    }

    #shopinfo .tel-main .icon {
        max-width: 20Spx
    }

    #shopinfo .btn-shared {
        margin-top: 0
    }

    #shopinfo .info {
        margin-top: 66px
    }

    #shopinfo .info .row {
        display: flex;
        gap: 60px
    }

    #shopinfo .info .col {
        width: 50%;
        flex: 1
    }

    #shopinfo .info dl {
        padding: 14px 0 15px;
        display: flex;
        line-height: 2;
        letter-spacing: .15em;
        font-size: 15px
    }

    #shopinfo .info dl dt {
        min-width: 90px;
        margin-right: 10px
    }

    #shopinfo .txt-gr {
        padding: 23px 10px 24px;
        text-align: center;
        margin-top: 29px;
        line-height: 2
    }

    #shopinfo .txt-gr .top {
        display: block;
        text-align: center;
        font-size: 16px
    }

    #shopinfo .txt-gr .bottom {
        display: block;
        margin-top: 18px
    }

    #shopinfo .sns-gr {
        justify-content: flex-end;
        margin: 17px -20px 0 0
    }

    #shopinfo .sns-gr .list {
        gap: 27px
    }

    #gmap {
        margin-top: 75px;
        padding-bottom: 101px
    }

    #gmap .wrap {
        max-width: 880px
    }

    #gmap .map {
        height: 373px
    }

    #gmap .links {
        margin-top: 20px;
        display: flex;
        align-items: flex-end;
        justify-content: flex-end;
        gap: 20px
    }

    #gmap .print_map {
        line-height: 1
    }

    #gmap .print_map a {
        line-height: 1;
        text-decoration: underline
    }

    #gmap .print_map a:hover {
        text-decoration: none
    }
}

@media(min-width: 768px)and (max-width: 1200px) {
    #sec2 .txt-gr {
        max-width: 480px;
        padding-right: 20px
    }

    #sec4 .slider-wrap {
        right: 520px
    }

    #sec3 .frame::after {
        height: 8.2vw
    }
}