@charset "UTF-8";
html {
  scroll-behavior: smooth;
  font-family: "Noto Sans", sans-serif;
  color: #000000;
}

.pc {
  display: block !important;
}
@media screen and (max-width: 767px) {
  .pc {
    display: none !important;
  }
}

.sp {
  display: none;
}
@media screen and (max-width: 767px) {
  .sp {
    display: initial;
  }
}

.top {
  position: fixed;
  background: linear-gradient(#fff 0%, #fff 37.93%, rgba(255, 255, 255, 0.69) 60.59%, rgba(255, 255, 255, 0.36) 77.34%, rgba(255, 255, 255, 0) 100%);
  top: 0;
  padding: 0 clamp(53.76px, 7vw, 112px) 20px clamp(28.8px, 3.75vw, 60px);
  margin-top: -20px;
  z-index: 100;
  width: 100%;
  z-index: 10000;
  color: #000000;
}
@media screen and (max-width: 767px) {
  .top {
    padding: 0 20px;
    width: 100vw;
    z-index: 10000;
  }
}
.top .logo_menu {
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.top .logo_menu .logo {
  position: relative;
  z-index: 999999;
}
@media screen and (max-width: 767px) {
  .top .logo_menu .logo {
    position: relative;
    display: block;
    width: clamp(63.46px, 24.77vw, 190px);
    padding-top: 0px;
    z-index: 999999;
  }
}
.top .logo_menu .logo img {
  width: 100%;
  max-width: 150px;
  height: auto;
}
.top .logo_menu .menu_area {
  display: flex;
  text-align: end;
}
.top .logo_menu .menu_area .menu {
  font-size: clamp(7.68px, 1vw, 16px);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-decoration: none;
  height: fit-content;
}
@media screen and (max-width: 767px) {
  .top .logo_menu .menu_area .menu {
    display: none;
  }
}
.top .logo_menu .menu_area .menu .menu-list {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: clamp(14.4px, 1.88vw, 30px);
}
.top .logo_menu .menu_area .menu .menu-link::after {
  margin-left: 0.5em;
  content: "";
  display: inline-block;
  background-image: url(../images/menu-down.png);
  background-position: center right;
  background-size: contain;
  background-repeat: no-repeat;
  width: clamp(4.8px, 0.63vw, 10px);
  height: 1em;
  vertical-align: middle;
}
.top .logo_menu .menu_area .menu a {
  padding: 0 8px;
  border-radius: 16px;
  text-align: center;
  text-decoration: none;
  color: #000000;
}
@media screen and (max-width: 767px) {
  .top .logo_menu .menu_area .menu a {
    font-size: 19px;
    text-align: left;
  }
}
.top .logo_menu .menu_area .menu.open {
  right: 0;
}

section {
  display: grid;
  place-items: center;
}
@media screen and (max-width: 767px) {
  section {
    width: 100%;
    place-items: initial;
  }
}
section .container {
  position: relative;
  display: block;
  width: 100%;
}
@media screen and (max-width: 767px) {
  section .container {
    width: calc(100% - clamp(19.2px, 2.5vw, 40px) * 2);
    margin: 0 clamp(19.2px, 2.5vw, 40px);
    max-width: 100%;
  }
}
section .title-jp {
  font-family: "Noto Sans", sans-serif;
  font-size: clamp(7.68px, 1vw, 16px);
  font-weight: 700;
  letter-spacing: 0.08em;
  color: #000000;
  text-align: left;
}
@media screen and (max-width: 767px) {
  section .title-jp {
    font-size: clamp(8.68px, 3.39vw, 26px);
  }
}
section .title-en {
  font-family: "Figtree", sans-serif;
  font-size: clamp(38.4px, 5vw, 80px);
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.125;
  color: #3a75bb;
  text-align: left;
}
@media screen and (max-width: 767px) {
  section .title-en {
    font-size: clamp(26.72px, 10.43vw, 80px);
  }
}
section .text-area {
  font-size: clamp(7.68px, 1vw, 16px);
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 2.1875;
}
@media screen and (max-width: 767px) {
  section .text-area {
    font-size: clamp(10.69px, 4.17vw, 32px);
    letter-spacing: 0.04em;
    line-height: 1.7307692308;
  }
}

.fv-anim {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #ffffff;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 999999;
  transition: opacity 2s ease-in-out;
}

.fv-anim-logo {
  position: absolute;
  width: auto;
  max-width: 40%;
  max-height: 40%;
  opacity: 0;
}

#first-view {
  position: relative;
}
#first-view::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-image: url("../images/first-view-slash.png");
  background-size: 100% 100%;
  background-repeat: no-repeat;
  z-index: 10;
}
@media screen and (max-width: 767px) {
  #first-view::after {
    background-image: url("../images/first-view-slash_sp.png");
    top: 0;
  }
}
#first-view .cover {
  position: relative;
}
#first-view .cover::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background-image: url("../images/top-cover.png");
  background-size: 100% 100%;
  z-index: 2;
  opacity: 50%;
  mix-blend-mode: lighten;
}
@media screen and (max-width: 767px) {
  #first-view .cover::after {
    background-image: url("../images/top-cover_sp.png");
  }
}
#first-view video {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
  mask-image: url(../images/fv-mask.png);
  mask-size: 100% 100%;
  border: none;
  outline: none;
  box-sizing: border-box;
  object-fit: cover;
}
@media screen and (max-width: 767px) {
  #first-view video {
    mask-image: url(../images/fv-mask_sp.png);
    display: block;
    line-height: 0;
  }
}
#first-view .container {
  z-index: 2;
}
@media screen and (max-width: 767px) {
  #first-view .container {
    width: 100%;
    margin: 0;
  }
}
#first-view .container::before, #first-view .container::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-size: 45%;
  background-position: top 55% left -5%;
  background-repeat: no-repeat;
  mix-blend-mode: multiply;
  z-index: 0;
}
@media screen and (max-width: 767px) {
  #first-view .container::before, #first-view .container::after {
    background-position: top 50% left -5%;
  }
}
#first-view .container::before {
  background-image: url("../images/first-view-triangle-bk.png");
}
@media screen and (max-width: 767px) {
  #first-view .container::before {
    background-image: url("../images/first-view-triangle-bk_sp.png");
  }
}
#first-view .container::after {
  background-image: url("../images/first-view-triangle.png");
}
@media screen and (max-width: 767px) {
  #first-view .container::after {
    background-image: url("../images/first-view-triangle_sp.png");
  }
}
#first-view .slogan {
  position: absolute;
  bottom: 5%;
  left: calc(clamp(53.76px, 7vw, 112px) + 15px);
  margin: 0 auto;
  font-size: clamp(33.6px, 4.38vw, 70px);
  font-weight: 700;
  letter-spacing: -0.05em;
  line-height: 1.6666666667;
  color: #000000;
}
@media screen and (max-width: 767px) {
  #first-view .slogan {
    left: clamp(19.2px, 2.5vw, 40px);
    bottom: -5%;
    font-size: clamp(20.04px, 7.82vw, 60px);
    letter-spacing: -0.05em;
  }
}

