@charset "utf-8";

.secCmnIndexTop{
    background: url(../img/mypage/bgCmnIndexTop.jpg) center top / cover;
}
@media only screen and (max-width:767px){
    .secCmnIndexTop{
        background: url(../img/mypage/bgCmnIndexTop_sp.jpg) center top / cover;
    }
}

/* secMypage */
.secMypage{
    margin-top: 50px;
}
.secMypage .tabList{
    display: flex;
}
.secMypage .tabItem{
    width: 31.16%;
    margin-right: 3.26%;
}
.secMypage .tabItem:last-child{
    margin-right: 0;
}
.secMypage .inner{
    width: 100%;
    height: 70px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    font-weight: 700;
    color: #000;
    background: #e7efef;
    border-radius: 15px;
    text-decoration: none;
    position: relative;
    letter-spacing: 1px;
}
.secMypage .inner::after{
    position: absolute;
    content: "";
    width: 32px;
    height: 32px;
    left: calc(50% - 16px);
    bottom: -16px;
    border: solid 1px #fff;
    border-radius: 50%;
}
.secMypage .inner.lazyloaded::after{
    background: url(../img/mypage/iconArrow.png) center center / 10px auto no-repeat #646868;
}
.secMypage .inner.active{
    background: #ed1b24;
    color: #fff;
}
.secMypage .inner.active.lazyloaded::after{
    background-color: #ed1b24;
}
.secMypage  .txtBox{
    margin-top: 89px;
}
.secMypage .titName{
    font-size: 30px;
    line-height: 1.6;
    text-align: center;
    font-weight: 700;
}
.secMypage .titNameUnder{
    font-size: 22px;
    line-height: 1.6;
    text-align: center;
    font-weight: 700;
    margin-top: 8px;
    letter-spacing: 2px;
}
@media only screen and (max-width:767px){
    .secMypage{
        margin-top: 0;
    }
    .secMypage .tabItem{
        width: 30.435%;
        margin-right: 4.3475%;
    }
    .secMypage .inner{
        width: 100%;
        height: 60px;
        font-size: 12px;
        line-height: 1.33;
        text-align: center;
        padding-bottom: 10px;
    }
    .secMypage .inner::after{
        width: 28px;
        height: 28px;
        left: calc(50% - 14px);
        bottom: -14px;
    }
    .secMypage  .txtBox{
        margin-top: 37px;
    }
    .secMypage .titName{
        font-size: 18px;
    }
    .secMypage .titNameUnder{
        font-size: 14px;
        margin-top: 10px;
        letter-spacing: 1px;
    }
}


/*==============================
    datepicker
==============================*/
.ui-widget.ui-widget-content{
	z-index: 1000 !important;
}

/*==============================
    mailcomplete
==============================*/
.ui-menu-item-wrapper{
	font-size: 13px;
	padding: 10px 15px !important;
}

/*==============================
    btnSendCo
==============================*/
.btnSendCo.no_tap,
.btnSendCoBack.no_tap{
    opacity: 0.3 !important;
    pointer-events: none !important;
    transition: none !important;
}
.btnSendCo.no_tap{
    opacity: 1 !important;
    background: url(../img/common/iconLoader.gif) center center / 32px auto no-repeat !important;
    font-size: 0 !important;
}

/*==============================
    secCmnForm
==============================*/
.secCmnForm{
    margin-top: 95px;
}
.secCmnForm .secFormWrap{
    width: calc(100% - 40px);
    max-width: 1320px;
    margin: 0 auto;
    background: #fff;
}
.secCmnForm .secForm {
    width: calc(100% - 40px);
    max-width: 1160px;
    margin: 0 auto;
}
@media only screen and (max-width:767px){
    .secCmnForm{
        margin-top: 15px;
    }
    .secCmnForm .secFormWrap{
        width: 100%;
        max-width: 100%;
    }
    .secCmnForm .secForm{
        width: 100%;
        max-width: 100%;
        padding: 0;
    }
}


