@charset "UTF-8";
/* 各ページ共通の設定 */

/*==============*/
/* 全ページ共通部分 */
/*==============*/
button.start-button:hover,button.stop-button:hover{
	background-color: transparent!important;	
}
#section-header {
	padding-bottom: 30px;
}
@media (min-width: 576px) {
#section-header {
}
}
@media (min-width: 768px) {
#section-header {
	padding-bottom: 60px;
}
}
@media (min-width: 992px) {
#section-header {
}
}
@media (min-width: 1200px) {
#section-header {
}
}
.top-bg{
	padding-top: 1em;
	padding-bottom: 1em;
	background-image: url(../images/bg-01.jpg),url(../images/bg-01.jpg);
	background-repeat: repeat-x,repeat-x;
	background-size: 30% auto,30% auto;
	background-position: left top,left bottom;
}
#news {
	background-color: rgba(245,164,32,1.00);
	padding-top: 30px;
	padding-bottom: 30px;
}
@media (min-width: 576px) {
#news {
}
}
@media (min-width: 768px) {
#news {
	padding-top: 60px;
	padding-bottom: 60px;
}
}
@media (min-width: 992px) {
#news {
}
}
@media (min-width: 1200px) {
#news {
}
}

#animation {
	padding-top: 30px;
	padding-bottom: 0px;
	overflow: hidden;
	
}
@media (min-width: 576px) {
#animation {
}
}
@media (min-width: 768px) {
#animation {
	padding-top: 60px;
}
}
@media (min-width: 992px) {
#animation {
}
}
@media (min-width: 1200px) {
#animation {
}
}
.animation-foot{
	background-color: rgba(245,164,32,1.00);
	padding-top: 1em;
	padding-bottom: 1em;
	margin-top: 1em;	
}
.animation-foot a{
	color: rgba(255,255,255,1.00);
	-webkit-transition: 0.7s;
    -moz-transition: 0.7s;
    -o-transition: 0.7s;
    transition: 0.7s;
}
.animation-foot a:hover{
	color: rgba(255,255,255,0.7);	
	-webkit-transition: 0.7s;
    -moz-transition: 0.7s;
    -o-transition: 0.7s;
    transition: 0.7s;
}
#playpark {
	background-color: rgba(20,93,147,1.00);
	padding-top: 30px;
	padding-bottom: 30px;	
}
@media (min-width: 576px) {
#playpark {
}
}
@media (min-width: 768px) {
#playpark {
	padding-top: 60px;
	padding-bottom: 60px;	
}
}
@media (min-width: 992px) {
#playpark {
}
}
@media (min-width: 1200px) {
#playpark {
}
}

#banner {
	padding-top: 30px;
	padding-bottom: 30px;
}
@media (min-width: 576px) {
#banner {
}
}
@media (min-width: 768px) {
#banner {
	padding-top: 60px;
	padding-bottom: 60px;
}
}
@media (min-width: 992px) {
#banner {
}
}
@media (min-width: 1200px) {
#banner {
}
}

#movie {
	background-color: rgba(112,104,232,1.00);
	padding-top: 30px;
	padding-bottom: 30px;
}
@media (min-width: 576px) {
#movie {
}
}
@media (min-width: 768px) {
#movie {
	padding-top: 60px;
	padding-bottom: 60px;
}
}
@media (min-width: 992px) {
#movie {
}
}
@media (min-width: 1200px) {
#movie {
}
}

#character {
	padding-top: 30px;
	padding-bottom: 30px;
}
@media (min-width: 576px) {
	#character{}
}
@media (min-width: 768px) {
#character {
	padding-top: 60px;
	padding-bottom: 60px;
}
}
@media (min-width: 992px) {
#character {
}
}
@media (min-width: 1200px) {
#character {
}
}

#contact {
	background-color: rgba(234,162,213,1.00);
	padding-top: 30px;
	padding-bottom: 30px;	
}
@media (min-width: 576px) {
#contact {
}
}
@media (min-width: 768px) {
#contact {
	padding-top: 60px;
	padding-bottom: 60px;	
}
}
@media (min-width: 992px) {
#contact {
}
}
@media (min-width: 1200px) {
#contact {
}
}