.scroll-sign {
  display: none;
}
@media screen and (max-width: 767px) {
  .scroll-sign {
    position: relative;
    display: inline-block;
    margin-top: clamp(66.8px, 26.08vw, 200px);
    left: 50%;
    transform: translateX(-50%);
    font-weight: 900;
    font-size: clamp(8.35px, 3.26vw, 25px);
    letter-spacing: 0.04em;
    color: #3a75bb;
  }
  .scroll-sign .arrow {
    display: block;
    width: 100%;
    height: clamp(26.72px, 10.43vw, 80px);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 50 60' fill='%233a75bb'%3E%3Cpath d='M25 10v38M7.5 30l17.5 18 17.5-18' stroke='%233a75bb' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-size: 100% 100%;
    background-position: center;
    background-repeat: no-repeat;
    animation: bounce 2s infinite;
  }
  @keyframes bounce {
    0%, 20%, 50%, 80%, 100% {
      transform: translateY(0);
    }
    40% {
      transform: translateY(-10px);
    }
    60% {
      transform: translateY(-5px);
    }
  }
}

#philosophy {
  position: relative;
  padding-top: clamp(38.4px, 5vw, 80px);
}
@media screen and (max-width: 767px) {
  #philosophy {
    padding: clamp(33.4px, 13.04vw, 100px) 0 0;
  }
}
#philosophy .container {
  position: relative;
  width: calc(100% - clamp(53.76px, 7vw, 112px) * 2);
  margin: 0 clamp(53.76px, 7vw, 112px);
}
@media screen and (max-width: 767px) {
  #philosophy .container {
    width: calc(100% - clamp(19.2px, 2.5vw, 40px) * 2);
    margin-inline: clamp(19.2px, 2.5vw, 40px);
  }
}
#philosophy .inner-container {
  margin-left: calc(clamp(42.24px, 5.5vw, 88px) + clamp(24px, 3.13vw, 50px) * 2);
  margin-bottom: clamp(76.8px, 10vw, 160px);
}
@media screen and (max-width: 767px) {
  #philosophy .inner-container {
    margin-inline: clamp(19.2px, 2.5vw, 40px);
    margin-bottom: clamp(33.4px, 13.04vw, 100px);
  }
}
#philosophy hgroup {
  margin-top: clamp(38.4px, 5vw, 80px);
}
#philosophy .text-area {
  margin-top: clamp(19.2px, 2.5vw, 40px);
}
@media screen and (max-width: 767px) {
  #philosophy .text-area {
    margin-top: clamp(20.04px, 7.82vw, 60px);
    margin-bottom: clamp(20.04px, 7.82vw, 60px);
  }
}
#philosophy .text-area p {
  margin-bottom: 1.5em;
}
@media screen and (min-width: 768px) {
  #philosophy .image-area {
    position: absolute;
    top: 0;
    right: 0;
    width: 31.25%;
    z-index: -1;
  }
}
#philosophy .image-area .main {
  padding-right: clamp(42.24px, 5.5vw, 88px);
}
@media screen and (max-width: 767px) {
  #philosophy .image-area .main {
    padding-right: 0;
  }
}
#philosophy .image-area .sub {
  width: 60%;
  margin-left: auto;
  transform: translateY(-20%);
}
@media screen and (max-width: 767px) {
  #philosophy .image-area .sub {
    transform: translate(clamp(19.2px, 2.5vw, 40px), -25%);
  }
}

