@charset "UTF-8";
/* 2022.06.24 追加
-------------------------------------------------------------- */
.livecamera {
  width: 400px;
  margin: 60px 0 80px;
}

@media only screen and (max-width:766px) {
  .livecamera {
    width: 340px;
    margin: 0 0 60px;
  }
}

/* COMMON
-------------------------------------------------------------- */
img {
  -ms-interpolation-mode: bicubic;
  max-width: 100%;
  max-height: 100%;
  height: auto;
/*  image-rendering: -webkit-optimize-contrast;*/
}

.pc {
  display: inline;
}
@media only screen and (max-width:766px) {
  .pc {
    display: none;
  }
}

.sm {
  display: none;
}
@media only screen and (max-width:766px) {
  .sm {
    display: inline;
  }
}

br.sm_br {
  display: none;
}
@media only screen and (max-width:766px) {
  br.sm_br {
    display: inline;
  }
}

br.tb_br {
  display: none;
}
@media only screen and (max-width:1023px) {
  br.tb_br {
    display: inline;
  }
}

@media only screen and (max-width:766px) {
  br.pc_br {
    display: none;
  }
}

.center {
  text-align: center !important;
}

strong {
  font-weight: bold;
}

a {
  text-decoration: none;
  outline: none;
  color: #000;
  transition: opacity 0.5s ease-out;
}

a:hover {
  opacity: 0.6;
  text-decoration: none;
  color: #000;
}

.youtube {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
}

.gmap {
  height: 100%;
  overflow: hidden;
  position: relative;
}
.gmap iframe {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
}

.list001 li {
  position: relative;
  padding-left: 1.2em;
  text-align: justify;
  text-justify: inter-ideograph;
  -ms-text-justify: inter-ideograph;
  line-height: 1.3em;
}
@media only screen and (max-width:766px) {
  .list001 li {
    font-size: 11px;
    font-size: 0.6875rem;
    margin-bottom: 0.5em;
  }
}
.list001 li:last-child {
  margin-bottom: 0;
}
.list001 li:before {
  content: "※";
  position: absolute;
  left: 0;
  top: 2px;
}

select::-ms-expand {
  display: none;
}

/* iOSでのデフォルトスタイルをリセット */
input[type=submit],
input[type=button] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
}
input[type=submit]::-webkit-search-decoration,
input[type=button]::-webkit-search-decoration {
  display: none;
}
input[type=submit]::focus,
input[type=button]::focus {
  outline-offset: -2px;
}

.construction {
  font-weight: bold;
  font-size: 20px;
  font-size: 1.25rem;
  display: table;
  max-width: 800px;
  margin: 0 auto;
  background: rgba(255, 255, 255, 0.8);
  margin-bottom: 300px;
}
@media only screen and (max-width:766px) {
  .construction {
    margin-bottom: 200px;
  }
}
.construction p {
  display: table-cell;
  vertical-align: middle;
  height: 500px;
  text-align: center;
}
@media only screen and (max-width:766px) {
  .construction p {
    height: 200px;
  }
}

/* LAYOUT
-------------------------------------------------------------- */
body {
  font-size: 20px;
  font-size: 1.25rem;
  line-height: 1.8em;
  font-family: "游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  background: #fff;
  color: #000;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -webkit-overflow-scrolling: touch;
  position: relative;
  height: 100%;
  background: url(../images/common/body_back.jpg) center top;
  background-attachment: fixed;
  overflow-x: hidden;
}
body.active {
  overflow-y: hidden;
}
@media only screen and (max-width:1023px) {
  body {
    background: none;
  }
}
@media only screen and (max-width:766px) {
  body {
    font-size: 12px;
    font-size: 0.75rem;
  }
}

@supports (-webkit-touch-callout: none) {
  body {
    /* Safari用のハック */
    height: -webkit-fill-available;
  }
}
html {
  height: 100%;
}

div#wrapper {
  /*
  	min-height: 100%;
  	height: 100%
  */
  max-width: 1366px;
  width: 100%;
  margin: 0 auto;
}

/*
旧レイアウト
.wrapper_001{
	background: url(../images/common/cont_top.jpg) no-repeat center top,url(../images/common/cont_bottom.jpg) no-repeat center bottom,#fff;
	background-size: 100% auto;
}
*/
.wrapper_001 {
  background: url(../images/common/cont_top.jpg) no-repeat left top, url(../images/common/cont_bottom.jpg) no-repeat center bottom, #fff;
  background-size: 740px auto, 100% auto;
}

.wrapper_002 {
  background: url(../images/common/cont_top.jpg) no-repeat center top, #fff;
  background-size: 100% auto;
}

div#overray {
  display: none;
  background: rgba(255, 255, 255, 0.2);
  height: 100vh;
  width: 100vw;
  position: fixed;
  z-index: 10;
  left: 0;
  top: 0;
}

