.txtJp{
    position: relative;
    margin: 0 auto;
    z-index: 10;
}
.txtJp img{
    position: relative;
    z-index: 9;
}
.txtJp::after{
    content: "";
    width: 70rem;
    height: 1.65rem;
    background: var(--colorWhite);
    position: absolute;
    bottom: 0.3rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 8;
}
@media only screen and (max-width:1215px){
    .txtJp::after{
        width: 8rem;
        height: 0.8rem;
        bottom: -0.3rem;
    }
}

/* secHero */
.secHero{
    height: 26rem;
    background: url(../img/menu/bgHero.jpg) center top / cover;
    display: flex;
    align-items: center;
}
.secHero .txtJpImg{
    margin-top: 2rem;
}
@media only screen and (max-width:1215px){
    .secHero{
        height: 10rem;
        background: url(../img/menu/bgHero_sp.jpg) center top / cover;
        display: flex;
        align-items: center;
    }
    .secHero .titEngImg{
        width: 18.2rem;
    }
    .secHero .txtJpImg{
        width: 13.3rem;
        margin-top: 1.5rem;
    }
}

/* secTopSlider */
.secTopSlider .boxSlider{
    position: relative;
}
.secTopSlider .swiper{
    overflow: visible;
}
.secTopSlider .swiper-button-prev,
.secTopSlider .swiper-button-next{
    width: 5rem;
    height: 5rem;
    margin-top: 0;
    top: calc(50% - 2.5rem);
    border-radius: 2.5rem;
}
.secTopSlider .swiper-button-prev{
    left: -7rem;
    transform: rotate(180deg);
}
.secTopSlider .swiper-button-next{
    right: -7rem;
}
.secTopSlider .swiper-button-prev::after,
.secTopSlider .swiper-button-next::after{
    display: none;
}
.secTopSlider .swiper-button-prev.lazyloaded{
    background: url(../img/menu/iconArrow.png) 2rem center / 0.8rem auto no-repeat var(--colorBgNextPrevBtn);
}
.secTopSlider .swiper-button-next.lazyloaded{
    background: url(../img/menu/iconArrow.png) 2rem center / 0.8rem auto no-repeat var(--colorBgNextPrevBtn);
}
.secTopSlider .imgSlider{
    display: block;
    height: 0;
    padding-top: 57.728%;
}
.secTopSlider .swiper-pagination{
	bottom: 3rem !important;
}
.secTopSlider .swiper-pagination-bullet{
    background: var(--colocPaginationOff);
    margin: 0 0.5rem!important;
    opacity: 1;
    width: 1rem;
    height: 1rem;
    border-radius: 0.5rem;
}
.secTopSlider .swiper-pagination-bullet-active{
    background: var(--colocPaginationOn);
}
@media only screen and (max-width:1215px){
    .secTopSlider .swiper-button-prev,
    .secTopSlider .swiper-button-next{
        display: none;
    }
    .secTopSlider .swiper-pagination{
        bottom: -1.5rem !important;
    }
    .secTopSlider .swiper-pagination-bullet{
        margin: 0 0.3rem!important;
        width: 0.5rem;
        height: 0.5rem;
        border-radius: 0.25rem;
    }
}

