body { margin: 0; padding: 0; }

html, body { height: 100%; }

img { line-height: 0; font-size: 0; border: 0; }

a img, fieldset, img { border: 0; }

blockquote, dd, div, dl, dt, fieldset, form, h1, h2, h3, h4, h5, h6, ul, li, ol, p, pre, span, td, th { margin: 0; padding: 0; }

h1, h2, h3, h4, h5, h6, p, address { font-size: 100%; font-weight: normal; }

ul, li, ol { list-style: none; }

table { border-collapse: collapse; border-spacing: 0; font-size: 100%; }

a:link, a:visited { color: #000; text-decoration: none; }

a:hover, a:active { color: #333; text-decoration: none; }

.cf:before, .cf:after { content: " "; display: table; }

.cf:after { clear: both; }

.cf { *zoom: 1; }

*, *:before, *:after { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -o-box-sizing: border-box; -ms-box-sizing: border-box; box-sizing: border-box; }

body { background: #233636; color: #FFF; }

#container { margin: 0 auto; text-align: center; font-size: 3.6vw; line-height: 160%; overflow-x: hidden; font-family: 'Noto Sans JP', sans-serif; font-weight: 500; }

.fit { width: 100%; height: auto; display: block; }

.pc { display: none; }

.cInner { width: 100%; margin: 0 auto; text-align: center; position: relative; padding: 0 5vw; }

/*-------------------------------------------------
	++ MAIN 
-------------------------------------------------*/
#main { height: 130vw; color: #FFF; background: url("../img/main_sp.jpg") no-repeat center top; background-size: 100% auto; position: relative; }
#main .rect { position: relative; -webkit-transform: rotate(10deg); transform: rotate(10deg); width: 150%; height: 50vw; display: block; position: absolute; margin: 0 0 0 -25%; top: 100vw; }
#main .rect:before { content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: #ffdd00; opacity: 1; transition: 0.5s 0.3s; }
#main .cInner { padding: 0; }
#main #mainHeader { margin: 0 auto; text-align: center; -webkit-transform: rotate(-10deg); transform: rotate(-10deg); position: relative; z-index: 1; }
#main #mainHeader h1 { padding-top: 3vw; }
#main .catch { position: absolute; font-size: 4.2vw; font-weight: 500; color: #1a2828; text-align: left; top: 109vw; left: -16vw; line-height: 160%; }
#main .time { background: #1a2828; width: 120%; height: 9vw; display: block; z-index: 1; padding: 2vw; position: absolute; top: 130vw; left: 0; margin-left: -20vw; }
#main .time img { width: auto; height: 5vw; }
#main .navigator { width: 35%; position: absolute; top: 68vw; z-index: 1; left: 3vw; }
#main .navigator .name { color: #1a2828; font-size: 3vw; font-weight: 500; }

/*-------------------------------------------------
	++ INTRO 
-------------------------------------------------*/
#intro { position: relative; padding: 25vw 0 20vw 0; }
#intro .profile { margin-top: 10vw; background: rgba(0, 0, 0, 0.3); padding: 3vw; position: relative; }
#intro .profile .pfLeft { font-weight: 700; width: 50%; margin: 0 auto; text-align: center; }
#intro .profile .pfRight { text-align: left; font-weight: 500; }
#intro .rect { display: block; background-color: #FFF; position: relative; transform: skewY(-10deg); width: 150%; height: 103%; position: absolute; background: url("../img/bg_mmap.jpg") repeat center top; top: 0; opacity: 1; transition: 0.5s 0.5s; }
#intro .rect:before { content: ""; display: block; height: 100%; -webkit-transition: width 1s cubic-bezier(1, 0, 0, 1) 0.7s; transition: width 1s cubic-bezier(1, 0, 0, 1) 0.7s; width: 0%; opacity: 1; background: #1a2828; }

#about { height: 135vw; color: #FFF; background: url("../img/csn_bg_sp.jpg") no-repeat center top; background-size: 100% auto; padding-top: 15%; }
#about .cInner { padding: 0 5vw; }
#about .aboutBox { text-align: left; color: #1a2828; font-weight: 500; padding-top: 10vw; }
#about .aboutBox h2 { color: #ffdd00; font-weight: 700; font-size: 5vw; background: url(../img/whats_bg.png) no-repeat left top; background-size: auto 15vw; min-height: 15vw; padding: 5vw 0 0 5vw; margin-bottom: 3vw; }
#about .aboutBox .text { font-size: 3.8vw; }

#guest { padding-bottom: 10vw; background-color: #1a2828; position: relative; }
#guest:before { content: ''; position: absolute; top: 0; left: 0; width: 150%; height: 100%; margin: 4% 0 0 -25%; background: #1a2828; -webkit-transform-origin: left center; -ms-transform-origin: left center; transform-origin: left center; -webkit-transform: rotate(3deg); -ms-transform: rotate(3deg); transform: rotate(-10deg); }
#guest h2 { width: 60%; margin: 0 auto 10vw auto; text-align: center; }
#guest ul { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-flex-wrap: wrap; -ms-flex-wrap: wrap; flex-wrap: wrap; position: relative; }
#guest ul li { width: 50%; padding: 0 3vw; }

#movie { background: #233636 url("../img/bg_mmap.jpg") repeat center top; padding-top: 10vw; padding-bottom: 10vw; }
#movie h2 { width: 60%; margin: 0 auto 10vw auto; text-align: center; }

#present { padding-top: 10vw; padding-bottom: 10vw; background-color: #1a2828; }
#present h2 { width: 60%; margin: 0 auto 10vw auto; text-align: center; }
#present .text { font-size: 4.2vw; margin-bottom: 5vw; text-align: left; }
#present .linkBtn { margin: 5vw auto 0 auto; text-align: center; position: relative; height: 80px; }
#present .linkBtn a { color: #1a2828; font-size: 3.6vw; position: relative; display: block; padding: 3vw 5vw; background-color: #FFF; display: inline-block; }
#present .linkBtn a:after { content: ""; display: block; position: absolute; top: 1vw; left: 1vw; width: 100%; height: 100%; border: 1px solid #FFF; }

.subPresent { overflow: hidden; }
.subPresent h2 { margin-bottom: 5vw; }
.subPresent .text { text-align: left; }

#footerPowerd { background: #1a2828 url("../img/footer_bg.png") repeat-x center bottom; background-size: auto 35vw; min-height: 35vw; padding: 10vw 0 5vw 0; }
#footerPowerd img { width: 50%; height: auto; }

.youtube { position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden; }

.youtube iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }

/*-------------------------------------------------
	++ FORM 
-------------------------------------------------*/
.formcontent { margin-top: 3vw; }
.formcontent .message { background-color: #FFF; color: #333; padding: 3vw 3vw; }
.formcontent .message .message-subtitle { background-color: #1a2828; color: #FFF; margin: 3vw 0; padding: 2vw; }
.formcontent .message .sub-link { margin: 3vw 0; }
.formcontent .message .sub-link a { margin: 0 3vw; }
.formcontent .message #form-notice { margin: 3vw 0; text-align: left; }
.formcontent .message #form-notice .formAtt { margin-bottom: 3vw; }
.formcontent .message a { text-decoration: underline; }
.formcontent .message table { width: 100%; border-collapse: collapse; }
.formcontent .message table tr th { display: block; text-align: left; padding-bottom: 1vw; }
.formcontent .message table tr td { display: block; text-align: left; padding-bottom: 5vw; }
.formcontent .message table tr td input.fname { width: 45%; margin-bottom: 2px; vertical-align: middle; }
.formcontent .message table tr td input.fage { width: 15%; margin-right: 3px; margin-bottom: 2px; vertical-align: middle; }

#hw-message input[type="text"], #hw-message input[type="password"], #hw-message input[type="tel"], #hw-message input[type="email"], #hw-message input[type="number"], #hw-message table textarea { width: 100%; border: 1px solid #d1d1d1; background: #fff; -webkit-appearance: none; padding: 2vw; border-radius: 0; }

#hw-message input[type="text"], #hw-message input[type="password"], #hw-message input[type="tel"], #hw-message input[type="email"], #hw-message input[type="number"] { vertical-align: top; }

.custom-selectbox { position: relative; }
.custom-selectbox .inner { position: relative; z-index: 0; height: 32px; line-height: 32px; margin-top: -2px; border: 1px solid #d1d1d1; }
.custom-selectbox .inner:before, .custom-selectbox .inner:after { content: ""; position: absolute; display: block; }
.custom-selectbox .inner:after { top: 50%; right: 7px; margin-top: -3px; width: 0; height: 0; border: solid transparent; border-top-color: #d1d1d1; border-width: 5px 5px 0; }
.custom-selectbox select { position: absolute; top: 0; left: 0; z-index: 1; width: 100%; height: 32px; display: block; }

#form-submit, #form-reset { -webkit-appearance: none; border: 1px solid #d1d1d1; height: 12vw; width: 80%; }

#form-submit { background: #333; border: 1px solid #333; color: #fff; margin-bottom: 3vw; }

/*-------------------------------------------------
	++ FOOTER
-------------------------------------------------*/
#jwaveFooter { background-color: #000; color: #FFF; padding: 3vw 0; }

#jwaveFooter .commonSet { text-align: left; }

#jwaveFooter .commonSet table { width: 100%; }

#jwaveFooter .commonSet table tr td { text-align: right; font-size: 2.6vw; }

#jwaveFooter .commonSet table tr td img { height: 3vw; width: auto; }

/* overrides common styles */
#commonFooter { width: 100% !important; position: static !important; }

#commonFooterInner { padding: 15px 0 !important; width: 100% !important; background-color: #282828 !important; text-align: center !important; }

#commonFooter li { display: inline-block !important; float: none !important; }

#pageTop { position: fixed; bottom: 5vw; right: 5vw; width: 10vw; height: 10vw; }

/*inview
---------------------------------------------------------------------------*/
.up { overflow: hidden; position: relative; opacity: 0; bottom: -80px; }

.upstyle { opacity: 1; bottom: 0px; transition: 1s 0.3s; }