#service {
  position: relative;
  background: linear-gradient(to right, transparent 0%, transparent clamp(53.76px, 7vw, 112px), #3a75bb clamp(53.76px, 7vw, 112px), #3a75bb 100%);
  z-index: 0;
}
@media screen and (max-width: 767px) {
  #service {
    background: linear-gradient(to right, #3a75bb 0%, #3a75bb 100%);
  }
}
#service::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-image: url("../images/service-triangle.png");
  background-size: cover;
  background-position: top 0% right 0;
  background-repeat: no-repeat;
  mix-blend-mode: darken;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  #service::before {
    background-image: url("../images/service-triangle_sp.png");
  }
}
#service .container {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto 1fr;
  grid-template-areas: "image title" "image text";
  gap: clamp(28.8px, 3.75vw, 60px) clamp(60px, 7.81vw, 125px);
  z-index: 2;
}
@media screen and (max-width: 767px) {
  #service .container {
    width: 100%;
    margin-inline: 0;
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr;
    grid-template-areas: "title" "image" "text";
    gap: clamp(20.04px, 7.82vw, 60px) clamp(41.75px, 16.3vw, 125px);
  }
}
#service .image-area {
  position: relative;
  grid-area: image;
  transform: translateY(clamp(28.8px, 3.75vw, 60px));
}
@media screen and (max-width: 767px) {
  #service .image-area {
    margin-right: calc(clamp(19.2px, 2.5vw, 40px) * 2);
    margin-bottom: clamp(20.04px, 7.82vw, 60px);
  }
}
#service .image-area img {
  position: relative;
}
#service .image-area img::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(#3a75bb 0%, rgba(30, 37, 54, 0.61) 100%);
}
#service hgroup {
  grid-area: title;
  margin-top: clamp(48px, 6.25vw, 100px);
}
@media screen and (max-width: 767px) {
  #service hgroup {
    margin-left: calc(clamp(19.2px, 2.5vw, 40px) * 2);
  }
}
#service hgroup .title-jp, #service hgroup .title-en {
  color: #ffffff;
}
#service .text-area {
  grid-area: text;
  color: #ffffff;
}
#service .service-item {
  margin-bottom: clamp(28.8px, 3.75vw, 60px);
}
@media screen and (max-width: 767px) {
  #service .service-item:nth-child(even) .service-image {
    margin-left: calc(clamp(19.2px, 2.5vw, 40px) * 2);
  }
  #service .service-item:nth-child(odd) .service-image {
    margin-right: calc(clamp(19.2px, 2.5vw, 40px) * 2);
  }
}
#service .service-item.open .service-text {
  max-height: 500px;
  opacity: 1;
  padding-top: 1em;
  padding-bottom: 1em;
}
#service .service-item.open .service-title .service-number {
  background-color: #ffffff;
  color: #3a75bb;
}
#service .service-item.closed .service-title .service-number {
  background: #3a75bb;
  color: #ffffff;
  border: 1px solid #ffffff;
}
#service .service-title {
  position: relative;
  display: flex;
  grid-area: title;
  margin-right: calc(clamp(53.76px, 7vw, 112px) + clamp(42.24px, 5.5vw, 88px));
  margin-bottom: clamp(9.6px, 1.25vw, 20px);
  vertical-align: baseline;
  align-items: center;
  justify-content: flex-start;
  cursor: pointer;
  font-size: clamp(12px, 1.56vw, 25px);
  font-weight: 700;
  letter-spacing: 0.04em;
  color: #ffffff;
}
@media screen and (max-width: 767px) {
  #service .service-title {
    margin-inline: calc(clamp(19.2px, 2.5vw, 40px) * 2);
    font-size: clamp(11.69px, 4.56vw, 35px);
  }
}
#service .service-title .service-number {
  display: inline-block;
  background-color: #ffffff;
  border-radius: clamp(12px, 1.56vw, 25px);
  width: 4em;
  margin-right: 1.5em;
  font-family: "Figtree", sans-serif;
  font-size: clamp(10.56px, 1.38vw, 22px);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-align: center;
  transition: background 0.3s, color 0.3s;
}
@media screen and (max-width: 767px) {
  #service .service-title .service-number {
    border-radius: clamp(8.35px, 3.26vw, 25px);
    font-size: clamp(8.35px, 3.26vw, 25px);
    color: #3a75bb;
    margin-right: 1em;
    padding: 0.25em 0;
  }
}
#service .service-title .accordion-icon {
  width: 1em;
  height: 1em;
  min-width: 1em;
  min-height: 1em;
  margin-left: auto;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  #service .service-title .accordion-icon {
    display: none;
  }
}
#service .service-title .accordion-icon .circle {
  width: 1em;
  height: 1em;
  border-radius: 50%;
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.3);
  padding: 0;
}
#service .service-title .accordion-icon .circle svg {
  width: 55%;
  height: 55%;
  stroke: #3a75bb;
  stroke-width: 2.5;
  fill: none;
  display: block;
  margin: auto;
}
#service .service-text {
  max-height: 0;
  margin-right: calc(clamp(53.76px, 7vw, 112px) + clamp(42.24px, 5.5vw, 88px));
  padding-top: 0;
  padding-bottom: 0;
  overflow: hidden;
  font-size: clamp(7.68px, 1vw, 16px);
  font-weight: 500;
  letter-spacing: 0.05em;
  color: #ffffff;
  transition: max-height 0.3s cubic-bezier(0.4, 0, 0.2, 1), padding 0.3s, opacity 0.3s;
  opacity: 0;
}
@media screen and (max-width: 767px) {
  #service .service-text {
    max-height: fit-content;
    margin-inline: calc(clamp(19.2px, 2.5vw, 40px) * 2);
    padding-bottom: 3rem;
    font-size: clamp(10.69px, 4.17vw, 32px);
    letter-spacing: 0.04em;
    line-height: 1.7307692308;
    opacity: 1;
  }
}

