@charset "UTF-8";
.bg-primary {
  background-color: var(--color-primary);
}

.text-primary {
  color: var(--color-primary);
}

.bg-primary-lighter {
  background-color: var(--color-primary-lighter);
}

.text-primary-lighter {
  color: var(--color-primary-lighter);
}

.bg-lightblue-1 {
  background-color: var(--color-lightblue-1);
}

.text-lightblue-1 {
  color: var(--color-lightblue-1);
}

.bg-lightblue-2 {
  background-color: var(--color-lightblue-2);
}

.text-lightblue-2 {
  color: var(--color-lightblue-2);
}

.bg-gray-1 {
  background-color: var(--color-gray-1);
}

.text-gray-1 {
  color: var(--color-gray-1);
}

.bg-gray-2 {
  background-color: var(--color-gray-2);
}

.text-gray-2 {
  color: var(--color-gray-2);
}

@media (min-width: 560px) {
  .sm\:bg-primary {
    background-color: var(--color-primary);
  }
  .sm\:text-primary {
    color: var(--color-primary);
  }
  .sm\:bg-primary-lighter {
    background-color: var(--color-primary-lighter);
  }
  .sm\:text-primary-lighter {
    color: var(--color-primary-lighter);
  }
  .sm\:bg-lightblue-1 {
    background-color: var(--color-lightblue-1);
  }
  .sm\:text-lightblue-1 {
    color: var(--color-lightblue-1);
  }
  .sm\:bg-lightblue-2 {
    background-color: var(--color-lightblue-2);
  }
  .sm\:text-lightblue-2 {
    color: var(--color-lightblue-2);
  }
  .sm\:bg-gray-1 {
    background-color: var(--color-gray-1);
  }
  .sm\:text-gray-1 {
    color: var(--color-gray-1);
  }
  .sm\:bg-gray-2 {
    background-color: var(--color-gray-2);
  }
  .sm\:text-gray-2 {
    color: var(--color-gray-2);
  }
}
@media (min-width: 768px) {
  .md\:bg-primary {
    background-color: var(--color-primary);
  }
  .md\:text-primary {
    color: var(--color-primary);
  }
  .md\:bg-primary-lighter {
    background-color: var(--color-primary-lighter);
  }
  .md\:text-primary-lighter {
    color: var(--color-primary-lighter);
  }
  .md\:bg-lightblue-1 {
    background-color: var(--color-lightblue-1);
  }
  .md\:text-lightblue-1 {
    color: var(--color-lightblue-1);
  }
  .md\:bg-lightblue-2 {
    background-color: var(--color-lightblue-2);
  }
  .md\:text-lightblue-2 {
    color: var(--color-lightblue-2);
  }
  .md\:bg-gray-1 {
    background-color: var(--color-gray-1);
  }
  .md\:text-gray-1 {
    color: var(--color-gray-1);
  }
  .md\:bg-gray-2 {
    background-color: var(--color-gray-2);
  }
  .md\:text-gray-2 {
    color: var(--color-gray-2);
  }
}
@media (min-width: 1024px) {
  .lg\:bg-primary {
    background-color: var(--color-primary);
  }
  .lg\:text-primary {
    color: var(--color-primary);
  }
  .lg\:bg-primary-lighter {
    background-color: var(--color-primary-lighter);
  }
  .lg\:text-primary-lighter {
    color: var(--color-primary-lighter);
  }
  .lg\:bg-lightblue-1 {
    background-color: var(--color-lightblue-1);
  }
  .lg\:text-lightblue-1 {
    color: var(--color-lightblue-1);
  }
  .lg\:bg-lightblue-2 {
    background-color: var(--color-lightblue-2);
  }
  .lg\:text-lightblue-2 {
    color: var(--color-lightblue-2);
  }
  .lg\:bg-gray-1 {
    background-color: var(--color-gray-1);
  }
  .lg\:text-gray-1 {
    color: var(--color-gray-1);
  }
  .lg\:bg-gray-2 {
    background-color: var(--color-gray-2);
  }
  .lg\:text-gray-2 {
    color: var(--color-gray-2);
  }
}
@media (min-width: 1728px) {
  .xl\:bg-primary {
    background-color: var(--color-primary);
  }
  .xl\:text-primary {
    color: var(--color-primary);
  }
  .xl\:bg-primary-lighter {
    background-color: var(--color-primary-lighter);
  }
  .xl\:text-primary-lighter {
    color: var(--color-primary-lighter);
  }
  .xl\:bg-lightblue-1 {
    background-color: var(--color-lightblue-1);
  }
  .xl\:text-lightblue-1 {
    color: var(--color-lightblue-1);
  }
  .xl\:bg-lightblue-2 {
    background-color: var(--color-lightblue-2);
  }
  .xl\:text-lightblue-2 {
    color: var(--color-lightblue-2);
  }
  .xl\:bg-gray-1 {
    background-color: var(--color-gray-1);
  }
  .xl\:text-gray-1 {
    color: var(--color-gray-1);
  }
  .xl\:bg-gray-2 {
    background-color: var(--color-gray-2);
  }
  .xl\:text-gray-2 {
    color: var(--color-gray-2);
  }
}
body {
  --color-base: #000;
  --color-error: #CF1E1E;
  --header-height: 92px;
  --container-size-sm: 1160px;
  --container-size-md: 1554px;
  --font-base: var(--font-noto);
  --font-poppins: "Poppins", sans-serif;
  --leading-relaxed: 1.75;
  --color-primary: #2B5188;
  --color-primary-rgb: 43 81 136;
  --color-primary-lighter: #3E74C1;
  --color-primary-lighter-rgb: 62 116 193;
  --color-lightblue-1: #EDF1F5;
  --color-lightblue-1-rgb: 237 241 245;
  --color-lightblue-2: #F8FBFE;
  --color-lightblue-2-rgb: 248 251 254;
  --color-gray-1: #888888;
  --color-gray-1-rgb: 136 136 136;
  --color-gray-2: #AAAAAA;
  --color-gray-2-rgb: 170 170 170;
}
@media (max-width: 767.98px) {
  body {
    --header-height: 80px;
  }
}

