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%; }

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; }

a { -webkit-transition: all 0.3s ease-in; -moz-transition: all 0.3s ease-in; -ms-transition: all 0.3s ease-in; -o-transition: all 0.3s ease-in; transition: all 0.3s ease-in; }

a:hover { filter: alpha(opacity=80); -moz-opacity: 0.80; opacity: 0.80; }

hr { display: 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; line-height: 160%; min-width: 980px; overflow-x: hidden; font-size: 16px; font-family: 'Noto Sans JP', sans-serif; font-weight: 300; }

.pc, #main img, #information img, .section img { display: block; }

.sp, img.sp { display: none !important; }

.cInner { width: 980px; margin: 0 auto; text-align: center; position: relative; }

/*-------------------------------------------------
	++ MAIN 
-------------------------------------------------*/
#content { overflow: hidden; }

#main { height: 874px; color: #FFF; background: url("../img/main.jpg") no-repeat center top; background-attachment: fixed; background-size: 100% auto; position: relative; }
#main .rect { position: relative; -webkit-transform: rotate(10deg); transform: rotate(10deg); width: 150%; height: 900px; display: block; position: absolute; margin: 0 0 0 -25%; top: 640px; }
#main .rect:before { content: ""; position: absolute; top: 0; left: 0; width: 0; height: 100%; background: #ffdd00; opacity: 1; transition: 0.5s 0.3s; }
#main .cInner { min-height: 874px; }
#main #mainHeader { margin: 0 auto; text-align: center; -webkit-transform: rotate(-10deg); transform: rotate(-10deg); position: relative; padding-top: 60px; z-index: 1; }
#main #mainHeader .catch { position: absolute; font-size: 20px; font-weight: 500; color: #1a2828; text-align: left; opacity: 0; top: 600px; left: -90px; line-height: 32px; transition: .5s 1.5s; }
#main #mainHeader .time { background: #1a2828; width: 0%; height: 50px; display: block; z-index: 1; padding: 12px; position: absolute; top: 710px; left: 0; margin-left: -140px; opacity: 0; transition: .5s 1.5s; }
#main .navigator { position: absolute; top: 600px; right: 0; z-index: 1; opacity: 0; transition: .5s 1.5s; }
#main.on .rect:before { opacity: 1; width: 100%; }
#main.on #mainHeader .catch { opacity: 1; }
#main.on #mainHeader .time { width: 200%; opacity: 1; }
#main.on .navigator { top: 550px; opacity: 1; }

