@charset "utf-8";
@import url(https://fonts.googleapis.com/earlyaccess/notosansjp.css);
/* CSS Document */
html,
body{
	height: 100%;
}
body {
    margin: 0;
    font-size: 16px;
    line-height: 1.6;
	font-family: 'Noto Sans JP', sans-serif;
	color: #333;
}
*{
	padding: 0;
	margin: 0;
	box-sizing: border-box;
	}
a{
	transition: all 0.3s ease;
}
img{
	max-width: 100%;
}
.fb{
	font-weight: 700;
}
.mb10{
	margin-bottom: 1rem;
}
/* =======================================
    layout
======================================= */
.container{
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
	padding: 0 20px;
	box-sizing: border-box;
	}
@media (max-width: 959px) {
	.container{
		padding: 0 1rem;
	}
}
/* =======================================
    header
======================================= */
.header-phone{
	border: solid 1px #003;
	border-radius: 4px;
	padding: 5px;
}
.header-phone img{
	display: inline-block;
	vertical-align: middle;
	width: 24px;
}
.header-right .sp{
	display: none;
	}
@media (max-width: 959px) {
  .header-right{
    margin-right: 3rem;
  }
	.header-right a:first-child,
	.header-phone{
		display: none;
	}
	.header-right .sp{
		display: block;
		width: 50px;
		height: 50px;
		border: solid 1px #003;
		border-radius: 50%;
		padding: 10px;
	}
	.header-right .sp img{
		display: block;
	}
}
/* =======================================
    main
======================================= */
.mainview{
	display: -webkit-flex;
	display: flex;
	-webkit-align-items: center;
	align-items: center;
	height: 460px;
	background-image: url(../img/bg-mainview.jpg);
	background-position: center center;
	background-repeat: repeat-y;
	background-size: cover;
	margin-bottom: 1rem;
	}
.mainview p{
	width: 100%;
	font-size: 3rem;
	text-align: center;
}
@media (max-width: 959px) {
	.mainview{
		height: 18rem;
		padding: 1rem;
	}
	.mainview p{
		font-size: 1.5rem;
		text-shadow: 0 0 20px #fff;
	}
}
/* =======================================
    common
======================================= */
article{
	}
article header{
	text-align: center;
}
h1{
	font-size: 2rem;
	text-align: center;
	}
article header span{
	display: block;
	font-size: .75rem;
}
@media (max-width: 959px) {
	h1{
		font-size: 1.75rem;
	}
}
/* =======================================
    concept
======================================= */
.concept.container{
	padding-top: 2rem;
	padding-bottom: 2rem;
}
.concept p{
margin-bottom: 1rem;
}

/* =======================================
    service
======================================= */
#service header{
	color: #009EB2;
	margin-bottom: 1rem;
}
#service header + p{
	text-align: center;
	margin-bottom: 2rem;
}
.service01{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-align-items: flex-start;
	align-items: flex-start;
	margin-bottom: 3rem;
}
.service01 section{
	width: 31%;
	text-align: center;
}
.service01 h2{
	margin: .5rem 0;
}
.service01 p{
	text-align: left;
	color: #444;
}
.service02{
	position: relative;
	border: solid 1px #ccc;
	padding: 1.25rem 1rem 1rem 1rem;
	margin-bottom: 1rem;
}
.service02 span{
	position: absolute;
	top: -1rem;
	left: 0;
	display: inline-block;
	font-size: .875rem;
	color: #fff;
	background-color: #119F93;
	border-radius: 1rem;
	padding: .25rem 1rem;
}
.service02 ul{
	list-style-type: none;
}
.service02 li{
	position: relative;
	padding-left: 1rem;
}
.service02 li::before{
	content: "・";
	position: absolute;
	top: 0;
	left: 0;
}
@media (max-width: 959px) {
	.service01{
		-webkit-flex-wrap: wrap;
		flex-wrap: wrap;
	}
	.service01 section{
		width: 100%;
		margin-bottom: 2rem;
	}
	.service01 h2{
		font-size: 1.25rem;
	}
}

