@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700&family=Noto+Serif+JP:wght@400;700&display=swap');
html,
body {
	color: #202020;
	height: 100%;
	min-height: 100%;
	font-size: 16px;
	font-family: "Noto Sans JP", "Meiryo UI", "ヒラギノ明朝 ProN", "小塚明朝 Pro", Hiragino Kaku Gothic ProN, "Yu Gothic Medium", "游ゴシック Medium", YuGothic, 游ゴシック体, "ヒラギノ角ゴ Pro W3", sans-serif;
	font-weight: 400;
	font-style: normal;
	line-height: 1.7;
	letter-spacing: 0.02em;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
body.is-menu-open {
	overflow: hidden;
}
h1,h2,h3,h4,h5,h6,strong,th {
	font-family: "Noto Sans JP", "Meiryo UI", "ヒラギノ明朝 ProN", "小塚明朝 Pro", Hiragino Kaku Gothic ProN, "Yu Gothic Medium", "游ゴシック Medium", YuGothic, 游ゴシック体, "ヒラギノ角ゴ Pro W3", sans-serif;
	font-weight: 700;
	font-style: normal;
}
.mn {
	font-family: 'Noto Serif JP', "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
/* 834 */
@media screen and (max-width: 834px) {
	body {
		/*font-size:calc(9px + 0.7vmin);*/
		-webkit-tap-highlight-color: transparent;
	}
}

/* 580 */
@media screen and (max-width: 580px) {
	body {
		/*font-size:calc(9px + 1vmin);*/
		-webkit-tap-highlight-color: transparent;
	}
	html,
	body {
		font-size: 15px;
	}
}
a {
	color: #202020;
	text-decoration: none;
	transition: color 0.3s ease;
}
a:visited {}
a:hover,
a:active {
	color: #3d3a39;
	text-decoration: none;
}
img {
	width: auto;
	max-width: 100%;
	height: auto;
	display: block;
}
::selection {
	background: rgba(0, 144, 202, 0.5); /* Safari */
}
::-moz-selection {
	background: rgba(0, 144, 202, 0.5); /* Firefox */
}
/* min835 */
@media screen and (min-width: 835px) {
	a[href^="tel:"] {
		pointer-events: none;
		cursor: default;
		text-decoration: none;
	}
}

/*--------------------------------------------------------------*/
/* Form関連 */
/*--------------------------------------------------------------*/
input, textarea, table select, button {
	font-family: inherit;
	font-size: inherit;
	font-weight: normal;
}
input, table select, button {
	vertical-align: middle;
}
textarea::placeholder,
input::placeholder {
	color: #ccc;
}
input:-ms-input-placeholder {
	color: #ccc;
}
input::-ms-input-placeholder {
	color: #ccc;
}
input[type=text],
input[type=password],
input[type=email],
input[type=tel],
input[type=checkbox],
input[type=submit],
input[type=button],
input[type=number],
button,
textarea {
	border-radius: 4px;
	border: 1px solid #ddd;
	margin: 0;
	padding: 10px 10px;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	width: 100%;
	background-color: #fff;
}
textarea {
	width: 100%;
	height: 240px;
}
input[type=text]:focus,
input[type=password]:focus,
input[type=email]:focus,
input[type=tel]:focus,
textarea:focus {
	outline: none;
	background-color: #FFFFDF;
}
input[type=submit],
input[type=button],
button {
	outline: none;
	cursor: pointer;
	background-color: #F4F4F4;
}
input[type=submit]:hover,
input[type=button]:hover {
	background-color: #fff;
}
input[type=submit]:active,
input[type=button]:active,
button:active {
	background-color: #01472e;
}
/* checkbox */
input[type=checkbox] {
	display: none;
}
input[type=checkbox] + .mwform-checkbox-field-text {
	position: relative;
	vertical-align: middle;
	cursor: pointer;
}
input[type=checkbox] + .mwform-checkbox-field-text:before {
	content: "\f0c8";
	font-family: "Font Awesome 5 Free";
	font-weight: 500;
	color: #ccc;
	font-size: 22px;
	margin-right: 4px;
	position: relative;
	bottom: -2px;
}
input[type=checkbox]:checked + .mwform-checkbox-field-text:before {
	content: "\f14a";
	color: #f39800;
}
/* radio */
input[type=radio] {
	display: none;
}
input[type=radio] + .mwform-radio-field-text:before {
	content: "\f111";
	font-family: "Font Awesome 5 Free";
	font-weight: 500;
	color: #ccc;
	font-size: 18px;
	margin-right: 6px;
}
input[type=radio]:checked + .mwform-radio-field-text:before {
	content: "\f192";
	color: #005F3D;
}
/* label */
.form label {
	white-space: nowrap;
}
/* select */
select {
	/* styling */
	background-image: linear-gradient(45deg, transparent 50.1%, #fff 50.1%), linear-gradient(135deg, #fff 50.1%, transparent 50.1%), linear-gradient(to right, #00214c, #00214c);
	background-position: calc(100% - 19px) calc(1em + 2px), calc(100% - 14px) calc(1em + 2px), 100% 0;
	background-size: 5px 5px, 5px 5px, 2.5em 2.5em;
	background-repeat: no-repeat;
	background-color: white;
	border: thin solid #bfbfbf;
	border-radius: 4px;
	display: inline-block;
	font: inherit;
	line-height: 1.5em;
	padding: 0.5em 3.5em 0.5em 1em;
	color: #000;
	/* reset */
	margin: 0;      
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-appearance: none;
	-moz-appearance: none;
	position: relative;
	width: 100%;
}
select:focus {
	background-image: linear-gradient(45deg, white 50.1%, transparent 50.1%), linear-gradient(135deg, transparent 50.1%, white 50.1%), linear-gradient(to right, #00214c, #00214c);
	background-position: calc(100% - 14px) calc(1em + 2px), calc(100% - 19px) calc(1em + 2px), 100% 0;
	background-size: 5px 5px, 5px 5px, 2.5em 2.5em;
	background-repeat: no-repeat;
	border-color: #bfbfbf;
	outline: 0;
}
select:-moz-focusring {
	color: transparent;
	text-shadow: 0 0 0 #000;
}

/*--------------------------------------------------------------*/
/* layout */
/*--------------------------------------------------------------*/
.flex {
	display: flex;
	flex-wrap: wrap;
}
.flex.reverse {
	flex-direction: row-reverse;
}
.center {
	text-align: center;
}
.right {
	text-align: right;
}
/* pc tb sp view */
.sp_view {
	display: none;
}
.tb_view {
	display: none;
}
/* 1230 */
@media (max-width: 1230px) {
	.mb14 {
		margin-bottom: max(11.4vw, 80px)!important;
	}
	.mb16 {
		margin-bottom: max(13vw, 80px)!important;
	}
}
/* 768 */
@media (max-width: 768px) {
	.pc_view {
		display: none;
	}
	.tb_view {
		display: block;
	}
	.tb_none {
		display: none;
	}
}
/* 580 */
@media (max-width: 580px) {
	.sp_view {
		display: block;
	}
	.sp_view.inline {
		display: inline-block;
	}
	.sp_none {
		display: none!important;
	}
}
/* base */
.content {
	width: auto;
	max-width: 1240px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 20px;
	padding-right: 20px;
}
.content2 {
	width: auto;
	max-width: 1640px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 20px;
	padding-right: 20px;
}

/*--------------------------------------------------------------*/
/* table */
/*--------------------------------------------------------------*/
table.tbl {
	width: 100%;
	border-top: 1px solid #BABABA;
	margin-bottom: 80px;
}
table.tbl tr {
	border-bottom: 1px solid #BABABA;
}
table.tbl tr th,
table.tbl tr td {
	padding: 40px;
	text-align: left;
	line-height: 1.8;
}
table.tbl tr th {
	white-space: nowrap;
	letter-spacing: 3px;
	text-indent: 3px;
}

/*--------------------------------------------------------------*/
/* .fixed */
/*--------------------------------------------------------------*/
.fixed {
	position: fixed!important;
	top: 0px;
	z-index: 99;
	animation: moveimg 1s 1;
	box-shadow: 0px 3px 3px rgba(0,0,0,0.3);
	border-bottom: none!important;
}
@keyframes moveimg {
	0% { top: -350px; }
	100% { top: 0px; }
}

/*--------------------------------------------------------------*/
/* vegas */
/*--------------------------------------------------------------*/
.vegas-animation-kenburns {
	animation: kenburns ease-out;
}
@keyframes kenburns {
	0% {
		transform: scale(1.1);
	}
	100% {
		transform: scale(1);
	}
}

/*--------------------------------------------------------------*/
/* zoom */
/*--------------------------------------------------------------*/
.zhover {
	display: block;
	overflow: hidden;
	z-index: 2;
	position: relative;
}
.zhover img {
	transform: scale(1) ;
	transition: all 0.5s cubic-bezier(0.5, 1, 0.89, 1);
}
a:hover .zhover img:hover {
	transform:scale(1.03) ;
}

/*--------------------------------------------------------------*/
/* btn */
/*--------------------------------------------------------------*/
.btn {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	background-image: radial-gradient(circle at 80% 50%, rgb(101 134 177), rgb(0 33 76) 95%);
	background-size: 150% 150%;
	background-position: 80% 50%;
	color: #fff;
	font-size: 20px;
	font-weight: bold;
	height: 70px;
	max-width: 280px;
	width: 80%;
	margin-top: 30px;
	position: relative;
	transition: .3s ease;
}
.btn::after {
	content: '';
	display: block;
	width: 100%;
	height: 100%;
	border: 1px solid #00214c;
	position: absolute;
	top: 7px;
	left: 7px;
	transition: .3s ease;
}
.btn::before {
	content: '';
	display: block;
	width: 80px;
	height: 1px;
	border-bottom: 1px solid #00214c;
	position: absolute;
	top: 50%;
	right: -20%;
	-webkit-transform: translate(0, -50%);
	transform: translate(0, -50%);
	transition: .3s ease;
}
.btn:hover {
	color: #fff;
	background-position: 0% 50%;
}
.btn:hover::after {
	top: 0px;
	left: 0px;
	opacity: 0;
}
.btn:hover::before {
	width: 0px;
}
.btn i {
	margin-left: 8px;
}
/* 1240 */
@media (max-width: 1240px) {
	.btn {
		font-size: max(1.613vw, 16px); //20px;
		height: max(5.645vw, 50px); //70px;
		margin-top: max(2.419vw, 25px); //30px;
	}
	.btn::after {
		top: max(0.565vw, 4px); //7px;
		left: max(0.565vw, 4px); //7px;
	}
	.btn::before {
		width: max(6.452vw, 60px); //80px;
		right: -4.5vw;
	}
}

/*--------------------------------------------------------------*/
/* btn */
/*--------------------------------------------------------------*/
.btn2 {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	border: 1px solid #fff;
	color: #fff;
	font-size: 20px;
	height: 65px;
	max-width: 280px;
	width: 70%;
	margin-top: 30px;
	position: relative;
	transition: color 0.8s ease;
}
.btn2::before {
	content: '';
	display: block;
	width: 80px;
	height: 1px;
	border-bottom: 1px solid #fff;
	position: absolute;
	top: 50%;
	left: 90%;
	-webkit-transform: translate(0, -50%);
	transform: translate(0, -50%);
	transition: .3s ease;
	z-index: -1;
}
body.is-pc .btn2:hover {
	color: #000;
}
body.is-pc .btn2:hover::before {
	animation: animateLine 0.7s ease forwards;
}
@keyframes animateLine {
	0% {
		left: 90%;
		width: 80px;
		height: 1px;
	}
	20% {
		left: 0;
		width: 80px;
		height: 1px;
	}
	40% {
		left: 0;
		width: 100%;
		height: 1px;
	}
	60% {
		left: 0;
		background: #fff;
	}
	100% {
		left: 0;
		width: 100%;
		height: 100%;
		background: #fff;
	}
}
/* 1240 */
@media (max-width: 1240px) {
	.btn2 {
		font-size: max(1.613vw, 16px); //20px;
		height: max(5.242vw, 50px); //65px;
		margin-top: max(2.419vw, 25px); //30px;
	}
	.btn2::after {
		top: max(0.565vw, 4px); //7px;
		left: max(0.565vw, 4px); //7px;
	}
	.btn2::before {
		width: max(6.452vw, 60px); //80px;
		right: -4.5vw;
	}
}

/*--------------------------------------------------------------*/
/* btn3 */
/*--------------------------------------------------------------*/
.btn3 {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	background-image: radial-gradient(circle at 80% 50%, rgba(101, 134, 177, 1), rgba(0, 33, 76, 1) 95%);
	background-size: 150% 150%;
	background-position: 80% 50%;
	color: #fff;
	height: 50px;
	max-width: 240px;
	min-width: 180px;
	width: 90%;
	position: relative;
	transition: .3s ease;
}
body.is-pc .btn3:hover {
	color: #fff;
	background-position: 0% 50%;
}
/* 1240 */
@media (max-width: 1240px) {
	.btn3 {
		font-size: max(1.613vw, 16px); //20px;
		height: max(4.032vw, 40px); //50px;
	}
}

/*--------------------------------------------------------------*/
/* .pd_std */
/*--------------------------------------------------------------*/
.pd_std {
	padding: 90px 0;
}
.pd_std.tzero {
	padding: 0 0 90px 0;
}
.pd_std.bzero {
	padding: 90px 0 0 0;
}
/* 1240 */
@media (max-width: 1240px) {
	.pd_std {
		padding: max(7.2vw, 50px) 0;
	}
	.pd_std.tzero {
		padding: 0 0 max(7.2vw, 50px) 0;
	}
	.pd_std.bzero {
		padding: max(7.258vw, 50px) 0 0 0;
	}
}

/*--------------------------------------------------------------*/
/* breadcrumbs */
/*--------------------------------------------------------------*/
.breadcrumbs span {
	font-size: 15px;
}
.breadcrumbs i {
	font-size: 13px;
	margin: 0 6px 0 7px;
}
.breadcrumbs a {
	color: #000;
}
.breadcrumbs a:hover {
	color: #5fa427;
}
/* 580 */
@media (max-width: 580px) {
	.breadcrumbs span {
		font-size: 14px;
	}
	.breadcrumbs i {
		font-size: 12px;
		margin: 0 3px 0 5px;
	}
}

/*--------------------------------------------------------------*/
/* #header */
/*--------------------------------------------------------------*/
#header {
	width: 100%;
	height: 80px;
	position: absolute;
	background: rgba(255,255,255,0.8);
	top: 0;
	left: 0;
	display: flex;
	align-items: center;
	z-index: 9;
}
#header.fixed {
	background: #fff;
}
#header .pc_head {
	width: 100%;
	padding: 0 20px;
	transition: .3s ease;
	position: relative;
}
#header .pc_head .flex {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
}
#header .pc_head .flex .flex_wrap {
	margin-left: 5vw;
	white-space: nowrap;
	transition: .3s ease;
}
/* logo */
#header .pc_head .logo {
	line-height: 1;
}
#header .pc_head .logo a {
	display: inline-flex;
	align-items: center;
	gap: 0 14px;
}
#header .pc_head .logo a img {
	max-width: 210px;
	width: 80%;
}
/* nav */
#header .pc_head nav {
	max-width: 600px;
	display: flex;
	justify-content: flex-end;
	align-items: center;
	gap: 0 2vw;
	width: 72%;
	padding-top: 10px;
	transition: width .3s ease;
}
#header .pc_head nav ul.gnav {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex: 1;
	margin-right: 1vw;
}
#header .pc_head nav ul.gnav li {
	text-align: center;
}
#header .pc_head nav ul.gnav li a {
	font-weight: bold;
	color: #00214c;
	line-height: 1;
	display: block;
	border-radius: 3px;
	padding: 5px 8px 6px 8px;
	transition: .4s ease;
	backface-visibility: hidden;
}
#header .pc_head nav ul.gnav li a:hover {
	background: #fff;
	color: initial;
}
/* div.contact */
#header .pc_head nav a.contact {
	color: #fff;
	text-align: center;
	max-width: 170px;
	width: 80%;
	display: block;
	padding: 5px 10px;
	border: 3px solid #fff;
	transition: .3s ease;
}
#header .pc_head nav a.contact:hover {
	background: #fff;
	color: initial;
}
/* div.language */
#header .pc_head nav div.language {
	padding: 3px 0;
	position: relative;
}
#header .pc_head nav div.language span.change {
	display: flex;
	align-items: center;
	gap: 0 3px;
	cursor: pointer;
}
#header .pc_head nav div.language span.change img.world {
	width: 18px;
}
#header .pc_head nav div.language span.change img.down {
	margin-top: 3px;
	width: 11px;
}
#header .pc_head nav div.language span.change span.select_lang {
	color: #fff;
}
#header .pc_head nav div.language ul {
	display: none;
}
#header .pc_head nav div.language ul li:nth-child(n+2) a {
	border-top: 1px solid #ddd;
}
#header .pc_head nav div.language ul li a {
	display: block;
	background: #fff;
	padding: 1px;
	text-align: center;
}
#header .pc_head nav div.language:hover ul {
	display: block;
	position: absolute;
	top: 100%;
	left: 0;
	width: 100%;
}

