@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: "termina", sans-serif;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1;
}

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

.yakuhan {
  font-family: "YakuHanJP", "source-han-sans-japanese", sans-serif;
}

/* mobile */
.mv {
  position: relative;
  box-sizing: border-box;
  padding: 85px 0 98px;
  background: #000 url("../images/top/bg_mv.png") center top/cover no-repeat;
}
@media (min-width: 768px) {
  .mv {
    aspect-ratio: 1440/730;
  }
  .mv::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 50%;
    display: block;
    width: 1440px;
    height: 100%;
    margin: 0 auto;
    background: url("../images/top/bg_mv_line.png") center top/cover no-repeat;
    transform: translateX(-50%);
  }
}
@media (max-width: 767px) {
  .mv {
    padding: 14.8717948718dvw 0 0;
    min-height: 158.9743589744dvw;
    background: #000 url("../images/top/sp/bg_mv.png") center top/cover no-repeat;
  }
}
@media (min-width: 1441px) {
  .mv {
    min-height: 50.6944444444vw;
    padding: 5.9027777778dvw 0 6.8055555556dvw;
  }
  .mv::before {
    left: 0;
    width: 100%;
    margin: 0;
    transform: none;
  }
}
.mv__txt {
  position: relative;
}
@media (min-width: 768px) {
  .mv__txt {
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 0 0 min(28px, 1.9444444444dvw);
    position: absolute;
    bottom: calc(79px + 2.8%);
  }
}
.mv__txt picture {
  display: block;
}
.mv__txt picture:nth-of-type(1) {
  margin-bottom: min(20px, 1.3888888889dvw);
}
@media (max-width: 767px) {
  .mv__txt picture:nth-of-type(1) {
    position: absolute;
    top: 0;
    left: 38.4615384615dvw;
    width: 17.9487179487dvw;
  }
}
.mv__txt picture:nth-of-type(2) {
  position: relative;
  z-index: 30;
}
@media (max-width: 767px) {
  .mv__txt picture:nth-of-type(2) {
    position: absolute;
    top: 0;
    left: 2.8205128205dvw;
    width: 76.9230769231dvw;
  }
}
@media (min-width: 1441px) {
  .mv__txt {
    max-width: none;
    width: 100%;
    margin: 0;
    padding: 0 0 0 1.9444444444dvw;
  }
  .mv__txt picture img {
    width: 100%;
  }
  .mv__txt picture:nth-of-type(1) {
    width: 41.3%;
    margin-bottom: 1.3888888889dvw;
  }
  .mv__txt picture:nth-of-type(2) {
    width: 95.31%;
  }
}

.mv-staff {
  position: absolute;
  inset: 0;
  max-width: 1440px;
  margin: auto;
}
@media (min-width: 1441px) {
  .mv-staff {
    max-width: none;
    width: 100%;
    margin: 0;
  }
}
.mv-staff__item {
  position: absolute;
  opacity: 0;
  animation: mvStaffSwitch 24s infinite;
  animation-timing-function: ease-in-out;
  will-change: opacity;
}
.mv-staff__item--phase01 {
  animation-delay: calc(-1 * var(--mv-slot-shift, 0s));
}
.mv-staff__item--phase02 {
  animation-delay: calc(-8s - var(--mv-slot-shift, 0s));
}
.mv-staff__item--phase03 {
  animation-delay: calc(-16s - var(--mv-slot-shift, 0s));
}
.mv-staff__item--01 {
  --mv-slot-shift: 0s;
  right: 32.6%;
  width: 38.75%;
}
@media (min-width: 1441px) {
  .mv-staff__item--01 {
    right: 27.8472222222dvw;
    width: 41.4583333333dvw;
  }
}
@media (min-width: 768px) {
  .mv-staff__item--01 {
    bottom: 0;
  }
}
@media (max-width: 767px) {
  .mv-staff__item--01 {
    right: 0;
    width: 76.92vw;
    bottom: 0;
  }
}
.mv-staff__item--02 {
  --mv-slot-shift: 2s;
  right: 13.3%;
  bottom: 0;
  width: 38.75%;
}
@media (max-width: 767px) {
  .mv-staff__item--02 {
    right: 0;
    width: 76.92vw;
  }
}
.mv-staff__item--03 {
  --mv-slot-shift: 4s;
  bottom: 0;
  width: 38.75%;
}
@media (min-width: 768px) {
  .mv-staff__item--03 {
    right: 0%;
  }
}
@media (max-width: 767px) {
  .mv-staff__item--03 {
    right: 0;
    width: 63.08vw;
  }
}

