@charset "UTF-8";
* {
  position: relative;
  border: solid 0px #888;
  font: inherit;
  line-height: inherit;
  letter-spacing: 0.1em;
  color: inherit;
}

html,
body {
  overflow: hidden auto;
  min-height: 100vh;
  height: 100vh;
  max-height: 100vh;
  min-width: 100vw;
  width: 100vw;
  max-width: 100vw;
  margin: 0;
  padding: 0;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 300;
  line-height: 1.5;
  background-color: #fff;
  color: #565656;
  overscroll-behavior: none;
  scroll-padding-top: 200px;
  scroll-behavior: smooth;
}

.serif {
  font-family: "Noto Serif JP";
}

a {
  color: -webkit-link;
}

::-webkit-scrollbar {
  -webkit-appearance: none;
          appearance: none;
  width: 10px;
  height: 10px;
  border-radius: 10px;
  background-color: rgba(0, 0, 0, 0.0666666667);
}

::-webkit-scrollbar-thumb {
  -webkit-appearance: none;
          appearance: none;
  width: 6px;
  height: 6px;
  border-radius: 6px;
  background-color: rgba(0, 0, 0, 0.2666666667);
  border: 2px solid transparent;
  background-clip: padding-box;
}

::-moz-placeholder {
  color: rgba(98, 78, 70, 0.5019607843);
}

::placeholder {
  color: rgba(98, 78, 70, 0.5019607843);
}

input,
.input,
textarea,
select,
.select {
  border: solid 1.5px #888;
  padding: 0.4em 0.5em;
  height: 1.5em;
  width: dpx(300);
}

select,
.select {
  height: 2.5em;
  padding: 0.3em 0.5em;
  width: calc(dpx(302) + 1em);
}

input,
.input,
textarea,
select,
.select {
  background-color: #eff;
}

.inputs,
.selects {
  border-radius: dpx(5);
}

textarea {
  min-height: dpx(150);
  height: dpx(150);
}

table {
  border-collapse: collapse;
  background-color: #fff;
}

th,
td {
  text-align: left;
  border: solid 0 #1d1c1d;
  box-shadow: inset 1px 1px #1d1c1d, inset -1px -1px #1d1c1d;
  padding: 0.5em 0.5em;
  white-space: normal;
  background-color: #fff;
  overflow: auto;
}

thead {
  position: sticky;
  top: 0px;
  z-index: 2;
  background-color: #fff;
}

tfoot {
  position: sticky;
  bottom: 0px;
  z-index: 2;
  background-color: #fff;
}

th {
  position: sticky;
  left: 0px;
  z-index: 1;
}

.tc {
  text-align: center;
}

.ts {
  text-align: start;
}

.te {
  text-align: end;
}

.fixed {
  position: fixed;
}

.rel {
  position: relative;
}

.abs {
  position: absolute;
}

.f {
  display: flex;
}

.if {
  display: inline-flex;
}

.v {
  flex-direction: column;
}

.fa {
  display: flex;
  justify-content: space-around;
}

.fac {
  display: flex;
  justify-content: space-around;
  align-items: center;
  align-content: center;
}

.fb {
  display: flex;
  justify-content: space-between;
}

.fbc {
  display: flex;
  justify-content: space-between;
  align-items: center;
  align-content: center;
}

.fbe {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  align-content: flex-end;
}

.fbs {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  align-content: flex-start;
}

.fc {
  display: flex;
  justify-content: center;
}

.fcc {
  display: flex;
  justify-content: center;
  align-items: center;
  align-content: center;
  align-items: center;
  align-content: center;
}

.fce {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  align-content: flex-end;
}

.fcs {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  align-content: center;
}

.fe {
  display: flex;
  justify-content: space-evenly;
}

.fee {
  display: flex;
  justify-content: space-evenly;
  align-items: flex-end;
  align-content: flex-end;
}

.fend {
  display: flex;
  justify-content: flex-end;
}

.fes {
  display: flex;
  justify-content: space-evenly;
  align-items: flex-start;
  align-content: flex-start;
}

.fec {
  display: flex;
  justify-content: space-evenly;
  align-items: center;
  align-content: center;
}

.fendc {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  align-content: center;
}

.fende {
  display: flex;
  justify-content: flex-end;
  align-items: flex-end;
  align-content: flex-end;
}

