@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700;900&display=swap");
@import url("https://use.typekit.net/qmr6ewy.css");
section.intro {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: clamp(4rem, 7vw, 10rem) 0;
}
section.intro .content-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 89.7%;
  max-width: 146rem;
  column-gap: clamp(3rem, 4vw, 4rem);
  row-gap: 5rem;
}
section.intro .content-container .text-container,
section.intro .content-container .img-container {
  width: 100%;
}
section.intro .content-container .text-container {
  display: flex;
  flex-direction: column;
  gap: clamp(2rem, 4vw, 4rem);
  box-sizing: border-box;
  padding-right: 1em;
}
section.intro .content-container .text-container h2 {
  font-size: clamp(2.4rem, 4vw, 4.5rem);
  line-height: 155%;
}
section.intro .content-container .text-container p {
  font-size: clamp(1.6rem, 2vw, 2rem);
  letter-spacing: 0.02em;
  font-weight: bold;
  line-height: 225%;
}
section.intro .content-container .img-container {
  max-width: 65rem;
}
section.intro .content-container .img-container img {
  display: block;
  width: 100%;
  border-radius: 3rem;
}
@media screen and (min-width: 651px) {
  section.intro {
    align-items: flex-end;
  }
  section.intro .content-container {
    flex-direction: row;
    justify-content: flex-end;
    width: 94%;
  }
  section.intro .content-container .img-container img {
    border-top-right-radius: unset;
    border-bottom-right-radius: unset;
  }
}
@media screen and (min-width: 1921px) {
  section.intro {
    align-items: center;
  }
  section.intro .content-container .img-container img {
    border-top-right-radius: 5rem;
    border-bottom-right-radius: 5rem;
  }
}

section.message {
  padding-top: clamp(5rem, 8vw, 8rem);
  background-color: #005ead;
  color: #ffffff;
}
section.message h2 {
  position: relative;
  z-index: 10;
  font-size: clamp(4rem, 6.725vw, 10rem);
  line-height: 100%;
  transform: translateY(50%);
  -webkit-text-stroke: 1px #ffffff;
}
section.message h2 {
  align-self: flex-end;
  margin-right: 5.15vw;
}
section.message .content-container {
  width: 89.7%;
  max-width: 100rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  column-gap: clamp(3rem, 5vw, 5rem);
  row-gap: 5rem;
}
section.message .img-container,
section.message .text-container {
  width: 100%;
}
section.message .img-container {
  align-self: flex-start;
  width: 90%;
}
section.message .img-container img {
  width: 100%;
}
section.message .text-container {
  display: flex;
  flex-direction: column;
  gap: clamp(2rem, 3.2vw, 3.2rem);
  max-width: 40rem;
}
section.message .text-container h3,
section.message .text-container h4 {
  font-size: clamp(2rem, 2vw, 2.5rem);
  font-weight: bold;
  line-height: 200%;
}
section.message .text-container h4 {
  display: flex;
  align-items: center;
  gap: 0.6em;
}
section.message .text-container h4 .spacer {
  display: block;
  background-color: #ffffff;
  height: 2px;
  width: 2em;
}
section.message .text-container h4 .text {
  font-size: clamp(2rem, 2vw, 3.2rem);
  line-height: 200%;
}
section.message .text-container p {
  font-weight: 500;
  letter-spacing: 0;
  line-height: 200%;
}
section.message .white-wave {
  display: flex;
  align-items: flex-end;
  min-height: 6rem;
  width: 100%;
}
section.message .white-wave picture,
section.message .white-wave img {
  display: block;
  width: 100%;
  object-position: bottom center;
}
@media screen and (min-width: 651px) {
  section.message h2 {
    -webkit-text-stroke: 2px #ffffff;
    align-self: unset;
    margin-right: unset;
  }
  section.message .content-container {
    flex-direction: row;
  }
  section.message .content-container .img-container,
section.message .content-container .text-container {
    width: 50%;
  }
  section.message .content-container .img-container {
    align-self: center;
    max-width: 45rem;
  }
  section.message .content-container .text-container {
    padding: calc(clamp(4rem, 6.725vw, 10rem) / 2) 0;
  }
  section.message .white-wave {
    min-height: 9rem;
  }
}
@media screen and (min-width: 1001px) {
  section.message .white-wave {
    min-height: 12rem;
  }
}