#recruit {
  position: relative;
  margin-top: clamp(76.8px, 10vw, 160px);
}
@media screen and (max-width: 767px) {
  #recruit {
    margin-top: clamp(33.4px, 13.04vw, 100px);
  }
}
#recruit .container {
  position: relative;
  width: calc(100% - (clamp(53.76px, 7vw, 112px) + clamp(42.24px, 5.5vw, 88px)) * 2);
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  #recruit .container {
    width: calc(100% - clamp(19.2px, 2.5vw, 40px) * 2);
    margin-inline: clamp(19.2px, 2.5vw, 40px);
  }
}
#recruit hgroup {
  margin-left: clamp(24px, 3.13vw, 50px);
}
#recruit .text-area {
  margin-top: clamp(28.8px, 3.75vw, 60px);
}
#recruit .recruit-tabs {
  display: flex;
}
#recruit .recruit-tab {
  display: flex;
  width: 50%;
  text-align: left;
  padding: 1em clamp(17.28px, 2.25vw, 36px);
  cursor: pointer;
  font-size: clamp(12px, 1.56vw, 25px);
  font-weight: 700;
  line-height: clamp(19.2px, 2.5vw, 40px);
  vertical-align: baseline;
  border: none;
  border-radius: clamp(14.4px, 1.88vw, 30px) clamp(14.4px, 1.88vw, 30px) 0 0;
  outline: none;
  background: transparent;
  transition: background 0.2s, color 0.2s;
}
#recruit .recruit-tab .number {
  display: inline-block;
  background-color: #ffffff;
  border: 1px solid #3a75bb;
  border-radius: clamp(24px, 3.13vw, 50px);
  width: 4em;
  height: clamp(19.2px, 2.5vw, 40px);
  margin-right: 1.5em;
  font-family: "Figtree", sans-serif;
  font-size: clamp(10.56px, 1.38vw, 22px);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-align: center;
  transition: background 0.3s, color 0.3s;
}
#recruit .recruit-tab.active {
  background: #edf5fc;
  z-index: 2;
}
#recruit .recruit-tab.active .number {
  background: #3a75bb;
  color: #ffffff;
  border: 1px solid #ffffff;
}
#recruit .recruit-tab .recruit-icon {
  width: 1em;
  min-width: 1em;
  margin-left: auto;
  display: flex;
  align-items: center;
  justify-content: center;
}
#recruit .recruit-tab .recruit-icon .circle {
  width: 1em;
  height: 1em;
  border-radius: 50%;
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.3);
  padding: 0;
}
#recruit .recruit-tab .recruit-icon .circle svg {
  width: 55%;
  height: 55%;
  stroke: #3a75bb;
  stroke-width: 2.5;
  fill: none;
  display: block;
  margin: auto;
}
#recruit .recruit-contents {
  background: #edf5fc;
  padding-top: clamp(38.4px, 5vw, 80px);
  padding-bottom: clamp(57.6px, 7.5vw, 120px);
  border-radius: 0 0 8px 8px;
}
@media screen and (max-width: 767px) {
  #recruit .recruit-contents {
    display: grid;
    background: transparent;
    padding-top: 0;
    padding-bottom: clamp(10.02px, 3.91vw, 30px);
    gap: clamp(20.04px, 7.82vw, 60px);
  }
  #recruit .recruit-contents .recruit-item {
    background: #edf5fc;
  }
}
#recruit .tab-content {
  display: none;
}
#recruit .tab-content.active {
  display: block;
}
#recruit .recruit-text {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 clamp(19.2px, 2.5vw, 40px);
  margin: 0 calc(clamp(24px, 3.13vw, 50px) * 2);
}
@media screen and (max-width: 767px) {
  #recruit .recruit-text {
    grid-auto-flow: initial;
    grid-template-columns: 1fr;
    grid-template-rows: 1fr;
    margin-top: clamp(10.02px, 3.91vw, 30px);
    margin-bottom: clamp(40.08px, 15.65vw, 120px);
    margin-inline: clamp(19.2px, 2.5vw, 40px);
  }
}
#recruit .recruit-text .recruit-title {
  font-size: clamp(11.69px, 4.56vw, 35px);
  font-weight: 700;
  letter-spacing: 0.04em;
  margin-bottom: clamp(8.35px, 3.26vw, 25px);
}
@media screen and (min-width: 768px) {
  #recruit .recruit-text .recruit-title {
    display: none;
  }
}
#recruit .recruit-text .recruit-title .number {
  display: inline-block;
  background: #3a75bb;
  color: #ffffff;
  border: 1px solid #ffffff;
  border-radius: clamp(16.7px, 6.52vw, 50px);
  width: 4em;
  padding: 0.25em 0;
  margin-right: 0.5em;
  font-family: "Figtree", sans-serif;
  font-size: clamp(8.35px, 3.26vw, 25px);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-align: center;
}
#recruit li {
  display: grid;
  grid-template-columns: 30% auto;
  padding-top: clamp(9.6px, 1.25vw, 20px);
  padding-bottom: clamp(9.6px, 1.25vw, 20px);
  border-bottom: 1px solid #000000;
  align-items: center;
}
@media screen and (max-width: 767px) {
  #recruit li {
    grid-template-columns: 1fr;
    font-size: clamp(10.02px, 3.91vw, 30px);
  }
}
#recruit li .title {
  font-weight: 700;
  color: #3a75bb;
}
@media screen and (max-width: 767px) {
  #recruit li .title {
    margin-bottom: clamp(3.34px, 1.3vw, 10px);
  }
}
#recruit li .content {
  letter-spacing: 0.04em;
  line-height: 1.5;
}
#recruit .recruit-link {
  display: grid;
  place-items: center;
  margin-top: clamp(28.8px, 3.75vw, 60px);
}
@media screen and (max-width: 767px) {
  #recruit .recruit-link {
    margin-top: 0;
    padding: clamp(26.72px, 10.43vw, 80px) 0;
  }
}
#recruit .recruit-link .link-area {
  width: 23em;
}
@media screen and (max-width: 767px) {
  #recruit .recruit-link .link-area {
    width: 14em;
  }
}
#recruit .recruit-link a {
  position: relative;
  display: block;
  text-decoration: none;
  width: 100%;
  height: 100%;
  color: #ffffff;
  background-color: #3a75bb;
  border: 1px solid #3a75bb;
  border-radius: clamp(24px, 3.13vw, 50px);
  font-size: clamp(9.6px, 1.25vw, 20px);
  font-weight: 700;
  text-align: center;
  line-height: 3;
  transition: color 0.3s ease, background-color 0.3s ease; /* 色変化をスムーズに */
  /* ホバー時に背景色と文字色を反転 */
}
@media screen and (max-width: 767px) {
  #recruit .recruit-link a {
    font-size: clamp(8.68px, 3.39vw, 26px);
  }
}
#recruit .recruit-link a span {
  position: absolute;
  top: 50%;
  right: 7.5%;
  transform: translate(0, -50%);
  width: 7.543px; /* SVGの幅を設定 */
  height: 12.257px; /* SVGの高さを設定 */
  background-image: url("../images/arrow-right-white.svg");
  background-repeat: no-repeat;
  background-position: center;
  transition: background-image 0.3s ease;
}
#recruit .recruit-link a:hover {
  color: #3a75bb; /* 文字色を背景色の元のカラーに */
  background-color: #ffffff; /* 背景色を文字色の元のカラーに */
}
#recruit .recruit-link a:hover span {
  background-image: url("../images/arrow-right-blue.svg");
}

