﻿@charset "utf-8";

/* page_name
-------------------------------------------------------------------*/
#page_top #main {
	overflow:hidden;
	position:relative;
	box-sizing: border-box;
}
@media screen and (max-width:760px) {
	#page_top #main {
		min-width:0;
		padding-top: 60px;
	}
}

#page_top #main .bx-wrapper{
	height: auto;
}
#page_top #main .sub_img {
	position: absolute;
	left: 0;
	top: 0;
	right: 0;
	margin: auto;
	width: auto;
	height: auto;
	min-width: 100%;
	min-height: 100%;
	display: none;
	z-index: 40;
}

@media screen and (max-width:760px) {
	#page_top #main .sub_img {
		display: none;
	}
	#page_top #main .bx-wrapper{
		height: auto;
	}
}

/***　スライド　***/
#page_top .kv{
	position:relative;
	z-index:2;
	max-height:calc(100vh - var(--notice));
	height:var(--height);
	overflow:hidden;
	--notice:7em;
	--height:970px;
}
#page_top .kv #kv_bg{
	max-height:calc(100vh - var(--notice));
	height:var(--height);
	position:relative;
	z-index:1;
}
#page_top .kv #kv_bg img{
	object-fit:cover;
	max-width: 100%;
}
#page_top .kv #kv_bnr{
	position:absolute;
	z-index:5;
	bottom:3em;
	right:3em;
	--width:620px;
	width:var(--width);
	filter:drop-shadow(0 0 5px #000);
}
#page_top .kv #kv_bnr .common_slider a{
	display:block;
	border:solid 2px #fff;
	border-radius:0.65rem;
	overflow:hidden;
}
#page_top .kv #kv_bnr .common_slider a img{
	max-width:100%;
	height:auto;	
}
#page_top .kv #kv_bnr .bx-controls-direction a{
	position:absolute;
	inset:0 auto 0 0;
	margin:auto;
	font-size:0;
	height: 2.0rem;
	width: 2.0rem;
	aspect-ratio:1 / 1;
	border:none;
	border-top:solid 4px #fff;
	border-right:solid 4px #fff;
	transform:rotate(-135deg);
	display:block;
	position:absolute;
	filter:drop-shadow(0 0 5px #000);
	background: none;
}
#page_top .kv #kv_bnr .bx-controls-direction a.bx-next{
	transform:rotate(45deg);
	inset:0 0 0 auto ;
}
#page_top .kv .bx-pager a{
	border:solid 1px #fff;
	background:transparent;
}
#page_top .kv .bx-pager a:is(:hover,.active,:focus){
	background:#fff;
}

#page_top .kv .bx-controls-auto{
	background:#fff;
	width:fit-content;
	margin-inline:auto 0;
	inset:auto 0 -1.5rem;
	padding:0.25rem;
	border-radius:2rem;
	display:flex;
	align-items:center;
	justify-content:center;
	gap:0rem;
}
#page_top .kv .bx-controls-auto a{
	aspect-ratio:1 / 1;
	height:1.5rem;
	width:1.5rem;
	display: block;
	border-radius:50%;
	background:var(--keycolor);
	position:relative;
	z-index:1;
	text-indent:-9999px;
	overflow:hidden;
	white-space: nowrap;
	text-align:left;
}
#page_top .kv .bx-controls-auto a.bx-start:before{
	content:"";
	display:block;
	clip-path: polygon(0% 0%, 100% 50%, 0% 100%);
	background:#fff;
	position:absolute;
	z-index:1;
	inset:0 0 0 0.2rem;
	width:0.65rem;
	height:0.65rem;
	margin:auto;
}
#page_top .kv .bx-controls-auto a.bx-stop:before,
#page_top .kv .bx-controls-auto a.bx-stop:after{
	content:"";
	display:block;
	background:#fff;
	position:absolute;
	z-index:1;
	inset:0 auto 0 0.475rem;
	width:0.2rem;
	height:0.75rem;
	margin:auto;
}
#page_top .kv .bx-controls-auto a.bx-stop:after{
	inset:0 0.475rem 0 auto;
}
#page_top .kv .bx-controls-auto a.active{
	background:#eee;
	box-shadow:0 0 6px rgba(0,0,0,0.1) inset;
}
#page_top .kv .bx-controls-auto a.active:before,
#page_top .kv .bx-controls-auto a.active:after{
	background:#999;
}


/***　メインバナーリンク***/
/***　メインバナーリンク***/
#page_top #main .box {
	width:100%;
	z-index:50;
	padding: 20px 0;
	background: #ffffff;
	position: relative;
}
#page_top #main .box ul,
#page_top .lang_box .box ul {
	text-align:center;
}
#page_top #main .box ul{
	display:flex;
	max-width:1000px;
	margin:auto;
}
#page_top #main .box ul li{
	display:block;
	width:25%;
	box-sizing:border-box;
}
#page_top #main .box ul li + li{
    border-left:solid 2px #dfdfdf;
}

#page_top #main .box ul li a{
	display:block;
	text-align:center;
	padding:10px 5px;
	color:#664422;
	box-sizing:border-box;
	-webkit-box-sizing: border-box;
	transition:all ease 0.3s;
	position:relative;
}
#page_top .lang_box .box ul li {
	display:inline-block;
	margin:0 5px;
	position:relative;
}
#page_top .lang_box .box ul li a {
	display:block;
	text-align:center;
	width:240px;
	padding:15px 5px;
	color:#FFF;
	border: 1px solid rgba(0,0,0,0.1);
	background:rgba(0,0,0,0.6);
	box-sizing:border-box;
	-webkit-box-sizing: border-box;
	transition:all ease 0.3s;
}
#page_top .lang_box .box ul li a {
	color: #444;
	background-color:rgba(200,200,200,0.8);
	border: 1px solid rgba(0,0,0,0.1);
}
#page_top #main .box ul li a:hover,
#page_top #main .box ul li a:focus {
	background-color:#f0f0f0;
	text-decoration:underline;
}
/***********/
#page_top #main .box ul li.one a:before,
#page_top #main .box ul li.two a:before,
#page_top #main .box ul li.three a:before,
#page_top #main .box ul li.four a:before{
	content:"";
	display:inline-block;
	vertical-align:middle;
	margin-right:10px;
	backface-visibility:hidden;
	width:40px;
	height:40px;
	background:url(../img/common/ico_kaien.png) no-repeat top center;
	background-size:40px;
}
#page_top #main .box ul li.one a:before {
	background-image:url(../img/common/ico_kaien.png);
}
#page_top #main .box ul li.two a:before {
	background-image:url(../img/common/ico_calendar.png);
}
#page_top #main .box ul li.three a:before {
	background-image:url(../img/common/ico_map.png);
}
#page_top #main .box ul li.four a:before {
	background-image:url(../img/common/ico_access.png);
}


#page_top #main .box ul li a span:before{
	content:"\30FB";
}
/******/

#page_top .lang_box{
	margin: 10px;
}
@media screen and (max-width: 760px) {
	#page_top #main .box {
		position:static;
		bottom:auto;
		padding: 0;
	}
	#page_top #main:before,	
	#page_top #main:after{
		display:none;
	}
	#page_top #main .box ul li,
	#page_top .lang_box .box ul li{
		margin:0;
		display:block;
		float:left;
		width:50%;
	}
	#page_top #main .box ul li a,
	#page_top .lang_box .box ul li a {
		width: 100%;
		height:100%;
		font-size:  12px;
		line-height:1.2;
	}
	#page_top #main .box ul li.one a:before,
	#page_top #main .box ul li.two a:before,
	#page_top #main .box ul li.three a:before,
	#page_top #main .box ul li.four a:before{
		display:block;
		margin:0 auto 5px;
		width: 28px;
		height: 28px;
		background-size: contain;
	}
	#page_top #main .box ul li a span{
		display:block;
	}

	#page_top #main .box ul li a span:before{
		display:none;
	}
	#page_top #main .bx-controls{
		padding:10px;
	}
	#page_top #main .bx-wrapper .bx-pager a{
		width:10px;
		height:10px;
	}
}
#page_top .notice {background:#FFF;padding:2em;--width:170px;}
#page_top .notice dl {
	display:flex;
	width: 100%;
	border:solid 1px var(--accent);
	border-radius:0.5rem;
	overflow:hidden;
}
#page_top .notice dl dt {
	background-color:var(--accent);
	display:flex;
	justify-content:center;
	gap:0.5em;
	color:#FFF;
	padding:0.5em 1.5em;
	width: var(--width);
	vertical-align:middle;
	text-align:center;
	font-size:1.125rem;
	align-items:center;
}
#page_top .notice dl dt *{
	display:inline-block;
	font-weight:600;
}
#page_top .notice dl dd {
	display:flex;
	justify-content:flex-start;
	align-items:center;
	padding:0.5em 1em;
	background:#fff5ed;
	width:calc(100% - var(--width));
}
/**TOP 緊急時のお知らせ**/
.emergency {
	background:url(../img/top/cation_news_bg.gif) center top repeat-y;
	background-size: contain;
	padding:10px 0;
	margin-bottom: 10px;
}

.emergency .box {
	width:640px;
	margin:auto;
	padding:30px;
	background-color:#FFDF7D;
}

.emergency .box dl {
	padding-left:20px;
	position: relative;
	border-left:2px solid #444444;
	margin-left:60px;	 
}
.emergency .box dl:before {
	content:"";
	display:block;
	background: url(../img/top/cation_news_icon.png) left center no-repeat;
	width:47px;
	height:45px;
	position:absolute;
	left: -65px;
	top:0;
	bottom:0;
	margin:auto 0;
}
.emergency .box dl dt {
	color: #dd2200;
	font-weight:bold;
}
:root .notice dl dd a,
:root .emergency .box a{
	color:#dd2200;
	font-weight: bold;
	text-decoration:underline solid 1px;
}
:root .notice dl dd a:hover,
:root .emergency .box a:hover{
	text-decoration-color:transparent;
}

@media screen and (max-width:760px) {
	.emergency{
		padding:5px;

	}
	.emergency .box {
		width:100%;
		box-sizing:border-box;
		padding: 8px;
	}
	.emergency .box dl{
		margin:0;
		border:none;
		padding: 30px 0 0;
	}
	.emergency .box dl:before{
		left: 0;
		right: 0;
		width:100%;
		background-position:center;
		background-size:contain;
		top: -5px;
		/* width:16px; */
		/* height:16px; */
		bottom:  auto;
	}
	.emergency .box dl dd{
		font-size:0.825rem;
	}
}
/******* コンテンツ1　*******/
#page_top .content01 {
	margin: 30px auto 10px;
}
/**　カレンダー　**/
#page_top .content01 .col_02 .left_area {
	width: 340px;
	float: left;
}
#page_top .content01 .col_02 #calendar {/*display: none;*/}
#page_top .content01 .col_02 #calendar table {
	width:100%;
	font-size:12px;
	border:1px solid #9E9E9E;
	max-width: 320px;
}
#page_top .content01 .col_02 #calendar table th {
	text-align:center;
	background-color:#999999;
	color:#FFF;
	width:42px;
	border:1px solid #E9E7E7;
}
#page_top .content01 .col_02 #calendar table th:nth-child(6) {
	background-color:#369;
	color:#fff;
}
#page_top .content01 .col_02 #calendar table th:nth-child(7) {
	background-color:#d30;
	color:#fff;
}
#page_top .content01 .col_02 #calendar table td {
	border:1px solid #E9E7E7;
	padding:5px;
	/* height:35px; */
	padding-bottom: 25px;
	vertical-align:top;
	position:relative;
}
#page_top .content01 .col_02 #calendar table td.event{
	padding:0;
}

#page_top .content01 .col_02 #calendar table td.event a{
	padding:5px;
	padding-bottom: 25px;
	vertical-align:top;
	position:relative;
	display:block;
	background:#ffe9f9;
	text-decoration:underline;
	color:#880000;
}
#page_top .content01 .col_02 #calendar table td.event a:hover{
	background:#f9d0e6;
	text-decoration:none;
	color:#000;
}
#page_top .content01 .col_02 #calendar table td.holiday {
	background-color:#FFFFBF;
	color:#333;
}
#page_top .content01 .col_02 #calendar table td.holiday span{
	background-color:#FFFFBF;
}
#page_top .content01 .col_02 #calendar table td.event.holiday a{
	background-color:#FFFFBF;	
}
#page_top .content01 .col_02 #calendar table td.event.holiday a:hover{
	background-color:#FFFFBF;	
}

#page_top .content01 .col_02 #calendar table td span{
	position:absolute;
	left:10px;
	top:25px;
}
#page_top .content01 .col_02 #calendar table td.label img {
	width:24px;
	height:24px;
	position:absolute;
	right:3px;
	bottom:3px;
}
#page_top .content01 .col_02 #calendar .box {
	position:relative;
	font-size:14px;
	margin-bottom:5px;
	max-width: 320px;
}
#page_top .content01 .col_02 #calendar .box .left {
	float:left;
	padding-top:5px;
}
#page_top .content01 .col_02 #calendar .box .center {
	position:absolute;
	width:50%;
	left:0;
	right:0;
	top:0;
	margin:auto;
	text-align:center;
}
#page_top .content01 .col_02 #calendar .box .center span {
	font-size:20px;
}
#page_top .content01 .col_02 #calendar .box .right {
	float: right;
	padding-top:5px;
}
.calendar_caption{
	margin: 10px 0;
}
.calendar_caption li{
	display:inline-block;
	font-size:14px;
	margin-bottom:5px;
	text-indent:-40px;
	margin-left:40px;
	margin-right: 4px;
	letter-spacing:-0.03em;
}
.calendar_caption li img{
	width:24px;
	height:auto;
	margin-right:4px;
}
@media screen and (max-width:760px) {
	#page_top .content01 .col_02 .left_area {
		width:auto;
		margin:0 10px 30px;;
		float: none;
	}
	#page_top .content01 .col_02 #calendar .fix,
	#page_top .content01 .col_02 #calendar table{
		max-width:100%;
	}
}