section.vision-mission {
  padding: clamp(10rem, 17vw, 17rem) 0 clamp(8rem, 13vw, 13rem);
  background: url(../img/philosophy/vm-bg-min.png) top left repeat;
  background-size: 50rem;
  gap: clamp(10rem, 15vw, 15rem);
}
section.vision-mission .vm-container {
  position: relative;
  width: 89.7%;
  max-width: 100rem;
}
section.vision-mission h2 {
  position: absolute;
  top: 0;
  left: 0.5em;
  z-index: 10;
  width: calc(100% - 1em);
  box-sizing: border-box;
  color: #005ead;
  font-size: clamp(4rem, 6.725vw, 10rem);
  letter-spacing: 0.1em;
  line-height: 90%;
  text-transform: uppercase;
  transform: translateY(-50%);
  -webkit-text-stroke: 1px #005ead;
}
section.vision-mission .white-card {
  padding: calc(clamp(4rem, 6.725vw, 10rem) * 0.8) 1em calc(clamp(4rem, 6.725vw, 10rem) * 0.7);
  background-color: #ffffff;
  border-radius: 3rem;
  font-size: clamp(1.6rem, 2vw, 2rem);
  font-weight: bold;
  letter-spacing: 0;
  line-height: 200%;
}
section.vision-mission .white-card p {
  max-width: 70rem;
}
section.vision-mission .white-card.vision-card {
  font-size: clamp(2rem, 3vw, 3rem);
  line-height: 233%;
}
section.vision-mission .white-card.mission-card {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  gap: clamp(2.4rem, 4vw, 5rem);
}
section.vision-mission .white-card.mission-card .content-group {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  gap: clamp(1.6rem, 2vw, 2.5rem);
}
section.vision-mission .white-card.mission-card .counter {
  font-family: din-2014, "din-2014", " Noto Sans JP", Noto Sans JP, YuGothic, "Yu Gothic", "Yu Gothic Medium", Meiryo, sans-serif;
  font-weight: 700;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: clamp(2rem, 2.5vw, 2.5rem);
  color: #005ead;
  gap: 0.3em;
}
section.vision-mission .white-card.mission-card .counter::before, section.vision-mission .white-card.mission-card .counter::after {
  content: "";
  display: block;
  background-color: #005ead;
  width: 3.2em;
  height: 1px;
}
@media screen and (min-width: 651px) {
  section.vision-mission h2 {
    -webkit-text-stroke: 2px #005ead;
  }
  section.vision-mission .white-card {
    padding: calc(clamp(4rem, 6.725vw, 10rem) * 0.8) 2em calc(clamp(4rem, 6.725vw, 10rem) * 0.7);
  }
}
@media screen and (min-width: 1001px) {
  section.vision-mission h2 {
    -webkit-text-stroke: 3px #005ead;
  }
  section.vision-mission .white-card {
    padding: calc(clamp(4rem, 6.725vw, 10rem) * 0.8) clamp(4rem, 6.725vw, 10rem) calc(clamp(4rem, 6.725vw, 10rem) * 0.7);
  }
}
@media screen and (min-width: 1201px) {
  section.vision-mission h2 {
    -webkit-text-stroke: 5px #005ead;
  }
}

section.lgs {
  margin-top: -1px;
  padding: clamp(5rem, 6vw, 8rem) 0 clamp(6rem, 10vw, 11rem);
}
section.lgs .content-container {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  column-gap: 4rem;
  row-gap: 8rem;
  max-width: 32rem;
}
section.lgs .lgs-card {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  gap: 2rem;
}
section.lgs .lgs-card .contents {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  gap: 2rem;
  margin-bottom: auto;
  width: 100%;
}
section.lgs .lgs-card .label-container {
  text-align: center;
}
section.lgs .lgs-card .label-container h5 {
  font-weight: bold;
}
section.lgs .lgs-card .label-container h5.rj {
  color: #005ead;
  font-size: clamp(2.8rem, 3vw, 3.5rem);
  line-height: 140%;
  text-transform: uppercase;
}
section.lgs .lgs-card .label-container h5.jp {
  font-size: 1.6rem;
  letter-spacing: 0;
  line-height: 200%;
}
section.lgs .lgs-card .title-container {
  width: 100%;
  box-sizing: border-box;
  padding: 0.5rem 0.8em;
  background-color: #ffd800;
  border-radius: 2rem;
  color: #005ead;
  font-size: clamp(2rem, 2vw, 2.5rem);
  line-height: 160%;
  text-align: center;
}
section.lgs .lgs-card p.text-body {
  font-weight: bold;
  letter-spacing: 0;
  line-height: 200%;
}
@media screen and (min-width: 1001px) {
  section.lgs .content-container {
    grid-template-columns: repeat(3, 1fr);
    max-width: 100rem;
  }
  section.lgs .lgs-card {
    align-self: stretch;
  }
}

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