@charset "utf-8";

body {
	font-family: 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', sans-serif;
	font-size: 24px;
	-webkit-text-size-adjust: none;
	color: #000000;
}

.clearfix {
 *zoom: 1;
}
.clearfix:before, .clearfix:after {
	display: table;
	content: "";
	line-height: 0;
}
.clearfix:after {
	clear: both;
}

.form_container{
    width: 960px;
    margin: auto;
}

.nav-open{
    overflow: hidden;
    position: fixed;
}

@media only screen and (max-width: 960px) {
    .form_container{
        width: 100%;
    }
}

/* **********************
　ヘッダー部分
********************** */

/* #form_header */

#form_header{
    border-bottom: 8px solid #080882;
}

#form_logo{
    float: left;
}

#form_tel_sp,
#form_tel_wrapper{
    display: none;
}

#form_tel_pc{
    float: right;
    text-align: left;
    padding: 16px 0;
    text-decoration: none;
    color: #333333;
    font-size: 20px;
    font-weight: bold;
    position: relative;
}

#form_tel_pc #form_tel_btn{
    display: block;
    cursor: pointer;
    font-size: 16px;    
    line-height: 18px;
    color: #5184a8;
    border: 2px solid #5184a8;
    padding: 10px 25px 10px 35px;
}

#form_tel_pc #form_tel_btn:before{
    content: url(../images/tel_icon.jpg);
    display: inline-block;
    vertical-align: middle;
    margin-right: 10px;
}

#form_tel_pc ul{
    position: absolute;
    width: 100%;
    opacity: 0;
    height: 0;
    z-index: 999;
}

#form_tel_pc ul.show {
    opacity: 1;
    height: auto;
}

#form_tel_pc li{
    color: white;
    font-size: 16px;
    background: #5184a8;
    padding: 10px 40px;
    -webkit-transform-origin: 0 0;
    -moz-transform-origin: 0 0;
    -ms-transform-origin: 0 0;
    -o-transform-origin: 0 0;
    transform-origin: 0 0;
    -webkit-transition: all 0.15s;
    -o-transition: all 0.15s;
    transition: all 0.15s;
    -webkit-transform: scale(1, 0);
    -ms-transform: scale(1, 0);
    transform: scale(1, 0);
    opacity: 0;
    border-top: 1px solid white;
    font-weight: normal;
}

#form_tel_pc li:first-child:before{
    content: "";
    position: absolute;
    left: 50%;
    top: -10px;
    margin-left: -10px;
    border-style: solid;
    border-width: 0 10px 10px 10px;
    border-color: transparent transparent #5184a8 transparent;
    -webkit-transition: border 0.15s;
    -o-transition: border 0.15s;
    transition: border 0.15s;
}

#form_tel_pc ul.show li{
    -webkit-transform: scale(1, 1);
    -ms-transform: scale(1, 1);
    transform: scale(1, 1);
    opacity: 1;
}

#form_tel_pc li span{
    font-size: 12px;
    display: block;
    margin-top: 3px;
}

