@charset "UTF-8";
/* ------------------------------------------------
  kv
------------------------------------------------ */
#kv {
  height: 100%;
}
#kv > .inner {
  width: 100%;
  height: 100%;
}
#kv .title {
  margin-top: 5.9285714286em;
  width: 100%;
  height: calc(100% - 5.9285714286em);
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
#kv .title picture {
  height: 100%;
}
#kv .title img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
@media screen and (max-width: 767.9px) {
  #kv > .inner {
    padding-left: 0;
    padding-right: 0;
    color: rgba(184, 203, 201, 0.1);
    color: rgba(191, 225, 243, 0.1);
  }
  #kv .title {
    margin-top: 6.9230769231em;
    height: calc(100% - 6.9230769231em);
  }
}

#kv__ > .inner {
  width: 100%;
}
#kv__ .title {
  background: url(../images/top/kv_bg.jpg) 50% 50% no-repeat;
  background: url(../images/top/kv.jpg) 50% 50% no-repeat;
  background-size: 111.4285714286em auto;
  margin-top: 5.9285714286em;
  width: 100%;
  height: max(100vh - 5.9285714286em, 50em);
  overflow: hidden;
  position: relative;
}
#kv__ .title .txt {
  display: none;
  width: 71.8571428571em;
  position: absolute;
  left: calc(50% - 36.2857142857em);
  top: calc(50% - 10.7142857143em);
}
@media screen and (min-width: 1920.1px) {
  #kv__ .title {
    font-size: 0.7291666667vw;
    height: max(100vh - 5.9285714286em, 36.4583333333vw);
  }
}
@media screen and (max-width: 767.9px) {
  #kv__ {
    height: 100%;
  }
  #kv__ > .inner {
    padding-left: 0;
    padding-right: 0;
    height: 100%;
  }
  #kv__ .title {
    background-image: url(../images/top/kv_bg-sp.jpg);
    background-image: url(../images/top/kv-sp.png);
    background-size: contain;
    margin-top: 6.9230769231em;
    height: calc(100% - 6.9230769231em);
  }
  #kv__ .title .txt {
    text-align: center;
    width: 100%;
    height: 13.4210526316%;
    height: min(5.8846153846em, 13.4210526316%);
    left: 2%;
    top: 44.2%;
  }
  #kv__ .title .txt img {
    margin: 0 auto;
    width: auto;
    height: 100%;
  }
}

/* ------------------------------------------------
 about
------------------------------------------------ */
#about .sbody {
  margin-top: 3.2142857143em;
  height: 86.5714285714em;
  position: relative;
}
#about .cast {
  position: absolute;
}
#about .cast[class^=img_] {
  width: 19.5em;
}
#about .cast.img_1 {
  left: 4.7142857143em;
}
#about .cast.img_2 {
  left: 47em;
  top: 34em;
}
#about .cast.img_3 {
  left: 5em;
  top: 66.7142857143em;
}
#about .cast[class^=maru_] {
  width: 3.7857142857em;
}
#about .cast.maru_1 {
  left: 26.9285714286em;
  top: 17.8571428571em;
}
#about .cast.maru_2 {
  left: 36em;
  top: 21.8571428571em;
}
#about .cast.maru_3 {
  left: 45.3571428571em;
  top: 28.5714285714em;
}
#about .cast.maru_4 {
  left: 44.7857142857em;
  top: 55em;
}
#about .cast.maru_5 {
  left: 37.1428571429em;
  top: 61.7142857143em;
}
#about .cast.maru_6 {
  left: 27.5714285714em;
  top: 65.1428571429em;
}
#about .cast[class^=txt_] {
  font-size: 1.2142857143em;
  line-height: 2.2;
}
#about .cast.txt_1 {
  top: 3.6470588235em;
  left: 23.0588235294em;
}
#about .cast.txt_2 {
  text-align: right;
  top: 30.7058823529em;
  right: 22.4705882353em;
}
#about .cast.txt_3 {
  top: 58.8235294118em;
  left: 23.0588235294em;
}
@media screen and (max-width: 767.9px) {
  #about {
    margin-top: 3.8461538462em;
  }
  #about .sbody {
    margin-top: 2.6923076923em;
    height: 70em;
  }
  #about .cast[class^=img_] {
    width: 8.1538461538em;
  }
  #about .cast.img_1 {
    left: 0;
    top: 1.1538461538em;
  }
  #about .cast.img_2 {
    left: 17.6923076923em;
    left: 18.0769230769em;
    top: 30.9230769231em;
  }
  #about .cast.img_3 {
    left: 0;
    top: 59.6153846154em;
  }
  #about .cast[class^=maru_] {
    width: 1.6153846154em;
  }
  #about .cast.maru_1 {
    left: 10.3846153846em;
    top: 12.7692307692em;
  }
  #about .cast.maru_2 {
    left: 14.9230769231em;
    top: 18.9230769231em;
  }
  #about .cast.maru_3 {
    left: 18.4615384615em;
    top: 25.3846153846em;
  }
  #about .cast.maru_4 {
    left: 18.4615384615em;
    top: 42.4615384615em;
  }
  #about .cast.maru_5 {
    left: 14.9230769231em;
    top: 48em;
  }
  #about .cast.maru_6 {
    left: 10.3846153846em;
    top: 53.0769230769em;
  }
  #about .cast[class^=txt_] {
    font-size: 1.0769230769em;
  }
  #about .cast.txt_1 {
    top: -0.5714285714em;
    left: 8.2857142857em;
  }
  #about .cast.txt_2 {
    text-align: left;
    margin-left: -1em;
    top: 26em;
    right: 8.4285714286em;
    right: 7.8571428571em;
  }
  #about .cast.txt_3 {
    top: 52.2857142857em;
    left: 8.8571428571em;
  }
}

