@charset "utf-8";
.secCmnHero.imgBack{
    background-image: url(../img/reserve/reserve_bg.jpg);
    height: 70rem;
}
@media only screen and (max-width:1215px){
    .secCmnHero.imgBack{
        background-image: url(../img/reserve/reserve_bg_sp.jpg);
        height: 96vw;
    }
}

.secCmnHero.imgBack .inner{
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding-top: 5.5rem;
    position: relative;
}
.secCmnHero.imgBack .titRoman{
    width: 37.8rem;
}
.secCmnHero.imgBack .tit{
    font-size: var(--pcFontSize66);
    font-weight: bold;
    letter-spacing: var(--pcLetterSpacing66_50);
    padding: 3.8rem 0 2.9rem;
}
.secCmnHero.imgBack .txt{
    font-size: var(--pcFontSize18);
    font-weight: bold;
    letter-spacing: var(--pcLetterSpacing18_50);
    line-height: var(--pcLineHeight18_36);
    padding: 0 0 2.9rem;
}
.secCmnHero.imgBack .txtPresent{
    font-size: var(--pcFontSize18);
    font-weight: bold;
    letter-spacing: var(--pcLetterSpacing18_50);
    line-height: var(--pcLineHeight18_36);
    color: #fff;
    background-color: var(--keyColor);
    padding: 1.3rem 4rem 1.1rem;
}
.secCmnHero.imgBack .txtPresent .fYellow{
    color: var(--y_lineColor);
}
@media only screen and (max-width:1215px){
    .secCmnHero.imgBack .inner{
        padding-top: 8.5rem;
        height: 96vw;
    }
    .secCmnHero.imgBack .titRoman{
        width: 18.8rem;
    }
    .secCmnHero.imgBack .tit{
        font-size: var(--spFontSize26);
        letter-spacing: 0;
        padding: 2.2rem 0 1.5rem;
    }
    .secCmnHero.imgBack .txt{
        font-size: var(--spFontSize14);
        letter-spacing: 0;
        line-height: var(--spLineHeight14_28);
        padding: 0;
    }
    .secCmnHero.imgBack .txtPresent{
        font-size: var(--spFontSize13);
        letter-spacing: 0;
        line-height: var(--spLineHeight13_22);
        padding: 1.2rem 0.6rem 1.1rem;
        text-align: center;
        position: absolute;
        bottom: 0;
        left: 0;
        z-index: 2;
        width: 100%;
    }
}

@media only screen and (min-width:1216px){
    .pageReserve .mainWrapper{
        padding-top: 0;
        position: relative;
    }
    .pageReserve #pnkz{
        position: absolute;
        top: 15.2rem;
    }
    .pageReserve #pnkz li{
        color: #fff;
    }
}
@media only screen and (max-width:1215px){
    .pageReserve .mainWrapper{
        padding-top: 0;
    }
}