/* HEDDER
-------------------------------------------------------------- */
/*旧レイアウト
header{
	position: relative;
	padding: 0 0 65px 0;
	@media only screen and (min-width:767px) and (max-width:1023px){
		padding: 30px 0 65px 0;
	}
	@media only screen and (max-width:766px){
		padding: 40px 0 35px 0;
	}

	.logo{
		width: 440px;
		height: 118px;
		position: absolute;
		top:60px;
		left: 78px;
		@media only screen and (max-width:1023px){
			position: inherit;
			top:auto;
			left: auto;
			margin: 0 auto;

		}
		@media only screen and (min-width:767px) and (max-width:1023px){
			width: 257px;
			height: 117px;
		}
		@media only screen and (max-width:766px){
			width: 132px;
			height: 60px;
		}

		a{
			display: block;
			mix-blend-mode:multiply;
			width: 440px;
			height: 118px;
			background: url(../images/common/logo.svg) no-repeat,
			url(../images/common/logo_ill.png) no-repeat right bottom;
			background-size: 257px 117px,171px 86px;
			@media only screen and (min-width:767px) and (max-width:1023px){
				width: 257px;
				height: 117px;
				background: url(../images/common/logo.svg) no-repeat;
				background-size: 257px auto;
			}
			@media only screen and (max-width:766px){
				width: 132px;
				height: 60px;
				background: url(../images/common/logo.svg) no-repeat;
				background-size: 132px auto;
			}
		}
	}


	.sns{
		li{
			a{
				display: block;
			}
		}
	}

	#header_sns{
		position: absolute;
		right: 50px;
		top: 60px;
		@media only screen and (max-width:1023px){
			display: none;
		}
		li{
			a{
				display: block;
				background: #000;
				width: 50px;
				height: 50px;
				color: #fff;
				border-radius: 50px;
				text-align: center;
				line-height: 0;
				padding-top: 12px;
				@include font-size(28);
			}
		}
	}

	nav{
		@media only screen and (max-width:1023px){
			display: none;
			background: rgba(72,77,79,0.9);
			width: 50%;
			position: fixed;
			right: 0;
			top:0;
			height: 100%;
			z-index: 200;
		}
		div#nav_inner{
			@media only screen and (max-width:766px){
			overflow: auto;
			height: 100%;
			width: 100%;
			-webkit-overflow-scrolling: touch;
			}
			#header_menu{
				text-align: center;
				font-size: 0;
				padding-top: 330px;
				@media only screen and (max-width:1023px){
					padding: 80px 20px 0 20px;
				}
				li{
					display: inline-block;
					padding: 0 15px;
					@media only screen and (min-width:1024px) and (max-width:1199px){
						padding: 0 5px;
					}
					@media only screen and (max-width:1023px){
						padding: 0;
						display: block;
						text-align: left;
						margin-bottom: 8px;
					}
					a{
						display: block;
						width: 152px;
						height: 60px;
						text-indent: -99999px;
						position: relative;
						@media only screen and (max-width:1023px){
							width: auto !important;
							height: auto !important;
							background: none !important;
							text-indent: 0 !important;
							color: #fff !important;
							@include font-size(14);
							font-weight: bold;
						}
						&:before{
							content: '';
							display: block;
							position: absolute;
							opacity: 0;
							width: 129px;
							height: 129px;
							top:-125px;
							left: 15px;
							@media only screen and (max-width:1023px){
								display: none !important;
							}
						}
						&:hover{
							opacity: 1;
							&:before{
								opacity: 1;
								mix-blend-mode:multiply;
							}
						}
						&.now{
							&:before{
								opacity: 1;
								mix-blend-mode:multiply;
							}
						}
					}
					&.nav_sm{
						display: none ;
						@media only screen and (max-width:1023px){
							display: block;
						}
					}
					&#menu_inn{
						a{
							background: url(../images/common/menu001.png) no-repeat;
							background-size: 152px auto;
							&:before{
								background: url(../images/common/menu001_ill.png) no-repeat;
								background-size: 129px auto;
							}
							&:hover,&.now{
								background: url(../images/common/menu001_ov.png) no-repeat;
								background-size: 152px auto;
							}

						}
					}
					&#menu_root{
						a{
							background: url(../images/common/menu002.png) no-repeat;
							background-size: 152px auto;
							&:before{
								background: url(../images/common/menu002_ill.png) no-repeat;
								background-size: 129px auto;
							}
							&:hover,&.now{
								background: url(../images/common/menu002_ov.png) no-repeat;
								background-size: 152px auto;
							}
						}
					}
					&#menu_current{
						a{
							background: url(../images/common/menu003.png) no-repeat;
							background-size: 152px auto;
							&:before{
								background: url(../images/common/menu003_ill.png) no-repeat;
								background-size: 129px auto;
							}
							&:hover,&.now{
								background: url(../images/common/menu003_ov.png) no-repeat;
								background-size: 152px auto;
							}
						}
					}

					&#menu_ac{
						a{
							background: url(../images/common/menu004.png) no-repeat;
							background-size: 152px auto;
							&:before{
								background: url(../images/common/menu004_ill.png) no-repeat;
								background-size: 129px auto;
							}
							&:hover,&.now{
								background: url(../images/common/menu004_ov.png) no-repeat;
								background-size: 152px auto;
							}
						}
					}
					&#menu_school{
						a{
							background: url(../images/common/menu005.png) no-repeat;
							background-size: 152px auto;
							&:before{
								background: url(../images/common/menu006_ill.png) no-repeat;
								background-size: 129px auto;
							}
							&:hover,&.now{
								background: url(../images/common/menu005_ov.png) no-repeat;
								background-size: 152px auto;
							}
						}
					}
					&#menu_goods{
						a{
							background: url(../images/common/menu006.png) no-repeat;
							background-size: 152px auto;
							&:before{
								background: url(../images/common/menu005_ill.png) no-repeat;
								background-size: 129px auto;
							}
							&:hover,&.now{
								background: url(../images/common/menu006_ov.png) no-repeat;
								background-size: 152px auto;
							}
						}
					}
				}
			}
			#header_sns-menu{
				display: none;
				@media only screen and (max-width:1023px){
					display: block;
					padding-left: 20px;
					margin-top: 20px;
					background: url(../images/common/logo_ill-wh.png) no-repeat left 70px top;
					background-size: 89px auto;
					min-height: 90px;
					li{
						a{
							display: block;
							width: 35px;
							height: 35px;
							border-radius: 35px;
							border: 1px solid #fff;
							color: #fff;
							text-align: center;
							line-height: 1em;
							padding-top: 6px;
							@include font-size(20);
						}
					}
				}
			}

		}
	}

	#sm_menu_bt{
		position: fixed;
		z-index: 300;
		top:50px;
		right: 30px;
		width: 40px;
		height: 20px;
		display: none;
		@media only screen and (max-width:1023px){
			display: block;
		}
		@media only screen and (max-width:766px){
			right: 20px;
			top:30px;
		}
		.menu-trigger,.menu-trigger span {
		  display: inline-block;
		  transition: all .4s;
		  box-sizing: border-box;
		}
		.menu-trigger {
		  position: relative;
		  width: 40px;
		  height: 20px;
		  display: block;
		  span {
			  position: absolute;
			  right: 0;
			  height: 1px;
			  background-color: $text-c;
			   width: 100%;
			  &:nth-of-type(1) {
				  top: 0;
				  width: 100%;
				}
			  &:nth-of-type(2) {
				  top: 9px;

				}
				&:nth-of-type(3) {
				  top: 19px;
				}
			}
			&:hover{
				cursor: pointer;
			}	
		}
		.menu-trigger.active span{
			background: #fff;

		}
		.menu-trigger.active span:nth-of-type(1) {
		  -webkit-transform: translateY(10px) translateX(0px) rotate(-45deg);
		  transform: translateY(10px) translateX(0px) rotate(-45deg);
		}

		.menu-trigger.active span:nth-of-type(2) {
		 opacity: 0;
		}

		.menu-trigger.active span:nth-of-type(3) {
		 -webkit-transform: translateY(-9px) translateX(0px) rotate(45deg);
		  transform: translateY(-9px) translateX(0px) rotate(45deg);
		}
	}
}
*/
/* 新レイアウト */
header {
  position: relative;
  padding: 0 0 65px 0;
  height: 220px;
}
@media only screen and (min-width:767px) and (max-width:1339px) {
  header {
    padding: 30px 0 65px 0;
    height: auto;
  }
}
@media only screen and (max-width:766px) {
  header {
    padding: 40px 0 35px 0;
    height: auto;
  }
}
header .logo {
  width: 214px;
  height: 98px;
  position: absolute;
  top: 60px;
  left: 100px;
}
@media only screen and (max-width:1339px) {
  header .logo {
    position: inherit;
    top: auto;
    left: auto;
    margin: 0 auto;
  }
}
@media only screen and (min-width:767px) and (max-width:1339px) {
  header .logo {
    width: 257px;
    height: 117px;
  }
}
@media only screen and (max-width:766px) {
  header .logo {
    width: 132px;
    height: 60px;
  }
}
header .logo a {
  display: block;
  mix-blend-mode: multiply;
  width: 214px;
  height: 98px;
  background: url(../images/common/logo.svg) no-repeat;
  background-size: 214px auto;
}
@media only screen and (min-width:767px) and (max-width:1339px) {
  header .logo a {
    width: 257px;
    height: 117px;
    background: url(../images/common/logo.svg) no-repeat;
    background-size: 257px auto;
  }
}
@media only screen and (max-width:766px) {
  header .logo a {
    width: 132px;
    height: 60px;
    background: url(../images/common/logo.svg) no-repeat;
    background-size: 132px auto;
  }
}
header .sns li a {
  display: block;
}
header #header_sns {
  position: absolute;
  right: 50px;
  top: 110px;
}
@media only screen and (max-width:1339px) {
  header #header_sns {
    display: none;
  }
}
header #header_sns li a {
  display: block;
  background: #000;
  width: 50px;
  height: 50px;
  color: #fff;
  border-radius: 50px;
  text-align: center;
  line-height: 0;
  padding-top: 12px;
  font-size: 28px;
  font-size: 1.75rem;
}
@media only screen and (max-width:1339px) {
  header nav {
    display: none;
    background: rgba(72, 77, 79, 0.9);
    width: 50%;
    position: fixed;
    right: 0;
    top: 0;
    height: 100%;
    z-index: 200;
  }
}
@media only screen and (max-width:766px) {
  header nav div#nav_inner {
    overflow: auto;
    height: 100%;
    width: 100%;
    -webkit-overflow-scrolling: touch;
  }
}
header nav div#nav_inner #header_menu {
  text-align: left;
  font-size: 0;
  padding-top: 113px;
  padding-left: 370px;
}
@media only screen and (max-width:1339px) {
  header nav div#nav_inner #header_menu {
    padding: 80px 20px 0 20px;
  }
}
header nav div#nav_inner #header_menu li {
  display: inline-block;
  padding: 0 12px;
}
@media only screen and (min-width:1024px) and (max-width:1199px) {
  header nav div#nav_inner #header_menu li {
    padding: 0 5px;
  }
}
@media only screen and (max-width:1339px) {
  header nav div#nav_inner #header_menu li {
    padding: 0;
    display: block;
    text-align: left;
    margin-bottom: 8px;
  }
}
header nav div#nav_inner #header_menu li a {
  display: block;
  width: 118px;
  height: 46px;
  text-indent: -99999px;
  position: relative;
}
@media only screen and (max-width:1339px) {
  header nav div#nav_inner #header_menu li a {
    width: auto !important;
    height: auto !important;
    background: none !important;
    text-indent: 0 !important;
    color: #fff !important;
    font-size: 14px;
    font-size: 0.875rem;
    font-weight: bold;
  }
}
header nav div#nav_inner #header_menu li a:before {
  content: "";
  display: block;
  position: absolute;
  opacity: 0;
  width: 110px;
  height: 110px;
  top: -95px;
  left: 15px;
}
@media only screen and (max-width:1339px) {
  header nav div#nav_inner #header_menu li a:before {
    display: none !important;
  }
}
header nav div#nav_inner #header_menu li a:hover {
  opacity: 1;
}
header nav div#nav_inner #header_menu li a:hover:before {
  opacity: 1;
  mix-blend-mode: multiply;
}
header nav div#nav_inner #header_menu li a.now:before {
  opacity: 1;
  mix-blend-mode: multiply;
}
header nav div#nav_inner #header_menu li.nav_sm {
  display: none;
}
@media only screen and (max-width:1339px) {
  header nav div#nav_inner #header_menu li.nav_sm {
    display: block;
  }
}
header nav div#nav_inner #header_menu li#menu_inn a {
  background: url(../images/common/menu001.png) no-repeat;
  background-size: 118px auto;
}
header nav div#nav_inner #header_menu li#menu_inn a:before {
  background: url(../images/common/menu001_ill.png) no-repeat;
  background-size: 90px auto;
}
header nav div#nav_inner #header_menu li#menu_inn a:hover, header nav div#nav_inner #header_menu li#menu_inn a.now {
  background: url(../images/common/menu001_ov.png) no-repeat;
  background-size: 118px auto;
}
header nav div#nav_inner #header_menu li#menu_root a {
  background: url(../images/common/menu002.png) no-repeat;
  background-size: 118px auto;
}
header nav div#nav_inner #header_menu li#menu_root a:before {
  background: url(../images/common/menu002_ill.png) no-repeat;
  background-size: 90px auto;
}
header nav div#nav_inner #header_menu li#menu_root a:hover, header nav div#nav_inner #header_menu li#menu_root a.now {
  background: url(../images/common/menu002_ov.png) no-repeat;
  background-size: 118px auto;
}
header nav div#nav_inner #header_menu li#menu_current a {
  background: url(../images/common/menu003.png) no-repeat;
  background-size: 118px auto;
}
header nav div#nav_inner #header_menu li#menu_current a:before {
  background: url(../images/common/menu003_ill.png) no-repeat;
  background-size: 90px auto;
}
header nav div#nav_inner #header_menu li#menu_current a:hover, header nav div#nav_inner #header_menu li#menu_current a.now {
  background: url(../images/common/menu003_ov.png) no-repeat;
  background-size: 118px auto;
}
header nav div#nav_inner #header_menu li#menu_ac a {
  background: url(../images/common/menu004.png) no-repeat;
  background-size: 118px auto;
}
header nav div#nav_inner #header_menu li#menu_ac a:before {
  background: url(../images/common/menu004_ill.png) no-repeat;
  background-size: 90px auto;
}
header nav div#nav_inner #header_menu li#menu_ac a:hover, header nav div#nav_inner #header_menu li#menu_ac a.now {
  background: url(../images/common/menu004_ov.png) no-repeat;
  background-size: 118px auto;
}
header nav div#nav_inner #header_menu li#menu_school a {
  background: url(../images/common/menu005.png) no-repeat;
  background-size: 118px auto;
}
header nav div#nav_inner #header_menu li#menu_school a:before {
  background: url(../images/common/menu006_ill.png) no-repeat;
  background-size: 90px auto;
}
header nav div#nav_inner #header_menu li#menu_school a:hover, header nav div#nav_inner #header_menu li#menu_school a.now {
  background: url(../images/common/menu005_ov.png) no-repeat;
  background-size: 118px auto;
}
header nav div#nav_inner #header_menu li#menu_goods a {
  background: url(../images/common/menu006.png) no-repeat;
  background-size: 118px auto;
}
header nav div#nav_inner #header_menu li#menu_goods a:before {
  background: url(../images/common/menu005_ill.png) no-repeat;
  background-size: 90px auto;
}
header nav div#nav_inner #header_menu li#menu_goods a:hover, header nav div#nav_inner #header_menu li#menu_goods a.now {
  background: url(../images/common/menu006_ov.png) no-repeat;
  background-size: 118px auto;
}
header nav div#nav_inner #header_sns-menu {
  display: none;
}
@media only screen and (max-width:1339px) {
  header nav div#nav_inner #header_sns-menu {
    display: block;
    padding-left: 20px;
    margin-top: 20px;
    background: url(../images/common/logo_ill-wh.png) no-repeat left 70px top;
    background-size: 89px auto;
    min-height: 90px;
  }
  header nav div#nav_inner #header_sns-menu li a {
    display: block;
    width: 35px;
    height: 35px;
    border-radius: 35px;
    border: 1px solid #fff;
    color: #fff;
    text-align: center;
    line-height: 1em;
    padding-top: 6px;
    font-size: 20px;
    font-size: 1.25rem;
  }
}
header #sm_menu_bt {
  position: fixed;
  z-index: 300;
  top: 50px;
  right: 30px;
  width: 40px;
  height: 20px;
  display: none;
}
@media only screen and (max-width:1339px) {
  header #sm_menu_bt {
    display: block;
  }
}
@media only screen and (max-width:766px) {
  header #sm_menu_bt {
    right: 20px;
    top: 30px;
  }
}
header #sm_menu_bt .menu-trigger, header #sm_menu_bt .menu-trigger span {
  display: inline-block;
  transition: all 0.4s;
  box-sizing: border-box;
}
header #sm_menu_bt .menu-trigger {
  position: relative;
  width: 40px;
  height: 20px;
  display: block;
}
header #sm_menu_bt .menu-trigger span {
  position: absolute;
  right: 0;
  height: 1px;
  background-color: #000;
  width: 100%;
}
header #sm_menu_bt .menu-trigger span:nth-of-type(1) {
  top: 0;
  width: 100%;
}
header #sm_menu_bt .menu-trigger span:nth-of-type(2) {
  top: 9px;
}
header #sm_menu_bt .menu-trigger span:nth-of-type(3) {
  top: 19px;
}
header #sm_menu_bt .menu-trigger:hover {
  cursor: pointer;
}
header #sm_menu_bt .menu-trigger.active span {
  background: #fff;
}
header #sm_menu_bt .menu-trigger.active span:nth-of-type(1) {
  transform: translateY(10px) translateX(0px) rotate(-45deg);
}
header #sm_menu_bt .menu-trigger.active span:nth-of-type(2) {
  opacity: 0;
}
header #sm_menu_bt .menu-trigger.active span:nth-of-type(3) {
  transform: translateY(-9px) translateX(0px) rotate(45deg);
}

