@charset "utf-8";

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

	reset

======================================================================================================================== */
body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, form, fieldset, p, blockquote, th, td, main, figure {
	margin: 0;
	padding: 0;
}
table {
	font-size: 100%;
	font-family: inherit;
}
fieldset, img {
	border: 0;
}
img {
	vertical-align: middle;
}
address, caption, cite, code, dfn, em, th, var {
	font-style: normal;
	font-weight: normal;
}
ol, ul {
	list-style: none;
}
caption, th {
	text-align: left;
}
h1, h2, h3, h4, h5, h6 {
	font-size: 100%;
}
q:before, q:after {
	content: '';
}
abbr, acronym {
	border: 0;
}
select, input, textarea {
	font-size: 100%;
}
header,footer,nav,main,section,article,figure,aside {
	display: block;
}


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

	ベースクラス

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

/* ClearFix
============================================================================================================ */
.clearfix,
.row {
	zoom: 1;
}
.clearfix:after,
.row:after {
	content: "."; display: block; height: 0; clear: both; visibility: hidden; line-height: 0; overflow: hidden;
}


/* float
============================================================================================================ */
.fl {float: left;}
.fr {float: right;}
@media screen and (min-width: 769px), print {
	.pc_fl {float: left;}
	.pc_fr {float: right;}
}
@media screen and (max-width: 768px) {
	.sp_fl {float: left;}
	.sp_fr {float: right;}
}

/* text-align
============================================================================================================ */
.tal {text-align: left;}
.tac {text-align: center;}
.tar {text-align: right;}
@media screen and (min-width: 769px), print {
	.pc_tal {text-align: left;}
	.pc_tac {text-align: center;}
	.pc_tar {text-align: right;}
}
@media screen and (max-width: 768px) {
	.sp_tal {text-align: left;}
	.sp_tac {text-align: center;}
	.sp_tar {text-align: right;}
}


/* margin
============================================================================================================ */
.m00 {margin: 0 !important;}
/*.mb {margin-bottom: 1.5em !important;}*/
.mb00 {margin-bottom: 0 !important;}
.mb05 {margin-bottom: 5px !important;}
.mb08 {margin-bottom: 8px !important;}
.mb10 {margin-bottom: 10px !important;}
.mb15 {margin-bottom: 15px !important;}
.mb20 {margin-bottom: 20px !important;}
.mb25 {margin-bottom: 25px !important;}
.mb30 {margin-bottom: 30px !important;}
.mb35 {margin-bottom: 35px !important;}
.mb40 {margin-bottom: 40px !important;}
.mb45 {margin-bottom: 45px !important;}
.mb50 {margin-bottom: 50px !important;}
/*.mt {margin-top: 1.5em !important;}*/
.mt00 {margin-top: 0 !important;}
.mt05 {margin-top: 5px !important;}
.mt08 {margin-top: 8px !important;}
.mt10 {margin-top: 10px !important;}
.mt15 {margin-top: 15px !important;}
.mt20 {margin-top: 20px !important;}
.mt25 {margin-top: 25px !important;}
.mt30 {margin-top: 30px !important;}
.mt35 {margin-top: 35px !important;}
.mt40 {margin-top: 40px !important;}
.mt45 {margin-top: 45px !important;}
.mt50 {margin-top: 50px !important;}
@media screen and (min-width: 769px), print {
	.pc_m00 {margin: 0 !important;}
	/*.pc_mb {margin-bottom: 1.5em !important;}*/
	.pc_mb00 {margin-bottom: 0 !important;}
	.pc_mb05 {margin-bottom: 5px !important;}
	.pc_mb08 {margin-bottom: 8px !important;}
	.pc_mb10 {margin-bottom: 10px !important;}
	.pc_mb15 {margin-bottom: 15px !important;}
	.pc_mb20 {margin-bottom: 20px !important;}
	.pc_mb25 {margin-bottom: 25px !important;}
	.pc_mb30 {margin-bottom: 30px !important;}
	.pc_mb35 {margin-bottom: 35px !important;}
	.pc_mb40 {margin-bottom: 40px !important;}
	.pc_mb45 {margin-bottom: 45px !important;}
	.pc_mb50 {margin-bottom: 50px !important;}
	/*.pc_mt {margin-top: 1.5em !important;}*/
	.pc_mt00 {margin-top: 0 !important;}
	.pc_mt05 {margin-top: 5px !important;}
	.pc_mt08 {margin-top: 8px !important;}
	.pc_mt10 {margin-top: 10px !important;}
	.pc_mt15 {margin-top: 15px !important;}
	.pc_mt20 {margin-top: 20px !important;}
	.pc_mt25 {margin-top: 25px !important;}
	.pc_mt30 {margin-top: 30px !important;}
	.pc_mt35 {margin-top: 35px !important;}
	.pc_mt40 {margin-top: 40px !important;}
	.pc_mt45 {margin-top: 45px !important;}
	.pc_mt50 {margin-top: 50px !important;}
}
@media screen and (max-width: 768px) {
	.sp_m00 {margin: 0 !important;}
	/*.sp_mb {margin-bottom: 1.5em !important;}*/
	.sp_mb00 {margin-bottom: 0 !important;}
	.sp_mb05 {margin-bottom: 5px !important;}
	.sp_mb08 {margin-bottom: 8px !important;}
	.sp_mb10 {margin-bottom: 10px !important;}
	.sp_mb15 {margin-bottom: 15px !important;}
	.sp_mb20 {margin-bottom: 20px !important;}
	.sp_mb25 {margin-bottom: 25px !important;}
	.sp_mb30 {margin-bottom: 30px !important;}
	.sp_mb35 {margin-bottom: 35px !important;}
	.sp_mb40 {margin-bottom: 40px !important;}
	.sp_mb45 {margin-bottom: 45px !important;}
	.sp_mb50 {margin-bottom: 50px !important;}
	/*.sp_mt {margin-top: 1.5em !important;}*/
	.sp_mt00 {margin-top: 0 !important;}
	.sp_mt05 {margin-top: 5px !important;}
	.sp_mt08 {margin-top: 8px !important;}
	.sp_mt10 {margin-top: 10px !important;}
	.sp_mt15 {margin-top: 15px !important;}
	.sp_mt20 {margin-top: 20px !important;}
	.sp_mt25 {margin-top: 25px !important;}
	.sp_mt30 {margin-top: 30px !important;}
	.sp_mt35 {margin-top: 35px !important;}
	.sp_mt40 {margin-top: 40px !important;}
	.sp_mt45 {margin-top: 45px !important;}
	.sp_mt50 {margin-top: 50px !important;}
}

/* padding
============================================================================================================ */
.p00 {padding: 0 !important;}
/*.pb {padding-bottom: 1.3em !important;}*/
.pb00 {padding-bottom: 0 !important;}
.pb05 {padding-bottom: 5px !important;}
.pb08 {padding-bottom: 8px !important;}
.pb10 {padding-bottom: 10px !important;}
.pb15 {padding-bottom: 15px !important;}
.pb20 {padding-bottom: 20px !important;}
.pb25 {padding-bottom: 25px !important;}
.pb30 {padding-bottom: 30px !important;}
.pb35 {padding-bottom: 35px !important;}
.pb40 {padding-bottom: 40px !important;}
.pb45 {padding-bottom: 45px !important;}
.pb50 {padding-bottom: 50px !important;}
.pt00 {padding-top: 0 !important;}
.pt05 {padding-top: 5px !important;}
.pt08 {padding-top: 8px !important;}
.pt10 {padding-top: 10px !important;}
.pt15 {padding-top: 15px !important;}
.pt20 {padding-top: 20px !important;}
.pt25 {padding-top: 25px !important;}
.pt30 {padding-top: 30px !important;}
.pt35 {padding-top: 35px !important;}
.pt40 {padding-top: 40px !important;}
.pt45 {padding-top: 45px !important;}
.pt50 {padding-top: 50px !important;}
@media screen and (min-width: 769px), print {
	.pc_p00 {padding: 0 !important;}
	/*.pc_pb {padding-bottom: 1.3em !important;}*/
	.pc_pb00 {padding-bottom: 0 !important;}
	.pc_pb05 {padding-bottom: 5px !important;}
	.pc_pb08 {padding-bottom: 8px !important;}
	.pc_pb10 {padding-bottom: 10px !important;}
	.pc_pb15 {padding-bottom: 15px !important;}
	.pc_pb20 {padding-bottom: 20px !important;}
	.pc_pb25 {padding-bottom: 25px !important;}
	.pc_pb30 {padding-bottom: 30px !important;}
	.pc_pb35 {padding-bottom: 35px !important;}
	.pc_pb40 {padding-bottom: 40px !important;}
	.pc_pb45 {padding-bottom: 45px !important;}
	.pc_pb50 {padding-bottom: 50px !important;}
	.pc_pt00 {padding-top: 0 !important;}
	.pc_pt05 {padding-top: 5px !important;}
	.pc_pt08 {padding-top: 8px !important;}
	.pc_pt10 {padding-top: 10px !important;}
	.pc_pt15 {padding-top: 15px !important;}
	.pc_pt20 {padding-top: 20px !important;}
	.pc_pt25 {padding-top: 25px !important;}
	.pc_pt30 {padding-top: 30px !important;}
	.pc_pt35 {padding-top: 35px !important;}
	.pc_pt40 {padding-top: 40px !important;}
	.pc_pt45 {padding-top: 45px !important;}
	.pc_pt50 {padding-top: 50px !important;}
}
@media screen and (max-width: 768px) {
	.sp_p00 {padding: 0 !important;}
	/*.sp_pb {padding-bottom: 1.3em !important;}*/
	.sp_pb00 {padding-bottom: 0 !important;}
	.sp_pb05 {padding-bottom: 5px !important;}
	.sp_pb08 {padding-bottom: 8px !important;}
	.sp_pb10 {padding-bottom: 10px !important;}
	.sp_pb15 {padding-bottom: 15px !important;}
	.sp_pb20 {padding-bottom: 20px !important;}
	.sp_pb25 {padding-bottom: 25px !important;}
	.sp_pb30 {padding-bottom: 30px !important;}
	.sp_pb35 {padding-bottom: 35px !important;}
	.sp_pb40 {padding-bottom: 40px !important;}
	.sp_pb45 {padding-bottom: 45px !important;}
	.sp_pb50 {padding-bottom: 50px !important;}
	.sp_pt00 {padding-top: 0 !important;}
	.sp_pt05 {padding-top: 5px !important;}
	.sp_pt08 {padding-top: 8px !important;}
	.sp_pt10 {padding-top: 10px !important;}
	.sp_pt15 {padding-top: 15px !important;}
	.sp_pt20 {padding-top: 20px !important;}
	.sp_pt25 {padding-top: 25px !important;}
	.sp_pt30 {padding-top: 30px !important;}
	.sp_pt35 {padding-top: 35px !important;}
	.sp_pt40 {padding-top: 40px !important;}
	.sp_pt45 {padding-top: 45px !important;}
	.sp_pt50 {padding-top: 50px !important;}
}


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

	基本設定

======================================================================================================================== */
html {
	font-size: 62.5%;
}
body {
	background-color: #fff;
	font-size: 1.6rem;
	line-height: 1.8;
	color: #000000;
	word-wrap: break-word;
	overflow-wrap: break-word;
	-webkit-text-size-adjust: 100%;
	text-size-adjust: 100%;
}
.ua_msie body {
	font-family: "メイリオ", "Meiryo", Verdana, Arial, Helvetica, sans-serif;
}

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

table {
	border-collapse: collapse;
	border-spacing: 0;
	line-height: 1.8;
}
a[href] {
	text-decoration: underline;
	outline: none;
}
a[href].a_reverse,
.a_reverse a[href] {
	text-decoration: none;
}
@media screen and (min-width: 769px) {
	a[href]:hover {
		text-decoration: none;
	}
	a[href].a_reverse:hover,
	.a_reverse a[href]:hover {
		text-decoration: underline;
	}
}
/*
a[href^="http"],
a[href^="mailto:"] {
	display: inline-block;
	word-break: break-all;
	word-wrap : break-word;
	overflow-wrap : break-word;
}
*/
label {
	cursor: pointer;
}
input, select, textarea, button {
	max-width: 100%;
	margin: 0;
	vertical-align: middle;
	font-family: inherit;
	outline: none;
	font-size: 100%;
}

