@charset "UTF-8";




/* メインビジュアル */

#mv {
	background: url(../../img/experience/main_bg.jpg) no-repeat center center;
	background-size: cover;
	padding: 10% 0;
	}

#mv h1 {
	display: block;
	color: #fff;
	font-size: 50px;
	font-weight: 700;
	line-height: 1em;
	text-align: center;
	letter-spacing: 10px;
	text-shadow: 0 2px 5px rgba(0,0,0,.5);
	}
@media screen and (max-width: 767px) {
#mv h1 {
	font-size: 24px;
	line-height: 1.5em;
	letter-spacing: 5px;
	}
}

#mv h1 span {
	display: block;
	font-size: 25px;
	}
@media screen and (max-width: 767px) {
#mv h1 span {
	font-size: 18px;
	}
}



/* intro */

#intro {
	margin: 0 0 50px 0;
	}
@media screen and (max-width: 767px) {
#intro {
	margin: 0;
	}
}

#intro h2 {
	margin: 80px 0 20px 0;
	color: #331F15;
	line-height: 1.5em;
	letter-spacing: 4px;
	}
@media screen and (max-width: 767px) {
#intro h2 {
	margin: 40px 0 20px 0;
	letter-spacing: 3px;
	}
}

#intro h2 span {
	display: block;
	font-size: .8em;
	letter-spacing: .1em;
	}

#intro .desc {
	display: block;
	width: 850px;
	margin: 0 auto;
	}
@media screen and (max-width: 767px) {
#intro .desc {
	width: 100%;
	}
}

#intro .desc p {
	color: #331F15;
	font-size: 18px;
	line-height: 2;
	letter-spacing: 2px;
	text-align: center;
	}
@media screen and (max-width: 767px) {
#intro .desc p {
	font-size: 16px;
	text-align: left;
	letter-spacing: 1.5px;
	}
#intro .desc p br {
	display: none;
	}
}




/* OPTION */

#option h2 {
	background: -webkit-gradient(linear, left top, left bottom, from(rgba(51, 31, 21, 0)), color-stop(48%, rgba(51, 31, 21, 0)), color-stop(48%, #331f15), color-stop(50%, #331f15), color-stop(50%, rgba(51, 31, 21, 0)), to(rgba(51, 31, 21, 0)));
	background: linear-gradient(to bottom, rgba(51, 31, 21, 0) 0%, rgba(51, 31, 21, 0) 48%, #331f15 48%, #331f15 50%, rgba(51, 31, 21, 0) 50%, rgba(51, 31, 21, 0) 100%);
	position: relative;
	margin: 140px auto 70px auto;
	color: #331F15;
	font-size: 30px;
	line-height: 1em;
	letter-spacing: 4px;
	z-index: 1;
	}
@media screen and (max-width: 767px) {
#option h2 {
	font-size: 32px;
	margin-top: 0;
	}
}

#option h2 span {
	content: '';
	display: inline-block;
	background-color: #fffffa;
	padding: 0 0.5em;
	width: auto;
	}

#option .inner div {
	display: block;
	margin: 0 0 50px 0;
	}
@media screen and (max-width: 767px) {
#howtoenjoy .inner div {
	margin: 0 0 50px 0;
	}
}

#option .inner div:after {
	display: block;
	content: "";
	clear: both;
	}

#option .inner img {
	display: block;
	width: 40%;
	}
#option .inner div:nth-child(odd) img { float: left;}
#option .inner div:nth-child(even) img { float: right;}

@media screen and (max-width: 767px) {
#option .inner img {
	width: 100%;
	}
#option .inner div:nth-child(odd) img { float: none;}
#option .inner div:nth-child(even) img { float: none;}
}

#option h3 {
	display: block;
	width: 57%;
	margin: 0 0 10px 0;
	padding: 0 0 5px 0;
	color: #331F15;
	font-size: 26px;
	letter-spacing: 4px;
	border-bottom: 1px solid #331F15;
	}
#option .inner div:nth-child(odd) h3 { float: right;}
#option .inner div:nth-child(even) h3 { float: left;}

@media screen and (max-width: 767px) {
#option h3 {
	width: 100%;
	margin: 0 0 10px 0;
	padding: 20px 0 5px 0;
	font-size: 24px;
	letter-spacing: 2px;
	border-bottom: 1px solid #331F15;
	}
#option .inner div:nth-child(odd) h3 { float: none;}
#option .inner div:nth-child(even) h3 { float: none;}
}

@media screen and (max-width: 767px) {
#option h3 {
	font-size: 22px;
	}
}