/* 1300 */
@media (max-width: 1300px) {
	#header .pc_head .flex .flex_wrap {
		margin-left: 0px;
	}
}
/* 840 */
@media (max-width: 840px) {
	#header {
		height: 70px;
	}
	#header .pc_head nav {
		display: none;
	}
}
/* 580 */
@media (max-width: 580px) {
	#header {
		height: 60px;
	}
}

/*--------------------------------------------------------------*/
/* #header SP MENU関連 */
/*--------------------------------------------------------------*/
/* sp_menu_btn */
#sp_menu_btn {
	display: none;
	width: 35px;
	height: 32px;
	position: absolute;
	top: 25px;
	right: 16px;
	cursor: pointer;
	z-index: 99;
	transition: top .3s ease;
}
#sp_menu_btn .oc {
	color: #00214c;
	font-size: 12px;
	line-height: 1;
	position: absolute;
	bottom: 0;
	font-weight: bold;
}
.menu--active #sp_menu_btn .oc {
	font-size: 11px;
}
#open {
	position: relative;
	height: 12px;
}
.menu_line {
	background: #00214c;
	display: block;
	height: 2px;
	position: absolute;
	transition:transform .3s;
	width: 100%;
}
.menu--active .menu_line {
	background: #000;
}
body.is-pc #sp_menu_btn:hover .menu_line {
	background: #ccc;
}
body.is-pc #sp_menu_btn:hover .oc {
	color: #ccc;
}
body.is-pc #header.fixed #sp_menu_btn:hover .menu_line {
	background: #777;
}
body.is-pc #header.fixed #sp_menu_btn:hover .oc {
	color: #777;
}
.menu_line-bottom {
	bottom: 0;
}
.menu--active .menu_line-top {
	top: 8px;
	transform: rotate(15deg);
}
.menu--active .menu_line-bottom {
	bottom: 2px;
	transform: rotate(165deg);
}
.menu--active #sp_menu_btn .oc {
	color: #000;
}
body.is-pc.menu--active #sp_menu_btn:hover .menu_line {
	background: #555;
}
body.is-pc.menu--active #sp_menu_btn:hover .oc {
	color: #555;
}
/* sp_menu_right */
.sp_menu_right {
	background: #fff;
	height: 100vh;
	overflow-y: auto;
	position: fixed;
	right: 0;
	top: 0;
	transform: translateX(100%);
	transition: all .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
	width: 75%;
	padding: 20px 10px 20px 25px;
	z-index: 98;
	-webkit-overflow-scrolling: touch;
}
.menu--active .sp_menu_right {
	right: 75%;
	margin-left: 0;
}
/* logo */
.sp_menu_right .logo {
	margin-bottom: 30px;
}
.sp_menu_right .logo a {
	display: inline-flex;
	align-items: center;
	gap: 0 10px;
}
.sp_menu_right .logo a img {
	width: 160px;
}
/* ul.nav */
.sp_menu_right ul.nav li {
	font-size: 17px;
	padding: 0 0 15px 0;
	position: relative;
}
.sp_menu_right ul.nav li a {
	font-size: 14px;
	display: inline-block;
	line-height: 1.2;
}
.sp_menu_right ul.nav li a span.eng {
	display: inline-block;
	font-size: 13px;
	font-family: "poppins", sans-serif;
	font-weight: 700;
}
.sp_menu_right ul.nav li a:hover svg {
	fill: orange;
}
/* flex left */
.sp_menu_right .flex {
	max-width: 360px;
	width: 100%;
}
.sp_menu_right .flex > div {
	width: 50%;
}
.sp_menu_right .flex .left a {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	flex-wrap: wrap;
	width: 100%;
	height: 80px;
	background: #3d3a39;
	color: #fff;
	position: relative;
	transition: .3s;
	backface-visibility: hidden;
}
body.is-pc .sp_menu_right .flex .left a:hover {
	opacity: 0.8;
}
body.is-pc .sp_menu_right .flex .right a:hover {
	background: #ffffe7;
}
/* flex right */
.sp_menu_right .flex {
	margin-top: 25px;
}
.sp_menu_right .flex .right span.txt {
	font-size: 14px;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	flex-wrap: wrap;
	width: 100%;
	height: 80px;
	border: 1px solid #3d3a39;
	background: #fff;
	color: #3d3a39;
	position: relative;
	transition: .3s;
	backface-visibility: hidden;
}
/* sp_menu_left */
.sp_menu_left {
	transform: translateX(-100%);
	transition: all .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
	background: #00214c;
	position: fixed;
	left: 0;
	top: 0;
	height: 100vh;
	width: 25%;
	text-align: center;
	z-index: 98;
}
.sp_menu_left::after {
	content: '';
	display: block;
	width: 100%;
	height: 100%;
	background: url(../images/mark.png) no-repeat;
	background-position: top 8% left 8%;
	background-size: 240%;
	opacity: 0.2;
}
.menu--active .sp_menu_left {
	left: 25%;
}
/* 840 */
@media (max-width: 840px) {
	/* sp_menu_btn */
	#sp_menu_btn {
		display: block;
	}
	/* sp_menu_btn */
	#header.fixed #sp_menu_btn {
		top: 17px;
	}
}
/* 580 */
@media (max-width: 580px) {
	/* sp_menu_btn */
	#sp_menu_btn {
		top: 16px;
		right: 16px;
	}
	.sp_menu_right .flex {
		margin-top: 12px;
		margin-left: -15px;
		width: calc(100% + 15px);
	}
	/* left */
	.sp_menu_right .flex .left {
		width: 55%;
	}
	.sp_menu_right .flex .left a {
		height: 60px;
	}
	.sp_menu_right .flex .left a span.tel {
		font-size: 13px;
	}
	.sp_menu_right .flex .left a span.time {
		font-size: 11px;
	}
	.sp_menu_right .flex .left a span.tel svg {
		width: 12px;
		margin-bottom: -3px;
		margin-right: 3px;
	}
	/* right */
	.sp_menu_right {
		padding: 20px 10px 20px 20px;
	}
	.sp_menu_right .flex .right {
		width: 45%;
	}
	.sp_menu_right .logo a span.txt span {
		font-size: 14px;
	}
	.sp_menu_right .flex .right span.txt {
		font-size: 13px;
		height: 60px;
	}
}