/* secPrice */
.secPrice{
    margin-top: 12.1rem;
    text-align: center;
}
.secPrice .txtJp::after{
    width: 19rem;
    background: var(--colorTitUnderLine);
}
.secPrice .txtAbout{
    font-size: var(--pcFontSize20);
    line-height: var(--pcLineHeight20_39);
    margin-top: 3.9rem;
}
.secPrice .boxTable{
    margin-top: 3.9rem;
    background: var(--colorBgTable);
    font-size: var(--pcFontSize22);
}
.secPrice .boxTr{
    border-bottom:  0.1rem solid var(--colorBorder);
}
.secPrice .boxTr:first-child{
    border-top:  0.1rem solid var(--colorBorder);
}
.secPrice .boxTr:nth-child(2n){
    background: var(--colorWhite);
}
.secPrice .boxTh{
    width: 35rem;
    padding: 1.9rem 0 1.8rem 3rem;
    font-weight: 500;
}
.secPrice .boxTr:first-child .boxTh{
    text-align: center;
}
.secPrice .boxTd{
    width: 28.3rem;
    padding: 1.9rem 0 1.8rem;
}
@media only screen and (max-width:1215px){
    .secPrice{
        margin-top: 3rem;
        margin-bottom: 5rem;
    }
    .secPrice .txtJp{
        width: 6.6rem;
    }
    .secPrice .txtJp::after{
        width: 8rem;
    }
    .secPrice .txtAbout{
        font-size: var(--spFontSize12);
        line-height: var(--spLineHeight12_22);
        margin-top: 2rem;
    }
    .secPrice .boxTableScroll{
        position: relative;
        width: 100%;
        height: 100%;
        overflow-x: auto;
        overflow-y: hidden;
        -ms-overflow-style: none;
        scrollbar-width: none;
        margin-left: 3rem;
    }
    .secPrice .boxTable{
        width: 57rem;
        margin-top: 1.1rem;
        font-size: var(--spFontSize12);
    }
    .secPrice .boxTh{
        width: 18rem;
        padding: 0.9rem 0 0.8rem 1.5rem;
    }
    .secPrice .boxTd{
        width: 13rem;
        padding: 0.9rem 0 0.8rem;
    }

}
/* scrollItem */
@media only screen and (min-width:1216px){
	.scrollItem::before{
		display: none;
	}
}
@media only screen and (max-width:1215px){
    .scrollItem{
        position: relative;
        width: 100%;
        height: 100%;
        overflow-x: auto;
        overflow-y: hidden;
        -ms-overflow-style: none;
        scrollbar-width: none;
    }
    .scrollItem::-webkit-scrollbar{
        display: none;
    }
    .scrollItem::before{
        content: "";
        display: block;
        width: 100%;
        height: 100%;
        position: absolute;
        top: 0;
        left: 0;
        background: url(../img/common/iconScroll.png) center center / 11rem auto no-repeat;
        transition: all 0.2s ease-out 0.2s;
        animation: scrollItemAnimation 1s linear infinite;
        z-index: 10;
        pointer-events: none;
    }
    .scrollItem.scrolled::before{
        opacity: 0;
    }
    @keyframes scrollItemAnimation {
        0%   { transform:translateX(0); }
        25%   { transform:translateX(1rem) }
        50% { transform:translateX(0); }
        75% { transform:translateX(-1rem); }
        100% { transform:translateX(0); }
    }
}

/* secSet */
.secSet{
    text-align: center;
    position: relative;
    margin-top: 28rem;
    padding-top: 4.9rem;
    padding-bottom: 10rem;
}
.secSet.lazyloaded{
    background-image: url(../img/common/bgDot.png);
    background-repeat: repeat;
    background-size: auto;
}
.secSet.lazyloaded::before{
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 21rem;
    background-image: url(../img/common/bgDot.png);
    background-repeat: repeat;
    background-size: auto;
    transform-origin: top right;
    transform: skewY(6deg);
    z-index: 1;
}
.secSet.lazyloaded::after{
    content: "";
    position: absolute;
    bottom: -0;
    left: 0;
    width: 100%;
    height: 21rem;
    background-image: url(../img/common/bgDot.png);
    background-repeat: repeat;
    background-size: auto;
    transform-origin: top left;
    transform: skewY(6deg);
    z-index: 1;
}
.secSet .txtJp::after{
    width: 54rem;
}
@media only screen and (max-width:1215px){
    .secSet{
        margin-top: 8rem;
        padding-top: 3.4rem;
        padding-bottom: 5rem;
    }
    .secSet .txtJp{
        width: 18.9rem;
    }
    .secSet .txtJp::after{
        width: 20rem;
    }
}

