@charset "UTF-8";

html {
	height: 100%;
}

body {
	position: relative;
	height: 100%;
	min-width: 980px;
	background: #ffffff;
}

html,body,.l_wrapper{
	line-height:1.8em;
	font-size: 16px;
	font-family : 'Open Sans',"游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", 'メイリオ' , Meiryo , Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-family: "游明朝体", "Yu Mincho", YuMincho, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ ゴシック", sans-serif;
	background: #ffffff;
	color:#000000;
	font-size: 100%;
}

a {
	color: #000000;
}

a:hover {
	color: #000000;
}

a:visited {
	color: #000000;
}

/*==================================
common
==================================*/

.l_wrapper {
	min-width: 980px;
}

.l_content {
	position: relative;
	margin: 100px auto 0px;
}

.l_content_inner .content_wrap {
}

.left_wrap {
	float: left;
}

.right_wrap {
	float: right;
}

/*==================================
header
==================================*/

.l_header {
	width:95%;
	max-width: 1483px;
	margin: 0 auto;
}

.l_header h1 {
	padding: 22px 0px;
}

.l_header .bottom_wrap {

}

.nav {
	width: 650px;
}

.nav ul li:last-child {
}

.nav ul li {
	display: inline-block;
}

.nav ul li a {
	display: block;	
	padding: 24px 14px;
}

.nav ul li a:hover {
	padding: 24px 14px 23px 14px;
	border-bottom: 1px solid #000000;
}

.nav .mail {
	float: right;
	margin-left: 15px;
}

.nav .mail a {
	display: block;
	padding: 24px 25px 31px 25px;
    background: #fff100;
}

.nav .mail a:hover {
	opacity: 0.7;
	background: #fff546;
}

/*==================================
l_visual
==================================*/

.l_visual{
	position: relative;
	width:95%;
	max-width: 1483px;
	height:902px;
	margin: 0 auto;
}

.flexslider,.slides,.flexslider li{
}

.flexslider,.slides,.flexslider li img{
	width: 100%;
}

.flexslider li{
	-webkit-background-size: 100% auto !important;
	-moz-background-size: 100% auto !important;
	background-size: 100% auto !important;
	background-attachment: fixed !important;
	background-position: center top;
}

.l_visual .l_visual_inner{
	position:absolute;
	width:100%;
	height:100%;
	top:0;
	left:0;
	z-index:0;
}

.l_visual .visual_table{
	-webkit-display:table;
	display:table;
	width:100%;
	height:100%;
}

.l_visual .l_visual_inner .visual_cell{
	display:table-cell;	
	vertical-align:middle;
	text-align:center;
	color: #f63c32;
}

.l_visual .l_visual_inner h1 {
	position: relative;
}

.l_visual .l_visual_inner h1 .btm_wrap{
	margin-top: 25px;
}


.l_visual .l_visual_inner h1 .recruit_icon {
	position: absolute;
	top: -50px;
	left: -50px;
}

.l_visual .l_visual_inner p{
	font-size:1.15em;
	line-height:1.8em;
	letter-spacing:0.05em;
	color: #341806;
}

/*==================================
concept
==================================*/

#concept {

}

#concept > div {
	width: 1115px;
	margin: 0 auto 85px;
}

#concept .right_wrap {
}

#concept .right_wrap .inner .right_wrap {
	max-width: 220px;
	margin-left: 16px;
}


#concept .right_wrap .inner .left_wrap {
	max-width: 497px;
}

#concept .right_wrap .inner h1,
#concept .right_wrap .inner h2 {
	display: inline-block;
	margin-left: 30px;	
}

#concept .right_wrap .inner h1 img,
#concept .right_wrap .inner h2 img{
	vertical-align: top;	
}


/*==================================
creaning
==================================*/

#creaning  {
	padding: 85px 0px;
	background: url(../img/creaning_bg.jpg);	
}


#creaning > div {
	width: 1115px;
	margin: 0 auto;
}

#creaning .right_wrap {
	max-width: 940px;
}

#creaning .right_wrap ul {
	width: 939px;
}

#creaning .right_wrap ul li {
    position: relative;
    height: 320px;
    max-width: 314px;
    background: #fff;
    padding: 20px;
    float: left;
    margin-left: 10px;
    margin-bottom: 10px;
}

#creaning .right_wrap ul li:first-child {
	margin-left: 0px;
}

