@import url('https://fonts.googleapis.com/css?family=Muli:400,700&display=swap');

#main * {
  font-family: 'Muli', Meiryo, "Hiragino Kaku Gothic Pro", Osaka, "MS PGothic", sans-serif;
}

/* ========================================================
  汎用
 ======================================================== */

.cat-inner {
  width: 1170px;
  margin: 0 auto;
}

.flex-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.flex-box > div {
  width: 565px;
}
.flex-box > div + div {
  margin-left: auto;
}

.detail-box > ul {
  background: url(../img/bg_detail.png)no-repeat left top;
  background-size: 100% 100%;
  padding: 36px 0 32px 85px;
  width: 504px;
}
.detail-box > ul > li {
  display: flex;
  align-items: center;
  line-height: 2;
  letter-spacing: 0.1em;
}
.detail-box > ul > li::before{
  content: '';
  display: inline-block;
  background: url(../img/icn_checkbox.png)no-repeat left top;
  background-size: 100% 100%;
  width: 17px;
  height: 16px;
  margin-right: 10px;
}

.contact {
  background-image: linear-gradient( 90deg, rgb(247,87,87) 0%, rgb(215,8,59) 37%, rgb(215,8,59) 83%, rgb(215,8,86) 100%);
  padding: 50px 0;
}
.contact > .contact-box {
  width: 600px;
  background: #fff;
  margin: 0 auto;
  border-radius: 2px;
}
.contact > .contact-box > a {
  display: block;
  text-decoration: none;
  text-align: center;
  padding: 27px 0 22px;
}
.contact > .contact-box > a:hover .address {
  text-decoration: underline;
}
.contact > .contact-box .text {
  font-size: 16px;
  letter-spacing: 0.1em;
}
.contact > .contact-box .text + .address{
  margin-top: 13px;
}
.contact > .contact-box .address {
  font-size: 30px;
  font-weight: bold;
  letter-spacing: 0.025em;
  color: #d7083b;
  display: inline-flex;
  align-items: center;
}
.contact > .contact-box .address::before {
  content: '';
  display: inline-block;
  background: url(../img/icn_mail.png)no-repeat left top;
  background-size: 100% 100%;
  width: 39px;
  height: 29px;
  margin-right: 15px;
}

.box-shadow {
  box-shadow: 0px 0px 30px 0px rgba(0,0,0,0.5);
  position: relative;
  z-index: 2;
}

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

#mv {
  background:url(../img/bg_mv.jpg)no-repeat center center , -webkit-gradient(linear,left top, right top,from(#080404),color-stop(50%, #080404),color-stop(50%, #3b2f2f),to(#3b2f2f));
  background:url(../img/bg_mv.jpg)no-repeat center center , linear-gradient(90deg,#080404 0%,#080404 50%,#3b2f2f 50%,#3b2f2f 100%);
  background-size: contain;
  min-width: 1400px;
}
#mv .text-block {
  width: 780px;
  margin-left: auto;
  position: relative;
  padding: 78px 0 0;
}
#mv .text-block > p {
  position: relative;
  color: #fff;
  font-size: 16px;
  line-height: 1.7;
  letter-spacing: 0.14em;
  font-weight: bold;
  transform: translate(7px, 1px);
}
#mv .text-block > p::after {
  content: '';
  display: inline-block;
  background: url(../img/k_mv.png)no-repeat left top;
  background-size: 100% 100%;
  width: 683px;
  height: 2px;
  transform: translate(0, -4px);
}
#mv .text-block > .btn {
  position: absolute;
  right: -43px;
  bottom: -15px;
}
#mv .text-block > h1 > img {
  transform: translate(-57px,-21px);
}

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

.feature_01 {
  background: url(../img/bg_feature_01.png);
  background-size: cover;
  padding: 80px 0;
}
.feature_01 .detail-box {
  transform: translate(-11px,0);
  margin-top: 71px;
}
.feature_01 .flex-box + .detail-list {
  margin-top: 24px;
}


