/** spacing in multiple of 8 **/
/** negative **/
/** mixin **/
/** reset **/


/* BreadcrumbList */
.BreadcrumbList__item + .BreadcrumbList__item::before {
  content: "";
  display: inline-block;
  width: 16px;
  height: 16px;
  -webkit-transform: rotate(-90deg);
          transform: rotate(-90deg);
  background-image: url("/corp/common/image/icon-arrow.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 16px;
  vertical-align: -0.4em;
}


/* CaseCard */
.CaseCard {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  padding-top: 8px;
  padding-left: 16px;
  padding-right: 16px;
  padding-bottom: 24px;
  -webkit-box-shadow: 0px 0px 6px #7F828880;
          box-shadow: 0px 0px 6px #7F828880;
  border-radius: 0px 0px 4px 4px;
  width: 100%;
}

@media screen and (min-width: 768px) {
  .CaseCard {
    width: calc(50% - (24px / 2));
    padding-left: 40px;
    padding-right: 40px;
    padding-bottom: 40px;
  }
}

@media screen and (min-width: 1280px) {
  .CaseCard {
    width: calc(33.33% - ((24px / 3)* 2));
  }
}

.CaseCard > * + * {
  margin-top: 16px;
}

.CaseCard.-hidden {
  display: none;
}

.CaseCard.-more {
  display: none;
}

.CaseCard__deco {
  position: relative;
  width: 40px;
  height: 80px;
  margin: auto auto 0px;
  padding-top: 40px;
}

.CaseCard__deco::after {
  position: absolute;
  top: calc(50% + 20px);
  left: 0px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  content: "";
  display: block;
  width: 40px;
  height: 2px;
  background-color: #0087D2;
}

.CaseCard__logo {
  max-width: 230px;
  max-height: 180px;
  margin: 0px auto;
}

.CaseCard__title {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 2.2rem;
  font-weight: bold;
  text-align: center;
  min-height: 2.8em;
  vertical-align: text-top;
  margin-top: 0px;
}

.CaseCard__desc {
  margin-top: 16px;
  min-height: 7.25em;
}

.CaseCard__listUnit {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 8px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.CaseCard__listTilte {
  font-size: 1rem;
  color: #0087D2;
  font-weight: bold;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.CaseCard__buttonOuter {
  margin-top: auto;
  padding-top: 40px;
  text-align: center;
}

.CaseCard__buttonOuter .CommonButton {
  width: 100%;
  max-width: 200px;
}


@media screen and (min-width: 768px) {
  .CommonButton.-hasImage {
    padding: 0px 0px 0px 40px;
  }
}


.CommonButton__labelImage {
  display: block;
  width: 100px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

/* 20241226 */
@media screen and (min-width: 768px) {
  .CommonButton__labelImage.-bottom {
    display: block;
    width: 120px;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
}

.CommonButton__labelText {
  display: block;
  margin-left: 8px;
  text-align: center;
  width: auto;
}

@media screen and (min-width: 768px) {
  .CommonButton__labelText {
    width: 100%;
    max-width: 280px;
    margin-left: 24px;
  }
}

/* 20241226 */
@media screen and (min-width: 768px) {
  .CommonButton__labelText.-bottom {
    width: 100%;
    max-width: 280px;
    margin-left: 0;
  }
}


/* CommonTag */
.CommonTag {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 8px;
}

.CommonTag__item {
  white-space: nowrap;
  font-size: 1rem;
  line-height: 1;
  font-weight: bold;
  color: #0087D2;
  padding: 8px 16px;
  background-color: #DEEEF7;
  border-radius: 999px;
}

/* HeroArea */
@media screen and (min-width: 768px) {
  .HeroArea__visual.-case {
    max-height: 580px;
  }
}

.MainContent__layout.-col3.-case {
  gap: 16px 24px;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

@media screen and (min-width: 768px) {
  .MainContent__layout.-col3.-case {
    gap: 40px 24px;
  }
}

.ModalContent__textButton::after {
  content: "";
  display: inline-block;
  width: 16px;
  height: 16px;
  background-image: url("/corp/common/image/icon_window.svg");
  background-repeat: no-repeat;
  background-size: 16px;
  background-position: center;
  vertical-align: -0.125em;
  margin-left: 8px;
}


/* NavCard */
.NavCard {
  width: 100%;
  border-radius: 0px 0px 4px 4px;
  -webkit-box-shadow: 0 0 6px rgba(127, 130, 136, 0.5);
          box-shadow: 0 0 6px rgba(127, 130, 136, 0.5);
  -webkit-transition: opacity ease .2s;
  transition: opacity ease .2s;
}

@media screen and (min-width: 1024px) {
  .NavCard:hover {
    opacity: .8;
  }
}

@media screen and (min-width: 768px) {
  .NavCard {
    /*width: calc(50% - 12px);*/
    width: calc(32% - 18px);
  }
}

@media screen and (min-width: 1024px) {
  .NavCard {
    width: calc(30% - 18px);
  }
}

.NavCard__title {
  display: block;
  font-size: 2.2rem;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  text-align: center;
  margin-top: 0px;
  margin-bottom: 16px;
}

@media screen and (min-width: 768px) {
  .NavCard__title {
    display: -webkit-box;
    display: -ms-flexbox;
    /*display: flex;
    text-align: left;*/
    display: block;
    text-align: center;
    margin-top: 16px;
  }
}

@media screen and (min-width: 1024px) {
  .NavCard__title {
    display: block;
    text-align: center;
    margin-top: 0px;
  }
}

.NavCard__title::before {
  content: attr(data-num);
  display: block;
  font-size: 4.8rem;
  font-weight: 400;
  color: #0087D2;
  margin-right: 16px;
    margin-right: 0px;
}

@media screen and (min-width: 1024px) {
  .NavCard__title::before {
    margin-right: 0px;
  }
}

.NavCard__title br {
  display: block;
}

@media screen and (min-width: 768px) {
  .NavCard__title br {
    display: none;
  }
}

@media screen and (min-width: 1024px) {
  .NavCard__title br {
    display: block;
  }
}

.NavCard__titleInner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  min-height: 3em;
}

.NavCard__desc {
  margin-bottom: 24px;
  text-align: center;
}

@media screen and (min-width: 768px) {
  .NavCard__desc {
    margin-bottom: 40px;
    text-align: left;
  }
}

@media screen and (min-width: 1024px) {
  .NavCard__desc {
    text-align: left;
    margin-bottom: 16px;
  }
}

.NavCard__wrapLink {
  display: block;
  padding: 0px 16px 32px;
}

.NavCard__wrapLink::before {
  content: "";
  display: block;
  position: absolute;
  z-index: 1;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
}

.NavCard__wrapLink::after {
  content: "";
  display: block;
  position: absolute;
  z-index: 1;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  bottom: 16px;
  width: 24px;
  height: 24px;
  background-image: url("/corp/common/image/icon-arrow.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 24px;
}


.PageFooter__menuLink.-external::after {
  content: "";
  display: inline-block;
  margin: 2px 0px 0px 8px;
  width: 16px;
  height: 16px;
  background-image: url("/corp/common/image/icon-window.svg");
  background-repeat: no-repeat;
  background-size: contain;
}

/*.PageHeader__menuItem::after {
  content: "";
  display: block;
  position: absolute;
  z-index: 1;
  top: 50%;
  right: 16px;
  width: 24px;
  height: 24px;
  background-image: url("/corp/common/image/icon-arrow.svg");
  background-size: 24px;
  -webkit-transform: translateY(-50%) rotate(-90deg);
          transform: translateY(-50%) rotate(-90deg);
  pointer-events: none;
}*/

.PageSection.-hasAction {
  padding: 16px 16px 0px;
  margin-top:40px;
}

@media screen and (min-width: 768px) {
  .PageSection.-hasAction {
    padding: 40px 40px 0px;
    margin-top:40px;
  }
}

.FlowFigure__listTitle::before {
  content: "";
  display: block;
  position: absolute;
  left: 0px;
  top: 0.2em;
  width: 16px;
  height: 16px;
  background-image: url("/corp/common/image/icon_arrow_right.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 8px;
}

.ProgramArea__subTitle {
  display: block;
  font-size: 1.6rem;
  font-weight: 400;
  margin-bottom: 4px;
}

.QAList__questText::before {
  background-image: url("/corp/common/image/faq_question.svg");
  background-repeat: no-repeat;
  background-size: contain;
  margin-right: 8px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.QAList__questText::after {
  content: "";
  position: absolute;
  z-index: 1;
  top: 50%;
  right: 18px;
  bottom: 16px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background-image: url("/corp/common/image/icon-arrow.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 24px;
  -webkit-transition: -webkit-transform ease .3s;
  transition: -webkit-transform ease .3s;
  transition: transform ease .3s;
  transition: transform ease .3s, -webkit-transform ease .3s;
}

.QAList__answerText::before {
  width: 48px;
  height: 48px;
  background-image: url("/corp/common/image/faq_answer.svg");
  background-repeat: no-repeat;
  background-size: contain;
  margin: 0px auto 24px;
}

/* Slider */
.Slider {
  width: 100%;
}

.Slider__item {
  max-width: 680px;
  max-height: 340px;
  -webkit-box-shadow: 10px 10px 20px #00000029;
          box-shadow: 10px 10px 20px #00000029;
}

.Slider__item img {
  width: 100%;
  height: auto;
}

.swiper-pagination {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 16px;
  width: 100%;
  height: 8px;
  text-align: center;
  margin-top: 24px;
}

.swiper-pagination-bullet {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 4px;
  background-color: #D1D4D7;
  cursor: pointer;
}

.swiper-pagination-bullet-active {
  background-color: #7F8288;
}

.Slider__link {
  -webkit-transition: opacity ease .2s;
  transition: opacity ease .2s;
}

.Slider__link:hover {
  opacity: .8;
}

.Filter__button.-reset {
  text-align: right;
  border: #0087D2 solid 1px;
  width: 100%;
  max-width: 240px;
  margin-top: 24px;
  margin-left: auto;
  margin-right: auto;
  padding-top: 7px;
  padding-bottom: 9px;
  padding-right: 84px;
  vertical-align: middle;
  background-image: url("/corp/common/image/icon-reset.svg");
  background-repeat: no-repeat;
  background-size: 16px;
  background-position: right 60px center;
}

.Filter__pulldown::after {
  content: "";
  display: block;
  position: absolute;
  z-index: 1;
  top: 50%;
  right: 24px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 24px;
  height: 24px;
  background-image: url("/corp/common/image/icon-pulldown.svg");
  background-size: 24px;
  pointer-events: none;
}

.SwitchArea__anchor::after {
  content: "";
  display: block;
  width: 24px;
  height: 24px;
  background-image: url("/corp/common/image/icon-arrow.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 24px;
  margin-left: auto;
  margin-right: auto;
}


/* ------------------------------------------------ Top Renewal 202408 START ------------------------------------------------ */
.LogoSlideArea{text-align: center;margin:auto;}
.LogoSlide_button{margin:10px auto 30px;}
span.blue-txt{color:#0087D2;}

.PageSection.-hasBorder{
  border-top: 2px solid #0087D2;
}
.PageSection.-hasBorder h3{
  font-size: 2.4rem;
  font-weight: 500;
  font-family: "Noto Sans JP", sans-serif;
}
@media screen and (max-width: 767px) {
  .pcImg{
    display: none;
  }
}
@media screen and (min-width: 768px) {
  .spImg{
    display: none;
  }
}
.MainContent__notes.-right {
  text-align: right;
}
.MainContent__notes.-left {
  text-align: left;
}

div#feature01, div#feature02, div#feature03{
  content: "";
  display: block;
  height: 40px;
  margin-top: -40px;
  visibility: hidden;
}
@media screen and (min-width: 768px) {
  div#feature01, div#feature02, div#feature03{
    height: 80px;
    margin-top: -80px;
  }
}

/* ------------------------------------------------ Top Renewal 202408 END ------------------------------------------------ */


/*# sourceMappingURL=style.css.map */