/*--------------------------------------------------------------*/
/* header#page_head */
/*--------------------------------------------------------------*/
header#page_head {
	margin-bottom: 60px;
}
header#page_head .head_wrap {
	margin-top: 90px;
	height: 410px;
	width: max-content;
	margin-left: auto;
	margin-right: auto;
	padding-bottom: 40px;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	transition: margin .3s ease;
}
header#page_head .head_wrap h1 {
	display: block;
	width: 100%;
	font-weight: normal;
	margin-bottom: 15px;
}
header#page_head .head_wrap span.eng {
	display: block;
	font-size: 120px;
	line-height: 1;
	position: relative;
}
header#page_head .head_wrap span.eng::after {
	content: '';
	display: inline-block;
	background-size: contain;
	background-repeat: no-repeat;
	position: absolute;
	right: -6%;
	top: 25%;
	/*aspect-ratio: 305 / 106;*/
	/*width: 305px;*/
	/*background-image: url(../images/works_an.svg);*/
}
header#page_head figure#subhead_img {
	display: block;
	width: 100%;
	height: 590px;
	background-size: 100% auto;
}
/* 1230 */
@media (max-width: 1230px) {
	header#page_head .head_wrap {
		margin-top: 80px;
	}
	header#page_head figure#subhead_img {
		height: max(48vw, 280px);
	}
}
/* 834 */
@media (max-width: 834px) {
	header#page_head .head_wrap {
		height: max(49.2vw, 300px);
	}
	header#page_head .head_wrap span.eng {
		font-size: max(14.4vw, 63px);
	}
}
/* 580 */
@media (max-width: 580px) {
	header#page_head .head_wrap {
		padding-bottom: 20px;
	}
	header#page_head .head_wrap h1 {
		font-size: 14px;
		margin-bottom: 15px;
	}
}

