@charset "utf-8";

/*-----------------------------------------------
	common
-----------------------------------------------*/
.mainTitBox.lazyloaded{ background:url(../img/title/bgPlan.jpg) top center / cover no-repeat;}
@media only screen and (max-width:767px){
    .mainTitBox.lazyloaded{ background:url(../img/title/bgPlanSp.jpg) top center / cover no-repeat;}
}

/*-----------------------------------------------
	index
-----------------------------------------------*/

/* secTopPlan */
.secTopPlan .boxTxt{
    height: 560px;
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-align-items: center;
    align-items: center;
}
.secTopPlan .boxTxt.lazyloaded{
    background: url(../img/plan/bgTop.jpg) center / cover no-repeat;
}
.secTopPlan .imgList{
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-align-items: center;
    align-items: center;
    -webkit-flex-wrap: nowrap;
    flex-wrap: nowrap;
    overflow: hidden;
}
@media only screen and (max-width:767px){
    .secTopPlan .boxTxt{
        height: auto;
        padding: 35px 9% 36px;
        text-align: center;
    }
    .secTopPlan .boxTxt img{
        max-width: 330px;
    }
    .secTopPlan .imgItem{
        width: calc(100% / 3);
        height: auto;
    }
}

/* secSearchPlan */
.secSearchPlan{
    margin-top: 72px;
}
.secSearchPlan .boxHead{
	display:-webkit-flex;
	display:flex;
	-webkit-justify-content:space-between;
	justify-content:space-between;
	-webkit-align-items:center;
	align-items:center;
}
.secSearchPlan .titHead{
	font-weight:700;
	font-size:17px;
	letter-spacing:1px;
}
.secSearchPlan .titHead::before{
    display:inline-block;
    width:22px;
    height:22px;
    margin-right:10px;
    background:url(../img/common/iconSearch.png) center center / contain no-repeat;
    vertical-align:middle;
    content:"";
}
.secSearchPlan .boxBtnFilter a{
    display:block;
    width:210px;
    border-radius:25px;
    background:#006253;
    color:#fff;
    font-weight:700;
    font-size:13px;
    line-height:50px;
    text-align:center;
    transition:all .2s ease-out;
}
.secSearchPlan .boxBtnFilter a::before{
    display:inline-block;
    width:0;
    height:0;
    margin-right:10px;
    border-style:solid;
    content:"";
    border-width:0 5px 10px 5px;
    border-color:transparent transparent #fff transparent;
    vertical-align:-2px;
}
.secSearchPlan .boxBtnFilter .active::before{
    border-width:10px 5px 0 5px;
    border-color:#fff transparent transparent transparent;
    vertical-align:0;
}
.secSearchPlan .boxBtnFilter span{
	display:none;
	-webkit-transition:all 0.2s ease-out;
	transition:all .2s ease-out;
}
.secSearchPlan .boxBtnFilter .txtOff,
.secSearchPlan .boxBtnFilter .active .txtOn{
	display:inline-block;
}
.secSearchPlan .boxBtnFilter .active .txtOff{
	display:none;
}
@media only screen and (max-width:767px){
    .secSearchPlan{
        margin-top: 6px;
    }
    .secSearchPlan .boxHead{
        display:-webkit-flex;
        display:flex;
        -webkit-justify-content:space-between;
        justify-content:space-between;
        -webkit-align-items:center;
        align-items:center;
    }
    .secSearchPlan .titHead{
        position: relative;
        width: 100%;
        margin: 24px 0 10px;
        font-size: 13px;
        letter-spacing: 0;
    }
    .secSearchPlan .titHead::before{
        width: 14px;
        height: 14px;
        margin-right: 8px;
        margin-bottom: 2px;
    }
    .secSearchPlan .boxBtnFilter{
        margin-top: 30px;
    }
    .secSearchPlan .boxBtnFilter a{
        width: 235px;
        margin: 0 auto;
        font-size: 11px;
        line-height: 44px;
    }
    .secSearchPlan .boxBtnFilter a::before{
        display: inline-block;
        width: 0;
        height: 0;
        margin-right: 10px;
        border-style: solid;
        content: "";
        border-width:0 5px 10px 5px;
        border-color:transparent transparent #fff transparent;
        vertical-align:-2px;
    }
    .secSearchPlan .boxBtnFilter .active::before{
        border-width: 10px 5px 0 5px;
        border-color: #fff transparent transparent transparent;
        vertical-align:0;
    }
    .secSearchPlan .boxBtnFilter span{
        display:none;
        -webkit-transition:all 0.2s ease-out;
        transition:all .2s ease-out;
    }
    .secSearchPlan .boxBtnFilter .txtOff,
    .secSearchPlan .boxBtnFilter .active .txtOn{
        display:inline-block;
    }
    .secSearchPlan .boxBtnFilter .active .txtOff{
        display:none;
    }
}