#creaning .right_wrap ul li:nth-child(4) {
	margin-left: 0px;
}

#creaning .right_wrap ul li:last-child {
	border: 1px solid #000000;
	height: 318px;
} 

#creaning .right_wrap ul li:last-child h4 {
	font-weight: bold;
	padding-bottom: 19px;
	margin-bottom: 10px;
	border-bottom: 1px solid #c4c5c7;
	text-align: center;
	font-size: 1.2em
}

#creaning .right_wrap ul li:last-child p {
	line-height: 2.1em;
}

#creaning .right_wrap ul li figure {
	text-align: center;
}

#creaning .right_wrap ul li  h2 {
	width: 263px;
	font-weight: bold;
	font-size: 1.2em;
	margin:  10px auto 10px;
}

#creaning .right_wrap ul li  h3 {
	position: absolute;
	top: 0;
	left: 0;
	width: 100px;
	padding: 0px 0px;
	background: #000000;
	color: #ffffff;
	font-family: 'Open Sans';
	text-align: center;
	font-size: 0.85em;
	display: block;
}

#creaning .right_wrap ul li  p {
	width: 263px;
	margin:  0 auto;
}

/*==================================
before after
==================================*/

#before_after .right_wrap ul li {
    position: relative;
    width: 300px;
    padding: 20px;
    float: left;
    margin-bottom: 10px;
	 height: 400px;
    background: #fff;
}
#before_after { margin-right: 110px;}
#before_after .right_wrap ul li  h3 {
	position: absolute;
	top: 0;
	left: 0;
	width: 100px;
	padding: 0px 0px;
	background: #000000;
	color: #ffffff;
	font-family: 'Open Sans';
	text-align: center;
	font-size: 0.85em;
	display: block;
}
#before_after .right_wrap ul li h2{
	font-size: 30px;
	font-weight: bold;
	display: table;
	margin:180px auto;
	letter-spacing: 10px;
	border-bottom: 2px solid #fff100;
	padding:5px;
}


/*==================================
area
==================================*/

#area  {
	padding: 85px 0px;	
}


#area > div {
	max-width: 1052px;
	margin: 0 auto;
}

#area .right_wrap {
	max-width: 118px;
	width: 100%;
}

#area .left_wrap {
	max-width: 885px;
	width: 100%;
}

#area .left_wrap .inner .left_wrap{
	width: 100%;
	max-width: 382px;
}

#area .left_wrap .inner .right_wrap{
	width: 100%;
	max-width: 470px;
	margin-top: 117px;
}

#area .left_wrap .inner .right_wrap h5 {
	margin-bottom: 24px;
}


#area .left_wrap .inner .right_wrap .btn_wrap {
	position: relative;
	padding: 25px;
	border: 1px solid #000000;
}

#area .left_wrap .inner .right_wrap .btn_wrap .time {
	font-size: 0.8em;
}

#area .left_wrap .inner .right_wrap .btn_wrap .tel {
	font-size: 1.5em;
	letter-spacing: 0.35px
}


#area .left_wrap .inner .right_wrap .btn_wrap .tel small{
	font-size: 0.6em;
}

#area .left_wrap .inner .right_wrap .btn_wrap .btn_main {
	position: absolute;
	right: 25px;
	bottom: 25px;
}


#area .left_wrap .inner .right_wrap .btn_wrap .btn_main a {
	position: relative;
	text-align: center;
	font-weight: bold;
	font-size: 0.9em;
	display: block;
	width: 140px;
	padding: 5px 0px 5px 27px;
    background: #fff100;
    font-family: 'Open Sans';
}


#area .left_wrap .inner .right_wrap .btn_wrap .btn_main:after {
	display: block;
	position: absolute;
	content: "";
	background: url(../img/mail.png) no-repeat;
	background-size: 100%;
	width: 23px;
	height: 25px;
	top: 50%;
	margin-top: -7px;
	left: 33px;
}

#area .left_wrap .inner .right_wrap .btn_wrap .btn_main a:hover {
	opacity: 0.7;
	background: #fff546;

}

.bg_image {
	background: url(../img/bg_image.jpg);
	background-attachment: fixed;
	height: 230px;
	width: 100%;
	background-size: cover
}

/*==================================
price
==================================*/

#price  {
	padding: 85px 0px;
	background: url(../img/creaning_bg.jpg);	
}


#price > div {
	max-width: 1115px;
	margin: 0 auto;
}

