@charset "UTF-8";
/*-----------------------

         COMMON

-----------------------*/
html {
  overflow-x: hidden;
  overflow-y: scroll;
  font-size: 62.5%;
  scroll-padding-top: 10rem;
}

p {
  margin: 0;
  text-align: justify;
}

a {
  text-decoration: none;
  color: var(--mainColor);
}

a:focus,
a:hover {
  opacity: 0.8;
  text-decoration: none;
  color: inherit;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

input,
textarea,
select,
button {
  font-family: inherit;
}

.pc {
  display: block;
}

.sp {
  display: none;
}

.text-c {
  text-align: center;
}

.text-l {
  text-align: left;
}

.text-r {
  text-align: right;
}

.text-j {
  text-align: justify;
}

.flex {
  display: flex;
}

/* iOSでのデフォルトスタイルをリセット */
input[type=submit],
input[type=button] {
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
}

input[type=submit]::-webkit-search-decoration,
input[type=button]::-webkit-search-decoration {
  display: none;
}

input[type=submit]::focus,
input[type=button]::focus {
  outline-offset: -2px;
}

input,
button,
textarea,
select,
.entry input[type=url],
input[type=email],
.entry input[type=text] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border-radius: 0;
}

@media only screen and (max-width: 559px) {
  .pc {
    display: none;
  }
  .sp {
    display: block;
  }
}
@media screen and (max-width: 559px) {
  /*セレクトボックスの矢印カスタマイズ*/
  .shelf-nav-sp {
    width: 100%;
    margin: 3rem auto 0;
    position: relative;
  }
  .shelf-nav-sp::before {
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 1rem 0.7rem 0 0.7rem;
    border-color: var(--mainColor) transparent transparent transparent;
    position: absolute;
    top: 55%;
    right: 1.5rem;
    transform: translateY(-50%);
    pointer-events: none;
  }
  .breadcrumb.form-control {
    width: 100%;
    padding: 1rem;
    /*デフォルトの矢印を削除*/
    -webkit-appearance: none;
    appearance: none;
  }
  /*サファリのフォームで入力時にズームしないようにする*/
  input,
  textarea,
  select {
    font-size: 20px;
    transform: scale(0.8);
  }
  /* ボタンは小さくしないように */
  input[type=submit],
  input[type=button] {
    font-size: 16px;
    transform: scale(1);
  }
  /* プルダウンは小さくしないように */
  select {
    font-size: 20px;
    transform: scale(1);
  }
}
body {
  width: 100%;
  color: var(--baseColor);
  font-size: 2rem;
  line-height: 1.75;
  letter-spacing: 0.1em;
  font-feature-settings: "palt";
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-style: normal;
  background: url(../img/bg.svg) repeat-y center center/cover;
}
@media only screen and (max-width: 559px) {
  body {
    overflow-x: hidden;
  }
}

.container,
.wrapper {
  max-width: 136.6rem;
  padding: 0 2rem;
  margin: 0 auto;
  min-height: auto;
  width: 136.6rem;
}
@media only screen and (max-width: 1369px) {
  .container,
  .wrapper {
    width: 100%;
    padding: 0 6rem;
  }
}
@media only screen and (max-width: 559px) {
  .container,
  .wrapper {
    padding: 0 6%;
  }
}

.bg-grd {
  background: #18bde7;
  background: linear-gradient(90deg, rgb(24, 189, 231) 0%, rgb(23, 42, 136) 100%);
}

