@charset "utf-8";
/* CSS Document */
* {
	margin: 0;
	padding: 0;
}
html {
	height: 100%;
}
body {
	position: relative;
	height: 100%;
	overflow-x:  hidden;
	font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 10px !important;
	background-repeat: repeat-x;
	background-position: 0 0;
}
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary {
	display: block;
}
h1, h2, h3, h4, h5, h6 {
	font-weight: bold;
}
p, li, dt, dd, th, td, span, a, label {
	line-height: 100%;
}
p *, li *, dt *, dd *, th *, td * {
	font-size: 100%;
}
img {
	border: none;
	vertical-align: bottom;
}
/******************************/
/* 共通
/******************************/
.gurutto:before {
	display: block;
	position: absolute;
	z-index: -1;
	height: 0;
	background-repeat: no-repeat;
	background-position: 50% 0;
	background-size: 100% auto;
	content: "";
}
.inner {
	position: relative;
	margin: 0 auto;
}
.rp {
	overflow: hidden;
	text-indent: 100%;
	white-space: nowrap;
	background-repeat: no-repeat;
	background-position: 0 0;
	background-size: 100% auto;
}
/*
* .header
*/
.header .inner {
	text-align: center;
}
.header .logo,
.header .beachfes {
	position: absolute;
	z-index: 1;
}
/*
* .schedule
*/
.schedule {
	text-align: center;
}
.schedule .program {
	overflow: hidden;
	margin: 0 auto;
}
.schedule .program > * {
	float: left;
}
.schedule .program ul {
	list-style: none;
}
.schedule .program li {
	height: 0;
	overflow: hidden;
	text-indent: 100%;
	white-space: nowrap;
	background-repeat: no-repeat;
	background-position: 0 0;
}
/*
* .contents
*/
.contents .inner {
	text-align: center;
}
/* .youtube */
.contents .youtube .inner > * {
	background-repeat: no-repeat;
	background-position: 0 0;
	background-size: 100% auto;
}
.contents .youtube .capture {
	cursor: pointer;
}
.youtube-wrap {
	position: fixed;
	z-index: -1;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.7);
	opacity: 0;
}
@media all and (-ms-high-contrast: none) {
	.youtube-wrap .inner:before {
		line-height: 2.2vw;
	}
}
.contents .apply {
	margin: 0 auto;
}
.contents .apply a {
	display: inline-block;
}
.contents .apply a:hover {
	opacity: 0.5;
	-webkit-transition: 0.8s;
	transition: 0.8s;
}
.contents .photo {
	display: table;
	overflow: hidden;
	margin: 0 auto;
}
.contents .photo > * {
	float: left;
}
.contents .map {
	margin: 0 auto;
}
.contents .googlemap {
	margin: 0 auto;
}
.contents .googlemap a {
	display: inline-block;
}
.contents .googlemap a:hover {
	opacity: 0.5;
	-webkit-transition: 0.8s;
	transition: 0.8s;
}
/*
* .footer
*/
.footer {
	display: block;
	position: absolute;
	bottom: 0;
	left: 0;
	margin: 0 auto;
	border-top: 1px dotted #ccc;
}
.footer p {
	color: #535353;
	text-align: center;
	line-height: 160%;
	background-color: #fbfbfb;
}

