@charset "utf-8";

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,svg,video{vertical-align:middle}address,caption,cite,code,dfn,em,th,var{font-style:normal;font-weight:400}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,picture{display:block}.clearfix:after,.row:after{content:"";display:table;clear:both}.fl{float:left}.fr{float:right}@media screen and (min-width: 768px),print{.pc_fl{float:left}.pc_fr{float:right}}@media screen and (max-width: 767px){.sp_fl{float:left}.sp_fr{float:right}}.tal{text-align:left!important}.tac{text-align:center!important}.tar{text-align:right!important}@media screen and (min-width: 768px),print{.pc_tal{text-align:left!important}.pc_tac{text-align:center!important}.pc_tar{text-align:right!important}}@media screen and (max-width: 767px){.sp_tal{text-align:left!important}.sp_tac{text-align:center!important}.sp_tar{text-align:right!important}}


/* ========================================================
	template.css => テンプレート用CSS
======================================================== */
html {
	font-size: 62.5%;
}
body {
	background-color: #fff;
	font-size: 10px;
	font-size: 1rem;
	line-height: 1.8;
	color: #1a1a1a;
	word-wrap: break-word;
	overflow-wrap: break-word;

	font-family: "游ゴシック", YuGothic, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", Verdana, Arial, Helvetica, sans-serif;
	font-weight: 400;
	-webkit-text-size-adjust: 100%;
	text-size-adjust: 100%;
}
*,
*::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] {
	color: #cb002d;
	text-decoration: underline;
	outline: none;
}
a[href]:hover {
	text-decoration: none;
}
a[href].a_reverse,
.a_reverse a[href] {
	text-decoration: none;
}
@media screen and (min-width: 768px) {
	a[href].a_reverse:hover,
	.a_reverse a[href]:hover {
		text-decoration: underline;
	}
}

label {
	cursor: pointer;
}
input, select, textarea, button {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	max-width: 100%;
	margin: 0;
	border-radius: 0;
	vertical-align: middle;
	font-family: inherit;
	outline: none;
	font-size: 100%;
}
::-webkit-input-placeholder {
	color: #ccc;
}
:-ms-input-placeholder {
	color: #ccc;
}
::-moz-placeholder {
	color: #ccc;
}
select::-ms-expand {
	display: none;
}

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

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


/* pc / sp
============================================================================================================ */
@media screen and (min-width: 768px), print {
	.sp {
		display: none !important;
	}
	.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: 767px) {
	.pc {
		display: none !important;
	}
	.sp_break {
		position: relative;
		display: block;
		height: 0;
		overflow: hidden;
	}
}
@media screen and (min-width: 371px) {
	.sps {
		display: none !important;
	}
}
@media screen and (max-width: 370px) {
	.sps_non {
		display: none !important;
	}
}

/* transition
============================================================================================================ */
@media screen and (min-width: 768px) {
	body.init a[href],
	body.init a[href]::before,
	body.init a[href]::after,
	body.init button,
	body.init button::before,
	body.init button::after,
	body.init .basic_trs,
	body.init .basic_trs::before,
	body.init .basic_trs::after,
	body.init .basic_trs *,
	body.init .basic_trs *::before,
	body.init .basic_trs *::after {
		transition: color 0.2s ease-in-out, background 0.2s ease-in-out, border 0.2s ease-in-out, opacity 0.2s ease-in-out;
	}
	body.init a svg {
		transition: fill 0.2s ease-in-out;
	}
}

/* font family
============================================================================================================ */
.ff_en {
	font-family: 'Roboto', sans-serif;
	font-weight: 700;
}

/* color
============================================================================================================ */
.c_blue {
	color: #133b8c;
}
.c_red {
	color: #cb002d;
}

/* font
============================================================================================================ */
.fwb {
	font-weight: bold;
}
.fwn {
	font-weight: normal;
}

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

/* position
============================================================================================================ */
.pos-r {
	position: relative;
}

