@charset "UTF-8";

body {
	font-family: "Noto Sans Japanese", "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","メイリオ","Meiryo","Osaka","ＭＳ Ｐゴシック", "MS P Gothic",Verdana,Arial, Helvetica, sans-serif;
	color: #333;
	line-height: 1.6;
	font-size: 16px;
	-webkit-text-size-adjust: 100%;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

@media only screen and (max-width: 750px) {
	body {
		min-width: 320px;
	}
}

input, textarea {
	font-family: "Noto Sans Japanese", "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","メイリオ","Meiryo","Osaka","ＭＳ Ｐゴシック", "MS P Gothic",Verdana,Arial, Helvetica, sans-serif;
}

strong {
	font-weight: bold;
}

a:focus {
	outline: none;
}

a {
	color: #09f;
	text-decoration: none;
}

a:hover {
	color: #09f;
	text-decoration: underline;
}

img{
-webkit-backface-visibility: hidden;
}


/*////////////////////////////////////////

padding, margin

////////////////////////////////////////*/
.padT0 {
	padding-top: 0 !important;
}

.padT1 {
	padding-top: 0.5em !important;
}

.padT2 {
	padding-top: 1em !important;
}

.padT3 {
	padding-top: 1.5em !important;
}

.padT4 {
	padding-top: 2em !important;
}

.padT5 {
	padding-top: 2.5em !important;
}

.padL0 {
	padding-left: 0 !important;
}

.padL1 {
	padding-left: 0.5em !important;
}

.padL2 {
	padding-left: 1em !important;
}

.padL3 {
	padding-left: 1.5em !important;
}

.padL4 {
	padding-left: 2em !important;
}

.padL5 {
	padding-left: 2.5em !important;
}

.padR0 {
	padding-right: 0 !important;
}

.padR1 {
	padding-right: 0.5em !important;
}

.padR2 {
	padding-right: 1em !important;
}

.padR3 {
	padding-right: 1.5em !important;
}

.padR4 {
	padding-right: 2em !important;
}

.padR5 {
	padding-right: 2.5em !important;
}

.padB0 {
	padding-bottom: 0 !important;
}

.padB1 {
	padding-bottom: 0.5em !important;
}

.padB2 {
	padding-bottom: 1em !important;
}

.padB3 {
	padding-bottom: 1.5em !important;
}

.padB4 {
	padding-bottom: 2em !important;
}

.padB5 {
	padding-bottom: 2.5em !important;
}

.marT0 {
	margin-top: 0 !important;
}

.marT1 {
	margin-top: 0.5em !important;
}

.marT2 {
	margin-top: 1em !important;
}

.marT3 {
	margin-top: 1.5em !important;
}

.marT4 {
	margin-top: 2em !important;
}

.marT5 {
	margin-top: 2.5em !important;
}

.marL0 {
	margin-left: 0 !important;
}

.marL1 {
	margin-left: 0.5em !important;
}

.marL2 {
	margin-left: 1em !important;
}

.marL3 {
	margin-left: 1.5em !important;
}

.marL4 {
	margin-left: 2em !important;
}

.marL5 {
	margin-left: 2.5em !important;
}

.marR0 {
	margin-right: 0 !important;
}

.marR1 {
	margin-right: 0.5em !important;
}

.marR2 {
	margin-right: 1em !important;
}

.marR3 {
	margin-right: 1.5em !important;
}

.marR4 {
	margin-right: 2em !important;
}

.marR5 {
	margin-right: 2.5em !important;
}

.marB0 {
	margin-bottom: 0 !important;
}

.marB1 {
	margin-bottom: 0.5em !important;
}

.marB2 {
	margin-bottom: 1em !important;
}

.marB3 {
	margin-bottom: 1.5em !important;
}

.marB4 {
	margin-bottom: 2em !important;
}

.marB5 {
	margin-bottom: 2.5em !important;
}

/*////////////////////////////////////////

汎用class

////////////////////////////////////////*/
.only-pc {
	display: block;
}

.only-pci {
	display: inline-block;
}

.only-sp {
	display: none;
}

.only-spi {
	display: none;
}

@media screen and (max-width: 750px) {
	.only-pc {
		display: none;
	}
	.only-pci {
		display: none;
	}
	.only-sp {
		display: block;
	}
	.only-spi {
		display: inline-block;
	}
}

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

.align-l {
	text-align: left !important;
}

.align-r {
	text-align: right !important;
}

.alpha-over{
    transition: all 0.3s;
}
.alpha-over:hover{
    opacity: 0.7;
}


/* main
-----------------------------*/
main{
	min-width: 1200px;
}
@media screen and (max-width: 750px) {
main{
	min-width: initial;
	padding-top: 65px;
}
}


/* .tpl-inner-wrap
-----------------------------*/
.tpl-inner-wrap {
	min-width: 1200px;
	width: auto;
	margin: 0 auto;
	clear: both;
	background: #fff;
}
@media screen and (max-width: 750px) {
.tpl-inner-wrap {
	min-width: initial;
}
}


/* .gnav
-----------------------------*/
.gnav {
	display: -webkit-flex; /* Safari */
	display: flex;
}
.gnav li {
	padding: 0 25px;
	position: relative;
	display: -webkit-flex; /* Safari */
	display: flex;
	-webkit-align-items: center;
	align-items: center;
}
.gnav li:last-child {
	padding: 0 0 0 25px !important;
}
.gnav li:not(:last-child)::after {
	content: "";
	display: block;
	width: 1px;
	height: 100%;
	background-color: white;
	position: absolute;
	top: 0;
	right: 0;
	opacity: 0.3;
}
.gnav li a {
	display: block;
	color: white;
	font-size: 15px;
	font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	font-weight: bold;
	text-align: center;
	text-decoration: none;
	line-height: 1.33;
	letter-spacing: 0.05em;
	position: relative;
}
.gnav li a::after {
	content: "";
	display: block;
	width: 100%;
	height: 1px;
	background-color: white;
	position: absolute;
	left: 0;
	bottom: -4px;
	transform: scale(0,1);
	transform-origin: center center;
	transition: all 1s cubic-bezier(0.19, 1, 0.22, 1);
}
.gnav li a:hover::after {
	transform: scale(1,1);
}


/* #tpl-top-header
-----------------------------*/
#tpl-top-header {
	width: 100%;
	position: fixed;
	z-index: 1999;
	opacity: 0;
	transition: all 1.5s cubic-bezier(0.19, 1, 0.22, 1);
	transform:translateY(-20px);
	pointer-events: none;
}
@media screen and (max-width: 750px) {
	#tpl-top-header {
		display: none;
	}
}

