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

colors setting

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

colors setting の変数ではなく
下記の左側の変数をcssで指定する

×：$black
◯：$dark-text

------------------------------------ */
/*  text-color
*----------------------------------- */
/*  background-color
*----------------------------------- */
/*  border-color
*----------------------------------- */
/*  system-color
*----------------------------------- */
/*  cv
*----------------------------------- */
/*  footer
*----------------------------------- */
/*  menu
*----------------------------------- */
/*  new icon
*----------------------------------- */
/*  horizontal
*----------------------------------- */
/*  slick-color
*----------------------------------- */
.en {
  font-family: "anton", sans-serif;
  font-weight: 400;
  letter-spacing: 0;
  line-height: 1;
}

.en02 {
  font-family: "anton", sans-serif;
  font-weight: 400;
  letter-spacing: 0;
  line-height: 1;
}

.yakuhan {
  font-family: "YakuHanJP", ryo-gothic-plusn, sans-serif;
}

/* mobile */
@media (min-width: 768px) {
  .page-top .header:not(.active):not(.open) {
    background-color: rgba(29, 32, 136, 0);
    padding: 30px 2% 0 3%;
  }
  .page-top .header:not(.active):not(.open) .header-sns a img {
    filter: brightness(0) invert(0);
  }
  .page-top .header:not(.active):not(.open) .global-nav li:last-child a {
    color: #1D2088;
  }
  .page-top .header:not(.active):not(.open) .global-nav li a {
    color: #1F1F1F;
  }
}

@media (min-width: 768px) {
  .page-top .l-toggle:not(.scroll):not(.active) span {
    background: #1F1F1F;
  }
}

.mv {
  height: 63.888dvw;
  max-height: 100dvh;
  display: grid;
  position: relative;
}
@media (max-width: 767px) {
  .mv {
    position: relative;
    height: 138.4615384615dvw;
  }
}
.mv__img {
  z-index: -1;
  position: fixed;
  display: block;
  width: 100dvw;
  height: 63.888dvw;
  max-height: 100dvh;
  content: "";
}
@media (max-width: 767px) {
  .mv__img {
    height: 138.4615384615dvw;
  }
}
.mv__img picture {
  display: block;
  position: absolute;
  inset: 0;
  margin: auto;
  transition: 0.5s;
}
.mv__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.mv__img.active-01 picture:nth-of-type(3) {
  opacity: 0;
}
.mv__img.active-02 picture:nth-of-type(2) {
  opacity: 0;
}
@media (max-width: 767px) {
  .mv::after {
    z-index: -2;
    position: fixed;
    content: "";
    top: 0;
    left: 0;
    right: 0;
    width: 100dvw;
    height: 100dvh;
    margin: auto;
    background-color: #1D2088;
  }
}
.mv__ttl {
  margin-left: 4.723dvw;
  position: relative;
}
@media (min-width: 768px) {
  .mv__ttl {
    margin-top: auto;
    bottom: max(-65px, -7.849%);
  }
}
@media (max-width: 767px) {
  .mv__ttl {
    position: absolute;
    margin-left: 5.1282051282dvw;
    top: 93.0769230769dvw;
  }
}
.mv__ttl img {
  width: 78.4723dvw;
  max-width: 1130px;
  height: auto;
}
@media (max-width: 767px) {
  .mv__ttl img {
    width: 87.4358974359dvw;
  }
}

.top-contents {
  background-color: rgba(29, 32, 136, 0.82);
}

.mv-news {
  position: absolute;
  z-index: 3;
  right: 0;
  bottom: -35px;
  transition: 0.5s;
}
@media (max-width: 767px) {
  .mv-news {
    left: 0;
    right: -11vw;
    bottom: -66.2vw;
    width: 90%;
    margin: auto;
  }
}
.load .mv-news {
  transition-delay: 1s;
  opacity: 1;
}
.mv-news a {
  max-width: 360px;
  min-height: 70px;
  display: grid;
  background-color: #fff;
  grid-template-columns: max-content auto;
  overflow: hidden;
}
@media (max-width: 767px) {
  .mv-news a {
    max-width: 89.7435897436dvw;
    min-height: 12.3076923077dvw;
  }
}
.mv-news span {
  min-width: 90px;
  font-size: 2.5rem;
  font-family: "anton", sans-serif;
  font-weight: bold;
  color: #1D2088;
  letter-spacing: 0.05em;
  display: grid;
  line-height: 56px;
  padding-bottom: 4px;
  place-content: center;
}
@media (max-width: 767px) {
  .mv-news span {
    min-width: 21.2820512821dvw;
    font-size: 21px;
    font-size: 5.3846153846dvw;
  }
}
.mv-news div {
  padding: 0 18px 0 0;
  display: grid;
  align-items: center;
}
@media (min-width: 768px) {
  .mv-news div {
    min-width: 232px;
  }
}
.mv-news p {
  font-size: 1.5rem;
  font-weight: 500;
  line-height: 1.5384615385;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}
