@charset "utf-8";

* {
    margin:0;
    padding:0;
    outline:0;
    vertical-align:baseline;
	box-sizing: border-box;
}

@font-face { 
  font-family: "quicksand"; 
  src: url("../font/quicksand.ttf") format("truetype") 
}


h1, h2, h3, h4, h5, h6, p {
	margin: 0;
}

address, em, cite, dfn, var {
  font-style: normal;
}

article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section {
    display:block;
}


ul {
	list-style:none;
	padding:0;
}
li {
	padding:0;
}

input[type="submit"] {
  -webkit-appearance: none;
  border-radius: 0;
}

table {
  border-collapse: collapse;
}

table th{
  vertical-align:top;
}

select {
    vertical-align:middle;
	-webkit-appearance: none;
	appearance: none;
}


a{
	text-decoration:none;
	color:#333;
}

a {
    -webkit-tap-highlight-color:transparent;
}

a:hover{
	color: #a0e0f0;
}

.clearfix:after {
	content: ".";
	display: block;
	height: 0.1px;
	font-size: 0.1em;
	line-height: 0; 
	clear: both;
	visibility: hidden; 
	overflow: hidden;
}

a img {
    border-style:none;
}

a:hover img:hover{
opacity: 0.6;
-webkit-opacity: 0.6;
-moz-opacity: 0.6;
}

a img{
-webkit-transition: opacity 0.3s ease-out;
-moz-transition: opacity 0.3s ease-out;
-ms-transition: opacity 0.3s ease-out;
transition: opacity 0.3s ease-out;
}


html,body {  
	-webkit-text-size-adjust: 100%; 
} 


body {
    margin:0;
	width:100%; 
	font-family: "Noto Sans JP", sans-serif;
  	color: #4d4d4d;
	background:#fff;
}

.center{
	text-align:center;
	margin:0 auto;
}

.left{
	text-align:left;
}


.right{
	text-align:right;
}


img{
	height: auto;
	max-width: 100%;
	vertical-align: bottom;
}


.clearfix:after {
	content: ".";
	display: block;
	height: 0.1px;
	font-size: 0.1em;	
	line-height: 0; 
	clear: both;
	visibility: hidden; 
}

.font{
	font-family: "quicksand"; 
	color: #a0e0f0;
}

.pbg{
	background: #f9f9f9;
}

.text-right{color: #fff;}
.text-right a{color: #fff;}

@media screen and (min-width: 1024px){

#header{
	margin:0;
	width:100%;
	height: 70px;
	background-color: rgb(255 255 255 / 0.9);
	position: relative;
	position: fixed;
	z-index: 10;
	top: 0;
	left: 0;
	align-items: center
}


h1{
	margin:0 auto;
	float: left;
	padding: 9px 17px 0;
	width: 150px;
}

.t-menu,nav{
	display: none;
}

#menu-wrap {
	float: right;
	
}

.menu{
	margin-top:13px;
}

.menu li {
	list-style:none;
	float:left;
	width: 140px;
	text-align: center;
}

.menu li a{
	display:block;
	padding: 15px;
	height: 63px;
}


#hero {
	width: 100%;
	height: 1300px;
	overflow: hidden;
	position: relative;
}

.slideimg {
	position: absolute;
 	inset: 0;
	opacity: 0;
	background-size: cover;
	background-position: center top;
	animation: slideAnime 15s infinite;
}

.slideimg:nth-of-type(1) { background-image: url('../images/hero01.jpg'); animation-delay: 0s; }
.slideimg:nth-of-type(2) { background-image: url('../images/hero02.jpg'); animation-delay: 5s; }
.slideimg:nth-of-type(3) { background-image: url('../images/hero03.jpg'); animation-delay: 10s; }

@keyframes slideAnime {
	0%, 63%, 100% { opacity: 0; }
	20%, 33% { opacity: 1; }
}

.hero_txt{
	text-align: center;	
	font-size: 16px;
	line-height: 30px;
 	position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
	text-shadow: 2px 2px 10px #fff,
	-2px 2px 10px #fff,
	2px -2px 10px #fff,
	-2px -2px 10px #fff;
	animation: fadeIn 3.8s cubic-bezier(0.33, 1, 0.68, 1) forwards;
}

 
@keyframes fadeIn {
  0% {
    opacity: 0;
  }
    10% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

.hero_txt p{
	margin-bottom: 20px;
}

/* ---------------------------------------------------------------------
contents
--------------------------------------------------------------------- */

.contents{
	width: 1140px;
	margin: 0 auto;
}

.title01{
	padding:80px 0;
	font-size: 18px;
	letter-spacing:0.2em;
}

.title01 span{
	font-size: 60px;
	margin-right: 30px;
	letter-spacing:0.2em;

}

.title02{
	padding:30px 0 ;
	font-size: 18px;
	letter-spacing:0.2em;
}

.title02 span{
	font-size: 60px;
	margin-right: 30px;
	letter-spacing:0.2em;

}

.title03{
	padding:80px 0 ;
	font-size: 18px;
	text-align: center;
	letter-spacing:0.2em;
}

.title03 p{
	padding-top:20px;
	letter-spacing:0.2em;
}



.title03 span{
	font-size: 60px;

}

#t01{
	margin: 20px 0 200px;
}