.grd {
  background: #18bde7;
  background: linear-gradient(90deg, rgb(24, 189, 231) 0%, rgb(23, 42, 136) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.jost {
  font-family: "Jost", system-ui, sans-serif;
}

.rad {
  border-radius: 0.5rem;
}

.holder {
  width: 100rem;
  margin-inline: auto;
}
@media only screen and (max-width: 559px) {
  .holder {
    width: 100%;
  }
}

.inner {
  width: 74rem;
  margin-inline: auto;
}
@media only screen and (max-width: 559px) {
  .inner {
    width: 100%;
  }
}

.cm__listflex {
  display: flex;
}
@media only screen and (max-width: 559px) {
  .cm__listflex {
    flex-direction: column;
    padding-inline: 6%;
  }
}
.cm__listbox {
  width: calc((100% - 5.5rem) / 2);
  min-height: 59.4rem;
  height: 30.9375vw;
}
@media only screen and (max-width: 559px) {
  .cm__listbox {
    min-height: inherit;
    width: 100%;
    height: inherit;
  }
}
.cm__listitem {
  position: relative;
}
@media only screen and (max-width: 559px) {
  .cm__listitem {
    display: flex;
    flex-direction: column-reverse;
    gap: 2.5rem;
  }
}
.cm__listitem:not(:last-child) {
  margin-bottom: 9rem;
}
@media only screen and (max-width: 559px) {
  .cm__listitem:not(:last-child) {
    margin-bottom: 5rem;
  }
}
@media only screen and (max-width: 559px) {
  .cm__list .wrapper {
    display: contents;
  }
}
.cm__listfigure {
  position: absolute;
  top: 0;
  right: calc(50% - 50vw);
  width: 50vw;
  height: 100%;
}
@media only screen and (max-width: 559px) {
  .cm__listfigure {
    position: static;
    width: 100%;
    height: auto;
    right: inherit;
    padding-left: 4%;
  }
}
.cm__listimg {
  width: 100%;
  height: 59.4rem;
  height: 30.9375vw;
  object-fit: cover;
  object-position: left center;
}
@media only screen and (max-width: 559px) {
  .cm__listimg {
    height: inherit;
  }
}
.cm__listnumber {
  font-family: var(--jost);
  font-size: 2.1rem;
  letter-spacing: 0;
  width: fit-content;
  line-height: 1;
  margin-bottom: 3.5rem;
}
@media only screen and (max-width: 559px) {
  .cm__listnumber {
    font-size: 1.2rem;
    margin-bottom: 1rem;
  }
}
.cm__listnumber span {
  font-size: 4.2rem;
}
@media only screen and (max-width: 559px) {
  .cm__listnumber span {
    font-size: 2.5rem;
  }
}
.cm__listttl {
  color: var(--mainColor);
  font-weight: 700;
  font-size: 4.4rem;
  padding-bottom: 3rem;
  margin-bottom: 4rem;
  border-bottom: 1px solid var(--mainColor);
}
@media only screen and (max-width: 559px) {
  .cm__listttl {
    font-size: 2.4rem;
    padding-bottom: 1.5rem;
    margin-bottom: 2rem;
  }
}
.cm__listsubttl {
  color: var(--subColor);
  font-size: 2.4rem;
  letter-spacing: 0.05em;
  line-height: 1.5;
  margin-bottom: 3rem;
}
@media only screen and (max-width: 559px) {
  .cm__listsubttl {
    font-size: 1.6rem;
    line-height: 1.5;
    margin-bottom: 2rem;
  }
}
.cm__listtextarea {
  margin-bottom: 4rem;
}
@media only screen and (max-width: 559px) {
  .cm__listtextarea {
    margin-bottom: 2.5rem;
  }
}
.cm__listtext {
  font-weight: 500;
  font-size: 1.8rem;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 559px) {
  .cm__listtext {
    font-size: 1.4rem;
  }
}

.cm-ttl {
  width: fit-content;
  line-height: 1.3;
  margin-bottom: 2.5rem;
  font-size: 2rem;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 559px) {
  .cm-ttl {
    font-size: 1.2rem;
    margin-bottom: 1rem;
  }
}
.cm-ttl span {
  font-family: var(--jost);
  font-size: 6.6rem;
  font-weight: 500;
}
@media only screen and (max-width: 559px) {
  .cm-ttl span {
    font-size: 3.2rem;
  }
}

.cm-card.o-card--4wrap {
  margin-bottom: 4.5rem;
}
@media only screen and (max-width: 559px) {
  .cm-card.o-card--4wrap {
    margin-bottom: 2.5rem;
    gap: 2rem;
  }
}
.cm-card__subttl {
  font-size: 1.6rem;
  letter-spacing: 0.05em;
  line-height: 1.5;
  margin-bottom: 1rem;
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
}
@media only screen and (max-width: 559px) {
  .cm-card__subttl {
    font-size: 1.2rem;
    margin-bottom: 0.5rem;
  }
}
.cm-card__date {
  font-size: 1.4rem;
  font-family: var(--jost);
  color: var(--subColor);
}
@media only screen and (max-width: 559px) {
  .cm-card__date {
    font-size: 1.2rem;
  }
}
.cm-card__cat {
  margin-top: -1.5rem;
  position: relative;
  margin-bottom: 0.5rem;
}
@media only screen and (max-width: 559px) {
  .cm-card__cat {
    margin-bottom: 0;
  }
}
.cm-card__cat span {
  color: var(--colorW);
  background: #18bde7;
  background: linear-gradient(90deg, rgb(24, 189, 231) 0%, rgb(23, 42, 136) 100%);
  border-radius: calc(infinity * 1px);
  padding: 0.2rem 1.5rem;
  line-height: 1;
  font-size: 1.4rem;
}
@media only screen and (max-width: 559px) {
  .cm-card__cat span {
    font-size: 1rem;
    padding: 0.1rem 0.9rem;
  }
}
.cm-card__img {
  aspect-ratio: 16/9;
  width: 100%;
  height: auto;
  object-fit: cover;
  border-radius: 1rem;
}

.bs-summary .ab-message__unitflex {
  margin-bottom: 0;
}
.bs-summary .ab-philosophy__deco {
  margin-bottom: 12rem;
}
@media only screen and (max-width: 559px) {
  .bs-summary .ab-philosophy__deco {
    top: -17rem;
  }
}
@media only screen and (max-width: 559px) {
  .bs-summary .ab-philosophy__deco {
    margin-bottom: 6rem;
  }
}
.bs-summary__cont {
  padding: 6rem 0 6.5rem;
}
@media only screen and (max-width: 559px) {
  .bs-summary__cont {
    padding: 3rem 0 3.5rem;
  }
}
.bs-summary__number {
  width: fit-content;
  margin-inline: auto;
  margin-bottom: 4rem;
  line-height: 1;
  font-family: var(--jost);
  font-size: 4.6rem;
}
@media only screen and (max-width: 559px) {
  .bs-summary__number {
    margin-bottom: 2rem;
    font-size: 2rem;
  }
}
.bs-summary__ttl {
  font-size: 5rem;
  padding: 1.2rem 2.8rem;
  line-height: 1;
  color: var(--colorW);
  width: fit-content;
  margin-inline: auto;
  margin-bottom: 5.5rem;
  text-align: center;
}
@media only screen and (max-width: 559px) {
  .bs-summary__ttl {
    font-size: 3rem;
    padding: 0.5rem 2rem;
    margin-bottom: 3rem;
  }
}
@media only screen and (max-width: 559px) {
  .bs-summary__ttl span {
    padding: 0.5rem 2rem;
    display: block;
    width: fit-content;
    text-align: center;
    margin-inline: auto;
  }
}
.bs-summary__ttl span:not(:last-child) {
  margin-bottom: 1rem;
}
.bs-summary__figure {
  text-align: center;
  margin-bottom: 6.5rem;
}
@media only screen and (max-width: 559px) {
  .bs-summary__figure {
    margin-bottom: 3rem;
  }
}
.bs-summary__textarea {
  margin-bottom: 6.5rem;
}
@media only screen and (max-width: 559px) {
  .bs-summary__textarea {
    margin-bottom: 0rem;
  }
}
.bs-summary__text {
  font-size: 2rem;
  letter-spacing: 0.05em;
  text-align: center;
}
.bs-summary__text:not(:last-child) {
  margin-bottom: 4rem;
}
@media only screen and (max-width: 559px) {
  .bs-summary__text:not(:last-child) {
    margin-bottom: 2rem;
  }
}
@media only screen and (max-width: 559px) {
  .bs-summary__text {
    font-size: 1.4rem;
    text-align: left;
  }
}
.bs-summary__text .bg-grd {
  color: var(--colorW);
  padding: 0.3rem 0.5rem;
  line-height: 2;
}
@media only screen and (max-width: 559px) {
  .bs-summary__text .bg-grd {
    padding: 0.1rem 0.5rem;
    margin-block: 0.2rem;
    display: inline-block;
  }
}

.bs-movie__cont {
  border-radius: 2rem;
  padding: 0.8rem;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media only screen and (max-width: 559px) {
  .bs-movie__cont {
    padding: 0.4rem;
    margin-top: -1.5rem;
  }
}
.bs-movie iframe {
  width: 100%;
  aspect-ratio: 16/9;
  height: auto;
  border-radius: 2rem;
  overflow: hidden;
}

.cm-faq {
  margin-bottom: 16rem;
}
@media only screen and (max-width: 559px) {
  .cm-faq {
    margin-bottom: 8rem;
  }
}
.cm-faq__wrap {
  margin-bottom: 6.5rem;
}
@media only screen and (max-width: 559px) {
  .cm-faq__wrap {
    margin-bottom: 3rem;
  }
}
.cm-faq__ttlarea {
  position: relative;
  margin-bottom: 3rem;
}
@media only screen and (max-width: 559px) {
  .cm-faq__ttlarea {
    margin-bottom: 2rem;
  }
}
.cm-faq__ttlarea .grd {
  display: flex;
  align-items: baseline;
  width: fit-content;
  gap: 1rem;
  margin-top: -9rem;
}
@media only screen and (max-width: 559px) {
  .cm-faq__ttlarea .grd {
    flex-direction: column;
    gap: 0.5rem;
  }
}
.cm-faq__ttlarea img {
  position: relative;
  left: -4rem;
}
.cm-faq__ttl {
  font-size: 6.6rem;
  font-family: var(--jost);
}
@media only screen and (max-width: 559px) {
  .cm-faq__ttl {
    font-size: 4rem;
  }
}
.cm-faq__subttl {
  font-size: 2rem;
}
@media only screen and (max-width: 559px) {
  .cm-faq__subttl {
    font-size: 1.4rem;
  }
}
.cm-faq__note {
  font-size: 2rem;
  letter-spacing: 0.05em;
  margin-bottom: 4rem;
}
@media only screen and (max-width: 559px) {
  .cm-faq__note {
    font-size: 1.6rem;
  }
}

.bs-cta {
  background-color: var(--colorW);
  border-radius: 5rem;
  margin-top: 14rem;
  padding-bottom: 9.5rem;
  margin-bottom: 12rem;
}
@media only screen and (max-width: 559px) {
  .bs-cta {
    margin-top: 7rem;
    border-radius: 2rem;
    padding-inline: 2rem;
    padding-bottom: 6rem;
    margin-bottom: 6rem;
  }
}
.bs-cta--bottom {
  margin-bottom: 0;
}
@media only screen and (max-width: 559px) {
  .bs-cta--bottom {
    margin-bottom: 0;
  }
}
.bs-cta__main-img {
  width: 100rem;
  margin-inline: auto;
  position: relative;
  top: -14rem;
}
@media only screen and (max-width: 559px) {
  .bs-cta__main-img {
    width: 90%;
    top: -7rem;
  }
}
.bs-cta__label {
  text-align: center;
  color: var(--mainColor);
  margin-top: -19rem;
  font-size: 3.4rem;
  margin-bottom: -1rem;
}
@media only screen and (max-width: 559px) {
  .bs-cta__label {
    margin-top: -8rem;
    font-size: 1.8rem;
    line-height: 1.3;
    margin-bottom: 1rem;
  }
}
.bs-cta__ttl {
  text-align: center;
  font-size: 5.2rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0;
  margin-bottom: 4rem;
}
@media only screen and (max-width: 559px) {
  .bs-cta__ttl {
    font-size: 3rem;
    margin-bottom: 2rem;
  }
}
.bs-cta__ttl-large {
  font-size: 10rem;
  font-weight: 700;
}
@media only screen and (max-width: 559px) {
  .bs-cta__ttl-large {
    font-size: 4.5rem;
  }
}
.bs-cta__ttl-sub {
  font-size: 4.2rem;
  font-weight: 700;
}
@media only screen and (max-width: 559px) {
  .bs-cta__ttl-sub {
    font-size: 2rem;
    padding-top: 1rem;
    display: block;
  }
}
.bs-cta__desc {
  font-size: 1.8rem;
  line-height: 2;
  margin-bottom: 4rem;
}
@media only screen and (max-width: 559px) {
  .bs-cta__desc {
    font-size: 1.4rem;
    margin-bottom: 2rem;
  }
}
.bs-cta__benefit-label {
  width: fit-content;
  margin-inline: auto;
  border-radius: calc(infinity * 1px);
  line-height: 1;
  padding: 1.5rem 3rem;
  font-size: 2.6rem;
  font-weight: 700;
  color: var(--colorW);
  margin-bottom: 1.5rem;
}
@media only screen and (max-width: 559px) {
  .bs-cta__benefit-label {
    font-size: 2rem;
    padding: 1rem 2rem;
    margin-bottom: 2rem;
  }
}
.bs-cta__benefit-box {
  display: flex;
  justify-content: center;
  gap: 3rem;
}
@media only screen and (max-width: 559px) {
  .bs-cta__benefit-box {
    flex-direction: column;
    align-items: center;
    gap: 1rem;
  }
}
.bs-cta__benefit-info {
  margin-top: 1.5rem;
  margin-bottom: 3rem;
}
@media only screen and (max-width: 559px) {
  .bs-cta__benefit-info {
    margin-top: 0;
    margin-bottom: 2rem;
  }
}
.bs-cta__author {
  font-size: 1.8rem;
  letter-spacing: 0.05em;
  line-height: 1;
  margin-bottom: 2rem;
}
@media only screen and (max-width: 559px) {
  .bs-cta__author {
    font-size: 1.6rem;
    margin-bottom: 1rem;
  }
}
.bs-cta__book-ttl {
  color: var(--mainColor);
  font-size: 2.2rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  margin-bottom: 1rem;
}
@media only screen and (max-width: 559px) {
  .bs-cta__book-ttl {
    font-size: 2rem;
    margin-bottom: 0.5rem;
    line-height: 1.3;
  }
}
.bs-cta__book-sub {
  color: var(--mainColor);
  font-size: 1.6rem;
  font-weight: 700;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 559px) {
  .bs-cta__book-sub {
    font-size: 1.4rem;
  }
}
.bs-cta__present {
  width: fit-content;
  margin-inline: auto;
  font-size: 4.6rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1;
  margin-bottom: 6rem;
}
@media only screen and (max-width: 559px) {
  .bs-cta__present {
    font-size: 2.2rem;
    margin-bottom: 3rem;
  }
}

.bs-case {
  margin-bottom: 12rem;
}
@media only screen and (max-width: 559px) {
  .bs-case {
    margin-bottom: 6rem;
  }
}
.bs-case__item {
  background-color: var(--colorW);
  border: 1px solid var(--subColor);
  border-radius: 3.5rem;
  padding: 6rem 0 6.5rem;
}
@media only screen and (max-width: 559px) {
  .bs-case__item {
    border-radius: 2rem;
    padding: 3rem 2rem 3.5rem;
  }
}
.bs-case__item:not(:last-child) {
  margin-bottom: 5rem;
}
@media only screen and (max-width: 559px) {
  .bs-case__item:not(:last-child) {
    margin-bottom: 3rem;
  }
}
.bs-case__content {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 5rem;
}
@media only screen and (max-width: 559px) {
  .bs-case__content {
    gap: 2rem;
    grid-template-columns: repeat(1, 1fr);
  }
}
.bs-case__profile {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 3.5rem;
}
@media only screen and (max-width: 559px) {
  .bs-case__profile {
    flex-direction: column;
    gap: 0.5rem;
    margin-bottom: 2rem;
    align-items: flex-start;
  }
}
.bs-case__number {
  font-size: 2rem;
  font-family: var(--jost);
  background-color: var(--colorW);
  width: 16rem;
  height: 5rem;
  transform: skewX(25deg);
  background: #18bde7;
  background: linear-gradient(90deg, rgb(24, 189, 231) 0%, rgb(23, 42, 136) 100%);
  display: block;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 2.5rem;
  margin-top: -8rem;
}
@media only screen and (max-width: 559px) {
  .bs-case__number {
    width: 10rem;
    height: 3rem;
    margin-top: -5rem;
  }
}
.bs-case__number-inner {
  transform: skewX(-25deg);
  display: flex;
  align-items: baseline;
  gap: 2px;
  color: var(--colorW);
  font-size: 2rem;
  letter-spacing: 0.1em;
}
@media only screen and (max-width: 559px) {
  .bs-case__number-inner {
    font-size: 1.4rem;
  }
}
.bs-case__number-large {
  font-size: 4rem;
}
@media only screen and (max-width: 559px) {
  .bs-case__number-large {
    font-size: 3rem;
  }
}
@media only screen and (max-width: 559px) and (max-width: 559px) {
  .bs-case__number-large {
    font-size: 2.2rem;
  }
}
.bs-case__tag {
  color: var(--mainColor);
  font-size: 1.5rem;
  border-radius: calc(infinity * 1px);
  display: block;
  line-height: 1;
  padding: 0.9rem 1.6rem;
  border: 1px solid var(--mainColor);
}
@media only screen and (max-width: 559px) {
  .bs-case__tag {
    font-size: 1.2rem;
    padding: 0.5rem 1.2rem;
  }
}
.bs-case__data {
  font-size: 2rem;
}
@media only screen and (max-width: 559px) {
  .bs-case__data {
    font-size: 1.2rem;
  }
}
.bs-case__ttl {
  color: var(--mainColor);
  font-size: 3.2rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--mainColor);
  margin-bottom: 2.5rem;
  letter-spacing: 0;
}
@media only screen and (max-width: 559px) {
  .bs-case__ttl {
    font-size: 2rem;
    line-height: 1.3;
  }
}
.bs-case__label {
  font-size: 1.7rem;
  width: fit-content;
  border-radius: calc(infinity * 1px);
  padding: 0.8rem 1.7rem;
  line-height: 1;
  color: var(--colorW);
  display: block;
  margin-bottom: 2rem;
}
@media only screen and (max-width: 559px) {
  .bs-case__label {
    font-size: 1.4rem;
    margin-bottom: 1rem;
  }
}
.bs-case__label.bg-gr {
  background-color: var(--baseColor);
}
.bs-case__list-item {
  font-size: 1.6rem;
  line-height: 1.5;
  display: flex;
}
@media only screen and (max-width: 559px) {
  .bs-case__list-item {
    font-size: 1.4rem;
  }
}
.bs-case__list-item::before {
  content: "・";
}
.bs-case__list-item:not(:last-child) {
  margin-bottom: 3rem;
}
@media only screen and (max-width: 559px) {
  .bs-case__list-item:not(:last-child) {
    margin-bottom: 1rem;
  }
}
.bs-case__result {
  font-size: 2rem;
  color: var(--mainColor);
  line-height: 1.45;
  margin-top: 3.5rem;
}
@media only screen and (max-width: 559px) {
  .bs-case__result {
    font-size: 1.6rem;
    margin-bottom: 0rem;
  }
}

.box {
  margin-bottom: 0;
  background-color: transparent;
  border: none;
  box-shadow: none;
}

.wide {
  position: relative;
  width: 100vw;
  left: 50%;
  transform: translateX(-50%);
}

.table-bordered span.required {
  background: var(--mainColor);
  color: var(--colorW) !important;
}

footer.main-footer {
  border-top: none;
}

.modal-open {
  overflow: visible;
}

.page-detail-top .content-header {
  display: none;
}

/*under-header*/
.content-header {
  margin-bottom: 0;
  border-bottom: none;
}

select::placeholder {
  color: #b6b7b7;
}

input,
select,
textarea,
button,
label {
  font-family: inherit !important;
}

.account-page [class^=icon-],
[class*=" icon-"] {
  font-family: inherit !important;
  font-size: 0.9em;
}

.top-mv img {
  width: 100vw;
}

/*-----------------------

         COMMON

-----------------------*/
.container, .wrapper {
  padding: 0 2rem;
  min-height: auto;
}

input, select, textarea, button, label {
  font-family: inherit !important;
}

.account-page [class^=icon-], [class*=" icon-"] {
  font-family: inherit !important;
  font-size: 0.9em;
}

.top-mv img {
  width: 100vw;
}

.col-lg-12.detail.fr-element.fr-view a {
  text-decoration: none;
}

@media screen and (max-width: 1024px) {
  footer.main-footer ul li a {
    font-size: 1.2rem !important;
  }
}
@media only screen and (max-width: 559px) {
  header .mypage.login {
    width: 100% !important;
  }
}
/*drawer*/ /*---------------数値など任意で書き換えを行う----------------------*/
.drawer-hamburger {
  width: 6rem;
  height: 2rem;
}

.drawer--right .drawer-hamburger,
.drawer--right.drawer-open .drawer-hamburger {
  background-color: transparent;
  right: 0.8rem;
  top: 0.8rem;
}

.drawer-hamburger-icon,
.drawer-hamburger-icon:before,
.drawer-hamburger-icon:after,
.drawer--left.drawer-open .drawer-hamburger-icon {
  background-color: var(--mainColor);
  height: 0.5rem;
}

.drawer-hamburger-icon {
  background-color: transparent;
}

.drawer-hamburger-icon:after {
  background-color: var(--mainColor);
  width: 80%;
}

.drawer-open .drawer-hamburger-icon:after {
  width: 100%;
}

.drawer--right.drawer-open .drawer-hamburger {
  z-index: 9999;
  background: none;
}

.drawer-hamburger .text {
  margin-top: 1.6rem;
  font-size: clamp(1.14rem, 0.943rem + 0.524vw, 1.95rem);
  text-align: center;
  font-weight: 500;
  letter-spacing: 0.05em;
}

.drawer--right .drawer-nav .drawer-hamburger .text {
  text-align: center;
}

.drawer--right .drawer-nav {
  width: 100%;
  right: -100%;
  z-index: 1000;
  padding: 2.5rem 14rem 3vw 3.5rem;
  background: #fff;
}

.drawer--right .drawer-nav::-webkit-scrollbar {
  display: none;
}

.drawer--right .drawer-nav .mypage a {
  color: var(--baseColor);
}

.drawer--right .drawer-nav .mypage img:first-child {
  top: 0;
}

.drawer--right .drawer-nav .wrapper {
  padding: 6rem 0;
}

.drawer--right .drawer-nav .flex-c {
  gap: 6vw;
}

.drawer--right .drawer-nav .drawer-menu {
  flex-direction: column;
  margin-top: 0;
}

.drawer--right .drawer-nav .drawer-menu li.hover {
  padding: 2.5rem 0 1rem;
  position: relative;
}

.drawer--right .drawer-nav .drawer-menu a {
  font-size: 2rem;
  font-weight: 500;
  color: var(--baseColor);
  padding: 2.5rem 0 1rem;
}

.drawer--right .drawer-nav .drawer-menu.hover a {
  font-size: 1.5rem;
  font-weight: 500;
}

.drawer--right .drawer-nav .drawer-menu.second {
  margin-top: 1.5rem;
}

.drawer--right .drawer-nav .drawer-menu.second a {
  padding: 1rem 0;
  font-size: 1.5rem;
}

.drawer-open .drawer-nav .sub-menu {
  /*    transition: .4s;*/
  visibility: hidden;
  opacity: 0;
  position: absolute;
  padding: 1rem 2rem 2.5rem;
  background: var(--mainColor);
  width: 32rem;
}

.drawer--right header .drawer-nav .drawer-menu li ul.sub-menu {
  position: absolute;
  top: 6rem;
  left: 0;
}

.drawer-open .drawer-nav li a.on + .sub-menu {
  transition: 0.4s;
  visibility: visible;
  opacity: 1;
}

.drawer-open .drawer-nav li a.on + .sub-menu a {
  color: #fff;
  letter-spacing: 0.05em;
  font-size: 1.7rem;
  text-align: center;
  display: block;
}

.drawer-open .drawer-nav li a.on + .sub-menu li:not(:last-child) {
  border-bottom: dashed 1px #fff;
}

.drawer-menu-item:hover {
  text-decoration: none;
}

.drawer--right.drawer-open .drawer-nav {
  right: 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overflow-x: hidden;
}

@media only screen and (max-width: 559px) {
  .drawer--right .drawer-hamburger,
  .drawer--right.drawer-open .drawer-hamburger {
    background: #18bde7;
    background: linear-gradient(90deg, rgb(24, 189, 231) 0%, rgb(23, 42, 136) 100%);
    width: 6.4rem;
    height: 6.4rem;
    border-radius: 50%;
    padding: 0;
    top: 0.8rem;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .drawer-hamburger-icon,
  .drawer-hamburger-icon:before,
  .drawer-hamburger-icon:after,
  .drawer--left.drawer-open .drawer-hamburger-icon {
    height: 1px;
    width: 3.2rem;
  }
  .drawer-hamburger-icon {
    margin-top: 0;
  }
  .drawer-hamburger-icon:after {
    top: -6px;
    background-color: var(--colorW);
  }
  .drawer-hamburger-icon:before {
    top: 6px;
    background-color: var(--colorW);
  }
  .drawer--right.drawer-open .drawer-nav {
    padding: 2.5rem 6% 3vw;
  }
}
.o-drawer__wrap {
  padding: 14.5rem 0 6rem;
  width: 1280px;
  margin: 0 auto;
  min-height: auto;
}
@media only screen and (max-width: 1440px) {
  .o-drawer__wrap {
    width: 100%;
    padding: 14.5rem 3rem 6rem;
  }
}
@media only screen and (max-width: 559px) {
  .o-drawer__wrap {
    padding: 0;
  }
}
.o-drawer__menu {
  display: flex;
  flex-direction: column;
  color: var(--baseColor);
}
.o-drawer__menu__item {
  font-size: 1.8rem;
  letter-spacing: 0.05em;
}
.o-drawer__menu__item:not(:last-child) {
  margin-bottom: 2rem;
}
.o-drawer__menu__item--second:not(:last-child) {
  margin-bottom: 1rem;
}
.o-drawer__menu__link {
  color: var(--colorW);
}
.o-drawer__menu__link--second {
  padding: 0;
  font-size: 1.2rem;
  color: var(--colorW);
}

.o-drawer__submenu {
  transition: display 0.3s ease;
  visibility: hidden;
  opacity: 0;
  position: absolute;
  padding: 1rem 2rem 2.5rem;
  background-color: rgba(62, 58, 57, 0.9);
  width: 200%;
  border-radius: 1.3rem;
}
.o-drawer__submenu__item {
  color: var(--colorW);
  font-size: 1.6rem;
  padding: 2rem 0 1rem;
  display: block;
  font-weight: 400;
  letter-spacing: 0.05em;
  text-align: center;
}
.o-drawer__submenu__item:not(:last-child) {
  border-bottom: 1px dashed var(--colorW);
}

.drawer--right .o-drawer__submenu {
  position: absolute;
  top: 2.9rem;
  left: 50%;
  transform: translateX(-50%);
}

.drawer-open .drawer-nav li a.on + .sub-menu {
  transition: 0.4s;
  visibility: visible;
  opacity: 1;
}
.drawer-open .drawer-nav li a.on + .sub-menu a {
  color: #fff;
  letter-spacing: 0.05em;
  font-size: 1.7rem;
  text-align: center;
  display: block;
}
.drawer-open .drawer-nav li a.on + .sub-menu li:not(:last-child) {
  border-bottom: dashed 1px #fff;
}

.o-drawer-menu-item:hover {
  text-decoration: none;
}

.drawer--right.drawer-open .drawer-nav {
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overflow-x: hidden;
  height: 100%;
}

.drawer-open .drawer-nav li a.on + .o-drawer__submenu__item {
  transition: 0.4s;
  visibility: visible;
  opacity: 0.9;
  opacity: 1;
}

.o-drawer__submenu {
  display: none;
  transition: 0.5s;
}

.o-drawer__submenu.active {
  display: block;
  z-index: 600;
  visibility: visible;
  opacity: 1;
}

.o-drawer__menu__item {
  position: relative;
  color: var(--baseColor);
  text-align: left;
}

.js-menu__item__link.on + .o-drawer__submenu {
  display: block;
}

@media only screen and (max-width: 559px) {
  .drawer--right .drawer-nav .flex-c {
    flex-direction: column;
    gap: 2.2rem;
  }
  .drawer--right.drawer-open .drawer-nav {
    padding: 1.2rem 1rem 8rem;
    background: linear-gradient(90deg, rgb(24, 189, 231) 0%, rgb(23, 42, 136) 100%);
  }
  .o-drawer__flex {
    display: flex;
    gap: 1.5rem;
    justify-content: center;
    padding-block: 2.5rem;
    padding-inline: 2rem;
  }
  .o-drawer__flex img {
    width: 100%;
  }
  .o-drawer__wrap {
    padding-inline: 2rem;
  }
  .o-drawer__menu__link,
  .o-drawer .js-menu__item__link {
    font-size: 1.4rem;
    color: var(--colorW);
  }
  .o-drawer .o-drawer__menu__item--second {
    line-height: 1;
    text-align: left;
  }
  .o-drawer__submenu__link {
    font-size: 1.4rem;
    color: var(--colorW);
  }
  .o-drawer__menu--second {
    margin-top: 0;
  }
  .o-drawer__menu__item:not(:last-child) {
    padding-bottom: 1.5rem;
    margin-bottom: 1rem;
  }
  .o-drawer__menu__item--second:not(:last-child) {
    margin-bottom: 0.5rem;
  }
  .drawer--right .o-drawer__submenu {
    width: 80%;
    padding: 1rem 2rem 1.5rem;
  }
  .o-drawer__submenu__item {
    padding: 1.5rem 0 0.5rem;
  }
  .o-drawer__submenu__item:last-child {
    padding-bottom: 0;
  }
  .drawer--right .drawer-nav {
    padding: 1.5rem 1rem 3vw;
  }
  .l-hdr__login {
    padding-bottom: 2rem;
    border-bottom: 1px solid;
    margin-bottom: 4rem;
  }
}
.drawer-nav {
  width: 100%;
}

.o-drawer__submenu {
  background: #18bde7;
  background: linear-gradient(90deg, rgba(24, 189, 231, 0.9) 0%, rgba(23, 42, 136, 0.9) 100%);
}

.o-drawer__menu__link {
  color: var(--colorW);
}

.primary-ttl {
  font-size: 16rem;
  font-family: var(--jost);
  line-height: 1.2;
  margin-bottom: 0.5rem;
  font-weight: 500;
  position: relative;
}
@media only screen and (max-width: 559px) {
  .primary-ttl {
    font-size: 6.6rem;
    text-align: center;
    margin-bottom: 0;
  }
}
.primary-ttl__sub {
  font-size: 2rem;
  color: var(--mainColor);
  line-height: 1.75;
  letter-spacing: 0.05em;
  margin-top: -3rem;
}
@media only screen and (max-width: 559px) {
  .primary-ttl__sub {
    font-size: 1.2rem;
    text-align: center;
  }
}
@media only screen and (max-width: 559px) and (max-width: 559px) {
  .primary-ttl__sub {
    margin-top: 0;
  }
}
.primary-ttl__area {
  margin-bottom: 6.5rem;
  position: relative;
}
@media only screen and (max-width: 559px) {
  .primary-ttl__area {
    margin-bottom: 10.5rem;
  }
}
.primary-ttl__wrap {
  position: absolute;
  bottom: 7rem;
  left: 0;
  display: flex;
  gap: 5.5rem;
  align-items: center;
}
@media only screen and (max-width: 559px) {
  .primary-ttl__wrap {
    gap: 2rem;
    flex-direction: column;
    justify-content: center;
    width: 100%;
    bottom: -8rem;
  }
}
.primary-ttl__mark {
  position: relative;
  left: -13rem;
}
@media only screen and (max-width: 559px) {
  .primary-ttl__mark {
    left: 0;
    width: 11.3rem;
    height: 18.6rem;
  }
}
.primary-ttl__mark--2 {
  left: 40%;
}
@media only screen and (max-width: 559px) {
  .primary-ttl__mark--2 {
    left: 50%;
    transform: translateX(-50%);
  }
}

.secondary-ttl {
  color: var(--mainColor);
  font-size: 3.6rem;
  line-height: 1;
  border-left: 9px solid var(--mainColor);
  padding-left: 1.5rem;
}
@media only screen and (max-width: 559px) {
  .secondary-ttl {
    font-size: 2.4rem;
    padding-left: 1rem;
    border-left: 5px solid var(--mainColor);
  }
}

.tertiary-ttl {
  font-size: 3.7rem;
  letter-spacing: 0.05em;
  color: var(--mainColor);
  line-height: 1;
  margin-bottom: 5.5rem;
}
@media only screen and (max-width: 559px) {
  .tertiary-ttl {
    font-size: 2.4rem;
    margin-bottom: 3rem;
  }
}
.tertiary-ttl__area {
  text-align: center;
}
.tertiary-ttl__img {
  margin-bottom: 2.5rem;
}
@media only screen and (max-width: 559px) {
  .tertiary-ttl__img {
    transform: scale(0.7);
    margin-bottom: 0.5rem;
  }
}

.quaternary-ttl {
  font-family: var(--jost);
  width: fit-content;
  font-size: 7.7rem;
  margin-top: -12rem;
  line-height: 1;
  margin-bottom: 0.4rem;
}
@media only screen and (max-width: 559px) {
  .quaternary-ttl {
    font-size: 4rem;
    margin-top: -10rem;
  }
}
.quaternary-ttl--center {
  font-size: 9.8rem;
  margin-inline: auto;
  margin-top: -18rem;
}
@media only screen and (max-width: 559px) {
  .quaternary-ttl--center {
    font-size: 4rem;
  }
}
.quaternary-ttl__sub {
  color: var(--mainColor);
  font-size: 2.2rem;
  letter-spacing: 0.05em;
  margin-top: -1rem;
}
@media only screen and (max-width: 559px) {
  .quaternary-ttl__sub {
    font-size: 1.4rem;
    margin-top: 0;
  }
}
.quaternary-ttl__sub--center {
  font-size: 2.4rem;
  text-align: center;
}
@media only screen and (max-width: 559px) {
  .quaternary-ttl__sub--center {
    font-size: 1.4rem;
  }
}
.quaternary-ttl__img {
  position: relative;
  left: -8rem;
}
@media only screen and (max-width: 559px) {
  .quaternary-ttl__img {
    left: -2rem;
  }
}
.quaternary-ttl__img--center {
  left: 0;
}
.quaternary-ttl__area {
  margin-bottom: 7rem;
}
@media only screen and (max-width: 559px) {
  .quaternary-ttl__area {
    margin-bottom: 5.5rem;
  }
}
.quaternary-ttl__area--center {
  text-align: center;
}

.quinary-ttl {
  font-size: 3.2rem;
  letter-spacing: 0.05em;
  color: var(--mainColor);
}
@media only screen and (max-width: 559px) {
  .quinary-ttl {
    font-size: 2.2rem;
  }
}
.quinary-ttl__area {
  display: flex;
  align-items: baseline;
  margin-bottom: 3.5rem;
  gap: 1rem;
  padding-left: 1.5rem;
  position: relative;
}
@media only screen and (max-width: 559px) {
  .quinary-ttl__area {
    margin-bottom: 2.5rem;
  }
}
.quinary-ttl__area::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 0.7rem;
  height: 100%;
  background: linear-gradient(90deg, rgb(24, 189, 231) 0%, rgb(23, 42, 136) 100%);
}
.quinary-ttl__en {
  font-family: var(--jost);
  font-family: 2rem;
}
@media only screen and (max-width: 559px) {
  .quinary-ttl__en {
    font-size: 1.4rem;
  }
}

.senary-ttl {
  font-size: 3.6rem;
  color: var(--mainColor);
  text-align: center;
}
@media only screen and (max-width: 559px) {
  .senary-ttl {
    font-size: 2.2rem;
    line-height: 1.4;
    margin-bottom: 0.3rem;
  }
}
.senary-ttl__area {
  margin-bottom: 3rem;
  position: relative;
  text-align: center;
}
@media only screen and (max-width: 559px) {
  .senary-ttl__area {
    margin-bottom: 3rem;
  }
}
@media only screen and (max-width: 559px) {
  .senary-ttl__area img {
    width: 30%;
  }
}
.senary-ttl__sub {
  font-size: 2.4rem;
  text-align: center;
}
@media only screen and (max-width: 559px) {
  .senary-ttl__sub {
    font-size: 1.4rem;
  }
}
.senary-ttl__en {
  font-family: var(--jost);
}
.senary-ttl__cont {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: 50%;
  width: 100%;
}

.o-btn {
  padding: 0.3rem;
  background: #18bde7;
  background: linear-gradient(90deg, rgb(24, 189, 231) 0%, rgb(23, 42, 136) 100%);
  width: fit-content;
  border-radius: calc(infinity * 1px);
  position: relative;
}
@media only screen and (max-width: 559px) {
  .o-btn {
    width: 100%;
    padding: 0.2rem;
  }
}
.o-btn--center {
  margin-inline: auto;
}
.o-btn::after {
  content: "";
  background: url(../img/icon__right.svg) no-repeat center center/contain;
  width: 1.1rem;
  height: 1.4rem;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 2rem;
}
@media only screen and (max-width: 559px) {
  .o-btn::after {
    width: 0.9rem;
    height: 1.2rem;
  }
}
.o-btn__link {
  text-align: center;
  position: relative;
  background: linear-gradient(90deg, rgb(24, 189, 231) 0%, rgb(23, 42, 136) 100%);
  padding: 1.2rem 7rem;
  font-size: 2.4rem;
  color: #fff;
  margin: 0 auto;
  border-radius: 4rem;
  display: inline-block;
  background: var(--colorW);
  border-radius: calc(infinity * 1px);
}
@media only screen and (max-width: 559px) {
  .o-btn__link {
    font-size: 1.6rem;
    width: 100%;
    height: 6rem;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 1rem;
  }
}
.o-btn__link span {
  background: #18bde7;
  background: linear-gradient(90deg, rgb(24, 189, 231) 0%, rgb(23, 42, 136) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media only screen and (max-width: 559px) {
  .o-btn__link--small {
    font-size: 1.4rem;
    height: 5rem;
  }
}

.secondary-btn {
  background: #18bde7;
  background: linear-gradient(90deg, rgb(24, 189, 231) 0%, rgb(23, 42, 136) 100%);
  border-radius: calc(infinity * 1px);
  width: fit-content;
  width: 50.6rem;
  height: 9.6rem;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  margin-inline: auto;
}
@media only screen and (max-width: 559px) {
  .secondary-btn {
    width: 100%;
    height: 6rem;
  }
}
.secondary-btn::before {
  content: "";
  position: absolute;
  top: 0.3rem;
  right: 0.3rem;
  clip-path: polygon(30% 0, 100% 0, 100% 100%, 0% 100%);
  background-color: #ffffff;
  width: 9.4rem;
  height: calc(100% - 0.6rem);
  border-radius: 0 calc(infinity * 1px) calc(infinity * 1px) 0;
}
@media only screen and (max-width: 559px) {
  .secondary-btn::before {
    top: 0.2rem;
    right: 0.2rem;
    height: calc(100% - 0.4rem);
    width: 6rem;
  }
}
.secondary-btn::after {
  content: "";
  background: url(../img/icon__right.svg) no-repeat center center/contain;
  width: 1.6rem;
  height: 2rem;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 2.5rem;
}
@media only screen and (max-width: 559px) {
  .secondary-btn::after {
    width: 0.9rem;
    height: 1.2rem;
  }
}
.secondary-btn__link {
  font-weight: 500;
  font-size: 2.4rem;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 559px) {
  .secondary-btn__link {
    font-size: 1.6rem;
  }
}
.secondary-btn__link span {
  color: var(--colorW);
}

.o-card {
  display: grid;
  margin-bottom: 4rem;
}
@media only screen and (max-width: 559px) {
  .o-card {
    margin-bottom: 2.5rem;
  }
}
.o-card--2wrap {
  grid-template-columns: repeat(2, 1fr);
  gap: 6rem;
}
.o-card--3wrap {
  grid-template-columns: repeat(3, 1fr);
  gap: 4.5rem;
}
@media only screen and (max-width: 559px) {
  .o-card--3wrap {
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem;
  }
}
.o-card--4wrap {
  grid-template-columns: repeat(4, 1fr);
  gap: 3.5rem 3rem;
}
@media only screen and (max-width: 559px) {
  .o-card--4wrap {
    grid-template-columns: calc((100% - 2rem) / 2) calc((100% - 2rem) / 2);
    gap: 2rem;
  }
}

.o-flex {
  display: flex;
  gap: 6rem;
}
.o-flex--c {
  justify-content: center;
}
.o-flex--b {
  justify-content: space-between;
}
.o-flex--e {
  justify-content: flex-end;
}
.o-flex__item {
  width: calc((100% - 5rem) / 2);
}
.o-flex__item--1 {
  width: calc((100% - 5rem) / 3);
}
@media only screen and (max-width: 559px) {
  .o-flex__item--1 {
    width: 100%;
  }
}
.o-flex__item--2 {
  width: calc((100% - 5rem) / 3 * 2);
}
@media only screen and (max-width: 559px) {
  .o-flex__item--2 {
    width: 100%;
  }
}

/* slickslider共通 */ /*---------------数値など任意で書き換えを行う----------------------*/
.slick-track {
  margin-right: 0;
  margin-left: 0;
}

.slider li div, .slider2 li div {
  margin: 0 1.3vw;
}

.notice-slider li div, .media-slider li div, .topics-slider li div {
  margin: 0 1.3vw;
}

.slick-dotted.slick-slider {
  padding-bottom: 2rem;
}

.slick-dots {
  left: 50%;
  margin-top: 2rem;
  transform: translateX(-50%);
}

.slick-next, .slick-prev {
  top: calc(50% - 5rem) !important;
  z-index: 9999 !important;
  width: auto;
  height: auto;
  transform: translateY(-50%);
}

.slick-next::before, .slick-prev::before {
  color: var(--mainColor) !important;
  opacity: 0.7;
}

.slick-prev {
  left: 15.5vw !important;
}

.slick-next {
  right: 15.5vw !important;
}

.slider2 li p.cat {
  padding: 0.2rem 1rem 0;
  font-family: "Hind", sans-serif;
  font-size: clamp(1.2rem, 1.2vw, 1.4rem);
  color: #fff;
}

.slider2 li p.contents {
  display: -webkit-box;
  overflow: hidden;
  font-size: clamp(1.4rem, 1.4vw, 1.6rem);
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
}

.slider2 li .post-info {
  margin: 0 0 1rem;
}

.slider li figure, .slider2 figure {
  margin-bottom: 1rem;
  overflow: hidden;
}

.slider li figure img, .slider2 figure img {
  width: 100%;
  object-fit: cover;
  height: 11.3vw;
}

.slick-dots li button:before {
  color: #d3d3d3;
  opacity: 1;
  font-size: 1.6rem;
}

.slick-dots li.slick-active button:before {
  color: var(--mainColor);
}

.slick-no-current {
  transition: opacity 0.4s;
}

/*====================================================================
　モーダル/*---------------数値など任意で書き換えを行う---------------------
====================================================================*/
.modal {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1050;
  display: none;
  width: 100%;
  height: 100vh;
}

.modal__bg {
  position: absolute;
  width: 100%;
  height: 100vh;
  background: rgba(0, 0, 0, 0.8);
}

.modal__content1 {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 660px;
  height: 90vh;
  padding: 6.5rem 3.5rem 2.5rem;
  overflow-y: auto;
  background: #fff;
  transform: translate(-50%, -50%);
}

.modal__content1 .top-close {
  position: absolute;
  top: -1rem;
  right: 1.5rem;
}

.modal__content1 .bottom-close {
  position: relative;
  top: 1rem;
  left: -2rem;
}

.modal__content1 .top-close a, .modal__content1 .bottom-close a {
  display: block;
  font-size: 5rem;
  font-weight: 400;
  color: #787878;
}

/* modalの中身 */
.modal__content1 h2 {
  font-size: clamp(1.4rem, 1.23rem + 0.453vw, 2.1rem);
  letter-spacing: 0.05em;
  color: var(--mainColor);
}

.modal__content1 figure {
  aspect-ratio: 7/4;
  overflow: hidden;
  text-align: center;
  margin: 1.5rem 0 3rem;
  border-radius: 1rem;
}

.modal__content1 figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.modal__content1 h3 {
  font-size: clamp(2.3rem, 2.227rem + 0.31vw, 2.6rem);
  font-weight: 700;
  line-height: 1.3;
}

.modal__content1 .information {
  margin: 1.5rem 0 3rem;
  padding-bottom: 1.5rem;
  border-bottom: solid 1px var(--mainColor);
  align-items: center;
  gap: 1.5rem;
}

.modal__content1 p.area {
  font-size: clamp(1.4rem, 1.23rem + 0.453vw, 2.1rem);
  font-weight: 500;
  color: #fff;
  letter-spacing: 0.025em;
  line-height: 1;
  padding: 0.4rem 1rem 0.6rem;
  border-radius: 0.8rem;
  background: var(--mainColor);
}

.modal__content1 p.name {
  font-size: clamp(1.4rem, 1.23rem + 0.453vw, 2.1rem);
  font-weight: 500;
  letter-spacing: 0.025em;
}

.modal__content1 p.name span {
  margin-left: 0.5rem;
  font-size: clamp(1.2rem, 1.054rem + 0.388vw, 1.8rem);
  font-weight: 500;
}

.modal__content1 p.txt-area {
  line-height: 1.5;
}

/*====================================================================
.faq-wrap .accordion
====================================================================*/
.faq-wrap {
  max-width: 100rem;
  margin: 0 auto;
}

.faq-wrap .accordion_one .accordion_header {
  padding: 2rem 7rem 1rem 0;
  position: relative;
  z-index: 1;
  cursor: pointer;
  transition-duration: 0.2s;
  font-size: 1.8rem;
  display: flex;
  align-items: baseline;
  border-bottom: dotted 1px var(--base50Color);
  line-height: 1.5;
  letter-spacing: 0.1em;
}
@media only screen and (max-width: 559px) {
  .faq-wrap .accordion_one .accordion_header {
    font-size: 1.4rem;
    padding-right: 4rem;
  }
}

.faq-wrap .accordion_one .accordion_header::before {
  content: "Q:";
  margin-right: 1rem;
  font-size: 1.8rem;
  font-weight: 500;
  position: relative;
  top: -0.5rem;
  line-height: 1;
}
@media only screen and (max-width: 559px) {
  .faq-wrap .accordion_one .accordion_header::before {
    top: 0rem;
  }
}

.faq-wrap .accordion_one .accordion_header:hover {
  opacity: 0.8;
}

.faq-wrap .accordion_one .accordion_header .i_box {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 50%;
  right: 1%;
  width: 40px;
  height: 40px;
  margin-top: -20px;
  box-sizing: border-box;
  -webkit-transform: rotate(0deg);
  transform: rotate(0deg);
  transform-origin: center center;
  transition-duration: 0.2s;
}
@media only screen and (max-width: 559px) {
  .faq-wrap .accordion_one .accordion_header .i_box {
    width: 2.5rem;
    height: 2.5rem;
    margin-top: -1rem;
  }
}

.faq-wrap .accordion_one .accordion_header .i_box .one_i {
  display: block;
  width: 18px;
  height: 18px;
  -webkit-transform: rotate(0deg);
  transform: rotate(0deg);
  transform-origin: center center;
  transition-duration: 0.2s;
  position: relative;
}

.faq-wrap .accordion_one .accordion_header.open .i_box {
  -webkit-transform: rotate(180deg);
  transform: rotate(180deg);
}

.faq-wrap .accordion_one .accordion_header .i_box .one_i:before,
.faq-wrap .accordion_one .accordion_header .i_box .one_i:after {
  display: flex;
  content: "";
  background-color: var(--mainColor);
  border-radius: 10px;
  width: 26px;
  height: 3px;
  position: absolute;
  top: 7px;
  left: -4px;
  -webkit-transform: rotate(0deg);
  transform: rotate(0deg);
  transform-origin: center center;
}

.faq-wrap .accordion_one .accordion_header .i_box .one_i:before {
  width: 3px;
  height: 26px;
  top: -4px;
  left: 7px;
}

.faq-wrap .accordion_one .accordion_header.open .i_box .one_i:before {
  content: none;
}

.faq-wrap .accordion_one .accordion_header.open .i_box .one_i:after {
  -webkit-transform: rotate(0deg);
  transform: rotate(0deg);
}

.faq-wrap .accordion_one .accordion_inner {
  display: none;
  padding: 2rem 2.5rem;
  background: rgba(23, 42, 136, 0.05);
  box-sizing: border-box;
  margin-top: 1.5rem;
  border-radius: 1rem;
}

.faq-wrap .accordion_one .accordion_inner .answer {
  position: relative;
  display: flex;
  align-items: baseline;
}

.faq-wrap .accordion_one .accordion_inner .answer::before {
  content: "A:";
  margin-right: 1rem;
  font-size: 1.8rem;
  font-weight: 500;
  position: relative;
  line-height: 1;
}

.faq-wrap .accordion_one .accordion_inner .answer .answer-wrap p {
  font-size: clamp(1.4rem, 1.254rem + 0.388vw, 2rem);
  font-weight: 500;
  line-height: 1.5;
}

.faq-wrap .accordion_one .accordion_inner .answer .answer-wrap p a {
  text-decoration: underline;
}

/*-----------------------
　　　　　
　　　  よくあるご質問/*---------------数値など任意で書き換えを行う---------------------

-----------------------*/
.faq-wrap2.accordion_wrap .accordion_one .accordion_inner {
  display: none;
  padding: 0 2% 5rem;
}

.faq-wrap2.accordion_wrap .accordion_one .accordion_inner .question {
  padding: 2rem 7rem 1rem 0;
  position: relative;
  z-index: 1;
  cursor: pointer;
  transition-duration: 0.2s;
  font-size: clamp(1.4rem, 1.254rem + 0.388vw, 2rem);
  display: flex;
  align-items: center;
  border-bottom: solid 1px var(--mainColor);
  line-height: 1.5;
  letter-spacing: 0.1em;
}

.faq-wrap2.accordion_wrap .accordion_one .accordion_inner .question::before {
  content: "Q.";
  margin-right: 1rem;
  font-size: clamp(3rem, 2.636rem + 0.971vw, 4.5rem);
  font-weight: 500;
  position: relative;
  top: -0.5rem;
  line-height: 1;
}

.faq-wrap2.accordion_wrap .accordion_one .accordion_inner .question .i_box {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 50%;
  right: 1%;
  width: 40px;
  height: 40px;
  margin-top: -20px;
  box-sizing: border-box;
  -webkit-transform: rotate(0deg);
  transform: rotate(0deg);
  transform-origin: center center;
  transition-duration: 0.2s;
}

.faq-wrap2.accordion_wrap .accordion_one .accordion_inner .question .i_box .one_i {
  display: block;
  width: 18px;
  height: 18px;
  transform-origin: center center;
  transition-duration: 0.2s;
  position: relative;
}

.faq-wrap2.accordion_wrap .accordion_one .accordion_inner .question .i_box .one_i:before,
.faq-wrap2.accordion_wrap .accordion_one .accordion_inner .question .i_box .one_i:after {
  display: flex;
  content: "";
  background-color: var(--mainColor);
  border-radius: 10px;
  width: 26px;
  height: 3px;
  position: absolute;
  top: 7px;
  left: -4px;
  -webkit-transform: rotate(0deg);
  transform: rotate(0deg);
  transform-origin: center center;
}

.faq-wrap2.accordion_wrap .accordion_one .accordion_inner .question .i_box .one_i:before {
  width: 3px;
  height: 26px;
  top: -4px;
  left: 7px;
}

.faq-wrap2.accordion_wrap .accordion_one .accordion_inner .question.open .i_box {
  -webkit-transform: rotate(180deg);
  transform: rotate(180deg);
}

.faq-wrap2.accordion_wrap .accordion_one .accordion_inner .question.open .i_box .one_i:before {
  display: none;
}

.faq-wrap2.accordion_wrap .accordion_one .accordion_inner .question.open .i_box .one_i:after {
  -webkit-transform: rotate(0deg);
  transform: rotate(0deg);
}

.faq-wrap2 .accordion_one .accordion_inner .accordion_inner {
  display: none;
  padding: 3rem 3rem 2.5rem;
  background: var(--bg-p);
  box-sizing: border-box;
}

.faq-wrap2 .accordion_one .accordion_inner .accordion_inner .answer {
  position: relative;
  display: flex;
  align-items: flex-start;
}

.faq-wrap2 .accordion_one .accordion_inner .accordion_inner .answer::before {
  content: "A.";
  margin-right: 1rem;
  font-size: clamp(3rem, 2.636rem + 0.971vw, 4.5rem);
  font-weight: 500;
  position: relative;
  line-height: 1;
  color: var(--mainColor);
  top: -1.2rem;
}

.faq-wrap2 .accordion_one .accordion_inner .accordion_inner .answer .answer-wrap p {
  font-size: clamp(1.4rem, 1.254rem + 0.388vw, 2rem);
  font-weight: 500;
  line-height: 1.5;
}

.faq-wrap2 .accordion_one .accordion_inner .accordion_inner .answer .answer-wrap p a {
  text-decoration: underline;
}

@media screen and (max-width: 559px) {
  /*セレクトボックスの矢印カスタマイズ*/
  .shelf-nav-sp {
    width: 100%;
    margin: 3rem auto 0;
    position: relative;
  }
  .shelf-nav-sp::before {
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 1rem 0.7rem 0 0.7rem;
    border-color: var(--mainColor) transparent transparent transparent;
    position: absolute;
    top: 55%;
    right: 1.5rem;
    transform: translateY(-50%);
    pointer-events: none;
  }
  .breadcrumb.form-control {
    width: 100%;
    padding: 1rem;
    /*デフォルトの矢印を削除*/
    -webkit-appearance: none;
    appearance: none;
  }
  /*サファリのフォームで入力時にズームしないようにする*/
  input,
  textarea,
  select {
    font-size: 20px;
    transform: scale(0.8);
  }
  /* ボタンは小さくしないように */
  input[type=submit],
  input[type=button] {
    font-size: 16px;
    transform: scale(1);
  }
  /* プルダウンは小さくしないように */
  select {
    font-size: 20px;
    transform: scale(1);
  }
}
/*-----------------------

       header /*---------------数値など任意で書き換えを行う---------------------

-----------------------*/
header {
  padding: 2.5rem 14rem 1.5rem 3.5rem;
}

.hdr-inner {
  justify-content: space-between;
  align-items: flex-start;
}

.navi {
  justify-content: flex-end;
}

p.login img {
  margin-right: 0.5rem;
  width: 24px;
  height: 24px;
  border-radius: 50%;
}

header nav {
  margin-top: -4rem;
}

header nav ul > li {
  position: relative;
}

header nav ul > li a {
  font-weight: 500;
  font-size: 1.8rem;
  position: relative;
}

/* カートの表示 ozaki ↓ */
header .right-Area {
  gap: 2rem;
}

header .right-Area .cart-area a {
  gap: 1rem;
  align-items: center;
}

header .right-Area .cart-area p {
  background: var(--mainColor);
  color: #fff;
  border-radius: 2rem;
  padding: 0.3rem 1rem 0.5rem;
  line-height: 1;
}

/* カートの表示 ozaki ↑ */
/*---------ドロワーのアコーディオン調整--------*/
header .linkG {
  position: relative;
  display: flex;
  justify-content: center;
}

.right-Area {
  position: relative;
  overflow: visible; /* ul がはみ出すのを許可 */
  cursor: pointer; /* マウスカーソル */
}

.mypage-list {
  display: none;
  position: absolute;
  top: 3.5rem;
  right: 0;
  font-size: 1em;
  padding: 0rem 1.8rem 1rem;
  border-radius: 0.8rem;
  z-index: 100;
  white-space: nowrap; /* 折り返さず横に伸びる */
  width: max-content; /* 中身に応じて広がる */
  min-width: 100%; /* 親と同じ以上にはなるように */
  overflow: visible; /* 子要素のはみ出し許可 */
}

.mypage-list::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--baseColor);
  opacity: 0.9;
  z-index: -1;
  border-radius: 0.8rem;
}

.mypage-item {
  border-bottom: 1px dashed #fff;
  padding: 0 0.5rem;
}

.mypage-item a {
  display: block;
  padding: 1.8rem 0 1rem;
  color: #fff;
  letter-spacing: 0.05em;
  font-weight: 500;
  font-size: 1.4rem;
  text-align: center;
  position: relative;
}

.loginBtn .img-circle {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  vertical-align: middle; /* これが重要！ */
}

.mypage.loginBtn.flex {
  display: flex;
  align-items: center;
  gap: 0.5rem; /* 画像とテキストの間隔調整（任意） */
}

@media screen and (max-width: 1440px) {
  header nav ul > li a {
    font-size: 1.6rem;
  }
}
.menu-arrow-b {
  margin-left: 1rem;
  color: var(--mainColor);
}

header nav ul > li a img {
  vertical-align: baseline;
  margin-left: 1rem;
}

header nav ul > li:not(:last-child) a::after {
  content: "/";
  padding: 0 1.5rem;
}

header nav ul.sub-menu > li a::after {
  display: none;
}

/*サブメニュー*/
header .flex.navi li {
  position: relative;
}

header .flex.navi li ul.sub-menu {
  display: none;
  position: absolute;
  top: 3.4rem;
  left: 50%;
  transform: translateX(-50%);
  font-size: 1em;
  padding: 0rem 1.8rem 1rem;
  border-radius: 0.8rem;
  z-index: 9999;
  background: transparent;
  white-space: nowrap;
  width: max-content;
  min-width: 100%;
  overflow: visible;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.4s ease, visibility 0.4s ease;
}

header .flex.navi li:hover ul.sub-menu {
  display: block;
  opacity: 1;
  visibility: visible;
}

/* 背景の半透明ボックス */
header .flex.navi li ul.sub-menu::before {
  content: "";
  position: absolute;
  inset: 0;
  background-color: var(--mainColor);
  opacity: 0.9;
  z-index: -1;
  border-radius: 0.8rem;
}

header .flex.navi li ul.sub-menu li {
  border-bottom: 1px dashed #fff;
  padding: 0 0.5rem;
  width: 100%;
}

header .flex.navi li ul.sub-menu li:last-child {
  border-bottom: none;
}

header .flex.navi li ul.sub-menu li a {
  display: block;
  padding: 1.8rem 0 1rem;
  color: #fff;
  letter-spacing: 0.05em;
  font-weight: 500;
  font-size: 1.6rem;
  text-align: center;
}

/* 不要な装飾を無効化 */
header .flex.navi li ul li:first-child {
  border-left: none;
}

header .flex.navi li ul.sub-menu li a::after {
  display: none;
}

header .flex.navi li.current-menu-item ul li::after {
  border-bottom: none;
}

header p.login,
header .mypage.loginBtn p {
  font-size: 1.6rem;
}

/* ロゴアイコンの表示を調整 */
header h1 img,
header p.logo img {
  height: auto;
  width: 16vw;
  max-width: 30rem;
}

header .navi .flex {
  flex-wrap: wrap;
  justify-content: end;
  line-height: 2.1;
  max-width: 72vw;
}

@media screen and (max-width: 1440px) {
  header .navi .flex {
    flex-wrap: wrap;
    justify-content: center;
    max-width: 100vw;
  }
}
header {
  padding: 0 !important;
  min-height: inherit !important;
  position: relative;
}

.hdr-inner {
  position: absolute;
  top: 3.5rem;
  left: 3.2rem;
  z-index: 100;
}

.navi {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 100;
}

header .navi .flex {
  flex-direction: column;
  background: rgba(255, 255, 255, 0.9);
  padding: 6rem 4.8rem 5rem 4.3rem;
  border-radius: 0 0 0 6rem;
  text-align: right;
}

header h1 img,
header p.logo img {
  width: 78.5rem;
  height: 6.5rem;
  max-width: inherit;
}

header nav ul > li:not(:last-child) a::after {
  display: none;
}

header nav ul > li a {
  color: var(--baseColor);
  font-size: 1.8rem;
  letter-spacing: 0;
  line-height: 1;
}

header nav ul > li a span {
  color: var(--mainColor);
}

.hdr-en {
  font-family: var(--jost);
  color: var(--base50Color);
  font-size: 1.4rem;
  letter-spacing: 0.05em;
  display: block;
  margin-top: -0.5rem;
  font-weight: 400;
}

header .flex.navi li:not(:last-child) {
  margin-bottom: 0.1rem;
}

.hdr-br {
  display: block;
  margin-top: -2.1rem;
}

@media only screen and (max-width: 559px) {
  .hdr-inner {
    top: 1rem;
    left: 1rem;
  }
}

/*-----------------------

      footer/*---------------数値など任意で書き換えを行う---------------------

-----------------------*/
footer.main-footer {
  padding: 4.5rem 0 0;
  margin-top: 9rem;
  border-top: none;
}

footer .sns-icon-Wrap {
  padding: 5rem 0 7rem;
  gap: 4.5rem;
}

footer .ftr-bottom-Area {
  padding: 5rem 0 2.5rem;
}

footer .ftr-bottom-Area ul {
  margin-bottom: 4rem;
  gap: 4rem;
}

footer .ftr-bottom-Area ul li a {
  color: #fff;
}

footer.main-footer p.copy {
  padding: clamp(4.5rem, 3.65rem + 2.265vw, 8rem) 0 2rem;
}

footer.main-footer p.copy small {
  font-weight: 700;
  font-size: clamp(1.2rem, 0.957rem + 0.647vw, 2.2rem);
  color: var(--colorW);
}

.ftr-navi ul {
  display: flex;
  justify-content: center;
  gap: 2rem; /* 項目の間隔（必要に応じて調整） */
  padding: 0;
  list-style: none;
}

.ftr-navi li {
  display: inline-block;
}

.ftr-navi a {
  text-decoration: none;
  color: var(--baseColor);
  font-size: 0.8em; /* お好みで */
}

.ftr-navi i {
  margin-right: 4px; /* アイコンとテキストの間のスペース */
}

.copylight strong {
  color: var(--baseColor) !important;
  font-size: 0.77em;
  font-weight: 500;
}

footer p.logo {
  padding-top: 2rem;
  max-width: 20rem;
  margin: 0 auto;
}

.l-ftr__wrap {
  width: 53rem;
  margin-inline: auto;
  padding-top: 10rem;
  padding-bottom: 1.5rem;
  position: relative;
}
@media only screen and (max-width: 559px) {
  .l-ftr__wrap {
    width: 100%;
    padding: 5rem 2rem 1rem;
  }
}
.l-ftr__wrap::after {
  content: "";
  background: url(../img/mark__img02.svg) no-repeat center center/contain;
  width: 25.6rem;
  height: 42.1rem;
  position: absolute;
  bottom: 0;
  right: -7rem;
  pointer-events: none;
}
@media only screen and (max-width: 559px) {
  .l-ftr__wrap::after {
    right: 1.5rem;
    width: 15.3rem;
    height: 25.3rem;
  }
}
.l-ftr__sns {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 4rem;
  margin-bottom: 6.5rem;
}
@media only screen and (max-width: 559px) {
  .l-ftr__sns {
    gap: 3rem;
    margin-bottom: 4rem;
  }
}
.l-ftr__group {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 4.5rem;
  gap: 1.5rem;
}
@media only screen and (max-width: 559px) {
  .l-ftr__group {
    gap: 0.8rem;
    margin-bottom: 3rem;
  }
}
.l-ftr__logo {
  text-align: center;
  margin-bottom: 1rem;
}
@media only screen and (max-width: 559px) {
  .l-ftr__logo {
    margin-bottom: 0;
  }
}
@media only screen and (max-width: 559px) {
  .l-ftr__logo img {
    width: 19rem;
    height: auto;
  }
}
.l-ftr__copy {
  text-align: center;
}
.l-ftr__copy small {
  color: var(--colorW);
  font-family: var(--jost);
  font-size: 1.4rem;
  letter-spacing: 0.2em;
  font-weight: 500;
}
@media only screen and (max-width: 559px) {
  .l-ftr__copy small {
    font-size: 1rem;
  }
}

.t-hero {
  margin-bottom: 20rem;
}
@media only screen and (max-width: 559px) {
  .t-hero {
    margin-bottom: 10rem;
  }
}
.t-hero__wrap {
  position: relative;
}
.t-hero video {
  width: 100%;
  height: 100svh;
  object-fit: cover;
}
@media only screen and (max-width: 559px) {
  .t-hero video {
    height: 60rem;
  }
}
.t-hero__cont {
  position: absolute;
  left: 0;
  top: 39.4%;
  top: inherit;
  bottom: 28%;
}
@media only screen and (max-width: 1440px) {
  .t-hero__cont {
    bottom: 17%;
  }
}
@media only screen and (max-width: 1280px) {
  .t-hero__cont {
    bottom: 15%;
  }
}
@media only screen and (max-width: 559px) {
  .t-hero__cont {
    bottom: inherit;
    top: 37%;
  }
}
.t-hero__ttl {
  position: relative;
}
.t-hero__ttl span {
  background: #18bde7;
  background: linear-gradient(90deg, rgba(24, 189, 231, 0.65) 0%, rgba(23, 42, 136, 0.65) 100%);
  color: var(--colorW);
  font-size: 14.8rem;
  font-size: clamp(5rem, calc(2.6213592233rem + 6.3430420712vw), 14.8rem);
  letter-spacing: 0;
  line-height: 1;
  font-weight: 500;
  display: inline-block;
  padding: 0.5rem 0.5rem 1.5rem 1.5rem;
}
@media only screen and (max-width: 559px) {
  .t-hero__ttl span {
    font-size: 5rem;
    padding: 0rem 0.5rem 0rem 0.7rem;
  }
}
.t-hero__ttl span:not(:last-child) {
  margin-bottom: 2rem;
}
@media only screen and (max-width: 559px) {
  .t-hero__ttl span:not(:last-child) {
    margin-bottom: 1.5rem;
  }
}
.t-hero__ttl::before {
  content: "";
  background: url(../img/t-hero__text02.webp) no-repeat center center/contain;
  position: absolute;
  left: 43.8%;
  top: 25.2%;
  width: 28.6458333333vw;
  height: 4.1666666667vw;
}
@media only screen and (min-width: 1921px) {
  .t-hero__ttl::before {
    width: 55rem;
    height: 8rem;
  }
}
@media only screen and (max-width: 559px) {
  .t-hero__ttl::before {
    width: 25.8rem;
    height: 3.4rem;
    left: 0;
    top: inherit;
    bottom: -4.8rem;
  }
}
.t-hero__ttl::after {
  content: "";
  background: url(../img/t-hero__text01.webp) no-repeat center center/contain;
  width: 62rem;
  height: 26.2rem;
  position: absolute;
  top: 65%;
  left: 76.7%;
  width: 32.2916666667vw;
  height: 13.6458333333vw;
}
@media only screen and (max-width: 1440px) {
  .t-hero__ttl::after {
    top: 70%;
  }
}
@media only screen and (max-width: 1024px) {
  .t-hero__ttl::after {
    left: 75%;
    top: 75%;
  }
}
@media only screen and (max-width: 559px) {
  .t-hero__ttl::after {
    width: 31rem;
    height: 13rem;
    left: 23%;
    top: 86%;
    top: inherit;
    top: 123%;
  }
}

.t-thought {
  position: relative;
  margin-bottom: 11rem;
}
@media only screen and (max-width: 559px) {
  .t-thought {
    margin-bottom: 7rem;
  }
}
.t-thought::after {
  content: "";
  background: url(../img/mark__img01.svg) no-repeat center center/contain;
  width: 54.6rem;
  height: 89.8rem;
  position: absolute;
  bottom: 3rem;
  left: 50%;
  transform: translateX(-50%);
}
@media only screen and (max-width: 559px) {
  .t-thought::after {
    width: 33rem;
    height: 54.2rem;
    bottom: inherit;
    top: 56%;
    transform: translate(-50%, -50%);
  }
}
.t-thought__ttl {
  text-align: center;
  font-size: 5.6rem;
  line-height: 1;
  margin-bottom: 3rem;
  font-weight: 500;
  margin-top: -17.5rem;
}
@media only screen and (max-width: 559px) {
  .t-thought__ttl {
    font-size: 3rem;
    margin-top: -9.5rem;
    margin-bottom: 1.5rem;
  }
}
.t-thought__deco {
  font-size: 16.6vw;
  background: #18bde7;
  background: linear-gradient(90deg, rgba(24, 189, 231, 0.15) 0%, rgba(23, 42, 136, 0.15) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  letter-spacing: 0;
  font-weight: 500;
  line-height: 1.2;
  font-family: var(--jost);
}
@media only screen and (max-width: 559px) {
  .t-thought__deco {
    font-size: 9.4rem;
    line-height: 0.8;
    font-weight: 500;
  }
}
.t-thought__ttlen {
  color: var(--mainColor);
  text-align: center;
  font-family: var(--jost);
  font-size: 2.4rem;
  line-height: 1;
  margin-bottom: 10.5rem;
}
@media only screen and (max-width: 559px) {
  .t-thought__ttlen {
    font-size: 1.4rem;
    margin-bottom: 6rem;
  }
}
.t-thought__textarea {
  padding-bottom: 6rem;
}
@media only screen and (max-width: 559px) {
  .t-thought__textarea {
    padding-bottom: 0;
  }
}
.t-thought__text {
  text-align: center;
  font-size: 2rem;
  line-height: 2.7;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 559px) {
  .t-thought__text {
    font-size: 1.6rem;
    line-height: 2;
    text-align: left;
  }
}
.t-thought__text:not(:last-child) {
  margin-bottom: 6rem;
}
@media only screen and (max-width: 559px) {
  .t-thought__text:not(:last-child) {
    margin-bottom: 3rem;
  }
}

.t-slide {
  overflow: hidden;
  margin-bottom: 16rem;
}
@media only screen and (max-width: 559px) {
  .t-slide {
    margin-bottom: 8rem;
  }
}
.t-slide__track {
  display: flex;
  width: max-content;
  animation: slideLoop 60s linear infinite;
}
.t-slide__track img {
  height: 37.7rem;
  width: auto;
  flex-shrink: 0;
}
@media only screen and (max-width: 559px) {
  .t-slide__track img {
    height: 22.6rem;
  }
}

/* アニメーション */
@keyframes slideLoop {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}
.t-solution {
  margin-bottom: 16rem;
}
@media only screen and (max-width: 559px) {
  .t-solution {
    margin-bottom: 8rem;
  }
}
@media only screen and (max-width: 559px) {
  .t-solution .primary-ttl__img {
    width: 10.3rem;
    height: 8.4rem;
  }
}
@media only screen and (max-width: 559px) {
  .t-solution .wrapper {
    display: contents;
  }
}
.t-solution__flex {
  gap: 5rem;
}
@media only screen and (max-width: 559px) {
  .t-solution__flex {
    flex-direction: column;
    gap: 0;
  }
}
.t-solution__item:not(:last-child) {
  margin-bottom: 13.5rem;
}
@media only screen and (max-width: 559px) {
  .t-solution__item:not(:last-child) {
    margin-bottom: 0;
  }
}
.t-solution__list {
  margin-bottom: 14rem;
}
@media only screen and (max-width: 559px) {
  .t-solution__list {
    margin-bottom: 7rem;
    display: flex;
    flex-direction: column;
    gap: 6.5rem;
  }
}
.t-solution__listttl {
  color: var(--mainColor);
  font-size: 3.2rem;
  font-weight: 700;
  margin-bottom: 3.5rem;
}
@media only screen and (max-width: 559px) {
  .t-solution__listttl {
    order: 1;
    font-size: 2rem;
    line-height: 1.3;
    display: flex;
    align-items: center;
    margin-bottom: 1.5rem;
  }
}
.t-solution__listttl span {
  font-family: var(--jost);
  color: var(--colorW);
  font-size: 4.4rem;
  font-weight: 500;
  width: 8.4rem;
  height: 8.4rem;
  border-radius: 50%;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-right: 1.5rem;
}
@media only screen and (max-width: 559px) {
  .t-solution__listttl span {
    width: 5rem;
    height: 5rem;
    font-size: 2.6rem;
  }
}
.t-solution__listsubttl {
  font-size: 2rem;
  font-family: var(--jost);
  letter-spacing: 0.2em;
  background-color: var(--baseColor);
  color: var(--colorW);
  width: fit-content;
  line-height: 1;
  padding: 0.4rem 1.2rem;
  margin-bottom: 2.5rem;
}
@media only screen and (max-width: 559px) {
  .t-solution__listsubttl {
    font-size: 1.4rem;
    padding: 0.2rem 0.7rem;
    margin-top: -1rem;
    position: relative;
    order: 3;
    margin-bottom: 1.5rem;
  }
}
.t-solution__listtext {
  color: var(--mainColor);
  font-size: 2rem;
  letter-spacing: 0.05em;
  margin-bottom: 5.5rem;
}
@media only screen and (max-width: 559px) {
  .t-solution__listtext {
    font-size: 1.4rem;
    text-align: left;
    display: flex;
    gap: 1rem;
    flex-direction: column;
    margin-bottom: 2rem;
  }
}
.t-solution__listtext span.bg-grd {
  color: var(--colorW);
  font-size: 3.8rem;
  letter-spacing: 0.05em;
  font-weight: 700;
  line-height: 1;
  padding: 0.5rem 1.5rem;
  display: inline-block;
  margin-inline: 1.5rem;
}
@media only screen and (max-width: 559px) {
  .t-solution__listtext span.bg-grd {
    font-size: 2.4rem;
    padding: 0.3rem 0.9rem;
    margin-inline: 0;
    width: fit-content;
  }
}
@media only screen and (max-width: 559px) {
  .t-solution__listtext span:last-child {
    margin-left: auto;
    width: fit-content;
  }
}
.t-solution__sublist {
  margin-bottom: 5rem;
}
@media only screen and (max-width: 559px) {
  .t-solution__sublist {
    margin-bottom: 2rem;
  }
}
.t-solution__subitem {
  font-size: 2rem;
  line-height: 2;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 559px) {
  .t-solution__subitem {
    font-size: 1.4rem;
    display: flex;
    line-height: 1.5;
  }
}
@media only screen and (max-width: 559px) {
  .t-solution__subitem:not(:last-child) {
    margin-bottom: 1rem;
  }
}
.t-solution__textarea {
  margin-bottom: 8.5rem;
}
@media only screen and (max-width: 559px) {
  .t-solution__textarea {
    margin-bottom: 4rem;
  }
}
.t-solution__text {
  font-size: 2rem;
  letter-spacing: 0.05em;
  line-height: 2;
  text-align: center;
}
@media only screen and (max-width: 559px) {
  .t-solution__text {
    font-size: 1.4rem;
    line-height: 2;
    text-align: left;
  }
}
@media only screen and (max-width: 559px) {
  .t-solution .o-flex__item--1 {
    order: 2;
  }
}
@media only screen and (max-width: 559px) {
  .t-solution .o-flex__item--2 {
    display: contents;
  }
}
@media only screen and (max-width: 559px) {
  .t-solution__img {
    width: 100%;
  }
}
@media only screen and (max-width: 559px) {
  .t-solution__box {
    order: 4;
  }
}

.t-service {
  margin-bottom: 22rem;
}
@media only screen and (max-width: 559px) {
  .t-service {
    margin-bottom: 12rem;
  }
}
@media only screen and (max-width: 559px) {
  .t-service .primary-ttl__img {
    width: 33rem;
    height: auto;
  }
}

.t-vision {
  border-radius: 14rem 0 14rem 0;
  padding: 26rem 0 10rem;
  position: relative;
}
@media only screen and (max-width: 559px) {
  .t-vision {
    border-radius: 8rem 0 8rem 0;
    padding: 0 0 7rem;
  }
}
.t-vision__ttl {
  font-size: 19rem;
  font-family: var(--jost);
  opacity: 0.5;
  color: var(--colorW);
  position: absolute;
  top: 0;
  left: 0;
  font-weight: 500;
}
@media only screen and (max-width: 559px) {
  .t-vision__ttl {
    font-size: 6.6rem;
    position: static;
    margin-bottom: 4rem;
  }
}
.t-vision__grid {
  display: grid;
  gap: 5.5rem;
  grid-template-columns: repeat(2, 1fr);
  margin-block: 9rem;
}
@media only screen and (max-width: 1280px) {
  .t-vision__grid {
    gap: 2.5rem;
    margin-top: 14rem;
  }
}
@media only screen and (max-width: 559px) {
  .t-vision__grid {
    grid-template-columns: repeat(1, 1fr);
    margin: 0;
    gap: 5rem;
    margin-bottom: 6rem;
  }
}
@media only screen and (max-width: 559px) {
  .t-vision__item:last-child {
    order: -1;
  }
}
.t-vision__subttl {
  font-size: 3.2rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.6875;
  color: var(--colorW);
  margin-bottom: 6rem;
}
@media only screen and (max-width: 559px) {
  .t-vision__subttl {
    font-size: 2.2rem;
    text-align: center;
    margin-bottom: 4.5rem;
  }
}
.t-vision__text {
  color: var(--colorW);
  font-size: 2rem;
  letter-spacing: 0.05em;
  line-height: 2.8;
}
@media only screen and (max-width: 559px) {
  .t-vision__text {
    font-size: 1.4rem;
    line-height: 2.7857142857;
  }
}
.t-vision__figure {
  margin-top: 10.5rem;
  position: relative;
}
@media only screen and (max-width: 559px) {
  .t-vision__figure {
    margin-top: 0;
  }
}
@media only screen and (max-width: 559px) {
  .t-vision__img {
    width: 22.8rem;
    height: auto;
  }
}
.t-vision__figcaption {
  position: absolute;
  right: 2.5rem;
  bottom: 2rem;
}
@media only screen and (max-width: 559px) {
  .t-vision__figcaption {
    right: 0;
    bottom: 0;
  }
}
.t-vision__company {
  color: var(--colorW);
  font-size: 2rem;
  line-height: 1;
  margin-bottom: 1rem;
  letter-spacing: 0.05em;
  font-weight: 500;
}
@media only screen and (max-width: 559px) {
  .t-vision__company {
    font-size: 1.4rem;
  }
}
.t-vision__name {
  font-size: 3.2rem;
  font-weight: 700;
  letter-spacing: 0.3em;
  color: var(--colorW);
  display: flex;
  gap: 1rem;
  align-items: baseline;
  font-size: 2.2rem;
}
.t-vision__name span {
  color: var(--colorW);
  font-size: 2rem;
  line-height: 1;
  margin-bottom: 2rem;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 559px) {
  .t-vision__name span {
    font-size: 1.4rem;
  }
}
.t-vision__box {
  background: rgba(255, 255, 255, 0.8);
  border-radius: 5rem;
  padding: 9rem 0 6rem;
}
@media only screen and (max-width: 559px) {
  .t-vision__box {
    padding: 4.5rem 3rem 3rem;
    border-radius: 2.5rem;
  }
}
.t-vision__boxgrid {
  display: grid;
  gap: 5.5rem;
  grid-template-columns: repeat(2, 1fr);
  width: 111.5rem;
  margin-inline: auto;
  margin-bottom: 4.5rem;
}
@media only screen and (max-width: 559px) {
  .t-vision__boxgrid {
    grid-template-columns: repeat(1, 1fr);
    width: 100%;
    gap: 3rem;
    margin-bottom: 2.5rem;
  }
}
.t-vision__boxsubttl {
  color: var(--mainColor);
  font-size: 1.6rem;
  letter-spacing: 0.05em;
  line-height: 1;
  margin-bottom: 2.5rem;
  font-weight: 700;
}
@media only screen and (max-width: 559px) {
  .t-vision__boxsubttl {
    font-size: 1.2rem;
    text-align: center;
    line-height: 1.3333333333;
  }
}
.t-vision__boxttl {
  color: var(--mainColor);
  margin-bottom: 4rem;
  line-height: 1;
  font-size: 3.2rem;
  font-weight: 700;
}
@media only screen and (max-width: 559px) {
  .t-vision__boxttl {
    font-size: 2.2rem;
    margin-bottom: 2.5rem;
    line-height: 1.3636363636;
    text-align: center;
  }
}
.t-vision__boxtext {
  font-size: 1.8rem;
  letter-spacing: 0.05em;
  line-height: 2;
}
@media only screen and (max-width: 559px) {
  .t-vision__boxtext {
    font-size: 1.4rem;
  }
}
.t-vision__boxmovie iframe {
  width: 100%;
  height: auto;
  aspect-ratio: 16/9;
  object-fit: cover;
}

.t-cmsarea {
  padding: 16rem 0 0;
  margin-bottom: 18rem;
  display: flex;
  flex-direction: column;
  gap: 6rem;
}
@media only screen and (max-width: 559px) {
  .t-cmsarea {
    padding: 8rem 0 0;
    gap: 4rem;
    margin-bottom: 9rem;
  }
}
@media only screen and (max-width: 559px) {
  .t-cmsarea .wrapper {
    display: contents;
  }
}

/*-----------------------

      下層ページ /*---------------数値など任意で書き換えを行う---------------------

-----------------------*/
/*header*/
.content-header {
  margin-bottom: clamp(5rem, 2.816rem + 5.825vw, 14rem);
  padding: 5vw;
  width: 100vw;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
  background: #18bde7;
  background: linear-gradient(90deg, rgb(24, 189, 231) 0%, rgb(23, 42, 136) 100%);
  padding-bottom: 8.3vw;
  margin-bottom: 30rem;
}

.page-header {
  font-weight: 500;
  border-bottom: none;
  font-size: clamp(3.2rem, calc(2.6660194175rem + 1.4239482201vw), 5.4rem);
  padding-inline: 1vw;
  color: #fff;
  width: 136.6rem;
  padding: 0 2rem;
  max-width: 100rem;
  margin-inline: inherit;
  margin-top: 9rem;
  padding-left: 19.5rem;
  margin-top: 8.2rem;
}
.page-header span {
  font-size: clamp(1.4rem, calc(1.1087378641rem + 0.7766990291vw), 2.6rem);
  display: block;
  padding-bottom: 0.5rem;
}

.login-required {
  font-size: 1.6rem;
}

.sns-detail {
  /* margin-top: -11rem; */
  margin-top: -8rem;
  margin-bottom: 5rem;
}

/* コンテンツの前後ページ */
.body-shelf-list .flex-c,
.body-info-detail .flex-c {
  flex-direction: row;
}

/* コンテンツの再生リストチェックボックス */
.body-shelf-comment input[type=checkbox] {
  -webkit-appearance: auto;
  -moz-appearance: auto;
  appearance: auto;
  border-radius: 0;
  margin-top: 0.8rem;
}

.page-detail-page .content-header {
  position: relative;
}
@media only screen and (max-width: 559px) {
  .page-detail-page .content-header {
    padding-bottom: 25.5rem;
    margin-bottom: 20rem;
    padding-left: 5.5vw;
  }
}
.page-detail-page .content-header::after {
  content: "";
  position: absolute;
  bottom: -20rem;
  right: 3%;
  height: 34rem;
  width: 126rem;
  width: 65.625vw;
  height: 17.7083333333vw;
}
@media only screen and (min-width: 1921px) {
  .page-detail-page .content-header::after {
    bottom: -26rem;
  }
}
@media only screen and (max-width: 559px) {
  .page-detail-page .content-header::after {
    width: 35.25rem;
    height: 34.3rem;
    top: 21rem;
    right: -1rem;
    z-index: -1;
  }
}
.page-detail-page .page-header {
  position: relative;
  line-height: 1.3;
}
@media only screen and (max-width: 559px) {
  .page-detail-page .page-header {
    margin-top: 7.5rem;
  }
}
.page-detail-page .page-header::before {
  content: "";
  position: absolute;
}

.page-detail-news-archive .content-header::after {
  background: url(../img/na-head__img01.webp) no-repeat center center/contain;
}
@media only screen and (max-width: 559px) {
  .page-detail-news-archive .content-header::after {
    background: url(../img/na-head__img01_sp.webp) no-repeat center center/contain;
  }
}
.page-detail-news-archive .page-header::before {
  background: url(../img/na-head__text01.webp) no-repeat center center/contain;
  width: 28.2rem;
  height: 19.7rem;
  position: absolute;
  top: 5rem;
  left: 9rem;
  top: 1rem;
  left: -3rem;
}
@media only screen and (max-width: 559px) {
  .page-detail-news-archive .page-header::before {
    top: -4rem;
    left: -4.5rem;
    transform: scale(0.6);
  }
}

.page-detail-blog-archive .content-header::after {
  background: url(../img/ba-head__img01.webp) no-repeat center center/contain;
}
@media only screen and (max-width: 559px) {
  .page-detail-blog-archive .content-header::after {
    background: url(../img/ba-head__img01_sp.webp) no-repeat center center/contain;
  }
}
.page-detail-blog-archive .page-header::before {
  background: url(../img/ba-head__text01.webp) no-repeat center center/contain;
  width: 28.2rem;
  height: 19.7rem;
  position: absolute;
  top: 5rem;
  left: 9rem;
  top: 1rem;
  left: -3rem;
}
@media only screen and (max-width: 559px) {
  .page-detail-blog-archive .page-header::before {
    top: -4rem;
    left: -4.5rem;
    transform: scale(0.6);
  }
}

.page-detail-case-archive .content-header::after {
  background: url(../img/ca-head__img01.webp) no-repeat center center/contain;
}
@media only screen and (max-width: 559px) {
  .page-detail-case-archive .content-header::after {
    background: url(../img/ca-head__img01_sp.webp) no-repeat center center/contain;
  }
}
.page-detail-case-archive .page-header::before {
  background: url(../img/as-head__text01.webp) no-repeat center center/contain;
  width: 28.2rem;
  height: 19.7rem;
  position: absolute;
  top: 5rem;
  left: 9rem;
  top: 1rem;
  left: -3rem;
}
@media only screen and (max-width: 559px) {
  .page-detail-case-archive .page-header::before {
    top: -4rem;
    left: -4.5rem;
    transform: scale(0.6);
  }
}

.page-detail-about .content-header::after {
  background: url(../img/ab-head__img01.webp) no-repeat center center/contain;
}
@media only screen and (max-width: 559px) {
  .page-detail-about .content-header::after {
    background: url(../img/ab-head__img01_sp.webp) no-repeat center center/contain;
  }
}
.page-detail-about .page-header::before {
  background: url(../img/ab-head__text01.webp) no-repeat center center/contain;
  width: 38rem;
  height: 23.5rem;
  position: absolute;
  top: 5rem;
  left: 9rem;
  top: -2rem;
  left: -3rem;
}
@media only screen and (max-width: 559px) {
  .page-detail-about .page-header::before {
    top: -5rem;
    left: -9.5rem;
    transform: scale(0.6);
  }
}

.page-detail-business-turnaround .content-header::after {
  background: url(../img/bt-head__img01.webp) no-repeat center center/contain;
}
@media only screen and (max-width: 559px) {
  .page-detail-business-turnaround .content-header::after {
    background: url(../img/bt-head__img01_sp.webp) no-repeat center center/contain;
  }
}
.page-detail-business-turnaround .page-header::before {
  background: url(../img/bt-head__text01.webp) no-repeat center center/contain;
  width: 38.8rem;
  height: 20.6rem;
  position: absolute;
  top: -2rem;
  left: 9rem;
  top: -2rem;
  left: -3rem;
}
@media only screen and (max-width: 559px) {
  .page-detail-business-turnaround .page-header::before {
    top: -5rem;
    left: -9.5rem;
    transform: scale(0.6);
  }
}

.page-detail-pdca .content-header::after {
  background: url(../img/pd-head__img01.webp) no-repeat center center/contain;
}
@media only screen and (max-width: 559px) {
  .page-detail-pdca .content-header::after {
    background: url(../img/pd-head__img01_sp.webp) no-repeat center center/contain;
  }
}
.page-detail-pdca .page-header::before {
  background: url(../img/pd-head__text01.webp) no-repeat center center/contain;
  width: 38.8rem;
  height: 20.6rem;
  position: absolute;
  top: -2rem;
  left: 9rem;
  top: -2rem;
  left: -3rem;
}
@media only screen and (max-width: 559px) {
  .page-detail-pdca .page-header::before {
    top: -5rem;
    left: -9.5rem;
    transform: scale(0.6);
  }
}

.page-detail-consulting-training .content-header::after {
  background: url(../img/ct-head__img01.webp) no-repeat center center/contain;
}
@media only screen and (max-width: 559px) {
  .page-detail-consulting-training .content-header::after {
    background: url(../img/ct-head__img01_sp.webp) no-repeat center center/contain;
  }
}
.page-detail-consulting-training .page-header::before {
  background: url(../img/pd-head__text01.webp) no-repeat center center/contain;
  width: 38.8rem;
  height: 20.6rem;
  position: absolute;
  top: -2rem;
  left: 9rem;
  top: -2rem;
  left: -3rem;
}
@media only screen and (max-width: 559px) {
  .page-detail-consulting-training .page-header::before {
    top: -5rem;
    left: -9.5rem;
    transform: scale(0.6);
  }
}

.page-detail-consultant-archive .content-header::after {
  background: url(../img/ca-head__img01.webp) no-repeat center center/contain;
}
@media only screen and (max-width: 559px) {
  .page-detail-consultant-archive .content-header::after {
    background: url(../img/ca-head__img01_sp.webp) no-repeat center center/contain;
  }
}
.page-detail-consultant-archive .page-header::before {
  background: url(../img/ca-head__text01.webp) no-repeat center center/contain;
  width: 41.1rem;
  height: 21.7rem;
  position: absolute;
  top: 5rem;
  left: 9rem;
  top: -2rem;
  left: -3rem;
}
@media only screen and (max-width: 559px) {
  .page-detail-consultant-archive .page-header::before {
    top: -5rem;
    left: -9.5rem;
    transform: scale(0.6);
  }
}

.page-detail-consultant-single .content-header {
  margin-bottom: 0;
}
.page-detail-consultant-single .content-header::after {
  display: none;
}
.page-detail-consultant-single .page-header::before {
  background: url(../img/ca-head__text01.webp) no-repeat center center/contain;
  width: 41.1rem;
  height: 21.7rem;
  position: absolute;
  top: 5rem;
  left: 9rem;
  top: -2rem;
  left: -3rem;
}
@media only screen and (max-width: 559px) {
  .page-detail-consultant-single .page-header::before {
    top: -5rem;
    left: -9.5rem;
    transform: scale(0.6);
  }
}

.page-detail-request .content-header::after {
  background: url(../img/re-head__img01.webp) no-repeat center center/contain;
}
@media only screen and (max-width: 559px) {
  .page-detail-request .content-header::after {
    background: url(../img/re-head__img01_sp.webp) no-repeat center center/contain;
  }
}
.page-detail-request .page-header::before {
  background: url(../img/re-head__text01.webp) no-repeat center center/contain;
  width: 37.2rem;
  height: 20.6rem;
  position: absolute;
  top: 5rem;
  left: 9rem;
  top: -2rem;
  left: -3rem;
}
@media only screen and (max-width: 559px) {
  .page-detail-request .page-header::before {
    top: -5rem;
    left: -9.5rem;
    transform: scale(0.6);
  }
}

.ab-philosophy {
  margin-bottom: 24rem;
  position: relative;
  padding-top: 28rem;
}
@media only screen and (max-width: 559px) {
  .ab-philosophy {
    padding-top: 10rem;
    margin-bottom: 12rem;
  }
}
.ab-philosophy__subttl {
  width: fit-content;
  margin-inline: auto;
  color: var(--colorW);
  font-size: 7.1rem;
  letter-spacing: 0.05em;
  line-height: 1;
  padding: 1.8rem 4rem;
  margin-bottom: 7rem;
}
@media only screen and (max-width: 559px) {
  .ab-philosophy__subttl {
    font-size: 2.2rem;
    padding: 0.8rem 1rem;
    margin-bottom: 3.5rem;
  }
}
.ab-philosophy__text {
  text-align: center;
  font-size: 2rem;
  line-height: 2.5;
  letter-spacing: 0.075em;
}
@media only screen and (max-width: 559px) {
  .ab-philosophy__text {
    font-size: 1.6rem;
    text-align: left;
    line-height: 1.75;
  }
}
.ab-philosophy__deco {
  font-family: var(--jost);
  font-size: 15.625vw;
  font-weight: 500;
  opacity: 0.4;
  position: absolute;
  line-height: 0.8;
  left: 0;
  top: -31rem;
}
@media only screen and (max-width: 559px) {
  .ab-philosophy__deco {
    font-size: 7.5rem;
    top: -12rem;
    line-height: 1;
  }
}

.ab-policy {
  position: relative;
}
.ab-policy__deco {
  font-family: var(--jost);
  font-size: 30rem;
  font-size: 15.625vw;
  font-weight: 500;
  opacity: 0.4;
  position: absolute;
  line-height: 0.8;
  left: 0;
  top: -15rem;
  z-index: 10;
}
@media only screen and (max-width: 559px) {
  .ab-policy__deco {
    top: -7rem;
  }
}
.ab-policy__head {
  text-align: right;
  margin-bottom: 12rem;
}
@media only screen and (max-width: 559px) {
  .ab-policy__head {
    margin-bottom: 6rem;
  }
}

.ab-policy {
  margin-bottom: 14rem;
}
@media only screen and (max-width: 559px) {
  .ab-policy {
    margin-bottom: 7rem;
  }
}
.ab-policy__box {
  text-align: center;
}
.ab-policy__number {
  color: var(--colorW);
  font-family: var(--jost);
  width: fit-content;
  margin-inline: auto;
  border-radius: calc(infinity * 1px);
  font-size: 1.8rem;
  line-height: 1;
  width: 28rem;
  height: 3.6rem;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 3.5rem;
  margin-top: -1.5rem;
  z-index: 10;
  position: relative;
}
@media only screen and (max-width: 559px) {
  .ab-policy__number {
    font-size: 1.2rem;
    width: 18rem;
    height: 2.5rem;
    margin-top: -2rem;
    margin-bottom: 1rem;
  }
}
@media only screen and (max-width: 559px) {
  .ab-policy__img {
    transform: scale(0.8);
  }
}
.ab-policy__subttl {
  text-align: center;
  color: var(--mainColor);
  font-size: 4.4rem;
  letter-spacing: 0.05em;
  margin-bottom: 4rem;
}
@media only screen and (max-width: 559px) {
  .ab-policy__subttl {
    font-size: 2.8rem;
    margin-bottom: 2rem;
    line-height: 1.3;
  }
}
.ab-policy__text {
  font-size: 1.8rem;
  line-height: 2;
  letter-spacing: 0.05em;
  text-align: center;
}
@media only screen and (max-width: 559px) {
  .ab-policy__text {
    font-size: 1.4rem;
    text-align: left;
  }
}
.ab-policy__item:not(:last-child) {
  margin-bottom: 8rem;
}
@media only screen and (max-width: 559px) {
  .ab-policy__item:not(:last-child) {
    margin-bottom: 4rem;
  }
}

.ab-message {
  margin-bottom: 16rem;
}
@media only screen and (max-width: 559px) {
  .ab-message {
    margin-bottom: 8rem;
  }
}
@media only screen and (max-width: 559px) {
  .ab-message .wrapper {
    display: contents;
  }
}
@media only screen and (max-width: 559px) {
  .ab-message .primary-ttl__wrap {
    bottom: 1rem;
  }
}
.ab-message__ttlarea {
  margin-bottom: 6rem;
}
@media only screen and (max-width: 559px) {
  .ab-message__ttlarea {
    margin-bottom: 3rem;
  }
}
.ab-message__subttl {
  color: var(--mainColor);
  font-size: 5.4rem;
  line-height: 1;
  margin-bottom: 2.5rem;
}
@media only screen and (max-width: 559px) {
  .ab-message__subttl {
    font-size: 3rem;
    margin-bottom: 1.5rem;
  }
}
.ab-message__suben {
  width: fit-content;
  font-family: var(--jost);
  font-size: 1.6rem;
  letter-spacing: 0.2em;
  margin-bottom: 4.5rem;
}
@media only screen and (max-width: 559px) {
  .ab-message__suben {
    font-size: 1.2rem;
    margin-bottom: 2.5rem;
  }
}
.ab-message__text {
  font-size: 1.8rem;
  letter-spacing: 0.05em;
  line-height: 1.7222222222;
}
@media only screen and (max-width: 559px) {
  .ab-message__text {
    font-size: 1.4rem;
  }
}
.ab-message__text:not(:last-child) {
  margin-bottom: 4rem;
}
@media only screen and (max-width: 559px) {
  .ab-message__text:not(:last-child) {
    margin-bottom: 2.5rem;
  }
}
.ab-message__textarea {
  margin-bottom: 7rem;
}
@media only screen and (max-width: 559px) {
  .ab-message__textarea {
    margin-bottom: 3.5rem;
  }
}
.ab-message__flex {
  display: flex;
  gap: 9rem;
  align-items: flex-end;
  margin-bottom: 7rem;
}
@media only screen and (max-width: 559px) {
  .ab-message__flex {
    flex-direction: column;
    gap: 4rem;
    margin-bottom: 3.5rem;
  }
}
.ab-message__company {
  font-size: 1.6rem;
}
@media only screen and (max-width: 559px) {
  .ab-message__company {
    font-size: 1.2rem;
  }
}
.ab-message__name {
  font-size: 2.6rem;
}
@media only screen and (max-width: 559px) {
  .ab-message__name {
    font-size: 2rem;
  }
}
.ab-message__name span {
  font-size: 1.6rem;
}
@media only screen and (max-width: 559px) {
  .ab-message__name span {
    font-size: 1.2rem;
  }
}
.ab-message__figure {
  width: 53.5rem;
}
@media only screen and (max-width: 559px) {
  .ab-message__figure {
    width: 100%;
  }
}
.ab-message__img {
  width: 100%;
  height: auto;
}
.ab-message__item {
  width: calc(100% - 53.5rem - 9rem);
}
@media only screen and (max-width: 559px) {
  .ab-message__item {
    width: 100%;
  }
}
.ab-message__box {
  border-radius: 3rem;
  border: 0.2rem solid transparent;
  background-image: linear-gradient(#fff, #fff), linear-gradient(90deg, rgb(24, 189, 231) 0%, rgb(23, 42, 136) 100%);
  background-origin: border-box;
  background-clip: padding-box, border-box;
  padding: 4rem 0;
  margin-bottom: 12rem;
}
@media only screen and (max-width: 559px) {
  .ab-message__box {
    padding: 3rem 2rem;
    margin-bottom: 6rem;
  }
}
.ab-message__boxwrap {
  width: 84.2rem;
  margin-inline: auto;
}
@media only screen and (max-width: 559px) {
  .ab-message__boxwrap {
    width: 100%;
  }
}
.ab-message__boxttlen {
  font-size: 1.8rem;
  font-family: var(--jost);
  line-height: 1;
  margin-bottom: 2rem;
  width: fit-content;
}
@media only screen and (max-width: 559px) {
  .ab-message__boxttlen {
    font-size: 1.4rem;
    margin-bottom: 1rem;
  }
}
.ab-message__boxttl {
  color: var(--mainColor);
  font-size: 2.6rem;
  line-height: 1;
  margin-bottom: 2.5rem;
}
@media only screen and (max-width: 559px) {
  .ab-message__boxttl {
    font-size: 2rem;
    margin-bottom: 1.5rem;
  }
}
.ab-message__boxtext {
  font-size: 1.6rem;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 559px) {
  .ab-message__boxtext {
    font-size: 1.2rem;
  }
}
.ab-message__unit {
  background-color: var(--colorW);
  border-radius: 6rem;
  padding: 8rem 0;
}
@media only screen and (max-width: 559px) {
  .ab-message__unit {
    border-radius: 3rem;
    padding: 4rem 2rem;
  }
}
.ab-message__unitflex {
  display: flex;
  gap: 3rem;
  margin-bottom: 5rem;
}
@media only screen and (max-width: 559px) {
  .ab-message__unitflex {
    margin-bottom: 2.5rem;
    gap: 2rem;
    flex-direction: column;
  }
}
.ab-message__unitfigure {
  width: 28.6rem;
}
@media only screen and (max-width: 559px) {
  .ab-message__unitfigure {
    width: 60%;
    margin-inline: auto;
  }
}
.ab-message__unitimg {
  width: 28.6rem;
  height: auto;
}
@media only screen and (max-width: 559px) {
  .ab-message__unitimg {
    width: 100%;
  }
}
.ab-message__unithead {
  width: calc(100% - 28.6rem - 3rem);
}
@media only screen and (max-width: 559px) {
  .ab-message__unithead {
    width: 100%;
  }
}
.ab-message__unitsubttl {
  font-size: 2.4rem;
  color: var(--mainColor);
  margin-bottom: 2.5rem;
}
@media only screen and (max-width: 559px) {
  .ab-message__unitsubttl {
    font-size: 1.7rem;
    margin-bottom: 1rem;
    line-height: 1.4;
  }
}
.ab-message__unitsubttl span {
  font-size: 2rem;
  display: block;
  padding-top: 1.5rem;
}
@media only screen and (max-width: 559px) {
  .ab-message__unitsubttl span {
    font-size: 1.4rem;
    padding-top: 0.5rem;
  }
}
.ab-message__unitnote {
  margin-bottom: 3.5rem;
  font-size: 1.5rem;
  line-height: 1;
}
@media only screen and (max-width: 559px) {
  .ab-message__unitnote {
    margin-bottom: 2rem;
    font-size: 1.2rem;
    line-height: 1.4;
  }
}
.ab-message__unittext {
  font-size: 1.6rem;
  letter-spacing: 0.05em;
  line-height: 2;
}
@media only screen and (max-width: 559px) {
  .ab-message__unittext {
    font-size: 1.2rem;
    line-height: 1.75;
  }
}
.ab-message__unitlist {
  width: 74rem;
  margin-inline: auto;
  margin-bottom: 5rem;
}
@media only screen and (max-width: 559px) {
  .ab-message__unitlist {
    width: 100%;
    margin-bottom: 3rem;
  }
}
.ab-message__unitlistitem:not(:last-child) {
  margin-bottom: 4rem;
}
@media only screen and (max-width: 559px) {
  .ab-message__unitlistitem:not(:last-child) {
    margin-bottom: 2rem;
  }
}
.ab-message__unitlistttl {
  color: var(--mainColor);
  font-size: 2.4rem;
  letter-spacing: 0.05em;
  margin-bottom: 1.5rem;
}
@media only screen and (max-width: 559px) {
  .ab-message__unitlistttl {
    font-size: 1.8rem;
    display: flex;
    line-height: 1.3;
    margin-bottom: 1rem;
  }
}
.ab-message__unitlistnote {
  font-size: 1.6rem;
  letter-spacing: 0.05em;
  line-height: 1;
  margin-bottom: 2rem;
}
@media only screen and (max-width: 559px) {
  .ab-message__unitlistnote {
    font-size: 1.2rem;
    margin-bottom: 1rem;
  }
}
.ab-message__unitlisttext {
  font-size: 1.6rem;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 559px) {
  .ab-message__unitlisttext {
    font-size: 1.2rem;
  }
}
.ab-message__unitadd {
  width: 74rem;
  margin-inline: auto;
  color: var(--mainColor);
  font-size: 2rem;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 559px) {
  .ab-message__unitadd {
    width: 100%;
    font-size: 1.6rem;
  }
}

@media only screen and (max-width: 559px) {
  .ab-service {
    margin-bottom: 4rem;
  }
}

.ab-company__row {
  display: grid;
  border-bottom: 1px solid var(--mainColor);
  grid-template-columns: 21rem 79rem;
  padding-bottom: 1.5rem;
  font-size: 1.8rem;
  letter-spacing: 0.05em;
  line-height: 1.75;
}
@media only screen and (max-width: 559px) {
  .ab-company__row {
    font-size: 1.4rem;
    grid-template-columns: repeat(1, 1fr);
  }
}
.ab-company__row:not(:last-child) {
  margin-bottom: 5rem;
}
@media only screen and (max-width: 559px) {
  .ab-company__row:not(:last-child) {
    margin-bottom: 3rem;
  }
}
.ab-company__term {
  text-align: center;
  font-weight: 500;
}
@media only screen and (max-width: 559px) {
  .ab-company__term {
    text-align: left;
    margin-bottom: 0.5rem;
    font-weight: 700;
  }
}
.ab-company__partner-item {
  display: flex;
}
.ab-company__partner-item:not(:last-child) {
  margin-bottom: 1rem;
}

@media only screen and (max-width: 559px) {
  .page-detail-request .ab-philosophy__deco {
    top: -15rem;
  }
}

.re-summary {
  background: url(../img/re-summary__img01.webp) no-repeat center center/cover;
  min-height: 75.7rem;
  display: flex;
  padding-top: 3rem;
  justify-content: center;
  align-items: center;
  margin-bottom: 16rem;
  margin-top: 3.5rem;
}
@media only screen and (max-width: 559px) {
  .re-summary {
    margin-bottom: 6rem;
    min-height: 30rem;
    padding-inline: 2rem;
    padding-block: 5rem;
    border-radius: 8rem 2.5rem 12rem 2.5rem;
    margin-top: 0;
  }
}
.re-summary__subttl {
  color: var(--colorW);
  font-size: 2.4rem;
  letter-spacing: 0.05em;
  margin-bottom: 1.5rem;
}
@media only screen and (max-width: 559px) {
  .re-summary__subttl {
    font-size: 1.4rem;
    margin-bottom: 0.5rem;
  }
}
.re-summary__ttl {
  color: var(--colorW);
  font-family: var(--jost);
  font-size: 8.2rem;
}
@media only screen and (max-width: 559px) {
  .re-summary__ttl {
    font-size: 3.2rem;
  }
}
.re-summary__ttlarea {
  margin-bottom: 4rem;
  position: relative;
}
@media only screen and (max-width: 559px) {
  .re-summary__ttlarea {
    margin-bottom: 2rem;
  }
}
.re-summary__ttlarea::before {
  content: "";
  background: url(../img/mark__img03.svg) no-repeat center center/contain;
  width: 18.2rem;
  height: 30rem;
  position: absolute;
  top: -53%;
  left: 0rem;
  opacity: 0.25;
}
@media only screen and (max-width: 559px) {
  .re-summary__ttlarea::before {
    width: 12rem;
    height: 22rem;
  }
}
.re-summary__textarea {
  width: 63.6rem;
}
@media only screen and (max-width: 559px) {
  .re-summary__textarea {
    width: 100%;
  }
}
.re-summary__text {
  font-size: 1.8rem;
  letter-spacing: 0.05em;
  color: var(--colorW);
}
@media only screen and (max-width: 559px) {
  .re-summary__text {
    font-size: 1.4rem;
  }
}
.re-summary__text:not(:last-child) {
  margin-bottom: 4rem;
}
@media only screen and (max-width: 559px) {
  .re-summary__text:not(:last-child) {
    margin-bottom: 1.5rem;
  }
}

.re-instructor {
  margin-bottom: 12rem;
}
@media only screen and (max-width: 559px) {
  .re-instructor {
    margin-bottom: 6rem;
  }
}
@media only screen and (max-width: 559px) {
  .re-instructor .primary-ttl__wrap {
    bottom: 1rem;
  }
}
.re-instructor__ttlarea {
  margin-bottom: 0rem;
}
@media only screen and (max-width: 559px) {
  .re-instructor__figure {
    width: 80%;
    margin-inline: auto;
  }
}
.re-instructor__flex {
  margin-bottom: 12rem;
  gap: 5rem;
}
@media only screen and (max-width: 559px) {
  .re-instructor__flex {
    margin-bottom: 6rem;
    flex-direction: column;
    gap: 3rem;
  }
}
.re-instructor__profile {
  color: var(--mainColor);
  font-size: 1.8rem;
  letter-spacing: 0.05em;
  margin-bottom: 1.5rem;
}
@media only screen and (max-width: 559px) {
  .re-instructor__profile {
    font-size: 1.6rem;
    margin-bottom: 1rem;
  }
}
.re-instructor__name {
  color: var(--mainColor);
  font-size: 5rem;
  letter-spacing: 0.1em;
  line-height: 1;
}
@media only screen and (max-width: 559px) {
  .re-instructor__name {
    font-size: 3rem;
  }
}
.re-instructor__nameen {
  font-family: var(--jost);
  font-size: 2.2rem;
}
@media only screen and (max-width: 559px) {
  .re-instructor__nameen {
    font-size: 1.4rem;
  }
}
.re-instructor__namearea {
  display: flex;
  align-items: baseline;
  gap: 2.5rem;
  margin-bottom: 1.5rem;
}
@media only screen and (max-width: 559px) {
  .re-instructor__namearea {
    gap: 1.5rem;
    margin-bottom: 1rem;
  }
}
.re-instructor__role {
  font-size: 1.6rem;
  letter-spacing: 0.05em;
  color: var(--mainColor);
  margin-bottom: 4rem;
}
@media only screen and (max-width: 559px) {
  .re-instructor__role {
    font-size: 1.4rem;
    margin-bottom: 2rem;
  }
}
.re-instructor__text {
  font-size: 1.8rem;
  letter-spacing: 0.05em;
  line-height: 2;
}
@media only screen and (max-width: 559px) {
  .re-instructor__text {
    font-size: 1.4rem;
    line-height: 1.75;
  }
}
.re-instructor__textarea {
  margin-bottom: 5rem;
}
@media only screen and (max-width: 559px) {
  .re-instructor__textarea {
    margin-bottom: 3rem;
  }
}
.re-instructor__sns {
  display: flex;
  gap: 3.5rem;
}
@media only screen and (max-width: 559px) {
  .re-instructor__sns {
    justify-content: center;
    gap: 2rem;
  }
}
.re-instructor__snsimg {
  width: 4.8rem;
  height: auto;
}
@media only screen and (max-width: 559px) {
  .re-instructor__snsimg {
    width: 3.5rem;
  }
}
.re-instructor .o-flex__item--1 {
  padding-top: 6.5rem;
}
@media only screen and (max-width: 559px) {
  .re-instructor .o-flex__item--1 {
    padding-top: 3.5rem;
  }
}
.re-instructor__message {
  margin-bottom: 8rem;
}
@media only screen and (max-width: 559px) {
  .re-instructor__message {
    margin-bottom: 4rem;
  }
}
.re-instructor__unit {
  position: relative;
  background-color: rgba(255, 255, 255, 0.5);
  border-radius: 2rem;
  padding: 9rem 0 10rem;
}
@media only screen and (max-width: 559px) {
  .re-instructor__unit {
    padding: 4.5rem 0 5rem;
  }
}
@media only screen and (max-width: 559px) {
  .re-instructor__unit .holder {
    padding-inline: 2rem;
  }
}
.re-instructor__unit::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: -1;
  border: 0.2rem solid transparent;
  border-radius: inherit;
  background-image: linear-gradient(90deg, rgba(24, 189, 231, 0.5) 0%, rgba(23, 42, 136, 0.5) 100%);
  background-origin: border-box;
  -webkit-mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: destination-out;
  mask-composite: exclude;
}
.re-instructor__unit::after {
  content: "";
  background: url(../img/re-instructor__img02.webp) no-repeat center center/contain;
  width: 47.1rem;
  height: 32rem;
  position: absolute;
  bottom: 8.5rem;
  right: 5.5rem;
}
@media only screen and (max-width: 559px) {
  .re-instructor__unit::after {
    width: 15rem;
    height: 8rem;
    bottom: -1rem;
    right: -2rem;
  }
}
.re-instructor__unitttlarea {
  display: flex;
  align-items: baseline;
  padding-bottom: 2rem;
  margin-bottom: 3.5rem;
  border-bottom: 1px solid var(--main50Color);
  gap: 4rem;
}
@media only screen and (max-width: 559px) {
  .re-instructor__unitttlarea {
    flex-direction: column;
    gap: 1rem;
    margin-bottom: 2rem;
  }
}
.re-instructor__unitttl {
  font-size: 3.2rem;
}
@media only screen and (max-width: 559px) {
  .re-instructor__unitttl {
    font-size: 2.4rem;
    line-height: 1.4;
  }
}
.re-instructor__unitttlen {
  font-size: 2.2rem;
  font-family: var(--jost);
}
@media only screen and (max-width: 559px) {
  .re-instructor__unitttlen {
    font-size: 1.4rem;
  }
}
.re-instructor__unitsubttl {
  color: var(--mainColor);
  font-size: 2.6rem;
  letter-spacing: 0.05em;
  margin-bottom: 2.5rem;
}
@media only screen and (max-width: 559px) {
  .re-instructor__unitsubttl {
    font-size: 2rem;
    margin-bottom: 2rem;
    line-height: 1.3;
  }
}
.re-instructor__unitsubttl span {
  font-size: 2rem;
}
@media only screen and (max-width: 559px) {
  .re-instructor__unitsubttl span {
    font-size: 1.6rem;
  }
}
.re-instructor__unitcont:not(:last-child) {
  margin-bottom: 4.5rem;
}
.re-instructor__unititem {
  font-size: 1.8rem;
  letter-spacing: 0.05em;
  line-height: 2;
  display: flex;
}
@media only screen and (max-width: 559px) {
  .re-instructor__unititem {
    font-size: 1.4rem;
    line-height: 1.5;
    margin-bottom: 1rem;
  }
}

.re-feature {
  margin-bottom: 28rem;
}
@media only screen and (max-width: 559px) {
  .re-feature {
    margin-bottom: 8rem;
  }
}
@media only screen and (max-width: 559px) {
  .re-feature .primary-ttl__img {
    width: 30%;
  }
}
.re-feature__item:not(:last-child) {
  margin-bottom: 4.5rem;
}
@media only screen and (max-width: 559px) {
  .re-feature__item:not(:last-child) {
    margin-bottom: 2.5rem;
  }
}
.re-feature__figure {
  text-align: center;
}
.re-feature__subttl {
  color: var(--colorW);
  margin-bottom: 3rem;
  width: fit-content;
  margin-inline: auto;
  font-size: 4.2rem;
  letter-spacing: 0.05em;
  padding: 1.4rem 3.4rem;
  margin-top: -4.5rem;
  z-index: 10;
  position: relative;
}
@media only screen and (max-width: 559px) {
  .re-feature__subttl {
    font-size: 2rem;
    padding: 0.5rem 1.5rem;
    text-align: center;
    margin-top: -3rem;
    margin-bottom: 1.5rem;
    line-height: 1.4;
  }
}
.re-feature__text {
  text-align: center;
  color: var(--mainColor);
  font-size: 2rem;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 559px) {
  .re-feature__text {
    font-size: 1.6rem;
  }
}
@media only screen and (max-width: 559px) {
  .re-feature img {
    width: 60%;
  }
}

.re-record {
  margin-bottom: 14rem;
}
@media only screen and (max-width: 559px) {
  .re-record {
    margin-bottom: 7rem;
  }
}
.re-record .quaternary-ttl__area {
  position: relative;
  margin-top: -36rem;
  margin-bottom: 12rem;
}
@media only screen and (max-width: 559px) {
  .re-record .quaternary-ttl__area {
    margin-top: -13rem;
    margin-bottom: 4rem;
  }
}
@media only screen and (max-width: 559px) {
  .re-record .quaternary-ttl__area img {
    width: 30%;
  }
}
@media only screen and (max-width: 559px) {
  .re-record .quaternary-ttl--center {
    margin-top: -8rem;
    font-size: 3.6rem;
  }
}
.re-record__box {
  background-color: var(--colorW);
  border-radius: 4rem;
  position: relative;
  padding-bottom: 12rem;
}
@media only screen and (max-width: 559px) {
  .re-record__box {
    border-radius: 2rem;
    padding-inline: 2rem;
    padding-bottom: 4rem;
    padding-top: 3rem;
  }
}
.re-record__img {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: -8rem;
}
@media only screen and (max-width: 559px) {
  .re-record__img {
    top: -1rem;
  }
}
.re-record__subttl {
  margin-bottom: 4.5rem;
  text-align: center;
  color: var(--mainColor);
  font-size: 3.8rem;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 559px) {
  .re-record__subttl {
    margin-bottom: 1.5rem;
    font-size: 2rem;
    line-height: 1.3;
  }
}
.re-record__textarea:not(:last-child) {
  margin-bottom: 9rem;
}
@media only screen and (max-width: 559px) {
  .re-record__textarea:not(:last-child) {
    margin-bottom: 3rem;
  }
}
.re-record__text {
  font-size: 1.6rem;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 559px) {
  .re-record__text {
    font-size: 1.2rem;
  }
}

.re-flow {
  margin-bottom: 14rem;
}
@media only screen and (max-width: 559px) {
  .re-flow {
    margin-bottom: 7rem;
  }
}
@media only screen and (max-width: 559px) {
  .re-flow .primary-ttl__area {
    text-align: center;
    margin-bottom: 14rem;
  }
}
@media only screen and (max-width: 559px) {
  .re-flow .primary-ttl__img {
    width: 30%;
    top: 1.5rem;
  }
}
.re-flow__list {
  margin-bottom: 24rem;
}
@media only screen and (max-width: 559px) {
  .re-flow__list {
    margin-bottom: 18rem;
  }
}
@media only screen and (max-width: 559px) {
  .re-flow {
    margin-bottom: 6rem;
  }
}
.re-flow__item {
  padding: 3.5rem 6.5rem;
  background-color: var(--colorW);
  border-radius: 2.5rem;
  position: relative;
  z-index: 0;
}
@media only screen and (max-width: 559px) {
  .re-flow__item {
    padding: 3rem 2rem;
  }
}
.re-flow__item:not(:last-child) {
  margin-bottom: 7.5rem;
}
@media only screen and (max-width: 559px) {
  .re-flow__item:not(:last-child) {
    margin-bottom: 5rem;
  }
}
.re-flow__item:not(:last-child)::after {
  content: "";
  background: url(../img/icon__bottom.webp) no-repeat center center/contain;
  width: 5.5rem;
  height: 3.3rem;
  position: absolute;
  bottom: -5rem;
  left: 50%;
  transform: translateX(-50%);
}
@media only screen and (max-width: 559px) {
  .re-flow__item:not(:last-child)::after {
    width: 3rem;
    height: 2rem;
    bottom: -3.5rem;
  }
}
.re-flow__item::before {
  content: "";
  position: absolute;
  top: -0.2rem;
  left: -0.2rem;
  right: -0.2rem;
  bottom: -0.2rem;
  z-index: -1;
  background: #18bde7;
  background: linear-gradient(90deg, rgb(24, 189, 231) 0%, rgb(23, 42, 136) 100%);
  border-radius: 2.5rem;
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  padding: 0.2rem;
}
@media only screen and (max-width: 559px) {
  .re-flow__item::before {
    padding: 0.3rem;
    top: -0.3rem;
    left: -0.3rem;
    right: -0.3rem;
    bottom: -0.3rem;
    border-radius: 2rem;
  }
}
.re-flow__number {
  font-family: var(--jost);
  color: var(--colorW);
  border-radius: calc(infinity * 1px);
  width: fit-content;
  font-size: 1.6rem;
  letter-spacing: 0.2em;
  padding: 1rem 1.8rem;
  line-height: 1;
  position: absolute;
  top: -3rem;
  left: 0;
}
@media only screen and (max-width: 559px) {
  .re-flow__number {
    font-size: 1.2rem;
    padding: 0.5rem 1.5rem;
    top: -2rem;
  }
}
.re-flow__number span {
  font-size: 2.9rem;
  letter-spacing: 0.3em;
}
@media only screen and (max-width: 559px) {
  .re-flow__number span {
    font-size: 2.3rem;
  }
}
.re-flow__subttl {
  color: var(--mainColor);
  font-size: 2.8rem;
  letter-spacing: 0.05em;
  margin-bottom: 1.5rem;
}
@media only screen and (max-width: 559px) {
  .re-flow__subttl {
    font-size: 2rem;
  }
}
.re-flow__sublist {
  width: 80%;
}
@media only screen and (max-width: 559px) {
  .re-flow__sublist {
    width: 100%;
  }
}
.re-flow__subitem {
  font-size: 1.6rem;
  letter-spacing: 0.05em;
  display: flex;
  line-height: 1.5;
}
@media only screen and (max-width: 559px) {
  .re-flow__subitem {
    font-size: 1.2rem;
  }
}
.re-flow__figure {
  position: absolute;
  top: -4rem;
  right: 1rem;
}
@media only screen and (max-width: 559px) {
  .re-flow__figure {
    right: 0;
  }
}
@media only screen and (max-width: 559px) {
  .re-flow__figure img {
    width: 10rem;
    height: 10rem;
  }
}
.re-flow__reward {
  border-radius: 20rem 3rem 30rem 3rem;
  background-color: var(--colorW);
  padding-bottom: 7rem;
}
@media only screen and (max-width: 559px) {
  .re-flow__reward {
    border-radius: 6rem 0.5rem 8rem 0.5rem;
    padding-bottom: 4rem;
    padding-inline: 2rem;
  }
}
.re-flow__rewardttlarea {
  margin-bottom: -2rem;
  position: relative;
  top: -5.5rem;
}
.re-flow__rewardttlarea::before {
  content: "";
  background: url(../img/mark__img01.svg) no-repeat center center/contain;
  width: 24.9rem;
  height: 23.6rem;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0;
}
@media only screen and (max-width: 559px) {
  .re-flow__rewardttlarea::before {
    width: 16rem;
    height: 18rem;
  }
}
.re-flow__rewardttlja {
  width: fit-content;
  margin-inline: auto;
  font-size: 2rem;
  line-height: 1;
  margin-bottom: 1.5rem;
  font-weight: 500;
}
@media only screen and (max-width: 559px) {
  .re-flow__rewardttlja {
    font-size: 1.4rem;
    margin-bottom: 1rem;
  }
}
.re-flow__rewardttl {
  color: var(--mainColor);
  text-align: center;
  font-size: 4rem;
  line-height: 1;
  margin-bottom: 1rem;
}
@media only screen and (max-width: 559px) {
  .re-flow__rewardttl {
    font-size: 2.6rem;
    margin-bottom: 0.5rem;
  }
}
.re-flow__rewardttlen {
  width: fit-content;
  margin-inline: auto;
  font-size: 2.4rem;
  padding-bottom: 3rem;
  font-weight: 500;
}
@media only screen and (max-width: 559px) {
  .re-flow__rewardttlen {
    font-size: 1.4rem;
  }
}
.re-flow__rewardsubttl {
  color: var(--colorW);
  width: fit-content;
  margin-inline: auto;
  font-size: 1.6rem;
  letter-spacing: 0.05em;
  margin-bottom: 2rem;
  padding: 0.4rem 1rem;
}
@media only screen and (max-width: 559px) {
  .re-flow__rewardsubttl {
    font-size: 1.4rem;
    padding: 0.2rem 0.5rem;
    margin-bottom: 1rem;
  }
}
.re-flow__rewardfee {
  text-align: center;
  color: var(--mainColor);
  font-size: 2.7rem;
  line-height: 1;
}
@media only screen and (max-width: 559px) {
  .re-flow__rewardfee {
    font-size: 2rem;
  }
}
.re-flow__rewardfee span {
  font-family: var(--jost);
  font-size: 5.5rem;
}
@media only screen and (max-width: 559px) {
  .re-flow__rewardfee span {
    font-size: 3.6rem;
  }
}
.re-flow__rewardtax {
  font-size: 1.8rem;
  letter-spacing: 0.05em;
  text-align: center;
  color: var(--mainColor);
  line-height: 1;
  margin-bottom: 2.5rem;
}
@media only screen and (max-width: 559px) {
  .re-flow__rewardtax {
    font-size: 1.4rem;
    margin-bottom: 2rem;
  }
}
.re-flow__rewardtextarea {
  margin-bottom: 6rem;
}
@media only screen and (max-width: 559px) {
  .re-flow__rewardtextarea {
    margin-bottom: 3rem;
  }
}
.re-flow__rewardnote {
  text-align: center;
  color: var(--mainColor);
  font-size: 1.6rem;
  line-height: 1.875;
}
@media only screen and (max-width: 559px) {
  .re-flow__rewardnote {
    font-size: 1.2rem;
  }
}

.re-scene {
  margin-bottom: 12rem;
}
@media only screen and (max-width: 559px) {
  .re-scene {
    margin-bottom: 6rem;
  }
}
@media only screen and (max-width: 559px) {
  .re-scene .primary-ttl__img {
    width: 40%;
  }
}
.re-scene__movie {
  text-align: center;
  margin-bottom: 6rem;
}
@media only screen and (max-width: 559px) {
  .re-scene__movie {
    margin-bottom: 1rem;
  }
}
.re-scene__movie iframe {
  width: 73.6rem;
  aspect-ratio: 16/9;
  height: auto;
  object-fit: cover;
  border-radius: 2rem;
}
@media only screen and (max-width: 559px) {
  .re-scene__movie iframe {
    width: 100%;
    border-radius: 1rem;
  }
}
.re-scene .o-card figure {
  width: 100%;
}
.re-scene .o-card figure img {
  width: 100%;
}
.re-scene__3wrap {
  gap: 5.5rem;
  margin-bottom: 3rem;
}
@media only screen and (max-width: 559px) {
  .re-scene__3wrap {
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    margin-bottom: 1rem;
  }
}
.re-scene__4wrap {
  gap: 3rem;
}
@media only screen and (max-width: 559px) {
  .re-scene__4wrap {
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
  }
}

.re-contact {
  background: url(../img/re-contact__bg.webp) no-repeat center left/cover;
  min-height: 71rem;
}
@media only screen and (max-width: 559px) {
  .re-contact {
    padding-inline: 6%;
    min-height: 50rem;
  }
}
.re-contact__ttl {
  text-align: center;
  font-size: 5rem;
  letter-spacing: 0.05em;
  margin-bottom: 7.5rem;
  color: var(--colorW);
  line-height: 1.5;
}
@media only screen and (max-width: 559px) {
  .re-contact__ttl {
    font-size: 2.8rem;
    text-align: center;
    margin-bottom: 3rem;
  }
}
.re-contact__text {
  font-size: 1.8rem;
  letter-spacing: 0.05em;
  color: var(--colorW);
  text-align: center;
}
@media only screen and (max-width: 559px) {
  .re-contact__text {
    font-size: 1.4rem;
    text-align: center;
  }
}
.re-contact__textarea {
  margin-bottom: 3.5rem;
}
@media only screen and (max-width: 559px) {
  .re-contact__textarea {
    margin-bottom: 2rem;
  }
}
.re-contact__box {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
}
@media only screen and (max-width: 559px) {
  .re-contact__box {
    width: 88%;
  }
}

@media only screen and (max-width: 559px) {
  .bt-summary {
    margin-bottom: 3rem;
  }
}

.bt-about {
  margin-bottom: 10rem;
}
@media only screen and (max-width: 559px) {
  .bt-about {
    margin-bottom: 7rem;
  }
}
@media only screen and (max-width: 559px) {
  .bt-about .wrapper {
    display: contents;
  }
}
.bt-about__textarea {
  margin-bottom: 9rem;
}
@media only screen and (max-width: 559px) {
  .bt-about__textarea {
    margin-bottom: 4.5rem;
  }
}
.bt-about__text {
  font-size: 2rem;
  letter-spacing: 0.05em;
  text-align: center;
}
@media only screen and (max-width: 559px) {
  .bt-about__text {
    font-size: 1.4rem;
    text-align: left;
  }
}
.bt-about__text:not(:last-child) {
  margin-bottom: 4rem;
}
@media only screen and (max-width: 559px) {
  .bt-about__text:not(:last-child) {
    margin-bottom: 2rem;
  }
}
.bt-about__text .bg-grd {
  color: var(--colorW);
  padding-inline: 1rem;
}
.bt-about__text .bg-gr {
  background-color: var(--baseColor);
  color: var(--base20Color);
  padding-inline: 1rem;
}
@media only screen and (max-width: 559px) {
  .bt-about__text .bg-gr {
    padding-inline: 0;
  }
}
.bt-about__text .bl {
  color: var(--mainColor);
}
.bt-about__box {
  background-color: var(--colorW);
  border-radius: 3rem;
  padding: 0 0 4.5rem;
}
@media only screen and (max-width: 559px) {
  .bt-about__box {
    border-radius: 2rem;
    padding: 0 0 3rem;
  }
}
.bt-about__boxttlarea {
  margin-bottom: 0rem;
  position: relative;
  top: -2rem;
}
@media only screen and (max-width: 559px) {
  .bt-about__boxttlarea {
    top: -1rem;
    margin-bottom: 2rem;
  }
}
.bt-about__boxttl {
  color: var(--mainColor);
  text-align: center;
  font-size: 2.6rem;
  margin-bottom: 0.5rem;
}
@media only screen and (max-width: 559px) {
  .bt-about__boxttl {
    font-size: 2rem;
  }
}
.bt-about__boxttlen {
  width: fit-content;
  margin-inline: auto;
  font-size: 2rem;
  font-family: var(--jost);
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 559px) {
  .bt-about__boxttlen {
    font-size: 1.4rem;
  }
}
.bt-about__boxtext {
  text-align: center;
  font-size: 3rem;
  line-height: 1;
}
@media only screen and (max-width: 559px) {
  .bt-about__boxtext {
    font-size: 1.8rem;
    line-height: 1.2;
  }
}
.bt-about__boxtext:not(:last-child) {
  margin-bottom: 0.5rem;
}
.bt-about__boxtext .bl {
  color: var(--mainColor);
}
.bt-about__boxtext .jos {
  font-family: var(--jost);
  font-size: 200%;
}
.bt-about__boxtext .grd {
  padding-block: 1rem;
}
.bt-about__figure {
  text-align: center;
  margin-top: -3rem;
}
@media only screen and (max-width: 559px) {
  .bt-about__figure img {
    width: 50%;
    margin-inline: auto;
  }
}

.bt-rec {
  margin-bottom: 12rem;
}
@media only screen and (max-width: 559px) {
  .bt-rec {
    margin-bottom: 6rem;
  }
}
@media only screen and (max-width: 559px) {
  .bt-rec .wrapper {
    display: contents;
  }
}
.bt-rec__ttlarea {
  margin-bottom: 2rem;
  position: relative;
  top: -4rem;
}
@media only screen and (max-width: 559px) {
  .bt-rec__ttlarea {
    top: -8rem;
  }
}
.bt-rec__wrap {
  background-color: var(--colorW);
  border-radius: 10rem;
  padding: 0 15rem 12rem;
}
@media only screen and (max-width: 559px) {
  .bt-rec__wrap {
    border-radius: 5rem;
    padding: 3rem 2rem 4rem;
  }
}
.bt-rec__text {
  font-size: 1.8rem;
  letter-spacing: 0.05em;
  margin-bottom: 6.5rem;
  text-align: center;
}
@media only screen and (max-width: 559px) {
  .bt-rec__text {
    margin-top: -10rem;
    font-size: 1.4rem;
    text-align-last: left;
    margin-bottom: 3rem;
  }
}
.bt-rec__list {
  width: 73rem;
  margin-left: auto;
  margin-bottom: 6.5rem;
}
@media only screen and (max-width: 559px) {
  .bt-rec__list {
    width: 100%;
    margin-bottom: 3rem;
  }
}
.bt-rec__item {
  display: flex;
  gap: 0.8rem;
}
.bt-rec__item:not(:last-child) {
  margin-bottom: 4rem;
}
@media only screen and (max-width: 559px) {
  .bt-rec__item:not(:last-child) {
    margin-bottom: 1.5rem;
  }
}
.bt-rec__item img {
  align-self: flex-start;
  padding-top: 1rem;
}
@media only screen and (max-width: 559px) {
  .bt-rec__item img {
    padding-top: 0.5rem;
  }
}
.bt-rec__itemtext {
  font-size: 2rem;
  letter-spacing: 0.05em;
  line-height: 1.6;
}
@media only screen and (max-width: 559px) {
  .bt-rec__itemtext {
    font-size: 1.6rem;
    line-height: 1.4;
  }
}
.bt-rec__itemtext span {
  font-size: 2.6rem;
  letter-spacing: 0.05em;
  color: var(--mainColor);
}
@media only screen and (max-width: 559px) {
  .bt-rec__itemtext span {
    font-size: 1.8rem;
  }
}
.bt-rec__message {
  text-align: center;
  font-size: 3.2rem;
  color: var(--mainColor);
  line-height: 2.5;
  margin-bottom: 7rem;
}
@media only screen and (max-width: 559px) {
  .bt-rec__message {
    margin-bottom: 3.5rem;
    font-size: 2.2rem;
    line-height: 1.5;
  }
}
.bt-rec__message span {
  color: var(--colorW);
  font-size: 4.6rem;
  display: block;
  width: fit-content;
  margin-inline: auto;
  padding: 1rem 2rem;
  line-height: 1;
}
@media only screen and (max-width: 559px) {
  .bt-rec__message span {
    font-size: 2.8rem;
    padding: 0.5rem 1rem;
    margin-block: 1rem;
  }
}
@media only screen and (max-width: 559px) {
  .bt-rec + .wrapper {
    display: contents;
  }
}

.bt-plan__wrap {
  position: relative;
  z-index: 0;
  padding: 7rem 2rem 13rem;
  background-color: rgba(255, 255, 255, 0.5);
  border-radius: 0 7rem 0 7rem;
  overflow: hidden;
}
@media only screen and (max-width: 559px) {
  .bt-plan__wrap {
    border-radius: 0 4rem 0 4rem;
    padding: 4rem 2rem 4rem;
  }
}
.bt-plan__wrap::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: -1;
  border: 0.6rem solid transparent;
  border-radius: inherit;
  background-image: linear-gradient(90deg, rgba(24, 189, 231, 0.5) 0%, rgba(23, 42, 136, 0.5) 100%);
  background-origin: border-box;
  -webkit-mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: destination-out;
  mask-composite: exclude;
}
.bt-plan__ttlarea {
  margin-bottom: 7.5rem;
}
@media only screen and (max-width: 559px) {
  .bt-plan__ttlarea {
    margin-bottom: 3.5rem;
  }
}
.bt-plan__subttl {
  color: var(--mainColor);
  text-align: center;
  font-size: 2.4rem;
  margin-bottom: 2rem;
}
@media only screen and (max-width: 559px) {
  .bt-plan__subttl {
    font-size: 1.8rem;
    margin-bottom: 1.5rem;
  }
}
.bt-plan__ttl {
  position: relative;
  color: var(--mainColor);
  width: fit-content;
  font-size: 4.6rem;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 3.3rem;
  margin-inline: auto;
  margin-bottom: 2rem;
}
@media only screen and (max-width: 559px) {
  .bt-plan__ttl {
    font-size: 2.2rem;
    gap: 1rem;
    margin-bottom: 1rem;
  }
}
.bt-plan__ttl::before, .bt-plan__ttl::after {
  content: "";
  width: 15.2rem;
  height: 0.3rem;
  background: #18bde7;
  background: linear-gradient(90deg, rgb(24, 189, 231) 0%, rgb(23, 42, 136) 100%);
  position: relative;
  display: inline-block;
}
@media only screen and (max-width: 559px) {
  .bt-plan__ttl::before, .bt-plan__ttl::after {
    width: 3rem;
  }
}
.bt-plan__ttlen {
  font-family: var(--jost);
  font-size: 2rem;
  letter-spacing: 0.1em;
  width: fit-content;
  margin-inline: auto;
}
@media only screen and (max-width: 559px) {
  .bt-plan__ttlen {
    font-size: 1.4rem;
  }
}
.bt-plan__grid {
  display: grid;
  grid-template-columns: 47rem 47rem;
  gap: 5.5rem;
  width: fit-content;
  margin-inline: auto;
}
@media only screen and (max-width: 559px) {
  .bt-plan__grid {
    grid-template-columns: repeat(1, 1fr);
    gap: 1rem;
    background-color: var(--main50Color);
    padding: 1.5rem;
    border-radius: 2rem;
    width: 100%;
  }
}
.bt-plan__griditem {
  background-color: var(--colorW);
  border: solid 0.6rem var(--main50Color);
  border-radius: 4rem;
  padding: 3rem;
}
@media only screen and (max-width: 559px) {
  .bt-plan__griditem {
    padding: 1rem;
    border-radius: 2rem;
    border: solid 0.2rem var(--main50Color);
  }
}
.bt-plan__gridttl {
  color: var(--mainColor);
  font-size: 2.8rem;
  text-align: center;
  margin-bottom: 2.4rem;
}
@media only screen and (max-width: 559px) {
  .bt-plan__gridttl {
    font-size: 2rem;
    margin-bottom: 1.5rem;
  }
}
.bt-plan__gridttl span {
  font-size: 3.6rem;
}
@media only screen and (max-width: 559px) {
  .bt-plan__gridttl span {
    font-size: 2.4rem;
  }
}
.bt-plan__griditem {
  text-align: center;
  font-size: 2rem;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 559px) {
  .bt-plan__griditem {
    font-size: 1.2rem;
  }
}
.bt-plan__arrow {
  text-align: center;
  margin-top: -0.1rem;
  margin-bottom: 2rem;
  display: flex;
  justify-content: center;
}
@media only screen and (max-width: 559px) {
  .bt-plan__arrow {
    margin-inline: auto;
  }
}
.bt-plan__arrow--02 {
  margin-top: 0;
}
@media only screen and (max-width: 559px) {
  .bt-plan__arrow img {
    margin-inline: auto;
    width: 20%;
  }
}
.bt-plan__flex {
  display: flex;
  gap: 4.5rem;
  justify-content: center;
}
@media only screen and (max-width: 559px) {
  .bt-plan__flex {
    gap: 0;
    position: relative;
  }
}
.bt-plan__flexcircle {
  border-radius: 50%;
  width: 25.2rem;
  height: 25.2rem;
  color: var(--colorW);
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  font-size: 3.2rem;
  line-height: 1.5;
  margin-bottom: 2rem;
}
@media only screen and (max-width: 559px) {
  .bt-plan__flexcircle {
    font-size: 1.4rem;
    width: 12rem;
    height: 12rem;
  }
}
.bt-plan__flexcircle::before {
  content: "";
  width: 27.5rem;
  height: 27.5rem;
  border-radius: 50%;
  background: #18bde7;
  background: linear-gradient(90deg, rgba(24, 189, 231, 0.3) 0%, rgba(23, 42, 136, 0.3) 100%);
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: -1;
}
@media only screen and (max-width: 559px) {
  .bt-plan__flexcircle::before {
    width: 13rem;
    height: 13rem;
  }
}
.bt-plan__flexnote {
  text-align: center;
  color: var(--mainColor);
  font-size: 2rem;
  line-height: 1.55;
}
@media only screen and (max-width: 559px) {
  .bt-plan__flexnote {
    font-size: 1.2rem;
  }
}
.bt-plan__flexitem--01 {
  margin-top: 6.5rem;
}
@media only screen and (max-width: 559px) {
  .bt-plan__flexitem--01 {
    position: absolute;
    top: 18rem;
    left: 0;
  }
}
@media only screen and (max-width: 559px) {
  .bt-plan__flexitem--03 {
    left: inherit;
    right: 0;
  }
}
.bt-plan__flexbox {
  position: relative;
  z-index: 0;
  padding: 4rem 2rem;
  background-color: #fff;
  border-radius: 4rem;
}
@media only screen and (max-width: 559px) {
  .bt-plan__flexbox {
    padding: 2rem 2rem;
    border-radius: 2rem;
  }
}
.bt-plan__flexbox::before {
  content: "";
  position: absolute;
  top: -0.7rem;
  left: -0.7rem;
  right: -0.7rem;
  bottom: -0.7rem;
  z-index: -1;
  background: #18bde7;
  background: linear-gradient(90deg, rgb(24, 189, 231) 0%, rgb(23, 42, 136) 100%);
  border-radius: 4.7rem;
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  padding: 0.7rem;
}
@media only screen and (max-width: 559px) {
  .bt-plan__flexbox::before {
    padding: 0.3rem;
    top: -0.3rem;
    left: -0.3rem;
    right: -0.3rem;
    bottom: -0.3rem;
    border-radius: 2rem;
  }
}
.bt-plan__flexboxttl {
  width: fit-content;
  margin-inline: auto;
  font-size: 4.4rem;
  margin-bottom: 3rem;
}
@media only screen and (max-width: 559px) {
  .bt-plan__flexboxttl {
    font-size: 2.8rem;
    margin-bottom: 1.5rem;
  }
}
.bt-plan__flexlistitem {
  display: flex;
  font-size: 2.2rem;
  letter-spacing: 0.05em;
  line-height: 1.5;
}
@media only screen and (max-width: 559px) {
  .bt-plan__flexlistitem {
    font-size: 1.4rem;
    line-height: 1.3;
  }
}
.bt-plan__flexlistitem:not(:last-child) {
  margin-bottom: 2rem;
}
@media only screen and (max-width: 559px) {
  .bt-plan__flexlistitem:not(:last-child) {
    margin-bottom: 1rem;
  }
}
.bt-plan__flextext {
  text-align: center;
  font-size: 2.2rem;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 559px) {
  .bt-plan__flextext {
    font-size: 1.4rem;
  }
}
.bt-plan__text {
  font-size: 5.8rem;
  color: var(--colorW);
  width: fit-content;
  margin-inline: auto;
  line-height: 1;
  padding: 1rem 2rem 1.5rem;
}
@media only screen and (max-width: 559px) {
  .bt-plan__text {
    font-size: 3rem;
    padding: 0.5rem 3rem 1rem;
  }
}
.bt-plan__figure {
  text-align: center;
  margin-top: -10rem;
  margin-bottom: 8rem;
}
@media only screen and (max-width: 559px) {
  .bt-plan__figure {
    margin-top: -4rem;
    margin-bottom: 4rem;
  }
}
@media only screen and (max-width: 559px) {
  .bt-plan__figure img {
    width: 40%;
  }
}

.bt-system {
  margin-bottom: 12rem;
}
@media only screen and (max-width: 559px) {
  .bt-system {
    margin-bottom: 3rem;
  }
}
.bt-system__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 6rem;
  margin-bottom: 5.5rem;
}
@media only screen and (max-width: 559px) {
  .bt-system__grid {
    grid-template-columns: repeat(1, 1fr);
    gap: 3rem;
    margin-bottom: 3rem;
  }
}
@media only screen and (max-width: 559px) {
  .bt-system__ttlarea img {
    width: 30%;
  }
}
.bt-system__ttl {
  color: var(--mainColor);
  font-size: 3.8rem;
  margin-bottom: 2rem;
  line-height: 1.3947368421;
  margin-top: -11rem;
}
@media only screen and (max-width: 559px) {
  .bt-system__ttl {
    font-size: 2.2rem;
    line-height: 1.4;
    margin-top: -6rem;
  }
}
.bt-system__text {
  font-size: 1.8rem;
  letter-spacing: 0.05em;
  font-weight: 500;
}
@media only screen and (max-width: 559px) {
  .bt-system__text {
    font-size: 1.4rem;
  }
}
.bt-system__note {
  font-size: 1.6rem;
  letter-spacing: 0.05em;
  text-align: center;
}
@media only screen and (max-width: 559px) {
  .bt-system__note {
    font-size: 1.2rem;
    text-align-last: left;
  }
}

.pd-summary .bs-summary__textarea {
  margin-bottom: 8rem;
}
@media only screen and (max-width: 559px) {
  .pd-summary .bs-summary__textarea {
    margin-bottom: 4rem;
  }
}
.pd-summary .bs-summary__cont {
  padding-bottom: 0;
}
@media only screen and (max-width: 559px) {
  .pd-summary .bs-summary__cont {
    margin-top: -5.5rem;
  }
}
@media only screen and (max-width: 559px) {
  .pd-summary .ab-philosophy__deco {
    top: -12rem;
  }
}

.pd-about {
  margin-bottom: 12rem;
}
@media only screen and (max-width: 559px) {
  .pd-about {
    margin-bottom: 6rem;
    padding-bottom: 1rem;
  }
}
.pd-about__figure {
  text-align: center;
  margin-top: 2.5rem;
}
@media only screen and (max-width: 559px) {
  .pd-about__figure {
    padding-inline: 2rem;
  }
}

.page-detail-pdca .bs-movie {
  margin-bottom: 12rem;
}
@media only screen and (max-width: 559px) {
  .page-detail-pdca .bs-movie {
    margin-bottom: 6rem;
  }
}
.page-detail-pdca .cm-faq {
  margin-bottom: 30rem;
}
@media only screen and (max-width: 559px) {
  .page-detail-pdca .cm-faq {
    margin-bottom: 13rem;
  }
}

.pd-concern {
  background: #f2f2f2;
  border-radius: 10rem;
  padding: 7.5rem 0 12rem;
  width: 160rem;
  margin-inline: auto;
  margin-bottom: 12rem;
}
@media only screen and (max-width: 1536px) {
  .pd-concern {
    width: 100%;
  }
}
@media only screen and (max-width: 559px) {
  .pd-concern {
    border-radius: 5rem;
    padding: 3.5rem 0 6rem;
    margin-bottom: 6rem;
  }
}
.pd-concern__ttlarea {
  margin-bottom: 3.5rem;
  text-align: center;
}
.pd-concern__ttl {
  text-align: center;
  color: var(--mainColor);
  margin-bottom: 2rem;
  line-height: 1;
  font-size: 4.4rem;
}
@media only screen and (max-width: 559px) {
  .pd-concern__ttl {
    font-size: 3rem;
    margin-bottom: 1.5rem;
  }
}
.pd-concern__ttlen {
  text-align: center;
  font-family: var(--jost);
  font-size: 2.4rem;
  color: #767676;
  line-height: 1;
}
@media only screen and (max-width: 559px) {
  .pd-concern__ttlen {
    font-size: 1.4rem;
  }
}
.pd-concern__ttlimg {
  margin-bottom: 3rem;
}
@media only screen and (max-width: 559px) {
  .pd-concern__ttlimg {
    margin-bottom: 1.5rem;
  }
}
.pd-concern__text {
  text-align: center;
  font-size: 2.2rem;
  letter-spacing: 0.05em;
  margin-bottom: 6rem;
}
@media only screen and (max-width: 559px) {
  .pd-concern__text {
    font-size: 1.8rem;
    margin-bottom: 3rem;
  }
}
.pd-concern__text--2nd {
  font-size: 1.8rem;
  letter-spacing: 0.05em;
  margin-bottom: 0;
}
@media only screen and (max-width: 559px) {
  .pd-concern__text--2nd {
    font-size: 1.4rem;
    text-align: left;
  }
}
.pd-concern__list-flex {
  display: grid;
  gap: 4rem;
  grid-template-columns: 55.7rem auto;
  justify-items: center;
  margin-bottom: 5.5rem;
}
@media only screen and (max-width: 559px) {
  .pd-concern__list-flex {
    display: flex;
    flex-direction: column-reverse;
    margin-bottom: 3rem;
  }
}
.pd-concern__item {
  display: flex;
  font-size: 2.6rem;
  letter-spacing: 0.05em;
  line-height: 1.3846153846;
}
@media only screen and (max-width: 559px) {
  .pd-concern__item {
    font-size: 1.6rem;
  }
}
.pd-concern__item:not(:last-child) {
  margin-bottom: 3rem;
}
@media only screen and (max-width: 559px) {
  .pd-concern__item:not(:last-child) {
    margin-bottom: 2rem;
  }
}
.pd-concern__item .yellow {
  position: relative;
  z-index: 0;
}
.pd-concern__item .yellow::after {
  content: "";
  width: 100%;
  height: 1.4rem;
  background: #fcee21;
  position: absolute;
  bottom: -0.5rem;
  left: 0;
  z-index: -1;
}
@media only screen and (max-width: 559px) {
  .pd-concern__item .yellow::after {
    height: 1rem;
    bottom: 0rem;
  }
}

@media only screen and (max-width: 559px) {
  .pd-reason .wrapper {
    display: contents;
  }
}
.pd-reason__textarea {
  margin-bottom: 9rem;
}
@media only screen and (max-width: 559px) {
  .pd-reason__textarea {
    margin-bottom: 4.5rem;
  }
}
.pd-reason__text {
  text-align: center;
  font-size: 2rem;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 559px) {
  .pd-reason__text {
    font-size: 1.4rem;
    text-align: left;
  }
}
.pd-reason__text span {
  color: var(--colorW);
}
.pd-reason__item:not(:last-child) {
  margin-bottom: 5rem;
}
@media only screen and (max-width: 559px) {
  .pd-reason__item:not(:last-child) {
    margin-bottom: 2.5rem;
  }
}
.pd-reason__list {
  margin-bottom: 12rem;
}
@media only screen and (max-width: 559px) {
  .pd-reason__list {
    margin-bottom: 6rem;
  }
}
.pd-reason__list-number {
  text-align: center;
  color: var(--mainColor);
  font-size: 3.6rem;
  width: fit-content;
  margin-inline: auto;
  margin-bottom: 2.5rem;
}
@media only screen and (max-width: 559px) {
  .pd-reason__list-number {
    font-size: 2.6rem;
    margin-bottom: 1rem;
  }
}
.pd-reason__list-number span {
  font-size: 150%;
}
.pd-reason__list-ttl {
  text-align: center;
  font-size: 3.4rem;
  line-height: 2.4;
  margin-bottom: 2rem;
}
@media only screen and (max-width: 559px) {
  .pd-reason__list-ttl {
    font-size: 2rem;
    margin-bottom: 1rem;
  }
}
.pd-reason__list-ttl span {
  background-color: var(--baseColor);
  color: var(--base50Color);
  padding: 0.7rem 1.7rem;
}
@media only screen and (max-width: 559px) {
  .pd-reason__list-ttl span {
    padding: 0.4rem 1.2rem;
  }
}
.pd-reason__list-text {
  text-align: center;
  font-size: 1.8rem;
  letter-spacing: 0.05em;
  margin-bottom: 3.5rem;
}
@media only screen and (max-width: 559px) {
  .pd-reason__list-text {
    font-size: 1.4rem;
    margin-bottom: 2rem;
    text-align: left;
  }
}
.pd-reason__list-figure {
  text-align: center;
}
@media only screen and (max-width: 559px) {
  .pd-reason__list-figure {
    width: 60%;
    margin-inline: auto;
  }
}
.pd-reason__visu {
  background-color: var(--baseColor);
  text-align: center;
  padding: 6.5rem 0;
}
@media only screen and (max-width: 559px) {
  .pd-reason__visu {
    padding: 3rem 0;
  }
}
@media only screen and (max-width: 559px) {
  .pd-reason__visu img {
    width: 50%;
  }
}

.pd-us {
  padding: 12rem 0 0;
}
@media only screen and (max-width: 559px) {
  .pd-us {
    padding: 6rem 0;
  }
}
@media only screen and (max-width: 559px) {
  .pd-us .wrapper {
    display: contents;
  }
}
@media only screen and (max-width: 559px) {
  .pd-us + .wrapper {
    display: contents;
  }
}
.pd-us__ttlarea {
  text-align: center;
  margin-bottom: 4rem;
  z-index: 0;
}
@media only screen and (max-width: 559px) {
  .pd-us__ttlarea {
    margin-bottom: 2.5rem;
  }
}
.pd-us__ttlarea img:first-child {
  margin-bottom: 2.5rem;
}
@media only screen and (max-width: 559px) {
  .pd-us__ttlarea img:first-child {
    margin-bottom: 1.5rem;
  }
}
.pd-us__ttlarea img:last-child {
  margin-top: -12rem;
  z-index: -1;
}
@media only screen and (max-width: 559px) {
  .pd-us__ttlarea img:last-child {
    margin-top: -6rem;
    width: 50%;
  }
}
.pd-us__ttl {
  color: var(--mainColor);
  font-size: 5.6rem;
  line-height: 1;
  margin-bottom: 1.5rem;
}
@media only screen and (max-width: 559px) {
  .pd-us__ttl {
    font-size: 2.6rem;
  }
}
.pd-us__ttlen {
  width: fit-content;
  margin-inline: auto;
  font-family: var(--jost);
  font-size: 2.4rem;
}
@media only screen and (max-width: 559px) {
  .pd-us__ttlen {
    font-size: 1.4rem;
  }
}
.pd-us__subttl {
  color: var(--colorW);
  margin-bottom: 5rem;
  font-size: 5.2rem;
  width: fit-content;
  margin-inline: auto;
  padding: 1.2rem 2.8rem;
}
@media only screen and (max-width: 559px) {
  .pd-us__subttl {
    font-size: 2.6rem;
    text-align: center;
    margin-bottom: 2.5rem;
    padding: 1rem 2rem;
  }
}
.pd-us__desc {
  text-align: center;
  color: var(--mainColor);
  font-size: 2.2rem;
  margin-bottom: 7rem;
}
@media only screen and (max-width: 559px) {
  .pd-us__desc {
    margin-bottom: 3.5rem;
    font-size: 1.6rem;
    text-align: left;
  }
}
.pd-us__concept {
  display: flex;
  justify-content: center;
  gap: 17.7rem;
  margin-bottom: 9.5rem;
}
@media only screen and (max-width: 559px) {
  .pd-us__concept {
    gap: 4rem;
    margin-bottom: 0;
  }
}
.pd-us__concept-item:first-child .pd-us__concept-lead {
  position: relative;
}
.pd-us__concept-item:first-child .pd-us__concept-lead::after {
  content: "";
  background: url(../img/icon__batsu01.webp) no-repeat center center/contain;
  width: 9.1rem;
  height: 9.1rem;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: -14.6rem;
}
@media only screen and (max-width: 559px) {
  .pd-us__concept-item:first-child .pd-us__concept-lead::after {
    width: 3rem;
    height: 3rem;
    right: -3rem;
  }
}
.pd-us__concept-badge {
  background-color: var(--mainColor);
  color: var(--colorW);
  font-size: 3.1rem;
  width: fit-content;
  margin-inline: auto;
  border-radius: calc(infinity * 1px);
  padding: 1rem 2.6rem;
  line-height: 1;
  margin-bottom: 3rem;
}
@media only screen and (max-width: 559px) {
  .pd-us__concept-badge {
    font-size: 1.4rem;
    padding: 0.5rem 1rem;
    margin-bottom: 1rem;
  }
}
.pd-us__concept-lead {
  text-align: center;
  color: var(--mainColor);
  font-size: 8.3rem;
  margin-bottom: 2rem;
}
@media only screen and (max-width: 559px) {
  .pd-us__concept-lead {
    font-size: 2.2rem;
  }
}
.pd-us__concept-figure {
  text-align: center;
}

.pd-flow__list {
  width: 84rem;
  margin-inline: auto;
}
@media only screen and (max-width: 559px) {
  .pd-flow__list {
    width: 100%;
  }
}
.pd-flow__wrap {
  padding-bottom: 39rem;
  margin-bottom: 12rem;
}
@media only screen and (max-width: 559px) {
  .pd-flow__wrap {
    padding-bottom: 8rem;
  }
}
.pd-flow__item {
  position: relative;
}
.pd-flow__item:not(:last-child) {
  margin-bottom: 14rem;
}
@media only screen and (max-width: 559px) {
  .pd-flow__item:not(:last-child) {
    margin-bottom: 7rem;
  }
}
.pd-flow__item::after {
  content: "";
  background: url(../img/icon__bottom2.webp) no-repeat center center/contain;
  width: 4.9rem;
  height: 6.3rem;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: -11.3rem;
}
@media only screen and (max-width: 559px) {
  .pd-flow__item::after {
    width: 4.5rem;
    height: 5rem;
    bottom: -6.5rem;
  }
}
.pd-flow__number {
  font-family: var(--jost);
  display: flex;
  flex-direction: column;
  line-height: 1;
  justify-content: center;
  text-align: center;
}
.pd-flow__number .grd {
  font-size: 17.3rem;
  width: fit-content;
}
@media only screen and (max-width: 559px) {
  .pd-flow__number .grd {
    font-size: 12rem;
  }
}
.pd-flow__number .bl {
  font-size: 3.4rem;
  color: var(--main30Color);
  margin-top: -1.6rem;
}
@media only screen and (max-width: 559px) {
  .pd-flow__number .bl {
    font-size: 2rem;
  }
}
.pd-flow__head {
  display: flex;
  align-items: flex-end;
  margin-bottom: 3rem;
  justify-content: center;
  gap: 2.5rem;
}
@media only screen and (max-width: 559px) {
  .pd-flow__head {
    gap: 0rem;
    margin-bottom: 1.5rem;
  }
}
.pd-flow__subttl {
  width: fit-content;
  margin-inline: auto;
  color: var(--colorW);
  font-size: 4.2rem;
  padding: 1.4rem 3.4rem;
  text-align: center;
  line-height: 1;
  margin-bottom: 3rem;
}
@media only screen and (max-width: 559px) {
  .pd-flow__subttl {
    font-size: 2rem;
    padding: 0.5rem 1.5rem;
    margin-bottom: 2rem;
    line-height: 1.3;
    width: 100%;
  }
}
.pd-flow__subttl span {
  display: block;
  width: fit-content;
  text-align: center;
  padding: 1.4rem 3.4rem;
  margin-inline: auto;
}
@media only screen and (max-width: 559px) {
  .pd-flow__subttl span {
    padding: 0.5rem 1.5rem;
  }
}
.pd-flow__subttl span:not(:last-child) {
  margin-bottom: 1rem;
}
.pd-flow__text {
  font-size: 2rem;
  color: var(--mainColor);
  text-align: center;
}
@media only screen and (max-width: 559px) {
  .pd-flow__text {
    font-size: 1.4rem;
    text-align: left;
  }
}

.pd-forward {
  padding-bottom: 12rem;
  margin-bottom: 7.5rem;
}
@media only screen and (max-width: 559px) {
  .pd-forward {
    padding-bottom: 6rem;
    margin-bottom: 3.5rem;
    margin-top: -6rem;
  }
}
.pd-forward__ttlarea {
  text-align: center;
  z-index: 0;
  position: relative;
}
.pd-forward__ttlarea::after {
  content: "";
  background: url(../img/icon__bottom2.webp) no-repeat center center/contain;
  width: 12.2rem;
  height: 15.6rem;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: -24rem;
}
@media only screen and (max-width: 559px) {
  .pd-forward__ttlarea::after {
    width: 6rem;
    height: 6rem;
    top: -8rem;
  }
}
.pd-forward__ttlarea img {
  margin-top: -17rem;
  z-index: -1;
}
@media only screen and (max-width: 559px) {
  .pd-forward__ttlarea img {
    width: 60%;
    margin-top: -5rem;
  }
}
.pd-forward__ttl {
  text-align: center;
  color: var(--mainColor);
  font-size: 5.6rem;
  line-height: 1;
  margin-bottom: 2.6rem;
}
@media only screen and (max-width: 559px) {
  .pd-forward__ttl {
    font-size: 2.6rem;
    margin-bottom: 1.5rem;
    line-height: 1.3;
  }
}
.pd-forward__ttlen {
  font-family: var(--jost);
  width: fit-content;
  margin-inline: auto;
  font-size: 2.4rem;
}
@media only screen and (max-width: 559px) {
  .pd-forward__ttlen {
    font-size: 1.4rem;
  }
}

.pd-service {
  margin-bottom: 12rem;
}
@media only screen and (max-width: 559px) {
  .pd-service {
    margin-bottom: 6rem;
  }
}
.pd-service .senary-ttl__cont {
  top: 26%;
}
.pd-service .senary-ttl {
  margin-bottom: 1rem;
  font-size: 4rem;
  line-height: 1;
}
@media only screen and (max-width: 559px) {
  .pd-service .senary-ttl {
    font-size: 2.4rem;
  }
}
.pd-service .senary-ttl__en {
  line-height: 1;
}
.pd-service .senary-ttl__area img {
  margin-top: -5rem;
}
@media only screen and (max-width: 559px) {
  .pd-service .wrapper {
    display: contents;
  }
}
.pd-service__ttl {
  width: fit-content;
  margin-inline: auto;
  font-size: 2rem;
  font-family: var(--jost);
  line-height: 1;
  margin-bottom: 1rem;
}
@media only screen and (max-width: 559px) {
  .pd-service__ttl {
    font-size: 1.4rem;
  }
}
.pd-service__text {
  text-align: center;
  font-size: 2.2rem;
  letter-spacing: 0.05em;
  margin-bottom: 4rem;
}
@media only screen and (max-width: 559px) {
  .pd-service__text {
    font-size: 1.6rem;
    margin-bottom: 1.5rem;
  }
}
.pd-service__subttl {
  text-align: center;
  color: var(--mainColor);
  font-size: 4.6rem;
  margin-bottom: 2.5rem;
  line-height: 1.4130434783;
}
@media only screen and (max-width: 559px) {
  .pd-service__subttl {
    font-size: 2.4rem;
    line-height: 1.2;
  }
}
.pd-service__head {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 7rem;
  gap: 2rem;
  font-size: 2.4rem;
  top: 50px;
  color: var(--mainColor);
}
@media only screen and (max-width: 559px) {
  .pd-service__head {
    margin-bottom: 3.5rem;
    flex-direction: column;
    gap: 1rem;
    font-size: 1.6rem;
    text-align: center;
  }
}
.pd-service__head span {
  background-color: var(--mainColor);
  color: var(--colorW);
  font-size: 2.2rem;
  line-height: 1;
  padding: 0.7rem 1.5rem;
}
@media only screen and (max-width: 559px) {
  .pd-service__head span {
    font-size: 1.6rem;
  }
}
.pd-service__list {
  margin-bottom: 5rem;
}
@media only screen and (max-width: 559px) {
  .pd-service__list {
    margin-bottom: 3rem;
  }
}
.pd-service__list-number {
  color: var(--colorW);
  font-size: 2rem;
  width: fit-content;
  margin-inline: auto;
  padding: 0.6rem 1rem;
  margin-bottom: 2rem;
  line-height: 1;
}
@media only screen and (max-width: 559px) {
  .pd-service__list-number {
    font-size: 1.6rem;
    padding: 0.4rem 0.8rem;
    margin-bottom: 1.5rem;
  }
}
.pd-service__list-ttl {
  text-align: center;
  color: var(--mainColor);
  font-size: 3.2rem;
  line-height: 1;
  margin-bottom: 2rem;
}
@media only screen and (max-width: 559px) {
  .pd-service__list-ttl {
    font-size: 2.2rem;
    margin-bottom: 1.5rem;
  }
}
.pd-service__list-text {
  font-size: 1.8rem;
  letter-spacing: 0.05em;
  width: 71rem;
  margin-left: 29.5rem;
}
@media only screen and (max-width: 559px) {
  .pd-service__list-text {
    font-size: 1.4rem;
    width: 100%;
    margin-left: 0;
  }
}
.pd-service__list-figure {
  position: absolute;
  top: 0;
  left: 0;
}
@media only screen and (max-width: 559px) {
  .pd-service__list-figure {
    display: none;
  }
}
.pd-service__item {
  position: relative;
  margin-bottom: 3.5rem;
}
.pd-service__item::after {
  content: "";
  background: url(../img/icon__bottom.webp) no-repeat center center/contain;
  width: 4.6rem;
  height: 2.7rem;
  display: inline-block;
  left: 50%;
  transform: translateX(-50%);
  position: relative;
  top: 3.5rem;
  margin-bottom: 3.5rem;
}
@media only screen and (max-width: 559px) {
  .pd-service__item::after {
    width: 2.3rem;
    height: 1.35rem;
    top: 2rem;
    margin-bottom: 0;
  }
}
.pd-service__bottom {
  margin-bottom: 6.5rem;
}
@media only screen and (max-width: 559px) {
  .pd-service__bottom {
    margin-bottom: 3rem;
  }
}
.pd-service__bottom-ttl {
  color: var(--colorW);
  width: fit-content;
  margin-inline: auto;
  font-size: 3.4rem;
  line-height: 1;
  padding: 1.6rem 3.8rem;
  margin-bottom: 2.5rem;
}
@media only screen and (max-width: 559px) {
  .pd-service__bottom-ttl {
    font-size: 2.6rem;
    padding: 1rem 2rem;
    margin-bottom: 1.5rem;
    text-align: center;
    line-height: 1.3;
  }
}
@media only screen and (max-width: 559px) {
  .pd-service__bottom-ttl span {
    padding: 0.2rem 2rem;
    line-height: 2;
  }
}
.pd-service__bottom-text {
  text-align: center;
  color: var(--mainColor);
  font-size: 1.8rem;
}
@media only screen and (max-width: 559px) {
  .pd-service__bottom-text {
    font-size: 1.4rem;
    text-align: left;
  }
}
.pd-service .bt-about__box {
  background-color: #f5f5f5;
  margin-bottom: 13rem;
  text-align: center;
}
@media only screen and (max-width: 559px) {
  .pd-service .bt-about__box {
    padding-inline: 2rem;
    margin-bottom: 8rem;
  }
}

.pd-fee {
  position: relative;
}
.pd-fee__text {
  text-align: center;
  font-size: 1.6rem;
  margin-bottom: 2rem;
  color: var(--mainColor);
}
@media only screen and (max-width: 559px) {
  .pd-fee__text {
    font-size: 1.4rem;
    text-align: left;
    margin-bottom: 1rem;
  }
}
.pd-fee__main {
  width: 74rem;
  margin-inline: auto;
  margin-bottom: 6rem;
}
@media only screen and (max-width: 559px) {
  .pd-fee__main {
    width: 100%;
    margin-bottom: 3rem;
  }
}
.pd-fee__ttl {
  font-size: 2rem;
  line-height: 1.5;
  color: var(--mainColor);
}
@media only screen and (max-width: 559px) {
  .pd-fee__ttl {
    font-size: 1.6rem;
  }
}
.pd-fee__subtext {
  color: var(--mainColor);
  font-size: 1.8rem;
  line-height: 1.5;
  padding-left: 1em;
}
@media only screen and (max-width: 559px) {
  .pd-fee__subtext {
    font-size: 1.6rem;
  }
}

.pd-application {
  position: relative;
  border-radius: 8rem;
  overflow: hidden;
  z-index: 0;
  padding: 11rem 0 12rem;
  margin-bottom: 26rem;
}
@media only screen and (max-width: 559px) {
  .pd-application {
    margin-bottom: 13rem;
    border-radius: 4rem;
    padding: 5rem 0 6rem;
  }
}
.pd-application::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: -1;
  border: 0.4rem solid transparent;
  border-radius: inherit;
  background-image: linear-gradient(90deg, rgba(24, 189, 231, 0.5) 0%, rgba(23, 42, 136, 0.5) 100%);
  background-origin: border-box;
  -webkit-mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: destination-out;
  mask-composite: exclude;
}
@media only screen and (max-width: 559px) {
  .pd-application::before {
    border: 0.2rem solid transparent;
  }
}
.pd-application__ttlarea {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 4rem;
  margin-bottom: 4.5rem;
}
@media only screen and (max-width: 559px) {
  .pd-application__ttlarea {
    margin-bottom: 2.5rem;
    gap: 1rem;
  }
}
.pd-application__ttlarea::before, .pd-application__ttlarea::after {
  content: "";
  width: 15rem;
  height: 0.2rem;
  display: inline-block;
  position: relative;
  background-color: var(--mainColor);
}
@media only screen and (max-width: 559px) {
  .pd-application__ttlarea::before, .pd-application__ttlarea::after {
    width: 4rem;
  }
}
.pd-application__ttl {
  text-align: center;
  font-size: 3.6rem;
  color: var(--mainColor);
  margin-bottom: 1.5rem;
  position: relative;
}
@media only screen and (max-width: 559px) {
  .pd-application__ttl {
    font-size: 2rem;
    margin-bottom: 0.5rem;
  }
}
.pd-application__ttl::before {
  content: "";
  content: "";
  background: url(../img/mark__img01.svg) no-repeat center center/contain;
  width: 8.9em;
  height: 14.7rem;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: -50%;
  z-index: -1;
}
@media only screen and (max-width: 559px) {
  .pd-application__ttl::before {
    width: 4.4rem;
    height: 7.5rem;
    left: 0;
  }
}
.pd-application__ttlen {
  text-align: center;
  font-family: var(--jost);
  width: fit-content;
  margin-inline: auto;
  font-size: 2.4rem;
}
@media only screen and (max-width: 559px) {
  .pd-application__ttlen {
    font-size: 1.4rem;
  }
}
.pd-application__ttl-main {
  width: fit-content;
  margin-inline: auto;
  font-size: 3.6rem;
  background-color: var(--baseColor);
  color: var(--base50Color);
  padding: 1.4rem 3.4rem;
  display: block;
  margin-bottom: 1.5rem;
}
@media only screen and (max-width: 559px) {
  .pd-application__ttl-main {
    font-size: 2rem;
    padding: 1rem 2rem;
    margin-bottom: 1rem;
  }
}
.pd-application__ttl-main.bg-grd {
  color: var(--colorW);
}
.pd-application__ttl-sub {
  width: fit-content;
  margin-inline: auto;
  font-size: 2.4rem;
  font-family: var(--jost);
  margin-bottom: 3rem;
  line-height: 1;
  display: block;
  color: #8a8a8a;
}
@media only screen and (max-width: 559px) {
  .pd-application__ttl-sub {
    font-size: 1.4rem;
  }
}
.pd-application__lead {
  text-align: center;
  font-size: 1.8rem;
  letter-spacing: 0.05em;
  margin-bottom: 4rem;
}
@media only screen and (max-width: 559px) {
  .pd-application__lead {
    font-size: 1.4rem;
    margin-bottom: 3rem;
  }
}
.pd-application__item {
  display: grid;
  grid-template-columns: 2.1rem auto;
  gap: 1rem;
}
.pd-application__item:not(:last-child) {
  margin-bottom: 3rem;
}
@media only screen and (max-width: 559px) {
  .pd-application__item:not(:last-child) {
    margin-bottom: 1rem;
  }
}
@media only screen and (max-width: 559px) {
  .pd-application__item {
    grid-template-columns: 1.6rem auto;
  }
}
.pd-application__item img {
  position: relative;
  top: 1rem;
}
@media only screen and (max-width: 559px) {
  .pd-application__item img {
    top: 0.7rem;
  }
}
.pd-application__text {
  color: var(--mainColor);
  font-size: 2rem;
  letter-spacing: 0.05em;
  line-height: 1.5;
}
@media only screen and (max-width: 559px) {
  .pd-application__text {
    font-size: 1.4rem;
  }
}
.pd-application__box {
  padding-inline: 2rem;
}
.pd-application__box--eligible {
  margin-bottom: 7.5rem;
}
@media only screen and (max-width: 559px) {
  .pd-application__box--eligible {
    margin-bottom: 4rem;
  }
}
.pd-application__box--not-eligible .pd-application__text {
  color: var(--baseColor);
}
.pd-application__figure {
  text-align: center;
}

