@charset "UTF-8";
.service__bg {
  background: linear-gradient(to top, rgba(217, 224, 33, 0.1) 0%, rgba(217, 224, 33, 0.1) 50%, rgba(255, 255, 255, 0.1) 100%);
}

.servicePageLead {
  background: #f9f9f9;
  padding-top: calc(20px + 3vw);
  padding-bottom: calc(20px + 3vw);
}
.servicePageLead__heading {
  color: #3c99b0;
  font-size: 2em;
  font-weight: 700;
  letter-spacing: 0.1em;
  margin-bottom: calc(10px + 2vw);
}
@media only screen and (max-width: 767px) {
  .servicePageLead__heading {
    font-size: 1.4em;
    line-height: 1.4;
  }
}
.servicePageLead p {
  margin-bottom: 1em;
}

.servicePageConcept {
  padding-top: calc(20px + 3vw);
  padding-bottom: calc(20px + 3vw);
}
.servicePageConcept__img {
  display: flex;
  justify-content: center;
}
.servicePageConcept__img picture {
  width: 86%;
  height: auto;
  display: flex;
  justify-content: center;
}
.servicePageConcept__img img {
  width: 100%;
  height: auto;
  display: block;
}
@media only screen and (max-width: 767px) {
  .servicePageConcept__img img {
    width: 78%;
  }
}
.servicePageConcept__img svg {
  width: 86%;
  height: auto;
  display: block;
}

.servicePageDomain {
  padding-top: calc(20px + 3vw);
  padding-bottom: calc(20px + 3vw);
}
.servicePageDomain__heading {
  font-size: 1.8em;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-align: center;
  color: #213784;
  line-height: 1.4;
  margin-bottom: calc(15px + 2vw);
}
@media only screen and (max-width: 767px) {
  .servicePageDomain__heading {
    font-size: 1.4em;
  }
}
.servicePageDomain__headingChild {
  display: flex;
  justify-content: center;
  align-items: center;
}
.servicePageDomain__headingNum {
  font-size: 1.7em;
  margin-right: 0.2em;
}

.servicePageDomainNav {
  margin-bottom: calc(20px + 3vw);
}
.servicePageDomainNav__grp {
  display: flex;
  gap: calc(15px + 2vw);
}
@media only screen and (max-width: 767px) {
  .servicePageDomainNav__grp {
    gap: 5px;
  }
}
.servicePageDomainNav__item {
  display: block;
  list-style: none;
  width: calc(33.3333% - calc(15px + 2vw) * 2 / 3);
}
@media only screen and (max-width: 767px) {
  .servicePageDomainNav__item {
    width: calc(33.3333% - 3.3333333333px);
  }
}

.servicePageCard {
  display: block;
  background: #fff;
  box-shadow: 7px 5px 11px rgba(0, 0, 0, 0.2);
  border-radius: 10px;
  overflow: hidden;
  color: #213784;
}
.servicePageCard:hover {
  opacity: 1;
}
.servicePageCard__contents {
  padding: 1em 1.2em;
  position: relative;
}
@media only screen and (max-width: 767px) {
  .servicePageCard__contents {
    padding: 1em 0.8em 2em 0.8em;
  }
}
.servicePageCard__img {
  overflow: hidden;
  aspect-ratio: 16/9;
}
.servicePageCard__img img {
  width: 100%;
  height: auto;
  display: block;
  transition: transform 0.3s ease-in-out;
}
.servicePageCard:hover .servicePageCard__img img {
  transform: scale(1.05);
}
.servicePageCard__name {
  font-weight: bold;
  font-size: 1.2em;
}
@media only screen and (max-width: 767px) {
  .servicePageCard__name {
    font-size: 1em;
    line-height: 1.2;
    text-align: center;
  }
}
.servicePageCard__icon {
  background: #213784;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  right: 1.2em;
  transform: translateY(-50%);
}
@media only screen and (max-width: 767px) {
  .servicePageCard__icon {
    right: auto;
    top: auto;
    bottom: 5px;
    left: 50%;
    transform: translate(-50%, 0%) rotate(90deg);
    width: 14px;
    height: 14px;
  }
}
.servicePageCard__icon::before {
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(calc(-50% - 1px), -50%) rotate(45deg);
}
@media only screen and (max-width: 767px) {
  .servicePageCard__icon::before {
    width: 5px;
    height: 5px;
    border-width: 1px;
  }
}

.servicePageDomainText {
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .servicePageDomainText {
    text-align: left;
  }
}
.servicePageDomainText p {
  margin-bottom: 1em;
}