/* boxBody */
.secSearchPlan .inputTable{
    margin-top: 24px;
}
.type02.spOnly{
    display: none!important;
}
.secSearchPlan .inputTable dl{
    border-top: 1px solid #e8e9ea;
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
}
.secSearchPlan .inputTable dl:last-child{
    border-bottom: 1px solid #e8e9ea;
}
.secSearchPlan .inputTable dt{
    min-width: 104px;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.7px;
    line-height: 1.5;
    padding: 35px 10px 35px 0;
    position: relative;
}
.secSearchPlan .inputTable dt::after{
    content: "";
    width: 1px;
    height: calc(100% - 60px);
    background: #e8e9ea;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    margin: auto;
}
.secSearchPlan .inputTable dt .txt{
    vertical-align: -5px;
}
.secSearchPlan .inputTable dd{
    -webkit-flex: 1;
    flex: 1;
    font-size: 14px;
    font-weight: 500;
    letter-spacing: 0.7px;
    line-height: 1.5;
    padding: 35px 10px 35px 19px;
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: flex-start;
    justify-content: flex-start;
    -webkit-align-items: flex-start;
    align-items: flex-start;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
}
.secSearchPlan .inputTable dd .inputWrap{
    min-width: 124px;
}
.secSearchPlan .inputTable dd .inputWrap input{
    width: 20px;
    height: 20px;
    margin: 6px 0;
}
.secSearchPlan .inputTable dd .inputWrap .txt{
    vertical-align: middle;
}
@media only screen and (max-width:767px){
    .type02.spOnly{
        display: block!important;
    }
    .secSearchPlan .inputTable{
        margin-top: 1px;
    }
    .secSearchPlan .inputTable dl{
        display: block;
        padding: 6px 0 9px;
    }
    .secSearchPlan .inputTable dt{
        min-width: 0;
        font-size: 12px;
        letter-spacing: 0.6px;
        padding: 0;
    }
    .secSearchPlan .inputTable dt::after{
        display: none;
    }
    .secSearchPlan .inputTable dt .txt{
        vertical-align: auto;
    }
    .secSearchPlan .inputTable dt .spOnly{
        display: inline;
    }
    .secSearchPlan .inputTable dd{
        font-size: 13px;
        letter-spacing: 0.65px;
        line-height: 1.5;
        padding: 0;
        margin-top: 5px;
    }
    .secSearchPlan .inputTable .type01 dd .inputWrap{ min-width: 100px;}
    .secSearchPlan .inputTable .type02 dd .inputWrap{ min-width: 86px;}
    .secSearchPlan .inputTable .type03 dd .inputWrap{ min-width: 77px;}
    .secSearchPlan .inputTable dd .inputWrap input{
        width: 18px;
        height: 18px;
        margin-right: 2px;
    }
}