/*==============================
    secFormTable
==============================*/
.secFormTable{
    width: 100%;
    margin: 0 auto;
    font-size: 0;
    border-top: solid 1px rgba(0, 0, 0, 0.2);
}
.secFormTable tr{
	border-bottom: solid 1px rgba(0, 0, 0, 0.2);
}
.secFormTable th,
.secFormTable td{
	letter-spacing: 1px;
	vertical-align: top;
	line-height: 1.5;
	padding: 50px 0;
}
.secForm td.hide .formError{
    display: none !important;
}
.secFormTable td.boxPass{
    position: relative;
}
.secFormTable th{
	width: 200px;
	position: relative;
	line-height: 2;
	padding: 45px 0;
	font-size: 15px;
	font-weight: 700;
}
.secCmnForm  .txtMust{
	position: absolute;
	width: 46px;
	display: inline-block;
	text-align: center;
	font-size: 11px;
	line-height: 18px;
	left: 0;
	color: #fff;
	padding: 2px 0;
	margin-right: 14px;
	vertical-align: text-bottom;
	top: 48px;
    border: solid 1px #dc0101;
    color: #dc0101;
}
.secCmnForm  .txtMust.no_must{
    border: solid 1px #055c64;
    color: #055c64;
}
.secFormTable td{
    width: calc(100% - 200px);
    vertical-align: middle;
    position: relative;
    padding: 30px 0;
}
.secFormTable input[type="text"], 
.secFormTable input[type="tel"], 
.secFormTable input[type="email"], 
.secFormTable input[type="number"], 
.secFormTable input[type="password"], 
.secFormTable select,
.secFormTable textarea{
    height: 60px;
    border: solid 1px #e1e1e1;
    font-size: 16px;
    padding-left: 15px;
    padding-right: 15px;
    background: #fff;
    position: relative;
    font-family: inherit;
    color: #1a1a1a;
}
.secFormTable textarea{
    width: 100%;
    height: 200px;
    padding: 10px 20px;
    line-height: 2;
    display: block;
}
.secFormTable input[type="checkbox"],
.secFormTable input[type="radio"] {
    width: 22px;
    height: 22px;
    margin: 0;
}
.secFormTable input::placeholder,
.secFormTable textarea::placeholder{
    color: rgba(0, 0, 0, 0.5);
}
.secFormTable .tdCalemder .flBox{
    display: flex;
    align-items: center;
}
.secFormTable .tdCalemder .timeWrapper{
    margin-left: 40px;
    display: flex;
    align-items: center;
}
.secFormTable .tdCalemder .timeTxt{
    font-size: 16px;
    margin-right: 10px;
}
.secFormTable .boxZip.flex{
    display: flex;
    align-items: center;
}
.secFormTable .boxZip{
    margin-top: 15px;
    font-size: 16px;
}
.secFormTable .boxZip.top{
    margin-top: 0;
}
.secFormTable .zipbtn{
    width: 130px;
    height: 40px;
    background: #1a1a1a;
    border-radius: 20px;
    font-size: 12px;
    letter-spacing: 1px;
    text-align: center;
    text-decoration: none;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    margin-left: 15px;
}
.secFormTable .boxZip .selectbox + .citybox{
    margin-left: 15px;
    flex: 1;
}
.secFormTable td .label03{
    font-size: 15px;
}
.secFormTable td .label03 a{
    color: #006699;
    text-underline-offset: 10px;
    display: inline-block;
}
.secFormTable td .checkPrivacy{
    margin: -2px 15px 0 0;
    width: 22px;
    height: 22px;
}
.secFormTable .txtNote{
	font-size: 12px;
	margin-top: 14px;
	line-height: 1.5;
}
.secFormTable .txtNote02{
	font-size: 12px;
	margin-top: 14px;
	line-height: 1.5;
    color: #dc0101;
}
.secFormTable .txtError,
.secFormCalendar .txtError{
	color: #f00;
	font-size: 12px;
	background: url(../img/common/iconError.png) left top no-repeat;
	background-size: 14px;
	padding: 0 0 0 17px;
	margin-top: 10px;
	line-height: 14px;
}
.secFormCalendar .txtError{
	margin-bottom: 10px;
}
.secFormTable .borderNone{
    border: none!important;
}
.secFormTable .txtMust.topCenter{
    top: calc(50% - 12px);
}
@media only screen and (max-width:767px){
    .secFormTable,
	.secFormTable tbody,
	.secFormTable tr,
	.secFormTable th,
	.secFormTable td {
		display: block;
	}
    .secFormTable{
        border-top: none;
    }
    .secFormTable{
        width: 92%;
    }
    .secFormTable th,
    .secFormTable td{
        line-height: 1.5;
        font-size: 13px;
        padding: 15px 0;
    }
    .secFormTable th,
    .secFormTable .privacy th{
        width: 100%;
        padding: 20px 0 0;
        position: relative;
    }
    .secCmnForm  .txtMust{
        left: auto;
        position: absolute;
        right: 0;
        top: 18px;
        margin: 0;
        font-size: 11px;
    }
    .secFormTable td,
    .secFormTable .privacy td{
        width: 100%;
        vertical-align: top;
        padding: 18px 0 25px;
    }
    .secFormTable input[type="text"], 
    .secFormTable input[type="tel"], 
    .secFormTable input[type="email"], 
    .secFormTable input[type="number"], 
    .secFormTable input[type="password"], 
    .secFormTable select,
    .secFormTable textarea {
        height: 48px;
        padding-left: 15px;
        padding-right: 15px;
    }
    .secFormTable textarea{
        height: 150px;
        padding: 10px;
        line-height: 2;
        font-size: 16px;
    }
    .secFormTable input::placeholder{
        font-size: 16px;
    }
    .secFormTable .tdCalemder .flBox{
        display: block;
    }
    .secFormTable .tdCalemder .timeWrapper{
        margin: 15px 0 0;
    }
    .secFormTable .tdCalemder .timeTxt{
        font-size: 13px;
        margin-right: 10px;
    }
    .secFormTable .boxZip.flex{
        display: block;
    }
    .secFormTable .boxZip{
        margin-top: 10px;
        font-size: 13px;
    }
    .secFormTable .boxZip.top{
        display: flex;
        flex-wrap: wrap;
    }
    .secFormTable .zipbtn{
        width: 110px;
        height: 34px;
        border-radius: 17px;
        font-size: 10px;
        letter-spacing: 1px;
        margin-left: 10px;
    }
    .secFormTable td .label03{
        font-size: 13px;
    }
    .secFormTable .txtNote{
        font-size: 11px;
        line-height: 1;
        margin-top: 14px;
    }
    .secFormTable .txtNote02{
        font-size: 11px;
        line-height: 1;
        margin-top: 14px;
    }
    .secFormTable .boxZip .selectbox + .citybox{
        margin-left: 0px;
        margin-top: 10px;
        flex: 1;
    }
    .secCmnForm .privacy .txtMust{
        top: 24px;
    }
    .secFormTable td .label03 a{
        text-underline-offset: 5px;
    }
    .secFormTable td .checkPrivacy{
        margin: -2px 10px 0 0;
        width: 20px;
        height: 20px;
    }
    .secFormTable .txtMust.topCenter{
        top: 18px;
    }
    .secForm .secEventForm{
        border-top: solid 1px rgba(0, 0, 0, 0.2);
    }
}
/* secCmnFormBtn */
.secCmnFormBtn .btnForm{
    font-size: 17px;
    font-weight: bold;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #ed1b24;
    height: 86px;
    color: #fff;
    width: 480px;
    margin: 80px auto 0;
    text-decoration: none;
    letter-spacing: 2px;
    border-radius: 15px;
    position: relative;
}
.secCmnFormBtn .btnForm.lazyloaded{
    background: url(../img/common/iconFormArrow.gif) center right 30px / 8px auto no-repeat #ed1b24;
}
@media only screen and (max-width:767px){
    .secCmnFormBtn .btnForm{
        font-size: 14px;
        height: 55px;
        width: 76%;
        margin: 38px auto 0;
        letter-spacing: 1px;
    }
    .secCmnFormBtn .btnForm.lazyloaded{
        background: url(../img/common/iconFormArrow.gif) center right 20px / 8px auto no-repeat #ed1b24;
    }
}
/* secCmnFormBtn back */
.secCmnFormBtn .btnBack{
    background: #fff;
    color: #ed1b24;
    border: solid 1px #ed1b24;
    width: 380px;
    height: 70px;
    font-size: 17px;
    font-weight: bold;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 40px auto 0;
    text-decoration: none;
    letter-spacing: 2px;
    border-radius: 15px;
    position: relative;
}
.secCmnFormBtn .btnBack.lazyloaded{
    background: url(../img/common/iconFormArrow02.gif) center left 30px / 8px auto no-repeat #fff;
}
@media only screen and (max-width:767px){
    .secCmnFormBtn .btnBack{
        height: 50px;
        width: 80%;
        font-size: 14px;
        margin: 30px auto 0;
        letter-spacing: 1px;
    }
    .secCmnFormBtn .btnBack.lazyloaded{
        background: url(../img/common/iconFormArrow02.gif) center left 20px / 8px auto no-repeat #fff;
    }
}
/* secFormTxtBox */
.secFormTxtBox{
    margin-top: 30px;
    background: #f8f8f8;
    padding: 32.5px 40px;
}
.secFormTxtBox .txt{
    font-size: 13px;
    line-height: 2.07;
    color: #333;
}
@media only screen and (max-width:767px){
    .secFormTxtBox{
        margin: 25px auto 0;
        width: 92%;
        padding: 24px 20px;
    }
    .secFormTxtBox .txt{
        font-size: 11px;
        line-height: 2;
    }
}

