@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;500;700;800;900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@300;400;500;600;700;900&display=swap');
/*------------------------------------------------------------
	デフォルトスタイル
------------------------------------------------------------*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td {
	margin: 0;
	padding: 0;
	background: transparent;
	border: 0;
	outline: 0;
	font-size: 1em;
}
html {
	font-size: 62.5%;
}
body, table, input, textarea, select, option {
	font-family: 'Noto Sans JP', sans-serif;
}
article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary {
	display: block;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
:focus {
	outline: 0;
}
ins {
	text-decoration: none;
}
del {
	text-decoration: line-through;
}
img {
	vertical-align: top;
	max-width: 100%;
	height: auto;
}
a, a:link {
	color: #333;
	text-decoration: none;
}
a:visited {
	color: #333;
}
a:hover {
	color: #333;
	opacity: 0.7;
}
a:active {
	color: #333;
}
/*------------------------------------------------------------
	レイアウト
------------------------------------------------------------*/
body {
	min-width: 1280px;
	color: #333;
	font-size: 1.6rem;
	line-height: 2;
	text-size-adjust: none;
	-webkit-text-size-adjust: none;
	background-color: #FFF;
}
#container {
	text-align: left;
}
#main {
	margin-bottom: 136px;
}
a[href^="tel:"] {
	cursor: default;
	pointer-events: none;
}
a[href^="tel:"]:hover {
	opacity: 1 !important;
}
@media all and (min-width: 897px) {
	.sp {
		display: none !important;
	}
	.menuBox {
		display: none !important;
	}
}
@media all and (max-width: 896px) {
	body {
		min-width: inherit;
	}
	body.fixed {
		width: 100%;
		position: fixed;
		left: 0;
		top: 0;
	}
	a:hover, a:hover img {
		opacity: 1 !important;
	}
	.pc {
		display: none !important;
	}
	a[href^="tel:"] {
		cursor: pointer;
		pointer-events: auto;
	}
	#main {
		margin-bottom: 116px;
	}
	#container {
		padding-top: 51px;
	}
}
/*------------------------------------------------------------
	ヘッダー
------------------------------------------------------------*/
#gHeader {
	padding: 24px 16px 13px;
}
#gHeader .logo {
	margin: -7px 10px 0 -1px;
	width: 356px;
}
#gHeader .logo a:hover {
	opacity: 1;
}
#gHeader .hBox {
	flex: 1;
	justify-content: flex-end;
}
#gHeader .hLink {
	width: 522px;
}
#gHeader .hLink li {
	width: 32.7%;
}
#gHeader .hLink li a {
	padding: 13px 5px 15px;
	display: block;
	color: #fff;
	background-color: #81CBDF;
	text-align: center;
}
#gHeader .hLink li a span {
	padding-left: 17px;
	letter-spacing: 0.05em;
	display: inline-block;
	background: url("../img/icon01.png") no-repeat left center;
	line-height: 1.25;
}

#gHeader .hLink li a p {
	font-size: 11px;
}