#tpl-top-header.show {
	opacity: 1;
	pointer-events: auto;
	z-index: 2001;
	transform:translateY(0);
}

#tpl-top-header .tpl-inner-wrap {
	background: none;
	color: #fff;
	padding: 30px 45px;
	display: -webkit-flex; /* Safari */
	display: flex;
	-webkit-justify-content: space-between; /* Safari */
	justify-content:         space-between;
	-webkit-align-items: center; /* Safari */
	align-items:         center;
}


/* #tpl-contents-header
-----------------------------*/
#tpl-contents-header {
	width: 100%;
	height: 90px;
	padding: 0 15px;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 2000;
	opacity: 0;
	transition: all 1.5s cubic-bezier(0.19, 1, 0.22, 1);
	background-color: white;
	border-bottom: 1px solid #EEEEEE;
}
@media screen and (max-width: 750px) {
#tpl-contents-header {
	display: none;
}
}

#tpl-contents-header.show{
	opacity: 1;
	z-index: 2002;
}

#tpl-contents-header .tpl-inner-wrap {
	height: 100%;
	background: none;
	color: #fff;
	padding: 0 30px;
	display: -webkit-flex; /* Safari */
	display: flex;
	-webkit-justify-content: space-between; /* Safari */
	justify-content:         space-between;
	-webkit-align-items: center; /* Safari */
	align-items:         center;
}
#tpl-contents-header .casual-logo {
	transition: all 1.5s cubic-bezier(0.19, 1, 0.22, 1);
	transform: translateY(20px);
}
#tpl-contents-header.show .casual-logo{
	transform: translateY(0px);
}
#tpl-contents-header .gnav {
	transition: all 1.5s cubic-bezier(0.19, 1, 0.22, 1);
	transform: translateY(20px);
}
#tpl-contents-header.show .gnav{
	transform: translateY(0px);
}
#tpl-contents-header .gnav li{
}
#tpl-contents-header .gnav li:not(:last-child)::after {
	background-color: black;
	opacity: 0.15;
}
#tpl-contents-header .gnav li a {
	color: black;
}
#tpl-contents-header .gnav li a::after {
	background-color: #333333;
}


