
 /* ==========================================================================
	main
========================================================================== */
#main {
    position: relative;
    width: 100%;
    padding: 178px 0 0;
    height: 350px;
    box-sizing: border-box;
    background: linear-gradient(90deg, #f5d760, #e68282);
}

#main .hasei_tit {
    font-size: 50px;
    font-weight: 500;
    color: #ffffff;
    margin-bottom: 26px;
}

#main .hasei_s_tit {
    font-size: 16px;
    font-weight: 500;
    color: #fff;
    text-transform: uppercase;
}

#pc_menu {
    -webkit-box-shadow: 4px 4px 10px 0px rgba(141, 141, 141, 0.3);
    -moz-box-shadow: 4px 4px 10px 0px rgba(141, 141, 141, 0.3);
    box-shadow: 4px 4px 10px 0px rgba(141, 141, 141, 0.3);
}

@media screen and (max-width: 800px) {

    #main {
        padding: 160px 0 0;
        height: 240px;
    }

    #main .hasei_tit {
        font-size: 30px;
        margin-bottom: 10px;
    }

    #main .hasei_s_tit {
        font-size: 10px;
    }
}
/* ==========================================================================
	intro
========================================================================== */
#intro{
    position: relative;
    padding:70px 0 80px;
    box-sizing:border-box;
}

#intro .c_txt{
     font-size: 18px;
    line-height: 32px;
    text-align: center;
    margin-bottom: 165px;
    padding:0 15px;
    box-sizing:border-box;
}

#intro h3{
    font-size: 50px;
    font-weight: 500px;
    text-align: center;
}
#intro .c_txt2{
     font-size: 16px;
    line-height: 28px;
    text-align: center;
    margin:40px auto 50px;
    padding:0 15px;
    box-sizing:border-box;
}



#intro .g_box{
    position: relative;
    width:calc(100% - 30px);
    max-width:1200px;
    margin:0 auto;
    background:#f7f7f7;
    padding:30px;
    border-radius:10px;
    box-sizing:border-box;
        
}

#intro .g_box:before{
     content:"";
    display: block;
    position: absolute;
    width: 394px;
    height: 120px;
    left:0;
    right:0;
    top:-120px;
    margin:auto;
    background:url(../image/form_illust.png);
    background-size:cover;
}


.w_box{
    width:100%;
    background:#fff;
    padding:60px 115px 66px;
    border-radius:10px;
    box-sizing:border-box;}
.form{
    width: 100%;    
}
.form li{
	box-sizing:border-box;
	position:relative;
	-js-display: flex;
	display:-webkit-box;
	display: -webkit-flex;
	display:-moz-box;
	display:-ms-flexbox;
	display: flex;
	-webkit-justify-content: space-between;
    justify-content: space-between;
	-webkit-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
			flex-wrap: wrap;
}

.form .text_area,
.form .form_area {
	padding: 20px 0;
	box-sizing:border-box;
}

.conf-area .form .text_area{
    padding-top:30px !important;
}
.conf-area .form .form_area{
	padding: 30px 0  !Important;
}