#use-header {
	background-color: rgba(20,93,147,1.00);
	margin-top: 1em;
	padding-top: 1.5em;
	padding-bottom: 1.5em;
}
@media (min-width: 576px) {
#use-header {
}
}
@media (min-width: 768px) {
#use-header {
}
}
@media (min-width: 992px) {
#use-header {
}
}
@media (min-width: 1200px) {
#use-header {
}
}
#use-header .container {
}

#use-header h2 {
	color: rgba(255,255,255,1);
	font-size: 8vw;
}

#use-header h3 {
	font-size: 6vw;
	margin: 0;
	padding: 0;
	color: rgba(255,255,255,.7);
	line-height: 100%;
}
@media (min-width: 576px) {
#use-header h2 {
	font-size: 2em;
}

#use-header h3 {
	font-size: 1.4em;
}
}
@media (min-width: 768px) {
#use-header h2 {
	font-size: 2em;
}

#use-header h3 {
	font-size: 1.6em;
}
}
@media (min-width: 992px) {
#use-header h2 {
	font-size: 2em;
}

#use-header h3 {
	font-size: 1.8em;
}
}
@media (min-width: 1200px) {
#use-header h2 {
	font-size: 2.8em;
}

#use-header h3 {
	font-size: 2em;
}
}

#use-section {
	padding-top: 30px;
	padding-bottom: 30px;
}
@media (min-width: 576px) {
#use-section {
}
}
@media (min-width: 768px) {
#use-section {
	padding-top: 60px;
	padding-bottom: 60px;
}
}
@media (min-width: 992px) {
#use-section {
}
}
@media (min-width: 1200px) {
#use-section {
}
}


/* 新着情報 */
.top-news {
	margin-top: 0em;
	padding: 0em;
	font-size: 3vw;	
}
@media (min-width: 576px) {
.top-news {
	font-size: 1em;	
}
}
.top-news dl {
	border-radius: 50em;
	padding-top: 1em;
	padding-right: 2em;
	padding-left: 2em;
	padding-bottom: 1em;
	background-color: rgba(255,255,255,1.00);
	margin-bottom: 2em;	
}
.top-news dt {
	color: rgba(12,108,191,1.00);	
}
.top-news dt span {
	font-size: 0.8em;
	color: rgba(255,255,255,1.00);
	border-radius: 50em;
	background-color: rgba(12,108,191,1.00);
	margin-right: 0.5em;
	padding-right: 1em;
	padding-left: 1em;
}
.top-news em {
	color: #FF0000;
	font-style: normal;
	font-weight: normal;
}
@media screen and (min-width: 992px) {
.top-news dl {
}
.top-news dt {
}
.top-news dd {
}
}



/*========*/
/* お問い合わせ */
/*========*/

#mailform {
	margin-right: 0px;
	margin-left: 0px;
	margin-bottom: 30px;
	margin-top: 0px;
	padding-top: 30px;
}
@media (min-width: 768px) {
#mailform {
	padding-top: 0px;
}}
.mailcont {
}
#mailform dl input,#mailform dl textarea{
	border:0;
	color:#000000;
	border:none;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;
	font-weight: normal;
	margin-top: 5px;
	margin-right: 0px;
	margin-bottom: 5px;
	margin-left: 0px;
	padding: 5px;
}
#mailform dl {
	overflow: hidden;
	padding: 0px;
	margin-top: 0px;
	margin-right: 0px;
	margin-left: 0px;
	margin-bottom: 1.5em;
	width: 100%;
	position: relative;	
}

#mailform dl dt {
	margin: 0px;
	display: block;
	text-align: left;
	vertical-align: top;
}
#mailform dl dd{
	margin: 0px;
	display: block;
	-moz-box-sizing: border-box;
  box-sizing: border-box;
}
@media (min-width: 768px) {
#mailform dl dt {
}
#mailform dl dd{
}}

