@charset "UTF-8";

/* リセット
----------------------------------------*/
html, body, div, dl, dt, dd, ul, ol, li, h1, h2, h2, h3, h4, h5, h6,
pre, form, fieldset, input, textarea, p, table, th, td, button {
    margin: 0;
	padding: 0;
	font-size: 100%;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
* { 
margin: 0px; 
padding: 0px; 
}

img {
	border: 0;
}
ol ,
ul {
	list-style: none;
}
a{
	text-decoration: none;
	color:#333;
}
a:hover{
	text-decoration:underline;
}
a:hover img{
	opacity: 0.8;
}
article, aside, details, figcaption, figure, footer, header, hgroup, main, nav, section, summary {
	display: block;
	margin: 0;
	padding: 0;
	font-size: 100%;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
body{
	margin:0;
	padding:0;
	font-family: "GenJG";
	color:#333;
	min-width: 100%;
	max-width: 100%;
	scroll-behavior: smooth;
}
html {
    scroll-behavior: smooth;
}
/* フォント
----------------------------------------*/
@font-face {
    font-family: 'GenJG';
    font-style: normal;
    font-weight: 400;
    src: url('../../font/GenJyuuGothicX-Regular.eot');
   src: url('../../font/GenJyuuGothicX-Regular.eot?#iefix') format('embedded-opentype'),
    url('../../font/GenJyuuGothicX-Regular.ttf') format('truetype'),
    url('../../font/GenJyuuGothicX-Regular.woff') format('woff');
}
@font-face {
    font-family: 'GenJG';
    font-style: normal;
    font-weight: 700;
    src: url('../../font/GenJyuuGothic-Bold.eot');
    src: url('../../font/GenJyuuGothic-Bold.eot?#iefix') format('embedded-opentype'),
    url('../../font/GenJyuuGothic-Bold.ttf') format('truetype'),
    url('../../font/GenJyuuGothic-Bold.woff') format('woff');
}


@font-face {
    font-family: 'GenJG';
    font-style: normal;
    font-weight: 900;
    src: url('../../font/GenJyuuGothicX-Heavy.eot');
    src: url('../../font/GenJyuuGothicX-Heavy.eot?#iefix') format('embedded-opentype'),
    url('../../font/GenJyuuGothicX-Heavy.ttf') format('truetype'),
    url('../../font/GenJyuuGothicX-Heavy.woff') format('woff');
}

@font-face{
	font-display:swap;
	font-family:'NotoSans_R';
	font-style:normal;
	src:url(../../font/NotoSansCJKjp-Regular.woff2) format('woff2'),
		url(../../font/NotoSansCJKjp-Regular.woff) format('woff');
}
@font-face{
	font-display:swap;
	font-family:'NotoSans_L';
	font-style:normal;
	src:url(../../font/NotoSansCJKjp-Light.woff2) format('woff2'),
		url(../../font/NotoSansCJKjp-Light.woff) format('woff');
}


/*----------------------------- 
			ヘッダー
----------------------------- */
header{
	top:0;
	left:0;
	width:100%;
	background: #fff;
	z-index: 999;
	position: relative;
}
header #wrap {
    position: relative;
	height:100px;
}
header #svg-bg {
    position: absolute;
    width: 100%;
    height: 15px;
    top: 0;
    left: 0;
    z-index: 10;
}
/*
header:after{
	content:"";
	display:block;
	position:absolute;
	bottom:-12px;
	height:12px !important;
	width:100%;
	background:url(../../images/base/u_nami.png) center center repeat-x;
	}*/
header .h-logo-s{
	z-index:20;
	position:absolute;
	top: 20px;
	left: calc(50% - 60px);
}
header .h-logo-s a:hover img{opacity: 1.0}
header .h-logo-s img{
	width:120px;
}
header #click-nav{
	position: absolute;
	right:7%;
	top:38px;
	z-index: 1000;
}
/* click-nav */
#click-nav {
	position: relative;
	width: 30px;
	height: 20px;
	cursor: pointer;
}
#click-nav span {
	display: block;
	position: absolute;
	background: #333;
	width: 100%;
	height: 2px;
	right: 0;
	-webkit-transition: .3s;
	transition: .3s;
	z-index: 999;
}
#click-nav .one{
	top: 0;
}
#click-nav .two {
	top: 10px;
}
#click-nav .three{
	top: 20px;
}


.nav_sp{
	display:block;
	width:100%;
	position:absolute;
	left:0;
	top:0;
	width:100%;
	background:#f6f6f6;
	box-sizing:border-box;
	position:relative;
	z-index:600;
	left:0;
	top:0;
	}