.pd-flow__arrow {
  position: relative;
}
.pd-flow__head {
  position: relative;
}
.pd-flow__arrowimg01-wrap {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: -5rem;
  width: 23.8rem;
}
@media only screen and (max-width: 559px) {
  .pd-flow__arrowimg01-wrap {
    width: 5rem;
    left: 0;
  }
}
.pd-flow__arrowimg01-wrap::before {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: -0.3rem;
  width: 5rem;
  height: 0.6rem;
  background-color: #18bde7;
}
@media only screen and (max-width: 1280px) {
  .pd-flow__arrowimg01-wrap::before {
    left: 0;
  }
}
@media only screen and (max-width: 559px) {
  .pd-flow__arrowimg01-wrap::before {
    display: none;
  }
}
.pd-flow__arrowimg02-wrap {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: -22rem;
  width: 79.5rem;
}
@media only screen and (max-width: 559px) {
  .pd-flow__arrowimg02-wrap {
    width: 100%;
    bottom: -8rem;
  }
}
.pd-flow__arrowimg02-wrap::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: -7rem;
  width: 10rem;
  height: 0.7rem;
  background-color: #18bde7;
}
@media only screen and (max-width: 559px) {
  .pd-flow__arrowimg02-wrap::before {
    display: none;
  }
}
.pd-flow__arrowimg02 {
  width: 79.5rem;
}
@media only screen and (max-width: 559px) {
  .pd-flow__arrowimg02 {
    width: 30rem;
  }
}
.pd-flow__item:last-child::after {
  display: none;
}
.pd-flow__main-line {
  background-color: #18bde7;
  width: 0.7rem;
  left: 17rem;
  position: absolute;
}
@media only screen and (max-width: 1369px) {
  .pd-flow__main-line {
    left: 15rem;
  }
}
@media only screen and (max-width: 1280px) {
  .pd-flow__main-line {
    left: 11rem;
  }
}
@media only screen and (max-width: 559px) {
  .pd-flow__main-line {
    width: 0.3rem;
    left: 0;
  }
}
@media only screen and (max-width: 559px) {
  .pd-flow__text {
    padding-left: 4rem;
  }
}
@media only screen and (max-width: 559px) {
  .pd-flow__wrap {
    padding-bottom: 15rem;
  }
}