#message {
  position: relative;
  margin-top: clamp(76.8px, 10vw, 160px);
  margin-bottom: clamp(48px, 6.25vw, 100px);
}
@media screen and (max-width: 767px) {
  #message {
    margin-top: clamp(33.4px, 13.04vw, 100px);
    margin-bottom: clamp(33.4px, 13.04vw, 100px);
  }
}
#message::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-image: url("../images/message-lines-bk.png");
  background-size: 48%;
  background-position: top 0% left 0%;
  background-repeat: no-repeat;
  mix-blend-mode: multiply;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  #message::before {
    background-image: url("../images/message-lines-bk_sp.png");
    background-size: calc(100% - clamp(19.2px, 2.5vw, 40px));
  }
}
#message::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-image: url("../images/message-lines.png");
  background-size: 48%;
  background-position: top 0% left 0%;
  background-repeat: no-repeat;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  #message::after {
    background-image: url("../images/message-lines_sp.png");
    background-size: calc(100% - clamp(19.2px, 2.5vw, 40px));
  }
}
#message .container {
  position: relative;
  display: grid;
  grid-template-columns: 38.5% auto;
  grid-template-rows: auto 1fr;
  grid-template-areas: "image title" "image text";
  width: calc(100% - clamp(53.76px, 7vw, 112px) * 2);
  margin: clamp(9.6px, 1.25vw, 20px) clamp(53.76px, 7vw, 112px) clamp(14.4px, 1.88vw, 30px);
}
@media screen and (max-width: 767px) {
  #message .container {
    width: calc(100% - clamp(19.2px, 2.5vw, 40px) * 4);
    margin: clamp(43.42px, 16.95vw, 130px) calc(clamp(19.2px, 2.5vw, 40px) * 2) clamp(20.04px, 7.82vw, 60px);
    grid-template-columns: 1fr;
    grid-template-rows: 1fr;
    grid-template-areas: "title" "image" "text";
  }
}
#message .image-area {
  position: relative;
  grid-area: image;
  width: 88.809946714%;
  margin-top: auto;
  margin-right: clamp(24px, 3.13vw, 50px);
  z-index: 1;
}
@media screen and (max-width: 767px) {
  #message .image-area {
    width: 100%;
    margin-top: clamp(20.04px, 7.82vw, 60px);
    margin-right: 0;
  }
}
#message .image-area .name {
  margin-top: 0.5em;
  font-size: clamp(9.6px, 1.25vw, 20px);
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 2;
}
#message .image-area .name span {
  font-size: clamp(7.68px, 1vw, 16px);
  font-weight: 500;
  line-height: 1.75;
  padding-right: 1em;
}
#message hgroup {
  grid-area: title;
  margin-top: clamp(57.6px, 7.5vw, 120px);
  margin-left: clamp(60px, 7.81vw, 125px);
}
@media screen and (max-width: 767px) {
  #message hgroup {
    margin-left: auto;
  }
}
#message .text-area {
  grid-area: text;
  margin-top: clamp(28.8px, 3.75vw, 60px);
  margin-right: clamp(42.24px, 5.5vw, 88px);
}
@media screen and (max-width: 767px) {
  #message .text-area {
    margin-right: 0;
  }
}