button {
	cursor: pointer;
}
iframe {
	max-width: 100%;
	vertical-align: middle;
}

.hidden {
	display: none;
}
.slick-slider * {
	outline: none;
}
@media screen and (max-width: 768px) {
	body {
		font-family: "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", Verdana, Arial, Helvetica, sans-serif;
		font-size: 1.44rem;
	}
	img {
		max-width: 100%;
		height: auto;
	}
}


/* pc / sp
============================================================================================================ */
.sp,
.sps {
	display: none !important;
}
@media screen and (min-width: 769px), print {
	.pc_break {
		position: relative;
		display: block;
		height: 0;
		overflow: hidden;
	}
	.pc_hidden {
		position: relative;
		overflow: hidden;
		display: block;
		height: 0;
	}
}
@media screen and (max-width: 768px) {
	.pc {
		display: none !important;
	}
	.sp {
		display: block !important;
	}
	img.sp, span.sp, br.sp, em.sp, strong.sp {
		display: inline !important;
	}
	td.sp, th.sp {
		display: table-cell !important;
	}
	.sp_break {
		position: relative;
		display: block;
		height: 0;
		overflow: hidden;
	}
}
@media screen and (max-width: 370px) {
	.sps {
		display: block !important;
	}
	img.sps, spsan.sps, br.sps, em.sps, strong.sps {
		display: inline !important;
	}
	.sps_non {
		display: none !important;
	}
}


/* transition
============================================================================================================ */
@media screen and (min-width: 769px) {
	a[href],
	a[href]::before,
	a[href]::after,
	button,
	.basic_trs,
	.basic_trs::before,
	.basic_trs::after,
	.basic_trs *,
	.basic_trs *::before,
	.basic_trs *::after {
		-webkit-transition: color 0.2s, background 0.2s, border 0.2s, opacity 0.2s;
		-o-transition: color 0.2s, background 0.2s, border 0.2s, opacity 0.2s;
		transition: color 0.2s, background 0.2s, border 0.2s, opacity 0.2s;
	}
}

/* font
============================================================================================================ */
.ff_en {
	font-family: 'Roboto', sans-serif;
}
.fwb {
	font-weight: bold;
}
.fwn {
	font-weight: normal;
}


/* display
============================================================================================================ */
.db {
	display: block;
}
.dib {
	display: inline-block;
}


/* hover
============================================================================================================ */
@media screen and (min-width: 769px), print {
	a.hv_wh,
	button.hv_wh,
	a .hv_wh,
	.hv_wh a {
		position: relative;
		overflow: hidden;
	}
	a.hv_wh::after,
	button.hv_wh::after,
	a .hv_wh::after,
	.hv_wh a::after {
		content: "";
		position: absolute;
		left: 0;
		right: 0;
		top: 0;
		bottom: 0;
		background-color: rgba(255,255,255,0);
		-webkit-transition: background 0.3s;
		-o-transition: background 0.3s;
		transition: background 0.3s;
		z-index: 3;
	}
	a[href].hv_wh:hover::after,
	button.hv_wh:hover::after,
	a[href]:hover .hv_wh::after,
	.hv_wh a[href]:hover::after {
		background-color: rgba(255,255,255,0.3);
	}
	a[href].hv_wh.a20:hover::after,
	button.hv_wh.a20:hover::after,
	a[href]:hover .hv_wh.a20::after,
	.hv_wh.a20 a[href]:hover::after {
		background-color: rgba(255,255,255,0.2);
	}
	a[href].hv_wh.a10:hover::after,
	button.hv_wh.a10:hover::after,
	a[href]:hover .hv_wh.a10::after,
	.hv_wh.a10 a[href]:hover::after {
		background-color: rgba(255,255,255,0.1);
	}

	a[href] .hv_op {
		-webkit-transition: opacity 0.3s;
		-o-transition: opacity 0.3s;
		transition: opacity 0.3s;
	}
	button.hv_op:hover,
	a[href].hv_op:hover,
	a[href]:hover .hv_op,
	.hv_op a[href]:hover {
		opacity: .7;
	}
	a[href].hv_op.a20:hover,
	a[href]:hover .hv_op.a20,
	.hv_op.a20 a[href]:hover {
		opacity: 0.8;
	}
	a[href].hv_op.a10:hover,
	a[href]:hover .hv_op.a10,
	.hv_op.a10 a[href]:hover {
		opacity: 0.9;
	}
}


/* target
============================================================================================================ */
.target {
	display: block;
	position: relative;
	width: 1px;
	top: -100px;
}
.target.pt {
	top: -130px;
}
@media screen and (max-width: 768px) {
	.target {
		top: -50px;
	}
	.target.pt {
		top: -70px;
	}
}



/* w
============================================================================================================ */
.w {
	position: relative;
}
.w::after {
	content: ""; display: table; clear: both;
}
@media screen and (min-width: 769px), print {
	.w {
		width: 960px;
		margin: 0 auto;
	}
	.mw {
		min-width: 1040px;
	}
	.xw {
		max-width: 1120px;
		margin: 0 auto;
		padding: 0 20px;
	}
}
@media screen and (max-width: 768px) {
}



/* spパディング
============================================================================================================ */
@media screen and (max-width: 768px) {
	.sp_pd {
		padding-left: 20px !important;
		padding-right: 20px !important;
	}
	.sp_full {
		margin-left: -20px !important;
		margin-right: -20px !important;
	}
}
@media screen and (max-width: 370px) {
	.sp_pd {
		padding-left: 15px !important;
		padding-right: 15px !important;
	}
	.sp_full {
		margin-left: -15px !important;
		margin-right: -15px !important;
	}
}

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

	モジュール

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

/* header
============================================================================================================ */
@media screen and (min-width: 769px), print {
	#header {
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		height: 140px;
		-webkit-transform: translate3d(0, 0, 0);
		-ms-transform: translate3d(0, 0, 0);
		-o-transform: translate3d(0, 0, 0);
		transform: translate3d(0, 0, 0);
		z-index: 1000;
	}
	#header::before {
		content: "";
		position: absolute;
		top: 0;
		right: 0;
		left: 0;
		height: 140px;
		background-color: #fff;
		-webkit-box-shadow: 0 0 5px rgba(0,0,0,.1);
		box-shadow: 0 0 5px rgba(0,0,0,.1);
		z-index: -1;
	}
	#header .logo {
		position: relative;
		float: left;
		padding: 25px 30px 0;
		background-color: #fff;
		z-index: 2;
	}

	#header nav {
	}
	#header nav .snav,
	#header nav .gnav {
		display: -webkit-flex;
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: flex;
		justify-content: flex-end;
	}
	#header nav .snav {
		border-bottom: 3px solid #e5e5e5;
	}
	#header nav .snav li {
		margin-left: 1px;
	}
	#header nav .snav a {
		position: relative;
		display: table;
		height: 68px;
		padding: 0 25px 0 40px;
		text-decoration: none;
		font-size: 1.3rem;
		line-height: 1.4;
		color: #fff;
		font-weight: bold;
	}
	#header nav .snav a > * {
		display: table-cell;
		vertical-align: middle;
	}
	#header nav .snav a::before {
		content: "";
		position: absolute;
		top: 50%;
		left: 18px;
		width: 10px;
		height: 10px;
		margin-top: -5px;
		border-top: 3px solid #fff;
		border-right: 3px solid #fff;
		-webkit-transform: rotate(45deg);
		-ms-transform: rotate(45deg);
		-o-transform: rotate(45deg);
		transform: rotate(45deg);
	}
	#header nav .snav .link a {
		padding-left: 45px;
		background-image: url(../img/ico_link.png);
		background-repeat: no-repeat;
		background-position: 18px;
		font-size: 1.4rem;
	}
	#header nav .snav .link a::before {
		content: none;
	}

	#header nav .gnav {
		padding-right: 10px;
	}
	#header nav .gnav > li {
		position: relative;
	}

	#header nav .gnav > li > a {
		position: relative;
		display: table;
		height: 69px;
		padding: 0 20px;
		font-weight: bold;
		font-size: 1.6rem;
		text-decoration: none;
		color: #000;
	}
	#header nav .gnav > li > a > * {
		display: table-cell;
		padding-top: 2px;
		vertical-align: middle;
	}
	#header nav .gnav > li + li > a::before {
		content: "";
		position: absolute;
		left: 0;
		top: 50%;
		height: 30px;
		margin-top: -15px;
		border-left: 1px solid #e5e5e5;
	}

	#header nav .gnav > li.contact > a > * {
		padding-left: 30px;
		background: url(../img/ico_contact.png) no-repeat 0;
	}

	#header nav .gnav > li > a::after {
		content: "";
		position: absolute;
		right: 1px;
		left: 0;
		bottom: 0;
		border-bottom: 5px solid;
		-webkit-transition: -webkit-transform .2s, opacity .2s;
		-o-transition: -o-transform .2s, opacity .2s;
		transition: transform .2s, opacity .2s;
		-webkit-transform: translateY(3px);
		-ms-transform: translateY(3px);
		-o-transform: translateY(3px);
		transform: translateY(3px);
		opacity: 0;
	}
	#header nav .gnav > li.non_link > a::after {
		content: none;
	}
	#header nav .gnav > li:hover > a::after,
	#header nav .gnav > li > a.current::after {
		-webkit-transform: translateY(0);
		-ms-transform: translateY(0);
		-o-transform: translateY(0);
		transform: translateY(0);
		opacity: 1;
	}

	#header nav .gnav .dd {
		position: absolute;
		top: 100%;
		left: 0;
		min-width: calc(100% - 1px);
		height: 0;
		overflow: hidden;
		-webkit-transition: height .3s;
		-o-transition: height .3s;
		transition: height .3s;
	}
	#header nav .gnav .dd ul {
		position: relative;
		z-index: 2;
	}
	#header nav .gnav .dd ul li + li {
		border-top: 1px solid rgba(255,255,255,.2);
	}
	#header nav .gnav .dd a {
		display: block;
		color: #fff;
		padding: 15px 20px;
		text-decoration: none;
		white-space: nowrap;
		font-size: 1.3rem;
		font-weight: bold;
		line-height: 1.4;
	}
	#header nav .gnav .dd::before {
		content: "";
		position: absolute;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		opacity: .9;
	}
}
@media screen and (min-width: 769px) {
	/* height low
	------------------------------------------------------------- */
	body.page-move #header,
	body.page-move #header nav .snav a,
	body.page-move #header nav .gnav > li > a {
		-webkit-transition: height 0.4s ease-in-out;
		-o-transition: height 0.4s ease-in-out;
		transition: height 0.4s ease-in-out;
	}
	body.page-move #header::before,
	body.page-move #header .logo {
		-webkit-transition: -webkit-transform 0.4s ease-in-out;
		-o-transition: -o-transform 0.4s ease-in-out;
		transition: transform 0.4s ease-in-out;
	}
	body.page-scroll #header {
		height: 100px;
	}
	body.page-scroll #header nav .snav a {
		height: 48px;
	}
	body.page-scroll #header nav .gnav > li > a {
		height: 49px;
	}
	body.page-scroll #header::before {
		-webkit-transform: translateY(-40px);
		-ms-transform: translateY(-40px);
		-o-transform: translateY(-40px);
		transform: translateY(-40px);
	}
	body.page-scroll #header .logo {
		-webkit-transform: translateY(-20px);
		-ms-transform: translateY(-20px);
		-o-transform: translateY(-20px);
		transform: translateY(-20px);
	}
}

