@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");
a.a-btn {
  width: clamp(20rem, 20vw, 26.5rem);
}

h2 {
  font-size: clamp(2.4rem, 6vw, 7.8rem);
  letter-spacing: 0;
  line-height: 150%;
}

.h2-group {
  display: flex;
  flex-direction: column;
  row-gap: 2rem;
  margin-bottom: 3.2rem;
}
.h2-group .uptitle {
  display: flex;
  align-items: center;
  gap: 0.666em;
  color: #005ead;
  font-size: clamp(2rem, 2.5vw, 3rem);
  letter-spacing: 0.05em;
}
.h2-group .uptitle span {
  display: block;
  background-color: #005ead;
  width: 3.333em;
  height: 1px;
}
.h2-group .uptitle h3 {
  font-weight: 400;
  font-size: 1em;
}
.h2-group h2 {
  font-family: din-2014, "din-2014", " Noto Sans JP", Noto Sans JP, YuGothic, "Yu Gothic", "Yu Gothic Medium", Meiryo, sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  color: #005ead;
  font-size: clamp(4rem, 10vw, 16rem);
  font-style: italic;
  line-height: 60%;
  letter-spacing: 0.1em;
  -webkit-text-stroke: 1px #005ead;
}
@media screen and (min-width: 651px) {
  .h2-group h2 {
    -webkit-text-stroke: 3px #005ead;
  }
}
@media screen and (min-width: 1201px) {
  .h2-group h2 {
    -webkit-text-stroke: 5px #005ead;
  }
}

section.top-landing {
  position: relative;
  width: 100%;
  max-width: 100%;
  height: calc(100vh + clamp(60px, 10vw, 120px));
  display: grid;
  grid-template-columns: 1fr clamp(10rem, 89.7%, 120rem) 1fr;
  grid-template-rows: auto;
}
section.top-landing .img-container {
  position: absolute;
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%;
  z-index: 0;
  grid-row: 1/2;
  pointer-events: none;
}
section.top-landing .img-container picture,
section.top-landing .img-container img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
}
section.top-landing .img-container.img-container-1 {
  display: none;
}
section.top-landing .img-container.img-container-2 {
  grid-column: 1/2;
  align-items: start;
  justify-content: end;
}
section.top-landing .img-container.img-container-2 picture {
  margin: 7rem auto auto 0;
  width: 24vw;
  max-width: 32.4rem;
}
section.top-landing .img-container.img-container-3 {
  grid-column: 1/4;
  align-items: end;
  justify-content: end;
}
section.top-landing .img-container.img-container-3 picture {
  margin: auto clamp(1rem, 25%, 26.4rem) 0 auto;
  width: 89.2%;
  max-width: 54rem;
}
section.top-landing .img-container.img-container-4 {
  grid-column: 2/4;
  align-items: end;
  justify-content: end;
}
section.top-landing .img-container.img-container-4 picture {
  margin: clamp(1rem, 10vh, 7rem) 0 auto auto;
  width: 40vw;
  max-width: 39rem;
}
section.top-landing .top-contents {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 2rem;
  position: relative;
  z-index: 10;
  color: #005ead;
  width: 100%;
  height: 100%;
  grid-column: 2/3;
  grid-row: 1/2;
}
section.top-landing .top-contents h1,
section.top-landing .top-contents p.subtitle {
  width: 100%;
}
section.top-landing .top-contents h1 {
  font-size: clamp(5rem, 10vw, 16rem);
  letter-spacing: 0.05em;
  line-height: 100%;
  -webkit-text-stroke: 1px #005ead;
}
section.top-landing .top-contents p.subtitle {
  font-size: clamp(2rem, 2.1vw, 3.4rem);
  line-height: 180%;
  letter-spacing: 0.01em;
}
@media screen and (min-width: 651px) {
  section.top-landing .img-container.img-container-1 {
    display: flex;
    grid-column: 1/3;
    align-items: start;
    justify-content: flex-start;
  }
  section.top-landing .img-container.img-container-1 picture {
    margin: 0 0 auto 10vw;
    width: 55%;
    max-width: 77.6rem;
  }
  section.top-landing .img-container.img-container-2 picture {
    margin: 12rem auto auto 0;
    width: 18vw;
    max-width: 32.4rem;
  }
  section.top-landing .img-container.img-container-3 picture {
    margin: auto auto 0 clamp(1rem, 12.5%, 16rem);
    width: 45%;
  }
  section.top-landing .img-container.img-container-4 picture {
    margin: auto 0 calc(clamp(60px, 10vw, 120px) + clamp(1rem, 13vh, 13rem)) auto;
    width: 24%;
  }
}
@media screen and (min-width: 1201px) {
  section.top-landing .top-contents h1 {
    -webkit-text-stroke: 3px #005ead;
  }
  section.top-landing .img-container.img-container-1 picture {
    width: 62%;
  }
  section.top-landing .img-container.img-container-2 picture {
    margin: auto auto clamp(60px, 10vw, 120px) 0;
    width: 95%;
    min-width: 16rem;
  }
  section.top-landing .img-container.img-container-3 {
    grid-column: 2/3;
  }
  section.top-landing .img-container.img-container-3 picture {
    margin: auto clamp(1rem, 25%, 26.4rem) 0 auto;
    width: 65%;
  }
  section.top-landing .img-container.img-container-4 {
    grid-column: 2/4;
  }
  section.top-landing .img-container.img-container-4 picture {
    margin: auto 0 calc(clamp(60px, 10vw, 120px) + clamp(1rem, 13vh, 13rem)) auto;
  }
  section.top-landing .top-contents {
    box-sizing: border-box;
    padding-left: clamp(4rem, 6vw, 10rem);
  }
}

