@charset "UTF-8";
/****************************************
Resetting
*****************************************/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	border: 0;
	font-size: 100%;
	font: inherit;
	margin: 0;
	padding: 0;
	vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, 
footer, header, main,hgroup, menu, nav, section {
	display: block;
}

body {
	font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', 'Meiryo', sans-serif;letter-spacing:.1em;
}

ol,ul,li{
	list-style: none;
}

blockquote, q {
	quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
	content: '';
	content: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

input[type="submit"],
input[type="button"],
input[type="reset"]{
	appearance: button;
	border: none;
	border-radius: 0;
	box-sizing: border-box;
	cursor: pointer;
	-webkit-box-sizing: content-box;
	-webkit-appearance: button;
}

a{
	text-decoration: none;
}
/******************************************
normarise
******************************************/
*{
	box-sizing:border-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-ms-box-sizing: border-box;
	-o-box-sizing: border-box;
}

html {
	-webkit-font-smoothing: antialiased;
}

@import url(http://fonts.googleapis.com/earlyaccess/notosansjapanese.css);
@font-face {
   font-family: 'Noto Sans Japanese';
   font-style: normal;
   font-weight: 500;
   src: url(//fonts.gstatic.com/ea/notosansjapanese/v6/NotoSansJP-Medium.woff2) format('woff2'),
        url(//fonts.gstatic.com/ea/notosansjapanese/v6/NotoSansJP-Medium.woff) format('woff'),
        url(//fonts.gstatic.com/ea/notosansjapanese/v6/NotoSansJP-Medium.otf) format('opentype');
 }

@font-face {
   font-family: 'Noto Sans Japanese';
   font-style: normal;
   font-weight: 700;
   src: url(//fonts.gstatic.com/ea/notosansjapanese/v6/NotoSansJP-Bold.woff2) format('woff2'),
        url(//fonts.gstatic.com/ea/notosansjapanese/v6/NotoSansJP-Bold.woff) format('woff'),
        url(//fonts.gstatic.com/ea/notosansjapanese/v6/NotoSansJP-Bold.otf) format('opentype');
 }

@font-face {
   font-family: 'Noto Sans Japanese';
   font-style: normal;
   font-weight: 900;
   src: url(//fonts.gstatic.com/ea/notosansjapanese/v6/NotoSansJP-Black.woff2) format('woff2'),
        url(//fonts.gstatic.com/ea/notosansjapanese/v6/NotoSansJP-Black.woff) format('woff'),
        url(//fonts.gstatic.com/ea/notosansjapanese/v6/NotoSansJP-Black.otf) format('opentype');
}

body{
	font-size:16px;
	line-height: 2;
}

a{
	color: #fff;
	transition: .5s;
}

a:hover{
	opacity: 0.8;
}

/******************************************
clearfix
******************************************/
.clearfix:after {
	content: ".";
	clear: both;
	display: block;
	height: 0;
	visibility: hidden;
}

.clearfix {
	display: inline-table;
}  
/* Hides from IE-mac \*/
* html .clearfix {
	height: 1%;
}  
.clearfix {
	display: block;
}  
/* End hide from IE-mac */

/****************************************
Layout
*****************************************/
/*flexbox*/
.flex{
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-wrap: wrap;
	-webkit-flex-wrap: wrap;
}
.flex--start{
	justify-content: flex-start;
	-webkit-justify-content: flex-start;
}

.flex--center{
	justify-content: center;
	-webkit-justify-content: center;
}
.flex--end{
	justify-content: flex-end;
	-webkit-justify-content: flex-end;
}

.flex--bet{
	justify-content: space-between;
	-webkit-justify-content: space-between;
}
.flex--around{
	justify-content: space-around;
	-webkit-justify-content: space-around;
}

/*col*/
.col2{
	width:48%;
}

.col3{
	width:30%;
}

.col4{
	width:25%;
}

.col5{
	width:18.4%;
}

.col6{
	width:15%;
}

.inner{
	margin: 0 auto;
	max-width: 1080px;
	width: 90%;
}
/****************************************
header
*****************************************/
.site-header{
	background: #000;
	padding: 20px;
	width: 100%;
	height: 120px;
	position: fixed;
	top: 0;
	transition: .5s;
	z-index: 10;
box-shadow: 0px 10px 10px rgba(0,0,0,.2);
}
#index.site-header{
	padding: 20px;
	width: 100%;
	position: fixed;
	top: 0;
	transition: .5s;
	z-index: 10;
	background-color:transparent;
}
.site-header.hide{
    top: -120px;
}
.site-logo__img{
	height: auto;
	width: 100%;
}
.gnav__menu__item{
	margin-left: 20px;
}
.gnav__menu__item__link{
	font-size: 16px;color:#fff;
}
.gnav__menu__item__link__name{
	color:#fff;
	margin-right: 5px;
}

.mnav__menu{
	overflow: hidden;
	}
.mnav__menu__tittle{
	display: flex;
	flex-direction: column;
	width: 100%;
	padding: 10px;
	color:#333;
	background: #ccc;
	font-size:1em;
}
.mnav__menu__item{
	display: flex;
	flex-direction: column;
	padding:10px;
	border-bottom: solid 1px #ccc;
}
.mnav__menu__item__link{
	font-size: 1em;
	padding: 10px;
	color: #666;
}

.hero__img{
	height: auto;
	width: 100%;
	margin-top: 100px;
}
.hero_header {
	color: #FFFFFF;
	text-align: center;
	margin: 0;
}
	.login2 {
    display:none;
	}

/*index用*/
.hero__img{
	height: auto;
	max-height: 400px;
	max-width: 1366px;
	width: 100%;
	margin-bottom: 50px;
}

.logo_item{
	width: 70%; margin: 0 auto;
}
.index__menu{
	margin: 100px 0 0 0;
	padding: 20px 0;
	border-top: 1px solid;
    border-image: linear-gradient(to right, #000 20%, #fff 50%, #000 80%);
    border-image-slice: 1;
	border-bottom: 1px solid;
    border-image: linear-gradient(to right, #000 20%, #fff 50%, #000 80%);
    border-image-slice: 1;
	width: 100%;
	text-align: center;
}
.index__menu__item{
	margin-left: 50px;
}

.index__menu__item__link{
	font-size: 16px;
	letter-spacing: 0.2em;
}
/****************************************
footer
*****************************************/

/* More info */

.button {
	width: 375px;
	margin-top: 40px;
	margin-right: auto;
	margin-bottom: auto;
	margin-left: auto;
	padding-top: 20px;
	padding-right: 10px;
	padding-bottom: 20px;
	padding-left: 10px;
	text-align: center;
	vertical-align: middle;
	border-radius: 0px;
	text-transform: uppercase;
	font-weight: bold;
	letter-spacing: 2px;
	border: 3px solid #FFFFFF;
	color: #FFFFFF;
	transition: all 0.3s linear;
}
.button:hover {
	background-color: #FEFEFE;
	color: #C4C4C4;
	cursor: pointer;
}
.copyright {
	text-align: center;
	padding-top: 20px;
	padding-bottom: 20px;
	background-color: #000;
	color: #FFFFFF;
	text-transform: uppercase;
	font-weight: lighter;
	letter-spacing: 2px;
	border-top-width: 2px;
	-webkit-filter: drop-shadow(0px 3px 10px rgba(0,0,0,.8));
    filter: drop-shadow(0px 0px 10px rgba(0,0,0,.8));

}
.footer_banner {
	background-color: #B3B3B3;
	padding-top: 60px;
	padding-bottom: 60PX;
	margin-bottom: 0px;
	background-image: url(../images/pattern.png);
	background-repeat: repeat;
}

.hidden {
	display: none;
}

/*scroll_buttom*/
.demo a {
  position: absolute;
  bottom: 20px;
  left: 50%;
  z-index: 2;
  display: inline-block;
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
  color: #000;
  font : normal 400 20px/1 'Josefin Sans', sans-serif;
  letter-spacing: .1em;
  text-decoration: none;
  transition: opacity .3s;
}
.demo a:hover {
  opacity: .5;
}
#section01 a {
  padding-top: 60px;
}
#section01 a span {
  position: absolute;
  top: 0;
  left: 50%;
  width: 24px;
  height: 24px;
  margin-left: -12px;
  border-left: 1px solid #000;
  border-bottom: 1px solid #000;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  box-sizing: border-box;
}

/*topに戻るボタン*/
 .pagetop{
	 width: 40px;
	 height: 40px;
	 position:fixed;
	 right: 1vw;
	 bottom: 2vh;
	 opacity: 0.6;
	 background: #fff;
}
.pagetop a{
	position: relative;
	display: block;
	width: 20px;
	height: 20px;
	margin: 15px 0 0 10px;
	text-decoration: none;
	border-right: 3px solid #000;
	border-top: 3px solid #000;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
	box-sizing: border-box;
}
/*ボタンリンク無効*/
.no_link{
	pointer-events:none;
}

/****************************************
tablet
*****************************************/
@media screen and (max-width:1024px) { 
.site-header{height: 150px;}
.gnav__menu{width: 95vw;}	
.hero__img{
	max-width: 1024px;
	height: 300px;
	margin-bottom: 10px;
	}
.logo_item {
	width: 100%; margin: 0 auto; display: inline-block; text-align: center;
}
.logo_item1 {
	height: 200px; margin: 0; padding-right: 100px;
}
.logo_item2 {
	height: 198px; margin: 0; padding-left: 100px;
}
.logo_item img{
	display: inline-block; vertical-align: top; margin-bottom: 30px;
}
.index__menu{
	margin: 0;
	padding: 20px 0;
	border-top: 1px solid;
    border-image: linear-gradient(to right, #000 20%, #fff 50%, #000 80%);
    border-image-slice: 1;
	border-bottom: 1px solid;
    border-image: linear-gradient(to right, #000 20%, #fff 50%, #000 80%);
    border-image-slice: 1;
	width: 100%;
	text-align: center;
}
.index__menu__item{
	margin: 0 20px;
}

.index__menu__item__link{
	font-size: 16px;
	letter-spacing: 0.2em;
}	
}

/****************************************
mobile max-width:780px
*****************************************/
@media screen and (max-width:780px) {
	.gnav__menu{width: 20%;}
	.site-header.hide{top: -150px;}
	.login {display:none;}
	.login2 {display:flex;}
	.site-logo{height: auto;width: 80%;font-size:0.7em ;}
	.mnav__menu{margin-top: 0;}
	.mnav__menu__item{display: flex;flex-direction: column;}
}

/****************************************
mobile max-width:480px
*****************************************/
@media screen and (max-width:480px) {
.hero__img{
	width: 100%;
	height: 140px;
	margin-bottom: 20px;
	}
.logo_item {
	width: 100%; margin: 0 auto; display: inline-block; text-align: center;
}
.logo_item1 {
	width: auto;
	height:120px;
	padding-right: 3em;
}
.logo_item2 {
	width: auto;
	height:118px;
	padding: 0;
}
.logo_item img{
	display: inline-block; vertical-align: top; margin:50px 0;
}
.index__menu{
	margin: 20px 0;
	padding: 20px 0;
	border-top: 1px solid;
    border-image: linear-gradient(to right, #000 20%, #fff 50%, #000 80%);
    border-image-slice: 1;
	border-bottom: 1px solid;
    border-image: linear-gradient(to right, #000 20%, #fff 50%, #000 80%);
    border-image-slice: 1;
	width: 100%;
	text-align: center;
	display: flex;
    flex-direction: column;
}
.index__menu__item{
	margin: 20px 0;
}

.index__menu__item__link{
	font-size: 16px;
	letter-spacing: 0.2em;
}	
}