.inn_bt_wrapper {
  position: fixed;
  left: 0;
  bottom: 50px;
  width: 180px;
  height: 360px;
  z-index: 50;
  overflow: hidden;
  background: url(../images/common/bt_shukuhaku_back.png) no-repeat;
  background-size: 180px auto;
  transition: 0.6s opacity;
}
@media only screen and (max-width:1199px) {
  .inn_bt_wrapper {
    width: 103px;
    height: 207px;
    background: url(../images/common/bt_shukuhaku_back.png) no-repeat;
    background-size: 103px auto;
  }
}
.inn_bt_wrapper:hover {
  opacity: 0.6;
  cursor: pointer;
}
@media only screen and (max-width:766px) {
  .inn_bt_wrapper:hover {
    opacity: 1;
    cursor: inherit;
  }
}
.inn_bt_wrapper .pc_bt {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 180px;
  height: 360px;
  z-index: 50;
}
@media only screen and (max-width:766px) {
  .inn_bt_wrapper .pc_bt {
    display: none;
  }
}
.inn_bt_wrapper .pc_bt:hover {
  opacity: 0.6;
}
.inn_bt_wrapper .pc_bt a {
  display: inline;
}
.inn_bt_wrapper .inn_bt_cont {
  display: none;
  position: relative;
}
@media only screen and (max-width:766px) {
  .inn_bt_wrapper .inn_bt_cont {
    display: block;
  }
}
.inn_bt_wrapper .inn_bt_cont div {
  position: absolute;
}
.inn_bt_wrapper .inn_bt_cont div a {
  display: block;
  text-indent: -99999px;
}
.inn_bt_wrapper .inn_bt_cont .inn_bt {
  top: 45px;
  left: 5px;
}
.inn_bt_wrapper .inn_bt_cont .inn_bt a {
  width: 80px;
  height: 40px;
}
.inn_bt_wrapper .inn_bt_cont .tel_bt {
  top: 85px;
  left: 5px;
}
.inn_bt_wrapper .inn_bt_cont .tel_bt a {
  width: 80px;
  height: 75px;
}

/* FOOTER
-------------------------------------------------------------- */
footer {
  padding-bottom: 95px;
}
@media only screen and (max-width:766px) {
  footer {
    padding-bottom: 20px;
  }
}
footer #footer_inner {
  text-align: center;
  position: relative;
}
footer #footer_inner #to_top {
  position: absolute;
  width: 122px;
  height: 192px;
  bottom: 110px;
  right: 80px;
}
@media only screen and (max-width:766px) {
  footer #footer_inner #to_top {
    width: 75px;
    height: 118px;
    bottom: 40px;
    right: 25px;
  }
}
footer #footer_inner #to_top a {
  display: block;
  width: 122px;
  height: 192px;
  background: url(../images/common/footer_ill002.png) no-repeat;
  background-size: 122px auto;
  text-indent: -99999px;
}
@media only screen and (max-width:766px) {
  footer #footer_inner #to_top a {
    width: 75px;
    height: 118px;
    background: url(../images/common/footer_ill002.png) no-repeat;
    background-size: 75px auto;
  }
}
footer #footer_inner #footer_facebook {
  margin-bottom: 100px;
  height: 480px;
}
footer #footer_inner #footer_banner {
  max-width: 350px;
  padding: 30px 0;
  margin: 0 auto 40px auto;
  border-top: 1px solid #000;
  border-bottom: 1px solid #000;
  font-size: 17px;
  font-size: 1.0625rem;
}
@media only screen and (max-width:766px) {
  footer #footer_inner #footer_banner {
    font-size: 14px;
    font-size: 0.875rem;
    max-width: 300px;
  }
}
footer #footer_inner #footer_banner li {
  text-align: center;
  margin-bottom: 40px;
}
footer #footer_inner #footer_banner li:last-child {
  margin-bottom: 0;
}
footer #footer_inner #footer_banner li p {
  margin-bottom: 0.1em;
}
footer #footer_inner #footer_banner li p:last-child {
  margin-bottom: 0;
}
footer #footer_inner #footer_banner li p a {
  text-decoration: underline;
}
footer #footer_inner #footer_address li {
  margin-bottom: 1em;
  font-size: 17px;
  font-size: 1.0625rem;
  line-height: 1.8em;
}
@media only screen and (max-width:766px) {
  footer #footer_inner #footer_address li {
    font-size: 14px;
    font-size: 0.875rem;
  }
}
footer #footer_inner #footer_address li.link {
  font-size: 14px;
  font-size: 0.875rem;
}
@media only screen and (max-width:766px) {
  footer #footer_inner #footer_address li.link {
    font-size: 11px;
    font-size: 0.6875rem;
  }
}
footer #footer_inner #footer_address li.sns {
  display: none;
}
@media only screen and (max-width:766px) {
  footer #footer_inner #footer_address li.sns {
    display: block;
    text-align: center;
    margin-bottom: 40px;
    margin-top: 30px;
  }
  footer #footer_inner #footer_address li.sns a {
    display: inline-block;
    width: 45px;
    height: 45px;
    background: #000;
    color: #fff;
    border-radius: 45px;
    font-size: 25px;
    font-size: 1.5625rem;
    padding-top: 10px;
  }
}
footer #footer_inner #footer_address li.copy {
  padding-top: 2em;
  font-size: 14px;
  font-size: 0.875rem;
  line-height: 2em;
}
@media only screen and (max-width:766px) {
  footer #footer_inner #footer_address li.copy {
    font-size: 11px;
    font-size: 0.6875rem;
  }
}
footer #footer_inner #footer_copy {
  font-size: 12px;
  font-size: 0.75rem;
}

/* MAIN
-------------------------------------------------------------- */
/* common */
main {
  display: block;
}

.wp-pagenavi {
  text-align: center;
  padding-top: 80px;
}
.wp-pagenavi a, .wp-pagenavi span {
  font-size: 14px;
  font-size: 0.875rem;
  margin: 0 5px;
  font-weight: bold;
  padding: 0 2px 8px 2px;
}
.wp-pagenavi span.current {
  position: relative;
  border-bottom: 1px solid #000;
}

.logo a {
  text-indent: -99999px;
  display: block;
}

.w1045 {
  max-width: 1045px;
  margin: 0 auto;
}

.w800 {
  max-width: 860px;
  margin: 0 auto;
  padding: 0 30px;
  box-sizing: border-box;
}

.w915 {
  max-width: 915px;
  margin: 0 auto;
  position: relative;
}

.ttl001 {
  position: absolute;
  top: 0;
  left: -105px;
}
@media only screen and (max-width:1023px) {
  .ttl001 {
    position: inherit;
    top: auto;
    left: auto;
    text-align: center;
    margin-bottom: 1em;
  }
}
.ttl001 img {
  max-width: 67px;
}
@media only screen and (max-width:1023px) {
  .ttl001 img {
    max-width: 116px;
  }
}

.page_ttl001 {
  display: none;
  text-align: center;
  margin-bottom: 10px;
}
@media only screen and (max-width:766px) {
  .page_ttl001 {
    display: block;
  }
}
.page_ttl001 img {
  display: block;
  margin: 0 auto;
}
.page_ttl001 img.page_ttl_text {
  width: 115px;
}
.page_ttl001 img.page_ttl_ill {
  width: 129px;
}

.page_ttl002 {
  font-size: 36px;
  font-size: 2.25rem;
  text-align: center;
  font-weight: bold;
}
@media only screen and (max-width:766px) {
  .page_ttl002 {
    font-size: 16px;
    font-size: 1rem;
    position: relative;
  }
  .page_ttl002 span {
    display: inline-block;
    padding: 5px 20px;
    background: #fff;
  }
  .page_ttl002:before {
    display: block;
    content: "";
    border-top: 1px solid #000;
    width: 100%;
    position: absolute;
    top: 48%;
    left: 0;
    z-index: -1;
  }
}

.point {
  color: #d87600;
  font-weight: bold;
}