.secSearchPlan .boxBtnSearch{
    margin-top: 50px;
    text-align: center;
}
.secSearchPlan .boxBtnSearch .aBtnLink{
    font-size: 16px;
    font-weight: 700;
    letter-spacing: 0.8px;
    width: 360px;
    padding: 27px 0;
    text-align: center;
    border: 1px solid #000;
    position: relative;
    display: inline-block;
    text-decoration: none;
    color: #000;
}
.secSearchPlan .boxBtnSearch .aBtnLink::after{
    content: "";
    background: url(../img/common/iconArrow60_12_b.png) center / contain no-repeat;
    width: 30px;
    height: 6px;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 30px;
    margin: auto;
}
@media only screen and (max-width:767px){
    .secSearchPlan .boxBtnSearch{
        margin-top: 20px;
    }
    .secSearchPlan .boxBtnSearch .aBtnLink{
        font-size: 14px;
        letter-spacing: 0.7px;
        max-width: 325px;
        width: 100%;
        padding: 21px 0;
    }
    .secSearchPlan .boxBtnSearch .aBtnLink::after{
        right: 20px;
    }
}

/* boxSearchResult */
.secPlanMain .boxSearchResult{
    text-align: left;
    font-size: 18px;
    font-weight: 700;
    letter-spacing: 1.8px;
    margin-top: 82px;
}
.secPlanMain .boxSearchResult .num{
    font-size: 34px;
    letter-spacing: 1.7px;
    color: #006253;
    display: inline-block;
    padding: 0 3px;
}
@media only screen and (max-width:767px){
    .secPlanMain .boxSearchResult{
        text-align: center;
        font-size: 14px;
        letter-spacing: 0.3px;
        margin-top: 50px;
    }
    .secPlanMain .boxSearchResult .num{
        font-size: 28px;
        letter-spacing: 1.3px;
        margin-top: 14px;
        vertical-align: -3px;
    }
}

/* boxPlanList */
.boxPlanList{
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: flex-start;
    justify-content: flex-start;
    -webkit-align-items: flex-start;
    align-items: flex-start;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-top: 60px;
}
.planItem{
    width: 48.551%;
    margin-left: 2.898%;
    background: #fff;
    box-shadow: 0 0 50px 1px rgba(0,0,0,0.12);
}
.planItem:nth-child(2n+1){
    margin-left: 0;
}
.planItem:nth-child(n+3){
    margin-top: 80px;
}
.planItem .aBoxLink{
    width: 100%;
    display: block;
    text-decoration: none;
    color: #000;
}
.planItem .tit{
    font-size: 22px;
    font-weight: 700;
    line-height: 1.636;
    letter-spacing: 2.2px;
    color: #fff;
    text-align: center;
    background: #012923;
    padding: 34px 40px;
    min-height: 138px;
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-align-items: center;
    align-items: center;
}
.planItem .tit .txt{
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    max-height: 72px;
}
.planItem .boxInner{
    padding: 30px 30px 44px;
    min-height: 480px;
}
.planItem .imgBox{
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: center;
    justify-content: center;
}
.planItem .imgBox .img{
    width: 49.180%;
    height: 0;
    padding-top: calc(71.333% * 0.4918);
}
.planItem .imgBox .img.imgPhoto{
    padding-top: calc(71.333% * 0.4918 + 2px);
}
.planItem .imgBox .img.imgFloor{
    margin-left: 1.64%;
    border: 1px solid #e5e5e5;
    position: relative;
}
.planItem .imgBox .img.imgFloor .imgWrap{
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    width: calc(100% - 20px);
    height: calc(100% - 20px);
}
.planItem .imgBox .img.imgFloor .imgIn{
    width: 100%;
    height: 100%;
}
.planItem .boxTxt{
    text-align: center;
    padding-top: 27px;
}
.planItem .boxTxt .pointTit{
    display: inline-block;
    background: #ffcc00;
    font-size: 16px;
    font-weight: 700;
    letter-spacing: 0.8px;
    padding: 3px 2px 1px;
}
.planItem .boxTxt .pointTxt{
    font-size: 20px;
    font-weight: 700;
    line-height: 1.6;
    letter-spacing: 1px;
    margin-top: 14px;
    height: 64px;
    align-items: center;
    justify-content: center;
    text-overflow:ellipsis;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2; /*表示マックスの行*/
    overflow: hidden;
}
.planItem .boxBtn{
    text-align: center;
    margin-top: 28px;
}
.planItem .boxBtn .aBtnLink{
    font-size: 16px;
    font-weight: 700;
    letter-spacing: 0.8px;
    width: 330px;
    padding: 21px 0;
    text-align: center;
    border: 1px solid #000;
    position: relative;
    display: inline-block;
    text-decoration: none;
    color: #000;
}
.planItem .boxBtn .aBtnLink::after{
    content: "";
    background: url(../img/common/iconArrow60_12_b.png) center / contain no-repeat;
    width: 30px;
    height: 6px;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 30px;
    margin: auto;
}
@media only screen and (max-width:767px){
    .boxPlanList{
        display: block;
        margin-top: 36px;
    }
    .planItem{
        width: 100%;
        margin-left: 0;
    }
    .planItem:nth-child(n+3),
    .planItem:nth-child(n+2){
        margin-top: 40px;
    }
    .planItem .tit{
        font-size: 13px;
        line-height: 1.538;
        letter-spacing: 0.65px;
        padding: 19px 15px;
        min-height: 0;
    }
    .planItem .tit .txt{
        max-height: 40px;
    }
    .planItem .boxInner{
        padding: 20px 20px 23px;
        min-height: 59vw;
    }
    .planItem .boxTxt{
        text-align: left;
        padding: 16px 5px 0;
    }
    .planItem .boxTxt .pointTit{
        font-size: 12px;
        letter-spacing: 0.6px;
        padding: 3px 2px 2px;
    }
    .planItem .boxTxt .pointTxt{
        font-size: 11px;
        line-height: 1.636;
        letter-spacing: 0.5px;
        margin-top: 8px;
        -webkit-line-clamp: 3;
        height: auto;
        max-height: 96px;
    }
    .planItem .boxBtn{
        display: none;
    }
}