@media (max-width: 1100px) { #main { background-attachment: fixed; background-size: 1100px auto; } }
/*-------------------------------------------------
	++ INTRO 
-------------------------------------------------*/
#intro { position: relative; margin-top: -280px; padding-top: 280px; }
#intro .cInner { padding-top: 100px; }
#intro .profile { margin-top: 50px; background: rgba(0, 0, 0, 0.3); padding: 20px; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-flex-wrap: wrap; -ms-flex-wrap: wrap; flex-wrap: wrap; position: relative; }
#intro .profile .pfLeft { width: 30%; font-weight: 700; }
#intro .profile .pfRight { width: 70%; text-align: left; padding-left: 20px; }
#intro .rect { display: block; background-color: #FFF; position: relative; transform: skewY(-10deg); width: 150%; height: 100%; position: absolute; background: url("../img/bg_mmap.jpg") repeat center top; top: 120px; opacity: 0; transition: 0.5s 0.5s; }
#intro .rect:before { content: ""; background: #1a2828; display: block; width: 100%; opacity: 0; 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; }
#intro .rect.on { top: 80px; opacity: 1; }
#intro .rect.on:before { width: 0%; opacity: 1; background: #1a2828; }

#about { height: 900px; color: #FFF; background: url("../img/csn_bg.jpg") no-repeat center top; background-attachment: fixed; background-size: cover; padding-top: 15%; }
#about .aboutBox { position: absolute; top: 100px; left: 50%; text-align: left; color: #1a2828; font-weight: 500; }
#about .aboutBox h2 { color: #ffdd00; font-weight: 700; font-size: 20px; background: url("../img/whats_bg.png") no-repeat left top; background-size: auto 60px; min-height: 60px; padding: 20px 0 0 20px; margin-bottom: 20px; }

#guest { padding-bottom: 100px; background-color: #1a2828; position: relative; opacity: 0; transition: 0.3s 0.3s; }
#guest:before { content: ''; position: absolute; top: 0; left: 0; width: 0; 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); -webkit-transition: width 0.5s cubic-bezier(1, 0, 0, 1) 0.3s; transition: width 0.5s cubic-bezier(1, 0, 0, 1) 0.3s; }
#guest h2 { margin-bottom: 50px; }
#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%; }
#guest.on { opacity: 1; }
#guest.on:before { width: 150%; }

#movie { background: #233636 url("../img/bg_mmap.jpg") repeat center top; padding-top: 50px; padding-bottom: 85px; }
#movie h2 { margin-bottom: 50px; }

#present { padding-top: 50px; padding-bottom: 85px; background-color: #1a2828; }
#present h2 { margin-bottom: 50px; }
#present .text { font-size: 18px; margin-bottom: 30px; }
#present .linkBtn { margin: 30px auto 0 auto; text-align: center; position: relative; height: 80px; }
#present .linkBtn span { display: block; width: 270px; height: 80px; position: absolute; top: 0; left: 50%; margin-left: -135px; border: 1px solid #FFF; }
#present .linkBtn a { color: #1a2828; font-size: 20px; font-weight: 700; display: block; width: 270px; height: 80px; position: absolute; top: -5px; left: 50%; margin-left: -140px; padding: 30px; background-color: #FFF; transition: all 0.1s ease-in; }
#present .linkBtn a:hover { opacity: 1; margin-left: -135px; top: 0; }

.subPresent { padding-bottom: 85px; overflow: hidden; }
.subPresent .cInner { padding-top: 0 !important; }
.subPresent h2 { margin-bottom: 50px; }
.subPresent .text { font-size: 18px; margin-bottom: 30px; }

#footerPowerd { background: #1a2828 url("../img/footer_bg.png") repeat-x center bottom; min-height: 217px; }

/*-------------------------------------------------
	++ FORM 
-------------------------------------------------*/
.formcontent { margin-top: 20px; }
.formcontent .formAtt { margin: 20px 0; text-align: left; font-size: 14px; }
.formcontent .message { background-color: #FFF; color: #333; padding: 20px 40px; }
.formcontent .message .message-subtitle { background-color: #1a2828; padding: 5px; color: #FFF; margin: 20px 0; }
.formcontent .message .sub-link { margin: 20px 0; font-size: 14px; }
.formcontent .message .sub-link a { margin: 0 20px; }
.formcontent .message #form-notice { margin: 20px 0; text-align: left; font-size: 14px; }
.formcontent .message #form-notice .formAtt { margin-bottom: 20px; }
.formcontent .message a { text-decoration: underline; }
.formcontent .message table { width: 100%; border-collapse: collapse; }
.formcontent .message table tr th { vertical-align: top; padding-top: 9px; width: 30%; padding-left: 30px; padding-right: 24px; text-align: right; font-size: 14px; }
.formcontent .message table tr td { padding: 1px 0px 7px 0; width: 70%; text-align: left; font-size: 14px; }
.formcontent .message table tr td input.fname { width: 50%; margin-bottom: 2px; vertical-align: middle; }
.formcontent .message table tr td input.fage { width: 10%; 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: 1rem; 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"] { height: 32px; 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: 44px; width: 264px; margin-right: 16px; font-size: 14px; }

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

#pageTop { position: fixed; bottom: 130px; right: 30px; }

/*-------------------------------------------------
	++ FOOTER
-------------------------------------------------*/
#jwaveFooter { background-color: #000; color: #FFF; padding: 20px 0 60px 0; }

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

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

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

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

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

.fade { opacity: 0; }

.fadeIn { opacity: 1; transition: 1s 0.3s; }
