@charset "UTF-8";
/*-----------------------------------------------------------
		font
-----------------------------------------------------------*/
@font-face {
	font-family: 'Satoshi-Bold';
	src: url("../fonts/Satoshi-Bold.woff2") format("woff2"), url("../fonts/Satoshi-Bold.woff") format("woff"), url("../fonts/Satoshi-Bold.ttf") format("truetype");
	font-weight: 700;
	font-display: swap;
	font-style: normal;
}
/*-----------------------------------------------------------
		リセット
-----------------------------------------------------------*/
html {
	overflow-y: scroll;
}

fieldset, img {
	border: none;
	vertical-align: top;
}

ul, ol {
	list-style-type: none;
}

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

caption, th {
	text-align: left;
}

a {
	outline: none;
}

h1, h2, h3, h4, h5, h6,
html, body, div,
p, ul, ol, li, dl, dt, dd,
pre, blockquote,
form, fieldset, input, textarea,
table, th, td, figure {
	margin: 0;
	padding: 0;
}

/*-----------------------------------------------------------
		初期設定
-----------------------------------------------------------*/
:root {
	color: #000;
	font-size: 0.52vw;
	/*@include for-over() {
		font-size: 10px;
	}
	*/
}
@media (max-width: 1219px) {
	:root {
		font-size: 0.62vw;
	}
}
@media (max-width: 995px) {
	:root {
		font-size: 0.7vw;
	}
}
@media (max-width: 767px) {
	:root {
		font-size: 1vw;
	}
}
@media (max-width: 995px) {
	:root {
		-webkit-text-size-adjust: 100%;
		-moz-text-size-adjust: 100%;
		-ms-text-size-adjust: 100%;
		text-size-adjust: 100%;
	}
}

body {
	color: #000;
	line-height: 1.5;
	font-size: 1.6rem;
	word-wrap: break-word;
	font-weight: 400;
	font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
}
@media (max-width: 995px) {
	body {
		-webkit-text-size-adjust: 100%;
		-moz-text-size-adjust: 100%;
		-ms-text-size-adjust: 100%;
		text-size-adjust: 100%;
	}
}
@media (max-width: 767px) {
	body {
		font-size: 3.5vw;
	}
}

h1, h2, h3, h4, h5, h6 {
	font-size: 100%;
}

img {
	max-width: 100%;
}

button, fieldset, form, input, label, legend, select, textarea {
	font-family: inherit;
	font-size: 100%;
	font-style: inherit;
	font-weight: inherit;
}

a {
	text-decoration: none;
	color: #000;
}
@media (min-width: 1220px) {
	a:hover {
		color: #000;
		text-decoration: underline;
	}
	a:visited {
		color: #000;
	}
	a:active {
		text-decoration: none;
	}
}

