@charset "utf-8";


/* Common
------------------------------------------------------------- */

.swiper-slide img {
	height: auto;
	width: 100%;
}


/* Contact Tab
------------------------------------------------------------- */

.contact_tab {
	display: block;
	width: 70px;
	height: 70px;
	position: fixed;
	right: 20px;
	bottom: 20px;
	z-index: 555;
}

.contact_tab a {
	display: block;
	text-align: center;
	width: 100%;
	height: 100%;
	padding-top: 72%;
	line-height: 1;
	font-size: 0.9rem;
	font-weight: 500;
	text-decoration: none;
	color: #fff;
	background-color: #f26363;
	background-image: url(../img/icon_contact_white.svg);
	background-position: center 15%;
	background-repeat: no-repeat;
	background-size: 70%;
	overflow: hidden;
	box-shadow: 2px 2px 0 rgba(0,0,0,0.3);
	transition: 0.3s background-color;
}

.contact_tab a:hover, .contact_tab a:active {
	background-color: #f88282;
	transform: translate(1px, 1px);
	box-shadow: 1px 1px 0 rgba(0,0,0,0.3);
}



/* Main BG
------------------------------------------------------------- */

.top_mainbg_box {
	width: 100%;
	height: 200px;
	padding: 0;
	margin: 60px 0 30px 0;
	background-size: cover;
	background-position: center center;
	position: relative;
	z-index: 1;
}

.top_mainbg_box::after {
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	background-color: rgba(0,0,0,0.15);
	z-index: 10;
}

/* Fadein */

.top_mainbg_box {
	animation: fadeIn 0.8s ease 0s 1 normal;
}

@keyframes fadeIn {
	0% {opacity: 0}
	100% {opacity: 1}
}


/* Catch */

.top_mainbg_box .top_mainbg_catch {
	padding:0 20px;
	width: 100%;
	height: fit-content;
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	opacity: 0;
	z-index: 20;
}

.top_mainbg_box .top_mainbg_catch p {
	width: fit-content;
	height: fit-content;
	text-align: left;
	font-size: 2.4rem;
	line-height: 1.5;
	font-weight: 500;
	color: #fff;
	white-space: nowrap;
	text-shadow: 1px 1px 1px rgba(0,0,0,0.5), -1px -1px 2px rgba(0,0,0,0.2), 1px -1px 2px rgba(0,0,0,0.2), -1px 1px 2px rgba(0,0,0,0.2);
	position: relative;
}

.top_mainbg_box .top_mainbg_catch p::after {
	content: "";
	display: block;
	width: calc(100% + 20px);
	height: 2px;
	background-color: #fff;
	box-shadow: 1px 1px 2px rgba(0,0,0,0.5);
	position: absolute;
	left: -20px;
	top: 1.45em;
}


.top_mainbg_box.bg_1 {
	background-image: url(../img_top/mainbg_bunsyokan.jpg);
}

.top_mainbg_box.bg_1 .top_mainbg_catch.catch_01 {
	opacity: 1;
}

.top_mainbg_box.bg_2 {
	background-image: url(../img_top/mainbg_ginzan.jpg);
}

.top_mainbg_box.bg_2 .top_mainbg_catch.catch_01 {
	opacity: 1;
}

.top_mainbg_box.bg_3 {
	background-image: url(../img_top/mainbg_hanagasa.jpg);
}

.top_mainbg_box.bg_3 .top_mainbg_catch.catch_01 {
	opacity: 1;
}

.top_mainbg_box.bg_4 {
	background-image: url(../img_top/mainbg_juhyo.jpg);
}

.top_mainbg_box.bg_4 .top_mainbg_catch.catch_02 {
	opacity: 1;
}

.top_mainbg_box.bg_5 {
	background-image: url(../img_top/mainbg_sakuranbo.jpg);
}

.top_mainbg_box.bg_5 .top_mainbg_catch.catch_02 {
	opacity: 1;
}

.top_mainbg_box.bg_6 {
	background-image: url(../img_top/mainbg_yamadera.jpg);
}

.top_mainbg_box.bg_6 .top_mainbg_catch.catch_01 {
	opacity: 1;
}

.top_mainbg_box.bg_7 {
	background-image: url(../img_top/mainbg_ootemon.jpg);
}