#mailform  label {
	font-weight: normal;
}
#mailform  label em {
	font-style: normal;
	font-weight: normal;
}
#mailform .size-s {
	width: 25%;
}
#mailform .size-m {
	width: 99%;
}
@media (min-width: 768px) {
#mailform .size-m {
	width: 50%;
}}
#mailform .size-l {
	width: 100%;
}
#mailform .addresssearch {
	padding-top: 5px;
	padding-bottom: 5px;
	border: 1px solid #CCCCCC;
	background-color: #FFFFFF;
	font-size: 10px;
	color: #000000;
	text-align: center;
	display: inline;
	padding-right: 10px;
	padding-left: 10px;
}
#mailform .addresssearch:hover {
	background-color: #CCFFFF;
	text-decoration: none;
}
#formbutton {
	text-align: center;
	padding-top: 15px;
}
#formbutton .submit-button input {
	font-size: 100%;
	background-color: #FF7519;
	color: #FFFFFF;
	padding-top: 15px;
	padding-right: 100px;
	padding-bottom: 15px;
	padding-left: 100px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;
	-webkit-transition: 0.7s;
	-moz-transition: 0.7s;
	-o-transition: 0.7s;
	transition: 0.7s;
	border: none;
}
#formbutton .submit-button input:hover {
	background-color: #999999;
	-webkit-transition: 0.7s;
	-moz-transition: 0.7s;
	-o-transition: 0.7s;
	transition: 0.7s;
}

#mailform .contactfoot {

	margin-top: 50px;
	margin-bottom: 20px;
}
#mailform dl.col1 textarea,#reservation #mailform dl textarea {

}
#mailform h4 {
	font-weight: bold;
	margin-top: 30px;
	font-size: 120%;
}
#mailform .priv_info {
	border: 1px solid #CCCCCC;
	padding: 10px;
	height: 140px;
	overflow: scroll;
	margin-bottom: 15px;
	font-size: 80%;
	overflow-x:hidden;
	background-color: #FFFFFF;
}
#mailform .priv_info h6 {
	font-size: 110%;
	font-weight: bold;
	margin-bottom: 10px;
}
#mailform select {
	font-size: 1.1em;
}#mailform h3 {
	float: none;
	margin-bottom: 30px;
}
.ajax-loader,.wpcf7-spinner {
	display: none !important;
}
select.select-form {
	border: 1px solid #CCC;
	font-size: .3em;
}

/*==============*/
/* ニュース */
/*==============*/
.use-news {
	margin-top: 0em;
	padding-top: 1em;
	padding-right: 0em;
	padding-left: 0em;
	padding-bottom: 0em;
	border-top: 1px solid #ccc;
	margin-bottom: 3em;
}
.use-news dl {
	padding-top: 0em;
	padding-right: 0;
	padding-left: 0;
	padding-bottom: 1em;
	border-bottom: 1px solid #ccc;
	width: 100%;
}
.use-news dt {
	color: rgba(12,108,191,1.00);	
}
.use-news dt span {
	font-size: 0.8em;
	color: rgba(255,255,255,1.00);
	border-radius: 50em;
	background-color: rgba(12,108,191,1.00);
	margin-right: 0.5em;
	padding-right: 1em;
	padding-left: 1em;
}
.use-news em {
	color: #FF0000;
	font-style: normal;
	font-weight: normal;
}
@media screen and (min-width: 992px) {
.use-news dl {
}
.use-news dt {
	font-weight: normal;
}
.use-news dd {
}
}

aside{
	padding: 0;
	margin-top: 0;
	margin-right: 0;
	margin-left: 0;
	margin-bottom: 1.5em;
}
aside h3{
	margin-bottom: 0em;
	padding-top: 0.2em;
	padding-right: 0.5em;
	padding-left: 0.5em;
	padding-bottom: 0.2em;
	background-color: #E46C2D;
	font-size: 1.2em;
	color: #FFFFFF;
}
aside nav ul{
	padding: 0;
	margin: 0;
	list-style-type: none;
}
aside nav ul li{
	border-bottom: 1px solid #969696;
	
}
aside nav ul li a{
	padding-top: 1em;
	padding-right: 0.5em;
	padding-left: 2em;
	padding-bottom: 1em;
	display: block;
	position: relative;
	color: #333333;
}
aside nav ul li a::before{
	content: '';
	display: block;
	width: 1em;
	border-radius: 50%;
	height: 1em;
	position: absolute;
	top: 50%;
	left: 0.5em;
	background-color: #EB702E;
	margin-top: -0.5em;
}
aside nav ul li a::after{
	content: '';
	position: absolute;
	top: 50%;
	left: 0.9em;
	margin-top: -0.4em;
	 width: 0;
  height: 0;
  border-left: 0.4em solid #fff;
  border-top: 0.4em solid transparent;
  border-bottom: 0.4em solid transparent;
}
h3.use-ti {
	font-weight: bold;
	border-bottom: 1px solid #C72E2A;
	padding-bottom: 0.2em;
	font-size: 7vw;
}
@media (min-width: 576px) {
h3.use-ti {
	font-size: 1.8em;
}
}
@media (min-width: 768px) {
h3.use-ti {
	font-size: 2em;
}
}
@media (min-width: 992px) {
h3.use-ti {
	font-size: 2.2em;
}
}