@media (max-width: 767px) {
  .mv-news p {
    font-size: 13px;
    font-size: 3.3333333333dvw;
  }
}

.lead {
  max-width: 1440px;
  margin: 0 0 0 5.5dvw;
  padding: 161px 0 223px;
}
@media (max-width: 767px) {
  .lead {
    margin: 0 6.1538461538dvw;
    padding: 83vw 0 27.6923076923dvw;
  }
}
.lead p {
  font-size: 4.4rem;
  font-weight: bold;
  line-height: 1.9545454545;
  color: #fff;
  clip-path: inset(0 100% 0 0);
  transition: 1.2s;
}
@media (min-width: 768px) {
  .lead p {
    letter-spacing: -0.01em;
  }
}
@media (max-width: 767px) {
  .lead p {
    font-size: 22px;
    font-size: 5.641025641dvw;
    line-height: 2.1818181818;
  }
}
.lead p:not(:last-child) {
  margin-bottom: 1.4em;
}
@media (max-width: 767px) {
  .lead p:not(:last-child) {
    margin-bottom: 2.1em;
  }
}
.lead p.active {
  clip-path: inset(0 0 0 0);
}

.message {
  max-width: 1440px;
  margin: 0 auto 117px;
}
@media (min-width: 768px) {
  .message {
    padding-left: 20px;
  }
}
@media (max-width: 767px) {
  .message {
    margin: 0 auto;
  }
}
.message__wrap {
  max-width: 1191px;
  position: relative;
}
@media (min-width: 768px) {
  .message__wrap {
    height: 64.862dvw;
    margin-left: auto;
    max-height: 934px;
  }
}
.message__ttl {
  position: relative;
  z-index: 2;
}
@media (min-width: 768px) {
  .message__ttl {
    top: -5px;
    left: 10px;
    margin-bottom: 68px;
  }
}
@media (max-width: 767px) {
  .message__ttl {
    margin: 0 0 -11.0256410256dvw 6.6666666667dvw;
  }
}
.message__ttl img {
  width: 77.6659%;
}
@media (max-width: 767px) {
  .message__ttl img {
    width: 84.6153846154dvw;
  }
}
@media (min-width: 768px) {
  .message__img {
    width: 79.429%;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 1;
  }
}
@media (max-width: 767px) {
  .message__img {
    margin-bottom: -22.8205128205dvw;
  }
}
.message__txt {
  color: #fff;
  position: relative;
  z-index: 2;
}
@media (max-width: 767px) {
  .message__txt {
    margin: 0 7.6923076923dvw;
  }
}
.message__txt p {
  font-size: 1.8rem;
  font-weight: 500;
}
@media (max-width: 767px) {
  .message__txt p {
    font-size: 16px;
    font-size: 4.1025641026dvw;
  }
}
.message__subttl {
  margin-bottom: 20px;
  font-size: min(11.4rem, 10dvw);
  font-weight: bold;
  line-height: 1.1228070175;
}
@media (max-width: 767px) {
  .message__subttl {
    margin-bottom: 3.3333333333dvw;
    font-size: 52px;
    font-size: 13.3333333333dvw;
    line-height: 1.1153846154;
  }
}
.message__btn {
  margin-top: 47px;
}
@media (max-width: 767px) {
  .message__btn {
    width: fit-content;
    margin: 7.6923076923dvw auto 0;
  }
}