.top_mainbg_box.bg_7 .top_mainbg_catch.catch_01 {
	opacity: 1;
}



/* Main Button
------------------------------------------------------------- */

.top_mainbtn_box {
	margin: 0 auto -60px auto;
	padding: 0 20px;
	width: 100%;
	max-width: 1280px;
	height: auto;
	position: relative;
	z-index: 10;
}

.top_mainbtn_box > div {
	width: 100%;
	max-width: 420px;
	margin: 0 auto 30px auto;
	padding:20px 30px 30px 30px;
	position: relative;
	background-color: #f2f2f2;
	box-shadow: 3px 3px 0 rgba(0,0,0,0.2);
}

.top_mainbtn_box > div > h2 {
	margin: 0 auto 20px auto;
	padding: 0;
	background-color: transparent;
	font-size: 3.8rem;
	font-weight: 500;
	line-height: 80px;
	text-align: center;
	text-shadow: 2px 2px 1px rgba(0,0,0,0.16);
}

.top_mainbtn_box > div > h2 a,
.top_mainbtn_box > div > h2 a:hover,
.top_mainbtn_box > div > h2 a:active {
	color: inherit;
	text-decoration: none;
}

.top_mainbtn_box > div.mainbtn_support > h2 {
	color: #0068b5;
}

.top_mainbtn_box > div.mainbtn_facility > h2 {
	color: #008559;
}

.top_mainbtn_box > div.mainbtn_miceplus > h2 {
	font-size: 0;
	width: 100%;
	height: 80px;
	margin: 0 auto 20px auto;
	background-image: url(../img_top/topbtn_miceplus.png);
	background-repeat: no-repeat;
	background-size: contain;
	background-position: center center;
}

.top_mainbtn_box > div > .btn_box {
	width: 100%;
}

.top_mainbtn_box > div > .btn_box > p {
	width: 100%;
	height: 60px;
	margin-bottom: 20px;
}

.top_mainbtn_box > div > .btn_box > p:last-child {
	margin-bottom: 0;
}

.top_mainbtn_box > div > .btn_box > p a {
	display: block;
	margin: 0;
	width: 100%;
	height: 100%;
	line-height: 60px;
	padding: 0 10px 0 3.5em;
	font-size: 1.7rem;
	font-weight: 400;
	color: #151515;
	box-shadow: inset 2px 2px 4px rgba(0,0,0,0.16);
	overflow: hidden;
	position: relative;
	transition: background-color 0.3s, box-shadow 0.3s;
}

.top_mainbtn_box > div > .btn_box > p a:hover,
.top_mainbtn_box > div > .btn_box > p a:active {
	color: #151515;
	text-decoration: none;
	box-shadow: inset 4px 4px 6px rgba(0,0,0,0.20);
}

.top_mainbtn_box > div > .btn_box > p a span {
	display: block;
	height: 100%;
	white-space: nowrap;
	position: relative;
	z-index: 50;
}

.top_mainbtn_box > div.mainbtn_facility > .btn_box > p a span {
	letter-spacing: 2.5em;
	padding-left: 1em;
}

.top_mainbtn_box > div > .btn_box > p a::before {
	content: "";
	display: block;
	width: 40px;
	height: 40px;
	position: absolute;
	left: 15px;
	top: 50%;
	margin-top: -20px;
	background-position: center center;
	background-size: contain;
	background-repeat: no-repeat;
	opacity: 1;
	z-index: 10;
	transition: all 0.3s;
}

.top_mainbtn_box > div > .btn_box > p:hover a::before {
	transform: scale(2.2, 2.2);
	transform-origin: center center;
	opacity: 0.7;
}

/* Button Setting */

.btn_box > p.btn_support_grant a {
	background-color: #efbbec;
}

.btn_box > p.btn_support_grant a:hover,
.btn_box > p.btn_support_grant a:active {
	background-color: #e298dd;
}

.btn_box > p.btn_support_grant a::before {
	background-image: url(../img/icon_money.svg);
}

.btn_box > p.btn_support_others a {
	background-color: #d3eb82;
}

.btn_box > p.btn_support_others a:hover,
.btn_box > p.btn_support_others a:active {
	background-color: #bddd53;
}

.btn_box > p.btn_support_others a::before {
	background-image: url(../img/icon_megaphone.svg);
}