/* object-fit
============================================================================================================ */
img.of {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* hover
============================================================================================================ */
@media screen and (min-width: 768px), 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);
		z-index: 3;
	}
	body.init a.hv_wh::after,
	body.init button.hv_wh::after,
	body.init a .hv_wh::after,
	body.init .hv_wh a::after {
		transition: background 0.2s;
	}
	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);
	}

	body.init a[href] .hv_op {
		transition: opacity 0.2s;
	}
	a[href].hv_op:hover,
	a[href]:hover .hv_op,
	button.hv_op:hover,
	.hv_op a[href]:hover {
		opacity: 0.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;
	}
	a[href].hv_op.a50:hover,
	a[href]:hover .hv_op.a50,
	.hv_op.a50 a[href]:hover {
		opacity: 0.5;
	}
}

.hv_zoom {
	position: relative;
	display: block;
	overflow: hidden;
}
.hv_zoom > * {
	position: absolute;
	top: 0;
	right: 0;
	left: 0;
	bottom: 0;
	background-repeat: no-repeat;
	background-position: 50%;
	background-size: cover;
}
@media screen and (min-width: 768px), print {
	body.init a[href].hv_zoom > *,
	body.init a[href] .hv_zoom > * {
		transition: transform 0.6s, opacity .3s;
	}
	a[href]:hover .hv_zoom.s > * {
		transform: scale(1.03);
	}
	a[href]:hover.hv_zoom > *,
	a[href]:hover .hv_zoom > * {
		transform: scale(1.05);
	}
}


/* target
============================================================================================================ */
.target {
	display: block;
	position: relative;
	width: 1px;
	top: -90px;
}
.target.pt {
	top: -120px;
}
@media screen and (max-width: 767px) {
	.target {
		top: -60px;
	}
	.target.pt {
		top: -80px;
	}
}



/* w
============================================================================================================ */
.w {
	position: relative;
}
@media screen and (min-width: 768px), print {
	.w {
		width: 960px;
		margin: 0 auto;
	}
	.mw {
		min-width: 1100px;
	}
	.xw {
		position: relative;
		max-width: 1300px;
		padding-left: 30px;
		padding-right: 30px;
		margin: 0 auto;
	}
}
@media screen and (max-width: 767px) {
}


/* spパディング
============================================================================================================ */
@media screen and (max-width: 767px) {
	.sp_pd {
		padding-left: 5vw !important;
		padding-right: 5vw !important;
	}
	.sp_full {
		margin-left: -5vw !important;
		margin-right: -5vw !important;
	}
	.sp_full_l {
		margin-left: -5vw !important;
	}
	.sp_full_r {
		margin-right: -5vw !important;
	}
}


