﻿@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&display=swap');
/* ***************************
icomoon
*************************** */
@font-face {
	font-family: "icomoon";
  src: url("/assets/css/fonts/icomoon.eot?le2o82");
  src: url("/assets/css/fonts/icomoon.eot?le2o82#iefix") format("embedded-opentype"), url("/assets/css/fonts/icomoon.ttf?le2o82") format("truetype"), url("/assets/css/fonts/icomoon.woff?le2o82") format("woff"), url("/assets/css/fonts/icomoon.svg?le2o82#icomoon") format("svg");
	font-weight: normal;
	font-style: normal;
	font-display: block;
}
.webservice_btn_link:after, .btn:after, .setting_head_body:after, .subnav_item_link:after, .listgnav_item_search .listgnav_item_btnbody:after, .linkicon:after, .quicklink_item_link:after, .listlnav_item_link:before {
	/* use !important to prevent issues with browser extensions that change fonts */
	font-family: "icomoon" !important;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	line-height: 1;
	text-transform: none;
	speak: none;
	/* Better Font Rendering =========== */
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}


.header {
	font-family: "Noto Sans JP", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", YuGothic, "Yu Gothic", "メイリオ", Meiryo, sans-serif;
}

.footer {
	font-family: "Noto Sans JP", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", YuGothic, "Yu Gothic", "メイリオ", Meiryo, sans-serif;
}

.header,
.footer,
.returntop {
	position: relative;
	min-width: 1000px;
}
@media only screen and (max-width: 768px) {
	.header,
	.footer,
	.returntop {
		min-width: 0;
	}
}

.header *,
.header :after,
.header :before,
.footer *,
.footer :after,
.footer :before {
	box-sizing: border-box;
}

.setting_head_btn {
	margin: 0;
	padding: 0;
	background: none;
	border: none;
	border-radius: 0;
	font: inherit;
	color: inherit;
	text-align: inherit;
	cursor: pointer;
	-webkit-appearance: none;
		 -moz-appearance: none;
					appearance: none;
}

.setting_body_btn {
	margin: 0;
	padding: 0;
	background: none;
	border: none;
	border-radius: 0;
	font: inherit;
	color: inherit;
	text-align: inherit;
	cursor: pointer;
	-webkit-appearance: none;
		 -moz-appearance: none;
					appearance: none;
}

.navtoggle_btn {
	margin: 0;
	padding: 0;
	background: none;
	border: none;
	border-radius: 0;
	font: inherit;
	color: inherit;
	text-align: inherit;
	cursor: pointer;
	-webkit-appearance: none;
		 -moz-appearance: none;
					appearance: none;
}

.listgnav_item_btn {
	margin: 0;
	padding: 0;
	background: none;
	border: none;
	border-radius: 0;
	font: inherit;
	color: inherit;
	text-align: inherit;
	cursor: pointer;
	-webkit-appearance: none;
		 -moz-appearance: none;
					appearance: none;
}

.listgnav_item_close {
	margin: 0;
	padding: 0;
	background: none;
	border: none;
	border-radius: 0;
	font: inherit;
	color: inherit;
	text-align: inherit;
	cursor: pointer;
	-webkit-appearance: none;
		 -moz-appearance: none;
					appearance: none;
}

.listgnavsub_search_input {
	margin: 0;
	padding: 0;
	background: none;
	border: none;
	border-radius: 0;
	font: inherit;
	color: inherit;
	text-align: inherit;
	-webkit-appearance: none;
		 -moz-appearance: none;
					appearance: none;
}
.listgnavsub_search_input::-ms-clear, .listgnavsub_search_input::-ms-reveal {
	display: none;
}

.listgnavsub_search_btn {
	margin: 0;
	padding: 0;
	background: none;
	border: none;
	border-radius: 0;
	font: inherit;
	color: inherit;
	text-align: inherit;
	-webkit-appearance: none;
		 -moz-appearance: none;
					appearance: none;
}
.listgnavsub_search_btn::-ms-clear, .listgnavsub_search_btn::-ms-reveal {
	display: none;
}

.spnavsearch_input {
	margin: 0;
	padding: 0;
	background: none;
	border: none;
	border-radius: 0;
	font: inherit;
	color: inherit;
	text-align: inherit;
	-webkit-appearance: none;
		 -moz-appearance: none;
					appearance: none;
}
.spnavsearch_input::-ms-clear, .spnavsearch_input::-ms-reveal {
	display: none;
}

.spnavsearch_btn {
	margin: 0;
	padding: 0;
	background: none;
	border: none;
	border-radius: 0;
	font: inherit;
	color: inherit;
	text-align: inherit;
	-webkit-appearance: none;
		 -moz-appearance: none;
					appearance: none;
}
.spnavsearch_btn::-ms-clear, .spnavsearch_btn::-ms-reveal {
	display: none;
}

.header_bottom,
.is-headerFixed .header_bottom {
	z-index: 30 !important;
}

.setting_body {
	z-index: 31 !important;
}

.setting_body_item {
	line-height: 1;
}

.returntop_inner.is-fixed {
	z-index: 10 !important;
}

/* ***************************
base
*************************** */
.base_head {
	height: 173px;
}


.base_head:has(.header) {
	height: auto;
}

@media only screen and (max-width: 768px) {
	.base_head {
		height: 50px;
	}
}

.base_foot {
	display: none;
}
body:has(.local_navi.done) .base_foot {
	display: block;
}

/* ***************************
header
*************************** */
@media only screen and (max-width: 768px) {
	.header {
		position: relative;
		padding-top: 50px;
		z-index: 11;
	}
}

.header_top {
	background-color: #0069b7;
}
@media only screen and (max-width: 768px) {
	.header_top {
		display: none;
	}
}

.header_top_inner {
	position: relative;
	display: flex;
	max-width: 1200px;
	margin: 0 auto;
	padding: 12px 8px 13px;
	align-items: center;
	justify-content: flex-end;
}

.header_bottom {
	position: relative;
	width: 100%;
	min-width: 1000px;
	background-color: #fff;
}
@media only screen and (max-width: 768px) {
	.header_bottom {
		position: fixed;
		top: 0;
		left: 0;
		min-width: 0;
		box-shadow: 0 5px 5px -2px rgba(0, 0, 0, 0.1);
	}
}

.header_bottom_inner {
	display: flex;
	max-width: 1230px;
	margin: 0 auto;
	padding: 18px 15px 0;
	justify-content: space-between;
	transition: padding-top 0.3s;
}
@media only screen and (max-width: 768px) {
	.header_bottom_inner {
		padding: 0;
	}
}

.header_bottom_left {
	margin-top: 6px;
	margin-left: 9px;
}
@media only screen and (max-width: 768px) {
	.header_bottom_left {
		display: flex;
		margin-top: 0;
		margin-left: 15px;
		align-items: center;
	}
}

@media only screen and (min-width: 769px) {
	.header_bottom_right {
		flex: 1 1;
	}
}

.is-headerFixed .header_bottom {
	position: fixed;
	top: 0;
	left: auto;
	box-shadow: 0 5px 5px -2px rgba(0, 0, 0, 0.1);
	z-index: 3;
}
.is-headerFixed .header_bottom_inner {
	padding-top: 0;
}

/* ***************************
main
*************************** */
.main {
	position: relative;
}

.main_middle {
	padding-bottom: 100px;
}
@media only screen and (max-width: 768px) {
	.main_middle {
		padding-bottom: 60px;
	}
}

.main_middle_inner {
	display: flex;
	max-width: 1210px;
	margin: auto;
	padding: 80px 15px 0;
}
@media only screen and (max-width: 768px) {
	.main_middle_inner {
		display: block;
		padding: 22px 0 0;
	}
}

.main_middle_main {
	width: 100%;
	max-width: calc(100% - 320px);
	margin-left: 40px;
	order: 2;
}
@media only screen and (max-width: 768px) {
	.main_middle_main {
		max-width: 100%;
		margin-left: 0;
		padding: 0 15px;
	}
}