.form .text_area {
    width: 290px;
	vertical-align: middle;
    font-size: 18px;
    font-weight: bold;
    padding-right:15px;
    box-sizing:border-box;
    padding-top:40px;
}
.form.conf .text_area,
.form.conf .form_area {
     padding-top: 30px;   
}
textarea.form-item{    
    min-height:440px;
    padding:20px 25px;
}
.form .text_area label{
    font-weight: bold;    
}
.form .text_area.req:after{
    content: "必須";
    position: absolute;
    top: 33px;
    font-size: 14px;
    line-height: 35px;
    font-weight: bold;
    color: #fff;
  background: linear-gradient(90deg, #f5d760,#e68282);
    border-radius: 17.5px;
    height: 35px;
    padding: 0 18px;
    margin-left: 22px;
}


.form .form_area {
    font-size: 16px;
	width:calc(100% - 290px);
}
input::placeholder,
textarea::placeholder {
  color: #bcbcbc;
}

/* IE */
input:-ms-input-placeholder,textarea:-ms-textarea-placeholder {
  color: #bcbcbc;
}

/* Edge */
input::-ms-input-placeholder,
textarea::-ms-textarea-placeholder {
  color: #bcbcbc;
}



.form-item {
	width: 100%;
    max-width:700px;
	height: 60px;
    border-radius:5px;
	padding: 0 25px;
	background:#f7f7f7;
	font-size: 16px;
	box-sizing: border-box;
    border:none;
}

.form-item:focus {
	border-color: #0f505b;
}




.form-list {
    overflow: hidden;
}
.form-list:after{
    
} 

.form-list li{
    display:inline-block;
    border:none;
    margin-right: 60px;
	position: relative;
    min-height:40px;
    padding-top:11px;
}

.form-list .type-mg {
	margin-right: 60px;
}

.form-list label {
	padding-left: 70px;
	position: relative;
	cursor: pointer;
	font-size:16px;
}

.form-list input {
	opacity: 0;
	position: absolute;
	left: 0;
	z-index: 0;
}

.form-list label:before,
.form-list label:after {
	content: "";
	display: block;
	position: absolute;
	box-sizing: border-box;
}

.form-list label:before {
	width: 40px;
	height: 40px;
	border: 1px solid #89b3ba;
	top: -11px;
	left: 0;
	z-index: 0;
    background:#f5f5f5;
}
_:-ms-fullscreen, :root .form-list label:before {
	top: -8px;
}

@supports (-ms-accelerator: true) and (not (color: unset)) {
  
.form-list label:before {
	top: -6px;
}
}
@supports (-ms-ime-align: auto) {
 .form-list label:before {
	top: -6px;
}
}




.form-list input:checked + label:before {
	border-color: #e9974e;
}

.form-list.input-radio label:before {
	border-radius: 50px;
}

.form-list input + label:after {
	width: 20px;
	height: 20px;
	background-color: #89b3ba;
	top: -1px;
	left: 10px;
	z-index: 1;
	opacity: 0;
}

.form-list input:checked + label:after {
	opacity: 1;
}

.form-list.input-radio input + label:after {
	border-radius: 50%;
}





.w_box .fc_txt{
     font-size: 16px;
    line-height: 28px;
    text-align: center;
    margin:30px 0 20px;
}

.w_box .fc_txt a{
     color:#e26d5f;
    text-decoration:underline;
}


.ps_area{
    width: 100%;
    text-align: center;
    margin-top: 50px;
}


.ps_area span{
     font-size: 14px;
    display:block;
    text-align:center;
    color:#7e7e7e;
    font-weight: 500;
    width: 100%;
    margin: 15px auto 27px;
}

input[type=radio], input[type=checkbox] {
        /*
  display: none;*/
        opacity: 0;
}

.checkbox {
  box-sizing: border-box;
  -webkit-transition: background-color 0.2s linear;
  transition: background-color 0.2s linear;
  position: relative;
  display: inline-block;
  margin: 0 0 20px 0;
  padding: 0 0 0 60px!Important;
  float:none !Important;
  vertical-align: middle;
  width:auto !Important;
  font-weight:bold !Important;
  font-size:16px !Important;
  display:inline-block !Important;
  cursor: pointer;
    font-weight: 500;
}

.checkbox:hover:after {
  border-color:  #e9974e;
    }
    .checkbox:after {
      -webkit-transition: border-color 0.2s linear;
      transition: border-color 0.2s linear;
      position: absolute;
      top: 0;
      left: 0;
      display: block;
      margin-top: -12px;
      width: 40px;
      height: 40px;
      border: 2px solid #dedede;
      border-radius: 5px;
        background: #fff;
      content: '';
}
.check_box input:checked + label:before {
	border-color: #e9974e;
}
input[type=radio]:checked + .radio:before {
  opacity: 1;
}

.check_box input + label:after {
	width: 18px;
	height: 18px;
	background-color: #e9974e;
	top: -2px;
	left: 4px;
	z-index: 1;
	opacity: 0;
}

.check_box input:checked + label:after {
	opacity: 1;
}
.checkbox:before {
  content: '';
  -webkit-transition: opacity 0.2s linear;
  transition: opacity 0.2s linear;
  position: absolute;
    top: -10px;
    left: 2px;
    width: 40px;
    height: 40px;
        z-index:500;
  opacity: 0;
    background:url(../image/check.png);
    background-size:cover;
}
input[type=checkbox]:checked + .checkbox:before {
  opacity: 1;
}




    
.conf-area{margin-top:60px;}

.conf-area .link_btn{
    margin-top: 45px;
}

.form_wrap .c_txt span{
    display: block;
    margin-top: 7px;
    font-size: 15px;
    line-height: 26px;
    color: #7e7e7e;
    }
.form_wrap .c_txt2{
     font-size: 15px;
    line-height: 26px;
    text-align: center;
    margin:0 0 20px;
}

.form_wrap h3{
    font-size: 26px;
    font-weight: 500;
    text-align: center;
    margin-bottom: 40px;
    
}


.form-foot {
	position:relative;
	z-index:650;
	max-width: 650px;
	margin:26px auto 0;
}
.form-foot.conf{margin-top: 46px;}

.form-foot.cancel{
    width: 280px;
}

.form-foot li{
    position:relative;
    width:280px;
    float:left;
}
.form-foot li:last-child{
 float:right;   
}

.form-foot li.cnt{
    float:none;margin:0 auto;width:370px;
}
.form-foot li:after{
 content:"";
    display: block;
    clear: both;
}
.form-foot.ctmr{
	max-width: 160px;
	margin: 30px auto 5.7vw;
	}


.form-foot:after{
	content:"";
	display:block;
	clear:both;
	}

.form-foot .btn {
	display:block;
	/*
	width: 160px;
	height: 40px;
	*/
	border: 0;
	border-radius: 0;
	font-size: 13px;
	font-weight: bold;
	-webkit-appearance: none;
}

.form-foot .btn:hover {
	opacity: .7;
}

.form-submit {
	width:378px;height:88px;
	margin:0 auto;
	background:url(../image/submit_btn.png);
	background-size:cover
}
.form-submit2 {
	width:278px;height:88px;
	margin:0 auto;
	background:url(../image/submit_btn2.png);
	background-size:cover
}
.form-submit.fr {
	float:right;
	margin:0;

}
.form-cancel{
	width:278px;height:88px;
	margin:0 auto;
	background:url(../image/submit_btn3.png);
	background-size:cover;
	float:left;
	
	}
.thanks {
	margin-bottom: calc(20px + 5vw);
}

.thanks-tit {
	margin-bottom: calc(20px + 2vw);
	font-size: calc(1.6rem + 1vw);
	font-weight: bold;
	line-height: 1.4;
	text-align: center;
	color: rgba(0, 0, 0, 1);
}

.thanks-tex {
	font-size: calc(1.3rem + .2vw);
	line-height: 1.8;
	text-align: center;
}

.thanks .more {
	margin: calc(20px + 5vw) auto;
}

.thanks .more a {
	font-weight: bold;
	text-decoration: none;
}


.error{
    display: block;
    font-size: 18px;
    line-height: 24px;
    text-align: center;
    font-weight: bold;
    
}



@media screen and (max-width: 1150px) {
    
.w_box{
    padding:40px 50px 46px;
    }    
}

@media screen and (max-width: 1000px) {
    
.w_box{
    padding:30px 25px 36px;
    }
 .form .text_area {
    width: 250px;
 }
.form .form_area {
    width: calc(100% - 250px);
}
}
@media screen and (max-width: 800px) {
#intro{
    padding:35px 0 0px;
}
#intro .c_txt{
     font-size: 15px;
    line-height: 28px;
    text-align: left;
    margin:0 auto 112px;
    }



