@charset "UTF-8";

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,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
margin: 0;
padding: 0;
border: 0;
font-size: 100%;
font: inherit;
font-family: 'Noto Sans JP', sans-serif;
vertical-align: baseline;
color: black;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
display: block;
}
body {
line-height: 1;
-webkit-text-size-adjust: none;
}
ol, ul {
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;
}

button, html input[type="button"], input[type="reset"], input[type="submit"] {
    cursor: pointer;
}

html, body { height: 100%; width:100%; }
/*==========================================================
  ボックス
==========================================================*/
#body {
  margin: 0px;
  padding: 0px;
  border:0px;
  text-align: center;
}

h1, h2, h3, h4, h5, h6 {}
p {}


img {
  margin: 0px;
  padding: 0px;
  border: 0px;
}

.floatleft{
	float: left;
}

.floatright{
	float: right;
}

.marginTB1{
	margin: 1em 0;
}

.marginTB2{
	margin: 2em 0;
}
.clearfix:after {
	content: "."; 
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
}

.clearfix {
	min-height: 1px;
}

* html .clearfix {
	height: 1px;
	/*¥*//*/
	height: auto;
	overflow: hidden;
	/**/
}

*, *:before, *:after {
    -webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
         -o-box-sizing: border-box;
        -ms-box-sizing: border-box;
            box-sizing: border-box;
}
/*==========================================================
  テキストサイズ
==========================================================*/
.text9 { font-size:9px; }
.text10 { font-size:10px; }
.text11 { font-size:11px; }
.text12 { font-size:12px; }
.text13 { font-size:13px; }
.text14 { font-size:14px; }
.text15 { font-size:15px; }
.text16 { font-size:16px; }
.text17 { font-size:17px; }
.text18 { font-size:18px; }
.text19 { font-size:146.5%; }
.text20 { font-size:153.9%; }
.text21 { font-size:21px; }
.text22 { font-size:167%; }
.text23 { font-size:174%; }
.text24 { font-size:182%; }
.text25 { font-size:189%; }
.text26 { font-size:197%; }

.bold{font-weight: bold;}

p {
  font-size:14px;
font-family: 'Noto Sans JP', sans-serif;
	font-weight: 400;
	line-height: 2em;
}

a {
font-size:14px;
font-family: 'Noto Sans JP', sans-serif;
  color: #555;
	text-decoration:none;
}
a:visited {
  color: #555;
}
a:hover {
  color: #999;
}

h1 {
font-family: 'Noto Sans JP', sans-serif;
  font-size:48px;
  font-weight: normal;
  line-height: 1.8em;
}

h2 {
font-family: 'Noto Sans JP', sans-serif;
  font-size:32px;
  line-height: 1.8em;
  font-weight: normal;
}

h3 {
font-family: 'Noto Sans JP', sans-serif;
  font-size:22px;
  line-height: 1.8em;
  font-weight: normal;
}

h2 img {
	vertical-align:middle;
	margin-right: 0.2em;
}

h5 {
font-family: 'Noto Sans JP', sans-serif;
  font-size:100%;
  color: #1A1A1A;
  line-height: 1.8em;
}

.center{
	text-align: center;
}

.right{
	text-align: right;
}


/*==========================================================
  改行
==========================================================*/
@media screen and (min-width: 750px){
  .br-pc { display:block; }
  .br-sp { display:none; }
}
	
@media screen and (max-width:750px){
  .br-pc { display:none; }
  .br-sp { display:block; }
}

/*===============================================
画面の横幅が769px以上（パソコン用）
===============================================*/
@media screen and (min-width: 751px){

}



/*===============================================
画面の横幅が640pxまで（スマホ用）
===============================================*/
@media screen and (max-width:750px){

}

/* パソコンで見たときは"pc"のclassがついた画像が表示される */
.pc { display: block !important; }
.sp { display: none !important; }
/* スマートフォンで見たときは"sp"のclassがついた画像が表示される */
@media only screen and (max-width: 750px) {
.pc { display: none !important; }
.sp { display: block !important; }
}

