@charset "UTF-8";
/*--------------------------------------------------
 ※※※※※※※※※※※※※※※※※※※※※※※※
 このファイルはsassでコンパイルされています
 以下の内容を変更したい場合は構成するscssファイルを
 ご確認ください
 ※※※※※※※※※※※※※※※※※※※※※※※※
--------------------------------------------------*/
/*============================
//_mixin.cscc
============================ */
/*============================
//_animate.scss
//PC
============================ */
@keyframes float {
  0% {
    transform: translateY(0) rotate(25deg);
  }
  33.33333% {
    transform: translateY(-10px) rotate(25deg);
  }
  66.66667% {
    transform: translateY(0) rotate(25deg);
  }
  100% {
    transform: translateY(0) rotate(25deg);
  }
}
@keyframes curtain {
  100% {
    left: -450px;
  }
  33% {
    left: -450px;
  }
  0% {
    left: 0;
  }
}
@keyframes move {
  0% {
    transform: translate(0, 0);
    opacity: 0;
  }
  40% {
    opacity: 1;
  }
  80% {
    transform: translate(0, 20px);
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}
@keyframes wave {
  0% {
    opacity: 0;
  }
  20% {
    opacity: 0;
  }
  30% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  65% {
    background-color: rgba(203, 210, 217, 0.6);
    opacity: 0;
    box-shadow: 0 0 0 40px rgba(31, 41, 51, 0.1);
  }
  100% {
    opacity: 0;
  }
}
/*============================
//_ba.scss
//PC
============================ */
.ba {
  box-sizing: border-box;
  width: 100%;
  min-width: 1300px;
  margin: 0 auto;
  padding: 160px 0;
}
.ba__inner {
  box-sizing: border-box;
  width: 1100px;
  margin: 0 auto;
}
.ba__lead {
  margin: 0 0 80px;
  font-size: 18px;
  font-weight: bold;
  text-align: center;
}
.ba__image {
  width: 100%;
}
.ba__image img {
  width: 100%;
}
.ba .button--base {
  margin: 75px auto 0;
}

.aws {
  padding: 140px 0 0;
}
.aws__box {
  display: flex;
  justify-content: space-between;
  width: 880px;
  margin: 0 auto;
}
.aws__banner {
  width: 250px;
  height: 240px;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.2);
}
.aws__banner img {
  width: 100%;
  height: 100%;
}
.aws__body {
  display: flex;
  flex-direction: column;
  width: 590px;
}
.aws__title {
  margin: 0 0 30px;
  font-family: "Red Hat Display", sans-serif;
  font-size: 24px;
  font-weight: 700;
  letter-spacing: 0.07em;
}
.aws__title span {
  display: block;
  font-family: "游ゴシック体", "Yu Gothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
  font-size: 18px;
  font-weight: bold;
}
.aws__desc {
  margin: 0 0 30px;
  font-size: 14px;
}
.aws__link {
  margin: auto 0 0 auto;
}

/*============================
//_button.scss
//PC
============================ */
.button {
  display: flex;
  position: relative;
  box-sizing: border-box;
  align-items: center;
  justify-content: center;
  width: 420px;
  height: 60px;
  transition: 0.3s;
  border-radius: 100vh;
  color: #ffffff;
  font-size: 16px;
  font-weight: bold;
}
.button::before, .button::after {
  content: "";
  position: absolute;
  transition: 0.3s;
}
.button span {
  position: relative;
  z-index: 1;
}
.button:hover {
  transition: 0.3s;
}