@media print {
	#header {
		position: absolute;
	}
}
@media screen and (max-width: 768px) {
	#header .logo {
		position: fixed;
		top: 0;
		right: 0;
		left: 0;
		padding-left: 10px;
		background-color: #fff;
		box-shadow: 0 0 4px 0 rgba(0, 0, 0, 0.1);
		z-index: 1000;
	}
	#header .logo a {
		display: block;
		height: 50px;
		background-repeat: no-repeat;
		background-position: 0;
		-webkit-background-size: 260px;
		background-size: 260px;
	}
	#header .logo a img {
		display: none;
	}

	#header .nav_btn {
		position: fixed;
		right: 0;
		top: 0;
		z-index: 1100;
	}
	#header .nav_btn-search {
		right: 50px;
	}
	.site-portal #header .nav_btn-search a {
		background-color : #001e62 !important;
	}
	#header .nav_btn a {
		display: -webkit-flex;
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: flex;
		align-items: center;
		justify-content: center;
		width: 50px;
		height: 50px;
		background-color: #323232;
		text-decoration: none;
		font-size: 1rem;
		color: #fff;
	}

	#header nav {
		position: fixed;
		top: 0;
		right: 0;
		left: 0;
		bottom: 0;
		-webkit-transform: scale(1.05);
		-ms-transform: scale(1.05);
		-o-transform: scale(1.05);
		transform: scale(1.05);
		opacity: 0;
		pointer-events: none;
		z-index: 6000;
		-webkit-transition: opacity 0.3s linear, -webkit-transform 0.3s ease-out;
		-o-transition: opacity 0.3s linear, -o-transform 0.3s ease-out;
		transition: opacity 0.3s linear, transform 0.3s ease-out;
	}
	#header nav::before {
		content: "";
		position: absolute;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		opacity: .9;
	}

	/* open */
	#header.open-menu nav.nav-menu {
		-webkit-transform: scale(1);
		-ms-transform: scale(1);
		-o-transform: scale(1);
		transform: scale(1);
		pointer-events: auto;
		opacity: 1;
	}
	#header.open-search nav.nav-search {
		-webkit-transform: scale(1);
		-ms-transform: scale(1);
		-o-transform: scale(1);
		transform: scale(1);
		pointer-events: auto;
		opacity: 1;
	}
	/* showed */
	#header.showed-menu nav.nav-menu {
		-webkit-transition: opacity 0.3s linear, -webkit-transform 0.3s ease-out;
		-o-transition: opacity 0.3s linear, -o-transform 0.3s ease-out;
		transition: opacity 0.3s linear, transform 0.3s ease-out;
	}
	#header.showed-search nav.nav-search {
		-webkit-transition: opacity 0.3s linear, -webkit-transform 0.3s ease-out;
		-o-transition: opacity 0.3s linear, -o-transform 0.3s ease-out;
		transition: opacity 0.3s linear, transform 0.3s ease-out;
	}


	#header nav {
	}
	#header nav .nav {
		position: relative;
		max-height: 100vh;
		padding: 40px 0;
		overflow-y: scroll;
		-webkit-overflow-scrolling: touch;
		z-index: 3;
	}
	#header nav .nav p {
		margin-bottom: 20px;
	}
	#header nav .nav ul a {
		position: relative;
		display: block;
		padding: 2px 0 2px 20px;
		color: #fff;
		text-decoration: none;
		font-size: 1.6rem;
	}
	#header nav .nav > ul > li {
		margin-bottom: 15px;
	}
	#header nav .nav > ul > li > a {
		font-weight: bold;
		font-size: 1.6rem;
	}
	#header nav .nav > ul > li > a::before {
		content: "";
		position: absolute;
		top: 50%;
		left: 0;
		width: 9px;
		height: 9px;
		margin-top: -4px;
		border-top: 3px solid;
		border-right: 3px solid;
		-webkit-transform: rotate(45deg);
		-ms-transform: rotate(45deg);
		-o-transform: rotate(45deg);
		transform: rotate(45deg);
	}
	#header nav .nav > ul > li li a::before {
		content: "";
		position: absolute;
		top: 0.9em;
		left: 2px;
		width: 9px;
		border-top: 3px solid;
	}
	#header nav .close {
		position: absolute;
		right: 0;
		top: 0;
		width: 50px;
		height: 50px;
		z-index: 10;
	}
	#header nav .close::before,
	#header nav .close::after {
		content: "";
		position: absolute;
		top: 50%;
		left: 50%;
		width: 30px;
		margin-left: -15px;
		margin-top: -3px;
		border-top: 6px solid #fff;
		-webkit-transform: rotate(45deg);
		-ms-transform: rotate(45deg);
		-o-transform: rotate(45deg);
		transform: rotate(45deg);
	}
	#header nav .close::after {
		-webkit-transform: rotate(-45deg);
		-ms-transform: rotate(-45deg);
		-o-transform: rotate(-45deg);
		transform: rotate(-45deg);
	}
}
@media screen and (max-width: 370px) {
}



/* footer
============================================================================================================ */
#footer {
	position: relative;
	background-color: #fff;
	font-size: 1.4rem;
}
@media screen and (max-width: 768px) {
}

/* ページトップ
------------------------------------------------------------- */
#pagetop {
	position: fixed;
	bottom: 32px;
	right: 40px;
	-webkit-transition: opacity .3s;
	-o-transition: opacity .3s;
	transition: opacity .3s;
	opacity: 0;
	pointer-events: none;
	z-index: 1000;
}
#pagetop.show {
	pointer-events: auto;
	opacity: 1;
}
@media print {
	#pagetop {
		display: none;
	}
}
@media screen and (max-width: 768px) {
	#pagetop {
		right: 15px;
	}
}


/* nav
------------------------------------------------------------- */
#footer nav {
	padding-top: 40px;
	padding-bottom: 40px;
}
#footer nav a {
	position: relative;
	display: block;
	padding-left: 14px;
	color: #333;
	text-decoration: none;
}
#footer nav > ul > li > a {
	font-weight: bold;
}
#footer nav > ul > li > a::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 0;
	width: 7px;
	height: 7px;
	margin-top: -5px;
	border-top: 2px solid;
	border-right: 2px solid;
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	-o-transform: rotate(45deg);
	transform: rotate(45deg);
}
#footer nav > ul > li li a::before {
	content: "";
	position: absolute;
	top: 0.7em;
	left: 0;
	width: 7px;
	border-top: 2px solid;
}
@media screen and (min-width: 769px), print {
	#footer nav {
		display: -webkit-flex;
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: flex;
	}
	#footer nav > ul:first-child {
		width: 83%;
		display: -webkit-flex;
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: flex;
	}
	#footer nav > ul:first-child > li {
		width: 20%;
		padding-right: 10px;
	}
	#footer nav > ul:last-child {
		width: 16.6%;
	}
	#footer nav > ul:last-child li + li {
		margin-top: 10px;
	}
	#footer nav > ul > li > a {
		margin-bottom: 5px;
	}
	#footer nav a[href]:hover {
		text-decoration: underline;
	}

	#footer nav > ul.nav4 {
		width: 80%;
	}
	#footer nav > ul.nav4 > li {
		width: 25%;
	}
	#footer nav > ul.nav4 + ul {
		width: 20%;
	}
}
@media screen and (max-width: 768px) {
	#footer nav {
		padding-top: 30px;
		padding-bottom: 40px;
	}
	#footer nav > ul + ul,
	#footer nav > ul > li + li {
		margin-top: 12px;
	}
	#footer nav > ul ul {
		margin-top: 3px;
	}
}


/* small
------------------------------------------------------------- */
#footer small {
	display: block;
	padding: 15px 0;
	background-color: #f5f5f5;
	font-size: 1.3rem;
	color: #666666;
	text-align: center;
	font-weight: bold;
}
@media screen and (max-width: 768px) {
	#footer small {
		padding: 12px 0;
		font-size: 1.1rem;
	}
}


/* container
============================================================================================================ */
#container {
	position: relative;
	padding: 140px 0 50px;
	background-color: #f5f5f5;
}
@media screen and (max-width: 768px) {
	#container {
		padding: 50px 0 20px;
	}
}

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

	パーツ

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

/* pagetop
============================================================================================================ */
a.pagetop {
	position: relative;
	display: block;
	width: 45px;
	height: 45px;
	border-radius: 100px;
	background-color: #f1c400;
}
a.pagetop::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	width: 12px;
	height: 12px;
	margin: -4px 0 0 -6px;
	border-top: 3px solid #fff;
	border-left: 3px solid #fff;
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	-o-transform: rotate(45deg);
	transform: rotate(45deg);
}
@media screen and (min-width: 769px), print {
	a.pagetop:hover {
		opacity: .7;
	}
}


/* breadcrumbs
============================================================================================================ */
.breadcrumbs {
	position: relative;
	padding: 5px 0;
	background-color: #fff;
	font-size: 1.2rem;
	z-index: 2;
}
.breadcrumbs ol li {
	position: relative;
	display: inline-block;
	padding-right: 20px;
}
.breadcrumbs ol li::after {
	content: "";
	position: absolute;
	right: 5px;
	top: 50%;
	width: 7px;
	height: 7px;
	margin-top: -5px;
	border-top: 2px solid #cdcdcd;
	border-right: 2px solid #cdcdcd;
	-webkit-transform: scaleX(.8) rotate(45deg);
	-ms-transform: scaleX(.8) rotate(45deg);
	-o-transform: scaleX(.8) rotate(45deg);
	transform: scaleX(.8) rotate(45deg);
}
.breadcrumbs ol li:last-child {
	padding-right: 0;
}
.breadcrumbs ol li:last-child::after {
	content: none;
}
.breadcrumbs ol li a {
	color: #000;
}
@media screen and (min-width: 769px), print {
	.breadcrumbs ol li {
		display: inline-block;
	}
}
@media screen and (max-width: 768px) {
	.breadcrumbs {
		font-size: 1.1rem;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}
	.breadcrumbs ol {
		display: table;
		white-space: nowrap;
	}
	.breadcrumbs ol li {
		display: table-cell;
		white-space: nowrap;
	}
}

/* title
============================================================================================================ */
/* page_title */
.page_title {
	background-image: url(../img/title_bg.jpg);
	background-position: 50%;
	-webkit-background-size: cover;
	background-size: cover;
	color: #fff;
}
.page_title .xw {
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	align-items: center;
	height: 150px;
}
.page_title h1 {
	position: relative;
	padding-left: 15px;
	font-size: 3.2rem;
	line-height: 1.5;
}
.page_title h1::before {
	content: "";
	position: absolute;
	left: 0;
	top: 5px;
	bottom: 5px;
	border-left: 4px solid;
}
@media screen and (min-width: 769px), print {
}
@media screen and (max-width: 768px) {
	.page_title .xw {
		height: 100px;
	}
	.page_title h1 {
		font-size: 2.4rem;
	}
}


/* hyphen_title */
.hyphen_title {
	text-align: center;
	margin-bottom: 60px;
	font-size: 2.8rem;
	line-height: 1.5;
	font-weight: bold;
}
.hyphen_title > span {
	position: relative;
	display: inline-block;
	padding: 0 44px;
}
.hyphen_title > span::before,
.hyphen_title > span::after {
	content: "";
	position: absolute;
	top: 50%;
	width: 20px;
	margin-top: -1px;
	border-top: 2px solid;
}
.hyphen_title > span::before {
	left: 0;
}
.hyphen_title > span::after {
	right: 0;
}
@media screen and (max-width: 768px) {
	.hyphen_title {
		margin-bottom: 25px;
		font-size: 2.2rem;
	}
}


/* h1 */
.h1 {
	margin-bottom: 30px;
	padding-bottom: 10px;
	border-bottom: 3px solid;
	font-size: 2.6rem;
	line-height: 1.5;
	font-weight: bold;
}
@media screen and (min-width: 769px), print {
}
@media screen and (max-width: 768px) {
	.h1 {
		font-size: 2.1rem;
	}
}

.has_caption_title {
	position: relative;
}
.has_caption_title::after {
	content: ""; display: table; clear: both;
}
.has_caption_title .title_caption {
	font-weight: normal;
	font-size: 1.2rem;
}
@media screen and (min-width: 769px), print {
	.has_caption_title .title_caption {
		position: absolute;
		right: 0;
		top: 10px;
	}
}
@media screen and (max-width: 768px) {
	.has_caption_title .title_caption {
		margin: -20px 0 20px;
		text-align: right;
	}
}

/* h2 */
.h2 {
	position: relative;
	margin-bottom: 30px;
	padding-left: 15px;
	font-size: 3.2rem;
	line-height: 1.5;
	font-weight: bold;
}
.h2::before {
	content: "";
	position: absolute;
	left: 0;
	top: 5px;
	bottom: 5px;
	border-left: 4px solid;
}
@media screen and (max-width: 768px) {
	.h2 {
		font-size: 2.4rem;
	}
}



/* h3 */
.h3 {
	position: relative;
	margin-bottom: 10px;
	padding-left: 20px;
	font-size: 1.8rem;
	line-height: 1.5;
	font-weight: bold;
}
.h3::before {
	content: "";
	position: absolute;
	top: 0.7em;
	left: 0;
	width: 12px;
	border-top: 4px solid;
	margin-top: -2px;
}
@media screen and (max-width: 768px) {
	.h3 {
		font-size: 1.7rem;
	}
}