.servicePageBlock {
  position: relative;
  padding-top: calc(20px + 3vw);
  overflow: hidden;
}
.servicePageBlock__inner {
  position: relative;
  z-index: 2;
}
.servicePageBlock__parallax {
  background-size: 150%;
  background-repeat: no-repeat;
  position: absolute;
  top: 0;
  left: 0;
  width: 88vw;
  aspect-ratio: 13/10;
  z-index: 1;
  overflow: hidden;
  background-attachment: fixed;
  background-position-x: center;
  pointer-events: none;
}
@media only screen and (max-width: 767px) {
  .servicePageBlock__parallax {
    background-attachment: scroll;
  }
}
.servicePageBlock__parallax--01 {
  background-image: url("../img/domain_lg_01.jpg");
}
.servicePageBlock__parallax--02 {
  background-image: url("../img/domain_lg_02.jpg");
  left: auto;
  right: 0;
}
.servicePageBlock__parallax--03 {
  background-image: url("../img/domain_lg_03.jpg");
}
.servicePageBlock__bg {
  background: #d9e021;
  position: absolute;
  top: 50vw;
  right: 0;
  width: 88vw;
  aspect-ratio: 1185/855;
  z-index: 0;
  opacity: 0.2;
}
@media only screen and (max-width: 767px) {
  .servicePageBlock__bg {
    top: 55vw;
  }
}
.servicePageBlock--02 .servicePageBlock__bg {
  left: 0;
  right: auto;
}
.servicePageBlock__body {
  padding-right: 80px;
  padding-left: 80px;
}
@media only screen and (max-width: 767px) {
  .servicePageBlock__body {
    padding: 0 15px;
  }
}

.servicePageBlockHead {
  background: linear-gradient(to right, rgba(251, 251, 236, 0.4) 0%, rgb(253, 253, 245) 100%);
  padding: calc(15px + 2vw);
  position: relative;
  z-index: 2;
}
@media only screen and (max-width: 767px) {
  .servicePageBlockHead {
    width: 100%;
    padding: calc(10px + 2vw) 0;
  }
}
.servicePageBlockHead::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: linear-gradient(to right, rgba(232, 248, 239, 0.7) 0%, rgba(216, 234, 247, 0.9) 50%, rgb(253, 253, 245) 80%);
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  pointer-events: none;
}
.servicePageBlock--02 .servicePageBlockHead {
  background: linear-gradient(to left, rgba(251, 251, 236, 0.4) 0%, rgb(252, 252, 234) 100%);
}
.servicePageBlock--02 .servicePageBlockHead::after {
  background: linear-gradient(to left, rgba(232, 248, 239, 0.7) 0%, rgba(216, 234, 247, 0.9) 50%, rgb(252, 252, 234) 80%);
}
.servicePageBlock--03 .servicePageBlockHead {
  background: linear-gradient(to right, rgba(251, 251, 236, 0.4) 0%, rgb(251, 251, 232) 100%);
}
.servicePageBlock--03 .servicePageBlockHead::after {
  background: linear-gradient(to right, rgba(232, 248, 239, 0.7) 0%, rgba(216, 234, 247, 0.9) 50%, rgb(251, 251, 232) 80%);
}
.servicePageBlockHead .inner {
  padding-left: 80px;
}
@media only screen and (max-width: 767px) {
  .servicePageBlockHead .inner {
    padding: 0 15px;
  }
}
.servicePageBlock--02 .servicePageBlockHead {
  margin-left: auto;
  display: flex;
  flex-direction: column;
}
.servicePageBlock--02 .servicePageBlockHead .inner {
  width: auto;
  margin-left: auto;
  margin-right: calc((100vw - 1260px) / 2);
  padding-right: 0;
}
@media only screen and (max-width: 767px) {
  .servicePageBlock--02 .servicePageBlockHead .inner {
    margin-right: 0;
    padding: 0 15px 0 15px;
  }
}
.servicePageBlockHead__heading {
  font-size: 2.2em;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: #213784;
  line-height: 1.4;
  margin-bottom: calc(5px + 1vw);
  position: relative;
  z-index: 2;
}
@media only screen and (max-width: 767px) {
  .servicePageBlockHead__heading {
    font-size: 1.5em;
  }
}
.servicePageBlockHead__text {
  line-height: 1.8;
  position: relative;
  z-index: 2;
  font-weight: 700;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 767px) {
  .servicePageBlockHead__text {
    font-size: 1em;
    line-height: 1.6;
  }
}