#gHeader .hLink li:nth-child(2) a {
	background-color: #3DB8D9;
}
#gHeader .hLink li:nth-child(3) a {
	background-color: #D9CB27;
	height: 32px;
}
#gHeader .telBox {
	margin: -10px 32px 0 0;
}
#gHeader .telBox .tel {
	margin-bottom: 4px;
}
#gHeader .telBox .tel a {
	color: #3DB8D9;
	font-size: 3rem;
	line-height: 1;
	font-family: 'Noto Serif JP', serif;
	letter-spacing: 0.05em;
}
#gHeader .telBox .tel span {
	margin-right: 9px;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 300;
	font-size: 1.8rem;
}
#gHeader .telBox .text {
	margin-left: 51px;
	padding-left: 5em;
	font-size: 1.3rem;
	line-height: 1.4;
	text-indent: -5em;
}
@media all and (max-width: 896px) {
	#gHeader {
		padding: 0;
		position: fixed;
		width: 100%;
		box-sizing: border-box;
		left: 0;
		top: 0;
		z-index: 1000;
	}
	#gHeader .flexB {
		padding: 13px 17px 8px;
		background-color: #fff;
		position: relative;
		z-index: 1001;
	}
	#gHeader .hBox {
		display: none;
	}
	#gHeader .logo {
		width: 178px;
	}
	.menu {
		display: block;
		position: fixed;
		right: 0;
		top: 2px;
		width: 60px;
		height: 60px;
		z-index: 1001;
	}
	.menu span {
		display: inline-block;
		transition: all .4s;
		box-sizing: border-box;
		position: absolute;
		right: 13px;
		width: 26px;
		height: 2px;
		background-color: #3DB8D9;
	}
	.menu span:nth-of-type(1) {
		top: 15px;
	}
	.menu span:nth-of-type(2) {
		top: 23px;
	}
	.menu span:nth-of-type(3) {
		top: 31px;
	}
	.menu.on span:nth-of-type(1) {
		-webkit-transform: translateY(10px) rotate(-45deg);
		transform: translateY(10px) rotate(-45deg);
	}
	.menu.on span:nth-of-type(2) {
		opacity: 0;
	}
	.menu.on span:nth-of-type(3) {
		-webkit-transform: translateY(-6px) rotate(45deg);
		transform: translateY(-6px) rotate(45deg);
	}
	.menuBox {
		display: none;
		padding-top: 92px;
		position: fixed;
		left: 0;
		top: 0;
		width: 100%;
		background-color: #fff;
		z-index: 1000;
		height: 100%;
		overflow-y: auto;
		box-sizing: border-box;
	}
	#gNavi {
		display: none;
	}
	.menuBox .bannerList {
		margin: 0 20px 62px;
	}
	.menuBox .bannerList li {
		margin-bottom: 5px;
	}
	.menuBox .bannerList li a {
		padding: 25px 17px 24px;
		display: flex;
		color: #fff;
		position: relative;
		align-items: center;
		justify-content: space-between;
		background: url("../img/sp_bg01.png") no-repeat center center;
		background-size: cover;
	}
	.menuBox .bannerList li.banner01 a::before, .menuBox .bannerList li.banner02 a::before {
		margin-top: -6px;
		width: 6px;
		height: 12px;
		position: absolute;
		right: 22px;
		top: 50%;
		background: url("../img/sp_icon03.png") no-repeat left top / 100% auto;
		content: '';
	}
	.menuBox .bannerList li.banner02 a {
		background: url("../img/sp_bg02.png") no-repeat center center;
		background-size: cover;
	}
	.menuBox .bannerList li.banner03 a {
		padding: 12px 17px;
		background: #81CBDF;
	}
	.menuBox .bannerList li.banner04 a {
		padding: 12px 17px 10px;
		background: #FBF9EE;
		color: #000;
	}
	.menuBox .bannerList li.banner05 a {
		padding: 12px 17px 13px;
		background: #DAF1F9;
		color: #000;
	}
	.menuBox .bannerList li.banner03 a:before, .menuBox .bannerList li.banner04 a:before, .menuBox .bannerList li.banner05 a:before {
		display: none;
	}
	.menuBox .bannerList li a:before {
		margin-top: -5px;
		position: absolute;
		right: 15px;
		top: 50%;
		background: url("../img/sp_icon12.png") no-repeat left top;
		background-size: 6px auto;
		width: 6px;
		height: 11px;
		content: "";
	}
	.menuBox .bannerList li .imgSpan {
		width: 51px;
		text-align: center;
	}
	.menuBox .bannerList li .imgSpan img {
		width: 100%;
	}
	.menuBox .bannerList li .txtBox {
		width: calc(100% - 65px);
		font-size: 1.7rem;
		font-weight: 500;
	}
	.menuBox .bannerList li .en {
		display: block;
		font-size: 1rem;
		letter-spacing: 0.05em;
		margin-top: 2px;
	}
	.menuBox .spNavi {
		margin: 0 20px 100px;
	}
	.menuBox .spNavi li {
		position: relative;
	}
	.menuBox .spNavi li > a {
		display: block;
		padding: 17px 0;
		border-bottom: 1px solid #ededed;
		border-top: 1px solid #ededed;
	}
	.menuBox .spNavi li .imgSpan {
		display: inline-block;
		width: 26px;
		text-align: center;
		margin: 0 14px 0 0;
	}
	.menuBox .spNavi li .imgSpan img {
		width: 100%;
	}
	.menuBox .spNavi li img {
		display: inline-block;
		vertical-align: middle;
		margin: -3px 0 0 0;
	}
	.menuBox .spNavi li .icoSpan {
		position: absolute;
		cursor: pointer;
		right: -10px;
		top: 10px;
		background: url("../img/sp_icon11.png") no-repeat center center;
		background-size: 14px auto;
		width: 50px;
		height: 50px;
		content: "";
	}
	.menuBox .spNavi li .icoSpan.on {
		background: url("../img/sp_icon10.png") no-repeat center center;
		background-size: 14px auto;
	}
	.menuBox .spNavi li .infoNavi {
		display: none;
		padding: 12px 0 32px 14px;
	}
	.menuBox .spNavi li .infoNavi li a {
		border: none;
		position: relative;
		padding: 7px 6px 7px 18px;
	}
	.menuBox .spNavi li .infoNavi li a:before {
		position: absolute;
		left: 4px;
		top: 24px;
		width: 8px;
		height: 1px;
		background: #333;
		content: "";
	}
	.spFixed {
		position: fixed;
		left: 0;
		right: -1px;
		bottom: 0;
		z-index: 200;
		background-color: #fff;
	}
	.spFixed li {
		float: left;
		width: 33.33%;
		box-sizing: border-box;
		border-right: 1px solid #81CBDF;
	}
	.spFixed li a {
		display: flex;
		align-items: center;
		justify-content: center;
		flex-wrap: wrap;
		flex-direction: column;
		color: #fff;
		height: 70px;
		font-size: 1.2rem;
		font-weight: 500;
		text-align: center;
		background: #3DB8D9;
		letter-spacing: 0;
	}
	.spFixed .bgColor a {
		background: #D9CC28;
	}
	.spFixed li img {
		margin-bottom: 7px;
		display: block;
		width: 23px;
	}
}
/*------------------------------------------------------------
	フッター
------------------------------------------------------------*/
#gNavi {
	margin: 58px auto 0;
	max-width: 1100px;
	text-align: center;
}
#gNavi ul {
	margin-right: -15px;
	display: flex;
}
#gNavi li {
	margin-right: 120px;
}
#gNavi li:last-child {
	margin-right: 0;
}
#gNavi li a {
	display: block;
	letter-spacing: 0.1em;
}
#gNavi li a span {
	margin-bottom: 6px;
	display: block;
}
@media all and (max-width: 896px) {
	#gNavi {
		display: none;
	}
}
/*------------------------------------------------------------
	pagePath
------------------------------------------------------------*/
#pagePath {
	margin: 0 auto 15px;
	padding: 21px 0 12px;
}
#pagePath ul {
	width: 1100px;
	margin: 0 auto;
}
#pagePath li {
	display: inline;
	font-size: 1.4rem;
}
#pagePath a {
	margin-right: 5px;
	font-size: 1.4rem;
}
@media all and (max-width: 896px) {
	#pagePath {
		display: none;
	}
}
/*------------------------------------------------------------
	フッター
------------------------------------------------------------*/
#gFooter {
	line-height: 1.5;
}
#gFooter .fBox {
	padding: 98px 0 88px;
	background: #333;
}
#gFooter .pageTop {
	position: fixed;
	right: 10px;
	bottom: 10px;
	z-index: 50;
}
#gFooter .fBox .fNavi {
	width: 850px;
}
#gFooter .fBox .fNavi p {
	margin-bottom: 24px;
	padding-bottom: 20px;
	color: #fff;
	font-size: 1.8rem;
	border-bottom: 1px solid rgba(255, 255, 255, 0.3);
	letter-spacing: 0.2em;
}
#gFooter .fBox .fNavi p a {
	color: #fff;
}
#gFooter .fNavi > li {
	margin-right: 51px;
	float: left;
	width: 248px;
}
#gFooter .fNavi > .liStyle01 {
	width: 500px;
}
#gFooter .fNavi > .liStyle02 {
	margin: 0 -16px 0 0;
	width: 250px;
}
#gFooter .fNavi > li > ul > li {
	padding-bottom: 10px;
	color: #fff;
	letter-spacing: 0.05em;
}
#gFooter .fNavi > li > ul > li > a {
	color: #fff;
	font-size: 1.4rem;
}
#gFooter .fNavi .infoUl > li {
	width: 250px;
	float: left;
}
#gFooter .fNavi .infoUl > li:last-child {
	float: right;
}
#gFooter .fNavi .infoUl > li > ul > li {
	padding-bottom: 10px;
}
#gFooter .fNavi .infoUl li a {
	color: #fff;
	letter-spacing: 0.05em;
	font-size: 1.4rem;
}
#gFooter .fBox .link {
	margin-top: 0px;
}
#gFooter .fBox .link .group{
    padding-bottom: 20px;
    margin-bottom: 24px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.3);
    font-size: 1.8rem;
	color: #fff;
}