#option h3 span {
	display: block;
	font-size: 18px;
	}

#option p {
	display: block;
	width: 57%;
	}
#option .inner div:nth-child(odd) p { float: right;}
#option .inner div:nth-child(even) p { float: left;}

@media screen and (max-width: 767px) {
#option p {
	display: block;
	width: 100%;
	}

#option .inner div:nth-child(odd) p { float: none;}
#option .inner div:nth-child(even) p { float: none;}
#option p br {
	display: none;
	}
}

#option p.summary {
	padding: 0 0 10px 0;
	}

#option p.info {
	padding: 0 0 10px 0;
	font-size: 16px;
	font-weight: bold;
	letter-spacing: 2px;
	}
@media screen and (max-width: 767px) {
#option p.info {
	letter-spacing: 0;
	}
}

#option p.price {
	font-size: 18px;
	font-weight: bold;
	line-height: 1.3em;
	letter-spacing: 0;
	text-align: right;
	}
@media screen and (max-width: 767px) {
#option p.price {
	font-size: 16px;
	}
#option p.price br {
	display: block;
	}
}

#option p.price span {
	font-size: 12px;
	}

#option .book_bt {
	width: 900px;
	margin: 40px auto 0 auto;
	}
@media screen and (max-width: 767px) {
#option .book_bt {
	width: 100%;
	}
}

#option .book img {
	max-width: 100%;
	}






#flow,
#howtoenjoy,
#option {
	margin-top: -90px;
	padding-top: 90px;
	}






/* 遊び放題 */
#unlimited {
	min-width: 1000px;
	margin: 0 0 100px 0;
	padding: 200px 0 100px 0;
	text-align: center;
	background: url(/img/experience/bg_unlimited.jpg) center top no-repeat;
	background-size: cover;
	z-index: 1;
	}
@media screen and (max-width: 767.98px){
#unlimited {
	min-width: auto;
	padding: 130px 4vw 50px 4vw;
	}
}

#unlimited h2 {
	position: relative;
	display: block;
	margin-bottom: 40px;
	color: #005c80;
	font-size: 40px;
	font-weight: 700;
	line-height: 1em;
	letter-spacing: .3em;
	text-align: center;
	}
@media screen and (max-width: 767.98px){
#unlimited h2 {
	font-size: 7vw;
	letter-spacing: .2em;
	margin-bottom: 20px;
	}
}

#unlimited h2 span {
	display: block;
	padding-top: 5px;
	font-size: 20px;
	letter-spacing: .1em;
	}
@media screen and (max-width: 767.98px){
#unlimited h2 span {
	padding-top: 10px;
	font-size: 5vw;
	letter-spacing: 0;
	}
}

#unlimited h2::before {
	position: absolute;
	left: 50%;
	top: -100px;
	transform: translate(-50%,0);
	display: block;
	width: 250px;
	height: 79.5054px;
	content: "";
	background: url(/img/experience/logo_TasoShirahamaBeach.svg) center center no-repeat;
	background-size: 100% 100%;
	}
@media screen and (max-width: 767.98px){
#unlimited h2::before {
	top: -75px;
	width: 195.7088px;
	height: 62.2396px;
	}
}

#unlimited p.desc {
	display: block;
	margin: 0 0 50px 0;
	font-size: 16px;
	line-height: 1.5em;
	}
@media screen and (max-width: 767.98px){
#unlimited p.desc {
	margin: 0 0 20px 0;
	padding: 0;
	font-size: 5vw;
	}
}

#unlimited .inner {
	position: relative;
	width: 100%;
	max-width: 900px;
	min-height: 285px;
	margin: 50px auto;
	padding: 0;
	}
@media screen and (max-width: 767.98px){
#unlimited .inner {
	min-height: auto;
	margin: 0 0 20px 0;
	}
}

#unlimited .inner ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	}

#unlimited .inner li {
	display: block;
	width: calc(100% / 4);
	padding: 10px;
	}
@media screen and (max-width: 767.98px){
#unlimited .inner li {
	width: calc(100% / 2);
	font-size: 4vw;
	}
}

#unlimited .inner li img {
	display: block;
	width: 100%;
	margin: 0 0 10px 0;
	border-radius: 50%;
	}

#unlimited p.fee {
	display: block;
	margin: 0 0 5px 0;
	font-size: 16px;
	line-height: 1.5em;
	}
@media screen and (max-width: 767.98px){
#unlimited p.fee {
	padding: 0;
	font-size: 4vw;
	line-height: 2em;
	}
}

