@charset "utf-8";
/* CSS Document */
@media screen and (max-width: 767px){
* {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-touch-callout: none;
  -webkit-user-select: none;
}
input, textarea {
 -webkit-user-select : auto;
}
input[type="button"],input[type="text"],input[type="submit"],input[type="image"],textarea,input[type="email"],input[type="tel"]{
   -webkit-appearance: none;
   border-radius: 0;
}
html{
	-webkit-overflow-scrolling: touch;
	overflow-y: scroll;
}
body{
	position: relative;
	background-color: #fff;
	overflow: hidden;
	-webkit-backface-visibility:hidden;
	backface-visibility:hidden;
	-webkit-overflow-scrolling: touch;
	height: 100%;
	width: 100%;
}
.wrapper{
    /*-webkit-overflow-scrolling: touch;*/
    overflow-y: scroll;
    height: 100vh;
}
	
/*header*/
.header{
	height: 50px;
}
		.logo{
			float: left;
			width: 199px;
			margin-top: 8px;
			margin-left: 10px;
		}
			.logo img{
				width: 100%;
			}
		.entry_btn{
			float: right;
			margin: 11px 9px 0 0;
		}
			.entry_btn p{
			}

/*top_area*/
.top_area{
	background: url(../img/top_bg_sp.png) no-repeat center bottom;
	background-size: cover;
	padding-top: 30px;
	margin-top: 0;
	position: relative;
	padding-bottom: 50px;
	height: auto;
}
.entry_voice a {
    width: auto;
	padding-left: 30px;
	padding-right: 30px;
}
.entry_voice span {
    background: url(../img/arrow1.png) no-repeat 0px center;
    padding-left: 23px;
	font-size: 20px;
}
	.top_words{
		margin-top: 0px;
		display: none !important;
	}
	.top_entry_btn{
		position: relative;
		top:0 !important;
	left:0 !important;
		margin-left: 15px;
		margin-right: 15px;
		width: auto;
	}
	.top_entry_btn .sp {
		display: block;
	}
	.top_entry_btn .pc {
		display: none !important;
	}
		.top_entry_btn .sp img{
			width: 100%;
		}
	img {
		max-width: 100%;
		height: auto;
	}
/*02.html--top_area*/
.top_area2{
	background: url(../img/top_bg02_2_sp.jpg) no-repeat right center;
	background-size: cover;
	height: 610px;
	position: relative;
}
	.top_words2{
		background: url(../img/top_words_img02_sp.png);
		background-repeat: no-repeat;
		background-position: center 20px;
		background-size: 100%;
		height: 603px;
		width: 95%;
		margin: 0 auto;
	}
	.top_entry_btn2{
		position: inherit;
		right: auto;
		text-align: center;
		width: 100%;
		padding-top: 139%;
	}
		.top_entry_btn2 img{
			width: 34%;
		}
	
	.inner {
		margin-left: 15px !important;
		margin-right: 15px !important;
		width: auto !important;
	}
	.area1 {
		margin-top: -40px;
	}
	.area1 .img02 {
		float: none !important;
		clear: both !important;
		margin-left: auto;
		margin-right: auto;
		padding-top: 20px !important;
		padding-bottom: 20px;
	}
	.area1 p.txt {
		position: relative !important;
		top: auto !important;
		left: auto !important;
		padding: 0 !important;
		right: auto !important;
		width: auto !important;
		font-size: 16px;
		line-height: 25px;
	}
	dl.resolution dt , dl.resolution dd {
		float: none !important;
		clear: both !important;
		padding-right: 0 !important;
		width: auto !important;
		display: block;
		padding-top: 0 !important;
		padding-bottom: 30px !important;
		padding-left: 0px !important;
	}
	dl.resolution .nayami {
		font-size: 16px !important;
		line-height: 25px !important;
	}
	dl.resolution .nara {
		font-size: 14px !important;
		line-height: 22px !important;
	}
	dl.resolution dt {
		text-align: center;
		padding-bottom: 10px !important;
	}
	dl.resolution {
		border-bottom: 0px;
		margin-bottom: 0;
		padding-bottom: 0;
	}
	.area1 .illust {
		position: relative;
		top: auto;
		left: auto;
		right: auto;
		display: block;
		text-align: center !important;
		border-bottom: 1px solid #000;
		padding-bottom: 40px;
		margin-bottom: 50px;
	}
	.area1 .illust .sp {
		display: block;
		margin-left: auto;
		margin-right: auto;
	}
	.area2 {
		background-image: none !important;
		background-color: #eeeeee;
	}
.area2 li {
	display: block;
	width: auto !important;
	margin-bottom: 10px !important;
	margin-right: 0 !important;
}		
	.illust.no_border {
		border-bottom: 0px;
		padding-bottom: 0;
	}
	.h2_title {
		margin-bottom: 40px !important;
	}
	.area2 , .area3 {
		padding: 50px 0;
	}
	.area2 .name{
		font-size: 14px;
		line-height: 22px;
	}
	.area2 .work {
		font-size: 13px;
		line-height: 21px;
	}
	.area2 .txt {
		font-size: 12px;
		line-height: 20px;
	}
	.area3 ul {
		display: block;
	}
.area3 li {
	width: 30% !important;
	margin-right: 1.6% !important;
	margin-left: 1.6% !important;	
	text-align: center;
}	
	
	.form_area{
    padding-top: 30px;
    padding-bottom: 47px;
	}
		.form_area_inner{
			background-color: rgba(255,237,241,0.3);
			padding: 21px 0px 40px;
		}
			.form_area_title img{
				width: 61%;
			}
			
			.entry_form1{margin-top: 30px;}
			.entry_form1 dt{
				font-size: 14px;
				margin-top: 20px !important;
			}
			.entry_form1 dt.re{
				background-image: url(../img/icon_important_sp.png);
				background-repeat: no-repeat;
				background-size: 30px;
				background-position-y: 2px;
			}
			.entry_form1 dt.re_1{
				background-position-x: 47px;
			}
			.entry_form1 dt.re_2{
				background-position-x: 102px;
			}
			.entry_form1 dt.re_3{
				background-position-x: 33px;
				margin-top: -12px !important;
			}
			.entry_form1 dt img{
				vertical-align: sub;
				margin-left: 10px;
			}
			.entry_form1 dt span.required{display: none;}
			.entry_form1 dt span.optional{display: none;}
			.entry_form1 dd span.error_blank:before{
				content: "\A" ;
				white-space: pre ;
			}
				.entry_form1 dd span.error_blank{
					color: #920020;
					font-size: 14px;
					font-weight: bold;
				}
				.entry_form1 dd span.agree_error{text-align: center;}
				
	form#mail_form input[type="text"],
	form#mail_form input[type="email"],
	form#mail_form input[type="tel"]{
		max-width : 100%;
		height : 26px;
		padding : 2px 2%;
		-webkit-appearance : none;
		font-size : 100%;
		margin-top : 5px;
	}

	form#mail_form input#name_1,
	form#mail_form input#name_2,
	form#mail_form input#read_1,
	form#mail_form input#read_2,
	form#mail_form input#postal,
	form#mail_form input#phone,
	form#mail_form input#schedule{
		width : 100%;
	}
	
	form#mail_form select{
		font-size : 14px;
		font-family : inherit;
		margin-top : 10px;
		color: #fff;
	    width: 172px;
	    height: 26px;
	    border: 1px solid #fff;
	    border-radius: 0;
	    background-image: url(../img/icon_select.png);
	    background-repeat: no-repeat;
	    background-position: 15px center;
	    padding-left: 40px;
	    -webkit-padding-left: 40px;
	    -webkit-appearance: none;
	    padding-bottom: 0;
	}
	
	form#mail_form input[type="button"]{
		background-size: 12px;
		background-position: 25px center;
		font-size: 18px;
		padding-left: 50px;
	}
	
	form#mail_form ul{
		/*margin-top: -20px;*/
	}
	form#mail_form ul.agree_check{
		margin-top: -20px;
	}
	form#mail_form p#form_submit {
		text-align: center;
	}
	form#mail_form input#form_submit_button{
		margin-top: 10px;
		margin-left: auto;
		height: 54px !important;
		background-image: url("../img/btn02_sp.png") !important;
		background-size: 203px auto !important;
		
	}

	ul.g_ul{}
	ul.g_ul li{
		display: inline-block;
		padding-right: 49px;
		font-size: 13px;
	}
	/*Radio*/
	.gender_radio input[type='radio']{
		filter: alpha(opacity=0); -moz-opacity:0; opacity:0;
		position: inherit;
	}
	form#mail_form ul li input[type="radio"]{
		margin-top: 0;
	}
		.g_radio{
			background-size: 21px;
			height: 21px;
			line-height: 21px;
			padding: 0 0 0 10px;
		}
			.r_on{
				background-size: 21px;
			}
	/*Checkbox*/	
	.agree_check label{
	    display: block;
	    background-position: left center;
	    background-repeat: no-repeat;
	    background-size: 16px;
	    width: 240px;
		height: 16px;
		margin: 0 auto;
	    cursor: pointer;
		overflow: hidden;
	}
		.agree_check input[type="checkbox"]{
		    opacity:0;
		    filter: alpha(opacity=0); -moz-opacity:0; opacity:0;
			position: inherit;
		}
			.agree_check label{background-image: url(../img/check_off.png);}
			.agree_check .c_on{background-image: url(../img/check_on.png);}
		.agree_p{
		    width: 200px;
			margin: -14px auto 0;
			font-size: 13px;
		}
			.agree_p a{
				color: #a40000;
				text-decoration: none;
			}

	
	.company_area{
		padding: 48px 20px 86px;
	}
		.company_area_title{
			padding-bottom: 33px;
		}
			.company_area_title p{
				font-size: 20px;
			}
		.company_area_inner{
			overflow: hidden;
			padding-bottom: 86px;
			padding-left: 0;
			padding-right: 0;
		}
			.company_address{
				float: none;
			}
				.company_address p.agentgate{
					font-size: 15px;
					padding-top: 27px;
				}
				.company_address p{
					font-size: 14px;
					line-height: 25px;
				}
					.company_address p a{
						color: #a40000;
						text-decoration: none;
						border-bottom: 1px solid #a40000;
						padding-bottom: 2px;
					}
			.company_map{
				float: none;
				position: relative;
				padding-top: 170px;
				height: auto;
				overflow: hidden;
			}
				.company_map iframe,
				.company_map object,
				.company_map embed {
					position: absolute;
					top: 0;
					left: 0;
					width: 100%;
					height: 100%;
				}
			
	.footer{
		height: 62px;
		text-align: center;
		bottom: 0;
		width: 100%;
		margin-bottom: -1px;
	}
	.footer p{
		height: 62px;
		font-size: 12px;
		padding-top: 18px;
	}
	
}/*@media screen and (max-width: 767px)*/


