@charset "utf-8";

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700&family=Noto+Serif+JP:wght@400;500;600;700;900&display=swap');

body {
	margin: 0;
	padding: 0;
	-webkit-text-size-adjust: 100%;
	-moz-text-size-adjust: 100%;
	text-size-adjust: 100%;
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 14px;
	color: #14173B;
	background-color: #f3f3f5;
}

img {
	line-height: 1px !important;
	vertical-align: bottom !important;
}
img.border {
	border: 1px solid #d0d1d8;
}

.clearfix:after {
	content: "";
	display: block;
	clear: both;
}

a {
	color: #1DAABD;
	-webkit-tap-highlight-color: rgba(0,0,0,0);
}

h1, h2, h3, h4, h5, h6, div, p, ul, ol, dl, dt, dd, li, a, table, th, td {
	margin: 0;
	padding: 0;
	line-height: 1;
}

.bold {
	font-weight: bold !important;
}

.txt_l {
	text-align: left !important;
}

.txt_r {
	text-align: right !important;
}

.txt_c {
	text-align: center !important;
}

.txt_indent {
	text-indent: 1em !important;
}

.indent_block {
	text-indent: -1em;
	padding-left: 1em;
}

.indent_txt_list {
	display: block;
	list-style: none;
}
.indent_txt_list li {
	display: block;
	list-style: none;
	text-indent: -1em;
	margin-left: 1em;
}





/*----------------------------
margin
----------------------------*/
.mb0 {
	margin-bottom: 0 !important;
}
.mb12 {
	margin-bottom: 12px !important;
}
.mb15 {
	margin-bottom: 15px !important;
}
.mb24 {
	margin-bottom: 24px !important;
}
.mb30 {
	margin-bottom: 30px !important;
}
.mb34 {
	margin-bottom: 34px !important;
}
.mb40 {
	margin-bottom: 40px !important;
}


.ml1 {
	margin-left: 1em !important;
}





/*----------------------------
text color
----------------------------*/
.cr1_900 {
	color: #04A0B6;
}
.cr1_800 {
	color: #1DAABD;
}
.cr1_700 {
	color: #36B3C5;
}
.cr1_600 {
	color: #4FBDCC;
}
.cr1_500 {
	color: #68C6D3;
}





/*----------------------------
header
----------------------------*/
.header_area {
	position: relative;
	padding: 17px 0px 12px 17px;
	border-bottom: 1px solid #C1C3CE;
	line-height: 1;
}
.header_area .header_logo {
	/* color: #784296;

	font-size: 22px;
	line-height: 1;
	font-family: Noto Sans JP Black;
	font-weight: 900;
	letter-spacing: 0px; */
	width: 107px;
	text-align: left;
}
.header_area .header_logo a {
	display: inline-block;
	line-height: 1;
	color: #784296;
	text-decoration: none;
}
.header_area img {
	width: 100%;
	height: auto;
	vertical-align: bottom;
}





/*----------------------------
footer
----------------------------*/
.footer_area {
	background: #F4F4F6;
}
.footer_area img {
	width: 100%;
	height: auto;
}
.footer_copyright {
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 400;
	font-size: 12px;
	line-height: 1;
	color: #8D91A1;
	text-align: center;
	margin: 0;
	padding: 21px 0;
}
.footer_copyright_txt {
	font-style: normal;
	font-weight: 400;
	font-size: 12px;
	line-height: 1;
	color: #8D91A1;
	text-align: center;
	margin: 0 12px;
	padding: 15px 0 30px 0;
	border-top: 1px solid #C1C3CE;
}

.footer_link {
	display: block;
	list-style: none;
	padding: 32px 29px 33px 29px;
}
.footer_link li {
	display: block;
	list-style: none;
}
.footer_link li a {
	font-size: 14px;
	line-height: 28px;
	color: #8D91A1;
	text-decoration: none;
}

.footer_logo {
	text-align: center;
	width: 124px;
	margin: 0 auto 7px auto;
}





/*----------------------------
bread_link
----------------------------*/
.bread_link {
	display: flex;
	align-items: flex-start;
	justify-content: flex-start;
	flex-wrap: wrap;
	margin: 15px 10px 11px 13px;
}

.bread_link img {
	width: 100%;
}

.bread_link li {
	float: left;
	display: inline-block;
	list-style: none;
	word-break: break-all;
	font-size: 14px;
	line-height: 20px;
	color: #53586C;
	text-decoration: none;
}

.bread_link li a {
	word-break: break-all;
	text-decoration: none;
}

.bread_link li.bread_link_icon {
	flex-shrink: 0;
	width: 17px;
	margin: 0 6px 0 0;
}







/*----------------------------
headline
----------------------------*/
.hl_1 {
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 400;
	font-size: 24px;
	line-height: 140%;
	color: #14173B;
}
.hl_2 {
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 400;
	font-size: 22px;
	line-height: 140%;
	color: #14173B;
}