/* #tpl-mv-header
-----------------------------*/
#tpl-mv-header {
	width: 100%;
	position: fixed;
	z-index: 1999;
	opacity: 0;
	transition: all 1.5s cubic-bezier(0.19, 1, 0.22, 1);
	transform:translateY(-20px);
	pointer-events: none;
}
@media screen and (max-width: 750px) {
#tpl-mv-header {
	display: none;
}
}
#tpl-mv-header.show {
	opacity: 1;
	pointer-events: auto;
	z-index: 2001;
	transform:translateY(0);
}

#tpl-mv-header .tpl-inner-wrap {
	background: none;
	color: #fff;
	padding: 37px 45px 0;
	display: -webkit-flex; /* Safari */
	display: flex;
	-webkit-justify-content: space-between; /* Safari */
	justify-content:         space-between;
	-webkit-align-items: center; /* Safari */
	align-items:         center;
}

#tpl-mv-header .site-logo img{
	width: auto;
}
#tpl-mv-header .site-logo img.only-message{
	display: none;
}
body.message #tpl-mv-header .site-logo img{
	display: none;
}
body.message #tpl-mv-header .site-logo img.only-message{
	display: block;
}


body.message #tpl-mv-header .gnav li{
	border-right-color: black;
}
body.message #tpl-mv-header .gnav li a {
	color: black;
}
#tpl-mv-header .gnav li a:hover{
	opacity: 1;
}
body.message #tpl-mv-header .gnav li a::after {
	background-color: black;
}


/* #sp-header
----------------------------*/
#sp-header {
	position: fixed;
	z-index: 9999;
	height: 51px;
	background-color: white;
	width: 100%;
}
@media screen and (min-width: 751px) {
#sp-header {
	display: none;
}
}

