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

html, body { height: 100%; }

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

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

a { -webkit-transition: all 0.2s ease-in; -moz-transition: all 0.2s ease-in; -ms-transition: all 0.2s ease-in; -o-transition: all 0.2s ease-in; transition: all 0.2s 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; }

#container { margin: 0 auto; text-align: center; line-height: 180%; min-width: 980px; overflow-x: hidden; font-size: 16px; font-family: 'Noto Sans JP'; }

.pc { display: block; }

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

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

/*-------------------------------------------------
	++ COMMON 
-------------------------------------------------*/
#main { background: url("../img/main.jpg") no-repeat center top; background-size: 1400px auto; height: 746px; }
#main .cInner { padding-top: 25px; }

body.sub #main { height: 450px; }

@media (min-width: 1400px) { #main { background-size: 100% auto; } }
.linkBtn { margin: 30px auto; text-align: center; }

.btn { font-size: 24px; color: #ee6e01 !important; padding: 20px 55px; border: 2px solid #ee6e01; display: inline-block; }
.btn:hover { background-color: #ee6e01; color: #FFF !important; }

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

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

#intro { padding-top: 45px; }
#intro .text { line-height: 195%; font-size: 20px; font-weight: bold; }
#intro .bnr { margin: 75px auto 25px auto; text-align: center; }
#intro #gigyaShare { margin-top: 70px; }

#movie { background: url("../img/bg_wave.png") no-repeat center bottom; background-size: 100% auto; padding: 0 0 85px 0; }
#movie .bnr.yt { margin-top: 65px; }

.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: 24%; margin-bottom: 50px; margin-right: 1%; }
.guestList ul li .photo { position: relative; margin-bottom: 20px; }
.guestList ul li .photo:after { content: ""; position: absolute; bottom: -30px; left: 0; width: 100%; height: 30px; background: url(../img/photo_shadow.png) no-repeat center top; }
.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; }
.guestList ul.flex34 li:nth-of-type(1) { margin-left: 12%; }
.guestList ul.flex34 li:nth-of-type(3) { margin-right: 12%; }

#guest .att { background-color: #FFF; border: 1px solid #ee6e01; font-size: 14px; color: #ee6e01; display: inline-block; padding: 3px 30px; }
#guest .guestList { margin-top: 50px; }

#message { padding: 40px 0 50px 0; }
#message .linkBtn { padding-top: 15px; }

#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: 24%; margin-bottom: 10px; margin-right: 1%; }
#gallery .photoList ul li img { width: 100%; height: auto; display: block; }

/*-------------------------------------------------
	++ FORM 
-------------------------------------------------*/
#messageform { padding-top: 50px; }
#messageform .secHead { text-align: left; }
#messageform .formAtt { margin: 20px 0; text-align: left; }
#messageform .formWrap { padding: 0 75px; }
#messageform .formWrap .message-subtitle { background-color: #fff2ec; color: #ee6e01; padding: 7px; margin: 20px 0; font-size: 18px; }
#messageform .formWrap .sub-link { margin: 20px 0; }
#messageform .formWrap .sub-link a { margin: 0 20px; }
#messageform .formWrap #form-notice { margin: 20px 0; text-align: left; font-size: 14px; }
#messageform .formWrap #form-notice .formAtt { margin-bottom: 20px; }
#messageform .formWrap a { text-decoration: underline; }
#messageform .formWrap table { width: 100%; border-collapse: collapse; }
#messageform .formWrap table tr th { vertical-align: top; padding-top: 9px; width: 30%; padding-left: 30px; padding-right: 24px; text-align: right; font-size: 16px; font-weight: normal; }
#messageform .formWrap table tr td { padding: 1px 0px 7px 0; width: 70%; text-align: left; font-size: 16px; }
#messageform .formWrap table tr td input.fname { width: 50%; margin-bottom: 2px; vertical-align: middle; }
#messageform .formWrap table tr td input.fage { width: 10%; margin-right: 3px; margin-bottom: 2px; vertical-align: middle; }
#messageform .formWrap .thanks { padding: 75px 0 50px 0; color: #ee6e01; }
#messageform .formWrap .thanks h2 { font-family: futura-pt, sans-serif; font-weight: 500; font-style: normal; font-size: 40px; color: #ee6e01; margin-bottom: 30px; }
#messageform .linkBtn { margin-top: 50px; }

#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: 5px; border-radius: 0; font-size: 16px; }

#hw-message table textarea { height: 100px; }

#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: 36px; vertical-align: top; }

#hw-message input:focus, #hw-message select:focus, #hw-message textarea:focus { outline: none; }

.custom-selectbox { position: relative; display: inline-block; border: 1px solid #d0d0d0; border-radius: 0; background: #fff; margin-bottom: 5px; }
.custom-selectbox:hover { border: 1px solid #999999; }
.custom-selectbox:before { content: ""; position: absolute; top: 50%; right: 5px; margin-top: -3px; display: block; width: 6px; height: 6px; border-top: solid 2px #4d4d4d; border-right: solid 2px #4d4d4d; transform: rotate(135deg); }
.custom-selectbox:nth-last-of-type(1) { margin-bottom: 0; }
.custom-selectbox select { cursor: pointer; position: relative; -webkit-appearance: none; -moz-appearance: none; appearance: none; display: block; padding: 2px 20px 2px 5px; 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; height: 44px; width: 264px; margin-right: 16px; font-size: 16px; cursor: pointer; transition: all 0.3s ease-in; }

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

/*-------------------------------------------------
	++ FOOTER
-------------------------------------------------*/
#jwaveFooter { padding: 20px 0 78px 0; transform: scale(-1, 1); background: url("../img/main.jpg") no-repeat center -200px; background-size: 100% 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: 50%; text-align: left; }
#jwaveFooter .commonSet .footerLogo { width: 50%; text-align: right; }
#jwaveFooter .commonSet .copyRight { width: 100%; text-align: center; font-size: 12px; }

.youtube { margin: 50px 0 0;}