/*================================================
    確認ページ
================================================*/
.secCmnForm.co{
    margin-top: 0;
}
.secFormTable.co td{
    padding-left: 40px;
    font-size: 16px;
}
.secFormTable.co th{
    padding-left: 0;
}
@media only screen and (max-width:767px){
    .secFormTable.co th{       
        padding: 30px 0 0;
    }
    .secFormTable.co td{
        padding: 15px 0 30px;
        font-size: 13px;
    }
    .secFormTable.co td .bold{
        font-weight: bold;
    }
    .secCmnForm.co .secForm{
        padding-bottom: 60px;
    }
}
/*================================================
    完了ページ
================================================*/
.secCmnForm.ok{
    margin-top: 0;
}
.secCmnForm.ok .secForm.ok{
    padding: 80px 0 80px;
}
.secForm.ok .sendOk{
    font-size: 30px;
    line-height: 1.5;
    font-weight: bold;
    letter-spacing: 1px;
    text-align: center;
}
.secForm.ok .txtNote{
    font-size: 16px;
    line-height: 1.8;
    text-align: center;
    margin-top: 50px;
}
@media only screen and (max-width:767px){
    .secForm.ok .sendOk{
        font-size: 18px;
        padding: 0 4%;
    }
    .secForm.ok .txtNote{
        font-size: 13px;
        text-align: left;
        margin-top: 30px;
        padding: 0 4%;
    }
}
/* 幅・スペース指定　*/
.secFormTable .mr10 {margin-right: 10px;}
.secFormTable .w200 {width: 200px;}
.secFormTable .w250 {width: 250px;}
.secFormTable .w400 {width: 400px;}
.secFormTable .w500 {width: 500px;}
.secFormTable .w100p {width: 100%;}
@media only screen and (max-width:767px){
    .secFormTable .ws160 {width: 160px;}
    .secFormTable .ws245 {width: 245px;}
    .secFormTable .ws100p {width: 100%;}
    .secFormTable .mrs5 {margin-right: 5px;}
}