/* secReserve */
.secReserve{
    padding-bottom: 20rem;
}
@media only screen and (max-width:1215px){
    .secReserve{
        padding-bottom: 10rem;
    }
}
/* secpoint */
.secPoint{
    margin-top: 9.2rem;
}
@media only screen and (min-width:1216px){
    .secPoint .secCmntitbox .jpnTit{
        font-size: var(--pcFontSize22);
    }
}
.secPoint .Inner{
    
}
.secPoint .list{
    display: flex;
    margin-top: 6.4rem;
}
.secPoint .item{
    width: calc((100% - 11rem) / 3);
    margin-right: 5.5rem;
}
.secPoint .item:last-child{
    margin-right: 0;
}
.secPoint .itemInner{
    width: 100%;
}
.secPoint .imgArea{
    position: relative;
    width: 100%;
}
.secPoint .pointbox{
    position: absolute;
    top: calc(0% - 1.6rem);
    left: 1.6rem;
    width: 9rem;
    height: 3.2rem;
    display: flex;
    align-items: center;
    background-color: var(--keyColor);
    color: #fff;
    border-radius: 0.3rem;
    z-index: 3;
}
.secPoint .pointtxt{
    font-size: var(--pcFontSize14);
    letter-spacing: var(--pcLetterSpacing14_50);
    font-weight: bold;
    display: inline-block;
    text-align: center;
    width: 100%;
}
.secPoint .imgBox{
    width: 100%;
    height: 0;
    padding-top: calc(440 / 390 * 100%);
    border-radius: 1rem;
    overflow: hidden;
    z-index: 1;
}
.secPoint .txtArea{
    margin-top: 3.4rem;
}
.secPoint .areaTit{
    font-size: var(--pcFontSize20);
    line-height: var(--pcLineHeight20_34);
    font-weight: bold;
    text-align: center;
}
.secPoint .areaTxt{
    margin-top: 1.7rem;
    font-size: var(--pcFontSize16);
    line-height: var(--pcLineHeight16_30);
}
@media only screen and (max-width:1215px){
    .secPoint{
        margin-top: 4.5rem;
    }
    .secPoint .list{
        display: block;
        margin-top: 3.6rem;
    }
    .secPoint .item{
        width: 100%;
        margin-right: 0;
    }
    .secPoint .item + .item{
        margin-top: 2.1rem;
    }
    .secPoint .itemInner{
        display: flex;
    }
    .secPoint .imgArea{
        width: 14.7rem;
    }
    .secPoint .pointbox{
        top: calc(0% - 1.2rem);
        left: 1rem;
        width: 6rem;
        height: 2.4rem;
    }
    .secPoint .pointtxt{
        font-size: var(--spFontSize10);
    }
    .secPoint .imgBox{
        border-radius: 0.5rem;
    }
    .secPoint .txtArea{
        margin-top: 0;
        flex: 1;
        padding-left: 2rem;
        padding-top: 1.6rem;
    }
    .secPoint .areaTit{
        font-size: var(--spFontSize13);
        line-height: var(--spLineHeight13_22);
        text-align: left;
    }
    .secPoint .areaTxt{
        margin-top: 0.6rem;
        font-size: var(--spFontSize12);
        line-height: var(--spLineHeight12_20);
    }
}
.secRecommend{
    margin-top: 9.1rem;
}
.secRecommend .Inner{}
.secRecommend .titlebox{
    width: 100%;
    height: 8rem;
    display: flex;
    align-items: center;
    border: 0.1rem solid;
    border-color: var(--keyColor);
    border-radius: 0.3rem;
    background-color: #fff;
}
.secRecommend .title{
    font-size: var(--pcFontSize20);
    line-height: var(--pcLineHeight20_34);
    font-weight: bold;
    color: var(--keyColor);
    display: inline-block;
    width: 100%;
    text-align: center;
}
.secRecommend .middletxt{
    margin-top: 3.1rem;
    font-size: var(--pcFontSize16);
    line-height: var(--pcLineHeight16_36);
    text-align: center;
    font-weight: bold;
}
.secRecommend .listbox{
    width: 100%;
    margin-top: 2.9rem;
}
.secRecommend .list{
    display: flex;
}
.secRecommend .item{
    width: calc(100% / 4);
}
.secRecommend .imgbox{
    width:24rem;
    margin: 0 auto;
}
.secRecommend .img{
    width: 100%;
    height: 0;
    padding-top: calc(240 / 240 * 100%);
    border-radius: 50%;
    overflow: hidden;
    z-index: 1;
}
.secRecommend .txtbox{
    text-align: center;
    margin-top: 2.7rem;
}
.secRecommend .txt{
    font-size: var(--pcFontSize16);
    line-height: var(--pcLineHeight16_30);
}
@media only screen and (max-width:1215px){
    .secRecommend{
        margin-top: 3.5rem;
    }
    .secRecommend .titlebox{
        height: 5rem;
    }
    .secRecommend .title{
        font-size: var(--spFontSize14);
        line-height: var(--spLineHeight14_22);
    }
    .secRecommend .middletxt{
        margin-top: 1.6rem;
        font-size: var(--spFontSize12);
        line-height: var(--spLineHeight12_20);
    }
    .secRecommend .listbox{
        margin-top: 20px;
    }
    .secRecommend .list{
        flex-wrap: wrap;
    }
    .secRecommend .item{
        width: calc((100% - 1.5rem) / 2);
        margin-right: 1.5rem;
    }
    .secRecommend .item:nth-child(2n){
        margin-right: 0;
    }
    .secRecommend .item:nth-child(n + 3){
        margin-top: 2rem;
    }
    .secRecommend .imgbox{
        width:calc((130 / 375) * 100vw);
        max-width: 48rem;
    }
    .secRecommend .txtbox{
        margin-top: 1.3rem;
    }
    .secRecommend .txt{
        font-size: var(--spFontSize12);
        line-height: var(--spLineHeight12_20);
    }
}
@media only screen and (max-width:374px){
    .secPoint .imgArea{
        width: calc((147 / 375) * 100vw);
    }
}
/* .secModel */
.secModel{
    border-top: 0.1rem solid;
    border-color: var(--textColor);
    margin-top: 4rem;
    padding-top: 9.1rem;
}
/* modelist */
.secModel .modelist{
    display: flex;
    flex-wrap: wrap;
    margin-top: 5.6rem;
}
.secModel .modelItem{
    width: calc((100% - 6rem) / 2);
    margin-right: 6rem;
    position: relative;
}
.secModel .modelItem:nth-child(2n){
    margin-right: 0;
}
.secModel .modelItem:nth-child(n + 3){
    margin-top: 6rem;
}
.secModel .modelLabel{
    position: relative;
    width: 100%;
    display: block;
    pointer-events: all;
    cursor: pointer;
    padding-bottom: calc(2.1rem + 6rem);
}
.secModel .modelCheck{
    position: absolute;
    left: 0;
    top: 0;
    width: 1rem;
    height: 1rem;
    visibility: hidden;
}
.secModel .modelIn{
    width: 100%;
    display: block;
}
.secModel .imgbox{
    display: block;
    width: 100%;
    position: relative;
}
.secModel .img{
    width: 100%;
    display: block;
    height: 0;
    padding-top: calc(360 / 610 * 100%);
    border-radius: 1rem;
    overflow: hidden;
    z-index: 1;
}
.secModel .modelCheck:checked + .modelIn .imgbox::after,
.secModel .modelCheck:checked + .modelIn .imgbox::before{
    content: "";
    position: absolute;
}
.secModel .modelCheck:checked + .modelIn .imgbox::after {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    border: 0.3rem solid;
    border-color: var(--keyColor);
    border-radius: calc(1rem + 0.3rem);
    z-index: 2;
}
.secModel .modelCheck:checked + .modelIn .imgbox::before{
    content: "";
    position: absolute;
    width: 4rem;
    height: 4rem;
    border-radius: 50%;
    background-color: var(--keyColor);
    top: calc(0% - 2rem);
    left: 2rem;
    z-index: 3;
}
.secModel.lazyloaded .modelCheck:checked + .modelIn .imgbox::before{
    background: url(../img/event/imgIconcheck.png) center center no-repeat var(--keyColor);
    background-size: 1.6rem auto;
}
.secModel .txtArea{
    margin-top: 3.8rem;
    display: block;
}
.secModel .Onbox{
    display: flex;
    align-items: center;
}
.secModel .modeltit{
    flex: 1;
    font-size: var(--pcFontSize26);
    line-height: var(--pcLineHeight26_36);
    font-weight: bold;
}
.secModel .modelIcon{
    width: fit-content;
}
.secModel .taglist{
    display: flex;
    justify-content: flex-end;
}
.secModel .tagItem{
    width: 8rem;
    height: 3rem;
    display: flex;
    align-items: center;
    color: #fff;
    border-radius: 0.5rem;
}
.secModel .tagItem + .tagItem{
    margin-left: 0.5rem;
}
.secModel .tagtxt{
    display: inline-block;
    font-size: var(--pcFontSize14);
    line-height: var(--pcLineHeight14_24);
    font-weight: bold;
    display: inline-block;
    text-align: center;
    width: 100%;
}
/* ▼背景色 */
.secModel .type_FEELE{
    background-color: var(--FEELEColor);
}
.secModel .type_YAT{
    background-color: var(--YATColor);
}
.secModel .type_CARRE{
    background-color: var(--CARREColor);
}
.secModel .type_RIV{
    background-color: var(--RIVColor);
}
.secModel .type_COSTA{
    background-color: var(--COSTAColor);
}
.secModel .type_ZUTTO{
    background-color: var(--ZUTTOColor);
}
.secModel .tagtxt{
    font-size: var(--pcFontSize14);
    line-height: var(--pcLineHeight14_32);
    font-weight: bold;
    letter-spacing: var(--pcLetterSpacing14_50);
}
.secModel .underbox{
    display: block;
    width: 100%;
    margin-top: 2rem;
    text-align: left;
}
.secModel .undertxt{
    font-size: var(--pcFontSize16);
    line-height: var(--pcLineHeight16_32);
    letter-spacing: var(--pcLetterSpacing16_50);
}
.secModel .btnbox{
    position: absolute;
    width: 24rem;
    bottom: 0;
    right: 0;
}
.secModel .btnInner{
    display: flex;
    align-items: center;
    width: 100%;
    height: 6rem;
    border-radius: 10rem;
    background-color: #fff;
    color: var(--textColor);
    border: 0.1rem solid;
    border-color: var(--textColor);
}
.secModel .btntxt{
    font-size: var(--pcFontSize16);
    line-height: var(--pcLineHeight16_30);
    font-weight: bold;
    display: inline-block;
    width: 100%;
    text-align: center;
}
.secModel .btntxt .ontxt,
.secModel .modelCheck:checked + .modelIn .offtxt{
    display: none;
}
.secModel .modelCheck:checked + .modelIn .ontxt{
    display: inline;
}
.secModel .modelCheck:checked + .modelIn .btnInner{
    background-color: var(--keyColor);
    color: #fff;
    border-color: var(--keyColor);
}
.secModel .modeBoxEnd{
    position: absolute;
    width: calc(100% - 24rem);
    bottom: 0;
    left: 0;
}
.secModel .modeBoxEnd .txtlist{
    width: 100%;
    height: 6rem;
    display: flex;
    align-items: center;
    justify-content: flex-start;
}
.secModel .modeBoxEnd .txtItem{
    display: inline-block;
    position: relative;
    padding-left: calc(0.6rem + 0.4rem);
}
.secModel .modeBoxEnd .txtItem + .txtItem{
    margin-left: 2rem;
}
.secModel .modeBoxEnd .txtItem::after{
    content: "";
    position: absolute;
    width: 0.6rem;
    height: 0.6rem;
    top: calc(50% - 0.3rem);
    left: 0;
    background-color: var(--textColor);
    clip-path: polygon(0 0, 0% 100%, 100% 50%);
}
.secModel .modeBoxEnd .txtLink{
    text-decoration: underline;
    font-size: var(--pcFontSize14);
    line-height: var(--pcLineHeight14_24);
}
.secModel + .formIn{
    margin-top: 20rem;
}
@media only screen and (max-width:1215px){
    .secModel{
        margin-top: 0.9rem;
        padding-top: 3.5rem;
    }
    /* modelist */
    .secModel .modelist{
        display: block;
        margin: 0 auto;
        margin-top: 3.7rem;
        max-width: 61rem;
    }
    .secModel .modelItem{
        width:100%;
        margin-right: 0;
    }
    .secModel .modelItem:nth-child(n + 2),
    .secModel .modelItem:nth-child(n + 3){
        margin-top: 3.6rem;
    }
    .secModel .modelLabel{
        padding-bottom:0;
    }
    .secModel .img{
        border-radius: 0.5rem;
    }
    .secModel .modelCheck:checked + .modelIn .imgbox::after {
        border-radius: 0.5rem;
    }
    .secModel .modelCheck:checked + .modelIn .imgbox::before{
        width: 3rem;
        height: 3rem;
        top: calc(0% - 1.5rem);
        left: 1.5rem;
    }
    .secModel.lazyloaded .modelCheck:checked + .modelIn .imgbox::before{
        background-size: 1.2rem auto;
    }
    .secModel .txtArea{
        margin-top: 2.2rem;
    }
    .secModel .Onbox{
        display:block;
    }
    .secModel .modeltit{
        width: 100%;
        display: block;
        text-align: center;
        font-size: var(--spFontSize18);
    }
    .secModel .modelIcon{
        width: 100%;
        display: block;
        margin-top: 1.2rem;
    }
    .secModel .taglist{
        justify-content: center;
    }
    .secModel .tagItem{
        width: 5.5rem;
        height: 2.2rem;
        border-radius: 0.3rem;
    }
    .secModel .tagItem + .tagItem{
        margin-left: 0.3rem;
    }
    .secModel .tagtxt{
        font-size: var(--spFontSize11);
        line-height: var(--spLineHeight11_20);
    }
    .secModel .underbox{
        margin-top: 10px;
        text-align: center;
    }
    .secModel .undertxt{
        font-size: var(--spFontSize11);
        line-height: var(--spLineHeight11_20);
        letter-spacing: 0;
    }
    .secModel .btnbox{
        position: static;
        display: block;
        width: 21.5rem;
        margin: 0 auto;
        margin-top: 1.6rem;
    }
    .secModel .btnInner{
        height: 5rem;
    }
    .secModel .btntxt{
        font-size: var(--spFontSize12);
    }
    .secModel .modeBoxEnd{
        position: relative;
        width: 100%;
        margin-top: 1.5rem;
    }
    .secModel .modeBoxEnd .txtlist{
        height: auto;
        display: block;
        text-align: center;
    }
    .secModel .modeBoxEnd .txtItem{
        padding-left: calc(0.4rem + 0.4rem);
    }
    .secModel .modeBoxEnd .txtItem::after{
        width: 0.4rem;
        height: 0.4rem;
        top: calc(50% - 0.2rem);
    }
    .secModel .modeBoxEnd .txtLink{
        text-decoration: underline;
        font-size: var(--spFontSize11);
        line-height: var(--spLineHeight11_20);
    }
    .secModel + .formIn{
        margin-top: 8rem;
    }
}