#intro .g_box{
    position: relative;
    width:100%;
    background:#f7f7f7;
    padding:20px 15px;
    border-radius:5px;
        
}

#intro .g_box:before{
    width: 261px;
    height: 79px;
    top:-79px;
}


.w_box{
    width:100%;
    background:#fff;
    padding:13px 15px 30px;
    border-radius:5px;
    box-sizing:border-box;
}
    

.form .text_area,
.form .text_area.vt,
.conf-area .form .text_area{
    width:100%;
	padding: 15px 0 15px !Important;
    font-size: 15px;
}
.form .form_area,.conf-area .form .form_area{
    font-size: 14px;
	padding: 0 0 15px !Important;
    width: 100%;
}
.form .text_area.req:after{
    top: 12px;
    font-size: 12px;
    line-height: 22px;
    border-radius: 11px;
    height: 22px;
    padding: 0 10px;
    margin-left: 14px;
}

.form-item {
	width: 100%;max-width: 800px;
	height: 50px;
	padding: 0 15px;
	font-size: 14px;
    
}

textarea.form-item {
	min-height: 300px;
    padding:15px;
}



.conf-area{margin-top:35px;}

.form_wrap h3{
    font-size: 18px;
    line-height: 26px;
    margin-bottom: 20px;
    
}
.conf-area .link_btn{
    margin-top: 20px;
}