/****　スライダー　*****/
#page_top .content01 .col_02 .right_area,
#page_top .zoobo_wrap {
	width:730px;
	float: right;
	margin-bottom: 50px;
	/* float: none; */
	margin: 0 auto 50px;
}
#page_top .content01 .col_02 .right_area .bg_area {
	text-align:center;
	background-color:#000000;
	padding: 0;
	margin-bottom: 40px;
	box-shadow: 0px 0px 20px 8px rgba(0, 0, 0, 0.12);
}
#page_top .content01 .col_02 .right_area + .zoobo_wrap{
	clear:both;
	margin: 0 0 50px;
	float: none;
	width: auto;
}

@media screen and (max-width:760px) {
	#page_top .content01 .col_02 .right_area {
		width:auto;
		float: none;
		padding:0;
		margin-bottom: 40px;
	}
	#page_top .content01 .col_02 .right_area .bg_area {
		box-shadow: 0px 0px 15px 5px rgba(0, 0, 0, 0.17);
	}
	#page_top .content01 .col_02 .right_area + .zoobo_wrap{
		margin:0 10px 50px
	}
}

/******* コンテンツ2　*******/


/******* コンテンツ3　*******/
#page_top .content03 {
	margin-bottom:50px;
	overflow:hidden;
	padding: 30px 0 60px;
	position:relative;
}
#page_top .content03:after {
	position:absolute;
	content:"";
	width:100%;
	background:url(../img/top/bg_news.png) center center no-repeat;
	height: 90px;
	bottom:40px;
	left:0;
	z-index:1;
}

#page_top .content03 .news_box .blogs_wrap{
    -moz-box-shadow:none;
    -webkit-box-shadow:none;
    -ms-box-shadow:none;
    box-shadow:none;
    padding-left:0;
    padding-right:0;
    background: none;
}

/****　新着のお知らせ　*****/
#page_top .content03 .left_area {
	width:760px;
	position:relative;
	/*height:575px;*/
}
#page_top .content03 .left_area:before {
	content:"";
	display:block;
	position:absolute;
	width:247px;
	height:398px;
	background:url(../img/top/news_bg_left.jpg) no-repeat;
	left: -90px;
	bottom:10%;
	z-index:-3;
}
#page_top .content03 .left_area:after {
	content:"";
	display:block;
	position:absolute;
	width:247px;
	height:398px;
	background:url(../img/top/news_bg_right.jpg) no-repeat;
	right: -50px;
	bottom:10%;
	z-index:-3;
}
.news_box ul.category{
	display:flex;
	width:100%;
	margin-bottom:4em;
	border-radius:15px;
	overflow:hidden;
	box-shadow:0 0 15px rgba(0,0,0,0.05)
}
.news_box ul.category:after{
	display:none;
}
.news_box .category li {
    font-weight: bold;
    color: #fff;
    position: relative;
	z-index:20;
	cursor: pointer;
	flex-basis:50%;
}
.news_box .category li:hover,
.news_box .category li.select {
	z-index:65;
}
.news_box .category li:nth-child(n+2){
	border-left:solid 1px #e9e9e9;
}
.news_box .category li span{
    display: flex;
    text-align: center;
	color:#333333;
	background:#fff;
    cursor: pointer;
	align-items:center;
	justify-content:center;
	min-height:3.5em;
	padding:0.25em;
	transition:all ease 0.3s; 
}
.news_box .category li:hover span,
.news_box .category li.select span {
	background:#33691e;
	color:#fff;
}

/*****/
.news_box .blogs_wrap {
-moz-box-shadow: 0px 0px 27px 7px rgba(0, 0, 0, 0.22);
-webkit-box-shadow: 0px 0px 27px 7px rgba(0, 0, 0, 0.22);
-ms-box-shadow: 0px 0px 27px 7px rgba(0, 0, 0, 0.22);
box-shadow: 0px 0px 27px 7px rgba(0, 0, 0, 0.22);
    margin-top: -6px;
    padding: 35px 30px 5px;
	position:relative;
	z-index:55;
	background: rgba(255,255,255,0.7);
}
.news_box .blogs_wrap .hide {
    display: none;
}
/***ニュース一覧***/
.news_box .blogs_wrap ul {
	margin-bottom:2em;	
}
.news_box .blogs_wrap ul li{
	border-bottom:1px solid #BBBBBB;
}
.news_box .blogs_wrap ul li a {
	width:100%;
	text-align:left;
	padding:0.5em 0;
	display:flex;
	align-items:center;
	min-height: 4em;
	transition:background .4s,color .4s;
}
.news_box .blogs_wrap ul li a:hover {
	background:#fff;
	color:#33691e;
}
.news_box .blogs_wrap dl{
	display:table;
	width:100%;
}
.news_box .blogs_wrap dl:after{
	content:none;
	display:none;
}
.news_box .blogs_wrap dl dt {
	display:table-cell;
	width:150px;
	padding-left:0;
}
.news_box .blogs_wrap dl dd {
	display:table-cell;
}
.blogs_wrap dl dd.ct_pre,
.blogs_wrap dl dd.ct_zoo,
.blogs_wrap dl dd.ct_gad,
.blogs_wrap dl dd.ct_cyc {
	width:115px;
	text-align:center;
	font-size:88%;
	color:#FFF;
	font-weight:bold;
}
.blogs_wrap dl dd[class*="ct_"] span{
	border-radius:50px;
	display:block;
	background:#1665ab;
}
.blogs_wrap dl dd.ct_pre span { background:#33691e; }
.blogs_wrap dl dd.ct_zoo span { background:#c34902; }
.blogs_wrap dl dd.ct_gad span { background:#457f10;}
.blogs_wrap dl dd.ct_cyc span { background:#c3730b;}
.blogs_wrap dl dd[class*="ct_"] + dd{
	padding-left:2em;
}

@media screen and (max-width:760px) {
	#page_top .content03 .left_area,
	#page_top .content03 .right_area {
		width:auto;
		float: none;
	}
	.news_box .blogs_wrap{
		padding: 0;
	}
	#page_top .content03 .left_area .title_01 span{
		font-size:26px;
		margin:  0;
	}
	#page_top .content03 .left_area .title_01 span:before{
		left:12px;
		top: -12px;
		background-size:  35px;
		width:  35px;
	}
	.news_box .category{
		width:100%;
		display:table;
		table-layout:fixed;
	}
	.news_box .category li{
		display:table-cell;
		width:20%;
		float:none;
		vertical-align:top;
	}
	.news_box .category:after{
		display:none;
	}
	.news_box .category li span {
		font-size: 0.65rem;
		font-weight:400;
		line-height: 1.1;
		display:flex;
		align-items:center;
		justify-content:center;
		height:40px;
	}
	.news_box .blogs_wrap dl dt {
		display:inline-block;
		width:10em;
		padding:0;
		font-size: 0.675rem;
		vertical-align: text-top;
	}
	.blogs_wrap dl dd[class*="ct_"] {
		display:inline-block;
		width: 90px;
		font-weight:400;
		line-height:1;
		vertical-align:top;
	}
	.blogs_wrap dl dd[class*="ct_"] span{
		font-size: 0.675rem;
		padding:0.25em;
	}
	.news_box .blogs_wrap dl dd:not([class*="ct_"]) {
		display:block;
		padding:0;	
		font-size:0.785rem;
		width:auto;
		line-height:1.5;
		vertical-align:middle;
		margin-top:0.5em;
	}
	#page_top .content03:after {
		display:none;
	}
}

/****　Twitter　*****/
#page_top .content03 .col_02 .right_area {
	width:320px;
}
/***タイトル****/
#page_top .content03 .right_area .title_01.bule {
	background: url(../img/common/title_bg_left02.png) left center repeat-y , url(../img/common/title_bg_right02.png) right center repeat-y;
}
#page_top .content03 .right_area .title_01.bule span {
	background-color:#1CA0F1;
	color:#fff;
}
#page_top .content03 .right_area .title_01 span {
	vertical-align: middle;
}
#page_top .content03 .right_area .title_01 svg {
    width: 40px;
	height: 40px;
    vertical-align: sub;
    padding-right: 13px;
}
#page_top .content03 .right_area .title_01 .st0{ fill:#FFFFFF; }
#page_top .content03 .right_area .title_01 .st1{ fill:#1DA1F2; }
#page_top .content03 .right_area .text {
	text-align:center;
	color:#1A9FF1;
	margin-bottom:20px;
	/*font-size:18px;*/
	font-size:113%;
}
#page_top .content03 .right_area .text::selection {
	background: #FFAE10;
}
#page_top .content03 .right_area .text::-moz-selection {
	background: #FFAE10;
}

@media screen and (max-width:760px) {
	#page_top .content03{
		padding-bottom:0;
		margin-bottom: 0;
	}

	#page_top .content03 .col_02 .right_area {
		width:auto;
	}
	#page_top .content03 .col_02 .right_area .frame_wrap{
		margin:0 15px;
	}
}
#page_top .sp_scroll{
	margin: 0 auto 3.25em;
}
#page_top .sp_scroll .scrollable{
	overflow-x: auto;
	overflow-y: clip;
	text-align:center;
	font-size:0;
	white-space:nowrap;
	padding: 1em 0 1em;
}
#page_top .sp_scroll .scrollable{
	
}
#page_top .sp_scroll .scrollable::-webkit-scrollbar {
	height: 8px;
}
#page_top .sp_scroll .scrollable::-webkit-scrollbar-track {
	border-radius: 8px;
	background: #e8e8e8;
}
#page_top .sp_scroll .scrollable::-webkit-scrollbar-thumb {
	border-radius: 8px;
	background: #b3b2b2;
}
#page_top .sp_scroll .scrollable > *{
	display: inline-block;
	vertical-align:top;
	font-size: 1rem;
}
#page_top .sp_scroll .scrollable > * + *{
	margin-left:10px;
}
#page_top .sp_scroll .scrollable > a{
	transition:opacity .4s, transform .4s;
}
#page_top .sp_scroll .scrollable > a:hover{
	opacity:0.7;
	transform:translateY(2px);
}
@media screen and (max-width:760px) {
	#page_top .sp_scroll .scrollable::-webkit-scrollbar {
		height: 4px;
	}
	#page_top .sp_scroll .scrollable::-webkit-scrollbar-track {
		border-radius: 4px;
	}
	#page_top .sp_scroll .scrollable::-webkit-scrollbar-thumb {
		border-radius: 4px;
	}
}
/******* コンテンツ4　動物園植物園 *******/
#page_top .sp_scroll .scrollable > *{
	display: inline-block;
	vertical-align:top;
	font-size: 16px;
}
#page_top .sp_scroll .scrollable > * + *{
	margin-left:10px;
}
#page_top .sp_scroll .scrollable > a{
	transition:opacity .4s, transform .4s;
}
#page_top .sp_scroll .scrollable > a:hover{
	opacity:0.7;
	transform:translateY(2px);
}
@media screen and (max-width:760px) {
	#page_top .sp_scroll{
		margin: 0 0 1.5em;
	}
}

/****　　*****/

/******* コンテンツ5　園内案内 *******/
#page_top .content05 {
	margin-bottom: 60px;
	/* min-width:1100px; */
}
#page_top .content05 ul li {
	width: 25%;
	float:left;
	position:relative;
}
#page_top .content05 ul li a {
	display:block;
	margin:0 5px;
	transition: all ease 0.3s;
	
}
#page_top .content05 ul li a img {
	width:100%; height:auto;
	transition: all ease 0.3s;
}
#page_top .content05 ul li .text {
    position: absolute;
    bottom: 0;
    left: 0;
	right: 0;
	margin: 0 auto;
    background: rgba(0,0,0,0.5);
    width:calc(100% - 10px);
    color: #fff;
	z-index:20;
    padding: 8px 0;
    text-align: center;
    font-size: 22px;
	font-size:138%;
	text-shadow:0 0 4px black,0 0 8px black;
	transition: all ease 0.3s;
    box-sizing: border-box;
	-webkit-box-sizing: border-box;	
}

/***画像　ホバー***/
#page_top .content05 ul li a .img {
	overflow:hidden;
	border-radius:5px;
}
#page_top .content05 ul li a img {
	-webkit-transform: scale(1);
	transform: scale(1);
	-webkit-transition: .3s ease-in-out;
	transition: .4s ease-in-out;
}
#page_top .content05 ul li a:hover img,
#page_top .content05 ul li a:focus img {
	-webkit-transform: scale(1.1);
	transform: scale(1.1);
}
#page_top .content05 ul li.last .img img {
	-webkit-transform:none;
	transform:none;
	-webkit-transition:none;
	transition: none;
}
#page_top .content05 ul li.las a:hover .img img,
#page_top .content05 ul li.las a:focus .img img {
	-webkit-transform: none;
	transform:none;
}
/****/

#page_top .content05 ul li .zoobo {
	position:absolute;
	width:15%;
	left:0;
	right:0;
	top:18%;
	margin:0 auto;
}
#page_top .content05 ul li .zoobo img {
	width:100%;
	height:auto;
}

@media screen and (max-width:760px) {
	#page_top .content05 {
		min-width:0;
		margin-bottom: 30px;
	}
	#page_top .content05 ul{
		margin: 0 5px;
	}
	#page_top .content05 ul li {
		width:49%;
		margin-bottom:10px;
	}
	#page_top .content05 ul li:nth-child(odd){
		margin-right: 2%;
	}	
	#page_top .content05 ul li a{
		margin:0;
	}
	#page_top .content05 ul li a .img {
		border-radius:0;
	}
	#page_top .content05 ul li .text {
		font-size:12px;
		bottom:0;
		width:  100%;
	}
}
/******* コンテンツ6　オフィシャルブログ *******/
#page_top .content06 {
	margin-bottom: 0;
	padding: 50px 0 0;
	overflow:hidden;
}

/***タイトル背景***/
#page_top .content06 .bg {
	position:relative;	
}
#page_top .content06 .bg:before {
    content:none;
}
#page_top .content06 .bg:after {
    content:none;
}


/**一覧**/
#page_top .content06 .col_4 {
	margin-bottom:30px;
}
#page_top .content06 .col_4 .col_child {
    width: 260px;
    padding:0;
	margin-right:20px;
}
#page_top .content06 .col_4 .col_child:first-child {
    padding:0;
}
#page_top .content06 .col_4 .col_child:last-child {
    padding:0;
	margin-right:0;
}