/* h4 */
.h4 {
	padding: 10px 20px;
	font-size: 1.9rem;
	line-height: 1.5;
	font-weight: bold;
}
@media screen and (max-width: 768px) {
	.h4 {
		font-size: 1.7rem;
	}
}




/* cat_ico
============================================================================================================ */
.cat_ico {
	display: inline-block;
	min-width: 60px;
	padding: 1px 5px;
	border: 1px solid;
	color: #698bd8;
	font-size: 1.3rem;
	line-height: 1.5;
	border-radius: 4px;
	text-align: center;
	font-weight: bold;
}
.cat_ico.new {
	color: #c63527;
}


/* btn
============================================================================================================ */
a.btn {
	position: relative;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 254px;
	height: 48px;
	padding: 0 10px;
	border-radius: 100px;
	text-decoration: none;
	color: #fff !important;
	text-align: center;
	font-weight: bold;
	font-size: 1.6rem;
	line-height: 1.3;
	z-index: 2;
}
a.btn::before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	border-radius: 100px;
	opacity: .9;
	z-index: -1;
}
a.btn > * {
	display: inline-block;
	position: relative;
	padding-left: 20px;
	vertical-align: middle;
}
a.btn > *::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 0;
	width: 10px;
	height: 10px;
	margin-top: -5px;
	border-top: 3px solid #fff;
	border-right: 3px solid #fff;
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	-o-transform: rotate(45deg);
	transform: rotate(45deg);
}
a.btn.center {
	margin-left: auto;
	margin-right: auto;
}
a.btn.right {
	margin-left: auto;
}
a.btn.prevnext {
	width: 140px;
}
@media screen and (min-width: 769px), print {
	a.btn[href]:hover {
		opacity: .7;
	}
}
@media screen and (max-width: 768px) {
}


@media screen and (min-width: 769px), print {
	.record_more_btn .btn {
		margin-left: auto;
	}
}
@media screen and (max-width: 768px) {
	.record_more_btn {
		margin-top: 20px;
	}
	.record_more_btn .btn {
		margin-left: auto;
		margin-right: auto;
	}
}



/* ico
============================================================================================================ */
.ico_pdf,
.ico_pdf_blue,
.ico_excel,
.ico_word {
	display: inline-block;
}
.ico_pdf::after,
.ico_pdf_blue::after,
.ico_excel::after,
.ico_word::after {
	content: "";
	display: inline-block;
	width: 15px;
	height: 18px;
	margin-left: 8px;
	margin-right: 5px;
	background-position: 100%;
	background-repeat: no-repeat;
	-webkit-background-size: 100%;
	background-size: 100%;
	vertical-align: middle;
}
.ico_pdf::after {
	background-image: url(../img/ico_pdf.png);
}
.ico_pdf_blue::after {
	background-image: url(../img/ico_pdf_blue.png);
}
.ico_excel::after {
	width: 20px;
	background-image: url(../img/ico_excel.png);
}
.ico_word::after {
	width: 20px;
	background-image: url(../img/ico_word.png);
}


/* page_contents
============================================================================================================ */
.page_contents {
	padding: 50px 0 60px;
}
.page_contents + .page_contents {
	padding-top: 30px;
}
@media screen and (max-width: 768px) {
	.page_contents {
		padding: 30px 0 50px;
	}
	.page_contents + .page_contents {
		padding-top: 0;
	}
}


/* mt_block
============================================================================================================ */
.mt_block {
	margin-top: 30px;
}
.mt_block_s {
	margin-top: 20px;
}
.mt_block_l {
	margin-top: 50px;
}
@media screen and (max-width: 768px) {
	.mt_block {
		margin-top: 20px;
	}
	.mt_block_s {
		margin-top: 15px;
	}
	.mt_block_l {
		margin-top: 40px;
	}
}

/* para_section (paragraph section)
============================================================================================================ */
.para_section > * + * {
	margin-top: 1.8em;
}
@media screen and (max-width: 768px) {
}


/* large_pdf_link
============================================================================================================ */
.large_pdf_link li a {
	position: relative;
	display: block;
	padding: 15px 90px 15px 20px;
	background-color: #fff;
	text-decoration: none;
	font-weight: bold;
	font-size: 1.8rem;
	line-height: 1.6;
	border-radius: 5px;
}
.large_pdf_link li a::after {
	content: "";
	position: absolute;
	top: 20px;
	right: 20px;
	width: 30px;
	height: 36px;
	background: url(../img/ico_pdf_l.png) no-repeat;
	-webkit-background-size: 100%;
	background-size: 100%;
}
.large_pdf_link li a.blue::after {
	background-image: url(../img/ico_pdf_l_blue.png);
}
.large_pdf_link li a .date {
	display: block;
	color: #333;
	margin-top: 3px;
	font-size: 1.2rem;
}
@media screen and (min-width: 769px), print {
	.large_pdf_link {
		display: -webkit-flex;
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: flex;
		-webkit-flex-wrap: wrap;
		-moz-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
		-o-flex-wrap: wrap;
		flex-wrap: wrap;
		justify-content: space-between;
		margin-top: 15px;
	}
	.large_pdf_link li {
		width: calc(50% - 10px);
	}
	.large_pdf_link li:nth-child(2) ~ * {
		margin-top: 20px;
	}
	.large_pdf_link li a {
		height: 100%;
	}
	.large_pdf_link li a:hover .title {
		text-decoration: underline;
	}
}
@media screen and (max-width: 768px) {
	.large_pdf_link li + li {
		margin-top: 10px;
	}
	.large_pdf_link li a {
		padding-right: 50px;
		font-size: 1.5rem;
	}
	.large_pdf_link li a::after {
		width: 24px;
	}
}


/* table
============================================================================================================ */
.basic_table {
	width: 100%;
}
.basic_table thead th {
	padding: 10px 15px;
	color: #fff;
	font-weight: bold;
	white-space: nowrap;
}
.basic_table tbody td {
	padding: 10px 15px;
	border: 1px solid #ebeaea;
	background-color: #fff;
}
.basic_table.fixed {
	table-layout: fixed;
}
.basic_table.center th,
.basic_table.center td {
	padding-right: 0;
	padding-left: 0;
	text-align: center;
}
.basic_table .w10 {
	width: 10%;
}
.basic_table .w20 {
	width: 20%;
}
.basic_table .w30 {
	width: 30%;
}
.basic_table .w40 {
	width: 40%;
}
.basic_table .w50 {
	width: 50%;
}
.basic_table .w60 {
	width: 60%;
}
.basic_table .w70 {
	width: 70%;
}
@media screen and (max-width: 768px) {
	.basic_table.sp_vertical,
	.basic_table.sp_vertical tbody,
	.basic_table.sp_vertical tr,
	.basic_table.sp_vertical th,
	.basic_table.sp_vertical td {
		display: block;
	}
	.basic_table.sp_vertical thead {
		display: none;
	}

	.basic_table.sp_vertical tr + tr {
		margin-top: 10px;
	}
	.basic_table.sp_vertical td {
		display: table;
		width: 100%;
		padding: 0;
		border: 0;
		line-height: 1.6;
	}
	.basic_table.sp_vertical td > * {
		display: table-cell;
		vertical-align: middle;
		padding: 8px 10px;
	}
	.basic_table.sp_vertical td::before {
		content: attr(data-label);
		display: table-cell;
		vertical-align: middle;
		width: 30%;
		padding: 8px 10px;
		color: #fff;
		font-weight: bold;
		line-height: 1.4;
	}
	.basic_table.sp_vertical td + td {
		border-top: 2px solid #ebeaea;
	}

	.basic_table .w10 {
		width: 20%;
	}
}

.basic_h_table {
	width: 100%;
}
.basic_h_table.min {
	width: auto;
}
.basic_h_table th,
.basic_h_table td {
	padding: 10px 20px;
	border: 1px solid #ebeaea;
}
.basic_h_table th {
	color: #fff;
	font-weight: bold;
	text-align: center;
}
.basic_h_table td {
	background-color: #fff;
}
@media screen and (max-width: 768px) {
	.basic_h_table.min {
		width: 100%;
	}
	.basic_h_table th,
	.basic_h_table td {
		padding: 10px 10px;
		line-height: 1.6;
	}
}



/* pager
============================================================================================================ */
.pager_block {
	position: relative;
	margin-top: 60px;
	text-align: center;
	z-index: 1;
}
a.pager {
	position: relative;
	display: block;
	width: 48px;
	height: 48px;
	line-height: 48px;
	margin: 0 10px;
	text-align: center;
	font-size: 2rem;
	border-radius: 100px;
	color: #fff !important;
	text-decoration: none;
	vertical-align: middle;
	z-index: 1;
}
a.pager::before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	left: 0;
	bottom: 0;
	border-radius: 100%;
	z-index: -1;
	opacity: .9;
}
@media screen and (min-width: 769px), print {
	.pager_block {
		display: -webkit-flex;
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: flex;
		justify-content: center;
	}
	.pager_block .prevnext {
		margin: 0 20px;
	}
}
@media screen and (max-width: 768px) {
	.pager_block {
		margin-top: 40px;
	}
	a.pager {
		display: inline-block;
		margin: 0 2px 6px;
	}
	a.prevnext {
		overflow: hidden;
		display: inline-block;
		width: 48px !important;
		height: 0;
		padding-top: 48px;
		margin: 0 2px 6px;
		vertical-align: middle;
	}
	a.prevnext::after {
		content: "";
		content: "";
		position: absolute;
		top: 50%;
		left: 50%;
		width: 12px;
		height: 12px;
		margin: -6px 0 0 -4px;
		border-top: 3px solid #fff;
		border-left: 3px solid #fff;
		-webkit-transform: rotate(-45deg);
		-ms-transform: rotate(-45deg);
		-o-transform: rotate(-45deg);
		transform: rotate(-45deg);
	}
	a.prevnext.next {
		-webkit-transform: rotate(180deg);
		-ms-transform: rotate(180deg);
		-o-transform: rotate(180deg);
		transform: rotate(180deg);
	}
}

.prevnext_block {
	margin-top: 60px;
	padding-top: 60px;
	border-top: 1px solid #dfdfdf;
}
.prevnext_block .prev {
	float: left;
}
.prevnext_block .next {
	float: right;
}
@media screen and (max-width: 768px) {
	.prevnext_block {
		margin-top: 40px;
		padding-top: 40px;
	}
}


/* list
============================================================================================================ */
.list_number_parentheses {
	counter-reset: number_parentheses;
}
.list_number_parentheses > li {
	position: relative;
	padding-left: 2em;
}
.list_number_parentheses > li::before {
	counter-increment: number_parentheses;
	content: "(" counter(number_parentheses) ")";
	position: absolute;
	top: 0;
	left: 0;
}
.list_spece > li + li {
	margin-top: 1.5em;
}

.list_circle > li {
	position: relative;
	padding-left: 1.2em;
}
.list_circle > li::before {
	content: "・";
	position: absolute;
	top: 0;
	left: 0;
}

.list_number > li {
	margin-left: 1.2em;
	list-style: decimal;
}

.list_notes > li {
	position: relative;
	padding-left: 1.2em;
}
.list_notes > li::before {
	content: "※";
	position: absolute;
	top: 0;
	left: 0;
}

.list_free > li {
	position: relative;
	padding-left: 1.2em;
}
.list_free > li> span:first-child {
	position: absolute;
	top: 0;
	left: 0;
}

.list_number_hyphen > li {
	position: relative;
	padding-left: 2.5em;
}
.list_number_hyphen > li> span:first-child {
	position: absolute;
	top: 0;
	left: 0;
	font-weight: bold;
}

.list_ine > li {
	position: relative;
	padding-left: 14px;
}
.list_ine > li::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 0;
	width: 7px;
	height: 7px;
	margin-top: -5px;
	border-top: 2px solid;
	border-right: 2px solid;
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	-o-transform: rotate(45deg);
	transform: rotate(45deg);
}

.list_date::after {
	content: ""; display: table; clear: both;
}
.list_date dt {
	float: left;
}
.list_date dd {
	margin-left: 7em;
}


/* fontsize
============================================================================================================ */
.fz_m {
	font-size: 90%;
}
.fz_s {
	font-size: 80%;
}