.vision {
  max-width: 1440px;
  margin: 0 auto;
  padding-top: 117px;
  position: relative;
}
@media (min-width: 768px) {
  .vision {
    min-height: min(893px, 62.0139dvw);
    padding-bottom: 0;
  }
}
@media (max-width: 767px) {
  .vision {
    margin: 0 7.6923076923dvw;
    padding-bottom: 0;
  }
}
@media (min-width: 768px) {
  .vision__wrap {
    position: relative;
    box-sizing: border-box;
    padding-left: 46.458%;
  }
}
.vision__ttl {
  color: #fff;
  font-size: min(25.8rem, 17.917dvw);
  font-weight: 400;
  letter-spacing: 0.03em;
  font-family: "anton", sans-serif;
  line-height: 1;
  position: relative;
  z-index: 2;
  margin-bottom: 41px;
}
@media (min-width: 768px) {
  .vision__ttl {
    top: -16px;
  }
}
@media (max-width: 767px) {
  .vision__ttl {
    margin-bottom: 6.4102564103dvw;
    font-size: 110px;
    font-size: 28.2051282051dvw;
  }
}
.vision__txt {
  color: #fff;
  position: relative;
  z-index: 2;
}
@media (min-width: 768px) {
  .vision__txt {
    margin-left: -5px;
  }
}
@media (max-width: 767px) {
  .vision__txt {
    margin-bottom: -22.5641025641dvw;
  }
}
.vision__txt p {
  font-size: min(10.4rem, 7.223dvw);
  font-weight: bold;
  line-height: 1.1634615385;
}
@media (max-width: 767px) {
  .vision__txt p {
    font-size: 52px;
    font-size: 13.3333333333dvw;
    line-height: 1.1153846154;
  }
}
.vision__img {
  width: 46.389%;
}
@media (min-width: 768px) {
  .vision__img {
    z-index: 1;
    position: absolute;
    top: 0;
    left: 4.862%;
  }
}
@media (max-width: 767px) {
  .vision__img {
    margin: 0 auto -16.9230769231dvw;
    width: 82.5641025641dvw;
  }
}
.vision__btn {
  margin: 47px 0 0 -5px;
}
@media (max-width: 767px) {
  .vision__btn {
    width: fit-content;
    margin: 10.2564102564dvw auto 0;
  }
}

.bridge-img:has(+ .other) {
  padding-bottom: 273px;
}
@media (max-width: 767px) {
  .bridge-img:has(+ .other) {
    padding-bottom: 18.7179487179dvw;
  }
}

.reason {
  padding-top: 240px;
  margin-bottom: 280px;
}
@media (max-width: 767px) {
  .reason {
    padding-top: 30.7692307692dvw;
    margin-bottom: 32vw;
  }
}
.reason__ttl {
  margin-bottom: 59px;
  color: #fff;
  text-align: center;
  line-height: 1;
  font-size: 2.2rem;
  font-weight: bold;
}
@media (max-width: 767px) {
  .reason__ttl {
    margin-bottom: 10.5128205128dvw;
    font-size: 17px;
    font-size: 4.358974359dvw;
  }
}
.reason__ttl span {
  margin-bottom: 51px;
  font-size: 22.2rem;
  display: block;
  font-family: "anton", sans-serif;
  font-weight: 400;
  letter-spacing: 0.03em;
}
@media (max-width: 767px) {
  .reason__ttl span {
    margin-bottom: 6.4102564103dvw;
    font-size: 102px;
    font-size: 26.1538461538dvw;
  }
}
.reason__slide {
  max-width: 1800px;
  margin: 0 auto;
  background-color: #66c5e3;
  border-radius: 30px;
}
@media (min-width: 768px) {
  .reason__slide {
    width: 94%;
    aspect-ratio: 1336/524;
  }
}
@media (max-width: 767px) {
  .reason__slide {
    height: 146.1538461538dvw;
    max-width: 88.2051282051dvw;
    border-radius: 7.6923076923dvw;
  }
}
.reason__slide a:hover {
  opacity: 1;
}
.reason__slide a:hover img {
  opacity: 1;
}
@media (min-width: 768px) {
  .reason__slide .slick-dots {
    bottom: auto;
    top: 50%;
    translate: 0 -50%;
    left: auto;
    right: 17px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    width: auto;
  }
  .reason__slide .slick-dots li {
    width: 3px;
    height: 30px;
    border-radius: 0;
  }
  .reason__slide .slick-dots li button {
    width: 20px;
    height: 30px;
    margin-left: -10px;
  }
}
@media (max-width: 767px) {
  .reason__slide .slick-dots {
    bottom: -10vw;
  }
  .reason__slide .slick-dots li.slick-active {
    background: #66C5E2;
  }
}

.person {
  margin-bottom: 152px;
}
@media (max-width: 767px) {
  .person {
    margin-bottom: 22.0512820513dvw;
  }
}
.person__header {
  max-width: 1440px;
  margin: 0 auto 72px;
  color: #fff;
}
@media (min-width: 768px) {
  .person__header {
    display: grid;
    gap: 42px;
    grid-template-columns: min(640px, 54.67dvw) auto;
    align-items: center;
    box-sizing: border-box;
    padding-left: 7.152%;
  }
}
@media (max-width: 767px) {
  .person__header {
    margin: 0 auto 9.2307692308dvw;
  }
}
.person__header p {
  font-size: 2.2rem;
  font-weight: bold;
  line-height: 1.6818181818;
}
@media (max-width: 767px) {
  .person__header p {
    text-align: center;
    font-size: 17px;
    font-size: 4.358974359dvw;
    line-height: 1.6470588235;
  }
}
@media (max-width: 767px) {
  .person__ttl {
    margin: 0 auto 4.6153846154dvw;
    width: 73.3333333333dvw;
  }
}