/* ------------------------------------------------
 solution
------------------------------------------------ */
#solutions {
  background: url(../images/top/solution_bg.jpg) 50% 0 no-repeat;
  background-size: 182.8571428571em auto;
  margin-top: 6.4285714286em;
  padding-top: 4em;
  padding-bottom: 8.9285714286em;
}
#solutions > .inner {
  position: relative;
  z-index: 1;
}
#solutions .sheader {
  padding-top: 3.5714285714em;
}
#solutions .sbody {
  background-color: #fff;
  border-radius: 1.1428571429em;
  margin: 2.2857142857em auto 0;
  padding: 3.2142857143em 3.5714285714em 3.3571428571em 3.2142857143em;
  width: 65.7142857143em;
  position: relative;
}
#solutions .sbody .category .txt {
  color: #fff;
  font-size: 1.5em;
  font-family: var(--ff-fw-normal);
  font-weight: bold;
  line-height: 1;
  border-radius: 1em;
  background-color: #535353;
  padding: 0.3333333333em 0.7619047619em;
  display: inline-block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
#solutions .sbody .category.cate_1 .txt {
  background-color: #64abc5;
}
#solutions .sbody .category.cate_2 .txt {
  background-color: #eec467;
}
#solutions .sbody .category.cate_3 .txt {
  background-color: #ff9eae;
}
#solutions .sbody .category.cate_4 .txt {
  background-color: #a4c180;
}
#solutions .sbody .category.cate_5 .txt {
  background-color: #64abc5;
}
#solutions .sbody > .category {
  width: 19em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  position: absolute;
  left: 3.2142857143em;
  top: 0;
}
#solutions .sbody > .category::after {
  content: "";
  background-repeat: no-repeat;
  background-size: contain;
  display: block;
}
#solutions .sbody > .category.cate_1 {
  top: 4.7142857143em;
}
#solutions .sbody > .category.cate_1::after {
  background-image: url(../images/top/solution_border_bl.png);
  width: 6.8571428571em;
  height: 14.4285714286em;
}
#solutions .sbody > .category.cate_1 .txt {
  margin-top: 0.4761904762em;
}
#solutions .sbody > .category.cate_2 {
  top: 18.8571428571em;
}
#solutions .sbody > .category.cate_2::after {
  background-image: url(../images/top/solution_border_org.png);
  width: 7em;
  height: 21.9285714286em;
}
#solutions .sbody > .category.cate_3 {
  top: 40.5714285714em;
}
#solutions .sbody > .category.cate_3::after {
  background-image: url(../images/top/solution_border_pk.png);
  width: 4.5em;
  height: 14.4285714286em;
}
#solutions .sbody > .category.cate_4 {
  top: 61.4285714286em;
}
#solutions .sbody > .category.cate_4::after {
  background-image: url(../images/top/solution_border_gr.png);
  width: 7.3571428571em;
  height: 14.4285714286em;
}
#solutions .sbody > .category.cate_5 {
  position: static;
}
#solutions .sbody > .category.cate_5::after {
  content: none;
}
#solutions .sbody .solution {
  border-top: 0.0714285714em solid rgba(77, 77, 77, 0.5);
  margin-left: auto;
  padding: 1.7142857143em 0 1.7142857143em;
  width: 38.8571428571em;
}
#solutions .sbody .solution:first-of-type {
  padding-top: 0;
  border-top-width: 0;
}
#solutions .sbody .solution .name {
  font-size: 1.3571428571em;
  font-family: var(--ff-fw-normal);
  font-weight: bold;
  line-height: 1;
}
#solutions .sbody .solution .summary {
  font-size: 1em;
  margin-top: 0.7142857143em;
  padding-left: 1em;
}
@media screen and (max-width: 767.9px) {
  #solutions {
    background-image: url(../images/top/solution_bg-sp.jpg);
    background-size: 100% 100%;
    margin-top: 4.6153846154em;
    padding-top: 0;
    padding-bottom: 2.7307692308em;
  }
  #solutions .sheader {
    padding-top: 2.1538461538em;
  }
  #solutions .sbody {
    border-radius: 1.2307692308em;
    margin-top: 1.9230769231em;
    padding: 1.8461538462em 1.5384615385em;
    width: auto;
  }
  #solutions .sbody .category {
    width: auto;
  }
  #solutions .sbody .category .txt {
    font-size: 1.1538461538em;
    border-radius: 1em;
    padding: 0.2666666667em 0.7333333333em;
  }
  #solutions .sbody .category.cate_1_2 .txt {
    background-image: -webkit-gradient(linear, left top, right top, from(rgb(110, 168, 189)), to(rgb(238, 196, 103)));
    background-image: linear-gradient(90deg, rgb(110, 168, 189) 0%, rgb(238, 196, 103) 100%);
  }
  #solutions .sbody .category.cate_2_3 .txt {
    background: -webkit-gradient(linear, left top, right top, from(rgb(238, 196, 103)), to(rgb(255, 158, 174)));
    background: linear-gradient(90deg, rgb(238, 196, 103) 0%, rgb(255, 158, 174) 100%);
  }
  #solutions .sbody .category.cate_5 {
    border-top: 0.0769230769em solid rgba(77, 77, 77, 0.5);
    padding-top: 1.2307692308em;
  }
  #solutions .sbody > .category:not(.cate_5) {
    display: none;
  }
  #solutions .sbody .solution {
    border-top-width: 0.0769230769em;
    padding: 1.2307692308em 0 1.1538461538em;
    width: auto;
  }
  #solutions .sbody .solution .name {
    font-size: 1.0769230769em;
    margin-top: 0.8571428571em;
  }
  #solutions .sbody .solution .summary {
    font-size: 1em;
    margin-top: 0.4615384615em;
  }
}

