@charset "UTF-8";

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,100..900;1,100..900&display=swap');

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p,
a, address,
em, img,
small, strong, sub, sup,
b, u, i,
ul, ol, li, dl, dt, dd,
form, label,
table, caption, tbody, tfoot, thead, tr, th, td,
article, section, aside, figure, figcaption,
header, footer, nav, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}

article, section, aside, figure, figcaption, header, footer, nav { display: block; }
body { line-height: 1; }
ul, ol { list-style: none; }
table { border-collapse: collapse; border-spacing: 0; }
strong { font-weight:bold;}

.clearfix::after {
	content: "";
	clear: both;
	display: table;
}

/*================================================

　全体

=================================================*/
*{ -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }
*::before,
*::after { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }

html { font-size: 62.5%; }
body { 
	position: relative;
	min-height: 100vh;
	color: #000;
	text-align: left;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 600;
	font-feature-settings: "palt" 1;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
a, a:link, a:focus, a:visited {
	color: #000;
	text-decoration: none;
	opacity: 1;
	transition: all 0.5s ease;
}
a:hover {
	opacity: 0.3;
}

@media screen and (min-width: 768px) {
	a[href^="tel:"]{
		pointer-events: none;
	}
}

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

/* Avoid Chrome to see Safari hack */
@supports (-webkit-touch-callout: none) {
	body {
		/* The hack for Safari */
		height: -webkit-fill-available;
	}
}

strong {
	color: #00ACD2;
}

/*================================================

　レイアウト共通

=================================================*/
.content__wrap {
	overflow: hidden;
	margin: 0;
	padding: 0;
}

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

	.pc-new-line02 {
		display: block;
	}

}

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

	.content__wrap {
		padding: 0;
	}
	.pc-new-line02 {
		display: none;
	}

}

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

	.pc-new-line {
		display: block;
	}
	.sp-new-line {
		display: none;
	}

}

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

	.pc-new-line {
		display: none;
	}
	.no_scroll {
		overflow: hidden;
	}

}


/*================================================

　title

=================================================*/
.title {
	position: relative;
	max-width: 836px;
	margin: auto;
	color: #1D3A7A;
	text-align: center;
	font-size: 3.1rem;
}
.title::after {
	position: absolute;
	content: '';
	top: calc(50% + 1px);
	left: 0;
	width: 100%;
	height: 1px;
	background-color: #00ACD2;
	z-index: 1;
}
.title span {
	position: relative;
	padding: 0 20px;
	background-color: #FFF;
	z-index: 10;
}

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

	.title {
		max-width: 836px;
		font-size: clamp(1.8rem, (100vw - 768px) * 13 / 511 + 18px, 3.1rem);
	}

}

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

	.title {
		position: relative;
		width: 89.6vw;
		max-width: 672px;
		font-size: 3.1rem;
		font-size: clamp(1.4rem, (100vw - 375px) * 14 / 393 + 14px, 2.8rem);
	}

}

/*================================================

　header

=================================================*/
.header__wrap {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	margin: 0 auto;
	z-index: 99999;
	transition: all 0.5s ease;
}
.header__wrap__inner {
	position: relative;
	transition: all 0.5s ease;
}
.header__wrap__inner.transform {
	height: 100px;
	background-color: rgba(255,255,255,0.9);
}
.header__wrap__inner .logo {
	position: absolute;
	top: 4.6875vw;
	left: 7.8125vw;
	width: 20.78125vw;
	transition: all 0.5s ease;
}
.header__wrap__inner .logo img {
	width: 100%;
}
.header__wrap__inner.transform .logo {
	position: absolute;
	top: 25px;
	left: 30px;
	width: 266px;
}

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

	.header__wrap__inner {
		height: 13.33333333vw;
		padding: 0;
	}
	.header__wrap__inner.transform {
		height: 12vw;
	}
	.header__wrap__inner .logo {
		top: 4vw;
		left: 4.26666666vw;
		width: 28.2666666vw;
	}
	.header__wrap__inner.transform .logo {
		position: absolute;
		top: 3.26666666vw;
		left: 4vw;
		width: 28.2666666vw;
	}

}

