/* xs_2017 */

/* ================================
 * MV
 * ================================ */

.l-section-mv {
  position: relative;
  height: 735px;
  color: #fff;
  background-image: url(../img/mv_bg01@pc.jpg);
  background-repeat: no-repeat;
  background-position: 50% 0;
}

@media screen and (min-width: 1280px){
  .l-section-mv {
    background-size: contain;
  }
}

.l-section-mv::before {
  content: '';
  display: block;
  position: absolute;
  top: 0; right: 0; bottom: 0; left: 0;
  width: 100%;
  height: 100%;
  background-image: url(../img/mv_bg_gradient01@pc.png);
  background-repeat: repeat-x;
  -webkit-background-size: contain;
  background-size: contain;
}

.l-section-mv__inner {
  position: relative;
  margin: auto;
  max-width: 980px;
  height: 100%;
  padding: 90px 0 0;
  z-index: 1;
}

.l-section-mv__content {
  width: 100%;
  height: 100%;
}

.l-section-mv__content:not(.hidden) {
  animation: mvAnime01 1000ms;
}

.l-section-mv__content.hidden {
  visibility: hidden;
}

.l-section-mv__title {
  height: 100%;
  background-image: url(../img/mv_img01@pc.png);
  background-repeat: no-repeat;
  background-position: left top;
  text-indent: -9999px;
  white-space: nowrap;
  overflow: hidden;
}

.l-section-mv .ico__new {
  position: absolute;
  top: 0;
  right: 0;
}

.l-section-mv .notes {
  position: absolute;
  left: 0;
  bottom: 15px;
  color: #666;
  font-size: 11px;
}

@keyframes mvAnime01 {
  0% {
    opacity: 0;
    transform: scale(1.025);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

/* ================================
 * Section 01
 * ================================ */

.l-section-01 {
  height: 500px;
  padding: 130px 0 50px;
  background-image: url(../img/bg_s01@pc.jpg);
  background-repeat: no-repeat;
  background-position: center bottom;
}

.l-section__inner {
  position: relative;
  margin: auto;
  width: 980px;
}

.l-section__headTtl {
  margin-bottom: 25px;
}

.l-section__title {
  margin-bottom: .75em;
  line-height: 1.428571;
  color: #fff;
  font-family: -apple-system, "Yu Gothic", YuGothic, Verdana, Meiryo, sans-serif;
  font-size: 1.75em;
  font-weight: bold;
}

.l-section__inner .btn {
  margin-top: 36px;
}

.l-section-01 .l-section__content {
  padding-left: 20px;
}

.l-section__content:not(.hidden) {
  animation: secAnime01 1000ms;
}

.l-section__content.hidden {
  visibility: hidden;
}

@keyframes secAnime01 {
  0% {
    opacity: 0;
    transform: translateY(20px);
  }
  100% {
    opacity: 1;
    transform: translateY(0px);
  }
}

/* ================================
 * Section 02
 * ================================ */

.l-section-02 {
  height: 580px;
  padding: 80px 0 0;
  background-color: #fff;
}

.l-section-02 .pic {
  margin-left: 35px;
}

.l-section-02 .l-section__content .txt {
  float: right;
  width: 380px;
  padding-top: 70px;
  color: #663e3e;
}

.l-section-02 .l-section__content .l-section__title {
  color: #663e3e;
}

/* ================================
 * Section 03
 * ================================ */

.l-section-03 {
  height: 500px;
  padding: 52px 0 80px;
  background-image: url(../img/bg_s03@pc.jpg);
  background-repeat: no-repeat;
  background-position: center bottom;
}

.l-section-03 .l-section__content .txt {
  float: left;
  width: 490px;
  padding-top: 70px;
  padding-left: 20px;
}

.l-section-03 .pic {
  float: right;
}

/* ================================
 * Section 04
 * ================================ */

.l-section-04 {
  height: 510px;
  padding: 80px 0 0;
  background-image: url(../img/bg_s04.jpg);
  background-repeat: no-repeat;
  background-position: center bottom;
  text-align: center;
}

.l-section-04 .l-section__inner {
  position: relative;
  height: 100%;
}

.l-section-04 .l-section__pic {
  width: 607px;
  height: 205px;
  margin: 0 auto 45px;
  background-image: url(../img/img_s04@pc.png);
  background-repeat: no-repeat;
  background-position: 50% 0;
  text-indent: -9999px;
  white-space: nowrap;
  overflow: hidden;
}

.l-section-04 .l-section__content {
  padding-left: 20px;
}

.l-section-04 .l-section__title {
  color: #e2ddd6;
  font-size: 1.5em;
}

.l-section-04 .btn a {
  margin: 0 auto;
}

.l-section-04 .notes {
  position: absolute;
  left: 0;
  bottom: 15px;
  color: #fff;
  font-size: 11px;
}

/* ================================
 * feature
 * ================================ */

.l-wrapper .feature {
  position: relative;
  padding: 85px 0 70px;
  background-color: #fff;
}

.l-wrapper .feature__inner {
  margin: auto;
  width: 980px;
}

.l-wrapper .feature__cols {
  margin-left: -40px;
  overflow: hidden;
}

.l-wrapper .feature__cols:not(.hidden) {
  animation: secAnime01 1000ms;
}

.l-wrapper .feature__cols.hidden {
  visibility: hidden;
}

.l-wrapper .feature__cols__item {
  float: left;
  width: 300px;
  margin-left: 40px;
  text-align: center;
}

.l-wrapper .feature__cols__item a {
  display: block;
  color: #663e3e;
  text-decoration: none;
}

.l-wrapper .feature__cols__item .pic {
  display: block;
  margin-bottom: 15px;
  background-color: #fff;
  font-size: 0;
}

.l-wrapper .feature__cols__item .pic img {
  transition: .2s;
}

.l-wrapper .feature__cols__item a:hover .pic img {
  opacity: .7;
}

.l-wrapper .feature__cols__item img {
  max-width: 100%;
  width: auto;
  height: auto;
}

/* ================================
 * btn
 * ================================ */

.l-wrapper .btn a {
  display: table;
  position: relative;
  text-decoration: none;
  transition: .2s;
}

.l-wrapper .btn span {
  display: table-cell;
  vertical-align: middle;
  padding-top: 1px;
  font-size: 15px;
  text-align: center;
  letter-spacing: .0625em;
}

.l-wrapper .btn span:before {
  content: '';
  position: relative;
  top: 0;
  bottom: 0;
  margin: auto;
  background-repeat: no-repeat;
  background-position: left center;
}

.l-wrapper .btn.s01 a {
  width: 220px;
  height: 40px;
}

.l-wrapper .btn.s02 a {
  width: 220px;
  height: 50px;
}

.l-wrapper .btn.c01 a {
  border: 2px solid #fff;
  color: #fff;
}

.l-wrapper .btn.c01 a:hover {
  border-color: #b3b3b3;
  background-color: #b3b3b3;
  color: #000;
}

.l-wrapper .btn.c02 a {
  border: 2px solid #663e3e;
  color: #663e3e;
}

.l-wrapper .btn.c02 a:hover {
  border-color: #663e3e;
  background-color: #663e3e;
  color: #adadad;
}

.l-wrapper .btn.i01 span:before {
  position: absolute;
  right: 15px;
  width: 8px;
  height: 12px;
  background-image: url(../img/ico_arw01.svg);
  background-size: 7px auto;
}

/* ================================
 *
 * ================================ */