#page_top .content06 .col_4 a {
	text-decoration:none;
}
#page_top .content06 .wrap a{
	display:block;
	width:262px;
}
#page_top .content06 .wrap .pht_wrap{
	margin-bottom:10px;
	box-shadow:0 1px 10px rgba(0,0,0,0.05);
}
#page_top .content06 .wrap .pht_wrap ~ p{
	text-align:left;
	display:block;
	white-space:normal;
}
#page_top .content06 .wrap .pht_wrap ~ p.day{
	font-size:88%;
}
#page_top .content06 .wrap .pht_wrap ~ p.text{
	text-decoration: underline;
	min-height: 3em;
}

#page_top .content06 .wrap a:hover .text,
#page_top .content06 .wrap  a:focus .text {
	text-decoration:none;
}

@media screen and (max-width:760px) {
	#page_top .content06 .bg:before {
		width: 103px;
		height: 120px;
		background-size:contain;
		left: 0;
		top: -70px;
	}
	#page_top .content06 .bg:after {
		width: 103px;
		height: 120px;
		background-size:contain;
		right: 0;
		top: -70px;
		z-index: -3;
	}
	#page_top .content06 .title_01 span:before {
		width:33px;
		height:48px;
		background-size:cover;
		left:10px;
		top:-10px;
	}
	#page_top .content06 .wrap a{
		display:block;
		width:184px;
		font-size:12px;
	}
	#page_top .content06 .wrap .pht_wrap ~ p.text{
		min-height:3em;
	}
}


/******* コンテンツ7　スペシャルコンテンツ *******/
#page_top .content07 {
	margin-bottom:50px;
	padding-top:30px;
}

#page_top .content07 .box01 {
	position:relative;
}
#page_top .content07 .box01 .text {
	position: absolute;
	width:358px;
	height:70px;
	left:6%;
	top:0;
	bottom:0;
	margin:auto;
}

#page_top .content07 .box02 {
	background-color:#E2E2E2;
	padding:20px;
}
#page_top .content07 .box02 .text {
	float: left;
	width:410px;
	text-align:center;
	background-color:#FFF;
}
#page_top .content07 .box02 .text img {
	display:inline-block;
	padding:53px 0;
}
#page_top .content07 .box02 .img {
	float: right;
}

@media screen and (max-width:760px) {
	#page_top .content07 .box01 .text {
		position: static;
		width:auto;
		padding: 10px 20px 10px;
		text-align:  center;
		background:#000;
		/* height:70px; */
		left:auto;
		top:auto;
		bottom:auto;
	}
	#page_top .content07 .box02 {
		padding:10px;
	}	
	#page_top .content07 .box02 .text {
		float: none;
		width:auto;
		text-align:center;
		padding:0 20px;
		background-color:#FFF;
	}
	#page_top .content07 .box02 .text img{
		padding:10px 0;
	}
}

/******* コンテンツ8　動画 *******/
#page_top .content_yt .wrap a{
	display:block;
}
#page_top .content_yt .wrap a span{
	position:relative;
	display: block;
}
#page_top .content_yt .wrap a span:after{
    content:"";
    width:61px;
    height:43px;
    display:inline-block;
    position:absolute;
    top:0;
	bottom:0;
	margin:auto;
    left:0;
    right:0;
	background:url(../img/common/ico_ytb.png) top center no-repeat;
}
#page_top .content_yt .wrap a img{
	display:block;
	width:268px;
}
#page_top .content_yt .wrap a p{
	margin:10px 0 0;
	text-align:left;
	line-height: 1.2;
}
#page_top .content08 {
	margin-bottom:50px;
	background:url(../img/top/content08_bg.jpg) top center no-repeat;
	background-size:cover;
	height:900px;
	display:table;
	width:100%;
}
#page_top .content08 .inner {
	text-align:center;
	display:table-cell;
	vertical-align:middle;
}
#page_top .content08 h2 {
	font-size:40px;
	color:#478A33;
	margin-bottom:20px;
}
#page_top .content08 h2 span {
	display:inline-block;
	padding:0 80px;
	padding-bottom:10px;
	background:url(../img/top/content08_title_border.jpg) left bottom repeat-x;
	text-shadow: 2px 2px 0px #FFF, -2px 2px 0px #FFF, 2px -2px 0px #FFF, -2px -2px 0px #FFF;
}
#page_top .content08 .text {
    margin-bottom: 30px;
    font-size: 113%;
    background-color: #FFF;
    width: 500px;
    display: inline-block;
    padding: 4px;
    border-radius: 15px;
    box-sizing: border-box;
}

#page_top .content08 .btn_01 a {
	display:inline-block;
	background-color:#FFF;
	margin-bottom:30px;
    -moz-box-shadow: 0px 0px 37px 3px rgba(0, 0, 0, 0.17);
    -webkit-box-shadow: 0px 0px 37px 3px rgba(0, 0, 0, 0.17);
    -ms-box-shadow: 0px 0px 37px 3px rgba(0, 0, 0, 0.17);
    box-shadow: 0px 0px 37px 3px rgba(0, 0, 0, 0.17);
}
/****/
#page_top .content08 .btn_02 a {
	display:block;
	width:300px;
	background-color:#D02121;
	border: 1px solid #D02121;
    -moz-box-shadow: 0px 0px 37px 3px rgba(0, 0, 0, 0.17);
    -webkit-box-shadow: 0px 0px 37px 3px rgba(0, 0, 0, 0.17);
    -ms-box-shadow: 0px 0px 37px 3px rgba(0, 0, 0, 0.17);
    box-shadow: 0px 0px 37px 3px rgba(0, 0, 0, 0.17);
	color:#FFF;
	margin:auto;
	border-radius:5px;
	padding:5px;
	padding-left: 26px;
	box-sizing:border-box;
	transition:all ease 0.3s;
}
#page_top .content08 .btn_02 a:before {
	content:"";
	display:block;
	width:33px;
	height: 38px;
	position:absolute;
	background:url(../img/top/content08_youtube_logo.png) no-repeat;
	transition:all ease 0.3s;
	z-index:20;
}
#page_top .content08 .btn_02 a span {
	display:inline-block;
	padding:7px 0;
	padding-left:30px;
	border-left:1px solid #FFF;
	font-size:18px;
	position:relative;
	margin-left: 15px;
	transition:all ease 0.3s;
}
#page_top .content08 .btn_02 a span:before{
	content:"";
	display:block;
	width:1px;
	height: 41px;
	position:absolute;
	background-color: #951717;
	left: -2px;
	top:0;
	bottom:0;
	margin:auto;
	z-index: 105;
	transition:all ease 0.3s;
}
/***　ホバー　***/
#page_top .content08 .btn_02 a:hover,
#page_top .content08 .btn_02 a:focus {
	background-color:#FFF;
	
}
#page_top .content08 .btn_02 a:hover:before,
#page_top .content08 .btn_02 a:focus:before {
	background: url(../img/top/content08_youtube_logo_on.png) no-repeat;
}
#page_top .content08 .btn_02 a:hover span,
#page_top .content08 .btn_02 a:focus span {
	border-left:1px solid #D02121;
	color: #D02121;
}
#page_top .content08 .btn_02 a:hover span:before,
#page_top .content08 .btn_02 a:focus span:before{
	background-color: #FFF;

}
#page_top .content08 .btn_02 a:active {
	position:relative;
	top:3px;
	-moz-box-shadow:none;
-webkit-box-shadow:none;
-ms-box-shadow:none;
box-shadow:none;
}

@media screen and (max-width:760px) {
	#page_top .content08 {
		margin-bottom:40px;
		height:450px;
	}
	#page_top .content08 h2 {
		font-size:26px;
		color:#478A33;
		text-align: center;
		margin-bottom:20px;
	}
	#page_top .content08 h2 span {
		padding:10px;
		padding-bottom:10px;
	}
	#page_top .content08 .text {
		padding:0 10px;
		text-align:left;
		font-size:100%;
		width:90%;
	}
	#page_top .content08 .btn_01 {
		padding:0 10px;
	}	
	#page_top .content08 .btn_02 {
		margin-bottom:10px;
	}		
}

/******* コンテンツ9　Instagram *******/
#page_top .content09 {
	margin-bottom:50px;
    padding-top: 30px;
}
#page_top .content09 a{
	display:block;
	width:100%;
	height:0;
	padding-bottom:100%;
	position:relative;
	overflow:hidden;
}
#page_top .content09 a img{
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  width: auto;
  height: 100%;
  max-width:inherit;
  max-width:initial; 
}
#page_top .content09 a:hover img,
#page_top .content09 a:focus img {
	opacity:0.6;
}




/******* コンテンツ10　Instagram *******/
#page_top .content10 {
	margin-bottom:0;
    padding-top:0;
}

#page_top .content10 .col_02 {
	background:url(../img/top/content10_bg.gif) left top repeat;
	border-radius:10px;
	overflow:hidden;
}
#page_top .content10 .col_02 .left_area {
	color:#FFF;
	width:320px;
	display:table;
}
#page_top .content10 .col_02 .left_area .inner {
	display:table-cell;
	vertical-align:middle;
	padding-left: 0;
	text-align: center;
}
#page_top .content10 .col_02 h3 {
	font-size:26px;
	margin-bottom:5px;
}
#page_top .content10 .col_02 p.text {

}
#page_top .content10 .col_02 .right_area {
	background-color:#FFF;
}


@media screen and (max-width:760px) {
	#page_top .content09 h2 img {
		width:150px;
		height:auto;
	}
	#page_top .content09 #no_slider div {
		width:33.3%;
		float:left;
	}
	#page_top .content10 .col_02 .left_area {
		width:40%;
		float:left;
	}
	#page_top .content10 .col_02 .left_area .inner {
		padding:10px;
		box-sizing: border-box;
		width: 100%;
	}
	#page_top .content10 .col_02 .left_area .inner h3{
		margin:0;
		padding:27px 0;
	}
	#page_top .content10 .col_02 .right_area {
		float:right;
		width:60%;
		display:block;
		overflow:hidden;
	}
	#page_top .content10 .col_02 .right_area img{
		width:auto;
		height: 100px;
	}
	#page_top .content10 .col_02 h3 {
		font-size:18px;
		margin-bottom: 0;
		text-align:center;
	}
	#page_top .content10 .col_02 p.text br{
		display:none;

	}
	#page_top .content10 .col_02 {
    margin: 0 10px;
	height: 100px;
	}
}


/******* コンテンツ11　ご案内 *******/
#page_top .content11 {
	margin-bottom:50px;
    padding-top: 30px;
}

#page_top .content11 .col3 .left,
#page_top .content11 .col3 .center,
#page_top .content11 .col3 .right {
	float:left;
	width:360px;
	margin-right:10px;
	border-radius:5px;
	height:160px;
	display:table;
	overflow:hidden;
}
#page_top .content11 .col3 .right {
	margin-right:0;
}
#page_top .content11 .col3 .right:first-child:last-child{
	width:100%;
}
#page_top .content11 .col3 .left a {
	background: url(../img/top/content11_bgimg_01.png) center 5% no-repeat , url(../img/top/content11_bg_01.png) left top repeat;
}
#page_top .content11 .col3 .center a {
	background: url(../img/top/content11_bgimg_02.png) center 5% no-repeat , url(../img/top/content11_bg_02.png) left top repeat;
}
#page_top .content11 .col3 .right a {
	background: url(../img/top/content11_bgimg_03.png) center 5% no-repeat , url(../img/top/content11_bg_03.png) left top repeat;
}
#page_top .content11 .col3 a {
	padding:10px 15px;
	display:table-cell;
	vertical-align:middle;
	margin:auto;
	text-align:center;
	color:#FFF;
}
#page_top .content11 .col3  a:hover,
#page_top .content11 .col3  a:focus {
	opacity:0.6;
}
#page_top .content11 .col3 h3 {
	font-size:22px;
	font-size:138%;
	margin-bottom:5px;
}


@media screen and (max-width:760px) {
	#page_top .content11 .col3{
		margin:0 10px;
	}
	#page_top .content11 .col3 .left,
	#page_top .content11 .col3 .center,
	#page_top .content11 .col3 .right {
		float:none;
		width:100%;
		margin:0 0 10px;
		height:100px;
	}
	#page_top .content11 .col3 .right{
		margin:0;
	}
}



/******* コンテンツ12　ご観覧時の注意事項 *******/
#page_top .content12 {
	margin-bottom:50px;
	background: url(../img/top/cation_news_bg.gif) center top repeat-y;
	background-size: contain;
	padding: 10px 0;
}
#page_top .content12 .box {
    width: 640px;
    margin: auto;
    padding: 30px 0;
    background-color: #FFDF7D;
}
#page_top .content12 .box h2 {
	font-size:24px;
	font-weight:bold;
	text-align:center;
}
#page_top .content12 .box h2 span {
	position:relative;
	padding-left:30px;
}
#page_top .content12 .box h2 span:before {
	content:"";
	position:absolute;
	z-index:8;
	display:block;
	width:50px;
	height:45px;
	left:-45px;
	bottom:-5px;
	background:url(../img/top/content12_icon.png) no-repeat;
}

@media screen and (max-width:760px) {
	#page_top .content12 .box {
		width: auto;
		padding: 30px 10px;
	}
	#page_top .content12 .box h2 {
		font-size:min(1.25rem,5.25vw);
		text-align:left;
	}
	#page_top .content12 .box h2 span{
		padding-left:25px;
	}
	#page_top .content12 .box h2 span:before {
		width:20px;
		height:18px;
		left:0;
		bottom: 0;
		background-size:cover;
	}
	#page_top .content12{
		position:relative;
	}
	#page_top .content12:after{
		content:"";
		display:inline-block;
		width: 8px;
		height: 8px;
		z-index:5;
		border-top:solid 2px #333;
		border-right:solid 2px #333;
		transform:rotate(45deg) skew(7deg,7deg);
		vertical-align:middle;
		margin:auto;
		position:absolute;
		right: 18px;
		top:0;
		bottom:0;
		border-radius:2px;
		transition:border .4s;
	}
}

/******* コンテンツ13　広告掲載 *******/
#page_top .content13{
	padding-top:50px;
}
#page_top .content13 ul {
	text-align:center;
	/* width:80%; */
	margin:auto;
	margin-bottom:20px;
}
#page_top .content13 ul li {
	display:inline-block;
	vertical-align:top;
	margin:0 5px;
	margin-bottom:12px;
}