/* secPlan */
.secPlan{
    text-align: center;
    position: relative;
    padding: 5rem 0 12rem;
    margin-top: 18.6rem;
}
.secPlan .boxFlex{
    display: flex;
    margin-top: 7.5rem;
    position: relative;
    z-index: 10;
}
.secPlan .boxFlex + .boxFlex{
    margin-top: 16rem;
}
.secPlan .boxImg{
    width: 69.167%;
}
.secPlan .boxImg img{
    border-radius: 2rem;
}
.secPlan .boxTxt{
    width: calc(100% - 69.167%);
    padding-left: 5.5rem;
    text-align: left;
}
.secPlan .boxTxtTop{
    position: relative;
    padding-bottom: 1.9rem;
}
.secPlan .boxTxtTop::after{
    content: "";
    width: calc(100% + 5.5rem);
    height: 0.2rem;
    background: var(--keyColor);
    position: absolute;
    bottom: 0;
    right: 0;
}
.secPlan .txtTit{
    font-size: var(--pcFontSize26);
    font-weight: bold;
}   
.secPlan .txtDate{
    width: 18rem;
    height: 3.2rem;
    padding-top: 0.3rem;
    border: 0.1rem solid var(--textColor);
    border-radius: 0.5rem;
    font-size: var(--pcFontSize20);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 5rem;
}
.secPlan .txtPriceTit{
    font-size: var(--pcFontSize22);
    margin-top: 1.5rem;
}
.secPlan .txtPrice{
    font-size: var(--pcFontSize52);
    font-weight: 800;
    color: var(--keyColor);
    margin-top: 1rem;
}
.secPlan .txtMin{
    font-size: var(--pcFontSize30);
}
.secPlan .boxTxtBottom{
    padding-top: 3.2rem;
}
.secPlan .txtIconTit{
    font-size: var(--pcFontSize21);
}
.secPlan .boxIconList{
    display: flex;
    flex-wrap: wrap;
    margin-top: 1.7rem;
    gap: 1.5rem;
}
.secPlan .iconPlan{
    width: calc((100% - 3rem) / 3);
}
.secPlan .txtBottom{
    font-size: var(--pcFontSize15);
    line-height: var(--pcLineHeight16_25);
    font-weight: normal;
    margin-top: 2.4rem;
}
.secPlan .txtNote{
    font-size: var(--pcFontSize17);
    line-height: var(--pcLineHeight17_29);
    text-align: left;
    margin-top: 5rem;
}
@media only screen and (max-width:1215px){
    .secPlan{
        padding: 3.4rem 0 5rem;
        margin-top: 3.9rem;
    }
    .secPlan .boxFlex{
        flex-direction: column;
        margin-top: 2.6rem;
    }
    .secPlan .boxFlex + .boxFlex{
        margin-top: 5rem;
    }
    .secPlan .boxImg{
        width: 100%;
    }
    .secPlan .boxImg img{
        border-radius: 0.5rem;
    }
    .secPlan .boxTxt{
        width: 100%;
        padding-left: 0;
        margin-top: 1.7rem;
    }
    .secPlan .boxTxtTop{
        padding-bottom: 1.6rem;
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-top: 2rem;
    }
    .secPlan .boxTxtTop::after{
        width: 100%;
        height: 0.2rem;
    }
    .secPlan .txtTit{
        font-size: var(--spFontSize18);
    }   
    .secPlan .txtDate{
        width: 9rem;
        height: 1.6rem;
        border-radius: 0.5rem;
        font-size: var(--spFontSize11);
        margin-top: 0;
    }
    .secPlan .txtPriceTit{
        font-size: var(--spFontSize13);
        margin-top: 0.8rem;
    }
    .secPlan .txtPrice{
        font-size: var(--spFontSize28);
        margin: 0 0 0 0.5rem;
    }
    .secPlan .txtMin{
        font-size: var(--spFontSize20);
        margin-left: 0.3rem;
    }
    .secPlan .boxTxtBottom{
        padding-top: 1.6rem;
    }
    .secPlan .txtIconTit{
        font-size: var(--spFontSize11);
    }
    .secPlan .boxIconList{
        margin-top: 0.8rem;
        gap: 0.6rem;
    }
    .secPlan .iconPlan{
        width: calc((100% - 3rem) / 6);
    }
    .secPlan .txtBottom{
        font-size: var(--spFontSize10);
        line-height: var(--spLineHeight10_15);
        margin-top: 0.7rem;
    }
    .secPlan .txtNote{
        font-size: var(--spFontSize10);
        line-height: var(--spLineHeight10_15);
        margin-top: 3rem;
    }
}
@media only screen and (max-width:370px){
    .secPlan{
        margin-top: 2.9rem;
    }
}