.font-poppins {
  font-family: var(--font-poppins);
}

#section-fv {
  padding-top: 167px;
}
@media (max-width: 767.98px) {
  #section-fv {
    padding-top: 64px;
  }
}

.section-fv-top-inner {
  display: flex;
  align-items: flex-end;
  gap: 20px;
  padding-right: 87px;
  padding-left: 84px;
}
@media (max-width: 767.98px) {
  .section-fv-top-inner {
    flex-direction: column;
    align-items: start;
    gap: 21px;
    padding-inline: var(--container-padding);
  }
}
.section-fv-top-inner p {
  padding-bottom: 20px;
  line-height: 1.714285714;
}
@media (max-width: 767.98px) {
  .section-fv-top-inner p {
    padding-bottom: 0;
    line-height: 1.666666667;
  }
}

.section-fv-top-title {
  width: clamp(42rem, 4.2834815756rem + 49.1740787802vw, 60.7rem);
  max-width: 100%;
}
@media (max-width: 767.98px) {
  .section-fv-top-title svg {
    vertical-align: middle;
  }
}
.section-fv-top-title .word-wrapper {
  overflow: hidden;
}

.section-fv-movie {
  aspect-ratio: 1728/910;
  margin-top: 55px;
}
@media (max-width: 767.98px) {
  .section-fv-movie {
    aspect-ratio: 1/1;
    margin-top: 34px;
  }
}
.section-fv-movie video {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  vertical-align: middle;
}