/*　ナビメニュー
=================================================*/
.header__wrap__inner .navlist {
	position: fixed;
	top: 0;
	left: 100%;
	width: 375px;
	height: 100%;
	padding: 25px 30px 0;
	background: rgba(0,133,192,0.9);
	transform: translate(0, 0);
	transition: 0.5s ease-in-out;
}
.header__wrap__inner .navlist ul {
	display: flex;
	justify-content: flex-start;
	flex-direction: column;
	align-items: center;
	width: 100%;
	height: 100%;
	margin: 30px 0 0;
	padding: 0;
	z-index: 999999;
}
.header__wrap__inner .navlist ul li {
	position: relative;
	display: block;
	width: 100%;
	margin-right: 0;
	padding: 30px 0 10px;
	font-size: 2rem;
	line-height: 1;
	border-right: none;
	border-bottom: 1px solid #FFF;
}
.header__wrap__inner .navlist ul li a {
	color: #FFF;
}

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

	.header__wrap__inner .navlist ul li {
		font-size: clamp(1.2rem, (100vw - 768px) * 8 / 511 + 12px, 2rem);
	}

}

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

	.header__wrap__inner .navlist {
		width: 100%;
		padding: 35px 30px 0;
	}
	.header__wrap__inner .navlist ul {
		margin: 0;
	}
	.header__wrap__inner .navlist ul li {
		font-size: clamp(1.2rem, (100vw - 375px) * 12 / 393 + 12px, 2.4rem);
	}

}

/*　ハンバーガー
=================================================*/
.menu-btn {
	visibility: hidden;
	position: absolute;
	top: 40px;
	right: 25px;
	opacity: 0;
	pointer-events: none;
	transition: all 0.5s ease;
	z-index: 10;
}
.header__wrap__inner.transform .menu-btn,
.finish .header__wrap__inner .menu-btn {
	visibility: visible;
	opacity: 1;
	pointer-events: auto;
}
.menu-btn .toggle {
	display: block;
	position: relative;
	width: 42px;
	height: 24px;
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
}
.menu-hamburger,
.menu-hamburger::before,
.menu-hamburger::after {
	display: block;
	position: relative;
	width: 100%;
	height: 1px;
	background-color: #000;
	transition: 0.2s ease-out;
}
.change .menu-hamburger,
.change .menu-hamburger::before,
.change .menu-hamburger::after {
	background-color: #000;
}
.menu-hamburger::before,
.menu-hamburger::after {
	position: absolute;
	content: '';
	top: -5px;
	left: 0;
}
.menu-hamburger::after {
	top: 5px;
}
.open .menu-hamburger {
	background-color: transparent;
}
.open .menu-hamburger::before,
.open .menu-hamburger::after {
	top: 0;
	background-color: #FFF;
}
.open .menu-hamburger::before {
	transform: rotate(45deg);
}
.open .menu-hamburger::after {
	transform: rotate(-45deg);
}
.menu-btn.open + .navlist {
	transform: translateX(-100%);
}

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

	.menu-btn {
		top: 50%;
		right: 4vw;
		opacity: 0;
		transform: translateY(-50%);
	}
	.menu-btn .toggle {
		min-width: 32px;
		width: 5.6vw;
		min-height: 24px;
		height: 3.2vw;
	}
	.menu-hamburger::before,
	.menu-hamburger::after {
		top: -.96666666vw;
	}
	.menu-hamburger::after {
		top: 0.96666666vw;
	}

}