@media only screen and (max-width : 768px) {
    #form_header{
        border-bottom: 4px solid #080882;
        height: 75px;
    }
    
    #form_logo{
        width: 65%;
        padding-left: 2%;
        height: 75px;
        overflow: hidden;
    }

    #form_tel_pc{
        display: none;
    }
    
    #form_tel_sp{
        display: block;
        float: right;
        z-index: 999;
        position: relative;
        width: 30%;
        height: 75px;
    }
    
    #form_tel_sp #form_tel_toggle{
        display: block;
        cursor: pointer;
        font-size: 16px;
        color: white;
        padding: 0 0 0 33%;
        height: 100%;
        background: #5184a8;
        position: relative;
        box-sizing: border-box;
        line-height: 20px;
    }
    
    #form_tel_sp #form_tel_toggle #on{
        display: none;
        padding: 27px 0 27px 10px;
        font-size: 24px;
        
    }
    
    #form_tel_sp #form_tel_toggle #on:before{
        content: "";
        background: url(../images/tel_icon_close.jpg) no-repeat left center;
        width: 25px;
        height: 25px;
        background-size: 25px 25px;
        position: absolute;
        left: 20px;
        top: 0;
        bottom: 0;
        margin: auto;
    }
    
    #form_tel_sp #form_tel_toggle #off{
        display: block;
        padding: 17px 0;
    }
    
    #form_tel_sp #form_tel_toggle #off:before{
        content: "";
        background: url(../images/tel_icon_sp.jpg) no-repeat left center;
        width: 25px;
        height: 25px;
        background-size: 25px 25px;
        position: absolute;
        left: 20px;
        top: 0;
        bottom: 0;
        margin: auto;
    }

        
    #form_tel_wrapper{
        width: 100%;
        background: white;
        position: absolute;
        left: 0;
        box-sizing: border-box;
        border: 20px solid #5184a8;
        top: 75px;
        z-index: 999;
    }
    
    #form_tel_wrapper ul.show{
        opacity: 1;
    }
    
    #form_tel_wrapper ul li{
        background: white;
        color: #333333;
        padding: 10px 20px;
        border-top: 2px solid #5184a8;
        font-size: 18px;
    }
    
    #form_tel_wrapper ul li a{
        color: #333333;
        text-decoration: none;
        font-size: 18px;
    }
    
    #form_tel_wrapper ul li span{
        display: block;
        font-size: 14px;
        margin-top: 5px;
    }
}

@media only screen and (max-width : 530px) {
    #form_header{
        height: 42px;
    }
    
    #form_logo {
        width: 200px;
        padding-left: 2%;
        height: 42px;
    }
    
    #form_logo img{
        max-width: 100%;
    }
    
    #form_tel_sp{
        height: 42px;
    }
    
    #form_tel_sp #form_tel_toggle{
        font-size: 10px;
        padding: 0 0 0 30%;
        line-height: 10px;
    }
    
    #form_tel_sp #form_tel_toggle #off{
        padding: 11px 0;
    }
    
    #form_tel_sp #form_tel_toggle #on{
        padding: 17px 0 15px 10px;
        font-size: 10px;
    }
    
    #form_tel_sp #form_tel_toggle #off:before {
        width: 15px;
        height: 15px;
        background-size: 15px 15px;
        left: 10%;
    }
    
    #form_tel_sp #form_tel_toggle #on:before {
        width: 15px;
        height: 15px;
        background-size: 15px 15px;
        left: 14%;
    }
    
    #form_tel_wrapper{
        top: 42px;
    }
    
}

@media only screen and (max-width : 321px) {
    #form_tel{
        padding: 0%;
    }   
    
}



/* #form_banner */
#form_banner{
    background: url(../images/form-banner.jpg) no-repeat center top;
    height: 312px;
    background-color: #fcfcfc;
}

#form_banner .form_container{
    padding-left: 40px;
    box-sizing: border-box;
    position: relative;
}

#form_banner h1{
    font-size: 36px;
    line-height: 40px;
    color: #080882;
    font-weight: bold;
    padding: 30px 0;
}

#form_container_p01{
    font-size: 16px;
    color: #000000;
    line-height: 24px;
}

#form_container_p01 span{
    color: #cc3333;
}

#form_banner ul{
    padding-top: 40px;
}

#form_banner ul li{
    float: left;
    margin-left: 2%;
    color: #000000;
    font-size: 16px;
    line-height: 24px;
    border: 1px solid #000055;
    background: white;
    padding: 25px 25px 15px 35px;
    position: relative;
    text-align: center;
}

#form_banner ul li:first-child{
    margin-left: 0;
}

#form_banner ul li:before{
    text-align: center;
    color: white;
    font-size: 16px;
    background: #000055;
    position: absolute;
    left: 0;
    top: 0;
    padding: 0 8px;
}