#section-client {
  position: relative;
  /* スライドの動き等速 */
  /* 画像のサイズ調整 */
}
#section-client .section-client-inner {
  display: flex;
  align-items: center;
  height: 228px;
  margin-top: 75px;
  background: url(../../../img/home/client_bg_ttl_pc.svg) no-repeat center center;
  background-size: cover;
}
@media screen and (max-width: 1728px) {}
@media (max-width: 767.98px) {
  #section-client .section-client-inner {
    height: auto;
    margin-block: 50px 36px;
    background-image: url(../../../img/home/client_bg_ttl_sp.svg);
    background-position: center;
    background-size: cover;
  }
}
@media screen and (max-width: 393px) {
  #section-client .section-client-inner {
    background-size: auto;
  }
}
#section-client .swiper-wrapper {
  transition-timing-function: linear;
}
#section-client .swiper {
  padding-inline: 10%;
}
#section-client .swiper-slide {
  width: auto;
  margin: auto;
  text-align: center;
  max-width: 80%;

}
@media (max-width: 767.98px) {
  #section-client .swiper-slide {
    width: auto;
    text-align: center;
  }
}
#section-client .swiper-slide :is(img, svg) {
  display: block;
  height: auto;
  width: 100%;

}
#section-client .container-md {
  position: absolute;
  inset: 0;
}
@media (max-width: 767.98px) {
  #section-client .container-md {
    position: relative;
  }
}
#section-client .section-client-text-wrapper {
  position: absolute;
  right: var(--container-padding);
  right: 14px;
  bottom: 20px;
}
@media (max-width: 767.98px) {
  #section-client .section-client-text-wrapper {
    bottom: 2px;
  }
}
#section-client .section-client-text {
  line-height: var(--leading-none);
}
@media (max-width: 767.98px) {
  #section-client .section-client-text {
    font-size: var(--text-xs);
  }
}

.section-company-subtitle {
  font-family: var(--font-poppins);
  line-height: var(--leading-none);
}

.section-company-title {
  margin-block: 64px 54px;
  font-size: clamp(2.4rem, 0.6457433291rem + 2.2871664549vw, 3.2rem);
  line-height: var(--leading-snug);
}
@media (max-width: 767.98px) {
  .section-company-title {
    margin-block: 31px 33px;
    font-size: var(--text-lg);
    line-height: 1.333333333;
  }
}

.section-company-text {
  font-size: var(--text-lg);
  line-height: var(--leading-loose);
}
@media (max-width: 767.98px) {
  .section-company-text {
    font-size: var(--text-xs);
    line-height: 1.857142857;
  }
}

#section-company {
  margin-top: 128px;
}
@media (max-width: 767.98px) {
  #section-company {
    margin-top: 56px;
  }
}
#section-company .text-link-primary-wrapper {
  margin-top: 64px;
}
@media (max-width: 767.98px) {
  #section-company .text-link-primary-wrapper {
    margin-top: 45px;
  }
}
#section-company .section-company-inner {
  display: grid;
  align-items: flex-start;
  justify-content: space-between;
  grid-template-columns: clamp(36.2rem, -2.198729352rem + 50.0635324015vw, 75.6rem) clamp(40rem, 20.5082592122rem + 25.4129606099vw, 60rem);
  gap: 20px;
}
@media (max-width: 767.98px) {
  #section-company .section-company-inner {
    display: flex;
    flex-direction: column;
    gap: 80px;
  }
}
#section-company .section-company-primary {
  padding-top: 20px;
}
@media (max-width: 767.98px) {
  #section-company .section-company-primary {
    padding-top: 0;
  }
}
#section-company .section-company-secondary {
  width: 100%;
  height: 100%;
}
@media (max-width: 767.98px) {
  #section-company .section-company-secondary {
    aspect-ratio: 393/103;
  }
}
#section-company .section-company-secondary .section-company-canvas-wrapper {
  position: relative;
  height: 100%;
}
@media (max-width: 767.98px) {
  #section-company .section-company-secondary .section-company-canvas-wrapper {
    margin-inline: calc(-1 * var(--container-padding));
  }
}
#section-company .section-company-secondary canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
@media (max-width: 767.98px) {
  #section-company .section-company-secondary canvas {
    position: static;
  }
}

