@charset "UTF-8";
.breadcrumb {
  position: absolute;
  top: 78px;
  left: 0;
  z-index: var(--z-base);
  width: 100%;
  padding: 0 calc(12 * var(--px)) 10px;
  overflow-x: auto;
}
.breadcrumb-list {
  display: flex;
  gap: calc(8 * var(--px));
  width: -moz-fit-content;
  width: fit-content;
  color: var(--color-blue);
}
.breadcrumb-list-item {
  display: flex;
  flex-shrink: 0;
  gap: calc(8 * var(--px));
  align-items: center;
  font-size: calc(0.625 * var(--rem));
  font-weight: 500;
  line-height: 1.3;
  pointer-events: auto;
}
.breadcrumb-list-item:not(:first-child)::before {
  content: '／';
}
.breadcrumb-list-item:last-child {
  padding-right: calc(12 * var(--px));
}
.breadcrumb-list-link-text {
  display: inline-block;
}
.breadcrumb-list-arrow {
  width: calc(9 * var(--px));
  height: calc(12 * var(--px));
}

@media screen and (min-width: 960px) {
  .breadcrumb {
    top: calc(108 * var(--px));
    width: 58.57vw;
    padding: 0 0 0 calc(52 * var(--px));
  }
  .breadcrumb-list {
    flex-wrap: wrap;
    background-color: transparent;
  }
  .breadcrumb-list-item {
    font-size: calc(0.8125 * var(--rem));
  }
  .breadcrumb-list-link-text {
    padding-bottom: 1px;
  }
}
.common-arrow {
  width: 100%;
  height: 100%;
  overflow: hidden;
  background-color: var(--color-blue);
  border-radius: 9999px;
}
.common-arrow-inner {
  display: flex;
  justify-content: flex-end;
  width: 100%;
  height: 100%;
}
.common-arrow-item {
  position: relative;
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}
.common-arrow-img {
  width: calc(12 * var(--px));
  height: calc(7 * var(--px));
}
.common-arrow.is-blank .common-arrow-inner {
  display: grid;
  grid-template-rows: 1fr;
  grid-template-columns: 1fr;
}
.common-arrow.is-blank .common-arrow-item {
  grid-row: 1;
  grid-column: 1;
}
.common-arrow.is-blank .common-arrow-item:nth-child(2) {
  transform: translate(-50%, 100%);
}
.common-arrow.is-blank .common-arrow-item img {
  transform: rotate(-45deg);
}

.future {
  position: relative;
}
.future-bg {
  position: sticky;
  top: 0;
  width: 100%;
  height: max(233.25vw, 100vh);
}
.future-inner {
  padding-bottom: calc(72 * var(--px));
  margin-top: min(-233.25vw, -100vh);
}