/* bg_box
============================================================================================================ */
.bg_box {
	padding: 20px;
	border-radius: 5px;
}
.fz_s {
	font-size: 80%;
}



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

	トップページ

======================================================================================================================== */
#indexMain {
	margin-bottom: 30px;
	background-image: url(../img/index_bg.jpg);
	background-position: 50%;
	-webkit-background-size: cover;
	background-size: cover;
}
#indexMain .title {
	color: #fff;
	font-weight: bold;
	font-size: 2.2rem;
}
#indexMain .title h1 {
	position: relative;
	padding-left: 15px;
	margin-bottom: 20px;
	font-size: 3.2rem;
	line-height: 1.5;
}
#indexMain .title h1::before {
	content: "";
	position: absolute;
	left: 0;
	top: 5px;
	bottom: 5px;
	border-left: 4px solid;
}
#indexMain .title .small {
	display: block;
	margin-top: 10px;
	font-size: 1.2rem;
}
#indexMain .title ul {
	margin-top: 30px;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
}
#indexMain .title ul a {
	font-size: 1.3rem;
	width: auto;
	height: 64px;
	padding: 0 20px;
	border-radius: 4px;
	text-align: left;
}
#indexMain .title ul a::before {
	border-radius: 4px;
}
#indexMain .date .box {
	margin-bottom: 35px;
	padding: 40px 0;
	background-color: rgba(255,255,255,.8);
	border-radius: 4px;
	text-align: center;
	font-weight: bold;
	line-height: 1.3;
}
#indexMain .date .box dt {
	margin-bottom: 10px;
}
#indexMain .date .box .open {
	font-size: 2.6rem;
}
#indexMain .date .box .open .ff_en {
	font-size: 3.2rem;
}
#indexMain .date .box .closing {
	margin-top: 20px;
	font-size: 2rem;
}
#indexMain .date .box .closing dt {
	display: inline-block;
	padding-bottom: 5px;
	border-bottom: 4px solid;
}
#indexMain .date .box .closing .ff_en {
	font-size: 2.8rem;
}
#indexMain .date .box .closing_wrap {

}
#indexMain .date .box .closing_wrap .closing_title {
font-size: 2rem;
margin-top: 20px;
}
#indexMain .date .box .closing_wrap .closing_box {
display: flex;
justify-content: space-between;
padding: 0 20px;
}
#indexMain .date .box .closing_wrap .closing_box .closing {
width: 48%;
margin-top: 10px;
}
#indexMain .date .box .closing_wrap .closing_box .closing dt {
width: 100%;
font-size: 1.8rem;
}
#indexMain .date .box .closing_wrap .closing_box .closing dd {
font-size: 1.3rem;
}
#indexMain .date .box .closing_wrap .closing_box .closing .ff_en {
font-size: 2rem;
}
@media screen and (min-width: 769px), print {
	#indexMain .xw {
		display: -webkit-flex;
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: flex;
		justify-content: space-between;
		align-items: center;
		height: 640px;
	}
	#indexMain .title {
		width: calc(100% - 500px);
	}
	#indexMain .title ul li {
		margin-right: 20px;
	}
	#indexMain .date {
		width: 460px;
		margin-top: 35px;
		padding-right: 70px;
	}
}
@media screen and (max-width: 768px) {
	#indexMain {
		margin-bottom: 10px;
		padding: 30px 0 40px;
	}
	#indexMain .title {
		font-size: 1.7rem;
	}
	#indexMain .title h1 {
		font-size: 2.4rem;
	}
	#indexMain .title ul {
		justify-content: space-between;
		margin-top: 15px;
	}
	#indexMain .title ul li {
		width: calc(50% - 5px);
	}
	#indexMain .title ul a {
		font-size: 1.1rem;
		line-height: 1.5;
		padding: 0 10px;
	}
	#indexMain .date .box {
		margin-top: 30px;
		margin-bottom: 20px;
		padding: 25px 0;
	}
	#indexMain .date .box .open {
		font-size: 2.1rem;
	}
	#indexMain .date .box .open .ff_en {
	}
	#indexMain .date .box .closing {
		margin-top: 15px;
		font-size: 1.3rem;
	}
	#indexMain .date .box .closing .ff_en {
	}
	#indexMain .date .box .closing_wrap .closing_box .closing dd {
	font-size: 1rem;
	}
	#indexMain .date .box .closing_wrap .closing_box .closing .ff_en {
	font-size: 1.6rem;
	}
}

.index_news_list {
	margin-bottom: 40px;
	border-top: 1px solid #dfdfdf;
}
.index_news_list li {
	border-bottom: 1px solid #dfdfdf;
}
.index_news_list a {
	position: relative;
	display: block;
	padding: 15px 0;
	text-decoration: none;
	color: #333 !important;
	line-height: 1.5;
}
@media screen and (min-width: 769px), print {
	.index_news_list a {
		display: table;
		width: 100%;
		height: 60px;
		padding: 8px 40px 8px 0;
	}
	.index_news_list a::after {
		content: "";
		position: absolute;
		top: 50%;
		right: 5px;
		width: 10px;
		height: 10px;
		margin-top: -5px;
		border-top: 3px solid;
		border-right: 3px solid;
		-webkit-transform: rotate(45deg);
		-ms-transform: rotate(45deg);
		-o-transform: rotate(45deg);
		transform: rotate(45deg);
	}
	.index_news_list a > * {
		display: table-cell;
		vertical-align: middle;
	}
	.index_news_list a .date {
		width: 7em;
	}
	.index_news_list a .cat {
		width: 80px;
	}
	.index_news_list a .cat span + span {
		margin-top: 3px;
	}
	.index_news_list a .title {
		padding: 8px 0;
	}
	.index_news_list a:hover .title {
		text-decoration: underline;
	}
}
@media screen and (max-width: 768px) {
	.index_news_list a .date {
		margin-right: 10px;
		font-size: 1.5rem;
	}
	.index_news_list a .title {
		margin-top: 10px;
		display: block;
	}
}

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

	お知らせ

======================================================================================================================== */
.news_list article {
	padding-bottom: 40px;
	border-bottom: 1px solid #dfdfdf;
	line-height: 1.6;
}
.news_list article + article {
	margin-top: 40px;
}
.news_list article time {
	font-weight: bold;
	margin-right: 10px;
	vertical-align: middle;
}
.news_list article h1 {
	margin: 10px 0;
	font-size: 1.8rem;
}
.news_list article h1 a {
	color: #333;
}
@media screen and (max-width: 768px) {
	.news_list article {
		padding-bottom: 30px;
	}
	.news_list article + article {
		margin-top: 30px;
	}
	.news_list article h1 {
		font-size: 1.6rem;
	}
}

.news_detail header time {
	font-weight: bold;
	margin-right: 10px;
	vertical-align: middle;
}
.news_detail header h1 {
	margin-top: 20px;
}

/* .entry_body
------------------------------------------------------------- */
.entry_body {
	word-wrap : break-word;
	overflow-wrap : break-word;
}
.entry_body img {
	max-width: 100%;
	height: auto;
}
.entry_body p {
	margin: 0 0 1.6em;
}
.entry_body ul,
.entry_body ol {
	margin: 0 0 1.6em 1.3333em;
}
.entry_body ul {
	list-style: disc;
}
.entry_body ol {
	list-style: decimal;
}
.entry_body li > ul,
.entry_body li > ol {
	margin-bottom: 0;
}
.entry_body dl {
	margin-bottom: 1.6em;
}
.entry_body dt {
	font-weight: bold;
}
.entry_body dd {
	margin-bottom: 1.6em;
}
.entry_body p:last-child,
.entry_body dl:last-child,
.entry_body ul:last-child,
.entry_body ol:last-child {
	margin-bottom: 0;
}
.entry_body cite,
.entry_body dfn,
.entry_body em,
.entry_body i {
	font-style: italic;
}
.entry_body mark,
.entry_body ins {
	border: 0;
	color: inherit;
	text-decoration: none;
}



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

	サイトマップ

======================================================================================================================== */
.sitemap_contents {
}
.sitemap_contents li a {
	display: inline-block;
	vertical-align: middle;
	color: #333;
}
.sitemap_contents li a.h3 {
	margin-bottom: 5px;
}
.sitemap_contents > ul > li + li {
	margin-top: 25px;
}
.sitemap_contents > ul ul {
	padding-left: 20px;
}
@media screen and (min-width: 769px), print {
	.sitemap_contents {
		display: -webkit-flex;
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: flex;
	}
	.sitemap_contents > * {
		width: 50%;
	}
}
@media screen and (max-width: 768px) {
	.sitemap_contents > ul + ul {
		margin-top: 30px;
	}
}



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

	サイトカラー

======================================================================================================================== */
/*
rinri
#357fef
#001e62
#e0e6f1
#1752ab
*/
.site-rinri a {
	color: #357fef;
}
.site-rinri #footer nav a::before {
	border-color: #357fef;
}
.site-rinri a.btn::before {
	background-color: #357fef;
}
.site-rinri a.pager::before {
	background-color: #357fef;
}
.site-rinri a.pager.current::before {
	background-color: #001e62;
}
.site-rinri .list_ine > li::before {
	border-color: #357fef;
}
.site-rinri .theme2_bd,
.site-rinri .theme2_bd::before,
.site-rinri .theme2_bd::after {
	border-color: #001e62 !important;
}
.site-rinri .h4,
.site-rinri .bg_box {
	background-color: #e0e6f1;
}
.site-rinri .basic_table thead th {
	background-color: #1752ab;
}
.site-rinri .basic_h_table th {
	background-color: #1752ab;
}
@media screen and (min-width: 769px), print {
	.site-rinri #header nav .snav a {
		background-color: #357fef;
	}
	.site-rinri #header nav .snav .link a {
		background-color: #001e62;
	}
	.site-rinri #header nav .gnav > li > a::after {
		border-bottom-color: #001e62;
	}
	.site-rinri #header nav .gnav .dd::before {
		background-color: #001e62;
	}
	.site-rinri .index_news_list a::after {
		border-color: #1752ab;
	}
}
@media screen and (max-width: 768px) {
	.site-rinri #header .logo a {
		width: 260px;
		background-image: url(../rinri/img/logo_sp.png);
	}
	.site-rinri #header .nav_btn a {
		background-color: #001e62;
	}
	.site-rinri #header .nav_btn-search-lower a {
		background-color: #5b5b5b;
	}
	.site-rinri #header nav::before {
		background-color: #001e62;
	}
	.site-rinri .basic_table.sp_vertical td::before {
		background-color: #1752ab;
	}
}


/*
saisei
#75be14
#295a29
#d0e1b9
#0f800f
*/

.site-saisei a {
	color: #75be14;
}
.site-saisei #footer nav a::before {
	border-color: #75be14;
}
.site-saisei a.btn::before {
	background-color: #75be14;
}
.site-saisei a.pager::before {
	background-color: #75be14;
}
.site-saisei a.pager.current::before {
	background-color: #295a29;
}
.site-saisei .list_ine > li::before {
	border-color: #75be14;
}
.site-saisei .theme2_bd,
.site-saisei .theme2_bd::before,
.site-saisei .theme2_bd::after {
	border-color: #295a29 !important;
}
.site-saisei .h4,
.site-saisei .bg_box {
	background-color: #d0e1b9;
}
.site-saisei .basic_table thead th {
	background-color: #0f800f;
}
.site-saisei .basic_h_table th {
	background-color: #0f800f;
}
@media screen and (min-width: 769px), print {
	.site-saisei #header nav .snav a {
		background-color: #75be14;
	}
	.site-saisei #header nav .snav .link a {
		background-color: #295a29;
	}
	.site-saisei #header nav .gnav > li > a::after {
		border-bottom-color: #295a29;
	}
	.site-saisei #header nav .gnav .dd::before {
		background-color: #295a29;
	}
	.site-saisei .index_news_list a::after {
		border-color: #0f800f;
	}
}
@media screen and (max-width: 768px) {
	.site-saisei #header .logo a {
		width: 220px;
		background-image: url(../saisei/img/logo_sp.png);
	}
	.site-saisei #header .nav_btn a {
		background-color: #295a29;
	}
	.site-saisei #header .nav_btn-search-lower a {
		background-color: #5b5b5b;
	}
	.site-saisei #header nav::before {
		background-color: #295a29;
	}
	.site-saisei .basic_table.sp_vertical td::before {
		background-color: #0f800f;
	}
}