@media screen and (max-width:760px) {
	#page_top .content13 ul {
		width:auto;
		margin: 0 0px 10px;
		display:flex;
		justify-content:center;
		gap:2%;
		flex-wrap:wrap;
	}
	#page_top .content13 ul:after{
		display:none;
	}
	#page_top .content13 ul li {
		display:block;
		max-width:49%;
		float:none;
		margin:0 0 2%;
	}
	#page_top .content13 ul li:nth-child(even) {
		margin-left:0;
	}
	#page_top .content13 ul li img{
		max-width:100%;
		height:auto;
		width:auto;
	}
	#footer {
		font-size:14px;
	}
}

/*20200210*/
#page_top .b_menu .box {
    width: 100%;
    z-index: 50;
}
#page_top .b_menu .box li{
	display: inline-block;
    margin: 0 5px;
    position: relative;
}
#page_top .b_menu ul li.one:before {
    background-image: url(../img/top/main_nav_icon_01.png);
    left: -35px;
    bottom: -5px;
}
#page_top .b_menu .box ul li a, #page_top .lang_box .box ul li a {
    display: block;
    text-align: center;
    max-width: 100%;
    padding: 15px 5px;
    color: #FFF;
    border: 1px solid rgba(0,0,0,0.1);
    background: rgba(0,0,0,0.6);
    box-sizing: border-box;
    -webkit-box-sizing: border-box;
    transition: all ease 0.3s;
}
#page_top .b_menu .box ul li.one:before, #page_top .b_menu .box ul li.one:after, #page_top .b_menu .box ul li.two:before, #page_top .b_menu .box ul li.two:after, #page_top .b_menu .box ul li.three:before, #page_top .b_menu .box ul li.three:after, #page_top .b_menu .box ul li.four:before {
    content: "";
    position: absolute;
    display: block;
    width: 40px;
    height: 40px;
    z-index: 70;
    background-repeat: no-repeat;
}

#page_top .b_menu .box ul li.one:after {
    background-image: url(../img/top/main_nav_icon_02.png);
    left: 10px;
    top: -20px;
}
#page_top .b_menu .box ul li.two:before {
    background-image: url(../img/top/main_nav_icon_03.png);
    left: -15px;
    bottom: 3px;
}
#page_top .b_menu .box ul li.two:before {
    background-image: url(../img/top/main_nav_icon_03.png);
    left: -15px;
    bottom: 3px;
}
#page_top .b_menu .box ul li.two:after {
    background-image: url(../img/top/main_nav_icon_04.png);
    right: -30px;
    bottom: 8px;
}
#page_top .b_menu .box ul li.three:before {
    background-image: url(../img/top/main_nav_icon_05.png);
    right: 50px;
    top: -23px;
}
#page_top.b_menu .box ul li.three:after {
    background-image: url(../img/top/main_nav_icon_06.png);
    right: -30px;
    bottom: 5px;
}
#page_top .b_menu .box ul li.four a span {
    right: 30px;
}
#page_top .b_menu .box ul li.four:before {
    background-image: url(../img/top/main_nav_icon_07.png);
    right: -25px;
    top: -15px;
}
#page_top .content11 .col3.mb,#page_top .content10.mb{
	margin-bottom:20px;
}
#page_top .content10 {
    background: url(../img/top/bg_education.jpg) no-repeat;
    background-position:right center;
}
#page_top .content10.plan {
    background-image: url(../img/top/bg_evolution.jpg);
    margin-bottom: 80px;
}
#page_top .content10 .half_wrap{
	min-height:410px;
	display:flex;
	align-items:center;
	margin-bottom: 0;
	padding-right:50%;
}
#page_top .content10 .half_wrap .inner{
	width:100%
}
#page_top .content10 .yumin{
	color: #e03400;
	text-align:center;
	font-weight:bold;
	margin-bottom:15px;
}
#page_top .content10.plan .yumin{
	color:#219fe7;
}
#page_top .content10 .yumin{
	font-size:23px;
	line-height:1.2;
}
#page_top .content10 .yumin ruby{
	font-size:178%;
}
#page_top .content10 .yumin ruby rt{
	font-size:12px;
}
#page_top .content10 .yumin b{
	font-size:119%;
}

@media screen and (max-width: 760px) {
	#page_top .b_menu .box ul li.one:before,
	#page_top .b_menu .box ul li.one:after,
	#page_top .b_menu .box ul li.two:before,
	#page_top .b_menu .box ul li.two:after,
	#page_top .b_menu .box ul li.three:before,
	#page_top .b_menu .box ul li.three:after,
	#page_top .b_menu .box ul li.four:before {
		content: none;
	}
	
	#page_top .b_menu .box ul li.four span img{
		display:none;
	}
	#page_top .b_menu .box ul li{
		margin: 0;
		display: block;
		float: left;
		width: 50%;
	}
	#page_top .b_menu .box ul li a{
		width: 100%;
		font-size: 12px;
	}
	#page_top .content11 .col3.mb, #page_top .content10.mb {
		margin-bottom: 10px;
	}
	#page_top .content11{
		padding-bottom:0;
		margin-bottom:10px;
	}
	#page_top .content06 .col_4 .col_child {
		width: 49%;
		padding: 0;
		margin: 0 0 10px;
		font-size: 12px;
	}
	#page_top .content10 {
		background: #ffffff url(../img/top/bg_education_sp.png) no-repeat;
		background-size:100%;
		background-position:center bottom;
		padding: 0;
	}
	#page_top .content10.plan {
		margin-bottom:0;
	}
	#page_top .content10 .half_wrap{
		width:auto;
		min-height:0;
		display:flex;
		align-items:center;
		margin-bottom: 50px;
	}
	#page_top .content10 .half_wrap .inner{
		width:100%
	}
	#page_top .content10 .half_wrap .inner .text {
		padding:20px 10px 0;
	}
	#page_top .content10 .yumin{
		text-align:left;
		padding:0 10px;
		font-weight:bold;
		margin-bottom:0;
		text-shadow:0 0 10px #fff,0 0 10px #fff,0 0 5px #fff;
	}
	#page_top .content10 .yumin{
		font-size: 5.8vw;
		line-height:1.2;
	}
}
#page_top .zoobo_appearing{
	margin: 0;
	background: url(../img/top/content_zoobo_bg.gif) top right;
	background-repeat:repeat;
	border-radius: 10px;
	height:160px;
	overflow:hidden;
}
#page_top .zoobo_appearing .left{
	float: none;
	background-image:url(../img/top/top_zoobo.png);
	width:320px;
	height:160px;
	background-repeat:no-repeat;
	background-size:100%;
	background-position:center;
}
#page_top .zoobo_appearing .right{
	float:right;
	width: 440px;
}
#page_top .right_area + .zoobo_wrap .zoobo_appearing .right{
	width:780px;
}

#page_top .zoobo_appearing .right h3{
	text-align:center;
	font-size: 26px;
	color:#fff;
	padding: 61px 0;
    box-sizing: border-box;
}
@media screen and (max-width:760px) {
	#page_top .zoobo_wrap{
		width:auto;
		float:none;
		margin:0 10px;
	}
	#page_top .zoobo_appearing{
		margin: 0;
		height:100px;
	}
	#page_top .zoobo_appearing .left{
		background-image:url(../img/top/top_zoobo.png);
		background-color:#C4E6EE;
		width:40%;
		height:100px;
		background-repeat:no-repeat;
		background-size: contain;
		background-position:center;
	}
	#page_top .zoobo_appearing .right,
	#page_top .right_area + .zoobo_wrap .zoobo_appearing .right{
		width:60%;
	}
	#page_top .zoobo_appearing .right h3{
		font-size: 17px;
		color:#fff;
		padding: 38px 0;
		box-sizing: border-box;
	}
}


#page_top .content_yt {
	margin-bottom:30px;
}
#page_top .content_yt .box .bx-wrapper{
	padding-bottom: 40px;
	margin-bottom:30px;
}
#page_top .content_yt .box .bx-wrapper .bx-pager.bx-default-pager a{
	background:#999;
}
#page_top .content_yt .box .bx-wrapper .bx-pager.bx-default-pager a.active,
#page_top .content_yt .box .bx-wrapper .bx-pager.bx-default-pager a:hover,
#page_top .content_yt .box .bx-wrapper .bx-pager.bx-default-pager a:focus{
	background:#FB992D;
}
#page_top .content_yt .box .wrap a p{
	font-size:15px;
	margin-top:10px;
}
#page_top .content_yt .btn_02 a {
	display:block;
	width:300px;
	background-color:#D02121;
	border: 1px solid #D02121;
	-moz-box-shadow: 0px 0px 37px 3px rgba(0, 0, 0, 0.17);
	-webkit-box-shadow: 0px 0px 37px 3px rgba(0, 0, 0, 0.17);
	-ms-box-shadow: 0px 0px 37px 3px rgba(0, 0, 0, 0.17);
	box-shadow: 0px 0px 37px 3px rgba(0, 0, 0, 0.17);
	color:#FFF;
	margin:auto;
	border-radius:5px;
	padding:5px;
	padding-left: 26px;
	box-sizing:border-box;
	transition:all ease 0.3s;
	text-align: center;
}
#page_top .content_yt .btn_02 a:before {
	content:"";
	display:block;
	width:33px;
	height: 38px;
	position:absolute;
	background:url(../img/top/content08_youtube_logo.png) no-repeat;
	transition:all ease 0.3s;
	z-index:20;
}
#page_top .content_yt .btn_02 a span {
	display:inline-block;
	padding:7px 0;
	padding-left:30px;
	border-left:1px solid #FFF;
	font-size:18px;
	position:relative;
	margin-left: 15px;
	transition:all ease 0.3s;
}
#page_top .content_yt .btn_02 a span:before{
	content:"";
	display:block;
	width:1px;
	height: 41px;
	position:absolute;
	background-color: #951717;
	left: -2px;
	top:0;
	bottom:0;
	margin:auto;
	z-index: 105;
	transition:all ease 0.3s;
}
/***　ホバー　***/
#page_top .content_yt .btn_02 a:hover,
#page_top .content_yt .btn_02 a:focus {
	background-color:#FFF;
	
}
#page_top .content_yt .btn_02 a:hover:before,
#page_top .content_yt .btn_02 a:focus:before {
	background: url(../img/top/content08_youtube_logo_on.png) no-repeat;
}
#page_top .content_yt .btn_02 a:hover span,
#page_top .content_yt .btn_02 a:focus span {
	border-left:1px solid #D02121;
	color: #D02121;
}

#page_top .content_yt .bx-wrapper a:focus{
	outline:solid 2px #000;
}
#page_top #content{
	margin: 0;
	padding-block:0 35em; 
	background:url(../img/bg_foot.jpg) no-repeat bottom center / 100% auto;
	margin-bottom:-5em;
}
@media screen and (max-width:760px) {
	#page_top .bx-wrapper .bx-prev,
	#page_top .bx-wrapper .bx-next{
		width:18px;
		background-size:contain;
		height:28.5px;
	}
	#page_top .kv #kv_bnr .bx-controls-direction a{
		height: 1.5rem;
		width: 1.5rem;
		border-width:3px;
	}
	#page_top .content_yt .bx-wrapper .bx-prev {
		left: 0px;
		background: url(../img/common/sp_slidel.png) no-repeat top left;
		background-size:contain;
		width:27px;
		height:54px;
		margin-top: -27px;
	}
	#page_top .content_yt .bx-wrapper .bx-next {
		right: 0;
		background: url(../img/common/sp_slider.png) no-repeat top right;
		background-size:contain;
		width:27px;
		height:54px;
		margin-top: -27px;
	}
	#page_top .content_yt .box .wrap a{
		padding:5px;
		display:block;
		font-size:14px;
		box-sizing:border-box;
	}
	#page_top .content_yt .box .wrap a img{
		max-width:100%;
	}
	#page_top .content_yt .box .wrap a p{
		font-size:14px;
		margin-top:5px;
	}
	#page_top .content_yt {
		margin-bottom: 40px;
	}
	#page_top .content_yt .box .bx-wrapper{
		padding-bottom: 20px;
		margin-bottom:50px;
	}
	#page_top .content_yt .bx-controls.bx-has-controls-auto.bx-has-pager .bx-controls-auto{
		right:10px;

	}

}
.top_open {
	position:relative;
	z-index:1;
	overflow:visible;
}
.open_info .box{
	z-index:1;
	background:var(--keyW);
	border:solid 1px var(--keycolor);
	border-radius: 0.75rem;
	overflow:hidden;
	padding: 1.25em 1.5em;
	margin-bottom: 3em;
}
.open_info .open_data{
	width:1040px;
	position:relative;
	display:block;
	padding:0;
	border:none;
	background:none;
	max-width:100%;
	margin-inline:auto;
	z-index:1;
	--headW:190px;
	--headB:610px;
}
.open_info .open_data .data_head{
	position:absolute;
	top:0;
	left:0;
	border-right:solid 1px var(--keycolor);
	padding-right:1em;
}
.open_info .open_data .data_head h2{
	display:block;
	width:auto;
	background:none;
	color:var(--keyD);
	height:auto;
	font-size: 1.125rem;
	font-weight:700;
	margin-bottom: 0.35em;
	line-height: 1;
}
.open_info .open_data .data_head input{
	appearance:none;
	border:none;
	background:transparent;
	font-size:1.95rem;
	font-weight:600;
	width:fit-content;
	max-width:5.5em;
	letter-spacing:0em;
	font-feature-settings:normal;
}
.open_info .open_data .data{
	width:auto;
	padding:0;
	background:transparent;
	text-align:left;
	display: flex;
	flex-direction: column;
	align-items: baseline;
	justify-content: flex-start;
	min-height: 0;
	height: auto;
	border-radius:0;
}
.open_info .open_data .data > div{
	width:100%;
}
.open_info .open_data .data dl{
	line-height:1.4;
	margin-bottom:10px;
	position:relative;
	text-align:left;
	display:inline-block;
	padding-left:60px;
}
.open_info .open_data .data dl dt:before{
	content:"";
	display:inline-block;
	width:44px;
	height:44px;
	vertical-align:middle;
	background:url(../img/top/ico_h0.png);
	position:absolute;
	top:0;
	left:0;
	bottom:0;
	margin:auto;
}
.open_info .open_data .data dl dd{
	font-size:112.75%;
}
.open_info .open_data .data .time{
	line-height:1.4;
	margin-bottom:10px;
	position:relative;
	text-align:left;
	display:inline-block;
	padding-left:60px;
}
.open_info .open_data .data div.time{
	display:flex;
	align-items:center;
	justify-content:flex-start;
	position:relative;
	margin: 0 var(--headB) 0.75em var(--headW);
	padding:0.15em 0.75em;
	font-size:1.25rem;
	font-weight:700;
	min-height: 3.125em;
}
.open_info .open_data .data .data_ttl{
	background:#f0f9e8;
	padding:0.5em;
	display:flex;
	align-items:center;
	justify-content:center;
	width: calc(100%);
}
.open_info .open_data .data_ttl h3{
	font-size:1.125rem;
	font-weight:600;
	display:inline-block;
	border-bottom:solid 1px #222;
}
.open_info .open_data .data_ttl h3 #select_day{
	appearance:none;
	-webkit-appearance:none;
	border:none;
	padding:0;
	margin:0;
	display:inline-block;
	vertical-align:bottom;
	font-weight:600;
	background:transparent;
	font-size:100%;
	width: auto;
	max-width: 8.5em;
	line-height:1;
	text-align:right;
	outline:none;
	font-family:inherit;
}
.open_info .open_data .data_ttl label{
	border:solid 1px #33691e;
	border-radius:30px;
	background:#fff;
	cursor:pointer;
	padding:0.5em 1.5em;
	font-size:0.75rem;
	color:#33691e;
	margin-left:1em;
}
.open_info .open_data .data_ttl label img{
	display:inline-block;
	margin-right:0.25em;
	vertical-align:middle;
}
.open_info .open_data .edit_area{
	text-align:left;
	padding: 0.75em 1em;
	background:#fff;
	font-size:1em;
	min-height:0;
	line-height: 1.6;
}
.open_info .open_data .edit_area:empty{
	display:none;
}
.open_info .open_data .edit_area a{
	color:#ff0000;
	text-decoration:underline;
	font-weight: bold;
}
.open_info .open_data .edit_area a:hover,
.open_info .open_data .edit_area a:focus{
	text-decoration:none;
}
.open_info .data_btns{
	position:absolute;
	top:0;
	right:0;
	display:flex;
	gap:1em;
	align-items:center;
	justify-content:flex-end;
	z-index: 5;
}
.open_info .data_btns a.btn{
	width:252px;
	justify-content:center;
	padding-inline:2.5em;
	box-shadow:0 0 5px rgba(0,0,0,0.2); 
}
.open_info .data_btns label{
	display:flex;
	align-items:center;
	gap:0.25em;
	position:relative;
	z-index:1;
	--basecolor:#fff;
	--subcolor:var(--keyD);
	background:var(--basecolor);
	color:var(--subcolor);
	border-radius:2em;
	padding:0.25em ;
	border:solid 1px;
	aspect-ratio:1 / 1;
	height:100%;
	margin-right:1em;
}
.open_info .data_btns a.btn:is(:hover,:focus),
.open_info .data_btns label:is(:hover,:focus){
	/* background:var(--keyD); */
	/* color:#fff; */
}