.fv-inner {
  position: relative;
  z-index: 1;
  padding: calc(117 * var(--px)) calc(16 * var(--px)) 0;
}
.fv-mv {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 233.25vw;
  overflow: hidden;
}
.fv-mv-object {
  position: absolute;
  opacity: var(--init-opacity);
}
.fv-mv-object:nth-child(1) {
  top: -4.5vw;
  left: -79.25vw;
  width: 245.5vw;
  height: 158.5vw;
  transform-origin: left top;
}
.fv-mv-object:nth-child(2) {
  top: 120.75vw;
  right: 0;
  width: 43.5vw;
  height: 65.25vw;
  transform-origin: right 70%;
}
.fv-title-sub {
  font-family: var(--font-oswald);
  font-size: calc(0.875 * var(--rem));
  font-weight: 400;
  line-height: 1.24;
  color: var(--color-blue);
  text-transform: uppercase;
  letter-spacing: 0.09em;
  opacity: var(--init-opacity);
}
.fv-title-sub .kakko {
  font-size: calc(0.9375 * var(--rem));
}
.fv-title-main {
  display: flex;
  flex-direction: column;
  gap: calc(1 * var(--rem));
  margin-top: calc(2 * var(--rem));
  font-size: calc(2 * var(--rem));
  font-weight: 600;
  line-height: 1;
  color: var(--color-blue);
  letter-spacing: 0.04em;
  opacity: var(--init-opacity);
}
.fv-title-main-text {
  display: flex;
  flex-direction: column;
  gap: calc(1 * var(--rem));
}
.fv-title-main-text-wrapper {
  display: flex;
  gap: calc(10 * var(--px));
  align-items: center;
}
.fv-title-main .keyword {
  padding: calc(0.25 * var(--rem)) calc(14 * var(--px)) calc(0.75 * var(--rem))
    calc(16 * var(--px));
  font-size: calc(3 * var(--rem));
  line-height: 1;
  color: var(--color-white);
  letter-spacing: 0.06em;
  background: linear-gradient(71deg, #3db7ec 0%, #05c3ae 111.89%);
  border-radius: calc(10 * var(--px));
}
.fv-intro {
  margin-top: calc(1.5 * var(--rem));
  font-size: calc(0.9375 * var(--rem));
  font-weight: 600;
  line-height: 1.7;
  color: var(--color-blue);
  letter-spacing: 0.04em;
  opacity: var(--init-opacity);
}

.for {
  position: relative;
  z-index: 1;
  margin: calc(3 * var(--rem)) calc(16 * var(--px)) 0;
}
.for-inner {
  display: grid;
  grid-template-columns: 1fr;
  grid-gap: calc(1.5 * var(--rem));
  gap: calc(1.5 * var(--rem));
  padding: calc(2.5 * var(--rem)) calc(32 * var(--px));
  background-color: var(--color-white);
  border-radius: calc(40 * var(--px));
  opacity: var(--init-opacity);
}
.for-head-title {
  display: flex;
  gap: calc(8 * var(--px));
  font-family: var(--font-shippori-antique);
  font-size: calc(1 * var(--rem));
  font-weight: 400;
  line-height: 1;
  color: var(--color-blue);
  letter-spacing: 0.04em;
}
.for-head-title::before {
  width: calc(32 * var(--px));
  height: 1px;
  margin-top: calc(0.5 * var(--rem));
  content: '';
  background-color: currentcolor;
}
.for-copy {
  font-family: var(--font-shippori-antique);
  font-size: calc(1.5 * var(--rem));
  font-weight: 400;
  line-height: 1.7;
  letter-spacing: 0.04em;
}
.for-case {
  display: grid;
  grid-template-columns: 1fr;
  grid-gap: calc(1.5 * var(--rem));
  gap: calc(1.5 * var(--rem));
  margin-top: calc(2 * var(--rem));
}
.for-case-item {
  display: flex;
  flex-direction: column;
  gap: calc(0.375 * var(--rem));
  padding-top: calc(0.75 * var(--rem));
  border-top: solid 1px #d0d0d0;
}
.for-case-item-headline {
  font-family: var(--font-shippori-antique);
  font-size: calc(1.25 * var(--rem));
  font-weight: 400;
  line-height: 1.7;
  letter-spacing: 0.04em;
}
.for-case-item-text {
  font-size: calc(1 * var(--rem));
  font-weight: 400;
  line-height: 1.7;
  letter-spacing: 0.04em;
}
.for-more {
  margin-top: calc(2 * var(--rem));
}
.for-more-link {
  position: relative;
  z-index: 1;
  width: 100%;
}
.for-more-link-bg {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
}
.for-more-link-inner {
  display: flex;
  flex-direction: column;
  padding: calc(0.5 * var(--rem)) 0 calc(18 * var(--px));
}
.for-more-link-content {
  display: contents;
}
.for-more-link-site {
  order: 1;
  padding: 0 calc(16 * var(--px));
  font-size: calc(0.875 * var(--rem));
  font-weight: 500;
  line-height: 1.5;
  color: var(--color-white);
}
.for-more-link-image {
  order: 2;
  width: 72vw;
  height: 57.5vw;
  margin: calc(0.6875 * var(--rem)) 0 0 auto;
  overflow: hidden;
  border-radius: 9999px 0 0 9999px;
}
.for-more-link-image-inner {
  width: 100%;
  height: 100%;
}
.for-more-link-page {
  display: flex;
  gap: calc(8 * var(--px));
  align-items: center;
  order: 3;
  width: -moz-fit-content;
  width: fit-content;
  padding: 0 calc(8 * var(--px)) 0 calc(10 * var(--px));
  margin: calc(1 * var(--rem)) calc(16 * var(--px)) 0 auto;
  color: var(--color-blue);
  background-color: var(--color-white);
}
.for-more-link-page-name {
  font-size: calc(1.125 * var(--rem));
  font-weight: 700;
  line-height: 1.5;
}
.for-more-link-page-arrow {
  width: calc(9 * var(--px));
  height: calc(6 * var(--px));
  transform: rotate(-45deg);
}

.career {
  margin-top: calc(24 * var(--px));
}
.career-inner {
  display: grid;
  grid-template-columns: 1fr;
  grid-gap: calc(24 * var(--px));
  gap: calc(24 * var(--px));
  padding: 0 calc(16 * var(--px));
}
.career-item-inner {
  display: flex;
  flex-direction: column;
  gap: calc(1.5 * var(--rem));
  padding: calc(2.5 * var(--rem)) calc(32 * var(--px));
  background-color: var(--color-white);
  border-radius: calc(40 * var(--px));
  opacity: var(--init-opacity);
}
.career-item-head-category {
  display: flex;
  gap: calc(8 * var(--px));
  font-family: var(--font-shippori-antique);
  font-size: calc(1 * var(--rem));
  font-weight: 400;
  line-height: 1;
  color: var(--color-blue);
  letter-spacing: 0.04em;
}
.career-item-head-category::before {
  width: calc(32 * var(--px));
  height: 1px;
  margin-top: calc(0.5 * var(--rem));
  content: '';
  background-color: currentcolor;
}
.career-item-title {
  margin-right: -0.5em;
  font-family: var(--font-shippori-antique);
  font-size: calc(1.5 * var(--rem));
  font-weight: 400;
  line-height: 1.7;
  letter-spacing: 0.04em;
}
.career-item-text {
  margin-top: calc(1 * var(--rem));
  font-size: calc(1 * var(--rem));
  font-weight: 400;
  line-height: 1.7;
  letter-spacing: 0.04em;
}
.career-item-link {
  display: flex;
  gap: calc(16 * var(--px));
  align-items: center;
  width: -moz-fit-content;
  width: fit-content;
  margin: calc(1.5 * var(--rem)) 0 0 auto;
}
.career-item-link-text {
  font-size: calc(1 * var(--rem));
  font-weight: 700;
  line-height: 1.5;
  color: var(--color-blue);
}
.career-item-link-arrow {
  width: calc(63 * var(--px));
  height: calc(23 * var(--px));
}

.bottom {
  padding: 0 calc(16 * var(--px)) calc(64 * var(--px));
  margin-top: calc(64 * var(--px));
}
.bottom-link {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 66.5vw;
}
.bottom-link-image {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
}
.bottom-link-inner {
  display: flex;
  flex-direction: column;
  gap: calc(16 * var(--px));
  align-items: center;
}
.bottom-link-title {
  padding: calc(0.25 * var(--rem)) calc(12 * var(--px));
  font-size: calc(1.25 * var(--rem));
  font-weight: 700;
  line-height: 1.5;
  color: var(--color-blue);
  background-color: var(--color-white);
}
.bottom-link-arrow {
  width: calc(63 * var(--px));
  height: calc(23 * var(--px));
}

@media screen and (min-width: 960px) {
  .future-bg {
    height: max(68.3vw, 100vh);
  }
  .future-inner {
    padding-bottom: calc(120 * var(--px));
    margin-top: min(-68.3vw, -100vh);
  }
  .fv-inner {
    display: grid;
    grid-template-rows: min-content;
    grid-template-columns: repeat(var(--grid-columns), 1fr);
    padding: calc(200 * var(--px)) 0 0;
  }
  .fv-mv {
    height: 68.3vw;
  }
  .fv-mv-object:nth-child(1) {
    top: calc(-126 * var(--px));
    left: calc(-175 * var(--px));
    width: calc(1211 * var(--px));
    height: calc(782 * var(--px));
  }
  .fv-mv-object:nth-child(2) {
    top: calc(281 * var(--px));
    width: calc(597 * var(--px));
    height: calc(448 * var(--px));
  }
  .fv-title {
    grid-column: 3/39;
  }
  .fv-title-sub {
    font-size: calc(1 * var(--rem));
    font-weight: 500;
  }
  .fv-title-sub .kakko {
    font-size: calc(1 * var(--rem));
  }
  .fv-title-main {
    gap: calc(1.5 * var(--rem));
    margin-top: calc(1.375 * var(--rem));
    font-size: calc(2.5 * var(--rem));
  }
  .fv-title-main-text {
    flex-direction: row;
    gap: 0;
  }
  .fv-title-main .keyword {
    font-size: calc(4 * var(--rem));
  }
  .fv-intro {
    grid-column: 3/39;
    margin-top: calc(2.25 * var(--rem));
    font-size: calc(1 * var(--rem));
  }
  .for {
    display: grid;
    grid-template-rows: min-content;
    grid-template-columns: repeat(var(--grid-columns), 1fr);
    margin: calc(5 * var(--rem)) 0 0;
  }
  .for-inner {
    grid-template-columns: auto 1fr;
    grid-column: 3/39;
    gap: 4.69vw;
    padding: calc(4.5 * var(--rem)) calc(64 * var(--px));
    border-radius: calc(56 * var(--px));
  }
  .for-head-title {
    flex-direction: column;
    align-items: center;
    font-size: calc(1.125 * var(--rem));
  }
  .for-head-title::before {
    width: 1px;
    height: calc(32 * var(--px));
    margin-top: 0;
  }
  .for-head-title-text {
    writing-mode: vertical-lr;
  }
  .for-copy {
    font-size: calc(1.75 * var(--rem));
  }
  .for-case {
    grid-template-columns: repeat(2, 1fr);
    row-gap: calc(2.5 * var(--rem));
    -moz-column-gap: 4.1vw;
    column-gap: 4.1vw;
    padding-right: 4.54vw;
    margin-top: calc(3.5 * var(--rem));
  }
  .for-case-item {
    padding-top: calc(1 * var(--rem));
  }
  .for-case-item-headline {
    font-size: calc(1.5 * var(--rem));
  }
  .for-more {
    margin-top: calc(5 * var(--rem));
  }
  .for-more-link-inner {
    flex-direction: row;
    gap: calc(20 * var(--px));
    align-items: center;
    justify-content: space-between;
    padding: calc(32 * var(--px)) 7.03vw;
  }
  .for-more-link-content {
    display: block;
    order: 2;
  }
  .for-more-link-site {
    padding: 0;
  }
  .for-more-link-image {
    order: 1;
    width: 43.56vw;
    height: 19.91vw;
    margin: 0;
    border-radius: 9999px;
  }
  .for-more-link-page {
    gap: calc(9 * var(--px));
    padding: 0 calc(10 * var(--px)) 0 calc(4 * var(--px));
    margin: calc(0.5625 * var(--rem)) 0 0;
  }
  .career {
    display: grid;
    grid-template-rows: min-content;
    grid-template-columns: repeat(var(--grid-columns), 1fr);
    margin-top: calc(48 * var(--px));
  }
  .career-inner {
    grid-template-columns: repeat(2, 1fr);
    grid-column: 3/39;
    row-gap: calc(32 * var(--px));
    -moz-column-gap: 2.34vw;
    column-gap: 2.34vw;
    padding: 0;
  }
  .career-item-inner {
    gap: calc(1 * var(--rem));
    height: 100%;
    padding: calc(4 * var(--rem)) calc(64 * var(--px));
    border-radius: calc(56 * var(--px));
  }
  .career-item-head-category {
    font-size: calc(1.125 * var(--rem));
  }
  .career-item-title {
    margin-right: 0;
    font-size: calc(1.75 * var(--rem));
  }
  .career-item-text {
    margin-top: calc(1.5 * var(--rem));
  }
  .career-item.--large {
    grid-column: 1/3;
    margin-bottom: calc(16 * var(--px));
  }
  .career-item.--large .career-item-inner {
    flex-direction: row;
    -moz-column-gap: 4.1vw;
    column-gap: 4.1vw;
  }
  .career-item.--large .career-item-head {
    flex-shrink: 0;
  }
  .career-item.--large .career-item-head-category {
    flex-direction: column;
    align-items: center;
  }
  .career-item.--large .career-item-head-category::before {
    width: 1px;
    height: calc(32 * var(--px));
    margin-top: 0;
  }
  .career-item.--large .career-item-head-category-text {
    writing-mode: vertical-lr;
  }
  .bottom {
    display: grid;
    grid-template-rows: min-content;
    grid-template-columns: repeat(var(--grid-columns), 1fr);
    padding: 0 0 calc(96 * var(--px));
    margin-top: calc(96 * var(--px));
  }
  .bottom-link {
    grid-column: 3/39;
    height: 26.35vw;
  }
  .bottom-link-title {
    font-size: calc(1.5 * var(--rem));
  }
}
@media (any-hover: hover) {
  .for-more-link {
    overflow: hidden;
    transition: border-radius 0.4s var(--ease-out-quart);
  }
  .for-more-link:hover {
    border-radius: calc(64 * var(--px));
  }
  .career-item-link {
    --underline-width: 1px;
  }
  .bottom-link {
    overflow: hidden;
    transition: border-radius 0.4s var(--ease-out-quart);
  }
  .bottom-link:hover {
    border-radius: calc(64 * var(--px));
  }
}