.nav_sp a{
	display:block;
	width:25%;
	padding:48px 0 8px;
	float:left;
	position:relative;
	color: #589600;
	}	
.nav_sp a:hover{text-decoration: none}	
.nav_sp a:before{
	content:"";
	display:block;position:absolute;
	top:10px;left:0;right:0;margin:auto;
	}
	
.nav_sp a:after{
	content:"";
	display:block;
	position:absolute;
	right:0;
	top:0;
	bottom:0;
	margin:auto;
	width:1px;
	height:28px;
	border-right:1px dotted #d1d1d1;
	}

.nav_sp a.menu01_sp:before{width:45px;height:36px;background:url(../../images/base/menu01.png); background-size:cover; }
.nav_sp a.menu02_sp:before{width:45px;height:35px;background:url(../../images/base/menu02.png); background-size:cover;}
.nav_sp a.menu03_sp:before{width:35px;height:35px;background:url(../../images/base/menu03.png); background-size:cover;}
.nav_sp a.menu04_sp:before{width:40px;height:35px;background:url(../../images/base/menu05.png); background-size:cover;}

.nav_sp a p {
    text-align: center;
    font-size: 11px;
    font-weight: 700;
    margin-bottom: 3px;
}
.navi_pan {
    display: none;
}
/*コンテンツ*/
#inner {
	margin: 20px auto 0;
}
h1{display:none;}
.w1080{width:94%;margin:0 auto;}

h2.title01{
    font-size: 22px;
    font-weight: 700;
    line-height: 1.8;
    text-align: center;
	margin-bottom: 30px;
}
h2.title01 span{
	display: block;
	font-size:14px;
	color:#589600;
	line-height: 1;
}
h3{
    font-size: 20px;
    font-weight: 700;
    line-height: 1.8;
    text-align: center;
	margin-bottom:10px;
}

h3.line01{
  position: relative;
  display: inline-block;
  padding: 0 55px;
}

h3.line01:before, h3.line01:after {
  content: '';
  position: absolute;
  top: 50%;
  display: inline-block;
  width: 45px;
  height: 1px;
  background-color: black;
}

h3.line01:before {
  left:0;
}
h3.line01:after {
  right: 0;
}

h3.stripe{
  background-color: #E9F7E8;
  background-image: -webkit-gradient(linear, 0 100%, 100% 0,
            color-stop(.25, #fff), color-stop(.25, transparent),
            color-stop(.5, transparent), color-stop(.5, #fff),
            color-stop(.75, #fff), color-stop(.75, transparent),
            to(transparent));
  background-image: -webkit-linear-gradient(45deg, #fff 25%, transparent 25%,
          transparent 50%, #fff 50%, #fff 75%,
          transparent 75%, transparent);
  background-image: -moz-linear-gradient(45deg, #fff 25%, transparent 25%,
          transparent 50%, #fff 50%, #fff 75%,
          transparent 75%, transparent);
  background-image: -ms-linear-gradient(45deg, #fff 25%, transparent 25%,
          transparent 50%, #fff 50%, #fff 75%,
          transparent 75%, transparent);
  background-image: -o-linear-gradient(45deg, #fff 25%, transparent 25%,
          transparent 50%, #fff 50%, #fff 75%,
          transparent 75%, transparent);
  background-image: linear-gradient(45deg, #fff 25%, transparent 25%,
          transparent 50%, #fff 50%, #fff 75%,
          transparent 75%, transparent);
  -webkit-background-size: 10px 10px;
  -moz-background-size: 10px 10px;
  background-size: 10px 10px;
  padding:20px 10px;
line-height: 1.4;
margin-bottom: 15px !important;
}


.half-box{
	width:90%;
	text-align: center;
	margin: 0 auto;
}
.fbn_link .half-box{
	margin-bottom:15px;
}
section#link{
	padding:60px 0 80px;
}
/*いのくんの絵かき歌*/
div.sl_y{
	position: relative;
	padding: 0px 40px;
	white-space: nowrap;
	text-align: center;
	line-height: 30px;
	font-size: 20px;
	font-weight: 800;
	margin-bottom:30px;
}
div.sl_y::before,
div.sl_y::after {
	content: "";
	position: absolute; top: 0px;
	display: block;
	width: 2px ;
	height: 100%;
	background: #fab701;
}
div.sl_y::before { left: 20px; transform: rotate( -30deg ) }

div.sl_y::after { right: 20px; transform: rotate( 30deg ) }

video{
	width:100%;
	height:auto;
}

footer{
	padding:45px 0 10px;
	background:#e3f5eb;
	text-align: center;
	font-size:13px;
	font-weight:700;
	line-height:24px;
	position:relative;
}
footer img{
	width:223px;
	display: block;
	margin:0 auto 10px;
}
footer .info{
	width:250px;
	margin:0 auto;
}
footer a.map{
	font-size: 13px;
	width: 235px;
	font-weight: 700;
	margin-top:15px;
}
.copyright{
	font-size:12px;
	margin:60px auto 0;
	text-align: center;
}
#pagetop {
    position: fixed;
    bottom: 25px;
    right: 15px;
    cursor: pointer;
    cursor: hand;
	z-index:999;
	width:100px;
}
/*----------------------------- 
SPメニュー
----------------------------- */
  /* body is-fixed */
  body.is-fixed {
    position: fixed;
    width: 100%;
    height: 100%;
  } 
	#menu-wrap {
    background: #F6F6F6;
    width: 100%;
    position: fixed;
    top: 0px;
    right: -90%;
    height: 100%;
    padding: 20px 0;
    opacity: 0;
	overflow: hidden;
	overflow-y: scroll;
    box-sizing: border-box;
    z-index: 1000;
    -webkit-transition: .3s;
    transition: .3s;
  }

  #menu-wrap.is-active {
    opacity: 1;
    visibility: visible;
    right: 0;
  }

  /* click-nav */
  #click-nav ,#click-nav2{
    position: relative;
    width: 30px;
    height: 20px;
    cursor: pointer;
  }

  #click-nav span,#click-nav2 span {
    display: block;
    position: absolute;
    background: #333;
    width: 100%;
    height: 2px;
    right: 0;
    -webkit-transition: .3s;
    transition: .3s;
	  z-index: 999;
  }

  #click-nav .one {
    top: 0;
  }

  #click-nav .two {
    top: 10px;
  }

  #click-nav .three {
    top: 20px;
  }

  /* click-nav is-active */