/* ページャー  */
.pager .pagination {
	display: flex;
	flex-wrap: wrap;
	justify-content: center !important;
	width: 100%;
}

.pager .pagination li {
	display: inline;
	margin: 0 10px;
	padding: 0;
	background-color: #F6B100;
	width: 40px;
	height: 40px;
	text-align: center;
	position: relative;
	border-radius: 50%;
	z-index: 0;
}


.pager .pagination li a{
  vertical-align: middle;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-align: center;
  display:table;
  color: #fff;
  text-decoration: none;
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all  0.3s ease;
	border-radius: 50%;
	z-index: 0;
}

.pager .pagination li a span{
  display:table-cell;
  vertical-align:middle;
}

.pager .pagination li a:hover,
.pager .pagination li a.active{
	color: #fff;
	background-color: #F06343;
}

@media only screen and (max-width: 767px){
  .pager .pagination li{
    display: none;
  }

  .pager .pagination li.pre,
  .pager .pagination li.next{
    display: inline-block;
    width: 40%;
    height: 50px;
    text-align: center;
	  
	border-radius: 50em;
  }
.pager .pagination li a{
}
  .pager .pagination li.pre a,
  .pager .pagination li.next a{
    width: 100%;
    text-align: center;
  }

  .pager .pagination li.pre span::after{
    content: "　前の10件へ";
  }

  .pager .pagination li.next span::before{
    content: "次の10件へ　";
  }

}
.post {
	padding-bottom: 20px;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #CCC;
}
.post .date {
	color: rgba(12,108,191,1.00);
	display: block;
	margin-bottom: 1em;
	position: relative;	
}
.post .date span {
	font-size: 0.8em;
	color: rgba(255,255,255,1.00);
	border-radius: 50em;
	background-color: rgba(12,108,191,1.00);
	margin-right: 0.5em;
	padding-right: 1em;
	padding-left: 1em;
	position: absolute;
	right: 0%;
	top: 0%;
}
.post .posthed {
	font-size: 86%;
	padding-bottom: 10px;
	display: block;
	position: relative;
}
.post .posthed em {
	padding-top: 5px;
	padding-right: 10px;
	padding-bottom: 5px;
	padding-left: 10px;
	font-style: normal;
	color: #FFFFFF;
	position: absolute;
	top: 0px;
	right: 0px;
	font-size: 100%;
	background-color: #666666;
}
.post h3 {
	font-size: 140%;
	margin-bottom: 20px;
	padding-bottom: 10px;
	border-bottom: 1px solid #7068E8;
}
.post h3 a {
	color: #000;
}
.post img {
	height: auto;
	width: 100%;
}
.post h3:first-letter {
}
.sidenav {
	margin-bottom: 30px;	
}
.sidenav h3 {
	font-size: 100%;
	color: #FFFFFF;
	margin-bottom: 10px;
	background-color: #C1976D;
	padding: 0.5em;
	border-radius: 5px;        /* CSS3草案 */
	-webkit-border-radius: 5px;    /* Safari,Google Chrome用 */
	-moz-border-radius: 5px;   /* Firefox用 */
}
.sidenav ul {
	list-style-type: none;
	margin: 0px;
	padding: 0px;
}
.sidenav ul li {
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #b2b2b2;
	padding-top: 10px;
	padding-bottom: 10px;
}
.sidenav ul li a {
}
.postnav {
	margin-bottom: 50px;
}

.column-item{
	margin-bottom: 2.5em;
	padding-bottom: 1.5em;
	border-bottom: 1px solid #969696;
}
@media (min-width: 768px) {
.column-item{
	padding-right: 5px;
	padding-left: 5px;
}
}
@media (min-width: 992px) {
.column-item{
	padding-right: 0px;
	padding-left: 0px;
}
}
.column-item .date{
	color: rgba(12,108,191,1.00);
	display: block;
	position: relative;
}
.column-item .date span{
	font-size: 0.8em;
	color: rgba(255,255,255,1.00);
	border-radius: 50em;
	background-color: rgba(12,108,191,1.00);
	margin-right: 0.5em;
	padding-right: 1em;
	padding-left: 1em;
	position: absolute;
	right: 0px;
	top: 0px;
}
.column-item h3{
	font-size: 1.2em;
	font-weight: bold;
	margin-top: 0.5em;
	margin-bottom: 0.2em;
	padding-bottom: 0.2em;
	border-bottom: 1px solid rgba(12,108,191,1.00);
}
.column-item h3 a{
	color: #333333;
}
.column-item h3 a:hover{
	color: #D62035;
}