.top_open .zoobo_area{
	position:absolute;
	bottom: -6em;
	right:-12em;
	z-index:5;
	transition:transform .4s .4s,right .4s .4s;
	transform:rotate(15deg);
	transform-origin:bottom right;
}
.top_open .zoobo_area.once{
	right:-3em;
	transform:rotate(0deg);
}
.top_open .zoobo_area a{
	display:flex;
}
.top_open .zoobo_area a .illust{
	margin-top:1.75em;
	transform-origin:bottom right;
	transition:transform .3s;
}
.top_open .zoobo_area a .illust img{
	--width:124px;
}
.top_open .zoobo_area a .btn_text{
	transform-origin:bottom right;
	transition:transform .3s;
}
.top_open .zoobo_area a .btn_text img{ 
	opacity:0;
	transform:scale(0);
	transform-origin:bottom center;
	transition:.2s .8s;
	display:block;
	--width:96px;
}
.top_open .zoobo_area.once a .btn_text img{ 
	opacity:1;
	transform:scale(1);
}

.top_open .zoobo_area a:is(:hover,:focus) .illust{
	transform:rotate(-10deg) translateX(-1em);
}
.top_open .zoobo_area a:is(:hover,:focus) .btn_text{
	transform:rotate(15deg) translate(-2em,-1.5em);
}
.news_blog {
	padding-bottom:1.25em;
}
.news_blog .tab_change{
	position:relative;
	z-index:1;
	margin-bottom: 2em;
}
.news_blog .more_link{
	position:absolute;
	top:0.35em;
	right:0;
	font-size:1.125rem;
}
#page_top .news_blog .sp_scroll .scrollable a{
	margin-bottom:0.5em
}
.calendar_caption{
	margin-top:15px;
}
.calendar_caption li{
	font-size:75%;
}
#page_top .content_guide{
	overflow:hidden;
	background:#fff;
	padding:50px 50px;
}
#page_top .content_guide .title_top02{
	border-bottom: dotted 6px #f9be00;
}
#page_top .facility_wrap{
    padding-block: 4.375em;
}
#page_top .content04 .inner{
	position:static;
	margin:0;
	transform:none;
	display:flex;
	flex-direction:column;
	gap:0.75em;
	align-items:center;
}
#page_top .content04 .inner h3{
	font-size:1.75rem;
}
#page_top .content04 a.btn{
	width:290px;
	justify-content:center;
	--basecolor:var(--keycolor);
	--subcolor:#fff;
	color:#fff;
	border:none;
	min-height:3.5em;
}
#page_top .content04 a.btn:is(:hover,:focus){
	color:var(--basecolor);
}
#page_top .content04 a.btn:is(:hover,:focus) i.arrow{
	background:var(--basecolor);
}





#layer_board_area {
	display: none;
	position: fixed;
	top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    padding: 0 3vw;
    overflow-y: auto;
    box-sizing: border-box; /*スクロールバーを非表示*/
    -ms-overflow-style: none; /*スクロールバーを非表示*/
    scrollbar-width: none; /*スクロールバーを非表示*/
    z-index: 20040;
}
#layer_board_area::-webkit-scrollbar {
	display:none; /*スクロールバーを非表示*/
}
.layer_board_bg {
	display: none;
	position: fixed;
	width: 100%;
	height: 100%;
	top: 0;
	bottom: 0;
	right: 0;
	left: 0;
	cursor: pointer;
	background: #000;
	z-index: 0;
}
/* --modalWindow ポップアップ部分-- */
.layer_board {
	display: none;
	position: relative;
	width: 95%;
	max-width: 800px;
	margin: 3em auto;
	padding: 2em ;
	border-radius: 5px;
	box-sizing: border-box;
	background: #fff;
	z-index: 10;
}
.layer_board.shortLayer {
	margin: 0;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}

/* --modalWindow バツ(閉じる)ボタン-- */
.layer_board .mdl_btn_close.circle_btn {
	position: absolute;
	top: 10px;
	right: 15px;
	width: 32px;
	height: 32px;
	box-sizing:border-box;
	background-color: #46a063;
	background-repeat: no-repeat;
	line-height: 1;
	background-position: 50%;
	border-radius: 50%;
	border: 1px solid #46a063;
	transition: .15s;
	cursor:pointer;
}
.layer_board .mdl_btn_close.circle_btn:before{
	content:"\00D7";
	color:#fff;
	font-size:16px;
	line-height:28px;
	display:flex;
	align-items:center;
	justify-content:center;
	text-align:center;
}

.layer_board .mdl_btn_close.circle_btn:hover {
	background-color: #999;
	border: 1px solid #999;
}

/* --↑必須なのはここまで↑-- */

/* --modalWindow タイトル部分-- */
.layer_borad_title {
	font-size: 200%;
	font-weight: 200;
	color: #ED344E;
}
/* --modalWindow コンテンツ部分-- */
.layer_borad_content {
	margin: 1em auto 1.5em;
}
/* --modalWindow 四角ボタン-- */
.layer_board .square_btn {
	display: block;
    position: relative;
    width:160px;
    margin: 0 auto;
    padding: 10px;
    border:2px solid #46a063;
    border-radius: 2px;
    font-size: 1.2em;
    font-weight: 400;
    color: #46a063;
    text-align: center;
    letter-spacing: 1px;
    text-decoration: none;
    transition: .15s;
}
.layer_board .square_btn:hover {
	background: #46a063;
	color: #fff;
}

.layer_board .edit_area img{
	max-width:100%;
	height:auto;
	display:block;
	margin:auto;
}
.layer_board .edit_area * + *{
	margin-top:0.5em;
}
.layer_board .edit_area a{
	color:#FF4C11;
	text-decoration:underline;
}
.layer_board .edit_area a:hover{
	text-decoration:none;
}

@media screen and (max-width:768px) {
	.layer_board {
		width: 90%;
		margin: 3em auto;
		padding: 1.5em 1em 1em;
	}
	.layer_board .mdl_btn_close.circle_btn {
		width: 26px;
		height: 26px;
	}
	.layer_board .mdl_btn_close.circle_btn:before{
		line-height:24px;
	}
}
/* 2022改修 */
#page_top .quickmenu{
	position:relative;
	z-index:10;	
}
#page_top .calendar_events{
	background:none;
	overflow: visible;
	position:relative;
	z-index:5;
	padding-block: 4.25em;
	background:var(--keyW);
}
#page_top .calendar_events:before,
#page_top .calendar_events:after{
	content:"";
	width:334px;
	height:440px;
	display:block;
	position:absolute;
	bottom:0;
	left:0;
	background-size:contain;
	z-index:-2;
}

#page_top .content01{
	margin:0 auto;
	overflow: hidden;
}

#page_top .content01 .left_area{
	float:none;
	width:auto;
	display:flex;
	align-items:center;
	justify-content:center;
	margin:10px 0  65px;
}
#page_top .content01 .calendar_caption{
	margin:0;
	margin-left:40px;
}
#page_top .today_event .site_wrapper{
	padding-bottom: 0;
}
.tit_simple{
	text-align:center;
	color:#664422;
	font-size:2rem;
	font-weight:bold;
	margin-bottom:0.5em;
}
.column_orientation{
	display:flex;
	justify-content:center;
}
#page_top .today_event .column_orientation{
	max-width: 1100px;
	flex-wrap: nowrap;
	justify-content: center;
	margin:0 auto 5em;
	gap:5%;
}
#page_top .today_event .column_orientation > *{
	width:30%;
}
#page_top .today_event .column_orientation a{
	display:block;
	box-shadow:0 2px 10px rgba(0,0,0,0.075);
	height:100%;
	margin: 0;
	text-decoration:none;
	background:#fff;
	transition:transform .4s, box-shadow .4s;
	border-radius:1rem;
	overflow:hidden;
}
#page_top .today_event .column_orientation a > *:not(.pht_wrap){
	padding-inline:1.5rem;
}
#page_top .today_event .pht_wrap{
	background:#fff;
	margin-bottom:1em;
}
#page_top .today_event .pht_wrap img{
	object-fit:cover;
	width:100%;
	height:100%;
}
#page_top  .today_event .column_orientation .time{
	padding-block:0.5rem 1rem;
	font-size:0.75rem;
	color:#727272;	
}
#page_top  .today_event .column_orientation a:hover{
	text-decoration:none;
	transform:translateY(0) scale(1.1);
}
#page_top  .today_event .column_orientation a:hover img{
	opacity:1;
}

#page_top .content04{
	display:flex;
	gap:2%;
	padding-top: 3em;
	max-width: 1420px;
	margin-inline:auto;
}
#page_top  .content04 .facility_area{
	width:auto;
	flex-grow:1;
	flex-basis:50%;
	border-radius:4em;
	background:var(--keycolor);
	--keycolor:var(--color01);
	position:relative;
	z-index:2;
	overflow:hidden;
	min-height: 577px;
	color:#fff;
	display:flex;
	flex-direction:column;
	justify-content:space-between;
	align-items:center;
	padding-block:2.5em 4em;
}
#page_top .illust_design .content04 .facility_area:before{
	content:"";
	display:block;
	background:url(../img/top/facility_zoo.png) no-repeat bottom center / cover;
	position:absolute;
	z-index:-1;
	inset:0;
}
#page_top .illust_design .content04 .facility_area.plant_area{
	--keycolor:var(--color02);
}
#page_top .illust_design .content04 .facility_area.plant_area:before{
	background-image:url(../img/top/facility_plant.png);
}
#page_top .illust_design .content04 .facility_area.shop_area{
	--keycolor:var(--color03);
}
#page_top .illust_design .content04 .facility_area.shop_area:before{
	background-image:url(../img/top/facility_shop.png);
}
#page_top .illust_design .content04 li a{
	max-width:100%;
	padding:10px;
	min-height:70px;
	display:flex;
	flex-wrap:wrap;
	align-items:center;
	justify-content:center;
	line-height:1.2;
	border-width:1px;
}
#page_top .illust_design .content04 div.plant_area li a{
	color:#457f10;
}
#page_top .illust_design .content04 div.shop_area li a{
	color:#1665ab;
}
#page_top .illust_design .content04 div.plant_area li a:hover,
#page_top .illust_design .content04 div.shop_area li a:hover{
	color:#fff;
}
#page_top .illust_design .content04 div.plant_area li a:hover,
#page_top .illust_design .content04 div.plant_area li a:before{
	background:#457f10;
}
#page_top .illust_design .content04 div.shop_area li a:hover,
#page_top .illust_design .content04 div.shop_area li a:before{
	background:#1665ab;
}
#page_top .illust_design .content04 div.shop_area li a span{
	padding:0;
}
#page_top .illust_design .content04 div.plant_area li.first a span:before{
	background-image:url(../img/top/note_green.png);
}
#page_top .illust_design .content04 div.plant_area li.last a span:before{
	background-image:url(../img/top/icon_plant.png);
}
#page_top .illust_design .content04 div.zoo_area li.first a span:after,
#page_top .illust_design .content04 div.plant_area li.first a span:after{
	background-image:url(../img/common/ico_notew.png);
}
#page_top .illust_design .content04 div.plant_area li.last a span:after{
	background-image:url(../img/common/ico_charaw2.png);
}