/*
hito
#ef35ab
#620055
#eedde8
#b9197e
*/

.site-hito a {
	color: #ef35ab;
}
.site-hito #footer nav a::before {
	border-color: #ef35ab;
}
.site-hito a.btn::before {
	background-color: #ef35ab;
}
.site-hito a.pager::before {
	background-color: #ef35ab;
}
.site-hito a.pager.current::before {
	background-color: #620055;
}
.site-hito .list_ine > li::before {
	border-color: #ef35ab;
}
.site-hito .theme2_bd,
.site-hito .theme2_bd::before,
.site-hito .theme2_bd::after {
	border-color: #620055 !important;
}
.site-hito .h4,
.site-hito .bg_box {
	background-color: #eedde8;
}
.site-hito .basic_table thead th {
	background-color: #b9197e;
}
.site-hito .basic_h_table th {
	background-color: #b9197e;
}
@media screen and (min-width: 769px), print {
	.site-hito #header nav .snav a {
		background-color: #ef35ab;
	}
	.site-hito #header nav .snav .link a {
		background-color: #620055;
	}
	.site-hito #header nav .gnav > li > a::after {
		border-bottom-color: #620055;
	}
	.site-hito #header nav .gnav .dd::before {
		background-color: #620055;
	}
	.site-hito .index_news_list a::after {
		border-color: #b9197e;
	}
}
@media screen and (max-width: 768px) {
	.site-hito #header .logo a {
		width: 260px;
		background-image: url(../hito/img/logo_sp.png);
	}
	.site-hito #header .nav_btn a {
		background-color: #620055;
	}
	.site-hito #header .nav_btn-search-lower a {
		background-color: #5b5b5b;
	}
	.site-hito #header nav::before {
		background-color: #620055;
	}
	.site-hito .basic_table.sp_vertical td::before {
		background-color: #b9197e;
	}
}

/*
nintei
#ff8c00
#9b5d12
#f0ddc6
#df7100
*/

.site-nintei a {
	color: #ff8c00;
}
.site-nintei #footer nav a::before {
	border-color: #ff8c00;
}
.site-nintei a.btn::before {
	background-color: #ff8c00;
}
.site-nintei a.pager::before {
	background-color: #ff8c00;
}
.site-nintei a.pager.current::before {
	background-color: #9b5d12;
}
.site-nintei .list_ine > li::before {
	border-color: #ff8c00;
}
.site-nintei .theme2_bd,
.site-nintei .theme2_bd::before,
.site-nintei .theme2_bd::after {
	border-color: #9b5d12 !important;
}
.site-nintei .h4,
.site-nintei .bg_box {
	background-color: #f0ddc6;
}
.site-nintei .basic_table thead th {
	background-color: #df7100;
}
.site-nintei .basic_h_table th {
	background-color: #df7100;
}
@media screen and (min-width: 769px), print {
	.site-nintei #header nav .snav a {
		background-color: #ff8c00;
	}
	.site-nintei #header nav .snav .link a {
		background-color: #9b5d12;
	}
	.site-nintei #header nav .gnav > li > a::after {
		border-bottom-color: #9b5d12;
	}
	.site-nintei #header nav .gnav .dd::before {
		background-color: #9b5d12;
	}
	.site-nintei .index_news_list a::after {
		border-color: #df7100;
	}
}
@media screen and (max-width: 768px) {
	.site-nintei #header .logo a {
		width: 260px;
		background-image: url(../nintei/img/logo_sp.png);
	}
	.site-nintei #header .nav_btn a {
		background-color: #9b5d12;
	}
	.site-nintei #header .nav_btn-search-lower a {
		background-color: #5b5b5b;
	}
	.site-nintei #header nav::before {
		background-color: #9b5d12;
	}
	.site-nintei .basic_table.sp_vertical td::before {
		background-color: #df7100;
	}
}


/*
portal
#698BD8
#001e62
#f0ddc6
#698BD8
*/

.site-portal a {
	color: #698BD8;
}
.site-portal #footer nav a::before {
	border-color: #698BD8;
}
.site-portal a.btn::before {
	background-color: #698BD8;
}
.site-portal a.pager::before {
	background-color: #698BD8;
}
.site-portal a.pager.current::before {
	background-color: #001e62;
}
.site-portal .list_ine > li::before {
	border-color: #698BD8;
}
.site-portal .theme2_bd,
.site-portal .theme2_bd::before,
.site-portal .theme2_bd::after {
	border-color: #001e62 !important;
}
.site-portal .h4,
.site-portal .bg_box {
	background-color: #f0ddc6;
}
.site-portal .basic_table thead th {
	background-color: #698BD8;
}
.site-portal .basic_h_table th {
	background-color: #698BD8;
}
@media screen and (min-width: 769px), print {
	.site-portal #header nav .snav a {
		background-color: #b2b2b2;
	}
	.site-portal #header nav .snav .link a {
		background-color: #5b5b5b;
	}
	.site-portal #header nav .gnav .dd::before {
		background-color: #000;
		opacity: .8;
	}
	.site-portal #header nav .gnav .dd_inner {
        display: flex;
		max-width: 930px;
	}
	.site-portal #header nav .gnav .dd_inner ul {
        width: 28%;
        padding: 0 3% 0 0;
	}
	.site-portal .index_news_list a::after {
		border-color: #698BD8;
	}
}
@media screen and (max-width: 768px) {
	.site-portal #header .nav_btn a {
		background-color: #5b5b5b;
	}
	.site-portal #header nav::before {
		background-color: #5b5b5b;
	}
	.site-portal .basic_table.sp_vertical td::before {
		background-color: #698BD8;
	}
}



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

	ポータルサイト

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

/* header
============================================================================================================ */
@media screen and (min-width: 769px), print {
	#header.portal {
		height: 240px;
	}
	#header.portal::before {
		height: 240px;
		-webkit-box-shadow: none;
		box-shadow: none;
	}
	#header.portal .logo {
		float: none;
		text-align: center;
		padding: 55px 0 40px;
		background: none;
		z-index: 1;
	}

	#header.portal nav {
		pointer-events: none;
	}
	#header.portal nav a {
		pointer-events: auto;
	}
	#header.portal nav .snav {
		position: absolute;
		top: 0;
		right: 0;
		border-bottom: 0;
	}
	#header.portal nav .snav a {
		height: 40px !important;
		padding-right: 10px;
		padding-left: 20px;
		font-size: 1.3rem;
	}
	#header.portal nav .snav a::before {
		left: 7px;
		width: 7px;
		height: 7px;
		margin-top: -4px;
		border-top-width: 2px;
		border-right-width: 2px;
	}
	#header.portal nav .snav .link a {
		padding-left: 35px;
		background-position: 10px;
	}

	#header.portal nav .nav {
		position: relative;
		z-index: 2;
	}
	#header.portal nav .gnav {
		padding-right: 0;
		justify-content: center;
	}
	#header.portal nav .gnav > li > a {
		height: 38px !important;
	}
	#header.portal nav .gnav > li.has_dd > a {
		padding-right: 40px;
		border-radius: 4px 4px 0 0;
	}
	#header.portal nav .gnav > li.has_dd > a > *::after {
		content: "";
		position: absolute;
		top: 50%;
		right: 20px;
		width: 7px;
		height: 7px;
		margin-top: -5px;
		border-bottom: 2px solid #cccccc;
		border-right: 2px solid #cccccc;
		-webkit-transform: rotate(45deg);
		-ms-transform: rotate(45deg);
		-o-transform: rotate(45deg);
		transform: rotate(45deg);
		-webkit-transition: border .2s;
		-o-transition: border .2s;
		transition: border .2s;
	}
	#header.portal nav .gnav > li.has_dd:hover > a[href] {
		background-color: rgba(0,0,0,.8);
		color: #fff;
	}
	#header.portal nav .gnav > li.has_dd:hover > a[href] > *::after {
		border-color: #fff;
	}

	#header.portal nav .gnav > li.contact > a > * {
		background-image: url(../img/ico_contact_portal.png);
	}
	#header.portal nav .gnav > li > a::after {
		right: 10px;
		left: 10px;
		bottom: -3px;
		border-bottom: 3px solid #333333;
	}

	#header.portal nav .gnav .non_link .dd {
		display: none !important;
	}
	#header.portal nav .gnav .dd {
		left: -2000px;
		right: -2000px;
		padding-left: 2000px;
		opacity: 0;
		-webkit-transition: height .3s, opacity .2s;
		-o-transition: height .3s, opacity .2s;
		transition: height .3s, opacity .2s;
	}
	#header.portal nav .gnav .dd.show {
		opacity: 1;
	}
	#header.portal nav .gnav .dd ul {
		padding: 20px 0;
	}
	#header.portal nav .gnav .dd ul ul {
		width: 100%;
		padding-top: 0;
	}
	#header.portal nav .gnav .dd ul li + li {
		border-top: none;
	}
	#header.portal nav .gnav .dd a {
		padding: 10px 25px;
		font-size: 1.4rem;
	}
	#header.portal nav .gnav .dd a::before {
		content: "";
		position: absolute;
		top: 50%;
		left: 5px;
		width: 7px;
		height: 7px;
		margin-top: -5px;
		border-top: 2px solid #fff;
		border-right: 2px solid #fff;
		-webkit-transform: rotate(45deg);
		-ms-transform: rotate(45deg);
		-o-transform: rotate(45deg);
		transform: rotate(45deg);
	}
#header.portal nav .gnav .dd .dd_inner ul ul a::before {
		content: "";
		position: absolute;
		top: 50%;
		left: 5px;
		width: 7px;
		height: 2px;
		margin-top: -5px;
		border-top: none;
		border-right: none;
		background: #fff;
		-webkit-transform: rotate(0deg);
		-ms-transform: rotate(0deg);
		-o-transform: rotate(0deg);
		transform: rotate(0deg);
	}
}

@media screen and (max-width: 768px) {
  #header.portal nav .gnav .dd .dd_inner ul ul {
      display: none;
  }
}


@media screen and (min-width: 769px) {
	/* height low
	------------------------------------------------------------- */
	body.page-move #header.portal,
	body.page-move #header.portal nav .snav a,
	body.page-move #header.portal nav .gnav > li > a {
		-webkit-transition: height 0.4s ease-in-out, background .2s, color .2s;
		-o-transition: height 0.4s ease-in-out, background .2s, color .2s;
		transition: height 0.4s ease-in-out, background .2s, color .2s;
	}
	body.page-move #header.portal .nav {
		-webkit-transition: -webkit-transform 0.4s ease-in-out;
		-o-transition: -o-transform 0.4s ease-in-out;
		transition: transform 0.4s ease-in-out;
	}
	body.page-scroll #header.portal {
		height: 140px;
	}
	body.page-scroll #header.portal::before {
		-webkit-transform: translateY(-100px);
		-ms-transform: translateY(-100px);
		-o-transform: translateY(-100px);
		transform: translateY(-100px);
	}
	body.page-scroll #header.portal .logo {
		-webkit-transform: translateY(-50px);
		-ms-transform: translateY(-50px);
		-o-transform: translateY(-50px);
		transform: translateY(-50px);
	}
	body.page-scroll #header.portal nav .nav {
		-webkit-transform: translateY(-80px);
		-ms-transform: translateY(-80px);
		-o-transform: translateY(-80px);
		transform: translateY(-80px);
	}
}
@media screen and (min-width: 769px), print {
	/* header no fix
	------------------------------------------------------------- */
	.page-forms #header.portal {
		position: absolute;
		height: 240px !important;
	}
	.page-forms #header.portal::before,
	.page-forms #header.portal .logo,
	.page-forms #header.portal  nav .nav {
		-webkit-transform: none !important;
		-ms-transform: none !important;
		-o-transform: none !important;
		transform: none !important;
	}
}
@media screen and (max-width: 768px) {
	#header.portal .logo {
		position: absolute;
		top: 0;
		right: 0;
		left: 0;
		height: 160px;
		padding: 0 20px;
		display: -webkit-flex;
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: flex;
		-ms-align-items: center;
		align-items: center;
		justify-content: center;
		box-shadow: none;
	}
	#header.portal .logo a {
		height: auto;
		text-align: center;
	}
	#header.portal .logo a img {
		display: block;
	}
	#header.portal nav .nav {
		padding-top: 60px;
	}
	#header.portal nav .nav p {
		margin: 0 -5px 40px;
	}
	#header.portal nav .nav p a {
		display: block;
		padding: 5px 10px;
		background-color: #fff;
	}
	#header.portal nav .gnav > li.contact > a {
		background: url(../img/ico_contact_sp.png) no-repeat 0;
		-webkit-background-size: 16px;
		background-size: 16px;
	}
	#header.portal nav .gnav > li.contact > a::before {
		content: none;
	}
}
@media screen and (max-width: 370px) {
}