.fs {
  display: flex;
  justify-content: flex-start;
}

.fsc {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  align-content: center;
}

.fxc {
  display: flex;
  align-items: center;
  align-content: center;
}

.fxe {
  display: flex;
  align-items: flex-end;
  align-content: flex-end;
}

.fxs {
  display: flex;
  align-items: flex-start;
  align-content: flex-start;
}

.bsb {
  box-sizing: border-box;
}

.wrap {
  flex-wrap: wrap;
}

.nowrap {
  flex-wrap: nowrap;
  text-wrap: nowrap;
}

.hidden {
  display: none;
}

.noselect {
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}

.notouch {
  touch-action: none;
  pointer-events: none;
}

.nodeco {
  color: inherit;
  text-decoration: none;
}

.nodeco2 {
  text-decoration: none;
}

.bn {
  border: none;
}

.pointer {
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}

.ofhh {
  overflow: hidden hidden;
}

.ofh {
  overflow: hidden;
}

.ofha {
  overflow: hidden auto;
}

.ofah {
  overflow: auto hidden;
}

.ofaa {
  overflow: auto auto;
}

.ofa {
  overflow: auto;
}

.wa {
  width: -moz-fit-content;
  width: fit-content;
}

.ha {
  height: auto !important;
}

@media screen and (min-width: 769px) {
  .sp {
    display: none;
  }
  .pct {
    opacity: 0.001;
  }
}
@media screen and (max-width: 768px) {
  .pc {
    display: none;
  }
  .spt {
    opacity: 0.001;
  }
  .spv {
    flex-direction: column;
  }
}
.check {
  background-color: 2px solid #e87122;
  border-radius: 6px;
  position: relative;
}
.check.checked {
  background-color: #e87122;
}
.check.checked::after {
  content: "✔";
  color: #fff;
  position: absolute;
  font-size: 16px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.nav-links a.current-page {
  color: #fbc157 !important;
}

.hover {
  color: inherit;
  transition: color 0.5s ease;
}
.hover:hover {
  color: blue;
}

.bold {
  font-weight: bold;
}

.normal {
  font-weight: normal;
}

.shadow1 {
  box-shadow: rgba(0, 0, 0, 0.1568627451) 0px 3px 6px;
}

.shadow2 {
  box-shadow: 1px 4px 50px 10px rgba(20, 24, 60, 0.29);
}

.shadow3 {
  box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
}

.t-shadow1 {
  text-shadow: rgba(0, 0, 0, 0.1568627451) 0px 3px 6px;
}

.img1px {
  width: 1px;
  max-width: 1px;
  height: 1px;
  max-height: 1px;
}

.cover {
  -o-object-fit: cover;
     object-fit: cover;
}

.pc.header {
  height: 80px;
}

.pcmain {
  padding-top: 80px;
}

.ib {
  display: inline-block;
}

.b {
  display: block;
}

#loader {
  position: fixed;
  inset: 0;
  background: #fff;
  display: grid;
  place-items: center;
  z-index: 9999;
  transition: opacity 0.8s ease, visibility 0.8s ease;
}

body.loaded #loader {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.loader-wrap {
  display: grid;
  place-items: center;
  gap: 14px;
}

.loader-line {
  width: 220px;
  height: 2px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.12);
  position: relative;
  overflow: hidden;
}

.loader-line::after {
  content: "";
  position: absolute;
  inset: 0;
  transform: translateX(-80%);
  background: linear-gradient(90deg, transparent 0%, rgba(1, 107, 181, 0.65) 35%, rgba(255, 0, 0, 0.55) 65%, transparent 100%);
  animation: loaderSweep 1s ease-in-out infinite;
}

@keyframes loaderSweep {
  0% {
    transform: translateX(-90%);
  }
  100% {
    transform: translateX(90%);
  }
}
.loader-caption {
  font-size: 14px;
  letter-spacing: 0.08em;
  color: rgba(0, 0, 0, 0.55);
}