#menu-wrap #click-nav2{
	position: absolute;
	right:7%;
	top:20px;
	z-index: 1000;
}

  #click-nav2.is-active .one {
    transform: rotate(45deg);
    top: 10px;
  }

  #click-nav2.is-active .two {
    right: -70px;
  }

  #click-nav2.is-active .three {
    top: 10px;
    transform: rotate(-45deg);
  }

  /* body-wrap */
  #body-wrap {
	position: fixed;
	top: 80px;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.7);
	z-index: 10;
  }
#menu-wrap img.sp-mino{
	width:18%;
	max-width:63px;
	height:auto;
	margin: 0 auto 0 15px;
}
#menu-wrap img.sp-mlogo{
	width:75%;
	max-width:223px;
	margin:40px auto 0;
}
#menu-wrap h2{
	font-size:22px;
	text-align: center;
}
#menu-wrap ul.sp_menu{
	margin:10px 0 35px;
	padding:0;
}
#menu-wrap ul.sp_menu li{
	background:#fff;
	font-size:15px;
	letter-spacing:0.02em;
	border-bottom:1px solid #ccc;
	position: relative;
}
#menu-wrap ul.Z li a{
	display: block;
	padding: 10px 20px 10px 50px;
}
#menu-wrap ul.sp_menu li::before{
	content: "笳�";
	display: block;
	float:left;
	font-size:10px;
	color:#d3a441;
	margin:13px 0 0 30px;
}
#menu-wrap ul.sp_menu li:after {
    content: '';
    display: inline-block;
    width: 8px;
    height: 8px;
    border-right: 2px solid #999;
    border-top: 2px solid #999;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
	position: absolute;
	top:15px;
	right:20px;
}
#menu-wrap ul.sp_menu li.title a{
	padding: 10px 20px 10px 30px;
}
#menu-wrap ul.sp_menu li.title::before{
	margin:13px 0 0 10px!important;
}
#menu-wrap ul.s_guide{
	width:90%;
	margin:0 5% 50px 5%;
}
#menu-wrap ul.s_guide li{
	color:#333333;
	background: none;
	float:left;
	width:33.3%;
	fons-weight:normal;
	text-align: center;
	border-bottom:1px solid #CCC;
	padding:0 0 10px 0;
	font-size:12px;
	line-height: 120%;
}

#menu-wrap ul.s_guide li:nth-child(odd){
	clear:none;
}
#menu-wrap ul.s_guide li span{
	border-right:1px solid #CCC;
	display: block;
	maring:0 auto 0 auto;
	width:100%;
	text-align: center;
}
#menu-wrap ul.s_guide li:last-child span{
	border:0;
}
#menu-wrap ul.s_guide li img{
	width:40px;
	height:auto;
}

#menu-wrap ul.sp-mnav li {
	padding: 0;
	display:block;
}
#menu-wrap ul.sp-mnav{
	width:calc(100% - 30px);
	margin:20px auto;
	-js-display: flex;
	display:-webkit-box;
	display: -webkit-flex;
	display:-moz-box;
	display:-ms-flexbox;
	display: flex;
	-webkit-justify-content: space-between;
    justify-content: space-between;
	-webkit-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
			flex-wrap: wrap;
	position:relative;
	}