/*==============*/
/* その他アイテム */
/*==============*/
h2.corner-title{
	font-size: 7vw;
	font-family: 'Yusei Magic', sans-serif;
	font-weight: bold;	
}
@media (min-width: 576px) {
h2.corner-title{
	font-size: 2em;	
}
}
@media (min-width: 768px) {
h2.corner-title{
	font-size: 2.5em;	
}
}
h2.corner-title span{
	font-size: 0.6em;
	margin-left: 1em;	
}

.movie{
	position: relative;
	width: 100%;
	margin:0 auto;
}
.movie video{
	width: 100%;
}
.movie .play-btn{
	display: block;
	
}
.train-area{
	position: relative;
	overflow: hidden;		
	}

.train-img img{
	width: auto;
	height: 30vw;

	}
@media (min-width: 576px) {
.train-img img{
	width: auto;
	height: 20vw;
	}
}
@media (min-width: 768px) {
.train-img img{
	width: auto;
	height: 300px;
	}
}
@media (min-width: 992px) {
.train-img img{
	width: auto;
	height: 400px;
	}
}
	.train-img{
	position: absolute;
	top: 50%;
	left: 100%;
	transform: translate(0%, -50%);
	z-index: -1;
	width: 400vw;		
	}
	.train-img.move{
		left: 100%;
	transform: translate(0%, -50%);
	animation: appearancekey 24s ease both;
		animation-delay: 3s;
}
@keyframes appearancekey{
  0% {
	  opacity: 1;
	  left: 100%;
	transform: translate(0%, -50%);
  }
95% {
	opacity: 1;
  }
  99% {
	  opacity: 0;
	  left: -300%;
	  transform: translate(-80%, -50%);
  }
	100% {
		opacity: 0;
	  left: 100%;
	transform: translate(0%, -50%);
  }
	
}
	button {
  padding: 0;
  border: none;
  background: transparent;
}

button img {
	display: block;
	width: 20vw;
	height: auto;
}
@media (min-width: 576px) {
button img {
	width: 120px;
}
}
@media (min-width: 768px) {
button img {
	width: 120px;
}
}
@media (min-width: 992px) {
button img {
	width: 140px;
}
}


.cspm_zoom_container {
	position: absolute;
	top: auto!important;
	left: auto !important;
	width: auto;
	height: auto;
	z-index: 200;
	right: 10px;
	bottom: 10px;
}

div.cspmks_btn {
	position: absolute;
	top: 10px!important;
	z-index: 192;
	padding: 8.9px 9px;
	background-color: rgba(255,255,255,.97);
	cursor: pointer;
	display: none;
	font-size: 14px !important;
	-webkit-transition: background .2s linear;
	-moz-transition: background .2s linear;
	-ms-transition: background .2s linear;
	-o-transition: background .2s linear;
	transition: background .2s linear;
	left: auto!important;
	border-radius: 50%;
	right: 10px;	
}

div.cspmks_tools_container {

    width: 260px;
    height: auto;
    position: absolute;
    top: 10px !important;
	 left: auto !important;
	right: 60px;	
    padding: 0;
    z-index: 198;
    display: none;
    background: 0 0;
    overflow: visible;

}
/*div.cspm_recenter_map_btn {
    top: 60px!important;
	left: auto!important;
    z-index: 200;
    padding: 10px 12px;
    background-color: rgba(255,255,255,.97);
    transition: background .2s linear;
	border-radius: 50%;
	right: 10px;
}*/
div.cspm_geotarget_btn {
    position: absolute;
     top: 60px!important;
	left: auto!important;
    z-index: 200;
    padding: 10px 12px!important;
    background-color: rgba(255,255,255,.97);
    font-size: 14px !important;
    -webkit-transition: background .2s linear;
    transition: background .2s linear;
    border-radius: 50%;
	right: 10px;
}

div.cspm_recenter_map_btn {
    display: none!important;
}

