@charset "utf-8";


@media only screen and (max-width: 599px) {
	.sp_only {
		display: block;
	}
	.sp_tablet_only {
		display: block;
	}
	.tablet_only {
		display: none;
	}
	.pc_only {
		display: none !important;
	}
	.pc_tablet_only {
		display:none !important;
	}
}
@media only screen and (min-width: 600px) and (max-width: 1024px) {
	.sp_only {
		display: none !important;
	}
	.sp_tablet_only {
		display: block !important;
	}
	.tablet_only {
		display: block;
	}
	.pc_only {
		display:none !important;
	}
	.pc_tablet_only {
		display:block;
	}
}
@media only screen and (min-width: 1025px) {
	.sp_only {
		display: none !important;
	}
	.sp_tablet_only {
		display: none !important;
	}
	.tablet_only {
		display: none;
	}
	.pc_only {
		display: block;
	}
	.pc_tablet_only {
		display:block;
	}
}






.sns_fixed {
	display: none;
	visibility: hidden;
}

/**
* Project
**/

.p-mv {
    position: relative;
    height: 100vh;
    min-height: 900px;
    background: #2d9eba;
}

@media only screen and (max-width: 960px) {
    .p-mv {
        /*height: 680px;*/
        height: initial;
        /*min-height: 680px;*/
    }
}

@keyframes scaleAnim {
  0% {
    transform: scale(1.2);
    opacity: 0;
  }
  100% {
    transform: scale(1);
    opacity: 1;
  }
}

.p-mv__img {
    width: 62.5%;
}

/*.p-mv__img img {
    animation-duration: 1.8s;
    animation-fill-mode: forwards;
    animation-name: scaleAnim;
    animation-timing-function: ease-out;
}*/

.p-mv .p-mv__inner,
.p-mv .swiper-wrapper {
    height: 100%;
}

.p-mv .p-mv__inner {
    display: flex;
}

@media only screen and (max-width: 960px) {
    .p-mv .p-mv__inner {
        flex-direction: column;
    }
}

.p-mv__txt {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 39%;
    min-width: 630px;
    color: #fff;
    padding: 5%;
    padding: min(4vw,20px) min(5vw,80px);
}

@media only screen and (max-width: 1200px) {
    .p-mv__txt {
        width: 30%;
        min-width: 480px;
        padding: 5%;
        padding: min(4vw,20px) min(3vw,40px);
    }
    @-moz-document url-prefix() {
        .p-mv__txt {
            padding: 20px;
        }
    }
}   


@media only screen and (max-width: 960px) {
    .p-mv__txt {
        width: 100%;
        min-width: inherit;
        padding: 8vw 5.3vw 5.3vw;
    }
}

.p-mv__ttl {
    margin-bottom: min(4vw,48px)
}
@-moz-document url-prefix() {
    .p-mv__ttl {
        margin-bottom: 48px;
    }
}

@media only screen and (max-width: 960px) {
    .p-mv__ttl {
        padding: 0 3vw;
    }
}

.p-mv__ttl h1 img,
.p-mv__ttl h1 svg {
    line-height: 1;
    vertical-align: middle;
}

.p-mv__ttl h2 {
    font-size: min(2.4vw,2.25rem);
    line-height: 1.4;
    font-family: "ShipporiMincho-Regular";
    text-align: center;
    letter-spacing: -0.1em;
    opacity: 0;
}
@-moz-document url-prefix() {
    .p-mv__ttl h2 {
        font-size: 2.25rem;
    }
}

@media only screen and (max-width: 960px) {
    .p-mv__ttl h2 {
        position: relative;
        top: -1.2vw;
        font-size: 5.4vw;
    }
}


.p-mv__ttl.is-active h2 {
    animation: mvFade 1.2s ease-out forwards 0.8s;
}

.p-mv__desc {
    margin-bottom: min(3vw,40px);
    font-size: 1rem;
    line-height: 2;
    opacity: 0;
}
@-moz-document url-prefix() {
    .p-mv__desc {
        margin-bottom: 40px;
    }
}

@media only screen and (max-width: 960px) {
    .p-mv__desc {
        margin-bottom: 4.8vw;
        font-size: 3.4vw;
    }
}

.p-mv__detail.is-active .p-mv__desc {
    animation: mvFade 1.2s ease-out forwards 1.2s;
}

.p-mv__coupon {
    display: flex;
    background: var(--color_bg);
    border: 2px solid var(--color_accent02);
    color: #000;
    opacity: 0;
}

@media only screen and (max-width: 960px) {
    .p-mv__coupon {
        display: block;
        background: inherit;
        border: 0;
    }
}

.p-mv__detail .p-mv__coupon {
    padding: 0;
    animation: mvFade 1.2s ease-out forwards 1.6s;
}

.p-mv__coupon li {
    width: 50%;
    padding: 10px;
}

@media only screen and (max-width: 960px) {
    .p-mv__coupon li {
        width: 100%;
        margin-bottom: 5.3vw;
        padding: 2.8vw;
        background: var(--color_bg);
        border: 2px solid var(--color_accent02);
    }
}

.p-mv__coupon li:first-child {
    border-right: 2px solid var(--color_accent02);
}

@media only screen and (max-width: 960px) {
    .p-mv__coupon li:last-child {
        margin-bottom: 0;
    }
}

.p-mv__couponFlex {
    display: flex;
}

.p-mv__couponItem {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: 50%;
    padding: min(1vw,10px) min(1vw,10px);
    text-align: center;
}
@-moz-document url-prefix() {
    .p-mv__couponItem {
        padding: 10px;
    }
}

@media only screen and (max-width: 960px) {
    .p-mv__couponItem {
        padding: 1.8vw 2.8vw;
    }
}

.p-mv__couponItem:first-child {
    width: 45%;
    border-right: 1px solid var(--color_main);
}

.p-mv__couponItem:last-child {
    width: 55%;
}

.p-mv__couponItem p {
    font-size: 0.875rem;
    font-family: "ShipporiMincho-Regular";
}

@media only screen and (max-width: 960px) {
    .p-mv__couponItem p {
        margin-bottom: 0.8vw;
        font-size: 4vw;
    }
}

.p-mv__couponItem .per {
    margin: 6px 0 0;
}


.p-mv__couponItem:first-child .per {
    width: 87%;
    margin: 6px auto 0;
}

@media only screen and (max-width: 960px) {
    .p-mv__couponItem:first-child .per {
        width: 88%;
        margin: 6px auto 0;
    }
}

.p-mv__couponItem:last-child .per {
    width: 93%;
}

@media only screen and (max-width: 960px) {
    .p-mv__couponItem:last-child .per {
        width: 93%;
    }
}

.p-mv__couponBtm {
    margin-top: min(1vw,10px);
    line-height: 1.6;
    font-size: 0.65rem;
    font-family: "ShipporiMincho-Regular";
    text-align: center;
}

@media only screen and (max-width: 960px) {
    .p-mv__couponBtm {
        margin-top: 2.8vw;
        font-size: 3.8vw;
        line-height: 1.2;
    }
}

.p-mv__couponDay {
    display: block;
    margin-bottom: min(1vw,12px);
    padding: min(0.2vw,2px) min(0.5vw,5px);
    text-align: center;
    color: #fff;
    font-size: 1.125rem;
    line-height: 1.4;
    letter-spacing: -0.02em;
    font-family: "ShipporiMincho-Regular";
}
@-moz-document url-prefix() {
    .p-mv__couponDay {
        margin-bottom:12px;
        padding:5px;
    }
}

@media only screen and (max-width: 960px) {
    .p-mv__couponDay {
        margin-bottom: 2.8vw;
        padding: 0.6vw 5vw;
        font-size: 4.4vw;
        letter-spacing: 0.02em;
    }
}

.p-mv__couponDay.is-blue {
    background: var(--color_accent01);
}

.p-mv__couponDay.is-brown {
    background: var(--color_accent02);
}

.p-mv__last {
    margin-top: min(1.4vw,14px);
    font-size: 0.875rem;   
    line-height: 1.6;
    opacity: 0;
}