.main_middle_side {
	width: 240px;
}
@media only screen and (max-width: 768px) {
	.main_middle_side {
		width: 100%;
		margin-top: 60px;
	}
}

* + .main_middle_body {
	margin-top: 50px;
}
@media only screen and (max-width: 768px) {
	* + .main_middle_body {
		margin-top: 30px;
	}
}

/* ***************************
footer
*************************** */
.footer {
	position: relative;
	margin-top: 52px;
	padding-bottom: 64px;
	overflow: hidden;
}
@media only screen and (max-width: 768px) {
	.footer {
		margin-top: 0;
	}
}
.footer:after {
	position: absolute;
	bottom: 0;
	left: 50%;
	display: block;
	width: 140%;
	height: 46px;
	margin: auto;
	background-color: #13a74a;
	border-top-left-radius: 50% 100%;
	border-top-right-radius: 50% 100%;
	content: "";
	-webkit-transform: translateX(-50%);
					transform: translateX(-50%);
}
@media only screen and (max-width: 768px) {
	.footer:after {
		width: 150%;
		height: 36px;
	}
}

.footer_inner {
	max-width: 1230px;
	margin: 0 auto;
	padding: 0 15px;
}
@media only screen and (max-width: 768px) {
	.footer_inner {
		padding: 26px 15px 0 !important;
	}
}

.footer_middle {
	margin-top: 70px;
}
@media only screen and (max-width: 768px) {
	.footer_middle {
		margin-top: 40px;
	}
}

.footer_bottom {
	margin-top: 18px;
}
@media only screen and (max-width: 768px) {
	.footer_bottom {
		margin-top: 14px;
	}
}

/* ***************************
logo
*************************** */
.logo {
	transition: -webkit-transform 0.3s;
	transition: transform 0.3s;
	transition: transform 0.3s, -webkit-transform 0.3s;
}
.is-headerFixed .logo {
	-webkit-transform: scale(0.82);
					transform: scale(0.82);
	-webkit-transform-origin: center left;
					transform-origin: center left;
}

.logo_link {
	display: block;
}
@media only screen and (max-width: 768px) {
	.logo_link {
		max-width: 75px;
	}
}

/* ***************************
navtoggle
*************************** */
.navtoggle {
	display: none;
	width: 50px;
	height: 50px;
}
@media only screen and (max-width: 768px) {
	.navtoggle {
		display: block;
	}
}

.navtoggle_btn {
	position: relative;
	width: 100%;
	height: 100%;
	padding-top: 10px;
	background-color: #0069b7;
	text-align: center;
}

.navtoggle_text {
	position: relative;
	display: block;
	margin-top: 2px;
	color: #fff;
	font-size: 0.625rem;
	line-height: 1.4;
}

.navtoggle_lines {
	position: relative;
	display: block;
	width: 26px;
	height: 16px;
	margin: auto;
}

.navtoggle_lines_item {
	position: absolute;
	right: 0;
	left: 0;
	display: inline-block;
	width: 23px;
	height: 2px;
	margin: auto;
	background-color: #fff;
	transition: -webkit-transform 0.3s;
	transition: transform 0.3s;
	transition: transform 0.3s, -webkit-transform 0.3s;
}
.navtoggle_lines_item:nth-of-type(1) {
	top: 0;
}
.navtoggle_lines_item:nth-of-type(2) {
	top: 0;
	bottom: 0;
	margin: auto;
}
.navtoggle_lines_item:nth-of-type(3) {
	bottom: 0;
}

.is-opened .navtoggle_lines_item {
	width: 26px;
	height: 3px;
}
.is-opened .navtoggle_lines_item:nth-of-type(1) {
	-webkit-transform: translateY(5px) rotate(-45deg);
					transform: translateY(5px) rotate(-45deg);
}
.is-opened .navtoggle_lines_item:nth-of-type(2) {
	background-color: transparent;
}
.is-opened .navtoggle_lines_item:nth-of-type(3) {
	-webkit-transform: translateY(-8px) rotate(45deg);
					transform: translateY(-8px) rotate(45deg);
}

/* ***************************
sitemenu
*************************** */
@media only screen and (max-width: 768px) {
	.sitemenu {
		position: absolute;
		top: auto;
		left: 0;
		display: none;
		width: 100%;
		height: calc(100vh - 50px);
		padding-bottom: 30px;
		background-color: #e2eff8;
		overflow-y: auto;
	}
}
@media only screen and (max-width: 768px) {
	.sitemenu:after {
		display: block;
		width: 100%;
		height: 50px;
		background-color: transparent;
		content: "";
	}
}

@media only screen and (max-width: 768px) {
	.sitemenu_body {
		padding-top: 21px;
	}
}
@media only screen and (max-width: 768px) {
	.sitemenu_body:after {
		position: absolute;
		bottom: auto;
		left: 0;
		display: block;
		width: 100%;
		height: 20px;
		margin-top: -10px;
		background-color: #00a63c;
		border-radius: 10px;
		content: "";
	}
}

@media only screen and (max-width: 768px) {
	.sitemenu_nav {
		padding: 0 15px;
	}
}

.sitemenu_link {
	margin-top: 17px;
}

.sitemenu_service {
	position: relative;
	padding: 21px 35px 20px 32px;
	background-color: #fff;
	z-index: 1;
}

@media only screen and (max-width: 768px) {
	.sitemenu_link,
	.sitemenu_search,
	.sitemenu_sns {
		display: block;
		padding: 0 15px;
	}
}

.sitemenu_link,
.sitemenu_search,
.sitemenu_sns,
.sitemenu_service {
	display: none;
}
@media only screen and (max-width: 768px) {
	.sitemenu_link,
	.sitemenu_search,
	.sitemenu_sns,
	.sitemenu_service {
		display: block;
	}
}

.navglobal {
	display: block;
}

/* ***************************
listgnav
*************************** */
.listgnav {
	display: flex;
	align-items: flex-end;
	justify-content: flex-end;
}
@media only screen and (max-width: 768px) {
	.listgnav {
		display: block;
	}
}

.listgnav_item {
	position: static;
	margin-top: 0;
	padding-left: 0;
}
@media only screen and (max-width: 768px) {
	.listgnav_item {
		border-bottom: 2px solid #0069b7;
	}
}
.listgnav_item:before {
	content: none;
}
@media only screen and (max-width: 768px) {
	.listgnav_item:first-child {
		border-top: 2px solid #0069b7;
	}
}
.listgnav_item + .listgnav_item {
	margin-left: 40px;
}
@media only screen and (max-width: 768px) {
	.listgnav_item + .listgnav_item {
		margin-left: 0;
	}
}

.listgnav_item_btn {
	position: relative;
	overflow: hidden;
}
@media only screen and (max-width: 768px) {
	.listgnav_item_btn {
		width: 100%;
	}
}
@media only screen and (max-width: 768px) {
	.listgnav_item_btn:before {
		right: 10px;
		width: 18px;
		height: 2px;
	}
}
.listgnav_item_btn:after {
	position: absolute;
	bottom: -8px;
	left: 0;
	display: block;
	width: 100%;
	height: 16px;
	background-color: #14a74a;
	border-radius: 8px;
	transition: -webkit-transform 0.2s;
	transition: transform 0.2s;
	transition: transform 0.2s, -webkit-transform 0.2s;
	-webkit-transform: translateY(100%);
					transform: translateY(100%);
	-webkit-transform-origin: center;
					transform-origin: center;
	content: "";
}
@media only screen and (max-width: 768px) {
	.listgnav_item_btn:after {
		right: 18px;
		left: auto;
		width: 2px;
		height: 18px;
		border-radius: 0;
		-webkit-transform: none;
						transform: none;
	}
}
@media only screen and (max-width: 768px) {
	.listgnav_item_btn:before, .listgnav_item_btn:after {
		position: absolute;
		top: 0;
		bottom: 0;
		display: block;
		margin: auto;
		background-color: #0069b7;
		content: "";
	}
}
.listgnav_item_btn:hover:after, .listgnav_item_btn.is-active:after {
	-webkit-transform: translateY(0);
					transform: translateY(0);
}
@media only screen and (max-width: 768px) {
	.listgnav_item_btn.is-active:after {
		-webkit-transform: rotate(90deg);
						transform: rotate(90deg);
	}
}