/* =======================================
    company
======================================= */
#company{
	background-color: #F9F5C6;
	padding: 2rem 0;
	margin-top: 4rem;
}
#company header{
	margin-bottom: 2rem;
}
.company-text{
	padding: 1rem 0 2rem;
}
.company-text p{
	margin-bottom: 1rem;
}
.company01,
.company02{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	margin-bottom: 3rem;
}
/*company02 外観写真とあいさつ*/
.company02{
	-webkit-align-items: flex-start;
	align-items: flex-start;
}
.company02 img{
	width: 50%;
}
.com-text{
	width: 45%;
}
.com-text p{
	margin-bottom: 1rem;
}
.com-info{
	width: 45%;
	border-top: solid 1px #fff;
}
.com-info div{
	display: table;
	width: 100%;
	border-bottom: solid 1px #fff;
	padding: .5rem;
}
.com-info dt{
	display: block;
	width: 8rem;
}
.com-info dd{
	display: table-cell;
	width: 100%;
}
.company01 iframe{
	width: 50%;
}
/*recruit リクルート*/
#recruit{
	background-color: #fff;
	padding: 4rem;
}
.recruit-title{
	color: #009EB2;
	line-height: 1.2;
	border-left: solid 4px #009EB2;
	padding-left: 1rem;
	margin-bottom: 1.25rem;
}
.recruit-title span{
	font-size: .75rem;
}
.recruit-img{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-align-items: flex-start;
	align-items: flex-start;
	width: 100%;
	margin-top: 1rem;
}
.recruit-img img{
	width: 32%;
}
#recruit h3{
	text-align: center;
	background-color: #efefef;
	padding: .5rem;
	margin: 1rem 0;
}
.rec-detail{
	border-top: solid 1px #ccc;
}
.rec-detail div{
	display: table;
	width: 100%;
	border-bottom: solid 1px #ccc;
	padding: .5rem;
}
.rec-detail dt{
	display: block;
	width: 8rem;
}
.rec-detail dd{
	display: table-cell;
	vertical-align: top;
	width: 100%;
}
@media (max-width: 959px) {
	#company header{
		margin-bottom: 1.5rem;
	}
	.company-text{
		padding: 0 0 1rem;
	}
	.company01,
	.company02{
		-webkit-flex-wrap: wrap;
		flex-wrap: wrap;
	}
	.company02{
		margin-bottom: 1rem;
	}
	.company02 img,
	.com-text,
	.com-info,
	.company01 iframe{
		width: 100%;
		margin-bottom: 1rem;
	}
	.recruit-img img{
		width: 33%;
	}
	.com-info div,
	.com-info dd,
	.rec-detail div,
	.rec-detail dd{
		display: block;
	}
	.com-info dt,
	.rec-detail dt{
		width: 100%;
		font-size: .875rem;
		font-weight: 700;
	}
	#recruit{
		padding: 2rem 1rem;
	}
}
/* =======================================
    information
======================================= */
#information header{
	padding: 2rem 0;
}
.info{
	text-decoration: none;
	border-top: solid 1px #ccc;
	margin-bottom: 4rem;
}
.info li{
	display: table;
	width: 100%;
	border-bottom: solid 1px #ccc;
	padding: .5rem;
}
.date{
	display: block;
	width: 6rem;
}
.info-title{
	display: table-cell;
	vertical-align: top;
	width: 100%;
}
@media (max-width: 959px) {
	.info li,
	.info-title{
		display: block;
	}
	.date{
		width: 100%;
		font-size: .875rem;
		font-weight: 700;
	}
}
/* =======================================
    contact
======================================= */
#contact{
	background: #c8ecf1;
	padding: 4rem 0;
}
#contact header{
	margin-bottom: 1.5rem;
}
.contact-note{
	text-align: center;
	margin-bottom: 1rem;
}
.wrap-form{
	max-width: 40rem;
	margin: 0 auto;
}
.form-name{
	display: block;
	font-weight: 700;
	padding: 1rem 0 .5rem;
}
.required{
	display: inline-block;
	vertical-align: middle;
	font-size: .75rem;
	color: #fff;
	background-color: #F38962;
	border-radius: 4px;
	padding: 2px 5px;
	margin-left: .5rem;
}
input[type="text"],
textarea{
	font-family: 'Noto Sans JP', sans-serif;
	width: 100%;
	font-size: 1rem;
	border: solid 1px #ccc;
	border-radius: .25rem;
	padding: .5rem;
}
.wrap-radio{
	display: inline-block;
	vertical-align: middle;
	margin: 0 1rem .5rem 0;
}
.wrap-radio label{
	padding-left: .25rem;
}
.form-btn{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	margin: 1rem 0;
}
.form-btn.btn-center{
	-webkit-justify-content: center;
	justify-content: center;
}
.form-btn input{
	width: 48%;
	font-size: 1rem;
	text-align: center;
	border: none;
	border-radius: .25rem;
	padding: .5rem;
	cursor: pointer;
}
input[type="submit"],
.back-to-top{
	color: #fff;
	background-color: #F38962
}
input[type="submit"]:hover,
.back-to-top:hover{
	background-color: #ff713c;
}
.back-to-top{
	display: block;
	width: 100%;
	max-width: 19rem;
	text-align: center;
	text-decoration: none;
    border-radius: .25rem;
    padding: .5rem;
	margin: 1rem auto;
}
input[type="reset"],
input[type="button"]{
	background-color: #efefef;
	border: solid 1px #ccc;
}
input[type="reset"]:hover,
input[type="button"]:hover{
	background-color: #d8d8d8;
}
/*確認画面 mail.php*/
.wrap-page{
	min-height: 100%;
	background: #c8ecf1;
	margin-bottom: -50px;
}
.contact-title{
	text-align: center;
	padding: 4rem 0 1rem;
}
.contact-title span{
	font-size: .75rem;
}
.wrap-form02{
	background-color: #fff;
	border-radius: 1rem;
	padding: 2rem;
}
.wrap-form02 .fb{
	margin-bottom: 1rem;
}
.wrap-form02 h2{
	line-height: 1.2;
	border-left: solid 6px #009EB2;
	padding-left: 1rem;
	margin-bottom: 1rem;
}
.wrap-form02 h2 + p{
	text-align: center;
}
.formTable{
	width: 100%;
	border-collapse: collapse;
	border-top: solid 1px #ccc;
}
.formTable th,
.formTable td{
	border-bottom: solid 1px #ccc;
	padding: .5rem .5rem;
}
.formTable th{
	width: 14rem;
	text-align: left;
}
@media (max-width: 959px) {
	#contact{
		padding: 2rem 0;
	}
	#contact header{
		margin-bottom: 1.25rem;
	}
	.contact-note{
		margin-bottom: .875rem;
	}
	.contact-title{
		padding: 2rem 0 1rem;
	}
	.contact-title h1{
		line-height: 1.2;
	}
	.form-name{
		padding-bottom: .25rem;
	}
	.wrap-radio{
		display: block;
		margin-bottom: .25rem;
	}
	.wrap-form02{
		padding: 1.5rem 1rem;
	}
	.wrap-form02 h2{
		font-size: 1.25rem;
	}
	.wrap-form02 h2 + p{
		text-align: left;
	}
	.formTable tr,
	.formTable th,
	.formTable td{
		display: block;
		width: 100%;
	}
	.formTable th{
		font-size: .75rem;
		border-bottom: none;
		padding-bottom: 0;
	}
	.form-btn input{
		font-size: .875rem;
		padding: .875rem .5rem;
		margin-bottom: 1rem;
	}
}
/* =======================================
    footer
======================================= */
footer{
	background-color: #c8ecf1;
}
footer small{
	display: block;
	height: 25px;
	line-height: 25px;
	color: #fff;
	text-align: center;
	background-color: #009EB2;
	}
footer::before{
	content: "";
	display: block;
	height: 25px;
}
.pagetop{
	position: fixed;
	bottom: 2rem;
	right: 2rem;
	z-index: 100;
	display: block;
	width: 80px;
	height: 80px;
	text-align: center;
	text-decoration: none;
	color: #fff;
	background-color: rgba(17, 159, 159, .6);
	border-radius: 50%;
	}
.pagetop img{
	display: block;
	width: 40px;
	margin: 10px auto 5px;
}
.pagetop span{
	display: block;
	font-size: .625rem;
}
@media (max-width: 959px) {
	.pagetop{
		right: 1rem;
		width: 50px;
		height: auto;
		border-radius: .5rem;
		padding: 5px;
	}
	.pagetop img{
		width: 30px;
		margin: 5px auto;
	}
	.pagetop span{
		line-height: 1.2;
	}
}