@media only screen and (max-width: 960px) {
    .p-mv__last {
        margin-top: 3.8vw;
        font-size: 3.4vw;   
    }
}

.p-mv__detail .p-mv__last {
    animation: mvFade 1.2s ease-out forwards 2s;
}

.p-mv__coupon.is-1col li {
    width: 100%;
    border-right: 0;
    padding: 0;
}

.p-mv__coupon.is-1col .p-mv__couponItem {
    width: 33%;
    padding: min(1.4vw, 16px) min(1.4vw, 16px);
}
@-moz-document url-prefix() {
    .p-mv__coupon.is-1col .p-mv__couponItem {
        padding: 16px;
    }
}

@media only screen and (max-width: 960px) {
    .p-mv__coupon.is-1col .p-mv__couponItem {
        padding: 3.2vw 0;
    }
}

.p-mv__coupon.is-1col .p-mv__couponItem p {
    color: var(--color_accent02);
    font-size: 1rem;
}

.p-mv__coupon.is-1col .p-mv__couponItem p:first-child {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
}

@media only screen and (max-width: 960px) {
    .p-mv__coupon.is-1col .p-mv__couponItem p {
        font-size: 3.2vw;
        line-height: 1.5;
    }
}

.p-mv__coupon.is-1col .p-mv__couponItem:first-child {
    border-right: 1px solid var(--color_accent02);
}
.p-mv__coupon.is-1col .p-mv__couponItem:nth-of-type(2n) {
    border-right: 1px solid var(--color_accent02);
}

.p-mv__coupon.is-1col .p-mv__couponDay {
    margin-bottom: 0;
    padding: min(0.2vw, 2px) min(0.8vw, 8px) min(0.4vw,4px);
    letter-spacing: 0.08em;
    line-height: 1.2;
    font-size: 1.25rem;
}
@-moz-document url-prefix() {
    .p-mv__coupon.is-1col .p-mv__couponDay {
        padding: 4px;
    }
}

@media only screen and (max-width: 960px) {
    .p-mv__coupon.is-1col .p-mv__couponDay {
        padding: 1.2vw 1.2vw 1.2vw;
        font-size: 4.4vw;
    }
}

.p-mv__coupon.is-1col .p-mv__couponItem:first-child {
    width: 33%;
}

.p-mv__coupon.is-1col .p-mv__couponItem:first-child .per {
    width: 100%;
    margin: 10px auto 0;
}

.p-mv__coupon.is-1col .p-mv__couponItem:nth-child(2n) .per {
    width: 100%;
    margin: 10px auto 0;
}

@media only screen and (max-width: 960px) {
    .p-mv__coupon.is-1col .p-mv__couponItem:first-child .per {
        width: 100%;
        margin: 10px auto 0;
    }
    .p-mv__coupon.is-1col .p-mv__couponItem .per > img{
        padding: 0 5%;
    }
}

.p-mv__coupon.is-1col .p-mv__couponItem:last-child {
    width: 33%;
}

.p-mv__coupon.is-1col .p-mv__couponItem:last-child .per {
    width: 100%;
    margin: 10px auto 0;
}

@media only screen and (max-width: 960px) {
    .p-mv__coupon.is-1col .p-mv__couponItem:last-child .per {
        margin: 10px auto 0;
    }
}

.p-mv__date {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: min(1vw,10px);
    margin-bottom: min(1vw,10px);
    font-size: 1.375rem;
    font-family: "ShipporiMincho-Regular";
    text-align: center;
    opacity: 0;
}
@-moz-document url-prefix() {
    .p-mv__date {
        gap: 10px;
        margin-bottom: 10px;
    }
}

@media only screen and (max-width: 960px) {
    .p-mv__date {
        margin-bottom: 2vw;
        gap: 2.8vw;
        font-size: 3.8vw;
    }
}

@keyframes mvFade {
    0% {
        opacity: 0;
        transform: translate(0,6px);
    }
    100% {
        opacity: 1;
        transform: translate(0,0);
    }
}

.p-mv__date.is-active {
    animation: mvFade 1s ease-out forwards 0.8s;
}

.p-mv__date small {
    margin-left: 4px;
    font-size: 0.875rem;
}

@media only screen and (max-width: 960px) {
    .p-mv__date small {
        margin-left: 1.4vw;
        font-size: 2.6vw;
    }
}

.p-mv__date i {
    display: block;
    width: min(5vw, 50px);
    margin-bottom: 5px;
    overflow: hidden;
}

@media only screen and (max-width: 960px) {
    .p-mv__date i {
        width: 10vw;
    }
}

@keyframes date-scroll {
    0% {
        -webkit-transform-origin: right;
        transform-origin: right;
        -webkit-transform: scaleX(1);
        transform: scaleX(1);
    }

    18% {
        -webkit-transform-origin: right;
        transform-origin: right;
        -webkit-transform: scaleX(0) translate(5%, 0);
        transform: scaleX(0) translate(5%, 0);
    }

    19% {
        -webkit-transform-origin: left;
        transform-origin: left;
    }

    20% {
        -webkit-transform: scaleX(0);
        transform: scaleX(0)
    }

    40%,100% {
        -webkit-transform-origin: left;
        transform-origin: left;
        -webkit-transform: scaleX(1);
        transform: scaleX(1)
    }
}

.p-mv__date i img {
    animation: date-scroll 4000ms cubic-bezier(0.23, 1, 0.32, 1) infinite;
}

@media only screen and (max-width: 960px) {
    .p-mv__date i img {
        width: 100%;

    }
}

@keyframes mvClip {
    0% {
        clip-path: polygon(0% 0%, 0% 0%, 0% 100%, 0% 100%);
    }
    100% {
        clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%)
    }
}

.p-mv__slider {
    position: relative;
    width: 61.25%;
    overflow: hidden;
    clip-path: polygon(0% 0%, 0% 0%, 0% 100%, 0% 100%);
}

@media only screen and (max-width: 960px) {
    .p-mv__slider {
        width: 100%;
        height: 78vw;
        min-height: 310px;
    }
}

.p-mv.is-active .p-mv__slider {
    animation: mvClip 1.2s cubic-bezier(0.23, 1, 0.32, 1) forwards 0.8s;
}

.p-mv__sliderList {
    width: 100%;
    height: 100%;
}

.p-mv__item {
    z-index: 1;
    position: relative;
    overflow: hidden;
    transform: translate3d(0, 0, 0);
}