@media screen and (max-width: 320px){
	/*top_area*/
	.top_area{
		height: 482px;
		margin-top: 0px;
	}
	.para_area_inner img{
		padding-top: 28px;
		width: 288px;
		height: 585px;
	}
	.para_area_inner img.happy_img_sp{
		margin-top: 0;
		height: 692px;
	}
	/*02.html--top_area*/
	.top_area2{
		height: 482px;
	}
		.top_words2{
			height: 603px;
		}
		.top_entry_btn2{
			padding-top: 139%;
		}

	
	
	.top_entry_btn{top: 61vh;}
	/*.section2{height: 1225px;}*/
	
	#girl{
		height: 1350px;
		/*height: 589px;*/
		background-size: 155px;
	}
	#girl2{
		background-size: 155px;
		height: 1350px;
	}
	.para_pc_wrap{
		background-size: 155px;
	}
	.para_pc_wrap.chan:before{
		background-size: 155px;
	}
	.para_area_inner, .para_area_inner img{
		height: auto;
	}
	
	.point_img, .point_img2{height: 185px;}
	
	.company_address p{font-size: 13px;}
	
	.voice_area_inner{
		width: 288px;
	}
		.voice1{
			height: 290px;
			padding: 28% 20px 0;
		}
			.voice1 p{
				font-size: 0.65em;
			}
		.voice2{
			height: 350px;
			padding: 28% 20px 0;
		}
			.voice2 p{
				font-size: 0.65em;
			}
}