/* ----- 背景用の動画ファイル ----- */
#video-background,
#video-overlay {
  position: fixed;
  top: 0;
  left: 0;
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
}
 
#video-background {
  z-index: -2;
}
 

/* fullpage用 */
.fp-bg {
 top:0;
 bottom:0;
 width: 100%;
 position:absolute;
 z-index: -1;
}
.fp-section, .fp-slide, .fp-section.fp-table, .fp-slide.fp-table, .fp-section .fp-tableCell, .fp-slide .fp-tableCell {
 position:relative;
 overflow: hidden;
}

.fp-bg {
 transition: transform 1000ms ease;
}
	
.fp-bg{
background-size: cover;
transform: translate3d(0,0,0);
-webkit-backface-visibility: hidden; /* Chrome, Safari, Opera */
backface-visibility: hidden;
background-position: center center;
}	


/* モーダルウィンドウ用 */
#modal-default{
		width: 100%;
		max-width: 100%;
	}
	.iziModal .iziModal-header.iziModal-noSubtitle .iziModal-header-title{
	font-family: 'Noto Sans JP', sans-serif;
  font-size:20px;
  line-height: 1.8em;
  font-weight: 400;
	}
	

/* ScrollMagic用 */
	
	.digit {
		opacity: 0;
		-webkit-transform: translateY(300px);
			 -moz-transform: translateY(300px);
				-ms-transform: translateY(300px);
				 -o-transform: translateY(300px);
						transform: translateY(300px);
		-webkit-transition: all 0.6s ease-out;
			 -moz-transition: all 0.6s ease-out;
				-ms-transition: all 0.6s ease-out;
				 -o-transition: all 0.6s ease-out;
						transition: all 0.6s ease-out;
	}
	.digit.visible {
		opacity: 1;
		-webkit-transform: none;
			 -moz-transform: none;
				-ms-transform: none;
				 -o-transform: none;
						transform: none;
	}

/* スクロールアイコン用 */
.ScrollIconB a,
.ScrollIcon a {
  position: absolute;
  bottom: 20px;
  left: 50%;
  z-index: 2;
  display: inline-block;
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
  text-decoration: none;
	  margin-left: -15px;
	color: #FFF;
	font-weight: 100;
}

.ScrollIconB a,
.ScrollIcon a {
  padding-top: 60px;
	cursor: pointer;
}

.ScrollIconB a span,
.ScrollIcon a span {
  position: absolute;
  top: 0;
  left: 50%;
  width: 30px;
  height: 50px;
  margin-left: -15px;
  border: 2px solid #FFF;
  border-radius: 50px;
  box-sizing: border-box;
}

.ScrollIconB a span{
	border: 2px solid #555;
}
.ScrollIconB a span::before,
.ScrollIcon a span::before {
  position: absolute;
  top: 10px;
  left: 50%;
  content: '';
  width: 6px;
  height: 6px;
  margin-left: -3px;
  background-color: #FFF;
  border-radius: 100%;
  -webkit-animation: sdb 2s infinite;
  animation: sdb 2s infinite;
  box-sizing: border-box;
}

.ScrollIconB a span::before {
	background-color: #555;
}
@-webkit-keyframes sdb {
  0% {
    -webkit-transform: translate(0, 0);
    opacity: 0;
  }
  40% {
    opacity: 1;
  }
  80% {
    -webkit-transform: translate(0, 20px);
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}
@keyframes sdb {
  0% {
    transform: translate(0, 0);
    opacity: 0;
  }
  40% {
    opacity: 1;
  }
  80% {
    transform: translate(0, 20px);
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}

.section{
background-size: cover;
transform: translate3d(0,0,0);
-webkit-backface-visibility: hidden; /* Chrome, Safari, Opera */
backface-visibility: hidden;
background-position: center center;
}

.Copyright{
		text-align: center;
		position: absolute;
		bottom: 5px;
		left: 50%;
		-webkit-transform: translate(-50%, 0);
  transform: translate(-50%, 0);
	font-size: 10px;
	}