#price h1 {
	margin-bottom: 30px;
	text-align: center;
}

#price .price_table table {
	width: 100%;
	border: 1px solid #000000;
}

#price .price_table table tr th,
#price .price_table table tr td {
	border: 1px solid #b5b5b5;
	text-align: left;
	padding: 15px;
}


#price .price_table table tr th {
	width: 207px;
	background: #f6f6f6;
}

#price .price_table table tr td small {
	color: #8f8f8f;
}

#price .price_table table tr .price {
	text-align: center;
}

#price  .right_text {
	text-align: right;
	font-size: 0.8em;
}


/*==================================
question
==================================*/

#question {
	padding: 85px 0px;	
	}


#question  > div {
	max-width: 1115px;
	margin: 0 auto;
}


#question  h1 {
	margin-bottom: 30px;
	text-align: center;
}

#question table tr {
	position: relative;
}

#question table {
	width: 100%;
	position: relative;
	border: 1px solid #000000;
	border-right: 0px;
	margin-bottom: 15px;
}

#question table tr li:first-child:after {
	display: block;
	position: absolute;
	content: "";
	background: url(../img/question_off.png) no-repeat;
	width: 22px;
	height: 22px;
	top: 50%;
	margin-top: -11px;
	right: 30px;
}

#question table tr li.active:after {
	display: block;
	position: absolute;
	content: "";
	background: url(../img/question_on.png) no-repeat;
	width: 22px;
	height: 22px;
	top: 50%;
	margin-top: -11px;
	right: 30px;
}

#question table tr th {
	width: 110px;
	background: #f6f6f6;
	font-size: 1.2em;
	font-family : 'Open Sans';
}

#question table tr td {
	font-size: 1.2em;
	vertical-align: middle;
	border-right: 1px solid #000000;
}

#question table tr td li {
	position: relative;
	padding: 20px 20px;
	border-bottom: 1px solid #e9e9e9;
}

#question table tr td ul {
	border-left: 1px solid #e9e9e9;
}


/*==================================
contact
==================================*/

.contact_wrapper{
	display: none;
	background:rgba(0,0,0,0.6);
	position:fixed;
	top:0;
	left:0;
	width:100%;
	height:100%;
	z-index:999;
	display:table;
	display: none;
}

.contact_inner{
	display:table-cell;
	vertical-align:middle;
}

.contact_layout{
	width:980px;
	margin:0 auto;		
	position:relative;
}

.contact_inner .contact_table{
	width:880px;
	height:800px;
	margin:0 auto;
	overflow-y:scroll;
	background:#fff;
	padding:70px;
	box-sizing:border-box;
	border:3px solid #ddd;


}

.contact_inner .contact_caption{
	border-bottom:1px solid #000;
}

.contact_inner .contact_caption h1{
	font-size:1.4em;

}

.contact_inner .contact_caption h1 span{
	font-size:0.7em;
	margin-left:10px;
}

.contact_inner .contact_caption h1 span b{
	color:#d84f35;
}

.contact_inner form {
	margin:40px 0;
}

.contact_inner form table{
	margin:0;
	width:100%;
}


.contact_inner form th{
	width:24%;
	text-align:left;
	vertical-align:top;
	padding:10px 0;
}

.contact_inner form th b{
	color:#d84f35;	
}

.contact_inner form table td{
	border-left:1px solid #000;	
	padding:10px 0 10px 5%;	
	width:70%;
}

.contact_inner form table td  input[type="text"]{
	height:30px;
	line-height:30px;
	border:1px solid #000;
}

.contact_inner form table td  input[type="radio"]{
	margin-right:5px;
}

.contact_inner form table td  input.short{
	width:60%;
}

.contact_inner form table td  input.long{
	width:100%;
}

.contact_inner form table td p{
	margin-bottom:5px;
}

.contact_inner form table td p:last-child{
	margin-bottom:0;
}

.contact_inner form table td textarea{
	border:1px solid #000;
	width:100%;
	resize:none;
}

p.submit{
	width:280px;
	margin:40px auto 0;
}

p.submit input{
	width:100%;
	background:#d84f35;
	border:none;
	color:#fff;
	padding:10px 0;
}

.privacy{
	width:100%;
	height:300px;
	padding:10px;
	-webkit-box-sizing:border-box;
	box-sizing:border-box;	
}

