@charset "UTF-8";
/* PC ================================================== */
@media all and (min-width: 921px) {
	body {
		background: #ACDFF2;
		color: #0E6E71;
		-webkit-font-smoothing: antialiased;
		-moz-osx-font-smoothing: grayscale;
		font-feature-settings: "halt" 1;
		font-feature-settings: "palt";
		-webkit-text-size-adjust: 100%;
		width: 100%;
		font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
		/*		font-family: 'M PLUS 1p', sans-serif;*/
	}

	.sp {
		display: none;
	}

	.loading {
		position: fixed;
		width: 100%;
		height: 100%;
		top: 0px;
		left: 0px;
		background: #fff;
		z-index: 9998;
	}

	.loader {
		position: fixed;
		top: 50%;
		left: 50%;
		width: 38px;
		height: 38px;
		margin-top: -19px;
		margin-left: -19px;
		text-align: center;
		z-index: 9999;
	}

	header {
		border-top: 12px solid #FFFF00;
	}

	#logo {
		width: 114px;
		position: fixed;
		top: 30px;
		left: 24px;
		z-index: 10;
	}

	section#fv {
		position: relative;
		margin-top: 130px;
		display: flex;
		justify-content: flex-end;
		margin-bottom: 93px;
	}

	section#fv h1 {
		width: 591px;
		position: absolute;
		top: -90px;
		left: 8%;
		z-index: 2;
	}

	section#fv div:nth-child(2) {
		width: 81%;
	}

	section#fv div:nth-child(3) {
		position: absolute;
		top: 18%;
		left: 8%;
		z-index: 2;
	}

	section#fv p#entry {
		font-family: "Acumin Pro";
		font-size: 22px;
		letter-spacing: 0.06em;
		line-height: 1em;
		text-align: center;
		width: 344px;
		position: absolute;
		bottom: 3%;
		left: 0;
		z-index: 2;
	}

	section#fv p#entry a {
		font-weight: bold;
		color: #fff;
		display: block;
		background: #08F6FE;
		height: 68px;
		border-radius: 0px 34px 34px 0px;
		box-sizing: border-box;
		padding: 26px 0 0;
		position: relative;
	}

	section#fv p#entry a:after {
		content: '';
		background: url("../img/arrow.svg") no-repeat;
		width: 38px;
		height: 38px;
		display: block;
		position: absolute;
		top: 15px;
		right: 12px;
		transition: .2s;
	}

	section#fv p#entry a:hover {
		background: #fff;
		color: #08F6FE;
	}

	section#fv p#entry a:hover:after {
		right: 8px;
		transition: .2s;
	}

	#flb1 {
		display: flex;
		justify-content: space-between;
	}

	#img-2 {
		width: 32%;
		margin-top: 6px;
		margin-right: 130px;
	}

	article#i2 {
		width: 62.5%;
		padding-bottom: 96px;
	}

	section#aid-station {
		position: relative;
		width: 92%;
		margin-bottom: 64px;
	}

	section#aid-station a {
		font-weight: bold;
		color: #FFFF00;
	}

	section#aid-station a:hover {
		color: #08F6FE;
	}

	section#aid-station:before {
		content: '';
		background: #fff;
		width: 13px;
		height: 280px;
		position: absolute;
		top: 6px;
		left: -6px;
	}

	section#aid-station:after {
		content: '';
		background: #fff;
		width: 1px;
		height: 500px;
		position: absolute;
		top: 286px;
		left: 0;
	}

	h2.vw {
		font-family: "Acumin Pro";
		font-weight: bold;
		font-size: 39px;
		letter-spacing: 0.1em;
		line-height: 1em;
		transform: rotate(-90deg);
	}

	section#aid-station h2 {
		text-align: left;
		color: #ff0;
		position: absolute;
		top: 202px;
		left: -282px;
	}

	section#aid-station > div {

	}

	section#aid-station > div p {
		font-weight: bold;
		font-size: 18px;
		letter-spacing: 0.04em;
		line-height: 37px;
		text-align: left;
		color: #fff;
		margin-bottom: 28px;
		padding-left: 44px;
	}

	section#aid-station > div p.small {
		font-size: 14px;
		line-height: 28px;
	}

	section#aid-station > div p span {
		position: relative;
		font-weight: bold;
	}

	section#aid-station > div p span:before {
		content: '';
		width: 173px;
		height: 20px;
		background: #08f6fe;
		position: absolute;
		bottom: -8px;
		left: -4px;
		z-index: -1;
	}

	p.attention {
		font-weight: normal;
		font-size: 14px;
	}

	#map {
		background: url("../img/map.jpg") no-repeat;
		width: 811px;
		height: 462px;
		background-size: cover;
	}

	#map {
		position: relative;
	}

	#map li {
		width: 56px;
		height: 66px;
		position: absolute;
	}

	#map li:nth-child(1) {
		top: 6px;
		left: 504px;
	}

	#map li:nth-child(2) {
		top: 287px;
		left: 455px;
	}

	#map li:nth-child(3) {
		top: 373px;
		left: 448px;
	}

	#map li:nth-child(4) {
		top: 338px;
		left: 324px;
	}

	#map li:nth-child(5) {
		top: 378px;
		left: 163px;
	}

	#map li a:hover {
		filter: brightness(150%);
	}

	section#special-music h2 {
		font-family: "Acumin Pro";
		font-weight: bold;
		font-size: 39px;
		letter-spacing: 0.1em;
		line-height: 39px;
		text-align: left;
		color: #ff0;
	}

	section#special-music h2 span {
		font-weight: bold;
		font-size: 18px;
		letter-spacing: 0.1em;
		line-height: 44px;
		text-align: left;
		color: #fff;
		vertical-align: middle;
		margin-left: 32px;
	}

	section#special-music > div {
		display: flex;
		justify-content: flex-start;
		position: relative;
		padding-top: 63px;
	}

	section#special-music > div:before {
		content: '';
		background: #fff;
		width: 345px;
		height: 15px;
		position: absolute;
		top: 20px;
		left: 0;
	}

	section#special-music > div:after {
		content: '';
		background: #fff;
		width: 100%;
		height: 1px;
		position: absolute;
		top: 27px;
		left: 0;
	}

	section#special-music > div > div {
		width: 255px;
		margin: 8px 58px 0 0;
	}

	section#special-music > div > div div:nth-child(1) {
		margin-bottom: 19px;
	}

	section#special-music > div > div div:nth-child(2) {
		width: 255px;
		font-size: 17px;
		letter-spacing: 0.1em;
		line-height: 44px;
		text-align: center;
	}

	section#special-music > div > div div:nth-child(2) a {
		display: block;
		font-family: "Acumin Pro";
		font-weight: 500;
		color: #fff;
		height: 46px;
		border-radius: 23px;
		background: #f05f5f;
		box-sizing: border-box;
		padding-top: 4px;
		position: relative;
	}

	section#special-music > div > div div:nth-child(2) a:after {
		content: '';
		background: url("../img/arrow2.svg") no-repeat;
		width: 30px;
		height: 30px;
		position: absolute;
		top: 7px;
		right: 7px;
		transition: .2s;
	}

	section#special-music > div > div div:nth-child(2) a:hover {
		background: #fff;
		color: #f05f5f;
	}

	section#special-music > div > div div:nth-child(2) a:hover:after {
		right: 4px;
		transition: .2s;
	}

	section#special-music > div p {
		width: 438px;
		font-weight: bold;
		font-size: 18px;
		letter-spacing: 0.04em;
		line-height: 37px;
		text-align: left;
		color: #fff;
	}

	section#how-it-works {
		width: 100%;
		background: #F2FCFF;
		padding: 69px 0 65px;
		position: relative;
		box-sizing: border-box;
	}

	section#how-it-works .vh2 {
		position: absolute;
		top: 50%;
		left: 48px;
		transform: rotate(-90deg);
		transform-origin: left top;
		margin-top: 170px;
	}

	section#how-it-works h2 {
		font-family: "Acumin Pro";
		font-weight: bold;
		font-size: 39px;
		letter-spacing: 0.1em;
		line-height: 1em;
		color: #009DD1;
		text-align: center;
		position: relative;
	}

	section#how-it-works h2:after {
		content: '';
		background: #009DD1;
		width: 100%;
		height: 1px;
		position: absolute;
		bottom: -32px;
		left: 0;
	}

	section#how-it-works h2 img {
		width: 302px;
		display: block;
		margin: 10px auto 0;
	}

	/*
        section#how-it-works h2 span {
            font-weight: 700;
            display: block;
            font-size: 18px;
            letter-spacing: -0.03em;
            line-height: 42px;
            text-align: center;
            color: #009dd1;
        }
    */
	section#how-it-works ul {
		width: 78%;
		margin-left: 16%;
		display: flex;
		justify-content: space-between;
		position: relative;
	}

	section#how-it-works ul li {
		width: 22.8%;
		background: #fafafa;
		border: 1px dashed #009dd1;
		padding: 3% 3% 20px 3%;
		box-sizing: border-box;
		position: relative;
	}

	section#how-it-works ul li:nth-child(-n+3):after {
		content: '';
		position: absolute;
		top: -1px;
		right: -13px;
		border-bottom: 13px solid transparent;
		border-left: 13px solid #6aa7cd;
	}

	section#how-it-works p.num {
		font-family: "Acumin Pro";
		font-weight: 500;
		font-size: 18px;
		line-height: 24px;
		text-align: center;
		color: #ff0;
		width: 34px;
		height: 34px;
		background: #009dd1;
		position: absolute;
		top: -17px;
		left: -17px;
		padding-top: 7px;
		box-sizing: border-box;
	}

	section#how-it-works h3 {
		font-family: "Acumin Pro";
		font-weight: bold;
		font-size: 24px;
		letter-spacing: 0.1em;
		line-height: 24px;
		text-align: center;
		color: #009dd1;
		position: relative;
		margin-bottom: 36px;
	}

	section#how-it-works h3:before {
		content: '';
		width: 100%;
		height: 6px;
		background: #ff0;
		position: absolute;
		bottom: -20px;
		left: 0;
	}

	section#how-it-works h3:after {
		content: '';
		width: 100%;
		height: 1px;
		background: #009dd1;
		position: absolute;
		bottom: -20px;
		left: 0;
	}

	section#how-it-works p {
		font-weight: 500;
		font-size: 13px;
		line-height: 24px;
		text-align: left;
		color: #009dd1;
		margin-bottom: 15px;
	}

	section#how-it-works ul li div:nth-child(4) {
		position: relative;
	}

	section#how-it-works ul li div:nth-child(4):after {
		content: '';
		width: 100%;
		height: 15px;
		background: #d8f6ff;
		position: absolute;
		bottom: -20px;
		left: 0;
	}

	section#area-schedule {
		background: url("../img/img_4.jpg") no-repeat;
		width: 100%;
		height: 580px;
		background-size: cover;
		background-position: top center;
		position: relative;
		box-sizing: border-box;
		padding-top: 232px;
	}

	section#area-schedule .vh2 {
		position: absolute;
		top: 50%;
		left: 48px;
		transform: rotate(-90deg);
		transform-origin: left top;
		margin-top: 210px;
	}

	section#area-schedule h2 {
		font-family: "Acumin Pro";
		font-weight: bold;
		font-size: 39px;
		letter-spacing: 0.1em;
		line-height: 1em;
		color: #FFFF00;
		text-align: center;
		position: relative;
	}

	section#area-schedule h2 img {
		width: 187px;
		display: block;
		margin: 10px auto 0;
	}

	section#area-schedule ul {
		width: 78%;
		margin-left: 16%;
		display: flex;
		justify-content: space-between;
		position: relative;
	}

	section#area-schedule ul li {
		width: 19.2%;
	}

	/*
        section#area-schedule h2 span {
            font-weight: 700;
            display: block;
            font-size: 18px;
            letter-spacing: -0.03em;
            line-height: 42px;
            text-align: center;
            color: #FFFF00;
        }
    */
	section#area-schedule h2:after {
		content: '';
		background: #fff;
		width: 100%;
		height: 1px;
		position: absolute;
		bottom: -32px;
		left: 0;
	}

	section#area-schedule ul li h3 {
		font-family: "Acumin Pro";
		font-weight: bold;
		font-size: 20px;
		letter-spacing: 0.1em;
		line-height: 1em;
		text-align: center;
		color: #ff0;
		margin-bottom: 10px;
	}

	section#area-schedule ul li .more {
		font-family: "Acumin Pro";
		font-size: 15px;
		letter-spacing: 0.06em;
		line-height: 1em;
		text-align: left;
		margin-bottom: 24px;
	}

	section#area-schedule ul li .more a {
		font-weight: 500;
		color: #525252;
		height: 36px;
		background: #08f6fe;
		box-sizing: border-box;
		display: block;
		padding-top: 12px;
		padding-left: 18%;
		position: relative;
	}

	section#area-schedule ul li .more a:after {
		content: '';
		background: url("../img/arrow3.svg") no-repeat;
		width: 36px;
		height: 36px;
		position: absolute;
		top: 0;
		right: 0;
	}

	section#area-schedule ul li .more a:hover {
		background: #fff;
		color: #009DD1;
	}

	section#area-schedule ul li .finished {
		font-family: "Acumin Pro";
		font-size: 15px;
		letter-spacing: 0.06em;
		line-height: 1em;
		text-align: left;
		margin-bottom: 24px;
		font-weight: 500;
		color: #525252;
		height: 36px;
		background: #08f6fe;
		box-sizing: border-box;
		display: block;
		padding-top: 12px;
		padding-left: 18%;
		position: relative;
	}

	section#area-schedule ul li p {
		font-family: "Acumin Pro";
		font-weight: 300;
		font-size: 30px;
		letter-spacing: 0.1em;
		line-height: 1em;
		text-align: center;
		color: #fff;
	}

	section#area-schedule .coming_soon {
		font-size: 85%;
		font-weight: bold;
		background-color: #000;
		width: 100%;
		position: absolute;
		top: 0;
		bottom: 0;
		opacity: .7;
		text-align: center;
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		color: #ffffff;
	}

	#img-10 {
		width: 32%;
		margin-top: 6px;
		margin-right: 190px;
	}

	#img-2 img, #img-10 img {
		object-fit: cover;
		height: 100%;
	}

	article#i10 {
		width: 48.8%;
		padding-bottom: 96px;
	}

	#flb2 {
		display: flex;
		justify-content: flex-start;
		padding-top: 100px;
	}

	section#prize {
		position: relative;
		width: 92%;
	}

	section#prize h2 {
		text-align: left;
		color: #ff0;
		position: absolute;
		top: 76px;
		left: -215px;
	}

	section#prize:before {
		content: '';
		background: #fff;
		width: 13px;
		height: 130px;
		position: absolute;
		top: 6px;
		left: -60px;
	}

	section#prize:after {
		content: '';
		background: #fff;
		width: 1px;
		height: calc(100% - 6px);
		position: absolute;
		top: 6px;
		left: -54px;
	}

	section#prize > div > div {
		float: left;
		width: 45%;
		margin-bottom: 19px;
		margin-right: 19px;
	}

	section#prize > div > div {
		border-bottom: 1px solid #08F6FE;
	}

	section#prize p {
		font-weight: bold;
		font-size: 18px;
		letter-spacing: 0.04em;
		line-height: 37px;
		text-align: left;
		color: #fff;
		margin-bottom: 40px;
	}

	section#prize div p {
		display: flex;
		justify-content: center;
		align-items: center;
		font-size: 16px;
		text-align: center;
		color: #64a9c3;
		background: #FFFFFF;
		line-height: 1em;
		height: 46px;
		box-sizing: border-box;
		margin-bottom: 0;
		padding: 2px;
	}

	section#prize dl {
		display: flex;
		justify-content: flex-start;
		border-top: 1px solid #08F6FE;
	}

	section#prize dl dt {
		display: flex;
		justify-content: center;
		align-items: center;
		width: 100%;
		text-align: center;
		font-weight: bold;
		font-size: 15px;
		letter-spacing: 0.04em;
		background: #D7EEF5;
		color: #64a9c3;
		height: 46px;
		box-sizing: border-box;
		border-right: 1px solid #08F6FE;
		padding: 5px;
	}

	section#prize dl dd {
		width: 34%;
		font-family: "Acumin Pro";
		font-size: 21px;
		font-weight: bold;
		letter-spacing: 0.06em;
		line-height: 1em;
		text-align: center;
		background: #D7EEF5;
		color: #64a9c3;
		height: 46px;
		box-sizing: border-box;
		padding-top: 15px;
	}

	section#prize dl dd a {
		display: block;
		font-weight: 500;
		height: 45px;
		box-sizing: border-box;
		padding-top: 17px;
		padding-left: 16%;
		color: #525252;
		background: #08f6fe;
		position: relative;
	}

	section#prize dl dd a:after {
		content: '';
		background: url(../img/arrow4.svg) no-repeat;
		width: 45px;
		height: 45px;
		position: absolute;
		top: 0;
		right: 0;
	}

	section#prize dl dd a:hover {
		background: #009DD1;
		color: #fff;
	}

	section#prize #note {
		font-weight: bold;
		font-size: 18px;
		letter-spacing: 0.06em;
		line-height: 28px;
		color: #fff;
		text-align: center;
		margin-bottom: 44px;
		position: relative;
	}

	section#prize #note br {
		display: none;
	}

	section#prize #note:after {
		content: '';
		background: url("../img/line.svg") no-repeat;
		width: 100%;
		height: 100%;
		background-size: contain;
		position: absolute;
		top: 101%;
		left: 0;
	}

	section#prize ul {
		display: flex;
		justify-content: space-between;
	}

	section#prize ul li {
		width: 19%;
	}

	section#prize ul li h3 {
		font-family: "Acumin Pro";
		font-weight: bold;
		font-size: 18px;
		letter-spacing: 0.1em;
		line-height: 1em;
		text-align: center;
		color: #fff;
		margin-bottom: 8px;
	}

	section#prize ul li a {
		position: relative;
		display: block;
	}

	section#prize ul li a:after {
		content: '';
		background: url("../img/arrow5.svg") no-repeat;
		width: 23px;
		height: 23px;
		background-size: cover;
		position: absolute;
		bottom: 0;
		right: 0;
	}

	section#prize ul li a:hover {
		filter: brightness(120%);
	}

	section#prize ul li .coming_soon {
		font-size: 100%;
		background-color: #000;
		width: 100%;
		position: absolute;
		top: 0;
		bottom: 0;
		opacity: .7;
		text-align: center;
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		color: #ffffff;
	}

	section#prize img {
		background: #ffffff;
	}

	section#supporters {
		position: relative;
		background: #fff;
		padding: 65px 0;
	}

	section#supporters div {
		position: absolute;
		top: 0;
		left: 48px;
		transform: rotate(-90deg);
		transform-origin: left top;
	}

	section#supporters .vh2 {
		position: absolute;
		top: 50%;
		left: 48px;
		transform: rotate(-90deg);
		transform-origin: left top;
		margin-top: 148px;
	}

	section#supporters h2 {
		font-family: "Acumin Pro";
		font-weight: bold;
		font-size: 39px;
		letter-spacing: 0.1em;
		line-height: 1em;
		color: #009DD1;
		text-align: center;
		position: relative;
	}

	section#supporters h2:after {
		content: '';
		background: #009DD1;
		width: 418px;
		height: 1px;
		position: absolute;
		bottom: -32px;
		left: -61px;
	}

	section#supporters ul {
		display: flex;
		justify-content: flex-start;
		flex-wrap: wrap;
		width: 74%;
		margin: 0 auto;
	}

	section#supporters ul li {
		width: 18%;
		margin-right: 2%;
		margin-bottom: 2%;
	}

	section#supporters ul li a:hover {
		opacity: .5;
	}

	footer {
		background: #ACDFF2;
		padding: 81px 0 40px;
		position: relative;
	}

	footer > div {
		width: 80%;
		margin: 0 auto;
	}

	footer > div h2 {
		font-family: "Acumin Pro";
		font-weight: bold;
		font-size: 22px;
		letter-spacing: 0.1em;
		line-height: 30px;
		margin-bottom: 12px;
	}

	footer > div {
		margin-bottom: 40px;
	}

	footer > div dl dt {
		font-size: 16px;
		letter-spacing: 0.1em;
		line-height: 30px;
		margin-right: 20px;
		float: left;
		clear: both;
	}

	footer > div dl dd {
		font-size: 16px;
		letter-spacing: 0.1em;
		line-height: 30px;
		float: left;
		margin-bottom: 8px;
	}

	footer > div dl dd:last-child {
		margin-bottom: 0;
	}

	footer ul {
		width: 528px;
		margin: 0 auto;
		display: flex;
		justify-content: space-between;
	}

	footer ul li:nth-child(1) {
		width: 314px;
	}

	footer ul li:nth-child(2) {
		width: 189px;
		padding-top: 25px;
	}

	footer li {
		list-style: initial;
		padding-left: 44px;
		text-indent: -22px;
	}

	footer ul li {
		list-style: none;
	}

	#copyright {
		font-family: "Acumin Pro";
		font-weight: normal;
		font-size: 14px;
		letter-spacing: 0.1em;
		line-height: 1em;
		text-align: center;
		color: #0e6e71;
		position: absolute;
		bottom: 0;
		right: -356px;
		transform: rotate(-90deg);
		transform-origin: left top;
	}


}