/* TOP
-------------------------------------------------------------- */
#sec_index001 {
  text-align: right;
  padding-bottom: 230px;
  background: url(../images/top/top_ill002.jpg) no-repeat center bottom;
  background-size: 100% auto;
}
@media only screen and (max-width:766px) {
  #sec_index001 {
    padding-bottom: 70px;
  }
}
#sec_index001 img#sec_index001-img {
  margin-bottom: 130px;
  max-width: 85%;
}
@media only screen and (max-width:766px) {
  #sec_index001 img#sec_index001-img {
    margin-bottom: 20px;
    max-width: 90%;
  }
}
#sec_index001 img#sec_index001-text {
  mix-blend-mode: multiply;
  width: 318px;
  height: auto;
  margin-right: 13%;
}
@media only screen and (max-width:766px) {
  #sec_index001 img#sec_index001-text {
    width: 135px;
    margin-right: 20px;
  }
}

#sec_index002 {
  background: url(../images/top/top_ill003.jpg) no-repeat center bottom;
  background-size: 100% auto;
  padding-bottom: 500px;
}
@media only screen and (max-width:766px) {
  #sec_index002 {
    padding-bottom: 200px;
    margin-bottom: 40px;
  }
}
#sec_index002 #sec_index002-img_wrap {
  width: 100%;
  overflow: hidden;
  position: relative;
  margin-bottom: 140px;
}
@media only screen and (max-width:766px) {
  #sec_index002 #sec_index002-img_wrap {
    margin-bottom: 0;
  }
}
#sec_index002 #sec_index002-img_wrap:before {
  content: "";
  display: block;
  position: absolute;
  right: 15px;
  top: 50%;
  opacity: 0.85;
  margin-top: -37px;
  width: 38px;
  height: 74px;
  background: url(../images/common/arrow_r.png) no-repeat;
  background-size: 38px auto;
  z-index: 10;
}
@media only screen and (max-width:766px) {
  #sec_index002 #sec_index002-img_wrap:before {
    margin-top: -17px;
    width: 19px;
    height: 37px;
    background: url(../images/common/arrow_r.png) no-repeat;
    background-size: 19px auto;
  }
}
#sec_index002 #sec_index002-img_wrap #sec_index002-img {
  display: flex;
  margin: 0 -4px;
  overflow: auto;
}
@media only screen and (max-width:766px) {
  #sec_index002 #sec_index002-img_wrap #sec_index002-img {
    margin-bottom: 0;
    margin: 0;
  }
}
#sec_index002 #sec_index002-img_wrap #sec_index002-img li {
  padding: 0 4px;
  flex: 0 0 480px;
}
@media only screen and (max-width:766px) {
  #sec_index002 #sec_index002-img_wrap #sec_index002-img li {
    padding: 0 4px 0 0;
    flex: 0 0 225px;
  }
  #sec_index002 #sec_index002-img_wrap #sec_index002-img li:last-child {
    padding: 0;
  }
}
#sec_index002 #sec_index002-text {
  text-align: center;
}
@media only screen and (max-width:766px) {
  #sec_index002 #sec_index002-text {
    margin-top: 40px;
  }
}
#sec_index002 #sec_index002-text img {
  max-width: 816px;
  width: 100%;
}
@media only screen and (min-width:767px) and (max-width:1023px) {
  #sec_index002 #sec_index002-text img {
    width: 70%;
  }
}
@media only screen and (max-width:766px) {
  #sec_index002 #sec_index002-text img {
    max-width: 260px;
  }
}

#sec_index003 {
  margin-bottom: 80px;
}
@media only screen and (max-width:766px) {
  #sec_index003 {
    margin-bottom: 60px;
  }
}
#sec_index003 img {
  max-width: 87%;
}

/* INN
-------------------------------------------------------------- */
#inn001 {
  padding: 0 30px;
}
#inn001 #inn_request {
  border: 2px solid #000;
  padding: 60px 100px;
  margin-bottom: 65px;
}
@media only screen and (min-width:767px) and (max-width:1023px) {
  #inn001 #inn_request {
    padding: 40px;
  }
}
@media only screen and (max-width:766px) {
  #inn001 #inn_request {
    padding: 35px 25px;
    margin-bottom: 30px;
  }
}
#inn001 #inn_request h2 {
  font-size: 21px;
  font-size: 1.3125rem;
  margin-bottom: 1em;
  font-weight: bold;
}
@media only screen and (max-width:766px) {
  #inn001 #inn_request h2 {
    font-size: 16px;
    font-size: 1rem;
    text-align: center;
  }
}
#inn001 #inn_request p {
  font-size: 20px;
  font-size: 1.25rem;
  margin-bottom: 1em;
  line-height: 1.3em;
}
@media only screen and (max-width:766px) {
  #inn001 #inn_request p {
    font-size: 14px;
    font-size: 0.875rem;
    line-height: 1.8em;
  }
}
#inn001 #inn_request p:last-child {
  margin-bottom: 0;
}
#inn001 #inn_request p a {
  color: #005cb9;
}
#inn001 #inn_info {
  background: #297037;
  color: #fff;
  font-size: 36px;
  font-size: 2.25rem;
  text-align: center;
  padding: 40px 30px;
  line-height: 1.5em;
  margin-bottom: 100px;
}
@media only screen and (max-width:766px) {
  #inn001 #inn_info {
    font-size: 16px;
    font-size: 1rem;
    padding: 15px;
    font-weight: bold;
    margin-bottom: 45px;
  }
}
/*
#inn001 #inn_detail {
  background: url(../images/inn/inn_ill002.jpg) no-repeat right 0px top 1950px;
  	background-size: 662px auto;
}
*/
@media only screen and (max-width:1023px) {
  #inn001 #inn_detail {
    background: none;
  }
}
#inn001 #inn_detail #inn_detail-img001 {
  margin-bottom: 70px;
}
@media only screen and (max-width:766px) {
  #inn001 #inn_detail #inn_detail-img001 {
    display: none;
  }
}
#inn001 #inn_detail section {
  margin-bottom: 60px;
  line-height: 1.4em;
}
#inn001 #inn_detail section#baiten {
  zoom: 1;
}
#inn001 #inn_detail section#baiten:before, #inn001 #inn_detail section#baiten:after {
  content: "";
  display: table;
}
#inn001 #inn_detail section#baiten:after {
  clear: both;
}
#inn001 #inn_detail section#baiten p {
  z-index: 10;
  position: relative;
}
#inn001 #inn_detail section#baiten #baiten_img {
  width: 662px;
  height: 441px;
  position: absolute;
  top: -60px;
  right: -230px;
  z-index: 0;
}
@media only screen and (max-width:1023px) {
  #inn001 #inn_detail section#baiten #baiten_img {
    position: inherit;
    top: auto;
    right: auto;
    zoom: 1;
    width: auto;
    height: auto;
  }
  #inn001 #inn_detail section#baiten #baiten_img:before, #inn001 #inn_detail section#baiten #baiten_img:after {
    content: "";
    display: table;
  }
  #inn001 #inn_detail section#baiten #baiten_img:after {
    clear: both;
  }
  #inn001 #inn_detail section#baiten #baiten_img img {
    width: 90%;
    float: right;
    margin-right: -20px;
  }
}
@media only screen and (max-width:766px) {
  #inn001 #inn_detail section {
    margin-bottom: 65px;
  }
}
#inn001 #inn_detail section:last-of-type {
  margin-bottom: 0;
}
#inn001 #inn_detail section h3 {
  font-size: 26px;
  font-size: 1.625rem;
  font-weight: bold;
  letter-spacing: 3px;
  color: #297037;
  margin-bottom: 0.5em;
}
@media only screen and (max-width:766px) {
  #inn001 #inn_detail section h3 {
    text-align: center;
    font-size: 16px;
    font-size: 1rem;
  }
}
#inn001 #inn_detail section p {
  margin-bottom: 1.5em;
}
#inn001 #inn_detail section p:last-child {
  margin-bottom: 0;
}
#inn001 #inn_detail section #price_list {
  display: flex;
  flex-wrap: wrap;
  border-top: 2px solid #000;
  border-left: 2px solid #000;
  margin-bottom: 1em;
}
@media only screen and (max-width:766px) {
  #inn001 #inn_detail section #price_list {
    display: block;
    border-top: 1px solid #000;
    border-left: 1px solid #000;
  }
}
#inn001 #inn_detail section #price_list li {
  width: 50%;
}
@media only screen and (max-width:766px) {
  #inn001 #inn_detail section #price_list li {
    width: 100%;
  }
}
#inn001 #inn_detail section #price_list li table {
  width: 100%;
}
#inn001 #inn_detail section #price_list li table th, #inn001 #inn_detail section #price_list li table td {
  padding: 20px 10px;
  width: 50%;
  border-bottom: 2px solid #000;
  font-size: 21px;
  font-size: 1.3125rem;
}
@media only screen and (max-width:766px) {
  #inn001 #inn_detail section #price_list li table th, #inn001 #inn_detail section #price_list li table td {
    border-bottom: 1px solid #000;
    font-size: 14px;
    font-size: 0.875rem;
    padding: 15px 10px;
  }
}
#inn001 #inn_detail section #price_list li table th {
  text-align: center;
  border-right: 1px solid #000;
}
#inn001 #inn_detail section #price_list li table td {
  text-align: right;
  border-right: 2px solid #000;
}
@media only screen and (max-width:766px) {
  #inn001 #inn_detail section #price_list li table td {
    border-right: 1px solid #000;
  }
}
#inn001 #inn_detail section .list001 {
  font-size: 20px;
  font-size: 1.25rem;
  margin-bottom: 60px;
}
@media only screen and (max-width:766px) {
  #inn001 #inn_detail section .list001 {
    margin-bottom: 30px;
  }
}
#inn001 #inn_detail section .table001 {
  width: 100%;
  background: url(../images/inn/inn_ill001.jpg) no-repeat right top;
  background-size: 300px;
}
@media only screen and (max-width:766px) {
  #inn001 #inn_detail section .table001 {
    background: none;
  }
}
#inn001 #inn_detail section .table001 th, #inn001 #inn_detail section .table001 td {
  text-align: left;
  vertical-align: top;
  line-height: 1.3em;
  padding-bottom: 15px;
}
@media only screen and (max-width:766px) {
  #inn001 #inn_detail section .table001 th, #inn001 #inn_detail section .table001 td {
    padding-bottom: 5px;
  }
}
#inn001 #inn_detail section .table001 th {
  color: #297037;
  white-space: nowrap;
  font-size: 20px;
  font-size: 1.25rem;
  font-weight: bold;
}
@media only screen and (max-width:766px) {
  #inn001 #inn_detail section .table001 th {
    font-size: 12px;
    font-size: 0.75rem;
  }
}
#inn001 #inn_detail section .table_dl {
  overflow: hidden;
}
#inn001 #inn_detail section .table_dl dt {
  float: left;
  color: #297037;
  font-size: 20px;
  font-size: 1.25rem;
  font-weight: bold;
}
@media only screen and (max-width:766px) {
  #inn001 #inn_detail section .table_dl dt {
    font-size: 12px;
    font-size: 0.75rem;
  }
}
#inn001 #inn_detail section .table_dl dd {
  margin-left: 10px;
  overflow: hidden;
  margin-bottom: 15px;
}
#inn001 .inn001_ill {
  max-width: 715px;
  width: 100%;
  margin-left: -40px;
}