#unlimited p.fee:after {
	display: block;
	content: "\f063" !important;
	font-family: FontAwesome;
	font-weight: 900;
	}

#unlimited h3 {
	display: block;
	margin: 0 0 10px 0;
	color: #333300;
	font-size: 24px;
	font-weight: 200;
	letter-spacing: .1em;
	line-height: 1em;
	}
@media screen and (max-width: 767.98px){
#unlimited h3 {
	font-size: 7vw;
	letter-spacing: 0;
	text-align: center;
	letter-spacing: .1em;
	}
#unlimited h3 span {
	display: block;
	padding: .5em 0 0 0;
	}
}

#unlimited p.fee_special {
	display: block;
	margin: 0 0 30px 0;
	font-size: 24px;
	line-height: 1.5em;
	}
@media screen and (max-width: 767.98px){
#unlimited p.fee_special {
	padding: 0;
	font-size: 7vw;
	line-height: 2em;
	}
}

#unlimited p.fee_special span {
	color: #38809c;
	font-size: 34px;
	}
@media screen and (max-width: 767.98px){
#unlimited p.fee_special span {
	font-size: 10vw;
	}
}

#unlimited p.tel {
	display: block;
	margin: 0 0 20px 0;
	color: #38809c;
	font-size: 34px;
	line-height: 1em;
	letter-spacing: .1em;
	}
@media screen and (max-width: 767.98px){
#unlimited p.tel {
	font-size: 8vw;
	letter-spacing: .05em;
	text-align: center;
	}
}

#unlimited p.notice {
	display: block;
	margin: 0 0 30px 0;
	font-size: 12px;
	line-height: 1em;
	}
@media screen and (max-width: 767.98px){
#unlimited p.notice {
	font-size: 5vw;
	text-align: center;
	}
}

#unlimited a {
	display: block;
	width: 100%;
	max-width: 800px;
	margin: 0 auto;
	padding: 20px 0;
	color: #fff;
	font-size: 35px;
	line-height: 1em;
	letter-spacing: .2em;
	text-align: center;
	background: #005c80;
	border-radius: 5px;
	}
@media screen and (max-width: 767.98px) {
#unlimited a {
	padding: 15px 0;
	font-size: 8vw;
	}
}

#unlimited a:hover {
	background: #38809c;
	}

#unlimited .line {
	margin: 0 0 20px 0;
    text-align: center;
    border-radius: 10px;
}

#unlimited .line img {
	display: block;
	width: 200px;
	margin: 20px auto;
}

#unlimited .line a {
    position: relative;
    display: block;
    width: 100%;
    max-width: 350px;
    margin: 0 auto;
    padding: 1em 0;
    color: #fff;
    font-size: 22px;
    line-height: 1em;
    text-align: center;
    background: #05b23b;
    border-radius: 10px;
}


/* スカイダイビング */
#skydiving {
	display: block;
	padding: 0 0 50px 0;
	color: #fff;
	background: #004f9a;
	}

#skydiving .title {
	position: relative;
	display: block;
	padding: 150px 0 20px 0;
	text-align: center;
	background: url(/img/experience/title_skydiving.jpg) center center no-repeat;
	background-size: cover;
	}

#skydiving h2 {
	position: relative;
	display: block;
	margin: 0 0 50px 0;
	color: #fff;
	font-size: 30px;
	font-family: din-2014;
	font-weight: 700;
	font-style: normal;
	}
@media screen and (max-width: 767.98px){
#skydiving h2 {
	font-size: 7vw;
	}
}

#skydiving h2 span {
	display: block;
	padding-top: 10px;
	color: #fff;
	font-size: 16px;
	font-family: "しまなみ JIS2004";
	letter-spacing: .1em;
	}
@media screen and (max-width: 767.98px){
#skydiving h2 span {
	font-size: 4vw;
	}
}

#skydiving .title h3 {
	display: block;
	margin: 0 0 5px 0;
	font-size: 12px;
	}

#skydiving .tel {
	display: block;
	margin: 0 0 5px 0;
	font-size: 30px;
	font-weight: 700;
	letter-spacing: .1em;
	}

#skydiving .time {
	display: block;
	margin: 0 0 50px 0;
	font-size: 12px;
	}

#skydiving .desc {
	display: block;
	font-size: 20px;
	}
@media screen and (max-width: 767.98px){
#skydiving .desc {
	padding: 0 3vw;
	font-size: 5vw;
	line-height: 1.5em;
	}
}

#skydiving ol {
	display: block;
	}