#page_top .illust_design .content04 div.shop_area li a span:before,
#page_top .illust_design .content04 div.shop_area li a span:after{
	display:none;
	content:none;
}
#page_top .illust_design .content05 ul{
	margin-bottom:50px;
}
#page_top .illust_design .content05 ul li{
	width:32%;
}
#page_top .illust_design .content05 ul li + li{
	margin-left:2%;
}
#page_top .illust_design .content05 ul li a{
	box-shadow:0 0 2px rgba(0,0,0,0.25);
}
#page_top .illust_design ul li .text{
	background:#f5f3ec;
	color:#664422;
	border:none;
	position:relative;
}
#page_top .illust_design ul li .text:before,
#page_top .illust_design ul li .text:after{
	
}
#page_top .illust_design ul li .text:before{
	content:"";
	display:inline-block;
	width:24px;
	height:24px;
	border-radius:50%;
	background:#664422;
	border:solid 1px #fff;
	position:absolute;
	left:12px;
	top:0;
	bottom:0;
	margin:auto;
	z-index:1;
}
#page_top .illust_design ul li .text:after{
	content:"";
	display:inline-block;
	border-radius:1px;
	left:19px;
	top:0;
	bottom:0;
	margin:auto;
	width:9px;
	height:9px;
	box-sizing:border-box;
	border-top:#fff 3px solid;
	border-right:#fff 3px solid;
	position:absolute;
	z-index:5;
	transform:rotate(45deg);
}
#page_top .illust_design .single_bnr a{
	display:flex;
	align-items:center;
	margin:0 auto;
	color:#664422;
	font-size:1.5rem;
	background:url(../img/top/bnr_zoobotop.png) no-repeat top center #c4e6ee;
	max-width:600px;
	height:150px;
	padding-left:250px;
	box-sizing:border-box;
	border-radius:8px;
	transition:transform .4s;
}
#page_top .illust_design .single_bnr a:hover{
	transform:translateY(5px);
}
#page_top .facility_wrap{
	position:relative;
	z-index: 5;
	padding-inline: 2%;
}
#page_top .facility_wrap .ttl_set ~ .text{
	font-size:1.125rem;
}
#page_top .facility_wrap .site_wrapper{
	overflow:visible;
}
#page_top .illust_design .bg_warp_02 {
	padding: 0;
	background:none;
	position: relative;
	z-index: 0;
}
#page_top .illust_design .bg_warp_02 .top_blog{
	position: relative;
	z-index: 2;
}
#page_top .illust_design .bg_warp_02 .content06{
	background: #f0f9e8;
	padding: 65px 0 50px;
}
#page_top .illust_design .bg_warp_02 .content06 .sp_scroll{
	margin-bottom:4em;
}

#page_top .illust_design .bg_warp_02 .content_yt{
	background:#fff;
	padding:50px 0;
}
#page_top .illust_design .channel_wrapper {
	background:#ebf7e1;
	padding:45px 0;
	margin-bottom:40px;
}
#page_top .illust_design .channel_wrapper .video_wrap{
	max-width:540px;
	margin:0 auto;
	font-size:1.125rem;
}
#page_top .illust_design .channel_wrapper .video_wrap span{
	display:block;
	position:relative;
	padding-bottom:56.25%;
}
#page_top .illust_design .channel_wrapper .video_wrap iframe{
	width:100%;
	height:100%;
	position:absolute;
	top:0;
	left:0;
	bottom:0;
	margin:auto;
	right:0;
	display:block;
	border:none;
}
#page_top .partner{
	overflow:visible;
}
#page_top .partner .ttl_set{
	margin-bottom:1.25em;
}
#page_top .partner .site_wrapper{
	padding-top:1em;
	margin-top:-1em;
}
#page_top .partner .content02{
	position: relative;
	z-index: 0;
	border:solid 2px;
	color:var(--keyD);
	background:var(--keyW);
	box-shadow:0 0 1em rgba(0,0,0,0.15);
	border-radius:1.5em;
	padding: 2.5em 3.25em 4.25em;
	margin-bottom: 1em;
}
#page_top #content .content02 .h_box{
	background:#fff;
	padding: 1.5em 1.5em 1em;
	text-align:center;
	border-radius:0.75em;
	margin: 1em;
}
#page_top .illust_design .content02 h3{
	font-size: 1.5rem;
	font-weight:600;
	margin-bottom: 0;
}
#page_top .illust_design .content02 ul{
	display:flex;
	justify-content:center;
	flex-wrap:wrap;
	gap: 0.5em 2em;
}
#page_top .illust_design .content02 ul li img{
	height:72px;
	width: auto;
}
#page_top .illust_design .content02 .bnr{
	text-align:center;
	margin-block:2em 0;
}

.check_modal{
	display:none;
	visibility:hidden;
	opacity:0;
	position:fixed;
	top:10%;
	left:0;
	right:0;
	bottom:10%;
	margin:auto;
	max-width:1100px;
	z-index:20100;
	background:#fff;
	width:fit-content;
	height: fit-content;
	display:flex;
	justify-content:center;
	align-items:center;
	overflow-y:auto;
	overscroll-behavior: contain;
	transition:opacity 0.4s, visibility 0.0s 0.4s;
}
.check_modal::-webkit-scrollbar {
	width: 6px;
}
.check_modal::-webkit-scrollbar-track {
	border-radius: 3px;
	background: #e8e8e8;
}
.check_modal::-webkit-scrollbar-thumb {
	border-radius: 3px;
	background: #b3b2b2;
}
#select_day:checked ~ .check_modal{
	display:block;
	visibility:visible;
	opacity:1;
	transition:opacity 0.4s .0s, visibility 0.0s 0.0s;
}
#select_day ~ section label[for="select_day"]:after{
	display:block;
	content:"";
	visibility:hidden;
	opacity:0;
	position:fixed;
	top:0;
	left:0;
	right:0;
	bottom:0;
	z-index:20050;
	background:rgba(0,0,0,0.5);
	transition:opacity 0.4s, visibility 0.0s 0.0s;
}
#select_day:checked ~ section label[for="select_day"]:after{
	visibility:visible;
	opacity:1;
	transition:opacity 0.4s, visibility 0.4s 0.0s;
}
input[name="select_month"],
input[name="select_month"] ~ div{
	display:none;
}
input[name="select_month"]#default_month:checked ~ .default_month,
input[name="select_month"]#prev_month:checked ~ .prev_month,
input[name="select_month"]#next_month:checked ~ .next_month{
	display:block;
}
.calendar_page #calendar .box label{
	display:block;
	text-align:center;
	background: #888;
	color:#fff;
	padding:5px 0;
	border-radius:20px;
	position:relative;
	cursor:pointer;
	width:8em;
}
.calendar_page #calendar .box label:before{
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	margin: auto;
	content: "";
	vertical-align: middle;
	display:inline-block;
	left: 15px;
	box-sizing: border-box;
	width: 4px;
	height: 4px;
	border: 4px solid transparent;
	border-right: 6px solid #fff;
}
.calendar_page #calendar .box .right label:before{
	left:auto;
	right:15px;
	transform:scale(-1,1);
}
.calendar_page #calendar .box{
	width:auto;
}
.calendar_page #calendar .box .left,
.calendar_page #calendar .box .center,
.calendar_page #calendar .box .right{
	width:120px;
}
.calendar_page #calendar .box .center{
	width:160px;
}
.calendar_page #calendar .box p{
	min-height:34px;
}
.check_modal.calendar_page #calendar{
	font-size:0.875rem;
	margin:1em;
}
.check_modal.calendar_page #calendar .event_calendar{
	width:auto;
	border-spacing:5px;
	margin:auto;
}
.check_modal.calendar_page #calendar .event_calendar td{
	height:4em;
	font-size:1.25rem;
}
.check_modal.calendar_page #calendar .event_calendar td:after{
	margin-top:0.875em;
}
@media screen and (max-width:760px) {
	.check_modal{
		left:10px;
		right:10px;
	}
	.check_modal.calendar_page #calendar{
		margin:10px 5px 5px;
	}
	.calendar_page #calendar .box{
		font-size:0.75rem;
		display:flex;
		justify-content:space-between;
		align-items:flex-end;
		width: auto;
		max-width:280px;
		margin:0 auto;
	}
	.calendar_page #calendar .box:after{
		display:none;
	}
	.calendar_page #calendar .box .left,
	.calendar_page #calendar .box .center,
	.calendar_page #calendar .box .right{
		width:auto;
	}
	.calendar_page #calendar .event_calendar th{
		height:2em;
	}
	.check_modal.calendar_page #calendar .event_calendar td{
		font-size:1rem;
	}
}

/*　top_sns　*/
#page_top .top_sns{
	background: #f4f2eb;
	padding-block: 2em;
	margin-bottom: 3em;
}
#page_top .top_sns_inner{
	max-width: 1000px;
	margin-inline: auto;
	display: flex;
	gap: 2em 4%;
	align-items: center;
}
#page_top .top_sns .sns_area{
	width: 48%;
	display: flex;
	gap: 0 5%;
}
#page_top .top_sns .sns_area .sns_title{
	font-size: 1.875rem;
	font-weight: 600;
	color: #33691e;
	line-height: 2;
}
#page_top .top_sns .sns_area .sns_list{
	display: flex;
	gap: 4%;
}
#page_top .top_sns .sns_area .sns_list li a{
	display: block;
	filter: drop-shadow(1px 1px 5px rgba(0, 0, 0, 0.1));
	transition: transform 0.3s ,filter 0.3s;	
}
#page_top .top_sns .zoobo_area{
	width: 48%;
}
#page_top .top_sns .zoobo_area a{
	display: block;
	position: relative;
	z-index: 0;
	background: url(../img/top/img_sns01.png) no-repeat;
	background-size: contain;
	color: #fff;
	width: 525px;
	height: 106px;
	filter: drop-shadow(1px 1px 5px rgba(0, 0, 0, 0.15));
	transition: transform 0.3s ,filter 0.3s;
	margin-bottom: 0.5em;
	padding-left: 2em;
	display: flex;
	gap: 2em;
	justify-content: center;
	align-items: center;
	font-weight: bold;
}
#page_top .top_sns .zoobo_area a .btn_text{
	text-align: center;
	color: #fff;
	z-index: 1;
	filter: drop-shadow(1px 1px 5px rgb(20 161 196));
}
#page_top .top_sns .zoobo_area a .btn_text span{
	display: block;
}
#page_top .top_sns .zoobo_area a .btn_text em{
	font-size: 1.5rem;
	font-style: normal;
}
#page_top .top_sns .zoobo_area a img.action_zoobo{
	opacity: 0;
	margin-bottom: 0.25em;
}
#page_top .top_sns .zoobo_area a img.action_zoobo.once{
    animation: popUp 0.8s ease-out forwards;
    animation-delay: 1s;
    opacity: 0;
}
@keyframes popUp {
    0% {
        transform: translateY(40px);
        opacity: 0;
    }
    60% {
        transform: translateY(-20px);
        opacity: 1;
    }
    80% {
        transform: translateY(10px);
    }
    100% {
        transform: translateY(0);
        opacity: 1;
    }
}

/*　effort　*/
#page_top .efforts{
	margin: 3.75em auto 0em;
	max-width: 1440px;
	position: relative;
	z-index: 1;
}
#page_top .efforts .scrollable{
	display:flex;
	gap:1%;
}
#page_top .efforts .wrap{
	margin:0;
	display:block;
	text-align:left;
	width: calc((100% - 3%) / 4);
	white-space: normal;
}
#page_top .efforts .wrap a{
	flex-direction:column;
	align-items:flex-start;
	gap: 0;
}

#page_top .efforts .wrap .img_fit{
	position:relative;
	z-index:1;
	overflow:hidden;
	border-radius:1rem;
}
#page_top .efforts .wrap .img_fit i.arrow{
	position:absolute;
	bottom:1em;
	right:1em;
	background:#fff;
	color:var(--keyD);
	height:2em;
}
#page_top .efforts .wrap .img_fit i.arrow:before{
	height:0.5em;
	margin-right:0.825em;
}

#page_top .efforts .wrap a:is(:hover,:focus){
	color:var(--keyD)
}
#page_top .efforts .wrap a:is(:hover,:focus) img{
	transform:scale(1.1)
}
#page_top .efforts .wrap a:is(:hover,:focus) i.arrow{
	background:var(--keyD);
	color:#fff;
}
#page_top .efforts h2{
	font-size:1.25rem;
	font-weight:600;
	margin-block: 0.5em 0;
}
#page_top .efforts .wrap p{
	line-height:1.75;
	font-weight:400;
}




/*　offical_sns　*/
#page_top .offical_sns{
	background:var(--keycolor);
	padding-block: 4em 1.5em;
	position: relative;
	z-index: 1;
}
#page_top .offical_sns .title_area{
	display: flex;
	justify-content: space-between;
	gap: 5%;
	color: #fff;
}
#page_top .offical_sns .title_area .ttl_set{
	align-items:flex-start;
	gap:0.5em;
	margin-bottom:1.5em;
}
#page_top .offical_sns .title_area .sns_icons{
	gap:1em;
	align-items: flex-start;
}
#page_top .offical_sns .title_area .sns_icons a{
	height: 4.375em;
}

#page_top .offical_sns .title_area .sns_list{
	display: flex;
	gap: 1em;
}
#page_top .offical_sns .title_area .sns_list a{
	display: block;
	filter: drop-shadow(1px 1px 5px rgba(0, 0, 0, 0.1));
}
#page_top .offical_sns .sns_cont{
	/* margin-bottom: 4em; */
}
#page_top .offical_sns .sns_cont .title_top02{
	color: #fff;
	font-weight: 500;
	font-size:1.5rem;
	margin-bottom: 0.85em;
}
#page_top .offical_sns .video_wrap span{
	display:block;
	position:relative;
	padding-bottom:56.25%;
}
#page_top .offical_sns .video_wrap iframe{
	width:100%;
	height:100%;
	position:absolute;
	top:0;
	left:0;
	bottom:0;
	margin:auto;
	right:0;
	display:block;
	border:none;
}