.btn_box > p.btn_support_process a {
	background-color: #ade1f0;
}

.btn_box > p.btn_support_process a:hover,
.btn_box > p.btn_support_process a:active {
	background-color: #84cbe0;
}

.btn_box > p.btn_support_process a::before {
	background-image: url(../img/icon_document.svg);
}


.btn_box > p.btn_facility_event a {
	background-color: #92d9a5;
}

.btn_box > p.btn_facility_event a:hover,
.btn_box > p.btn_facility_event a:active {
	background-color: #55be71;
}

.btn_box > p.btn_facility_event a::before {
	background-image: url(../img/icon_event.svg);
}

.btn_box > p.btn_facility_inn a {
	background-color: #acb4e5;
}

.btn_box > p.btn_facility_inn a:hover,
.btn_box > p.btn_facility_inn a:active {
	background-color: #8b96d9;
}

.btn_box > p.btn_facility_inn a::before {
	background-image: url(../img/icon_inn.svg);
}


.btn_box > p.btn_mice_attraction a {
	background-color: #add5b9;
}

.btn_box > p.btn_mice_attraction a:hover,
.btn_box > p.btn_mice_attraction a:active {
	background-color: #97c3a4;
}

.btn_box > p.btn_mice_attraction a::before {
	background-image: url(../img/icon_mice_attraction.svg);
}

.btn_box > p.btn_mice_venues a {
	background-color: #ffc188;
}

.btn_box > p.btn_mice_venues a:hover,
.btn_box > p.btn_mice_venues a:active {
	background-color: #f7a75c;
}

.btn_box > p.btn_mice_venues a::before {
	background-image: url(../img/icon_mice_venues.svg);
}

.btn_box > p.btn_mice_sightseeing a {
	background-color: #f6a496;
}

.btn_box > p.btn_mice_sightseeing a:hover,
.btn_box > p.btn_mice_sightseeing a:active {
	background-color: #ef8879;
}

.btn_box > p.btn_mice_sightseeing a::before {
	background-image: url(../img/icon_mice_sightseeing.svg);
}

.btn_box > p.btn_mice_tours a {
	background-color: #accef7;
}

.btn_box > p.btn_mice_tours a:hover,
.btn_box > p.btn_mice_tours a:active {
	background-color: #8db5e5;
}

.btn_box > p.btn_mice_tours a::before {
	background-image: url(../img/icon_mice_tours.svg);
}

.btn_box > p.btn_mice_souvenirs a {
	background-color: #fcd352;
}

.btn_box > p.btn_mice_souvenirs a:hover,
.btn_box > p.btn_mice_souvenirs a:active {
	background-color: #fac61d;
}

.btn_box > p.btn_mice_souvenirs a::before {
	background-image: url(../img/icon_mice_souvenirs.svg);
}



/* Calendar
------------------------------------------------------------- */

.calendar_box {
	margin-top: 0;
}



/* News
------------------------------------------------------------- */

#news_box {
	width: 100%;
	padding: 20px 20px;
	line-height: 2;
	position: relative;
}

#news_box::after {
	content:"";
	display:block;
	clear:both;
}

#news_box .news_cont_wrapper {
	margin-top: -5px;
}



/* Sanjo
------------------------------------------------------------- */

#sanjo_box {
	width: 100%;
	margin-bottom: 40px;
	padding: 20px 20px;
	line-height: 2;
	position: relative;
}

#sanjo_box::after {
	content:"";
	display:block;
	clear:both;
}

#sanjo_box .sanjo_cont_wrapper {
	margin-top: -5px;
}

#sanjo_box .section_title span.en {
	letter-spacing: 0;
	font-size: 1.6rem;
	transform: scaley(1.125);
	transform-origin: top left;
}

#sanjo_box .sanjo_btn_box {
	margin-bottom: 60px;
}

#sanjo_box .sanjo_btn_box .btn_txt {
	margin: 0 auto 30px auto;
	padding: 0 20px 0 40px;
	line-height: 70px;
}

#sanjo_box .sanjo_btn_box .btn_txt::before {
	content: "";
	display: inline-block;
	width: 60px;
	height: 60px;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	left: 5%;
	top: 50%;
	margin-top: -30px;
}

#sanjo_box .sanjo_btn_box .btn_sanjo_bosyu .btn_txt::before {
	background-image: url(../img/icon_sanjo_join.svg);
}

