@charset "UTF-8";

:root {
	--oswald: "Oswald", "Noto Sans JP", sans-serif;
}

body {
	width: 100%;
	-webkit-text-size-adjust: 100%;
	font-size: 18px;
	line-height: 1.5em;
	font-family: "Noto Sans JP", sans-serif;
}

input, textarea, select, button {
	font-family: "Noto Sans JP", sans-serif;
	color: #707070;
}

select {
	background: #FFF;
}

.oswald {
	font-family: var(--oswald);
}

.wrap {
	width: 100%;
	max-width: 1100px;
	margin: 0 auto;
}

small {
	font-size: 0.8rem;
}

.sp, .sp1 {
	display: none !important;
}

.ovfH {
	overflow: hidden;
}

.hover {
	display: none;
	position: absolute;
}

.flex {
	display: flex;
}

.grid {
	display: grid;
}

.gtc2 {
	grid-template-columns: repeat(2, 1fr);
}

.gtc3 {
	grid-template-columns: repeat(3, 1fr);
}

.gtc4 {
	grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
	gap: 30px 5px;
}

.gtc5 {
	grid-template-columns: repeat(5, 1fr);
}

.gtcMM200 {
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
}

.fdC {
	flex-direction: column;
}

.flexNW {
	display: flex;
}

.flex.Jsb {
	justify-content: space-between;
}

.flexNW.Jsb {
	justify-content: space-between;
}

.flex.Jcn {
	justify-content: center;
}

.flex.Jsa {
	justify-content: space-around;
}

.flex.Jfe {
	justify-content: flex-end;
}

.alIfs {
	align-items: flex-start;
}

.alIfe {
	align-items: flex-end;
}

.alIcn {
	align-items: center;
}

.alIbl {
	align-items: baseline;
}

.alCfe {
	align-content: flex-end;
	margin-top: auto;
}

.alignL {
	text-align: left;
}

.alignC {
	text-align: center;
}

.alignR {
	text-align: right;
}

.mt0 {
	margin-top: 0px;
}

.mt10, .umt10>* {
	margin-top: 10px;
}

.mt20, .umt20>* {
	margin-top: 20px;
}

.mt30, .umt30>* {
	margin-top: 30px;
}

.mt40, .umt40>* {
	margin-top: 40px;
}

.mt50, .umt50>* {
	margin-top: 50px;
}

.mt60 {
	margin-top: 60px;
}

.mt70 {
	margin-top: 70px;
}

.mt80 {
	margin-top: 80px;
}

.mt90 {
	margin-top: 90px;
}

.mt100 {
	margin-top: 100px;
}

.mt110 {
	margin-top: 110px;
}

.mt120 {
	margin-top: 120px;
}

.mt150 {
	margin-top: 150px;
}

.mb10 {
	margin-bottom: 10px;
}

.mb20 {
	margin-bottom: 20px;
}

.mb30 {
	margin-bottom: 30px;
}

.mb40 {
	margin-bottom: 40px;
}

.mb50 {
	margin-bottom: 50px;
}

.mb60 {
	margin-bottom: 60px;
}

.mb70 {
	margin-bottom: 70px;
}

.mb80 {
	margin-bottom: 80px;
}

.mb90 {
	margin-bottom: 90px;
}

.mb100 {
	margin-bottom: 100px;
}

.mb110 {
	margin-bottom: 110px;
}

.mb120 {
	margin-bottom: 120px;
}

.mb150 {
	margin-bottom: 150px;
}

.mr1p, .umr1p>* {
	margin-right: 1%;
}

.mr10, .umr10>* {
	margin-right: 10px;
}

.mr20, .umr20>* {
	margin-right: 20px;
}

.mr30, .umr30>* {
	margin-right: 30px;
}

.mr40, .umr40>* {
	margin-right: 40px;
}

.mr50, .umr50>* {
	margin-right: 50px;
}

.mlAt {
	margin-left: auto;
}

.gp10 {
	gap: 10px;
}

.gp20 {
	gap: 20px;
}

.gp30 {
	gap: 30px;
}

.gp30 {
	gap: 30px;
}

.gp40 {
	gap: 40px;
}