.button__arrow {
  position: relative;
  top: -5px;
  width: 15px;
  height: 15px;
}
.button--base {
  margin: 75px 0 0;
  background-image: -webkit-gradient(linear, left top, right top, color-stop(10%, #25a8d8), to(#4ad5d9));
  background-image: -webkit-linear-gradient(left, #25a8d8 10%, #4ad5d9 100%);
  background-image: linear-gradient(90deg, #25a8d8 10%, #4ad5d9 100%);
}
.button--base::before {
  top: -15px;
  left: -15px;
  width: 100%;
  height: 100%;
  border: 15px solid #25a8d8;
  border-radius: 100vh;
  opacity: 0.1;
  pointer-events: none;
}
.button--base::after {
  z-index: -1;
  display: inline-block;
  bottom: 0;
  left: calc(50% - 150px);
  width: 300px;
  height: 60px;
  transform-style: preserve-3d;
  border-radius: 100vh;
  opacity: 0;
  background-image: -webkit-gradient(linear, left top, right top, color-stop(10%, #25a8d8), to(#4ad5d9));
  background-image: -webkit-linear-gradient(left, #25a8d8 10%, #4ad5d9 100%);
  background-image: linear-gradient(90deg, #25a8d8 10%, #4ad5d9 100%);
  filter: blur(15px);
}
@media all and (-ms-high-contrast: none) {
  .button--base::after {
    display: none;
  }
}
.button--base:hover {
  transform: scale(1.05);
}
.button--base:hover::before {
  opacity: 0;
  transform: scale(-1.05);
}
.button--base:hover::after {
  bottom: -15px;
  opacity: 0.5;
}
@media all and (-ms-high-contrast: none) {
  .button--base:hover {
    box-shadow: 0 10px 30px rgba(37, 168, 216, 0.3);
  }
}
.button--min {
  width: 200px;
  height: 40px;
  background-image: -webkit-gradient(linear, left top, right top, color-stop(10%, #25a8d8), to(#4ad5d9));
  background-image: -webkit-linear-gradient(left, #25a8d8 10%, #4ad5d9 100%);
  background-image: linear-gradient(90deg, #25a8d8 10%, #4ad5d9 100%);
  font-size: 14px;
}
.button--min span {
  top: 1.5px;
}
.button--min::before {
  z-index: 1;
  top: -10px;
  left: -10px;
  width: 100%;
  height: 100%;
  border: 10px solid #25a8d8;
  border-radius: 100vh;
  opacity: 0.1;
  pointer-events: none;
}
.button--min::after {
  display: inline-block;
  bottom: 0;
  left: calc(50% - 60px);
  width: 120px;
  height: 40px;
  transform-style: preserve-3d;
  border-radius: 100vh;
  opacity: 0;
  background-image: -webkit-gradient(linear, left top, right top, color-stop(10%, #25a8d8), to(#4ad5d9));
  background-image: -webkit-linear-gradient(left, #25a8d8 10%, #4ad5d9 100%);
  background-image: linear-gradient(90deg, #25a8d8 10%, #4ad5d9 100%);
  filter: blur(15px);
}
.button--min:hover {
  transform: scale(1.05);
}
.button--min:hover::before {
  opacity: 0;
  transform: scale(-1.05);
}
.button--min:hover::after {
  bottom: -10px;
  opacity: 0.5;
}

/*============================
//_common.scss
//PC
============================ */
.is-onlySP {
  display: none;
}

.is-onlyPC {
  display: inline-block;
}

body {
  letter-spacing: 0;
}

ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

img {
  vertical-align: bottom;
}

a,
a:hover {
  text-decoration: none;
}

p,
h1,
h2,
h3,
h4 {
  margin: 0;
  padding: 0;
}

.header {
  z-index: 2;
  min-width: 1300px;
  background: #ffffff;
  letter-spacing: 0.07em;
}

.footer__map {
  margin: 0;
}

.main {
  position: relative;
}

.heading {
  position: relative;
  margin: 0 0 80px;
  font-family: "Montserrat", sans-serif;
  font-size: 26px;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.1em;
  line-height: 1.2em;
}
.heading span {
  font-size: 16px;
}
.heading::after {
  content: "";
  position: absolute;
  bottom: -15px;
  left: calc(50% - 35px);
  width: 70px;
  height: 7px;
  background: url("../../images/ico_heading.svg") no-repeat center center/100% 100%;
}

.text-link {
  display: inline-block;
  position: relative;
  padding: 0 20px 0 0;
  color: #4ad5d9;
  font-size: 14px;
  font-weight: bold;
  text-align: right;
}
.text-link::before {
  content: "";
  position: absolute;
  top: calc(50% - 8.5px);
  right: 0;
  width: 15px;
  height: 15px;
  transition: 0.2s;
  background: url("../../images/ico_arrow_link.svg") no-repeat center center/100% 100%;
}
.text-link:hover::before {
  right: -5px;
}

.page-top {
  display: flex;
  position: fixed;
  z-index: 100;
  align-items: center;
  justify-content: center;
  right: 20px;
  bottom: 20px;
  width: 80px;
  height: 80px;
  border-radius: 40px;
  background: #585e64;
  color: #585e64;
}
.page-top::before {
  content: "";
  position: absolute;
  top: calc(50% - 10px);
  left: calc(50% - 15px);
  width: 30px;
  height: 20px;
  background: url(../../images/ico_arrow.svg) no-repeat center center/100% 100%;
  transform: rotate(270deg);
}

/*============================
//_concept.scss
//PC
============================ */
.concept {
  box-sizing: border-box;
  width: 100%;
  min-width: 1300px;
  margin: 0 auto;
  position: relative;
  color: #ffffff;
  background: #1f2933;
}
.concept::after {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: -150px;
  left: 0;
  width: 100%;
  height: 150px;
  transform: rotate(180deg);
  background: url("../../images/bg_wave001.png") no-repeat center center/100% 100%;
}
.concept__inner {
  box-sizing: border-box;
  width: 1100px;
  margin: 0 auto;
  padding: 180px 0;
}
.concept__lead {
  margin: 0 0 80px;
  font-size: 18px;
  font-weight: bold;
  text-align: center;
}
.concept__arrow {
  width: 80px;
  margin: 0 auto;
}
.concept__arrow img {
  width: 100%;
}

.concept-category {
  display: flex;
  justify-content: space-between;
  margin: 0 0 30px;
}
.concept-category a {
  color: #ffffff;
}
.concept-category__item {
  width: 120px;
}
.concept-category__image img {
  width: 100%;
}
.concept-category__image img:hover {
  transform: scale(1.1, 1.1);
  transition: 0.3s;
}
.concept-category__unset img {
  width: 100%;
}
.concept-category__unset:hover {
  transform: unset;
}
.concept-category__label {
  font-size: 14px;
  text-align: center;
}

.concept-service {
  display: flex;
  justify-content: space-between;
}
.concept-service__box {
  position: relative;
  width: 45%;
}
.concept-service__image {
  margin: 0 0 30px;
}
.concept-service__image img {
  width: 100%;
}
.concept-service__title {
  margin: 0 0 20px;
  font-size: 22px;
  font-weight: bold;
  text-align: center;
}
.concept-service__text {
  font-size: 16px;
}
.concept-service__line {
  position: relative;
  top: 60px;
  width: 4px;
  height: 600px;
  margin: 0 auto;
}
.concept-service__line img {
  width: 100%;
}

/*============================
//_contact.scss
//PC
============================ */
.uly-heading--game::after {
  background: url(../../images/ico_heading.svg) no-repeat center center/100% 100%;
}

/*============================
//_cycle-case.scss
//PC
============================ */
.cycle-case {
  box-sizing: border-box;
  width: 100%;
  min-width: 1300px;
  margin: 0 auto;
  position: relative;
  padding: 100px 0 60px;
  background: #f5f7fa;
  color: #3e4c59;
}
.cycle-case__inner {
  box-sizing: border-box;
  width: 1100px;
  margin: 0 auto;
}
.cycle-case__num {
  margin: 0 0 20px;
  color: #e04943;
  font-family: "Montserrat", sans-serif;
  font-size: 22px;
  font-weight: bold;
}
.cycle-case__num span {
  font-size: 36px;
}
.cycle-case__title {
  margin: 0 0 10px;
  color: #3e4c59;
  font-size: 42px;
  font-weight: bold;
}
.cycle-case__period {
  margin: 0 0 60px;
  color: #3e4c59;
  font-size: 24px;
  font-weight: bold;
}
.cycle-case__box {
  display: flex;
  justify-content: space-between;
}
.cycle-case__image {
  width: 560px;
  box-shadow: 0 0 26px rgba(0, 0, 0, 0.2);
}
.cycle-case__image img {
  width: 100%;
}
.cycle-case__textarea {
  width: 480px;
}
.cycle-case__point {
  margin: 0 0 15px;
  color: #e04943;
  font-family: "Montserrat", sans-serif;
  font-size: 24px;
  font-weight: bold;
}
.cycle-case__text {
  margin: 0 0 10px;
  color: #3e4c59;
  font-size: 20px;
  font-weight: bold;
}
.cycle-case__list {
  position: relative;
  margin: 0 0 60px;
}
.cycle-case__list::after {
  content: "";
  position: absolute;
  right: 0;
  bottom: -62px;
  width: 550px;
  height: 47px;
  background: url("../../images/pickup-cycle_002.png") no-repeat center center/contain;
}
.cycle-case__item {
  position: relative;
  margin: 0 0 8px;
  padding: 0 0 0 30px;
  font-size: 16px;
}
.cycle-case__item::before {
  content: "";
  position: absolute;
  top: 5px;
  left: 0;
  width: 15px;
  height: 15px;
  background: url("../../images/ico_check.svg") no-repeat center center/contain;
}
.cycle-case__desc {
  margin: 60px 0 0;
  font-size: 14px;
  text-align: center;
}
.cycle-case .button--base {
  margin: 75px auto 100px;
}

/*============================
//_environment.scss
//PC
============================ */
.environment {
  box-sizing: border-box;
  width: 100%;
  min-width: 1300px;
  margin: 0 auto;
  position: relative;
  color: #3e4c59;
}
.environment__inner {
  box-sizing: border-box;
  width: 1100px;
  margin: 0 auto;
}
.environment__dl {
  width: 600px;
  margin: 0 auto 50px;
}
.environment__box {
  display: flex;
  justify-content: space-between;
  padding: 20px 0;
  border-bottom: 1px solid #cbd2d9;
}
.environment__box:first-child {
  border-top: 1px solid #cbd2d9;
}
.environment__dt {
  width: 300px;
  margin: 0;
  font-size: 18px;
  font-weight: bold;
}
.environment__dd {
  width: 300px;
  margin: 0;
  font-size: 18px;
}

.basic-function {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.basic-function__box {
  display: flex;
  box-sizing: border-box;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: calc((100% - 50px) / 4);
  margin: 0 0 30px;
  padding: 40px 30px 20px;
  border: 3px solid #f5f7fa;
  border-radius: 8px;
}
.basic-function__image {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 0 30px;
  width: 95px;
  height: 95px;
  background: #f8e0dc;
  border-radius: 48px;
}
.basic-function__title {
  margin-bottom: 15px;
  font-size: 18px;
}
.basic-function__text {
  font-size: 14px;
  text-align: center;
}
.basic-function__hide {
  display: none;
}
.basic-function__more {
  display: flex;
  position: relative;
  align-items: center;
  justify-content: center;
  width: 200px;
  height: 45px;
  margin: 40px auto 0;
  padding: 0 12px 0 0;
  border: 2px solid #3e4c59;
  border-radius: 50px;
  color: #3e4c59;
  font-size: 14px;
}
.basic-function__more::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 10px;
  width: 16px;
  height: 2px;
  background: #3e4c59;
  transform: translateY(-50%);
}
.basic-function__more::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 17px;
  width: 2px;
  height: 16px;
  background: #3e4c59;
  transform: translateY(-50%);
  transition: 0.3s;
}
.basic-function__more.is-open::after {
  top: 25%;
  opacity: 0;
  transform: rotate(90deg);
}
.basic-function__desc {
  margin: 40px 0 0;
  font-size: 14px;
  text-align: center;
}

/*============================
//_hero.scss
//PC
============================ */
.hero {
  box-sizing: border-box;
  width: 100%;
  min-width: 1300px;
  margin: 0 auto;
  position: relative;
  height: 100vh;
  min-height: 730px;
  background: url("../../images/hero_001.jpg") no-repeat center center/100% 100%;
  background-size: cover;
  color: #ffffff;
}
.hero::before, .hero::after {
  content: "";
  position: absolute;
  left: 0;
}
.hero::before {
  z-index: 2;
  top: 82px;
  width: 100%;
  height: 80px;
  background: url("../../images/hero_top.png") no-repeat center center/100% 100%;
}
.hero::after {
  z-index: 0;
  bottom: -1px;
  width: 100%;
  height: 530px;
  background: url("../../images/hero_002.png") no-repeat center center/100% 100%;
}
.hero__inner {
  box-sizing: border-box;
  width: 1100px;
  margin: 0 auto;
  z-index: 10;
  display: flex;
  position: absolute;
  bottom: 40px;
  left: 50%;
  align-items: flex-end;
  justify-content: space-between;
  transform: translateX(-50%);
}
.hero__textarea {
  width: 670px;
}
.hero__seg {
  z-index: 2;
  position: relative;
  margin: 0 0 20px;
  color: #e04943;
  font-family: "Montserrat", sans-serif;
  font-size: 22px;
  font-weight: bold;
  letter-spacing: 2px;
}
.hero__headline {
  z-index: 2;
  position: relative;
  margin: 0 0 15px;
  font-family: "Red Hat Display", sans-serif;
  font-size: 31px;
  font-weight: bold;
  letter-spacing: 0.07em;
}
.hero__headline span {
  display: block;
  font-family: "游ゴシック体", "Yu Gothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
  font-size: 26px;
  font-weight: normal;
}
.hero__desc {
  z-index: 2;
  position: relative;
  font-size: 14px;
  font-weight: nomal;
  color: #cbd2d9;
  line-height: 2;
  letter-spacing: 0.075em;
}
.hero__cycle {
  z-index: 2;
  position: relative;
  width: 400px;
}
.hero__cycle img {
  width: 100%;
}

.scroll {
  display: inline-block;
  position: relative;
  z-index: 2;
  bottom: 2vh;
  left: 50%;
  padding: 20px 0 0;
  transform: translateX(-50%);
  color: #ffffff;
}
.scroll span {
  position: absolute;
  top: -40px;
  left: calc(50% - 15px);
  box-sizing: border-box;
  width: 30px;
  height: 50px;
  border: 2px solid #ffffff;
  border-radius: 50px;
}
.scroll span::before {
  content: "";
  position: absolute;
  top: 10px;
  left: calc(50% - 3px);
  width: 6px;
  height: 6px;
  animation: move 2s infinite;
  border-radius: 100%;
  background: #ffffff;
}

/*============================
//_loading.scss
//PC
============================ */
.loader {
  position: fixed;
  z-index: 100;
  top: 0;
  left: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  background: #ffffff;
}
.loader__inner {
  position: relative;
}
.loader__object {
  position: absolute;
  top: 0;
  left: calc(50% - 25px);
  width: 50px;
  height: 50px;
  animation: bound 1s infinite;
  background: url("../../images/ico_logo.png") no-repeat center center/100% 100%;
}
.loader__text {
  margin: 60px 0 0;
  color: #9aa5b1;
  font-family: 'Montserrat', sans-serif;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: .25em;
}

@keyframes bound {
  0%,100% {
    top: 0;
    transform: scale(1);
  }
  30% {
    top: -20%;
    transform: scale(0.96, 1.04);
  }
  60% {
    transform: scale(1);
  }
  90% {
    top: 0;
    transform: scale(1.3, 0.9);
  }
}
.is-fixed {
  position: fixed;
  width: 100%;
  height: 100%;
  left: 0;
}

@media all and (-ms-high-contrast: none) {
  .is-fixed {
    position: relative;
  }
}
.pickup {
  box-sizing: border-box;
  width: 100%;
  min-width: 1300px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
  padding: 120px 0 0;
}

.pickup-case {
  margin: -30px 0 100px;
  padding: 30px 0 70px;
  overflow: hidden;
}
.pickup-case__item {
  position: relative;
  bottom: 0;
  width: 265px;
  margin: 0 15px;
  overflow: hidden;
  transition: .3s;
  border-radius: 10px 10px 0 0;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
}
.pickup-case__item--hover:hover {
  bottom: 10px;
}
.pickup-case__image {
  width: 100%;
  height: 138px;
  overflow: hidden;
}
.pickup-case__image img {
  width: 100%;
  object-fit: cover;
}
.pickup-case__tag {
  display: flex;
  position: absolute;
  align-items: center;
  justify-content: center;
  width: 90px;
  height: 25px;
  border-radius: 10px 0 0;
  background: #e04943;
  color: #ffffff;
  font-size: 10px;
  font-weight: bold;
}
.pickup-case__body {
  display: flex;
  flex-direction: column;
  align-items: center;
  height: 100%;
  padding: 20px;
  background: #ffffff;
}
.pickup-case__title {
  margin-bottom: 20px;
  color: #000;
  font-size: 14px;
  font-weight: bold;
  text-align: center;
}
.pickup-case__desc {
  margin-bottom: 20px;
  color: #1f2933;
}
.pickup-case__desc:last-child {
  margin-bottom: 0;
}
.pickup-case__link {
  display: inline-block;
  position: relative;
  margin: 0 auto;
  padding-right: 22px;
  color: #e04943;
  font-size: 14px;
  font-weight: bold;
}
.pickup-case__link::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  width: 16px;
  height: 16px;
  transform: translateY(-50%);
  background: url("../../images/ico_arrow_link_red.svg") no-repeat center center/contain;
}
.pickup-case .slick-list {
  box-sizing: border-box;
  width: 1100px;
  margin: 0 auto;
  overflow: visible;
}
.pickup-case .slick-track {
  display: flex;
}
.pickup-case .slick-slide {
  height: auto;
}
.pickup-case .slick-dots {
  bottom: 0;
  left: 50%;
  width: 290px;
  margin-left: -145px;
}
.pickup-case .slick-dots li {
  width: 6px;
  margin: 0 6px;
}
.pickup-case .slick-dots li button {
  width: 6px;
}
.pickup-case .slick-dots li button::before {
  content: "";
  top: calc(50% - 6px);
  left: calc(50% - 6px);
  width: 6px;
  height: 6px;
  border-radius: 100vh;
  background: #1f2933;
}
.pickup-case .slick-prev,
.pickup-case .slick-next {
  z-index: 1;
  top: auto;
  right: 0;
  bottom: -10px;
  left: 50%;
  width: 30px;
  height: 34px;
}
.pickup-case .slick-prev::before,
.pickup-case .slick-next::before {
  top: 0;
  left: 0;
  width: 30px;
  height: 30px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 22 16'%3E%3Cpath d='M22 8c0 .6-.4 1-1 1H3.4l5.3 5.3c.4.4.4 1 0 1.4-.2.2-.4.3-.7.3s-.5-.1-.7-.3l-7-7c-.1-.1-.2-.2-.2-.3-.1-.3-.1-.5 0-.8.1-.1.1-.2.2-.3l7-7c.4-.4 1-.4 1.4 0s.4 1 0 1.4L3.4 7H21c.6 0 1 .4 1 1z' fill='%233e4c59'/%3E%3C/svg%3E%0A");
  background-position: center center;
  font-size: 36px;
}
.pickup-case .slick-prev {
  margin-left: -145px;
  transform: translate(0);
}
.pickup-case .slick-next {
  margin-left: 115px;
  transform: scale(-1, 1);
}

.pickup {
  box-sizing: border-box;
  width: 100%;
  min-width: 1300px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
  padding: 120px 0 0;
}

.pickup-case {
  margin: -30px 0 100px;
  padding: 30px 0 70px;
  overflow: hidden;
}
.pickup-case__item {
  position: relative;
  bottom: 0;
  width: 265px;
  margin: 0 15px;
  overflow: hidden;
  transition: .3s;
  border-radius: 10px 10px 0 0;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
}
.pickup-case__item--hover:hover {
  bottom: 10px;
}
.pickup-case__image {
  width: 100%;
  height: 138px;
  overflow: hidden;
}
.pickup-case__image img {
  width: 100%;
  object-fit: cover;
}
.pickup-case__tag {
  display: flex;
  position: absolute;
  align-items: center;
  justify-content: center;
  width: 90px;
  height: 25px;
  border-radius: 10px 0 0;
  background: #e04943;
  color: #ffffff;
  font-size: 10px;
  font-weight: bold;
}
.pickup-case__body {
  display: flex;
  flex-direction: column;
  align-items: center;
  height: 100%;
  padding: 20px;
  background: #ffffff;
}
.pickup-case__title {
  margin-bottom: 20px;
  color: #000;
  font-size: 14px;
  font-weight: bold;
  text-align: center;
}
.pickup-case__desc {
  margin-bottom: 20px;
  color: #1f2933;
}
.pickup-case__desc:last-child {
  margin-bottom: 0;
}
.pickup-case__link {
  display: inline-block;
  position: relative;
  margin: 0 auto;
  padding-right: 22px;
  color: #e04943;
  font-size: 14px;
  font-weight: bold;
}
.pickup-case__link::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  width: 16px;
  height: 16px;
  transform: translateY(-50%);
  background: url("../../images/ico_arrow_link_red.svg") no-repeat center center/contain;
}
.pickup-case .slick-list {
  box-sizing: border-box;
  width: 1100px;
  margin: 0 auto;
  overflow: visible;
}
.pickup-case .slick-track {
  display: flex;
}
.pickup-case .slick-slide {
  height: auto;
}
.pickup-case .slick-dots {
  bottom: 0;
  left: 50%;
  width: 290px;
  margin-left: -145px;
}
.pickup-case .slick-dots li {
  width: 6px;
  margin: 0 6px;
}
.pickup-case .slick-dots li button {
  width: 6px;
}
.pickup-case .slick-dots li button::before {
  content: "";
  top: calc(50% - 6px);
  left: calc(50% - 6px);
  width: 6px;
  height: 6px;
  border-radius: 100vh;
  background: #1f2933;
}
.pickup-case .slick-prev,
.pickup-case .slick-next {
  z-index: 1;
  top: auto;
  right: 0;
  bottom: -10px;
  left: 50%;
  width: 30px;
  height: 34px;
}
.pickup-case .slick-prev::before,
.pickup-case .slick-next::before {
  top: 0;
  left: 0;
  width: 30px;
  height: 30px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 22 16'%3E%3Cpath d='M22 8c0 .6-.4 1-1 1H3.4l5.3 5.3c.4.4.4 1 0 1.4-.2.2-.4.3-.7.3s-.5-.1-.7-.3l-7-7c-.1-.1-.2-.2-.2-.3-.1-.3-.1-.5 0-.8.1-.1.1-.2.2-.3l7-7c.4-.4 1-.4 1.4 0s.4 1 0 1.4L3.4 7H21c.6 0 1 .4 1 1z' fill='%233e4c59'/%3E%3C/svg%3E%0A");
  background-position: center center;
  font-size: 36px;
}
.pickup-case .slick-prev {
  margin-left: -145px;
  transform: translate(0);
}
.pickup-case .slick-next {
  margin-left: 115px;
  transform: scale(-1, 1);
}

/*============================
//_pickup-cycle.scss
//PC
============================ */
.pickup-cycle {
  box-sizing: border-box;
  width: 100%;
  min-width: 1300px;
  margin: 0 auto;
  position: relative;
  padding: 100px 0 60px;
  background: #3e4c59;
  color: #ffffff;
}
.pickup-cycle::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: -150px;
  left: 0;
  width: 100%;
  height: 150px;
  background: url("../../images/bg_wave.png") no-repeat center center/100% 100%;
}
.pickup-cycle__inner {
  box-sizing: border-box;
  width: 1100px;
  margin: 0 auto;
  padding: 0 0 80px;
  background: #3e4c59;
}
.pickup-cycle__heading {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 0 20px;
  font-size: 36px;
  text-align: center;
}
.pickup-cycle__heading span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  margin: 0 15px 0 0;
  border-radius: 10px;
  background: #1f2933;
  color: #ffffff;
  font-size: 24px;
}
.pickup-cycle__box {
  display: flex;
  justify-content: space-between;
}
.pickup-cycle__image {
  width: 440px;
}
.pickup-cycle__image img {
  width: 100%;
}
.pickup-cycle__textarea {
  width: 580px;
}
.pickup-cycle__title {
  margin: 0 0 20px;
  font-size: 22px;
}
.pickup-cycle__text {
  position: relative;
  font-size: 18px;
}
.pickup-cycle__text::after {
  content: "";
  position: absolute;
  right: 0;
  bottom: -70px;
  width: 650px;
  height: 47px;
  background: url("../../images/pickup-cycle_001.png") no-repeat center center/contain;
}

/*============================
//_people.scss
//PC
============================ */
.people {
  box-sizing: border-box;
  width: 100%;
  min-width: 1300px;
  margin: 0 auto;
  padding: 160px 0;
}
.people__inner {
  box-sizing: border-box;
  width: 1100px;
  margin: 0 auto;
}
.people__lead {
  margin: 0 0 60px;
  color: #1f2933;
  font-size: 36px;
  text-align: center;
}
.people__lead span {
  font-size: 24px;
}
.people__box {
  display: flex;
  justify-content: space-between;
}
.people__item {
  width: calc((100% - 60px) / 3);
}
.people__image {
  margin: 0 0 30px;
  border-radius: 10px;
}
.people__image img {
  width: 100%;
}
.people__name {
  margin: 0 0 10px;
  color: #616e7c;
  font-size: 12px;
  font-weight: bold;
}
.people__title {
  margin: 0 0 20px;
  color: #1f2933;
  font-size: 18px;
  font-weight: bold;
}
.people__desc {
  color: #3e4c59;
  font-size: 14px;
  line-height: 2em;
}

/*============================
//_performance.scss
//PC
============================ */
.performance {
  box-sizing: border-box;
  width: 100%;
  min-width: 1300px;
  margin: 0 auto;
  position: relative;
  z-index: -1;
  overflow: hidden;
  color: #ffffff;
  background: url("../../images/img_team.jpg") no-repeat center center/cover;
}
.performance::before, .performance::after {
  content: "";
  position: absolute;
}
.performance::before {
  z-index: 1;
  top: 0;
  left: 0;
  width: 100%;
  height: 150px;
  transform: scale(-1, -1);
  background: url("../../images/bg_wave002.png") no-repeat center center/100% 100%;
}
.performance::after {
  z-index: -1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(31, 41, 51, 0.8);
}
.performance__inner {
  box-sizing: border-box;
  width: 1100px;
  margin: 0 auto;
  position: relative;
  padding: 240px 0 140px;
}
.performance__box {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.performance__box:first-of-type {
  margin: 0 0 60px;
}
.performance__heading {
  margin: 0 0 20px;
  font-size: 20px;
  text-align: center;
}
.performance__panel {
  display: flex;
  justify-content: space-between;
  width: 880px;
}
.performance__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: calc((100% - 80px) / 3);
  padding: 50px 0;
  border: 1px solid #f5f7fa;
  border-radius: 10px;
  background-color: rgba(31, 41, 51, 0.7);
  text-align: center;
}
.performance__ico {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
}
.performance__ico img {
  max-width: 50px;
  max-height: 50px;
}
.performance__title {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100px;
  font-size: 18px;
  font-weight: bold;
}
.performance__value {
  position: relative;
  font-family: "游ゴシック体", "Yu Gothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
  font-size: 30px;
  font-weight: bold;
  letter-spacing: 0.05em;
}
.performance__value span {
  padding: 0 2px;
  color: #e04943;
  font-family: "Roboto", sans-serif;
  font-size: 42px;
  font-weight: 700;
}
.performance__value::after {
  content: "";
  position: absolute;
  bottom: -5px;
  left: calc(50% - 18px);
  width: 36px;
  height: 2px;
  background: #e04943;
}
.performance__list {
  margin: 25px 0 0;
}
.performance__desc {
  font-size: 18px;
  font-weight: bold;
}
.performance__desc span {
  color: #e04943;
  font-size: 26px;
}

@media all and (-ms-high-contrast: none) {
  .performance {
    top: -1px;
  }
}
/*============================
//_qa.scss
//PC
============================ */
.qa {
  box-sizing: border-box;
  width: 100%;
  min-width: 1300px;
  margin: 0 auto;
  position: relative;
  margin: 120px 0 0;
  padding: 120px 0;
  background: #f5f7fa;
}
.qa__inner {
  box-sizing: border-box;
  width: 1100px;
  margin: 0 auto;
}
.qa__box {
  width: 865px;
  margin: 0 auto;
}
.qa__q {
  position: relative;
  margin: 0 0 20px;
  padding: 0 0 0 60px;
  font-size: 20px;
}
.qa__q::before {
  content: "Q";
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 0;
  padding: 6px 13px;
  transform: translateY(-50%);
  border-radius: 5px;
  background: #3e4c59;
  color: #ffffff;
  font-family: "Montserrat", sans-serif;
  font-weight: bold;
}
.qa__a {
  position: relative;
  margin: 0 0 40px;
  padding: 0 0 0 60px;
  font-size: 16px;
}
.qa__a::before {
  content: "A";
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 0;
  padding: 6px 13px;
  transform: translateY(-50%);
  border-radius: 5px;
  background: #616e7c;
  color: #ffffff;
  font-family: "Montserrat", sans-serif;
  font-size: 20px;
  font-weight: bold;
}
.qa__desc {
  margin: 100px 0 0;
  font-size: 14px;
  text-align: center;
}

/*============================
//_service-step.scss
//PC
============================ */
.service-step {
  box-sizing: border-box;
  width: 100%;
  min-width: 1300px;
  margin: 0 auto;
  padding: 160px 0 0;
}
.service-step__inner {
  box-sizing: border-box;
  width: 1100px;
  margin: 0 auto;
}
.service-step__title {
  position: relative;
}
.service-step__title::before, .service-step__title::after {
  content: "";
  position: absolute;
}
.service-step__title::before {
  top: -45px;
  left: calc(50% - 100px);
  width: 200px;
  height: 200px;
  border: 4px solid #9aa5b1;
  border-radius: 110px;
}
.service-step__title::after {
  z-index: -2;
  top: 160px;
  left: calc(50% - 2px);
  width: 4px;
  height: 90px;
  background: #9aa5b1;
}

.solution-service {
  position: relative;
  margin: 120px 0 -450px;
}
.solution-service::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: calc(50% - 600px);
  width: 1200px;
  height: 1235px;
  background: url("../../images/service_step_bg.png") no-repeat center center/100% 100%;
}
.solution-service__box {
  display: flex;
  position: relative;
  justify-content: flex-end;
  right: 80px;
}
.solution-service__box:nth-child(even) {
  justify-content: flex-start;
  left: 80px;
}
.solution-service__box:nth-child(even) .solution-service__item {
  box-shadow: -10px 10px 10px rgba(0, 0, 0, 0.05);
}
.solution-service__box:nth-child(even) .solution-service__item::before {
  content: "";
  position: absolute;
  top: 30px;
  left: 420px;
  border: 14px solid transparent;
  border-left: 20px solid #f5f7fa;
}
.solution-service__box:nth-child(even) .solution-service__num {
  right: 20px;
  text-align: right;
}
.solution-service__box:nth-child(even) .solution-service__phase {
  left: 20px;
}
.solution-service__box:first-child {
  top: -25px;
}
.solution-service__box:nth-child(2) {
  top: -155px;
}
.solution-service__box:nth-child(3) {
  top: -365px;
}
.solution-service__box:nth-child(4) {
  top: -525px;
}
.solution-service__box:nth-child(5) {
  top: -630px;
}
.solution-service__box:last-child {
  top: -680px;
}
.solution-service__item {
  position: relative;
  box-sizing: border-box;
  width: 420px;
  padding: 40px;
  border-radius: 10px;
  background: #f5f7fa;
  box-shadow: 10px 10px 10px rgba(0, 0, 0, 0.05);
}
.solution-service__item::before {
  content: "";
  position: absolute;
  top: 30px;
  left: -30px;
  border: 14px solid transparent;
  border-right: 20px solid #f5f7fa;
}
.solution-service__num {
  position: absolute;
  top: -26px;
  left: 20px;
  font-family: "Roboto", sans-serif;
  font-size: 36px;
  font-weight: bold;
}
.solution-service__phase {
  position: absolute;
  top: -16px;
  right: 20px;
  width: 150px;
  padding: 8px 0;
  border-radius: 5px;
  background: #e04943;
  color: #ffffff;
  font-size: 12px;
  font-weight: bold;
  text-align: center;
}
.solution-service__title {
  margin: 0 0 20px;
  font-size: 20px;
  font-weight: bold;
}
.solution-service__desc {
  margin: 0 0 20px;
  color: #3e4c59;
  font-size: 12px;
}
.solution-service__check {
  position: relative;
  margin: 0 0 10px;
  padding: 0 0 0 25px;
  font-weight: bold;
}
.solution-service__check::before {
  content: "";
  position: absolute;
  top: 5px;
  left: 0;
  width: 14px;
  height: 10px;
  background: url("../../images/ico_check.svg") no-repeat center center/100% 100%;
}
.solution-service__check:last-child {
  margin: 0;
}

.uniquness {
  box-sizing: border-box;
  width: 100%;
  min-width: 1300px;
  margin: 0 auto;
  position: relative;
  padding: 120px 0 0;
}
.uniquness::before, .uniquness::after {
  content: "";
  position: absolute;
  z-index: -1;
  top: -280px;
  width: 50%;
  height: 1600px;
  background: url(../../images/uniquness_bg.png) no-repeat center center/100% 100%;
}
.uniquness::before {
  left: 0;
}
.uniquness::after {
  right: 0;
  transform: rotate(180deg);
}
.uniquness__inner {
  box-sizing: border-box;
  width: 1100px;
  margin: 0 auto;
}
.uniquness__bg {
  position: absolute;
  z-index: -1;
  left: 50%;
  width: 500px;
  height: 500px;
  transform: translateX(-50%);
}
.uniquness__bg img {
  width: 100%;
}

.reason-list {
  display: flex;
  justify-content: space-between;
  margin: 0 auto 100px;
}
.reason-list__box {
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: calc((100% - 40px) / 2);
}
.reason-list__title {
  margin: 0 auto 30px;
  color: #ed7b77;
  font-family: "Montserrat", sans-serif;
  font-size: 24px;
  font-weight: bold;
  text-align: center;
  letter-spacing: 3px;
}
.reason-list__link {
  display: flex;
  align-items: center;
  width: 400px;
  height: 90px;
  margin: 0 auto 40px;
  border-radius: 2px;
  background: #ffffff;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.2);
  color: #3e4c59;
}
.reason-list__link:hover {
  transform: scale(1.05, 1.05);
  transition: 0.3s;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
}
.reason-list__num {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  margin: 0 20px;
  border-radius: 2px;
  background: #3e4c59;
  color: #ffffff;
  font-family: "Montserrat", sans-serif;
  font-size: 24px;
  font-weight: bold;
}
.reason-list__desc {
  color: #3e4c59;
  font-size: 18px;
  font-weight: bold;
}

.reason {
  box-sizing: border-box;
  width: 100%;
  min-width: 1300px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
  padding: 120px 0 200px;
}
.reason__inner {
  box-sizing: border-box;
  width: 1100px;
  margin: 0 auto;
}
.reason__box {
  display: flex;
  box-sizing: border-box;
  justify-content: space-between;
  margin: 0 0 100px;
}
.reason__textarea {
  width: calc((100% - 60px) / 2);
}
.reason__image {
  width: calc((100% - 60px) / 2);
}
.reason__image img {
  width: 100%;
  border-radius: 10px;
}
.reason__title {
  display: flex;
  align-items: center;
  margin: 0 0 30px;
}
.reason__catch {
  font-size: 22px;
  font-weight: bold;
}
.reason__num {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  margin: 0 20px 0 0;
  border-radius: 2px;
  background: #3e4c59;
  color: #ffffff;
  font-family: "Montserrat", sans-serif;
  font-size: 24px;
  font-weight: bold;
}
.reason__list {
  margin: 0 0 20px;
}
.reason__point {
  position: relative;
  margin: 0 0 10px;
  padding: 0 0 0 20px;
  font-size: 16px;
}
.reason__point::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 15px;
  height: 15px;
  transform: translateY(-50%);
  background: url("../../images/ico_check.svg") no-repeat center center/contain;
}
.reason__text {
  font-size: 14px;
  line-height: 2em;
}
.reason .button--base {
  margin: 75px auto 0;
}

/*# sourceMappingURL=style.css.map */