#sanjo_box .sanjo_btn_box .btn_sanjo_info .btn_txt::before {
	background-image: url(../img/icon_sanjo_info.svg);
}



/* Topics
------------------------------------------------------------- */

.topics_box {
	margin: -40px 0 0 0;
	padding: 20px;
}

ul.topics_list {
	width: 100%;
	list-style-type: none;
	list-style-position: outside;
}

ul.topics_list li {
	width: 100%;
	height: 100px;
	margin-bottom: 20px;
	padding: 0;
	background-color: #fff;
	position: relative;
	box-shadow: 2px 2px 0 rgba(0,0,0,0.25);
}

ul.topics_list li:last-child {
	margin-bottom: 0;
}

ul.topics_list li a {
	display: block;
	width: 100%;
	height: 100px;
}

ul.topics_list li img {
	width: 100px;
	height: 100px;
	object-fit: cover;
	position: absolute;
	left: 0;
	top: 0;
	opacity: 1;
	transition: opacity 0.3s;
}

ul.topics_list li:hover {
	transform: translate(1px, 1px);
	box-shadow: 1px 1px 0 rgba(0,0,0,0.25);
}

ul.topics_list li:hover img {
	opacity: 0.7;
}

ul.topics_list li h3 {
	padding: 8px 10px 0 115px;
	font-size: 1.6rem;
	font-weight: 600;
	line-height: 1.2;
	height: 2.5em;
}

ul.topics_list li a,
ul.topics_list li a:hover,
ul.topics_list li a:active,
ul.topics_list li a:visited {
	color: #151515;
	text-decoration: none;
}

ul.topics_list li p {
	width: calc(100% - 125px);
	min-height: 3em;
	font-size: 1.15rem;
	font-weight: 350;
	line-height: 1.35;
	color: #333;
	position: absolute;
	right: 10px;
	bottom: 5px;
}



/* Youtube
------------------------------------------------------------- */

.youtube_box {
	width: 100%;
	max-width: 1360px;
	margin: 0 auto;
	padding: 40px 20px;
}

.youtube_swiper_wrapper {
	padding: 0 40px;
	margin-bottom: 20px;
	position: relative;
}

.movieslide_inner .movie_thmb {
	position: relative;
}

.movieslide_inner .movie_thmb::before {
	content: "";
	display: block;
	width: 20%;
	height: auto;
	aspect-ratio: 1/1;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	background-image: url(../img/icon_youtube_red.png);
	background-size: contain;
	background-position: center center;
	background-repeat: no-repeat;
	pointer-events: none;
	z-index: 1;
}

.movieslide_inner .movie_thmb a[data-fancybox]::before {
	display: none;
}

.movieslide_inner .movie_thmb a img {
	width: 100%;
	aspect-ratio: 16/9;
	object-fit: cover;
	margin-bottom: 5px;
}

.youtube_swiper_wrapper .swiper-button-prev,
.youtube_swiper_wrapper .swiper-button-next {
	width: 32px !important;
	height: 32px !important;
	margin-top: -16px !important;
	background-color: #a0a0a0;
	background-size: contain;
	background-repeat: no-repeat;
	z-index: 100;
	color: transparent;
}

.youtube_swiper_wrapper .swiper-button-prev {
	background-image: url(../img/arrow_prev_white.svg);
	background-position: center right -2px;
	left: 0;
}

.youtube_swiper_wrapper .swiper-button-next {
	background-image: url(../img/arrow_next_white.svg);
	background-position: center left -2px;
	right: 0;
}

.youtube_box .btn_center a.btn_txt {
	margin-bottom: 0;
}



/* Banner
------------------------------------------------------------- */