.p-mv__img {
    display: block;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.p-mv__img img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

@keyframes mvImg {
    0% {
        transform: scale(1.2);
        filter: blur(8px);
    }
    100% {
        transform: scale(1);
        filter: blur(0);
    }
}

.p-mv__img.is-active img {
    animation: mvImg 4s ease-out forwards;
}

.p-mv .swiper-pagination {
    display: flex;
    align-items: flex-end;
    gap: 12px;
    position: absolute;
    bottom: 34px !important;
    left: 34px !important;
    text-align: left;
}

.p-mv .swiper-pagination .swiper-pagination-bullet {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    font-size: 1rem;
    background: inherit !important;
    z-index: 1;
    opacity: 1 !important;
}

.p-mv .swiper-pagination .swiper-pagination-bullet-active {
    background: inherit !important;
    /*border: 1px solid #fff;*/
}

.p-mv .swiper-pagination .swiper-pagination-bullet .circle-wrapper {
    position: absolute;
    width: 100%;
    height: 100%;
    z-index: -1;
}

.p-mv .swiper-pagination .swiper-pagination-bullet .circle-animation {
    opacity: 0;
}

.p-mv .swiper-pagination .swiper-pagination-bullet-active .circle-animation {
    stroke-dasharray: 628;
    stroke-dashoffset: 628;
    animation: dash 1.6s ease-in-out forwards;
    /*transform: rotate(-90deg);*/
    transform-origin: 50% 50%;
    opacity: 1;
}

@keyframes dash{
  to{
    stroke-dashoffset:0;
  }
}

.p-feature {
    padding: 5%;
    padding: min(7vw,70px) min(8vw,80px) min(4vw,40px);
    background: #f7f2ee;
}

@media only screen and (max-width: 1200px) {
    .p-feature {
        padding: 5%;
        padding: min(7vw,70px) min(4vw,40px) min(4vw,40px);
    }
}

@media only screen and (max-width: 960px) {
    .p-feature {
        padding: 8vw 5.3vw 5.3vw;
    }
}

.p-feature__ttl {
    display: flex;
    gap: 32px;
    gap: min(2.8vw,32px);
    margin-bottom: 40px;
    margin-bottom: min(4vw,40px);
}

@media only screen and (max-width: 960px) {
    .p-feature__ttl {
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: 3.2vw;
        margin-bottom: 8vw;
    }
}

.p-feature__ttl strong {
    font-size: 2.625rem;
    font-family: "RoBodoni";
    font-style: italic;
    color: var(--color_accent01);
}

@media only screen and (max-width: 960px) {
    .p-feature__ttl strong {
        font-size: 6.8vw;
    }
}

.p-feature__ttl small {
    font-family: "ShipporiMincho-Regular";
    font-size: 1.5rem;
}

@media only screen and (max-width: 960px) {
    .p-feature__ttl small {
        font-size: 3.4vw;
    }
}

.p-feature__list {
    display: flex;
    gap: 0px;
    gap: min(4vw,40px);
    padding: 0;
}

@media only screen and (max-width: 960px) {
    .p-feature__list {
        flex-direction: column;
        gap: 8vw;
    }
}

.p-feature__item {
    width: calc(100% - min(8vw,80px) / 3);
}

@media only screen and (max-width: 960px) {
    .p-feature__item {
        width: 100%;
    }
}

.p-feature__item a {
    display: block;
}

.p-feature__item a figure {
    position: relative;
    overflow: hidden;
}

.p-feature__item a figure img {
    transition-duration: 0.5s;
    vertical-align: middle;
}

.p-feature__item a:hover figure img {
    filter: blur(6px);
}

.p-feature__item a figure i {
    opacity: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 50%;
    left:50%;
    transform: translate(-50%,-50%);
    width: 38px;
    width: min(6.8vw,38px);
    height: 38px;
    height: min(6.8vw,38px);
    border-radius: min(6.8vw,38px);
    background: #fff;
    transition-duration: 0.5s;
}


.p-feature__item a figure i:after {
    content: "";
    width: 55%;
    height: 29%;
    background: url(../images/common/icon-scroll-b.svg) no-repeat;
    background-size: 100%;
}

.p-feature__item a figure i:before {
    content: "";
    position: absolute;
    top: -4px;
    left: -4px;
    width: calc(100% + 8px);
    height: calc(100% + 8px);
    border-radius: 100%;
    border: 1px solid #fff;
}

.p-feature__item a:hover figure i {
    opacity: 1;
    animation: float 1.2s ease-in-out infinite alternate;
}

@keyframes float {
    0% {
        transform: translate(-50%,-50%);
    }
    50% {
        transform: translate(-50%,-20%);
    }
    100% {
        transform: translate(-50%,-50%);
    }
}

.p-feature__txt {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 20px;
    font-family: "RoBodoni", "ShipporiMincho-Regular";
}

@media only screen and (max-width: 960px) {
    .p-feature__txt {
        gap: 2.8vw;
        margin-top: 5.3vw;
    }
}

.p-feature__txt span {
    position: relative;
    /* padding-right: min(5vw,50px); */
    font-size: 2rem;
    color: var(--color_accent01);
}

@media only screen and (max-width: 960px) {
    .p-feature__txt span {
        padding-right: 8.8vw;
        font-size: 5.8vw;
    }
}
/*
.p-feature__txt span:after {
    position: absolute;
    right: min(1vw,10px);
    top: 50%;
    display: block;
    content: "";
    width: min(3vw,30px);
    height: 1px;
    background: var(--color_main);
}

@media only screen and (max-width: 960px) {
    .p-feature__txt span:after {
        width: 5vw;
    }
}
*/

.p-feature__txt span {
    font-size: 2rem;
}

@media only screen and (max-width: 960px) {
    .p-feature__txt span {
        font-size: 5.8vw;
    }
}

.p-feature__txt h4 {
    font-size: 1.5rem;
}

@media only screen and (max-width: 960px) {
    .p-feature__txt h4 {
        font-size: 4.8vw;
    }
}

.p-feature__txt p {
    /*margin-left: min(2vw,20px);*/
    font-size: 1.4rem;
}

@media only screen and (max-width: 960px) {
    .p-feature__txt p {
        margin-left: 2.8vw;
        font-size: 4vw;
    }
}

.p-feature__btn,
.p-bnr__btn {
    margin-top: 90px;
    margin-top: min(9vw,90px);
    text-align: center;
}

@media only screen and (max-width: 960px) {
    .p-feature__btn,
    .p-bnr__btn {
        margin-top: 14vw;
    }
}

.p-feature__btn a,
.p-bnr__btn a {
    position: relative;
    z-index: 1;
    display: inline-block;
    max-width: 1020px;
    width: 100%;
    padding: 14px 20px;
    text-align: center;
    font-size: 1.5rem;
    line-height: 1.4;
    font-family: "ShipporiMincho-Regular";
    color: var(--color_btn);
    background: var(--bg_btn02);
    border: 1px solid var(--color_btn);
    box-shadow: 0 0 0 1px var(--bg_btn02);
    transition-duration: 0.3s;
    overflow: hidden;
}

@media only screen and (max-width: 960px) {
    .p-feature__btn a,
    .p-bnr__btn a {
        padding: 3.8vw 4vw;
        font-size: 3.8vw;
        border: 2px solid var(--color_btn);
        box-shadow: 0 0 0 1px var(--bg_btn02);
    }
}

.p-feature__btn a:before,
.p-bnr__btn a:before {
    position: absolute;
    top: 0;
    left: 0;
    content: "";
    width: 100%;
    height: 100%;
    background: var(--bg_btn02);
    z-index: -1;
}

.p-feature__btn a:hover,
.p-bnr__btn a:hover {
    color: var(--bg_btn02);
    background: var(--color_btn);
    border: 1px solid var(--bg_btn02);
    box-shadow: 0 0 0 1px var(--color_btn);
}

@media only screen and (max-width: 960px) {
    .p-feature__btn a:hover,
    .p-bnr__btn :hover {
        border: 1px solid var(--color_btn);
        box-shadow: 0 0 0 1px var(--bg_btn02);
    }
}

@keyframes btn-anim2 {
    0% {
        transform: translate(0,0);
    }
    100% {
        transform: translate(0,-100%);
    }
}

.p-feature__btn a:hover:before,
.p-bnr__btn a:hover:before {
    animation: btn-anim2 0.8s cubic-bezier(0.23, 1, 0.32, 1) forwards;
}

.p-feature__btn a:after,
.p-bnr__btn a:after {
    position: absolute;
    top: 50%;
    right: 32px;
    content: "";
    width: 24px;
    height: 24px;
    transform: translate(-50%,-50%);
    background: url(../images/common/icon-arrow-white.svg) no-repeat;
    background-size: 100%;
}

@media only screen and (max-width: 960px) {
    .p-feature__btn a:after,
    .p-bnr__btn a:after {
        right: 3vw;
        width: 5vw;
        height: 5vw;
    }
}

@keyframes btn-anim {
    0% {
        background-position: 0px;
    }

    60% {
        background-position: 40px;
    }

    61% {
        background-position: -40px;
    }

    100% {
        background-position: 0px;
    }
}

.p-feature__btn a:hover:after,
.p-bnr__btn a:hover:after {
    background: url(../images/common/icon-arrow-gold.svg) no-repeat;
    background-size: 100%;
    animation: btn-anim 650ms cubic-bezier(0.4, 1, 0.3, 1) forwards;
}

.p-linklist {
    padding: 80px;
    padding: min(38px,3.8vw) min(8vw,80px);
    background: #e6eef6;
}

@media only screen and (max-width: 1200px) {
    .p-linklist {
        padding: 5%;
        padding: min(38px,3.8vw) min(4vw,40px);
    }
}

@media only screen and (max-width: 960px) {
    .p-linklist {
        padding: 5.3vw 5.3vw;
    }
}

.p-linklist__list {
    display: flex;
    gap: 20px;
    max-width: 1020px;
    margin: 0 auto;
    padding: 0;
}

@media only screen and (max-width: 960px) {
    .p-linklist__list {
        flex-direction: column;
        gap: 2.8vw;
    }
}

.p-linklist__item {
    width: calc((100% - 10px) / 2);
    text-align: center;
}

@media only screen and (max-width: 960px) {
    .p-linklist__item {
        width: 100%;
    }
}

.p-linklist__item a {
    position: relative;
    display: inline-block;
    max-width: 1020px;
    width: 100%;
    padding: 18.5px 20px;
    text-align: center;
    font-size: 1.5rem;
    font-family: "ShipporiMincho-Regular";
    color: var(--color_btn) !important;
    background: var(--bg_btn01);
    border: 1px solid var(--color_btn);
    box-shadow: 0 0 0 1px var(--bg_btn01); 
    z-index: 1;
    overflow: hidden;
}

@media only screen and (max-width: 960px) {
    .p-linklist__item a {
        padding: 4.8vw 4vw;
        font-size: 3.8vw;
        border: 2px solid var(--color_btn);
        box-shadow: 0 0 0 1px var(--bg_btn01);
    }
}

.p-linklist__item a:hover {
    color: var(--bg_btn01) !important;
    background: var(--color_btn);
    border: 1px solid var(--bg_btn01);
    box-shadow: 0 0 0 1px var(--color_btn);
}

@media only screen and (max-width: 960px) {
    .p-linklist__item a:hover {
        border: 2px solid var(--bg_btn01);
        box-shadow: 0 0 0 1px var(--color_btn);
    }
}

.p-linklist__item a:after {
    position: absolute;
    top: 50%;
    right: 32px;
    content: "";
    width: 24px;
    height: 24px;
    transform: translate(-50%,-50%);
    background: url(../images/common/icon-arrow-white.svg) no-repeat;
    background-size: 100%;
}

@media only screen and (max-width: 960px) {
    .p-linklist__item a:after {
        right: 3vw;
        width: 5vw;
        height: 5vw;
    }
}

.p-linklist__item a:before {
    position: absolute;
    top: 0;
    left: 0;
    content: "";
    width: 100%;
    height: 100%;
    background: var(--bg_btn01);
    z-index: -1;
}

.p-linklist__item a:hover:after {
    background: url(../images/common/icon-arrow-blue.svg) no-repeat;
    background-size: 100%;
    animation: btn-anim 650ms cubic-bezier(0.4, 1, 0.3, 1) forwards;
}

@keyframes btn-anim2 {
    0% {
        transform: translate(0,0);
    }
    100% {
        transform: translate(0,-100%);
    }
}

.p-linklist__item a:hover:before {
    animation: btn-anim2 0.8s cubic-bezier(0.23, 1, 0.32, 1) forwards;
}

.p-item {
    padding: 5%;
    padding: 0 min(8vw,80px) min(8vw,80px);
}

@media only screen and (max-width: 1200px) {
    .p-item {
        padding: 5%;
        padding: 0 min(4vw,40px) min(8vw,80px);
    }
}


@media only screen and (max-width: 960px) {
    .p-item {
        padding: 0 5.3vw 8vw;
    }
}

.p-item__head {
    padding: 5%;
    padding: min(7vw,108px) 0 min(4vw,40px);
    text-align: center;
}

@media only screen and (max-width: 960px) {
    .p-item__head {
        padding: 14vw 0 8vw; 
        text-align: center;
    }
}

.p-item__catch {
    font-family: "RoBodoni";
    color: var(--color_accent01);
}

.p-item__catch {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 16px;
    margin-bottom: 24px;
}

@media only screen and (max-width: 960px) {
    .p-item__catch {
        gap: 2.8vw;
        margin-bottom: 2.8vw;
    }
}

.p-item__catch small {
    font-size: 1.5rem;
    font-style: italic;
}

@media only screen and (max-width: 960px) {
    .p-item__catch small {
        font-size: 4vw;
    }
}

.p-item__catch strong {
    font-size: 3rem;
}

@media only screen and (max-width: 960px) {
    .p-item__catch strong {
        font-size: 6.4vw;
    }
}

.p-item__ttl {
    text-align: center;
}

.p-item__ttl strong {
    display: block;
    margin-bottom: 12px;
    margin-bottom: min(1.2vw,12px);
    font-family: "RoBodoni";
    font-size: 4.25rem;
    line-height: 1.2;
}

@media only screen and (max-width: 960px) {
    .p-item__ttl strong {
        font-size: 8.4vw;
    }
}

.p-item__ttl small {
    display: block;
    font-family: "ShipporiMincho-Regular";
    font-size: 1.5rem;
    line-height: 1.2;
}

@media only screen and (max-width: 960px) {
    .p-item__ttl small {
        margin-top: 2vw;
        font-size: 3.8vw;
    }
}


.p-item__intro {
    font-size: 1rem;
    line-height: 1.8;
    margin-top: 28px;
    margin-top: min(2.8vw,28px);
}

@media only screen and (max-width: 960px) {
    .p-item__intro {
        font-size: 3.6vw;
        margin-top: 5.3vw;
        text-align: left;
    }
}

.p-series {
    margin-bottom: min(8vw,80px);
}

@media only screen and (max-width: 960px) {
    .p-series {
        margin-bottom: 8vw;
    }
}

.p-series:last-child {
    margin-bottom: 0;
}

.p-series__img {
    width: 70%;
    overflow: hidden;
}

@media only screen and (max-width: 960px) {
    .p-series__img {
        width: 100%;
    }
}

.p-series__img--slide {
    width: 100%;
    height: 654px;
    height: min(654px,38vw);
}

@media only screen and (max-width: 960px) {
    .p-series__img--slide {
        height: 60vw;
    }
}
.p-series__img--slide .swiper-slide {
    z-index: 1;
    position: relative;
    overflow: hidden;
    transform: translate3d(0, 0, 0);
}

.p-series__img--slide .swiper-slide span {
    display: block;
    width: 100%;
    height: 100%;
}

.p-series__img--slide img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.p-series__ttl {
    margin-bottom: 80px;
    margin-bottom: min(8vw,80px);
}

@media only screen and (max-width: 960px) {
    .p-series__ttl {
        margin-bottom: 7vw;
    }
}

.p-series__ttl h4 {
    position: relative;
    color: var(--color_accent01);
    font-family: "RoBodoni";
    z-index: 1;
}

.p-series__ttl.is-reverse h4 {
    text-align: right;
}

.p-series__ttl h4:after {
    content: "";
    position: absolute;
    bottom: 6px;
    left: 0;
    width: 0;
    height: 2px;
    background: var(--color_accent01);
    z-index: -1;
    transition-duration: 2.4s;
    transition-delay: 0.5s;
}

@media only screen and (max-width: 960px) {
    .p-series__ttl h4:after {
        height: 1px;
    }
}

.p-series__ttl.is-active h4:after {
    width: 100%;
}

.p-series__ttl h4 small {
    display: inline-block;
    margin-bottom: 4px;
    font-size: 1.125rem;
}

@media only screen and (max-width: 960px) {
    .p-series__ttl h4 small {
        margin-bottom: -0.2vw;
        font-size: 3.2vw;
    }
}

.p-series__ttl h4 strong {
    position: relative;
    display: inline-block;
    padding-right: 20px;
    font-size: 2.75rem;
    line-height: 1;
    background: #fff;
    z-index: 1;
}

@media only screen and (max-width: 960px) {
    .p-series__ttl h4 strong {
        padding-right: 5.3vw;
        font-size: 5.8vw;
    }
}

.p-series__ttl.is-reverse h4 strong {
    padding-right: 0;
    padding-left: 20px;
}

@media only screen and (max-width: 960px) {
    .p-series__ttl.is-reverse h4 strong {
        padding-left: 4vw;
    }
}

.p-series__flex {
    display: flex;
    align-items: flex-start;
    gap: min(6vw,60px);
    margin-bottom: 80px;
    margin-bottom: min(8vw,80px);
}

@media only screen and (max-width: 960px) {
    .p-series__flex {
        flex-direction: column;
        gap: 5.3vw;
        margin-bottom: 8vw;
    }
}

.p-series__flex:last-child {
    margin-bottom: 0;
}

.p-series__flex.is-reverse {
    flex-direction: row-reverse;
}

@media only screen and (max-width: 960px) {
    .p-series__flex.is-reverse {
        flex-direction: column;
    }
}

.p-series__txt {
    max-width: 500px;
    min-width: 380px;
    width: 35%;
    margin-top: auto;
    padding-bottom: 32px;
    padding-bottom: min(2vw,32px);
}

@media only screen and (max-width: 960px) {
    .p-series__txt {
        max-width: 100%;
        width: 100%;
        min-width: inherit;
        padding-bottom: 0;
    }
}

.p-series__name {
    position: relative;
    padding-bottom: 32px;
    font-size: 1.5rem;
    letter-spacing: -0.01em;
    line-height: 1.4;
    font-family: "ShipporiMincho-Regular";
}

@media only screen and (max-width: 960px) {
    .p-series__name {
        padding-bottom: 5.3vw;
        font-size: 4.8vw;
    }
}

.p-series__name:after {
    position: absolute;
    bottom: 0;
    left: 0;
    content: "";
    width: 40px;
    height: 1px;
    background: #000;
}

@media only screen and (max-width: 960px) {
    .p-series__name:after {
        width: 6vw;
    }
}


.p-series__desc {
    padding: 32px 0;
    font-size: 1rem;
    line-height: 1.8;
}

@media only screen and (max-width: 960px) {
    .p-series__desc {
        padding: 5.3vw 0 5.3vw;
        font-size: 3.6vw;
    }
}

.p-series__info {
    display: block;
    max-width: 220px;
    width: 55%;
    margin: 0 0 45px;
    margin: 0 0 min(4vw,45px);
}

@media only screen and (max-width: 960px) {
    .p-series__info {
        max-width: 66%;
        width: 66%;
        margin: 0 0 6.8vw;
    }
}

.p-series__infoList {
    display: flex;
    gap: 10px; 
    margin-top: 10px;
}

@media only screen and (max-width: 960px) {
    .p-series__infoList {
        margin-top: 1.6vw;
    }
}

.p-series__infoItem {
    max-width: 132px;
    width: 50%;
    padding: 8px 5px 8px;
    border-radius: 3px;
    color: #fff;
    font-size: 1.5rem;
    line-height: 1;
    text-align: center;
    background: #555555;
}

.p-series__infoItem span {
    font-size: 0.875rem;
}

@media only screen and (max-width: 960px) {
    .p-series__infoItem {
        max-width: 50%;
        padding: 2.8vw 1.8vw;
        font-size: 4.8vw;
    }
    .p-series__infoItem span {
        font-size: 3.2vw;
    }
}

.p-series__infoItem small {
    display: block;
    margin-bottom: 2px;
    font-size: 0.75rem;
    line-height: 1.2;
}

@media only screen and (max-width: 960px) {
    .p-series__infoItem small {
        font-size: 3vw;
        margin-bottom: 1.2vw;
    }
}
.p-credit {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 5%;
    padding: min(4vw,40px) 0 min(4vw,40px);
    border-top: 1px solid #dddddd;
}

@media only screen and (max-width: 960px) {
    .p-credit {
        gap: 3.8vw;
        padding: 5.3vw 0 0;
    }
}

.p-credit li p {
    margin-bottom: 12px;
    line-height: 1.6;
}

@media only screen and (max-width: 960px) {
    .p-credit li p {
        margin-bottom: 2vw;
        font-size: 3.6vw;
    }
}

.p-credit li a {
    display: flex;
    align-items: flex-start;
    align-items: center;
    justify-content: space-between;
    gap: 6px;
}

.p-credit li a.is-reserve {
    pointer-events: none;
}

.p-credit__name {
    font-size: 1rem;
    line-height: 1.4;
}

@media only screen and (max-width: 960px) {
    .p-credit__name {
        font-size: 3.6vw;
    }
}

.p-credit__name em {
    display: inline-flex;
    align-items: flex-end;
}

.p-credit__name strong {
    font-size: 1.275rem;
    font-family: "RoBodoni";
}

@media only screen and (max-width: 960px) {
    .p-credit__name strong {
        font-size: 5.4vw;
    }
}
.p-credit__name strong.ja {
    font-size: 1rem;
    font-family: "ShipporiMincho-Regular";
}

@media only screen and (max-width: 960px) {
    .p-credit__name strong.ja {
        font-size: 3.6vw;
    }
}

.p-credit__name b {
    font-size: 0.875rem;
}

@media only screen and (max-width: 960px) {
    .p-credit__name b {
        font-size: 3.2vw;
    }
}

.p-credit__name small {
    font-size: 0.75rem;
    line-height: 2;
    white-space: nowrap;
}

@media only screen and (max-width: 960px) {
    .p-credit__name small {
        font-size: 3vw;
        line-height: 2;
    }
}

.p-credit__btn {
    position: relative;
    display: inline-block;
    min-width: 78px;
    padding: 4px 6px 5px;
    text-align: center;
    border: 1px solid var(--bg_btn02);
    background: var(--bg_btn02);
    color: var(--bg_btn02);
    line-height: 1;
    white-space: nowrap;
    transition-duration: 0.3s;
    z-index: 1;
    overflow: hidden;
}

@media only screen and (max-width: 960px) {
    .p-credit__btn {
        min-width: 19vw;
        padding: 1.8vw 1.2vw 2vw;
    }
}

@media only screen and (max-width: 480px) {
    .p-credit__btn {
        padding: 1.8vw 1.2vw 2.2vw;
    }
}
.p-credit__btn:before {
    display: inline-block;
    content: "ONLINE";
    font-size: 0.875rem;
    font-weight: 400;
    line-height: 1;
}

@media only screen and (max-width: 960px) {
    .p-credit__btn:before {
        font-size: 3.2vw;
    }
}

.p-credit__btn.is-reserve {
    min-width: 125px;
    border: 1px solid var(--bg_btn01);
    background: var(--bg_btn01);
    color: var(--bg_btn01);
}

.p-credit__btn.is-reserve:before {
    content: "5\6708\4E2D\65EC\767A\58F2\4E88\5B9A";
}

.p-credit__btn.is-contact {
    border: 1px solid var(--color_main);
    background: var(--color_main);
    color: var(--color_main);
}

.p-credit__btn.is-contact:before {
    content: "CONTACT";
}

.p-credit__btn:after {
    position: absolute;
    top: 0;
    left: 0;
    content: "";
    width: 100%;
    height: 100%;
    background: #fff;
    z-index: -1;
}

.p-credit li a:hover .p-credit__btn {
    color: #fff;
    background: #b4a969;
    border: 1px solid #b4a969;
}

.p-credit li a:hover .p-credit__btn.is-contact {
    color: #fff;
    background: var(--color_main);
    border: 1px solid var(--color_main);
}

.p-credit li a:hover .p-credit__btn:after {
    animation: btn-anim2 650ms cubic-bezier(0.4, 1, 0.3, 1) forwards;
}

.p-credit li.mt {
    margin-top: 20px;
}

@media only screen and (max-width: 960px) {
    .p-credit li.mt {
        margin-top: 3vw;
    }
}

.p-coordinate {
    padding: 0 5%;
    padding: 0 min(8vw,80px) min(12vw,120px);
}

@media only screen and (max-width: 1200px) {
    .p-coordinate {
        padding: 0 5%;
        padding: 0 min(4vw,40px) min(12vw,120px);
    }
}

@media only screen and (max-width: 960px) {
    .p-coordinate {
        padding: 0 5%;
        padding: 0 5.3vw min(10vw,100px);
    }
}

.p-coordinate__head {
    padding: 5% 0;
    padding: min(7vw,70px) 0;
    text-align: center;
}

@media only screen and (max-width: 960px) {
    .p-coordinate__head {
        padding: 8vw 0;
    }
}

.p-coordinate__catch {
    margin-bottom: 26px;
    font-size: 1.5rem;
    font-family: "RoBodoni";
}

@media only screen and (max-width: 960px) {
    .p-coordinate__catch {
        margin-bottom: 3.2vw;
        font-size: 3.6vw;
    }
}

.p-coordinate__ttl {
    font-size: 2.75rem;
    line-height: 1.2;
    font-family: "ShipporiMincho-Regular";
}

@media only screen and (max-width: 960px) {
    .p-coordinate__ttl {
        margin-bottom: 4vw;
        font-size: 4.8vw;
        line-height: 1.4;
    }
}

.p-coordinate__top {
    position: relative;
    display: flex;
    align-items: center;
    z-index: 1;
    margin-bottom: 20px;
    margin-bottom: min(2vw,20px);
    padding-right: 15%;
}

@media only screen and (max-width: 1200px) {
    .p-coordinate__top {
        margin-bottom: 40px;
        padding-right: 2%;
    }
}

@media only screen and (max-width: 960px) {
    .p-coordinate__top {
        flex-direction: column;
        gap: 4vw;
        margin-bottom: 8vw;
        padding-right: 0;
    }
}

.p-coordinate__top:after {
    position: absolute;
    top: 40px;
    left: 0;
    content: "";
    width: 100vw;
    height: 100%;
    margin-right: calc(50% - 50vw);
    margin-left: calc(50% - 50vw);
    padding-right: calc(50vw - 50%);
    padding-left: calc(50vw - 50%);
    background: #f2f2f2;
    z-index: -1;
}

@media only screen and (max-width: 1200px) {
    .p-coordinate__top:after {
        top: 3vw;
        height: 110%;
    }
}

@media only screen and (max-width: 960px) {
    .p-coordinate__top:after {
        top: 5.3vw;
        height: 138vw;
    }
}

.p-coordinate__top .p-coordinate__img {
    width: 58.2%;
    overflow: hidden;
}


@media only screen and (max-width: 960px) {
    .p-coordinate__top .p-coordinate__img {
        width: 100%;
    }
}

.p-coordinate__top .p-coordinate__txt {
    position: relative;
    top: 10px;
    width: 41.8%;
    min-width: 565px;
    padding: 0 5%;
    padding: 0 min(8vw,80px);
}

@media only screen and (max-width: 1200px) {
    .p-coordinate__top .p-coordinate__txt {
        padding: 0 5%;
        padding: 0 min(4vw,40px);
        min-width: 430px;
    }
}

@media only screen and (max-width: 960px) {
    .p-coordinate__top .p-coordinate__txt {
        width: 100%;
        min-width: auto;
        top: 0;
        padding: 0;
    }
}

.p-coordinate__btm {
    position: relative;
    display: flex;
    align-items: flex-end;
    flex-direction: row-reverse;
    z-index: 1;
    padding-right: 15%;
}

@media only screen and (max-width: 1200px) {
    .p-coordinate__btm {
        padding-right: 2%;
    }
}

@media only screen and (max-width: 960px) {
    .p-coordinate__btm {
        flex-direction: column;
        gap: 5.3vw;
        padding-right: 0;
    }
}

.p-coordinate__btm .p-coordinate__img {
    width: 41.8%;
    min-width: 565px;
    padding: 0 80px;
    padding: 0 min(8vw,80px);
    overflow: hidden;
}

@media only screen and (max-width: 1200px) {
    .p-coordinate__btm .p-coordinate__img {
        padding: 0 40px;
        padding: 0 min(4vw,40px);
        min-width: 430px;
    }
}

@media only screen and (max-width: 960px) {
    .p-coordinate__btm .p-coordinate__img {
        width: 100%;
        min-width: inherit;
        padding: 0;
    }
}

.p-coordinate__btm .p-coordinate__txt {
    width: 58.2%;
    padding-left: 9%;
}

@media only screen and (max-width: 960px) {
    .p-coordinate__btm .p-coordinate__txt {
        width: 100%;
        padding: 0;
    }
}

.p-coordinate__subttl {
    margin-bottom: 32px;
    margin-bottom: min(2.8vw,32px);
    font-size: 1.7rem;
    line-height: 1.4;
    letter-spacing: -0.02em;
    font-family: "ShipporiMincho-Regular";
}

@media only screen and (max-width: 960px) {
    .p-coordinate__subttl {
        margin-bottom: 5.3vw;
        font-size: 4.8vw;
        text-align: center;
    }
}

.p-coordinate__list {
    display: flex;
    flex-direction: column;
    gap: min(1.2vw,18px);
}

@media only screen and (max-width: 960px) {
    .p-coordinate__list {
        gap: 2vw;
    }
}

.p-coordinate__list li {
    position: relative;
    padding-left:45px ;
    padding-left: min(3.6vw,45px);
    line-height: 1.6;
    opacity: 0;
}

@media only screen and (max-width: 960px) {
    .p-coordinate__list li {
        padding-left: 6.2vw;
        font-size: 3.6vw;
    }
}

.p-coordinate__list li:before {
    position: absolute;
    top: -2px;
    left: 0;
    content: "";
    width: 28px;
    width: min(2.2vw,28px);
    height: 28px;
    height: min(2.2vw,28px);
    border: 2px solid #000;
}

@media only screen and (max-width: 960px) {
    .p-coordinate__list li:before {
        top: 0.6vw;
        width: 4.2vw;
        height: 4.2vw;
        border: 1px solid #000;
    }
}

.p-coordinate__list li:after {
    position: absolute;
    top: -5px;
    left: 2px;
    content: "";
    width: 30px;
    width: min(2.8vw,30px);
    height: 30px;
    height: min(2.8vw,30px);
    background: url(../images/common/icon-check.png) no-repeat;
    background-size: 100%;
    clip-path: inset(0 100% 0 0);
    transition-duration: 0.4s;
}

@media only screen and (max-width: 960px) {
    .p-coordinate__list li:after {
        top: 0.6vw;
        width: 4.4vw;
        height: 4.4vw;
    }
}

.p-coordinate__list li.is-active:after {
    clip-path: inset(0 0 0 0);
}


.p-coordinate__desc {
    font-size: 1rem;
    line-height: 1.8;
}

@media only screen and (max-width: 960px) {
    .p-coordinate__desc {
        font-size: 3.6vw;
    }
}

.p-shop {
    padding: 0 5% 5%;
    padding: 0 min(8vw,80px) min(7vw,70px);
    background: #f3f3f3;
}

@media only screen and (max-width: 1200px) {
    .p-shop {
        padding: 0 5%;
        padding: 0 min(4vw,40px) min(7vw,70px);
    }
}

@media only screen and (max-width: 960px) {
    .p-shop {
        padding: 0 5.3vw 8vw;
    }
}

.p-shop__head {
    padding: 5% 0;
    padding: min(7vw,70px) 0;
    text-align: center;
}

@media only screen and (max-width: 960px) {
    .p-shop__head {
        padding: 8vw 0;
    }
}

.p-shop__catch {
    margin-bottom: 5%;
    margin-bottom: min(2.6vw,26px);
    font-size: 1.5rem;
    font-family: "RoBodoni";
}

@media only screen and (max-width: 960px) {
    .p-shop__catch {
        margin-bottom: 2.8vw;
        font-size: 3.6vw;
    }
}

.p-shop__ttl {
    font-size: 2.75rem;
    line-height: 1.2;
    font-family: "ShipporiMincho-Regular";
}

@media only screen and (max-width: 960px) {
    .p-shop__ttl {
        font-size: 5.8vw;
    }
}

.p-shop__list {
    display: flex;
    flex-wrap: wrap;
    gap: 2%;
    gap: min(4vw,40px);
}

@media only screen and (max-width: 960px) {
    .p-shop__list {
        flex-direction: column;
        gap: 5.3vw;
    }
}

.p-shop__item {
    position: relative;
    width: calc((90%) / 4);
    width: calc((100% - min(12vw,120px)) / 4);
    background: #fff;
}

@media only screen and (max-width: 960px) {
    .p-shop__item {
        width: 100%;
    }
}

.p-shop__img {
    position: relative;
    overflow: hidden;
}

.p-shop__img img {
    vertical-align: middle;
    width: 100%;
}

.p-shop__img i {
    position: absolute;
    top: 10px;
    padding: 2px 8px;
    color: #fff;
    background: var(--color_accent01);
    text-align: center;
    font-size: 0.875rem;
    z-index: 1;
}

@media only screen and (max-width: 960px) {
    .p-shop__img i {
        top: 2.8vw;
        padding: 0.8vw 2vw;
        font-size: 3.2vw;
        line-height: 1;
    }
}

.p-shop__txt {
    padding: 30px min(1.6vw,20px);
    background: #fff;
    text-align: center;
}

@media only screen and (max-width: 960px) {
    .p-shop__txt {
        padding: 4vw 5vw;
    }
}

.p-shop__name {
    margin-bottom: 16px;
    font-size: 1.125rem;
    line-height: 1.4;
    min-height: 48px;
}

@media only screen and (max-width: 960px) {
    .p-shop__name {
        min-height: inherit;
        margin-bottom: 3.2vw;
        font-size: 4.4vw;
    }
}

.p-shop__addr {
    font-size: 0.875rem;
    line-height: 1.8;
    min-height: 89px;
}

@media only screen and (max-width: 960px) {
    .p-shop__addr {
        min-height: inherit;
        font-size: 3.6vw;
        text-align: left;
    }
}

.p-shop__btn {
    position: relative;
    display: inline-block;
    margin-top: 16px;
    padding: 11px min(0.8vw,17px); 
    font-size: 0.875rem;
    border: 1px solid var(--color_main);
    background: var(--color_main);
    z-index: 1;
    overflow: hidden;
}

@media only screen and (max-width: 960px) {
    .p-shop__btn {
        display: none;
    }
}

.p-shop__btn:after {
    position: absolute;
    top: 0;
    left: 0;
    content: "";
    width: 100%;
    height: 100%;
    background: var(--color_bg);
    z-index: -1;
}

.p-shop__item {
    opacity: 0;
}

.p-shop__item a:hover .p-shop__btn {
    color: var(--color_bg);
}

.p-shop__btn i {
    display: inline-block;
    margin-left: 5%;
    margin-left: min(0.8vw,12px);
    width: 16px;
    height: 16px;
    background: url(../images/common/icon-arrow-black.svg) no-repeat;
    background-size: 100%;
    vertical-align: -2px;
}

.p-shop__item a:hover .p-shop__btn i {
    background: url(../images/common/icon-arrow-white.svg) no-repeat;
    background-size: 100%;
    animation: btn-anim 850ms cubic-bezier(0.4, 1, 0.3, 1) forwards;
}

.p-shop__item a:hover .p-shop__btn:after {
    animation: btn-anim2 650ms cubic-bezier(0.4, 1, 0.3, 1) forwards;
}

@media only screen and (max-width: 960px) {
    .p-shop__item a:after {
        content: "";
        position: absolute;
        right: 5.3vw;
        bottom: 5.3vw;
        display: inline-block;
        width: 4vw;
        height: 4vw;
        background: url(../images/common/icon-arrow-black.svg) no-repeat;
        background-size: 100%;
    }
}

.p-bnr {
    padding: 5%;
    padding: min(4vw,40px) min(8vw,80px) min(4vw,40px);
    background: #f7f2ee;
}

@media only screen and (max-width: 1200px) {
    .p-bnr {
        padding: 5%;
        padding: min(4vw,40px) min(4vw,40px) min(4vw,40px);
    }
}

@media only screen and (max-width: 960px) {
    .p-bnr {
        padding: 5.3vw 5.3vw 5.3vw;
    }
}

.p-bnr__desc {
    max-width: 1020px;
    margin: 40px auto;
    font-size: 1rem;
    line-height: 1.8;
}

@media only screen and (max-width: 960px) {
    .p-bnr__desc {
        margin: 8vw auto;
        font-size: 3.6vw;
        line-height: 1.6;
    }

}

.p-bnr__coupon {
    display: flex;
    max-width: 1020px;
    margin: 0 auto;
    background: var(--color_bg);
    border: 2px solid var(--color_accent02);
    color: #000;
    padding: 0;
}

@media only screen and (max-width: 960px) {
    .p-bnr__coupon {
        display: block;
        background: inherit;
        border: 0;
    }
}

.p-bnr__coupon li {
    width: 50%;
    padding: 10px 10px 16px;
}

@media only screen and (max-width: 960px) {
    .p-bnr__coupon li {
        width: 100%;
        margin-bottom: 5.3vw;
        padding: 2.8vw;
        background: var(--color_bg);
        border: 2px solid var(--color_accent02);
    }
}

.p-bnr__coupon li:first-child {
    border-right: 2px solid var(--color_accent02);
}

@media only screen and (max-width: 960px) {
    .p-bnr__coupon li:last-child {
        margin-bottom: 0;
    }
}

.p-bnr__couponFlex {
    display: flex;
}

.p-bnr__couponItem {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: 50%;
    padding: 5%;
    padding: min(1.2vw,13px) min(1vw,10px);
    text-align: center;
}

@media only screen and (max-width: 960px) {
    .p-bnr__couponItem {
        padding: 1.8vw 2.8vw;
    }
}

.p-bnr__couponItem:first-child {
    width: 50%;
    border-right: 1px solid var(--color_main);
}

@media only screen and (max-width: 960px) {
    .p-bnr__couponItem:first-child {
        width: 45%;
    }
}

.p-bnr__couponItem:last-child {
    width: 50%;
}

@media only screen and (max-width: 960px) {
    .p-bnr__couponItem:last-child {
        width: 55%;
    }
}

.p-bnr__couponItem p {
    margin-bottom: 12px;
    font-size: 1rem;
    font-family: "ShipporiMincho-Regular";
}

@media only screen and (max-width: 960px) {
    .p-bnr__couponItem p {
        margin-bottom: 1.8vw;
        font-size: 4vw;
    }
}

.p-bnr__couponItem .per img {
    vertical-align: middle;
}

.p-bnr__couponItem:first-child .per {
    width: 48%;
    margin: 0 auto;
}

@media only screen and (max-width: 960px) {
    .p-bnr__couponItem:first-child .per {
        width: 88%;
        margin: 6px auto 0;
    }
}

.p-bnr__couponItem:last-child .per {
    width: 70%;
    margin: 0 auto;
}

@media only screen and (max-width: 960px) {
    .p-bnr__couponItem:last-child .per {
        width: 93%;
    }
}

.p-bnr__couponBtm {
    margin-top: 16px;
    margin-top: min(1.6vw,16px);
    line-height: 1.2;
    font-size: 0.875rem;
    font-family: "ShipporiMincho-Regular";
    text-align: center;
}

@media only screen and (max-width: 960px) {
    .p-bnr__couponBtm {
        margin-top: 2.8vw;
        font-size: 3.8vw;
        line-height: 1.2;
    }
}

.p-bnr__couponDay {
    display: block;
    margin-bottom: 20px;
    margin-bottom: min(1vw,20px);
    padding: 5px;
    padding: min(0.8vw,4px) min(0.5vw,5px);
    text-align: center;
    color: #fff;
    font-size: 1.375rem;
    line-height: 1.4;
    letter-spacing: -0.02em;
    font-family: "ShipporiMincho-Regular";
}

@media only screen and (max-width: 960px) {
    .p-bnr__couponDay {
        margin-bottom: 2.8vw;
        padding: 0.6vw 5vw;
        font-size: 4.4vw;
        letter-spacing: 0.02em;
    }
}

.p-bnr__couponDay.is-blue {
    background: var(--color_accent01);
}

.p-bnr__couponDay.is-brown {
    background: var(--color_accent02);
}

@media only screen and (max-width: 960px) {
    .p-bnr__coupon.is-1col {
        border-right: 2px solid var(--color_accent02);
    }
}

.p-bnr__coupon.is-1col li {
    width: 100%;
    padding: 0;
    border-right: 0;
}

.p-bnr__coupon.is-1col .p-bnr__couponDay {
    margin-bottom: 0;
    font-size: 1.75rem;
    letter-spacing: 0.1em;
    line-height: 1.2;
}

@media only screen and (max-width: 960px) {
    .p-bnr__coupon.is-1col .p-bnr__couponDay {
        padding: 1.2vw 1.2vw 1.2vw;
        font-size: 4.4vw;
        letter-spacing: 0.08em;
    }
}

.p-bnr__coupon.is-1col .p-bnr__couponItem {
    padding: 24px;
    padding: min(2vw,24px) min(2vw,24px);
}

@media only screen and (max-width: 960px) {
    .p-bnr__coupon.is-1col .p-bnr__couponItem {
        padding: 3.2vw 2vw 3.2vw;
    }
}

.p-bnr__coupon.is-1col .p-bnr__couponItem p {
    margin-bottom: 0;
    line-height: 1.2;
    font-size: 1.5625rem;
    color: var(--color_accent02)
}

.p-bnr__coupon.is-1col .p-bnr__couponItem p:first-child {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
}

@media only screen and (max-width: 960px) {
    .p-bnr__coupon.is-1col .p-bnr__couponItem p {
        margin-bottom: 0.8vw;
        font-size: 3vw;
    }
}

.p-bnr__coupon.is-1col .p-bnr__couponItem:first-child {
    width: 50%;
    margin: 0 auto;
    border-right: 1px solid var(--color_accent02);
}

.p-bnr__coupon.is-1col .p-bnr__couponItem:nth-child(2n) {
    width: 50%;
    margin: 0 auto;
    border-right: 1px solid var(--color_accent02);
}

.p-bnr__coupon.is-1col .p-bnr__couponItem:last-child {
    width: 50%;
    margin: 0 auto;
}

.p-bnr__coupon.is-1col .p-bnr__couponItem:first-child .per {
    width: 63%;
    margin: 5% auto 0;
    margin: min(2vw, 5px) auto 0;
}

.p-bnr__coupon.is-1col .p-bnr__couponItem:nth-child(2n) .per {
    width: 50%;
    margin: 22px auto 0;
    margin: min(2vw,22px) auto 0;
}

@media only screen and (max-width: 960px) {
    .p-bnr__coupon.is-1col .p-bnr__couponItem:first-child .per {
        width: 100%;
        margin: 0.5vw auto 0;
    }
    .p-bnr__coupon.is-1col .p-bnr__couponItem:nth-child(2n) .per {
        width: 71%;
        margin: 22px auto 0;
        margin: min(2vw,22px) auto 0;
    }
}
.p-bnr__coupon.is-1col .p-bnr__couponItem:last-child .per {
    width: 50%;
    margin: 22px auto 0;
    margin: min(2vw,22px) auto 0;
}

@media only screen and (max-width: 960px) {
    .p-bnr__coupon.is-1col .p-bnr__couponItem:last-child .per {
        width: 71%;
        margin: 2vw auto 0;
    }
}

.p-bnr__btn {
    margin-top: 40px;
    margin-top: min(4vw, 40px);
    line-height: 1;
}

.p-mv__icon {
    position: absolute;
    right: 20px;
    bottom: 20px;
    width:  120px;
    z-index: 2;
}

@media only screen and (max-width: 960px) {
    .p-mv__icon {
        right: 4.8vw;
        top: 4.8vw;
        bottom: inherit;
        width:  20vw;
    }
}


@media only screen and (max-width: 960px) {
    .p-others__top {
        display: flex;
        flex-direction: column-reverse;
    }
}

.p-others__ttl {
    margin-bottom: 80px;
    margin-bottom: min(8vw, 80px);
}

@media only screen and (max-width: 960px) {
    .p-others__ttl {
        margin-bottom: 7vw;
    }
}

.p-others__ttl h4 {
    position: relative;
    color: var(--color_accent01);
    font-family: "RoBodoni";
    z-index: 1;
}

.p-others__ttl.is-reverse h4 {
    text-align: right;
}

.p-others__ttl h4:after {
    content: "";
    position: absolute;
    bottom: 6px;
    left: 0;
    width: 0;
    height: 2px;
    background: var(--color_accent01);
    z-index: -1;
    transition-duration: 2.4s;
    transition-delay: 0.5s;
}

@media only screen and (max-width: 960px) {
    .p-others__ttl h4:after {
        height: 1px;
    }
}

.p-others__ttl.is-active h4:after {
    width: 100%;
}

.p-others__ttl h4 small {
    display: inline-block;
    margin-bottom: 4px;
    font-size: 1.125rem;
}

@media only screen and (max-width: 960px) {
    .p-others__ttl h4 small {
        margin-bottom: -0.2vw;
        font-size: 3.2vw;
    }
}

.p-others__ttl h4 strong {
    position: relative;
    display: inline-block;
    padding-right: 20px;
    font-size: 2.75rem;
    line-height: 1;
    background: #fff;
    z-index: 1;
}

@media only screen and (max-width: 960px) {
    .p-others__ttl h4 strong {
        padding-right: 5.3vw;
        font-size: 5.8vw;
    }
}

.p-others__ttl.is-reverse h4 strong {
    padding-right: 0;
    padding-left: 20px;
}

@media only screen and (max-width: 960px) {
    .p-others__ttl.is-reverse h4 strong {
        padding-left: 4vw;
    }
}

.p-others__flex {
    display: flex;
    gap: 60px;
}

@media only screen and (max-width: 960px) {
    .p-others__flex {
        flex-direction: column;
        gap: 8vw;
    }
}

.p-others__item {
    width: calc((100% - 60px) / 3);
}

@media only screen and (max-width: 960px) {
    .p-others__item {
        width: 100%;
    }
}

.p-others__item .p-credit {
    min-height: 148px;
    min-height: min(10vw,148px);
}

@media only screen and (max-width: 960px) {
    .p-others__item .p-credit {
        min-height: inherit;
    }
}

.p-others__name {
    position: relative;
    padding-bottom: 30px;
    padding-bottom: min(2.4vw,30px)
}

@media only screen and (max-width: 960px) {
    .p-others__name {
        margin-bottom: 5.3vw;
        padding-bottom: 5.3vw;
    }
}

.p-others__name:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 40px;
    height: 1px;
    background: #000;
}