.person-list__item {
  margin: 0 12.5px;
  width: 384px;
  color: #fff;
  text-align: center;
  font-size: 1.5rem;
  font-weight: 500;
}
@media (max-width: 767px) {
  .person-list__item {
    margin: 0 2.5641025641dvw;
    width: 75.3846153846dvw;
  }
}
.person-list__item figure {
  margin-bottom: 20px;
}
@media (max-width: 767px) {
  .person-list__item figure {
    margin-bottom: 2.5641025641dvw;
  }
}
.person-list__item figure img {
  width: 100%;
  aspect-ratio: 383/493;
  object-fit: cover;
}
.person-list__item p {
  width: 79.6875%;
  margin: 0 auto;
  line-height: 1.5333333333;
  min-height: 3em;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  text-align: left;
}
@media (max-width: 767px) {
  .person-list__item p {
    margin: 0 auto;
    width: 100%;
  }
}
.person-list__item .p-item__icons {
  width: 79.6875%;
  margin: 10px auto 0;
  padding-top: 14px;
  display: block;
  border-top: 1px solid rgba(255, 255, 255, 0.3);
  text-align: center;
  line-height: 1;
}
@media (max-width: 767px) {
  .person-list__item .p-item__icons {
    margin: 2.5641025641dvw auto 0;
    padding-top: 3.5897435897dvw;
    width: 100%;
    max-height: fit-content;
    border-top: 1px solid #fff;
  }
}
.person-list__item .p-item__icons .icon {
  background: none !important;
  color: #fff;
  font-size: 15px;
  font-weight: 500;
  padding: 0 3px;
}
@media (max-width: 767px) {
  .person-list__item .p-item__icons .icon {
    padding: 0 2px;
  }
}

.person-bottom {
  width: fit-content;
  margin: 62px auto 0;
  position: relative;
}
@media (max-width: 767px) {
  .person-bottom {
    margin: 5.3846153846dvw auto 0;
  }
}
@media (min-width: 768px) {
  .person-bottom__link {
    position: absolute;
    top: 0;
    bottom: 0;
    left: calc(100% + 22px);
    margin: auto;
    height: fit-content;
  }
}
@media (max-width: 767px) {
  .person-bottom__link {
    margin-top: 9.7435897436dvw;
  }
}
.person-bottom__link a {
  white-space: nowrap;
  color: #fff;
  font-size: 1.3rem;
  font-weight: 400;
  letter-spacing: 0.03em;
  font-family: "anton", sans-serif;
  line-height: 1;
  display: flex;
  align-items: center;
  gap: 8px;
}
@media (max-width: 767px) {
  .person-bottom__link a {
    font-size: 13px;
    font-size: 3.3333333333dvw;
    gap: 1.7948717949dvw;
  }
}
.person-bottom__link a::after {
  width: 10px;
  height: 8px;
  background: url("../images/cmn/icon_arrow.svg") center/contain no-repeat;
  display: block;
  filter: brightness(0) invert(1);
  content: "";
}
@media (max-width: 767px) {
  .person-bottom__link a::after {
    width: 2.5641025641dvw;
    height: 2.0512820513dvw;
  }
}

.person-list-controller {
  display: flex;
  gap: 28px;
}
.person-list-controller .slick-arrow {
  position: relative;
  inset: 0;
  margin: 0;
  width: 67px;
  height: 67px;
  transform: none;
  border-radius: 50%;
  background: #fff;
  transition: 0.3s;
}
.person-list-controller .slick-arrow::before {
  position: absolute;
  inset: 0;
  left: -3px;
  width: 14px;
  height: 14px;
  margin: auto;
  content: "";
  transform: rotate(45deg);
  border-top: 2px solid #1D2088;
  border-right: 2px solid #1D2088;
}
.person-list-controller .slick-arrow.slick-prev {
  transform: scaleX(-1);
}
.person-list-controller .slick-arrow:hover {
  opacity: 0.7;
}
.person-list-controller .slick-dots {
  position: relative;
  inset: 0;
  display: flex !important;
  justify-content: center;
  flex-flow: wrap;
  gap: 2.5641025641dvw;
}
.person-list-controller .slick-dots li,
.person-list-controller .slick-dots button {
  margin: 0;
  padding: 0;
  width: 2.8205128205dvw;
  height: 2.8205128205dvw;
}
.person-list-controller .slick-dots li {
  background-color: #cecece;
}
.person-list-controller .slick-dots li.slick-active {
  background-color: #66c5e2;
}