.banner_box {
	width: 100%;
	margin: 0;
	padding: 20px;
	background-color: #f0f0f0;
	background: linear-gradient(0deg,#fafafa 0%, #d5d5d5 100%);
}

ul.banner_list {
	width: 100%;
	max-width: 1080px;
	margin: 0 auto;
	padding: 0;
	list-style-type: none;
	list-style-position: outside;
}

ul.banner_list li {
	width: 200px;
	height: auto;
	margin: 0 auto 10px auto;
	font-size: 0;
	text-align: center;
}

ul.banner_list li:last-child {
	margin-bottom: 0;
}

ul.banner_list li.bn_large {
	width: 100%;
}

ul.banner_list li a {
	text-decoration: none;
}

ul.banner_list li a img {
	width: 100%;
	height: auto;
	opacity: 1;
	transition: opacity 0.3s;
	vertical-align: text-top;
}

ul.banner_list li a:hover img {
	opacity: 0.8;
}





/* for SmallSize
--------------------------------------------------------------------------------- */
@media print, screen and (min-width:360px) {



}





/* for MiddleSize(480-)
-------------------------------------------------------------------------------- */
@media print, screen and (min-width:420px) {

	/* Catch */

	.top_mainbg_box .top_mainbg_catch p {
		font-size: 2.8rem;
	}



	.top_mainbtn_box > div > .btn_box > p a {
		font-size: 2rem;
	}


	/* Topics
	------------------------------------------------------------- */

	ul.topics_list li {
		height: 120px;
	}

	ul.topics_list li a {
		height: 120px;
	}

	ul.topics_list li img {
		width: 120px;
		height: 120px;
	}

	ul.topics_list li h3 {
		font-size: 1.8rem;
		padding: 12px 18px 0 135px;
		line-height: 1.4;
	}

	ul.topics_list li h3 br {
		display: none;
	}

	ul.topics_list li p {
		width: calc(100% - 145px);
		right: 10px;
		bottom: 12px;
		line-height: 1.5;
	}


	/* Banner
	------------------------------------------------------------- */

	ul.banner_list {
		display: grid;
		grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
		column-gap: 20px;
		row-gap: 20px;
	}

	ul.banner_list li {
		width: 100%;
		margin: 0;
	}

	ul.banner_list li.bn_large {
		grid-column: 1 / -1;
	}

}





/* for MiddleSize(540-787)
-------------------------------------------------------------------------------- */
@media print, screen and (min-width:540px) {





}





/* for MiddleSize
-------------------------------------------------------------------------------- */
@media print, screen and (min-width:788px) {


	/* Contact Tab
	------------------------------------------------------------- */

	.contact_tab {
		width: 80px;
		height: 80px;
	}

	.contact_tab a {
		font-size: 1rem;
	}
	


	/* Main BG
	------------------------------------------------------------- */

	.top_mainbg_box {
		height: 240px;
	}

	/* Catch */

	.top_mainbg_box .top_mainbg_catch {
		padding: 0 40px;
	}

	.top_mainbg_box .top_mainbg_catch p {
		font-size: 3.4rem;
	}

	.top_mainbg_box .top_mainbg_catch p::after {
		width: calc(100% + 40px);
		left: -40px;
	}


	/* Main Button
	------------------------------------------------------------- */

	.top_mainbtn_box {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		padding: 0 40px;
		margin-bottom: -80px;
	}

	.top_mainbtn_box > div {
		width: calc(50% - 15px);
		max-width: none;
		margin: 0 0 30px 0;
	}

	.top_mainbtn_box > div.mainbtn_support {
		margin-right: 30px;
	}

	.top_mainbtn_box > div.mainbtn_facility .btn_box p {
		height: 100px;
	}

	.top_mainbtn_box > div.mainbtn_facility .btn_box p a {
		line-height: 100px;
		padding-left: 4.5em;
	}

	.top_mainbtn_box > div.mainbtn_facility .btn_box p a::before {
		left: 30px;
	}

	.top_mainbtn_box > div.mainbtn_miceplus {
		width: 70%;
	}


	/* Calendar
	------------------------------------------------------------- */

	.calendar_box {
		margin-top: -20px;
	}


	/* News
	------------------------------------------------------------- */

	#news_box {
		padding: 0 40px;
		line-height: 2;
	}


	/* Sanjo
	------------------------------------------------------------- */

	#sanjo_box {
		padding: 40px 40px 0 40px;
		line-height: 2;
	}


	/* Topics
	------------------------------------------------------------- */

	.topics_box {
		padding: 40px 40px;
	}

	ul.topics_list {
		display: grid;
		grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
		justify-content: start;
		column-gap: 20px;
		row-gap: 20px;
	}

	ul.topics_list li {
		margin: 0;
	}

	ul.topics_list li h3 {
		font-size: 1.75rem;
		line-height: 1.2;
	}

	ul.topics_list li h3 br {
		display: inline;
	}


	/* Youtube
	------------------------------------------------------------- */

	.youtube_box {
		padding: 40px 40px;
	}


	/* Banner
	------------------------------------------------------------- */

	.banner_box {
		padding: 40px 40px;
	}


}