/* member */
.planItem.member .boxInner{
    position: relative;
}
.planItem.member .boxMember{
    position: absolute;
    background: rgba(0,0,0,0.75);
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: center;
    justify-content: center;
    align-items: center;
    -webkit-flex-direction: column;
    flex-direction: column;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    padding-bottom: 44px;
}
.planItem.member .boxMember .txtMember01{
    font-size: 22px;
    font-weight: 700;
    line-height: 1.818;
    letter-spacing: 2.2px;
    color: #cfb71b;
    margin-top: 17px;
    text-align: center;
}
.planItem.member .boxMember .txtMember02{
    font-size: 16px;
    font-weight: 700;
    line-height: 1.875;
    letter-spacing: 1.6px;
    color: #fff;
    margin-top: 12px;
    text-align: center;
}
.planItem.member .boxMember .boxBtnMember{
    width: 85.075%;
    margin: 34px auto 0;
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: center;
    justify-content: center;
}
.planItem.member .boxMember .boxBtnMember .aBtnLink{
    width: 49.123%;
    text-decoration: none;
    color: #000;
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-align-items: center;
    align-items: center;
    position: relative;
    font-size: 16px;
    font-weight: 700;
    letter-spacing: 0.3px;
    padding: 27px 0;
}
.planItem.member .boxMember .boxBtnMember .aBtnLink::after{
    content: "";
    width: 20px;
    height: 6px;
    position: absolute;
    top: 0;
    right: 20px;
    bottom: 0;
    margin: auto;
}
.planItem.member .boxMember .boxBtnMember .aBtnLink.btnLogin{
    background: #fff;
    color: #000;
}
.planItem.member .boxMember .boxBtnMember .aBtnLink.btnLogin::after{
    background: url(../img/common/iconArrow40_12_b.png) center / contain no-repeat;
}
.planItem.member .boxMember .boxBtnMember .aBtnLink.btnMember{
    background: #cfb71b;
    color: #fff;
    margin-left: 1.754%;
}
.planItem.member .boxMember .boxBtnMember .aBtnLink.btnMember::after{
    background: url(../img/common/iconArrow40_12_w.png) center / contain no-repeat;
}
.planItem.member .boxMember .boxBtnMember .aBtnLink .ktknAdj{
    letter-spacing: -2px;
}
@media only screen and (max-width:767px){
    .planItem.member .boxMember{
        background: rgba(0,0,0,0.85);
        padding-bottom: 0;
    }
    .planItem.member .boxMember .boxImgMember{
        width: 14px;
    }
    .planItem.member .boxMember .txtMember01{
        font-size: 13px;
        line-height: 1.385;
        letter-spacing: 0.65px;
        margin-top: 9px;
    }
    .planItem.member .boxMember .boxBtnMember{
        width: 76.812%;
        margin: 17px auto 0;
        display: flex;
        flex-wrap: wrap;
    }
    .planItem.member .boxMember .boxBtnMember .aBtnLink{
        width: 100%;
        font-size: 13px;
        letter-spacing: 0.65px;
        padding: 15px 0;
    }
    .planItem.member .boxMember .boxBtnMember .aBtnLink::after{
        width: 30px;
        height: 6px;
    }
    .planItem.member .boxMember .boxBtnMember .aBtnLink.btnLogin{
        order: 2;
    }
    .planItem.member .boxMember .boxBtnMember .aBtnLink.btnLogin::after{
        background: url(../img/common/iconArrow60_12_b.png) center / contain no-repeat;
    }
    .planItem.member .boxMember .boxBtnMember .aBtnLink.btnMember{
        order: 1;
    }
    .planItem.member .boxMember .boxBtnMember .aBtnLink.btnMember{
        margin-left: 0;
        margin-top: 0;
        margin-bottom: 8px;
    }
    .planItem.member .boxMember .boxBtnMember .aBtnLink.btnMember::after{
        background: url(../img/common/iconArrow60_12_w.png) center / contain no-repeat;
    }
    .planItem.member .boxMember .boxBtnMember .aBtnLink .ktknAdj{
        letter-spacing: -2px;
    }
}