@media only screen and (max-width: 960px) {
    .p-others__name:after {
        width: 6vw;
    }
}

.p-others__name h4 {
    margin-bottom: 6px;
    margin-bottom: min(0.6vw,6px);
    font-size: 1rem;
    font-family: "ShipporiMincho-Regular";
    line-height: 1.6;
}

@media only screen and (max-width: 960px) {
    .p-others__name h4 {
        margin-bottom: 0;
        font-size: 3.6vw;
    }
}

.p-others__name h3 {
    font-size: 1.5rem;
    font-family: "ShipporiMincho-Regular";
    line-height: 1.4;
}

@media only screen and (max-width: 960px) {
    .p-others__name h3 {
        font-size: 4.8vw;
    }
}

.p-others__img {
    margin-top: 40px;
    margin-top: min(4vw,40px);
    margin-bottom: 20px;
    margin-bottom: min(2vw,20px);
}

@media only screen and (max-width: 960px) {
    .p-others__img {
        margin-bottom: 4vw;
    }
}

.p-others__desc {
    margin-bottom: 40px;
    margin-bottom: min(4vw,40px);
    font-size: 1rem;
    line-height: 1.8;
}

@media only screen and (max-width: 960px) {
    .p-others__desc {
        margin-bottom: 5.3vw;
        font-size: 3.6vw;
    }
}

.p-others__info {
    min-height: 58px;
    min-height: min(5vw, 58px);
    margin-bottom: 40px;
    font-size: 1rem;
    line-height: 1.8;
}

@media only screen and (max-width: 960px) {
    .p-others__info {
        min-height: inherit;
        margin-bottom: 5vw;
        font-size: 3.6vw;
    }
}

a {
    color:initial;
    text-decoration: none; /* 下線を消したい場合 */
  }
  a:visited {
    color: initial; /* 訪問済みリンクも黒に */
  }