/* header
============================================================================================================ */
#header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	font-weight: bold;
	z-index: 999;
}
@media print {
	#header {
		position: absolute;
	}
}
@media screen and (min-width: 768px), print {
	#header > * {
		position: relative;
		display: flex;
		justify-content: space-between;
		align-items: center;
		height: 90px;
	}
	#header > *::before {
		content: "";
		position: absolute;
		top: 0;
		bottom: 0;
		right: 320px;
		left: -1000px;
		background-color: #fff;
		border-radius: 0 0 30px 0;
		box-shadow: 0 0 5px rgba(0,0,0,.1);
		transform-origin: 100% 100%;
		transform: skewX(-45deg);
		z-index: -1;
	}
	#header nav,
	#header nav ul,
	#header nav dl {
		display: flex;
		align-items: center;
	}
	#header nav ul a {
		position: relative;
		display: block;
		text-align: center;
		text-decoration: none;
		line-height: 1.5;
		color: #1a1a1a;
	}
	#header nav .gnav a {
		overflow: hidden;
		display: flex;
		height: 90px;
		justify-content: center;
		align-items: center;
		padding: 0 25px;
		font-size: 1.8rem;
	}
	#header nav .gnav a::after {
		content: "";
		position: absolute;
		right: 25px;
		left: 25px;
		bottom: 0;
		border-top: 4px solid #133b8c;
		transform: translateY(3px);
		opacity: 0;
	}
	body.init #header nav .gnav a::after {
		transition: transform .2s ease-in-out, opacity .2s ease-in-out;
	}
	#header nav .gnav a:hover,
	#header nav .gnav a.current {
		color: #133b8c;
	}
	#header nav .gnav a:hover::after,
	#header nav .gnav a.current::after {
		transform: translateY(0);
		opacity: 1;
	}
	#header nav .lang {
		margin-left: 130px;
		margin-right: -15px;
		font-size: 1.4rem;
		padding: 15px;
		border-radius: 100px;
	}
	.init #header nav .lang {
		transition: background .3s;
	}
	.head-min #header nav .lang {
		background-color: rgba(255,255,255,.9);
	}

	#header nav .lang dt {
		margin-right: 10px;
	}
	#header nav .lang li + li {
		border-left: 1px solid #1a1a1a;
	}
	#header nav .lang a {
		padding: 2px 16px;
	}
	#header nav .lang a::after {
		content: "";
		position: absolute;
		right: 16px;
		left: 16px;
		bottom: 0;
		border-top: 2px solid #000;
		transform: translateY(3px);
		opacity: 0;
	}
	body.init #header nav .lang a::after {
		transition: transform .2s ease-in-out, opacity .2s ease-in-out;
	}
	#header nav .lang a:hover::after,
	#header nav .lang a.current::after {
		transform: translateY(0);
		opacity: 1;
	}
}
@media screen and (max-width: 767px) {
	#header {
		height: 60px;
	}
	#header::before {
		content: "";
		position: absolute;
		top: 0;
		right: 100px;
		bottom: 0;
		left: -1000px;
		background-color: #fff;
		border-radius: 0 0 30px 0;
		box-shadow: 0 0 5px rgba(0,0,0,.1);
		transform-origin: 100% 100%;
		transform: skewX(-45deg);
		z-index: -1;
		z-index: 2;
	}
	#header .logo {
		position: relative;
		float: left;
		z-index: 3;
	}
	#header .logo a {
		display: flex;
		align-items: center;
		height: 60px;
		padding: 0 15px;
	}

	/* nav_btn */
	#header .nav_btn {
		position: absolute;
		right: 0;
		top: 0;
		width: 60px;
		height: 60px;
		/* background-color: #133b8c; */
		z-index: 15;
	}
	#header .nav_btn a {
		position: relative;
		display: block;
		height: 60px;
	}
	#header .nav_btn::after {
		content: "";
		position: absolute;
		top: 5px;
		right: 5px;
		left: 5px;
		bottom: 5px;
		background-color: #fff;
		border-radius: 100%;
		opacity: 0;
		z-index: -1;
	}
	#header .nav_btn::before,
	#header .nav_btn a::before,
	#header .nav_btn a::after {
		content: "";
		position: absolute;
		left: 50%;
		top: 50%;
		width: 24px;
		margin-top: -1px;
		margin-left: -12px;
		border-top: 2px solid #133b8c;
		pointer-events: none;
	}
	body.init #header .nav_btn::before,
	body.init #header .nav_btn::after,
	body.init #header .nav_btn a::before,
	body.init #header .nav_btn a::after {
		transition: all 0.3s ease-in-out;
	}
	#header .nav_btn a::before {
		transform: translateY(-8px);
	}
	#header .nav_btn a::after {
		transform: translateY(8px);
	}

	/* nav_btn open */
	#header.open .nav_btn::before,
	#header.open .nav_btn a::before,
	#header.open .nav_btn a::after {
		border-color: #fff;
	}
	#header.open .nav_btn::after {
		opacity: 0 !important;
	}
	#header.open .nav_btn::before {
		opacity: 0;
	}
	#header.open .nav_btn a::before {
		transform: translateY(0) rotate(45deg);
	}
	#header.open .nav_btn a::after {
		transform: translateY(0) rotate(-45deg);
	}

	.head-min #header .nav_btn::after {
		opacity: 1;
	}

	/* nav */
	#header nav {
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		max-height: 100vh;
		padding-top: 60px;
		background-color: #133b8c;
		overflow-y: scroll;
		-webkit-overflow-scrolling: touch;
		transform: translateX(110%);
		z-index: 1;
	}
	body.init #header nav {
		transition: transform 0.3s ease-in-out;
	}
	/* open */
	#header.open nav {
		transform: translateX(0%);
	}

	#header nav ul a {
		position: relative;
		display: block;
		padding: 20px 35px;
		text-decoration: none;
		line-height: 1.5;
		color: #fff;
	}
	#header nav .gnav a {
		border-bottom: 1px solid rgba(255,255,255,0.3);
		font-size: 1.5rem;
	}
	#header nav .gnav a::before {
		content: "";
		position: absolute;
		top: 50%;
		right: 20px;
		width: 10px;
		height: 10px;
		border-top: 3px solid #fff;
		border-right: 3px solid #fff;
		transform-origin: 100% 0;
		transform: rotate(45deg);
	}
	#header nav .lang {
		display: flex;
		justify-content: center;
		align-items: center;
		padding: 20px 35px;
		font-size: 1.1rem;
		color: #fff;
	}
	#header nav .lang dt {
		margin-right: 10px;
	}
	#header nav .lang ul {
		display: flex;
		justify-content: center;
		align-items: center;
	}
	#header nav .lang li + li {
		border-left: 1px solid #fff;
	}
	#header nav .lang a {
		padding: 2px 16px;
	}
	#header nav .lang a::after {
		content: "";
		position: absolute;
		right: 16px;
		left: 16px;
		bottom: 0;
		border-top: 2px solid #fff;
		transform: translateY(3px);
		opacity: 0;
	}
	#header nav .lang a.current::after {
		transform: translateY(0);
		opacity: 1;
	}
}
@media screen and (max-width: 359px) {
	#header .logo a {
		width: 200px;
	}
}