section.about {
  color: #ffffff;
  margin-top: calc(-1 * clamp(60px, 10vw, 120px));
}
section.about .overlay {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 100;
  display: block;
  pointer-events: none;
  width: 100%;
  height: 100%;
}
section.about .text-container {
  position: relative;
  z-index: 101;
}
section.about .wave {
  display: block;
  width: 100%;
  height: 12rem;
  background: #005ead;
}
section.about .wave.top-wave {
  background: url(../img/top/sp/about-bg-wave-top.svg) bottom no-repeat;
  background-size: 100% auto;
  height: 12rem;
  margin-bottom: -1px;
}
section.about .wave.bottom-wave {
  background: url(../img/top/sp/about-bg-wave-bottom.svg) top no-repeat;
  background-size: 100% auto;
  height: 12rem;
  margin-top: -1px;
}
@media screen and (min-width: 651px) {
  section.about .wave.top-wave {
    background: url(../img/top/tab/about-bg-wave-top.svg) bottom no-repeat;
    background-size: 100% auto;
  }
  section.about .wave.bottom-wave {
    background: url(../img/top/tab/about-bg-wave-bottom.svg) top no-repeat;
    background-size: 100% auto;
  }
}
@media screen and (min-width: 1001px) {
  section.about .wave.top-wave {
    background: url(../img/top/medium/about-bg-wave-top.svg) bottom no-repeat;
    background-size: 100% auto;
    height: clamp(12rem, 10vw, 16rem);
  }
  section.about .wave.bottom-wave {
    background: url(../img/top/medium/about-bg-wave-bottom.svg) top no-repeat;
    background-size: 100% auto;
    height: clamp(12rem, 10vw, 16rem);
  }
}
@media screen and (min-width: 1601px) {
  section.about .wave.top-wave {
    background: url(../img/top/large/about-bg-wave-top.svg) bottom no-repeat;
    background-size: 100% auto;
    height: clamp(16rem, 10vw, 26rem);
  }
  section.about .wave.bottom-wave {
    background: url(../img/top/large/about-bg-wave-bottom.svg) top no-repeat;
    background-size: 100% auto;
    height: clamp(16rem, 10vw, 26rem);
  }
}
section.about .content-container {
  background-color: #004693;
}
section.about .content-container .container-st {
  gap: clamp(6rem, 8vw, 13rem);
}
section.about .content-container .text-container {
  gap: clamp(4rem, 7vw, 10rem);
}
section.about .content-container .text-block {
  gap: 3em;
  font-size: clamp(1.6rem, 2vw, 2.4rem);
  line-height: 200%;
}
section.about img.bg-hands {
  position: absolute;
  pointer-events: none;
  width: 34.7vw;
  right: 15vw;
  bottom: clamp(16rem, 20vw, 26rem);
  mix-blend-mode: multiply;
}
@media screen and (min-width: 651px) {
  section.about .content-container .text-block {
    line-height: 250%;
  }
}

