@charset "UTF-8";
/* --------------------------------
  ud-mv
--------------------------------*/
.ud-mv {
  position: relative;
}
.ud-mv::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(#3492ff80, #e7e9ff66 50%, #ffffff);
  mix-blend-mode: multiply;
  z-index: 1;
}
.ud-mv.ttl-blue::after {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  height: 100%;
  transform: translateX(-50%);
  background-color: rgba(0, 60, 120, 0.8);
  mix-blend-mode: multiply;
  z-index: -1;
  max-width: 480px;
  width: 100%;
}
.ud-mv__inr {
  padding-left: 64px;
  padding-right: 64px;
}
.ud-mv__txt.center {
  width: max-content;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.ud-mv__txt.white .sec-ttl,
.ud-mv__txt.white .sec-subttl {
  color: var(--c-white);
}
.ud-mv__bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: -1;
}
.ud-ttl {
  font-size: var(--fs-40);
  font-weight: var(--fw-thin);
  letter-spacing: 0.16em;
  line-height: 1;
  color: var(--c-white);
  margin: 10px;
}
.ud-subttl {
  font-size: var(--fs-21);
  font-family: var(--font-comfortaa);
  letter-spacing: 0.3em;
  color: var(--c-white);
}
.ud-ttl.narrow {
  letter-spacing: 0.075em;
}

@media screen and (max-width: 1500px) {
  .ud-mv__inr {
    padding-left: 5%;
    padding-right: 5%;
  }
}
@media screen and (max-width: 960px) {
  .ud-ttl {
    font-size: clamp(28px, 7vw, 35px);
  }
  .ud-subttl {
    font-size: clamp(18px, 4vw, 21px);
  }
  .ud-mv.ttl-blue::after {
    max-width: clamp(240px, 50vw, 480px);
  }
}

@media screen and (max-width: 600px) {
  .ud-mv {
    padding-top: 120px;
    padding-bottom: 40px;
  }
}
/* --------------------------------
  ser-nav（サービスナビ）
--------------------------------*/
#ser-nav {
  background-image: linear-gradient(#3492ff80, #e7e9ff80 50%, #ffffff);
}
.ser-nav__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
.ser-nav__card {
  position: relative;
  display: block;
  aspect-ratio: 426 / 247;
  overflow: hidden;
  text-decoration: none;
  color: var(--c-white);
}
.ser-nav__card:hover {
  opacity: 1;
}
.ser-nav__card:hover .ser-nav__card-bg {
  transform: scale(1.05);
  filter: brightness(1.15);
}
.ser-nav__card.is-current {
  cursor: default;
  pointer-events: none;
}
.ser-nav__card.is-current:hover .ser-nav__card-bg {
  transform: scale(1);
  filter: brightness(1);
}
.ser-nav__card-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  transform: scale(1);
  filter: brightness(1);
  transition:
    transform 0.4s ease,
    filter 0.4s ease;
  will-change: transform;
}
.ser-nav__card-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  transition: opacity 0.4s ease;
  mix-blend-mode: color;
}
.ser-nav__card.is-current .ser-nav__card-bg::before,
.ser-nav__card:hover .ser-nav__card-bg::before,
.ser-nav__card:active .ser-nav__card-bg::before,
.ser-nav__card:focus .ser-nav__card-bg::before {
  background-color: #c8c8c8;
  mix-blend-mode: multiply;
}
.ser-nav__card--01 .ser-nav__card-bg::before {
  background-color: var(--c-ser-01);
}
.ser-nav__card--02 .ser-nav__card-bg::before {
  background-color: #0054cc;
}
.ser-nav__card--03 .ser-nav__card-bg::before {
  background-color: var(--c-ser-03);
}
.ser-nav__card--04 .ser-nav__card-bg::before {
  background-color: var(--c-ser-04);
}
.ser-nav__card--05 .ser-nav__card-bg::before {
  background-color: var(--c-ser-05);
}
.ser-nav__card--06 .ser-nav__card-bg::before {
  background-color: var(--c-ser-06);
}
.ser-nav__card-content {
  position: relative;
  z-index: 2;
  height: 100%;
  padding: 24px 32px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
}
.ser-nav__card-content.last-child {
  justify-content: center;
  gap: 12px;
}
.ser-nav__card-ttl {
  font-size: var(--fs-22);
  font-weight: var(--fw-bold);
  letter-spacing: 0.2em;
  line-height: 1.4;
  padding-bottom: 1em;
  border-bottom: 1px solid var(--c-white);
}
.ser-nav__card-ttl.mincho {
  font-family: var(--font-shippori);
  font-size: var(--fs-37);
  font-weight: var(--fw-medium);
  letter-spacing: 0.11em;
  border-bottom: none;
  padding-bottom: 0;
}
.ser-nav__card-desc {
  font-size: var(--fs-14);
  line-height: 1.6;
}
.ser-nav__card-label {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.ser-nav__card-label span {
  display: block;
  width: fit-content;
  padding: 2px 4px;
  background: var(--c-red-01);
  font-size: var(--fs-15);
  font-weight: var(--fw-bold);
  line-height: 1.4;
}
.ser-nav__card:hover .cmn-cnt__card-arrow::before {
  width: 35px;
}
.ser-nav__card.is-current:hover .cmn-cnt__card-arrow::before {
  width: 0;
}
@media screen and (max-width: 1300px) {
  .ser-nav__card-ttl.mincho {
    font-size: var(--fs-30);
  }
}
@media screen and (max-width: 1200px) {
  .ser-nav__card-content {
    padding: 16px 20px;
  }
  .ser-nav__card-ttl {
    font-size: var(--fs-18);
  }
  .ser-nav__card-ttl.mincho {
    font-size: var(--fs-24);
  }
  .ser-nav__card-label span {
    font-size: var(--fs-13);
  }
}
@media screen and (max-width: 960px) {
  .ser-nav__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
    justify-items: center;
  }
  .ser-nav__card {
    max-width: 425px;
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .ser-nav__grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }
}