/* ------------------------------------------------
 NEWS
------------------------------------------------ */
#news {
  margin-top: 1.8571428571em;
}
#news .sbody {
  margin-top: 3.5714285714em;
}
#news .list {
  margin: 0 auto;
  width: 52.1428571429em;
}
#news .list li {
  font-size: 0.9em;
  line-height: 1.4;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 10.9523809524em 8.7301587302em auto;
  grid-template-columns: 10.9523809524em 8.7301587302em auto;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
  -ms-flex-line-pack: center;
      align-content: center;
}
#news .list li + li {
  margin-top: 3.1746031746em;
}
#news .list li a {
  text-decoration: none;
}
@media screen and (min-width: 768.1px) {
  #news .list li a {
    -webkit-transition: opacity 0.4s ease-in-out;
    transition: opacity 0.4s ease-in-out;
  }
  #news .list li a:hover {
    opacity: 0.5;
  }
}
#news .list li .date {
  color: #64abc5;
  font-family: var(--ff-fw-normal);
  font-weight: bold;
  -ms-grid-column-align: center;
      justify-self: center;
  margin-top: 0.1587301587em;
}
#news .list li .title {
  color: #585858;
  margin-top: 0.0793650794em;
  -ms-flex-item-align: start;
      -ms-grid-row-align: start;
      align-self: start;
}
#news .list li .label {
  font-family: var(--ff-fw-normal);
  font-weight: bold;
  text-align: center;
  line-height: 1;
  border-width: 0.0793650794em;
  border-style: solid;
  padding: 0.0793650794em 0;
  padding-top: 0.3174603175em;
  padding-bottom: 0.2380952381em;
  position: relative;
}
#news .list li .label.en {
  letter-spacing: -0.02em;
}
#news .list li .label::before {
  content: "";
  background-color: #ccc;
  height: 1.746031746em;
  width: 1.746031746em;
  -webkit-clip-path: polygon(0 0, 100% 0%, 0 100%);
          clip-path: polygon(0 0, 100% 0%, 0 100%);
  display: block;
  position: absolute;
  left: -0.0793650794em;
  top: -0.0793650794em;
}
#news .list li .label.pink {
  color: #ff9eae;
}
#news .list li .label.pink::before {
  background-color: #ff9eae;
}
#news .list li .label.orange {
  color: #eeab67;
}
#news .list li .label.orange::before {
  background-color: #eeab67;
}
#news .list li .label.green {
  color: #a4c180;
}
#news .list li .label.green::before {
  background-color: #a4c180;
}
@media screen and (max-width: 767.9px) {
  #news {
    margin-top: 2.4615384615em;
  }
  #news .sbody {
    margin: 1.7692307692em -0.3846153846em 0;
  }
  #news .list {
    width: auto;
  }
  #news .list li {
    font-size: 1em;
    -ms-grid-columns: 10.2307692308em 1.1538461538em auto;
    grid-template-columns: 10.2307692308em auto;
    grid-gap: 0.3846153846em 1.1538461538em;
  }
  #news .list li + li {
    margin-top: 2.6923076923em;
  }
  #news .list li .date {
    font-size: 0.8461538462em;
    margin-top: 0;
    -ms-grid-column-align: start;
        justify-self: start;
    -ms-flex-item-align: center;
        -ms-grid-row-align: center;
        align-self: center;
  }
  #news .list li .title {
    line-height: 1.75;
    margin-top: 0;
    grid-column-start: span 2;
  }
}

