@charset "shift_jis";
/*-----------------------------------------------
	•ÒW‰Â”\‚Èƒtƒ@ƒCƒ‹‚Å‚·B
-----------------------------------------------*/
.pan_wrap ul {
	display: flex;
	flex-wrap: wrap;
}
.pan_wrap ul li {
	margin-right: 10px;
}
h2.cms_h2 {
	margin: 0% 0 5% 0;
	position: relative;
	padding-bottom: 0.5em;
	border-bottom: 4px solid #DDD;
	font-size: 5vw;
	line-height: 1.5em;
}
h2.cms_h2:after {
	position: absolute;
	content: ' ';
	border-bottom: solid 4px #042455;
	bottom: -4px;
	width: 13%;
	display: block;
	left: 0px;
}
/*------------gallery_list------------*/
.gallery_main_wrap {
	width: 100%;
	height: 100px;
	background: url(../img_cms/ga_main_bg.png);
	background-size: cover;
	background-position: center;
	margin: 20px 0;
}
.gallery_main_inner {
	width: 90%;
	margin: 0 auto;
	position: relative;
}
.gallery_main_inner::before {
	content: "";
	display: block;
	background: url(../img_cms/ga_ti.png);
	background-repeat: no-repeat;
	background-size: contain;
	width: 110px;
	height: 110px;
	position: absolute;
	left: -4%;
	top: -5px;
}
.gallery_main_inner h2 {
	color: #fff;
	font-weight: bold;
	font-size: 4.5vw;
	border-bottom: none;
	line-height: 100px;
	padding-left: 115px;
	letter-spacing: 0.1em;
	margin: 0;
}
.gallery_main_inner h2::after {
	content: none;
}
.gallery_category_wrap {
	width: 90%;
	margin: 40px auto;
}
.gallery_category_wrap span {
	font-weight: bold;
	font-size: 4vw;
	color: #000;
	display: block;
	margin-bottom: 15px;
}
.gallery_category_wrap ul {
	display: flex;
	flex-wrap: wrap;
}
.gallery_category_wrap ul li a {
	display: inline-block;
	line-height: 35px;
	padding: 0 15px;
	margin-right: 10px;
	margin-bottom: 10px;
	font-size: 3vw;
	font-weight: bold;
	text-align: center;
	color: #000;
	border: 1px solid #000;
	transition: .3s;
}
.gallery_list {
	width: 90%;
	margin: 0 auto;
}
.gallery_list ol {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 0;
	padding: 0;
}
.gallery_list ol li {
	width: 48%;
	list-style: list-item inside !important;
	position: relative;
	top: 0;
	left: 0;
	margin-bottom: 30px;
}
.gallery_list ol li::marker {
	content: none;
}
.gallery_list_ti p {
	font-size: 13px;
	line-height: 20px;
	color: #000;
	font-weight: bold;
	display: -webkit-box;
	display: -ms-flexbox;
	-webkit-box-orient: vertical;
	-ms-flex-direction: column;
	-webkit-line-clamp: 2;
	overflow: hidden;
	height: 40px;
}
.gallery_img {
	margin-top: 10px;
	width: 100%;
	height: 170px;
	overflow: hidden;
}
.gallery_img img {
	height: 100% !important;
	object-fit: cover;
	transition: .6s;
}
.gallery_img:hover img {
	transform: scale(1.1, 1.1);
	transition: .6s;
}
.gallery_con_wrap {
	width: 90%;
	margin: 30px auto;
}
.gallery_con_wrap h3 {
	font-size: 6vw;
	line-height: 160%;
	font-weight: bold;
	color: #000;
}
.gallery_con_inner {
	margin: 30px 0;
	padding-bottom: 20px;
	border-bottom: 1px solid #2b4156;
}
.slider {
	width: 100%;
}
.gallery_con_comment {
	margin-top: 30px;
	font-size: 14px;
	line-height: 28px;
	font-weight: bold;
	color: #333;
	letter-spacing: 0.05em;
}
.gallery_btn a {
	display: block;
	width: 100%;
	line-height: 50px;
	padding: 0 20px;
	font-size: 14px;
	font-weight: bold;
	text-align: center;
	color: #333;
	border: 1px solid #333;
	transition: .3s;
	margin: 0 auto;
	box-sizing: border-box;
}
.gallery_btn a:hover {
	background: #333;
	color: #fff;
	transition: .3s;
}
.build_flow_btn {
	width: 90%;
	margin: 0 auto;
}
.build_link_btn ul {
	width: 90%;
	margin: 40px auto;
}
.build_link_btn ul li a {
	display: block;
	box-shadow: 0 0 10px rgb(0 0 0 / 20%);
	transition: 0.3s;
	margin-bottom: 20px;
}
.build_link_btn ul li a:hover {
	box-shadow: 0 0 0px rgb(0 0 0 / 20%);
	transform: translateY(3px);
}
/* ----------------------------------------
‚¨‹q—l‚Ìº voice
---------------------------------------- */
.voice_main {
	width: 100%;
	height: 100px;
	background: url(../img/img_cms/voice_bg.png);
	background-size: cover;
	background-position: center;
	margin: 20px 0;
}
.voice_inner {
	width: 90%;
	margin: 0 auto;
	position: relative;
}
.voice_inner::before {
	content: "";
	display: block;
	background: url(../img/img_cms/cs_vo.png);
	background-repeat: no-repeat;
	background-size: contain;
	width: 110px;
	height: 110px;
	position: absolute;
	left: -4%;
	top: -5px;
}
.voice_inner h2 {
	color: #fff;
	font-weight: bold;
	font-size: 4.5vw;
	border-bottom: none;
	line-height: 100px;
	padding-left: 115px;
	letter-spacing: 0.1em;
	margin: 0;
}
.voice8_list ul {}
.voice8_list ul li {
	margin-bottom: 40px;
}
.voice8_list_photo {
	overflow: hidden;
}
.voice8_list_photo img {
	display: block;
	width: 100%;
	object-fit: contain;
}
.voice8_list_title a {
	font-size: 14px;
	line-height: 26px;
	height: 50px;
	font-weight: bold;
	margin-top: 10px;
	display: -webkit-box;
	display: -ms-flexbox;
	-webkit-box-orient: vertical;
	-ms-flex-direction: column;
	-webkit-line-clamp: 2;
	overflow: hidden;
	color: #000 !important;
	text-decoration: none !important;
}
/* ----------------------------------------
‚¨‹q—l‚Ìº Ú× voice
---------------------------------------- */
.voice8_detail {
	width: 90%;
	margin: 0 auto;
}
.voice8_detail h3 {
	font-size: 20px;
	line-height: 30px;
	text-align: center;
	font-weight: bold;
	margin: 20px 0;
}
.voice8_detail_top {}
.voice8_detail_img {
	margin: 15px 0;
}
.voice8_detail_con {
	background: #2b4156;
	padding: 10px;
}
.voice8_detail_con span {
	display: block;
	color: #fff;
	font-size: 14px;
	line-height: 24px;
	font-weight: 500;
}
.voice8_detail_txt {
	font-size: 14px;
	line-height: 24px;
	letter-spacing: 0.05em;
	color: #333;
	font-weight: bold;
	padding-bottom: 60px;
	margin-bottom: 60px;
	border-bottom: 1px solid #2b4156;
}
.voice8_detail_btn {
	margin-top: 30px;
}
.voice8_detail_btn a {
	display: block;
	width: 100%;
	height: 50px;
	line-height: 48px;
	text-align: center;
	border: 1px solid #2b4156;
	box-sizing: border-box;
	font-size: 14px;
	letter-spacing: 0.05em;
	color: #333;
	font-weight: bold;
	transition: .3s;
	margin: 0 auto;
	box-sizing: border-box;
}
.voice8_detail_btn a:hover {
	background: #2b4156;
	color: #fff;
	transition: .3s;
}
/*-------------------info----------------------*/
.info_main .structure_inner::before {
	content: "";
	display: block;
	background: url(../info/img/info.png);
	background-repeat: no-repeat;
	background-size: contain;
	width: 110px;
	height: 110px;
	position: absolute;
	left: -4%;
	top: -5px;
}
.info_hp {
	width: 90%;
	margin: 50px auto;
}
.info_hp ul {}
.info_hp li {
	width: 100% !important;
	margin-bottom: 50px;
}
.info_hp li div {
	height: 230px;
	overflow: hidden;
}
.info_hp li img {
	width: 100%;
	height: auto;
	transition: all 0.4s ease-out;
	object-fit: cover;
}
.info_hp li:hover img {
	transform: scale(1.2);
	transition: all 0.4s ease-out;
}
.info_hp li p {
	font-size: 16px;
	font-weight: 500;
	line-height: 24px;
	margin: 5px 0px 0px;
}
.info_hp li p span {
	color: #aaa;
	font-size: 12px;
	line-height: 24px;
	display: block;
}
.info_hp_sh {
	width: 90%;
	margin: 30px auto;
	font-size: 16px !important;
	line-height: 28px !important;
	font-weight: 500 !important;
}
.info_hp_sh>div:nth-child(1) {
	width: 100%;
}
.info_hp_sh>div:nth-child(2) {
	width: 100%;
	margin-top: 50px;
}
.info_hp_sh h3 {
	color: #fff;
	background: #2b4156;
	margin: 0px;
	padding: 10px;
}
.info_hp_sh a {
	color: #004CCA !important;
	text-decoration: underline !important;
}
.info_hp_sh img {
	width: 100% !important;
	height: auto !important;
	filter: drop-shadow(0px 0px 3px #ccc) !important;
	margin: 10px 0px;
}
.hp_voice_qa li {
	margin-top: 30px;
}
.hp_voice_qa h3 {
	font-size: 16px;
	line-height: 24px;
	margin: 0px;
	padding: 0px 0px 5px;
	text-align: left;
	text-decoration: none;
	border-bottom: solid 1px #333;
}
.hp_voice_qa p {
	font-size: 14px;
	font-weight: 500;
	margin: 5px 0px 0px 0px;
	padding: 0px;
	text-align: left;
	text-decoration: none;
}
/*---------------flick------------------*/
.flickThumb {
	margin-top: 5px;
}
.flickThumb ul {
	display: flex !important;
	flex-wrap: wrap;
	gap: 4%;
}
.flickThumb ul li {
	width: calc(33% - 10px) !important;
	max-height: 60px !important;
	border: none !important;
	margin-bottom: 10px !important;
}
.flickThumb ul li img {
	width: 100% !important;
	height: auto !important;
}
.flickSlider li {
	position: relative;
}
.flickSlider li p {
	position: absolute;
	bottom: 20px;
	background-color: #0005;
	width: 100%;
	padding: 5px 10px;
	color: #fff;
	text-align: left;
	margin: 0 auto;
	left: 0;
	right: 0;
	box-sizing: border-box;
	font-size: 12px;
}
.flickSlider li p:empty {
	display: none;
}
/* ----------------------------------------
	article_li
	---------------------------------------- */
.article_li_block {
	width: 90vw;
	margin: 0 auto;
}
.article_li_box {
	margin: 40px 0 0 0;
	display: block;
}
.article_li_box ul {
	display: flex;
	flex-wrap: wrap;
}
.article_li_box li {
	flex-basis: 100%;
	box-sizing: border-box;
	position: relative;
	margin: 0 0 20px 0;
	width: 90vw;
}
.article_li_box .thumb {
	position: relative;
	width: 100%;
	text-align: center;
	box-shadow: 0px 0px 3px 3px rgba(153, 153, 153, 0.2);
	height: 90vw;
	overflow: hidden;
}
.article_li_box .thumb img {
	height: 90vw;
}
.article_li_box .thumb iframe {
	height: 90vw;
}
.article_li_box .date {
	margin: 5px;
	color: #bbb;
	font-weight: bold;
	font-size: 12px;
	line-height: 16px;
	padding: 0;
}
.article_li_box .tag {
	padding-top: 60px;
	padding-bottom: 10px;
}
.article_li_box .tag p {
	overflow: hidden;
}
.article_li_box .tag label {
	cursor: pointer;
	display: block;
	float: left;
	margin: 1px;
	position: relative;
}
.article_li_box .tag label a::before {
	position: absolute;
	content: "#";
	margin-left: -10px;
}
.article_li_box .tag label a {
	display: block;
	border: 1px solid #fff !important;
	border-radius: 3px;
	padding: 2px 5px;
	position: relative;
	z-index: 10;
	color: #2b4156 !important;
	font-size: 11px;
	line-height: 15px;
	padding-left: 15px;
	margin: 0 !important;
	background: #f4f5f7;
}
.article_li_box li>a {
	position: absolute;
	width: 100%;
	height: 100%;
	text-decoration: none;
	top: 0;
	left: 0;
	box-sizing: border-box;
}
.article_li_box li>a p {
	position: absolute;
	font-size: 4vw;
	line-height: 1.5;
	font-weight: bold;
	height: 44px;
	overflow: hidden;
	top: 94vw;
	width: 100%;
	color: #000000;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
}
/* ----------------------------------------
article01
---------------------------------------- */
.article01_top {
	margin: 2vh 0 0;
}
.article01_ttl {
	font-size: 6vw;
	line-height: 1.3;
	font-weight: bold;
}
.article01_ttl_tag {
	padding: 1vh;
}
.article01_ttl_tag p {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
}
.article01_ttl_tag label a {
	display: block;
	border: 1px solid #000;
	margin-right: 1vh;
	color: #000;
	font-weight: bold;
	font-size: 3vw;
	padding: 0 1vh;
}
.article01_ttl_tag label a:before {
	content: "#";
	padding-right: 3px;
}
.article01_ttl_tag a:hover {
	background: #2b4156;
	color: #ffffff;
	border: 1px solid #2b4156;
}
.cms_topic_tag {}
.article01 {
	width: 96%;
	margin: 0 auto;
	overflow: hidden;
}
.article01>div {}
.article01_main {}
.article01_main img {
	margin: 2vh 0;
	height: auto !important;
}
.article01_main iframe {
	margin: 2vh 0;
	width: 90vw;
}
.article01_main p {
	margin: 1vh 0;
	font-size: 3.5vw;
	line-height: 1.5;
}
.article01_txt {}
.article01_txt_box {
	padding: 3vh;
	background-color: #e2e9f0;
	line-height: 1.5;
	font-size: 3.8vw;
	margin: 3vh 0;
}
.article01_btm {}
.article01_side {}
.article01_side_box {}
.article01_side_tl {
	font-size: 4vw;
	padding: 0px 1.2vh;
	margin: 4vh 0 0 0.5vh;
	border-left: 5px solid #dcd9ca;
	font-weight: bold;
}
.article01_side_tag {}
.article01_tag_tl {}
.article01_tag {
	margin: 1vh;
}
.article01_tag p {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
}
.article01_tag label a {
	display: block;
	border: 1px solid #000;
	margin: 5px;
	color: #000;
	font-weight: bold;
	font-size: 12px;
	padding: 3px 7px;
}
.article01_tag label a:before {
	content: "#";
	padding-right: 3px;
}
.article01_tag a:hover {
	background: #2b4156;
	color: #ffffff;
	border: 1px solid #2b4156;
}
.article01_link {}
.article01_link a {
	display: block;
	margin: 2vh 0;
}
.article01_link img:hover {
	opacity: 0.8;
}
.article01_link_tl {}
.article01_new_box_wrap iframe {
	width: 100%;
	height: 700px;
}
/* ----------------------------------------
	group_all_topiclinks
	---------------------------------------- */
.group_all_topiclinks {
	width: 95%;
	margin: 40px auto 20px auto;
	overflow: hidden;
	padding: 20px;
	align-items: center;
	box-sizing: border-box;
	background: #e2e9f0;
}
.group_all_topiclinks ul {
	width: 100%;
	overflow: hidden;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
.group_all_topiclinks li {
	margin: 3px;
}
.group_all_topiclinks li img {
	max-width: 90%;
}
.group_all_topiclinks_tl {
	text-align: center;
	margin-bottom: 10px;
	font-size: 15px;
}
.group_all_topiclinks li a {
	border: 1px solid #2b4156;
	background-color: #fff;
	padding: 3px 10px;
	display: block;
	color: #2b4156;
	border-radius: 5px;
}
/*------------------
@ƒRƒ‰ƒ€ƒpƒbƒN
--------------------*/
.column_list_subject>h2 {
	border-bottom: solid;
	padding-bottom: 10px;
	font-size: 18px;
	font-weight: bold;
	margin-top: 20px;
}
/* -----ƒ^ƒOˆê——------- */
.col_li_tag {
	background: #eee;
	width: 100%;
	margin: 20px 0;
	padding: 15px;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
.col_li_tag ul {
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-wrap: wrap;
}
.col_li_tag li {
	padding: 3px;
}
.col_li_tag a {
	display: inline-block;
	border: 1px solid #042455 !important;
	background: #fff;
	color: #042455 !important;
	border-radius: 3px;
	font-size: 12px;
	padding: 5px 10px;
	font-weight: bold;
	text-decoration: none;
}
.col_li_tag a:hover {
	background: #042455;
	color: #e5efec;
}
.col_li_tag_ti p {
	font-size: 15px;
	font-weight: bold;
	border-bottom: solid 1px #000;
	padding: 0 0 5px 0px;
	margin: 0 0 5px 0;
}
/*---/list---*/
.col ul {
	width: 100%;
	padding: 0;
	overflow: hidden;
}
.col ul li {
	width: 100%;
	border: 1px solid #666666;
	margin-bottom: 15px;
	position: relative;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
.col ul li:hover {
	background: #F5F4F2;
}
.col ul li:hover .col_item_theme .cms_topic_tag {}
.column_list_subject .col_item_theme {
	position: absolute;
	top: 5px;
	left: 5px;
	padding: 0;
	background-color: unset;
	border: 0;
}
.column_list_subject .col_item_theme p {
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	flex-wrap: wrap;
	padding: 0 !important;
	width: auto !important;
	height: auto !important;
	background: inherit !important;
	margin: 0;
}
.column_list_subject .col_item_theme .cms_topic_tag {
	background-color: #FFFFFF;
	border: 1px solid #333333;
	padding: 0 5px;
	margin: 2px;
	line-height: 28px;
	font-size: 12px;
	font-weight: bold;
}
.column_list_subject .col_item_img {
	width: 100%;
	height: 200px;
}
.column_list_subject .col_item_img img {
	width: 100%;
	height: 200px;
	object-fit: cover;
}
.col_item_date {
	width: 120px;
	line-height: 30px;
	font-size: 14px;
	color: #FFFFFF;
	background-color: #333333;
	position: absolute;
	top: 115px;
	left: 60px;
	text-align: center;
	font-family: 'Century Gothic', 'Arial';
	z-index: 5;
}
.col_item_tl {
	width: 100%;
	height: 100%;
	position: absolute;
	z-index: 10;
	top: 0;
	left: 0;
}
.col_item_tl a {
	color: #333333;
	font-size: 15px;
	font-weight: bold;
	line-height: 1.2em;
	width: 100%;
	height: 100%;
	display: block;
}
.column_list_subject .col_item_tl a span {
	position: absolute;
	top: 210px !important;
	height: 45px;
	overflow: hidden;
	display: block;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	width: 100%;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	padding: 0 15px;
	line-height: 26px;
	font-size: 17px;
}
.column_list_subject .col ul li>p {
	font-size: 13px;
	line-height: 20px;
	background-color: #FFFFFF;
	margin: 65px 15px 15px 15px;
	height: 60px;
	display: -webkit-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
	overflow: hidden;
}
.col ul li:hover>p {
	background-color: #F5F4F2;
}
/*---detail---*/
.column_detail {
	margin-top: 8px;
}
.column_title {
	font-size: 20px;
	line-height: 30px;
	font-weight: bold;
	background-color: #ccc3;
	padding: 15px 10px;
	margin-bottom: 20px;
}
.column_detail table {
	width: 100% !important;
	border-collapse: collapse;
}
.column_detail table th, .column_detail table td {
	font-size: 13px !important;
	font-weight: normal !important;
	line-height: 22px !important;
	border: solid 1px #999 !important;
	padding: 10px 5px;
	background: #cccccc14;
	;
}
.column_det_img {
	width: 100%;
	min-height: 250px;
	padding-bottom: 20px;
}
.column_det_intro {
	font-size: 15px;
	line-height: 1.7;
	padding-bottom: 20px;
}
.column_det_intro:empty {
	padding: 0;
	display: none;
}
.column_det_index {
	background: #eee3;
	padding: 20px 5%;
}
.column_det_ttl {
	width: 70px;
	text-align: center;
	border: 1px solid #111;
	background: #fff;
	font-size: 15px;
	font-weight: bold;
	line-height: 35px;
	flex-shrink: 0;
}
.column_det_index ol {
	counter-reset: section;
	font-weight: normal;
}
.column_det_index ol li::before {
	counter-increment: section;
	content: counters(section, "-") ". ";
	padding-right: 10px;
}
.column_det_index>ol>li {
	font-weight: bold;
	padding: 10px 0;
}
.column_det_index ol li a {
	color: #111;
	text-decoration: none;
}
.column_det_index ol li a:hover {
	text-decoration: underline;
}
.column_det_index ol ol {
	margin-top: 10px;
	padding-left: 20px;
}
.column_det_index ol ol li {
	font-size: 13px;
}
.column_det_free {
	font-size: 15px;
	line-height: 1.7;
	color: #111;
	margin-bottom: 30px;
}
.column_det_free-o h3,
.column_det_free-n h2 {
	font-size: 20px;
	line-height: 34px;
	border-bottom: 5px solid #ddd;
	position: relative;
	padding: 90px 5px 5px 1%;
	margin: -40px 0 14px 0;
	font-weight: bold;
}
.column_det_free-o h3::before,
.column_det_free-n h2::before {
	content: "";
	display: block;
	line-height: 0;
	overflow: hidden;
	position: absolute;
	left: 0;
	bottom: -5px;
	width: 50%;
	border-bottom: 5px solid #ffa500;
}
.column_det_free-o h3::after,
.column_det_free-n h2::after {
	content: '';
	background-image: url(/img/column/det_hakase.png);
	background-repeat: no-repeat;
	background-position: right;
	position: absolute;
	right: 0;
	bottom: -12px;
	width: 40px;
	height: 59px;
	background-size: contain;
}
.column_det_free-o h4,
.column_det_free-n h3 {
	font-size: 18px;
	line-height: 30px;
	font-weight: bold;
	padding: 10px;
	margin: 30px 0 20px;
	text-decoration: underline;
	background-color: #e2eaf1;
	border-radius: 10px;
}
.column_det_free-n h4 {
	border-bottom: solid 1px #aaa;
	margin: 20px 0;
	font-weight: bold;
}
.column_det_free-n hr {
	display: none;
}
.column_det_intro .block,
.column_det_free .block {
	border: 3px solid #ff56268f;
	padding: 20px 3%;
	margin: 10px 0;
	color: #5d3937;
	background-color: #ffbfb20a;
	font-weight: bold;
	border-radius: 8px;
	line-height: 22px;
}
.column_det_intro .block span,
.column_det_free .block span {
	color: #333;
	font-weight: bold;
}
.column_det_intro span.bold,
.column_det_free span.bold {
	font-weight: bold;
}
.column_det_intro a,
.column_det_free a {
	color: #ff9426;
	text-decoration: none;
	overflow-wrap: break-word;
	font-weight: bold;
}
.column_det_intro a:hover,
.column_det_free a:hover {
	color: #2c3f50;
}
.column_det_intro a.link_relate,
.column_det_free a.link_relate {
	display: block;
	border-radius: 5px;
	border: 1px solid #2799fb;
	color: #2799fb;
	font-weight: bold;
	margin: 10px 0;
	padding: 10px 15px 10px 30px;
	position: relative;
}
.column_det_intro a.link_relate:before,
.column_det_free a.link_relate:before {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 10px;
	margin: auto;
	content: "";
	vertical-align: middle;
	width: 6px;
	height: 6px;
	border-top: 2px solid #008dd0;
	border-right: 2px solid #008dd0;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
.column_det_intro a.link_relate:hover,
.column_det_free a.link_relate:hover {
	background: #2799fb;
	color: #fff;
}
.column_det_intro a.link_relate:hover:before,
.column_det_free a.link_relate:hover:before {
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
}
.column_det_free img {
	margin: 15px 0;
	width: 100% !important;
	height: auto !important;
}
.column_det_free>iframe {
	min-width: 100% !important;
}
.column_det_free .linkblock {
	margin: 20px 0;
	box-shadow: 0 0 5px rgba(0, 0, 0, 0.5);
	display: flex;
}
.column_det_free .linkblock:hover {
	background: #eee;
}
.column_det_free .linkblock a.linkblock_img {
	padding: 3%;
	width: 35%;
	flex-shrink: 0;
}
.column_det_free .linkblock a.linkblock_img img {
	margin: 0;
}
.column_det_free .linkblock_txt {
	display: flex;
	flex-wrap: wrap;
	align-content: center;
	padding: 3% 3% 3% 0;
}
.column_det_free .linkblock_txt span:nth-child(1) {
	color: #111;
	font-size: 16px;
	display: block;
	padding-bottom: 10px;
}
.column_det_free .linkblock_txt span:nth-child(2) {
	color: #999;
	font-size: 12px;
	display: block;
	line-height: 1.5;
}
.jc_pagelink {
	padding: 10px 5%;
	display: block;
	height: 100%;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	color: #111;
	font-size: 3.5vw;
	line-height: 150%;
}
.jc_pagelink:hover {
	background: #dfebf5;
	color: #2799fb;
}
.jc_pre {
	padding-left: 10%;
}
.jc_next {
	padding-right: 10%;
}
.column_conts {
	margin: 0 3%;
	margin-bottom: 15px;
}
strong, strong span, strong span u {
	font-weight: bold !important;
}
.column_bn img {
	text-align: center;
}
.company_coment {
	font-size: 15px;
	line-height: 1.7;
	color: #111;
	margin-bottom: 30px;
}
.jc_pagelink {
	padding: 10px 5%;
	display: block;
	height: 100%;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	color: #111 !important;
	font-size: 3.5vw;
	line-height: 150%;
	text-decoration: none;
}
.jc_pagelink:hover {
	background: #dfebf5;
	color: #2799fb;
}
.jc_pre {
	padding-left: 10%;
}
.jc_next {
	padding-right: 10%;
}
/* -------column_side------- */
.column_side {
	margin-top: 30px;
}
.sidebar__inner {
	position: relative;
	transform: translate(0, 0);
	transform: translate3d(0, 0, 0);
	will-change: position, transform;
}
.column_side_tag {
	background: #f5f5f5;
	border-radius: 10px;
	padding: 15px;
	padding-bottom: 5px;
	margin-bottom: 20px;
}
.column_side_tag_item {
	padding-bottom: 15px;
}
.column_side_tag_ttl {
	display: flex;
	align-items: center;
	flex-shrink: 0;
	margin-bottom: 10px;
}
.column_side_tag_ttl img {
	margin-right: 5px;
	width: 20px;
}
.column_side_tag_ttl p {
	font-size: 16px;
	line-height: 25px;
	font-weight: 600;
	margin: 0;
}
.column_side_tag_ttl hr {
	border-top: 1px solid #999;
	width: 40%;
	margin: 0 0 0 auto;
}
.column_side_tag ul {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
}
.column_side_tag li {
	margin-bottom: 5px;
	margin-right: 5px;
}
.column_side_tag a {
	display: inline-block;
	border: 1px solid #042455 !important;
	background: #fff;
	color: #042455 !important;
	font-size: 13px;
	line-height: 19px;
	font-weight: 600;
	border-radius: 5px;
	padding: 4px 8px 4px 5px;
}
.column_side_tag a::before {
	content: '#';
	padding-right: 2px;
}
.column_side_tag a:hover {
	border: 1px solid #042455;
	background: #042455;
	color: #fff;
}
.column_side_tag .cms_keysearch_form {
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.column_side_tag .cms_keysearch_form input {
	border: 1px solid #111;
	background: #fff;
	border-radius: 5px;
	color: #111;
	font-size: 14px;
	line-height: 40px;
	height: 40px;
	padding: 0 3%;
	width: 80%;
	box-sizing: border-box;
	box-shadow: none;
}
.column_side_tag .cms_keysearch_form button {
	width: 20%;
	background: #042455;
	border: 1px solid #042455;
	border-radius: 5px;
	text-align: center;
	display: block;
	box-sizing: border-box;
	cursor: pointer;
	margin-left: 1%;
	padding: 10px;
	height: 40px;
}
.column_side_tag .cms_keysearch_form button:hover {
	border: 1px solid #042455;
	background: #042455;
}
.column_side_tag .cms_keysearch_form button i {
	color: #fff;
}
.column_side_tag .cms_keysearch_form img {
	width: 18px;
}
.column_side_new {
	margin-bottom: 20px;
	border-bottom: 1px solid #111;
}
.column_side_new_ttl {
	width: 100%;
	text-align: center;
	font-family: 'Century Gothic', 'Arial';
	position: relative;
	display: inline-block;
	margin-bottom: 22px;
	padding: 5px;
	font-size: 14px;
	border-bottom: solid 1px #111;
	box-sizing: border-box;
}
.column_side_new_ttl:before {
	content: "";
	position: absolute;
	bottom: -20px;
	left: 50%;
	margin-left: -15px;
	border: 11px solid transparent;
	border-top: 11px solid #FFF;
	z-index: 2;
}
.column_side_new_ttl:after {
	content: "";
	position: absolute;
	bottom: -19px;
	left: 50%;
	margin-left: -12.9px;
	border: 9px solid transparent;
	border-top: 9px solid #111;
	z-index: 1;
}
.column_side_new_box {}
.column_side_new_box iframe {
	width: 100%;
	height: 300px;
}
.column_side_bnr {
	margin-bottom: 20px;
}
.column_side_bnr a {
	display: block;
	background: url(/img/column/bnr_mediahakase_on.jpg) no-repeat 0 0;
}
.column_side_bnr a:hover img {
	visibility: hidden;
}
.column_side_bnr img {}
.column_side_img {
	width: 270px;
	margin: 0 auto;
	display: block;
	position: -webkit-sticky;
	position: sticky;
	top: 50px;
}
.column_side_link {
	margin: 0 0 20px 0;
}
.column_side_link a {
	display: block;
	margin-bottom: 5px;
	border-radius: 5px;
	border: 1px solid #e60012;
	padding: 5px 15px;
	color: #e60012;
	font-weight: 600;
	position: relative;
}
.column_side_link a:hover {
	background: #e60012;
	color: #fff;
}
.column_side_link a::after {
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
	content: "";
	vertical-align: middle;
}
.column_side_link a::after {
	right: 15px;
	width: 4px;
	height: 4px;
	border-top: 2px solid #e60012;
	border-right: 2px solid #e60012;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
.column_side_link a:hover::after {
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
}
/*---/column_side---*/
/*---‹LŽ–iframe---*/
.column_side_if ul {
	font-family: æ¸¸ã‚´ã‚·ãƒ?‚¯ä½?, "Yu Gothic", YuGothic, "Noto Sans Japanese", Roboto, "ãƒ’ãƒ©ã‚®ãƒŽè§’ã‚´ Pro W3", "Hiragino Kaku Gothic Pro", ãƒ¡ã‚¤ãƒªã‚ª, Meiryo, Osaka, "?­?³ ?°ã‚´ã‚·ãƒ?‚¯", "MS PGothic", sans-serif;
	padding: 0;
	margin: 0;
}
.column_side_if li {
	margin-bottom: 10px;
	list-style-type: none;
	border-bottom: dashed 1px #ccc;
	padding: 0 0 10px;
}
.column_side_if a {
	display: block;
	color: #111;
	text-decoration: none;
}
.column_side_if a:hover {
	color: #008dd0;
}
.column_side_new_conts {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 2px;
}
.column_side_new_conts img {
	width: 30% !important;
	height: 70px !important;
	object-fit: cover;
	border-radius: 5px;
}
p.column_side_new_info {
	width: 65%;
	font-size: 14px;
	line-height: 20px;
	font-weight: 600;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 4;
	height: 70px;
	overflow: hidden;
	margin: 0;
}
.column_side_new_conts .date {
	font-family: 'Century Gothic', 'Arial';
	font-size: 12px;
	line-height: 15px;
	display: block;
	margin-bottom: 5px;
	color: #008dd0;
	font-weight: normal;
}
.column_side_if a>p {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	white-space: nowrap;
	text-overflow: ellipsis;
	overflow: hidden;
	width: 100%;
	height: 27px;
	margin: 0;
}
.column_side_if a>p label {
	margin-right: 3px;
	margin-bottom: 3px;
	margin-top: 3px;
	display: block;
	background: #eee;
	border-radius: 3px;
	padding: 0 5px;
	color: #666;
	font-size: 12px;
	line-height: 24px;
	font-weight: 600;
}
.column_side_if a>p label::before {
	content: '#';
	padding-right: 0px;
}
.column_side_if a:hover>p label {
	background: #2c3f50;
	color: #fff;
}
/*---/‹LŽ–iframe---*/
.column_conts {
	width: 780px;
	margin: 60px auto 0 auto;
	margin-bottom: 20px;
}
.column_box_ttl {
	margin-bottom: 15px;
}
.column_box_ttl h2 {
	display: flex;
	align-items: center;
	justify-content: space-between;
	font-size: 26px;
	line-height: 32px;
	border-bottom: 1px solid #ccc;
	padding-left: 5px;
	padding-bottom: 10px;
}
.column_box_ttl span {
	font-size: 15px;
	line-height: 30px;
	color: #e60012;
	font-family: 'Century Gothic', 'Arial';
	padding-left: 5px;
}
.column_box {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.column_conts .column_box iframe {
	width: 780px;
	height: 600px;
}
.scene_other_link {
	width: 100%;
	padding: 15px 20px;
	margin: 30px 0;
}
.scene_other_link li {
	margin: 3px;
	width: 255px;
}
.scene_other_link a {
	padding: 10px 12px 10px 25px;
}
.scene_other_link a::before {
	margin-right: 10px;
}
.container:has(>.column_conts_wrap) {
	overflow: unset;
}
/*---/detail---*/
/* ----------------------------------
‚«‚½‚È‚çƒGƒŠƒAî•ñ
---------------------------------- */
h2.cms_h2.cms_h2_town {
	border: none;
	background-color: #2b4156;
	color: #fff;
	font-size: 20px;
	padding: 35px 0px;
	line-height: 1.3;
	margin-bottom: 20px;
	.cms_h2_town_in {
		width: 90%;
		margin: 0 auto;
	}
	&:after {
		content: none;
	}
}
.gallery_main_inner.town_main_inner::before {
	background-image: url(../img_cms/town_ti.png);
}
.area_wrap {}
.area_list h3 {
	font-weight: bold;
	font-size: 16px;
	margin: 0 auto 10px;
	color: #FFF;
	padding: 10px;
	background: url(../img/img_cms/area_h3_bg.gif);
}
.area_detail_img {
	width: 94%;
	margin: 0 auto;
	& .flickThumb ul {
		gap: 3%;
	}
}
.area_list_mainimg {}
.area_list {}
.area_list ul {
	overflow: hidden;
	width: 98%;
	margin: 0 auto;
}
.area_list ul li {
	border-bottom: dotted #AAA 1px;
}
.area_list ul li a {
	height: 100%;
	padding: 15px 2%;
	overflow: hidden;
}
.area_list ul li.area_top {}
.area_list ul li:last-child {
	margin-right: 0px;
}
.area_list ul li:hover {
	background: #F1EDEA;
}
.area_list ul li a,
.area_list ul li a:hover {
	color: #003B77;
	text-decoration: none;
	display: block;
}
.area_list ul li a:hover {}
.area_list ul li:nth-child(4n) {
	margin-right: 0px;
	 !important
}
.area_list ul li div.area_list_title {
	text-align: left;
	font-size: 14px;
	margin-bottom: 2%;
	font-weight: bold;
	background-color: #e2eaf1;
	padding: 5px 10px;
}
.area_list ul li div.area_list_photo {
	float: left;
	margin: 1% 3% 0 0;
	width: 45%;
}
.area_list ul li div.area_list_photo img {
	max-height: 110px !important;
	width: 100%;
	object-fit: cover;
}
.area_list ul li div.area_list_txt {
	color: #333;
	line-height: 20px;
	font-size: 13px;
	font-weight: normal;
	text-align: left;
}
.area_list ul li div.area_list_txt span {
	display: block;
}
.area_detail {}
.area_detail h3 {
	background: #EEEEEE;
	margin: 2% 0;
	padding: 3%;
	color: #003A77;
	font-size: 16px;
	letter-spacing: 3px;
}
.area_detail .area_detail_txt {
	margin: 10% 0;
}
.area_detail .area_detail_txt p {
	width: 95%;
	margin: 0 auto;
	font-size: 14px;
	line-height: 25px;
}
.area_detail_txt img {
	max-width: 100% !important;
	height: auto !important;
}