/*================================================

　mainvisual

=================================================*/
.mainvisual {
	position: relative;
	height:  60.703125vw;
	width: 100%;
	padding: 0 7.8125vw;
	background: url("../images/fv/mainvisual_img_pc_01.jpg") center center / 100% auto no-repeat;
}
.mainvisual__content {
	position: relative;
}
.mainvisual__content h1 {
	position: absolute;
	top: 14.921875vw;
	width: 46.328125vw;
	filter:
		drop-shadow(0 0 0.390625vw rgba(255, 255, 255, 1))
		drop-shadow(0 0 0.78125vw rgba(255, 255, 255, 1))
		drop-shadow(0 0 1.171875vw rgba(255, 255, 255, 1))
		drop-shadow(0 0 1.5625vw rgba(255, 255, 255, 1));
	z-index: 10;
}
.mainvisual__content h1 img {
	width: 100%;
	height: 100%;
}
.mainvisual__content h2 {
	position: absolute;
	top: 25.46875vw;
	left: -7.8125vw;
	width: 61.484375vw;
}
.mainvisual__content h2 img {
	width: 100%;
	height: 100%;
}
.mainvisual__content h3 {
	position: absolute;
	top: 44.921875vw;
	left: 0.3125vw;
	width: 49.5vw;
	height: 2.5vw;
}
.mainvisual__content h3 span {
	position: absolute;
	top: 0;
	left: 0;
	width: 49.5vw;
	height: 2.5vw;
	filter:
		drop-shadow(0 0 0.15625vw rgba(0, 143, 210, 1))
		drop-shadow(0 0 0.533333333vw rgba(0, 143, 210, 1))
		drop-shadow(0 0 0.625vw rgba(0, 143, 210, 1))
		drop-shadow(0 0 0.78125vw rgba(0, 143, 210, 0.5));
	mix-blend-mode: multiply;
}
.mainvisual__content h3 img {
	width: 100%;
	height: 100%;
}
.mainvisual__content ul {
	display: flex;
	flex-wrap: wrap;
	position: absolute;
	top: 33.203125vw;
	left: 52.03125vw;
	width: 32.5vw;
}
.mainvisual__content ul li {
	width: 8.75vw;
	margin-right:0.46875vw;
}
.mainvisual__content ul li img {
	width: 100%;
}
.mainvisual__content ul li:last-child {
	margin-right:0;
}
.mainvisual__content ul li:nth-of-type(4) {
	margin-left: 5.15625vw;
}
.mainvisual__content .medal {
	position: absolute;
	top: 6.015625vw;
	left: 47.03125vw;
	width: 16.640625vw;
	z-index: 11;
}
.mainvisual__content .medal img {
	width: 100%;
}

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

	.mainvisual {
		height:  149.066666vw;
		padding: 0;
		background: url("../images/fv/mainvisual_img_sp_01.jpg") center center / 100% auto no-repeat;
	}
	.mainvisual__content h1 {
		width: 64.6666666vw;
		top: 19.2vw;
		left: 4.93333333vw;
		filter:
			drop-shadow(0 0 0.666666666vw rgba(255, 255, 255, 1))
			drop-shadow(0 0 1.33333333vw rgba(255, 255, 255, 1))
			drop-shadow(0 0 2.66666666vw rgba(255, 255, 255, 1))
			drop-shadow(0 0 2.66666666vw rgba(255, 255, 255, 1));
	}
	.mainvisual__content h2 {
		top: 39.6vw;
		left: 0;
		width: 57.8666666vw;
		z-index: 10;
	}
	.mainvisual__content h3 {
		top: 61.3333333vw;
		left: 15.3333333vw;
		width: 74.4vw;
		height: 3.73333333vw;
	}
	.mainvisual__content h3 span {
		width: 74.4vw;
		height: 3.73333333vw;
		filter:
			drop-shadow(0 0 0.260416667vw rgba(0, 143, 210, 1))
			drop-shadow(0 0 0.520833333vw rgba(0, 143, 210, 1))
			drop-shadow(0 0 1.04166666vw rgba(0, 143, 210, 1))
			drop-shadow(0 0 1.30208333vw rgba(0, 143, 210, 0.5));
		mix-blend-mode: multiply;
	}
	.mainvisual__content ul {
		top: 70.6666666vw;
		left: 8.13333333vw;
		width: 84.1333333vw;
	}
	.mainvisual__content ul li {
		width: 22.6666666vw;
		margin-right: 1.2vw;
	}
	.mainvisual__content ul li img {
		width: 100%;
	}
	.mainvisual__content ul li:last-child {
		margin-right:0;
	}
	.mainvisual__content ul li:nth-of-type(4) {
		margin-left: 13.6vw;
	}
	.mainvisual__content .medal {
		position: absolute;
		width: 24.1333333vw;
		top: 4.53333333vw;
		left: auto;
		right: 4.26666666vw;
	}

}