.listgnav_item_btnbody {
	position: relative;
	display: inline-block;
	padding: 17px 0 19px;
	font-size: 1.125rem;
	line-height: 1.3333333333;
	font-weight: 700;
	transition: padding 0.3s;
}
@media only screen and (max-width: 768px) {
	.listgnav_item_btnbody {
		width: 100%;
		padding: 12px 35px 15px 0;
	}
}

.listgnav_item_panel {
	position: absolute;
	top: 100%;
	left: 0;
	width: 100%;
	display: none;
	background-color: #e2eff8;
	border-radius: 0 0 8px 8px;
	overflow: hidden;
	z-index: 2;
}
@media only screen and (max-width: 768px) {
	.listgnav_item_panel {
		position: static;
		border-radius: 0;
	}
}

.listgnav_item_child {
	max-width: 1210px;
	margin: 0 auto;
	padding: 32px 15px 60px;
}
@media only screen and (max-width: 768px) {
	.listgnav_item_child {
		padding: 0;
	}
}

.listgnav_item_close {
	width: 100%;
	padding: 17px 0 19px;
	color: #fff;
	font-size: 1.125rem;
	line-height: 1.3333333333;
	font-weight: 700;
	background-color: #14a74a;
	text-align: center;
	vertical-align: bottom;
}
@media only screen and (max-width: 768px) {
	.listgnav_item_close {
		display: none;
	}
}
.listgnav_item_close:hover {
	text-decoration: underline;
}

.listgnav_item_closebody {
	position: relative;
	padding-right: 46px;
}
.listgnav_item_closebody:before {
	-webkit-transform: rotate(45deg);
					transform: rotate(45deg);
}
.listgnav_item_closebody:after {
	-webkit-transform: rotate(-45deg);
					transform: rotate(-45deg);
}
.listgnav_item_closebody:before, .listgnav_item_closebody:after {
	position: absolute;
	top: 1px;
	right: 15px;
	bottom: 0;
	width: 3px;
	height: 42px;
	margin: auto;
	background-color: #fff;
	content: "";
}

.listgnavsub {
	display: flex;
}
@media only screen and (max-width: 768px) {
	.listgnavsub {
		display: block;
	}
}

.listgnavsub_title {
	display: flex;
	margin-right: 50px;
	flex-direction: column;
	flex-basis: 260px;
}
@media only screen and (max-width: 768px) {
	.listgnavsub_title {
		display: block;
		margin-right: 0;
		padding-bottom: 12px;
		border-bottom: 1px solid #0069b7;
	}
}

.listgnavsub_title_text {
	color: #0069b7;
	font-size: 1.875rem;
	line-height: 1.4;
	font-weight: 500;
}
@media only screen and (max-width: 768px) {
	.listgnavsub_title_text {
		display: none;
	}
}

.listgnavsub_title_link {
	display: flex;
	margin-top: 12px;
}
@media only screen and (max-width: 768px) {
	.listgnavsub_title_link {
		display: block;
		margin-top: 8px;
	}
}

.listgnavsub_link {
	margin: 12px 0 0;
	flex-basis: calc(100% - 310px);
}
@media only screen and (max-width: 768px) {
	.listgnavsub_link {
		display: block;
		margin-top: 0;
		margin-left: 33px;
	}
}

@media only screen and (max-width: 768px) {
	.listgnav_item_search {
		display: none;
	}
}
.listgnav_item + .listgnav_item_search {
	margin-left: 28px;
}
.listgnav_item_search .listgnav_item_btnbody {
	padding: 17px 29px 19px 28px;
	font-size: 0%;
	line-height: 0;
}
.listgnav_item_search .listgnav_item_btnbody:before {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	width: 2px;
	height: 26px;
	margin: auto;
	background-color: #cdd6dd;
	content: "";
}
.listgnav_item_search .listgnav_item_btnbody:after {
	color: #0f303f;
	font-size: 25px;
	line-height: 1;
	content: "\e902";
}
.listgnav_item_search .listgnavsub_title {
	min-width: 60px;
	margin-right: 40px;
	flex-basis: auto;
}

.is-headerFixed .listgnav_item_btnbody {
	padding-top: 10px;
	padding-bottom: 10px;
}

.listgnavsub_search {
	position: relative;
	width: 100%;
	max-width: 980px;
	margin-top: 25px;
}

.listgnavsub_search_input {
	width: 100%;
	padding: 22px 80px 22px 40px;
	background-color: #fff;
	border: 2px solid #0069b7;
	border-radius: 8px;
}
.listgnavsub_search_input::-webkit-input-placeholder {
	color: #0f303f;
	font-size: 1rem;
	line-height: 1.25;
	font-weight: 700;
}
.listgnavsub_search_input::-moz-placeholder {
	color: #0f303f;
	font-size: 1rem;
	line-height: 1.25;
	font-weight: 700;
}
.listgnavsub_search_input:-ms-input-placeholder {
	color: #0f303f;
	font-size: 1rem;
	line-height: 1.25;
	font-weight: 700;
}
.listgnavsub_search_input::placeholder {
	color: #0f303f;
	font-size: 1rem;
	line-height: 1.25;
	font-weight: 700;
}

.listgnavsub_search_btn {
	position: absolute;
	top: 0;
	right: 30px;
	bottom: 0;
	width: 48px;
	height: 48px;
	margin: auto;
	background-image: url(/assets/img/icon-search.png);
	background-repeat: no-repeat;
	background-size: contain;
	text-indent: -9999px;
	cursor: pointer;
}

/* ***************************
subnav
*************************** */
.subnav {
	display: flex;
	flex-wrap: wrap;
	margin: 0 -15px;
	padding-left: 0;
}
@media only screen and (max-width: 768px) {
	.subnav {
		display: block;
		margin: 0;
	}
}

.subnav_item {
	display: flex;
	width: 50%;
	margin-top: 0;
	padding: 0 15px;
}
@media only screen and (max-width: 768px) {
	.subnav_item {
		display: block;
		width: 100%;
		padding: 0;
	}
}
.subnav_item:before {
	content: none;
}

.subnav_item_link {
	position: relative;
	display: flex;
	width: 100%;
	min-height: 56px;
	padding: 5px 25px 5px 0;
	align-items: center;
	color: #0f303f;
	font-size: 1rem;
	line-height: 1.375;
	font-weight: 700;
	border-bottom: 1px solid #0069b7;
}
@media only screen and (max-width: 768px) {
	.subnav_item_link {
		min-height: 0;
		padding: 11px 30px 12px 0;
		font-size: 1rem;
		line-height: 1.4285714286;
		font-weight: 400;
	}
}
@media only screen and (min-width: 769px) {
	.subnav_item_link:hover {
		text-decoration: underline;
	}
}
.subnav_item_link:hover, .subnav_item_link:visited, .subnav_item_link:focus {
	color: #0f303f;
}
.subnav_item_link:after {
	position: absolute;
	top: 4px;
	right: 0;
	bottom: 0;
	width: 11px;
	height: 18px;
	margin: auto;
	color: #0069b7;
	font-size: 18px;
	line-height: 1;
	content: "\e900";
	transition: right 0.3s;
	-webkit-transform: translate3d(0, 0, 0);
					transform: translate3d(0, 0, 0);
}
@media only screen and (max-width: 768px) {
	.subnav_item_link:after {
		top: 0;
		right: 10px;
		height: 14px;
		font-size: 14px;
	}
}
.subnav_item_link:hover:after {
	text-decoration: underline;
}
.subnav_item_link:hover:after {
	text-decoration: none;
}
@media only screen and (min-width: 769px) {
	.subnav_item_link:hover:after {
		right: -10px;
	}
}