/* secSystemBus */
.secSystemBus{
    background: var(--colorBgPnkz);
}
.secSystemBus .txtJp::after{
    width: 32rem;
}
.secSystemBus::before{
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 21rem;
    background-color: var(--colorBgPnkz);
    background-repeat: repeat;
    background-size: auto;
    transform-origin: top right;
    transform: skewY(6deg);
    z-index: 1;
}
.secSystemBus::after{
    content: "";
    position: absolute;
    bottom: -0;
    left: 0;
    width: 100%;
    height: 21rem;
    background-color: var(--colorBgPnkz);
    background-repeat: repeat;
    background-size: auto;
    transform-origin: top left;
    transform: skewY(6deg);
    z-index: 1;
}
@media only screen and (max-width:1215px){
    .secSystemBus .txtJp{
        width: 11.3rem;
    }
    .secSystemBus .txtJp::after{
        width: 12.5rem;
    }
}

/* secKitchen */
.secKitchen .txtJp::after{
    width: 25rem;
    background: var(--colorTitUnderLine);
}
.secKitchen::before{
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 21rem;
    background-color: var(--colorWhite);
    background-repeat: repeat;
    background-size: auto;
    transform-origin: top right;
    transform: skewY(6deg);
    z-index: 1;
}
/* .secKitchen::after{
    content: "";
    position: absolute;
    bottom: -0;
    left: 0;
    width: 100%;
    height: 21rem;
    background-color: var(--colorWhite);
    background-repeat: repeat;
    background-size: auto;
    transform-origin: top left;
    transform: skewY(6deg);
    z-index: 1;
} */
@media only screen and (max-width:1215px){
    .secKitchen .txtJp{
        width: 9.7rem;
    }
    .secKitchen .txtJp::after{
        width: 8rem;
    }
}

/* secToilet */
.secToilet{
    background: var(--colorBgPnkz);
}
.secToilet .txtJp::after{
    width: 14rem;
}
.secToilet::before{
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 21rem;
    background-color: var(--colorBgPnkz);
    background-repeat: repeat;
    background-size: auto;
    transform-origin: top right;
    transform: skewY(6deg);
    z-index: 1;
}
.secToilet::after{
    content: "";
    position: absolute;
    bottom: -0;
    left: 0;
    width: 100%;
    height: 21rem;
    background-color: var(--colorBgPnkz);
    background-repeat: repeat;
    background-size: auto;
    transform-origin: top left;
    transform: skewY(6deg);
    z-index: 1;
}
@media only screen and (max-width:1215px){
    .secToilet .txtJp{
        width: 5.6rem;
    }
    .secToilet .txtJp::after{
        width: 7rem;
    }
}

