/* Variables  */
/* Color Styles  */
.index {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  width: 100%;
  position: relative;
  overflow: hidden;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  line-height: normal;
  letter-spacing: normal; }

.hero-main-title {
  position: relative;
  font-size: inherit;
  font-weight: 900;
  font-family: inherit;
  text-shadow: 0 0 12px #000; }

.hero-subtitle {
  position: relative;
  font-size: inherit;
  letter-spacing: 0.01em;
  line-height: 36px;
  font-weight: 700;
  font-family: inherit;
  display: inline-block;
  text-shadow: 0 0 12px #000; }

.hero-subtitle-container,
.hero-title-container {
  -ms-flex-item-align: stretch;
  align-self: stretch;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start; }

.hero-subtitle-container {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  font-size: 21px; }

.hero-title-container {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  gap: var(--gap-xl); }

.hero-button-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start; }

.hero-button-container {
  -ms-flex-item-align: stretch;
  -ms-grid-row-align: stretch;
  align-self: stretch;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  padding: 0 var(--padding-xl); }

.hero-title-container-parent {
  width: 967px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  gap: var(--gap-53xl);
  max-width: 100%; }

.hero,
.hero-content {
  -ms-flex-item-align: stretch;
  align-self: stretch;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  max-width: 100%; }

.hero-content {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  padding: 0 var(--padding-xl) 0 21px; }

.hero {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  padding: 245px 0 173px;
  height: 700px;
  background-image: url(../public/hero@3x.png);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: top;
  text-align: center;
  font-size: 44px;
  color: var(--white);
  font-family: var(--font-noto-sans-jp); }

.about-icon {
  width: 40px;
  height: 40px;
  position: relative; }

.icon-bg {
  width: 88px;
  height: 88px;
  border-radius: var(--br-141xl);
  background-color: var(--black-light);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  padding: var(--padding-5xl);
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }

.about-description,
.about-title {
  position: relative; }

.about-title {
  -ms-flex-item-align: stretch;
  -ms-grid-row-align: stretch;
  align-self: stretch; }

.about-description {
  font-size: var(--font-size-mini);
  letter-spacing: 0.01em;
  line-height: 32px;
  text-align: left;
  display: inline-block;
  max-height: 96px;
  word-break: break-word; }

.about-card,
.about-card-content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start; }

.about-card-content {
  -ms-flex-item-align: stretch;
  -ms-grid-row-align: stretch;
  align-self: stretch;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: var(--gap-base); }

.about-card {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  border-radius: var(--br-5xs);
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: var(--gap-5xl);
  width: 33%;
  min-width: 256px;
  max-width: 100%; }
  @media screen and (max-width: 1050px) {
    .about-card {
      width: 50%; } }
  @media screen and (max-width: 450px) {
    .about-card {
      width: 100%; } }

.about-inner,
.about-row,
.about-section {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  max-width: 100%; }

.about-row {
  width: 1118px;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  padding: 0 0 var(--padding-5xl);
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  gap: 48px;
  font-size: var(--font-size-5xl);
  color: var(--dark-blue);
  font-family: var(--font-noto-sans-jp); }

.about-inner,
.about-section {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center; }

.about-inner {
  width: 1118px;
  gap: var(--gap-53xl); }

.about-section {
  background-color: var(--main-super-pale);
  text-align: center;
  font-size: var(--font-size-sm);
  color: var(--main);
  font-family: var(--font-open-sans); }

.strength-value-description {
  position: relative;
  display: inline-block; }

.strength-value-description {
  font-size: var(--font-size-53xl);
  line-height: 60px;
  font-family: var(--font-roboto);
  color: var(--main-light); }

.strength-card-values {
  -ms-flex-item-align: stretch;
  align-self: stretch;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  row-gap: 20px; }

.strength-text {
  position: relative;
  font-size: var(--font-size-mini);
  letter-spacing: 0.01em;
  line-height: 36px;
  display: inline-block;
  word-break: break-word; }