.gp50 {
	gap: 50px;
}

.gp60 {
	gap: 60px;
}

.gpR10 {
	row-gap: 10px;
}

.gpR20 {
	row-gap: 20px;
}

.gpR30 {
	row-gap: 30px;
}

.gpR40 {
	row-gap: 40px;
}

.gpR50 {
	row-gap: 50px;
}

.lh1 {
	line-height: 2.5;
}

.fCl01 {
	color: #13B7C2;
}

iframe {
	width: 100%;
}

.fontL {
	font-size: 1.8em;
	font-weight: bold;
	line-height: normal;
}

.flex.fwrap {
	flex-wrap: wrap;
}

.Jsb.uw33.fwrap::after {
	content: "";
	display: block;
	width: 32%;
}

.Jsb.uw25.fwrap::before {
	content: "";
	width: 23%;
	order: 1;
}

.Jsb.uw25.fwrap::after {
	content: "";
	width: 23%;
}

.w30, .uw30>* {
	width: 29%;
}

.w33, .uw33>* {
	width: 32%;
}

.w50, .uw50>* {
	width: 49%;
}

.w20, .uw20>* {
	width: 19%;
}

.w25, .uw25>* {
	width: 23%;
}

.w40, .uw40>* {
	width: 39%;
}

.w60, .uw60>* {
	width: 59%;
}

.w70, .uw70>* {
	width: 69%;
}

.w75, .uw75>* {
	width: 75%;
}

.w100 {
	width: 100%;
}

.wh130 {
	width: 230px;
	max-width: 100%;
	height: 230px;
	display: flex;
	justify-content: center;
	align-items: center;
	overflow: hidden;
	margin: auto;
}

.lead {
	font-size: 1.1em;
	line-height: 1.8;
	font-weight: bold;
}

.red {
	color: #CE0000;
}

.orange {
	color: #E86D21;
}

.icored {
	background: #AD0C0C;
	color: #FFF;
	display: inline-block;
	font-size: 0.75em;
	margin-right: 30px;
	padding: 5px 10px;
}

.icoblue {
	background: #1F4893;
	color: #FFF;
	display: inline-block;
	font-size: 0.75em;
	margin-right: 30px;
	padding: 5px 10px;
}

main {
	text-align: left;
}

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

img.imgWaH100, .imgWaH100 img {
	max-width: inherit;
	width: auto;
	height: 100%;
}

ul {
	list-style: none;
}

main ul {
	list-style: disc;
	padding-left: 4em;
}

main ol {
	counter-reset: item;
	list-style-type: decimal;
	padding-left: 4em;
	margin-left: 0;
	margin: 0;
}

a:hover {
	transition: 0.3s;
	text-decoration: underline;
}

.tableScroll {
	width: 100%;
	overflow-x: scroll;
	scrollbar-width: none;
	-ms-overflow-style: none;
}

.tableScroll::-webkit-scrollbar {
	display: none;
}

@media (max-width: 768px) {
	.tableScroll table {
		width: 100%;
		min-width: 500px;
	}
}

table {
	border-collapse: collapse;
	width: 100%;
	margin-top: 0px !important;
	box-sizing: border-box;
}

table.tableScroll {
	height: 440px;
	overflow-y: scroll;
	border-bottom: solid 1px #989898;
}

table tr {
	width: 100%;
}

table .stickyWrap {
	border-top: 1px solid #989898;
	max-height: 424px;
	overflow-y: scroll;
}

table th {
	color: #191d6a;
	padding: 10px;
	border-bottom: solid 1px #191d6a;
}

table td {
	padding: 10px;
	border-bottom: solid 1px #191d6a;
}

table td a {
	text-decoration: underline;
}

table td a:hover {
	text-decoration: none;
	opacity: 1;
}

.btn01 {
	display: inline-block;
	width: 315px;
	max-width: 100%;
	text-align: center;
	padding: 20px;
	color: #FFF;
	border: solid 1px #FFF;
	text-align: center;
	line-height: normal;
	text-decoration: none;
	box-sizing: border-box;
	overflow: hidden;
	position: relative;
	z-index: 1;
}

.btn01:hover {
	text-decoration: none;
	color: #191d6a !important;
	opacity: 1;
}