/*--------------------------------------------------------------*/
/* MAIN VISUAL */
/*--------------------------------------------------------------*/
#main_visual {
	height: 100svh!important;
	position: relative;
}
#main_visual::after {
	content: '';
	display: block;
	width: 100%;
	height: 100%;
	background: linear-gradient(rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.19) 26.11%, rgba(255, 255, 255, 0.38) 53.2%, rgba(255, 255, 255, 0.49) 100%);
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
}
body.sub #main_visual {
	display: none;
}
#main_visual .content {
	height: 100svh;
	position: relative;
	z-index: 2;
}
#main_visual .content {
	position: relative;
}
#main_visual .content .wrap {
	position: absolute;
	top: 50%;
	left: 0;
	width: 100%;
	text-align: center;
	-webkit-transform: translate(0, -50%);
	transform: translate(0, -50%);
	color: #fff;
}
#main_visual .content .wrap h2 {
	font-size: 50px;
	letter-spacing: 0.5vw;
	text-indent: 0.5vw;
	margin-bottom: 60px;
	text-shadow: 3px 3px 2px rgba(0,0,0,0.5);
}
#main_visual .content .wrap img {
	max-width: 280px;
	width: 40%;
	margin: 0 auto;
}
/* 1200 */
@media (max-width: 1200px) {
	#main_visual .content .wrap h2 {
		font-size: max(4.167vw, 23px); //50px;
		margin-bottom: max(5vw, 42px); //60px;
	}
}

/*--------------------------------------------------------------*/
/* SUB VISUAL */
/*--------------------------------------------------------------*/
#sub_visual {
	height: 240px;
	background: url(../images/sub_head.jpg) no-repeat;
	background-size: cover;
	background-position: center center;
	position: relative;
	margin-top: 80px;
	margin-bottom: 10px;
}
/* 1080 */
@media (max-width: 1080px) {
	#sub_visual {
		margin-top: 70px;
	}
}
/* 580 */
@media (max-width: 580px) {
	#sub_visual {
		margin-top: 60px;
	}
}
#sub_visual::after {
	content: '';
	display: block;
	width: 100%;
	height: 100%;
	background: linear-gradient(rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.19) 26.11%, rgba(255, 255, 255, 0.38) 53.2%, rgba(255, 255, 255, 0.49) 100%);
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
}
#sub_visual .content h1,
#sub_visual .content h2 {
	font-size: 40px;
	line-height: 1.4;
	text-shadow: 1px 1px 6px rgba(0,0,0,0.5);
	position: absolute;
	top: 50%;
	left: 0;
	z-index: 2;
	width: 100%;
	text-align: center;
	-webkit-transform: translate(0, -50%);
	transform: translate(0, -50%);
	color: #fff;
}
#sub_visual .content h1 span.small,
#sub_visual .content h2 span.small {
	display: block;
	font-size: 20px;
}
/* 1240 */
@media (max-width: 1240px) {
	#sub_visual {
		height: max(19.355vw, 168px); //240px;
	}
	#sub_visual .content h1,
	#sub_visual .content h2 {
		font-size: max(3.226vw, 28px); //40px;
	}
}

/*--------------------------------------------------------------*/
/* TopAbout */
/*--------------------------------------------------------------*/
#TopAbout {
	text-align: center;
}
#TopAbout header h1 {
	font-size: 30px;
	font-weight: bold;
	color: #00214c;
	margin-bottom: 40px;
}
/* 1240 */
@media (max-width: 1240px) {
	#TopAbout header h1 {
		font-size: max(2.419vw, 21px); //30px;
		margin-bottom: max(3.226vw, 28px); //40px;
	}
}