.wpcf7-list-item.last,
.wpcf7-not-valid-tip,
.hidden{display: none!important;}
.lastBlock .wpcf7-list-item.last{display: block!important;}

.secCmnFormBtn input{
    position: absolute;
    left: 0;
    top: 0;
    z-index: 10;
    width: 100%;
    height: 100%;
    opacity: 0;
    padding: 0;
    margin: 0;
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
    font-size: 0;
    background: inherit;
    border: none;
}
.secCmnFormBtn .wpcf7-spinner{
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
}
.wpcf7-form-control-wrap {
    position: relative;
}
.secForm .wpcf7-list-item {
    display: block;
    margin: 0;
}
.secFormTable input[type="checkbox"] {
    width: 23px;
    height: 23px;
    margin: 0 3px 0 0;
    visibility: hidden;
    position: absolute;
}
.secFormTable input[type="checkbox"] {
    accent-color: #a40f17;
}
.secFormTable .wpcf7-list-item-label {
    position: relative;
    font-size: 15px;
    padding-left: 37px;
}
.secFormTable input[type="checkbox"] + .wpcf7-list-item-label::before {
    content: '';
    height: 23px;
    width: 23px;
    display: inline-block;
    vertical-align: middle;
    background: #fff;
    border: 1px solid #e1e1e1;
    border-radius: 4px;
    position: absolute;
    top: 1px;
    left: 0;
}
.secFormTable input[type="checkbox"]:checked + .wpcf7-list-item-label::before {
    background: url(../img/common/imgCheckbox.png) center center / auto no-repeat #a40f17;
    border: 1px solid #a40f17;
}
.secFormTable .privacy {
    display: inline-block;
    color: #006699;
    text-decoration: none;
    padding-bottom: 5px;
    border-bottom: 1px solid #006699;
}
.wpcf7-list-item-label::before, .wpcf7-list-item-label::after {
    content: " ";
}
.secFormTable .wpcf7-list-item-label {
    position: relative;
    font-size: 15px;
    padding-left: 37px;
    font-weight: 700;
}
@media only screen and (max-width:767px){
    .secFormTable td.first{
        vertical-align: top;
        padding: 19px 0 9px;
    }
    .secFormTable .wpcf7-list-item-label {
        font-size: 13px;
        padding-left: 32px;
    }
    .secFormTable input[type="checkbox"] + .wpcf7-list-item-label::before {
        height: 20px;
        width: 20px;
        top: 1px;
        left: 0;
    }
}

