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


@media all and (max-width: 768px) {
	body {
		min-width: 100% !important;
		max-width: 100% !important;
		width: 100% !important;
	}
	.h1box {
		max-width: 100%;
		width: 100%;
		box-sizing: border-box;
		width: auto !important;
		min-width: 100% !important;
		padding: 4px;
		display: none;
	}
	#header {
		max-width: 100%;
		width: 100%;
		box-sizing: border-box;
	}
	.siteTitle {
		width: 160px;
	}
	.siteTitle img {
		width: 100%;
		height: auto;
	}
	#fontSize {
		position: absolute;
		right: 70px;
		top: 13px;
		width: 80px;
		padding-top: 0;
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}
	#fontSize li {
		flex-basis: 48% !important;
		text-align: center;
		float: none !important;
	}
	#fontSize li:nth-child(1),
	#fontSize li:nth-child(4) {
		width: 100%;
		text-align: center;
		font-size: 12px;
		padding: 3px 0 !important;
	}
	#header .local-nav {
		display: none;
	}
	#gl-nav {
		display: none;
	}
	
	#visual.subimg {
		overflow: hidden;
	}
	#visual.subimg img {
		display: block;
		object-fit: cover;
		width: auto;
		height:105px;
		position: relative;
		left: -200px;
	}
	
	#wrap-content {
		box-sizing: border-box;
		padding-left: 4%;
		padding-right: 4%;
	}
	#pagebody {
		box-sizing: border-box;
		width: 100% !important;
	}
	#pagebody #main,
	#pagebody #sidebar{
		box-sizing: border-box;
		width: 100% !important;
		clear: both;
		float: none;
	}
	#pagebody img {
		max-width: 100%;
		height: auto !important;
	}
	#pagebody iframe {
		width: 100%;
	}
	
	.totop {
		width: 100%;
		box-sizing: border-box;
	}
	#footer {
		width: 100%;
		box-sizing: border-box;
	}
	#footer .logo {
		text-align: center;
		float: none;
		width: 100%;
	}
	#footer .nav {
		display: none;
	}
	.sp-over {
		overflow: auto;
	}
	.sp-over table {
		min-width: 800px;
	}
	.nofl li {
		float: none !important;
		clear: both;
		margin-bottom: 10px;
	}
	.w100p {
		width: 100% !important;
	}
	.noflmain {
		clear: both !important;
		float: none !important;
	}
	.link ul {
		height: auto !important;
	}
	
	
	.bx-wrapper img {
		width: 100% !important;
		height: 420px !important;
		object-fit: cover !important;
	}
	.news li span.time {
		display: block;
		flex-basis: 100%;
		width: 100% !important;
	}
	.bnr-lr li {
		width: 48%;
		display: flex;
		align-items: center;
	}
	.bnr-lr img {
		width: 100%;
	}
	
	
	#sidebar ul {
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}
	#sidebar ul li {
		display: block;
		flex-basis: 48%;
	}
	#sidebar li img {
		width: 100%;
	}
	
	.information_top ul {
		display: flex !important;
		justify-content: space-between !important;
		flex-wrap: wrap !important;
	}
	.information_top ul li {
		flex-basis: 48%;
	}
	.information_top ul li img {
		width: 100%;
	}
	.imgright {
		margin-left: 0 !important;
		float: none !important;
		margin-bottom: 16px !important;
	}
	.imgright img {
		width: 100%;
	}
	.imgleft {
		margin-right: 0 !important;
		float: none !important;
		margin-bottom: 16px !important;
	}
	.imgleft img {
		width: 100%;
	}
	#main.subcon p {
		padding: 0px 0px 25px 0px;
	}
	.treasuresArea .fleft,
	.treasuresArea .fright{
		float: none !important;
		margin: 0 !important;
	}
	.treasuresArea .fleft img,
	.treasuresArea .fright img {
		width: 100%;
		margin-bottom: 16px;
	}
	.treasuresArea dl {
		width: 100% !important;
		box-sizing: border-box;
	}
	#gallery li{
		float: none !important;
		clear: both !important;
		width: 100% !important;
		height: auto !important;
		margin-bottom: 35px;
	}
	#gallery li img {
		width: 100% !important;
	}
	.treasuresArea li .trimming {
		width: 100%;
	}
	.treasuresArea li p {
		width: 100%;
	}
	.subbtn li {
		float: none !important;
		width: 100% !important;
	}
	.subbtn li img {
		width: 100% !important;
	}
	.imglist li {
		float: none !important;
		width: 100%;
	}
	.imglist li img {
		width: 100% !important;
	}
	.guideList li {
		float: none !important;
		width: 100%;
		margin-bottom: 22px;
	}
	.guideList li dl {
		box-sizing: border-box;
		width: 100% !important;
	}
	.guideList li dl dd {
		padding: 12px !important;
	}
	.guideList li img {
		width: 100%;
		padding: 0 !important;
		margin: 0 !important;
	}
	.catsday img {
		width: 100% !important;
	}
	.dayTable th,
	.dayTable td {
		font-size: 13px !important;
		line-height: 1.5 !important;
		padding-left: 1% !important;
		padding-right: 1% !important;
	}
	.subbtn02 li {
		padding-left: 0 !important;
		padding-right: 0 !important;
		margin-left: 0 !important;
		margin-right: 0 !important;
		width: 100% !important;
	}
	.subbtn02 li img {
		width: 100% !important;
	}
	.setsuList li {
		float: none !important;
		width: 100% !important;
		margin-left: 0 !important;
		margin-right: 0 !important;
	}
	.setsuList li img {
		width: 100% !important;
	}
	.memorialImg li {
		float: none !important;
		width: 100% !important;
		margin-left: 0 !important;
		margin-right: 0 !important;
		margin-top: 12px  !important;
	}
	.memorialImg li img {
		width: 100% !important;
	}
	.timberList {
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}
	.timberList li {
		flex-basis: 48%;
		margin-left: 0 !important;
		margin-right: 0 !important;
		margin-bottom: 13px;
	}
	.timberList li img {
		width: 100%;
	}
	.pr-sp-tab th {
		display: block;
		text-align: center;
		width: 100%;
		box-sizing: border-box;
	}
	.pr-sp-tab td {
		text-align: left;
		display: block;
		box-sizing: border-box;
		width: 100%;
	}
	.karenkaDl {
		padding-right: 0 !important;
	}
	.karenkaDl p,
	.karenkaDl img{
		width: 100%;
	}
	.sitemap-list.fleft,
	.sitemap-list.fright {
		float: none !important;
		width: 100% !important;
	}
	.topics dt,
	.topics dd {
		float: none !important;
		width: 100%;
		margin-bottom: 13px;
	}
	.topics dt img {
		width: 100% !important;
	}
	#main.subcon img {
		width: 100%;
	}
	.defTable01 th,
	.defTable01 td {
		display: block;
		box-sizing: border-box;
		width: 100%;
	}
	input[name="mail"],
	input[name="mail2"],
	input[name="zyuusyo"],
	input[name="name1"],
	input[name="name2"],
	textarea{
		width: 93%;
	}
}
@media all and (min-width: 600px) and (max-width: 768px) {
	.bx-wrapper img {
		width: 100% !important;
		height: 590px !important;
		object-fit: cover !important;
	}
}