#sp-header .sp-header-inner {
	position: relative;
	width: 100%;
	height: 100%;
	display: -webkit-flex; /* Safari */
	display: flex;
	-webkit-align-items: center; /* Safari */
	align-items:         center;
}
#sp-header .casual-logo {
	width: 233px;
	margin-left: 15px;
}
#sp-header .casual-logo img{
	width: 100%;
}
#sp-header .sp-nav-btn{
	position: absolute;
	width: 58px;
	height: 100%;
	top: 0;
	right: 0;
	display: -webkit-flex; /* Safari */
	display: flex;
	-webkit-justify-content: center; /* Safari */
	justify-content:         center;
	-webkit-align-items: center; /* Safari */
	align-items:         center;
}
#sp-header .sp-nav-btn-inner{
	position: relative;
	width: 18px;
	height: 14px;
}
#sp-header .sp-nav-btn-inner .line{
	position: absolute;
	left: 0;
	width: 100%;
	height: 2px;
	background-color: #999999;
}
#sp-header .sp-nav-btn-inner .line:nth-child(2){
	top: 6px;
}
#sp-header .sp-nav-btn-inner .line:nth-child(3){
	top: 12px;
}
#sp-header .sp-nav-btn-inner .line:nth-of-type(1) {
  animation: menu-bar01 .75s forwards;
}
@keyframes menu-bar01 {
  0% {
    transform: translateY(6px) rotate(45deg);
  }
  50% {
    transform: translateY(6px) rotate(0);
  }
  100% {
    transform: translateY(0) rotate(0);
  }
}
#sp-header .sp-nav-btn-inner .line:nth-of-type(2) {
  transition: all .25s .25s;
  opacity: 1;
}
#sp-header .sp-nav-btn-inner .line:nth-of-type(3) {
  animation: menu-bar02 .75s forwards;
}
@keyframes menu-bar02 {
  0% {
    transform: translateY(-6px) rotate(-45deg);
  }
  50% {
    transform: translateY(-6px) rotate(0);
  }
  100% {
    transform: translateY(0) rotate(0);
  }
}
#sp-header .sp-nav-btn.active .sp-nav-btn-inner .line:nth-of-type(1) {
  animation: active-menu-bar01 .75s forwards;
}
@keyframes active-menu-bar01 {
  0% {
    transform: translateY(0) rotate(0);
  }
  50% {
    transform: translateY(6px) rotate(0);
  }
  100% {
    transform: translateY(6px) rotate(45deg);
  }
}
#sp-header .sp-nav-btn.active .sp-nav-btn-inner .line:nth-of-type(2) {
  opacity: 0;
}
#sp-header .sp-nav-btn.active .sp-nav-btn-inner .line:nth-of-type(3) {
  animation: active-menu-bar03 .75s forwards;
}
@keyframes active-menu-bar03 {
  0% {
    transform: translateY(0) rotate(0);
  }
  50% {
    transform: translateY(-6px) rotate(0);
  }
  100% {
    transform: translateY(-6px) rotate(-45deg);
  }
}


/* #sp-nav
----------------------------*/
#sp-nav{
	opacity: 0;
	pointer-events: none;
	transition: all 0.75s;
	position: fixed;
	z-index: 9998;
	background-color: white;
	width: 100%;
	padding: 0 20px 0;
    overflow-y: scroll;
    height: 100vh;
    -webkit-overflow-scrolling: touch;
}
@media screen and (min-width: 751px) {
#sp-nav{
	display: none;
}
}

#sp-nav.show{
	opacity: 1;
	pointer-events: auto;
}
#sp-nav ul{
	margin-bottom: 35px;
	padding-top: 65px;
}
#sp-nav ul li:not(:last-child){
	border-bottom: 1px solid #F2F2F2;
}
#sp-nav ul li a{
	color: inherit;
	font-size: 15px;
	font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	letter-spacing: 0.1em;
	padding: 20px 10px;
	display: block;
	position: relative;
}
#sp-nav ul li a::before,
#sp-nav ul li a::after{
	content: "";
	display: block;
	position: absolute;
}
#sp-nav ul li a::before{
	width: 13px;
	height: 1px;
	top: 33px;
	right: 10px;
	background-color: #333;
	transform-origin: left center;
}
#sp-nav ul li a::after{
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 3px 0 0 6px;
	border-color: transparent transparent transparent #333333;
	top: 30px;
	right: 10px;
	transform-origin: right bottom;
}
#sp-nav .sp-nav-close{
	display: inline-block;
	float: right;
	padding-bottom: 50px;
}
#sp-nav .sp-nav-close-mark{
	font-size: 13px;
	color: #999999;
	padding-right: 5px;
}
#sp-nav .sp-nav-close-text{
	color: inherit;
	font-size: 15px;
	font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	letter-spacing: 0.1em;
}


/* #tpl-topicpath
-----------------------------*/
#tpl-topicpath {
	width: 100%;
}

@media screen and (max-width: 750px) {
	#tpl-topicpath {
		display: none;
	}
}

#tpl-topicpath ul {
	overflow: hidden;
	padding: 10px;
}

#tpl-topicpath li {
	display: inline-block;
}


