@charset "UTF-8";

img {
  width: auto;
  height: auto
}

a {
  outline: none
}

html#form, #form body {
  height: 100%;
  min-height: 720px
}

body {
  color: #333;
  font-size: 16px;
  line-height: 1;
  min-width: 1000px;
  max-width: 100%;
  overflow-x: hidden;
  margin: 0 auto
}

strong {
  font-weight: bold
}

.hover {
  -webkit-transition: .5s;
  transition: .5s;
  opacity: 1
}

.hover:hover {
  opacity: .7
}

.pageInner {
  margin: auto;
  width: 1000px
}

.center {
  text-align: center
}

.flex, .flexBetween, .flexStyleBC, .alignCenter {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap
}

.flexBetween, .flexStyleBC {
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between
}

.alignCenter, .flexStyleBC {
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center
}

/* header */
header{
  display: none;
  background-color: #fbf549;
  position: fixed;
  text-align: center;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 90px;
  z-index: 9999;
}

header:hover{
  opacity: 0.8;
}

header h2{
  margin: -20px auto 0;
}

/* FV */
#fv{
  background: #e8e8d7 url(../img/fv_background.jpg) no-repeat;
  background-position: center top;
  text-align: center;
  padding: 30px 0 40px 0;
}

#fv h1{
  text-align: left;
}

#fv h2{
  margin-top: 18px;
}

#fv p{
  font-weight: bold;
  font-size: 28px;
  line-height: 1.3em;
  position: absolute;
  top:85%;
  left:50%;
  -ms-transform: translate(-50%,-50%);
  -webkit-transform: translate(-50%,-50%);
  transform: translate(-50%,-50%);
}

#fv .pageInner{
  position: relative;
}

#fv figure{
  position: absolute;
  top: -11px;
  right: 84px;
}

#fv .text_pink{
  font-weight: bold;
  color: #eb3862;
}

/* campaign */
.campaign{
  position: relative;
  text-align: center;
  padding: 40px 0 0 0;
}
.campaign > p{
}
.campaign > span{
  position: absolute;
  z-index:10;
  top: 180px;
  left: 560px;
  font-size: 24px;
  color: #1e2013;
}




/* info */
.info{
  text-align: center;
  padding: 60px 0;
}

/* graph */
#graph .pageInner{
  overflow: hidden;
  margin-bottom: 40px;
}

#graph .pageInner figure{
  float: left;
}

#graph p{
  float: right;
  width: 52%;
  line-height: 1.8em;
  padding: 85px 15px 85px 0;
}

#graph h2{
  text-align: center;
  padding-bottom: 30px;
}

#graph figure{
  text-align: center;
}

#graph .graph_box{
  margin-bottom: 70px;
}

/* job */
#job{
  background: url(../img/blue_background.png);
}

#job .pageInner{
  padding: 50px 0 65px;
}

#job h2{
  text-align: center;
  padding-bottom: 40px;
}

#job figure{
  text-align: center;
}

/* reason */
#reason h2{
  text-align: center;
  padding-bottom: 80px;
}

#reason .reason_box{
  overflow: hidden;
  margin-bottom: 40px;
}

.reason_box figure{
  float: left;
}

.right_box{
  float: right;
  width: 56%;
}

.right_box h3{
  padding-bottom: 25px;
}

.right_box h4{
  text-align: center;
  margin-bottom: 25px;
}

.right_box p{
  width: 98%;
  line-height: 1.8em;
  margin: 0 auto;
}

/* flow */
#flow h2{
  text-align: center;
  padding:90px 0 40px 0;
}

#flow p{
  text-align: center;
  line-height: 1.7em;
  font-size: 18px;
}

#flow h3{
  text-align: center;
  padding-top: 30px;
}

#flow ul{
  text-align: center;
}

#flow li {
  position: relative;
  padding-bottom: 30px;
}

#flow li span{
  position: absolute;
  bottom: -15px;
  left: 0;
  right: 0;
  z-index: 99;
}

/* careerpartner */
#careerpartner h2{
  text-align: center;
  padding:20px 0 40px 0;
}

#careerpartner .text{
  text-align: center;
  line-height: 1.7em;
  font-size: 18px;
  padding-bottom: 30px;
}

#careerpartner .blue_box{
  background: url(../img/blue_background.png);
  padding-bottom: 85px;
}

#careerpartner ul{
  display: flex;
  justify-content: space-between;
  padding: 60px 0 30px;
}

#careerpartner .staff_box{
  border: solid 4px #1e1e1e;
  background-color: #fff;
  padding: 13px 13px 25px;
  overflow: hidden;
}

#careerpartner figure{
  float: left;
}

#careerpartner h3{
  padding:10px 0 20px;
}

#careerpartner .staff_right{
  width: 710px;
  float: right;
  margin-right: 24px;
}

#careerpartner .box_text{
  text-align: left;
  line-height: 1.9em;
}

/* office */
#office h2{
  text-align: center;
  margin-top: 80px;
  padding-bottom: 30px;
}

#office figure{
  text-align: center;
}

#office h3{
  font-size: 30px;
  text-align: center;
  font-weight: bold;
  padding:30px 0 10px 0;
}

#office .center_text{
  text-align: center;
  font-size: 18px;
  line-height: 1.5em;
}

#office .access{
  overflow: hidden;
  padding: 40px 0;
}

#office iframe{
  float: left;
}

#office .right_box{
  width: 570px;
}

#office .access_text{
  float: right;
  line-height: 1.8em;
}

#office .text{
  font-weight: bold;
  font-size: 26px;
}

#office strong{
  padding-bottom: 28px;
  display: inline-block;
}

#office ul li{
  margin-bottom: 20px;
  text-align: left;
  padding-left: 10px;
}

/* faq */
#faq h2{
  text-align: center;
  margin-top: 80px;
  padding-bottom: 30px;
}

#faq li{
  list-style: none;
}

#faq dl dt{
  background: url(../img/faq_ribbon.png);
  color: #fff;
  font-weight: bold;
  height: 80px;
  font-size: 24px;
  line-height: 80px;
  margin-bottom: 20px;
  padding-left: 20px;
  position: relative;
  cursor:pointer
}

#faq dl dt::after{
  content: '';
  height: 17px;
  width: 25px;
  background: url(../img/faq_arrow_open.png) no-repeat top center;
  display: inline-block;
  background-size: contain;
  position: absolute;
  top:40%;
  right: 3%;
}

#faq dl dt img{
  vertical-align: middle;
  margin-right: 10px;
}

#faq dl dt.active{
  color: #feef87;
}

#faq dl dt.active::after{
  background: url(../img/faq_arrow_close.png) no-repeat top center;
}

#faq dl dd{
  display: none;
  line-height: 30px;
  width: 940px;
  margin: 0 auto;
  padding-bottom: 20px;
}

/* footer */
footer hr{
  width: 100%;
  border:#8c8c8c solid 1px;
  border-left: none;
  border-bottom: none;
  border-right: none;
  background-color: #8c8c8c;
}

footer h2{
  text-align: center;
  margin: 20px 0;
}

footer table{
  margin: 0 auto;
}

footer th{
  width: 8em;
}

footer td{
  width: 19em;
  line-height: 30px;
}

footer small{
  text-align: center;
  display: block;
  font-size: 14px;
  margin: 30px 0;
}