#company {
  position: relative;
  background-color: #3a75bb;
  z-index: 0;
}
#company::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-image: url("../images/company-triangle.png");
  background-size: 100%;
  background-position: top 0% left 0%;
  background-repeat: no-repeat;
  mix-blend-mode: normal;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  #company::before {
    background-image: url("../images/company-triangle_sp.png");
  }
}
#company .container {
  position: relative;
  width: calc(100% - (clamp(53.76px, 7vw, 112px) + clamp(42.24px, 5.5vw, 88px) + clamp(24px, 3.13vw, 50px) + clamp(24px, 3.13vw, 50px)) * 2);
  margin: 0 auto;
  margin-bottom: clamp(76.8px, 10vw, 160px);
  z-index: 2;
}
@media screen and (max-width: 767px) {
  #company .container {
    width: calc(100% - clamp(19.2px, 2.5vw, 40px) * 4);
    margin-inline: calc(clamp(19.2px, 2.5vw, 40px) * 2);
    margin-bottom: clamp(33.4px, 13.04vw, 100px);
  }
}
#company hgroup {
  margin-top: clamp(48px, 6.25vw, 100px);
}
#company hgroup .title-jp, #company hgroup .title-en {
  color: #ffffff;
}
#company .text-area {
  margin-top: clamp(28.8px, 3.75vw, 60px);
  color: #ffffff;
}
#company .company-item {
  display: grid;
  grid-template-columns: 20% 80%;
  border-bottom: 1px solid rgba(255, 255, 255, 0.3);
  padding-top: clamp(14.4px, 1.88vw, 30px);
  padding-bottom: clamp(14.4px, 1.88vw, 30px);
}
@media screen and (max-width: 767px) {
  #company .company-item {
    grid-template-columns: 1fr;
    font-size: clamp(10.02px, 3.91vw, 30px);
  }
}
#company .company-item .item-title {
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  #company .company-item .item-title {
    margin-bottom: clamp(3.34px, 1.3vw, 10px);
  }
}