#t02{
	margin: 20px 0 100px;
}

#t03{
	margin: 20px 0 200px;
}

#t04{
	margin: 20px 0 200px;
}

#t05{
	margin: 20px 0 200px;
}

#t06{
	margin: 20px 0 200px;
}

.service{
	margin-bottom: 50px;
	font-size: 16px;
	line-height: 30px;
}

.service img{
	border-radius: 30px;
}


.service01{
	float: left;
	width: 440px;
}

.service02{
	margin-left: 470px;
	padding-top: 15px;
}

.service03{
	font-size: 22px;
	font-weight: bold;
	margin: 12px 0;
	color: #a0e0f0;
}



.company {
	margin: 0 auto;
	font-size: 16px;
	line-height: 30px;
}

.company table{
	width: 100%;
}

.company tr{
		border-bottom: 1px solid #cecece;
}

.company th{
		text-align: left;
		font-weight: normal;
		vertical-align: top;
		width: 130px;
		padding: 30px 0;
}

.company td{
		text-align: left;
		vertical-align: top;
		padding: 30px 0;
}

.recruit{
	font-size: 16px;
	line-height: 30px;
	text-align: center;
	padding: 20px 0;
	width: 780px;
	background: #f9f9f9;
	margin: 30px auto;

}

.news {
	padding: 30px 0 50px;
	font-size: 16px;
	line-height: 30px;
}

.news table{
	width: 100%;
}

.news tr{
		border-bottom: 1px solid #cecece;
}

.news th{
		text-align: left;
		font-weight: normal;
		vertical-align: top;
		width: 130px;
		padding: 30px 0;
}

.news td{
		text-align: left;
		vertical-align: top;
		padding: 30px 0;
}

.contact {
	text-align: center;
	margin: 30px auto 200px;
}

.btn{
	margin: 30px auto;
	width: 400px;
	background: #a0e0f0;
	text-align: center;
	font-size: 18px;
}

.btn a{
	margin: 30px auto;
	color: #fff;
	display: block;
	padding: 20px 0;
}

.btn:hover{
	background: #999;
}

/* ---------------------------------------------------------------------
Footer
--------------------------------------------------------------------- */


#footer{
	padding:0;
	text-align:center;
	font-size: 12px;
}

#footer ul {
	width: 1000px;
	font-size: 18px;
	margin: 0 auto;
}


#footer li {
	list-style:none;
	float:left;
	width: calc(100% / 5);
	text-align: center;
}

#footer li a{
	display:block;
	padding: 15px;
	height: 63px;
}


#footer .logo {
	padding:20px 0 0;
}

address {
	margin:0px auto;
	padding:20px 0;
}

}



@media screen and (max-width: 1140px){
.contents{
	width: 100%;
	margin: 0 auto;
	padding: 0 2%;
}

.contact2{
	width: 100%;
	margin: 50px auto;
	padding: 0 2%;
}

.slideimg {
	position: absolute;
 	inset: 0;
	opacity: 0;
	background-size: cover;
	background-position: center top;
	animation: slideAnime 15s infinite;
}

.slideimg:nth-of-type(1) { background-image: url('../images/sp_hero01.jpg'); animation-delay: 0s; }
.slideimg:nth-of-type(2) { background-image: url('../images/sp_hero02.jpg'); animation-delay: 5s; }
.slideimg:nth-of-type(3) { background-image: url('../images/sp_hero03.jpg'); animation-delay: 10s; }

@keyframes slideAnime {
	0%, 63%, 100% { opacity: 0; }
	20%, 33% { opacity: 1; }
}
}




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

#main{
	margin:0;
	overflow:hidden;
}


#header{
	margin:0;
	width:100%;
	height: 50px;
	background-color: rgb(255 255 255 / 0.9);
	position: relative;
	position: fixed;
	z-index: 10;
	top: 0;
	left: 0;
	align-items: center
}

h1{
	margin:0 auto;
	float: left;
	padding: 0px 10px 0;
	width: 130px;
}

#menu-wrap{
	display: none;
}

#hero {
	width: 100%;
	height: 700px;
	overflow: hidden;
	position: relative;
}