#page_top .offical_sns .sp_scroll{
	margin: 0 auto 2em;
}
#page_top .offical_sns .sp_scroll .scrollable{
	overflow:auto;
	text-align:center;
	font-size:0;
	white-space:nowrap;
	padding: 0;
	padding-bottom:5px;
}
#page_top .offical_sns .sp_scroll .scrollable::-webkit-scrollbar {
	height: 8px;
}
#page_top .offical_sns .sp_scroll .scrollable::-webkit-scrollbar-track {
	border-radius: 8px;
	background: #8fad83;
}
#page_top .offical_sns .sp_scroll .scrollable::-webkit-scrollbar-thumb {
	border-radius: 8px;
	background: #ffffff;
}
#page_top .offical_sns .sns_youtube .sp_scroll .scrollable > *{
	display: inline-block;
	max-width: 263px;
	margin-bottom: 20px;
	vertical-align: top;
	width: 100%;
}
#page_top .offical_sns .sns_youtube .sp_scroll .scrollable > * p{
	color: #fff;
	font-size: 16px;
	text-align: left;
	margin-top: 0.5em;
	display: block;
	white-space: normal;
}
#page_top .offical_sns .sns_youtube .sp_scroll .scrollable > * span{
	display: block;
	position: relative;
	z-index: 0;
}
#page_top .offical_sns .sns_youtube .sp_scroll .scrollable > * img{
	width: 100%;
	height: auto;
}
#page_top .offical_sns .sns_youtube .sp_scroll .scrollable .video_wrap span:after{
	content: none;
}
#page_top .offical_sns .sns_youtube  .sp_scroll .scrollable > * + *{
	margin-left:16px;
}
#page_top .offical_sns .sns_youtube  .sp_scroll .scrollable a{
	transition:opacity .4s, transform .4s;
}
@media (any-hover: hover) {
	#page_top .offical_sns .sns_youtube .sp_scroll .scrollable a:hover{
		opacity:0.7;
		transform:translateY(2px);
	}
}
#page_top .offical_sns .sns_instagram .sp_scroll .scrollable .instagram-item{
	display: inline-block;
	max-width: 200px;
	margin-bottom: 20px;
	vertical-align: top;
}
#page_top .offical_sns .sns_instagram  .sp_scroll .scrollable > * + *{
	margin-left: 25px;
}
#page_top .offical_sns .sns_instagram  .sp_scroll .scrollable a{
	overflow: hidden;
	display: block;
}
#page_top .offical_sns .sns_instagram  .sp_scroll .scrollable a img{
	width: 100%;
	height: 100%;
	aspect-ratio:1 / 1;
	object-fit:cover;
	display: block;
	transition: transform .4s;
}
#page_top .offical_sns iframe{
	width:100%;
	height:100%;
	position:absolute;
	top:0;
	left:0;
	bottom:0;
	margin:auto;
	right:0;
	display:block;
	border:none;
}

@media (any-hover: hover) {
	#page_top .offical_sns .sns_instagram .sp_scroll .scrollable a:hover img{
		transform: scale(1.05);
	}
}

