@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@500;700;900&display=swap");
@import url(/common/css/reset.css);
@import url(/common/css/style.v3.css?20220510);
@import url(/common/css/header.v2.css?20230718);
@import url(/bs/lp/common/css/layout.css);
@import url(/common/css/footer.css?20221031);
@import url(/common/css/layout.v2.css?20221219);
@import url(/common/css/smph/layout.v2.css?20220106);
.font-size-40 {
  font-size: clamp(26px, 4vw, 40px);
}

.font-size-32 {
  font-size: clamp(24px, 3.2vw, 32px);
}

.font-size-30 {
  font-size: clamp(24px, 3vw, 30px);
}

.font-size-26 {
  font-size: clamp(22px, 2.6vw, 26px);
}

.font-size-22 {
  font-size: clamp(21px, 2.6vw, 22px);
}

.font-size-24 {
  font-size: clamp(20px, 2.4vw, 24px);
}

.font-size-20 {
  font-size: clamp(18px, 2vw, 20px);
}

.font-size-18 {
  font-size: clamp(16px, 1.8vw, 18px);
}

.font-size-16 {
  font-size: clamp(14px, 1.6vw, 16px);
}

.font-size-15 {
  font-size: clamp(14px, 1.5vw, 15px);
}

.font-size-12 {
  font-size: 12px;
}

body {
  overflow-x: hidden;
}

#sub {
  display: none;
}

#main {
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  padding: 0 10px;
  font-size: 16px;
}
#main p {
  line-height: 1.75;
}
#main figure img {
  max-width: 100%;
  height: auto;
}
#main img, #main svg {
  max-width: 100%;
  height: auto;
}

a {
  transition: 0.3s;
  word-wrap: break-word;
}

cite {
  font-size: 0.8125rem;
}

* {
  box-sizing: border-box;
  word-break: break-word;
}

#main {
  padding-right: 0 !important;
  padding-left: 0 !important;
}
@media screen and (max-width: 1024px) {
  #main {
    max-width: 1024px;
    margin-right: 0 !important;
    margin-left: 0 !important;
  }
}

.mt10 {
  margin-top: 10px;
}

.mt20 {
  margin-top: 20px;
}

.mt30 {
  margin-top: clamp(20px, 3.0303030303vw, 30px);
}

.mt40 {
  margin-top: clamp(20px, 4.0404040404vw, 40px);
}

.mt50 {
  margin-top: clamp(25px, 5.0505050505vw, 50px);
}

.mt60 {
  margin-top: clamp(30px, 6.0606060606vw, 60px);
}

.mt80 {
  margin-top: clamp(40px, 8.0808080808vw, 80px);
}

.mb20 {
  margin-bottom: 20px;
}

.mb40 {
  margin-bottom: clamp(20px, 4.0404040404vw, 40px);
}

.ml10 {
  margin-left: 10px;
}

.pt60 {
  padding-top: clamp(30px, 6.0606060606vw, 60px);
}

.pb60 {
  padding-bottom: clamp(60px, 6.0606060606vw, 60px);
}

.pl10 {
  padding-left: 10px;
}

.pl20 {
  padding-left: 20px;
}

.pt40 {
  padding-top: clamp(20px, 4.0404040404vw, 40px);
}

.pt110 {
  padding-top: clamp(80px, 11.1111111111vw, 110px);
}

.pb10 {
  padding-bottom: 10px;
}

.pb50 {
  padding-bottom: clamp(40px, 5.0505050505vw, 50px);
}

.pb110 {
  padding-bottom: clamp(80px, 11.1111111111vw, 110px);
}

.font-size-14 {
  font-size: 14px;
}

.font-size-16 {
  font-size: 16px;
}

.font-size-18 {
  font-size: clamp(17px, 1.8181818182vw, 18px);
}

.font-size-20 {
  font-size: clamp(18px, 2.0202020202vw, 20px);
}

.font-size-24 {
  font-size: clamp(21px, 2.4242424242vw, 24px);
}

.font-size-30 {
  font-size: clamp(26px, 3.0303030303vw, 30px);
}

.text-white {
  color: #ffffff;
}

#main p.lineHeight-2 {
  line-height: 2;
}

.width-200px {
  width: 200px;
}

.margin-auto {
  margin-left: auto;
  margin-right: auto;
}

@media screen and (max-width: 1023px) {
  .sp_p10 {
    padding-left: 10px;
  }
}
.lineHeight-16 {
  line-height: 1.6;
}

.vertical-align-middle {
  vertical-align: middle;
}

#contents ol.note.mb0, #contents ul.note.mb0 {
  margin-bottom: 0;
}

ol.note-counter {
  counter-reset: listnum;
}

ol.note-counter li::before {
  counter-increment: listnum;
  content: "※" counter(listnum);
  margin-right: 0.5em;
}

.gap-12 {
  gap: 12px;
}

.col4 {
  width: calc((100% - 24px) / 3);
}
@media screen and (max-width: 1023px) {
  .col4 {
    width: calc(50% - 6px);
  }
}
@media screen and (max-width: 767px) {
  .col4 {
    width: 100%;
  }
}

@media screen and (max-width: 1010px) {
  .sp_pr20 {
    padding-right: 20px;
  }
}

@media screen and (max-width: 1010px) {
  .sp_pl20 {
    padding-left: 20px;
  }
}

.justify-content-center {
  justify-content: center;
}