.page-detail-consulting-training .cm-faq {
  margin-bottom: 30rem;
}
@media only screen and (max-width: 559px) {
  .page-detail-consulting-training .cm-faq {
    margin-bottom: 13rem;
  }
}
@media only screen and (max-width: 559px) {
  .page-detail-consulting-training .bs-summary .ab-philosophy__deco {
    top: -12rem;
  }
}

.ct-ttl {
  margin-bottom: 1rem;
}

.ct-summary .bs-summary__cont {
  padding-bottom: 2.5rem;
}
@media only screen and (max-width: 559px) {
  .ct-summary .bs-summary__cont {
    margin-top: -5.5rem;
  }
}
@media only screen and (max-width: 559px) {
  .ct-summary__figure {
    margin-top: 6rem;
  }
}

.ct-problem {
  border-radius: 3.7rem;
  min-height: 65rem;
  color: var(--colorW);
  position: relative;
  z-index: 0;
  padding-top: 5rem;
  margin-bottom: 25rem;
}
@media only screen and (max-width: 559px) {
  .ct-problem {
    padding: 5rem 2rem 10rem;
    min-height: inherit;
    border-radius: 2.4rem;
    margin-bottom: 14rem;
  }
}
.ct-problem::before {
  content: "";
  background: url(../img/ct-summary__img02.webp) no-repeat center center/cover;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0rem;
  left: 0rem;
  z-index: -1;
  border-radius: 3.7rem;
  border-radius: 2.4rem;
}
.ct-problem::after {
  content: "";
  background: url(../img/ct-problem__img01.webp) no-repeat center center/contain;
  width: 10rem;
  height: 18.9rem;
  bottom: -11rem;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}