#last-area {
  position: relative;
  padding: clamp(38.4px, 5vw, 80px) 0 clamp(9.6px, 1.25vw, 20px);
}
#last-area .container {
  width: calc(100% - clamp(53.76px, 7vw, 112px) * 2);
  margin: 0 auto;
  padding-bottom: clamp(38.4px, 5vw, 80px);
  border-bottom: 1px solid rgba(0, 0, 0, 0.3);
}
@media screen and (max-width: 767px) {
  #last-area .container {
    width: calc(100% - clamp(19.2px, 2.5vw, 40px) * 2);
    margin-inline: clamp(19.2px, 2.5vw, 40px);
    padding-bottom: clamp(10.02px, 3.91vw, 30px);
  }
}
#last-area .inner-container {
  display: grid;
  margin: 0 calc(clamp(42.24px, 5.5vw, 88px) + clamp(24px, 3.13vw, 50px) * 2);
  grid-template-columns: 30% auto;
  grid-template-areas: "company menu";
}
#last-area .inner-container a {
  font-size: clamp(7.68px, 1vw, 16px);
  font-weight: 500;
  text-decoration: none;
  color: #000000;
}
@media screen and (max-width: 767px) {
  #last-area .inner-container a {
    font-size: clamp(7.68px, 3vw, 23px);
  }
}
@media screen and (max-width: 767px) {
  #last-area .inner-container {
    width: 100%;
    margin-inline: 0;
    grid-template-columns: 100%;
    grid-template-areas: "menu" "company";
  }
}
#last-area .inner-container .company-info {
  grid-area: company;
  font-size: clamp(6.72px, 0.88vw, 14px);
  line-height: 2.5;
}
@media screen and (max-width: 767px) {
  #last-area .inner-container .company-info {
    margin-top: clamp(20.04px, 7.82vw, 60px);
    font-size: clamp(7.68px, 3vw, 23px);
    line-height: 1.5;
  }
}
#last-area .inner-container .company-info .company-name {
  font-size: clamp(9.6px, 1.25vw, 20px);
  font-weight: 700;
  line-height: 1;
  margin-bottom: clamp(9.6px, 1.25vw, 20px);
}
@media screen and (max-width: 767px) {
  #last-area .inner-container .company-info .company-name {
    font-size: clamp(7.68px, 3vw, 23px);
    margin-bottom: clamp(3.34px, 1.3vw, 10px);
  }
}
#last-area .inner-container .menu-list {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  grid-area: menu;
  margin-left: clamp(24px, 3.13vw, 50px);
  color: #000000;
}
@media screen and (max-width: 767px) {
  #last-area .inner-container .menu-list {
    margin-inline: clamp(19.2px, 2.5vw, 40px);
  }
}

.copyright {
  font-size: clamp(6.72px, 0.88vw, 14px);
  font-weight: 500;
  letter-spacing: 0.04em;
  color: #000000;
  text-align: center;
  padding-top: clamp(9.6px, 1.25vw, 20px);
}
@media screen and (max-width: 767px) {
  .copyright {
    font-size: clamp(6.68px, 2.61vw, 20px);
  }
}

.floating_item {
  position: absolute;
  z-index: 200;
  right: calc(clamp(53.76px, 7vw, 112px) + clamp(42.24px, 5.5vw, 88px));
  bottom: clamp(96px, 12.5vw, 200px);
  text-align: center;
  font-size: clamp(7.68px, 1vw, 16px);
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 2.1875;
  color: #000000;
  text-decoration: none;
}
@media screen and (max-width: 767px) {
  .floating_item {
    right: clamp(19.2px, 2.5vw, 40px);
    bottom: clamp(81.6px, 10.63vw, 170px);
    font-size: clamp(6.68px, 2.61vw, 20px);
    z-index: 1000;
  }
}
.floating_item.hidden {
  opacity: 0;
  transition: opacity 0.3s ease;
}
.floating_item .top-link {
  display: grid;
  place-items: center;
  background-color: #3a75bb;
  text-align: center;
  border: 1px solid #ffffff;
  border-radius: 50%;
  width: clamp(48px, 6.25vw, 100px);
  height: clamp(48px, 6.25vw, 100px);
  margin-bottom: clamp(4.8px, 0.63vw, 10px);
}
@media screen and (max-width: 767px) {
  .floating_item .top-link {
    width: clamp(33.4px, 13.04vw, 100px);
    height: clamp(33.4px, 13.04vw, 100px);
    margin-bottom: 0;
  }
}
.floating_item .top-link .link-arrow {
  position: relative;
  display: inline-block;
  width: 2px;
  height: 25px;
  margin: 0 9.2px;
  border-radius: 9999px;
  background-color: #ffffff;
}
@media screen and (max-width: 767px) {
  .floating_item .top-link .link-arrow {
    width: clamp(0.67px, 0.26vw, 2px);
    height: clamp(6.68px, 2.61vw, 20px);
  }
}
.floating_item .top-link .link-arrow::before, .floating_item .top-link .link-arrow::after {
  content: "";
  position: absolute;
  top: 0;
  left: calc(50% - 1px);
  width: 2px;
  height: 15px;
  border-radius: 9999px;
  background-color: #ffffff;
  transform-origin: 50% 1px;
}
@media screen and (max-width: 767px) {
  .floating_item .top-link .link-arrow::before, .floating_item .top-link .link-arrow::after {
    left: 50%;
    transform-origin: 50% 0px;
    width: clamp(0.67px, 0.26vw, 2px);
    height: clamp(4.68px, 1.83vw, 14px);
  }
}
.floating_item .top-link .link-arrow::before {
  transform: rotate(45deg);
}
.floating_item .top-link .link-arrow::after {
  transform: rotate(-45deg);
}