.form-foot {
	position:relative;
	z-index:650;
	max-width: 500px;
	margin:25px auto 0;
}

.form-foot {
	margin:38px auto 0;
}
.form-foot.ctmr{
	max-width: 220px;
	margin: 0 auto;
	
	}
    
.form-foot.conf {
    margin-top: 26px;
}
.form-foot li{
    position:relative;
    width:220px;
    float:none;
    margin:0 auto 10px;
}
.form-foot li:last-child{
 float:none;
    margin:0 auto;
}


.form-foot li.cnt{width:272px;
    margin:0 auto 20px;}

.form-foot:after{
	content:"";
	display:block;
	clear:both;
	}

.form-foot .btn {
	display:block;
	border: 0;
	border-radius: 0;
	font-size: 13px;
	font-weight: bold;
	-webkit-appearance: none;
}

.form-foot .btn:hover {
	opacity: .7;
}

.form-submit {
	width:272px;height:64px;
	margin:0 auto;
	background:url(../image/submit_btn_sp.png);
	background-size:cover
}
.form-submit2 {
	width:222px;height:64px;
	margin:0 auto;
	background:url(../image/submit_btn2_sp.png);
	background-size:cover
}
.form-submit.fr {
	float:none;
	margin:0;

}
.form-cancel{
	width:222px;height:64px;
	background:url(../image/submit_btn3_sp.png);
	background-size:cover;
	float:none;
	
	}
    
.form-list label {
	padding-left: 60px;
	font-size:15px;
}
    
    
    
.w_box .fc_txt{
     font-size: 14px;
    line-height: 27px;
    text-align: center;
    margin:7px 0 20px;
}

.w_box .fc_txt a{
     color:#e26d5f;
    text-decoration:underline;
}

    
.ps_area{
    margin-top: 35px;
}

.checkbox {
  margin: 0;
  padding: 0 0 0 65px!Important;
  float:none !Important;
  vertical-align: middle;
  width:auto !Important;
  font-size:15px !Important;
  display:inline-block !Important;
  cursor: pointer;
    font-weight: 500;
}
.checkbox:after {
      margin-top: -14px;
}
.checkbox:before {
    top: -12px;
}
    
.Android .form-list label:before {
	top: -10px;
}
.error{
    font-size: 14px;
    line-height: 24px;
    }    
    
    
    
    
.form-foot.cancel{
    width: 280px;
}

    
    
}





 /* ==========================================================================
	thanks
========================================================================== */

#thanks {
    position: relative;
    padding: 95px 0 310px;
    box-sizing: border-box;
    text-align: center;
    background: url(/company/image/intro_bg.jpg) top center no-repeat;
}
#thanks:after{
     content:"";
    display: block;
    width: 340px;
    height: 222px;
    position: absolute;
    left:0;
    right:0;
    bottom:0;
    margin:auto;
    background:url(../image/thanks_illust.png);
    background-size:cover;
}
#thanks h2 {
    display: inline;
    font-size: 50px;
    font-weight: 500;
    background: -webkit-gradient(linear, left top, left bottom, color-stop(65%, #fff), color-stop(35%, #f7ee13), to(#f7ee13));
    background: -webkit-linear-gradient(#fff 65%, #f7ee13 35%, #f7ee13);
    background: linear-gradient(#fff 65%, #f7ee13 35%, #f7ee13);
}
#thanks .c_txt {
    font-size: 18px;
    line-height: 32px;
    margin:63px 0 30px;
    padding:0 15px;
    box-sizing:border-box;
}
#thanks .c_txt2 {
    font-size: 15px;
    line-height: 32px;
    padding:0 15px;
    box-sizing:border-box;
    color:#808080;
}




@media screen and (max-width: 800px) {
#thanks {
    padding: 45px 0 185px;
    background: none;
}
#thanks:after{
    width: 228px;
    height: 149px;
}
#thanks h2 {
    font-size: 26px;
    z-index:10;
}
#thanks .c_txt {
    font-size: 14px;
    line-height: 27px;
    margin:30px 0 15px;
}
#thanks .c_txt2 {
    font-size: 12px;
    line-height: 24px;
}

#thanks .sp_illust01 {
    display: block;
    width: 84px;
    height: 98px;
    position: absolute;
    left: 0;
    top: 0;
    z-index: 0;
}
#thanks .sp_illust02 {
    display: block;
    width: 63px;
    height: 170px;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 0;
}
    
    .g-recaptcha{margin-bottom: 15px;}
    
}