.hero_txt{
	text-align: center;	
	font-size: 14px;
	line-height: 24px;
 	position: absolute;
    top: 50%;
    left: 50%;
	width: 96%;
    transform: translate(-50%, -50%);
	text-shadow: 2px 2px 10px #fff,
	-2px 2px 10px #fff,
	2px -2px 10px #fff,
	-2px -2px 10px #fff;
	animation: fadeIn 3.8s cubic-bezier(0.33, 1, 0.68, 1) forwards;
}

 
@keyframes fadeIn {
  0% {
    opacity: 0;
  }
    50% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

.hero_txt p{
	margin-bottom: 20px;
}	

.overlay {
  content: "";
  display: block;
  width: 0;
  height: 0;
  background-color: rgba(0, 0, 0, 0.5);
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
  opacity: 0;
  transition: opacity .5s;
}

.overlay.open {
  width: 100%;
  height: 100%;
  opacity: 1;
}

.t-menu{
	position: absolute;
	width: 30px;
	top:10px;
	right: 10px;	
}

main.open {
  transform: translateX(-250px);
}

.menu-trigger{
	cursor: pointer;
}

.menu-trigger.active{
  display: none;
}

.cl{
	position: absolute;
	width: 30px;
	top:10px;
	right: 10px;
	cursor: pointer;

}

nav {
  width: 100%;
  height: 100%;
  background:#a0e0f0;
  position: fixed;
  top: 0;
  right: 0;
  z-index: 3;
  transform: translate(100%);
  transition: all .2s;
  z-index: 100;
}

nav.open {
  transform: translateZ(0);
}

nav ul{
	padding-top: 40px;
}


nav li{
	border-bottom: 1px #fff dotted;
}

nav li a{
	background: url("../images/arrow.svg")no-repeat right 15px center;
	background-size: 8px;
	color: #fff;
	text-decoration: none;
	padding: 20px;
	display: block;
	font-size: 14px;
	line-height: 24px;
	font-weight: bold;
}

/* ---------------------------------------------------------------------
contents
--------------------------------------------------------------------- */

.contents{
	width: 96%;
	margin: 0 auto;
}

.title01{
	padding:15% 0;
	font-size: 10px;
	letter-spacing:0.2em;
}

.title01 span{
	font-size: 36px;
	margin-right: 10px;
	letter-spacing:0.2em;

}

.title02{
	padding:30px 0 ;
	font-size: 10px;
	letter-spacing:0.2em;
}

.title02 span{
	font-size: 36px;
	margin-right: 10px;
	letter-spacing:0.2em;

}

.title03{
	padding:80px 0 ;
	font-size: 18px;
	text-align: center;
	letter-spacing:0.2em;
}

.title03 p{
	padding-top:20px;
	letter-spacing:0.2em;
}



.title03 span{
	font-size: 36px;

}

#t01{
	margin: 10% 0 30%;
}

#t02{
	margin: 10% 0 30%;
}

#t03{
	margin: 10% 0 30%;
}

#t04{
	margin: 10% 0 30%;
}

#t05{
	margin: 10% 0 30%;
}

#t06{
	margin: 10% 0 30%;
}

.service{
	margin-bottom: 50px;
	font-size: 14px;
	line-height: 24px;
}

.service img{
	border-radius: 15px;
	width: 100%;
}


.service01{
	float:none;
	width: 100%;
}

.service02{
	margin-left: 0;
	padding-top: 15px;
}

.service03{
	font-size: 18px;
	font-weight: bold;
	margin: 12px 0;
	color: #a0e0f0;
}

.company {
	margin: 0 auto;
	font-size: 14px;
	line-height: 24px;
}

.company table{
	width: 100%;
}

.company tr{
		border-bottom: 1px solid #cecece;
}

.company th{
		width: 80px;
		padding: 20px 0;
}

.company td{
		padding: 20px 0;
}

.recruit{
	font-size: 14px;
	line-height: 24px;
	text-align: center;
	padding: 20px 0;
	background: #f9f9f9;
	margin: 5% auto;

}

.news {
	padding: 30px 0 50px;
	font-size: 14px;
	line-height: 24px;
}

.news table{
	width: 100%;
}

.news tr{
		border-bottom: 1px solid #cecece;
}

.news th{
		text-align: left;
		font-weight: normal;
		vertical-align: top;
		width: 100px;
		padding: 30px 0;
}

.news td{
		text-align: left;
		vertical-align: top;
		padding: 30px 0;
}

.contact {
	text-align: center;
	margin: 30px auto 200px;
}

.btn{
	margin: 30px auto;
	width: 80%;
	background: #a0e0f0;
	text-align: center;
	font-size: 16px;
}

.btn a{
	margin: 30px auto;
	color: #fff;
	display: block;
	padding: 20px 0;
}

.btn:hover{
	background: #999;
}



/* ---------------------------------------------------------------------
Footer
--------------------------------------------------------------------- */


#footer{
	padding:0;
	text-align:center;
	font-size: 12px;
}

#footer ul {
	display: none;
}

#footer .logo {
	padding:20px 0 0;
}

address {
	margin:0px auto;
	padding:20px 0;
}

}