/* SP ================================================== */
@media all and (max-width: 920px) {
	body {
		background: #ACDFF2;
		color: #0E6E71;
		-webkit-font-smoothing: antialiased;
		-moz-osx-font-smoothing: grayscale;
		font-feature-settings: "halt" 1;
		font-feature-settings: "palt";
		-webkit-text-size-adjust: 100%;
		width: 100%;
		font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
		overflow-x: hidden;
	}

	.pc {
		display: none;
	}

	.loading {
		position: fixed;
		width: 100%;
		height: 100%;
		top: 0px;
		left: 0px;
		background: #fff;
		z-index: 9998;
	}

	.loader {
		position: fixed;
		top: 50%;
		left: 50%;
		width: 38px;
		height: 38px;
		margin-top: -19px;
		margin-left: -19px;
		text-align: center;
		z-index: 9999;
	}

	header {
		width: 100%;
		height: 48px;
		box-sizing: border-box;
		border-top: 8px solid #FFFF00;
	}

	#logo {
		width: 114px;
		position: fixed;
		top: 16px;
		left: 6px;
		z-index: 10;
	}

	section#fv {
		position: relative;
		margin-top: 48px;
		margin-bottom: 40px;
	}

	section#fv h1 {
		width: 320px;
		position: absolute;
		top: -51px;
		left: 5%;
		z-index: 2;
	}

	section#fv div:nth-child(2) {
		width: 100%;
	}

	section#fv div:nth-child(3) {
		width: 58%;
		position: absolute;
		top: 72px;
		left: 5%;
		z-index: 2;
	}

	section#fv p#entry {
		font-family: sans-serif;
		font-size: 18px;
		letter-spacing: 0.06em;
		line-height: 1em;
		text-align: center;
		width: 200px;
		position: absolute;
		bottom: 66px;
		left: 0;
		z-index: 2;
	}

	section#fv p#entry a {
		font-weight: bold;
		color: #fff;
		display: block;
		background: #08F6FE;
		height: 40px;
		border-radius: 0px 34px 34px 0px;
		box-sizing: border-box;
		padding: 13px 0 0;
		position: relative;
	}

	section#fv p#entry a:after {
		content: '';
		background: url(../img/arrow.svg) no-repeat;
		width: 24px;
		height: 24px;
		display: block;
		position: absolute;
		top: 8px;
		right: 8px;
		background-size: cover;
	}

	#flb1 {
		position: relative;
	}

	#img-2 {
		width: 24%;
		position: absolute;
		top: 0;
		right: 0;
	}

	article#i2 {
		padding-bottom: 48px;
	}

	section#aid-station {
		position: relative;
		width: 100%;
		margin-bottom: 64px;
		padding-top: 14px;
	}

	section#aid-station:before {
		content: '';
		background: #fff;
		width: 7px;
		height: 280px;
		position: absolute;
		top: 0;
		left: 0;
	}

	h2.vw {
		font-family: sans-serif;
		font-weight: bold;
		font-size: 28px;
		letter-spacing: 0.1em;
		line-height: 1em;
	}

	section#aid-station h2 {
		text-align: left;
		color: #ff0;
		padding-left: 24px;
		margin-bottom: 16px;
	}

	section#aid-station > div {

	}

	section#aid-station > div p {
		font-weight: bold;
		font-size: 14px;
		letter-spacing: 0.04em;
		line-height: 32px;
		text-align: left;
		color: #fff;
		margin-bottom: 24px;
		padding-left: 24px;
	}

	section#aid-station > div p.small {
		font-size: 10px;
		line-height: 20px;
		padding: 0 24px;
	}

	section#aid-station > div p span {
		position: relative;
		font-weight: bold;
	}

	section#aid-station > div p span:before {
		content: '';
		width: 100%;
		height: 16px;
		background: #08f6fe;
		position: absolute;
		bottom: 0px;
		left: 0;
		z-index: -1;
	}

	#map {
		background: url("../img/map.jpg") no-repeat;
		width: 400px;
		height: 228px;
		background-size: cover;
		margin: 0 auto;
	}

	#map ul {
		position: relative;
	}

	#map li {
		width: 28px;
		height: 33px;
		position: absolute;
	}

	#map li:nth-child(1) {
		top: 3px;
		left: 248px;
	}

	#map li:nth-child(2) {
		top: 145px;
		left: 224px;
	}

	#map li:nth-child(3) {
		top: 184px;
		left: 219px;
	}

	#map li:nth-child(4) {
		top: 164px;
		left: 158px;
	}

	#map li:nth-child(5) {
		top: 186px;
		left: 82px;
	}

	#map li a:hover {
		filter: brightness(150%);
	}

	section#special-music h2 {
		font-family: sans-serif;
		font-weight: bold;
		font-size: 28px;
		letter-spacing: 0.1em;
		line-height: 32px;
		text-align: center;
		color: #ff0;
	}

	section#special-music h2 span {
		font-weight: bold;
		font-size: 14px;
		letter-spacing: 0.1em;
		line-height: 28px;
		color: #fff;
		display: block;
	}

	section#special-music > div {
		position: relative;
		padding-top: 40px;
		width: 90%;
		margin: 0 auto;
	}

	section#special-music > div:before {
		content: '';
		background: #fff;
		width: 28%;
		height: 7px;
		position: absolute;
		top: 8px;
		left: 0;
	}

	section#special-music > div:after {
		content: '';
		background: #fff;
		width: 100%;
		height: 1px;
		position: absolute;
		top: 11px;
		left: 0;
	}

	section#special-music > div > div {
		width: 255px;
		margin: 0 auto;
	}

	section#special-music > div > div div:nth-child(1) {
		margin-bottom: 19px;
	}

	section#special-music > div > div div:nth-child(2) {
		width: 200px;
		font-size: 12px;
		letter-spacing: 0.1em;
		line-height: 1em;
		text-align: center;
		margin: 0 auto 16px;
	}

	section#special-music > div > div div:nth-child(2) a {
		display: block;
		font-family: sans-serif;
		font-weight: 700;
		color: #fff;
		height: 40px;
		border-radius: 20px;
		background: #f05f5f;
		box-sizing: border-box;
		padding-top: 14px;
		position: relative;
	}

	section#special-music > div > div div:nth-child(2) a:after {
		content: '';
		background: url(../img/arrow2.svg) no-repeat;
		width: 15px;
		height: 15px;
		position: absolute;
		top: 12px;
		right: 12px;
		background-size: contain;
	}

	section#special-music > div > div div:nth-child(2) a:hover {
		background: #fff;
		color: #f05f5f;
	}

	section#special-music > div > div div:nth-child(2) a:hover:after {
		right: 4px;
		transition: .2s;
	}

	section#special-music > div p {
		font-weight: bold;
		font-size: 14px;
		letter-spacing: 0.04em;
		line-height: 28px;
		text-align: left;
		color: #fff;
	}

	section#how-it-works {
		width: 100%;
		background: #F2FCFF;
		padding: 48px 0;
		position: relative;
		box-sizing: border-box;
	}

	section#how-it-works .vh2 {
		margin-bottom: 40px;
	}

	section#how-it-works h2 {
		font-family: sans-serif;
		font-weight: bold;
		font-size: 28px;
		letter-spacing: 0.1em;
		line-height: 28px;
		color: #009DD1;
		text-align: center;
	}

	section#how-it-works h2 img {
		width: 200px;
		display: block;
		margin: 6px auto 0;
	}

	section#how-it-works ul {
		width: 80%;
		margin: 0 auto;
	}

	section#how-it-works ul li {
		width: 100%;
		background: #fafafa;
		border: 1px dashed #009dd1;
		padding: 32px 20px;
		box-sizing: border-box;
		position: relative;
		margin-bottom: 32px;
	}

	section#how-it-works ul li:last-child {
		margin-bottom: 0;
	}

	section#how-it-works ul li:nth-child(-n+3):after {
		content: '';
		position: absolute;
		bottom: -13px;
		left: -1px;
		border-bottom: 13px solid transparent;
		border-left: 13px solid #6aa7cd;
	}

	section#how-it-works p.num {
		font-family: sans-serif;
		font-weight: 500;
		font-size: 18px;
		line-height: 24px;
		text-align: center;
		color: #ff0;
		width: 34px;
		height: 34px;
		background: #009dd1;
		position: absolute;
		top: -17px;
		left: -17px;
		padding-top: 7px;
		box-sizing: border-box;
	}

	section#how-it-works h3 {
		font-family: sans-serif;
		font-weight: bold;
		font-size: 20px;
		letter-spacing: 0.1em;
		line-height: 20px;
		text-align: center;
		color: #009dd1;
		position: relative;
		margin-bottom: 36px;
	}

	section#how-it-works h3:before {
		content: '';
		width: 100%;
		height: 6px;
		background: #ff0;
		position: absolute;
		bottom: -20px;
		left: 0;
	}

	section#how-it-works h3:after {
		content: '';
		width: 100%;
		height: 1px;
		background: #009dd1;
		position: absolute;
		bottom: -20px;
		left: 0;
	}

	section#how-it-works p {
		font-weight: 500;
		font-size: 13px;
		line-height: 24px;
		text-align: left;
		color: #009dd1;
		margin-bottom: 12px;
	}

	section#how-it-works ul li div:nth-child(4) {
		position: relative;
	}

	section#how-it-works ul li div:nth-child(4):after {
		content: '';
		width: 100%;
		height: 8px;
		background: #d8f6ff;
		position: absolute;
		bottom: -13px;
		left: 0;
	}

	section#area-schedule {
		background: url("../img/img_4_sp.jpg") no-repeat;
		width: 100%;
		height: auto;
		background-size: cover;
		background-position: top center;
		position: relative;
		box-sizing: border-box;
		padding: 48px 0;
	}

	section#area-schedule .vh2 {
		margin-bottom: 40px;
	}

	section#area-schedule h2 {
		font-family: sans-serif;
		font-weight: bold;
		font-size: 28px;
		letter-spacing: 0.1em;
		line-height: 28px;
		color: #FFFF00;
		text-align: center;
		position: relative;
	}

	section#area-schedule h2 img {
		width: 140px;
		display: block;
		margin: 8px auto 0;
	}

	section#area-schedule ul {
		width: 90%;
		position: relative;
		margin: 0 auto;
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}

	section#area-schedule ul li {
		margin-bottom: 16px;
		width: 48%;
	}

	section#area-schedule ul li:last-child {
		margin-bottom: 0;
	}

	section#area-schedule ul li h3 {
		font-family: sans-serif;
		font-weight: bold;
		font-size: 16px;
		letter-spacing: 0.1em;
		line-height: 1em;
		text-align: left;
		color: #ff0;
		margin-bottom: 8px;
	}

	section#area-schedule ul li .more {
		font-family: sans-serif;
		font-size: 11px;
		letter-spacing: 0.06em;
		line-height: 1em;
		text-align: left;
		margin-bottom: 8px;
	}

	section#area-schedule ul li .more a {
		font-weight: 500;
		color: #525252;
		height: 36px;
		background: #08f6fe;
		box-sizing: border-box;
		display: block;
		padding-top: 13px;
		padding-left: 32px;
		position: relative;
	}

	section#area-schedule ul li .more a:after {
		content: '';
		background: url("../img/arrow3.svg") no-repeat;
		width: 36px;
		height: 36px;
		position: absolute;
		top: 0;
		right: 0;
	}

	section#area-schedule ul li .finished {
		font-family: sans-serif;
		font-size: 11px;
		letter-spacing: 0.06em;
		line-height: 1em;
		text-align: left;
		margin-bottom: 8px;
		font-weight: 500;
		color: #525252;
		height: 36px;
		background: #08f6fe;
		box-sizing: border-box;
		display: block;
		padding-top: 13px;
		padding-left: 32px;
		position: relative;
	}

	section#area-schedule ul li p {
		font-family: sans-serif;
		font-weight: 300;
		font-size: 14px;
		letter-spacing: 0.1em;
		line-height: 1em;
		text-align: right;
		color: #fff;
	}

	section#area-schedule .coming_soon {
		font-size: 75%;
		font-weight: bold;
		background-color: #000;
		width: 100%;
		position: absolute;
		top: 0;
		bottom: 0;
		opacity: .7;
		text-align: center;
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		color: #ffffff;
	}

	#img-10 {
		/*
                width: 24%;
                position: absolute;
                top: -156px;
                right: 0;
        */
		display: none;
	}

	article#i10 {
		width: 90%;
		margin: 0 auto;
	}

	#flb2 {
		position: relative;
		padding: 48px 0;
	}

	section#prize {
		position: relative;
	}

	section#prize h2 {
		text-align: center;
		color: #ff0;
		margin-bottom: 4px;
	}

	section#prize p {
		font-weight: bold;
		font-size: 14px;
		letter-spacing: 0.04em;
		line-height: 28px;
		text-align: center;
		color: #fff;
		margin-bottom: 20px;
	}

	section#prize p br {
		display: none;
	}

	section#prize div p {
		text-align: center;
		color: #64a9c3;
		background: #FFFFFF;
		padding-top: 12px;
		line-height: 1em;
		height: 38px;
		box-sizing: border-box;
		margin-bottom: 0;
	}

	section#prize > div {
		margin-bottom: 19px;
	}

	section#prize > div > div {
		border-bottom: 1px solid #08F6FE;
	}

	section#prize dl {
		display: flex;
		justify-content: flex-start;
		border-top: 1px solid #08F6FE;
	}

	section#prize dl dt {
		width: 100%;
		text-align: center;
		font-weight: bold;
		font-size: 14px;
		letter-spacing: 0.04em;
		line-height: 1em;
		background: #D7EEF5;
		color: #64a9c3;
		height: 38px;
		box-sizing: border-box;
		padding-top: 12px;
		border-right: 1px solid #08F6FE;
	}

	section#prize dl dd {
		width: 40%;
		font-family: sans-serif;
		font-weight: bold;
		font-size: 14px;
		letter-spacing: 0.06em;
		line-height: 1em;
		text-align: center;
		background: #D7EEF5;
		color: #64a9c3;
		height: 38px;
		box-sizing: border-box;
		padding-top: 12px;
	}

	section#prize dl dd a {
		display: block;
		font-weight: 500;
		height: 36px;
		box-sizing: border-box;
		padding-top: 13px;
		padding-left: 16px;
		color: #525252;
		background: #08f6fe;
		position: relative;
	}

	section#prize dl dd a:after {
		content: '';
		background: url(../img/arrow4.svg) no-repeat;
		width: 36px;
		height: 36px;
		background-size: cover;
		position: absolute;
		top: 0;
		right: 0;
	}

	section#prize dl dd a:hover {
		background: #009DD1;
		color: #fff;
	}

	section#prize p:nth-child(6) {
		font-weight: bold;
		font-size: 14px;
		letter-spacing: 0.06em;
		line-height: 22px;
		color: #fff;
		text-align: center;
		margin-bottom: 32px;
		position: relative;
	}

	section#prize p:nth-child(6):after {
		content: '';
		background: url("../img/line.svg") no-repeat;
		width: 100%;
		height: 100%;
		background-size: contain;
		position: absolute;
		top: 115%;
		left: 0;
	}

	section#prize ul {
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}

	section#prize ul li {
		width: 48%;
		margin-bottom: 16px;
	}

	section#prize ul li:last-child {
		margin-bottom: 0;
	}

	section#prize ul li h3 {
		font-family: sans-serif;
		font-weight: bold;
		font-size: 14px;
		letter-spacing: 0.1em;
		line-height: 1em;
		text-align: center;
		color: #fff;
		margin-bottom: 6px;
	}

	section#prize ul li a {
		position: relative;
		display: block;
	}

	section#prize ul li a:after {
		content: '';
		background: url("../img/arrow5.svg") no-repeat;
		width: 23px;
		height: 23px;
		background-size: cover;
		position: absolute;
		bottom: 0;
		right: 0;
	}

	section#prize ul li .coming_soon {
		font-size: 100%;
		font-weight: bold;
		background-color: #000;
		width: 100%;
		position: absolute;
		top: 0;
		bottom: 0;
		opacity: .7;
		text-align: center;
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		color: #ffffff;
	}

	section#prize img {
		background: #ffffff;
	}

	section#supporters {
		position: relative;
		background: #fff;
		padding: 48px 0;
	}

	section#supporters div {
		margin-bottom: 32px;
	}

	section#supporters h2 {
		font-family: sans-serif;
		font-weight: bold;
		font-size: 28px;
		letter-spacing: 0.1em;
		line-height: 1em;
		color: #009DD1;
		text-align: center;
		position: relative;
	}

	section#supporters h2:after {
		content: '';
		background: #009DD1;
		width: 320px;
		height: 1px;
		position: absolute;
		bottom: -16px;
		left: 50%;
		margin-left: -160px;
	}

	section#supporters ul {
		display: flex;
		justify-content: flex-start;
		flex-wrap: wrap;
		width: 90%;
		margin: 0 auto;
	}

	section#supporters ul li {
		width: 30%;
		margin-bottom: 2%;
	}

	section#supporters ul li a:hover {
		opacity: .5;
	}

	footer {
		background: #ACDFF2;
		padding: 48px 0 24px;
		position: relative;
	}

	footer li {
		list-style: initial;
		padding-left: 44px;
		text-indent: -22px;
	}

	footer ul li {
		list-style: none;
	}

	footer > div {
		width: 78%;
		margin: 0 auto;
	}

	footer > div h2 {
		font-family: sans-serif;
		font-weight: bold;
		font-size: 20px;
		letter-spacing: 0.1em;
		line-height: 30px;
		margin-bottom: 16px;
	}

	footer > div {
		margin-bottom: 24px;
	}

	footer > div dl dt {
		font-size: 14px;
		font-weight: bold;
		letter-spacing: 0.1em;
		line-height: 24px;
	}

	footer > div dl dd {
		font-size: 14px;
		letter-spacing: 0.1em;
		line-height: 24px;
		margin-bottom: 16px;
	}

	footer > div dl dd:last-child {
		margin-bottom: 0;
	}

	footer ul {
		width: 264px;
		margin: 0 auto 16px;
		display: flex;
		justify-content: space-between;
	}

	footer ul li:nth-child(1) {
		width: 157px;
	}

	footer ul li:nth-child(2) {
		width: 94px;
	}

	#copyright {
		font-family: sans-serif;
		font-weight: normal;
		font-size: 9px;
		letter-spacing: 0.1em;
		line-height: 1em;
		text-align: center;
		color: #0e6e71;
	}
}

.fixed {
	position: fixed !important;
}