@media only screen and (max-width: 559px) {
  .ct-problem::after {
    width: 7rem;
    height: 13rem;
    bottom: -5rem;
  }
}
.ct-problem__ttlen {
  font-family: var(--jost);
  font-size: 2.4rem;
  line-height: 1;
  margin-bottom: 1.5rem;
  margin-top: -17rem;
}
@media only screen and (max-width: 559px) {
  .ct-problem__ttlen {
    font-size: 1.2rem;
    margin-top: -9rem;
  }
}
.ct-problem__ttl {
  font-size: 2.4rem;
  font-weight: 700;
  margin-bottom: 4.5rem;
}
@media only screen and (max-width: 559px) {
  .ct-problem__ttl {
    font-size: 2rem;
    line-height: 1.3;
    margin-bottom: 2.5rem;
  }
}
.ct-problem__ttlarea img {
  position: relative;
  left: 4rem;
}
@media only screen and (max-width: 559px) {
  .ct-problem__ttlarea img {
    width: 30%;
    left: 0;
  }
}
.ct-problem__text {
  font-size: 1.8rem;
  letter-spacing: 0.05em;
  line-height: 1.75;
}
@media only screen and (max-width: 559px) {
  .ct-problem__text {
    font-size: 1.4rem;
  }
}
.ct-problem__text:not(:last-child) {
  margin-bottom: 3rem;
}
@media only screen and (max-width: 559px) {
  .ct-problem__text:not(:last-child) {
    margin-bottom: 2rem;
  }
}
.ct-problem__text span {
  background-color: var(--base50Color);
  color: var(--baseColor);
  display: block;
  font-weight: 700;
  width: fit-content;
  line-height: 1;
  padding: 0.6rem 0.1rem;
}
.ct-problem__text span:not(:last-child) {
  margin-bottom: 1rem;
}
.ct-problem .holder {
  width: 74rem;
}
@media only screen and (max-width: 559px) {
  .ct-problem .holder {
    width: 100%;
  }
}