.upper {
  opacity: 0;
  transform: translate(0px, 70px);
  transition-delay: 200ms;
  transition-duration: 750ms;
  transition-timing-function: ease;
}
.upper.is-active {
  opacity: 1;
  transform: translate(0px, 0px);
}

#voice .swiper {
  width: 100vw;
}
@media screen and (max-width: 767px) {
  #voice .swiper {
    width: calc(100vw - clamp(19.2px, 2.5vw, 40px) * 2);
  }
}

@media screen and (max-width: 767px) {
  #staff .swiper {
    width: 100vw;
  }
  #staff .swiper .swiper-wrapper {
    margin-left: clamp(20.04px, 7.82vw, 60px);
  }
  #staff .swiper .swiper-slide {
    text-align: center;
  }
}

.swiper {
  /* 前へ次への矢印カスタマイズ */
  /* 前への矢印カスタマイズ */
  /* 次への矢印カスタマイズ */
  /* 画像サイズ調整 */
}
.swiper .swiper-wrapper {
  padding-bottom: clamp(28.8px, 3.75vw, 60px);
}
.swiper .swiper-slide, .swiper .staff-item {
  margin-top: clamp(28.8px, 3.75vw, 60px);
  gap: 20px;
  letter-spacing: 0.05em;
  line-height: 2.1875;
}
.swiper .swiper-slide .slide-image, .swiper .staff-item .slide-image {
  background-color: transparent;
}
.swiper .swiper-slide .slide-image img, .swiper .staff-item .slide-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.swiper .swiper-slide .slide-customer, .swiper .staff-item .slide-customer {
  margin-top: clamp(7.2px, 0.94vw, 15px);
}
.swiper .swiper-slide .slide-voice, .swiper .staff-item .slide-voice {
  margin-top: clamp(7.2px, 0.94vw, 15px);
}
.swiper .swiper-nav {
  display: grid;
  grid-template-columns: 50px 50px 1fr;
  grid-template-areas: "left right bar";
  align-items: center;
  margin-bottom: clamp(19.2px, 2.5vw, 40px);
  gap: 50px;
}
@media screen and (max-width: 767px) {
  .swiper .swiper-nav {
    grid-template-columns: clamp(20.04px, 7.82vw, 60px) clamp(6.68px, 2.61vw, 20px) auto;
    gap: clamp(6.68px, 2.61vw, 20px);
  }
}
.swiper .swiper-button-prev {
  grid-area: left;
}
.swiper .swiper-button-next {
  grid-area: right;
}
.swiper .swiper-scrollbar {
  position: relative !important;
  background-color: #cccccc;
  grid-area: bar;
  transform: translateY(100%);
  width: 70% !important;
}
@media screen and (max-width: 767px) {
  .swiper .swiper-scrollbar {
    width: 92.5% !important;
  }
}
.swiper .swiper-scrollbar-drag {
  background-color: #fb5b45;
}
.swiper .swiper-button-prev, .swiper .swiper-button-next {
  position: relative;
  width: 70px;
}
@media screen and (max-width: 767px) {
  .swiper .swiper-button-prev, .swiper .swiper-button-next {
    width: clamp(6.68px, 2.61vw, 20px);
  }
}
.swiper .swiper-button-prev::after,
.swiper .swiper-button-next::after {
  content: "";
}
.swiper .swiper-button-prev::after {
  border-bottom: 13px solid transparent;
  border-right: 20px solid #fb5b45;
  border-top: 13px solid transparent;
}
.swiper .swiper-button-next::after {
  border-bottom: 13px solid transparent;
  border-left: 20px solid #fb5b45;
  border-top: 13px solid transparent;
}
.swiper .swiper-slide img {
  height: auto;
  width: 100%;
}

.hmbg_menu-list .banner {
  display: grid;
  grid-template-columns: 30px 1fr;
  place-content: center;
  gap: 10px;
  width: fit-content;
  background-color: #fb5b45;
  color: #ffffff;
  text-align: center;
  border-radius: 50px;
  padding: 10px 40px;
}
@media screen and (max-width: 767px) {
  .hmbg_menu-list .banner {
    position: absolute;
    width: 16em;
  }
}
.hmbg_menu-list .banner span {
  display: grid;
  place-content: center;
}/*# sourceMappingURL=style.css.map */