.special {
  padding-bottom: 348px;
}
@media (max-width: 767px) {
  .special {
    padding-bottom: 36.6666666667dvw;
  }
}
.special__ttl {
  margin-bottom: 78px;
  font-size: min(16rem, 13.34dvw);
  line-height: 1;
  text-align: center;
  font-family: "anton", sans-serif;
  font-weight: 400;
  letter-spacing: 0.03em;
  color: #fff;
}
@media (max-width: 767px) {
  .special__ttl {
    margin-bottom: 7.1794871795dvw;
    font-size: 83px;
    font-size: 21.2820512821dvw;
    line-height: 1.0481927711;
  }
}

.number {
  margin-bottom: 109px;
  position: relative;
}
@media (max-width: 767px) {
  .number {
    margin-bottom: 11.2820512821dvw;
  }
}
.number__ttl {
  color: #fff;
  font-weight: bold;
}
@media (min-width: 768px) {
  .number__ttl {
    height: fit-content;
    width: fit-content;
    position: absolute;
    inset: 0;
    margin: auto;
    z-index: 3;
    font-size: 3rem;
    line-height: 1;
    padding: 0.3em 0.75em;
    background-color: #1D2088;
    pointer-events: none;
  }
}
@media (max-width: 767px) {
  .number__ttl {
    margin-bottom: 4.1025641026dvw;
    text-align: center;
    font-size: 18px;
    font-size: 4.6153846154dvw;
  }
}
.number a {
  max-width: 1800px;
  margin: 0 auto;
  display: grid;
}
@media (min-width: 768px) {
  .number a {
    width: 94%;
    grid-template-columns: 1fr 1fr;
  }
}
.number a > div {
  position: relative;
}
.number a > div img:nth-of-type(1) {
  position: relative;
  z-index: 2;
  animation: fadeIn 10s infinite;
}
@keyframes fadeIn {
  0% {
    opacity: 1;
  }
  40% {
    opacity: 1;
  }
  50% {
    opacity: 0;
  }
  90% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.number a > div img:nth-of-type(2) {
  position: absolute;
  z-index: 1;
  inset: 0;
}
.number a > div:nth-of-type(2) img:nth-of-type(1) {
  animation-delay: 4s;
}
@media (max-width: 767px) {
  .number a > div:nth-of-type(3) {
    display: none;
  }
}
.number a > div:nth-of-type(3) img:nth-of-type(1) {
  animation-delay: 6s;
}
.number a > div:nth-of-type(4) img:nth-of-type(1) {
  animation-delay: 2s;
}

.education {
  max-width: 1800px;
  margin: 0 auto;
  position: relative;
}
@media (min-width: 768px) {
  .education {
    width: 94%;
  }
}
.education a {
  display: block;
  position: relative;
}
.education a::before, .education a::after {
  position: absolute;
  right: 22px;
  bottom: 16px;
  display: block;
  content: "";
}
@media (max-width: 767px) {
  .education a::before, .education a::after {
    right: 2.5641025641dvw;
    bottom: 2.3076923077dvw;
  }
}
.education a::before {
  width: 21px;
  height: 21px;
  background-color: #fff;
  border-radius: 50%;
}
@media (max-width: 767px) {
  .education a::before {
    width: 4.1025641026dvw;
    height: 4.1025641026dvw;
  }
}
.education a::after {
  right: 29px;
  bottom: 22px;
  width: 5px;
  height: 6px;
  background-color: #1D2088;
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
}
@media (max-width: 767px) {
  .education a::after {
    right: 3.8461538462dvw;
    bottom: 3.5897435897dvw;
    width: 1.2820512821dvw;
    height: 1.5384615385dvw;
  }
}
@media (min-width: 768px) {
  .education figure {
    width: 100%;
    aspect-ratio: 1352/434;
    height: 434px;
  }
}
@media (min-width: 768px) {
  .education figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top left;
  }
}
.education__txt {
  position: absolute;
  z-index: 2;
  left: 56px;
}
@media (min-width: 768px) {
  .education__txt {
    top: 58px;
  }
}
@media (max-width: 767px) {
  .education__txt {
    left: 4.358974359dvw;
    bottom: 3.5897435897dvw;
  }
}
.education__txt p {
  font-size: 1.8rem;
  font-weight: bold;
  line-height: 1.9444444444;
}
@media (max-width: 767px) {
  .education__txt p {
    font-weight: 500;
    font-size: 16px;
    font-size: 4.1025641026dvw;
  }
}
.education__txt p span {
  background-color: #fff;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
  padding: 0.25em 0.5em;
}
@media (max-width: 767px) {
  .education__txt p span {
    padding: 0.2em;
  }
}
.education__ttl {
  margin-bottom: 18px;
  color: #fff;
  font-size: 3rem;
  font-weight: bold;
}
@media (max-width: 767px) {
  .education__ttl {
    margin-bottom: 2.5641025641dvw;
    font-size: 18px;
    font-size: 4.6153846154dvw;
  }
}
.education__ttl span {
  background-color: #1D2088;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
  padding: 0.25em 0.6em;
}
@media (max-width: 767px) {
  .education__ttl span {
    padding: 0.25em 0.35em;
  }
}