#form_banner ul li span{
    font-size: 18px;
    color: #cc3333;
    font-weight: bold;
}

#form_banner ul li#form_point01:before{
    content: "1";  
}
#form_banner ul li#form_point02:before{
    content: "2";  
}
#form_banner ul li#form_point03:before{
    content: "3";  
}

@media only screen and (max-width : 768px) {
    #form_banner .form_container{
        padding-left: 0px;
    }
    
    #form_banner{
        background: white;
        height: auto;
    }
    
    #form_banner h1{
        background: url(../images/form_h1_sp.jpg) no-repeat center;
        background-size: cover;
        text-align: center;
        color: white;
        padding: 4% 0;
        font-size : 5.63vw;
    }
    
    #form_container_p01{
        padding: 3%;
    }
    
    #form_container_p01 .break{
        display: none;
    }
    
    #form_banner ul{
        padding: 0 3%;
    }
    
    #form_banner ul li{
        padding: 6% 0% 2% 0%;
        width: 32%;
        box-sizing: border-box;
        line-height: 20px;
        font-size: 2.51vw;
    }

    #form_banner ul li span{
        font-size: 2.51vw;
    }
}


@media only screen and (max-width : 321px){ 

    #form_banner ul li{
        font-size: 2.01vw;
    }

    #form_banner ul li span{
        font-size: 2.01vw;
    }
}



/* #form_step */
#form_step{
    padding-top: 25px;
    margin: auto;
    text-align: center;
    clear: both;
}

#form_step p{
    font-size: 12px;
    line-height: 20px;
    padding: 40px 0 40px 130px;
    text-align: left;
}

#form_step p img{
    vertical-align: middle;
}

#form_step_sp{
    display: none;
}

@media only screen and (max-width : 960px) {
    #form_step{
        padding: 5% 2%;
    }
    
    #form_step img{
        max-width: 100%;
    }
    
    #form_step p{
        padding: 20px 10px;
    }
}

@media only screen and (max-width : 768px) {
    #form_step_sp{
        display: block;
    }
    
    #form_step_pc{
        display: none;
    }
    
    #form_step p{
        padding: 1% 0 2% 0;
    }
    
    #form_step p span{
        display: block;
    }
}


/* **********************
　フッター部分
********************** */
#form_footer{
    background: #000055;
}

#form_footer p{
    font-size: 16px;
    color: #eae9e9;
    text-align: center;
    padding: 28px 0;
}



/* **********************
　フォーム部分
********************** */
.form_wrapper{
    width: 760px;
    margin: auto;
    background: white;
    border: 1px solid #eeeeee;
    box-sizing: border-box;
    margin-bottom: 50px;
}

.form_wrapper tr{
    border-bottom: 1px solid #eeeeee;
    position: relative;
}

.form_wrapper tr td{
    position: relative;
}

.form_wrapper th,
.form_wrapper td{
    font-size: 12px;
    line-height: 17px;
    padding: 25px;
}

.form_wrapper th,
.form_wrapper td.tdSituation{
    background: #eeeeee;
}

.form_wrapper th, .form_wrapper td.tdSituation{
    text-align: left;
    border-top: 1px solid #dedede;
}

.form_wrapper tr:first-child th, .form_wrapper tr:first-child td.tdSituation{
    border-top: 0;
}

.form_wrapper td.tdSituation{
    padding: 25px 15px;
}

.form_wrapper input{
    border: 1px solid #d4d4d4;
    border-radius: 5px;
    padding: 3%;
    width: 90%;
    box-sizing: border-box;
    -webkit-box-shadow: inset 1px 2px 0px 0px rgba(199,197,197,1);
    -moz-box-shadow: inset 1px 2px 0px 0px rgba(199,197,197,1);
    box-shadow: inset 1px 2px 0px 0px rgba(199,197,197,1);
}