/*================================================

　info

=================================================*/
.info {
	width: 100%;
	margin: -94px auto 0;
	padding: 0;
}
.info__content {
	position: relative;
	margin: 0;
	padding: 0;
}
.info-card {
	position: relative;
	display: flex;
	justify-content: space-between;
	align-items: center;
	max-width: 1080px;
	margin: auto;
}
.info-card::after {
	position: absolute;
	content: '';
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: #FFF;
	border-radius: 20px;
	filter:
		drop-shadow(1px 1px 6px rgba(18, 34, 127, 0.3));
	mix-blend-mode: multiply;
	z-index: 1;
}
.info-card ul {
	position: relative;
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: calc(100% / 2);
	height: 170px;
	margin: auto;
	padding: 9px 0;
	background-color: #FFF;
	border-top-left-radius: 20px; 
	border-bottom-left-radius: 20px;
	z-index: 10;
}
.info-card ul:nth-of-type(2) {
	border-top-left-radius: 0; 
	border-bottom-left-radius: 0;
	border-top-right-radius: 20px; 
	border-bottom-right-radius: 20px;
}
.info-card ul li {
	display: flex;
	justify-content: flex-end;
	flex-direction: row-reverse;
	align-items: center;
	width: calc(100% / 2);
	height: 100%;
	margin: auto;
	padding: 0 0 0 20px;
	color: #1D3A7A;
	font-size: 2.4rem;
	font-weight: 600;
	line-height: 1.3;
	border-left: 1px solid #1D3A7A;
}
.info-card ul:nth-of-type(1) li:first-child {
	padding: 0 0 0 25px;
	border-left: none;
}
.info-card ul:nth-of-type(2) li:last-child {
	padding: 0 0 0 15px;
}
.info-card ul li figure {
	margin-right: 20px;
}
.info-card ul:nth-of-type(2) li:last-child figure {
	margin-right: 10px;
}

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

	.info {
		margin: -7.34949179vw auto 0;
	}
	.info__content {
		padding: 0 7.81860829vw;
	}
	.info-card::after {
		border-radius: 1.56372166vw;
		filter:
			drop-shadow(1px 1px 6px rgba(18, 34, 127, 0.3));
	}
	.info-card ul {
		height: 13.2916341vw;
		padding: 0.703674746vw 0;
		border-top-left-radius: 1.56372166vw;
		border-bottom-left-radius: 1.56372166vw;
	}
	.info-card ul:nth-of-type(2) {
		border-top-right-radius: 1.56372166vw;
		border-bottom-right-radius: 1.56372166vw;
	}
	.info-card ul li {
		padding: 0 0 0 1.56372166vw;
		font-size: 2.4rem;
		font-size: clamp(1.4rem, (100vw - 768px) * 10 / 511 + 14px, 2.4rem);
	}
	.info-card ul:nth-of-type(1) li:first-child {
		padding: 0 0 0 1.95465207vw;
	}
	.info-card ul:nth-of-type(2) li:last-child {
		padding: 0 0 0 1.17279124vw;
	}
	.info-card ul li figure {
		margin-right: 1.56372166vw;
	}
	.info-card ul:nth-of-type(2) li:last-child figure {
		margin-right: 0.781860829vw;
	}
	.info-card ul li:nth-of-type(1) figure img {
		width: 3.98749023vw;
	}
	.info-card ul li:nth-of-type(2) figure img {
		width: 3.2056294vw;
	}
	.info-card ul:nth-of-type(2) li:nth-of-type(1) figure img {
		width: 5.78577013vw;
	}
	.info-card ul:nth-of-type(2) li:nth-of-type(2) figure img {
		width: 4.69116497vw;
	}
	
}

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

	.info {
		margin: -28vw auto 13.3333333vw;
	}
	.info__content {
	}
	.info-card {
		flex-wrap: wrap;
		width: 77.6vw;
		max-width: 582px;
	}
	.info-card::after {
		display: none;
	}
	.info-card ul {
		width: 100%;
		height: 10.6666666vw;
		padding: 0.933333333vw 0;
		border-radius: 1.6vw;
	}
	.info-card ul::after {
		position: absolute;
		content: '';
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background-color: #FFF;
		border-radius: 1.6vw;
		filter:
			drop-shadow(0.5px 0.5px 0.4666666666vw rgba(18, 34, 127, 0.3));
		mix-blend-mode: multiply;
		z-index: -1;
	}
	.info-card ul:nth-of-type(2) {
		border-radius: 1.6vw;
	}
	.info-card ul li {
		padding: 0 0 0 2vw;
		font-size: 2.2rem;
		font-size: clamp(1.1rem, (100vw - 375px) * 11 / 393 + 11px, 2.2rem);
		line-height: 1.2;
	}
	.info-card ul li:first-child {
		padding: 0 0 0 2vw;
		border-left: none;
	}
	.info-card ul:nth-of-type(1) li:first-child {
		padding: 0 0 0 2vw;
	}
	.info-card ul:nth-of-type(2) li:last-child {
		padding: 0 0 0 2vw;
	}
	.info-card ul li figure {
		width: 5.33333333vw;
		margin-right: 1.33333333vw;
		text-align: center;
	}
	.info-card ul:nth-of-type(2) li:last-child figure {
		margin-right: 1.33333333vw;
	}
	.info-card ul li:nth-of-type(1) figure img {
		width: 4.66666666vw;
	}
	.info-card ul li:nth-of-type(2) figure img {
		width: 3.73333333vw;
	}
	.info-card ul:nth-of-type(2) li:nth-of-type(1) figure img {
		width: 6.53333333vw;
	}
	.info-card ul:nth-of-type(2) li:nth-of-type(2) figure img {
		width: 5.33333333vw;
	}

}


/*================================================

　フッター

=================================================*/
footer {
	position: relative;
	margin: 0;
	padding: 0;
}
.footer__content {
	display: flex;
	justify-content: center;
	align-items: center;
	margin: auto;
	padding: 20px 0;
	background-color: #1D3A7A;
}
#copy {
	color: #FFF;
	text-align: center;
	font-size: clamp(1.5rem, (100vw - 1079px) * 3 / 320 + 15px, 1.8rem);
}
#copy p {
	margin: 0 0 5px;
}

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

}

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

	.footer__content {
		padding: 2vw 0;
	}
	#copy {
		color: #FFF;
		text-align: center;
		font-size: clamp(1rem, (100vw - 393px) * 2 / 320 + 10px, 1.2rem);
	}

}

/*================================================

　表示　関連

=================================================*/

.bgappearTrigger,
.fadeUpTrigger {
	opacity: 0;
	transition: 0.5s;
}
.delay_01 { transition-delay: 0.3s; }