.ct-start {
  margin-bottom: 6.5rem;
}
@media only screen and (max-width: 559px) {
  .ct-start {
    margin-bottom: 3rem;
  }
}
.ct-start__text {
  font-size: 1.8rem;
  letter-spacing: 0.05em;
  margin-bottom: 3rem;
}
@media only screen and (max-width: 559px) {
  .ct-start__text {
    font-size: 1.4rem;
    margin-bottom: 2rem;
  }
}
.ct-start__flex {
  display: grid;
  grid-template-columns: auto 53.1rem;
  gap: 5rem;
  margin-bottom: 9.5rem;
}
@media only screen and (max-width: 559px) {
  .ct-start__flex {
    grid-template-columns: repeat(1, 1fr);
    gap: 2rem;
    margin-bottom: 4rem;
  }
}
.ct-start__ttlen {
  font-family: var(--jost);
  width: fit-content;
  font-size: 2.4rem;
  line-height: 1;
  margin-bottom: 2.5rem;
  letter-spacing: 0;
  font-weight: 500;
}
@media only screen and (max-width: 559px) {
  .ct-start__ttlen {
    font-size: 1.4rem;
    margin-bottom: 1rem;
  }
}
.ct-start__ttl {
  color: var(--mainColor);
  font-size: 3.8rem;
  letter-spacing: 0.05em;
  margin-bottom: 4rem;
}
@media only screen and (max-width: 559px) {
  .ct-start__ttl {
    font-size: 2.4rem;
    margin-bottom: 2rem;
  }
}
.ct-start__ttlarea {
  position: relative;
  z-index: 0;
}
.ct-start__ttlarea::after {
  content: "";
  background: url(../img/mark__img01.svg) no-repeat center center/contain;
  width: 15.1rem;
  height: 24.8rem;
  position: absolute;
  bottom: -2rem;
  left: 2rem;
}
@media only screen and (max-width: 559px) {
  .ct-start__ttlarea::after {
    width: 10rem;
    height: 16rem;
  }
}
.ct-start__subttl {
  color: var(--mainColor);
  font-size: 2.6rem;
  line-height: 1.5;
  letter-spacing: 0.05em;
  margin-bottom: 4.5rem;
}
@media only screen and (max-width: 559px) {
  .ct-start__subttl {
    font-size: 2rem;
    margin-bottom: 2rem;
  }
}
.ct-start__visu {
  text-align: center;
}
@media only screen and (max-width: 559px) {
  .ct-start__visu img {
    width: 60%;
    margin-inline: auto;
  }
}