p.close{
	position: absolute;
	top: -32px;
	right: 14px;
	color: #fff;
	width: 30px;
	height: 30px;
	background: url(../img/close.png);
	cursor: pointer;
	text-indent: 1px;
}


/*==================================
privacy
==================================*/

.privacy_wrapper{
	background:rgba(0,0,0,0.6);
	position:fixed;
	top:0;
	left:0;
	width:100%;
	height:100%;
	z-index:999;
	display:table;
	display: none;
}

.privacy_inner{
	display:table-cell;
	vertical-align:middle;
}

.privacy_layout{
	width:980px;
	margin:0 auto;		
	position:relative;
}

.privacy_inner .privacy_table{
	width:880px;
	margin:0 auto;
	overflow-y:scroll;
	background:#fff;
	padding:70px;
	box-sizing:border-box;
	border:3px solid #ddd;
}

.privacy_inner .privacy_caption{
	border-bottom:1px solid #000;
}

.privacy_inner .privacy_caption h1{
	font-size:1.4em;
}

.privacy_inner .privacy_caption h1 span{
	font-size:0.7em;
	margin-left:10px;
}

.privacy_inner .privacy_caption h1 span b{
	color:#d84f35;
}

.privacy_wrapper .privacy {
	width: 100%;
	height: 365px;
	padding: 10px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	margin-top: 10px;
}

/*==================================
footer
==================================*/

.l_footer {
	padding: 48px 0px;
	background: #484848;
	color: #ffffff;
	font-size: 0.85em;
	font-weight: normal;
	line-height: 2.1em;
	text-align: center;
}

.l_footer p a {
	color: #ffffff;
}

.l_footer h1 {
	margin-bottom: 15px;
}


.copy {
	padding: 15px 0px;	
	text-align: center;
	font-size: 0.85em;
	font-family : 'Open Sans';
}

@media screen and (max-width: 1483px) {
	.l_visual {
		height: auto;
		padding-top: 58%;
	}

	.l_wrapper {
		overflow: hidden;
	}
}

@media screen and (max-height: 800px) {
	.contact_inner .contact_table{
		height: 600px;
	}
}

@media screen and (max-height: 700px) {
	.contact_inner .contact_table{
		height: 500px;
	}
}

@media screen and (max-width: 1160px) {
	
	img {
		width: 100%;
	}

	#concept > div {
		width: 95%;
	}

	#concept  .left_wrap figure {
		width: 230px;
	}

	#concept .right_wrap .inner h1, #concept .right_wrap .inner h2 {
		width: 50px;
	}

	#concept .left_wrap .inner .left_wrap {
		width: 480px;
	}

	#creaning .right_wrap {
		width: 83%;
	}

	#creaning > div {
		width: 95%;
		margin: 0 auto;
	}

	#creaning .left_wrap h1{
		width: 100px;
	}
	#creaning .right_wrap ul {
		width: 100%;
	}

	#creaning .right_wrap ul li {
		width: 27%;
	}

	#creaning .right_wrap ul li  h2 {
		width: 100%;
	}

	#creaning .right_wrap ul li  p {
		width: 100%;
	}

	#creaning .right_wrap ul li  {
		height: 355px;
	}

	#creaning .right_wrap ul li:last-child {
		height: 355px;
	}

	#creaning .right_wrap ul li:last-child h4 {
		font-size: 1em;
	}

	#area > div {
		width: 95%;
		margin: 0 auto;
	}

	#area .right_wrap h1 {
		width: 110px;
	}

	#area .left_wrap {
		width: 83%;
	}

	#area .left_wrap .inner .left_wrap {
		width: 34%;
	}

	#area .left_wrap .inner .right_wrap {
		margin-top: 37px;
	}

	#price > div {
		width: 95%;
		margin: 0 auto;
	}

	#price h1 {
		width: 110px;
		margin: 0 auto 20px;
	}

	#question > div {
		width: 95%;
		margin: 0 auto;
	}

	#question h1 {
		width: 210px;
		margin: 0 auto 20px;
	}

	#creaning .right_wrap ul li {
		height: 312px;
	}

	#creaning .right_wrap ul li:last-child {
		height: 310px;
	}

	#creaning .right_wrap ul li:last-child h4 {
		font-size: 1.1em;
		padding-bottom: 10px;
	}

	#creaning .right_wrap ul li:last-child p {
		line-height: 1.65em;
	}

	.l_footer h1 {
		width: 230px;
		margin: 0 auto 20px;
	}




}