#inn002 {
  padding: 0 30px;
  margin-bottom: 90px;
}
@media only screen and (max-width:766px) {
  #inn002 {
    margin-bottom: 50px;
  }
}
#inn002 .inn_detal-img {
  margin-bottom: 40px;
}
@media only screen and (max-width:766px) {
  #inn002 .inn_detal-img {
    margin-bottom: 30px;
  }
}
#inn002 #tent_price {
  color: #297037;
  font-weight: bold;
  margin-top: 1em;
  margin-bottom: 1em;
}
#inn002 #tent_price th {
  padding-right: 1em;
}
#inn002 #tent_caution {
  line-height: 1.3em;
}
#inn002 #tent_caution span {
  color: #d87600;
}

#inn003 {
  padding: 0 30px;
  margin-bottom: 90px;
}
#inn003 .list001 {
  margin-top: 1.5em;
}

#inn004 {
  border-top: 2px solid #000;
  border-bottom: 2px solid #000;
  padding: 50px 20px;
  text-align: center;
  margin-bottom: 145px;
}
#inn004 h2 {
  font-size: 26px;
  font-size: 1.625rem;
  margin-bottom: 1em;
}
@media only screen and (max-width:766px) {
  #inn004 {
    padding: 35px 20px;
  }
  #inn004 h2 {
    font-size: 16px;
    font-size: 1rem;
    margin-bottom: 1em;
    line-height: 1.8em;
  }
}

.inn_detal-img {
  display: flex;
  margin: 0 -29px;
  font-size: 0;
  line-height: 1em;
}
.inn_detal-img div {
  padding: 0 29px;
}
@media only screen and (max-width:766px) {
  .inn_detal-img {
    display: block;
    margin: 0;
  }
  .inn_detal-img div {
    padding: 0px;
    margin-bottom: 20px;
  }
  .inn_detal-img div:last-of-type {
    margin-bottom: 0;
  }
}

#meal {
  position: relative;
}

.google_calendar iframe {
  width: 100%;
}
@media only screen and (max-width:766px) {
  .google_calendar iframe {
    height: 600px;
  }
}

/* CURRENT
-------------------------------------------------------------- */
@media only screen and (max-width:1199px) {
  .sec_current {
    padding: 0 30px;
  }
}

#sec_current_ttl {
  margin-bottom: 170px;
  padding-top: 50px;
}
@media only screen and (max-width:766px) {
  #sec_current_ttl {
    padding-top: 0;
    margin-bottom: 40px;
    margin-top: 50px;
  }
}

.sm_hr {
  display: none;
}
@media only screen and (max-width:766px) {
  .sm_hr {
    display: block;
    margin: 40px 0;
  }
}

.kakko_common {
  background: url(../images/common/kakko_l.png) left top repeat-y, url(../images/common/kakko_r.png) right top repeat-y;
  background-size: 3px auto;
  position: relative;
}
.kakko_common:before, .kakko_common:after {
  content: "";
  display: block;
  width: 100%;
  position: absolute;
  left: 0;
}
.kakko_common:before {
  height: 12px;
  background: url(../images/common/kakko_tl.png) left top no-repeat, url(../images/common/kakko_tr.png) right top no-repeat;
  background-size: 31px auto;
  top: -12px;
}
.kakko_common:after {
  height: 13px;
  background: url(../images/common/kakko_bl.png) left top no-repeat, url(../images/common/kakko_br.png) right top no-repeat;
  background-size: 31px auto;
  bottom: -12px;
}

.kakko001 {
  min-height: 79px;
  width: 231px;
  font-size: 32px;
  font-size: 2rem;
  font-weight: bold;
  text-align: center;
  letter-spacing: 2px;
  padding-top: 20px;
}
@media only screen and (max-width:766px) {
  .kakko001 {
    min-height: 51px;
    font-size: 16px;
    font-size: 1rem;
    letter-spacing: 2px;
    padding-top: 16px;
    width: 114px;
  }
}

.kakko {
  font-size: 20px;
  font-size: 1.25rem;
  line-height: 1.3em;
  text-align: justify;
  text-justify: inter-ideograph;
  -ms-text-justify: inter-ideograph;
  font-weight: bold;
  padding: 5px 35px;
}
@media only screen and (max-width:766px) {
  .kakko {
    font-size: 12px;
    font-size: 0.75rem;
    padding: 5px 25px;
  }
}

.kakko002 {
  min-height: 134px;
  width: 288px;
}
@media only screen and (max-width:766px) {
  .kakko002 {
    min-height: 100px;
    width: 280px;
  }
}

.kakko003 {
  min-height: 187px;
  width: 535px;
}
@media only screen and (min-width:1024px) and (max-width:1199px) {
  .kakko003 {
    width: 400px;
  }
}
@media only screen and (max-width:766px) {
  .kakko003 {
    min-height: 98px;
    width: 280px;
  }
}

.course_img001 {
  max-width: 288px;
  margin: 0 auto 1em auto;
}
@media only screen and (max-width:766px) {
  .course_img001 {
    margin: 0 auto 2.5em auto;
    max-width: 230px;
  }
}

.flex_bottom {
  display: flex;
  align-items: flex-end;
}

.flex_top {
  display: flex;
}
@media only screen and (max-width:766px) {
  .flex_top {
    display: block;
  }
}

#current_001 {
  position: relative;
  margin-bottom: 75px;
  margin-top: 75px;
}
@media only screen and (max-width:766px) {
  #current_001 {
    margin-bottom: 0px;
  }
}
#current_001:before {
  position: absolute;
  left: 0;
  top: 0;
  content: "";
  display: block;
  width: 460px;
  background: #fff;
  height: 2px;
}
@media only screen and (max-width:766px) {
  #current_001:before {
    display: none;
  }
}
#current_001 #current_day {
  background: url(../images/current/current_day.png) no-repeat;
  background-size: 406px auto;
  width: 406px;
  height: 197px;
  font-size: 28px;
  font-size: 1.75rem;
  font-weight: bold;
  text-align: center;
  padding-top: 23px;
  letter-spacing: 2px;
  position: absolute;
  left: 0;
  top: -75px;
}
@media only screen and (min-width:1024px) and (max-width:1199px) {
  #current_001 #current_day {
    left: 30px;
  }
}
@media only screen and (min-width:767px) and (max-width:1023px) {
  #current_001 #current_day {
    left: 30px;
  }
}
@media only screen and (max-width:766px) {
  #current_001 #current_day {
    background: url(../images/current/current_day.png) no-repeat;
    background-size: 240px auto;
    width: 240px;
    height: 116px;
    font-size: 16px;
    font-size: 1rem;
    padding-top: 15px;
    margin: 0 auto;
    position: inherit;
    left: auto;
    top: auto;
  }
}
#current_001 .unit {
  font-size: 30px;
  font-size: 1.875rem;
  padding-left: 10px;
}
@media only screen and (max-width:766px) {
  #current_001 .unit {
    font-size: 16px;
    font-size: 1rem;
  }
}
#current_001 .time {
  font-size: 30px;
  font-size: 1.875rem;
  padding-right: 10px;
}
@media only screen and (max-width:766px) {
  #current_001 .time {
    font-size: 15px;
    font-size: 0.9375rem;
    padding-right: 5px;
  }
}
#current_001 #current_001_inner_wrap {
  border-top: 1px solid #000;
  border-bottom: 1px solid #000;
  padding: 50px 10px;
}
@media only screen and (max-width:766px) {
  #current_001 #current_001_inner_wrap {
    border-top: none;
    border-bottom: none;
    padding: 0;
    margin-top: -40px;
  }
}
#current_001 #current_001_inner {
  display: flex;
  background: url(../images/common/dotted_tate.png) repeat-y left 37% top;
  background-size: 4px auto;
}
@media only screen and (max-width:1023px) {
  #current_001 #current_001_inner {
    background: none;
    display: block;
  }
}
#current_001 #current_001_inner > div h5 {
  font-size: 23px;
  font-size: 1.4375rem;
  margin-bottom: 5px;
  font-weight: bold;
  margin-bottom: 15px;
}
@media only screen and (min-width:767px) and (max-width:1023px) {
  #current_001 #current_001_inner > div h5 {
    text-align: left;
  }
}
@media only screen and (max-width:766px) {
  #current_001 #current_001_inner > div h5 {
    text-align: left;
    font-size: 12px;
    font-size: 0.75rem;
  }
}
#current_001 #current_001_inner > div#current_001_inner001 {
  width: 37%;
  padding-left: 50px;
}
@media only screen and (max-width:1023px) {
  #current_001 #current_001_inner > div#current_001_inner001 {
    text-align: center;
    width: 100%;
    padding-left: 0;
  }
}
@media only screen and (min-width:767px) and (max-width:1023px) {
  #current_001 #current_001_inner > div#current_001_inner001 {
    margin-bottom: 100px;
  }
}
@media only screen and (max-width:766px) {
  #current_001 #current_001_inner > div#current_001_inner001 {
    margin-bottom: 60px;
  }
}
@media only screen and (max-width:1023px) {
  #current_001 #current_001_inner > div#current_001_inner001 ul {
    display: inline-block;
  }
}
@media only screen and (min-width:767px) and (max-width:1023px) {
  #current_001 #current_001_inner > div#current_001_inner001 ul {
    padding-left: 40px;
  }
}
@media only screen and (max-width:766px) {
  #current_001 #current_001_inner > div#current_001_inner001 ul {
    max-width: 170px;
    padding-left: 30px;
  }
}
#current_001 #current_001_inner > div#current_001_inner001 ul li {
  margin-bottom: 50px;
}
#current_001 #current_001_inner > div#current_001_inner001 ul li:last-child {
  margin-bottom: 0;
}
#current_001 #current_001_inner > div#current_001_inner002 {
  width: 63%;
  padding: 0 20px 0 60px;
}
@media only screen and (max-width:1023px) {
  #current_001 #current_001_inner > div#current_001_inner002 {
    width: 100%;
    text-align: center;
    padding: 0;
  }
}
#current_001 #current_001_inner > div#current_001_inner002 ul {
  display: inline-block;
}
#current_001 #current_001_inner > div#current_001_inner002 ul li:first-child {
  text-align: center;
  margin-bottom: 60px;
  text-align: center;
}
#current_001 #current_001_inner > div#current_001_inner002 ul li:first-child div#morgenro {
  display: inline-block;
}
#current_001 #current_001_inner > div#current_001_inner002 ul li:first-child div#morgenro h5 {
  text-align: left;
}
@media only screen and (max-width:766px) {
  #current_001 #current_001_inner > div#current_001_inner002 ul li:first-child div#morgenro {
    max-width: 180px;
  }
}
@media only screen and (min-width:1024px) and (max-width:1199px) {
  #current_001 #current_001_inner > div#current_001_inner002 ul li:last-child {
    text-align: center;
  }
}
@media only screen and (min-width:1024px) and (max-width:1199px) {
  #current_001 #current_001_inner > div#current_001_inner002 ul li:last-child .flex_top {
    display: block;
  }
}
#current_001 #current_001_inner > div#current_001_inner002 ul li:last-child .flex_top #morgenro_photo {
  max-width: 300px;
  padding-right: 30px;
  margin-top: -12px;
}
@media only screen and (min-width:1024px) and (max-width:1199px) {
  #current_001 #current_001_inner > div#current_001_inner002 ul li:last-child .flex_top #morgenro_photo {
    padding-right: 0;
    max-width: 288px;
    margin-bottom: 1em;
  }
}
@media only screen and (max-width:1023px) {
  #current_001 #current_001_inner > div#current_001_inner002 ul li:last-child .flex_top #morgenro_photo {
    padding-right: 30px;
  }
}
@media only screen and (max-width:766px) {
  #current_001 #current_001_inner > div#current_001_inner002 ul li:last-child .flex_top #morgenro_photo {
    max-width: 288px;
    padding-right: 0;
    margin: 0 auto 30px auto;
  }
}
@media only screen and (max-width:766px) {
  #current_001 #current_001_inner > div#current_001_inner002 ul li:last-child .flex_top #morgenro_text .kakko002 {
    margin: 0 auto;
  }
}