.strength-card-values-parent {
  -ms-flex-item-align: stretch;
  align-self: stretch;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  padding: var(--padding-13xl) var(--padding-17xl);
  gap: var(--gap-5xl); }

.strength-card,
.strength-card-item {
  max-width: 100%;
  overflow: hidden;
  -ms-flex-negative: 0;
  flex-shrink: 0; }

.strength-card {
  width: 48.5%;
  -webkit-box-shadow: 0 0 16px rgba(0, 0, 0, 0.16);
  box-shadow: 0 0 16px rgba(0, 0, 0, 0.16);
  border-radius: var(--br-5xs);
  background-color: var(--black-light);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start; }
  @media screen and (max-width: 1050px) {
    .strength-card {
      width: 100%; } }

.strength-card-item {
  -ms-flex-item-align: stretch;
  -ms-grid-row-align: stretch;
  align-self: stretch;
  height: 210px;
  -o-object-fit: cover;
  object-fit: cover; }

.row,
.strength-section {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  max-width: 100%; }

.row {
  width: 1118px;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  padding: var(--padding-13xl) 0 var(--padding-13xl);
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  gap: var(--gap-17xl) 0;
  text-align: left;
  font-size: var(--font-size-5xl);
  color: var(--white);
  font-family: var(--font-noto-sans-jp); }

.strength-inner,
.strength-section {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  max-width: 100%; }

.strength-inner {
  width: 1118px;
  gap: var(--gap-53xl); }

.strength-section {
  background-color: var(--black-main);
  text-align: center;
  font-size: var(--font-size-sm);
  color: var(--main);
  font-family: var(--font-open-sans); }

.flow-term-text {
  position: relative;
  display: inline-block;
  -ms-flex-negative: 0;
  flex-shrink: 0; }
  .flow-term-text > span {
    display: block; }

.flow-term-label {
  width: 72px;
  border-radius: 58px;
  background-color: var(--main-super-pale);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  padding: 296px var(--padding-3xs);
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }

.flow-inner,
.flow-section {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  max-width: 100%; }

.flow-inner {
  width: 1118px;
  gap: var(--gap-53xl); }