/*　fade_item　*/
#page_top .fade_item{
	position: absolute;
	z-index: 0;
	margin: auto;
	width: fit-content;
	inset: 0;
	opacity: 0;
	height: auto;
}
#page_top .fade_item img{
	max-width: 100%;
	height: auto; 
}
#page_top .fade_item.item01{
	inset: auto auto -2.75em 84%;
	opacity: 0;
	transform: translateX(66%) translateY(0px);
}
#page_top .fade_item.item01.once{
	animation: walkInFromRight 1.2s ease-in-out forwards;
}
@keyframes walkInFromRight {
    1% {
        transform: translateX(66%) translateY(0px);
    }
	10% {
        opacity: 1;
    }
    50% {
        transform: translateX(33%) translateY(-10px) rotate(4deg);
    }
    100% {
        opacity: 1;
        transform: translateX(0%) translateY(0px);
    }
}
#page_top .fade_item.item02{
	inset: auto 14% 0em auto;
	transform: translateX(0%) translateY(0) rotate(0deg);
}
#page_top .fade_item.item02.once{
	animation: elephantWalk 1.8s ease-in-out forwards;
}
@keyframes elephantWalk {
    0% {
        opacity: 0;
        transform: translateX(0%) translateY(0) rotate(0deg);
    }
    10% {
        opacity: 1;
	}
    50% {
        transform: translateX(0%) translateY(0) rotate(10deg);
    }
    100% {
        opacity: 1;
        transform: translateX(0%) translateY(0) rotate(0deg);
    }
}
#page_top .fade_item.item03 {
    inset: 4.5em auto auto calc(50% - 500px);
    transform: translateY(0);
    opacity: 0;
}
#page_top .fade_item.item03.once{
    animation: gorillaJump 0.5s ease-in-out forwards;
    /* animation-delay:0.6s; */
}
@keyframes gorillaJump {
    0% {
        transform: translateY(10px);
        opacity: 0;
    }
    10% {
        opacity: 1;
    }
    50% {
        transform: translateY(-30px) scaleY(1.05);
    }
    98% {
        transform: translateY(2px) scaleY(0.95);
    }
    100% {
        transform: translateY(0);
		opacity: 1;
    }
}
#page_top .fade_item.item04 {
    inset: auto auto 20.5em calc(50% + 230px);
    transform: translateX(40%) rotate(-5deg) translateY(-10px);
    transform-origin: bottom center;
}
#page_top .fade_item.item04.once {
    animation: flamingoWalk 1.2s ease-in-out forwards;
	animation-delay: 0.4s;
}
@keyframes flamingoWalk {
	0% {
		opacity: 0;
		transform: translateX(40%) rotate(-5deg) translateY(-10px);
	}
	10% {
		opacity: 1;
	}
	60% {
		transform: translateX(20%) rotate(5deg) translateY(0);
	}
	100% {
		opacity: 1;
		transform: translateX(0%) rotate(0deg) translateY(0);
	}
}
#page_top .fade_item.item05{
	inset: auto auto 0.5em 13%;
	transform: translateX(-90%) translateY(0)  rotate(5deg);
	opacity: 0;
}
#page_top .fade_item.item05.once{
	animation: kangarooHop 1.8s forwards;
	animation-delay:0.8s;
}
@keyframes kangarooHop {
    0% {
        transform: translateX(-90%) translateY(0)  rotate(5deg);
        opacity: 0;
    }
    10% {
        opacity: 1;
    }
    25% {
        transform: translateX(-75%) translateY(-30px) rotate(-3deg) scaleY(0.95);
    }
    50% {
        transform: translateX(-50%) translateY(5px) rotate(0deg) scaleY(1);
    }
    75% {
        transform: translateX(-25%) translateY(-25px) rotate(-5deg)  scaleY(1.05);
    }
    100% {
        transform: translateX(0%) translateY(0) rotate(0deg) scaleY(1);
        opacity: 1;
    }
}
#page_top .fade_item.item06 {
    inset: auto auto -0.2em 83%;
    opacity: 0;
    transform-origin: bottom center;
}
#page_top .fade_item.item06.once{
    animation: giraffeSwayingFadeIn 2s ease-in-out forwards;
}
@keyframes giraffeSwayingFadeIn {
    0% {
        transform: rotate(0deg);
        opacity: 0;
    }
    10% {
        opacity: 1;
    }
    25% {
        transform: rotate(5deg);
    }
    75% {
        transform: rotate(-1deg);
    }
    100% {
        transform: rotate(0deg);
        opacity: 1;
    }
}
#page_top .fade_item.item07{
	inset: auto auto -4.5em calc(50% - 340px);
	opacity: 0;
	transform: translateX(80%) scale(0.5) skew(-20deg);
}
#page_top .fade_item.item07.once{
	animation: cheetahQuickDash 0.8s cubic-bezier(0.25, 0.1, 0.25, 1) forwards;
	animation-delay: 0.4s;
}
@keyframes cheetahQuickDash {
    0% {
        opacity: 0;
        transform: translateX(80%) scale(0.5) skew(-20deg);
    }
    100% {
        opacity: 1;
        transform: translateX(0%) scale(1) skew(0deg);
    }
}
#page_top .fade_item.item08{
    inset: auto auto 0 0;	
    opacity: 0;
}
#page_top .fade_item.item08.once {
    animation: polarBearWalk 0.8s ease-in-out forwards;
}
@keyframes polarBearWalk {
    0% {
        transform: translateX(-50px) translateY(0);
        opacity: 0;
    }
    10% {
        opacity: 1;
    }
    50% {
        transform: translateX(-25px) translateY(-10px);
    }
    100% {
        transform: translateX(0px) translateY(0);
        opacity: 1;
    }
}
#page_top .fade_item.item09 {
    inset: auto auto -6em 33%;
    opacity: 0;
    transform: translateX(100%);
}
#page_top .fade_item.item09.once {
    animation: lionWalkIn 1.0s ease-in-out forwards;
}
@keyframes lionWalkIn {
    0% {
        transform: translateX(25%) translateY(0);
		        opacity: 0;
    }
    10% {
        opacity: 1;
    }
    50% {
        transform: translateX(12.5%) translateY(-10px);
    }
    100% {
        transform: translateX(0) translateY(0);
        opacity: 1;
    }
}
#page_top .fade_item.item10{
	inset: auto 4% -14em auto;
	transform-origin: top left;
}
#page_top .fade_item.item10.once{
	animation: hangDown 0.8s ease-out forwards;
	animation-delay: 0.4s;
}
@keyframes hangDown {
	0% {
	  transform: rotate(-70deg);
	  opacity: 0;
	}
	10% {
        opacity: 1;
    }
	60% {
	  transform: rotate(10deg);
	  opacity: 1;
	}
	80% {
	  transform: rotate(-5deg);
	  opacity: 1;
	}
	100% {
	  transform: rotate(0deg);
	  opacity: 1;
	}
}
@media screen and (max-width:1700px) {
	#page_top .open_info .box{
		margin-bottom:9em;
		min-height: 9.5em;
	}
	#page_top .top_open .zoobo_area{
		bottom:-8em;
	}
	.open_info .open_data{
		width:100%;
		--headB: 456px;
	}
	.open_info .data_btns a.btn{
		width:auto;
		padding-left:1em;
		justify-content:flex-start;
	}
	.open_info .data_btns label{
		margin-right:0;
	}
	.news_blog .more_link{
		right:var(--inner)
	}
	#page_top .content04 .inner .text{
		font-size: 1rem;
	}
	#page_top .fade_item.item03{
		left:1em;
	}
	#page_top .fade_item.item01{
		width: 150px;
	}
	#page_top .fade_item.item06{
		width: 90px;
	}
	#page_top .fade_item.item08{
		width: 190px;
	}
}
@media screen and (max-width: 1200px) {
	#page_top .kv{
		margin-top: calc(var(--header) + 96px);
	}
	#page_top .kv,
	#page_top .kv #kv_bg{
		max-height:fit-content;
		--height:727px;
	}
	#page_top .kv #kv_bg img{
		height:var(--height);
	}
	#page_top .kv #kv_bnr{
		--width:462px;
	}
	#page_top .top_open .zoobo_area{
		bottom: -8em;
	}
	#page_top .top_open .zoobo_area.once{
		right:-1em;
	}
	.open_info .open_data {
	        --headB: 5em;
    }
	#page_top .open_info .open_data .data_head{
		position:static;
		margin-bottom:1em;
		width:var(--headW);
	}
	.open_info .open_data .data div.time{
		position:absolute;
		top:0;
		display:flex;
		align-items:center;
		height:3em;
	}
	#page_top .open_info .data_btns {
		position:static;
		margin-bottom:1em;
		justify-content:center;
	}
	#page_top .open_info .data_btns label{
		position:absolute;
		width:3em;
		height:3em;
		top:0.25em;
		right:0;
	}
	#page_top .open_info .data_btns a.btn{
		flex-basis:49%;
		max-width:305px;
	}
	#page_top .top_open .zoobo_area img{
		width:calc(var(--width) * 0.75);
	}

	#page_top .illust_design .content04{
		flex-wrap:wrap;
		justify-content:center;
		padding:2.5em 0 0;
		gap:1.5em 2%;
		max-width:900px;
	}
	#page_top .illust_design .content04 .facility_area{
		flex-grow:0;
		flex-basis:auto;
		border-radius:2.85em;
		overflow:hidden;
		width:calc(48%);
	}

}
@media screen and (max-width: 767px) {
	#page_top .kv{
		margin-top: calc(var(--header) + 70px);
	}
	#page_top .kv, #page_top .kv #kv_bg{
		--height: 470px;
		max-height:var(--height);
	}
	#page_top .kv #kv_bnr{
		--width: 300px;
		right:0;
		left:0;
		margin:auto;
		bottom: 3.5em;
	}
	#page_top .kv .bx-pager{
		width:auto;
		right:var(--inner);
		margin: 0;
	}
	#page_top .notice{
		padding:0;
		position:relative;
		z-index:5;
		overflow:visible;
	}
	#page_top .notice .site_wrapper{
		padding-inline:0;
	}
	#page_top .notice.notice dl{
		display:block;
		border-inline:none;
		border-radius:0;
	}
	#page_top .notice.notice dl dt{
		position:absolute;
		top:-36px;
		height:36px;
		border-top-right-radius:0.5rem;
		padding-inline:1em;
		width:auto;
	}
	#page_top .notice.notice dl dd{
		width:100%;
		padding:1em;
	}
	#page_top #content{
	    padding-bottom:80%;
	    background-image: url(../img/bg_foot@sp.jpg);
	}
	#page_top .emergency{
		margin: 0 10px 10px;
		width:auto;
	}
	.emergency .box dl{
		padding: 0;
	}
	.emergency .box dl:before{
		width:18px;
		height: 16px;
		top: 2px;
	}
	.emergency .box dl dt{
		padding: 0 0 5px;
		padding-left: 26px;
	}
	.open_info{
		margin:1em;
		width:auto;
	}
	#page_top .open_info .box{
		padding: 1em 1em 0;
		margin-bottom:2em;
		min-height: 11.5em;
	}

	.open_info .open_data {
	    --headW: 110px;
	    --headB: 40px;
	}
	.open_info .open_data .data_head h2{
		font-size: 0.857rem;
	}
	.open_info .open_data .data_head input{
		font-size:1.285rem;
	}
	.open_info .open_data .data div.time{
		font-size:1rem;
	}
	.open_info .open_data .edit_area{
		font-size:0.857rem;
		margin-inline:-1em;
		padding:1em;
	}
	#page_top .content01 .col_02 .left_area{
		margin-bottom: 0;
	}
	#page_top .open_info .data_btns{
		gap:2%;
	}
	.open_info .open_data .data{
	}
	#page_top .open_info .data_btns a.btn{
		font-size:1rem;
		font-weight:700;
		justify-content:center;
		padding-inline: 0.5em 1.5em;
	}
	#page_top .open_info .data_btns a.btn img{
		width:22px;
	}
	#page_top .content03 .news_box .blogs_wrap{
		padding: 0 0 25px;
	}
	.news_box .blogs_wrap ul li:first-child a{
		border-top:none;
	}
	.news_box .blogs_wrap ul li a{
		padding:10px 20px;
	}
	#page_top .content_guide{
		padding-top:20px;
	}
	#page_top .content_guide .title_top02{
		border-width:3px;
		margin:0 10px;
	}
	#page_top .content04 .facility_area{
		width:auto;
		position:relative;
		box-sizing: border-box;
	}
	#page_top .facility_wrap {
		transition: background-color 0.5s ease;
	}
	#page_top .facility_detail {
		/* height: auto; */
		/* position: relative; */
	}
	#page_top .content05{
		margin:0;
	}
	#page_top .content05 ul{
		margin:0 10px;
	}
	#page_top .content05 ul li{
		width:49%;
		margin-right:2%;
		margin-bottom:0;
	}
	#page_top .content05 ul li + li{
		margin:0;
	}
	#page_top .content05 ul li:nth-child(2n){
		margin-right:0%;
	}
	#page_top .caution{
		padding:0;
		margin:30px 10px;
		width:auto;
	}
	#page_top .content12{
		margin:0;
		padding: 8px;
	}
	#page_top .content13 .title_top02{
		border-width:2px;
	}
	#page_top .offical_sns{
		padding-block: 4em 1em;
		border-radius:2em;
	}
	#page_top .offical_sns .title_area .ttl_set{
		justify-content:center;
		margin-inline:auto;
		align-items: center;
	}
	#page_top .offical_sns .title_area{
		flex-direction: column;
	}
	#page_top .offical_sns .title_area .sns_icons{
		gap:0.5em;
		margin-bottom:2em;
	}
	#page_top .offical_sns .title_area .sns_icons a{
		height:3.5em;
		
	}
	#page_top .offical_sns .title_area .sns_icons img{
		width: 29px;
		height: auto;
	}
	#page_top .offical_sns .sns_cont{
		margin-bottom: 0em;
	}
	#page_top .offical_sns .sns_cont .title_top02{
		font-size:1.285rem;
	}
	#page_top .offical_sns .sp_scroll{
		margin: 0 auto 3em;
	}
	#page_top .offical_sns .sp_scroll .scrollable::-webkit-scrollbar {
		height: 4px;
	}
	#page_top .offical_sns .sp_scroll .scrollable::-webkit-scrollbar-thumb {
		border-radius: 4px;
	}
	#page_top .offical_sns .sns_youtube .sp_scroll .scrollable > *{
		max-width: 130px;
		margin-bottom: 10px;
	}
	#page_top .offical_sns .sns_youtube .sp_scroll .scrollable > * p{
		font-size: 0.811rem;
	}
	#page_top .offical_sns .sns_youtube .sp_scroll .scrollable > * span:after{
	    width:27px;
	    height:19px;
		background-size: contain;
	}
	#page_top .offical_sns .sns_youtube .sp_scroll .scrollable > *:last-child{
		margin-right: 10px;
	}
	#page_top .offical_sns .sns_youtube  .sp_scroll .scrollable > * + *{
		margin-left:10px;
	}
	#page_top .offical_sns .sns_youtube  .sp_scroll .scrollable a{
		transition:opacity .4s, transform .4s;
	}
	#page_top .offical_sns .sns_instagram .sp_scroll .scrollable .instagram-item{
		max-width: 100px;
		margin-bottom: 10px;
	}
	#page_top .offical_sns .sns_instagram .sp_scroll .scrollable .instagram-item:last-child{
		margin-right: 10px;
	}
	#page_top .offical_sns .sns_instagram  .sp_scroll .scrollable > * + *{
		margin-left: 10px;
	}
	#page_top .illust_design .open_info{
		padding: 0;
	}
	#page_top .illust_design .open_info .box .open_data{
		margin:0;
	}
	#page_top .top_open .zoobo_area{
		bottom:-5.575em;
		right:-1em;
	}
	#page_top .top_open .zoobo_area.once{
		right:-1.85em;
	}
	#page_top .top_open .zoobo_area img{
		width: calc(var(--width) * 0.60);
	}
	#page_top .calendar_events{
		padding-block:2.75em;
		border-radius:2em 2em 0;
	}
	#page_top .illust_design .today_event .scroll{
		width:100%;
		overflow-x:auto;
		margin-bottom:2.0em;
	}
	#page_top .illust_design .today_event .column_orientation{
		width: fit-content;
		justify-content:flex-start;
		align-items:stretch;
		gap:1.5em;
		margin-bottom:1em;
	}
	#page_top .illust_design .today_event .column_orientation > *{
		min-width:310px;
		width:auto;
	}
	#page_top .today_event .column_orientation a{
		border-radius:0.5rem;
	}
	#page_top .today_event .column_orientation a:hover{
		transform:none;		
	}
	#page_top .today_event .column_orientation a > *:not(.pht_wrap){
		padding-inline:1rem;
		font-size: 0.875rem;
	}
	#page_top .illust_design .today_event .column_orientation {
		
	}
	.news_blog .more_link{
		position:static;
		text-align:right;
		margin-top: 0.75em;
		font-size:0.875rem;
	}
	#page_top .news_blog .sp_scroll{
		/* margin-right:-1em; */
	}
	#page_top .news_blog .sp_scroll img{
		height:76px;
		width:auto;
	}
	#page_top .illust_design .content_guide{
		padding: 0 0 50px;
		background: none;
	}
	#page_top .content_guide .sp_scroll .scrollable img{
		width:auto;
		height:78.5px;
	}
	#page_top .illust_design .facility_wrap{
		padding-inline:var(--inner);
	}
	#page_top .facility_wrap .ttl_set ~ .text{
		font-size:1rem;
		text-align:left;
		margin-bottom:2em;
	}
	#page_top .illust_design .content04{
		padding:0;
		display:flex;
		gap:2em;
		align-items: center;
	}
	#page_top .illust_design .content04 .facility_area{
		border-radius: 2.35rem;
		aspect-ratio:auto;
		min-height: 380px;
		width: 100%;
		max-width: 100%;
		padding-block: 1.75em 2.0em;
	}
	#page_top .content04 .inner .text{
		font-size:0.94rem;
	}
	#page_top .illust_design .content04 .facility_area:before{
		background-size:100% auto;
		background-position-y: 10%;
	}
	#page_top .illust_design .facility_lead {
		width:100%;
	}
	#page_top .illust_design .facility_lead .text {
		font-size: 1rem;
		text-align:center;
		line-height:1.75;
	}
	#page_top .illust_design .content04 > div:before{
		background-size:100%;
		background-position-y:110%;
	}
	#page_top .illust_design .content04 a.btn{
		width:calc(100% - 2em);
	}

	#page_top .illust_design .content05{
		margin:0 10px;
	}
	#page_top .illust_design .content05 ul{
		margin:0 10px 20px;
		display:block;
		max-width:100%;
	}
	#page_top .illust_design .content05 ul li{
		width: auto;
		float:none;
		margin:0;
	}
	#page_top .illust_design .content05 ul li + li{
		margin:20px 0 0;
	}
	#page_top .illust_design .content05 ul li a{
		display:flex;
		align-items:center;
		background:#f5f3ec;
		box-shadow:0 0 5px rgba(0,0,0,0.2);
		margin: 0 auto;
		max-width: 100%;
	}
	#page_top .illust_design .content05 ul li .img{
		width:260px;
	}
	#page_top .illust_design .content05 ul li .text{
		text-align:left;
		padding:0;
		padding-left:20px;
		font-size:14px;
		font-weight:600;
	}
	#page_top .illust_design .content05 ul li .text:before,
	#page_top .illust_design .content05 ul li .text:after{
		display:none;
	}
	#page_top .illust_design .single_bnr{
		margin:0 10px;
	}
	#page_top .illust_design .single_bnr a{
		height:calc(30vw - 20px);
		background-size:contain;
		padding-left:42.5%;
		font-size:1rem;
		font-weight:600;
		box-shadow:0 0 5px rgba(0,0,0,0.2);
	}
	#page_top .illust_design .facility_wrap:before{
		display:none;
	}
	#page_top .illust_design .facility_wrap:after{
		width:100%;
		height:50vw;
	}
	#page_top .illust_design .bg_warp_02 .content06{
		padding:35px 0;
	}
	#page_top .illust_design .bg_warp_02{
		margin-top:-2em;
		margin-top: 0;
		overflow:visible;
		z-index:2;
		position:relative;
	}
	#page_top .efforts{
		padding-block: 1em;
		margin: 0;
	}
	#page_top .efforts .scrollable{
		gap: 1rem;
	}
	#page_top .efforts .wrap{
		position: relative;
		z-index: 1;
	}
	#page_top .efforts .wrap .caption{
		padding: 0.5em;
		position:absolute;
		inset:0;
		z-index:5;
		display:flex;
		align-items:flex-end;
		background: linear-gradient(0deg, rgba(0, 0, 0, 0.6) 5%, rgba(0, 0, 0, 0) 40%);
	}
	#page_top .efforts .wrap .caption h2{
		font-size:min(3.65vw,1rem);
		color:#fff;
	}
	#page_top .efforts .wrap .caption p,
	#page_top .efforts .wrap .img_fit i.arrow{
		display:none;
	}
	#page_top .illust_design .bg_warp_02 .content_yt{
		padding:50px 0;
	}

	#page_top .illust_design .channel_wrapper{
		padding:20px;
	}
	#page_top .illust_design .bg_warp_02 .content_yt .site_wrapper{
		border:none;
		padding:0;
	}
	#page_top .illust_design .bg_warp_02 .content_yt .wrap{
		width:135px;
	}
	#page_top .content_yt .wrap a span:after{
		height:20px;
		width:27px;
		background-size:contain;
	}
	#page_top .illust_design .bg_warp_02 .content_yt .wrap p{
		white-space:normal;
		font-size:0.85rem;
		min-height: 2.6em;
	}
	#page_top .illust_design .bg_warp_02 .content_yt .wrap img{
		max-width:100%;
	}
	#page_top .illust_design .content02{
		padding:2em 1em;
		width:auto;
		border-radius:0.5rem;
		border-width:1px;
	}
	#page_top #content .content02 .h_box{
		margin-inline:0;
		padding: 1em 0em;
		border-radius:0.5em;
	}
	#page_top .illust_design .content02 .bnr{
		margin-top:1em;
	}
	#page_top .illust_design .content02 h3{
		font-size:1.285rem;
		font-weight:700;
		margin-bottom:0.5em;
	}
	#page_top .illust_design .content02 ul {
		gap:0;
	}
	#page_top .illust_design .content02 ul li{
		width:calc(100% / 3);
		margin:0;
	}
	#page_top .illust_design .content02 ul li img{
		height: 35px;
	}
	#page_top .illust_design .caution{
		padding:0;
		margin:30px 10px;
	}
	#page_top .illust_design .content13 {
		padding:30px 10px 0;
	}
	#page_top .efforts_list .efforts_item .text_area a span::before{
		content: none;
	}
	#page_top .efforts :is(.sp_scroll,.wrap){
		margin:0;
	}
	#page_top .efforts .sp_scroll .bx-viewport{
		padding-bottom:3em;
	}
	#page_top .efforts .sp_scroll .bx-wrapper{
	}
	#page_top .efforts .sp_scroll .bx-wrapper img{
	}
	#page_top .efforts .bx-wrapper .bx-pager.bx-default-pager a{
		background:var(--dgray);
	}
	#page_top .efforts .bx-wrapper .bx-pager.bx-default-pager a.active{
		background:var(--keycolor);
	}
	#page_top .fade_item.item03{
		display:none;
	}		
	#page_top .fade_item.item04{
		inset: auto 2% 15em auto;
		width: 50px;
	}
	#page_top .fade_item.item05{
		inset: auto auto -3em -3%;
		width: 100px;
	}
	#page_top .fade_item.item07{
		width: 150px;
		inset: auto 5% -3em  auto;
		opacity: 1;
	}
	#page_top .fade_item.item09{
		width: 120px;
		inset: auto auto -5em 3%;
		z-index: -1;
	}
	#page_top .fade_item.item10{
		width: 90px;
		inset: auto -2% -8em auto;
	}
	#page_top .efforts .scrollable{
		gap: 1em 3%;
		white-space:normal;
		flex-wrap:wrap;
		font-size: 100%;
	}
	#page_top .efforts .wrap{
		width: 48.5%;
		min-width:0;
	}
	#page_top .efforts .wrap a{
		position:relative;
		margin-inline:auto;
		width: 100%;
		height: auto;
		display:flex;
		z-index:2;
		border-radius:1rem;
		overflow:hidden;
		box-shadow: 0 2px 4px rgba(0,0,0,0.25);
		align-items: stretch;
	}
	#page_top .efforts .wrap .img_fit{
		border-radius:0;
	}
	#page_top .efforts :is(.bx-prev,.bx-next){
		background:var(--keyD);
		width:2em;
		border-radius:50%;
		color:#fff;
	}
	#page_top .efforts .bx-prev{
		left:-.25em;
	}
	#page_top .efforts .bx-next{
		right:-.25em;
	}
	#page_top .efforts :is(.bx-prev,.bx-next):after{
		content:"";
		display:block;
		width:0.75em;
		height:0.75em;
		border-top:solid 3px;
		border-right:solid 3px;
		position:absolute;
		inset:0;
		left:0.25em;
		transform:rotate(-135deg);
		margin:auto;
	}
	#page_top .efforts .bx-next:after{
		transform:rotate(45deg);
		left:0;
		right:0.25em;
	}
}