/* for LargeSize
-------------------------------------------------------------------------------- */
@media print, screen and (min-width:980px) {

	/* Contact Tab
	------------------------------------------------------------- */

	.contact_tab {
		width: 80px;
		height: 80px;
		position: absolute;
		right: 20px;
		bottom: auto;
		top: 130px;
	}

	.contact_tab.fixed {
		position: fixed;
		top: 160px;
	}

	.contact_tab a {
		font-size: 1rem;
	}


	/* Main BG
	------------------------------------------------------------- */

	.top_mainbg_box {
		margin-top: 140px;
		height: 460px;
	}

	.top_mainbg_box::after {
		height: 80%;
		background: linear-gradient(0deg,rgba(0,0,0,0) 0%, rgba(0,0,0,0.2) 100%);
	}

	/* Catch */

	.top_mainbg_box .top_mainbg_catch {
		top: 22%;
	}

	.top_mainbg_box .top_mainbg_catch p {
		font-size: 3.8rem;
	}


	/* Main Button
	------------------------------------------------------------- */

	.top_mainbtn_box {
		display: flex;
		flex-wrap: nowrap;
		justify-content: space-between;
		margin-top: -298px;
		margin-bottom: -100px;
	}

	.top_mainbtn_box > div {
		width: calc(33.3333% - 26.6666px);
		max-width: 360px;
		margin: 0;
		padding: 20px;
		background-color: #fff;
/*
		background-color: rgba(255,255,255,0.5);
		backdrop-filter: blur(8px) brightness(120%);
*/
	}

	.top_mainbtn_box > div > h2 {
		font-size: 3.4rem;
	}

	.top_mainbtn_box > div.mainbtn_support {
		margin-right: 0;
	}

	.top_mainbtn_box > div.mainbtn_facility .btn_box p {
		height: 100px;
	}

	.top_mainbtn_box > div.mainbtn_facility .btn_box p a {
		line-height: 100px;
	}

	.top_mainbtn_box > div.mainbtn_miceplus {
		width: calc(33.3333% - 26.6666px);
	}

	.top_mainbtn_box > div > .btn_box > p {
		height: 50px;
	}

	.top_mainbtn_box > div > .btn_box > p a {
		line-height: 50px;
		padding: 0 5px 0 3.5em;
		font-size: 1.8rem;
	}

	.top_mainbtn_box > div.mainbtn_support > .btn_box > p {
		height: 76px;
		margin-bottom: 31px;
	}

	.top_mainbtn_box > div.mainbtn_support > .btn_box > p:last-child {
		margin-bottom: 0;
	}

	.top_mainbtn_box > div.mainbtn_support > .btn_box > p a {
		line-height: 76px;
	}

	.top_mainbtn_box > div.mainbtn_facility > .btn_box > p {
		height: 130px;
		margin-bottom: 30px;
	}

	.top_mainbtn_box > div.mainbtn_facility > .btn_box > p:last-child {
		margin-bottom: 0;
	}

	.top_mainbtn_box > div.mainbtn_facility > .btn_box > p a {
		line-height: 130px;
	}

	.top_mainbtn_box > div.mainbtn_miceplus > .btn_box > p {
		margin-bottom: 10px;
	}

	.top_mainbtn_box > div.mainbtn_miceplus > .btn_box > p:last-child {
		margin-bottom: 0;
	}

	.top_mainbtn_box > div.mainbtn_miceplus > .btn_box > p a {
		line-height: 50px;
		padding: 0 5px 0 2.5em;
		font-size: 1.7rem;
	}

	.top_mainbtn_box > div.mainbtn_miceplus > .btn_box > p a::before {
		left: 3px;
	}


	/* News
	------------------------------------------------------------- */

	#news_box {
		padding: 10px 0 40px 0;
	}

	#news_box .section_title {
		padding-left: 40px;
		margin-left: 0;
	}

	#news_box ul.news_tab {
		justify-content: flex-start;
		border-bottom: 0;
		padding-bottom: 10px;
	}

	#news_box .news_cont_wrapper {
		width: calc(100% - 230px);
		float: right;
		margin-top: -100px;
		padding: 0 0 30px 0;
		background-color: #f0f0f0;
	}

	#news_box .news_cont_wrapper ul.news_list {
		padding: 10px 40px 0 30px;
	}

	#news_box .news_cont_wrapper ul.news_list li:first-child {
		border-top: 0;
	}

	#news_box .news_cont_wrapper .btn_txt {
		background-color: #fff;
		width: 420px;
		margin-bottom: 5px;
	}



	/* Sanjo
	------------------------------------------------------------- */

	#sanjo_box {
		padding: 40px 0 40px 0;
		margin-bottom: 40px;
	}

	#sanjo_box .section_title {
		padding-left: 40px;
		margin-left: 0;
	}

	#sanjo_box ul.sanjo_tab {
		justify-content: flex-start;
		border-bottom: 0;
		padding-bottom: 10px;
	}

	#sanjo_box .sanjo_cont_wrapper {
		width: calc(100% - 360px);
		float: right;
		margin-top: -100px;