q:before, q:after {
	content: '';
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

@font-face {
	font-family: 'Yasashisa';
	font-style: normal;
	font-weight: 400;
	src: url(../font/yasashisa-tegaki.woff) format("woff"), url(../font/yasashisa-tegaki.woff2) format("woff2");
	font-display: swap;
}
@font-face {
	font-family: 'Satoshi-Bold';
	src: url("../font/Satoshi-Bold.woff2") format("woff2"), url("../font/Satoshi-Bold.woff") format("woff"), url("../font/Satoshi-Bold.ttf") format("truetype");
	font-weight: 700;
	font-display: swap;
	font-style: normal;
}
@font-face {
	font-family: 'Satoshi-Regular';
	src: url("../font/Satoshi-Regular.woff2") format("woff2"), url("../font/Satoshi-Regular.woff") format("woff"), url("../font/Satoshi-Regular.ttf") format("truetype");
	font-weight: 400;
	font-display: swap;
	font-style: normal;
}
@font-face {
	font-family: 'Satoshi-Light';
	src: url("../font/Satoshi-Light.woff2") format("woff2"), url("../font/Satoshi-Light.woff") format("woff"), url("../font/Satoshi-Light.ttf") format("truetype");
	font-weight: 300;
	font-display: swap;
	font-style: normal;
}
/*-----------------------------------------------------------
		フォームタグ設定
-----------------------------------------------------------*/
[type=text], [type=email], [type=tel], [type=password], [type=number], [type=search], [type=date], textarea, select {
	padding: 0.75em 1em;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	border: 1px solid #c3c3c3;
	border-radius: 1rem;
	background: #fff;
}

select {
	max-width: 100%;
	padding: 0.75em 3em 0.75em 1em;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	border: 1px solid #c3c3c3;
	border-radius: 1rem;
	background: #fff url("../img/common/arrow.svg") right center/auto 100% no-repeat;
}

option {
	color: #000;
}

select::-ms-expand {
	display: none;
}

[type=text], [type=email], [type=tel], [type=password], [type=submit], [type=number], [type=search], [type=date], textarea, button {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

[type=text]:focus, [type=email]:focus, [type=password]:focus, [type=number]:focus, [type=search]:focus, [type=date]:focus, textarea:focus {
	background: none;
	border: 1px solid #fff;
}

button {
	cursor: pointer;
}

input[type=checkbox],
input[type=radio] {
	display: none;
}

input[type=checkbox] + label,
input[type=radio] + label,
[type=radio] + .mwform-radio-field-text,
[type=checkbox] + .mwform-checkbox-field-text {
	display: inline-block;
	position: relative;
	padding-left: 2em;
}
input[type=checkbox] + label:before, input[type=checkbox] + label:after,
input[type=radio] + label:before,
input[type=radio] + label:after,
[type=radio] + .mwform-radio-field-text:before,
[type=radio] + .mwform-radio-field-text:after,
[type=checkbox] + .mwform-checkbox-field-text:before,
[type=checkbox] + .mwform-checkbox-field-text:after {
	display: block;
	content: "";
	position: absolute;
	top: 50%;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	border-radius: 0.5rem;
}
input[type=checkbox] + label:before,
input[type=radio] + label:before,
[type=radio] + .mwform-radio-field-text:before,
[type=checkbox] + .mwform-checkbox-field-text:before {
	left: 0px;
	width: 1.25em;
	height: 1.25em;
	border: 1px solid #c3c3c3;
	background-color: #fff;
}
input[type=checkbox] + label.single,
input[type=radio] + label.single,
[type=radio] + .mwform-radio-field-text.single,
[type=checkbox] + .mwform-checkbox-field-text.single {
	height: 1.25em;
	padding-left: 1.25em;
}

input[type=radio] + label:before, input[type=radio] + label:after,
[type=radio] + .mwform-radio-field-text:before,
[type=radio] + .mwform-radio-field-text:after {
	border-radius: 50%;
}

input[type=checkbox]:checked + label:after,
[type=checkbox]:checked + .mwform-checkbox-field-text:after {
	border-radius: 0.4rem;
}

input[type=checkbox]:checked + label:after,
input[type=radio]:checked + label:after,
[type=checkbox]:checked + .mwform-checkbox-field-text:after,
[type=radio]:checked + .mwform-radio-field-text:after {
	left: 3px;
	width: -webkit-calc(1.25em - 6px);
	width: calc(1.25em - 6px);
	height: -webkit-calc(1.25em - 6px);
	height: calc(1.25em - 6px);
	background-color: #37488b;
}

/*-----------------------------------------------------------
		スクロールバー設定
-----------------------------------------------------------*/
:placeholder-shown {
	color: #BABABA;
}

/* Google Chrome, Safari, Opera 15+, Android, iOS */
::-webkit-input-placeholder {
	color: #BABABA;
}

/* Firefox 18- */
:-moz-placeholder {
	color: #BABABA;
	opacity: 1;
}

/* Firefox 19+ */
::-moz-placeholder {
	color: #BABABA;
	opacity: 1;
}

/* IE 10+ */
:-ms-input-placeholder {
	color: #BABABA;
}

/*-----------------------------------------------------------
		基本レイアウト
-----------------------------------------------------------*/
html {
	scroll-behavior: smooth;
}

body {
	-webkit-perspective: 900px;
	perspective: 900px;
}
body.lock {
	height: 100dvh;
	overflow: hidden;
}

.wrap {
	position: relative;
	margin: 0px 10vw;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
@media (max-width: 767px) {
	.wrap {
		margin: 0 5vw;
	}
}

.linkbox {
	cursor: pointer;
}

.sp {
	display: none;
}
@media (max-width: 767px) {
	.sp {
		display: inherit;
	}
}

@media (max-width: 767px) {
	.spnone {
		display: none !important;
	}
}

.tb {
	display: none;
}
@media (max-width: 995px) {
	.tb {
		display: inherit;
	}
}

@media (max-width: 995px) {
	.tbnone {
		display: none !important;
	}
}

@media (max-width: 995px) {
	.pc {
		display: none !important;
	}
}

/*----------------------- header --------------------------*/
header {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
	position: absolute;
	width: 100%;
	z-index: 1000;
}
header .title {
	width: 11.5rem;
	padding: 4rem 1rem 4rem 4rem;
	background-color: #fff;
}
@media (max-width: 767px) {
	header .title {
		width: 16vw;
	}
}
@media (max-width: 767px) {
	header .title {
		padding: 5.5vw 2vw 4vw 2vw;
	}
}
header .logo {
	width: 22rem;
	padding: 4rem 4rem 2rem 2rem;
	background-color: #fff;
}
@media (max-width: 767px) {
	header .logo {
		width: 30vw;
		padding: 4vw 5vw 2vw 4vw;
	}
}

/*----------------------- content --------------------------*/
.contact {
	margin-top: 15rem;
	padding: 20rem 0 15rem;
	background-color: #37488b;
	color: #fff;
}
.contact .text {
	font-size: 2.6rem;
	text-align: center;
}
@media (max-width: 767px) {
	.contact .text {
		font-size: 3.5vw;
	}
}
.contact .more {
	margin-top: 1.75em;
	text-align: center;
	font-size: 2.2rem;
}
@media (max-width: 767px) {
	.contact .more {
		font-size: 3.5vw;
	}
}
.contact .more a {
	display: inline-block;
	padding: 0.75em 2.5em;
	border-radius: 3em;
	border: 1px solid #fff;
	color: #fff;
	text-decoration: none;
	-webkit-transition: 0.3s;
	-o-transition: 0.3s;
	transition: 0.3s;
}
@media (min-width: 1220px) {
	.contact .more a:hover {
		background-color: #fff;
		color: #37488b;
	}
}

/*----------------------- footer --------------------------*/
footer {
	padding: 6rem 5vw 0;
}
footer .addr {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	gap: 2em;
}
@media (max-width: 767px) {
	footer .addr {
		display: block;
		text-align: center;
	}
}
footer .addr .logo {
	width: 27rem;
}
@media (max-width: 767px) {
	footer .addr .logo {
		width: 36vw;
		margin: 0 auto;
	}
}
footer .addr .logo span {
	display: block;
	margin-top: 0.25em;
	text-align: center;
	font-size: 2rem;
	font-weight: 600;
}
@media (max-width: 767px) {
	footer .addr .logo span {
		font-size: 3vw;
	}
}
footer .addr address {
	margin-top: -0.15em;
	font-weight: 500;
	font-size: 2rem;
}
@media (max-width: 767px) {
	footer .addr address {
		font-size: 3.25vw;
		margin-top: 1em;
	}
}
footer .end {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	-ms-flex-pack: justify;
	justify-content: space-between;
	padding: 3em 0 1em;
}
@media (max-width: 767px) {
	footer .end {
		display: block;
		text-align: center;
		padding-bottom: 1.5em;
	}
}
footer .end .links {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	gap: 1em;
}
@media (max-width: 767px) {
	footer .end .links {
		-webkit-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		-webkit-box-pack: center;
		-webkit-justify-content: center;
		-ms-flex-pack: center;
		justify-content: center;
		font-size: 3vw;
	}
}
@media (max-width: 767px) {
	footer .end .copy {
		margin-top: 2em;
		font-size: 2.5vw;
	}
}

/*-----------------------------------------------------------
	index
-----------------------------------------------------------*/
@-webkit-keyframes explodeAndFall {
	0% {
		-webkit-transform: translate3d(var(--tx), var(--ty), var(--tz)) rotate(0deg);
		transform: translate3d(var(--tx), var(--ty), var(--tz)) rotate(0deg);
		opacity: 0;
		-webkit-animation-timing-function: cubic-bezier(0.2, 0.9, 0.3, 1);
		animation-timing-function: cubic-bezier(0.2, 0.9, 0.3, 1);
	}
	20% {
		/* 斜め上に到達 */
		-webkit-transform: translate3d(-webkit-calc(var(--ux) * 0.85), var(--uy), var(--uz)) rotate(var(--r));
		transform: translate3d(calc(var(--ux) * 0.85), var(--uy), var(--uz)) rotate(var(--r));
		opacity: 1;
		-webkit-animation-timing-function: linear;
		animation-timing-function: linear;
	}
	100% {
		/* 垂直落下 */
		-webkit-transform: translate3d(var(--ux), var(--dy), var(--uz)) rotate(-webkit-calc(var(--r) * 1.2));
		transform: translate3d(var(--ux), var(--dy), var(--uz)) rotate(calc(var(--r) * 1.2));
		opacity: 0;
	}
}
@keyframes explodeAndFall {
	0% {
		-webkit-transform: translate3d(var(--tx), var(--ty), var(--tz)) rotate(0deg);
		transform: translate3d(var(--tx), var(--ty), var(--tz)) rotate(0deg);
		opacity: 0;
		-webkit-animation-timing-function: cubic-bezier(0.2, 0.9, 0.3, 1);
		animation-timing-function: cubic-bezier(0.2, 0.9, 0.3, 1);
	}
	20% {
		/* 斜め上に到達 */
		-webkit-transform: translate3d(-webkit-calc(var(--ux) * 0.85), var(--uy), var(--uz)) rotate(var(--r));
		transform: translate3d(calc(var(--ux) * 0.85), var(--uy), var(--uz)) rotate(var(--r));
		opacity: 1;
		-webkit-animation-timing-function: linear;
		animation-timing-function: linear;
	}
	100% {
		/* 垂直落下 */
		-webkit-transform: translate3d(var(--ux), var(--dy), var(--uz)) rotate(-webkit-calc(var(--r) * 1.2));
		transform: translate3d(var(--ux), var(--dy), var(--uz)) rotate(calc(var(--r) * 1.2));
		opacity: 0;
	}
}
@-webkit-keyframes fadeIn1 {
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}
@keyframes fadeIn1 {
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}
@-webkit-keyframes fadeOut {
	from {
		opacity: 1;
	}
	to {
		opacity: 0;
	}
}
@keyframes fadeOut {
	from {
		opacity: 1;
	}
	to {
		opacity: 0;
	}
}
@-webkit-keyframes fadeIn {
	from {
		opacity: 0;
		-webkit-transform: scale(1.2);
		transform: scale(1.2);
	}
	to {
		opacity: 1;
		-webkit-transform: scale(1);
		transform: scale(1);
	}
}
@keyframes fadeIn {
	from {
		opacity: 0;
		-webkit-transform: scale(1.2);
		transform: scale(1.2);
	}
	to {
		opacity: 1;
		-webkit-transform: scale(1);
		transform: scale(1);
	}
}
@-webkit-keyframes rotate {
	0% {
		-webkit-transform: rotate(0deg);
		transform: rotate(0deg);
	}
	100% {
		-webkit-transform: rotate(365deg);
		transform: rotate(365deg);
	}
}
@keyframes rotate {
	0% {
		-webkit-transform: rotate(0deg);
		transform: rotate(0deg);
	}
	100% {
		-webkit-transform: rotate(365deg);
		transform: rotate(365deg);
	}
}
@-webkit-keyframes arrow {
	0% {
		top: 40%;
	}
	40% {
		top: 50%;
	}
	100% {
		top: 40%;
	}
}
@keyframes arrow {
	0% {
		top: 40%;
	}
	40% {
		top: 50%;
	}
	100% {
		top: 40%;
	}
}
.text-wrapper span {
	display: inline-block;
	min-width: 0.25em;
	opacity: 0;
	-webkit-animation: fadeIn 0.6s ease-in-out forwards;
	animation: fadeIn 0.6s ease-in-out forwards;
}

.top {
	height: 100dvh;
	-webkit-perspective: 900px;
	perspective: 900px;
	overflow: hidden;
}
.top .first, .top .second {
	position: absolute;
	left: 0;
	top: 0;
	right: 0;
	bottom: 0;
}
.top .first {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(7rem, 1fr));
	grid-auto-rows: 7rem;
	padding: 2rem;
	overflow: hidden;
	-webkit-perspective: 800px;
	perspective: 800px;
}
@media (max-width: 767px) {
	.top .first {
		padding: 1vw 1vw;
		grid-template-columns: repeat(auto-fill, minmax(9.8vw, 1fr));
		grid-auto-rows: 9.8vw;
	}
}
.top .first .cell {
	width: 7rem;
	padding: 1rem;
	aspect-ratio: 1 / 1;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	--tx: 0px;
	--ty: 0px;
	--tz: 0px;
	--scale: 0.3;
	--r: 0deg;
	opacity: 0;
	-webkit-transform: translate3d(var(--tx), var(--ty), var(--tz)) scale(var(--scale)) rotate(0deg);
	transform: translate3d(var(--tx), var(--ty), var(--tz)) scale(var(--scale)) rotate(0deg);
	-webkit-transition: -webkit-transform 0.7s cubic-bezier(0.37, 0, 0.63, 1);
	transition: -webkit-transform 0.7s cubic-bezier(0.37, 0, 0.63, 1);
	-o-transition: transform 0.7s cubic-bezier(0.37, 0, 0.63, 1);
	transition: transform 0.7s cubic-bezier(0.37, 0, 0.63, 1);
	transition: transform 0.7s cubic-bezier(0.37, 0, 0.63, 1), -webkit-transform 0.7s cubic-bezier(0.37, 0, 0.63, 1);
	will-change: transform, opacity;
	-webkit-transform-style: preserve-3d;
	transform-style: preserve-3d;
}
@media (max-width: 767px) {
	.top .first .cell {
		width: 9.8vw;
		aspect-ratio: initial;
		padding: 2vw 1.5vw;
	}
}
.top .first .cell img {
	width: 5rem;
}
@media (max-width: 767px) {
	.top .first .cell img {
		width: 6.8vw;
	}
}
.top .first .cell.is-active {
	--scale: 1;
	-webkit-animation: fadeIn1 0.8s ease forwards;
	animation: fadeIn1 0.8s ease forwards;
}
.top .first .cell.is-center {
	--scale: 1;
	-webkit-animation: fadeOut 0.8s ease forwards;
	animation: fadeOut 0.8s ease forwards;
}
.top .first .cell.is-explode {
	-webkit-animation: explodeAndFall 3.6s cubic-bezier(0.5, 1, 0.89, 1) forwards;
	animation: explodeAndFall 3.6s cubic-bezier(0.5, 1, 0.89, 1) forwards;
}
.top .second {
	opacity: 0;
	-webkit-transition: opacity 1.2s ease;
	-o-transition: opacity 1.2s ease;
	transition: opacity 1.2s ease;
}
.top .second .name, .top .second .run, .top .second .textbox, .top .second .title {
	position: absolute;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
}
.top .second .run, .top .second .textbox, .top .second .title, .top .second .scroll {
	opacity: 0;
}
.top .second .name {
	display: none;
	top: 50%;
	width: 73rem;
	aspect-ratio: 67 / 45;
	overflow: hidden;
	-webkit-transition: top 1.2s ease, width 1.2s ease, -webkit-transform 1.2s ease;
	transition: top 1.2s ease, width 1.2s ease, -webkit-transform 1.2s ease;
	-o-transition: transform 1.2s ease, top 1.2s ease, width 1.2s ease;
	transition: transform 1.2s ease, top 1.2s ease, width 1.2s ease;
	transition: transform 1.2s ease, top 1.2s ease, width 1.2s ease, -webkit-transform 1.2s ease;
	-webkit-transform: translate(-50%, -50%) scale(0.6);
	-ms-transform: translate(-50%, -50%) scale(0.6);
	transform: translate(-50%, -50%) scale(0.6);
}
.top .second .run {
	display: none;
	top: 47%;
	width: 20rem;
	margin-left: -55rem;
	-webkit-transition: opacity 1.2s ease;
	-o-transition: opacity 1.2s ease;
	transition: opacity 1.2s ease;
	-webkit-transition-delay: 5s;
	-o-transition-delay: 5s;
	transition-delay: 5s;
}
@media (max-width: 995px) {
	.top .second .run {
		top: 67%;
		width: 25rem;
		margin-left: -33rem;
	}
}
@media (max-width: 767px) {
	.top .second .run {
		width: 28vw;
		top: 71%;
		margin-left: -30vw;
	}
}
.top .second .textbox {
	display: none;
	top: 45.5%;
	color: #37488b;
	font-weight: 700;
	margin-left: 58rem;
	white-space: nowrap;
	-webkit-transition: opacity 1.2s ease;
	-o-transition: opacity 1.2s ease;
	transition: opacity 1.2s ease;
	-webkit-transition-delay: 5.8s;
	-o-transition-delay: 5.8s;
	transition-delay: 5.8s;
}
@media (max-width: 995px) {
	.top .second .textbox {
		position: static;
		margin: 0;
		-webkit-transform: none;
		-ms-transform: none;
		transform: none;
	}
}
.top .second .textbox .label {
	font-size: 3.3rem;
}
@media (max-width: 995px) {
	.top .second .textbox .label {
		position: absolute;
		left: 50%;
		top: 21%;
		-webkit-transform: translateX(-50%);
		-ms-transform: translateX(-50%);
		transform: translateX(-50%);
		font-size: 4.25vw;
	}
}
@media (max-width: 767px) {
	.top .second .textbox .label {
		top: 18%;
		font-size: 6vw;
	}
}
.top .second .textbox .text {
	margin-top: 0.75em;
	font-size: 2.7rem;
	line-height: 1.65;
}
@media (max-width: 995px) {
	.top .second .textbox .text {
		position: absolute;
		left: 40%;
		top: 63%;
		font-size: 3.15vw;
	}
}
@media (max-width: 767px) {
	.top .second .textbox .text {
		left: 38%;
		top: 66%;
		font-size: 4vw;
	}
}
.top .second .title {
	left: 52.5%;
	top: 73%;
	font-size: 11.2rem;
	font-family: "Satoshi-Bold", "Noto Sans JP", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
	color: #37488b;
	white-space: nowrap;
}
@media (max-width: 995px) {
	.top .second .title {
		left: 40%;
		top: 56%;
		-webkit-transform: none;
		-ms-transform: none;
		transform: none;
		font-size: 5vw;
		line-height: 1;
	}
}
@media (max-width: 767px) {
	.top .second .title {
		left: 38%;
		top: 58%;
		font-size: 7.2vw;
	}
}
.top .second .scroll {
	display: none;
	position: absolute;
	left: 50%;
	bottom: 4rem;
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	transform: translateX(-50%);
	-webkit-transition: opacity 1.2s ease;
	-o-transition: opacity 1.2s ease;
	transition: opacity 1.2s ease;
	-webkit-transition-delay: 6.6s;
	-o-transition-delay: 6.6s;
	transition-delay: 6.6s;
}
@media (max-width: 767px) {
	.top .second .scroll {
		bottom: 10vw;
	}
}
.top .second .scroll a {
	display: block;
	width: 9.6rem;
	aspect-ratio: 1 / 1;
}
@media (max-width: 767px) {
	.top .second .scroll a {
		width: 13.5vw;
	}
}
.top .second .scroll a::before, .top .second .scroll a::after {
	content: "";
	display: block;
}
.top .second .scroll a::before {
	width: 100%;
	height: 100%;
	background: url(../img/down.svg) center/100% no-repeat;
}
.top .second .scroll a::after {
	position: absolute;
	left: 50%;
	top: 50%;
	width: 19%;
	margin-left: -9.5%;
	aspect-ratio: 1 / 1;
	background: url(../img/down_arrow.svg) center/100% no-repeat;
}
.top .second.is-active {
	opacity: 1;
}
.top .second.is-active .name {
	display: block;
	-webkit-transform: translate(-50%, -50%) scale(1);
	-ms-transform: translate(-50%, -50%) scale(1);
	transform: translate(-50%, -50%) scale(1);
}
.top .second.is-active .run {
	display: block;
}
.top .second.is-active .textbox {
	display: block;
}
.top .second.is-active .scroll {
	display: block;
}
.top .second.is-finish .name {
	top: 40%;
	width: 67rem;
}
@media (max-width: 995px) {
	.top .second.is-finish .name {
		width: 73rem;
	}
}
.top .second.is-finish .run, .top .second.is-finish .textbox, .top .second.is-finish .title, .top .second.is-finish .scroll {
	opacity: 1;
}
.top .second.is-finish .scroll a::before {
	-webkit-animation: rotate 3s linear infinite;
	animation: rotate 3s linear infinite;
}
.top .second.is-finish .scroll a::after {
	-webkit-animation: arrow 3s ease-in-out infinite;
	animation: arrow 3s ease-in-out infinite;
}

/*-----------------------------------------------------------
	common
-----------------------------------------------------------*/
.greeting, .movie, .logobox, .history {
	margin-top: 16rem;
}

.greeting .wrap, .logobox .wrap, .history .wrap {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start;
}
@media (max-width: 767px) {
	.greeting .wrap, .logobox .wrap, .history .wrap {
		display: block;
	}
}
.greeting .titlebox, .logobox .titlebox, .history .titlebox {
	position: -webkit-sticky;
	position: sticky;
	top: 10rem;
	width: 40%;
}
@media (max-width: 767px) {
	.greeting .titlebox, .logobox .titlebox, .history .titlebox {
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-align: center;
		-webkit-align-items: center;
		-ms-flex-align: center;
		align-items: center;
		-webkit-box-pack: justify;
		-webkit-justify-content: space-between;
		-ms-flex-pack: justify;
		justify-content: space-between;
		width: auto;
		position: static;
	}
}
.greeting .titlebox h2, .logobox .titlebox h2, .history .titlebox h2 {
	font-size: 3rem;
	color: #37488b;
}
@media (max-width: 767px) {
	.greeting .titlebox h2, .logobox .titlebox h2, .history .titlebox h2 {
		font-size: 4.15vw;
	}
}
.greeting .titlebox h2 span, .logobox .titlebox h2 span, .history .titlebox h2 span {
	display: block;
	margin-top: 0.5rem;
	font-family: "Satoshi-Bold", "Noto Sans JP", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
	font-size: 2.3em;
	line-height: 1.2;
}
@media (max-width: 995px) {
	.greeting .titlebox h2 span, .logobox .titlebox h2 span, .history .titlebox h2 span {
		font-size: 2em;
	}
}
@media (max-width: 767px) {
	.greeting .titlebox h2 span, .logobox .titlebox h2 span, .history .titlebox h2 span {
		font-size: 2.2em;
	}
}
.greeting .titlebox figure, .logobox .titlebox figure, .history .titlebox figure {
	width: 19rem;
	margin: 5rem 0 0 10rem;
}
@media (max-width: 767px) {
	.greeting .titlebox figure, .logobox .titlebox figure, .history .titlebox figure {
		width: 20vw;
		margin: 0;
	}
}
.greeting .content, .logobox .content, .history .content {
	width: 60%;
	font-size: 2.4rem;
}
@media (max-width: 767px) {
	.greeting .content, .logobox .content, .history .content {
		width: auto;
		margin-top: 5vw;
		font-size: 3.6vw;
	}
}
.greeting .content h3, .logobox .content h3, .history .content h3 {
	font-size: 4.2rem;
	color: #37488b;
	line-height: 1.2;
}
@media (max-width: 767px) {
	.greeting .content h3, .logobox .content h3, .history .content h3 {
		font-size: 5.8vw;
	}
}

.greeting .content {
	line-height: 1.65;
}
.greeting .content .textbox figure {
	float: right;
	width: 36%;
	margin-left: 2em;
}
@media (max-width: 767px) {
	.greeting .content .textbox figure {
		float: none;
		margin: 1.5em auto 0;
		width: 56.25vw;
	}
}
.greeting .content .name {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: end;
	-webkit-justify-content: flex-end;
	-ms-flex-pack: end;
	justify-content: flex-end;
	gap: 0 5rem;
	margin-top: 1em;
}
@media (max-width: 767px) {
	.greeting .content .name {
		display: block;
		text-align: center;
	}
}
.greeting .content .name img {
	width: 27rem;
}
@media (max-width: 767px) {
	.greeting .content .name img {
		display: block;
		margin: 0 auto;
		width: 32vw;
	}
}

@-webkit-keyframes scroll {
	from {
		-webkit-transform: translateX(0);
		transform: translateX(0);
	}
	to {
		-webkit-transform: translateX(-33.3333%);
		transform: translateX(-33.3333%);
	}
}

@keyframes scroll {
	from {
		-webkit-transform: translateX(0);
		transform: translateX(0);
	}
	to {
		-webkit-transform: translateX(-33.3333%);
		transform: translateX(-33.3333%);
	}
}
.movie {
	position: relative;
}
@media (max-width: 767px) {
	.movie {
		overflow: hidden;
	}
}
.movie video {
	width: 100%;
}
@media (max-width: 767px) {
	.movie video {
		width: 270vw;
		margin-left: -85vw;
	}
}
.movie .text {
	position: absolute;
	left: 50%;
	top: 50%;
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	font-family: "Satoshi-Bold", "Noto Sans JP", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
	font-size: 11.2rem;
	color: #fff;
	white-space: nowrap;
}
@media (max-width: 767px) {
	.movie .text {
		font-size: 15vw;
	}
	.movie .text .track {
		display: -webkit-box;
		display: -webkit-flex;
		display: -ms-flexbox;
		display: flex;
		width: -webkit-max-content;
		width: -moz-max-content;
		width: max-content;
		gap: 0 0.5em;
		-webkit-animation: scroll 15s linear infinite;
		animation: scroll 15s linear infinite;
	}
}

.logobox .content {
	line-height: 2;
}
@media (max-width: 767px) {
	.logobox .content figure {
		width: 70vw;
		margin: 0 auto 5vw;
	}
}
.logobox .content dl dt {
	margin-top: 1.5em;
	font-size: 3.4rem;
	color: #37488b;
	font-weight: 700;
}
@media (max-width: 767px) {
	.logobox .content dl dt {
		margin-top: 1.75em;
		font-size: 5vw;
		line-height: 1.25;
	}
}
.logobox .content dl dd {
	margin-top: 0.25em;
}
@media (max-width: 767px) {
	.logobox .content dl dd {
		margin-top: 0.5em;
	}
}

.history .content .videobox {
	margin-top: 1.5em;
	padding: 2rem;
	background-color: #37488b;
	border-radius: 1rem;
	line-height: 0;
}
.history .content .videobox video {
	width: 100%;
}
.history .content .more {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: end;
	-webkit-justify-content: flex-end;
	-ms-flex-pack: end;
	justify-content: flex-end;
	margin-top: 2em;
}
@media (max-width: 767px) {
	.history .content .more {
		-webkit-box-pack: center;
		-webkit-justify-content: center;
		-ms-flex-pack: center;
		justify-content: center;
	}
}
.history .content .more a {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
	gap: 1em;
	font-size: 3rem;
	color: #37488b;
	font-weight: 700;
	text-decoration: none;
}
@media (max-width: 767px) {
	.history .content .more a {
		font-size: 4.5vw;
	}
}
.history .content .more a::before {
	content: "";
	display: block;
	width: 2em;
	aspect-ratio: 1 / 1;
	background: url(../img/arrow.svg) center/100% no-repeat;
	-webkit-transition: 0.3s;
	-o-transition: 0.3s;
	transition: 0.3s;
}
@media (min-width: 1220px) {
	.history .content .more a:hover::before {
		-webkit-transform: translateX(0.5em);
		-ms-transform: translateX(0.5em);
		transform: translateX(0.5em);
	}
}



/*# sourceMappingURL=style.css.map */
