@charset "utf-8";

html { font-size: 62.5%; }
body {
	color: #333;
	font-size: 1.4rem;
	font-family: "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, "Yu Gothic", YuGothic, Arial, "メイリオ", Meiryo, sans-serif;
	line-height: 1.8;
	background: #fff;
	word-wrap: break-word;
	-webkit-text-size-adjust: 100%;
}
img {
	max-width: 100%;
}
a {
	color: #333;
	text-decoration: none;
	transition: .2s;
}
a:hover {
	opacity: .7;
}
@media print,screen and (max-width: 767px) {
	a:hover {
		opacity: 1;
	}
}



/****	---- area ----
===================================****/
.area-search__select-tab-list {
	margin: 0 0 50px 0;
	display: flex;
	justify-content: center;
}
@media print,screen and (max-width: 767px) {
	.area-search__select-tab-list {
		margin: 0 0 20px 0;
		justify-content: space-between;
	}
}
.area-search__select-tab-list-item {
	color: #0a7daf;
	font-size: 1.6rem;
	text-align: center;
	width: 282px;
	height: 50px;
	border: 1px solid #0a7daf;
	border-radius: 50px;
	box-sizing: border-box;
	margin: 0 22px;
	display: flex;
	justify-content: center;
	align-items: center;
	transition: .2s;
}
@media print,screen and (max-width: 767px) {
	.area-search__select-tab-list-item {
		font-size: 1.4rem;
		width: calc((100% - 20px) / 2);
		height: 40px;
		margin: 0;
	}
}
.area-search__select-tab-list-item:hover {
	cursor: pointer;
}
.area-search__select-tab-list-item.active {
	color: #fff;
	background: linear-gradient(to right, #1b1a82, #0a7daf);
	border: none;
}
.area-search__select-contents.hide {
	display: none;
}
.area-search__title-contents {
	text-align: center;
	margin: 0 0 45px 0;
}
@media print,screen and (max-width: 767px) {
	.area-search__title-contents {
		margin: 0 0 30px 0;
	}
}
.area-search__title-contents span {
	color: #0a7daf;
	font-size: 2.8rem;
	font-weight: bold;
	border-bottom: 4px solid #0a7daf;
	padding: 0 0 .5em 0;
}
@media print,screen and (max-width: 767px) {
	.area-search__title-contents span {
		font-size: 2.0rem;
	}
}
.area-search__section {
	box-shadow: 0 0 8px #ddd;
	padding: 0 0 45px 0;
	margin: 0 0 20px 0;
}
@media print,screen and (max-width: 767px) {
	.area-search__section {
		padding: 0 0 20px 0;
	}
}
.area-search__section:last-of-type {
	margin: 0;
}
.area-search__title-section {
	color: #0a7daf;
	font-size: 2.8rem;
	font-weight: bold;
	line-height: 1.4;
	background: #e2f1f7;
	padding: 10px 30px;
}
@media print,screen and (max-width: 767px) {
	.area-search__title-section {
		font-size: 2.0rem;
		padding: 10px;
	}
}
.area-search__section-grid {
	padding: 40px 30px 0;
	margin: 0 0 25px 0;
	display: flex;
	justify-content: space-between;
}
@media print,screen and (max-width: 767px) {
	.area-search__section-grid {
		padding: 10px;
		margin: 0 0 10px 0;
		display: block;
	}
}
.area-search__section-img {
	width: 42.5531%;
}
@media print,screen and (max-width: 767px) {
	.area-search__section-img {
		text-align: center;
		width: auto;
		margin: 0 0 10px 0;
	}
}
.area-search__section-contents {
	width: 51.5957%;
}
@media print,screen and (max-width: 767px) {
	.area-search__section-contents {
		width: auto;
	}
}
.area-search__section-text {
	font-size: 1.6rem;
	margin: 0 0 1.5em 0;
}
@media print,screen and (max-width: 767px) {
	.area-search__section-text {
		font-size: 1.4rem;
		margin: 0 0 1em 0;
	}
}
.area-search__section-caption {
	font-size: 2.0rem;
	font-weight: bold;
	padding: 0 0 0 28px;
	margin: 0 0 .5em 0;
	position: relative;
}
@media print,screen and (max-width: 767px) {
	.area-search__section-caption {
		font-size: 1.6rem;
		padding: 0 0 0 22px;
	}
}
.area-search__section-caption::before {
	content: "";
	width: 1em;
	height: 1em;
	background: #0a7daf;
	border-radius: 1em;
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	margin: auto;
}
.area-search__section-table {
	border-collapse: collapse;
	table-layout: fixed;
	width: 100%;
	border: none;
}
@media print,screen and (max-width: 767px) {
	.area-search__section-table {
		table-layout: inherit;
	}
}
.area-search__section-table th,
.area-search__section-table td {
	font-size: 1.6rem;
	font-weight: normal;
	text-align: center;
	vertical-align: middle;
	border: 1px solid #ccc;
	padding: .5em 0;
}
@media print,screen and (max-width: 767px) {
	.area-search__section-table th,
	.area-search__section-table td {
		font-size: 1.2rem;
		padding: 10px;
	}
}
.area-search__section-table th {
	color: #0a7daf;
	background: #e2f1f7;
}
.area-search__section-table th:first-of-type {
	width: 40.2061%;
}
@media print,screen and (max-width: 767px) {
	.area-search__section-table th:first-of-type {
		width: auto;
	}
}
.area-search__section-table-caution {
	font-size: 1.4rem;
	margin: 4px 0 0 0;
}
@media print,screen and (max-width: 767px) {
	.area-search__section-table-caution {
		font-size: 1.2rem;
	}
}
.area-search__section-btn {
	color: #fff;
	font-size: 1.6rem;
	text-align: center;
	width: 282px;
	height: 50px;
	background: linear-gradient(to right, #1b1a82, #0a7daf);
	border-radius: 50px;
	box-sizing: border-box;
	margin: 0 auto;
	display: flex;
	justify-content: center;
	align-items: center;
}
@media print,screen and (max-width: 767px) {
	.area-search__section-btn {
		font-size: 1.4rem;
		width: 260px;
		height: 40px;
	}
}

/****	---- sitemap ----
===================================****/
.sitemap__section {
	margin: 0 0 30px 0;
}
.sitemap__section:last-of-type {
	margin: 0;
}
.sitemap__title,
.sitemap__title a {
	font-size: 2.4rem;
	font-weight: bold;
}
@media print,screen and (max-width: 767px) {
	.sitemap__title,
	.sitemap__title a {
		font-size: 1.8rem;
	}
}
.sitemap__title {
	border-bottom: 1px solid #ccc;
	margin: 0 0 1em 0;
}
.sitemap__title a {
	background: url('../img/arrow.png') 6px center / 8px no-repeat;
	padding: 0 0 0 1em;
}
@media print,screen and (max-width: 767px) {
	.sitemap__title a {
		background: url('../img/arrow.png') 2px center / 8px no-repeat;
	}
}
.sitemap__title-pref {
	font-size: 2.0rem;
	font-weight: bold;
	line-height: 1.6;
	border-left: 4px solid #0a7daf;
	padding: 0 0 0 16px;
	margin: 0 0 1em 0;
}
@media print,screen and (max-width: 767px) {
	.sitemap__title-pref {
		font-size: 1.6rem;
		padding: 0 0 0 12px;
	}
}
.sitemap__title-city {
	margin: 0 0 20px 0;
}
@media print,screen and (max-width: 767px) {
	.sitemap__title-city {
		margin: 0 0 10px 0;
	}
}
.sitemap__title-city a {
	font-size: 1.6rem;
	font-weight: normal;
	background: #e2f1f7 url('../img/arrow.png') 28px center / 8px no-repeat;
	padding: 1em 1em 1em 44px;
	display: block;
}
@media print,screen and (max-width: 767px) {
	.sitemap__title-city a {
		font-size: 1.4rem;
		background: #e2f1f7 url('../img/arrow.png') 12px center / 8px no-repeat;
		padding: 1em 1em 1em 24px;
	}
}
.sitemap__col {
	display: flex;
	justify-content: space-between;
}
@media print,screen and (max-width: 767px) {
	.sitemap__col {
		display: block;
	}
}
.sitemap__col-half {
	width: 50%;
}
@media print,screen and (max-width: 767px) {
	.sitemap__col-half {
		width: auto;
	}
}
.sitemap__col .sitemap__col-half {
	width: calc((100% - 5px) / 2);
}
@media print,screen and (max-width: 767px) {
	.sitemap__col .sitemap__col-half {
		width: auto;
	}
}
.sitemap__list {
	margin: 0 0 40px 0;
	display: flex;
	flex-wrap: wrap;
}
@media print,screen and (max-width: 767px) {
	.sitemap__list {
		margin: 0 0 20px 0;
	}
}
.sitemap__list-item {
	width: calc((100% - 15px) / 4);
	margin: 0 5px 5px 0;
}
@media print,screen and (max-width: 767px) {
	.sitemap__list-item {
		width: calc((100% - 5px) / 2);
	}
	.sitemap__list-item:nth-child(even) {
		margin: 0 0 5px 0;
	}
}
.sitemap__list-item:nth-child(4n) {
	margin: 0 0 5px 0;
}
.sitemap__col-half .sitemap__list-item {
	width: calc((100% - 5px) / 2);
	margin: 0 5px 5px 0;
}
.sitemap__col-half .sitemap__list-item:nth-child(even) {
	margin: 0 0 5px 0;
}
.sitemap__list-item a {
	font-size: 1.6rem;
	line-height: 1.2;
	height: 60px;
	background: #f8f8f8 url('../img/arrow.png') 28px center / 8px no-repeat;
	padding: 0 1em 0 44px;
	display: flex;
	align-items: center;
}
@media print,screen and (max-width: 1023px) {
	.sitemap__list-item a {
		font-size: 1.4rem;
		height: 50px;
		background: #f8f8f8 url('../img/arrow.png') 12px center / 8px no-repeat;
		padding: 0 1em 0 24px;
	}
}

/****	---- end ----
===================================****/