/* footer
============================================================================================================ */
@media screen and (min-width: 769px), print {
	.site-portal #footer nav {
		justify-content: center;
	}
	.site-portal #footer nav > ul {
		width: auto;
		margin: 0 50px;
	}
	.site-portal #footer nav > ul:first-child > li {
		width: auto;
		padding-right: 0;
	}
	.site-portal #footer nav > ul > li + li {
		margin-top: 10px;
	}
}

/* iinkai_nav
------------------------------------------------------------- */
.site-portal #footer .iinkai_nav {
	padding: 25px 0;
	background-color: #f1f1f1;
}
@media screen and (min-width: 769px), print {
	.site-portal #footer .iinkai_nav {
		display: -webkit-flex;
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: flex;
		justify-content: center;
	}
	.site-portal #footer .iinkai_nav > li {
		margin: 0 15px;
	}
}
@media screen and (max-width: 768px) {
	.site-portal #footer .iinkai_nav {
		padding: 10px 0;
		background-color: #f1f1f1;
	}
	.site-portal #footer .iinkai_nav > li {
		padding: 5px 0;
	}
}

/* small
------------------------------------------------------------- */
.site-portal #footer small {
	background-color: #fff;
}
@media screen and (max-width: 768px) {
}

/* container
============================================================================================================ */
.site-portal #container {
	padding-top: 240px;
}
@media screen and (max-width: 768px) {
	.site-portal #container {
		padding-top: 160px;
	}
}


/* portalMain
============================================================================================================ */
#portalMain {
	background-repeat: no-repeat;
	background-position: 50%;
	-webkit-background-size: cover;
	background-size: cover;
}
#portalMain a {
	position: relative;
	display: block;
	text-align: center;
	text-decoration: none;
	z-index: 1;
}
#portalMain a::before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	left: 0;
	bottom: 0;
	opacity: .5;
	z-index: -1;
}
#portalMain a .btn {
	position: relative;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 254px;
	height: 48px;
	margin: 20px auto 0;
	padding: 0 10px;
	border-radius: 100px;
	text-decoration: none;
	color: #fff !important;
	text-align: center;
	font-weight: bold;
	font-size: 1.6rem;
	line-height: 1.3;
	z-index: 2;
}
#portalMain a .btn::before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	border-radius: 100px;
	opacity: .9;
	z-index: -1;
}
#portalMain a .btn > * {
	display: inline-block;
	position: relative;
	padding-left: 20px;
	vertical-align: middle;
}
#portalMain a .btn > *::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 0;
	width: 10px;
	height: 10px;
	margin-top: -5px;
	border-top: 3px solid #fff;
	border-right: 3px solid #fff;
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	-o-transform: rotate(45deg);
	transform: rotate(45deg);
}
#portalMain a.rinri::before  {
	background: linear-gradient(127deg, #0066FF 0%, #478AEF 100%);
}
#portalMain a.rinri .btn  {
	background-color: #357fef;
}
#portalMain a.saisei::before  {
	background: linear-gradient(127deg, #579800 0%, #75BE14 100%);
}
#portalMain a.saisei .btn  {
	background-color: #75be14;
}
#portalMain a.nintei::before  {
	background: linear-gradient(127deg, #AA5D00 0%, #FF8C00 100%);
}
#portalMain a.nintei .btn  {
	background-color: #ff8c00;
}
#portalMain a.hito::before  {
	background: linear-gradient(127deg, #C2007C 0%, #EF47B2 100%);
}
#portalMain a.hito .btn  {
	background-color: #ef35ab;
}
@media screen and (min-width: 769px), print {
	#portalMain {
		background-image: url(../img/portal_main_bg.jpg);
	}
	#portalMain ul {
		display: -webkit-flex;
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: flex;
		-webkit-flex-wrap: wrap;
		-moz-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
		-o-flex-wrap: wrap;
		flex-wrap: wrap;
	}
	#portalMain ul li {
		width: 50%;
	}
	#portalMain a {
		height: 200px;
		padding-top: 30px;
	}
	#portalMain a .btn {
		-webkit-transition: background 0.2s;
		-o-transition: background 0.2s;
		transition: background 0.2s;
	}
	#portalMain a.hito  {
		padding-top: 20px;
	}
	#portalMain a.hito .btn  {
		margin-top: 15px;
	}
	#portalMain a.rinri:hover .btn  {
		background-color: #001e62;
	}
	#portalMain a.saisei:hover .btn  {
		background-color: #295a29;
	}
	#portalMain a.nintei:hover .btn  {
		background-color: #9b5d12;
	}
	#portalMain a.hito:hover .btn  {
		background-color: #620055;
	}
}
@media screen and (max-width: 768px) {
	#portalMain {
		background-image: url(../img/portal_main_bg_sp.jpg);
	}
	#portalMain a {
		padding: 30px 20px;
	}
}


/* portal_news
============================================================================================================ */
.site-portal .page_contents .chiken a {
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	-ms-align-items: center;
	align-items: center;
	background-color: #ebe9e7;
	text-decoration: none;
	color: #001E62;
	font-weight: bold;
	font-size: 1.6rem;
	line-height: 1.4;
}
.site-portal .page_contents .chiken a .img {
	width: 56px;
	height: 100%;
	background: url(../img/portal_chiken_img.jpg) no-repeat 50%;
	-webkit-background-size: cover;
	background-size: cover;
}
.site-portal .page_contents .chiken a .txt {
	position: relative;
	padding-left: 36px;
}
.site-portal .page_contents .chiken a .txt span {
	font-size: 1.8rem;
}
.site-portal .page_contents .chiken a .txt::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 15px;
	width: 8px;
	height: 8px;
	margin-top: -4px;
	border-top: 2px solid;
	border-right: 2px solid;
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	-o-transform: rotate(45deg);
	transform: rotate(45deg);
}
.site-portal .page_contents .h2 {
	font-size: 2.8rem;
}
.site-portal .portal_news section {
	padding-top: 10px;
}
.site-portal .portal_news section h1 {
	position: relative;
	margin-bottom: 20px;
	padding-left: 25px;
	font-size: 2.4rem;
	line-height: 1.5;
	font-weight: bold;
}
.site-portal .portal_news section h1::before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	width: 15px;
	border-top: 5px solid;
	margin-top: -3px;
}
.site-portal .portal_news .rinri h1::before {
	border-color: #3D84EE;
}
.site-portal .portal_news .saisei h1::before {
	border-color: #78BE1C;
}
.site-portal .portal_news .nintei h1::before {
	border-color: #FB8E09;
}
.site-portal .portal_news .hito h1::before {
	border-color: #EB4EB2;
}

.site-portal .portal_news .portal_news_list {
	margin-bottom: 40px;
	border-top: 1px solid #dfdfdf;
}
.site-portal .portal_news .portal_news_list li {
	border-bottom: 1px solid #dfdfdf;
}
.site-portal .portal_news .portal_news_list a {
	position: relative;
	display: block;
	padding: 15px 0;
	text-decoration: none;
	color: #333 !important;
	line-height: 1.5;
}
.site-portal .portal_news .portal_news_list a .cat span + span {
	display: none;
}
.site-portal .portal_news .portal_news_list a .title {
	display: block;
	margin-top: 6px;
}
@media screen and (min-width: 769px), print {
	.site-portal .page_contents .chiken {
		position: absolute;
		right: 0;
		top: 50px;
		z-index: 3;
	}
	.site-portal .page_contents .chiken a {
		width: 410px;
		height: 40px;
	}
	.site-portal .page_contents .chiken a:hover {
		text-decoration: underline;
	}
	.site-portal .page_contents .h2 {
		margin-bottom: 40px;
	}
	.site-portal .portal_news {
		display: -webkit-flex;
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: flex;
		justify-content: space-between;
		-webkit-flex-wrap: wrap;
		-moz-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
		-o-flex-wrap: wrap;
		flex-wrap: wrap;
	}
	.site-portal .portal_news section {
		width: 460px;
	}
	.site-portal .portal_news .portal_news_list a .date {
		display: inline-block;
		width: 6.6em;
	}
	.site-portal .portal_news .portal_news_list a:hover .title {
		text-decoration: underline;
	}
}
@media screen and (max-width: 768px) {
	.site-portal .page_contents .chiken {
		margin-bottom: 30px;
	}
	.site-portal .page_contents .chiken a {
		height: 80px;
	}
	.site-portal .page_contents .chiken a .img {
		width: 110px;
	}
	.site-portal .page_contents .chiken a .txt span {
		display: block;
	}
	.site-portal .portal_news section:last-child  .portal_news_list {
		margin-bottom: 0;
	}
	.site-portal .portal_news .portal_news_list a .date {
		font-size: 1.5rem;
		margin-right: 10px;
	}
	.site-portal .portal_news .portal_news_list a .title {
		margin-top: 10px;
	}
}

/* skr追加 */
.form_contents {
  width: 80%;
  margin: 0 auto;
}
.form_ul {
  border: 1px solid #999;
  padding: 10px;
  margin: 0 0 20px;
}

.colgroup {
display: flex;
margin-bottom: 30px;
}

.colgroup .col6 {
width: 48%;
}

.colgroup .col:last-of-type {
margin-right: 0;
}

@media screen and (max-width: 768px) {
    .colgroup {
      flex-direction: column;
      margin-bottom: 0;
    }
    .colgroup .col6 {
      width: 100%;
    }
    .colgroup .col {
      margin-bottom: 30px;
    }
}

/* 関連法規集 */
.category_buttons {
	display: flex;
	justify-content: center;
	margin-bottom: 50px;
}

.category_buttons a {
	width: 20%;
	margin: 0 1%;
	padding: 5px 10px;
	background: #357fef;
	color: #fff;
	text-align: center;
	text-decoration: none;
}

.category_buttons a:hover {
	background: #001e62;
}

.category_buttons a.is-current {
	background: #001e62;
}

.category_buttons a.saisei {
	background: #75be14;
}

.category_buttons a.saisei:hover {
	background: #295a29;
}

.category_buttons a.saisei.is-current {
	background: #295a29;
}

.category_buttons a.saisei.anchor {
	background: #295a29;
}

.category_buttons a.saisei.anchor:hover {
	background: #75be14;
}

.category_buttons_faq > ul > li > span.is-current.saisei {
	background: #75be14;
}

.category_buttons_faq > ul > li > span.is-current.saisei:hover {
	background: #295a29;
}

.category_buttons a.rinri {
	background: #357fef;
}

.category_buttons a.rinri:hover {
	background: #001e62;
}

.category_buttons a.rinri.is-current {
	background: #001e62;
}

.category_buttons a.rinri.anchor {
	background: #001e62;
}

.category_buttons a.rinri.anchor:hover {
	background: #357fef;
}

.category_buttons_faq > ul > li > span.is-current.rinri {
	background: #357fef;
}

.category_buttons_faq > ul > li > span.is-current.rinri:hover {
	background: #001e62;
}

.category_buttons a.nintei {
	background: #ff8c00;
}

.category_buttons a.nintei:hover {
	background: #9b5d12;
}

.category_buttons a.nintei.is-current {
	background: #9b5d12;
}

.category_buttons a.nintei.anchor {
	background: #9b5d12;
}

.category_buttons a.nintei.anchor:hover {
	background: #ff8c00;
}

.category_buttons_faq > ul > li > span.is-current.nintei {
	background: #ff8c00;
}

.category_buttons_faq > ul > li > span.is-current.nintei:hover {
	background: #9b5d12;
}

.category_buttons a.hito {
	background: #ef35ab;
}

.category_buttons a.hito:hover {
	background: #620055;
}

.category_buttons a.hito.is-current {
	background: #620055;
}

.category_buttons a.hito.anchor {
	background: #620055;
}

.category_buttons a.hito.anchor:hover {
	background: #ef35ab;
}

.category_buttons_faq > ul > li > span.is-current.hito {
	background: #ef35ab;
}