/* ------------------------------------------------
 article
------------------------------------------------ */
#article {
  margin-top: 1.8571428571em;
}
#article .sbody {
  margin-top: 3.5714285714em;
}
#article .list {
  display: -ms-grid;
  display: grid;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -ms-grid-columns: 18.4285714286em 2.5714285714em 18.4285714286em 2.5714285714em 18.4285714286em;
  grid-template-columns: repeat(3, 18.4285714286em);
  grid-auto-rows: 16.7142857143em;
  grid-gap: 2.2857142857em 2.5714285714em;
}
#article .list li {
  background: url(../images/article/item_bg.jpg) no-repeat;
  background-size: contain;
}
#article .list li a {
  margin: 3.8759689922% auto 0;
  width: 89.1472868217%;
  display: block;
}
@media screen and (min-width: 768.1px) {
  #article .list li a {
    -webkit-transition: opacity 0.4s ease-in-out;
    transition: opacity 0.4s ease-in-out;
  }
  #article .list li a:hover {
    opacity: 0.5;
  }
}
@media screen and (max-width: 767.9px) {
  #article {
    margin-top: 3.2307692308em;
  }
  #article .sbody {
    margin-top: 2.3076923077em;
  }
  #article .list {
    -ms-grid-columns: 22.4615384615em;
    grid-template-columns: 22.4615384615em;
    grid-auto-rows: 20.3076923077em;
    grid-gap: 2.6923076923em;
  }
}

/* ------------------------------------------------
 CONTACT​
------------------------------------------------ */
#contact {
  background: url(../images/top/contact_bg.jpg) 50% 1px no-repeat;
  background-size: auto 100%;
  background-size: cover;
  margin-top: 6.4285714286em;
  padding-top: 14.1428571429em;
  min-height: 34.2857142857em;
}
#contact > .inner {
  text-align: center;
  border-radius: 0.7142857143em;
  background-color: rgba(255, 255, 255, 0.7);
  padding-top: 2.1428571429em;
  padding-bottom: 2em;
  width: 57.1428571429em;
  position: relative;
}
#contact .sheader .title {
  color: #64abc5;
  font-size: 2.1428571429em;
  text-align: center;
  padding-left: 0;
}
#contact .sbody {
  color: #64abc5;
  font-family: var(--ff-fw-normal);
  font-weight: bold;
  margin-top: 2em;
}
#contact .sbody p {
  font-size: 1.2142857143em;
}
#contact .sbody p + p {
  margin-top: 0.5882352941em;
}
@media screen and (max-width: 767.9px) {
  #contact {
    background-image: url(../images/top/contact_bg-sp.jpg);
    margin-top: 5.5384615385em;
    margin-bottom: 1.3846153846em;
    padding-top: 14.9230769231em;
    min-height: 43.4615384615em;
  }
  #contact > .inner {
    border-radius: 0.3846153846em;
    background-color: rgba(255, 255, 255, 0.8);
    padding: 2.1538461538em 0 1.5384615385em;
    width: 20.7692307692em;
  }
  #contact .sheader .title {
    font-size: 1.3846153846em;
  }
  #contact .sbody {
    margin-top: 0.9230769231em;
  }
  #contact .sbody p {
    font-size: 0.9230769231em;
    line-height: 1.8;
  }
  #contact .sbody p + p {
    margin-top: 0.5em;
  }
  #contact .list {
    -ms-grid-columns: 22.4615384615em;
    grid-template-columns: 22.4615384615em;
    grid-auto-rows: 20.3076923077em;
    grid-gap: 2.6923076923em;
  }
}