@keyframes mvStaffSwitch {
  0% {
    opacity: 0;
  }
  6%, 30% {
    opacity: 1;
  }
  36%, 100% {
    opacity: 0;
  }
}
.news {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  margin: 0 auto;
  border-top: 2px solid #fff;
  border-bottom: 2px solid #fff;
  color: #fff;
}
@media (max-width: 767px) {
  .news {
    border-top: 0.5128205128dvw solid #fff;
    border-bottom: 0.5128205128dvw solid #fff;
  }
}
.news::before {
  content: "";
  position: absolute;
  display: block;
  width: 100%;
  height: 100%;
  margin: auto;
  background: rgba(8, 19, 77, 0.3);
  inset: 0;
  mix-blend-mode: multiply;
}
.news__item {
  position: relative;
  display: grid;
  align-items: center;
  grid-template-columns: 216px auto;
  box-sizing: border-box;
  width: 100%;
  height: 76px;
}
@media (min-width: 768px) {
  .news__item {
    max-width: 1440px;
    margin: 0 auto;
  }
}
@media (max-width: 767px) {
  .news__item {
    grid-template-columns: 28.2051282051dvw auto;
    height: 15.3846153846dvw;
  }
}
.news a {
  display: block;
  height: 100%;
}
.news__ttl-link {
  display: flex;
  align-items: center;
  justify-content: center;
}
.news__txt-link {
  display: flex;
  align-items: center;
}
.news__ttl {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
  font-family: "termina", sans-serif;
  font-size: 2.4rem;
  font-weight: bold;
}
@media (min-width: 768px) {
  .news__ttl {
    border-right: 2px solid #fff;
  }
}
@media (max-width: 767px) {
  .news__ttl {
    font-size: 22px;
    font-size: 5.641025641dvw;
  }
}
.news p {
  display: -webkit-box;
  overflow: hidden;
  font-size: 1.6rem;
  font-weight: bold;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  line-clamp: 1;
}
@media (min-width: 768px) {
  .news p {
    padding: 24px 38px;
  }
}
@media (max-width: 767px) {
  .news p {
    font-size: 15px;
    font-size: 3.8461538462dvw;
    line-height: 1.3333333333;
    padding: 5vw 0;
  }
}