.secForm .txtForget{
    margin-top: 29px;
    text-align: center;
}
.secForm .linkPass{
    color: #006699;
    font-size: 15px;
    letter-spacing: 1px;
    text-underline-offset: 8px;
}
@media only screen and (max-width:767px){
    .secForm .txtForget{
        margin-top: 24px;
    }
    .secForm .linkPass{
        font-size: 12px;
        text-underline-offset: 6px;
    }
}

.secMypageTop{
    margin-top: 100px;
}
.secMypageTop .formMainTit{
    text-align: center;
    position: relative;
    font-size: 25px;
    line-height: 1.5;
}
.secMypageTop .formTxt {
    text-align: center;
    font-size: 15px;
    line-height: 2.13;
    margin-top: 17px;
    letter-spacing: 1.2px;
}
@media only screen and (max-width:767px){
    .secMypageTop{
        margin-top: 30px;
    }
    .secMypageTop .formMainTit{
        font-size: 18px;
    }
    .secMypageTop .formTxt{
        font-size: 13px;
        margin-top: 13px;
        line-height: 1.84;
        letter-spacing: 0px;
    }
}

/* --------------------------------------------
    secNopass
-------------------------------------------- */
.secNopass{
    padding: 100px 0;
}
.secNopass .noTit{
    font-size: 28px;
    text-align: center;
    letter-spacing: 1px;
}
.secNopass .noTxt{
    margin-top: 30px;
    text-align: center;
    font-size: 15px;
}
.secNopass .btnForm{
    font-size: 17px;
    font-weight: bold;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #ed1b24;
    height: 86px;
    color: #fff;
    width: 480px;
    margin: 80px auto 0;
    text-decoration: none;
    letter-spacing: 2px;
    border-radius: 15px;
    position: relative;
}
.secNopass .btnForm.lazyloaded{
    background: url(../img/common/iconFormArrow.gif) center right 30px / 8px auto no-repeat #ed1b24;
}
@media only screen and (max-width:767px){
    .secNopass{
        padding: 70px 0;
    }
    .secNopass .noTit{
        font-size: 18px;
        letter-spacing: 0.5px;
    }
    .secNopass .noTxt{
        margin-top: 30px;
        font-size: 12px;
    }
    .secNopass .btnForm{
        font-size: 14px;
        height: 55px;
        width: 76%;
        margin: 38px auto 0;
        letter-spacing: 1px;
    }
    .secNopass .btnForm.lazyloaded{
        background: url(../img/common/iconFormArrow.gif) center right 20px / 8px auto no-repeat #ed1b24;
    }
}

.wpcf7-not-valid-tip {
    display: block !important;
    background: url(../img/common/iconError.png) left 2px / 14px auto no-repeat;
    width: 100%;
    color: #F00 !important;
    font-size: 12px !important;
    line-height: 17px !important;
    padding: 0 0 0 17px;
    margin-top: 10px;
}