/*		padding: 0;	*/
		padding: 0 0 30px 0;
		background-color: #f9f5ed;
	}

	#sanjo_box .sanjo_cont_wrapper ul.news_list {
/*		margin: 0 0 10px 0;	*/
		padding: 10px 40px 0 30px;
	}

	#sanjo_box .sanjo_cont_wrapper ul.news_list li:first-child {
		border-top: 0;
	}
/*
	#sanjo_box .sanjo_cont_wrapper ul.news_list li:last-child {
		border-bottom: 0;
	}
*/
	#sanjo_box .sanjo_cont_wrapper .btn_txt {
		background-color: #fff;
		width: 420px;
		margin-bottom: 5px;
	}

	#sanjo_box .sanjo_btn_box {
		margin: 0 0 0 40px;
		width: 280px;
	}

	#sanjo_box .sanjo_btn_box .btn_txt {
		margin: 0 0 20px 0;
		width: 100%;
	}


	/* Topics
	------------------------------------------------------------- */

	.topics_box {
		padding: 40px 40px;
		max-width: 1280px;
		margin: 0 auto;
	}

	ul.topics_list {
		grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
		column-gap: 30px;
		row-gap: 30px;
	}

	ul.topics_list li h3 {
		font-size: 1.8rem;
	}

	/* Banner
	------------------------------------------------------------- */

	.banner_box {
		padding: 40px 40px;
	}

}





/* for ExtraLargeSize
-------------------------------------------------------------------------------- */
@media print, screen and (min-width:1080px) {

	/* Main Button
	------------------------------------------------------------- */

	.top_mainbtn_box > div > .btn_box > p a {
		font-size: 2rem;
	}


	.top_mainbtn_box > div.mainbtn_miceplus > .btn_box > p a {
		padding: 0 5px 0 3.5em;
	}

	.top_mainbtn_box > div.mainbtn_miceplus > .btn_box > p a::before {
		left: 10px;
	}

}