.servicePageItem {
  position: relative;
  z-index: 2;
  -webkit-tap-highlight-color: transparent;
}
.servicePageItem__link {
  background: #fff;
  padding: calc(15px + 2vw);
  max-width: 1260px;
  margin: calc(30px + 4vw) auto;
  border-radius: 20px;
  box-shadow: 7px 5px 11px rgba(0, 0, 0, 0.2);
  overflow: hidden;
  display: block;
  transition: opacity 0.3s ease, transform 0.3s ease;
  position: relative;
  inset: 0;
  z-index: 0;
  -webkit-tap-highlight-color: transparent;
}
.servicePageItem__link:hover {
  opacity: 1;
  transform: scale(1.02);
}
.servicePageItem__link:hover::before {
  opacity: 1;
}
@media only screen and (max-width: 767px) {
  .servicePageItem__link {
    border-radius: 10px;
    padding: 0;
    margin: calc(15px + 2vw) auto;
  }
  .servicePageItem__link:hover {
    transform: none;
  }
}
.servicePageItem__summary {
  pointer-events: none;
  display: block;
  width: 100%;
  text-align: left;
  cursor: pointer;
  border: none;
  background: none;
  padding: 0;
  position: relative;
  z-index: 1;
  -webkit-tap-highlight-color: transparent;
}
@media only screen and (max-width: 767px) {
  .servicePageItem__summary {
    pointer-events: auto;
    padding: 15px 18px 0;
  }
}
.servicePageItem__toggle {
  display: none;
}
@media only screen and (max-width: 767px) {
  .servicePageItem__toggle {
    display: block;
    width: 22px;
    height: 22px;
    border: 1px solid #213784;
    border-radius: 50%;
    position: absolute;
    top: calc(15px + 2vw);
    right: calc(5px + 1vw);
    cursor: pointer;
  }
}
@media only screen and (max-width: 767px) and (max-width: 767px) {
  .servicePageItem__toggle {
    top: 10px;
  }
}
@media only screen and (max-width: 767px) {
  .servicePageItem__toggle::before {
    content: "";
    display: block;
    width: 16px;
    height: 1px;
    background: #213784;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    transition: transform 0.3s ease-in-out;
  }
}
@media only screen and (max-width: 767px) {
  .servicePageItem__toggle::after {
    content: "";
    display: block;
    width: 16px;
    height: 1px;
    background: #213784;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) rotate(90deg);
    transition: transform 0.3s ease-in-out;
  }
}
@media only screen and (max-width: 767px) {
  .servicePageItem.is-open .servicePageItem__toggle::after {
    opacity: 0;
  }
}
.servicePageItem__anim {
  display: block;
  -webkit-tap-highlight-color: transparent;
}
@media only screen and (max-width: 767px) {
  .servicePageItem__anim {
    overflow: hidden;
    --h: 0px;
    max-height: 0;
    opacity: 0;
    transition: max-height 0.36s ease, opacity 0.36s ease;
    will-change: max-height, opacity;
    /* モバイル実機の点滅対策（層を固定） */
    transform: translateZ(0);
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
    contain: layout paint;
  }
}
@media only screen and (max-width: 767px) {
  .servicePageItem.is-open .servicePageItem__anim {
    max-height: var(--h);
    opacity: 1;
  }
}
@media only screen and (max-width: 767px) {
  .servicePageItem__contents {
    padding: 0 18px 10px;
  }
}
.servicePageItem__head {
  margin-bottom: calc(5px + 1vw);
}
.servicePageItem__title {
  font-size: 1.75em;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: #213784;
  margin-bottom: calc(2px + 0.5vw);
}
@media only screen and (max-width: 767px) {
  .servicePageItem__title {
    font-size: 1.3em;
  }
}
.servicePageItem__text {
  color: #000;
}
@media only screen and (max-width: 767px) {
  .servicePageItem__text {
    font-size: 0.95em;
  }
}
.servicePageItem__list {
  display: flex;
  flex-wrap: wrap;
  gap: calc(5px + 1vw) calc(10px + 2vw);
}
@media only screen and (max-width: 767px) {
  .servicePageItem__list {
    gap: calc(5px + 1vw);
  }
}
.servicePageItem__element {
  width: calc(50% - calc(10px + 2vw) / 2);
}
@media only screen and (max-width: 767px) {
  .servicePageItem__element {
    width: 100%;
  }
}
.servicePageItem__elementName {
  color: #3c99b0;
  font-size: 1.25em;
  margin-bottom: calc(2px + 0.5vw);
}
@media only screen and (max-width: 767px) {
  .servicePageItem__elementName {
    font-size: 1em;
  }
}
.servicePageItem__elementDetail {
  display: flex;
  align-items: baseline;
  gap: 0.2em;
  font-size: 0.95em;
}
@media only screen and (max-width: 767px) {
  .servicePageItem__elementDetail {
    font-size: 0.9em;
  }
}
.servicePageItem__elementDetail--brand {
  font-size: 1.2em;
}
.servicePageItem__elementYear {
  font-weight: bold;
  font-size: 1.2em;
}
.servicePageItem__elementYearUnit {
  font-size: 0.75em;
}
.servicePageItem__logo {
  position: absolute;
  right: calc(15px + 2vw);
  bottom: calc(15px + 2vw);
  width: 220px;
}
@media only screen and (max-width: 767px) {
  .servicePageItem__logo {
    position: relative;
    right: auto;
    bottom: auto;
    margin: calc(15px + 2vw) auto;
    width: 150px;
  }
}
.servicePageItem__logo img {
  width: 100%;
  height: auto;
  display: block;
}
.servicePageItem__tags {
  position: absolute;
  top: calc(15px + 2vw);
  right: calc(15px + 2vw);
  display: flex;
  gap: 1.5em;
}
@media only screen and (max-width: 767px) {
  .servicePageItem__tags {
    position: relative;
    right: auto;
    top: auto;
    margin-bottom: 8px;
  }
}
.servicePageItem__tagItem {
  position: relative;
  display: flex;
  align-items: center;
  list-style: none;
  gap: 0.2em;
  font-size: 0.9em;
}
.servicePageItem__tagItem::before {
  content: "";
  display: block;
  background-image: url("../img/icon_tag.svg");
  width: 16px;
  height: 11px;
  background-size: contain;
  background-repeat: no-repeat;
  transform: translateY(1px);
}