@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=DotGothic16&family=Noto+Serif+JP:wght@900&display=swap');

/* CSS Document */

*{
	margin:0;padding:0;
	font-feature-settings: "palt";
	box-sizing: border-box;
}

img {border:0;}
address {font-style:normal;}
a{text-decoration:none;}

.m0auto{margin: 0 auto;}
.mb1{margin-bottom: 1em!important;}
.mb1-5{margin-bottom: 1.5em!important;}
.mb2{margin-bottom: 2em!important;}
.mb2-5{margin-bottom: 2.5em!important;}
.mb3{margin-bottom: 3em!important;}
.red {color: red;}
.yelllow {color: yellow;}
.white{color:white;}
.blue{color:blue;}
.green{color:green;}
.DechauOrange{color:#FF4200;}
.clear {clear:both;}
.copyright {font-size: 0.5em;margin: 20px 0;text-align: center;}

body{
	background: black;
	position: relative;
	overflow-x: hidden;
}

.introMovie {
	position: fixed;
	inset: 0;
	z-index: 2147483647;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #000;
	opacity: 1;
	visibility: visible;
	transition: opacity 1.25s ease, visibility 1.25s ease;
}

.introMovie video {
	width: auto;
	height: 100%;
	max-width: 100%;
	object-fit: contain;
	display: block;
}

.introSkip {
	position: absolute;
	left: 50%;
	bottom: 24px;
	transform: translateX(-50%);
	z-index: 1;
	min-width: 72px;
	padding: 7px 16px;
	border: 1px solid rgba(255, 255, 255, 0.48);
	border-radius: 999px;
	background: rgba(0, 0, 0, 0.42);
	color: rgba(255, 255, 255, 0.86);
	font-family: Arial, "Helvetica Neue", sans-serif;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1;
	cursor: pointer;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.introSkip:hover,
.introSkip:focus-visible {
	background: rgba(255, 66, 0, 0.78);
	border-color: rgba(255, 255, 255, 0.82);
	color: #fff;
	outline: none;
}

body.is-lp-ready .introMovie {
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
}

.lpMovieBg {
	position: fixed;
	inset: 0;
	z-index: 0;
	overflow: hidden;
	background: #000;
	opacity: 0;
	transition: opacity 1.3s ease;
}

.lpMovieBg video {
	width: 100%;
	height: auto;
	min-height: 0;
	object-fit: contain;
	object-position: center top;
	display: block;
}

.lpMovieBg::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 1;
	background-image:
		radial-gradient(circle, rgba(0, 0, 0, 0.46) 1px, rgba(0, 0, 0, 0) 1.4px),
		repeating-linear-gradient(0deg, rgba(0, 0, 0, 0.22) 0, rgba(0, 0, 0, 0.22) 1px, rgba(255, 94, 0, 0.05) 1px, rgba(255, 94, 0, 0.05) 3px);
	background-size: 4px 4px, 100% 4px;
	mix-blend-mode: multiply;
	pointer-events: none;
}

.lpMovieBg::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 2;
	background:
		radial-gradient(circle at 50% 22%, rgba(255, 92, 0, 0.14), rgba(0, 0, 0, 0) 42%),
		linear-gradient(180deg, rgba(0, 0, 0, 0.12), rgba(0, 0, 0, 0.48));
	pointer-events: none;
}

body.is-lp-ready .lpMovieBg {
	opacity: 1;
}

.lpShell {
	min-height: 100vh;
	opacity: 0;
	transform: translateY(18px) scale(0.985);
	filter: brightness(0.5) saturate(1.35);
	transition: opacity 1.3s ease, transform 1.3s ease, filter 1.3s ease;
}

body.is-lp-ready .lpShell {
	opacity: 1;
	transform: translateY(0) scale(1);
	filter: brightness(1) saturate(1.08);
}

#ember-canvas {
	position: fixed;
	inset: 0;
	width: 100vw;
	height: 100vh;
	pointer-events: none;
	z-index: 5;
	opacity: 0;
	mix-blend-mode: screen;
	transition: opacity 1.5s ease;
}

body.is-lp-ready #ember-canvas {
	opacity: 0.9;
}

.body1 {
	width: calc(100% - 2em);
	max-width: 700px; /** デザインの最大幅 **/
	margin: 0 auto;
	font-family: "Helvetica Neue",Arial,
    "Hiragino Kaku Gothic ProN",
    "Hiragino Sans",
    Meiryo,
    sans-serif;
}

.mainVisu{
	display: flex;
	justify-content: center;
}
.mainVisu img{
	max-width: 1300px;
}
.mainTitle{
	width: 100%;
	margin-bottom: 2em;
}
.mainTitle img{
	width: 100%;
}
.mainTitle h1{
	color: white;
	text-align: center;
	font-family: 'Noto Serif JP', serif;
	font-weight: 900;
	font-size: 1.7em;
	margin-bottom: 0.5em;
	text-shadow: #FC0 1px 0 10px;
}
.mainTitle p{
	color: white;
	text-align: center;
	width: 100%;
	margin: 0 auto;
	text-shadow: 0px 0px 8px black;
}

.hizuke img{
	display: flex;
	justify-content: center;
	width: 100%;
}

.embeddedWrap{
	display: flex;
	justify-content: center;
	background: white;
	border: 2px solid gray;
	border-radius: 10px;
	margin-bottom: 2em;
}
.embedded1{
	width: 100%;
	max-width: 812px;
	height: 85vh;
	border-radius: 10px;
}

.content {
  flex: 1;
  position: relative;
  z-index: 4;
}
footer {
	position: fixed;
  width: 100%;
  background: #44aa33;
}

/*
FlexBoxの設定
----------------------------------------------------------- */
/*コンテナ*/
.flexContainer{
	display:flex;
	justify-content: flex-start; /*水平方向の揃え設定*/
	align-items: stretch; /*垂直方向の揃え設定*/
}
/*アイテム*/
.flexItem{
	width: calc(100%/2 - 0.3em); /*分割数を指定*/
}
/*要素の真ん中に配置*/
.mannaka{
	display: flex;
	justify-content: center;
	align-items: center;
}
/*
 フェイドインクラス
----------------------------------------------------------- */
.fadeInUp {
  opacity : 0;
  transform: translateY(20px);
  transition: 5s;
}

/*
 メディアクエリ 
----------------------------------------------------------- */
@media (min-width:600px){
	.mainTitle h1{
	font-size: 2.8em;
}
	.mainTitle p{
	font-size: 1.5em;
}
	
}