.ct-power {
  background-color: var(--colorW);
  padding: 7rem 0 12rem;
  border-radius: 10rem;
  margin-bottom: 12rem;
}
@media only screen and (max-width: 559px) {
  .ct-power {
    border-radius: 5rem;
    padding: 3.5rem 2rem 6rem;
    margin-bottom: 6rem;
  }
}
.ct-power__textarea {
  margin-bottom: 6rem;
}
@media only screen and (max-width: 559px) {
  .ct-power__textarea {
    margin-bottom: 3rem;
  }
}
.ct-power__text {
  font-size: 1.8rem;
  text-align: center;
}
@media only screen and (max-width: 559px) {
  .ct-power__text {
    font-size: 1.4rem;
    text-align: left;
  }
}
.ct-power__text:not(:last-child) {
  margin-bottom: 4rem;
}
@media only screen and (max-width: 559px) {
  .ct-power__text:not(:last-child) {
    margin-bottom: 2rem;
  }
}
.ct-power__text .bl {
  color: var(--mainColor);
}
.ct-power__text .gy {
  background-color: var(--baseColor);
  color: #d8d8d8;
  padding: 0.2rem 0.5rem;
  font-size: 2.6rem;
}
@media only screen and (max-width: 559px) {
  .ct-power__text .gy {
    font-size: 1.6rem;
    padding: 0.1rem 0.3rem;
  }
}
.ct-power__list {
  margin-bottom: 7.5rem;
  width: fit-content;
  margin-inline: auto;
}
@media only screen and (max-width: 559px) {
  .ct-power__list {
    margin-bottom: 4rem;
  }
}
.ct-power__item {
  color: var(--mainColor);
  font-size: 2.2rem;
  letter-spacing: 0.05em;
  line-height: 2;
  position: relative;
  display: flex;
  gap: 1rem;
  align-items: center;
}
@media only screen and (max-width: 559px) {
  .ct-power__item {
    font-size: 1.4rem;
    line-height: 1.3;
    display: grid;
    grid-template-columns: 1.5rem auto;
  }
}
.ct-power__item::before {
  content: "";
  background: url(../img/mark__img04.svg) no-repeat center center/contain;
  width: 1.5rem;
  height: 2.4rem;
  position: relative;
  display: inline-block;
}
@media only screen and (max-width: 559px) {
  .ct-power__item:not(:last-child) {
    margin-bottom: 1rem;
  }
}
.ct-power__figure {
  text-align: center;
}