/*--------------------------------------------------------------*/
/* TopService */
/*--------------------------------------------------------------*/
#TopService {
	background: #00214c;
}
#TopService header h1 {
	color: #fff;
	font-size: 60px;
	font-weight: bold;
	text-align: center;
	margin-bottom: 80px;
}
#TopService ul li {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
}
#TopService ul li:nth-child(even) {
	flex-direction: row-reverse;
}
#TopService ul li figure {
	width: 50%;
}
#TopService ul li div.text {
	width: 50%;
	color: #fff;
	padding: 30px 60px;
}
#TopService ul li div.text h3 {
	font-size: 28px;
	font-weight: bold;
	margin-bottom: 30px;
}
/* 1240 */
@media (max-width: 1240px) {
	#TopService header h1 {
		font-size: max(4.839vw, 42px); //60px;
		margin-bottom: max(6.452vw, 56px); //80px;
	}
	#TopService ul li div.text {
		padding: 30px max(4.839vw, 30px); //60px;
	}
	#TopService ul li div.text h3 {
		font-size: max(2.258vw, 20px); //28px;
		margin-bottom: max(2.419vw, 15px); //30px;
	}
}
/* 768 */
@media (max-width: 768px) {
	#TopService ul li figure {
		width: 100%;
	}
	#TopService ul li div.text {
		width: 100%;
	}
}


/*--------------------------------------------------------------*/
/* TopCompany */
/*--------------------------------------------------------------*/
#TopCompany {
	background: #f1f0e8;
}
#TopCompany header h1 {
	color: #00214c;
	font-size: 60px;
	font-weight: bold;
	text-align: center;
	margin-bottom: 80px;
}
#TopCompany table {
	border-collapse: collapse;
	border-top: 1px solid #000;
	width: 100%;
	margin-bottom: 60px;
}
#TopCompany table tr {
	border-bottom: 1px solid #000;
}
#TopCompany table tr th,
#TopCompany table tr td {
	padding: 20px;
}
#TopCompany h2 {
	margin-bottom: 30px;
}
/* 1240 */
@media (max-width: 1240px) {
	#TopCompany header h1 {
		font-size: max(4.839vw, 42px); //60px;
		margin-bottom: max(6.452vw, 56px); //80px;
	}
	#TopCompany table {
		margin-bottom: max(4.839vw, 42px); //60px;
	}
	#TopCompany table tr th,
	#TopCompany table tr td {
		padding: max(1.613vw, 14px); //20px;
	}
	#TopCompany h2 {
		margin-bottom: max(2.419vw, 21px); //30px;
	}
}
/* 580 */
@media (max-width: 580px) {
	#TopCompany table tr th {
		display: block;
		text-align: left;
		padding-bottom: 0;
	}
	#TopCompany table tr td {
		display: block;
	}
}

/*---------------------------------------------*/
/* トップページ -> お知らせ */
/*---------------------------------------------*/
#TopNews header h1 {
	color: #00214c;
	font-size: 60px;
	font-weight: bold;
	text-align: center;
	margin-bottom: 80px;
}
#TopNews ul.news {
	max-width: 900px;
	background: #fff;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 40px;
	border-top: 1px solid #aaa;
}
#TopNews ul.news li {
	border-bottom: 1px solid #aaa;
	padding: 20px 15px;
	display: flex;
	flex-wrap: wrap;
	gap: 10px 0;
}
#TopNews ul.news li time {
	margin-right: 60px;
}
#TopNews ul.news li p {
	flex: 1;
}
/* 1240 */
@media (max-width: 1240px) {
	#TopNews header h1 {
		font-size: max(4.839vw, 42px); //60px;
		margin-bottom: max(6.452vw, 56px); //80px;
	}
	#TopNews ul.news {
		margin-bottom: max(3.226vw, 28px); //40px;
	}
	#TopNews ul.news li {
		padding: 20px 15px;
	}
	#TopNews ul.news li time {
		margin-right: max(4.839vw, 42px); //60px;
	}
}
/* 580 */
@media (max-width: 580px) {
	#TopNews ul.news li time {
		margin-right: 0;
		width: 100%;
	}
	#TopNews.pd_std {
		padding-bottom: 80px;
	}
}

/*--------------------------------------------------------------*/
/* トップページ -> FAQ */
/*--------------------------------------------------------------*/
#TopFaq {
	background: #e6e5d8;
}
#TopFaq header h1 {
	color: #00214c;
	font-size: 60px;
	font-weight: bold;
	text-align: center;
	margin-bottom: 80px;
}
.qa_lists dl:last-child {
	margin-bottom: 0;
}
.qa_lists dl {
	background: #fff;
	margin-bottom: 16px;
}
.qa_lists dl dt {
	font-size: 18px;
	font-weight: bold;
	width: 100%;
	line-height: 1.2;
	padding: 32px 70px 28px 25px;
	position: relative;
	cursor: pointer;
}
.qa_lists dl dt:hover {
	background: #fbfbfb;
}
.qa_lists dl dt.is-open .text,
.qa_lists dl dt:hover .text {
	background: #eb7077;
	color: #fff;
}
.qa_lists dl dt span.qq {
	font-size: 24px;
	color: #00214c;
	position: absolute;
	top: 26px;
	left: 30px;
}
.qa_lists dl dt span.q_txt {
	margin-left: 50px;
	display: block;
	line-height: 1.4;
}
.qa_lists dl dd {
	padding: 32px 70px 28px 75px;
	background: #fdfdfd;
	position: relative;
}
.qa_lists dl dd span.aa {
	font-size: 24px;
	font-weight: bold;
	color: #ea7280;
	position: absolute;
	top: 26px;
	left: 30px;
}
.qa_lists dl dd p.txt {
	font-size: 18px;
}
.qa_lists dl dt.is-close + dd {
	display: none;
}
.qa_lists dl dt.is-open + dd {
	display: block;
}
.qa_lists dl dt::after {
	display: block;
	content: '';
	position: absolute;
	top: 50%;
	right: 30px;
	width: 20px;
	height: 4px;
	background: #00214c;
	-webkit-transition-property: all;
	transition-property: all;
	-webkit-transition-duration: .6s;
	transition-duration: .6s;
	-webkit-transition-delay: 0;
	transition-delay: 0;
	-webkit-transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
	transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
	transform: rotate(-180deg);
}
.qa_lists dl dt.is-close:not(.is-open)::after,
.qa_lists dl dt.is-open::after {
	transform: rotate(-90deg);
}
.qa_lists dl dt.is-close.is-open::after {
	transform: rotate(-180deg);
}
.qa_lists dl dt::before {
	display: block;
	content: '';
	position: absolute;
	top: 50%;
	right: 30px;
	width: 20px;
	height: 4px;
	background: #00214c;
	-webkit-transition-property: all;
	transition-property: all;
	-webkit-transition-duration: .6s;
	transition-duration: .6s;
	-webkit-transition-delay: 0;
	transition-delay: 0;
	-webkit-transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
	transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
	transform: rotate(0deg);
}
.qa_lists dl dt.is-close:not(.is-open)::before,
.qa_lists dl dt.is-open::before {
	transform: rotate(180deg);
}
.qa_lists dl dt.is-close.is-open::before {
	transform: rotate(0deg);
}
/* 1240 */
@media (max-width: 1240px) {
	#TopFaq header h1 {
		font-size: max(4.839vw, 42px); //60px;
		margin-bottom: max(6.452vw, 56px); //80px;
	}
	.qa_lists dl dt {
		font-size: max(1.452vw, 16px); //18px;
	}
	.qa_lists dl dt span.qq {
		font-size: max(1.935vw, 20px); //24px;
		top: max(2.097vw, 18px); //26px;
		left: max(2.419vw, 14px); //30px;
	}
	.qa_lists dl dt span.q_txt {
		margin-left: max(4.032vw, 40px); //50px;
	}
	.qa_lists dl dd {
		padding: max(2.581vw, 22px) max(5.645vw, 45px) max(2.258vw, 18px) max(6.048vw, 44px);
	}
	.qa_lists dl dd span.aa {
		font-size: max(1.935vw, 20px); //24px;
		top: max(2.097vw, 18px); //26px;
		left: max(2.419vw, 14px); //30px;
	}
	.qa_lists dl dd p.txt {
		font-size: max(1.452vw, 16px); //18px;
	}
}
/* 580 */
@media (max-width: 580px) {
	#Faq div.wrap {
		padding-top: 30px;
	}
	.qa_lists dl dt {
		padding: 22px 45px 18px 5px;
	}
	.qa_lists dl dt::after {
		right: 12px;
	}
	.qa_lists dl dt::before {
		right: 12px;
	}
}

