body {
  margin: 0;
  padding: 0;
}
.hide {
  position: absolute;
  left: -9999px;
}
img {
  max-width: 100%;
  height: auto;
}
.inner-wrap-1300 {
  width: 100%;
  max-width: 1300px;
  margin: auto;
}
.inner-wrap-1200 {
  width: 100%;
  max-width: 1200px;
  margin: auto;
}
.inner-wrap-1000 {
  width: 100%;
  max-width: 1000px;
  margin: auto;
}
.fl-box {
  display: flex;
}
.base-tl {
  text-align: center;
  font-size: 36px;
  margin-bottom: 50px;
}
.blue {
  color: #0d63dc;
}
.button-box {
  text-align: center;
}
.button {
  width: 100%;
  max-width: 320px;
  margin: 70px auto 20px;
  display: block;
  color: #fff !important;
  text-decoration: none;
  font-weight: normal;
  font-size: 24px;
  background-color: #0d63dc;
  text-align: center;
  padding: 15px;
  border-radius: 10px;
}
.button:hover {
  opacity: 0.8;
}
.mail-button {
  background-image: url(/-/Media/Ricoh/Sites/co_jp/special/contract-workflow-service/img/icon_m_mail_02.png);
  background-repeat: no-repeat;
  background-position: 42px -5px;
}
.magazine-button {
  background-image: url(/-/Media/Ricoh/Sites/co_jp/special/contract-workflow-service/img/icon_m_information_02.png);
  background-repeat: no-repeat;
  background-position: 30px -6px;
}
.link {
  color: #000;
}
.icon_nwg {
  background: url(/-/Media/Ricoh/Sites/co_jp/img/icon_newwindow_g.png) no-repeat;
  background-position: 0 center;
  padding-left: 25px;
  color: #0d63dc !important;
  text-decoration: underline !important;
}
/*HEADER*/
header .fl-box {
  justify-content: space-between;
  align-items: center;
  padding: 20px 0;
}
header .logo {
  width: 140px;
}
header.fixed {
  width: 100%;
  position: fixed;
  top: 0;
  left: 0;
  background-color: #fff;
  z-index: 9;
}
.button-list {
  width: calc(100% - 140px);
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
.button-list .mail-button {
  color: #fff;
}
.button-list .magazine-button {
  color: #fff;
}
.button img {
  width: 30px;
  margin-right: 10px;
}
.mail-button {
  max-width: 280px;
  font-size: 20px;
  padding: 6px 8px 5px 30px;
  font-weight: bold;
  color: #fff !important;
  margin: 0 20px 0 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.magazine-button {
  max-width: 280px;
  font-size: 20px;
  font-weight: bold;
  padding: 6px 8px 5px 50px;
  margin: 0;
  color: #fff !important;
  display: flex;
  align-items: center;
  justify-content: center;
}
/*FV*/
.box-fv {
  background: url(/-/Media/Ricoh/Sites/co_jp/special/contract-workflow-service/img/bg_fv.png) no-repeat center / cover;
  padding: 130px 0;
}
.fv-text-box {
  width: 52%;
}
.fv-sub-tl {
  margin-bottom: 20px;
}
.fv-tl {
  color: #fff;
  font-size: 51px;
  font-weight: bold;
  margin-bottom: 20px;
  letter-spacing: 1px;
}
.fv-tl span {
  color: #fcff00;
}
.fv-text {
  color: #fff;
  font-size: 28px;
}
.fl-photo {
  width: 48%;
}
.fl-photo img {
  width: 100%;
}
/*LEAD*/
.box-lead {
  padding: 70px 0;
  text-align: center;
}
.box-lead .tl {
  font-size: 24px;
  line-height: 1.8;
}
/*COMPANY*/
.box-company {
  margin-bottom: 70px;
}
.box-company .list {
  display: flex;
  flex-wrap: wrap;
}
.box-company .list li {
  width: 19%;
  margin: 0 0.5%;
  text-align: center;
}
.box-company .text {
  text-align: right;
}
/*ABOUT*/
.box-about {
  margin-bottom: 100px;
}
.box-about .text {
  font-size: 24px;
  margin-bottom: 50px;
  text-align: center;
}
/*PROBLEM*/
.box-problem {
  margin-bottom: 70px;
}
.box-problem .photo {
  width: 40%;
}
.box-problem .text-box {
  width: 57%;
  margin-left: 3%;
}
.box-problem .tl {
  font-size: 36px;
  margin-bottom: 20px;
}
.box-problem .text {
  font-size: 18px;
  line-height: 1.8;
}
/*FEATURE*/
.box-feature {
  background: #f5f9fe;
  padding: 70px 0;
}
.box-feature .box {
  background-color: #fff;
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.2);
  justify-content: space-between;
}
.box-feature .box:nth-child(odd) {
  margin: 40px 0;
}
.box-feature .box:nth-child(odd) .photo {
  order: 2;
}
.box-feature .photo {
  width: 32%;
}
.box-feature .img-01 {
  background: url(/-/Media/Ricoh/Sites/co_jp/special/contract-workflow-service/img/pho_features_01.png) no-repeat center / cover;
}
.box-feature .img-02 {
  background: url(/-/Media/Ricoh/Sites/co_jp/special/contract-workflow-service/img/pho_features_02.png) no-repeat center / cover;
}
.box-feature .img-03 {
  background: url(/-/Media/Ricoh/Sites/co_jp/special/contract-workflow-service/img/pho_features_03.png) no-repeat center / cover;
}
.box-feature .text-box {
  width: 68%;
  padding: 40px 10px 40px 30px;
}
.box-feature .tl {
  font-size: 28px;
  margin-bottom: 20px;
}
.box-feature .list li {
  position: relative;
  font-size: 18px;
  margin-bottom: 10px;
  padding-left: 15px;
}
.box-feature .list li::before {
  content: "";
  width: 8px;
  height: 8px;
  background-color: #000;
  border-radius: 100%;
  position: absolute;
  top: 8px;
  left: 0;
}
.box-feature .list li span {
  font-weight: bold;
  font-size: 20px;
}
/*SUPPORT*/
.box-support {
  padding: 70px 0;
}
.support-list {
  justify-content: space-between;
}
.support-list-box {
  width: 23%;
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.2);
}
.support-list-box .tl {
  background-color: #0d63dc;
  color: #fff;
  text-align: center;
  padding: 10px 0;
  font-size: 24px;
}
.support-list-box .box {
  padding: 10px;
}
.support-list-box .ico {
  text-align: center;
  margin-bottom: 10px;
  height: 120px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.support-list-box .text {
  font-size: 20px;
  margin-bottom: 20px;
  padding: 0;
  height: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.support-list-box .list {
  background-color: #f5f9fe;
  padding: 15px;
  height: 205px;
}
.support-list-box .list li {
  position: relative;
  margin-bottom: 5px;
  font-size: 18px;
  padding-left: 10px;
}
.support-list-box .list li:last-child {
  margin-bottom: 0;
}
.support-list-box .list li::before {
  content: "";
  width: 5px;
  height: 5px;
  background-color: #000;
  border-radius: 100%;
  position: absolute;
  top: 10px;
  left: 0;
}
.support-other {
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.2);
  background-color: #fff;
  margin-top: 50px;
}
.support-other .tl {
  background-color: #6babfd;
  color: #fff;
  text-align: center;
  font-size: 24px;
  padding: 10px 0;
}
.support-other .text-box {
  padding: 40px 50px 20px 50px;
}
.support-other dl {
  font-size: 20px;
  display: flex;
  align-items: center;
  margin-bottom: 20px;
}
.support-other dt {
  width: 210px;
  text-align: center;
  background-color: #f5f9fe;
  padding: 20px;
  margin-right: 20px;
}
.support-other dd {
  margin: 0;
}
/*CUSTOMER*/
.box-customer {
  padding: 70px 0;
  background-color: #f5f9fe;
}
.customer-list {
  flex-wrap: wrap;
  justify-content: flex-start;
}
.customer-list-box {
  width: 32%;
  background-color: #fff;
  text-decoration: none;
  margin-right: 2%;
  margin-bottom: 40px;
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.2);
  position: relative;
}
.customer-list-box:nth-child(3n) {
  margin-right: 0;
}
.customer-list-box::before {
  content: "";
  position: absolute;

  right: 10px;
  bottom: 80px;
  margin: auto;
  width: 15px;
  height: 15px;
  border-top: 2px solid #747474;
  border-right: 2px solid #747474;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
.customer-list-box:hover .name {
  text-decoration: underline;
  color: #0d63dc;
}
.customer-list-box .photo img {
  width: 100%;
}
.customer-list-box .text-box {
  padding: 15px 30px 15px 15px;
}

.customer-list-box .name {
  text-align: center;
  font-size: 24px;
  font-weight: bold;
  margin-bottom: 20px;
}
.customer-list-box .text {
  font-size: 18px;
}
.customer-list-box.new ::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 46px;
  height: 46px;
  background-image: url(/-/Media/Ricoh/Sites/co_jp/cmn_jp_v1/img/icon-thumb_mn-new_r.png);
}
/*NEWS*/
.box-news {
  padding: 20px 0 70px;
}
.box-news .list li {
  border-bottom: 1px solid #cacaca;
  padding: 10px 0 10px 60px;
  position: relative;
  font-size: 18px;
  display: flex;
  align-items: center;
}
.box-news .list a {
  text-decoration: none;
  color: #000;
  font-size: 18px;
}
.box-news .list .date {
  margin-right: 20px;
  width: 140px;
}
.box-news .list .text {
  display: inline-block;
  width: calc(100% - 156px);
}
.box-news .list .new {
  font-size: 14px;
  height: 29px;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
  background-color: #0c63dc;
  color: #fff;
  padding: 5px;
  margin-right: 10px;
  display: inline-block;
}
/*CONTACT*/
.box-contact .box {
  background-color: #e8effb;
  border: 2px solid #c1def5;
  padding: 40px;
  margin-bottom: 50px;
}
.box-contact .base-tl {
  margin-bottom: 30px;
}
.box-contact .text {
  text-align: center;
}
.box-contact .button {
  margin: 30px auto 0;
  color: #fff;
}
.box-contact .contact-btn {
  display: flex;
  align-items: center;
  justify-content: center;
}
.page-top {
  margin-bottom: 50px;
}
.banner {
  position: fixed;
  bottom: 20px;
  right: 10px;
  max-width: 180px;
  width: 10vw;
  opacity: 0;
  visibility: hidden;
  transition: 300ms;
}
.banner .close-btn {
  position: absolute;
  top: -10px;
  right: -5px;
}
.banner.fixed {
  opacity: 1;
  visibility: visible;
}
.pc-none {
  display: none;
}
.sp-none {
  display: block;
}
.hidden {
  display: none !important;
}
.cp-PageTop {
  display: none !important;
}
@media screen and (max-width: 1300px) {
  .inner-wrap-1300 {
    width: 100%;
    padding: 0 3%;
  }
}
@media screen and (max-width: 1200px) {
  .inner-wrap-1200 {
    width: 100%;
    padding: 0 3%;
  }
  .support-list-box .text br {
    display: none;
  }
  .support-list-box .list li {
    font-size: 14px;
  }
  .support-list-box .list li::before {
    top: 6px;
  }
}
@media screen and (max-width: 1000px) {
  .inner-wrap-1000 {
    width: 100%;
    padding: 0 3%;
  }
}
@media screen and (max-width: 768px) {
  .base-tl {
    font-size: 28px;
    margin-bottom: 30px;
  }
  .button {
    margin-top: 50px;
  }
  header .button img {
    width: 20px;
  }
  .box-lead .tl {
    font-size: 20px;
  }
  header .logo {
    margin-bottom: 10px;
  }
  header .fl-box {
    flex-wrap: wrap;
    padding: 10px 3%;
  }
  .button-list {
    width: 100%;
    justify-content: center;
  }
  .mail-button {
    font-size: 14px;
    padding: 10px 0 10px 30px;
    margin: 0 10px 0 0;
    height: 41px;
    background-position: 0px -2px;
  }
  .magazine-button {
    font-size: clamp(10px, 3.5vw, 14px);
    height: 41px;
    padding: 10px 0 10px 30px;
    margin: 0;
    background-position: 0px -3px;
  }
  .box-fv {
    padding: 50px 0;
  }
  .box-fv .fl-box {
    flex-wrap: wrap;
  }
  .fv-sub-tl {
    text-align: center;
  }
  .fv-tl {
    font-size: 34px;
  }
  .fv-text {
    font-size: 20px;
  }
  .fv-text-box {
    width: 100%;
    margin-bottom: 30px;
  }
  .fl-photo {
    width: 100%;
  }
  .box-lead {
    padding: 50px 0;
  }
  .box-company .list li {
    width: 23%;
    margin: 0 5%;
  }
  .box-company .text {
    font-size: 14px;
  }
  .box-problem .fl-box {
    flex-wrap: wrap;
  }
  .box-problem .photo {
    width: 100%;
    margin-bottom: 20px;
  }
  .box-problem .tl {
    font-size: 24px;
  }
  .box-problem .tl br {
    display: none;
  }
  .box-problem .text-box {
    width: 100%;
    margin: 0;
  }
  .box-about {
    margin-bottom: 70px;
  }
  .box-about .text {
    font-size: 20px;
  }
  .box-feature .box {
    flex-wrap: wrap;
  }
  .box-feature .photo {
    width: 100%;
    height: 200px;
  }
  .box-feature .text-box {
    width: 100%;
    padding: 20px;
  }
  .box-feature .box:nth-child(odd) .photo {
    order: 1;
  }
  .box-feature .box:nth-child(odd) .text-box {
    order: 2;
  }
  .box-support {
    padding: 50px 0;
  }
  .support-list {
    flex-wrap: wrap;
  }
  .support-list-box {
    width: 100%;
    margin-bottom: 30px;
  }
  .support-list-box .text {
    height: auto;
  }
  .support-list-box .list {
    height: auto;
  }
  .support-other {
    margin-top: 30px;
  }
  .support-other .text-box {
    padding: 20px;
  }
  .support-other dl {
    flex-wrap: wrap;
    font-size: 16px;
  }
  .support-other dt {
    width: 100%;
    margin: 0 0 10px;
    padding: 10px;
  }

  .box-customer {
    padding: 50px 0;
  }
  .customer-list-box {
    width: 100%;
    margin-bottom: 30px;
    margin-right: 0;
  }
  .customer-list-box:last-child {
    margin-bottom: 0;
  }
  .box-news {
    padding: 50px 0;
  }
  .box-contact .box {
    padding: 20px;
    margin-bottom: 30px;
  }
  .box-contact .base-tl {
    margin-bottom: 20px;
  }
  .box-contact .button {
    font-size: clamp(16px, 3.5vw, 18px);
    background-position: 30px;
  }
  .banner {
    width: auto;
    max-width: 320px;
    right: 0;
    bottom: 0;
    margin: 10px;
  }
  .pc-none {
    display: block;
  }
  .sp-none {
    display: none;
  }
  .box-news .list li {
    display: block;
  }
  .box-news .list .text {
    width: 100%;
  }
}