.news-cards {
  margin-top: clamp(4rem, 7vw, 10rem);
  position: relative;
  z-index: 101;
  display: grid;
  gap: 2.4rem;
  grid-template-columns: repeat(1, 1fr);
  color: #005ead;
}
.news-cards .img-card {
  display: block;
  aspect-ratio: 16/9;
}
.news-cards .img-card img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.news-cards .card {
  position: relative;
  aspect-ratio: 16/9;
  width: 100%;
  box-sizing: border-box;
  padding: 1rem;
  background-color: #ffffff;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  font-weight: bold;
  overflow-y: scroll;
}
.news-cards .card:hover {
  opacity: 0.8;
}
.news-cards .card .blog-date,
.news-cards .card .blog-title,
.news-cards .card .tag-list {
  position: relative;
  z-index: 10;
  pointer-events: none;
}
.news-cards .card .blog-date {
  width: fit-content;
  font-size: 1.4rem;
}
.news-cards .card .blog-title {
  color: #005ead;
  font-size: 1.6rem;
  line-height: 150%;
}
.news-cards .card .tag-list ul {
  display: flex;
  flex-wrap: wrap;
  font-size: 1.3rem;
  column-gap: 1.5em;
  row-gap: 0.5em;
  width: fit-content;
  max-width: 100%;
}
.news-cards .card .tag-list li {
  line-height: 100%;
}
.news-cards .card .tag-list a {
  color: #005ead;
}
.news-cards .card .tag-list a:before {
  content: "#";
}
.news-cards .card a.bg-link {
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
@media screen and (min-width: 651px) {
  .news-cards {
    grid-template-columns: repeat(3, 1fr);
  }
}

section.lgs {
  gap: clamp(6rem, 10vw, 12rem);
}
section.lgs a.a-btn {
  font-size: clamp(1.4rem, 2vw, 1.6rem);
}
section.lgs .lgs-cards {
  display: flex;
  flex-direction: column;
  width: 92%;
  gap: clamp(6rem, 12vw, 15rem);
}
section.lgs .lgs-card {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(4rem, 5vw, 6rem);
}
section.lgs .lgs-card .img-container {
  overflow: hidden;
  width: 100%;
  max-width: 50rem;
  border-radius: clamp(2rem, 4vw, 4rem);
  aspect-ratio: 9/7;
}
section.lgs .lgs-card .img-container picture,
section.lgs .lgs-card .img-container img {
  height: 100%;
  width: 100%;
  object-fit: cover;
}
section.lgs .lgs-card .text-container {
  position: relative;
  z-index: 100;
  display: flex;
  flex-direction: column;
  gap: 2rem;
  width: 100%;
  max-width: 50rem;
}
section.lgs .lgs-card .text-container h3 {
  font-family: din-2014, "din-2014", " Noto Sans JP", Noto Sans JP, YuGothic, "Yu Gothic", "Yu Gothic Medium", Meiryo, sans-serif;
  font-weight: 600;
  color: #ffd800;
  font-style: italic;
  font-size: clamp(6rem, 10vw, 16rem);
  letter-spacing: 0.1em;
  line-height: 100%;
  -webkit-text-stroke: 1px solid #ffd800;
}
section.lgs .lgs-card .text-container p {
  font-weight: bold;
  letter-spacing: 0.02em;
  line-height: 220%;
}
@media screen and (min-width: 651px) {
  section.lgs .lgs-cards {
    width: 100%;
  }
  section.lgs .lgs-card {
    flex-direction: row;
    width: 96%;
    max-width: 146rem;
  }
  section.lgs .lgs-card .img-container {
    width: 40%;
    max-width: 90rem;
    border-bottom-left-radius: unset;
    border-top-left-radius: unset;
  }
  section.lgs .lgs-card .text-container h3 {
    -webkit-text-stroke: 3px solid #ffd800;
  }
  section.lgs .lgs-card .a-btn {
    margin-top: clamp(2rem, 4vw, 5rem);
  }
  section.lgs .lgs-card:nth-child(even) {
    flex-direction: row-reverse;
    align-self: flex-end;
  }
  section.lgs .lgs-card:nth-child(even) .img-container {
    border-bottom-right-radius: unset;
    border-top-right-radius: unset;
    border-bottom-left-radius: clamp(2rem, 4vw, 4rem);
    border-top-left-radius: clamp(2rem, 4vw, 4rem);
  }
}
@media screen and (min-width: 1201px) {
  section.lgs .lgs-card .img-container {
    width: 70%;
  }
  section.lgs .lgs-card .text-container h3 {
    -webkit-text-stroke: 5px solid #ffd800;
  }
}
@media screen and (min-width: 1921px) {
  section.lgs .lgs-card .img-container {
    border-bottom-left-radius: clamp(2rem, 4vw, 4rem);
    border-top-left-radius: clamp(2rem, 4vw, 4rem);
  }
  section.lgs .lgs-card:nth-child(even) .img-container {
    border-bottom-right-radius: clamp(2rem, 4vw, 4rem);
    border-top-right-radius: unset;
  }
}

section.event {
  margin-top: clamp(6rem, 10vw, 13rem);
}
section.event .overlay {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 100;
  display: block;
  pointer-events: none;
  width: 100%;
  height: 100%;
}
section.event .wave {
  display: block;
  width: 100%;
  height: 12rem;
  background: #fff0a0;
}
section.event .wave.top-wave {
  background: url(../img/top/sp/event-bg-wave-top.svg) bottom no-repeat;
  background-size: 100% auto;
  height: 12rem;
  margin-bottom: -1px;
}
section.event .wave.bottom-wave {
  background: url(../img/top/sp/event-bg-wave-bottom.svg) top no-repeat;
  background-size: 100% auto;
  height: 12rem;
  margin-top: -1px;
}
@media screen and (min-width: 651px) {
  section.event .wave.top-wave {
    background: url(../img/top/tab/event-bg-wave-top.svg) bottom no-repeat;
    background-size: 100% auto;
  }
  section.event .wave.bottom-wave {
    background: url(../img/top/tab/event-bg-wave-bottom.svg) top no-repeat;
    background-size: 100% auto;
  }
}
@media screen and (min-width: 1001px) {
  section.event .wave.top-wave {
    background: url(../img/top/medium/event-bg-wave-top.svg) bottom no-repeat;
    background-size: 100% auto;
    height: clamp(12rem, 10vw, 16rem);
  }
  section.event .wave.bottom-wave {
    background: url(../img/top/medium/event-bg-wave-bottom.svg) top no-repeat;
    background-size: 100% auto;
    height: clamp(12rem, 10vw, 16rem);
  }
}
@media screen and (min-width: 1601px) {
  section.event .wave.top-wave {
    background: url(../img/top/large/event-bg-wave-top.svg) bottom no-repeat;
    background-size: 100% auto;
    height: clamp(16rem, 10vw, 26rem);
  }
  section.event .wave.bottom-wave {
    background: url(../img/top/large/event-bg-wave-bottom.svg) top no-repeat;
    background-size: 100% auto;
    height: clamp(16rem, 10vw, 26rem);
  }
}
section.event .content-container {
  padding: clamp(4rem, 7vw, 10rem) 0 clamp(4rem, 7vw, 8rem);
  background-color: #fff0a0;
  gap: clamp(4rem, 7vw, 10rem);
}
section.event .content-container .container-st {
  gap: clamp(4rem, 7vw, 8rem);
  position: relative;
  z-index: 101;
  max-width: 124rem;
}
section.event .content-container .container-st .a-btn {
  align-self: center;
}

section.interview {
  margin-bottom: clamp(10rem, 10vw, 14rem);
  gap: clamp(5rem, 5vw, 7.5rem);
}
section.interview .h2-group {
  align-self: flex-end;
  width: fit-content;
}
section.interview .h2-group h2 {
  text-align: end;
  line-height: 100%;
}
section.interview .interview-section {
  width: 100%;
  gap: clamp(6rem, 7vw, 9rem);
}
section.interview .interview-section .post-grid {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: clamp(4rem, 5vw, 6rem);
}
section.interview .interview-section .post-card {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: 35rem;
  margin: auto;
}
section.interview .interview-section .post-card .img-container {
  position: relative;
  display: block;
  width: 100%;
  margin-bottom: clamp(2rem, 3vw, 3rem);
}
section.interview .interview-section .post-card .img-container img {
  width: 100%;
  aspect-ratio: 1/1;
  border-radius: 50%;
  object-fit: cover;
}
section.interview .interview-section .post-card .img-container img.placeholder {
  border: 2px solid #005ead;
}
section.interview .interview-section .post-card .img-container .yellow-label {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  font-family: din-2014, "din-2014", " Noto Sans JP", Noto Sans JP, YuGothic, "Yu Gothic", "Yu Gothic Medium", Meiryo, sans-serif;
  font-weight: 600;
  position: absolute;
  top: 0;
  left: 0;
  font-style: italic;
  width: clamp(10rem, 10vw, 14.6rem);
  aspect-ratio: 1/1;
  background-color: #ffd800;
  border-radius: 50%;
}
section.interview .interview-section .post-card .img-container .yellow-label img {
  aspect-ratio: unset;
  max-width: 90%;
  max-height: 1.8rem;
  border-radius: unset;
  object-fit: contain;
}
section.interview .interview-section .post-card .text-container {
  width: 100%;
  display: flex;
  flex-direction: column;
  flex: 1;
  max-width: 44.5rem;
}
section.interview .interview-section .post-card .text-container p.date {
  margin-bottom: 1rem;
  color: #005ead;
  font-size: clamp(1.6rem, 2vw, 2rem);
  font-weight: bold;
}
section.interview .interview-section .post-card .text-container .categories {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 2rem;
  width: 100%;
  column-gap: 1rem;
  row-gap: 0.5rem;
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.02em;
  line-height: 100%;
}
section.interview .interview-section .post-card .text-container .categories a {
  color: #005ead;
  background-color: #ffd800;
  padding: 0.25em 0.5em;
  border-radius: 3px;
}
section.interview .interview-section .post-card .text-container .categories a:before {
  content: "#";
}
section.interview .interview-section .post-card .text-container h3 {
  margin-bottom: 2rem;
  color: #005ead;
  font-size: clamp(2rem, 2.5vw, 3rem);
  letter-spacing: 0;
  text-decoration: underline;
}
section.interview .interview-section .post-card .text-container h4 {
  color: #005ead;
  font-size: clamp(1.6rem, 2vw, 2rem);
  line-height: 150%;
  letter-spacing: 0.05em;
}
section.interview .interview-section .post-card .text-container p.excerpt {
  line-height: 180%;
  letter-spacing: 0.02em;
}
section.interview .interview-section .post-card .text-container .a-btn {
  align-self: flex-end;
  margin-top: 2rem;
}
@media screen and (min-width: 651px) {
  section.interview .interview-section .post-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  section.interview .interview-section .post-card.hero-post {
    flex-direction: row;
    align-items: flex-start;
    max-width: 100rem;
  }
  section.interview .interview-section .post-card.hero-post .img-container {
    width: 40vw;
    max-width: 50rem;
    min-width: 24rem;
    margin-bottom: 0;
  }
  section.interview .interview-section .post-card.hero-post .text-container {
    padding-left: clamp(2rem, 4vw, 5.5rem);
  }
}
@media screen and (min-width: 1201px) {
  section.interview .h2-group {
    align-self: flex-end;
    transform: translate(2em);
    margin-bottom: -7rem;
  }
  section.interview .interview-section .post-card.hero-post {
    align-items: flex-end;
  }
  section.interview .interview-section .post-card.hero-post .text-container {
    padding-top: 10rem;
  }
}
@media screen and (min-width: 1801px) {
  section.interview .h2-group {
    transform: translate(clamp(1rem, 16vw, 30rem));
  }
}

section.philosophy {
  color: #ffffff;
}
section.philosophy .overlay {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 101;
  display: block;
  pointer-events: none;
  width: 100%;
  height: 100%;
  opacity: 0.3;
  mix-blend-mode: plus-lighter;
}
section.philosophy .wave {
  display: block;
  width: 100%;
  height: 12rem;
  background: #004693;
}
section.philosophy .wave.upper-wave {
  background: url(../img/top/sp/about-bg-wave-top.svg) bottom no-repeat;
  background-size: 100% auto;
  height: 12rem;
  margin-bottom: -1px;
}
section.philosophy .wave.lower-wave {
  background: #005ead;
  background: url(../img/top/sp/mc-bg-wave-top.svg) bottom no-repeat;
  background-size: 100% auto;
  height: 12rem;
  margin-bottom: -1px;
}
section.philosophy .upper,
section.philosophy .lower {
  position: relative;
  z-index: 100;
  width: 100%;
}
section.philosophy .upper .upper-contents {
  padding: clamp(8rem, 15vw, 20rem) 0 clamp(8rem, 10vw, 16rem);
  background-color: #004693;
  background-image: url(../img/top/bg-world.svg);
  background-position: center;
  background-size: clamp(20rem, 64vw, 86rem) auto;
  background-repeat: no-repeat;
}
section.philosophy .lower {
  background-color: #004693;
}
section.philosophy .lower .lower-contents {
  padding: clamp(6rem, 10vw, 12rem) 0 clamp(12rem, 18vw, 22rem);
  background-color: #005ead;
  width: 100%;
}
section.philosophy .text-container {
  gap: clamp(2rem, 3vw, 3rem);
}
section.philosophy .text-container .bar-title {
  margin-bottom: 1rem;
}
section.philosophy .text-container .bar-title .spacer {
  width: 3.33em;
  height: 1px;
}
section.philosophy .text-container .bar-title h3 {
  font-size: clamp(2rem, 3vw, 3rem);
}
section.philosophy .text-container h2 {
  font-size: clamp(2.4rem, 4vw, 5rem);
  line-height: 140%;
}
section.philosophy .text-container p.text-block {
  font-size: clamp(1.6rem, 2vw, 2rem);
  font-weight: bold;
  line-height: 200%;
}
section.philosophy .text-container .a-btn {
  margin-top: 1rem;
}
@media screen and (min-width: 651px) {
  section.philosophy .wave.upper-wave {
    background: url(../img/top/tab/about-bg-wave-top.svg) bottom no-repeat;
    background-size: 100% auto;
  }
  section.philosophy .wave.lower-wave {
    background: url(../img/top/tab/mc-bg-wave-top.svg) bottom no-repeat;
    background-size: 100% auto;
  }
}
@media screen and (min-width: 1001px) {
  section.philosophy .upper .upper-contents {
    background-position: left center;
    background-size: clamp(20rem, 50vw, 86rem) auto;
  }
  section.philosophy .upper .text-container {
    max-width: 50rem;
    align-self: flex-end;
  }
  section.philosophy .lower .a-btn {
    align-self: center;
    margin-top: 2rem;
  }
  section.philosophy .wave.upper-wave {
    background: url(../img/top/medium/about-bg-wave-top.svg) bottom no-repeat;
    background-size: 100% auto;
    height: clamp(12rem, 10vw, 16rem);
  }
  section.philosophy .wave.lower-wave {
    background: url(../img/top/medium/mc-bg-wave-top.svg) bottom no-repeat;
    background-size: 100% auto;
    height: clamp(12rem, 10vw, 16rem);
  }
}
@media screen and (min-width: 1601px) {
  section.philosophy .wave.upper-wave {
    background: url(../img/top/large/about-bg-wave-top.svg) bottom no-repeat;
    background-size: 100% auto;
    height: clamp(16rem, 10vw, 26rem);
  }
  section.philosophy .wave.lower-wave {
    background: url(../img/top/large/mc-bg-wave-top.svg) bottom no-repeat;
    background-size: 100% auto;
    height: clamp(16rem, 10vw, 26rem);
  }
}

section.humano {
  padding: clamp(16rem, 20vw, 23rem) 0;
  background: url(../img/top/sp/bg-humano.webp) center no-repeat;
  background-size: cover;
  gap: clamp(4rem, 5vw, 6rem);
}
section.humano h2 {
  font-size: clamp(2.4rem, 3vw, 4rem);
  letter-spacing: 0.05em;
  color: #005ead;
}
section.humano .container-st {
  gap: clamp(4rem, 5vw, 6rem);
}
section.humano .humano-contents {
  width: 100%;
  max-width: 40rem;
  gap: clamp(5rem, 6vw, 7rem);
}
section.humano .humano-contents .img-container {
  width: 100%;
  max-width: 33rem;
}
section.humano .humano-contents .img-container img {
  width: 100%;
}
section.humano .humano-contents .text-container {
  width: 100%;
  max-width: 60rem;
  display: flex;
  flex-direction: column;
  gap: clamp(2.4rem, 3vw, 4rem);
}
section.humano .humano-contents .text-container h4 {
  font-size: clamp(2.4rem, 3vw, 3.5rem);
  font-weight: bold;
}
section.humano .humano-contents .text-container h3 {
  font-size: clamp(2rem, 2vw, 2.6rem);
  line-height: 150%;
}
section.humano .humano-contents .text-container p.text-block {
  font-size: clamp(1.6rem, 2vw, 1.8rem);
  line-height: 155%;
}
@media screen and (min-width: 651px) {
  section.humano {
    background: url(../img/top/tab/bg-humano.webp) center no-repeat;
    background-size: cover;
  }
  section.humano .humano-contents {
    max-width: 100%;
  }
}
@media screen and (min-width: 1001px) {
  section.humano {
    background: url(../img/top/medium/bg-humano.webp) center no-repeat;
    background-size: cover;
  }
}
@media screen and (min-width: 1601px) {
  section.humano {
    background: url(../img/top/large/bg-humano.webp) center no-repeat;
    background-size: cover;
  }
}

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