/******************************/
/* Mobile Layout: ～ 767px
/******************************/
@media screen and (max-width: 767px) {
	body {
		overflow: visible;
		background-image: url(../img/sp_bg.jpg);
		background-size: 100% auto;
	}
	.gurutto {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
	}
	.gurutto:before {
		top: 23.5937vw;
		width: 100%;
		height: 0;
		padding-top: 147.9688%;
		background-image: url(../img/sp_illust.png);
		background-size: 100% auto;
	}
	.rp {
		height: 0;
	}
	.pcNone {
		display: block;
	}
	.spNone {
		display: none;
	}
	/*
	* .header
	*/
	.header .inner {
		padding-top: 3.125%;
	}
	.header .soukai_ttl {
		width: 56.25%;
		padding-top: 9.375%;
		margin: 0 auto 5.1563%;
		background-image: url(../img/sp_haeder_soukai_title.png);
	}
	.header .copy {
		width: 87.5%;
		padding-top: 18.75%;
		margin: 0 auto 4.0625%;
		background-image: url(../img/sp_haeder_copy.png);
	}
	.header h1 {
		width: 73.4375%;
		padding-top: 8.2813%;
		margin: 0 auto 2.9688%;
		background-image: url(../img/sp_haeder_title.png);
	}
	.header .logo {
		top: 1.5625%;
		left: 1.5625%;
		width: 14.0625%;
		padding-top: 14.0625%;
		background-image: url(../img/sp_haeder_logo.png);
	}
	.header .beachfes {
		top: 1.7188%;
		right: 0.625%;
		width: 20.3125%;
		padding-top: 15%;
		background-image: url(../img/sp_haeder_beachfes.png);
	}
	/*
	* .schedule
	*/
	.schedule {
		margin-bottom: 0;
	}
	.schedule .date {
		width: 23.4375%;
		padding-top: 12.5%;
		margin: 0 auto 3.125%;
		background-image: url(../img/sp_schedule_date.png);
	}
	.schedule .place {
		width: 51.7188%;
		padding-top: 4.8438%;
		margin: 0 auto 2.1875%;
		background-image: url(../img/sp_schedule_place.png);
	}
	.schedule .time {
		width: 53.125%;
		padding-top: 3.2813%;
		margin: 0 auto 5.15625%;
		background-image: url(../img/sp_schedule_time.png);
	}
	.schedule .program {
		width: 100%;
		margin-bottom: 65.625%;
	}
	.schedule .program h2 {
		width: 18.75%;
		padding-top: 15.625%;
		background-image: url(../img/sp_schedule_program_icon.png);
	}
	.schedule .program ul {
		width: 81.25%;
	}
	.schedule .program li {
		width: 100%;
		padding-top: 3.4616%;
		background-size: 100% auto;
	}
	.schedule .program li:nth-child(1) {
		margin-bottom: 1.7308%;
		background-image: url(../img/sp_schedule_program01.png);
	}
	.schedule .program li:nth-child(2) {
		margin-bottom: 1.7308%;
		background-image: url(../img/sp_schedule_program02.png);
	}
	.schedule .program li:nth-child(3) {
		margin-bottom: 1.9231%;
		background-image: url(../img/sp_schedule_program03.png);
	}
	.schedule .program li:nth-child(4) {
		background-image: url(../img/sp_schedule_program04.png);
	}
	/* .youtube */
	.contents .youtube {
		margin: 0 3.125% 10%;
	}
	.contents .youtube h3 {
		width: 100%;
		height: 0;
		margin: 0 auto 5%;
		padding-top: 5.83334%;
		background-image: url(../img/sp_youtube_title.png);
	}
	.contents .youtube .inner .capture {
		width: 100%;
		height: 0;
		margin-bottom: 5%;
		padding-top: 56.26152%;
		background-image: url(../img/youtube_capture.jpg);
	}
	.contents .youtube .inner .capture:hover {
		background-image: url(../img/youtube_capture_o.jpg);
	}
	.contents .youtube .desc {
		width: 95.5%;
		height: 0;
		margin: 0 auto 10%;
		padding-top: 30.335%;
		background-image: url(../img/sp_youtube_desc.png);
	}
	.youtube-wrap .inner {
		position: relative;
		width: 94%;
		margin: 0 auto;
		padding-top: 67%;
	}
	.youtube-wrap iframe {
		position: absolute;
		top: 10%;
		right: 0;
		z-index: 3;
		width: 100%;
		height: 100%;
		margin: 0 auto;
	}
	.youtube-wrap .inner:before {
		display: block;
		position: absolute;
		top: 6%;
		right: -1.5%;
		z-index: 5;
		width: 6.4vw;
		height: 6.4vw;
		border-radius: 50%;
		color: #21cbfd;
		font-size: 6.4vw;
		font-weight: bold;
		text-align: center;
		line-height: 5.4vw;
		background-color: #fff032;
		content: "×";
	}
	/*
	* .contents
	*/
	.contents > .inner > .desc {
		width: 76.7188%;
		padding-top: 24.375%;
		margin: 7.8125%;
		background-image: url(../img/sp_contents_desc.png);
	}
	.contents .apply a {
		width: 54.6875%;
		padding-top: 9.375%;
		background-image: url(../img/sp_btn_apply.png);
	}
	.contents > .inner .desc + .apply {
		margin-bottom: 10.1563%;
	}
	.contents .googlemap + .apply {
		margin-bottom: 10.9375%;
	}
	.contents .photo {
		margin: 0 3.125% 10.9375%;
	}
	.contents .photo > * {
		width: 49%;
	}
	.contents .photo > *:first-child {
		margin-right: 1.875%;
	}
	.contents .photo > * img {
		width: 100%;
		height: auto;
	}
	.contents .about-btbc {
		margin-bottom: 10.9375%;
	}
	.contents .about-btbc h3 {
		width: 34.375%;
		padding-top: 3.125%;
		margin: 0 auto 4.375%;
		background-image: url(../img/sp_about_btbc_title.gif);
	}
	.contents .about-btbc p {
		width: 90.625%;
		padding-top: 21.875%;
		margin: 0 auto;
		background-image: url(../img/sp_about_btbc_desc.gif);
	}
	.contents .about-grutto {
		margin-bottom: 10.625%;
	}
	.contents .about-grutto h3 {
		width: 56.25%;
		padding-top: 3.125%;
		margin: 0 auto 4.6875%;
		background-image: url(../img/sp_about_grutto_title.gif);
	}
	.contents .about-grutto p {
		width: 90.625%;
		padding-top: 35.9375%;
		margin: 0 auto;
		background-image: url(../img/sp_about_grutto_desc.gif);
	}
	.contents .about-wmbb {
		margin-bottom: 10.625%;
	}
	.contents .about-wmbb h3 {
		width: 43.75%;
		padding-top: 3.125%;
		margin: 0 auto 4.6875%;
		background-image: url(../img/sp_about_wmbb_title.gif);
	}
	.contents .about-wmbb p {
		width: 93.75%;
		padding-top: 26.5625%;
		margin: 0 auto;
		background-image: url(../img/sp_about_wmbb_desc.gif);
	}
	.contents .map {
		width: 93.75%;
		margin: 0 auto 10.9375%;
		padding-top: 66.6667%;
		background: url(../img/sp_map.gif) no-repeat 50% 0;
		background-size: 100% auto;
	}
	.contents .map img {
		display: none;
	}
	.contents .googlemap {
		margin-bottom: 7.8125%;
	}
	.contents .googlemap a {
		width: 54.6875%;
		padding-top: 9.375%;
		background-image: url(../img/sp_btn_googlemap.png);
	}
	.contents .sponsor {
		width: 64.6875%;
		padding-top: 20.1563%;
		margin: 0 auto 5.9375%;
		background-image: url(../img/sp_sponsor.png);
	}
	.contents .inquiry {
		width: 71.25%;
		padding-top: 7.0313%;
		margin: 0 auto 15.625%;
		background-image: url(../img/sp_inquiry.png);
	}
	/*
	* .footer
	*/
	.footer p {
		padding: 10px 0;
		font-size: 100%;
	}
}
/******************************/
/* PC Layout： 768px～
/******************************/
@media screen and (min-width:768px) {
	body {
		background-image: url(../img/pc_bg.gif);
	}
	.gurutto {
		position: absolute;
		top: 0;
		left: 50%;
		width: 1024px;
		margin-left: -512px;
	}
	.gurutto:before {
		top: 60px;
		left: 50%;
		width: 1363px;
		height: 1102px;
		margin-left: -681px;
		background-image: url(../img/pc_illust.png);
	}
	.inner {
		width: 1024px;
	}
	.pcNone {
		display: none;
	}
	.spNone {
		display: block;
	}
	/*
	* .header
	*/
	.header {
		margin-bottom: 8px;
	}
	.header .inner {
		padding-top: 28px;
	}
	.header .soukai_ttl {
		width: 678px;
		height: 35px;
		margin: 0 auto 33px;
		background-image: url(../img/haeder_soukai_title.png);
	}
	.header .copy {
		width: 586px;
		height: 125px;
		margin: 0 auto 26px;
		background-image: url(../img/haeder_copy.png);
	}
	.header h1 {
		width: 436px;
		height: 49px;
		margin: 0 auto 9px;
		background-image: url(../img/haeder_title.png);
	}
	.header .logo {
		top: 20px;
		left: 32px;
		width: 108px;
		height: 108px;
		margin: 0 auto 29px;
		background-image: url(../img/haeder_logo.png);
	}
	.header .beachfes {
		top: 23px;
		right: 15px;
		width: 152px;
		height: 112px;
		margin: 0 auto 29px;
		background-image: url(../img/haeder_beachfes.png);
	}
	/*
	* .schedule
	*/
	.schedule {
		margin-bottom: 525px;
	}
	.schedule .date {
		width: 125px;
		height: 67px;
		margin: 0 auto 20px;
		background-image: url(../img/schedule_date.png);
	}
	.schedule .place {
		width: 378px;
		height: 36px;
		margin: 0 auto 17px;
		background-image: url(../img/schedule_place.png);
	}
	.schedule .time {
		width: 391px;
		height: 23px;
		margin: 0 auto 33px;
		background-image: url(../img/schedule_time.png);
	}
	.schedule .program {
		display: table;
	}
	.schedule .program h2 {
		width: 82px;
		height: 66px;
		background-image: url(../img/schedule_program_icon.png);
	}
	.schedule .program ul {
		width: 480px;
	}
	.schedule .program li {
		height: 16px;
	}
	.schedule .program li:nth-child(1) {
		margin-bottom: 7px;
		background-image: url(../img/schedule_program01.png);
	}
	.schedule .program li:nth-child(2) {
		margin-bottom: 8px;
		background-image: url(../img/schedule_program02.png);
	}
	.schedule .program li:nth-child(3) {
		margin-bottom: 9px;
		background-image: url(../img/schedule_program03.png);
	}
	.schedule .program li:nth-child(4) {
		background-image: url(../img/schedule_program04.png);
	}
	/*
	* .contents
	*/
	.contents > .inner > .desc {
		width: 806px;
		height: 78px;
		margin: 58px auto 70px;
		background-image: url(../img/contents_desc.png);
	}
	/* .youtube */
	.contents .youtube {
		display: table;
		margin: 0 auto 70px;
	}
	.contents .youtube h3 {
		width: 806px;
		height: 35px;
		margin: 0 auto 30px;
		background-image: url(../img/youtube_title.png);
	}
	.contents .youtube .inner {
		width: 806px;
		overflow: hidden;
	}
	.contents .youtube .inner > * {
		float: left;
	}
	.contents .youtube .inner .capture {
		width: 413px;
		height: 232px;
		margin-right: 30px;
		background-image: url(../img/youtube_capture.jpg);
	}
	.contents .youtube .inner .capture:hover {
		background-image: url(../img/youtube_capture_o.jpg);
	}
	.contents .youtube .desc {
		width: 343px;
		height: 266px;
		background-image: url(../img/youtube_desc.png);
	}
	.youtube-wrap .inner {
		position: relative;
		width: 70%;
		margin: 0 auto;
		padding-top: 43%;
	}
	.youtube-wrap iframe {
		position: absolute;
		top: 5%;
		right: 0;
		z-index: 3;
		width: 100%;
		height: 100%;
		margin: 0 auto;
	}
	.youtube-wrap .inner:before {
		display: block;
		position: absolute;
		top: 3%;
		right: -1.5%;
		z-index: 5;
		width: 3%;
		height: 5%;
		border-radius: 50%;
		color: #21cbfd;
		font-size: 1.8vw;
		font-weight: bold;
		text-align: center;
		line-height: 1.8vw;
		background-color: #fff032;
		content: "×";
		cursor: pointer;
	}
	.contents .apply a {
		width: 195px;
		height: 34px;
		background-image: url(../img/btn_apply.png);
	}
	.contents > .inner > .desc + .apply {
		margin-bottom: 60px;
	}
	.contents .googlemap + .apply {
		margin-bottom: 59px;
	}
	.contents .photo {
		margin-bottom: 49px;
	}
	.contents .photo > *:first-child {
		margin-right: 17px;
	}
	.contents .about-btbc {
		margin-bottom: 59px;
	}
	.contents .about-btbc h3 {
		width: 197px;
		height: 18px;
		margin: 0 auto 32px;
		background-image: url(../img/about_btbc_title.gif);
	}
	.contents .about-btbc p {
		width: 766px;
		height: 72px;
		margin: 0 auto;
		background-image: url(../img/about_btbc_desc.gif);
	}
	.contents .about-grutto {
		margin-bottom: 38px;
	}
	.contents .about-grutto h3 {
		width: 317px;
		height: 18px;
		margin: 0 auto 37px;
		background-image: url(../img/about_grutto_title.gif);
	}
	.contents .about-grutto p {
		width: 766px;
		height: 123px;
		margin: 0 auto;
		background-image: url(../img/about_grutto_desc.gif);
	}
	.contents .about-wmbb {
		margin-bottom: 80px;
	}
	.contents .about-wmbb h3 {
		width: 251px;
		height: 19px;
		margin: 0 auto 37px;
		background-image: url(../img/about_wmbb_title.gif);
	}
	.contents .about-wmbb p {
		width: 766px;
		height: 95px;
		margin: 0 auto;
		background-image: url(../img/about_wmbb_desc.gif);
	}
	.contents .map {
		margin-bottom: 45px;
	}
	.contents .googlemap {
		margin-bottom: 26px;
	}
	.contents .googlemap a {
		width: 195px;
		height: 34px;
		background-image: url(../img/btn_googlemap.png);
	}
	.contents .sponsor {
		width: 540px;
		height: 64px;
		margin: 0 auto 70px;
		background-image: url(../img/sponsor.gif);
	}
	.contents .inquiry {
		width: 398px;
		height: 40px;
		margin: 0 auto 90px;
		background-image: url(../img/inquiry.gif);
	}
	/*
	* .footer
	*/
	.footer p {
		padding: 15px 0;
		font-size: 120%;
	}
}