.other {
  z-index: 2;
  padding: 140px 0 50px;
  position: relative;
  background-color: #000;
}
@media (max-width: 767px) {
  .other {
    padding: 7.9487179487dvw 0 12.8205128205dvw;
  }
}
.other__ttl {
  text-align: center;
  font-family: "anton", sans-serif;
  color: #fff;
  line-height: 1;
  font-size: min(16rem, 13.34dvw);
  font-weight: 400;
  letter-spacing: 0.03em;
  margin: auto;
}
@media (min-width: 768px) {
  .other__ttl {
    position: absolute;
    top: -0.62em;
    left: 0;
    right: 0;
  }
}
@media (max-width: 767px) {
  .other__ttl {
    margin: 0 auto 11.2820512821dvw;
    font-size: 76px;
    font-size: 19.4871794872dvw;
    line-height: 1.0526315789;
  }
}

.other-list {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  gap: 26px;
}
@media (min-width: 768px) {
  .other-list {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 767px) {
  .other-list {
    gap: 10.2564102564dvw;
    margin: 0 5.1282051282dvw;
  }
}
@media (max-width: 767px) {
  .other-list img {
    margin-bottom: 4.6153846154dvw;
  }
}
.other-list p {
  color: #fff;
}
@media (min-width: 768px) {
  .other-list p {
    display: none;
  }
}
@media (max-width: 767px) {
  .other-list p {
    font-size: 16px;
    font-size: 4.1025641026dvw;
    font-weight: 500;
    line-height: 1.75;
  }
}

.voice {
  padding: 28px 0 92px;
  background-color: #000;
}
@media (max-width: 767px) {
  .voice {
    padding: 14.8717948718dvw 0 17.1794871795dvw;
  }
}
.voice__ttl {
  margin-bottom: 35px;
  text-align: center;
  color: #fff;
  line-height: 1;
  font-size: 1.5rem;
  font-weight: 500;
}
@media (max-width: 767px) {
  .voice__ttl {
    margin-bottom: 9.7435897436dvw;
    font-size: 15px;
    font-size: 3.8461538462dvw;
  }
}
.voice__ttl span {
  margin-bottom: 17px;
  display: block;
  font-size: 8.1rem;
  letter-spacing: 0.03em;
  font-weight: 400;
  font-family: "anton", sans-serif;
}
@media (max-width: 767px) {
  .voice__ttl span {
    margin-bottom: 4.8717948718dvw;
    font-size: 81px;
    font-size: 20.7692307692dvw;
  }
}

.voice-list {
  max-width: 1200px;
  margin: 0 auto 58px;
  color: #fff;
}
@media (min-width: 768px) {
  .voice-list {
    display: grid;
    gap: 60px;
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: 767px) {
  .voice-list {
    margin: 0 auto 11.0256410256dvw;
  }
}
@media (max-width: 767px) {
  .voice-list__item {
    margin: 0 5.1282051282dvw;
  }
}
.voice-list__item figure {
  margin-bottom: 24px;
  aspect-ratio: 360/232;
  overflow: hidden;
}
@media (max-width: 767px) {
  .voice-list__item figure {
    margin-bottom: 6.1538461538dvw;
  }
}
.voice-list__item figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.voice-list__item ul {
  margin-bottom: 10px;
  display: flex;
  flex-flow: wrap;
  gap: 1em 0.5em;
  line-height: 1;
  font-size: 1.5rem;
}
@media (max-width: 767px) {
  .voice-list__item ul {
    font-size: 15px;
    font-size: 3.8461538462dvw;
    margin-bottom: 2.5641025641dvw;
  }
}
.voice-list__item ul li {
  font-size: 14px;
  color: #fff !important;
}
.voice-list__item p {
  margin-bottom: 20px;
  font-size: 1.5rem;
  line-height: 1.4666666667;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}
@media (max-width: 767px) {
  .voice-list__item p {
    font-size: 15px;
    font-size: 3.8461538462dvw;
    margin-bottom: 3.3333333333dvw;
  }
}
.voice-list__item time {
  line-height: 1;
  display: block;
  font-size: 1.3rem;
  letter-spacing: 0.03em;
}
@media (max-width: 767px) {
  .voice-list__item time {
    font-size: 13px;
    font-size: 3.3333333333dvw;
  }
}
.voice-list .slick-dots {
  position: relative;
  inset: 0;
  display: flex !important;
  justify-content: center;
  flex-flow: wrap;
  margin-top: 8.7179487179dvw !important;
  gap: 2.5641025641dvw;
}
.voice-list .slick-dots li,
.voice-list .slick-dots button {
  margin: 0;
  padding: 0;
  width: 2.8205128205dvw;
  height: 2.8205128205dvw;
}
.voice-list .slick-dots li {
  background-color: #cecece;
}
.voice-list .slick-dots li.slick-active {
  background-color: #66c5e2;
}

.voice-btn a {
  margin: 0 auto;
  display: grid;
  place-content: center;
  width: fit-content;
  min-width: 159px;
  min-height: 45px;
  font-family: "anton", sans-serif;
  font-size: 1.3rem;
  font-weight: 400;
  letter-spacing: 0.03em;
  box-sizing: border-box;
  color: #fff;
  border: 1px solid #fff;
  position: relative;
  padding-bottom: 5px;
}
.voice-btn a::before {
  position: absolute;
  top: 0;
  right: 13px;
  bottom: 0;
  width: 10px;
  height: 8px;
  background: url("../images/cmn/icon_arrow.svg") center/contain no-repeat;
  display: block;
  margin: auto;
  content: "";
  filter: brightness(0) invert(1);
}
@media (max-width: 767px) {
  .voice-btn a::before {
    right: 4.6153846154dvw;
    width: 3.5897435897dvw;
    height: 3.0769230769dvw;
  }
}

.partner {
  padding: 67px 0 86px;
  background-color: rgba(255, 255, 255, 0.91);
}
@media (max-width: 767px) {
  .partner {
    padding: 12.0512820513dvw 5.1282051282dvw 16.4102564103dvw;
  }
}
.partner__header {
  margin-bottom: 46px;
}
@media (max-width: 767px) {
  .partner__header {
    margin-bottom: 9.2307692308dvw;
  }
}
.partner__header p {
  font-size: 1.5rem;
  line-height: 1.7333333333;
}
@media (min-width: 768px) {
  .partner__header p {
    text-align: center;
  }
}
@media (max-width: 767px) {
  .partner__header p {
    font-size: 15px;
    font-size: 3.8461538462dvw;
    line-height: 1.8;
  }
}
.partner__ttl {
  margin-bottom: 18px;
  text-align: center;
  line-height: 1.4545454545;
  font-size: 3.3rem;
  font-weight: bold;
}
@media (max-width: 767px) {
  .partner__ttl {
    margin-bottom: 4.1025641026dvw;
    font-size: 22px;
    font-size: 5.641025641dvw;
  }
}

.partner-box {
  max-width: 1200px;
  margin: 0 auto;
  box-sizing: border-box;
  border: 1px solid #2f2f2f;
}
.partner-box__ttl {
  min-height: 62px;
  display: grid;
  place-content: center;
  background-color: #1D2088;
  color: #fff;
  font-size: 1.8rem;
  font-weight: bold;
}
@media (max-width: 767px) {
  .partner-box__ttl {
    min-height: 11.5384615385dvw;
    font-size: 17px;
    font-size: 4.358974359dvw;
  }
}
.partner-box__wrap {
  padding: 31px 24px 35px 50px;
  background-color: #fff;
}
@media (min-width: 768px) {
  .partner-box__wrap {
    display: grid;
    grid-template-columns: auto auto auto;
  }
}
@media (max-width: 767px) {
  .partner-box__wrap {
    padding: 5.8974358974dvw 6.6666666667dvw;
    height: 139.2307692308dvw;
    overflow-y: scroll;
  }
}

@media (min-width: 768px) {
  .partner-list:not(:first-child) {
    padding-left: 44px;
    margin-left: 44px;
    border-left: 1px solid #afafaf;
  }
}
.partner-list__ttl {
  margin-bottom: 0.8em;
  font-weight: bold;
  color: #1D2088;
  font-size: 1.6rem;
}
@media (max-width: 767px) {
  .partner-list__ttl {
    margin-bottom: 0.3em;
    font-size: 16px;
    font-size: 4.1025641026dvw;
  }
}
.partner-list__ttl:not(:first-child) {
  margin-top: 2em;
}
.partner-list ul {
  display: grid;
  gap: 0.24em;
}
@media (max-width: 767px) {
  .partner-list ul {
    gap: 0.1em;
  }
}
.partner-list li {
  line-height: 1.5;
  font-size: 1.5rem;
  font-weight: 500;
}
@media (max-width: 767px) {
  .partner-list li {
    font-size: 15px;
    font-size: 3.8461538462dvw;
  }
}

.recruitment {
  padding: 67px 20px 184px;
}
@media (max-width: 767px) {
  .recruitment {
    padding: 21.7948717949dvw 5.1282051282dvw 35.8974358974dvw;
  }
}
.recruitment__ttl {
  margin-bottom: 20px;
  text-align: center;
  color: #fff;
  font-size: 1.6rem;
  font-weight: 500;
}
@media (max-width: 767px) {
  .recruitment__ttl {
    margin-bottom: 7.6923076923dvw;
    font-size: 16px;
    font-size: 4.1025641026dvw;
  }
}
.recruitment__ttl span {
  margin-bottom: 16px;
  display: block;
  font-size: 9rem;
  font-weight: 400;
  letter-spacing: 0.03em;
  font-family: "anton", sans-serif;
  line-height: 1;
}
@media (max-width: 767px) {
  .recruitment__ttl span {
    font-size: 60px;
    font-size: 15.3846153846dvw;
  }
}
.recruitment ul {
  margin: 0 auto;
  max-width: 1200px;
  display: grid;
  gap: 15px;
}
@media (min-width: 768px) {
  .recruitment ul {
    grid-template-columns: repeat(4, 1fr);
  }
}
@media (max-width: 767px) {
  .recruitment ul {
    gap: 4.6153846154dvw;
  }
}
.recruitment a {
  display: grid;
  place-content: center;
  background-color: #fff;
  min-height: 68px;
  font-size: 1.6rem;
  font-weight: 500;
  position: relative;
}
.recruitment a::before, .recruitment a::after {
  position: absolute;
  top: 0;
  right: 16px;
  bottom: 0;
  margin: auto;
  display: block;
  content: "";
}
.recruitment a::before {
  width: 17px;
  height: 17px;
  background-color: #1D2088;
  border-radius: 50%;
}
.recruitment a::after {
  right: 21px;
  width: 5px;
  height: 6px;
  background-color: #fff;
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
}

.movie {
  background-color: #000;
  color: #fff;
  padding: 0 20px;
  overflow-x: clip;
}
@media (max-width: 767px) {
  .movie {
    padding: 0 5.1282051282dvw 19.7435897436dvw;
  }
}
.movie__wrap {
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
}
@media (min-width: 768px) {
  .movie__wrap {
    padding: 126px 0 105px;
  }
}
.movie__ttl {
  max-width: 651px;
}
@media (min-width: 768px) {
  .movie__ttl {
    position: absolute;
    top: -83px;
    left: 0;
  }
}
@media (max-width: 767px) {
  .movie__ttl {
    margin: 0 auto -4.8717948718dvw;
    position: relative;
    top: -11.2820512821dvw;
    max-width: 64.1025641026dvw;
  }
}
.movie__col {
  position: relative;
  z-index: 2;
}
@media (min-width: 768px) {
  .movie__col {
    display: grid;
    gap: 3%;
    grid-template-columns: auto 68.34%;
  }
}
@media (min-width: 768px) {
  .movie__txt {
    margin-left: -12px;
    padding-top: 66px;
  }
}
@media (max-width: 767px) {
  .movie__txt {
    margin-bottom: 8.4615384615dvw;
  }
}
.movie__txt p {
  font-size: 1.5rem;
  line-height: 2.2;
}
.movie__subttl {
  margin-bottom: 26px;
  font-size: 2.4rem;
  font-weight: bold;
}
@media (max-width: 767px) {
  .movie__subttl {
    margin-bottom: 2.3076923077dvw;
    text-align: center;
    font-size: 22px;
    font-size: 5.641025641dvw;
  }
}
.movie__iframe {
  border: 2px solid #BFBFBF;
}
@media (min-width: 768px) {
  .movie__iframe {
    position: relative;
  }
}
.movie__iframe iframe {
  display: grid;
}
.movie__area {
  display: flex;
  gap: 2rem;
}
@media (max-width: 767px) {
  .movie__area {
    gap: 5vw;
    flex-wrap: wrap;
    justify-content: center;
  }
}
.movie__item:last-child {
  display: none;
}
.movie__text {
  text-align: center;
  font-weight: 500;
  margin-top: 10px;
}

.l-other-cmn {
  display: none !important;
}

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