#menu-wrap ul.sp-mnav li{
	width:33%;
	width:calc(33% - 5px);
	margin-bottom:10px;
	position:relative;
}

#menu-wrap ul.sp-mnav li a{
	position:relative;
	display: block;
	background:#fff;
	width:100%;
	box-sizing:border-box;
	padding:60px 0 15px;
	text-align: center;
	text-decoration: none;
	color:#333;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
	border-radius: 5px;	
	-webkit-transition: background 0.4s ease;
    -moz-transition: background 0.4s ease;
    -o-transition: background 0.4s ease;
    transition: background 0.4s ease;
	position:relative;
}

	
#menu-wrap ul.sp-mnav li:before{
content:"";
	display:block;
	position:absolute;
	left:0;right:0;
	margin:auto;
}

#menu-wrap ul.sp-mnav li.menu01:before{
	width:50px;
	height:39px;
	top:12px;
	background:url(../../images/base/menu01.png);
	background-size:cover; z-index:9999;
}
#menu-wrap ul.sp-mnav li.menu02:before{
	width:50px;
	height:38px;
	top:12px;
	background:url(../../images/base/menu02.png);
	background-size:cover;
	z-index:9999;
}
#menu-wrap ul.sp-mnav li.menu03:before{
	width:40px;
	height:40px;
	top:12px;
	background:url(../../images/base/menu03.png);
	background-size:cover;
	z-index:9999;}
#menu-wrap ul.sp-mnav li.menu04:before{
	width:50px;
	height:37px;
	top:12px;
	background:url(../../images/base/menu04.png);
	background-size:cover;
	z-index:9999;
}
#menu-wrap ul.sp-mnav li.menu05:before{
	width:42px;
	height:36px;
	top:12px;
	background:url(../../images/base/menu05.png);
	background-size:cover;
	z-index:9999;}
#menu-wrap ul.sp-mnav li.menu06:before{
	width:40px;
	height:40px;
	top:12px;
	background:url(../../images/base/menu06.png);
	background-size:cover;
	z-index:9999;
}
#menu-wrap ul.sp-mnav li a p{
	text-align:center;font-size:13px;font-weight:700;color:#333; margin-bottom:5px;
}

#menu-wrap ul.sp-mnav li a span{font-size:9.5px;color:#589600;font-weight:700;display:inline-block;text-align:center;width:100%;text-transform: uppercase;}

#menu-wrap .sp-mbn{
	width:calc(100% - 30px);
	margin:0 auto 30px;
	text-align:center;
}
#menu-wrap .sp-mbn a{
	display:block;
	width:calc(50% - 7.5px);
	float:left;
}
#menu-wrap .sp-mbn a:last-of-type{
	margin-left:15px;
}
#menu-wrap .sp-mbn img{
	width:100%;
	max-width:459px;
	display: block;
}
/*
#menu-wrap .video{
	width:75%;
	margin: 20px auto;
	max-width:400px;
}
#menu-wrap video{
	height:auto;
}

#menu-wrap div.sl_y{
	margin-bottom:10px;
}*/

#menu-wrap .video_link{
	width:calc(100% - 30px);
	margin:0 auto 30px;
}

#menu-wrap .video_link a{
	display:block;
	border:1px solid #e6720b;
	border-radius: 10px;
	background:#FFF0E2;
	color:#e6720b;
	padding:15px;
	text-align: center;
	font-weight: bold;
}
#menu-wrap .video_link a span{
	font-size:0.8rem;
	margin: 0 2px;
}

#spmenu_info {
    margin: 0 auto 35px;
    text-align: center;
}
#spmenu_info p, #spmenu_info p span {
    font-size: 12px;
}
#spmenu_info p.tel{
	font-size:24px;
	font-weight:700;
	position:relative;
    width: 200px;
    padding-left: 20px;
    margin: 15px auto 10px;
	line-height:24px;
}
#spmenu_info p.tel:before {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    top: 0px;
    width: 24px;
    height: 24px;
    background: url(../../images/base/ico_tel.png);
    background-size: cover;
}
#spmenu_info .contact_link {
    display: block;
    position: relative;
    width: 235px;
    margin: 15px auto;
    font-weight: 700;
    color: #589600;
    background: #fff;
    border: 2px solid #589600;
    font-size: 12px;
    padding: 12px;
    -moz-border-radius: 45px;
    -webkit-border-radius: 45px;
    border-radius: 45px;
    box-sizing: border-box;
}