/*SP ハンバーガー*/
@media all and (min-width: 769px) {
	.hamburger {
		display: none;
	}
	.back__bg {
		display: none;
	}
	.global__nav {
		display: none;
	}
}

@media all and (max-width: 768px) {
	.hamburger{
		display: block !important;
		width:55px !important;
		height:55px !important;
		box-sizing: border-box;
		cursor: pointer;
		position:fixed;
		background: #666;
		right: 5px;
		top: 10px;
		z-index: 300;
	}
	/* line open */
	.hamburger__line {
		position: absolute;
		left: 50%;
		transform: translateX(-50%);
		width: 38px;
		height: 3px;
		background-color: #fff;
		transition: all .1s ease-out;
	}
	.hamburger__line--1 {
		top: 20px;
		width: 25px;
		left: 39%;
	}
	.hamburger__line--3 {
		top: 34px;
	}
	/* line close */
	.nav-open .hamburger__line--1 {
		transform: rotate(45deg);
		top: 25px;
		left: 16%;
		width: 38px;
	}
	.nav-open .hamburger__line--3 {
		transform: rotate(-45deg);
		top: 25px;
		left: 16%;
	}
	.nav-open .hBox,
	.nav-open .sub-mv-box,
	.nav-open .branch,
	.nav-open #main,
	.nav-open .mainVisual{
		opacity: 0;
	}
	/* back__bg */
	.back__bg {
		position: fixed;
		left: 0;
		top: 0;
		width: 100vw;
		height: 100vh;
		z-index: 100;
		background:#F9FAFD;
		opacity: 0;
		visibility: hidden;
		transition: all .1s;
		cursor: pointer;
		display: none;
	}
	/* 表示された時用のCSS */
	.nav-open .global__nav {
	  right: 0;
	}
	.nav-open .back__bg {
		background:rgba(0,0,0,0.9);
		opacity: 1;
		visibility: visible;
		display: block;
	}
	.global__nav {
		display: none;
	}
	.nav-open .global__nav {
		display:block;
	}

	/* ハンバーガーメニュー内 */
	.hlogo-open {
		position: absolute;
		left: 2%;
		top: 15px;
	}
	.bbt-mos {
		position: absolute;
		left: 15px;
		bottom: 15px;
		font-size: 160px;
		line-height: 150px;
		font-weight: 600;
		letter-spacing: 0px;
		color: #1C72D4;
		opacity: 0.1;
	}
	nav.global__nav {
		position: fixed;
		right: -100%;
		top: 0;
		box-sizing: border-box;
		width: 100%;
		height: 100vh;
		transition: all .1s ease-out;
		z-index: 200;
		padding: 8.8% 7.8% 2% 7.8%;
		overflow: hidden;
	}
	.flx-wrap-open {
		display: block;
		max-width: 1000px;
		margin-left: auto;
		margin-right: auto;
		position: relative;
		z-index: 20;
	}
	nav.gnav ul.nav__right--menu {
	  display: block;
	}
	.nav__right--inner {
		display: block;
		height: 80vh;
		overflow: auto;
		margin-top: 60px;
	}
	.nav__right--inner ul {
		display: block;
	}
	.nav__right--inner li {
		display: block;
		margin-bottom: 13px;
		padding: 0px !important;
	}
	.nav__right--inner li a,
	.nav__right--inner li span{
		letter-spacing: 0px;
		color: #fff;
		opacity: 1;
		display: block;
		text-align: center;
		padding: 7px 10px;
		border: #fff solid 1px;
		background: #444;
	}
	.nav__right--inner li ul li a {
		margin-left: 15px;
		margin-right: 15px;
		padding: 4px 10px;
		margin-top: 4px;
		background: none;
	}
	.nav__right--inner li.active > a{
	}
}