.ct-fee {
  margin-top: 2.5rem;
}
.ct-fee__list {
  width: fit-content;
  margin-inline: auto;
  margin-bottom: 2.5rem;
}
.ct-fee__item {
  display: flex;
  font-size: 2.4rem;
}
@media only screen and (max-width: 559px) {
  .ct-fee__item {
    font-size: 1.6rem;
    flex-direction: column;
  }
}
.ct-fee__item:not(:last-child) {
  margin-bottom: 2rem;
}
@media only screen and (max-width: 559px) {
  .ct-fee__item:not(:last-child) {
    margin-bottom: 1rem;
  }
}
.ct-fee__label {
  color: var(--mainColor);
}
@media only screen and (max-width: 559px) {
  .ct-fee__label {
    margin-bottom: 0.5rem;
    margin-left: -1rem;
  }
}
.ct-fee__notes {
  width: 56.8rem;
  margin-inline: auto;
  margin-bottom: 4.5rem;
}
@media only screen and (max-width: 559px) {
  .ct-fee__notes {
    width: 100%;
    margin-bottom: 2.5rem;
  }
}
.ct-fee__notes-item {
  font-size: 1.6rem;
  line-height: 1.4375;
  display: flex;
}
@media only screen and (max-width: 559px) {
  .ct-fee__notes-item {
    font-size: 1.2rem;
  }
}
.ct-fee__notes-item:not(:last-child) {
  margin-bottom: 1rem;
}
@media only screen and (max-width: 559px) {
  .ct-fee__notes-item:not(:last-child) {
    margin-bottom: 0.5rem;
  }
}

.ct-application {
  padding-bottom: 2.5rem;
}
@media only screen and (max-width: 559px) {
  .ct-application {
    margin-bottom: 6rem;
  }
}
.ct-application__text {
  margin-top: 3.5rem;
}
@media only screen and (max-width: 559px) {
  .ct-application__text {
    font-size: 1.4rem;
    margin-top: 2rem;
  }
}

.ct-forward {
  position: relative;
  padding-bottom: 0;
  margin-bottom: 21.5rem;
}
@media only screen and (max-width: 559px) {
  .ct-forward {
    margin-bottom: 10rem;
  }
}
.ct-forward__ttlarea {
  margin-bottom: 7.5rem;
}
@media only screen and (max-width: 559px) {
  .ct-forward__ttlarea {
    margin-bottom: 4rem;
  }
}
.ct-forward__ttlarea::after {
  display: none;
}
.ct-forward__ttlarea img {
  margin-top: -30rem;
}
@media only screen and (max-width: 559px) {
  .ct-forward__ttlarea img {
    margin-top: -18rem;
  }
}
.ct-forward__ttlja {
  color: var(--mainColor);
  text-align: center;
  font-size: 3rem;
}
@media only screen and (max-width: 559px) {
  .ct-forward__ttlja {
    font-size: 1.4rem;
  }
}

.ct-message {
  margin-bottom: 12rem;
}
@media only screen and (max-width: 559px) {
  .ct-message {
    margin-bottom: 6rem;
  }
}
.ct-message__text {
  font-size: 1.8rem;
  line-height: 2;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 559px) {
  .ct-message__text {
    font-size: 1.4rem;
  }
}
.ct-message__text:not(:last-child) {
  margin-bottom: 5rem;
}
@media only screen and (max-width: 559px) {
  .ct-message__text:not(:last-child) {
    margin-bottom: 2rem;
  }
}
.ct-message__textarea {
  margin-bottom: 6rem;
  width: 74rem;
  margin-inline: auto;
}
@media only screen and (max-width: 559px) {
  .ct-message__textarea {
    width: 100%;
    margin-bottom: 3rem;
  }
}
.ct-message__subttl {
  text-align: center;
  color: var(--mainColor);
  font-size: 3.4rem;
  letter-spacing: 0.05em;
  line-height: 2;
  margin-bottom: 3.5rem;
}
@media only screen and (max-width: 559px) {
  .ct-message__subttl {
    font-size: 2.2rem;
    line-height: 1.5;
  }
}
.ct-message__ttl {
  color: var(--colorW);
  font-size: 5rem;
  line-height: 1;
  text-align: center;
  margin-inline: auto;
}
@media only screen and (max-width: 559px) {
  .ct-message__ttl {
    font-size: 2.8rem;
  }
}
.ct-message__ttl span {
  display: inline-block;
  padding: 1.2rem 2.8rem;
}
@media only screen and (max-width: 559px) {
  .ct-message__ttl span {
    padding: 0.5rem 1.5rem;
  }
}
.ct-message__ttl span:not(:last-child) {
  margin-bottom: 1rem;
}

.ct-cta--bottom {
  margin-bottom: 0;
}

.ca-deco {
  top: -32rem;
}
@media only screen and (max-width: 559px) {
  .ca-deco {
    top: -12rem;
  }
}

.ca-cont {
  margin-top: 3rem;
}
.ca-cont__list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 3.5rem 3rem;
}
@media only screen and (max-width: 559px) {
  .ca-cont__list {
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem 2rem;
  }
}
.ca-cont__figure {
  margin-bottom: 2rem;
  position: relative;
}
@media only screen and (max-width: 559px) {
  .ca-cont__figure {
    margin-bottom: 1rem;
  }
}
.ca-cont__figure::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 2rem;
  padding: 0.8rem;
  background: linear-gradient(90deg, rgb(24, 189, 231) 0%, rgb(23, 42, 136) 100%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  opacity: 0;
  pointer-events: none;
  z-index: 100;
}
@media only screen and (max-width: 559px) {
  .ca-cont__figure::before {
    border-radius: 1rem;
  }
}
.ca-cont__img {
  border-radius: 2rem;
  aspect-ratio: 1/1;
  object-fit: cover;
  width: 100%;
  height: 100%;
}
@media only screen and (max-width: 559px) {
  .ca-cont__img {
    border-radius: 1rem;
  }
}
.ca-cont__company, .ca-cont__name {
  text-align: center;
  color: var(--baseColor);
}
.ca-cont__company {
  font-size: 1.6rem;
  letter-spacing: 0.05em;
  line-height: 1.3125;
  margin-bottom: 0.5rem;
}
@media only screen and (max-width: 559px) {
  .ca-cont__company {
    font-size: 1.2rem;
  }
}
.ca-cont__name {
  font-size: 1.6rem;
  line-height: 1.625;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 559px) {
  .ca-cont__name {
    font-size: 1.2rem;
  }
}
.ca-cont__name span {
  font-size: 2.2rem;
  line-height: 1.1818181818;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 559px) {
  .ca-cont__name span {
    font-size: 1.4rem;
  }
}
.ca-cont__link:hover {
  opacity: 1;
}
.ca-cont__link:hover .ca-cont__figure::before {
  opacity: 1;
}
@media only screen and (max-width: 559px) {
  .ca-cont__link:hover .ca-cont__figure::before {
    opacity: 0;
  }
}

.cs-cont {
  margin-top: -13rem;
  margin-top: -6.7708333333vw;
}
@media only screen and (max-width: 559px) {
  .cs-cont {
    margin-top: -20rem;
  }
}
.cs-cont .o-flex__item--2 {
  padding-top: 23rem;
  padding-top: 11.9791666667vw;
}
@media only screen and (max-width: 559px) {
  .cs-cont .o-flex__item--2 {
    padding-top: 0;
  }
}
@media only screen and (max-width: 559px) {
  .cs-cont .o-flex {
    flex-direction: column;
    gap: 3rem;
  }
}
.cs-cont__head {
  margin-bottom: 8rem;
}
@media only screen and (max-width: 559px) {
  .cs-cont__head {
    margin-bottom: 4rem;
  }
}
.cs-cont__company {
  font-size: 2.2rem;
  letter-spacing: 0.05em;
  margin-bottom: 2rem;
}
@media only screen and (max-width: 559px) {
  .cs-cont__company {
    font-size: 1.8rem;
    margin-bottom: 1rem;
  }
}
.cs-cont__name {
  font-size: 2.6rem;
  letter-spacing: 0.05em;
  margin-bottom: 3.5rem;
}
@media only screen and (max-width: 559px) {
  .cs-cont__name {
    font-size: 2rem;
    margin-bottom: 1.8rem;
  }
}
.cs-cont__name span {
  font-size: 5.2rem;
  letter-spacing: 0.2em;
  padding-left: 1rem;
}
@media only screen and (max-width: 559px) {
  .cs-cont__name span {
    font-size: 3rem;
  }
}
.cs-cont__qualification {
  font-size: 1.8rem;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 559px) {
  .cs-cont__qualification {
    font-size: 1.4rem;
  }
}
@media only screen and (max-width: 559px) {
  .cs-cont__figure {
    width: 80%;
    margin-inline: auto;
  }
}
.cs-cont__body {
  margin-bottom: 12rem;
}
@media only screen and (max-width: 559px) {
  .cs-cont__body {
    margin-bottom: 6rem;
  }
}
.cs-cont__item:not(:last-child) {
  margin-bottom: 6rem;
}
@media only screen and (max-width: 559px) {
  .cs-cont__item:not(:last-child) {
    margin-bottom: 3rem;
  }
}
.cs-cont__subttl {
  margin-bottom: 3rem;
  color: var(--mainColor);
  font-size: 3rem;
  letter-spacing: 0;
  padding-left: 1rem;
  border-left: 1rem solid var(--mainColor);
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 559px) {
  .cs-cont__subttl {
    margin-bottom: 1.5rem;
    font-size: 2.2rem;
    border-left: 0.5rem solid var(--mainColor);
    padding-left: 0.5rem;
  }
}
.cs-cont__text {
  font-size: 1.8rem;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 559px) {
  .cs-cont__text {
    font-size: 1.4rem;
  }
}
.cs-cont__pager {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 4rem;
}
@media only screen and (max-width: 559px) {
  .cs-cont__pager {
    gap: 2rem;
  }
}
.cs-cont__pagerlink {
  font-size: 2rem;
  text-decoration: underline !important;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 559px) {
  .cs-cont__pagerlink {
    font-size: 1.4rem;
  }
}
@media only screen and (max-width: 559px) {
  .cs-cont .na-archive__prev,
  .cs-cont .na-archive__next {
    position: relative;
    bottom: 0;
  }
}

.ba-archive .cm-card__cat span {
  background: var(--mainColor);
}

.ba-card {
  margin-bottom: 9rem;
}
@media only screen and (max-width: 559px) {
  .ba-card {
    margin-bottom: 4.5rem;
  }
}

.ba-pickup {
  margin-bottom: 11rem;
}
@media only screen and (max-width: 559px) {
  .ba-pickup {
    margin-bottom: 5rem;
  }
}
.ba-pickup__ttlarea {
  margin-bottom: 1rem;
  display: flex;
  align-items: baseline;
  gap: 1rem;
  margin-bottom: 3rem;
}
@media only screen and (max-width: 559px) {
  .ba-pickup__ttlarea {
    margin-bottom: 2rem;
  }
}
.ba-pickup__ttl {
  font-size: 6.6rem;
  font-family: var(--jost);
  line-height: 1;
  letter-spacing: 0;
}
@media only screen and (max-width: 559px) {
  .ba-pickup__ttl {
    font-size: 3rem;
  }
}
.ba-pickup__ttlja {
  color: var(--mainColor);
  font-size: 2rem;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 559px) {
  .ba-pickup__ttlja {
    font-size: 1.4rem;
  }
}
@media only screen and (max-width: 559px) {
  .ba-pickup__list {
    grid-template-columns: repeat(1, 1fr);
    gap: 2rem;
  }
}
.ba-pickup .cm-card__cat span {
  font-size: 2rem;
  padding: 0.5rem 2rem;
}
@media only screen and (max-width: 559px) {
  .ba-pickup .cm-card__cat span {
    font-size: 1.2rem;
    padding: 0.2rem 1.5rem;
  }
}
.ba-pickup .cm-card__subttl {
  font-size: 2.6rem;
}
@media only screen and (max-width: 559px) {
  .ba-pickup .cm-card__subttl {
    font-size: 1.6rem;
    margin-top: 0.5rem;
  }
}
.ba-pickup .cm-card__date {
  font-size: 2.2rem;
}
@media only screen and (max-width: 559px) {
  .ba-pickup .cm-card__date {
    font-size: 1.4rem;
  }
}

.na-archive__ttl {
  margin-bottom: 3.5rem;
}
@media only screen and (max-width: 559px) {
  .na-archive__ttl {
    margin-bottom: 2rem;
  }
}
.na-archive__catlist {
  display: flex;
  align-items: center;
  gap: 3rem 1rem;
  margin-bottom: 6.5rem;
  flex-wrap: wrap;
}
@media only screen and (max-width: 559px) {
  .na-archive__catlist {
    margin-bottom: 3.5rem;
    gap: 1.5rem 1rem;
  }
}
.na-archive__catlink span {
  font-size: 1.8rem;
  letter-spacing: 0.05em;
  color: var(--colorW);
  width: fit-content;
  padding: 1.1rem 2rem;
  background-color: var(--main30Color);
  border-radius: calc(infinity * 1px);
}
@media only screen and (max-width: 559px) {
  .na-archive__catlink span {
    font-size: 1.2rem;
    padding: 0.5rem 1rem;
  }
}
.na-archive__catlink span.current {
  background: #18bde7;
  background: linear-gradient(90deg, rgb(24, 189, 231) 0%, rgb(23, 42, 136) 100%);
}
.na-archive__newslist {
  margin-bottom: 13rem;
}
@media only screen and (max-width: 559px) {
  .na-archive__newslist {
    margin-bottom: 5rem;
  }
}
.na-archive__newsitem {
  padding-bottom: 2rem;
  border-bottom: 1px solid;
  border-image-source: linear-gradient(90deg, rgb(24, 189, 231) 0%, rgb(23, 42, 136) 100%);
  border-image-slice: 1;
}
@media only screen and (max-width: 559px) {
  .na-archive__newsitem {
    padding-bottom: 1.5rem;
  }
}
.na-archive__newsitem:not(:last-child) {
  margin-bottom: 3rem;
}
@media only screen and (max-width: 559px) {
  .na-archive__newsitem:not(:last-child) {
    margin-bottom: 2rem;
  }
}
.na-archive__newsbox {
  display: flex;
  gap: 2rem;
  margin-bottom: 2rem;
}
@media only screen and (max-width: 559px) {
  .na-archive__newsbox {
    gap: 1rem;
    margin-bottom: 1.5rem;
  }
}
.na-archive__newsdate {
  font-family: var(--jost);
  color: var(--main50Color);
  font-size: 1.8rem;
  font-weight: 500;
}
@media only screen and (max-width: 559px) {
  .na-archive__newsdate {
    font-size: 1.4rem;
  }
}
.na-archive__newsttl {
  font-size: 2.2rem;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 559px) {
  .na-archive__newsttl {
    font-size: 1.6rem;
  }
}
.na-archive__newscat span {
  background-color: var(--mainColor);
  color: var(--colorW);
  border-radius: calc(infinity * 1px);
  font-size: 1.4rem;
  letter-spacing: 0.05em;
  padding: 0.8rem 1.6rem;
}
@media only screen and (max-width: 559px) {
  .na-archive__newscat span {
    font-size: 1.2rem;
    padding: 0.4rem 1rem;
  }
}
.na-archive__pager {
  display: flex;
  gap: 3rem;
  align-items: center;
  justify-content: center;
}
@media only screen and (max-width: 559px) {
  .na-archive__pager {
    gap: 1.5rem;
    position: relative;
    margin-bottom: 5rem;
  }
}
.na-archive__pagerlist {
  display: flex;
  gap: 1.5rem;
}
@media only screen and (max-width: 559px) {
  .na-archive__pagerlist {
    gap: 1rem;
  }
}
.na-archive__pagerlink span {
  font-size: 2.1rem;
  width: 4.7rem;
  height: 4.7rem;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  background: transparent;
  color: var(--base50Color);
  border: 2px solid;
}
@media only screen and (max-width: 559px) {
  .na-archive__pagerlink span {
    width: 3rem;
    height: 3rem;
    font-size: 1.4rem;
  }
}
.na-archive__pagerlink--dot span {
  border: none;
  color: var(--baseColor);
}
.na-archive__pagerlink--current span {
  background: #18bde7;
  background: linear-gradient(90deg, rgb(24, 189, 231) 0%, rgb(23, 42, 136) 100%);
  color: var(--colorW);
  border: none;
}
.na-archive__prevlink, .na-archive__nextlink {
  background-color: var(--mainColor);
  color: var(--colorW) !important;
  border-radius: calc(infinity * 1px);
  width: 11rem;
  height: 4.5rem;
  font-family: var(--jost);
  font-size: 1.8rem;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media only screen and (max-width: 559px) {
  .na-archive__prevlink, .na-archive__nextlink {
    font-size: 1.4rem;
    width: 8rem;
    height: 3rem;
  }
}
@media only screen and (max-width: 559px) {
  .na-archive__prev {
    position: absolute;
    bottom: -5rem;
    left: 0;
  }
}
@media only screen and (max-width: 559px) {
  .na-archive__next {
    position: absolute;
    bottom: -5rem;
    right: 0;
  }
}

.na-archive__catlist {
  --all-offset: 0px; /* JSで上書きされる */
  padding-left: var(--all-offset);
}
@media only screen and (max-width: 559px) {
  .na-archive__catlist {
    padding-left: 0;
  }
}

.na-archive__catitem:first-child {
  margin-left: calc(-1 * var(--all-offset));
}
@media only screen and (max-width: 559px) {
  .na-archive__catitem:first-child {
    margin-left: 0;
  }
}

.as-archive {
  margin-bottom: 6.5rem;
}
@media only screen and (max-width: 559px) {
  .as-archive {
    margin-bottom: 3rem;
  }
}
.as-archive__catlink span {
  background-color: var(--colorW);
  border: 1px solid var(--subColor);
  color: var(--subColor);
}
.as-archive__catlink.active span {
  background: #18bde7;
  background: linear-gradient(90deg, rgb(24, 189, 231) 0%, rgb(23, 42, 136) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  border: none;
}
.as-archive__catitem--active {
  background: linear-gradient(90deg, rgb(24, 189, 231) 0%, rgb(23, 42, 136) 100%);
  width: fit-content;
  border-radius: calc(infinity * 1px);
  position: relative;
  padding: 0.2rem;
}
.as-archive__catitem--active .as-archive__catlink {
  background-color: var(--colorW);
  border-radius: calc(infinity * 1px);
  display: block;
  padding: 0.7rem 1.6rem;
}
@media only screen and (max-width: 559px) {
  .as-archive__catitem--active .as-archive__catlink {
    padding: 0;
  }
}
.as-archive__catitem--active span {
  background: #18bde7;
  background: linear-gradient(90deg, rgb(24, 189, 231) 0%, rgb(23, 42, 136) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  padding: 0;
  padding: 1.1rem 2rem;
  border: none;
}
.as-archive__item {
  background-color: var(--colorW);
  border-radius: 3.5rem;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 5rem;
  padding: 6rem;
}
@media only screen and (max-width: 559px) {
  .as-archive__item {
    padding: 2rem;
    gap: 2.5rem;
    grid-template-columns: repeat(1, 1fr);
    border-radius: 2rem;
  }
}
.as-archive__item:not(:last-child) {
  margin-bottom: 5rem;
}
@media only screen and (max-width: 559px) {
  .as-archive__item:not(:last-child) {
    margin-bottom: 3rem;
  }
}
.as-archive__ttl {
  color: var(--mainColor);
  font-size: 2.6rem;
  letter-spacing: 0.05em;
  line-height: 1.5;
  margin-bottom: 1.5rem;
}
@media only screen and (max-width: 559px) {
  .as-archive__ttl {
    font-size: 1.8rem;
    margin-bottom: 1rem;
  }
}
.as-archive__name {
  font-size: 1.6rem;
  letter-spacing: 0.05em;
  color: #8a8a8a;
  padding-bottom: 1.5rem;
  margin-bottom: 2rem;
  border-bottom: 1px solid var(--mainColor);
}
@media only screen and (max-width: 559px) {
  .as-archive__name {
    font-size: 1.2rem;
    padding-bottom: 1rem;
    margin-bottom: 1.5rem;
  }
}
.as-archive__text {
  font-size: 1.6rem;
  letter-spacing: 0.05em;
  line-height: 1.5;
  margin-bottom: 5rem;
}
@media only screen and (max-width: 559px) {
  .as-archive__text {
    font-size: 1.2rem;
    margin-bottom: 3rem;
  }
}
.as-archive__catlist {
  margin-bottom: 2rem;
}
@media only screen and (max-width: 559px) {
  .as-archive__catlist {
    margin-bottom: 1rem;
  }
}
.as-archive__catitem {
  display: flex;
  gap: 1rem;
}
.as-archive__catitem span {
  border: 1px solid var(--mainColor);
  border-radius: calc(infinity * 1px);
  font-size: 1.5rem;
  letter-spacing: 0.05em;
  line-height: 1;
  padding: 0.8rem 1.7rem;
}
@media only screen and (max-width: 559px) {
  .as-archive__catitem span {
    font-size: 1.2rem;
    padding: 0.5rem 1.5rem;
  }
}
.as-archive__catitem span.cat {
  background-color: var(--mainColor);
  color: var(--colorW);
}
.as-archive__catitem span.cat--wh {
  background-color: var(--colorW);
  color: var(--mainColor);
}
.as-archive__btn {
  position: relative;
  width: fit-content;
}
.as-archive__btn::after {
  content: "";
  background: url(../img/icon__right--wh.svg) no-repeat center center/contain;
  width: 1.1rem;
  height: 1.4rem;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 2rem;
}
@media only screen and (max-width: 559px) {
  .as-archive__btn::after {
    width: 0.9rem;
    height: 1.2rem;
  }
}
.as-archive__btnlink {
  border-radius: calc(infinity * 1px);
  background-color: var(--mainColor);
  color: var(--colorW) !important;
  font-size: 1.6rem;
  letter-spacing: 0.05em;
  line-height: 1;
  width: 26rem;
  height: 5rem;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media only screen and (max-width: 559px) {
  .as-archive__btnlink {
    font-size: 1.4rem;
  }
}
.as-archive__list {
  margin-bottom: 9.5rem;
}
@media only screen and (max-width: 559px) {
  .as-archive__list {
    margin-bottom: 4.5rem;
  }
}
/*# sourceMappingURL=style.css.map */