.main-visual .background {
  width: 100%;
  height: 65.7142857143vw;
  min-height: 820px;
  max-height: 920px;
  background-position: center top;
  background-repeat: no-repeat;
  background-attachment: fixed;
  background-size: cover;
  background-image: url(/bs/lp/white/common/images/bg-pc-white-operations.webp);
  padding: 173px 20px;
}
@media screen and (max-width: 767px) {
  .main-visual .background {
    background-image: url(/bs/lp/white/common/images/bg-sp-white-operations.webp);
    height: 183.0769230769vw;
    min-height: auto;
    padding: 25.641025641vw 20px 12.8205128205vw;
  }
}
.main-visual .main-visual-title {
  margin-right: auto;
  margin-left: auto;
  max-width: 1200px;
}
.main-visual h1 {
  font-size: min(8.2051282051vw, 48px);
  font-weight: 800;
  text-shadow: rgba(0, 0, 0, 0.1882352941) 0 0 0.25em;
}
.main-visual h2 {
  font-size: min(3.8461538462vw, 20px);
  margin-top: min(11.0256410256vw, 50px);
  line-height: 2 !important;
  font-weight: 800;
  text-shadow: rgba(0, 0, 0, 0.1882352941) 0 0 0.25em;
}
.main-visual .main-visual-massage {
  margin-right: auto;
  margin-left: auto;
  max-width: 1200px;
}
.main-visual .main-visual-massage p {
  max-width: 420px;
  margin-top: 30px;
  margin-left: auto;
  font-weight: 800;
  text-shadow: rgba(0, 0, 0, 0.1882352941) 0 0 0.25em;
  line-height: 2 !important;
}
@media screen and (max-width: 767px) {
  .main-visual .main-visual-massage p {
    margin-top: min(21.2820512821vw, 50px);
    margin-left: 0;
    font-size: min(3.8461538462vw, 15px);
  }
}
.main-visual .main-visual-massage p + .main-visual-massage p {
  margin-top: 60px;
}

.headline-2 {
  font-size: clamp(26px, 2.6666666667vw, 32px);
  font-weight: 700;
  color: #35579D;
}

section.white-operations-content {
  padding: clamp(60px, 15.3846153846vw, 110px) 20px;
}

section.white-operations-content:has(.about-white-operations) {
  background-color: #f5f5f5;
}

.about-white-operations {
  margin-right: auto;
  margin-left: auto;
  max-width: 990px;
}

.white-operations-solution {
  margin-right: auto;
  margin-left: auto;
  max-width: 990px;
}

.table-wrap {
  width: 100%;
  margin: 20px calc(50% - 600px);
}
@media screen and (max-width: 1230px) {
  .table-wrap {
    width: calc(100% - 30px);
    margin: 0 15px 40px;
  }
}
@media screen and (min-width: 0) and (max-width: 768px) {
  .table-wrap {
    width: auto;
    overflow: auto;
    white-space: nowrap;
    margin-left: 10px;
    padding-bottom: 10px;
  }
}

.color-table {
  width: 100%;
  border-top: 2px solid #f5f5f5;
  border-left: 2px solid #f5f5f5;
}
.color-table th, .color-table td {
  border-right: 2px solid #f5f5f5;
  border-bottom: 2px solid #f5f5f5;
  padding: 0.85em;
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .color-table th, .color-table td {
    padding: 0.5em;
  }
}
@media screen and (max-width: 767px) {
  .color-table th, .color-table td {
    padding: 0.5em;
  }
}
.color-table thead th {
  background: #4A5A5F;
  color: #fff;
  text-align: center;
  font-weight: bold;
}
.color-table tbody th {
  background: #DFE2E5;
  color: #212121;
  font-weight: bold;
  text-align: left;
}
.color-table tbody td {
  vertical-align: middle;
  background: #ffffff;
}
.color-table tbody td p:nth-last-of-type(1) {
  margin-bottom: 0 !important;
}
.color-table thead th:first-child {
  text-align: left;
}
.color-table tbody th {
  font-weight: normal;
}
.color-table tbody td {
  text-align: center;
}
@media screen and (min-width: 0) and (max-width: 768px) {
  .color-table thead th,
  .color-table tbody td {
    text-align: left;
  }
}

.to-product {
  background-color: #F2F8FC;
  padding: clamp(60px, 15.3846153846vw, 80px) 20px clamp(60px, 15.3846153846vw, 88px);
}

.to-product-info-list {
  margin-right: auto;
  margin-left: auto;
  max-width: 862px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: min(3vw, 80px);
}
@media screen and (min-width: 0) and (max-width: 768px) {
  .to-product-info-list {
    grid-template-columns: 1fr;
    gap: 12vw;
  }
}

.to-product-info {
  text-align: center;
}

*[class^=links-] a {
  display: block;
  padding: 0.8em 1.5em;
  letter-spacing: 0.15em;
  background: linear-gradient(70deg, #0b61b7, #00b9ff);
  background-size: 100% 100%;
  background-position: 0 0;
  font-weight: 700;
  color: #ffffff;
  font-size: 0.9375rem;
  border-radius: 100px;
  box-sizing: border-box;
  text-decoration: none;
  text-align: center;
  margin: 10px 0;
  text-shadow: 0 0 2px #0b61b7;
}
*[class^=links-] a:hover {
  background: #fff;
  color: #0b61b7;
  outline: 3px solid #0b61b7;
  outline-offset: -3px;
  text-shadow: none;
}

.white-operations-news {
  margin-right: auto;
  margin-left: auto;
  max-width: 990px;
}
@media screen and (max-width: 767px) {
  .white-operations-news {
    padding: 0 20px;
  }
}