@charset "utf-8";
@import url('reset.css');
@import url('general.css');
@import url(https://fonts.googleapis.com/earlyaccess/notosansjp.css);
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans:ital,wght@0,400;0,700;1,400;1,700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,100..1000;1,9..40,100..1000&display=swap');
@import url(https://fonts.googleapis.com/icon?family=Material+Icons);
@import url(https://fonts.googleapis.com/icon?family=Material+Icons+Outlined);

* {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
html {
	font-size: 62.5%;
}
body {
	width:100%;
	font-size: 10px;
	font-size: 1.0rem;
	line-height: 1.8;
	color:#222;
	font-family:'DM Sans', "Noto Sans JP", YuGothic, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif, "游ゴシック", "ヒラギノ角ゴ ProN W3", "メイリオ";
	-webkit-text-size-adjust:100%;
	background-color:#F5F9FC;
	overflow:hidden;
}

h1,h2,h3,h4 {
	margin:0;
}
p {
	font-size:160%;
	margin:1em 0;
}
img {
	display:block;
	max-width:100%;
	height:auto;
	margin:0;
	padding:0;
}
ul {
	list-style-type:none;
}
strong {
	font-weight:bold;
}

a,a:visited,a:hover {
	color:#0E7CD9;
	transition-property: all;
	transition: 0.1s linear;
}
a:hover {
	text-decoration:none;
	opacity: 0.7;
	filter: alpha(opacity=70);
	-ms-filter: "alpha(opacity=70)";
	-moz-opacity: 0.7;
	-khtml-opacity: 0.7;
}

.btn,.btn:visited,.btn:hover {
	display:inline-block;
	font-size:140%;
	color:#fff;
	text-align:center;
	text-decoration:none;
	background-color:#2380D0;
	border-radius:50px;
	padding:10px 20px;
	margin-top:0;
}

input[type=text],input[type=password],textarea {
	width:98%;
	font-size:100%;
	padding:10px 1%;
	border:1px solid #ccc;
}
input[type=text],input[type=password],textarea,button,select {
	font-family:"Noto Sans JP", YuGothic, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif, "游ゴシック", "ヒラギノ角ゴ ProN W3", "メイリオ";
}
select {
	width:300px;
	font-size:100%;
	padding:10px 1%;
	border:1px solid #ccc;
}

header {
	position:fixed;
	z-index:1000001;
	width:100%;
	padding:0 0 0 15px;
	background-color:rgba(255,255,255,.5);
	backdrop-filter: blur(5px);
}
header > div,
header > div > div {
	display:flex;
	justify-content:space-between;
	align-items:center;
}
header h1 {
	display:inline-block;
	vertical-align:bottom;
	white-space:nowrap;
	overflow:hidden;
	margin:0 30px 0 0;
}
header h1 img {
	width:auto;
	max-height:50px;
}
header > div > a img {
	display:inline-block;
	width:auto;
	max-height:40px;
	margin:0 10px 0 0;
}
header > div div a,
header > div div a:visited,
header > div div a:hover {
	display:inline-block;
	vertical-align:middle;
	text-decoration:none;
	margin-right:10px;
}
header h1 a,
header h1 a:visited,
header h1 a:hover {
	display:block;
}
header > div > div > ul {
	display:inline-block;
}
header > div > div > ul li {
	width:40px;
	text-align:center;
	line-height:30px;
	background-color:#eaeaea;
}
header > div > div > ul li.active {
	background-color:#0E7CD9;
}
header > div > div > ul li a,
header > div > div > ul li a:visited,
header > div > div > ul li a:hover {
	display:block;
	font-size:120%;
	margin-right:0;
}
header > div > div > ul li.active a,
header > div > div > ul li.active a:visited,
header > div > div > ul li.active a:hover {
	color:#fff;
	text-decoration:underline;
}

.sp-open,.sp-open-fix,p.close {
	display:none;
}
header nav ul {
	display:flex;
	justify-content:right;
	margin-right:10px;
}
header nav li {
	text-align:center;
	font-size:160%;
	line-height:1.5;
	padding:4px 10px;
}
header nav li span.material-icons-outlined {
	display:block;
	font-size:180%;
}
header nav li img {
	max-width:50px;
	margin:0 auto;
}
header nav li a,
header nav li a:visited,
header nav li a:hover {
	display:block;
	color:#333;
	text-decoration:none;
}
.junbi {
	color:#ccc !important;
}
header nav .lang span {
	margin-bottom:10px;
}
header nav .lang a {
	border-bottom:5px solid #034988;
	padding:0 !important;
}
header nav .sns div {
	display:flex;
	border-bottom:5px solid #034988;
}
header nav .sns a {
	padding:0 2px !important;
}
header nav .sns svg {
	width:26px;
	height:26px;
	margin-bottom:6px;
}
header nav li.entry,
header nav li.login {
	border-radius:50px;
	color:#fff;
	background-color:#0E7CD9;
	padding:4px;
}
header nav li.login {
	background-color:#ff8000;
	margin-right:10px;
}
header nav li.entry a,
header nav li.entry a:visited,
header nav li.entry a:hover,
header nav li.login a,
header nav li.login a:visited,
header nav li.login a:hover {
	color:#fff;
	margin-right:0;
	border-radius:50px;
	padding:0 10px;
}
header nav li.entry a,
header nav li.entry a:visited,
header nav li.entry a:hover {
	border:1px solid #0b5fa4;
}
header nav li.login a,
header nav li.login a:visited,
header nav li.login a:hover {
	border:1px solid #ce6700;
}

.wrapper {
	background-color:#fff;
}
.container {
	max-width:1000px;
	width:80%;
	padding:3% 0;
	margin:0 auto;
}
.frame {
	width:800px;
	max-width:100%;
	margin:30px auto 0;
}

.mid {
	text-align:center;
	border-bottom:1px solid #DEE0E6;
	padding-bottom:10px;
}
.mid span {
	font-size:200%;
	font-weight:600;
	letter-spacing:7px;
	line-height:1.2;
	color:#0E7CD9;
	padding-right:15px;
}


.pankuzu.container {
	padding-bottom:0;
}
.pankuzu li {
	display:inline-block;
	font-size:14px;font-size:1.4rem;
}

footer {
	background-color:#F4FCFF;
}
footer section.container {
	padding-top:3%;
}
footer ul {
	font-size:160%;
}
footer a,
footer a:visited,
footer a:hover {
	text-decoration:none;
}
footer section > div:first-child {
	display:flex;
	justify-content:space-between;
}
footer section > div:last-child {
	text-align:center;
	padding-top:3%;
	margin-top:3%;
}
footer section > div:last-child a,
footer section > div:last-child a:visited {
	text-decoration:underline;
}
footer section > div:first-child > div:first-child a {
	display:flex;
	justify-content:space-between;
	align-items:center;
	background-color:#0E7CD9;
	color:#fff;
	padding:1.5em 3em;
}
footer h5 {
	font-size:180%;
	font-weight:600;
	line-height:1.5;
	letter-spacing:1px;
	margin-right:100px;
}
footer h5 span {
	display:block;
	font-size:65%;
	font-weight:400;
}
footer section > div:first-child > div:first-child a > span {
	font-size:160%;
	font-weight:400;
	padding-left:15px;
	border-left:1px solid #fff;
}
footer section > div:first-child div:last-child ul {
	display:flex;
	flex-wrap:wrap;
}
footer section > div:first-child div:last-child li {
	width:50%;
	margin-bottom:5px;
}
footer section > div:first-child div:last-child li:before {
	content:'\e5cc';
	font-family:"Material Icons";
	color:#28A7E1;
	margin-right:3px;
	vertical-align:top;
}
footer section > div:first-child div:last-child li a {
	color:#3e3e3e;
}
footer p {
	font-size:120%;
	margin:0;
}
footer section > div:last-child a {
	font-size:160%;
}

.pagetop {
	position:fixed;
	bottom:12px;
	right:12px;
	z-index:9999;
}
.pagetop a {
	display:block;
	text-indent:-9999px;
	width:36px;
	height:36px;
	background-color:#0E7CD9;
	-webkit-border-radius:18px;
	-moz-border-radius:18px;
	border-radius:18px;
	-webkit-box-shadow:0 0 5px #ccc;
	-moz-box-shadow:0 0 5px #ccc;
	box-shadow:0 0 5px #ccc;
	position:relative;
}
.pagetop a:before,
.pagetop a:after {
	content:'';
	border:10px solid transparent;
	position:absolute;
	left:50%;
	margin-left:-10px;
}
.pagetop a:before {
	border-bottom:10px solid #fff;
	top:1px;
}
.pagetop a:after {
	border-bottom:10px solid #0E7CD9;
	top:4px;
}

@media only screen and (max-width: 1480px) {
	header > div {
		display:block;
	}
	header > div > div {
		justify-content:start;
	}
	header > div > div > ul li {
		display:inline-block;
	}
}
@media only screen and (max-width: 1200px) {
	body {
		line-height:1.5;
	}
	.container {
		max-width:1000px;
		padding:30px 0;
	}
}
@media only screen and (max-width: 1050px) {
	.container {
		width:90%;
		padding:30px 5%;
	}
	.sp-open,.sp-open span,
	.sp-open-fix,.sp-open-fix span {
		display: inline-block;
		transition: all .4s;
		box-sizing: border-box;
	}
	a.sp-open,a.sp-open-fix {
		position: relative;
		width: 36px;
		height: 36px;
		padding:10px;
		border-radius:18px;
		float:right;
		text-decoration:none;
		background-color:#fff;
		opacity: 1;
		filter: alpha(opacity=100);
		-ms-filter: "alpha(opacity=100)";
		-moz-opacity: 1;
		-khtml-opacity: 1;
		margin:6px 12px 0 0;
	}
	a.sp-open-fix {
		position:fixed;
		top:12px;
		right:12px;
		float:none;
		background-color:#5667a9;
		margin:0;
	}
	.sp-open span,.sp-open-fix span {
		position: absolute;
		left: 6px;
		width: 24px;
		height: 3px;
		background-color: #5667a9;
		border-radius: 3px;
	}
	.sp-open-fix span {
		background-color: #fff;
	}
	.sp-open span:nth-of-type(1),
	.sp-open-fix span:nth-of-type(1) {
		top: 9px;
	}
	.sp-open span:nth-of-type(2),
	.sp-open-fix span:nth-of-type(2) {
		top: 16px;
	}
	.sp-open span:nth-of-type(3),
	.sp-open-fix span:nth-of-type(3) {
		top: 23px;
	}
	.sp-open.active span:nth-of-type(1),
	.sp-open-fix.active span:nth-of-type(1) {
		-webkit-transform: translateY(8px) rotate(-45deg);
		transform: translateY(8px) rotate(-45deg);
	}
	.sp-open.active span:nth-of-type(2),
	.sp-open-fix.active span:nth-of-type(2) {
		opacity: 0;
	}
	.sp-open.active span:nth-of-type(3),
	.sp-open-fix.active span:nth-of-type(3) {
		-webkit-transform: translateY(-6px) rotate(45deg);
		transform: translateY(-6px) rotate(45deg);
	}
	header {
		position:static;
		backdrop-filter:none;
		padding:5px 0 5px 10px;
	}
	header nav {
		float:none;
		margin:0;
		background:none;
		padding:0;
		position:absolute;
		top:0;
		right:0;
	}
	.sp-menu {
		position: relative;
		display: none;
		width: 86%;
		margin: 7%;
		padding: 0 0 30px;
		background-color: rgb(255,255,255);
	}
	p.close {
		display: block;
		width: 80%;
		text-align: center;
		margin-left: auto;
		margin-right: auto;
	}
	p.close.btn {
		margin-top:0;
	}
	p.close a,
	p.close a:visited,
	p.close a:hover {
		display:inline-block;
		width:50%;
		max-width:210px;
		margin-right:0;
	}
	.modal-overlay {
		z-index:1;
		display:none;
		position:fixed;
		top:0;
		left:0;
		width:100%;
		height:120%;
		background-color:rgba(0,0,70,0.8);
	}
	.modal-wrap {
		z-index:3;
		display:none;
		position:fixed;
		top:0;
		left:0;
		width:100%;
		height:100%;
		overflow:auto;
	}
	header > div,
	header > div > div {
		display:inline;
		padding:0;
	}
	header > div > div > ul li {
		display:inline-block;
	}
	header h1 {
		margin-right:1em;
	}
	header > div div h1 a, header > div div h1 a:visited, header > div div h1 a:hover {
		margin-right:0;
	}
	header nav ul {
		flex-wrap:wrap;
		justify-content:space-evenly;
		margin-right:0;
	}
	header nav ul li {
		width:48%;
		text-align:center;
		padding:0;
		margin:0 .5%;
		border-bottom:1px solid #5667a9;
	}
	header nav li.entry,
	header nav li.login {
		margin-top:1em;
	}
	header nav ul li:first-child,
	header nav ul li:nth-child(2) {
		border-top:1px solid #5667a9;
	}
	header nav li a, header nav li a:visited, header nav li a:hover {
		display:block;
		padding:1em 0;
	}
	header nav li a img {
		display:none;
	}
	header nav .lang a {
		border:none;
		padding:1em 0 !important;
	}
	header nav .lang span {
		margin-bottom:0;
	}
	header nav li.lang span.material-icons-outlined {
		font-size:230%;
	}
	header nav .sns div {
		justify-content:center;
		border:none;
	}
	header nav .sns a {
		padding:1em !important;
	}
	header nav .sns svg {
		margin-bottom:0;
	}
	header nav li.login {
		margin-right:0;
	}
	select {
		width:98%;
	}
	footer h5 {
		margin-right:50px;
	}
}
@media only screen and (max-width: 800px) {
	html {
		font-size:50%;
	}
	a:hover {
		text-decoration:none;
		opacity: 1;
		filter: alpha(opacity=100);
		-ms-filter: "alpha(opacity=100)";
		-moz-opacity: 1;
		-khtml-opacity: 1;
	}
}
@media only screen and (max-width: 600px) {
	header > div {
		display:inline-block;
	}
	header h1 {
		display:inline-block;
		margin-right:0;
	}
	header h1 img {
		max-height:none;
		max-width:80%;
	}
	p.close a {
		width:80%;
	}
	header nav ul {
		margin-right:0;
	}
	header nav ul li {
		display:block;
		width:100%;
		margin:0;
	}
	header nav ul li.entry,
	header nav ul li.login {
		width:70%;
	}
	header nav ul li:nth-child(2) {
		border-top:none;
	}
	footer section > div:first-child {
		display:block;
	}
	footer section > div:first-child div:last-child li {
		width:33%;
	}
	.mid {
		display:block;
		font-size:3rem;
		letter-spacing:0 !important;
	}
	.mid span {
		font-size:1.6rem;
	}
	.mid span:first-child {
		display:block;
		font-size:150%;
		padding-right:0;
	}
}