/* secBathroomVanity */
.secBathroomVanity .txtJp::after{
    width: 30rem;
    background: var(--colorTitUnderLine);
}
.secBathroomVanity::before{
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 21rem;
    background-color: var(--colorWhite);
    background-repeat: repeat;
    background-size: auto;
    transform-origin: top right;
    transform: skewY(6deg);
    z-index: -1;
}
.secBathroomVanity::after{
    content: "";
    position: absolute;
    bottom: -0;
    left: 0;
    width: 100%;
    height: 21rem;
    background-color: var(--colorWhite);
    background-repeat: repeat;
    background-size: auto;
    transform-origin: top left;
    transform: skewY(6deg);
    z-index: -1;
}
.secBathroomVanity .btnCmnDetails{
    margin: 15rem auto 0;
}
@media only screen and (max-width:1215px){
    .secBathroomVanity .txtJp{
        width: 12.4rem;
    }
    .secBathroomVanity .txtJp::after{
        width: 13.5rem;
    }
    .secBathroomVanity .btnCmnDetails{
        margin: 5rem auto 0;
    }
    .secBathroomVanity .btnCmnDetails::before{
        right: 1.5rem;
    }
}

/* secBottomSlider */
.secBottomSlider{
    text-align: center;
    position: relative;
    background: var(--colorBgPnkz);
    padding: 6rem 0 25rem;
    margin-top: 19.6rem;
}
.secBottomSlider::before{
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 21rem;
    background-color: var(--colorBgPnkz);
    background-repeat: repeat;
    background-size: auto;
    transform-origin: top right;
    transform: skewY(6deg);
    z-index: -1;
}
.secBottomSlider .txtJp::after{
    width: 81rem;
}
.secBottomSlider .boxSlider{
    width: 54.7rem;
    margin: 7.7rem auto 0;
    position: relative;
}
.secBottomSlider .swiper{
    overflow: visible;
}
.secBottomSlider .swiper-button-prev,
.secBottomSlider .swiper-button-next{
    width: 4rem;
    height: 4rem;
    margin-top: 0;
    top: calc(50% - 2rem);
    border-radius: 2rem;
}
.secBottomSlider .swiper-button-prev{
    left: -6.1rem;
    transform: rotate(180deg);
}
.secBottomSlider .swiper-button-next{
    right: -6.1rem;
}
.secBottomSlider .swiper-button-prev::after,
.secBottomSlider .swiper-button-next::after{
    display: none;
}
.secBottomSlider .swiper-button-prev.lazyloaded{
    background: url(../img/menu/iconArrow.png) 1.7rem center / 0.8rem auto no-repeat var(--colorBgNextPrevBtn);
}
.secBottomSlider .swiper-button-next.lazyloaded{
    background: url(../img/menu/iconArrow.png) 1.7rem center / 0.8rem auto no-repeat var(--colorBgNextPrevBtn);
}
.secBottomSlider .imgSlider{
    display: block;
    height: 0;
    padding-top: 57.728%;
}
.secBottomSlider .imgSlider img{
    border-radius: 1.5rem;
}
.secBottomSlider .swiper-pagination{
	bottom: -5.2rem !important;
}
.secBottomSlider .swiper-pagination-bullet{
    background: var(--colorWhite);
    margin: 0 0.5rem!important;
    opacity: 1;
    width: 1rem;
    height: 1rem;
    border-radius: 0.5rem;
}
.secBottomSlider .swiper-pagination-bullet-active{
    background: var(--colocPaginationOn);
}
@media only screen and (max-width:1215px){
    .secBottomSlider{
        padding: 4.9rem 0 5rem;
        margin-top: 8.5rem;
    }
    .secBottomSlider .txtJp{
        width: 22.7rem;
    }
    .secBottomSlider .txtJp::after{
        width: 23.5rem;
    }
    .secBottomSlider .boxSlider{
        width: 100%;
        margin: 5rem auto 0;
    }
    .secBottomSlider .swiper-button-prev,
    .secBottomSlider .swiper-button-next{
        display: none;
    }
    .secBottomSlider .imgSlider img{
        border-radius: 0;
    }
    .secBottomSlider .swiper-pagination{
        bottom: -1.5rem !important;
    }
    .secBottomSlider .swiper-pagination-bullet{
        margin: 0 0.3rem!important;
        width: 0.5rem;
        height: 0.5rem;
        border-radius: 0.25rem;
    }
}