#skydiving li {
	display: block;
	min-height: 240px;
	padding: 20px;
	}

#skydiving li:nth-child(even) {
	background: #03679b;
	}

#skydiving ol div {
	position: relative;
	width: 100%;
	max-width: 900px;
	margin: 0 auto;
	padding: 0 0 0 300px;
	}
@media screen and (max-width: 767.98px){
#skydiving ol div {
	padding: 0;
	}
}

#skydiving ol img {
	position: absolute;
	left: 0;
	top: 0;
	display: block;
	width: 273px;
	height: 200px;
	}
@media screen and (max-width: 767.98px){
#skydiving ol img {
	position: relative;
	left: auto;
	top: auto;
	width: 100%;
	height: auto;
	margin: 0 0 10px 0;
	}
}

#skydiving ol h3 {
	display: block;
	padding: 20px 0 10px 0;
	font-size: 26px;
	line-height: 1em;
	}
@media screen and (max-width: 767.98px){
#skydiving ol h3 {
	font-size: 6vw;
	text-align: center;
	}
}

#skydiving ol p {
	display: block;
	font-size: 18px;
	line-height: 2em;
	}
@media screen and (max-width: 767.98px){
#skydiving ol p {
	font-size: 4vw;
	}
#skydiving ol p br {
	display: none;
	}
}

/* MOVIE */
#skydiving #movie {
	padding: 30px;
	background: #004f9a;
	}
@media screen and (max-width: 767.98px) {
#skydiving #movie {
	padding: 20px;
	}
}

#skydiving img {
	display: block;
	max-width: 700px;
	margin: 0 auto;
	transition: .5s ease;
	}
@media screen and (max-width: 767.98px) {
#skydiving img {
	width: 100%;
	}
}

#skydiving img:hover {
	opacity: .8;
	}

#skydiving a {
	display: block;
	width: 100%;
	max-width: 800px;
	margin: 0 auto;
	padding: 20px 0;
	color: #fff;
	font-size: 35px;
	line-height: 1em;
	letter-spacing: .2em;
	text-align: center;
	background: #ff6600;
	border-radius: 5px;
	}
@media screen and (max-width: 767.98px) {
#skydiving a {
	max-width: 90vw;
	padding: 15px 0;
	font-size: 8vw;
	}
}

#skydiving a:hover {
	background: #ffaa00;
	}

#skydiving a span {
	display: block;
	font-size: 22px;
	}
@media screen and (max-width: 767.98px) {
#skydiving a span {
	font-size: 5vw;
	letter-spacing: 0;
	}
}




/* YOGA 2023.07.12 小田切 追加 */
#yoga {
	background: #fff;
	padding: 5rem 0;
	}

#yoga .mov {
	width: 100%;
	aspect-ratio: 16 / 9;
}

#yoga .mov iframe {
	width: 100%;
	height: 100%;
}

#yoga h3 {
	font-size: 1.25rem;
	margin: 0 0 .5rem;
	}
@media screen and (max-width: 767.98px) {
#yoga h3 {
	text-align: center;
	}
}

#yoga .desc {
	margin: 0 0 1rem;
}
@media screen and (max-width: 767.98px) {
#yoga .desc {
	padding: 4vw;
	}
}

#yoga .info {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

#yoga .price {
	width: 23%;
}
@media screen and (max-width: 767.98px) {
#yoga .price {
	width: 100%;
	padding: 4vw;
	}
}

#yoga .price dl {
	display: flex;
	flex-wrap: wrap;
	border: 1px solid #333;
	border-bottom: 0;
}

#yoga .price dt {
	display: block;
	width: 40%;
	padding: .5rem 1rem;
	border-bottom: 1px solid #333;
}

#yoga .price dd {
	display: block;
	width: 60%;
	padding: .5rem 1rem;
	text-align: right;
	border-bottom: 1px solid #333;
}

#yoga .teacher {
	width: 72.5%;
	margin: 0 0 3rem;
}
@media screen and (max-width: 767.98px) {
#yoga .teacher {
	width: 100%;
	padding: 4vw;
	}
}

#yoga .intro {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

#yoga .intro .detail {
	width: 65%;
}

#yoga .intro .pic {
	width: 29%;
}

#yoga a {
    position: relative;
    display: block;
    width: 100%;
    max-width: 350px;
    margin: 0 auto;
    padding: 1em 0;
    color: #fff;
    font-size: 22px;
    line-height: 1em;
    text-align: center;
    background: #05b23b;
    border-radius: 10px;
}