.details_infos {
    display: none!important;
}

.jcarousel-skin-default .jcarousel-item-horizontal {
	height: auto!important;
    margin: 0!important;
    background: #fff;
        background-color: rgb(255, 255, 255);
}
.cspm_txt_hex, .cspm_link_hex a, .cspm_txt_hex_hover, .cspm_txt_hex_hover a, .cspm_marker_overlay button.si-close-button {
	color: #6b6b6b !important;
	text-decoration: none;	
}
.details_title a {
	text-decoration: none;
	font-size: 0.9em!important;
	font-weight: 400;
	background: 0 0;
	padding-top: 1em!important;
	padding-right: 0!important;
	padding-left: 0!important;
	padding-bottom: 0!important;
	text-overflow: ellipsis;
	overflow: hidden;
	white-space: nowrap;
	display: block;
	
	border-bottom: 1px solid #f5f5f5;
	line-height: 100%;

}
.details_btn {
    left: 0px!important;
    top: 0px!important;
}
.details_container {
	width: 100%!important;
	
	height: auto!important;	
}
a.details_btn {
	position: relative!important;
	height: auto!important;
	width: auto!important;
	padding-top: 0.3em!important;
	padding-right: 20px!important;
	padding-left: 20px!important;
	padding-bottom: 0.3em!important;
	-webkit-transition: all 1s ease-in-out!important;
	-moz-transition: all 1s ease-in-out!important;
	-o-transition: all 1s ease-in-out!important;
	-ms-transition: all 1s ease-in-out!important;
	transition: all 1s ease-in-out!important;
	-webkit-transform: scale(1)!important;
	-moz-transform: scale(1)!important;
	-o-transform: scale(1)!important;
	-ms-transform: scale(1)!important;
	transform: scale(1)!important;
	font-size: 1em!important;
	color: #fff;
	font-size: 0.8em!important;
		margin-right: auto!important;
	margin-left: auto!important;
	border-radius: 50em!important;
}
a.details_btn:hover {
	text-decoration: none;	
}
.details_container{
	display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
	
}
.details_container div:first-child{
	order: 2;
	padding: 1em!important;
	text-align: center;
	width: 100%!important;
	height: 3em;	
}
.details_container div.details_title{
	order: 1;
}
.jcarousel-skin-default .jcarousel-container-horizontal ul.jcarousel-list-horizontal {
	padding-left: 0px !important;
	height: auto!important;
	margin-left: -10px!important;
	position: relative;
	overflow: visible!important;
}
.jcarousel-skin-default .jcarousel-container-horizontal {
    width: auto;
    padding: 0px 0 !important;
    margin-top: 0;
}
.cspm_border_shadow {
    box-shadow: 
		0 0px 0px -1px,inset 0 -1px 0 0 transparent!important;
}
ul[id^="cspm_carousel_"] li.cspm_carousel_first_item, ul[id^="cspm_carousel_"] li:hover {
    cursor: pointer !important;
    background: #fbfbfb;
        background-color: rgb(255, 255, 255)!important;
    box-shadow: transparent 0 1px 4px -1px,inset 0 0 0 1px transparent!important;
}
.jcarousel-skin-default .jcarousel-container {
    background: #fff!important;
    border-top: 0;
    border-bottom: 0;
}
div[id^="codespacing_progress_map_div"] {
    height: 100vh!important;
	margin: 0 auto;
    padding: 0;
}

.cspm_linear_gradient_bg {
	width: 100%;
    height: auto!important;
    background:  transparent!important;
        background-size: auto;
    background-size: 4px 4px;
}
.iziModal .iziModal-iframe {
	border: 0;
	margin: 0 0 -6px;
	width: 100%;
	height: 80vh!important;
	transition: height .3s ease;
	background-color: rgba(255,255,255,1.00)!important;
}
.iziModal {
    display: none;
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
        margin-top: auto;
        margin-bottom: auto;
    background: #fff;
    box-shadow: 0 0 8px transparent!important;
    transition: margin-top .3s ease,height .3s ease;
    transform: translateZ(0);
    box-sizing: border-box;
	height: 90vh!important;
}