.btn01::before {
	content: "";
	width: 0.5em;
	height: 0.5em;
	display: block;
	border-top: solid 3px #FFF;
	border-right: solid 3px #FFF;
	rotate: 45deg;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 20px;
	margin: auto;
}

.btn01::after {
	background: #FFF;
	position: absolute;
	top: 0;
	left: 0;
	content: '';
	width: 100%;
	height: 100%;
	transform: scale(0, 1);
	transform-origin: left top;
	transition: 0.2s cubic-bezier(0.45, 0, 0.55, 1);
	z-index: -1;
}

.btn01:hover::after {
	transform: scale(1, 1);
}

.btn02 {
	display: block;
	width: 535px;
	max-width: 100%;
	text-align: center;
	padding: 50px 20px;
	color: #191d6a;
	background: #FFF url(../img/icoChamp.svg) no-repeat 30px center;
	background-size: 70px;
	text-align: center;
	line-height: normal;
	text-decoration: none;
	box-sizing: border-box;
	font-family: var(--oswald);
	font-size: 2rem;
	position: relative;
	overflow: hidden;
	z-index: 1;
}

.btn02.type02 {
	background: #FFF url(../img/icoMail.svg) no-repeat 40px center;
	background-size: 80px;
}

.btn02::before {
	content: "";
	width: 20px;
	height: 20px;
	display: block;
	border-top: solid 4px #191d6a;
	border-right: solid 4px #191d6a;
	rotate: 45deg;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 25px;
	margin: auto;
}

.btn02::after {
	background: #191d6a;
	position: absolute;
	top: 0;
	left: 0;
	content: '';
	width: 100%;
	height: 100%;
	transform: scale(0, 1);
	transform-origin: left top;
	transition: 0.2s cubic-bezier(0.45, 0, 0.55, 1);
	z-index: -1;
}

.btn02:hover {
	text-decoration: none;
	opacity: 1;
	color: #FFF;
}

.btn02:hover::after {
	transform: scale(1, 1);
}

.tab .tabcont {
	display: none;
}

.tab .tabcont.active {
	display: block;
}

header {
	width: 100%;
	position: absolute;
}

header.fixed {
	position: fixed;
	z-index: 100;
	background: #FFF;
}

header.fixed .hLogo {
	display: none;
}

header.wrap {
	max-width: 1300px;
	box-sizing: border-box;
	display: flex;
	justify-content: space-between;
}

header .hLogo {
	padding: 35px 35px;
	background: #FFF;
}

header nav {
	background: #FFF;
	padding: 10px 30px;
	margin-left: auto;
	height: 50px;
	box-sizing: border-box;
	flex: 1;
}

header nav a {
	color: #191d6a;
	font-family: var(--oswald);
	font-weight: 500;
}

header nav a:hover {
	text-decoration: none;
	opacity: 1;
	color: #13B7C2;
}

header nav .ico {
	display: none;
	margin-top: 6vh;
}

header .hamburger {
	display: none;
}

.icoList {
	position: fixed;
	top: 70px;
	right: 10px;
	z-index: 100;
	display: flex;
	flex-direction: column;
	gap: 10px;
}

footer {
	background: #FFF;
	color: #1e2b59;
	padding: 50px 0 20px;
	font-family: var(--oswald);
}

footer .fBnr {
	font-size: 1.3rem;
	display: flex;
	flex-direction: column;
	gap: 50px;
}

footer .fBnr dd {
	display: flex;
	justify-content: center;
	gap: 15px;
	margin-top: 20px;
	flex-wrap: wrap;
}

footer .fBnr dd>* {
	max-width: 100%;
}

footer .fBnr dd.sz01>* {
	width: 320px;
}

footer .fBnr dd.sz02>* {
	width: 220px;
}

@media (max-width: 768px) {
	footer .fBnr dd.sz02>* {
		width: 165px;
	}
}

footer .fBnr dd.sz03>* {
	width: 182px;
}

@media (max-width: 768px) {
	footer .fBnr dd.sz03>* {
		width: 165px;
	}
}

footer .fBnr dd.sz04>* {
	width: 144px;
}