/* footer
============================================================================================================ */
#footer {
	position: relative;
	border-top: 1px solid #e6e6e6;
	font-size: 1.6rem;
	color: #1a1a1a;
}
@media screen and (min-width: 768px), print {
	#footer .xw {
		display: flex;
		align-items: center;
		justify-content: space-between;
		height: 90px;
	}
}
@media screen and (max-width: 767px) {
	#footer {
		font-size: 1.2rem;
	}
}

/* info
------------------------------------------------------------- */
@media screen and (min-width: 768px), print {
	#footer .info {
		display: flex;
		align-items: center;
	}
	#footer .logo {
		margin-right: 1.5em;
	}
}
@media screen and (max-width: 767px) {
	#footer .info {
		padding: 25px 0;
		text-align: center;
		font-size: 1.4rem;
	}
	#footer .logo {
		margin-bottom: 10px;
	}
}

/* nav
------------------------------------------------------------- */
#footer .nav ul {
	display: flex;
	align-items: center;
}
#footer .nav a {
	position: relative;
	display: block;
	color: #1a1a1a;
}
@media screen and (min-width: 768px), print {
	#footer .nav li {
		margin-left: 20px;
	}
	#footer .nav a {
		padding-left: 26px;
	}
	#footer .nav a::before {
		content: "";
		position: absolute;
		left: 0;
		top: 50%;
		width: 18px;
		height: 18px;
		margin-top: -9px;
		background-color: #133b8c;
		border-radius: 100%;
	}
	#footer .nav a::after {
		content: "";
		position: absolute;
		top: 50%;
		left: 6px;
		width: 6px;
		height: 6px;
		border-top: 1px solid #fff;
		border-right: 1px solid #fff;
		transform-origin: 100% 0;
		transform: rotate(45deg);
	}
}
@media screen and (max-width: 767px) {
	#footer .nav {
		padding: 15px 0;
		background-color: #f5f3f0;
	}
	#footer .nav ul {
		justify-content: center;
	}
	#footer .nav a {
		padding: 0 10px;
	}
}