/*-----------------------------------------------
	details
-----------------------------------------------*/
/* detailsTit */
.detailsTit{
    display:-webkit-flex;
    display:flex;
    -webkit-flex-wrap:wrap;
    flex-wrap:wrap;
    -webkit-align-items:center;
    align-items:center;
	position:relative;
    margin:60px auto 50px;
    padding:0 0 38px;
    border-bottom:1px solid #e8e9ea;
}
.detailsTit::after{
    position:absolute;
    bottom:-1px;
    left:0;
    width:70px;
    height:1px;
    background:#000;
    content:"";
}
.detailsTit .boxTit{
    -webkit-order:2;
    order:2;
    width:100%;
    margin-top:18px;
	font-weight:700;
	font-size:26px;
	line-height:44px;
	letter-spacing:2.6px;
}
.detailsTit .boxSub{
    -webkit-order:1;
    order:1;
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: flex-start;
    justify-content: flex-start;
    -webkit-align-items: center;
    align-items: center;
}
.detailsTit .txtArea{
    font-weight:700;
    font-size:20px;
    letter-spacing:2px;
}
.detailsTit .txtSub{
    position:relative;
    margin-left:12px;
    padding-left:12px;
    font-size:14px;
    line-height:20px;
    letter-spacing:.75px;
    top: 1px;
}
.detailsTit .txtSub::before{
    position:absolute;
    top:calc(50% - 6px);
    left:0;
    width:1px;
    height:12px;
    background:#c3c3c3;
    content:"";
}
@media only screen and (max-width:767px){
	.secDetails .detailsTit{
        margin:26px auto 22px;
        padding-bottom:18px;
    }
    .detailsTit::after{
        width:30px;
    }
	.secDetails .detailsTit .boxTit{
        margin-top:5px;
		font-size:16px;
        line-height:25px;
		letter-spacing:.5px;
	}
	.secDetails .detailsTit .txtArea{
		font-size:16px;
		letter-spacing:.8px;
	}
    .secDetails .detailsTit .txtSub{
        font-size:10px;
        font-weight: 500;
        letter-spacing: .5px;
        top: 1px;
        margin-left: 7px;
        padding-left: 0;
    }
    .secDetails .detailsTit .txtSub::before{
        display: none;
    }
}