.iziModal .iziModal-header {
    background: #88a0b9;
    padding: 14px 18px 15px;
    box-shadow: inset 0 -10px 15px -12px rgba(0,0,0,.3),0 0 0 #555;
    overflow: hidden;
    position: relative;
    z-index: 10;
}
.iziModal.hasShadow::after{
	display: none;   
}
.iziModal .iziModal-header {
    background: transparent!important;
    padding: 14px 18px 15px;
    box-shadow: inset 0 -10px 15px -12px transparent,0 0 0 transparent!important;
    overflow: hidden;
    position: relative;
    z-index: 10;
}
.iziModal {
    display: none;
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
        margin-top: auto;
        margin-bottom: auto;
    background: transparent!important;
    box-shadow: 0 0 8px rgba(0,0,0,.3);
    transition: margin-top .3s ease,height .3s ease;
    transform: translateZ(0);
    box-sizing: border-box;
}
.iziModal .iziModal-button {
    display: block;
    float: right;
    z-index: 2;
    outline: 0;
    height: 34px;
    width: 34px;
    border: 0;
    padding: 0;
    margin: 0;
    opacity: 1!important;
    border-radius: 50%;
    transition: transform .5s cubic-bezier(.16,.81,.32,1),opacity .5s ease;
    background-size: 67% !important;
    -webkit-tap-highlight-color: transparent;
}
.iziModal .iziModal-button-fullscreen{
	display: none !important;
}
div.cspm_zoom_in_control, div.cspm_zoom_out_control {
	left: 0;
	top: 0;
	position: relative;
	z-index: 9;
	padding: 14px !important;
	font-size: 14px !important;
	cursor: pointer;
	-webkit-transition: background .2s linear;
	-moz-transition: background .2s linear;
	-ms-transition: background .2s linear;
	-o-transition: background .2s linear;
	transition: background .2s linear;
	background-color: rgba(255,255,255,1.00)!important;	
	
}
div.cspm_zoom_in_control {
	border-top-left-radius: 50em!important;	
	border-top-right-radius: 50em!important;		
}
div.cspm_zoom_out_control {
	border-bottom-left-radius: 50em!important;	
	border-bottom-right-radius: 50em!important;		
}
div.cspm_zoom_in_control svg.cspm_svg .st0, div.cspm_zoom_out_control svg.cspm_svg .st0 {
	fill: rgba(87,87,87,1.00) !important;
	
}
/*サークルの色*/
div.cspm_infobox_content_container.rounded_bubble, div.cspm_infobox_content_container.square_bubble {
	height: 60px;
	width: 60px;
	padding: 5px;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	background: rgba(255,255,255,1);
	position: relative;	
}

.playground div.cspm_infobox_content_container.rounded_bubble, .playground div.cspm_infobox_content_container.square_bubble {
	background-color: rgba(255,224,225,1.00)!important;	
}
.trainview div.cspm_infobox_content_container.rounded_bubble, .trainview div.cspm_infobox_content_container.square_bubble {
	background-color: rgba(201,250,255,1.00)!important;	
}
.fumikiri div.cspm_infobox_content_container.rounded_bubble, .fumikiri div.cspm_infobox_content_container.square_bubble {
	background-color: rgba(255,252,202,1.00)!important;	
}
.sightseeing div.cspm_infobox_content_container.rounded_bubble, .sightseeing div.cspm_infobox_content_container.square_bubble {
	background-color: rgba(223,255,211,1.00)!important;	
}
.mini-railroad div.cspm_infobox_content_container.rounded_bubble, .mini-railroad div.cspm_infobox_content_container.square_bubble {
    background: rgba(255,255,255,1)!important;	
}
div.cspm_infobox_content_container.rounded_bubble::after, div.cspm_infobox_content_container.square_bubble::after {
	content: '';
	width: 0;
	height: 0;
	border-left: 6px solid transparent;
	border-right: 6px solid transparent;
	border-top: 14px solid rgba(255,255,255,1.00);
	position: absolute;
	top: 98%;
	left: 50%;
	margin-left: -6px;	
}
.playground div.cspm_infobox_content_container.rounded_bubble::after, .playground div.cspm_infobox_content_container.square_bubble::after {
	content: '';
  border-top: 14px solid rgba(255,224,225,1.00);
}
.trainview div.cspm_infobox_content_container.rounded_bubble::after, .trainview div.cspm_infobox_content_container.square_bubble::after {
	content: '';
  border-top: 14px solid rgba(201,250,255,1.00);
}
.fumikiri div.cspm_infobox_content_container.rounded_bubble::after, .fumikiri div.cspm_infobox_content_container.square_bubble::after {
	content: '';
  border-top: 14px solid rgba(255,252,202,1.00);
}
.sightseeing div.cspm_infobox_content_container.rounded_bubble::after, .sightseeing div.cspm_infobox_content_container.square_bubble::after {
	content: '';
  border-top: 14px solid rgba(223,255,211,1.00);
}
.mini-railroad div.cspm_infobox_content_container.rounded_bubble::after, .mini-railroad div.cspm_infobox_content_container.square_bubble::after {
	content: '';
  border-top: 14px solid rgba(255,255,255,1.00);
}
.si-content, .si-frame {
	overflow: visible!important;
}
/*サークルにある背景*/
div.cspm_infobox_container {
    height: auto;
    width: auto;
    z-index: 99;
    background: transparent!important;	
}
/*下の三角消してもいいかも*/
.cspm_marker_infobox .si-pointer-bg-top {
    border-bottom: 0 solid transparent !important;
    border-left: 2px solid transparent !important;
    border-right: 10px solid transparent !important;
    border-top: 10px solid #fff !important;
    position: absolute;
    margin-left: 3px;
    bottom: -9px;
    border-radius: 0 !important;
	display: none !important;
}