.category_buttons_faq > ul > li > span.is-current.hito:hover {
	background: #620055;
}

.regulations_list article {
	padding-bottom: 30px;
	margin-bottom: 30px;
	border-bottom: solid 1px #dfdfdf;
}

.regulations_list article:last-of-type {
	padding-bottom: 0px;
	margin-bottom: 0px;
	border-bottom: none;
}

.regulations_list_entry {
	display: inline;
	margin-right: 10px;
}

.regulations_list_entry a {
	color: #000;
}

.regulations_list_category {
	display: inline-block;
}

.regulations_list_category ul {
	display: inline-block;
}

.regulations_list_category ul li {
	display: inline-block;
	margin-right: 3px;
}

.regulations_list_category ul li a {
	display: inline-block;
	width: 120px;
	padding: 3px 10px;
	margin-bottom: 3px;
	font-size: 11px;
	background: #357fef;
	color: #fff;
	text-decoration: none;
	text-align: center;
}

.regulations_list_category ul li a:hover {
	background: #001e62;
}

.regulations_list_category ul li a.saisei {
	background: #75be14;
}

.regulations_list_category ul li a.saisei:hover {
	background: #295a29;
}

.regulations_list_category ul li a.nintei {
	background: #ff8c00;
}

.regulations_list_category ul li a.nintei:hover {
	background: #9b5d12;
}

.regulations_list_category ul li a.hito {
	background: #ef35ab;
}

.regulations_list_category ul li a.hito:hover {
	background: #620055;
}

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

	.category_buttons {
		flex-wrap: wrap;
		margin-bottom: 30px;
	}

	.category_buttons a {
    width: 48%;
    margin: 0 4% 10px 0;
		font-size: 13px;
	}

	.category_buttons a:nth-child(2n) {
		margin-right: 0;
	}

	.regulations_list article {
    padding-bottom: 20px;
    margin-bottom: 20px;
	}

	.regulations_list_category ul li a {
		width: 100px;
		font-size: 10px;
	}
}


/* faq */

.category_buttons_faq {
	margin-bottom: 30px;
}

.category_buttons_faq > ul {
	display: flex;
	flex-grow: 1;
}

.category_buttons_faq > ul > li {
	position: relative;
	width: 100%;
	margin: 0 7px 0 0;
}

.category_buttons_faq > ul > li > a,
.category_buttons_faq > ul > li > span {
	display: flex;
	justify-content: center;
	width: 100%;
	padding: 5px 10px;
	background: #3a3a3a;
	color: #fff;
	cursor: pointer;
	font-size: 13px;
}

.category_buttons_faq > ul > li > span.is-current {
	background: #717171;
}

.category_buttons_faq > ul > li > a:hover {
	background: #717171;
}

.category_buttons_faq > ul > li > span:hover {
	background: #3a3a3a;
}

.category_buttons_faq > ul > li:last-of-type {
	margin-right: 0;
}

.category_buttons_faq > ul > li > span.js-accordion:before {
	position: absolute;
	top: 50%;
	right: 10px;
	content: "";
	display: block;
	width: 5px;
	height: 5px;
	margin-top: -2.5px;
	border-top: solid 1px #fff;
	border-right: solid 1px #fff;
	transform: rotate(135deg);
}

.category_buttons_faq .accordion_body {
	position: absolute;
	top: 100%;
	left: 0;
	display: none;
	width: 100%;
	font-size: 13px;
}

.category_buttons_faq .accordion_body > ul {
	width: 100%;
}

.category_buttons_faq .accordion_body > ul > li {
	display: block;
	background: #3a3a3a;
}

.category_buttons_faq .accordion_body > ul > li > a {
	display: block;
	width: 100%;
	padding: 5px 10px;
	margin: 0;
	background: #3a3a3a;
	border-bottom: solid 1px #919191;
}

.category_buttons_faq .accordion_body > ul > li > a:hover {
	background: #717171;
}

.faq_csv {
	margin-bottom: 40px;
	text-align: right;
}

a.faq_csv_button {
	display: inline-block;
	padding: 7px 30px;
	background: #357fef;
	color: #fff;
	border-radius: 20px;
	text-decoration: none;
}

a.faq_csv_button:hover {
	background: #001e62;
}

.categorylabel_top {
	padding-bottom: 10px;
	margin-bottom: 20px;
	font-size: 25px;
	border-bottom: solid 3px #001e62;
}

.faq_list > li {
	margin-bottom: 40px;
}

.faq_list_entries {
	margin-bottom: 40px;
	padding-left: 30px;
}

.faq_list_entries article {
	padding-bottom: 20px;
	margin-bottom: 20px;
	border-bottom: solid 1px #c1c1c1;
}

.faq_list_entries article:last-of-type {
	padding-bottom: 0;
	margin-bottom: 0;
	border-bottom: none;
}

.faq_list_entries_question {
	position: relative;
	padding-left: 30px;
	margin-bottom: 10px;
	font-weight: bold;
}

.faq_list_entries_question:before {
	position: absolute;
	top: -4px;
	left: 0;
	content: "Q";
	font-size: 20px;
	font-weight: bold;
	color: #357fef;
}

.faq_list_entries_answer {
	position: relative;
	padding-left: 30px;
	font-size: 13px;
}

.faq_list_entries_answer:before {
	position: absolute;
	top: -4px;
	left: 0;
	content: "A";
	font-size: 20px;
	font-weight: bold;
	color: #ff8c00;
}

.submenu > li > .categorylabel_sub {
	padding-left: 30px;
	margin-bottom: 20px;
	font-size: 20px;
	font-weight: bold;
	border-left: solid 3px #001e62;
}

.submenu > li > .submenu > li > .categorylabel_sub {
	position: relative;
	padding-left: 30px;
	margin-bottom: 20px;
	font-size: 17px;
	font-weight: bold;
	border-left: none;
}

.submenu > li > .submenu > li > .categorylabel_sub:before {
	position: absolute;
	top: 50%;
	left: 0;
	content :"";
	display: block;
	width: 20px;
	height: 2px;
	margin-top: -1px;
	background: #001e62;
}

.faq_title {
	position: relative;
	padding-left: 40px;
	margin-top: 60px;
	margin-bottom: 20px;
	font-size: 25px;
}

.faq_title:before {
	position: absolute;
	top: -10px;
	left: 0;
	content: "Q";
	font-size: 35px;
	font-weight: bold;
	color: #357fef;
}

.faq_entry_detail {
	position: relative;
	padding-top: 15px;
	padding-left: 40px;
}

.faq_entry_detail:before {
	position: absolute;
	top: -4px;
	left: 0;
	content: "A";
	font-size: 35px;
	font-weight: bold;
	color: #ff8c00;
}

.faq_entry_detail p {
	margin-bottom: 40px;
}

.faq_entry_detail h2 {
	padding-left: 20px;
	margin-bottom: 10px;
	font-size: 20px;
	font-weight: bold;
	border-left: solid 3px #001e62;
}

.faq_entry_detail h3 {
	position: relative;
	padding-left: 30px;
	margin-bottom: 10px;
	font-size: 17px;
	font-weight: bold;
	border-left: none;
}

.faq_entry_detail h3:before {
	position: absolute;
	top: 50%;
	left: 0;
	content :"";
	display: block;
	width: 20px;
	height: 2px;
	margin-top: -1px;
	background: #001e62;
}

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

	.category_buttons_faq > ul {
		flex-wrap: wrap;
		align-items: baseline;
	}

	.category_buttons_faq > ul > li {
		width: 48%;
		margin: 0 4% 10px 0;
	}

	.category_buttons_faq > ul > li:nth-child(2n) {
		margin-right: 0;
	}

	.category_buttons_faq .accordion_body {
		z-index: 1000;
	}

	.faq_csv {
		margin-bottom: 20px;
	}

	.faq_list_entries {
		padding-left: 0;
	}

	.faq_title {
		padding-left: 30px;
		line-height: 1.4;
		font-size: 20px;
	}

	.faq_title:before {
    position: absolute;
    top: -7px;
    left: 0;
    content: "Q";
    font-size: 25px;
    font-weight: bold;
    color: #357fef;
	}

	.faq_entry_detail {
    padding-top: 5px;
    padding-left: 30px;
	}

	.faq_entry_detail:before {
    font-size: 25px;
	}

	.faq_entry_detail p {
    margin-bottom: 20px;
	}

	.faq_entry_detail h2 {
    padding-left: 10px;
    margin-bottom: 10px;
    font-size: 17px;
		line-height: 1.6;
	}

	.faq_entry_detail h3 {
    padding-left: 25px;
    margin-bottom: 10px;
		line-height: 1.6;
	}

	.faq_entry_detail h4 {
		margin-bottom: 10px;
		line-height: 1.6;
	}

	.category_buttons_faq > ul > li > a,
	.category_buttons_faq > ul > li > span {
    display: flex;
    justify-content: center;
    width: 100%;
    padding: 5px 15px;
    font-size: 12px;
	}

	.category_buttons_faq > ul > li > span.js-accordion:before {
		margin-top: -5px;
	}

}

/* search */

#header nav .gnav > li.search {
	position: relative;
	width: 200px;
	pointer-events: painted;
}

#header nav .gnav > li.search-lower {
	top: 15px;
	-webkit-transition: top 0.4s ease-in-out;
	-o-transition: top 0.4s ease-in-out;
	transition: top 0.4s ease-in-out;
}

.page-scroll #header nav .gnav > li.search-lower {
	top: 5px;
}

#header nav .gnav > li.search form {
	position: relative;
	top: 3px;
	display: flex;
}

#header nav .gnav > li.search form input[type="text"] {
	width: 160px;
	padding: 5px 15px;
	font-size: 13px;
	box-sizing: border-box;
	background: #fff;
	border: solid 1px #c1c1c1;
	cursor: pointer;
	border-top-left-radius: 3px;
	border-bottom-left-radius: 3px;
}

#header nav .gnav > li.search form input[type="text"]:hover {
	background: #f6f6f6;
}

#header nav .gnav > li.search form input[type="text"]::placeholder {
	font-size: 11px;
	color: #999;
}

#header nav .gnav > li.search form button {
	width: 40px;
	background: #3a3a3a;
	border: none;
	border-top-right-radius: 3px;
	border-bottom-right-radius: 3px;
}

#header nav .gnav > li.search form button:hover {
	background: #717171;
}

#header nav .gnav > li.search form button img {
	position: relative;
	top: -2px;
	width: 16px;
	height: auto;
}

.nav-search {
	position: absolute;
	top: 35%;
	opacity: 0;
}

.showed-search .nav-search {
	opacity: 1;
}

.showed-search .nav-search form {
	display: flex;
	padding-bottom: 8px;
	border-bottom: solid 1px #999;
}

.showed-search .nav-search form input[type="text"] {
	flex: 1;
	padding: 5px 15px;
	border: none;
	background: none;
	color: #fff;
}

.showed-search .nav-search form input[type="text"]::placeholder {
	color: #fff;
}

.showed-search .nav-search form button {
	width: 25px;
	padding: 0;
	background: none;
	border: none;
}

.showed-search .nav-search form button img {
	width: 25px;
}

#header .nav_btn-search img {
	width: 17px;
}

.content-nav {
	margin-top: 40px;
	text-align: center;
}

.content-nav span {
	display: inline-block;
	width: 35px;
	height: 35px;
	margin: 0 3px;
	font-size: 17px;
	background: #001e62;
	color: #fff;
	font-weight: bold;
	text-align: center;
	line-height: 35px;
	border-radius: 17.5px;
}

.content-nav a {
	display: inline-block;
	width: 35px;
	height: 35px;
	margin: 0 3px;
	font-size: 17px;
	background: #357fef;
	color: #fff;
	font-weight: bold;
	text-align: center;
	line-height: 35px;
	border-radius: 17.5px;
	text-decoration: none;
}

.content-nav a.prev,
.content-nav a.next {
	width: auto;
	padding: 0 20px;
}

.news_list_search {
	padding-top: 40px;
}

a.faq-btn-small {
display: inline-block;
width: auto;
margin-top: 5px;
padding: 3px 15px;
font-size: 12px;
background: #698BD8;
color: #fff;
border-radius: 20px;
text-decoration: none;
}

a.faq-btn-small:hover {
background: #357fef;
}

@media screen and (max-width: 768px) {
  #header nav .gnav > li.search {
    display: none;
  }
}