/* secPlanImg */
.secDetails .secPlanImg{
    margin-top: 50px;
}
.secDetails .secPlanImg{
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: center;
    justify-content: center;
}
.secDetails .secPlanImg .boxImg{
    width: 49.275%;
    height: 0;
    padding-top: calc(71.029% * 0.4918);
}
.secDetails .secPlanImg .boxImg.imgPhoto{
    padding-top: calc(71.029% * 0.4918 + 2px);
}
.secDetails .secPlanImg .boxImg.imgFloor{
    margin-left: 1.45%;
    border: 1px solid #e5e5e5;
    position: relative;
    display: block;
}
.secDetails .secPlanImg .boxImg.imgFloor .imgWrap{
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    width: calc(100% - 20px);
    height: calc(100% - 20px);
}
.secDetails .secPlanImg .boxImg.imgFloor .imgIn{
    width: 100%;
    height: 100%;
}
@media only screen and (max-width:767px){
    .secDetails .secPlanImg{
        margin-top: 22px;
    }
    .secDetails .secPlanImg{
        display: block;
    }
    .secDetails .secPlanImg .boxImg{
        width: 100%;
        padding-top: 71.029%;
    }
    .secDetails .secPlanImg .boxImg.imgPhoto{
        padding-top: 71.029%;
    }
    .secDetails .secPlanImg .boxImg.imgFloor{
        margin-left: 0;
        margin-top: 20px;
    }
}

/* secPlanTxt */
.secDetails .secPlanTxt{
    margin-top: 60px;
    text-align: left;
}
.secDetails .secPlanTxt .pointTit{
    font-size: 18px;
    font-weight: 700;
    letter-spacing: 0.5px;
    display: inline-block;
    padding: 4px 3px 2px;
    background: #ffcc00;
}
.secDetails .secPlanTxt .pointSubTit{
    font-size: 22px;
    font-weight: 700;
    line-height: 1.5;
    letter-spacing: 2px;
    margin-top: 20px;
}
.secDetails .secPlanTxt .pointTxt{
    font-size: 15px;
    font-weight: 500;
    line-height: 2.067;
    letter-spacing: 0.75px;
    margin-top: 21px;
}
@media only screen and (max-width:767px){
    .secDetails .secPlanTxt{
        margin-top: 30px;
    }
    .secDetails .secPlanTxt .pointTit{
        font-size: 15px;
        letter-spacing: 0.75px;
        padding: 5px 3px 3px;
    }
    .secDetails .secPlanTxt .pointSubTit{
        font-size: 15px;
        line-height: 1.733;
        letter-spacing: 0.75px;
        margin-top: 14px;
    }
    .secDetails .secPlanTxt .pointTxt{
        font-size: 12px;
        font-weight: 400;
        line-height: 1.917;
        letter-spacing: 0.6px;
        margin-top: 12px;
    }
}

/* secPlanTable */
.secDetails .secPlanTable{
    margin-top: 62px;
}
.secDetails .secPlanTable dl{
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
}
.secDetails .secPlanTable dt{
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-align-items: flex-start;
    align-items: flex-start;
    padding: 21px 15px;
    font-size: 15px;
    font-weight: 400;
    line-height: 1.8;
    letter-spacing: 0.75px;
    background: #f9f9f9;
    border: 1px solid #ccc;
    border-bottom: none;
    width: 250px;
}
.secDetails .secPlanTable dl:last-child dt{
    border-bottom: 1px solid #ccc;
}
.secDetails .secPlanTable dd{
    -webkit-flex: 1;
    flex: 1;
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: flex-start;
    justify-content: flex-start;
    -webkit-align-items: flex-start;
    align-items: flex-start;
    padding: 21px 15px 21px 30px;
    font-size: 15px;
    font-weight: 400;
    line-height: 1.8;
    letter-spacing: 0.75px;
    border-top: 1px solid #ccc;
    border-right: 1px solid #ccc;
    width: calc(100% - 250px);
}
.secDetails .secPlanTable dl:last-child dd{
    border-bottom: 1px solid #ccc;
}
@media only screen and (max-width:767px){
    .secDetails .secPlanTable{
        margin-top: 33px;
    }
    .secDetails .secPlanTable dt{
        padding: 15px 10px;
        font-size: 12px;
        font-weight: 500;
        line-height: 1.7;
        letter-spacing: 0.6px;
        width: 100px;
    }
    .secDetails .secPlanTable dd{
        padding: 15px 10px 15px 14px;
        font-size: 12px;
        font-weight: 500;
        line-height: 1.7;
        letter-spacing: 0.6px;
        width: calc(100% - 100px);
    }
}