a.subnav_item_link[target="_blank"]:after {
	content: none;
}
.subnav_item_link .ic_window {
	position: absolute;
	top: 4px;
	right: 0;
	bottom: 0;
	margin: auto;
}
@media only screen and (max-width: 768px) {
	.subnav_item_link .ic_window {
		top: 0;
		right: 8px;
	}
}
.subnav_item_link .ic_window:after {
	margin-left: 0;
	font-size: 18px;
	vertical-align: top;
}
@media only screen and (max-width: 768px) {
	.subnav_item_link .ic_window:after {
		font-size: 14px;
	}
}

@media only screen and (max-width: 768px) {
	.subnav_item:last-of-type .subnav_item_link {
		border-bottom: none;
	}
}

/* ***************************
headerlink
*************************** */
.headerlink {
	display: flex;
	align-items: center;
}

.headerlink_item {
	margin-top: 0;
	padding-left: 0;
}
.headerlink_item:before {
	content: none;
}
.headerlink_item + .headerlink_item {
	margin-left: 26px;
}

.headerlink_link {
	color: #fff;
	font-size: 0.75rem;
	line-height: 1;
	font-weight: 700;
}
.headerlink_link:hover, .headerlink_link:visited, .headerlink_link:focus {
	color: #fff;
}

/* ***************************
setting
*************************** */
.setting {
	margin-left: 32px;
}

.setting_head_btn {
	position: relative;
	padding-right: 3px;
}
.setting_head_btn:before {
	position: absolute;
	bottom: -10px;
	right: 0;
	display: block;
	width: 100%;
	height: 100%;
	content: "";
}

.setting_head_body {
	position: relative;
	color: #fff;
	font-size: 0.75rem;
	line-height: 1;
	font-weight: 700;
}
.setting_head_body:after {
	display: inline-block;
	margin-left: 6px;
	color: #fff;
	font-size: 10px;
	line-height: 1;
	content: "\e900";
	-webkit-transform: rotate(90deg);
					transform: rotate(90deg);
}

.setting_body {
	position: absolute;
	top: 100%;
	right: 4px;
	padding-top: 4px;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.3s, visibility 0.3s;
	z-index: 1;
}
.setting_body[aria-hidden=false] {
	opacity: 1;
	visibility: visible;
}

.setting_body_item {
	margin-top: 0;
	padding-left: 0;
	border-radius: 8px 8px 0 0;
	overflow: hidden;
}
.setting_body_item + .setting_body_item {
	border-radius: 0 0 8px 8px;
	border-top: 2px solid #cdd6dd;
}
.setting_body_item:before {
	content: none;
}

.setting_body_btn {
	width: 100%;
	padding: 14px 30px;
	color: #fff;
	font-size: 1rem;
	line-height: 1.3125;
	font-weight: 700;
	background-color: #0069b7;
	text-align: center;
}
.setting_body_btn:hover {
	text-decoration: underline;
}

.setting_body_btnbody {
	position: relative;
}

/* ***************************
servicelink
*************************** */
.servicelink {
	display: flex;
	margin-top: 0;
	margin-right: 10px;
	align-items: center;
	justify-content: flex-end;
}
@media only screen and (max-width: 768px) {
	.servicelink {
		display: none;
	}
}

.servicelink_item {
	margin-top: 0;
	padding-left: 0;
	line-height: 1;
}
.servicelink_item:before {
	content: none;
}
.servicelink_item + .servicelink_item {
	margin-left: 16px;
}

.servicelink_item_border {
	position: relative;
	padding-left: 12px;
}
.servicelink_item_border:before {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	width: 2px;
	height: 26px;
	margin: auto;
	background-color: #cdd6dd;
	content: "";
}
.servicelink_item + .servicelink_item_border {
	margin-left: 22px;
}

.servicelink_link:after {
	content: none;
}
@media only screen and (min-width: 769px) {
	.servicelink_link:hover {
		opacity: 0.7;
	}
}

/* ***************************
snslink
*************************** */
.snslink {
	display: flex;
	align-items: center;
	justify-content: center;
}

.snslink_item {
	position: relative;
	margin-top: 0;
	padding-left: 0;
}
.snslink_item:before {
	content: none;
	border-radius: 0;
}
.snslink_item + .snslink_item {
	padding-left: 45px;
}
.snslink_item + .snslink_item:before {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 25px;
	width: 1px;
	height: 39px;
	margin: auto;
	background-color: #0069b7;
	content: "";
}

.snslink_link:after {
	content: none;
}
@media only screen and (max-width: 768px) {
	.snslink_link img {
		max-width: 100%;
		width: 36px;
		height: auto;
	}
}
@media only screen and (min-width: 769px) {
	.snslink_link:hover {
		opacity: 0.7;
	}
}

/* ***************************
spnavlink
*************************** */
.spnavlink_item {
	padding-left: 0;
}
.spnavlink_item:before {
	content: none;
}
.spnavlink_item + .spnavlink_item {
	margin-top: 10px;
}

.spnavlink_link {
	color: #0f303f;
	font-size: 1rem;
	line-height: 1.4285714286;
	font-weight: 700;
}
.spnavlink_link:hover, .spnavlink_link:visited, .spnavlink_link:focus {
	color: #0f303f;
}

/* ***************************
spnavsearch
*************************** */
.spnavsearch {
	position: relative;
	width: 100%;
}

.spnavsearch_form {
	position: relative;
	width: 100%;
}

.spnavsearch_input {
	width: 100%;
	padding: 7px 55px 7px 29px;
	background-color: #fff;
	border: 1px solid #0f303f;
	border-radius: 8px;
}
@media only screen and (max-width: 768px) {
	.spnavsearch_input {
		padding-top: 13px;
		padding-bottom: 12px;
	}
}
.spnavsearch_input::-webkit-input-placeholder {
	color: #0f303f;
	font-size: 1rem;
	line-height: 1.2857142857;
}
.spnavsearch_input::-moz-placeholder {
	color: #0f303f;
	font-size: 1rem;
	line-height: 1.2857142857;
}
.spnavsearch_input:-ms-input-placeholder {
	color: #0f303f;
	font-size: 1rem;
	line-height: 1.2857142857;
}
.spnavsearch_input::placeholder {
	color: #0f303f;
	font-size: 1rem;
	line-height: 1.2857142857;
}

.spnavsearch_btn {
	position: absolute;
	top: 0;
	right: 15px;
	bottom: 0;
	width: 33px;
	height: 33px;
	margin: auto;
	background-image: url(/assets/img/icon-search.png);
	background-repeat: no-repeat;
	background-size: contain;
	text-indent: -9999px;
	cursor: pointer;
}

/* ***************************
spwebservice
*************************** */
.spwebservice {
	position: relative;
}

.spwebservice_head {
	color: #0f303f;
	font-size: 1.1428571429rem;
	line-height: 1.4375;
	font-weight: 700;
	text-align: center;
}

.spwebservice_item {
	padding: 14px 0 10px;
}
.spwebservice_item + .spwebservice_item {
	margin-top: 8px;
	padding-top: 22px;
	border-top: 1px solid #ddd;
}