.flow-section {
  background: -webkit-gradient(linear, left top, left bottom, from(#155ed6), to(#0047bd));
  background: -webkit-linear-gradient(top, #155ed6, #0047bd);
  background: -o-linear-gradient(top, #155ed6, #0047bd);
  background: linear-gradient(180deg, #155ed6, #0047bd);
  text-align: center;
  font-size: var(--font-size-sm);
  color: var(--main);
  font-family: var(--font-open-sans); }

@media screen and (max-width: 750px) {
  .strength-card-values-parent {
    padding: var(--padding-3xl) var(--padding-7xl); } }

.profile-title-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  max-width: 100%; }

.swiper-bg-wrapper {
  position: relative;
  width: 100%;
  margin: 0 auto; }

.swiper-pagination {
  position: relative !important;
  margin-top: 24px; }

.swiper-pagination-bullet {
  width: 10px !important;
  height: 10px !important;
  margin: 0 0 0 24px !important;
  background: #fff !important;
  opacity: 1 !important; }
  @media screen and (max-width: 450px) {
    .swiper-pagination-bullet {
      margin: 0 0 0 12px !important; } }

.swiper-pagination-bullet:first-child {
  margin: 0 !important; }

.swiper-pagination-bullet-active {
  background: #155ed6 !important; }

.swiper-button-next,
.swiper-button-prev {
  background: url(../public/chevron-right.svg) no-repeat center; }

.swiper-button-prev {
  -webkit-transform: translateY(-50%) scale(-1, 1);
  -ms-transform: translateY(-50%) scale(-1, 1);
  transform: translateY(-50%) scale(-1, 1); }

.swiper-button-prev:after,
.swiper-button-next:after {
  display: none; }

.swiper-button-next {
  right: -48px !important; }

.swiper-button-prev {
  left: -48px !important; }

.profile-title-container {
  width: 1118px;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center; }

.engineer-profile-img-icon {
  max-width: 100%;
  overflow: hidden;
  max-height: 100%; }

.engineer-name {
  margin: 0;
  position: relative;
  font-size: inherit;
  font-weight: 700;
  font-family: inherit;
  display: inline-block; }

.engineer-profile-lable,
.engineer-profile-txt {
  position: relative;
  letter-spacing: 0.01em;
  line-height: 32px; }

.engineer-profile-lable {
  -ms-flex-item-align: stretch;
  -ms-grid-row-align: stretch;
  align-self: stretch;
  font-size: var(--font-size-base);
  color: var(--color-gray-200); }

.engineer-profile-txt {
  font-size: var(--font-size-sm);
  display: inline-block;
  word-break: break-word; }

.engineer-profile-txt-wrapper {
  -ms-flex-item-align: stretch;
  align-self: stretch;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  padding: var(--padding-xl) var(--padding-xl) 0 var(--padding-xl);
  gap: var(--gap-5xs); }

.btn-wrap,
.swiper-slide.engineer-card {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between; }

.btn-wrap {
  -ms-flex-item-align: stretch;
  -ms-grid-row-align: stretch;
  align-self: stretch;
  padding: var(--padding-xl) var(--padding-5xl); }

.engineer-card {
  -webkit-box-shadow: 0 0 8px rgba(0, 0, 0, 0.08);
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.08);
  border-radius: var(--br-5xs);
  background-color: var(--white);
  overflow: hidden;
  gap: var(--gap-5xl);
  width: 31%; }

.profile-cards-container,
.profile-section {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  max-width: 100%; }

.profile-cards-container {
  width: 1118px;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: var(--gap-17xl);
  text-align: left;
  font-size: var(--font-size-lg);
  color: var(--dark-blue);
  font-family: var(--font-noto-sans-jp); }
  .profile-cards-container .swiper-slide {
    background: #fff;
    height: auto !important; }

.profile-section {
  background-color: var(--black-main);
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: var(--gap-41xl);
  text-align: center;
  font-size: var(--font-size-sm);
  color: var(--main);
  font-family: var(--font-open-sans);
  padding-top: 0; }
  .profile-section .profile-title-container {
    margin-top: 72px; }
  @media screen and (max-width: 750px) {
    .profile-section .profile-title-container {
      margin-top: 60px; } }
  @media screen and (max-width: 450px) {
    .profile-section {
      gap: var(--gap-17xl); } }

@media screen and (max-width: 1050px) {
  .hero-main-title {
    font-size: 35px; }
  .strength-value-description {
    font-size: var(--font-size-39xl);
    line-height: 48px; }
  .engineer-card {
    width: 48.5%; } }

@media screen and (max-width: 750px) {
  .hero {
    gap: 86px;
    padding-bottom: 112px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box; }
  .strength-card-values {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap; }
  .strength-inner {
    gap: var(--gap-lg); }
  .flow-term-text {
    font-size: var(--font-size-7xl);
    width: var(--font-size-7xl); }
  .flow-term-label {
    width: 64px;
    padding: 262px var(--padding-3xs); }
  .engineer-card {
    width: 100%; } }

@media screen and (max-width: 450px) {
  .hero {
    background-size: auto 100%;
    background-position: bottom center;
    height: 580px;
    padding: 174px 0 0; }
  .hero-main-title {
    font-size: var(--font-size-7xl); }
  .hero-subtitle {
    font-size: 17px;
    line-height: 29px; }
  .about-title {
    font-size: var(--font-size-lgi); }
  .strength-value-description {
    font-size: var(--font-size-24xl);
    line-height: 36px; }
  .flow-contents {
    gap: 12px; }
  .flow-text {
    font-size: 18px; }
  .flow-term-label {
    width: 40px;
    padding: 256px var(--padding-3xs); }
  .flow-term-text {
    font-size: var(--font-size-lgi);
    width: var(--font-size-lgi); }
  .flow-text-ttl {
    font-size: var(--font-size-sm); }
  .ai-badge {
    min-width: 72px; }
  .ai-badge-img-icon {
    width: 21px;
    height: 21px; } }