#current_002 {
  margin-bottom: 80px;
}
@media only screen and (max-width:766px) {
  #current_002 {
    margin-bottom: 0px;
  }
}
#current_002 #current_002_title {
  zoom: 1;
  margin-bottom: 50px;
}
#current_002 #current_002_title:before, #current_002 #current_002_title:after {
  content: "";
  display: table;
}
#current_002 #current_002_title:after {
  clear: both;
}
@media only screen and (max-width:766px) {
  #current_002 #current_002_title {
    margin-bottom: 20px;
  }
}
#current_002 #current_002_title img {
  max-width: 465px;
  float: left;
  margin-right: 30px;
}
@media only screen and (max-width:1023px) {
  #current_002 #current_002_title img {
    float: none;
    margin-right: 0;
    margin: 0 auto;
    display: block;
  }
}
@media only screen and (max-width:766px) {
  #current_002 #current_002_title img {
    max-width: 243px;
  }
}
#current_002 #current_002_title p {
  padding: 30px 0 0 0;
  font-size: 21px;
  font-size: 1.3125rem;
  font-weight: bold;
  line-height: 1.4em;
  overflow: hidden;
}
@media only screen and (max-width:1023px) {
  #current_002 #current_002_title p {
    text-align: center;
  }
}
@media only screen and (max-width:766px) {
  #current_002 #current_002_title p {
    font-size: 12px;
    font-size: 0.75rem;
  }
}
#current_002 #current_002_photo .current_002_day {
  text-align: right;
  font-size: 21px;
  font-size: 1.3125rem;
  padding-top: 5px;
}
@media only screen and (max-width:766px) {
  #current_002 #current_002_photo .current_002_day {
    font-size: 10px;
    font-size: 0.625rem;
  }
}

#current_003 {
  margin-bottom: 90px;
  /*
  #current_003_inner{
  		display: flex;
  		@media only screen and (max-width:766px){
  			display: block;
  		}
  		> div{
  			padding: 0 20px;
  			@media only screen and (min-width:767px) and (max-width:1023px){
  				width: 50%;
  				text-align: center;
  				padding: 0 10px;
  			}
  			@media only screen and (max-width:766px){
  				padding: 0;
  				margin-bottom: 40px;
  				&:last-of-type{
  					margin-bottom: 0;
  				}
  			}
  		}
  		h5{
  			text-align: center;
  			@include font-size(28);
  			font-weight: bold;
  			margin-bottom: 40px;
  			white-space: nowrap;
  			@media only screen and (max-width:766px){
  				@include font-size(15);
  				margin-bottom: 20px;
  			}
  		}
  		.kakko002{
  			margin: 0 auto;
  		}
  	}
  */
}
@media only screen and (max-width:1023px) {
  #current_003 {
    display: block;
  }
}

/*
@media only screen and (max-width:766px) {
  #current_003 {
    margin-bottom: 40px;
  }
}
*/

#current_003 #current_003_title {
  padding-right: 30px;
  margin-bottom: 40px;
}
@media only screen and (max-width:1023px) {
  #current_003 #current_003_title {
    padding-top: 0;
    padding-right: 0;
  }
}
@media only screen and (min-width:767px) and (max-width:1023px) {
  #current_003 #current_003_title {
    margin-bottom: 1em;
  }
}
@media only screen and (max-width:766px) {
  #current_003 #current_003_title {
    margin-bottom: 10px;
  }
}
#current_003 #current_003_title img {
  max-width: 315px;
}
@media only screen and (max-width:1023px) {
  #current_003 #current_003_title img {
    display: block;
    margin: 0 auto;
  }
}
@media only screen and (max-width:766px) {
  #current_003 #current_003_title img {
    max-width: 165px;
  }
}
#current_003 #current_003_001 {
  margin-bottom: 70px;
}
@media only screen and (max-width:766px) {
  #current_003 #current_003_001 {
    margin-bottom: 50px;
  }
}
#current_003 #current_003_001 h5 {
  top: 0px;
}
@media only screen and (max-width:1023px) {
  #current_003 #current_003_001 h5 {
    top: auto;
  }
}
#current_003 #current_003_002 h5 {
  top: 0px;
}
@media only screen and (max-width:1023px) {
  #current_003 #current_003_002 h5 {
    top: auto;
    margin-bottom: 1em;
  }
}
#current_003 #current_003_text001 {
  padding-top: 100px;
}
@media only screen and (max-width:1023px) {
  #current_003 #current_003_text001 {
    padding-top: 20px;
  }
}
#current_003 #current_003_text002 {
  padding-top: 170px;
}
@media only screen and (max-width:1023px) {
  #current_003 #current_003_text002 {
    padding-top: 20px;
  }
}

#current_004 {
  margin-bottom: 90px;
}
@media only screen and (max-width:766px) {
  #current_004 {
    margin-bottom: 40px;
  }
}
@media only screen and (min-width:1024px) and (max-width:1199px) {
  #current_004 #current_004_title {
    left: 30px;
  }
}

#current_005 {
  margin-bottom: 180px;
}
@media only screen and (max-width:766px) {
  #current_005 {
    margin-bottom: 60px;
  }
}
@media only screen and (min-width:1024px) and (max-width:1199px) {
  #current_005 #current_005_title {
    left: 30px;
  }
}

.current_common {
  display: flex;
  position: relative;
  flex-direction: row-reverse;
}
@media only screen and (max-width:1023px) {
  .current_common {
    display: block;
  }
}
.current_common h5 {
  font-size: 28px;
  font-size: 1.75rem;
  font-weight: bold;
  margin-bottom: 2em;
  position: absolute;
  left: 0;
  top: 0;
}
@media only screen and (max-width:1023px) {
  .current_common h5 {
    position: inherit;
    text-align: center;
  }
}
@media only screen and (max-width:766px) {
  .current_common h5 {
    font-size: 15px;
    font-size: 0.9375rem;
    margin-bottom: 1em;
  }
}
.current_common .current_common_title {
  position: absolute;
  left: 0;
  top: 0;
}
.current_common .current_common_title img {
  max-width: 465px;
}
@media only screen and (max-width:1023px) {
  .current_common .current_common_title {
    position: inherit;
    margin-bottom: 1em;
  }
  .current_common .current_common_title img {
    display: block;
    margin: 0 auto;
  }
}
@media only screen and (max-width:766px) {
  .current_common .current_common_title img {
    max-width: 243px;
  }
}
.current_common .current_common_text {
  padding-right: 80px;
}
@media only screen and (max-width:1023px) {
  .current_common .current_common_text {
    padding-top: 1em;
    padding-right: 0;
  }
  .current_common .current_common_text > div {
    margin: 0 auto;
  }
}
.current_common .current_common_text002 {
  padding-top: 150px;
}
@media only screen and (max-width:1023px) {
  .current_common .current_common_text002 {
    padding-top: 20px;
  }
}
.current_common .current_common_photo {
  text-align: center;
  min-width: 440px;
}
.current_common .current_common_photo img {
  max-height: 385px;
  width: auto;
}
@media only screen and (max-width:766px) {
  .current_common .current_common_photo {
    max-width: 230px;
    margin: 0 auto 20px auto;
    min-width: inherit;
  }
}

.current_ttl001 {
  text-align: center;
  font-size: 32px;
  font-size: 2rem;
  font-weight: bold;
  margin-bottom: 40px;
}
.current_ttl001 span {
  display: inline-block;
  background: #000;
  color: #fff;
  padding: 15px 25px;
}
@media only screen and (max-width:766px) {
  .current_ttl001 {
    font-size: 16px;
    font-size: 1rem;
    margin-bottom: 20px;
  }
  .current_ttl001 span {
    padding: 8px 20px 5px 20px;
  }
}

.current_ttl_cont {
  max-width: 1045px;
  margin: 0 auto;
}
.current_ttl_cont .current_ttl001 {
  text-align: left;
}
@media only screen and (max-width:1023px) {
  .current_ttl_cont .current_ttl001 {
    text-align: center;
  }
}