/* ***************************
footernav
*************************** */
.footernav_list {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
@media only screen and (max-width: 768px) {
	.footernav_list {
		margin: 0;
		justify-content: flex-start;
	}
}

.footernav_item {
	position: relative;
	margin-top: 0;
	padding: 5px 0 5px 22px;
}
@media only screen and (max-width: 768px) {
	.footernav_item {
		width: 33.33333%;
		padding-top: 10px;
		padding-right: 10px;
		padding-bottom: 10px;
	}
}
@media only screen and (max-width: 540px) {
	.footernav_item {
		width: 50%;
	}
}
.footernav_item:before {
	position: absolute;
	top: 0.75em;
	left: 0;
	width: 18px;
	height: 18px;
	background-color: transparent;
	background-image: url(/assets/img/icon-arrow.svg);
	background-repeat: no-repeat;
	background-size: 100% 100%;
	border-radius: 0;
	content: "";
}
@media only screen and (max-width: 768px) {
	.footernav_item:before {
		top: 1.1em;
		width: 17px;
		height: 17px;
	}
}
_::-webkit-full-page-media, _:future, :root .footernav_item:before {
	top: 0.7em;
}
@media only screen and (max-width: 768px) {
	_::-webkit-full-page-media, _:future, :root .footernav_item:before {
		top: 1em;
	}
}
.footernav_item + .footernav_item {
	margin-left: 26px;
}
@media only screen and (max-width: 768px) {
	.footernav_item + .footernav_item {
		margin-left: 0;
	}
}

.footernav_link {
	font-size: 1rem;
	line-height: 1.875;
	font-weight: 700;
	text-decoration: none;
}
@media only screen and (max-width: 768px) {
	.footernav_link {
		font-size: 1rem;
		line-height: 1.9285714286;
	}
}
@media only screen and (min-width: 769px) {
	.footernav_link:hover {
		text-decoration: underline;
	}
}

/* ***************************
footerlink
*************************** */
.footerlink {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
@media only screen and (max-width: 768px) {
	.footerlink {
		justify-content: flex-start;
	}
}

.footerlink_item {
	position: relative;
	padding: 0 18px;
	margin: 5px 0 4px -1px;
}
@media only screen and (max-width: 768px) {
	.footerlink_item {
		width: 33.33333%;
		padding: 8px 10px 7px 0;
	}
}
@media only screen and (max-width: 540px) {
	.footerlink_item {
		width: 50%;
	}
}
.footerlink_item:first-child {
	padding-left: 0;
}
.footerlink_item:last-child {
	padding-right: 0;
}
.footerlink_item:before {
	content: none;
}
.footerlink_item + .footerlink_item:before {
	position: absolute;
	top: 0.25em;
	left: 0;
	width: 2px;
	height: 18px;
	background-color: #0f303f;
	content: "";
}
@media only screen and (max-width: 768px) {
	.footerlink_item + .footerlink_item:before {
		content: none;
	}
}

.footerlink_link {
	color: #0f303f;
	font-size: 1rem;
	line-height: 1.5;
	font-weight: 700;
	text-decoration: none;
}
@media only screen and (max-width: 768px) {
	.footerlink_link {
		font-size: 1rem;
		line-height: 1.4285714286;
	}
}
@media only screen and (min-width: 769px) {
	.footerlink_link:hover {
		text-decoration: underline;
	}
}
.footerlink_link:hover, .footerlink_link:visited, .footerlink_link:focus {
	color: #0f303f;
}

/* ***************************
returntop
*************************** */
.returntop {
	position: relative;
	height: 50px;
	background-color: #e2eff8;
}

.returntop_inner {
	position: absolute;
	top: 20px;
	right: calc(50% - 590px);
	max-width: 1210px;
	margin: 0;
	padding: 0;
	z-index: 1;
}
@media only screen and (max-width: 1240px) {
	.returntop_inner {
		right: 15px;
	}
}
.returntop_inner.is-fixed {
	position: fixed;
	top: auto;
	bottom: 30px;
}

.returntop_link {
	display: block;
	width: 60px;
	height: 60px;
	margin-left: auto;
	font-size: 0%;
	line-height: 0;
	background-color: #0069b7;
	background-image: url(/assets/img/btn-top.png);
	background-position: 15px 15px;
	background-repeat: no-repeat;
	background-size: 30px 30px;
	border-radius: 8px;
	transition: background-position 0.3s;
}
@media only screen and (max-width: 768px) {
	.returntop_link {
		width: 50px;
		height: 50px;
		background-position: 10px 10px;
	}
}
@media only screen and (min-width: 769px) {
	.returntop_link:hover {
		background-position: 15px 9px;
	}
}

/* ***************************
copyright
*************************** */
.copyright {
	display: block;
	font-size: 0.875rem;
	line-height: 1.7142857143;
	text-align: center;
}
@media only screen and (max-width: 768px) {
	.copyright {
		font-size: 0.8571428571rem;
		line-height: 1.5;
	}
}

/* ***************************
btn
*************************** */
.btn {
	position: relative;
	display: inline-flex;
	padding: 15px 45px 17px 35px;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-size: 1rem;
	line-height: 1.5;
	font-weight: 700;
	background-color: #0069b7;
	border-radius: 8px;
	text-align: center;
}
@media only screen and (max-width: 768px) {
	.btn {
		font-size: 1rem;
		line-height: 1.4285714286;
	}
}
.btn:hover, .btn:visited, .btn:focus {
	color: #fff;
}
.btn:after {
	position: absolute;
	top: 0;
	right: 25px;
	bottom: 0;
	width: 10px;
	height: 16px;
	margin: auto;
	color: #fff;
	font-size: 16px;
	line-height: 1;
	content: "\e900";
	transition: right 0.3s;
	-webkit-transform: translate3d(0, 0, 0);
					transform: translate3d(0, 0, 0);
}
@media only screen and (max-width: 768px) {
	.btn:after {
		right: 10px;
		height: 14px;
		font-size: 14px;
	}
}
.btn:hover:after {
	text-decoration: underline;
}
.btn:hover:after {
	text-decoration: none;
}
@media only screen and (min-width: 769px) {
	.btn:not(.btn.btn_anchor):hover:after {
		right: 10px;
	}
}

a.btn[target="_blank"]:after {
	content: none;
}
.btn .ic_window {
	position: absolute;
	top: 0;
	right: 12px;
	bottom: 0;
	margin: auto;
}
.btn .ic_window:after {
	margin-left: 0;
	color: #fff;
	font-size: 18px;
	vertical-align: top;
}
@media only screen and (max-width: 768px) {
	.btn .ic_window:after {
		font-size: 14px;
	}
}

.btn_body {
	position: relative;
}

.btn_mid {
	max-width: 290px;
}
@media only screen and (max-width: 768px) {
	.btn_mid {
		padding: 13px 35px 15px;
	}
}
@media only screen and (max-width: 768px) {
	.btn_mid:after {
		right: 13px;
		font-size: 14px;
	}
}

.btn_header {
	min-height: 54px;
	padding: 7px 35px 8px;
}
@media only screen and (max-width: 768px) {
	.btn_header {
		display: block;
		max-width: 100%;
		min-height: 0;
		padding: 0 30px 0 0;
		color: #0f303f;
		background-color: transparent;
		font-size: 1rem;
		line-height: 1.4285714286;
		text-align: left;
	}
}
@media only screen and (max-width: 768px) {
	.btn_header:hover, .btn_header:visited, .btn_header:focus {
		color: #0f303f;
	}
}
@media only screen and (max-width: 768px) {
	.btn_header:after {
		color: #0069b7;
	}
}
.btn_header:hover:after {
	text-decoration: underline;
}
.btn_header:hover:after {
	text-decoration: none;
}

.btn_strong {
	background-color: #dc000c;
}
.btn_strong:after {
	color: #fff;
}
.btn_strong .ic_window:after {
	color: #fff;
}

.btn_weak {
	color: #0f303f;
	background-color: #fff;
	border: 2px solid #0f303f;
}
.btn_weak:hover, .btn_weak:visited, .btn_weak:focus {
	color: #0f303f;
}
.btn_weak:after {
	color: #0f303f;
}
.btn_weak .ic_window:after {
	color: #0f303f;
}

.btn_megaphone {
	padding: 24px 72px 24px 54px;
	font-size: 1.5rem;
	line-height: 1.75;
}
@media only screen and (max-width: 768px) {
	.btn_megaphone {
		padding: 14px 25px 15px 5px;
		font-size: 1.2857142857rem;
		line-height: 1.4444444444;
	}
}
.btn_megaphone .btn_body:before {
	width: 54px;
	min-width: 54px;
	height: 45px;
	margin-top: -6px;
	margin-right: 16px;
	margin-left: -8px;
	background-image: url(/assets/img/icon-megaphone.png);
}
@media only screen and (max-width: 768px) {
	.btn_megaphone .btn_body:before {
		width: 32px;
		min-width: 0;
		height: 27px;
		margin-top: 0;
		margin-right: 5px;
		margin-left: 12px;
	}
}

.btn_japan {
	padding: 24px 72px 24px 54px;
	font-size: 1.5rem;
	line-height: 1.75;
}
@media only screen and (max-width: 768px) {
	.btn_japan {
		padding: 7px 25px 6px 5px;
		font-size: 1.2857142857rem;
		line-height: 1.1666666667;
		text-align: center;
	}
}
.btn_japan .btn_body:before {
	width: 46px;
	min-width: 46px;
	height: 48px;
	margin-top: -6px;
	margin-right: 16px;
	margin-left: 20px;
	background-image: url(/assets/img/icon-japan--yellow.png);
}
@media only screen and (max-width: 768px) {
	.btn_japan .btn_body:before {
		width: 29px;
		height: 30px;
		margin-top: 0;
		margin-right: 5px;
		margin-left: 20px;
	}
}

.btn_megaphone,
.btn_japan {
	display: inline-block;
	max-width: 580px;
	color: #fff;
	background-color: #0069b7;
}
@media only screen and (max-width: 768px) {
	.btn_megaphone,
.btn_japan {
		border-radius: 5px;
	}
}
.btn_megaphone:after,
.btn_japan:after {
	right: 30px;
	width: 11px;
	height: 18px;
	font-size: 18px;
}
@media only screen and (max-width: 768px) {
	.btn_megaphone:after,
.btn_japan:after {
		right: 8px;
		height: 14px;
		font-size: 14px;
	}
}
@media only screen and (min-width: 769px) {
	.btn_megaphone:hover:after,
.btn_japan:hover:after {
		right: 20px;
	}
}
.btn_megaphone .btn_body,
.btn_japan .btn_body {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
}
.btn_megaphone .btn_body:before,
.btn_japan .btn_body:before {
	display: inline-block;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
}
@media only screen and (max-width: 768px) {
	.btn_megaphone .btn_body:before,
.btn_japan .btn_body:before {
		min-width: 0;
	}
}

.btn_application {
	max-width: 320px;
	padding: 14px 35px 11px;
	color: #0f303f;
	background-color: #fff;
	border: 2px solid #cdd6dd;
}
@media only screen and (max-width: 768px) {
	.btn_application {
		padding: 11px 35px;
	}
}
.btn_application:hover, .btn_application:visited, .btn_application:focus {
	color: #0f303f;
}
.btn_application:after {
	color: #0069b7;
}
.btn_application .btn_body:before {
	display: inline-block;
	width: 33px;
	min-width: 33px;
	height: 30px;
	margin-top: -5px;
	margin-right: 8px;
	margin-left: -11px;
	background-image: url(/assets/img/icon-application--color.png);
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	vertical-align: middle;
}
@media only screen and (max-width: 768px) {
	.btn_application .btn_body:before {
		width: 26px;
		min-width: 26px;
		height: 24px;
		margin-top: -5px;
		margin-right: 8px;
		margin-left: -9px;
	}
}

.btn_plan .btn_body:before {
	width: 50px;
	min-width: 50px;
	height: 57px;
	margin-right: 20px;
	background-image: url(/assets/img/icon-plan.png);
}
@media only screen and (max-width: 768px) {
	.btn_plan .btn_body:before {
		width: 32px;
		min-width: 32px;
		height: 37px;
		margin-right: 15px;
	}
}

.btn_payment .btn_body:before {
	width: 62px;
	min-width: 62px;
	height: 62px;
	margin-right: 14px;
	background-image: url(/assets/img/icon-payment--brown.png);
}
@media only screen and (max-width: 768px) {
	.btn_payment .btn_body:before {
		width: 38px;
		min-width: 38px;
		height: 38px;
		margin-right: 11px;
	}
}

.btn_plan,
.btn_payment {
	display: flex;
	max-width: 420px;
	min-height: 90px;
	padding: 12px 25px;
	font-size: 1.25rem;
	line-height: 1.4;
	border-color: #cdd6dd;
	justify-content: flex-start;
	text-align: left;
}
@media only screen and (max-width: 768px) {
	.btn_plan,
.btn_payment {
		min-height: 60px;
		padding: 9px 30px 9px 15px;
		font-size: 1rem;
		line-height: 1.2857142857;
	}
}
.btn_plan:after,
.btn_payment:after {
	right: 14px;
	height: 18px;
	color: #0069b7;
	font-size: 18px;
}
@media only screen and (max-width: 768px) {
	.btn_plan:after,
.btn_payment:after {
		right: 7px;
		height: 14px;
		font-size: 14px;
	}
}
@media only screen and (max-width: 768px) {
	.btn_plan .ic_window,
.btn_payment .ic_window {
		right: 6px;
	}
}
.btn_plan .ic_window:after,
.btn_payment .ic_window:after {
	color: #0069b7;
}
.btn_plan .btn_body,
.btn_payment .btn_body {
	position: relative;
	display: flex;
	align-items: center;
}
.btn_plan .btn_body:before,
.btn_payment .btn_body:before {
	display: inline-block;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
}

.newsarea .btn_weak {
	display: inline-block;
	max-width: 350px;
	padding: 13px 15px;
}
@media only screen and (max-width: 768px) {
	.newsarea .btn_weak {
		max-width: 290px;
		padding: 12px 28px 12px 15px;
	}
}

.btn_large {
	max-width: 860px;
	padding: 15px 35px 17px;
	align-items: center;
	justify-content: center;
}

/* ***************************
webservice
*************************** */
.webservice {
	display: flex;
	flex-direction: column;
	align-items: center;
}

.webservice_btn {
	display: flex;
	width: 100%;
	max-width: 290px;
}

.webservice_btn_link {
	position: relative;
	display: flex;
	width: 100%;
	min-height: 56px;
	margin: auto;
	padding: 8px 40px;
	color: #fff;
	font-size: 1rem;
	line-height: 1.25;
	font-weight: 700;
	align-items: center;
	justify-content: center;
	background-color: #0069b7;
	border-radius: 8px;
	text-align: center;
}
@media only screen and (max-width: 768px) {
	.webservice_btn_link {
		min-height: 48px;
		padding: 5px 38px 5px 5px;
		font-size: 1rem;
		line-height: 1.2142857143;
	}
}
.webservice_btn_link:before {
	position: absolute;
	top: 0;
	bottom: 0;
	display: inline-block;
	margin: auto;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
}
@media only screen and (max-width: 768px) {
	.webservice_btn_link:before {
		position: static;
	}
}
.webservice_btn_link:after {
	position: absolute;
	top: 0;
	right: 18px;
	bottom: 0;
	width: 11px;
	height: 18px;
	margin: auto;
	color: #fff;
	font-size: 18px;
	line-height: 1;
	content: "\e900";
	transition: right 0.3s;
	-webkit-transform: translate3d(0, 0, 0);
					transform: translate3d(0, 0, 0);
}
@media only screen and (max-width: 768px) {
	.webservice_btn_link:after {
		right: 14px;
		height: 16px;
		font-size: 14px;
	}
}
.webservice_btn_link:hover:after {
	right: 8px;
}
.webservice_btn_link:hover, .webservice_btn_link:visited, .webservice_btn_link:focus {
	color: #fff;
}
a.webservice_btn_link[target="_blank"]:after {
	content: none;
}
.webservice_btn_link .ic_window {
	position: absolute;
	top: 0;
	right: 17px;
	bottom: 0;
	margin: auto;
}
@media only screen and (max-width: 768px) {
	.webservice_btn_link .ic_window {
		right: 10px;
	}
}
.webservice_btn_link .ic_window:after {
	margin-left: 0;
	color: #fff;
	font-size: 18px;
	vertical-align: top;
}
@media only screen and (max-width: 768px) {
	.webservice_btn_link .ic_window:after {
		font-size: 14px;
	}
}

.webservice_btn_body {
	display: flex;
	align-items: center;
}

.webservice_btn_link_login:before {
	left: 16px;
	width: 23px;
	min-width: 23px;
	height: 30px;
	background-image: url(/assets/img/icon-lock.png);
}
@media only screen and (max-width: 768px) {
	.webservice_btn_link_login:before {
		margin: 0 10px 0 33px;
	}
}

@media only screen and (max-width: 768px) {
	.webservice_btn_link_mall {
		padding-left: 5px;
	}
}
.webservice_btn_link_mall:before {
	left: 19px;
	width: 30px;
	min-width: 30px;
	height: 31px;
	background-image: url(/assets/img/icon-mall.png);
}
@media only screen and (max-width: 768px) {
	.webservice_btn_link_mall:before {
		margin: -3px 10px 0 0;
		width: 24px;
		min-width: 24px;
		height: 25px;
	}
}

* + .webservice_link {
	margin-top: 7px;
}
@media only screen and (max-width: 768px) {
	* + .webservice_link {
		margin-top: 10px;
	}
}

.webservice_link_item {
	position: relative;
	padding-left: 30px;
}
.webservice_link_item:before {
	position: absolute;
	top: 0.4em;
	left: 5px;
	display: inline-block;
	width: 18px;
	height: 18px;
	background-color: transparent;
	background-image: url(/assets/img/icon-arrow.svg);
	background-repeat: no-repeat;
	background-size: 100% 100%;
	border-radius: 0;
	content: "";
}

@media only screen and (max-width: 768px) {
	.webservice_link_item:before {
		top: 0.25em;
		left: 7px;
		width: 17px;
		height: 17px;
	}
}
_::-webkit-full-page-media, _:future, :root .webservice_link_item:before {
	top: 0.35em;
}
@media only screen and (max-width: 768px) {
	_::-webkit-full-page-media, _:future, :root .webservice_link_item:before {
		top: 0.1em;
	}
}

.webservice_link_item + .webservice_link_item {
	margin-top: 0;
}
@media only screen and (max-width: 768px) {
	.webservice_link_item + .webservice_link_item {
		margin-top: 16px;
	}
}

.webservice_link_link {
	position: relative;
	font-size: 1rem;
	line-height: 1.875;
	font-weight: 700;
}
@media only screen and (max-width: 768px) {
	.webservice_link_link {
		font-size: 1rem;
		line-height: 1.4285714286;
	}
}

.webservice_fixed * + .webservice_link {
	margin-top: 14px;
}
.webservice_fixed .webservice_link_item {
	padding-left: 30px;
}
.webservice_fixed .webservice_link_item:before {
	left: 1px;
}

/* ***************************
display
*************************** */
@media only screen and (max-width: 768px) {
	.pc_vis {
		display: none !important;
	}
}

@media only screen and (min-width: 769px) {
	.sp_vis {
		display: none !important;
	}
}

.block {
	display: block;
}

.inline {
	display: inline;
}

.inlineblock {
	display: inline-block;
}

/* ***************************
icon
*************************** */
header .linkicon {
	font-size: 0%;
	line-height: 0;
}
header .linkicon:after {
	display: inline-block;
	font-size: 16px;
	line-height: 1;
	background-color: transparent;
	background-image: none;
	text-decoration: none;
}

header .ic_window {
	width: 20px;
	height: 18px;
}
@media only screen and (max-width: 768px) {
	header .ic_window {
		width: 16px;
		height: 14px;
	}
}
header .ic_window:after {
	margin-left: 7px;
	color: #0069b7;
	font-size: 16px;
	content: "\e901";
}
@media only screen and (max-width: 768px) {
	header .ic_window:after {
		font-size: 14px;
	}
}

header .ic_rss {
	padding-right: 5px;
}
header .ic_rss:after {
	color: #ed6008;
	content: "\e909";
}

header .ic_pdf:after {
	color: #dc000c;
	font-weight: 600;
	content: "\e90a";
}

header .ic_word:after {
	color: #0069b7;
	font-weight: 600;
	content: "\e907";
}

header .ic_excel:after {
	color: #00a63c;
	font-weight: 600;
	content: "\e90b";
}

header .ic_csv:after {
	color: #00a63c;
	font-weight: 600;
	content: "\e906";
}

header .ic_zoom {
	padding-right: 5px;
}
header .ic_zoom:after {
	color: #0069b7;
	content: "\e908";
}

header .ic_map {
	padding-right: 7px;
	background: none !important;
}
header .ic_map:after {
	margin-left: 3px;
	color: #0069b7;
	content: "\e90c";
}

header .ic_pdf,
header .ic_word,
header .ic_excel,
header .ic_csv {
	vertical-align: middle;
	background: none !important;
}
header .ic_pdf:after,
header .ic_word:after,
header .ic_excel:after,
header .ic_csv:after {
	margin-left: 5px;
	font-size: 20px;
	vertical-align: middle;
}

/* css打ち消し */
header .ic_window {
	width: initial;
	padding: 0;
	background: none !important;
	
}
@media only screen and (max-width: 768px){
	header .ic_window {
		width: initial;
		padding: 0;
		background: none !important;
	}
}

.footer_inner{
	width: auto;
}

@media only print {
	.is-headerFixed .header_bottom {
		position: relative !important;
	}
	#header.header {
		padding-bottom: 0 !important;
	}
	.returntop_inner {
		display: none;
	}
	html, body, div, span, applet, object, iframe,
	h1, h2, h3, h4, h5, h6, p, blockquote, pre,
	a, abbr, acronym, address, big, cite, code,
	del, dfn, em, img, ins, kbd, q, s, samp,
	small, strike, strong, tt, var,
	b, u, i, center,
	dl, dt, dd, ol, ul, li,
	fieldset, form, label, legend,
	table, caption, tbody, tfoot, thead, tr, th, td,
	article, aside, canvas, details, embed,
	figure, figcaption, footer, header, hgroup,
	menu, nav, output, ruby, section, summary,
	time, mark, audio, video {
		-webkit-print-color-adjust: exact;
	}
}

/* ***************************
navlocal
*************************** */
.main_middle_side {
	display: none;
}
.main_middle_side:has(.local_navi.done) {
	display: block;
}

.main_middle_side .local_navi {
	margin-bottom: 0px;
}
.navlocal_head {
	display: flex;
	margin: 0;
	padding: 0;
	color: #fff;
	font-size: 1.25rem;
	line-height: 1.6;
	font-weight: 700;
	border: none;
}
@media only screen and (max-width: 768px) {
	.navlocal_head {
		font-size: 1.1428571429rem;
		line-height: 1.375;
	}
}

.navlocal_head_link {
	display: flex;
	width: 100%;
	min-height: 80px;
	padding: 0px 20px;
	color: #fff;
	align-items: center;
	background-color: #0069b7;
}
@media only screen and (max-width: 768px) {
	.navlocal_head_link {
		min-height: 60px;
		padding: 8px 15px;
	}
}
.navlocal_head_link:hover, .navlocal_head_link:visited {
	color: #fff;
}

.listlnav_item {
	margin-top: 0;
	padding-left: 0;
}
.listlnav_item:before {
	content: none;
}
.listlnav_item + .listlnav_item {
	border-top: 1px solid #cdd6dd;
}

.listlnav_item_link {
	position: relative;
	display: block;
	padding: 15px 12px 16px 38px;
	color: #0069b7;
	font-size: 1rem;
	line-height: 1.5;
	font-weight: 700;
	background-color: #d6e6f2;
}
@media only screen and (max-width: 768px) {
	.listlnav_item_link {
		padding: 15px 15px 14px 30px;
		font-size: 1rem;
		line-height: 1.4285714286;
	}
}
.listlnav_item_link:before {
	position: absolute;
	top: 1.6em;
	left: 19px;
	width: 10px;
	height: 16px;
	color: #0069b7;
	font-size: 13px;
	line-height: 1;
	content: "\e900";
}
@media only screen and (max-width: 768px) {
	.listlnav_item_link:before {
		left: 14px;
		height: 12px;
		font-size: 12px;
	}
}

.listlnav_item_link:hover:before {
	text-decoration: underline;
}
.listlnav_item_link:hover:before {
	text-decoration: none;
}
.listlnav_item_link:hover, .listlnav_item_link:visited {
	color: #0069b7;
}
.listlnav_item_link.is-current {
	background-color: #aadef5;
}

.top_level {
	background: #e3eaf5;
	margin-bottom: 30px;
}
.top_level > li {
	border-left: #bbd0e8 6px solid;
	font-weight: bold;
}
.top_level > li > a {
	border-top: #bbd0e8 1px solid;
	display: block;
	padding: 15px 12px 16px 35px;
}
.top_level > li:first-child > a {
	border-top: none;
	padding: 15px 12px 16px 35px;
}
.top_level > li.is_active {
	border-left: #0068b6 6px solid;
	background: #89aad3;
}
.top_level > li.is_open {
	border-left: #4f97cd 6px solid;
}
.top_level > li.is_active > a {
	border-top: none;
	padding: 15px 12px 16px 35px;
	color: #0f303f;
}
.top_level > li.is_open > a {
	padding: 15px 12px 16px 35px;
}
.top_level > li:first-child.is_active > a,
.top_level > li:first-child.is_open > a {
	padding: 15px 12px 16px 35px;
}

.second_level {
	border-top: #bbd0e8 1px solid;
}
.second_level > li {
	font-weight: bold;
	margin-left: -6px;
}
.second_level > li > a {
	border-left: #4f97cd 6px solid;
	background: #e2eff8 url(/assets/img/ic_lnavi_2nd.png) no-repeat 25px 22px;
	display: block;
	padding: 15px 12px 16px 48px;
	border-top: #bbd0e8 1px solid;
}
.second_level > li.is_active > a {
	border-left: #0068b6 6px solid;
	background: #a5d3f6 url(/assets/img/ic_lnavi_2nd_active.png) no-repeat 25px 22px;
	color: #0f303f;
}
.second_level > li.is_active > a,
.second_level > li:first-child > a {
	border-top: none;
}

.third_level > li {
	font-weight: normal;
}
.third_level > li > a {
	border-left: #4f97cd 6px solid;
	background: #f2f5fa url(/assets/img/ic_lnavi_3rd.png) no-repeat 33px 25px;
	display: block;
	padding: 15px 12px 16px 53px;
	border-top: #bbd0e8 1px solid;
}
.third_level > li:first-child > a {
	padding: 0 15px 0 9px;
}
.third_level > li.is_active > a {
	border-left: #0068b6 6px solid;
	background: #a5d3f6 url(/assets/img/ic_lnavi_3rd_active.png) no-repeat 33px 25px;
	color: #0f303f;
}
.third_level > li:first-child > a {
	border-top: #bbd0e8 1px solid;
	padding: 15px 12px 16px 53px;
}
.third_level > li.is_active > a {
	border-top: none;
	padding: 15px 12px 16px 53px;
}

.fourth_level > li {
	font-weight: normal;
}
.fourth_level > li > a {
	border-left: #4f97cd 6px solid;
	background: #f4f4f4 url(/assets/img/ic_lnavi_4th.png) no-repeat 38px 25px;
	display: block;
	padding: 4px 15px 0 9px;
}
.fourth_level > li.is_active > a {
	border-left: #0068b6 6px solid;
	background: #a5d3f6 url(/assets/img/ic_lnavi_4th_active.png) no-repeat 38px 25px;
	color: #0f303f;
}
.fourth_level > li > a {
	display: block;
	border-top: #bbd0e8 1px solid;
	padding: 15px 12px 16px 58px;
}

@media only screen and (max-width: 768px) {
	.second_level > li > a {
		padding-top: 10px;
		padding-bottom: 10px;
	}
}

/* navilocal layout.css revision */ 
.top_level > li > a,
.top_level > li:first-child > a,
.second_level,
.second_level > li > a > span,
.second_level > li.is_active > a > span,
.second_level > li:first-child > a > span,
.third_level > li:first-child > a > span,
.third_level > li > a > span,
.third_level > li.is_active > a > span {
	border-top: none;
}
.second_level,
.second_level > li > a > span,
.second_level > li.is_active > a > span,
.second_level > li:first-child > a > span,
.third_level > li:first-child > a > span,
.third_level > li > a > span,
.third_level > li.is_active > a > span {
	padding: 3px 0 0;
}

/* navilocal responsive.css revision */ 
@media screen and (max-width: 767px) {
	.second_level > li.is_active > a {
    	padding: 10px 15px 10px 48px;
	}
}

/* ***************************
quicklink
*************************** */
.quicklink {
	display: none;
}

.main_middle_side:has(.local_navi.done) .quicklink{
	display: block;
}


.quicklink + .quicklink {
	margin-top: 10px;
}
@media only screen and (max-width: 768px) {
	.quicklink + .quicklink {
		margin-top: 8px;
	}
}

.quicklink_item + .quicklink_item {
	margin-top: 10px;
}
@media only screen and (max-width: 768px) {
	.quicklink_item + .quicklink_item {
		margin-top: 8px;
	}
}

@media only screen and (max-width: 768px) {
	.quicklink_body {
		padding: 0 15px;
	}
}

.quicklink_item {
	display: flex;
	min-width: 240px;
	margin: 0 auto;
	padding-left: 0;
}
.quicklink_item:before {
	content: none;
}

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

.quicklink_item_link {
	position: relative;
	display: flex;
	width: 100%;
	min-height: 72px;
	padding: 10px 30px 10px 10px ;
	color: #0f303f;
	font-size: 1rem;
	line-height: 1.5;
	font-weight: 700;
	align-items: center;
	background-color: #fff;
	border: 2px solid #cdd6dd;
	border-radius: 8px;
}
@media only screen and (max-width: 768px) {
	.quicklink_item_link {
		min-height: 60px;
		padding: 8px 30px 8px 10px;
		font-size: 1rem;
		line-height: 1.4285714286;
	}
}
.quicklink_item_link:hover, .quicklink_item_link:visited {
	color: #0f303f;
}
.quicklink_item_link:after {
	position: absolute;
	top: 0;
	right: 9px;
	bottom: 0;
	width: 10px;
	height: 14px;
	margin: auto;
	color: #0069b7;
	font-size: 14px;
	line-height: 1;
	content: "\e900";
	transition: right 0.3s;
	-webkit-transform: translate3d(0, 0, 0);
					transform: translate3d(0, 0, 0);
}
@media only screen and (max-width: 768px) {
	.quicklink_item_link:after {
		right: 7px;
		height: 14px;
		font-size: 14px;
	}
}
.quicklink_item_link:hover:after {
	text-decoration: underline;
}
.quicklink_item_link:hover:after {
	text-decoration: none;
}
@media only screen and (min-width: 769px) {
	.quicklink_item_link:hover:after {
		right: 4px;
	}
}

a.quicklink_item_link[target="_blank"]:after {
	content: none;
}
.quicklink_item_link .ic_window {
	position: absolute;
	top: 0;
	right: 8px;
	bottom: 0;
	margin: auto;
}
.quicklink_item_link .ic_window:after {
	margin-left: 0;
	font-size: 18px;
	vertical-align: top;
}
@media only screen and (max-width: 768px) {
	.quicklink_item_link .ic_window:after {
		font-size: 14px;
	}
}

.quicklink_item_body {
	display: block;
	padding-left: 10px;
}
@media only screen and (max-width: 768px) {
	.quicklink_item_body {
		padding-left: 20px;
	}
}
.quicklink_item_body:before {
	position: absolute;
	top: 0;
	bottom: 0;
	display: inline-block;
	margin: auto 0;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
}