/* #local-nav
-----------------------------*/
#tpl-local-nav{
	max-width: 1400px;
	margin: auto;
}
#tpl-local-nav ul{
	display: -webkit-flex; /* Safari */
	display: flex;
}
#tpl-local-nav ul li{
	width: 25%;
}
body.route #tpl-local-nav ul li.route{
	display: none;
}
body.attraction #tpl-local-nav ul li.attraction{
	display: none;
}
body.view #tpl-local-nav ul li.view{
	display: none;
}
body.history #tpl-local-nav ul li.history{
	display: none;
}
body.project #tpl-local-nav ul li.project{
	display: none;
}
body.message #tpl-local-nav ul li.message{
	display: none;
}
#tpl-local-nav ul li .local-nav-inner{
	padding-top: 65.714285714%;
	display: block;
	color: white;
	text-decoration: none;
	position: relative;
	overflow: hidden;
}
#tpl-local-nav ul li a:hover{
	opacity: 1;
}
#tpl-local-nav ul li .local-nav-img{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}
#tpl-local-nav ul li.route .local-nav-img{
	background-image: url(/lp/casual/assets/common/img/local-nav-bg-route.jpg);
}
#tpl-local-nav ul li.attraction .local-nav-img{
	background-image: url(/lp/casual/assets/common/img/local-nav-bg-attraction.jpg);
}
#tpl-local-nav ul li.view .local-nav-img{
	background-image: url(/lp/casual/assets/common/img/local-nav-bg-view.jpg);
}
#tpl-local-nav ul li.history .local-nav-img{
	background-image: url(/lp/casual/assets/common/img/local-nav-bg-history.jpg);
}
#tpl-local-nav ul li.project .local-nav-img{
	background-image: url(/lp/casual/assets/common/img/local-nav-bg-project.jpg);
}
#tpl-local-nav ul li.message .local-nav-img{
	background-image: url(/lp/casual/assets/common/img/local-nav-bg-message.jpg);
}
#tpl-local-nav ul li .local-nav-txt-wrap{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: -webkit-flex; /* Safari */
	display: flex;
	-webkit-justify-content: center; /* Safari */
	justify-content:         center;
	-webkit-align-items: center; /* Safari */
	align-items:         center;
	padding: 15px;
}
#tpl-local-nav ul li .local-nav-txt{
	text-align: center;
	font-size: 18px;
	font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	font-weight: bold;
	letter-spacing: 0.05em;
}
#tpl-local-nav ul li .local-nav-txt small{
	font-size: 15px;
	font-weight: normal;
	padding-top: 10px;
	display: block;
	letter-spacing: 0.15em;
}
@media screen and (min-width: 751px) {
	#tpl-local-nav ul li .local-nav-img{
		transition: all 2s cubic-bezier(0.19, 1, 0.22, 1);
	}
	#tpl-local-nav ul li a:hover .local-nav-img{
		transform: scale(1.1);
	}
}
@media screen and (max-width: 750px) {
	#tpl-local-nav{
		padding-left: 5.33333vw;
		padding-right: 5.33333vw;
		max-width: initial;
	}
	#tpl-local-nav ul{
		-webkit-flex-wrap: wrap; /* Safari */
		flex-wrap:         wrap;
	}
	#tpl-local-nav ul li{
		width: 50%;
	}
	#tpl-local-nav ul li .local-nav-txt{
		font-size: 12px;
	}
	#tpl-local-nav ul li .local-nav-txt small{
		padding-top: 5px;
		font-size: 10px;
	}
}


.ferry-sunflower-bnr{
	padding: 80px 0;
	text-align: center;
}
.ferry-sunflower-bnr p{
	width: 520px;
	margin: auto;
}
.ferry-sunflower-bnr img{
	width: 100%;
}
@media screen and (max-width: 750px) {
	.ferry-sunflower-bnr{
		padding: 40px 20px;
	}
	.ferry-sunflower-bnr p{
		width: 100%;
	}
}