@media (prefers-reduced-motion: reduce) {
  .loader-line::after {
    animation: none;
  }
}
.ham-btn {
  position: relative;
  width: 38px;
  height: 38px;
  border-radius: 0;
  background: linear-gradient(180deg, #5db77d 0%, #00735c 100%);
  cursor: pointer;
  transition: background-color 0.35s ease;
}

.ham-btn .ham-bar {
  position: absolute;
  left: 50%;
  width: 24px;
  height: 2px;
  background: #fff;
  border-radius: 999px;
  transform: translate(-50%, -50%);
  transform-origin: center;
  transition: top 0.35s ease, transform 0.35s ease, opacity 0.2s ease, background-color 0.35s ease;
}

.ham-btn .ham-bar:nth-child(1) {
  top: 17px;
}

.ham-btn .ham-bar:nth-child(2) {
  top: 24px;
}

.ham-btn .ham-bar:nth-child(3) {
  top: 31px;
}

.ham-btn.active {
  background: #fff;
}

.ham-btn.active .ham-bar {
  background: #2f9d72;
}

.ham-btn.active .ham-bar:nth-child(1) {
  top: 24px;
  transform: translate(-50%, -50%) rotate(45deg);
}

.ham-btn.active .ham-bar:nth-child(2) {
  opacity: 0;
}

.ham-btn.active .ham-bar:nth-child(3) {
  top: 24px;
  transform: translate(-50%, -50%) rotate(-45deg);
}

.grad1 {
  opacity: 0.7;
  background: linear-gradient(214deg, #359814 -7.68%, #07f 79.66%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.grad-bg-1 {
  background: linear-gradient(90deg, rgba(73, 158, 227, 0.9) 0%, rgba(20, 192, 114, 0.9) 100%);
}
.grad-bg-2 {
  background: linear-gradient(269deg, rgba(74, 212, 175, 0.6) 26.47%, rgba(49, 92, 81, 0.6) 116.69%);
}
.grad-bg-2-8 {
  background: linear-gradient(269deg, rgba(74, 212, 175, 0.8) 26.47%, rgba(49, 92, 81, 0.8) 116.69%);
}
.grad-bg-3 {
  background: linear-gradient(269deg, #4ad4af 26.47%, #315c51 116.69%);
}
.grad-bg-4 {
  background: linear-gradient(241deg, #e6e6e6 8.74%, #b9d6ce 61.61%, #5eb69d 91.11%);
}
.grad-bg-5 {
  background: linear-gradient(269deg, rgba(74, 212, 175, 0.6) 26.47%, rgba(255, 255, 255, 0.6) 116.69%);
}
.grad-bg-6 {
  background: linear-gradient(90deg, rgba(74, 212, 175, 0.7) 26.47%, rgba(49, 92, 81, 0.7) 116.69%);
}
.grad-bg-7 {
  background: linear-gradient(300deg, rgba(74, 212, 175, 0.6) -67.63%, rgba(62, 152, 128, 0.6) -30.78%, rgba(0, 31, 23, 0.6) 81.87%);
}
.grad-bg-8 {
  background: linear-gradient(237deg, #178e6c 31.49%, #58cead 69.01%, #dff0e9 94.41%);
}
.grad-bg-9 {
  background: linear-gradient(250deg, #76ac8c 4.05%, #8cc6b5 87.63%);
}
.grad-bg-10 {
  background: linear-gradient(90deg, #3b8762 0%, #299dd7 100%);
}
.grad-bg-11 {
  background: linear-gradient(180deg, #5db77d 0%, #00735c 100%);
}
.grad-bg-12 {
  background: linear-gradient(241deg, #a2f3ff 8.74%, #07966e 91.11%);
}
.grad-bg-13 {
  background: linear-gradient(269deg, #4ad4af 26.47%, #3240ff 116.69%);
}

.btn1 {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  text-decoration: none;
  background: linear-gradient(269deg, #4ad4af 26.47%, #315c51 116.69%);
  box-shadow: 0 3.451px 3.451px 0 rgba(0, 0, 0, 0.25);
}

.btn2 {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  background: #fff;
  box-shadow: 0 3.451px 3.451px 0 rgba(0, 0, 0, 0.25);
}

.btn-text {
  text-align: center;
}

.btn-arrow {
  position: absolute;
  right: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  border-radius: 50%;
}
.btn-arrow::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 47%;
  width: 10px;
  height: 10px;
  border-right: 3px solid #8cc6b5;
  border-top: 3px solid #8cc6b5;
  transform: translate(-58%, -50%) rotate(45deg);
  box-sizing: border-box;
}

.btn-arrow2 {
  position: absolute;
  right: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #49cfac;
  border-radius: 50%;
}
.btn-arrow2::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 47%;
  width: 10px;
  height: 10px;
  border-right: 3px solid #fff;
  border-top: 3px solid #fff;
  transform: translate(-58%, -50%) rotate(45deg);
  box-sizing: border-box;
}

@media screen and (max-width: 768px) {
  .btn-arrow::before {
    left: 46%;
    border-right: 2px solid #8cc6b5;
    border-top: 2px solid #8cc6b5;
  }
  .btn-arrow2::before {
    left: 46%;
    border-right: 2px solid #fff;
    border-top: 2px solid #fff;
  }
}
.title1 {
  color: #40927d;
  font-family: Orbitron;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
}

.history-row {
  display: grid;
  grid-template-columns: 100px 1fr;
  -moz-column-gap: 16px;
       column-gap: 16px;
  align-items: start;
}

.history-date {
  color: #8a8a8a;
  font-size: 18px;
  line-height: 1.4;
  letter-spacing: 0;
}

.history-text {
  color: #8a8a8a;
  font-size: 18px;
  line-height: 1.4;
  letter-spacing: 0;
}

@media screen and (max-width: 768px) {
  .history-date {
    font-size: 14px;
  }
  .history-text {
    font-size: 14px;
  }
}
.map-wrap iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

.sideword {
  writing-mode: vertical-rl;
  text-orientation: mixed;
  letter-spacing: 0;
  line-height: 1;
}

.sideword2 {
  writing-mode: vertical-rl;
  text-orientation: mixed;
  letter-spacing: 0;
  line-height: 1;
  transform: rotate(180deg);
}

.fit {
  display: inline-block;
  width: -moz-fit-content;
  width: fit-content;
  height: -moz-fit-content;
  height: fit-content;
}

.hero-connect {
  overflow: hidden;
  white-space: nowrap;
}

.anim-hero-connect {
  opacity: 1;
}

.hero-char {
  display: inline-block;
  opacity: 0;
  will-change: transform, opacity, filter;
  backface-visibility: hidden;
  transform-origin: left center;
  filter: blur(8px);
}

.hero-char-1 {
  transform: translate3d(-56px, 0, 0);
}

.hero-char-2 {
  transform: translate3d(-42px, 0, 0);
  margin-left: -0.43em;
}

.hero-char-3 {
  transform: translate3d(-28px, 0, 0);
  margin-left: -0.34em;
}

.anim-hero-connect.is-animated .hero-char-1 {
  animation: heroCharFlow 1.25s cubic-bezier(0.22, 1, 0.36, 1) 0s forwards;
}

.anim-hero-connect.is-animated .hero-char-2 {
  animation: heroCharFlow 1.25s cubic-bezier(0.22, 1, 0.36, 1) 0.18s forwards;
}

.anim-hero-connect.is-animated .hero-char-3 {
  animation: heroCharFlow 1.25s cubic-bezier(0.22, 1, 0.36, 1) 0.36s forwards;
}

@keyframes heroCharFlow {
  0% {
    opacity: 0;
    filter: blur(8px);
  }
  55% {
    opacity: 0.9;
    filter: blur(1.2px);
  }
  100% {
    opacity: 1;
    transform: translate3d(0, 0, 0);
    filter: blur(0);
  }
}
.sp-hero-connect {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  overflow: hidden;
  width: -moz-fit-content;
  width: fit-content;
  margin-top: 0;
  margin-left: 0;
}

.sp-hero-char {
  display: block;
  line-height: 1;
  opacity: 0;
  will-change: transform, opacity, filter;
  backface-visibility: hidden;
  filter: blur(8px);
}

.sp-hero-char-1 {
  font-size: 200px;
  transform: translate3d(0, -56px, 0);
}

.sp-hero-char-2 {
  font-size: 96px;
  padding-left: 50px;
  margin-top: 10px;
  transform: translate3d(0, -42px, 0);
}

.sp-hero-char-3 {
  font-size: 96px;
  padding-left: 100px;
  margin-top: -10px;
  transform: translate3d(0, -28px, 0);
}

.anim-hero-connect.is-animated .sp-hero-char-1 {
  animation: heroCharFlowSp 1.25s cubic-bezier(0.22, 1, 0.36, 1) 0s forwards;
}

.anim-hero-connect.is-animated .sp-hero-char-2 {
  animation: heroCharFlowSp 1.25s cubic-bezier(0.22, 1, 0.36, 1) 0.18s forwards;
}

.anim-hero-connect.is-animated .sp-hero-char-3 {
  animation: heroCharFlowSp 1.25s cubic-bezier(0.22, 1, 0.36, 1) 0.36s forwards;
}

@keyframes heroCharFlowSp {
  0% {
    opacity: 0;
    filter: blur(8px);
  }
  55% {
    opacity: 0.6;
    filter: blur(1.2px);
  }
  100% {
    opacity: 0.7;
    transform: translate3d(0, 0, 0);
    filter: blur(0);
  }
}
.hero-media {
  overflow: hidden;
}

.hero-media__img,
.hero-media__video {
  display: block;
  width: 100%;
  height: auto;
}

.hero-media__video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  opacity: 0;
  transition: opacity 0.8s ease;
  pointer-events: none;
}

.hero-media.is-video-ready .hero-media__video {
  opacity: 1;
}

.hero-media__img {
  transition: opacity 0.8s ease;
}

.hero-media.is-video-ready .hero-media__img {
  opacity: 0;
}

.job-link {
  width: 100%;
  padding: 0 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: transparent;
  border: none;
  cursor: pointer;
  font: inherit;
  color: inherit;
  text-align: left;
}

.job-toggle-mark {
  font-size: 28px;
  line-height: 1.3;
  transition: transform 0.3s ease, opacity 0.3s ease;
}

.job-accordion.is-open .job-toggle-mark {
  transform: rotate(180deg);
}

.job-detail {
  height: 0;
  overflow: hidden;
  transition: height 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}

.job-detail-inner {
  padding: 0 0 30px;
  opacity: 0;
  transform: translateY(-8px);
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.job-accordion.is-open .job-detail-inner {
  opacity: 1;
  transform: translateY(0);
}

.rotate90 {
  transform: rotate(90deg);
}

.pagetop {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  transition: transform 0.25s ease, opacity 0.25s ease, background-color 0.25s ease;
}

.pagetop:hover {
  transform: translateY(-4px);
  background: #a8cfbf;
}

.pagetop__arrow {
  width: 22px;
  height: 22px;
  border-left: 5px solid #8cc6b5;
  border-top: 5px solid #8cc6b5;
  transform: rotate(45deg) translate(4px, 4px);
  display: block;
}

@media screen and (max-width: 768px) {
  .pagetop {
    width: 54px;
    height: 54px;
  }
  .pagetop__arrow {
    width: 16px;
    height: 16px;
    border-left: 4px solid #8cc6b5;
    border-top: 4px solid #8cc6b5;
  }
}
.link-circle-arrow {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  text-decoration: none;
  color: #fff;
  font-size: 22px;
  font-weight: 500;
  letter-spacing: 0.08em;
}

.link-circle-arrow__text {
  line-height: 1.2;
}

.link-circle-arrow__icon {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: #fff;
  position: relative;
  flex-shrink: 0;
}

.link-circle-arrow__icon::before {
  content: "";
  position: absolute;
  top: 46%;
  left: 50%;
  width: 10px;
  height: 10px;
  border-right: 3px solid #444;
  border-bottom: 3px solid #444;
  transform: translate(-50%, -60%) rotate(45deg);
}

.link-circle-arrow:hover .link-circle-arrow__icon {
  transform: translateY(2px);
  transition: transform 0.2s ease;
}

@media screen and (max-width: 768px) {
  .link-circle-arrow {
    gap: 5px;
    font-size: 18px;
  }
  .link-circle-arrow__icon::before {
    width: 8px;
    height: 8px;
    border-right: 2px solid #444;
    border-bottom: 2px solid #444;
  }
}
.link-circle-arrow2 {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  text-decoration: none;
  font-weight: 500;
  letter-spacing: 0.08em;
}

.link-circle-arrow2__text {
  line-height: 1.2;
}

.link-circle-arrow2__icon {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #f2f2f2;
  position: relative;
  flex-shrink: 0;
}

.link-circle-arrow2__icon::before {
  content: "";
  position: absolute;
  top: 46%;
  left: 50%;
  width: 7px;
  height: 7px;
  border-right: 2px solid #000;
  border-bottom: 2px solid #000;
  transform: translate(-50%, -60%) rotate(45deg);
}

.link-circle-arrow2:hover .link-circle-arrow__icon {
  transform: translateY(2px);
  transition: transform 0.2s ease;
}

.interview-modal {
  position: fixed;
  inset: 0;
  z-index: 5000;
  display: none;
}

.interview-modal.is-open {
  display: block;
}

.interview-modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.35);
}

.interview-modal__dialog {
  position: absolute;
  top: 50%;
  left: 50%;
  width: min(70%, 100vw - 40px);
  max-height: calc(100vh - 40px);
  transform: translate(-50%, -50%);
  background: #fff;
  border-radius: 32px;
  overflow: hidden;
  box-sizing: border-box;
}

.interview-modal__inner {
  position: relative;
  padding: 50px 100px 40px;
  overflow-y: auto;
  max-height: calc(100vh - 40px);
}

.interview-modal__close {
  position: absolute;
  top: 22px;
  right: 24px;
  z-index: 2;
  border: none;
  background: transparent;
  color: #6cab9a;
  font-size: 38px;
  line-height: 1;
  cursor: pointer;
}

.interview-modal__icon-wrap {
  display: flex;
  justify-content: center;
  margin-bottom: 12px;
}

.interview-modal__icon {
  width: 60px;
}

.interview-modal__name {
  text-align: center;
  color: #7e7e7e;
  font-size: 22px;
  font-weight: 500;
  margin-bottom: 50px;
}

.interview-qa {
  margin-bottom: 70px;
}

.interview-qa:last-child {
  margin-bottom: 0;
}

.interview-qa__qrow {
  display: flex;
  align-items: center;
}

.interview-qa__arow {
  display: flex;
  align-items: flex-start;
}

.interview-qa__qrow {
  padding-bottom: 10px;
}

.interview-qa__mark {
  flex: 0 0 52px;
  color: #69a994;
  font-size: 42px;
  font-weight: 700;
  line-height: 1;
}

.interview-qa__mark--a {
  color: #E4E4E4;
}

.interview-qa__qcol,
.interview-qa__acol {
  flex: 1;
  min-width: 0;
}

.interview-qa__qwrap {
  position: relative;
  padding-top: 4px;
}

.interview-qa__qtext {
  color: #6BA895;
  font-size: 28px;
  font-weight: 700;
  line-height: 1.5;
}

.interview-qa__atext {
  color: #555;
  font-size: 15px;
  line-height: 2;
}

.interview-qa__bubbleimg {
  position: absolute;
  top: -40px;
  right: -40px;
  width: 150px;
  max-width: none;
  z-index: 2;
  pointer-events: none;
}

.interview-qa__qtext,
.interview-qa__atext {
  white-space: pre-line;
}

@media screen and (max-width: 767px) {
  .interview-qa {
    margin-bottom: 26px;
  }
  .interview-qa__mark {
    flex: 0 0 34px;
    font-size: 28px;
  }
  .interview-qa__qtext {
    font-size: 18px;
    line-height: 1.5;
  }
  .interview-qa__atext {
    font-size: 12px;
    line-height: 1.9;
  }
  .interview-qa__bubbleimg {
    display: none;
  }
}
.anim-up-item,
.anim-fade-item,
.anim-down-item,
.anim-left-item,
.anim-right-item,
.anim-bg-item,
.anim-pop-item {
  opacity: 0;
  will-change: opacity, transform, filter;
}

.anim-up-item {
  transform: translateY(70px) scale(0.97);
  filter: blur(6px);
  transition: opacity 0.75s cubic-bezier(0.22, 1, 0.36, 1), transform 0.75s cubic-bezier(0.22, 1, 0.36, 1), filter 0.75s cubic-bezier(0.22, 1, 0.36, 1);
}

.anim-up-item.is-animated {
  opacity: 1;
  transform: translateY(0) scale(1);
  filter: blur(0);
}

.anim-fade-item {
  transform: translateY(16px);
  filter: blur(2px);
  transition: opacity 0.9s ease, transform 0.9s ease, filter 0.9s ease;
}

.anim-fade-item.is-animated {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}

.anim-down-item {
  transform: translateY(-70px) scale(0.97);
  filter: blur(6px);
  transition: opacity 0.75s cubic-bezier(0.22, 1, 0.36, 1), transform 0.75s cubic-bezier(0.22, 1, 0.36, 1), filter 0.75s cubic-bezier(0.22, 1, 0.36, 1);
}

.anim-down-item.is-animated {
  opacity: 1;
  transform: translateY(0) scale(1);
  filter: blur(0);
}

.anim-left-item {
  transform: translateX(-70px) scale(0.97);
  filter: blur(6px);
  transition: opacity 0.75s cubic-bezier(0.22, 1, 0.36, 1), transform 0.75s cubic-bezier(0.22, 1, 0.36, 1), filter 0.75s cubic-bezier(0.22, 1, 0.36, 1);
}

.anim-left-item.is-animated {
  opacity: 1;
  transform: translateX(0) scale(1);
  filter: blur(0);
}

.anim-right-item {
  transform: translateX(70px) scale(0.97);
  filter: blur(6px);
  transition: opacity 0.75s cubic-bezier(0.22, 1, 0.36, 1), transform 0.75s cubic-bezier(0.22, 1, 0.36, 1), filter 0.75s cubic-bezier(0.22, 1, 0.36, 1);
}

.anim-right-item.is-animated {
  opacity: 1;
  transform: translateX(0) scale(1);
  filter: blur(0);
}

.anim-pop-item {
  transform: translateY(40px) scale(0.92);
  filter: blur(3px);
}

.anim-pop-item.is-animated {
  opacity: 1;
  animation: pop-up-light 0.62s cubic-bezier(0.22, 1, 0.36, 1) forwards;
  filter: blur(0);
}

@keyframes pop-up-light {
  0% {
    opacity: 0;
    transform: translateY(40px) scale(0.92);
    filter: blur(3px);
  }
  60% {
    opacity: 1;
    transform: translateY(-6px) scale(1.01);
    filter: blur(0);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: blur(0);
  }
}
.anim-bg-item,
.anim-bg-item2 {
  display: inline-flex;
  width: -moz-fit-content;
  width: fit-content;
  max-width: 100%;
  overflow: hidden;
  vertical-align: top;
  background: transparent;
  opacity: 1;
}

.anim-bg-item2 {
  justify-content: center;
  align-items: center;
}

.anim-bg-item::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  opacity: 0;
  will-change: transform, opacity;
  transition: transform 1.45s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.9s ease;
}

.anim-bg-item .inn {
  position: relative;
  z-index: 1;
  display: inline-block;
  opacity: 0;
  color: #fff;
  filter: blur(4px);
  will-change: transform, opacity, filter;
  transition: opacity 0.9s cubic-bezier(0.22, 1, 0.36, 1) 0.32s, transform 0.95s cubic-bezier(0.22, 1, 0.36, 1) 0.32s, filter 0.95s cubic-bezier(0.22, 1, 0.36, 1) 0.32s;
}

.anim-bg-item2 .inn2 {
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  text-align: center;
}

.anim-bg-left::before {
  transform: scaleX(0.12) translateX(-3%);
  transform-origin: left center;
}

.anim-bg-left .inn {
  transform: translateX(-18px);
}

.anim-bg-left.is-animated::before {
  opacity: 1;
  transform: scaleX(1) translateX(0);
}

.anim-bg-left.is-animated .inn {
  opacity: 1;
  transform: translateX(0);
  filter: blur(0);
}

.anim-bg-right::before {
  transform: scaleX(0.12) translateX(3%);
  transform-origin: right center;
}

.anim-bg-right .inn {
  transform: translateX(18px);
}

.anim-bg-right.is-animated::before {
  opacity: 1;
  transform: scaleX(1) translateX(0);
}

.anim-bg-right.is-animated .inn {
  opacity: 1;
  transform: translateX(0);
  filter: blur(0);
}

.anim-bg-down::before {
  transform: scaleY(0.12) translateY(-8%);
  transform-origin: center top;
}

.anim-bg-down .inn {
  transform: translateY(-14px);
}

.anim-bg-down.is-animated::before {
  opacity: 1;
  transform: scaleY(1) translateY(0);
}

.anim-bg-down.is-animated .inn {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}

.anim-bg-hero {
  box-shadow: none;
  transition: box-shadow 0.45s ease 1s;
}

.anim-bg-hero.is-animated {
  box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
}

.anim-bg-hero2.is-animated .inn {
  text-shadow: rgba(0, 0, 0, 0.1568627451) 0px 3px 6px;
}

.anim-bg-1::before {
  background: linear-gradient(90deg, rgba(73, 158, 227, 0.9) 0%, rgba(20, 192, 114, 0.9) 100%);
}

.anim-bg-2::before {
  background: linear-gradient(269deg, rgba(74, 212, 175, 0.6) 26.47%, rgba(49, 92, 81, 0.6) 116.69%);
}

.anim-bg-2-8::before {
  background: linear-gradient(269deg, rgba(74, 212, 175, 0.8) 26.47%, rgba(49, 92, 81, 0.8) 116.69%);
}

.anim-bg-3::before {
  background: linear-gradient(269deg, #4ad4af 26.47%, #315c51 116.69%);
}

.anim-bg-4::before {
  background: linear-gradient(241deg, #e6e6e6 8.74%, #b9d6ce 61.61%, #5eb69d 91.11%);
}

.anim-bg-5::before {
  background: linear-gradient(269deg, rgba(74, 212, 175, 0.6) 26.47%, rgba(255, 255, 255, 0.6) 116.69%);
}

.anim-bg-6::before {
  background: linear-gradient(90deg, rgba(74, 212, 175, 0.7) 26.47%, rgba(49, 92, 81, 0.7) 116.69%);
}

.anim-bg-7::before {
  background: linear-gradient(300deg, rgba(74, 212, 175, 0.6) -67.63%, rgba(62, 152, 128, 0.6) -30.78%, rgba(0, 31, 23, 0.6) 81.87%);
}

@keyframes bg-slide-in {
  0% {
    opacity: 0;
    transform: scaleX(0) translateX(-5%);
  }
  30% {
    opacity: 1;
    transform: scaleX(1) translateX(0);
  }
  100% {
    opacity: 1;
    transform: scaleX(1) translateX(0);
  }
}
.anim-whole-item {
  opacity: 0;
  filter: blur(4px);
  will-change: transform, opacity, filter;
  --anim-opacity-duration: 0.9s;
  --anim-move-duration: 0.95s;
  --anim-filter-duration: 0.95s;
  --anim-ease: cubic-bezier(0.22, 1, 0.36, 1);
  transition: opacity var(--anim-opacity-duration) var(--anim-ease), transform var(--anim-move-duration) var(--anim-ease), filter var(--anim-filter-duration) var(--anim-ease);
}

.anim-whole-left {
  transform: translateX(-18px);
}

.anim-whole-right {
  transform: translateX(18px);
}

.anim-whole-down {
  transform: translateY(-14px);
}

.anim-whole-up {
  transform: translateY(14px);
}

.anim-whole-item.is-animated {
  opacity: 1;
  transform: translate(0, 0);
  filter: blur(0);
}

.anim-speed-fast {
  --anim-opacity-duration: 0.45s;
  --anim-move-duration: 0.5s;
  --anim-filter-duration: 0.5s;
}

.anim-speed-normal {
  --anim-opacity-duration: 0.9s;
  --anim-move-duration: 0.95s;
  --anim-filter-duration: 0.95s;
}

.anim-speed-slow {
  --anim-opacity-duration: 2.9s;
  --anim-move-duration: 3s;
  --anim-filter-duration: 3s;
}

@media (prefers-reduced-motion: reduce) {
  .hero-connect-main,
  .hero-connect-sub,
  .anim-up-item,
  .anim-fade-item,
  .anim-down-item,
  .anim-left-item,
  .anim-right-item,
  .anim-whole-item {
    opacity: 1;
    transform: none;
    filter: none;
    transition: none;
  }
  .anim-bg-item {
    opacity: 1;
  }
  .anim-bg-item::before {
    animation: none;
    opacity: 1;
    transform: none;
  }
  .anim-bg-item .inn {
    opacity: 1;
    transform: none;
    filter: none;
    transition: none;
  }
}/*# sourceMappingURL=style.css.map */