#gFooter .fInner {
	padding: 28px 5px;
	text-align: center;
}
#gFooter .fInner address {
	display: block;
	font-style: normal;
	font-size: 1.5rem;
	text-align: center;
}
@media all and (max-width: 896px) {
	#gFooter {
		padding-bottom: 70px;
	}
	#gFooter .pageTop {
		bottom: 80px;
	}
	#gFooter .fBox {
		padding: 65px 0 51px;
	}
	#gFooter .fBox .fNavi {
		width: 100%;
		margin-bottom: 53px;
	}
	#gFooter .fBox .fNavi p {
		margin-bottom: 0;
		padding-left: 36px;
		padding-bottom: 20px;
		font-size: 1.7rem;
		background: url("../img/sp_icon01.png") no-repeat left 2px top / auto 24px;
	}
	#gFooter .fNavi > .liStyle01 p {
		background-image: url("../img/sp_icon02.png");
		background-size: auto 25px;
	}
	#gFooter .fBox .fNavi p .en {
		font-size: 1rem;
		margin-left: 17px;
	}
	#gFooter .fNavi > li {
		margin: 0 0 78px;
		float: none;
		width: 100%;
	}
	#gFooter .fNavi > .liStyle01 {
		margin-bottom: 0;
		width: 100%;
	}
	#gFooter .fNavi > .liStyle02 {
		margin: 0;
		width: 100%;
	}
	#gFooter .fNavi > li > ul > li {
		padding-bottom: 0;
	}
	#gFooter .fNavi > li > ul > li > a {
		color: #fff;
		display: block;
		padding: 19px 10px 19px 0;
		border-bottom: 1px solid rgba(255, 255, 255, 0.3);
	}
	#gFooter .fNavi > li > ul > li > a:hover {
		text-decoration: none;
	}
	#gFooter .fNavi .infoUl > li {
		width: 100%;
		float: none;
	}
	#gFooter .fNavi .infoUl > li:last-child {
		float: none;
	}
	#gFooter .fNavi .infoUl > li > ul > li {
		padding-bottom: 0;
	}
	#gFooter .fNavi .infoUl li a {
		display: block;
		padding: 19px 10px 19px 0;
		border-bottom: 1px solid rgba(255, 255, 255, 0.3);
	}
	#gFooter .fBox .link {
		padding: 0 0;
		width: 100%;
		box-sizing: border-box;
	}
	#gFooter .fBox .link a {
		padding: 2px 0;
		display: block;
		text-align: center;
		background-color: #fff;
	}
	#gFooter .fBox .link a img {
		width: 200px;
	}
    #gFooter .fBox .link .group{
        padding-bottom: 20px;
        margin-bottom: 24px;
        font-size: 1.7rem;
        color: #fff;
    }
    #gFooter .fInner address {
		font-size: 1.3rem;
		line-height: 1.34;
	}
	#gFooter .fInner {
		padding: 24px;
		letter-spacing: 0.05em;
	}
}
/*------------------------------------------------------------
	sideBar
------------------------------------------------------------*/
#sideBar {
	width: 301px;
}
#sideBar .sNavi {
	margin-bottom: 60px;
}
#sideBar .sNavi li {
	margin-bottom: 10px;
}
#sideBar .sNavi li a:hover {
	opacity: 0.7;
}
#sideBar .title {
	font-size: 1.8rem;
}
#sideBar .title a {
	color: #282828;
	padding: 14px 52px 15px;
	display: block;
	font-weight: 700;
	position: relative;
	background: #E7F6FA;
	letter-spacing: 0.05em;
}
#sideBar .title img {
	position: absolute;
	width: 22px;
	left: 15px;
	top: 50%;
	transform: translateY(-50%);
}
#sideBar .linkList {
	margin-bottom: 60px;
}
#sideBar .linkList:last-child {
	margin-bottom: 0;
}
#sideBar .linkList li a {
	padding: 13px 15px 15px;
	display: block;
	position: relative;
	border-bottom: 1px solid #ddd;
	letter-spacing: 0.05em;
	transition: .3s;
	-webkit-transition: .3s;
}
#sideBar .linkList li a:hover {
	color: #81CBDF;
	opacity: 1;
}
#sideBar .linkList li a:hover:before {
	margin-top: -6px;
	position: absolute;
	right: 10px;
	top: 50%;
	width: 7px;
	height: 12px;
	background: url("../img/icon11.png") no-repeat left top;
	background-size: 100% 100%;
	content: "";
}
#sideBar .title02 a {
	background: #E7F6FA url("../img/icon10.png") no-repeat right 30px center;
}
@media all and (max-width: 896px) {
	#sideBar {
		display: none;
	}
}
/*------------------------------------------------------------
	conts
------------------------------------------------------------*/
#conts {
	margin-right: 1px;
	width: 710px;
	float: right;
}
#conts > *:last-child {
	margin-bottom: 0 !important;
}
@media all and (max-width: 896px) {
	#conts {
		margin: 0;
		width: auto;
		float: none;
	}
}
/*------------------------------------------------------------
	汎用スタイル
------------------------------------------------------------*/
/* clearfix */
.clearfix:after {
	content: "";
	display: block;
	clear: both;
}
/* flex */
.flex, .flexA, .flexB, .flexC {
	display: flex;
	flex-wrap: wrap;
}
.flexA {
	justify-content: space-around;
}
.flexB {
	justify-content: space-between;
}
.flexC {
	justify-content: center;
}
/*------------------------------------------------------------
	minCho
------------------------------------------------------------*/
.minCho {
	font-family: 'Noto Serif JP', serif;
}
/*------------------------------------------------------------
	pageTitle
------------------------------------------------------------*/
.pageTitle {
	height: 300px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	text-align: center;
	background: url("../img/page_title_bg.jpg") no-repeat center center;
	background-size: cover;
}
.pageTitle h1 {
	padding: 27px 10px 34px;
	width: 530px;
	color: #000;
	font-weight: 700;
	font-size: 3.6rem;
	line-height: 1.2;
	letter-spacing: 0.23em;
	background-color: #fff;
	box-sizing: border-box;
}
.pageTitle h1 span {
	margin-top: 6px;
	display: block;
	color: #81CBDF;
	font-family: 'Noto Serif JP', serif;
	font-size: 1.8rem;
	font-weight: 400;
	letter-spacing: 0.13em;
}
.pageTitle h1 span::first-letter {
	text-transform: uppercase;
}
@media all and (max-width: 896px) {
	.pageTitle {
		margin-bottom: 40px;
		height: 110px;
		background-image: url("../img/sp_page_title_bg.jpg");
	}
	.pageTitle h1 {
		width: 165px;
		padding: 5px;
		font-size: 1.7rem;
		font-weight: 500;
		letter-spacing: 0.1em;
	}
	.pageTitle h1 span {
		margin-top: 2px;
		font-size: 0.65rem;
	}
}
/*------------------------------------------------------------
	content
------------------------------------------------------------*/
.content {
	width: 1100px;
	margin: 0 auto;
}
@media all and (max-width: 896px) {
	.content {
		width: auto;
		padding: 0 20px;
	}
}
/*------------------------------------------------------------
	headLine01
------------------------------------------------------------*/
.headLine01 {
	margin-bottom: 39px;
	padding: 11px 15px 11px;
	color: #fff;
	line-height: 1.4;
	font-size: 3.2rem;
	font-weight: 700;
	font-family: 'Noto Serif JP', serif;
	background: -webkit-linear-gradient(135deg, #81CBDF, #0071AA);
	background: -moz-linear-gradient(135deg, #81CBDF, #0071AA); /* Firefox 3.6+ */
	background: -ms-linear-gradient(135deg, #81CBDF, #0071AA); /* IE 10 */
	background: -o-linear-gradient(135deg, #81CBDF, #0071AA); /* Opera 11.10+ */
	background: linear-gradient(-45deg, #81CBDF, #0071AA);
	letter-spacing: 0.1em;
}
@media all and (max-width: 896px) {
	.headLine01 {
		display: flex;
		min-height: 68px;
		align-items: center;
		margin-bottom: 41px;
		padding: 6px 20px 6px 15px;
		font-size: 2rem;
		line-height: 1.4;
		box-sizing: border-box;
	}
}
/*------------------------------------------------------------
	headLine02
------------------------------------------------------------*/
.headLine02 {
	margin-bottom: 23px;
	padding-left: 26px;
	font-size: 2.6rem;
	position: relative;
	line-height: 1.4;
	font-family: 'Noto Serif JP', serif;
	font-weight: 700;
	letter-spacing: 0.11em;
}
.headLine02::before {
	width: 2px;
	position: absolute;
	top: 3px;
	bottom: 0;
	left: 0;
	background-color: #3db8d9;
	content: '';
}
@media all and (max-width: 896px) {
	.headLine02 {
		margin-bottom: 39px;
		padding-left: 15px;
		font-size: 1.9rem;
	}
}
/*------------------------------------------------------------
	headLine03
------------------------------------------------------------*/
.headLine03 {
	margin-bottom: 40px;
	padding-bottom: 24px;
	position: relative;
	text-align: center;
	font-size: 3.2rem;
	font-weight: 500;
	letter-spacing: 0.1em;
}
.headLine03::before {
	width: 43px;
	height: 2px;
	bottom: 0;
	position: absolute;
	left: 50%;
	background: #3DB8D9;
	content: '';
	transform: translateX(-50%);
}
@media all and (max-width: 896px) {
	.headLine03 {
		margin-bottom: 21px;
		padding-bottom: 16px;
		font-size: 2rem;
	}
	.headLine03::before {
		width: 26px;
	}
}
/*------------------------------------------------------------
	comDateTab
------------------------------------------------------------*/
.comDateBox {
	margin: 24px auto 10px;
	padding: 22px 20px;
	background-color: #fff;
	width: 680px;
	box-sizing: border-box;
	line-height: 1.5;
}
.comDateTab {
	width: 100%;
	word-break: break-all;
	border-collapse: collapse;
}
.comDateTab th, .comDateTab td {
	padding: 12px 10px;
	width: 10%;
	text-align: center;
	vertical-align: middle;
	border-right: 1px solid #ddd;
	border-bottom: 1px solid #ddd;
	background-color: #fff;
}
.comDateTab th {
	padding: 11px 10px 14px 20px;
	width: 27%;
	font-weight: 500;
	text-align: left;
}
.comDateTab td:last-child {
	border-right: none;
}
.comDateTab tr:last-child th, .comDateTab tr:last-child td {
	border-bottom: none;
}
.comDateTab tr:first-child th, .comDateTab tr:first-child td {
	padding: 8px 10px 11px;
}
.comDateTab td .ico {
	color: #333333;
}
@media all and (max-width: 896px) {
	.comDateBox {
		margin: 0 0 12px;
		width: auto;
		padding: 14px 10px 15px;
	}
	.comDateTab th, .comDateTab td {
		padding: 9px 2px;
		width: 9%;
		font-size: 1.3rem;
	}
	.comDateTab th {
		padding: 9px 2px;
		width: 34%;
	}
	.comDateTab td:last-child {
		border-right: none;
	}
	.comDateTab tr:last-child th, .comDateTab tr:last-child td {
		border-bottom: none;
	}
	.comDateTab tr:first-child th, .comDateTab tr:first-child td {
		padding: 5px 2px;
	}
}
/*------------------------------------------------------------
	comImgBox
------------------------------------------------------------*/
.comImgBox {
	display: flex;
	align-items: flex-start;
	flex-direction: row-reverse;
	justify-content: space-between;
}
.comImgBox .textBox {
	width: 390px;
}
.comImgBox .photoBox {
	width: 239px;
}
.comImgBox .textBox p:not(:last-of-type) {
	margin-bottom: 33px;
}
.comImgBox .textBox p strong {
	background: url(../../common/img/com_bg01.png) repeat-x left bottom / 2px auto;
}
@media all and (max-width: 896px) {}
/*------------------------------------------------------------
	comBorderBox
------------------------------------------------------------*/
.comBorderBox {
	margin-bottom: 80px;
	padding: 25px 20px 26px;
	border: 6px solid #E7F6FA;
}
@media all and (max-width: 896px) {}
/*------------------------------------------------------------
	comBgBox
------------------------------------------------------------*/
.comBgBox {
	padding: 30px 70px 37px;
	position: relative;
	background-color: #E7F6FA;
}
.comBgBox::before {
	width: calc(100% - 9px);
	height: calc(100% - 10px);
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	box-sizing: border-box;
	border: 1px solid #3FAECC;
	content: '';
}
.comBgBox .title {
	margin-bottom: 33px;
	position: relative;
	color: #333;
	font-size: 2.2rem;
	font-weight: 500;
	line-height: 1.55;
	letter-spacing: 0.15em;
	text-align: center;
	font-family: 'Noto Serif JP', serif;
}
.comBgBox .textList li {
	padding: 17px 60px 20px;
	font-size: 1.8rem;
	line-height: 1.4;
	border-bottom: 1px solid #989898;
	background: url(../../img/mutsu/bg01.png) no-repeat left 20px center / 23px auto;
}
.comBgBox .textList li span {
	padding-left: 30px;
	font-weight: 700;
	background: url(../img/com_bg01.png) repeat-x left 20px bottom / 2px auto, url(../img/icon14.png) no-repeat left center / 17px auto;
}
.comBgBox .textList li:first-of-type {
	border-top: 1px solid #989898;
}
@media all and (max-width: 896px) {}
/*------------------------------------------------------------
	comTextList
------------------------------------------------------------*/
.comTextList li {
	margin-bottom: 16px;
	padding: 0 35px 16px;
	position: relative;
	line-height: 2;
	border-bottom: 1px solid #E5E5E5;
}
.comTextList li:last-of-type {
	margin-bottom: 0;
	padding-bottom: 0;
	border-bottom: none;
}
.comTextList.textList01 li:last-of-type {
	padding-bottom: 16px;
	border-bottom: 1px solid #E5E5E5;
}
.comTextList.textList01 li:first-of-type {
	padding-top: 16px;
	border-top: 1px solid #E5E5E5;
}
.comTextList li::before {
	width: 12px;
	height: 12px;
	position: absolute;
	left: 10px;
	top: calc(50% - 8px);
	transform: translateY(-50%);
	background-color: #3db8d9;
	content: '';
}
.comTextList li:last-of-type::before {
	top: 50%;
}
.comTextList.textList01 li:last-of-type::before {
	top: calc(50% - 8px);
}
.comTextList.textList01 li:first-of-type::before {
	top: 50%;
}
@media all and (max-width: 896px) {}
/*------------------------------------------------------------
	comInfo
------------------------------------------------------------*/
.comInfo {
	padding: 71px 0 131px;
	background: -webkit-linear-gradient(-180deg, #80CBE0, #3DB8D9);
	background: -moz-linear-gradient(-180deg, #80CBE0, #3DB8D9); /* Firefox 3.6+ */
	background: -ms-linear-gradient(-180deg, #80CBE0, #3DB8D9); /* IE 10 */
	background: -o-linear-gradient(-180deg, #80CBE0, #3DB8D9); /* Opera 11.10+ */
	background: linear-gradient(90deg, #80CBE0, #3DB8D9);
}
.comInfo h2 {
	margin-bottom: 55px;
	padding-bottom: 23px;
	position: relative;
	text-align: center;
	color: #fff;
	font-size: 3.2rem;
	font-weight: 500;
	letter-spacing: 0.1em;
}
.comInfo h2::before {
	width: 43px;
	height: 1px;
	bottom: 0;
	position: absolute;
	left: 50%;
	background: #fff;
	content: '';
	transform: translateX(-50%);
}
.comInfo .imgBox {
	padding-bottom: 92px;
	margin-bottom: 75px;
	border-bottom: 1px solid #fff;
}
.comInfo .imgBox .mapBox {
	margin-top: 14px;
	width: 480px;
}
.comInfo .imgBox .mapBox .map {
	margin-bottom: 13px;
	background-color: #fff;
	padding-bottom: 481px;
	position: relative;
}
.comInfo .imgBox .mapBox .map iframe {
	width: 100% !important;
	height: 100% !important;
	position: absolute;
	left: 0;
	top: 0;
}
.comInfo .imgBox .mapBox .btn a {
	padding: 19px 19px 17px;
	display: block;
	background: #fff;
	font-size: 1.7rem;
	box-sizing: border-box;
	text-align: center;
}
.comInfo .imgBox .mapBox .btn img {
	display: inline-block;
	vertical-align: middle;
	margin: -3px 22px 0 0;
}
.comInfo .imgBox .textBox {
	width: 579px;
	color: #fff;
}
.comInfo .imgBox .logo {
	margin-bottom: 39px;
}
.comInfo .imgBox .textBox dl {
	line-height: 1.875;
	letter-spacing: 0.05em;
}
.comInfo .imgBox .textBox dt {
	width: 86px;
	float: left;
	position: relative;
}
.comInfo .imgBox .textBox dt::before {
	width: 1px;
	height: 16px;
	position: absolute;
	right: 3px;
	top: 9px;
	background-color: #fff;
	content: '';
}
.comInfo .imgBox .logo p {
	margin-top: 14px;
}
.comInfo .imgBox .textBox dd {
	padding: 0 0 21px 102px;
}
.comInfo .imgBox .textBox dd a {
	color: #fff;
}
.comInfo .notes {
	margin: 0 auto;
	width: 680px;
	text-align: right;
	color: #fff;
	font-size: 1.4rem;
	line-height: 1.928;
	letter-spacing: 0.05em;
}
.comInfo .notes span {
	width: 235px;
	display: inline-block;
	text-align: left;
}
@media all and (max-width: 896px) {
	.comInfo {
		padding: 55px 0 60px;
	}
	.comInfo h2 {
		margin-bottom: 47px;
		padding-bottom: 16px;
		font-size: 2rem;
	}
	.comInfo h2::before {
		width: 26px;
	}
	.comInfo .imgBox {
		margin-bottom: 40px;
		padding-bottom: 41px;
		display: block;
	}
	.comInfo .imgBox .textBox {
		width: auto;
	}
	.comInfo .imgBox .logo {
		margin-bottom: 29px;
	}
	.comInfo .imgBox .logo img {
		width: 178px;
	}
	.comInfo .imgBox .logo p {
		margin-top: 17px;
		line-height: 1.625;
	}
	.comInfo .imgBox .textBox dl {
		line-height: 1.625;
	}
	.comInfo .imgBox .textBox dt {
		padding-left: 22px;
		margin-bottom: 3px;
		width: auto;
		float: none;
	}
	.comInfo .imgBox .textBox dd {
		padding: 0 0 25px;
	}
	.comInfo .imgBox .textBox dt::before {
		width: 13px;
		height: 13px;
		right: auto;
		left: 1px;
		top: 8px;
	}
	.comInfo .imgBox .mapBox {
		margin-top: 36px;
		width: auto;
	}
	.comInfo .imgBox .mapBox .map {
		margin-bottom: 21px;
		padding-bottom: 100%;
	}
	.comInfo .imgBox .mapBox .btn {
		margin: 0 auto;
		width: 100%;
		max-width: 300px;
	}
	.comInfo .imgBox .mapBox .btn a {
		padding: 12px 10px 13px;
		width: 100%;
		font-size: 1.5rem;
		max-width: 300px;
		margin: 0 auto;
	}
	.comInfo .imgBox .mapBox .btn a img {
		margin-right: 11px;
		width: 20px;
	}
	.comInfo .notes {
		width: auto;
		font-size: 1.4rem;
		line-height: 1.428;
	}
	.comInfo .notes span {
		width: auto;
		text-align: right;
	}
}
/*------------------------------------------------------------
	comText
------------------------------------------------------------*/
.comText {
	margin-bottom: 49px;
	letter-spacing: 0.1em;
}
@media all and (max-width: 896px) {}
/*------------------------------------------------------------
	comLine
------------------------------------------------------------*/
.comLine {
	font-weight: 700;
	background: url(../../common/img/com_bg01.png) repeat-x left bottom / 2px auto;
}
/*------------------------------------------------------------
	comTextBox
------------------------------------------------------------*/
.comTextBox {
	margin-bottom: 56px;
	padding-bottom: 21px;
	border-radius: 10px;
	background-color: #F2F2F2;
}
.comTextBox .title {
	margin-bottom: 21px;
	padding: 18px 48px;
	color: #fff;
	font-size: 2rem;
	font-weight: 500;
	line-height: 1.4rem;
	letter-spacing: 0.1em;
	border-radius: 10px;
	background: url(../../common/img/icon12.png) no-repeat left 15px center / 16px auto;
	background-color: #D9CB27;
}
.comTextBox .linkList {
	margin: -18px 15px 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.comTextBox .linkList li {
	margin-top: 18px;
	display: flex;
	align-items: center;
	height: 42px;
	width: calc((100% - 30px) / 2);
	font-size: 1.5rem;
	font-weight: 600;
	line-height: 1.4;
	letter-spacing: 0.1em;
	box-sizing: border-box;
	font-family: 'Noto Serif JP', serif;
}
.comTextBox .linkList li a {
	width: 100% !important;
	padding: 0 21px 0 22px;
	position: relative;
	display: block;
	background: url(../../common/img/icon10.png) no-repeat right 0 center / 6px auto;
	box-sizing: border-box;
}
.comTextBox .linkList li a::before {
	width: 9px;
	height: 9px;
	position: absolute;
	left: 4px;
	top: 6px;
	border-radius: 50%;
	background-color: #D7CC25;
	content: '';
}
@media all and (max-width: 896px) {
	.comTextBox {
		padding-bottom: 5px;
		border-radius: 5px;
	}
	.comTextBox .title {
		margin-bottom: 10px;
		padding-left: 56px;
		border-radius: 5px;
		background-position: left 18px center;
	}
	.comTextBox .linkList {
		margin-top: 0;
		display: block;
	}
	.comTextBox .linkList li {
		margin: 0 0 9px;
		width: auto;
		letter-spacing: 0;
	}
	.comTextBox .linkList li:last-of-type {
		margin-bottom: 0;
	}
	.comTextBox .linkList li a {
		padding: 0 15px 0 22px;
	}
}
/*------------------------------------------------------------
	comTabBox
------------------------------------------------------------*/
.comTabBox {
	margin-bottom: 75px;
}
.comTabBox p {
	margin-bottom: 23px;
}
.comTabBox table {
	width: 100%;
	border-collapse: collapse;
}
.comTabBox table th, .comTabBox table td {
	padding: 21px 25px 19px;
	text-align: left;
	vertical-align: top;
	font-weight: 400;
	border: 1px solid #CDCBCB;
	word-break: break-all;
}
.comTabBox table th {
	padding: 0 10px;
	width: 24%;
	letter-spacing: 0.05em;
}
@media all and (max-width: 896px) {
	.comTabBox {
		margin-bottom: 107px;
	}
	.comTabBox p {
		margin-bottom: 32px;
	}
	.comTabBox table th, .comTabBox table td {
		padding: 8px 11px 10px;
		letter-spacing: 0.02em;
	}
	.comTabBox table td {
		letter-spacing: 0;
	}
	.comTabBox table th {
		padding-top: 8px;
		width: 32.5%;
	}
}
/*------------------------------------------------------------
	comBtn
------------------------------------------------------------*/
.comBtn {
	margin: 0 auto;
	width: 300px;
}
.comBtn a {
	padding: 14px 40px;
	display: block;
	color: #fff;
	line-height: 2;
	letter-spacing: 0.12em;
	text-align: center;
	background: url(../img/icon01.png) no-repeat right 30px center / 7px auto;
	background-color: #D9CB27;
}
.comBtn01 {
	width: 360px;
}
.comBtn01 a {
	letter-spacing: 0;
}
@media all and (max-width: 374px) {
	.comBtn {
		width: auto;
		max-width: 300px;
	}
}
@media all and (max-width: 767px) {
	.comBtn a {
		background-position: right 13px center;
	}
	.comBtn01 {
		max-width: 300px;
		width: auto;
	}
	.comBtn01 a {
		padding: 8px 56px 7px;
		line-height: 1.4;
	}
}
/*------------------------------------------------------------
	comBtn
------------------------------------------------------------*/
.comBtnWhite a {
	color: #333;
	background-image: url("../img/icon11.png");
	background-color: #fff;
}
/*------------------------------------------------------------
	comImgBox
------------------------------------------------------------*/
.comImgBox {
	display: flex;
	align-items: flex-start;
	flex-direction: row-reverse;
	justify-content: space-between;
}
.comImgBox .textBox {
	width: 390px;
}
.comImgBox .photoBox {
	width: 239px;
}
.comImgBox .textBox p:not(:last-of-type) {
	margin-bottom: 33px;
}
.comImgBox .textBox p strong {
	background: url(../../common/img/com_bg01.png) repeat-x left bottom / 2px auto;
}
@media all and (max-width: 896px) {
	.comImgBox {
		display: block;
	}
	.comImgBox .textBox {
		width: auto;
	}
	.comImgBox .photoBox {
		margin: 0 auto 47px;
		width: 202px;
	}
	.comImgBox .textBox p:not(:last-of-type) {
		margin-bottom: 33px;
	}
	.comImgBox .textBox p strong {
		background: url(../../common/img/com_bg01.png) repeat-x left bottom / 2px auto;
	}
}
/*------------------------------------------------------------
	comTextList
------------------------------------------------------------*/
.comTextList li {
	margin-bottom: 16px;
	padding: 0 45px 16px;
	position: relative;
	line-height: 2;
	border-bottom: 1px solid #E5E5E5;
}
.comTextList.textList02 li {
	margin-bottom: 8px;
	padding: 0 10px 8px 45px;
}
.comTextList li:last-of-type {
	margin-bottom: 0;
	padding-bottom: 0;
	border-bottom: none;
}
.comTextList.textList01 li:last-of-type {
	padding-bottom: 16px;
	border-bottom: 1px solid #E5E5E5;
}
.comTextList.textList01 li:first-of-type {
	padding-top: 16px;
	border-top: 1px solid #E5E5E5;
}
.comTextList.textList02 li:first-of-type {
	padding-top: 8px;
	border-top: 1px solid #E5E5E5;
}
.comTextList.textList02 li:last-of-type {
	padding-bottom: 8px;
	border-bottom: 1px solid #E5E5E5;
}
.comTextList li::before {
	width: 12px;
	height: 12px;
	position: absolute;
	left: 18px;
	top: calc(50% - 8px);
	transform: translateY(-50%);
	background-color: #3db8d9;
	content: '';
}
.comTextList.textList02 li::before {
	width: 15px;
	left: 17px;
	top: calc(50% - 4px);
	background: url(../img/icon15.png) no-repeat left center / cover;
}
.comTextList.textList02 li:first-of-type::before {
	top: 50%;
}
.comTextList li:last-of-type::before {
	top: 50%;
}
.comTextList.textList01 li:last-of-type::before {
	top: calc(50% - 8px);
}
.comTextList.textList01 li:first-of-type::before {
	top: 50%;
}
@media all and (max-width: 896px) {
	.comTextList li {
		margin-bottom: 11px;
		padding: 0 35px 14px;
		line-height: 1.4;
	}
	.comTextList.textList01 li {
		padding: 0 20px 10px 45px;
	}
	.comTextList.textList02 li {
		margin-bottom: 0;
		padding: 13px 10px 13px 45px !important;
		min-height: 49px;
		display: flex;
		align-items: center;
		box-sizing: border-box;
	}
	.comTextList.textList01 li:last-of-type {
		padding-bottom: 10px;
	}
	.comTextList.textList01 li:first-of-type {
		padding-top: 11px;
	}
	.comTextList li::before {
		left: 5px;
		top: calc(50% - 5px);
	}
	.comTextList li:last-of-type::before {
		top: 50%;
	}
	.comTextList.textList01 li::before {
		left: 15px;
		top: 5px;
		transform: translateY(0);
	}
	.comTextList.textList01 li:last-of-type::before {
		top: 5px;
	}
	.comTextList.textList01 li:first-of-type::before {
		top: 16px;
	}
	.comTextList.textList02 li::before {
		top: 50%;
		transform: translateY(-50%);
	}
	.comTextList.textList02 li:first-of-type::before {
		top: 50%;
	}
}
/*------------------------------------------------------------
	comBorderBox
------------------------------------------------------------*/
.comBorderBox {
	margin-bottom: 80px;
	padding: 25px 20px 26px;
	border: 6px solid #E7F6FA;
}
.comBorderBox01 {
	border-color: #F8EAFA;
}
.comBorderBox01 .comTextList li::before {
	background-color: #F07FCD;
}
@media all and (max-width: 896px) {
	.comBorderBox {
		margin-bottom: 78px;
		padding: 31px 20px 29px;
		border-width: 4px;
	}
}
/*------------------------------------------------------------
	comBgBox
------------------------------------------------------------*/
.comBgBox {
	padding: 30px 70px 37px;
	position: relative;
	background-color: #E7F6FA;
	font-family: 'Noto Serif JP', serif;
}
.comBgBox::before {
	width: calc(100% - 9px);
	height: calc(100% - 10px);
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	box-sizing: border-box;
	border: 1px solid #3FAECC;
	content: '';
}
.comBgBox .title {
	margin-bottom: 33px;
	position: relative;
	color: #333;
	font-size: 2.2rem;
	font-weight: 500;
	line-height: 1.55;
	letter-spacing: 0.15em;
	text-align: center;
	font-family: 'Noto Serif JP', serif;
}
.comBgBox .textList li {
	padding: 17px 60px 20px;
	font-size: 1.8rem;
	line-height: 1.4;
	font-weight: 600;
	border-bottom: 1px solid #989898;
	background: url(../../img/mutsu/bg01.png) no-repeat left 20px center / 23px auto;
}
.comBgBox .textList li span {
	padding-left: 30px;
	font-weight: 900;
	background: url(../img/com_bg01.png) repeat-x left 20px bottom / 2px auto, url(../img/icon14.png) no-repeat left center / 17px auto;
}
.comBgBox .textList li:first-of-type {
	border-top: 1px solid #989898;
}
@media all and (max-width: 896px) {
	.comBgBox {
		padding: 30px 32px 37px;
	}
	.comBgBox .title {
		margin-bottom: 25px;
	}
	.comBgBox .textList li {
		padding: 12px 0 11px 30px;
		font-size: 1.5rem;
		background-position: left center;
	}
	.comBgBox .textList li span {
		padding-left: 30px;
		font-weight: 700;
	}
	.comBgBox .title {
		margin: 0 -10px 4px;
		font-size: 1.9rem;
	}
	.comBgBox::before {
		height: calc(100% - 6px);
		width: calc(100% - 6px);
	}
}
/*------------------------------------------------------------
	comPho
------------------------------------------------------------*/
.comPho {
	margin: 36px auto 31px;
	width: 300px;
}
@media all and (max-width: 896px) {
	.comPho {
		width: 200px;
	}
	.comPho img {
		width: 100%;
	}
}
/*------------------------------------------------------------
	comBlueBox
------------------------------------------------------------*/
.comBlueBox {
	padding: 33px 33px 42px;
	background-color: #E7F6FA;
}
.comBlueBox h3 {
	margin-bottom: 15px;
}
.comBlueBox h3 .txt {
	width: 56px;
	height: 56px;
	float: left;
}
.comBlueBox h3 .ttl {
	padding: 5px 0 5px 86px;
	display: block;
	font-size: 2.3rem;
	font-weight: 500;
	letter-spacing: 0.15em;
	font-family: 'Noto Serif JP', serif;
}
.comBlueBox p:not(:last-child) {
	margin-bottom: 72px !important;
}
@media all and (max-width: 896px) {
	.comBlueBox {
		padding: 13px 15px 15px;
	}
	.comBlueBox h3 {
		margin-bottom: 6px;
	}
	.comBlueBox h3 .txt {
		width: 28px;
		height: 28px;
	}
	.comBlueBox h3 .ttl {
		margin-top: 3px;
		padding: 0 34px 0 45px;
		font-size: 1.8rem;
		line-height: 1.788;
		letter-spacing: 0.05em;
	}
	.comBlueBox p:not(:last-child) {
		margin-bottom: 67px !important;
	}
}

.gap {gap: 32px;}

.mar-bt136 {margin-bottom: -136px!important}