.form_wrapper textarea{
    border: 1px solid #d4d4d4;
    border-radius: 5px;
    padding: 3%;
    box-sizing: border-box;
    -webkit-box-shadow: inset 1px 2px 0px 0px rgba(199,197,197,1);
    -moz-box-shadow: inset 1px 2px 0px 0px rgba(199,197,197,1);
    box-shadow: inset 1px 2px 0px 0px rgba(199,197,197,1);
    vertical-align: top;
}

.form_wrapper textarea.inner_textarea{
    margin-top: 10px;
}

.form_wrapper select{
    border: 1px solid #d4d4d4;
    padding: 3%;
    box-sizing: border-box;
    width: 90%;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background: #eee;
    background: url(../images/select-arrow.png) right 50% no-repeat;
    background-color: white;
    outline: none;
    background-size: auto 100%;
    outline: none;
}


select:-moz-focusring {
    color: transparent;
    text-shadow: 0 0 0 #000;
}


.form_wrapper input[type="checkbox"],
.form_wrapper input[type="radio"]{
    margin-right: 20px;
    padding: 5px 0;
}

.form_wrapper input[type=checkbox] + label,
.form_wrapper input[type=radio] + label{
    position: relative;
    padding: 0px 0px 0px 27px;
    line-height: 25px;
}

.form_wrapper input[type=radio].check_type01{
    width: 1px;
    margin: 0;
    opacity: 0;
}
 
.form_wrapper input[type=radio].check_type01 + label:before{
    background: url(../images/form_check.jpg) no-repeat;
    height: 18px;
    width: 18px;
    background-position: 0% 0%;
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    margin: auto;
}

.form_wrapper input[type=radio].check_type01:checked + label:before{
    background-position: 0% 100%;
}

.form_wrapper input[type=checkbox].check_type02{
    display:none;
}
 
.form_wrapper input[type=checkbox].check_type02 + label:before{
    background: url(../images/form_check02.jpg) no-repeat;
    height: 18px;
    width: 18px;
    background-position: 0% 0%;
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    margin: auto;
}

.form_wrapper input[type=checkbox].check_type02:checked + label:before{
    background-position: 0% 100%;
}

input[type=submit].form_submit{
    background: #2eca4d; /* Old browsers */
    background: -moz-linear-gradient(top,  #2eca4d 0%, #22ac38 100%); /* FF3.6-15 */
    background: -webkit-linear-gradient(top,  #2eca4d 0%,#22ac38 100%); /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(to bottom,  #2eca4d 0%,#22ac38 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#2eca4d', endColorstr='#22ac38',GradientType=0 ); /* IE6-9 */
    color: white;
    font-weight: bold;
    border: 0;
    border-radius: 5px;
    width: 400px;
    padding: 28px 0px;
    margin: auto;
    font-size: 20px;
}

input[type=submit].form_submit:hover{
    background: #4bee75; /* Old browsers */
    background: -moz-linear-gradient(top,  #4bee75 0%, #3ce05e 100%); /* FF3.6-15 */
    background: -webkit-linear-gradient(top,  #4bee75 0%,#3ce05e 100%); /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(to bottom,  #4bee75 0%,#3ce05e 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#4bee75', endColorstr='#3ce05e',GradientType=0 ); /* IE6-9 */
}

.form_wrapper input.required_field{
    width: 90%;
}

#form_privacy{
    margin-top: 50px; 
    margin-bottom: 100px;
}

#form_privacy .form_container{
    padding: 0 20px;
    box-sizing: border-box;
}

#privacy_wrapper{
    overflow:auto;
    -webkit-overflow-scrolling:touch;
    display: inline-block;
    width: 100%;
    height: 400px;
}

#privacy_wrapper iframe{
    width:100%;
    height:100%;
    border:none;
    display:block;
    font-size: 12px;
    line-height: 18px;
    box-sizing: border-box;
    -webkit-box-shadow: inset 2px 2px 0px 0px rgba(154,154,154,1);
    -moz-box-shadow: inset 2px 2px 0px 0px rgba(154,154,154,1);
    box-shadow: inset 2px 2px 0px 0px rgba(154,154,154,1);
    border: 1px solid #9a9a9a;
}