/* boxBtnPlanIndex */
.boxBtnPlanIndex{
    margin-top: 70px;
    text-align: center;
}
.boxBtnPlanIndex .aBtnLink{
    font-size: 16px;
    font-weight: 700;
    letter-spacing: 0.8px;
    width: 360px;
    padding: 28px 0;
    text-align: center;
    border: 1px solid #000;
    position: relative;
    display: inline-block;
    text-decoration: none;
    color: #000;
}
.boxBtnPlanIndex .aBtnLink::after{
    content: "";
    background: url(../img/common/imgBack.png) center / contain no-repeat;
    width: 30px;
    height: 6px;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 30px;
    margin: auto;
}
@media only screen and (max-width:767px){
    .boxBtnPlanIndex{
        margin-top: 50px;
    }
    .boxBtnPlanIndex .aBtnLink{
        font-size: 14px;
        letter-spacing: 0.7px;
        max-width: 325px;
        width: 100%;
        padding: 20px 0;
    }
    .boxBtnPlanIndex .aBtnLink::after{
        left: 20px;
    }
}

.secIndex .item{
    overflow: hidden;    
    height: 0;
}
.secIndex .item.show{
    overflow: visible;
    height: auto;
}
/* プランのタブ切り替え */
.secPlanTab {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    max-width: 1400px;
    margin: 60px auto;
}
.secPlanTab .boxTab {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-direction: column;
    flex-direction: column;
    -webkit-justify-content: center;
    justify-content: center;
    position: relative;
    width: 48.572%;
    height: 130px;
    padding-bottom: 5px;
    padding-left: 9.226%;
    color: #fff;
}
.secPlanTab .boxTab {
    padding-bottom: 0;
    cursor: pointer;
}
.secPlanTab .boxTab:hover{
    filter:alpha(opacity=80); 
    opacity:0.8;
    -webkit-transition:opacity 0.2s ease-out;
    -moz-transition:opacity 0.2s ease-out;
    -ms-transition:opacity 0.2s ease-out;
    transition:opacity 0.2s ease-out;
}
.secPlanTab .boxTab.active {
    background: #012923;
    color: #fff;
}
.secPlanTab .boxTab.active:before {
    display: none;
}
.secPlanTab .boxTab {
    position: relative;
    background: #fff;
    border: 3px solid #012923;
    color: #012923;
    padding-left: 11.226%;
}
.secPlanTab .boxTab::before {
    content:"";
    display:block;
    width:100%;
    height:7px;
    background-color:#cccccc;
    position:absolute;
    bottom:0;
    left:0;
    z-index: 2;
}
.secPlanTab .boxTab .boxImg {
    position: absolute;
    right: 20px;
    bottom: 0;
}
.secPlanTab .boxTxt {
    font-weight: 700;
    line-height: 40px;
    letter-spacing: .25px;
    font-size: 32px;

}
@media only screen and (max-width:767px){
    
    .secPlanSlider .item.show{ padding:0;}
    .secPlanTab {
        margin-top: 35px;
        margin-bottom: 30px;
    }
    .secPlanTab .boxTab {
        width: 48.41%;
        height: 68px;
        padding-left: 23px!important;
        border: 1px solid #012923;
    }
    .secPlanTab .boxTxt {
        font-size:18px;
        line-height: 1.2;
    }
    .secPlanTab .boxTab .boxImg{
        right: 0;
    }
    .secPlanTab .boxTab::before{
        height: 4px;
    }
}

@media only screen and (max-width:360px){
    .secPlanTab .boxTab .boxImg{
        width: 50%;
    }
    .secPlanTab .boxTab .boxImg img{
        width: 100%;
        height: auto;
    }
}