/* small
------------------------------------------------------------- */
#footer small {
	display: block;
	padding: 20px;
	background-color: #343434;
	font-size: 1.3rem;
	color: #fff;
	text-align: center;
}
@media screen and (max-width: 767px) {
	#footer small {
		padding: 15px 0;
		font-size: 1rem;
	}
}

/* pagetop
------------------------------------------------------------- */
#pagetop {
	position: fixed;
	overflow: hidden;
	bottom: 30px;
	right: 30px;
	width: 40px;
	height: 40px;
	border: 2px solid #133b8c;
	background-color: #133b8c;
	border-radius: 6px;
	pointer-events: none;
	opacity: 0;
	z-index: 98;
}
#pagetop::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	width: 10px;
	height: 10px;
	margin-top: -5px;
	border-top: 2px solid #fff;
	border-left: 2px solid #fff;
	transform-origin: 0 0;
	transform: rotate(45deg);
}
.init #pagetop {
	transition: opacity 0.3s, background .2s;
}
#pagetop.show {
	opacity: 1;
	pointer-events: auto;
}
#pagetop.abs {
	position: absolute;
	bottom: calc(100% + 30px);
}
@media print {
	#pagetop {
		display: none;
	}
}
@media screen and (min-width: 768px) {
	#pagetop:hover {
		background-color: #fff;
	}
	#pagetop:hover::before {
		border-color: #133b8c;
	}
}
@media screen and (max-width: 767px) {
	#pagetop {
		bottom: 15px;
		right: 15px;
	}
	#pagetop.abs {
		bottom: calc(100% + 15px);
	}
}


/* container
============================================================================================================ */
#container {
	position: relative;
	font-size: 1.6rem;
	line-height: 1.8;
}
#container::before,
#container::after {
	content: "";
	display: table;
	clear: both;
}
@media screen and (max-width: 767px) {
	#container {
		font-size: 1.4rem;
	}
}


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

	パーツ

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

/* ul / ol
============================================================================================================ */
.dot_li > li {
	position: relative;
	padding-left: 1em;
}
.dot_li > li::before {
	content: "・";
	position: absolute;
	top: 0;
	left: 0;
}

.circle_li > li {
	position: relative;
	padding-left: 1.1em;
}
.circle_li > li::before {
	content: "●";
	position: absolute;
	top: 0;
	left: 0;
	color: #005f8b;
	transform-origin: 0;
	transform: scale(0.8);
}

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

.parentheses_li_h > li {
	position: relative;
	padding-left: 1.6em;
}
.parentheses_li_h > li > span:first-child {
	position: absolute;
	top: 0;
	left: 0;
}
.parentheses_li_hh > li {
	position: relative;
	padding-left: 2.2em;
}
.parentheses_li_hh > li > span:first-child {
	position: absolute;
	top: 0;
	left: 0;
}

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

.square_li > li {
	position: relative;
	padding-left: 0.8em;
}
.square_li > li::before {
	content: "";
	position: absolute;
	left: 0;
	top: .8em;
	width: 5px;
	height: 5px;
	background-color: #14143c;
}
@media screen and (max-width: 767px) {
	.square_li > li::before {
		top: 0.6em;
	}
}

.num_li {
	margin-left: 1.8em;
	list-style: decimal;
}
.alphabet_li {
	margin-left: 1.8em;
	list-style: lower-latin;
}

.mt_li > li + li {
	margin-top: 0.8em;
}
@media screen and (max-width: 767px) {
	.sp_mt_li > li + li {
		margin-top: 0.8em;
	}
}

.inline_li > li {
	display: inline-block;
	margin-right: 0.3em;
}