/*--------------------------------------------------------------*/
/* TopBlog */
/*--------------------------------------------------------------*/
#TopBlog {
	background: #f1f0e8;
}
#TopBlog header {
	background: #00214c;
	padding: 20px 20px 20px 30px;
	box-shadow: 3px 3px 3px 0px rgba(0,0,0,0.2);
}
#TopBlog header h2 {
	color: #fff;
	font-size: 30px;
	font-weight: bold;
}
#TopBlog div.list_wrap {
	background: #fff;
	padding-bottom: 80px;
	box-shadow: 3px 3px 3px 0px rgba(0,0,0,0.2);
}
#TopBlog div.list_wrap div.view_more a.btn {
	margin-top: 50px;
}
/* 1240 */
@media (max-width: 1240px) {
	#TopBlog header {
		padding: max(1.613vw, 14px) max(1.613vw, 14px) max(1.613vw, 14px) max(2.419vw, 20px);
	}
	#TopBlog header h2 {
		font-size: max(2.419vw, 21px); //30px;
	}
	#TopBlog div.list_wrap {
		padding-bottom: max(6.452vw, 56px); //80px;
	}
	#TopBlog div.list_wrap div.view_more a.btn {
		margin-top: max(4.032vw, 35px); //50px;
	}
}

/*--------------------------------------------------------------*/
/* TopContact */
/*--------------------------------------------------------------*/
#TopContact header h1 {
	color: #00214c;
	font-size: 60px;
	font-weight: bold;
	text-align: center;
	margin-bottom: 80px;
}
#TopContact .content {
	max-width: 700px;
}
#TopContact table {
	width: 100%;
}
#TopContact table tr th {
	text-align: left;
	width: 200px;
}
#TopContact table tr th span.hissu {
	color: red;
}
#TopContact table tr th,
#TopContact table tr td {
	padding: 10px;
}
#TopContact div.send input {
	display: block;
	margin: 25px auto 0 auto;
}
/* wpcf7 */
#Contact ul li:last-child {
	display: flex;
	align-items: center;
}
.wpcf7 form .wpcf7-response-output {
	margin: 20px 0;
	border: 2px solid #ff0000;
	border-radius: 6px;
}
.wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.unaccepted .wpcf7-response-output, .wpcf7 form.payment-required .wpcf7-response-output {
	border-color: #ff0000;
}
.wpcf7-spinner {
	margin-top: 20px;
}
/* 1240 */
@media (max-width: 1240px) {
	#TopContact header h1 {
		font-size: max(4.839vw, 42px); //60px;
		margin-bottom: max(6.452vw, 56px); //80px;
	}
}
/* 580 */
@media (max-width: 580px) {
	#TopContact table tr th,
	#TopContact table tr td {
		display: block;
	}
	#TopContact table tr th {
		padding-bottom: 4px;
	}
	#TopContact table tr td {
		padding-top: 4px;
	}
}

/*--------------------------------------------------------------*/
/* common -> NewsList  */
/*--------------------------------------------------------------*/
ul.news_list {
	background: #fff;
}
ul.news_list > li {
	display: flex;
	flex-wrap: wrap;
	gap: 25px 5%;
	padding: 30px 35px;
}
ul.news_list > li {
	border-bottom: 1px solid #ddd;
}
ul.news_list > li figure {
	max-width: 300px;
	min-width: 250px;
	width: 30%;
}
ul.news_list > li figure img {
	display: block;
}
/* div.text */
ul.news_list > li div.text {
	flex: 1;
}
ul.news_list > li div.text div.meta {
	display: flex;
	flex-wrap: wrap;
	gap: 15px 20px;
	margin-bottom: 20px;
}
ul.news_list > li div.text div.meta time {
	font-size: 16px;
}
ul.news_list > li div.text div.meta ul.tags {
	display: flex;
	flex-wrap: wrap;
	gap: 12px 10px;
}
ul.news_list > li div.text div.meta ul.tags li a {
	display: block;
	padding: 2px 10px;
	font-size: 14px;
	font-weight: bold;
	color: #fff;
	background: #00214c;
	transition: .3s ease;
}
ul.news_list > li div.text div.meta ul.tags li a:hover {
	color: #fff!important;
	background: #378dad!important;
}
ul.news_list > li div.text h3 {
	font-size: 20px;
	font-weight: bold;
	margin-bottom: 15px;
}
ul.news_list > li div.text h3 a:hover {
	color: #3e95b4;
}
ul.news_list > li div.text p.txt {
	line-height: 1.8;
	margin-bottom: 15px;
}
ul.news_list > li div.text div.more {
	text-align: right;
}
ul.news_list > li div.text div.more a {
	display: inline-flex;
	align-items: center;
	gap: 0 8px;
	padding-right: 10px;
	transition: .3s ease;
	color: #00214c;
}
ul.news_list > li div.text div.more a i {
	font-size: 12px;
	margin-top: 4px;
	transition: .3s ease;
}
ul.news_list > li div.text div.more a:hover {
	color: #3e95b4;
}
ul.news_list > li div.text div.more a:hover i {
	transform: translateX(3px);
}
/* 1240 */
@media (max-width: 1240px) {
	ul.news_list > li {
		padding: max(2.419vw, 20px) max(2.823vw, 20px);
	}
	ul.news_list > li div.text h3 {
		font-size: max(1.613vw, 18px); //20px;
		margin-bottom: 15px;
	}
}
/* 700 */
@media (max-width: 700px) {
	ul.news_list > li figure {
		max-width: initial;
		width: 100%;
	}
	ul.news_list > li div.text {
		flex: 1;
	}
}

