body { margin: 0; padding: 0; background: #FFF; color: #333; }

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: #000; 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; }

#container { margin: 0 auto; text-align: center; font-size: 3.6vw; line-height: 160%; font-family: 'Noto Sans JP'; }

.pc { display: none; }

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

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

#content { overflow: hidden; }

/*-------------------------------------------------
	++ COMMON 
-------------------------------------------------*/
#main { background: url("../img/main.jpg") no-repeat center top; background-size: auto 100%; }
#main .cInner { padding: 15vw 5vw; }

.linkBtn { margin: 5vw auto; text-align: center; }

.btn { font-size: 5vw; color: #ee6e01 !important; padding: 3vw 10vw; border: 2px solid #ee6e01; display: inline-block; }
.btn:hover { background-color: #ee6e01; color: #FFF !important; }

#pageTitle { width: 100%; background-color: #ee6e01; color: #FFF; padding: 5vw 0; }
#pageTitle h2 { font-family: futura-pt, sans-serif; font-weight: 500; font-style: normal; font-size: 6vw; }

/*-------------------------------------------------
	++ HOME CONTENTS 
-------------------------------------------------*/
.section { position: relative; padding: 10vw 0; }
.section.line { background-color: #fff2ec; }
.section.line:before { content: ""; width: 100%; height: 5vw; background: url("../img/main.jpg") no-repeat center -10vw; background-size: 100% auto; position: absolute; top: 0; left: 0; transform: scale(1, -1); }
.section.line:after { content: ""; width: 100%; height: 5vw; background: url("../img/main.jpg") no-repeat center -10vw; background-size: 100% auto; position: absolute; bottom: 0; left: 0; transform: scale(-1, 1); }
.section .secHead { margin-bottom: 8vw; }
.section .secHead h2 { font-weight: bold; font-size: 5.4vw; color: #ee6e01; margin-bottom: 5vw; line-height: 160%; }
.section .secHead h2.en { font-family: futura-pt, sans-serif; font-weight: 500; font-style: normal; font-size: 6.4vw; }

#intro .text { line-height: 195%; font-size: 4vw; font-weight: bold; }
#intro .bnr { margin: 8vw auto; text-align: center; }

#movie { background: url("../img/bg_wave.png") no-repeat center bottom; background-size: auto 80vw; }
#movie .youtube { position: relative; width: 100%; padding-top: 56.25%; }
#movie .youtube iframe { position: absolute; top: 0; right: 0; width: 100% !important; height: 100% !important; }
#movie .bnr.yt { margin-top: 10vw; }

.guestList ul { position: relative; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-flex-wrap: wrap; -ms-flex-wrap: wrap; flex-wrap: wrap; justify-content: center; }
.guestList ul li { width: 49%; margin-bottom: 5vw; margin-right: 1%; }
.guestList ul li .photo { position: relative; margin-bottom: 5vw; }
.guestList ul li .photo:after { content: ""; position: absolute; bottom: -10vw; left: 0; width: 100%; height: 10vw; background: url(../img/photo_shadow.png) no-repeat center top; background-size: 100% 10vw; }
.guestList ul li .photo img { width: 100%; height: auto; display: block; }
.guestList ul li .name { font-weight: bold; color: #333; }
.guestList ul li .name small { display: block; }

#guest .att { background-color: #FFF; border: 1px solid #ee6e01; color: #ee6e01; font-size: 3.6vw; display: inline-block; padding: 1vw 5vw; }
#guest .guestList { margin-top: 10vw; }

#gallery .photoList ul { position: relative; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-flex-wrap: wrap; -ms-flex-wrap: wrap; flex-wrap: wrap; justify-content: center; }
#gallery .photoList ul li { width: 49%; margin-bottom: 1.5vw; margin-right: 1%; }
#gallery .photoList ul li img { width: 100%; height: auto; display: block; }

/*-------------------------------------------------
	++ FORM 
-------------------------------------------------*/
#messageform .formWrap { padding: 5vw; }
#messageform .formWrap .message-subtitle { background-color: #fff2ec; color: #ee6e01; margin: 3vw 0; padding: 2vw; font-weight: bold; }
#messageform .formWrap .sub-link { margin: 3vw 0; }
#messageform .formWrap .sub-link a { margin: 0 3vw; }
#messageform .formWrap #form-notice { margin: 3vw 0; text-align: left; }
#messageform .formWrap #form-notice .formAtt { margin-bottom: 3vw; }
#messageform .formWrap a { text-decoration: underline; }
#messageform .formWrap table { width: 100%; border-collapse: collapse; }
#messageform .formWrap table tr th { display: block; text-align: left; padding-bottom: 1vw; }
#messageform .formWrap table tr td { display: block; text-align: left; padding-bottom: 5vw; font-size: 3.6vw; }
#messageform .formWrap table tr td input { font-size: 16px; }
#messageform .formWrap table tr td input.fname { width: 45%; margin-bottom: 2px; vertical-align: middle; }
#messageform .formWrap table tr td input.fage { width: 15%; margin-right: 3px; margin-bottom: 2px; vertical-align: middle; }
#messageform .formWrap table tr td textarea, #messageform .formWrap table tr td select { font-size: 16px; }
#messageform .formWrap .thanks { color: #ee6e01; }
#messageform .formWrap .thanks h2 { font-family: futura-pt, sans-serif; font-weight: 500; font-style: normal; font-size: 7vw; color: #ee6e01; margin-bottom: 5vw; }
#messageform .linkBtn { margin: 5vw auto 0 auto; text-align: center; width: 50%; }

#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; display: inline-block; border: 1px solid #d0d0d0; border-radius: 0; background: #fff; margin-bottom: 3vw; }
.custom-selectbox:before { content: ""; position: absolute; top: 50%; right: 3vw; margin-top: -1vw; display: block; width: 2vw; height: 2vw; border-top: solid 2px #4d4d4d; border-right: solid 2px #4d4d4d; transform: rotate(135deg); }
.custom-selectbox select { cursor: pointer; position: relative; -webkit-appearance: none; -moz-appearance: none; appearance: none; display: block; padding: 1vw 7vw 1vw 3vw; border: none; outline: none; border-radius: 0; background: transparent; width: 100%; font-size: 16px; }
.custom-selectbox select::-ms-expand { display: none; }

#form-submit, #form-reset { -webkit-appearance: none; border: 1px solid #ee6e01; background-color: #ee6e01; color: #FFF; width: 80%; padding: 2vw 3vw; font-size: 3.4vw; margin-bottom: 3vw; }

#form-reset { background-color: #f7f7f7; border: 1px solid #d1d1d1; color: #333; }

/*-------------------------------------------------
	++ FOOTER
-------------------------------------------------*/
#jwaveFooter { padding: 6vw 0; transform: scale(-1, 1); background: url("../img/main.jpg") no-repeat center -10vw; background-size: 1400px auto; }
#jwaveFooter .cInner { transform: scale(-1, 1); }
#jwaveFooter .commonSet { position: relative; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-flex-wrap: wrap; -ms-flex-wrap: wrap; flex-wrap: wrap; align-items: center; }
#jwaveFooter .commonSet .toHome { width: 70%; text-align: left; }
#jwaveFooter .commonSet .toHome a { width: 25%; display: block; }
#jwaveFooter .commonSet .footerLogo { width: 30%; text-align: right; }
#jwaveFooter .commonSet .copyRight { width: 60%; margin: 0 auto; text-align: center; margin-top: 8vw; }

.youtube { margin: 50px 0 0;}