/*----------------------------
title
----------------------------*/
.ttl_1 {
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 400;
	font-size: 20px;
	line-height: 140%;
	color: #14173B;
}
.ttl_2 {
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 400;
	font-size: 18px;
	line-height: 140%;
	color: #14173B;
}
.ttl_3 {
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 400;
	font-size: 16px;
	line-height: 140%;
	color: #14173B;
}





/*----------------------------
text
----------------------------*/
.txt_1 {
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 400;
	font-size: 15px;
	line-height: 150%;
	color: #14173B;
}
.txt_2 {
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 400;
	font-size: 14px;
	line-height: 150%;
	color: #14173B;
}
.txt_3 {
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 400;
	font-size: 12px;
	line-height: 150%;
	color: #14173B;
}





/*----------------------------
text caption
----------------------------*/
.txt_cap {
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 400;
	font-size: 10px;
	line-height: 150%;
	color: #14173B;
}





/*----------------------------
card
----------------------------*/
.card_box {
	background: #fff;
	border: 1px solid #D0D1D8;
	border-radius: 8px;
	padding: 24px;
}
.card_box_ttl {
	font-weight: 500;
	font-size: 18px;
	line-height: 140%;
	color: #303251;
	margin-bottom: 8px;
}
.card_box_txt {
	font-weight: 400;
	font-size: 15px;
	line-height: 150%;
	color: #14173B;
}





/*----------------------------
slick custom style
----------------------------*/
.slide_nav_prev {
	position: absolute;
	z-index: 150;
	top: 50%;
	left: 7px;
	transform: translateY(-50%);
	width: 13px;
}
.slide_nav_next {
	position: absolute;
	z-index: 200;
	top: 50%;
	right: 7px;
	transform: translateY(-50%);
	width: 13px;
}

.slide_nav_prev.slick-disabled,
.slide_nav_next.slick-disabled {
	opacity: 0;
}

.slick-dotted.slick-slider {
	margin-bottom: 53px;
}
.slick-dots {
	position: absolute;
	bottom: -22px;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	padding: 0;
	margin: 0;
	list-style: none;
	text-align: center;
}
.slick-dots li {
	position: relative;
	display: block;
	width: 10px;
	height: 10px;
	margin: 0 8px 0 0;
	padding: 0;
	cursor: pointer;
}
.slick-dots li:last-child {
	margin-right: 0;
}
.slick-dots li button {
	display: block;
	width: 10px;
	height: 10px;
	padding: 0;
}
.slick-dots li button:before {
	font-size: 6px;
	line-height: 1;
	width: 10px;
	height: 10px;
	content: '•';
	opacity: 1;
	color: #72748A;
}
.slick-dots li.slick-active button:before {
	opacity: 1;
	color: #4FBDCC;
}
.slick-track {
	display: flex;
}
.slick-slide {
	height: auto !important;
}



/* slider */
.slide_item_area {
	background-color: #f4f4f6;
	padding: 24px 13px 24px 14px;
	padding: 24px 0px 24px 0px;
}

.slide_item_list {
	position: relative;
	display: block;
	list-style: none;
}

.slide_item_list .slide_item {
	display: block;
	list-style: none;
	background: #fff;
	border: 1px solid #D0D1D8;
	border-radius: 8px;
	padding: 24px;
	margin: 0 14px;
}

.slide_item_list .slide_item_ttl {
	text-align: center;
	font-weight: 500;
	font-size: 15px;
	line-height: 150%;
	color: #303251;
	margin-bottom: 10px;
}

.slide_item_list .slide_item_desc {
	display: flex;
	align-items: center;
	justify-content: flex-start;
}

.slide_item_list .slide_item_img {
	flex-shrink: 0;
	margin: 0 15px 0 0;
	width: 45%;
}

.slide_item_list .slide_item_txt {
	font-weight: 400;
	font-size: 14px;
	line-height: 150%;
	color: #14173B;
}





/*----------------------------
banner
----------------------------*/
.bnr_border {
	border: 1px solid #C1C3CE;
}





/*----------------------------
button
----------------------------*/
.btn_type_a {
	text-decoration: none !important;

	background: none;
	background-color: #1DAABD;
	border: none;
	border-radius: 12px;

	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 500;
	font-size: 16px;
	line-height: 140%;

	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	color: #fff;

	margin: 0 auto;
	padding: 17px 32px;
}

.btn_type_a .btn_icon {
	flex-shrink: 0;
	margin-right: 11px;
	width: 18px;
}

.btn_type_a:hover {
	background-color: #04A0B6;
}





.info_area {
	border: 1px solid #D81241;
	margin: 0 15px 28px 15px;
	padding: 12px 9px;
}
.info_area .info_txt,
.info_area p.info_txt {
	font-size: 15px;
	line-height: 26px;
	color: #D81241;
	margin-bottom: 1em;
}
.info_area .info_txt:last-child,
.info_area p.info_txt:last-child {
	margin-bottom: 0;
}