#form_privacy_frame p{
    font-size: 14px;
    line-height: 18px;
    padding: 10px 0;
}

.form_wrapper .errtext{
    width: 100%;
    color: white;
    display: block;
    background: url(../images/error_mark.gif) no-repeat center left;
    background-position: 4px 5px;
    background-color: #FE0000;
    margin-top: 10px;
    padding: 0px 23px;
    line-height: 22px;
    box-sizing: border-box;
}

.checkmark{
    width: 8%;
    text-align: center;
    position: absolute;
    top: 30px;
    right: 20px;
}

.checkmark.checkmark-ab{
    position: absolute;
    top: 22px;
    right: 20px;
}

@media only screen and (max-width : 760px) {
    .form_wrapper{
        width: 96%;
        border-left: 0;
        border-right: 0;
    }
    
    .form_wrapper tr{
        padding: 3% 5%;
        display: block;
    }
    
    .form_wrapper th{
        display: block;
        background: white!important;
        padding: 0;
        border-left: 5px solid #2a55c9;
        padding-left: 2%;
        line-height: 30px;
        font-weight: bold;
        margin-bottom: 2%;
    }
    
    .form_wrapper th .sp-break{
        display: none;
    }
    
    .form_wrapper td{
        display: block;
        background: white!important;
        padding: 0;
    }
    
    .form_wrapper th, .form_wrapper td.tdSituation{
        border-top: 0;
    }

    
    .form_wrapper input[type=checkbox] + label,
    .form_wrapper input[type=radio] + label{
        line-height: 36px;
        margin-left: 5%;
    }
    
    .form_wrapper select{
        height: 40px;
        line-height: 30px;
        padding: 0 3%;
    }

    .form_wrapper textarea{
        width: 90%;
    }
    
    #form_privacy .form_container{
        padding: 2%;
    }
    
    input[type=submit].form_submit{
        width: 90%;
        margin: auto;
        height: auto;
        background-size: 100% auto;
        font-size: 18px;
    }
    
    .form_wrapper td.tdSituation{
        position: absolute;
        right: 5%;
        top: 17px;
        padding: 0;
    }
    
    #privacy_wrapper{
        height: 200px;
    }
    
    #form_privacy{
        margin-bottom: 50px;
    }
    
    .checkmark{
	    position: relative;
	    vertical-align: middle;
	    display: inline-block;
        top: auto;
   		right: auto;
	}
}

@media only screen and (max-width : 321px) {
    input[type=submit].form_submit{
        font-size: 16px;
    }

}



/* **********************
　サンクスページ
********************** */

#form_thanks_container{
    width: 960px;
    margin: auto;
    padding: 35px 0;
}

#form_thanks_step{
    text-align: center;
}

#form_step_sp{
    display: none;
    text-align: center;
    max-width: 100%;
    margin: auto;
}

#form_thanks h1{
    color: #080882;
    padding: 35px 0;
    font-size: 36px;
    text-align: center;
}

#form_thanks_text{
    text-align: center;
    width: 100%;
}

#form_thanks p{
    font-size: 16px;
    line-height: 30px;
    color: #333333;
}


#form_thanks a{
    color: #00a0e9;
    text-decoration: underline;
    font-size: 16px;
    margin-top: 35px;
    display: block;
}

@media only screen and (max-width : 960px) {
    #form_thanks_container{
        width: 98%;
        margin: auto;
    }
}

@media only screen and (max-width : 768px) {
    #form_step_sp{
        display: block;
    }
    
    #form_step_pc{
        display: none;
    }
    
    #form_thanks h1{
        font-size: 20px;
        font-weight: bold;
    }
    
    #form_thanks p,
    #form_thanks a{
        font-size: 13px;
    }
    
    #form_thanks_text{
        text-align: left;
        width: 70%;
        margin: auto;
    }
}