/*--------------------------------------------------------------*/
/* お知らせ一覧ページ #NewsList */
/*--------------------------------------------------------------*/
#NewsList nav {
	margin-bottom: 60px;
}
#NewsList nav dl {
	max-width: 800px;
	width: 100%;
	border: 2px solid #378dad;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
}
#NewsList nav dl dt {
	font-size: 18px;
	font-weight: bold;
	color: #fff;
	padding: 10px 20px;
	background: #378dad;
	display: flex;
	justify-content: center;
	align-items: center;
}
#NewsList nav dl dd {
	flex: 1;
	padding: 20px 35px;
}
#NewsList nav dl dd ul.cats {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 15px;
}
#NewsList nav dl dd ul.cats li a {
	display: block;
	padding: 2px 5px 3px 5px;
	color: #fff;
	background: #ccc;
	transition: .3s ease;
}
#NewsList nav dl dd ul.cats li a:hover {
	background: #353535!important;
}
/* 1240 */
@media (max-width: 1240px) {
	#NewsList nav {
		margin-bottom: max(4.839vw, 42px); //60px;
	}
	#NewsList nav dl dt {
		font-size: max(1.452vw, 16px); //18px;
		padding: 10px max(1.613vw, 14px); //20px;
	}
}
/* 580 */
@media (max-width: 580px) {
	#NewsList nav dl dt {
		width: 100%;
	}
	#NewsList nav dl dd {
		width: 100%;
		padding: 20px 20px;
	}
	/* ul.news_list over */
	#NewsList ul.news_list > li {
		padding-left: 0;
		padding-right: 0;
	}
}

/*--------------------------------------------------------------*/
/* お知らせ */
/*--------------------------------------------------------------*/
#NewsDetail.pd_std {
	padding-bottom: 120px;
}
ul.cat {
	display: flex;
	flex-wrap: wrap;
}
ul.cat li {
	font-size: 1.4rem;
	margin-right: 5px;
	color: #fff;
}
ul.cat li a {
	color: #fff;
}
article.post-wrap {
	max-width: 800px;
	width: 100%;
	margin: 0 auto;
}
/* header */
article.post-wrap header {
	margin-bottom: 20px;
}
article.post-wrap header h1 {
	font-size: 36px;
	line-height: 1.3;
	margin-bottom: 15px;
}
article.post-wrap header .timecat {
	margin-bottom: 40px;
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 12px 15px;
}
article.post-wrap header .timecat time {
	margin-left: 7px;
	font-size: 14px;
}
article.post-wrap header .timecat ul.cat {
	display: inline-flex;
	gap: 0 3px;
}
article.post-wrap header .timecat ul.cat li a {
	display: block;
	font-size: 14px;
	padding: 0 5px;
	background: #00214c;
	color: #fff;
}
body.is-pc article.post-wrap header .timecat ul.cat li a:hover {
	background: #378dad;
}
article.post-wrap header figure img {
	width: 100%;
}
/* entry */
article.post-wrap div.entry {
	margin-bottom: 60px;
}
article.post-wrap div.entry p {
	margin-bottom: 30px;
}
article.post-wrap div.entry a {
	color: blue;
	text-decoration: underline;
	transition: .2s ease;
}
body.is-pc article.post-wrap div.entry a:hover {
	color: orange;
	text-decoration: none;
}
article.post-wrap div.entry figure {
	display: block;
	line-height: 1;
	margin-bottom: 30px;
}
/* sns */
.sns__container {
	display: flex;
	justify-content: flex-end;
	flex-wrap: wrap;
	gap: 0 15px;
	margin-bottom: 70px;
}
body.is-pc .sns__container a:hover {
	opacity: 0.7;
}
.sns__container a i {
	font-size: 25px;
}
.sns__twitter i {
	color: #000;
}
.sns__facebook i {
	color: #3b5998;
}
.sns__line i {
	color: #1dcd00;
}
/* h1～h6 */
article.post-wrap div.entry h1,
article.post-wrap div.entry h2 {
	color: #00214c;
	font-size: 24px;
	font-weight: bold;
	margin-top: 60px;
	margin-bottom: 24px;
	padding-bottom: 15px;
	border-bottom: 1px dotted #000;
}
article.post-wrap div.entry h3 {
	font-size: 22px;
	font-weight: bold;
	margin-top: 60px;
	margin-bottom: 24px;
}
article.post-wrap div.entry h4,
article.post-wrap div.entry h5,
article.post-wrap div.entry h6 {
	font-size: 20px;
	font-weight: bold;
	margin-top: 60px;
	margin-bottom: 20px;
}
article.post-wrap div.entry ul {
	list-style-type: initial;
	margin-left: 26px;
	margin-top: 40px;
	margin-bottom: 40px;
}
/* blockquote */
article.post-wrap div.entry blockquote {
	position: relative;
	padding: 30px 30px 30px 30px;
	background: #f8f8f8;
	border-left: 3px solid #00214c;
	margin-top: 40px;
	margin-bottom: 30px;
}
article.post-wrap div.entry blockquote::before {
	font-family: 'Font Awesome 6 Free';
	font-weight: bold;
	font-size: 16px;
	color: #00214c;
	content: "\f10d";
	display: block;
	width: 24px;
	height: 21px;
	position: absolute;
	top: 5px;
	left: 14px;
}
article.post-wrap div.entry blockquote p {
	padding: 0;
	margin: 0;
	line-height: 1.7;
}
article.post-wrap div.entry cite {
	display: block;
	text-align: right;
	font-size: 14px;
	padding-top: 2px;
	margin-top: -30px;
	margin-bottom: 30px;
}
article.post-wrap div.entry cite::before {
	content: '\5F15\7528\FF1A';
}
article.post-wrap div.entry cite a {
	color: #6ACEFF;
}
body.is-pc article.post-wrap div.entry cite a:hover {
	color: orange;
}
/* ul */
article.post-wrap div.entry ul {
	list-style: disc;
}
article.post-wrap div.entry ul li {
	margin-bottom: 5px;
}
article.post-wrap div.entry ul li::marker {
	color: #00214c;
}
/* ol */
article.post-wrap div.entry ol {
	list-style: revert;
	margin-left: 26px;
	margin-top: 40px;
	margin-bottom: 40px;
}
article.post-wrap div.entry ol li {
	padding-bottom: 8px;
	margin-bottom: 8px;
	border-bottom: 1px dotted #00214c;
}
article.post-wrap div.entry ol li::marker {
	font-weight: bold;
	color: #00214c;
}
/* hr */
article.post-wrap div.entry hr {
	border-top: none;
	border-bottom: 1px dotted #00214c;
	margin: 30px 0;
}
/* wp-block-columns */
.wp-block-columns {
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 20px;
}
/* wp-block-button */
.wp-block-button {
	display: inline-block;
	margin: 10px;
}
.wp-block-button .wp-block-button__link {
	display: block;
	position: relative;
	max-width: 200px;
	width: 100%;
	text-align: center;
	margin: 20px;
	padding: 10px;
	color: #fff;
	background: #c1007b;
	border: none;
	font-size: 1.6rem;
	transition: 0.3s all;
}
.wp-block-button .wp-block-button__link::after {
	position: absolute;
	top: 50%;
	right: 15px;
	-webkit-transform: translate(0, -50%);
	transform: translate(0, -50%);
	color: #fff;
	font-family: "Ionicons";
	content: '\f488';
	font-size: 1.4rem;
	transition: 0.3s all;
}
.wp-block-button .wp-block-button__link:hover {
	background: #c1007b;
	color: #fff;
	box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.4);
	opacity: 0.9;
}
.wp-block-button .wp-block-button__link:hover::after {
	right: 10px;
}
/* table */
article.post-wrap div.entry table {
	width: 100%;
	margin-top: 40px;
	margin-bottom: 40px;
}
article.post-wrap div.entry table th {
	color: #fff;
	background: #00214c;
	text-align: center;
}
article.post-wrap div.entry table th {
	padding: 15px;
	border: 1px solid #fff;
}
article.post-wrap div.entry table td {
	padding: 15px;
	border: 1px solid #00214c;
}
/* gallery */
article.post-wrap div.entry ul.blocks-gallery-grid {
	list-style-type: none;
	margin: 0;
	display: flex;
	justify-content: space-between;
}
/* 1240 */
@media (max-width: 1240px) {
	#NewsDetail.pd_std {
		padding-bottom: max(9.677vw, 84px); //120px;
	}
	/* header */
	article.post-wrap header {
		margin-bottom: max(1.613vw, 14px); //20px;
	}
	article.post-wrap header h1 {
		font-size: max(2.903vw, 20px); //36px;
	}
	article.post-wrap header .timecat {
		margin-bottom: max(3.226vw, 28px); //40px;
	}
	/* h1～h6 */
	article.post-wrap div.entry h1,
	article.post-wrap div.entry h2 {
		font-size: max(1.935vw, 20px); //24px;
		margin-top: max(4.839vw, 42px); //60px;
		margin-bottom: max(1.935vw, 17px); //24px;
		padding-bottom: max(1.21vw, 11px); //15px;
	}
	article.post-wrap div.entry h3 {
		font-size: max(1.774vw, 18px); //22px;
		margin-top: max(4.839vw, 42px); //60px;
		margin-bottom: max(1.935vw, 17px); //24px;
	}
	article.post-wrap div.entry h4,
	article.post-wrap div.entry h5,
	article.post-wrap div.entry h6 {
		font-size: max(1.613vw, 16px); //20px;
		margin-top: max(4.839vw, 42px); //60px;
		margin-bottom: max(1.613vw, 14px); //20px;
	}
}
/* 580 */
@media (max-width: 580px) {
	article.post-wrap {
		padding: 0;
	}
	article.post-wrap header .timecat time {
		margin-left: 1px;
	}
	article.post-wrap div.entry table th,
	article.post-wrap div.entry table td {
		padding: 10px 15px;
	}
}