@-webkit-keyframes flash2 {
  from, 50%, to {
    opacity: 1 !important;
  }

  25%, 75% {
    opacity: 1 !important;
  }
	from, 20%, 53%, 80%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
    animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
    -webkit-transform: translate3d(0,0,0);
    transform: translate3d(0,0,0);
  }

  40%, 43% {
    -webkit-animation-timing-function: cubic-bezier(0.755, 0.050, 0.855, 0.060);
    animation-timing-function: cubic-bezier(0.755, 0.050, 0.855, 0.060);
    -webkit-transform: translate3d(0, -30px, 0);
    transform: translate3d(0, -30px, 0);
  }

  70% {
    -webkit-animation-timing-function: cubic-bezier(0.755, 0.050, 0.855, 0.060);
    animation-timing-function: cubic-bezier(0.755, 0.050, 0.855, 0.060);
    -webkit-transform: translate3d(0, -15px, 0);
    transform: translate3d(0, -15px, 0);
  }

  90% {
    -webkit-transform: translate3d(0,-4px,0);
    transform: translate3d(0,-4px,0);
  }
}

@keyframes flash2 {
  from, 50%, to {
    opacity: 1 !important;
  }

  25%, 75% {
    opacity: 1 !important;
  }
	from, 20%, 53%, 80%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
    animation-timing-function: cubic-bezier(0.215, 0.610, 0.355, 1.000);
    -webkit-transform: translate3d(0,0,0);
    transform: translate3d(0,0,0);
  }

  40%, 43% {
    -webkit-animation-timing-function: cubic-bezier(0.755, 0.050, 0.855, 0.060);
    animation-timing-function: cubic-bezier(0.755, 0.050, 0.855, 0.060);
    -webkit-transform: translate3d(0, -30px, 0);
    transform: translate3d(0, -30px, 0);
  }

  70% {
    -webkit-animation-timing-function: cubic-bezier(0.755, 0.050, 0.855, 0.060);
    animation-timing-function: cubic-bezier(0.755, 0.050, 0.855, 0.060);
    -webkit-transform: translate3d(0, -15px, 0);
    transform: translate3d(0, -15px, 0);
  }

  90% {
    -webkit-transform: translate3d(0,-4px,0);
    transform: translate3d(0,-4px,0);
  }
}

.flash {
  -webkit-animation-name: flash2 !important;
  animation-name: flash2 !important;
}

.jcarousel-skin-default .jcarousel-direction-rtl .jcarousel-prev-horizontal, .jcarousel-skin-default .jcarousel-prev-horizontal, .jcarousel-skin-default .jcarousel-prev-horizontal:focus, .jcarousel-skin-default .jcarousel-prev-horizontal:hover {
    background-image: url(../../img/jCarousel/left_arrow.png);
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-color: transparent!important;
}
.jcarousel-skin-default .jcarousel-next-horizontal {
    position: absolute;
    top: 0;
    right: 0;
    width: 40px;
    height: 100%;
    cursor: pointer;
    background-image: url(../../img/jCarousel/right_arrow.png);
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-color: transparent!important;
    opacity: .7;
}