@media (max-width: 768px) {
	footer .fBnr dd.sz04>* {
		width: 105px;
	}
}

footer .fBnr dd.sz05>* {
	width: 100px;
}

@media (max-width: 768px) {
	footer .fBnr dd.sz05>* {
		width: 80px;
	}
}

footer .bnrBt {
	width: 240px;
}

footer .fLogo {
	max-width: 150px;
	margin-bottom: 50px;
}

footer nav {
	background: #e8e8f0;
	padding: 30px 0;
}

footer nav ul li {
	padding: 0 0.7em;
	position: relative;
	line-height: normal;
	font-size: 0.8em;
}

footer nav ul li a {
	color: #191d6a;
}

footer nav ul li a:hover {
	opacity: 1;
	text-decoration: none;
	color: #13B7C2;
}

footer .copy {
	font-size: 0.75em;
	margin-top: 35px;
}

footer .copy.mt0 {
	margin-top: 0;
}

.pageTop {
	height: 170px;
	width: 80px;
	background: url(../img/pagetop.png) no-repeat center center;
	margin-top: 30px;
	cursor: pointer;
	position: fixed;
	z-index: 4;
	right: 20px;
	bottom: 30px;
}

.newsList dl {
	display: grid;
	grid-template-columns: 100px auto;
	gap: 20px 20px;
}

@media screen and (max-width: 1025px) {
	.wrap {
		width: 95%;
	}

	header .flex {
		padding-right: 0;
	}

	header .hLogo {
		width: 100px;
		padding: 20px;
	}

	header .hNav ul {
		font-size: 0.9em;
		gap: 10px;
	}
}