.current_text_sub {
  position: absolute;
  top: 50px;
  left: 0;
  max-width: 550px;
  line-height: 1.5em;
}
@media only screen and (min-width:1024px) and (max-width:1199px) {
  .current_text_sub {
    max-width: 400px;
  }
}
@media only screen and (max-width:1023px) {
  .current_text_sub {
    position: relative;
    top: auto;
    left: auto;
    max-width: 520px;
    margin: 0 auto 2em auto;
  }
}
@media only screen and (max-width:766px) {
  .current_text_sub {
    max-width: 230px;
  }
}
.current_text_sub p {
  margin-bottom: 1.5em;
  font-weight: bold;
}
.current_text_sub p:last-child {
  margin-bottom: 0;
}

/* ROOT */
#root_cont {
  padding-top: 60px;
}
@media only screen and (min-width:767px) and (max-width:1023px) {
  #root_cont {
    padding-top: 0;
  }
}
#root_cont #root001 {
  text-align: center;
  margin-bottom: 75px;
}
#root_cont #root001 h3 {
  font-size: 23px;
  font-size: 1.4375rem;
  font-weight: bold;
  text-align: left;
  margin-bottom: 1em;
}
@media only screen and (max-width:766px) {
  #root_cont #root001 h3 {
    font-size: 15px;
    font-size: 0.9375rem;
    text-align: center;
    margin-bottom: 2em;
  }
}
#root_cont #root001 img {
  max-width: 791px;
  width: 100%;
}
@media only screen and (max-width:766px) {
  #root_cont #root001 img {
    max-width: 198px;
  }
}
#root_cont #root003 {
  max-width: 730px;
  margin: 0 auto 100px auto;
  padding: 60px 40px;
}
@media only screen and (max-width:766px) {
  #root_cont #root003 {
    padding: 20px 0;
  }
}
#root_cont #root003 p {
  margin-bottom: 1em;
}
#root_cont #root003 p:last-child {
  margin-bottom: 0;
}

.dotted_top {
  background: url(../images/common/dotted.png) repeat-x left top;
  background-size: 10px auto;
}
@media only screen and (max-width:766px) {
  .dotted_top {
    background-size: 5px auto;
  }
}

/* SCHOOL */
#school_cont {
  padding-top: 70px;
}
#school_cont .school_sec {
  padding: 0 15px;
  display: initial;
}
#school_cont .school_sec .school_inner {
  max-width: 732px;
  margin: 0 auto;
  background: url(../images/school/border_lr_pc.png) repeat-y;
  position: relative;
  margin-bottom: 85px;
  border-bottom: 1px solid #000;
}
@media only screen and (min-width:767px) and (max-width:1023px) {
  #school_cont .school_sec .school_inner {
    background: url(../images/school/border_lr_tb.png) repeat-y;
    max-width: 700px;
  }
}
@media only screen and (max-width:766px) {
  #school_cont .school_sec .school_inner {
    background: url(../images/school/border_lr_sm.png) repeat-y;
    background-size: 309px;
    max-width: 309px;
    margin-bottom: 70px;
  }
}
#school_cont .school_sec .school_inner:before {
  content: "";
  display: block;
  width: 732px;
  height: 26px;
  background: url(../images/school/border_t_pc.png) no-repeat;
  position: absolute;
  top: -26px;
  left: 0px;
}
/* 追加 2023.6.21 */
#school_cont .school_sec .school_inner.beige {
  background-color: #f8f8f0;
}
#school_cont .school_sec .school_inner.beige:before {
  background: url(../images/school/border_t_beige_pc.png) no-repeat;
}
@media only screen and (min-width:767px) and (max-width:1023px) {
  #school_cont .school_sec .school_inner:before {
    width: 700px;
    top: -24px;
    background: url(../images/school/border_t_tb.png) no-repeat;
  }
  /* 追加 2023.6.21 */
  #school_cont .school_sec .school_inner.beige:before {
    background: url(../images/school/border_t_beige_tb.png) no-repeat;
  }
}
@media only screen and (max-width:766px) {
  #school_cont .school_sec .school_inner:before {
    width: 309px;
    top: -20px;
    background: url(../images/school/border_t_sm.png) no-repeat;
    background-size: 309px;
  }
  /* 追加 2023.6.21 */
  #school_cont .school_sec .school_inner.beige:before {
    background: url(../images/school/border_t_beige_sm.png) no-repeat;
    background-size: 309px;
  }
}
#school_cont .school_sec .school_inner .school_sub_ttl {
  font-size: 22px;
  font-size: 1.375rem;
  font-weight: bold;
  text-align: center;
  margin-bottom: 0.5em;
}
@media only screen and (max-width:766px) {
  #school_cont .school_sec .school_inner .school_sub_ttl {
    font-size: 15px;
    font-size: 0.9375rem;
  }
}
#school_cont .school_sec .school_inner .school_sub_ttl span {
  margin-right: 1em;
}
@media only screen and (max-width:766px) {
  #school_cont .school_sec .school_inner .school_sub_ttl span {
    margin-right: 0;
    display: block;
  }
}
#school_cont .school_sec .school_inner .school_ttl {
  background: #297037;
  color: #fff;
  font-size: 29px;
  font-size: 1.8125rem;
  font-weight: bold;
  text-align: center;
  line-height: 1em;
  padding: 15px 10px 10px 10px;
}
@media only screen and (max-width:766px) {
  #school_cont .school_sec .school_inner .school_ttl {
    font-size: 16px;
    font-size: 1rem;
  }
}
#school_cont .school_sec .school_inner .school_ttl .school_no {
  margin-right: 1em;
}
@media only screen and (max-width:766px) {
  #school_cont .school_sec .school_inner .school_ttl .school_no {
    margin-right: 0;
    display: block;
    margin-bottom: 0.5em;
  }
}
#school_cont .school_sec .school_inner .school_end {
  position: relative;
}
#school_cont .school_sec .school_inner .school_end:after {
  display: block;
  content: "";
  width: 130px;
  height: 130px;
  background: url(../images/school/badge_teiin1.svg?v=20230707) no-repeat;
  background-size: 130px auto;
  position: absolute;
  top: -20px;
  right: -20px;
}
#school_cont .school_sec .school_inner .school_end.cancel:after {
  background: url(../images/school/badge_teiin2.svg?v=20230707) no-repeat;
}
@media only screen and (max-width:766px) {
  #school_cont .school_sec .school_inner .school_end:after {
    width: 90px;
    height: 90px;
    background-size: 90px;
    top: -10px;
    right: 0;
  }
}
#school_cont .school_sec .school_inner .school_body {
  padding: 40px 50px;
  font-size: 21px;
  font-size: 1.3125rem;
}
@media only screen and (max-width:766px) {
  #school_cont .school_sec .school_inner .school_body {
    font-size: 12px;
    font-size: 0.75rem;
    padding: 20px;
  }
}
#school_cont .school_sec .school_inner .school_body p {
  margin-bottom: 1em;
  text-align: justify;
  text-justify: inter-ideograph;
  -ms-text-justify: inter-ideograph;
}
#school_cont .school_sec .school_inner .school_body .mountain_overview h4 {
  margin-bottom: 0.5em;
}
#school_cont .school_sec .school_inner .school_body .mountain_overview table tr th, #school_cont .school_sec .school_inner .school_body .mountain_overview table tr td {
  text-align: left;
  vertical-align: top;
  line-height: 1.5em;
  padding-bottom: 0.5em;
}
#school_cont .school_sec .school_inner .school_body .mountain_overview table tr th {
  white-space: nowrap;
}
#school_cont .school_sec .school_inner .school_body .mountain_overview table tr td {
  text-align: justify;
  text-justify: inter-ideograph;
  -ms-text-justify: inter-ideograph;
}
#school_cont .school_sec .school_inner .kakko_text {
  font-size: 0.8em;
}
#school_cont #school_overview {
  max-width: 1050px;
  margin: 100px auto 50px auto;
  position: relative;
}
#school_cont #school_overview #school_flag {
  width: 210px;
  position: absolute;
  top: -30px;
  right: -55px;
}
@media only screen and (min-width:1024px) and (max-width:1199px) {
  #school_cont #school_overview #school_flag {
    top: 0;
    right: auto;
    left: 200px;
  }
}
@media only screen and (min-width:767px) and (max-width:1023px) {
  #school_cont #school_overview #school_flag {
    top: 0;
    right: auto;
    left: 60px;
  }
}
@media only screen and (max-width:766px) {
  #school_cont #school_overview #school_flag {
    width: 130px;
    top: 0;
    right: auto;
    left: 60px;
    mix-blend-mode: multiply;
  }
}
@media only screen and (max-width:1199px) {
  #school_cont #school_overview {
    padding-top: 220px;
  }
}
@media only screen and (max-width:766px) {
  #school_cont #school_overview {
    padding: 130px 20px 0 20px;
    margin: 0px auto 20px auto;
  }
}
#school_cont #school_overview #school_overview_inner {
  max-width: 730px;
  margin: 0 auto;
}
#school_cont #school_overview #school_overview_inner h3 {
  font-size: 23px;
  font-size: 1.4375rem;
  padding-bottom: 20px;
  margin-bottom: 55px;
  font-weight: bold;
  text-align: center;
  background: url(../images/common/dotted.png) left bottom repeat-x;
  background-size: 10px auto;
}
@media only screen and (max-width:766px) {
  #school_cont #school_overview #school_overview_inner h3 {
    font-size: 15px;
    font-size: 0.9375rem;
    margin-bottom: 20px;
    background-size: 5px auto;
  }
}
#school_cont #school_overview #school_overview_inner #school_overview_table {
  padding: 0 40px;
}
@media only screen and (max-width:766px) {
  #school_cont #school_overview #school_overview_inner #school_overview_table {
    padding: 0 20px;
  }
}
#school_cont #school_overview #school_overview_inner #school_overview_table table tr th, #school_cont #school_overview #school_overview_inner #school_overview_table table tr td {
  vertical-align: top;
  text-align: left;
  line-height: 1.3em;
  padding-bottom: 1.5em;
  font-size: 21px;
  font-size: 1.3125rem;
}
@media only screen and (max-width:766px) {
  #school_cont #school_overview #school_overview_inner #school_overview_table table tr th, #school_cont #school_overview #school_overview_inner #school_overview_table table tr td {
    font-size: 12px;
    font-size: 0.75rem;
  }
}
#school_cont #school_overview #school_overview_inner #school_overview_table table tr th {
  white-space: nowrap;
  padding-right: 1.5em;
}
#school_cont #school_overview #school_overview_inner #school_overview_table table tr td p {
  margin-bottom: 1em;
  text-align: justify;
  text-justify: inter-ideograph;
  -ms-text-justify: inter-ideograph;
}
#school_cont #school_overview #school_overview_inner #school_overview_table table tr td p:last-child {
  margin-bottom: 0;
}
#school_cont #school_overview #school_overview_inner #school_overview_table table tr td a {
  text-decoration: underline;
}
#school_cont #school_overview #school_overview_inner #school_overview_table table tr td#guide {
  position: relative;
  z-index: 2;
}
@media only screen and (max-width:1199px) {
  #school_cont #school_overview #school_overview_inner #school_overview_table table tr td#guide {
    padding-right: 250px;
  }
}
@media only screen and (max-width:766px) {
  #school_cont #school_overview #school_overview_inner #school_overview_table table tr td#guide {
    padding-right: 110px;
  }
}
#school_cont #school_overview #school_overview_inner #school_overview_table table tr td#guide div {
  position: absolute;
  width: 180px;
  bottom: -20px;
  right: -220px;
}
@media only screen and (max-width:1199px) {
  #school_cont #school_overview #school_overview_inner #school_overview_table table tr td#guide div {
    right: 0;
    bottom: 20px;
  }
}
@media only screen and (max-width:766px) {
  #school_cont #school_overview #school_overview_inner #school_overview_table table tr td#guide div {
    width: 80px;
  }
}
#school_cont #school_img {
  max-width: 1110px;
  margin: 0 auto 100px auto;
  padding: 0 25px;
}
#school_cont #school_img ul {
  display: flex;
  align-items: flex-end;
}
@media only screen and (max-width:766px) {
  #school_cont #school_img ul {
    display: block;
  }
}
#school_cont #school_img ul li {
  vertical-align: bottom;
  padding: 0 27px;
}
@media only screen and (min-width:767px) and (max-width:1023px) {
  #school_cont #school_img ul li {
    padding: 0 10px;
  }
}
#school_cont #school_img ul li img {
  width: 100%;
}
@media only screen and (max-width:766px) {
  #school_cont #school_img ul li:first-child {
    margin-bottom: 1em;
  }
}