#section-works {
  margin-top: clamp(7.8rem, 0.1007623888rem + 10.0381194409vw, 15.7rem);
}
#section-works .section-title {
  margin-bottom: clamp(3.5rem, 1.4533672173rem + 2.668360864vw, 5.6rem);
  font-size: clamp(3.6rem, -1.0780177891rem + 6.0991105464vw, 7.4rem);
  font-weight: var(--font-medium);
  font-family: var(--font-poppins);
  line-height: var(--leading-none);
}
#section-works .text-link-primary-wrapper {
  gap: clamp(3rem, -1.872935197rem + 6.3532401525vw, 6rem);
  margin-top: clamp(4.8rem, 1.8762388818rem + 3.8119440915vw, 7.8rem);
}

#section-camera {
  margin-top: clamp(8rem, 4.1016518424rem + 5.082592122vw, 12rem);
  padding: 40px 0;
  background-color: var(--color-black);
}
#section-camera .swiper-wrapper .swiper {
  padding-inline: 10%;
}
#section-camera .swiper-slide {
  width: clamp(31rem, 18.3303684879rem + 16.5184243964vw, 44rem);
  border-radius: 8px;
  overflow: hidden;
}
#section-camera .swiper-slide img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

#section-join {
  padding-top: clamp(6rem, 2.7372299873rem + 6.8614993647vw, 13.4rem);
  overflow: hidden;
}
#section-join .swiper-wrapper {
  transition-timing-function: linear;
}
#section-join .swiper-wrapper .swiper {
  padding-inline: 10%;
}
#section-join .swiper-slide {
  width: auto;
}
@media (max-width: 767.98px) {
  #section-join .swiper-slide {
    width: 590px;
  }
  #section-join .swiper-slide img {
    -o-object-fit: contain;
       object-fit: contain;
  }
}
#section-join .section-join-bottom {
  position: relative;
  z-index: 2;
  display: grid;
  position: relative;
  align-items: flex-start;
  grid-template-columns: clamp(27rem, -1.2630241423rem + 36.8487928844vw, 56rem) 1fr max-content;
  gap: clamp(4rem, -1.8475222363rem + 7.623888183vw, 10rem);
  padding-right: clamp(0rem, -7.7966963151rem + 10.165184244vw, 8rem);
  padding-bottom: 40px;
}
@media (max-width: 767.98px) {
  #section-join .section-join-bottom {
    grid-template-columns: 1fr max-content;
    padding-bottom: 40px;
  }
}
#section-join .section-join-bottom::before {
  display: block;
  content: "";
  position: absolute;
  z-index: -1;
  inset: 0;
  top: 110px;
  margin-inline: calc(50% - 50cqw);
  background-color: var(--color-lightblue-2);
}
@media (max-width: 767.98px) {
  #section-join .section-join-bottom::before {
    top: 20px;
  }
}
@media (min-width: 768px) {
  #section-join .section-join-bottom-inner {
    display: contents;
  }
}
#section-join .section-join-image {
  padding-top: 70px;
}
@media (max-width: 767.98px) {
  #section-join .section-join-image {
    margin-bottom: 32px;
    padding-top: 60px;
  }
  #section-join .section-join-image img {
    width: 100%;
  }
}
#section-join .section-join-content {
  margin-top: auto;
  padding-bottom: 36px;
}
@media (max-width: 767.98px) {
  #section-join .section-join-content {
    padding-bottom: 0;
  }
}
#section-join .section-join-text {
  margin-bottom: clamp(2.5rem, -1.3983481576rem + 5.082592122vw, 6.5rem);
  font-size: var(--text-lg);
}
@media (max-width: 767.98px) {
  #section-join .section-join-text {
    font-size: var(--text-xs);
    line-height: 1.857142857;
  }
}