@media screen and (max-width: 768px) {
	.wrap {
		width: 95%;
		max-width: 100%;
	}

	.smt0 {
		margin-top: 0;
	}

	.sidebnr {
		display: none;
	}

	.sp {
		display: block !important;
	}

	.pc {
		display: none !important;
	}

	.flex {
		flex-wrap: wrap;
		justify-content: center;
	}

	body {
		font-size: 14px;
	}

	.icoList {
		display: none;
	}

	.btn01 {
		max-width: 250px;
		padding: 15px;
	}

	.btn02 {
		padding: 7vw 5vw;
		background: #FFF url(../img/icoChamp.svg) no-repeat 7vw center;
		background-size: 10vw;
		font-size: 1.6rem;
		line-height: normal;
		box-sizing: border-box;
		width: 90vw;
	}

	.btn02.type02 {
		background: #FFF url(../img/icoMail.svg) no-repeat 6vw center;
		background-size: 12vw;
	}

	.btn02::before {
		content: "";
		width: 2vw;
		height: 2vw;
		right: 6vw;
		border-width: 5px;
		margin: auto;
	}

	.tab .tabmenu {
		justify-content: center;
	}

	.tab .tabmenu li a {
		width: 45vw;
	}

	.newsList dl {
		display: block;
	}

	.newsList dl dt {
		margin-bottom: 5px;
	}

	.newsList dl dd {
		margin-bottom: 20px;
	}

	header {
		display: block;
		margin-bottom: 0;
		padding: 0;
		background: none !important;
	}

	header .hLogo {
		position: relative;
		z-index: 300;
	}

	header.fixed {
		width: auto;
		margin-left: auto;
		position: fixed;
		right: 10px;
		top: 10px;
	}

	header.active .hLogo {
		position: fixed;
		display: block;
		top: 0;
		left: 0;
	}

	header.flex {
		padding-right: 0;
	}

	header nav {
		width: 100%;
		position: fixed;
		background: #191d6a;
		height: 100vh;
		top: 0;
		left: 0;
		margin: 0;
		z-index: 200;
		padding: 10vh 3vw;
		box-sizing: border-box;
		display: none !important;
		text-align: center;
		height: 100vh;
		overflow-y: scroll;
	}

	header nav.active {
		display: block !important;
	}

	header nav .flex {
		border: 0;
		display: block;
		margin-bottom: 20px;
		font-size: 1em;
	}

	header nav .ico.flex {
		display: flex;
	}

	header nav li {
		padding: 10px 0;
		display: block;
		text-align: center;
		color: #FFF;
		margin-top: 2vh;
	}

	header nav li a {
		color: #FFF !important;
		font-size: 1.5em;
	}

	header .hamburger {
		display: block;
		position: absolute;
		top: 10px;
		right: 10px;
		z-index: 9999;
		width: 42px;
		height: 42px;
		cursor: pointer;
		text-align: center;
		background: #191d6a;
		border-radius: 1000px;
		margin-left: auto;
	}

	header .hamburger span {
		display: block;
		position: absolute;
		width: 23px;
		height: 3px;
		left: 9px;
		background: #FFF;
		-webkit-transition: 0.3s ease-in-out;
		-moz-transition: 0.3s ease-in-out;
		transition: 0.3s ease-in-out;
	}

	header .hamburger span:nth-child(1) {
		top: 15px;
	}

	header .hamburger span:nth-child(2) {
		top: 23px;
	}

	header .hamburger.active {
		background: #474a88;
	}

	header .hamburger.active span:nth-child(1) {
		top: 19px;
		left: 9px;
		background: #fff;
		-webkit-transform: rotate(-45deg);
		-moz-transform: rotate(-45deg);
		transform: rotate(-45deg);
	}

	header .hamburger.active span:nth-child(2) {
		top: 19px;
		background: #fff;
		-webkit-transform: rotate(45deg);
		-moz-transform: rotate(45deg);
		transform: rotate(45deg);
	}

	header .hamburger p span.open, header .hamburger.active p span.close {
		display: block;
		position: absolute;
		bottom: -10px;
		left: 0;
		font-size: 10px;
		right: 0;
		margin: 0 auto;
		text-align: center;
		color: #FFF;
	}

	header .hamburger.active p span.close {
		color: #FFF;
	}

	header .hamburger.active p span.open, header .hamburger p span.close {
		display: none;
	}

	footer .flex {
		flex-wrap: wrap;
	}

	footer .fNav ul {
		gap: 10px 0;
	}

	footer .bnrBt {
		width: 175px;
	}

	.pageTop {
		background-size: 100%;
		width: 13vw;
		height: 27vw;
	}

	.sJcn {
		justify-content: center;
	}

	.w30, .uw30>* {
		width: 100%;
	}

	.w33, .uw33>* {
		width: 100%;
	}

	.w50, .uw50>* {
		width: 100%;
	}

	.w25, .uw25>* {
		width: 100%;
	}

	.w40, .uw40>* {
		width: 100%;
	}

	.w60, .uw60>* {
		width: 100%;
	}

	.w70, .uw70>* {
		width: 100%;
	}

	.w75, .uw75>* {
		width: 100%;
	}

	.sw100 {
		width: 100%;
	}

	.suw33>* {
		width: 33%;
	}

	.suw50>* {
		width: 48%;
	}

	.smt10, .sumt10>* {
		margin-top: 10px;
	}

	.smt20, .sumt20>* {
		margin-top: 20px;
	}

	.smt30, .sumt30>* {
		margin-top: 30px;
	}

	.smt40 {
		margin-top: 40px;
	}

	.smt50 {
		margin-top: 50px;
	}

	.smt90 {
		margin-top: 90px;
	}

	.smA {
		margin-left: auto;
		margin-right: auto;
	}

	.scrollBox {
		width: 100%;
		box-sizing: border-box;
		overflow-x: auto;
	}

	.scrollBox>* {
		min-width: 800px;
		table-layout: fixed;
	}

	.scrollBox table th, .scrollBox table td {
		display: table-cell;
		width: 10%;
	}

	.scrollBox table td {
		border-top: 0;
	}

	.tablepc {
		display: none !important;
	}

	.fw25>*, .fw33>* {
		width: 49%;
	}

	.fw50>* {
		width: 100%;
	}

	.flex.wid475 div {
		width: 100%;
		margin-bottom: 20px;
	}

	.flex.sJcn {
		display: flex;
		justify-content: center;
		flex-wrap: wrap;
	}

	.flex.sJfs {
		justify-content: flex-start;
	}

	.flex.sJcn>* {
		margin-left: auto;
		margin-right: auto;
	}

	.flex.flexNW {
		flex-wrap: nowrap;
	}
}