/* GOODS */
#goods_cont {
  max-width: 1257px;
  margin: 0 auto;
}
#goods_cont #goods_list {
  margin-bottom: 60px;
  padding: 0 15px;
}
#goods_cont #goods_list li {
  text-align: center;
}
@media only screen and (max-width:766px) {
  #goods_cont #goods_list li:after {
    content: "";
    margin: 45px auto;
    width: 50%;
    background: url(../images/common/dotted.png) repeat-x;
    background-size: 10px auto;
    height: 10px;
    display: block;
  }
  #goods_cont #goods_list li:last-child:after {
    display: none;
  }
}
#goods_cont #goods_list li.goods_list_sm {
  display: none;
}
@media only screen and (max-width:766px) {
  #goods_cont #goods_list li.goods_list_sm {
    display: block;
  }
}
#goods_cont #goods_list li div {
  display: none;
}
@media only screen and (max-width:766px) {
  #goods_cont #goods_list li div {
    display: block;
  }
}
#goods_cont #goods_text_wrap {
  padding: 0 20px;
}
#goods_cont #goods_text_wrap #goods_text {
  max-width: 515px;
  margin: 0px auto 200px auto;
  border: 1px solid #cccccc;
  padding: 50px 20px;
  border-radius: 15px;
}
@media only screen and (max-width:766px) {
  #goods_cont #goods_text_wrap #goods_text {
    padding: 20px 10px;
    margin-bottom: 100px;
  }
}
#goods_cont #goods_text_wrap #goods_text p {
  font-size: 16px;
  font-size: 1rem;
  text-align: center;
}
@media only screen and (max-width:766px) {
  #goods_cont #goods_text_wrap #goods_text p {
    font-size: 11px;
    font-size: 0.6875rem;
  }
}

/* AUTUMN COLORS */
#ac_cont {
  max-width: 660px;
  margin: 0 auto 300px auto;
  padding-top: 30px;
  padding: 30px;
}
@media only screen and (max-width:766px) {
  #ac_cont {
    margin: 0 auto 0px auto;
  }
}
#ac_cont .ac_cont___logo {
  text-align: center;
  margin-bottom: 30px;
}
#ac_cont .ac_cont___logo img {
  max-width: 449px;
  width: 100%;
}
@media only screen and (max-width:766px) {
  #ac_cont .ac_cont___logo img {
    max-width: 207px;
  }
}
#ac_cont .ac_cont___archive {
  text-align: center;
  font-size: 0px;
  font-size: 0rem;
  max-width: 600px;
  margin: 0 auto 70px auto;
}
@media only screen and (max-width:766px) {
  #ac_cont .ac_cont___archive {
    max-width: 360px;
    margin: 0 auto 50px auto;
  }
}
#ac_cont .ac_cont___archive li {
  display: inline-block;
  margin: 0 8px 18px 8px;
}
@media only screen and (max-width:766px) {
  #ac_cont .ac_cont___archive li {
    margin: 0 5px 10px 5px;
  }
}
#ac_cont .ac_cont___archive li a {
  display: block;
  background: #d9cea1;
  color: #595757;
  font-size: 18px;
  font-size: 1.125rem;
  line-height: 1em;
  padding: 8px 15px;
  border-radius: 5px;
}
@media only screen and (max-width:766px) {
  #ac_cont .ac_cont___archive li a {
    font-size: 11px;
    font-size: 0.6875rem;
    padding: 8px 10px;
  }
}
#ac_cont .ac_cont___archive li.current a {
  background: #ca5b4b;
  color: #fff;
}
#ac_cont .ac_cont__caution {
  text-align: center;
  margin-top: -50px;
  margin-bottom: 100px;
  font-size: 15px;
  font-size: 0.9375rem;
}
@media only screen and (max-width:766px) {
  #ac_cont .ac_cont__caution {
    margin-top: -20px;
    font-size: 13px;
    font-size: 0.8125rem;
  }
}
#ac_cont .ac_cont__caution a {
  text-decoration: underline;
}
#ac_cont .ac_cont__ttl {
  text-align: center;
  background: url(../images/common/dotted.png) repeat-x left bottom;
  background-size: 5px auto;
  padding-bottom: 35px;
  margin-bottom: 45px;
}
@media only screen and (max-width:766px) {
  #ac_cont .ac_cont__ttl {
    padding-bottom: 25px;
    margin-bottom: 25px;
  }
}
#ac_cont .ac_cont__ttl img {
  max-width: 152px;
}
#ac_cont article {
  background: url(../images/common/dotted.png) repeat-x left bottom;
  background-size: 5px auto;
  padding-bottom: 60px;
  margin-bottom: 50px;
}
#ac_cont article h4 {
  background: url(../images/common/dotted_tate.png) repeat-y left top;
  background-size: 2px auto;
  margin-left: 8px;
  margin-bottom: 10px;
  padding: 5px 0 5px 12px;
  line-height: 1em;
}
@media only screen and (max-width:766px) {
  #ac_cont article h4 {
    margin-left: 0;
    font-size: 15px;
    font-size: 0.9375rem;
  }
}
#ac_cont article .ac_body {
  padding: 0 20px;
}
@media only screen and (max-width:766px) {
  #ac_cont article .ac_body {
    padding: 0;
  }
}
#ac_cont article .ac_body p {
  font-size: 15px;
  font-size: 0.9375rem;
  line-height: 1.8em;
  margin-bottom: 1em;
}
#ac_cont article .ac_body p:last-child {
  margin-bottom: 0;
}
@media only screen and (max-width:766px) {
  #ac_cont article .ac_body p {
    font-size: 13px;
    font-size: 0.8125rem;
  }
}

/* LINK */
#link_cont {
  max-width: 840px;
  padding: 0 35px;
  margin: 0 auto;
  padding-top: 100px;
  margin-bottom: 100px;
  zoom: 1;
}
#link_cont:before, #link_cont:after {
  content: "";
  display: table;
}
#link_cont:after {
  clear: both;
}
@media only screen and (min-width:767px) and (max-width:1023px) {
  #link_cont {
    max-width: 500px;
  }
}
@media only screen and (max-width:766px) {
  #link_cont {
    max-width: 100%;
    margin-bottom: 100px;
    padding-top: 50px;
    text-align: center;
  }
}
#link_cont h2 {
  font-size: 18px;
  font-size: 1.125rem;
  margin-bottom: 60px;
}
@media only screen and (max-width:766px) {
  #link_cont h2 {
    font-size: 15px;
    font-size: 0.9375rem;
    text-align: center;
  }
}
#link_cont h2 span {
  border-bottom: 2px solid #000;
  padding-bottom: 5px;
}
#link_cont #link_inner {
  zoom: 1;
}
#link_cont #link_inner:before, #link_cont #link_inner:after {
  content: "";
  display: table;
}
#link_cont #link_inner:after {
  clear: both;
}
@media only screen and (max-width:766px) {
  #link_cont #link_inner {
    display: inline-block;
  }
}
#link_cont #link_inner ul {
  width: 47%;
  margin-bottom: 4em;
}
@media only screen and (max-width:1023px) {
  #link_cont #link_inner ul {
    width: 100%;
  }
}
@media only screen and (max-width:766px) {
  #link_cont #link_inner ul {
    margin-bottom: 6em;
    width: auto;
  }
}
#link_cont #link_inner ul.link_left {
  float: left;
}
@media only screen and (max-width:1023px) {
  #link_cont #link_inner ul.link_left {
    float: none;
  }
}
#link_cont #link_inner ul.link_right {
  float: right;
}
@media only screen and (max-width:1023px) {
  #link_cont #link_inner ul.link_right {
    float: none;
  }
}
#link_cont #link_inner ul li {
  line-height: 1.3em;
  font-size: 20px;
  font-size: 1.25rem;
  margin-bottom: 1.8em;
  position: relative;
  padding-left: 1.2em;
}
@media only screen and (max-width:766px) {
  #link_cont #link_inner ul li {
    font-size: 16px;
    font-size: 1rem;
    padding-left: 1.5em;
    text-align: left;
  }
}
#link_cont #link_inner ul li:before {
  width: 17px;
  height: 17px;
  display: block;
  content: "";
  background: #CD9D00;
  border-radius: 17px;
  position: absolute;
  left: 0;
  top: 5px;
}
@media only screen and (max-width:766px) {
  #link_cont #link_inner ul li:before {
    top: 2px;
  }
}
#link_cont #link_inner ul li:last-child {
  margin-bottom: 0;
}