/* #tpl-pagetop
-----------------------------*/
#tpl-pagetop {
	position: fixed;
	bottom: 50px;
	right: 30px;
	width: 38px;
	height: 46px;
	opacity: 0;
	transition: all 1s;
}
#tpl-pagetop.show {
	opacity: 1;
}
#tpl-pagetop a{
	color: black;
	font-size: 14px;
	font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	font-weight: bold;
	position: relative;
	padding: 12px 0 0 12px;
	display: block;
	height: 100%;
	letter-spacing: 0.1em;
	text-decoration: none;
}
#tpl-pagetop a::before,
#tpl-pagetop a::after{
	content: "";
	display: block;
	position: absolute;
}
#tpl-pagetop a::before{
	width: 1px;
	height: 100%;
	top: 0;
	left: 0;
	background-color: #333;
	transform-origin: center bottom;
}
#tpl-pagetop a::after{
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 10px 0 0 4px;
	border-color: transparent transparent transparent #333333;
	top: 0;
	left: 0;
	transform-origin: left top;
}
#tpl-pagetop a:hover::before{
    animation-name: pagetop-line-1;
	animation-duration: 0.5s;
	animation-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
}
#tpl-pagetop a:hover::after{
    animation-name: pagetop-line-2;
	animation-duration: 0.5s;
	animation-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
}
@keyframes pagetop-line-1 {
    0% {
    	transform: scale(1,0);
    }
    100% {
    	transform: scale(1,1);
    }
}
@keyframes pagetop-line-2 {
    0% {
    	transform: scale(0,0);
    }
    50% {
    	transform: scale(0,0);
    }
    100% {
    	transform: scale(1,1);
    }
}
@media screen and (max-width: 750px) {
	#tpl-pagetop {
		bottom: 25px;
		right: 15px;
		width: 30px;
		height: 28px;
	}
	#tpl-pagetop a{
		font-size: 12px;
		padding: 4px 0 0 10px;
	}
	#tpl-pagetop a::after{
		border-width: 6px 0 0 3px;
	}
}


/* #tpl-footer
-----------------------------*/
#tpl-footer {
	clear: both;
	background-color: white;
	position: relative;
	z-index: 1000;
	border-top: 1px solid #EAEAEA;
	height: 120px;
}

#tpl-footer .tpl-inner-wrap {
	background: none;
	display: -webkit-flex; /* Safari */
	display: flex;
	-webkit-justify-content: space-between; /* Safari */
	justify-content:         space-between;
}
#tpl-footer .footer-logo{
	padding: 25px 0 0 35px;
}
#tpl-footer .footer-logo a{
	font-size: 13px;
	color: inherit;
}
#tpl-footer .footer-logo a:hover{
	text-decoration: none;
}
#tpl-footer .footer-logo img{
	vertical-align: middle;
	margin-right: 10px;
	width: 145px;
}
#tpl-footer .footer-logo a .footer-logo-txt{
	padding-right: 20px;
	background: url(/lp/casual/assets/common/img/blank-icon.png) no-repeat right center;
}

#tpl-footer .copyright {
	font-size: 10px;
	padding: 40px 125px 0 0;
}

@media screen and (max-width: 750px) {
	#tpl-footer {
		height: auto;
		padding: 30px 0 10px;
	}

	#tpl-footer .tpl-inner-wrap {
		display: block;
	}
	#tpl-footer .footer-logo{
		padding: 0;
	}
	#tpl-footer .footer-logo a{
		font-size: 10px;
		padding-right: 0;
		display: block;
		text-align: center;
	}
	#tpl-footer .footer-logo img{
		display: block;
		margin-left: auto;
		margin-right: auto;
		margin-bottom: 10px;
	}
	#tpl-footer .footer-logo a .footer-logo-txt{
		padding-right: 17px;
		background-size: 10px auto;
	}

	#tpl-footer .copyright {
		padding: 30px 0 0;
		text-align: center;
	}
}