.feature_02 {
  background: url(../img/bg_feature_02.png);
  background-size: cover;
  padding: 80px 0 76px;
}
.feature_02 .detail-box {
  transform: translate(-11px,0);
}
.feature_02 .desc + .detail-box {
  margin-top: 28px;
}
.feature_02 .img-wrp {
  background: rgba(255,255,255,.75);
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.feature_02 .flex-box > .flex-box__body {
  margin-bottom: -10px;
}

.feature_03 {
  background: url(../img/bg_feature_03.png);
  background-size: cover;
  padding: 100px 0 112px;
}

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

#feature > h2 {
  background-image: linear-gradient(90deg, rgb(247,87,87) 0%, rgb(215,8,59) 37%, rgb(215,8,59) 83%, rgb(215,8,86) 100%);
  text-align: center;
  position: relative;
  padding: 37.5px 0;
}
#feature > h2::after {
  content: '';
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 20px 26px 0 26px;
  border-color: #d7083b transparent transparent transparent;
  position: absolute;
  left: 0;
  right: 0;
  bottom: -20px;
  margin: auto;
}
#feature .number + h3 {
  margin-top: 23px;
}
#feature h3 {
  font-size: 32px;
  line-height: 1.5;
  letter-spacing: 0.1em;
  color: #fff;
}
#feature h3 + .desc {
  margin-top: 26px;
}
#feature .desc {
  color: #fff;
  font-size: 16px;
  line-height: 1.7;
  letter-spacing: .1em;
}
#feature .desc + .desc {
  margin-top: 25px;
}
.detail-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  color: #fff;
}
.detail-list > li {
  width: 100%;
  color: #fff;
  font-size: 14px;
  text-align: center;
  padding: 24px 0 25px;
  height: 164px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
}
.detail-list > li > .title {
  letter-spacing: 0.1em;
}
.detail-list > li > .detail {
  font-size: 16px;
  line-height: 1.25;
  letter-spacing: 0.1em;
}
.detail-list > li:nth-child(1) {
  background: url(../img/bg_detail_01.jpg)no-repeat left top;
  background-size: cover;
}
.detail-list > li:nth-child(2) {
  background: url(../img/bg_detail_02.jpg)no-repeat left top;
  background-size: cover;
}
.detail-list > li:nth-child(3) {
  background: url(../img/bg_detail_03.jpg)no-repeat left top;
  background-size: cover;
}
.detail-list > li:nth-child(4) {
  background: url(../img/bg_detail_04.jpg)no-repeat left top;
  background-size: cover;
}
.detail-list > li:nth-child(5) {
  background: url(../img/bg_detail_05.jpg)no-repeat left top;
  background-size: cover;
}
.detail-list > li + li {
  margin-left: 4px;
}

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

#about {
  background: url(../img/bg_about.png)no-repeat left top;
  background-size: cover;
  padding: 70px 0;
}
#about h2 {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  font-size: 24px;
}
#about h2 .bt-1{
  transform: translateY(-9px);
}
#about h2 .bt-2{
  transform: translateY(1px);
}
#about h2 > img {
  margin-left: 20px;
}

#about h2 + .flex-box {
  margin-top: 46px;
}
#about .flex-box + h2 {
  margin-top: 65px;
}
.about-list > li {
  position: relative;
  padding-left: 1.5em;
  line-height: 1.7;
  letter-spacing: .08em;
}
.about-list > li + li {
  margin-top: 26px;
}
.about-list > li::before {
  content: '';
  display: inline-block;
  background: url(../img/icn_about.png)no-repeat left top;
  background-size: 100% 100%;
  width: 12px;
  height: 12px;
  position: absolute;
  left: 0;
  top: 5px;
}
.about-list > li small {
  font-size: 12px;
}
#about img[src*="img_about_01"] {
  transform: translate(-9px,-5px);
}
#about img[src*="img_about_02"] {
  transform: translate(0,4px);
}

.page-top {
  position: fixed;
  right: 115px;
  bottom: 50px;
  z-index: 999;
}
.page-top > a > i {
  display: inline-block;
  background: url(../img/icn_pagetop.png);
  background-size:100% 100%;
  width: 40px;
  height: 40px;
}