/* for ExtraLargeSize
-------------------------------------------------------------------------------- */
@media print, screen and (min-width:1280px) {

	/* Contact Tab
	------------------------------------------------------------- */

	.contact_tab {
		right: 40px;
	}


	/* Main BG
	------------------------------------------------------------- */

	.top_mainbg_box {
		height: 520px;
	}

	/* Catch */

	.top_mainbg_box .top_mainbg_catch {
		top: 25%;
		padding-left: calc((100vw - 1200px) / 2);
	}

	.top_mainbg_box .top_mainbg_catch p {
		font-size: 4.2rem;
	}

	.top_mainbg_box .top_mainbg_catch p::after {
		width: calc(100% + ((100vw - 1200px) / 2));
		left: calc((100vw - 1200px) / -2);
	}


	/* Main Button
	------------------------------------------------------------- */

	.top_mainbtn_box > div {
		padding: 20px 30px 30px 30px;
	}

	.top_mainbtn_box > div > h2 {
		font-size: 4.2rem;
	}

	.top_mainbtn_box > div > .btn_box > p a {
		font-size: 2.2rem;
	}

	.top_mainbtn_box > div.mainbtn_miceplus > .btn_box > p a {
		padding: 0 5px 0 3em;
		font-size: 2rem;
	}

	.top_mainbtn_box > div.mainbtn_miceplus > .btn_box > p a::before {
		left: 10px;
	}



	/* News
	------------------------------------------------------------- */

	#news_box .section_title {
	padding-left: calc((100vw - 1200px) / 2);
	}

	#news_box .news_cont_wrapper {
		width: calc((100vw - ((100vw - 1200px) / 2)) - 220px);
		padding-bottom: 40px;
	}

	#news_box .news_cont_wrapper ul.news_list {
		padding: 15px 60px 0 40px;
		max-width: 1040px;
	}

	#news_box .news_cont_wrapper .btn_center {
		max-width: 1040px;
	}

	#news_box .news_cont_wrapper .btn_txt {
		margin-bottom: -5px;
	}


	/* Sanjo
	------------------------------------------------------------- */

	#sanjo_box .section_title {
	padding-left: calc((100vw - 1200px) / 2);
	}

	#sanjo_box .section_title span.en {
		font-size: 1.8rem;
		transform: scaley(1);
	}

	#sanjo_box .sanjo_cont_wrapper {
		width: calc((100vw - ((100vw - 1200px) / 2)) - 360px);
		padding-bottom: 20px;
	}

	#sanjo_box .sanjo_cont_wrapper ul.news_list {
		padding: 15px 60px 0 40px;
		max-width: 900px;
	}

	#sanjo_box .sanjo_cont_wrapper .btn_center {
		max-width: 900px;
	}

	#sanjo_box .sanjo_cont_wrapper .btn_txt {
		margin-bottom: 15px;
	}

	#sanjo_box .sanjo_btn_box {
		width: 310px;
		margin-left: calc((100vw - 1200px) / 2);
	}


	/* Youtube
	------------------------------------------------------------- */

	/* 動画が5つ以上になったら下記の設定は無効にする */
/*
	.youtube_box {
		max-width: 1280px;
	}

	.youtube_swiper_wrapper {
		padding: 0;
	}
*/

}






/*** Print Styles ***/

@media print {

	/* Main BG
	------------------------------------------------------------- */

	.top_mainbg_box {
		margin-top: 0;
		height: 160px;
	}

	/* Catch */

	.top_mainbg_box .top_mainbg_catch {
		padding: 50px 20px 0 20px;
		height: auto;
	}

	.top_mainbg_box .top_mainbg_catch p {
		font-size: 3.2rem;
	}

	.top_mainbg_box .top_mainbg_catch p::after {
		display: block;
		width: calc(100% + 20px);
		left: -20px;
		top: 1.45em;
	}


	/* Contact Tab
	------------------------------------------------------------- */

	.contact_tab {
		display: none !important;
	}


	/* Main Button
	------------------------------------------------------------- */

	.top_mainbtn_box {
		margin: 0 auto 20px auto;
		padding: 0 20px;
	}

	.top_mainbtn_box > div {
		width: calc(33.3333% - 6px);
		margin: 0;
		padding: 10px;
		background-color: #f2f2f2;
	}

	.top_mainbtn_box > div > h2 {
		font-size: 3.2rem;
	}

	.top_mainbtn_box > div > .btn_box > p a {
		padding: 0 5px 0 5em !important;
		font-size: 1.8rem !important;
	}

	.top_mainbtn_box > div.mainbtn_miceplus > .btn_box > p a {
		padding: 0 5px 0 2.5em !important;
		font-size: 1.7rem !important;
	}


	/* News
	------------------------------------------------------------- */

	#news_box ul.news_tab {
		display: none;
	}

	#news_box .news_cont_wrapper {
		width: 100%;
		float: none;
		margin-top: 0;
	}


	/* Sanjo
	------------------------------------------------------------- */

	#sanjo_box ul.sanjo_tab {
		display: none;
	}

	#sanjo_box .sanjo_cont_wrapper {
		width: 100%;
		float: none;
		margin-top: 0;
	}

	#sanjo_box .sanjo_btn_box {
		display: none;
	}


	/* Topics
	------------------------------------------------------------- */

	.topics_box {
		padding: 20px 20px;
	}

	ul.topics_list {
		display: grid;
		grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
		justify-content: start;
		column-gap: 20px;
		row-gap: 20px;
	}

	ul.topics_list li {
		margin: 0;
	}

	ul.topics_list li h3 br {
		display: none;
	}



}