/*--------------------------------------------------------------*/
/* ページナビ */
/*--------------------------------------------------------------*/
/* table */
table.page_navi {
	margin-top: 90px;
	margin-bottom: 10px;
	margin-left: auto;
	margin-right: auto;
	max-width: 600px;
	width: 100%;
	background: #fff;
	border: none;
}
table.page_navi th,
table.page_navi td {
	border: none;
	width: calc(100%/3);
	text-align: center;
}
table.page_navi td span.txt {
	margin: 0 15px;
}
table.page_navi td div.ya a {
	transition: .3s ease;
}
body.is-pc table.page_navi td div.ya a:hover {
	color: #f39800;
}

/*--------------------------------------------------------------*/
/* pager */
/*--------------------------------------------------------------*/
.navigation {
	margin-top: 20px;
	overflow: hidden;
}
.navigation ul li:hover::before {
	position: initial;
	left: 0;
	content: "";
	border-left: none;
	height: 0;
	top: 0;
}
ul.page-numbers {
	padding: 10px 0;
	text-align: center;
	margin-top: 50px;
	display: flex;
	justify-content: center;
}
ul.page-numbers li {
	margin: 0 2.5px;
}
ul.page-numbers li span,
ul.page-numbers li a {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 36px;
	height: 36px;
	color: #000;
	border: 1px solid #E6E6E6;
	background-color: #fff;
	font-size: 16px;
	line-height: 1;
	transition: .3s ease;
}
ul.page-numbers li span {
	color: #fff;
	background-color: #00214c;
}
ul.page-numbers li span.dots {
	color: #000;
	background-color: #fff;
	border: none;
}
body.is-pc ul.page-numbers li a:hover {
	background-color: #378dad;
	color: #fff;
}
/* 768 */
@media (max-width: 768px) {
	ul.page-numbers {
		margin-top: 40px;
	}
}
/* 580 */
@media (max-width: 580px) {
	.navigation {
		margin-top: 0px;
	}
	ul.page-numbers li span,
	ul.page-numbers li a {
		width: 30px;
		height: 30px;
	}
}

/*---------------------------------------------*/
/* 404 */
/*---------------------------------------------*/
#Fn404 p.txt {
	text-align: center;
	line-height: 2.4;
}
#Fn404 p a {
	color: #37b4ec;
	text-decoration: underline;
	transition: .3s ease;
}
body.is-pc #Fn404 p a:hover {
	color: #f19700;
	text-decoration: none;
}

/*--------------------------------------------------------------*/
/* footer */
/*--------------------------------------------------------------*/
footer {
	color: #fff;
	background: #00214c;
	padding-top: 40px;
	padding-bottom: 10px;
}
footer div.flex {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	position: relative;
}
footer div.flex div.foot_left {
	width: 65%;
	display: flex;
	flex-wrap: wrap;
	gap: 30px 5%;
}
footer div.flex div.foot_left figure img {
	width: 170px;
}
footer div.flex div.foot_left address {
	font-style: normal;
	line-height: 1.7;
}
footer div.flex div.foot_left address a {
	color: #fff;
}
footer div.flex div.foot_left strong {
	margin-right: 5px;
}
footer div.flex div.foot_left .foot_contact {
	margin-top: 12px;
}
footer div.flex div.foot_left .foot_contact a {
	max-width: 300px;
	min-width: 180px;
	width: 90%;
	display: block;
	padding: 5px 20px 7px 20px;
	border: 2px solid #fff;
	text-align: center;
	color: #fff;
	transition: .3s ease;
}
body.is-pc footer div.flex div.foot_left .foot_contact a:hover {
	background: #fff;
	color: #00214c;
}
footer div.flex div.foot_right {
	width: 35%;
	position: absolute;
	right: 0;
	top: 0;
}
footer div.flex div.foot_right nav ul {
	display: flex;
	flex-direction: column;
	gap: 10px 0;
}
footer div.flex div.foot_right nav ul li {
	text-align: right;
}
footer div.flex div.foot_right nav ul li a {
	color: #fff;
}
footer div.flex div.foot_right nav ul li a:hover {
	color: #ccc;
}
footer .copy {
	margin-top: 40px;
	text-align: center;
	font-size: 14px;
}
footer .copy a {
	color: #fff;
}
footer .copy a:hover {
	color: #ccc;
}
/* 780 */
@media (max-width: 780px) {
	footer div.flex div.foot_right {
		top: initial;
		bottom: 0;
	}
}
/* 620 */
@media (max-width: 620px) {
	footer div.flex div.foot_left {
		width: 100%;
		display: flex;
		flex-wrap: wrap;
		gap: 30px 5%;
	}
	footer div.flex div.foot_left figure {
		width: 100%;
	}
	footer div.flex div.foot_left figure img {
		margin: 0 auto;
	}
	footer div.flex div.foot_left .company_info {
		width: 100%;
		text-align: center;
	}
	footer div.flex div.foot_right {
		width: 100%;
		position: initial;
		margin: 30px 0 20px 0;
	}
	footer div.flex div.foot_right nav ul li {
		text-align: center;
	}
	footer div.flex div.foot_left .foot_contact a {
		width: 80%;
		margin: 0 auto;
	}
}