.intro {
  box-sizing: border-box;
  min-height: 1036px;
  padding: 102px 40px 169px;
  background: #000 url("../images/cmn/bg_blue.png") repeat;
  background-size: contain;
}
@media (max-width: 767px) {
  .intro {
    padding: 24.358974359dvw 5.1282051282dvw 29.7435897436dvw;
  }
}
.intro__wrap {
  display: grid;
  margin: 0 auto;
}
@media (min-width: 768px) {
  .intro__wrap {
    justify-content: space-between;
    gap: 40px;
    grid-template-columns: auto auto;
    max-width: 1200px;
  }
}
@media (max-width: 767px) {
  .intro__ttl {
    margin: 0 auto 11.5384615385dvw;
    width: 77.9487179487dvw;
  }
}
@media (min-width: 768px) {
  .intro__txt {
    order: -1;
    padding-top: 73px;
  }
}
.intro__txt p {
  color: #fff;
  font-size: 2.2rem;
  font-weight: bold;
  line-height: 2;
}
@media (max-width: 767px) {
  .intro__txt p {
    font-size: 18px;
    font-size: 4.6153846154dvw;
  }
}
.intro__txt p span {
  margin-top: 12px;
  font-size: 2.8rem;
  display: inline-block;
  line-height: 1.2;
  font-weight: 900;
}
@media (max-width: 767px) {
  .intro__txt p span {
    margin: 2.0512820513dvw 0 0;
    font-size: 5.3vw;
  }
}
.intro__txt p span mark {
  display: inline-block;
  padding: 2.5px 8.6px;
  margin-bottom: 8px;
  background-color: #fff;
  color: #08134d;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}
@media (max-width: 767px) {
  .intro__txt p span mark {
    margin-bottom: 1.3vw;
    padding: 1.2vw 1.5vw;
    line-height: 1;
  }
}
.intro__txt p b {
  display: inline-block;
  margin-top: 0.5em;
  font-size: 6.6rem;
  font-weight: 900;
  line-height: 1.2727272727;
}
@media (max-width: 767px) {
  .intro__txt p b {
    font-size: 35px;
    font-size: 8.9743589744dvw;
    line-height: 1.2857142857;
  }
}

.movie {
  position: relative;
  box-sizing: border-box;
  background: #000 url("../images/cmn/bg_gray.png") repeat;
  background-size: contain;
}
@media (min-width: 768px) {
  .movie {
    min-height: 736px;
    padding: 120px 40px;
  }
  .movie::before {
    content: "";
    position: absolute;
    top: 30px;
    left: 50%;
    z-index: 1;
    display: block;
    width: 1462px;
    height: 698px;
    margin: auto;
    background: url("../images/top/bg_movie.png") center/contain no-repeat;
    background-size: contain;
    transform: translateX(-50%);
    mix-blend-mode: soft-light;
  }
}
@media (max-width: 767px) {
  .movie {
    padding-top: 12.8205128205dvw;
    height: 72.0512820513dvw;
    background: #000 url("../images/top/sp/bg_movie.png") center/cover no-repeat;
  }
}
.movie__wrap {
  position: relative;
  z-index: 2;
  max-width: 880px;
  margin: 0 auto;
  aspect-ratio: 880/495;
}
@media (max-width: 767px) {
  .movie__wrap {
    max-width: 84.6153846154dvw;
    aspect-ratio: 330/186;
  }
}
.movie__wrap iframe {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

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

mv-slide-txt

------------------------------------ */
.movie-en-01 {
  overflow-x: clip;
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  box-sizing: border-box;
  height: clamp(26px, 6.92vw, 119.36px);
  position: absolute;
  mix-blend-mode: difference;
  top: -19%;
  left: 50%;
  transform: translate(-50%, -50%);
  rotate: -12deg;
  width: 100%;
  gap: 40px;
}
@media (max-width: 767px) {
  .movie-en-01 {
    rotate: -15deg;
    gap: 3vw;
  }
}
.movie-en-01 > div {
  flex: 0 0 auto;
  height: fit-content;
  animation: slideWhiteRtl 60s infinite linear;
  display: flex;
  align-items: center;
  white-space: nowrap;
  position: relative;
  transform: translateX(-100%);
}
@keyframes slideWhiteRtl {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(-100%);
  }
}
.movie-en-01 > div img {
  margin: 0 0.5rem;
  width: 2681.76px;
  max-width: none;
}
@media (max-width: 767px) {
  .movie-en-01 > div img {
    width: 214.88vw;
  }
}

.movie-en-02 {
  overflow-x: clip;
  display: flex;
  align-items: center;
  box-sizing: border-box;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  transform: translateY(-50%);
  z-index: 4;
  width: 100%;
  gap: 40px;
}
@media (max-width: 767px) {
  .movie-en-02 {
    gap: 3vw;
  }
}
.movie-en-02 > div {
  flex: 0;
  height: fit-content;
  animation: slideOutlineLtr 40s infinite linear;
  display: flex;
  align-items: center;
  white-space: nowrap;
  transform: translateX(-100%);
}
.movie-en-02 img {
  width: 1716px;
  max-width: none;
}
@media (max-width: 767px) {
  .movie-en-02 > div {
    animation-name: slideOutlineLtrSp;
  }
  .movie-en-02 img {
    width: 158.2051282051dvw;
  }
}

@keyframes slideOutlineLtr {
  0% {
    transform: translateX(-100%);
  }
  100% {
    transform: translateX(0%);
  }
}
@keyframes slideOutlineLtrSp {
  0% {
    transform: translateX(-100%);
  }
  100% {
    transform: translateX(0%);
  }
}
.revolution.revolution-0 {
  padding: 135px 20px 140px;
  background: #000 url("../images/cmn/bg_black.png") repeat;
  background-size: contain;
}
@media (max-width: 767px) {
  .revolution.revolution-0 {
    padding: 24.8717948718dvw 5.1282051282dvw 25.641025641dvw;
  }
}
.revolution.revolution-1 {
  padding: 138px 20px 40px;
  background: #000 url("../images/cmn/bg_blue.png") repeat;
  background-size: contain;
}
@media (max-width: 767px) {
  .revolution.revolution-1 {
    padding: 27.1794871795dvw 5.1282051282dvw 25.641025641dvw;
  }
}
.revolution.revolution-2 {
  padding: 130px 20px 143px;
  background: #000 url("../images/cmn/bg_black.png") repeat;
  background-size: contain;
}
@media (max-width: 767px) {
  .revolution.revolution-2 {
    padding: 22.3076923077dvw 5.1282051282dvw 25.641025641dvw;
  }
}
.revolution.revolution-3 {
  padding: 78px 20px 120px;
  background: #000 url("../images/cmn/bg_gray.png") repeat;
  background-size: contain;
}
@media (max-width: 767px) {
  .revolution.revolution-3 {
    padding: 19.2307692308dvw 5.1282051282dvw 20.5128205128dvw;
  }
}
.revolution.revolution-4 {
  padding: 100px 0;
  background: #000 url("../images/cmn/bg_blue.png") repeat;
  background-size: contain;
}
@media (max-width: 767px) {
  .revolution.revolution-4 {
    padding: 18.9743589744dvw 5.1282051282dvw 15.3846153846dvw;
  }
}
.revolution__wrap {
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
}
@media (min-width: 768px) {
  .revolution__wrap {
    box-sizing: content-box;
  }
  .revolution-0 .revolution__wrap, .revolution-2 .revolution__wrap {
    display: grid;
    justify-content: flex-end;
  }
}

@media (min-width: 768px) {
  .revolution-ttl {
    height: 100%;
    top: 0;
    position: absolute;
  }
  .revolution-0 .revolution-ttl {
    left: 0;
  }
  .revolution-1 .revolution-ttl {
    right: 0;
  }
}
@media (max-width: 767px) {
  .revolution-ttl {
    margin-bottom: 16.4102564103dvw;
  }
}
.revolution-ttl picture {
  display: block;
}
@media (min-width: 768px) {
  .revolution-ttl picture {
    position: sticky;
    top: 70px;
    left: 0;
  }
}
@media (min-width: 768px) {
  .revolution-ttl img {
    width: min(403px, 27.9861111111dvw);
  }
}

.revolution-contents {
  color: #fff;
}
@media (min-width: 768px) {
  .revolution-0 .revolution-contents {
    padding-left: min(430px, 29.8611111111dvw);
  }
  .revolution-1 .revolution-contents {
    padding-right: min(430px, 29.8611111111dvw);
  }
  .revolution-2 .revolution-contents {
    padding-left: min(517px, 35.9027777778dvw);
  }
}

@media (min-width: 768px) {
  .revolution-catch:has(+ a) {
    margin-bottom: 32px;
  }
  .education .revolution-catch {
    margin-left: auto;
    margin-right: 30px;
  }
  .personality .revolution-catch {
    margin-bottom: 27px;
  }
}
@media (max-width: 767px) {
  .revolution-catch {
    margin-bottom: 6.4102564103dvw;
  }
}

.revolution-item {
  display: flex;
  flex-flow: column;
}
@media (max-width: 767px) {
  .revolution-item:not(:last-child) {
    margin-bottom: 17.9487179487dvw;
  }
}
.revolution-item a {
  display: block;
  width: fit-content;
}
@media (min-width: 768px) {
  .revolution-item.message {
    margin-bottom: 133px;
  }
  .revolution-item.message a {
    margin-left: auto;
  }
}
@media (min-width: 768px) {
  .revolution-item.vision {
    flex-flow: row-reverse;
    gap: 0 30px;
  }
  .revolution-item.vision a {
    margin-top: 64px;
  }
}
@media (min-width: 768px) {
  .revolution-item.reason {
    margin-bottom: 100px;
  }
}
@media (min-width: 768px) {
  .revolution-item.number {
    flex-flow: row;
    gap: 0 20px;
  }
  .revolution-item.number a {
    margin-top: 43px;
  }
}
@media (min-width: 768px) {
  .revolution-item.education {
    margin-bottom: 110px;
  }
  .revolution-item.education a {
    margin-left: auto;
  }
}
@media (min-width: 768px) {
  .revolution-item.executive {
    flex-flow: row-reverse;
    gap: 0 20px;
  }
}
.revolution-item.personality {
  padding-bottom: 116px;
  border-bottom: 2px solid #181818;
}
@media (max-width: 767px) {
  .revolution-item.personality {
    padding-bottom: 15.3846153846dvw;
    border-bottom: 0.5128205128dvw solid #181818;
  }
}
.revolution-item__ttl {
  position: relative;
  z-index: 2;
  color: #002aff;
  font-family: "termina", sans-serif;
  font-size: 6rem;
  font-weight: bold;
  text-box: trim-both cap alphabetic;
  line-height: 1;
}
@media (min-width: 768px) {
  .revolution-item__ttl {
    padding-left: 5px;
  }
  .revolution-item__ttl:has(+ .revolution-item__txt) {
    margin-bottom: 26px;
  }
  .revolution-item__ttl:has(+ .revolution-item__img) {
    margin-bottom: -15px;
  }
  .personality .revolution-item__ttl {
    margin-bottom: -60px;
  }
}
@media (max-width: 767px) {
  .revolution-item__ttl {
    font-size: 50px;
    font-size: 12.8205128205dvw;
  }
  .revolution-item__ttl:has(+ .revolution-item__txt) {
    margin-bottom: 3.3333333333dvw;
  }
  .revolution-item__ttl:has(+ .revolution-item__img) {
    margin-bottom: -3.8461538462dvw;
  }
}
.revolution-item__ttl--right {
  text-align: right;
}
.revolution-item__ttl--right span {
  margin-left: auto;
}
@media (max-width: 767px) {
  .number .revolution-item__ttl {
    font-size: 44px;
    font-size: 11.2820512821dvw;
  }
}
@media (max-width: 767px) {
  .executive .revolution-item__ttl {
    font-size: 42px;
    font-size: 10.7692307692dvw;
  }
}
.personality .revolution-item__ttl {
  color: #181818;
}
@media (max-width: 767px) {
  .personality .revolution-item__ttl {
    font-size: 35px;
    font-size: 8.9743589744dvw;
  }
}
.revolution-item__ttl__en {
  margin-left: -0.1em;
}
.revolution-item__ttl__jp {
  display: inline-block;
  background-color: #002aff;
  font-family: "source-han-sans-japanese", sans-serif;
  color: #fff;
  font-size: 1.8rem;
  padding: 0.41em 0.28em;
  vertical-align: 0.34em;
  text-box: trim-both cap alphabetic;
}
@media (max-width: 767px) {
  .revolution-item__ttl__jp {
    font-size: 15px;
    font-size: 3.8461538462dvw;
  }
}
.personality .revolution-item__ttl__jp {
  background-color: #181818;
}
br + .revolution-item__ttl__jp {
  display: block;
  width: fit-content;
}
@media (min-width: 768px) {
  .revolution-item__img {
    max-width: 525px;
  }
  .revolution-item__img:has(+ .revolution-item__ttl) {
    margin-bottom: -22px;
  }
  .revolution-item__img:has(+ .revolution-item__txt) {
    margin-bottom: 30px;
  }
  .revolution-item__img:has(+ .revolution-catch) {
    margin-bottom: -25px;
  }
}
@media (max-width: 767px) {
  .revolution-item__img {
    margin-bottom: 5.1282051282dvw;
  }
  .revolution-item__img:has(+ .revolution-item__ttl) {
    margin-bottom: -5.1282051282dvw;
  }
}
@media (min-width: 768px) {
  .personality .revolution-item__img {
    max-width: min(880px, 73.3333333333dvw);
  }
}
@media (max-width: 767px) {
  .personality .revolution-item__img {
    margin-left: -5.1282051282dvw;
  }
}
.revolution-item__txt {
  position: relative;
  box-sizing: border-box;
}
@media (min-width: 768px) {
  .revolution-item__txt {
    padding-right: 80px;
  }
  .executive .revolution-item__txt {
    margin-right: -50px;
  }
}
.revolution-item__txt p {
  font-size: 1.8rem;
  font-weight: bold;
  line-height: 1.7777777778;
}
@media (max-width: 767px) {
  .revolution-item__txt p {
    font-size: 15px;
    font-size: 3.8461538462dvw;
    line-height: 1.8;
  }
}
.revolution-item__icon {
  position: absolute;
  bottom: 0;
  right: 0;
  margin: auto;
  width: 60px;
  height: 60px;
  box-sizing: border-box;
  border: 2px solid #fff;
  display: grid;
  place-content: center;
}
@media (max-width: 767px) {
  .revolution-item__icon {
    width: 12.8205128205dvw;
    height: 12.8205128205dvw;
    border: 0.5128205128dvw solid #fff;
  }
}
.personality .revolution-item__icon {
  border-color: #181818;
}
.revolution-item__icon img {
  width: 21px;
  filter: brightness(0) invert(1);
}
@media (max-width: 767px) {
  .revolution-item__icon img {
    width: 5.3846153846dvw;
  }
}
.personality .revolution-item__icon img {
  filter: none;
}

.revolution-3__ttl {
  margin: 0 -30px -143px auto;
  width: fit-content;
}
@media (max-width: 767px) {
  .revolution-3__ttl {
    margin: 0 auto 6.9230769231dvw;
  }
}
@media (min-width: 768px) {
  .revolution-3__ttl img {
    width: min(437px, 30.3472222222dvw);
  }
}

.revolution-4__wrap {
  display: grid;
}
@media (min-width: 768px) {
  .revolution-4__wrap {
    margin: 0 auto;
    gap: 20px;
    max-width: 1440px;
    align-items: center;
    justify-content: space-between;
    grid-template-columns: auto auto auto;
  }
}
@media (max-width: 767px) {
  .revolution-4__ttl {
    margin-bottom: 8.2051282051dvw;
  }
}
.revolution-4__ttl img {
  display: block;
  margin: 0 auto;
}
@media (min-width: 768px) {
  .revolution-4__ttl img {
    width: min(283px, 19.6527777778dvw);
  }
}
@media (min-width: 768px) {
  .revolution-4__bnr {
    max-width: 525px;
  }
  .revolution-4__bnr:nth-of-type(1) {
    order: -1;
  }
}
@media (max-width: 767px) {
  .revolution-4__bnr:not(:last-child) {
    margin-bottom: 5.1282051282dvw;
  }
}

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