@charset "utf-8";
/* CSS Document */

/*==============================*/
/* Header */
/*==============================*/

	/* ======= SP以上 =======*/
	@media (min-width: 768px) {
		#top header{display: none}
	}


/*==============================*/
/* メインビジュアル */
/*==============================*/
div.mainVisual{
	position: relative;
	padding-bottom: 64px;
	margin-bottom: 40px;
}
div.mainVisual::before{
	position: absolute; top: 0; left: 0;
	content: "";
	width: 50%;
	height: 100%;
	background: #00597A url("/common/img/share/bg-texture-white.png");
	z-index: -1;
}
	/* ======= TB =======*/
	@media screen and (min-width: 768px) and (max-width: 1024px) {
	}
	/* ======= SP =======*/
	@media (max-width: 767px) {
		div.mainVisual{
			padding-bottom: 0px;
			margin-bottom: 56px;
		}
		div.mainVisual::before{ display: none;}
	}


/*-- header
------------------------- */
div.mainVisual div.topHeader{
	display: flex; display: -webkit-flex;
	justify-content: space-between; -webkit-justify-content: space-between;
	align-items: center; -webkit-align-items: center;
    padding: 14px 32px 16px 40px;
}
div.mainVisual div.topHeader div{
	display: flex; display: -webkit-flex;
	align-items: center; -webkit-align-items: center;
	width: 694px;
}

/*-- MENU --- */
div.mainVisual div.topHeader ul.topNavi{
	display: flex; display: -webkit-flex;
	margin-right: 48px;
}
div.mainVisual div.topHeader ul.topNavi li:not(:last-child){ margin-right: 48px;}
div.mainVisual div.topHeader ul.topNavi li{
    text-align: center;
    line-height: 1em;
}
div.mainVisual div.topHeader ul.topNavi li a{
	font-size: 17px;
	color: #000;
}
div.mainVisual div.topHeader ul.topNavi li a:hover{
	color: #00597A;
	text-decoration: underline;
}


/*-- Btn --- */
div.mainVisual div.topHeader div p{
	width: 100%;
	max-width: 160px;
}
div.mainVisual div.topHeader div p a{
	display: block;
	padding: 9px 0 12px 0;
	background: #00597A url("/common/img/share/bg-texture-white.png");
	color: #fff;
	font-size: 15px;
	text-align: center;
	border-radius: 5px;
}
div.mainVisual div.topHeader div p a:hover{ background: #003548;}

	/* ======= TB =======*/
	@media screen and (min-width: 768px) and (max-width: 1024px) {
		div.mainVisual div.topHeader{ padding: 14px 16px 16px 20px;}
		div.mainVisual div.topHeader div{ width: 560px;}
		
		/*-- LOGO --- */
		div.mainVisual div.topHeader p.topLogo img{ width: 160px;}
		
		/*-- MENU --- */
		div.mainVisual div.topHeader ul.topNavi{
			display: flex; display: -webkit-flex;
			margin-right: 20px;
		}
		div.mainVisual div.topHeader ul.topNavi li:not(:last-child){ margin-right: 24px;}
		div.mainVisual div.topHeader ul.topNavi li a{
			font-size: 16px;
		}
		
		/*-- Btn --- */
		div.mainVisual div.topHeader div p{ max-width: 144px;}
		div.mainVisual div.topHeader div p a{
			padding: 8px 0 11px 0;
			font-size: 14px;
		}
	}
	/* ======= SP =======*/
	@media (max-width: 767px){
		div.mainVisual div.topHeader{ display: none;}
	}


/*-- Content
------------------------- */
div.mainVisual div.topContent{
	display: flex; display: -webkit-flex;
	align-items: center; -webkit-align-items: center;
}

/*-- content --- */
div.mainVisual div.topContent div{
	width: 50%;
	padding: 64px 80px 0 14%;
	color: #fff;
}
div.mainVisual div.topContent h2{
	margin-bottom: 24px;
	font-size: 32px;
	font-weight: 600;
	line-height: 1.618em;
}
/*-- Btn --- */
div.mainVisual div.topContent p.topBtn{
	width: 100%;
	max-width: 184px;
}
div.mainVisual div.topContent p.topBtn a{
	display: block;
	padding: 10px 0 12px 0;
	background: #fff;
	color: #00597A;
	text-align: center;
	border-radius: 5px;
	border: 1px solid #fff;
}
div.mainVisual div.topContent p.topBtn a:hover{
	background: #00597A;
	color: #fff;
}

/*-- Img --- */
div.mainVisual div.topContent figure{
	position: relative;
	width: calc(50% + 40px);
	margin-left: -40px;
}
div.mainVisual div.topContent figure img{
	object-fit: cover;
	aspect-ratio: 5 / 3;
}

	/* ======= TB：個別設定 =======*/
	@media screen and (min-width: 1025px) and (max-width: 1600px) {
		/*-- content --- */
		div.mainVisual div.topContent div{ padding: 80px 72px 0 64px;}
		div.mainVisual div.topContent h1{
			margin-bottom: 24px;
			font-size: 26px;
		}
		div.mainVisual div.topContent p{ font-size: 14px;}

		/*-- Img --- */
		div.mainVisual div.topContent figure{
			width: calc(50% + 32px);
			margin-left: -32px;
		}
		
	}
	/* ======= TB =======*/
	@media screen and (min-width: 768px) and (max-width: 1024px) {
		/*-- content --- */
		div.mainVisual div.topContent div{ padding: 80px 72px 0 28px;}
		div.mainVisual div.topContent h2{
			margin-bottom: 24px;
			font-size: 24px;
		}
		div.mainVisual div.topContent p{ font-size: 14px;}

		/*-- Img --- */
		div.mainVisual div.topContent figure{
			width: calc(50% + 32px);
			margin-left: -32px;
		}
		div.mainVisual div.topContent figure img{
			object-fit: cover;
			aspect-ratio: 5 / 4;
		}
	}
	/* ======= SP =======*/
	@media (max-width: 767px) {
		div.mainVisual div.topContent{ flex-direction: column-reverse; -webkit-flex-direction: column-reverse;}

		/*-- content --- */
		div.mainVisual div.topContent div{
			width: 100%;
			padding: 32px 24px 32px 24px;
			background: #00597A;
		}
		div.mainVisual div.topContent h2{
			margin-bottom: 20px;
			font-size: 22px;
		}

		/*-- Img --- */
		div.mainVisual div.topContent figure{
			width: 100%;
			margin-left: 0px;
		}
	}


/*==============================*/
/* サービス説明 */
/*==============================*/
div.topService-wrap{ position: relative;}
div.topService-wrap::before{
	position: absolute; top: -104px; right: 0;
	content: "";
	width: 1040px;
	height: 400px;
	background: #F6F6F6;
	z-index: -99;
}

div.topService-box{
	position: relative;
	display: flex; display: -webkit-flex;
	align-items: flex-end;-webkit-align-items: flex-end;
	margin-bottom: 56px;
}

	/* ======= TB =======*/
    @media screen and (min-width: 768px) and (max-width: 1024px) {
    }
    /* ======= SP =======*/
    @media (max-width: 767px) {
		div.topService-wrap{ position: relative;}
		div.topService-wrap::before{ display: none;}

		div.topService-box{
			flex-direction: column-reverse; -webkit-flex-direction: column-reverse;
			margin-bottom: 0px;
		}
    }


/*-- 画像
------------------------- */
div.topService-box figure{ width: 504px;}

	/* ======= TB =======*/
    @media screen and (min-width: 768px) and (max-width: 1024px) {
    }
    /* ======= SP =======*/
    @media (max-width: 767px) {
		div.topService-box figure{ width: 100%; margin-bottom: 24px;}
    }

/*-- コンテンツ
------------------------- */
div.topService-box div{
	flex: 1;
	margin-right: 40px;
	padding-bottom: 48px;
}
	/* ======= TB =======*/
    @media screen and (min-width: 768px) and (max-width: 1024px) {
    }
    /* ======= SP =======*/
    @media (max-width: 767px) {
		div.topService-box div{
			width: 100%;
			margin-right: 0px;
			padding-bottom: 0px;
		}
    }



/*==============================*/
/* サービス */
/*==============================*/
div.topService{
	display: flex; display: -webkit-flex;
	flex-wrap: wrap; -webkit-flex-wrap: wrap;
	gap: 0 32px;
}
div.topService > div{
	position: relative;
	width: calc( calc( 100% - calc( 32px * 1 ) ) / 2 );
	padding: 40px 32px 32px 32px;
	background: #F4F4F4 url("/common/img/share/bg-texture.png");
	border-radius: 5px;
}

	/* ======= TB =======*/
    @media screen and (min-width: 768px) and (max-width: 1024px) {
		div.topService{ gap: 0 20px;}
		div.topService > div{
			width: calc( calc( 100% - calc( 20px * 1 ) ) / 2 );
			padding: 40px 28px 28px 28px;
		}
    }
    /* ======= SP =======*/
    @media (max-width: 767px) {
		div.topService{
			flex-direction: column; -webkit-flex-direction: column;
			gap: 20px 0;
		}
		div.topService > div{
			width: 100%;
			padding: 40px 28px 28px 28px;
		}
    }


/*-- コンテンツ
------------------------- */
div.topService > div:nth-child(1) figure{position: absolute; top: -60px; right: 24px;}
div.topService > div:nth-child(2) figure{position: absolute; top: -56px; right: 24px;}

	/* ======= TB =======*/
    @media screen and (min-width: 768px) and (max-width: 1024px) {
    }
    /* ======= SP =======*/
    @media (max-width: 767px) {
		div.topService > div:nth-child(1) figure{ position: absolute; top: -12px; right: 24px;}
		div.topService > div:nth-child(1) figure img{ width: 120px;}
		div.topService > div:nth-child(2) figure{position: absolute; top: -12px; right: 24px;}
		div.topService > div:nth-child(2) figure img{ width: 160px;}
    }


/*-- コンテンツ
------------------------- */
div.topService h3{
	margin-bottom: 16px;
	font-size: 25px;
	font-weight: 600;
	color: #000;
}
div.topService h3 small{
	display: block;
	color: #00597A;
	font-family: 'Roboto', sans-serif!important;
	font-weight: 600;
	line-height: 1.3em;
	letter-spacing: 0.03em;
}

div.topService div p{
	font-size: 15px;
	line-height: 1.8em;
	text-align: justify;
	text-align-last: left;
}
div.topService div p:not(:last-child){ margin-bottom: 14px;}

	/* ======= TB =======*/
    @media screen and (min-width: 768px) and (max-width: 1024px) {
    }
    /* ======= SP =======*/
    @media (max-width: 767px) {
		div.topService h3{
			margin-bottom: 16px;
			font-size: 24px;
		}
		div.topService div p{
			font-size: 14px;
			line-height: 1.7em;
		}
		div.topService div p:not(:last-child){ margin-bottom: 10px;}
    }




/*==============================*/
/* リンクボックス */
/*==============================*/
div.linkBox{
	display: flex; display: -webkit-flex;
	gap: 0 48px;
}
div.linkBox dl{
	display: flex; display: -webkit-flex;
	flex-direction: column; -webkit-flex-direction: column;
	width: calc( calc( 100% - calc( 48px * 1 ) ) / 2 );
}
div.linkBox dl dt{
	position: relative; top: -20px;
	order: 2;
	max-width: 360px;
	margin-left: 32px;
}
div.linkBox dl dt a{
	display: block;
	padding: 16px 28px 18px 28px;
	background: #fff;
	box-shadow: 4px 4px 0px 0px rgba(0,89,122,1);
	font-size: 28px;
	font-weight: bold;
	line-height: 1.3em;
}
div.linkBox dl dt a small{
	display: block;
	color: #00597A;
	font-size: 15px;
	font-weight: 500;
	letter-spacing: -0.02em;
	line-height: 1.3em;
}
div.linkBox dl dd{ order: 1;}

	/* ======= TB =======*/
	@media screen and (min-width: 768px) and (max-width: 1024px) {
		div.linkBox{gap: 0 24px;}
		div.linkBox dl{ width: calc( calc( 100% - calc( 24px * 1 ) ) / 2 );}
		div.linkBox dl dt{ margin: 0 20px;}
	}
	/* ======= SP =======*/
	@media (max-width: 767px) {
		div.linkBox{
			flex-direction: column; -webkit-flex-direction: column;
			gap: 8px 0;
		}
		div.linkBox dl{ width: 100%;}
		div.linkBox dl dt{
			position: relative; top: -20px;
			order: 2;
			max-width: 360px;
			margin: 0 8px;
		}
		div.linkBox dl dt a{
			padding: 12px 16px;
			font-size: 22px;
		}
		div.linkBox dl dt a small{ font-size: 13px;}
	}



/*==============================*/
/* お知らせ */
/*==============================*/
section.topicsWrap{
	display: flex; display: -webkit-flex;
	align-items: center; -webkit-align-items: center;
	padding-top: 48px;
	padding-bottom: 44px;
	background: #F4F4F4 url("/common/img/share/bg-texture.png");
}


div.topics{
	flex: 1;
	padding: 32px 48px 24px 48px;
	background: #fff;
	border-radius: 5px;
}
div.topics article{
	padding: 24px 0 16px 0;
	border-bottom: 1px solid #ccc;
}
div.topics article:first-child{ padding-top: 0;}
div.topics article:last-child{ padding-bottom: 0; border-bottom: none;}

	 /* ======= SPi以上 =======*/
	@media (min-width: 767px) {
		section.topicsWrap h2{ width: 160px; font-size: 34px;}
	}
	/* ======= TB =======*/
    @media screen and (min-width: 768px) and (max-width: 1024px) {
    }
    /* ======= SP =======*/
    @media (max-width: 767px) {
		section.topicsWrap{
			flex-direction: column; -webkit-flex-direction: column;
			padding-top: 24px;
			padding-bottom: 32px;
		}
		
		section.topicsWrap h2{ width: 100%;}
		
		div.topics{
			width: 100%;
			padding: 28px 24px 24px 24px;
		}
		div.topics article{ padding: 24px 0 20px 0;}
		div.topics article:first-child{ padding-top: 0;}
		div.topics article:last-child{ padding-bottom: 0; border-bottom: none;}
    }


/*-- 
------------------------- */
div.topics article dl{
	display: flex; display: -webkit-flex;
	align-items: center; -webkit-align-items: center;
}

/*-- 日付 -- */
div.topics article dl dt{
	display: flex; display: -webkit-flex;
	align-items: center; -webkit-align-items: center;
	justify-content: space-between; -webkit-justify-content: space-between;
	width: 192px;
}
div.topics article dl dt p:first-child{
	margin-right: 24px;
	font-size: 32px;
	line-height: 1.3em;
	font-family: 'Roboto', sans-serif; letter-spacing: -0.03em;
}
div.topics article dl dt p:first-child small{
	display: block;
	line-height: 1em;
	font-size: 14px;
	letter-spacing: -0.01em;
}
div.topics article dl dt p:first-child span{
	display: inline-block;
	margin-left: 6px;
	padding: 2px 4px 1px 4px;
	border: 1px solid #ccc;
	border-radius: 3px;
	font-size: 14px;
	line-height: 1.3em;
}
div.topics article dl dt p:last-child{
	max-width: 74px;
	width: 100%;
	background: #fff;
	border: 1px solid #00597A;
	border-radius: 3px;
	font-weight: 400;
	color: #00597A;
	font-size: 14px;
	text-align: center;
}

/*-- 日付 -- */
div.topics article dl dd{
	margin-left: 12px;
	flex: 1;
}
div.topics article dl dd a{
	display: block;
	line-height: 1.414em;
}

	/* ======= TB =======*/
    @media screen and (min-width: 768px) and (max-width: 1024px) {
    }
    /* ======= SP =======*/
    @media (max-width: 767px) {
		div.topics article dl{
			align-items: flex-start; -webkit-align-items: flex-start;
			flex-direction: column; -webkit-flex-direction: column;
		}

		/*-- 日付 -- */
		div.topics article dl dt{
			justify-content: flex-start; -webkit-justify-content: flex-start;
			align-items: flex-end;-webkit-align-items: flex-end;
			width: 100%;
			margin-bottom: 4px;
		}
		div.topics article dl dt p:first-child{
			margin-right: 12px;
			font-size: 28px;
		}
		div.topics article dl dt p:first-child small{
			line-height: 0.5em;
			font-size: 13px;
		}
		div.topics article dl dt p:first-child span{
			margin-left: 5px;
			padding: 1px 5px 2px 5px;
			font-size: 12px;
		}
		div.topics article dl dt p:last-child{
			position: relative; top: -5px;
			font-size: 14px;
		}

		/*-- 日付 -- */
		div.topics article dl dd{ margin-left: 0px;}
    }

