.button-circle--blue {
  position: relative;
  display: block;
  background-color: var(--color-navy);
  border-radius: 50%;
}
.button-circle--blue__arrow {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 2;
  display: block;
  width: 36.67%;
  transform: translate(-50%, -50%);
  aspect-ratio: 22/17;
}
.button-circle--blue__arrow svg {
  display: block;
  width: 100%;
  height: 100%;
  color: var(--color-white);
  transition: color 0.3s ease;
}
.button-circle--blue__inner {
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  width: 100%;
  height: 100%;
  background-color: var(--color-white);
  border-radius: 50%;
  transition: transform 0.45s cubic-bezier(0.4, 0, 0.2, 1);
  transform: translate(-50%, -50%) scale(0);
  transform-origin: center;
}
.button-circle--blue:hover, .button-circle--blue:active {
  border: solid 1px var(--color-navy);
}
.button-circle--blue:hover .button-circle--blue__arrow svg, .button-circle--blue:active .button-circle--blue__arrow svg {
  color: var(--color-navy);
}
.button-circle--blue:hover .button-circle--blue__inner, .button-circle--blue:active .button-circle--blue__inner {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.button-circle--blue--diagonal {
  position: relative;
  display: block;
  background-color: var(--color-navy);
  border-radius: 50%;
}
.button-circle--blue--diagonal__arrow {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 2;
  display: block;
  width: 36.67%;
  transform: translate(-50%, -50%);
  aspect-ratio: 22/17;
}
.button-circle--blue--diagonal__arrow svg {
  display: block;
  width: 100%;
  height: 100%;
  color: var(--color-white);
  transition: color 0.3s ease;
  transform: rotate(-45deg);
}
.button-circle--blue--diagonal__inner {
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  width: 100%;
  height: 100%;
  background-color: var(--color-white);
  border-radius: 50%;
  transition: transform 0.45s cubic-bezier(0.4, 0, 0.2, 1);
  transform: translate(-50%, -50%) scale(0);
  transform-origin: center;
}
.button-circle--blue--diagonal:hover, .button-circle--blue--diagonal:active {
  border: solid 1px var(--color-navy);
}
.button-circle--blue--diagonal:hover .button-circle--blue--diagonal__arrow svg, .button-circle--blue--diagonal:active .button-circle--blue--diagonal__arrow svg {
  color: var(--color-navy);
}
.button-circle--blue--diagonal:hover .button-circle--blue--diagonal__inner, .button-circle--blue--diagonal:active .button-circle--blue--diagonal__inner {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.button-circle--red {
  position: relative;
  display: block;
  background-color: var(--color-red);
  border-radius: 50%;
}
.button-circle--red__arrow {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 2;
  display: block;
  width: 36.67%;
  transform: translate(-50%, -50%);
  aspect-ratio: 22/17;
}
.button-circle--red__arrow svg {
  display: block;
  width: 100%;
  height: 100%;
  color: var(--color-white);
  transition: color 0.3s ease;
}
.button-circle--red__inner {
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  width: 100%;
  height: 100%;
  background-color: var(--color-white);
  border-radius: 50%;
  transition: transform 0.45s cubic-bezier(0.4, 0, 0.2, 1);
  transform: translate(-50%, -50%) scale(0);
  transform-origin: center;
}
.button-circle--red:hover, .button-circle--red:active {
  border: solid 1px var(--color-red);
}
.button-circle--red:hover .button-circle--red__arrow svg, .button-circle--red:active .button-circle--red__arrow svg {
  color: var(--color-red);
}
.button-circle--red:hover .button-circle--red__inner, .button-circle--red:active .button-circle--red__inner {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.button-circle--white {
  position: relative;
  display: block;
  background-color: var(--color-white);
  border-radius: 50%;
}
.button-circle--white__arrow {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 2;
  display: block;
  width: 36.67%;
  transform: translate(-50%, -50%);
  aspect-ratio: 22/17;
}
.button-circle--white__arrow svg {
  display: block;
  width: 100%;
  height: 100%;
  color: var(--color-navy);
  transition: color 0.3s ease;
}
.button-circle--white__inner {
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  width: 100%;
  height: 100%;
  background-color: var(--color-navy);
  border-radius: 50%;
  transition: transform 0.45s cubic-bezier(0.4, 0, 0.2, 1);
  transform: translate(-50%, -50%) scale(0);
  transform-origin: center;
}
.button-circle--white:hover .button-circle--white__arrow svg, .button-circle--white:active .button-circle--white__arrow svg {
  color: var(--color-white);
}
.button-circle--white:hover .button-circle--white__inner, .button-circle--white:active .button-circle--white__inner {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.button-plus--blue {
  position: relative;
  background: #0e0e8f;
  border-radius: 50%;
}
.button-plus--blue__plus {
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  width: 10px;
  transform: translate(-50%, -50%);
  aspect-ratio: 1/1;
}
.button-plus--blue__plus svg {
  display: block;
  width: 100%;
  height: 100%;
  color: #fff;
  transition: color 0.3s ease;
}
@media (width < 1440px) {
  .button-plus--blue__plus {
    width: 0.69vw;
  }
}
@media (width <= 767px) {
  .button-plus--blue__plus {
    width: 6px;
  }
}

.pdf-link__link {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  width: 160px;
  height: 38px;
  background: #ffffff;
  border: 1px solid #6c6c6c;
  border-radius: 100px;
  cursor: pointer;
}
@media (width < 1440px) {
  .pdf-link__link {
    gap: 0.69vw;
    width: 12vw;
    height: 2.64vw;
    padding: 0.56vw 1.53vw 0.56vw 1.78vw;
  }
}
@media (width <= 767px) {
  .pdf-link__link {
    gap: 8px;
    width: 120px;
    height: 28px;
    padding: 6px 16px 6px 18px;
  }
}
.pdf-link__link-text {
  font-size: 14px;
  font-weight: 700;
  line-height: 160%;
  letter-spacing: 0.05em;
  color: var(--color-black);
  white-space: nowrap;
}
@media (width < 1440px) {
  .pdf-link__link-text {
    font-size: 0.97vw;
  }
}
@media (width <= 767px) {
  .pdf-link__link-text {
    font-size: 10px;
  }
}
.pdf-link__link-icon {
  width: 29px;
  aspect-ratio: 29/16;
}
@media (width < 1440px) {
  .pdf-link__link-icon {
    width: 2.01vw;
  }
}
@media (width <= 767px) {
  .pdf-link__link-icon {
    width: 16px;
  }
}

.message {
  margin-top: min(7.71vw, 111px);
}
.message__title-text {
  display: flex;
  align-items: center;
  font-size: 30px;
  font-size: min(30px, 2.08vw);
  font-weight: 900;
  line-height: 120%;
  color: var(--blue-01);
}
@media (width <= 767px) {
  .message__title-text {
    font-size: 24px;
  }
}
.message__content {
  margin-top: min(2.78vw, 40px);
}
@media (width <= 767px) {
  .message__content {
    margin-top: 24px;
  }
}
.message__subtitle {
  font-size: min(1.81vw, 26px);
  font-weight: 600;
  line-height: 180%;
  color: #000;
  margin-bottom: min(1.39vw, 20px);
}
@media (width <= 767px) {
  .message__subtitle {
    font-size: 15.6px;
    margin-bottom: 12px;
  }
}
.message__text {
  font-size: min(1.11vw, 16px);
  font-weight: 400;
  line-height: 180%;
  color: #000;
}
@media (width <= 767px) {
  .message__text {
    font-size: 11px;
  }
}
@media (width <= 767px) {
  .message {
    margin-top: 66.6px;
  }
}

.voice {
  margin-top: min(6.94vw, 100px);
}
.voice__title-text {
  display: flex;
  align-items: center;
  font-size: 30px;
  font-size: min(30px, 2.08vw);
  font-weight: 900;
  line-height: 120%;
  color: var(--blue-01);
}
@media (width <= 767px) {
  .voice__title-text {
    font-size: 24px;
  }
}
.voice__content {
  margin-top: min(2.78vw, 40px);
}
@media (width <= 767px) {
  .voice__content {
    margin-top: 24px;
  }
}
.voice__subtitle {
  font-size: min(1.81vw, 26px);
  font-weight: 600;
  line-height: 180%;
  color: #000;
  margin-bottom: min(1.39vw, 20px);
}
@media (width <= 767px) {
  .voice__subtitle {
    font-size: 15.6px;
    margin-bottom: 12px;
  }
}
.voice__text {
  font-size: min(1.11vw, 16px);
  font-weight: 400;
  line-height: 180%;
  color: #000;
}
@media (width <= 767px) {
  .voice__text {
    font-size: 11px;
  }
}
.voice__content {
  display: flex;
  justify-content: center;
  gap: min(1.67vw, 24px);
}
@media (width <= 767px) {
  .voice__content {
    flex-direction: column;
    align-items: center;
    gap: 20px;
  }
}
.voice__link {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: min(0.69vw, 10px);
  width: min(39.31vw, 566px);
  background-size: cover;
  background-position: center;
  aspect-ratio: 566/190;
  padding-left: min(2.78vw, 40px);
}
@media (width <= 767px) {
  .voice__link {
    width: 100%;
    max-width: 345px;
    padding-left: 20px;
  }
}
.voice__link--tsukuba-factory {
  /* prettier-ignore */
  background-image: image-set(url("../images/bg_recruit-voice-link--tsukuba-factory.png") 1x, url("../images/bg_recruit-voice-link--tsukuba-factory@2x.png") 2x);
}
.voice__link--saitama-factory {
  /* prettier-ignore */
  background-image: image-set(url("../images/bg_recruit-voice-link--saitama-factory.png") 1x, url("../images/bg_recruit-voice-link--saitama-factory@2x.png") 2x);
}
.voice__text--business {
  font-size: min(1.39vw, 20px);
  font-weight: 500;
  line-height: 120%;
  color: var(--color-white);
}
@media (width <= 767px) {
  .voice__text--business {
    font-size: 12px;
  }
}
.voice__text--factory {
  font-size: min(2.08vw, 30px);
  font-weight: 900;
  line-height: 120%;
  color: #ffffff;
}
@media (width <= 767px) {
  .voice__text--factory {
    font-size: 18px;
  }
}
@media (width <= 767px) {
  .voice {
    margin-top: 60px;
  }
}

.head-office {
  margin-top: 100px;
}
.head-office__title-text {
  display: flex;
  align-items: center;
  font-size: min(30px, 2.08vw);
  font-weight: 900;
  line-height: 120%;
  color: var(--blue-01);
}
@media (width <= 767px) {
  .head-office__title-text {
    font-size: 24px;
  }
}
.head-office__content {
  display: flex;
  justify-content: space-between;
  margin-top: 40px;
}
@media (width < 1440px) {
  .head-office__content {
    margin-top: 2.78vw;
  }
}
@media (width <= 767px) {
  .head-office__content {
    flex-direction: column;
    align-items: center;
    margin-top: 30px;
  }
}
.head-office__img-wrapper {
  width: 401px;
}
@media (width < 1440px) {
  .head-office__img-wrapper {
    width: 27.93vw;
  }
}
@media (width <= 767px) {
  .head-office__img-wrapper {
    width: 100%;
    max-width: 345px;
  }
}
@media (width <= 767px) {
  .head-office__recruit-guidelines {
    margin-top: 30px;
  }
}
.head-office__recruit-guidelines-title {
  font-size: 20px;
  font-weight: 600;
  line-height: 27px;
  color: var(--color-black);
}
@media (width < 1440px) {
  .head-office__recruit-guidelines-title {
    font-size: 1.39vw;
    line-height: 1.93vw;
  }
}
@media (width <= 767px) {
  .head-office__recruit-guidelines-title {
    font-size: 18px;
    line-height: 24px;
  }
}
.head-office__table-wrapper {
  border: 1px solid #d0d0d0;
  border-radius: 14px;
  overflow: hidden;
  margin-top: 25px;
}
@media (width < 1440px) {
  .head-office__table-wrapper {
    border-radius: 0.97vw;
    margin-top: 1.74vw;
  }
}
@media (width <= 767px) {
  .head-office__table-wrapper {
    border-radius: 10px;
    margin-top: 20px;
  }
}
.head-office__table {
  width: 709px;
  background: var(--color-white);
  border-collapse: collapse;
}
@media (width < 1440px) {
  .head-office__table {
    width: 49.24vw;
  }
}
@media (width <= 767px) {
  .head-office__table {
    width: 100%;
  }
}
.head-office__table-row:not(:last-child) {
  border-bottom: 1px solid #d0d0d0;
}
.head-office__table-header {
  width: 212px;
  padding: 24px 20px;
  font-size: 16px;
  font-weight: 600;
  color: #f19405;
  text-align: left;
  background: #fff3e3;
}
@media (width < 1440px) {
  .head-office__table-header {
    width: 14.72vw;
    padding: 1.39vw 1.04vw;
    font-size: 1.11vw;
  }
}
@media (width <= 767px) {
  .head-office__table-header {
    width: 28%;
    max-width: 100px;
    padding: 18px 10px;
    font-size: 14px;
  }
}
.head-office__table-data {
  padding: 24px 20px;
  font-size: 16px;
  font-weight: 400;
  line-height: 19px;
  color: var(--color-black);
}
@media (width < 1440px) {
  .head-office__table-data {
    padding: 1.39vw 1.04vw;
    font-size: 1.11vw;
    line-height: 1.32vw;
  }
}
@media (width <= 767px) {
  .head-office__table-data {
    padding: 18px 10px;
    font-size: 14px;
    line-height: 17px;
  }
}
.head-office__apply-link {
  position: relative;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 30px;
  width: 100%;
  text-align: right;
  margin-top: 35px;
}
@media (width < 1440px) {
  .head-office__apply-link {
    gap: 2.08vw;
    margin-top: 2.43vw;
  }
}
@media (width <= 767px) {
  .head-office__apply-link {
    gap: 20px;
    margin-top: 25px;
  }
}
.head-office__apply-link-text {
  font-size: 20px;
  font-weight: 700;
  line-height: 160%;
  letter-spacing: 0.05em;
  color: #c13434;
}
@media (width < 1440px) {
  .head-office__apply-link-text {
    font-size: 1.39vw;
  }
}
@media (width <= 767px) {
  .head-office__apply-link-text {
    font-size: 18px;
  }
}
.head-office__button-circle {
  width: 40px;
  height: 40px;
  transform: rotate(-45deg);
}
@media (width < 1440px) {
  .head-office__button-circle {
    width: 2.78vw;
    height: 2.78vw;
  }
}
@media (width <= 767px) {
  .head-office__button-circle {
    width: 35px;
    height: 35px;
  }
}
@media (width < 1440px) {
  .head-office {
    margin-top: 6.94vw;
  }
}
@media (width <= 767px) {
  .head-office {
    margin-top: 60px;
  }
}

.toho-printing-saitama-factory {
  margin-top: 40px;
  margin-bottom: min(14.38vw, 207px);
}
.toho-printing-saitama-factory__title-text {
  display: flex;
  align-items: center;
  font-size: min(30px, 2.08vw);
  font-weight: 900;
  line-height: 120%;
  color: var(--blue-01);
}
@media (width <= 767px) {
  .toho-printing-saitama-factory__title-text {
    font-size: 24px;
  }
}
.toho-printing-saitama-factory__content {
  margin-top: 40px;
}
@media (width < 1440px) {
  .toho-printing-saitama-factory__content {
    margin-top: 2.78vw;
  }
}
@media (width <= 767px) {
  .toho-printing-saitama-factory__content {
    margin-top: 30px;
  }
}
.toho-printing-saitama-factory__description {
  font-size: 16px;
  font-weight: 400;
  line-height: 19px;
  color: var(--color-black);
}
.toho-printing-saitama-factory__apply-link {
  position: relative;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 30px;
  width: 100%;
  text-align: right;
  margin-top: 15px;
}
@media (width < 1440px) {
  .toho-printing-saitama-factory__apply-link {
    gap: 2.08vw;
    margin-top: 1.04vw;
  }
}
@media (width <= 767px) {
  .toho-printing-saitama-factory__apply-link {
    gap: 20px;
    margin-top: 15px;
  }
}
.toho-printing-saitama-factory__apply-link-text {
  font-size: 20px;
  font-weight: 700;
  line-height: 160%;
  letter-spacing: 0.05em;
  color: #0e0e8f;
}
@media (width < 1440px) {
  .toho-printing-saitama-factory__apply-link-text {
    font-size: 1.39vw;
  }
}
@media (width <= 767px) {
  .toho-printing-saitama-factory__apply-link-text {
    font-size: 18px;
  }
}
.toho-printing-saitama-factory__button-circle {
  width: 40px;
  height: 40px;
  transform: rotate(-45deg);
}
@media (width < 1440px) {
  .toho-printing-saitama-factory__button-circle {
    width: 2.78vw;
    height: 2.78vw;
  }
}
@media (width <= 767px) {
  .toho-printing-saitama-factory__button-circle {
    width: 35px;
    height: 35px;
  }
}
@media (width < 767px) {
  .toho-printing-saitama-factory {
    margin-bottom: 60px;
  }
}
@media (width < 1440px) {
  .toho-printing-saitama-factory {
    margin-top: 2.78vw;
  }
}
@media (width <= 767px) {
  .toho-printing-saitama-factory {
    margin-top: 40px;
  }
}

.tsukuba-factory {
  margin-top: 100px;
  margin-bottom: 135px;
}
.tsukuba-factory__title-text {
  display: flex;
  align-items: center;
  font-size: min(30px, 2.08vw);
  font-weight: 900;
  line-height: 120%;
  color: var(--blue-01);
}
@media (width <= 767px) {
  .tsukuba-factory__title-text {
    font-size: 24px;
  }
}
.tsukuba-factory__content {
  display: flex;
  justify-content: space-between;
  gap: min(3.26vw, 47px);
  margin-top: 40px;
}
@media (width < 1440px) {
  .tsukuba-factory__content {
    margin-top: 2.78vw;
  }
}
@media (width <= 767px) {
  .tsukuba-factory__content {
    flex-direction: column;
    align-items: center;
    margin-top: 30px;
  }
}
.tsukuba-factory__img-wrapper {
  width: min(27.85vw, 401px);
}
@media (width <= 767px) {
  .tsukuba-factory__img-wrapper {
    width: 100%;
    max-width: 345px;
  }
}
.tsukuba-factory__recruit-guidelines {
  flex: 1;
}
@media (width <= 767px) {
  .tsukuba-factory__recruit-guidelines {
    margin-top: 30px;
  }
}
.tsukuba-factory__recruit-guidelines-title {
  font-size: 20px;
  font-weight: 600;
  line-height: 27px;
  color: var(--color-black);
}
@media (width < 1440px) {
  .tsukuba-factory__recruit-guidelines-title {
    font-size: 1.39vw;
    line-height: 1.93vw;
  }
}
@media (width <= 767px) {
  .tsukuba-factory__recruit-guidelines-title {
    font-size: 18px;
    line-height: 24px;
  }
}
.tsukuba-factory__table-wrapper {
  border: 1px solid #d0d0d0;
  border-radius: 14px;
  overflow: hidden;
  margin-top: 25px;
}
@media (width < 1440px) {
  .tsukuba-factory__table-wrapper {
    border-radius: 0.97vw;
    margin-top: 1.74vw;
  }
}
@media (width <= 767px) {
  .tsukuba-factory__table-wrapper {
    border-radius: 10px;
    margin-top: 20px;
  }
}
.tsukuba-factory__table {
  width: 709px;
  background: var(--color-white);
  border-collapse: collapse;
}
@media (width < 1440px) {
  .tsukuba-factory__table {
    width: 49.24vw;
  }
}
@media (width <= 767px) {
  .tsukuba-factory__table {
    width: 100%;
  }
}
.tsukuba-factory__table-row:not(:last-child) {
  border-bottom: 1px solid #d0d0d0;
}
.tsukuba-factory__table-header {
  width: 29.9%;
  padding: 24px 20px;
  font-size: 16px;
  font-weight: 600;
  color: var(--blue-01);
  text-align: left;
  background: #edf0fe;
}
@media (width < 1440px) {
  .tsukuba-factory__table-header {
    padding: 1.39vw 1.04vw;
    font-size: 1.11vw;
  }
}
@media (width <= 767px) {
  .tsukuba-factory__table-header {
    width: 28%;
    max-width: 100px;
    padding: 18px 10px;
    font-size: 14px;
  }
}
.tsukuba-factory__table-data {
  width: 70.1%;
  padding: 24px 20px;
  font-size: 16px;
  font-weight: 400;
  line-height: 19px;
  color: var(--color-black);
}
.tsukuba-factory__table-data span {
  font-size: min(0.97vw, 14px);
}
@media (width <= 767px) {
  .tsukuba-factory__table-data span {
    font-size: 11px;
  }
}
@media (width < 1440px) {
  .tsukuba-factory__table-data {
    padding: 1.39vw 1.04vw;
    font-size: 1.11vw;
    line-height: 1.32vw;
  }
}
@media (width <= 767px) {
  .tsukuba-factory__table-data {
    padding: 18px 10px;
    font-size: 14px;
    line-height: 17px;
  }
}
.tsukuba-factory__apply-link {
  position: relative;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 30px;
  width: 100%;
  text-align: right;
  margin-top: 35px;
}
@media (width < 1440px) {
  .tsukuba-factory__apply-link {
    gap: 2.08vw;
    margin-top: 2.43vw;
  }
}
@media (width <= 767px) {
  .tsukuba-factory__apply-link {
    gap: 20px;
    margin-top: 25px;
  }
}
.tsukuba-factory__apply-link-text {
  font-size: 20px;
  font-weight: 700;
  line-height: 160%;
  letter-spacing: 0.05em;
  color: #0e0e8f;
}
@media (width < 1440px) {
  .tsukuba-factory__apply-link-text {
    font-size: 1.39vw;
  }
}
@media (width <= 767px) {
  .tsukuba-factory__apply-link-text {
    font-size: 18px;
  }
}
.tsukuba-factory__button-circle {
  width: 40px;
  height: 40px;
}
@media (width < 1440px) {
  .tsukuba-factory__button-circle {
    width: 2.78vw;
    height: 2.78vw;
  }
}
@media (width <= 767px) {
  .tsukuba-factory__button-circle {
    width: 35px;
    height: 35px;
  }
}
@media (width < 1440px) {
  .tsukuba-factory {
    margin-top: 6.94vw;
    margin-bottom: 9.38vw;
  }
}
@media (width <= 767px) {
  .tsukuba-factory {
    margin-top: 60px;
    margin-bottom: 80px;
  }
}

.modal {
  position: fixed;
  z-index: 1000;
  display: flex;
  max-height: calc(100dvh - 40px);
  opacity: 0;
  transition: opacity 0.3s ease;
  visibility: hidden;
  inset: 0;
  pointer-events: none;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.modal.is-open {
  justify-content: center;
  align-items: center;
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.modal__overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: rgba(0, 0, 0, 0.6);
}
.modal__inner {
  width: 100%;
  height: 100%;
  padding-inline: 2%;
}
.modal__content {
  position: relative;
  width: 100%;
  max-width: 1156px;
  margin: 5% auto;
  padding: 60px 50px;
  background: #fff;
  border: 3px solid var(--blue-01);
  border-radius: 20px;
  opacity: 0;
  transition: opacity 0.3s ease, transform 0.3s ease;
  transform: translateY(20px);
}
.is-open .modal__content {
  opacity: 1;
  transform: translateY(0);
}
@media (width < 1440px) {
  .modal__content {
    padding: 4.17vw 3.47vw;
    border-radius: 1.39vw;
  }
}
@media (width <= 767px) {
  .modal__content {
    padding: 30px 2%;
    border-radius: 15px;
  }
}
.modal__close {
  position: absolute;
  top: -12px;
  right: -12px;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 36px;
  height: 36px;
  background: var(--blue-01);
  border-radius: 4px;
  cursor: pointer;
}
@media (width < 1440px) {
  .modal__close {
    top: -0.83vw;
    right: -0.83vw;
    width: 2.5vw;
    height: 2.5vw;
  }
}
@media (width <= 767px) {
  .modal__close {
    top: -10px;
    right: -10px;
    width: 30px;
    height: 30px;
  }
}
.modal__title {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: min(0.69vw, 10px);
  width: 100%;
  background-size: cover;
  background-position: center;
  aspect-ratio: 1056/259;
  padding-left: min(3.04vw, 43.76px);
}
.modal-tsukuba-factory .modal__title {
  /* prettier-ignore */
  background-image: image-set(url("../images/bg_recruit-modal-tsukuba-factory-title.png") 1x, url("../images/bg_recruit-modal-tsukuba-factory-title@2x.png") 2x);
}
.modal-saitama-factory .modal__title {
  /* prettier-ignore */
  background-image: image-set(url("../images/bg_recruit-modal-saitama-factory-title.png") 1x, url("../images/bg_recruit-modal-saitama-factory-title@2x.png") 2x);
}
@media (width < 768px) {
  .modal__title {
    gap: 0;
    padding-left: 20px;
  }
}
.modal__title--business {
  font-size: min(1.11vw, 16px);
  font-weight: 500;
  line-height: 140%;
  color: var(--color-white);
}
@media (width <= 767px) {
  .modal__title--business {
    font-size: 12px;
  }
}
.modal__title--factory {
  font-size: min(2.78vw, 40px);
  font-weight: 700;
  line-height: 120%;
  color: #ffffff;
}
@media (width <= 767px) {
  .modal__title--factory {
    font-size: 30px;
  }
}
.modal__voice-content {
  margin-top: min(2.78vw, 40px);
}
@media (width <= 767px) {
  .modal__voice-content {
    margin-top: 20px;
  }
}
.modal__voice-header-title {
  position: relative;
  padding-left: min(6.74vw, 97px);
}
.modal__voice-header-title::before {
  position: absolute;
  top: 50%;
  left: 0;
  display: inline-block;
  font-size: min(5.56vw, 80px);
  font-weight: 600;
  line-height: 160%;
  letter-spacing: -0.06em;
  background: linear-gradient(180deg, #8b9fe5 0%, #c3cdf0 100%);
  opacity: 0.5;
  transform: translateY(-50%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.modal__voice-content--mh .modal__voice-header-title::before {
  content: "01";
}
.modal__voice-content--rs .modal__voice-header-title::before {
  content: "02";
}
.modal__voice-content--sm .modal__voice-header-title::before {
  content: "03";
}
@media (width <= 768px) {
  .modal__voice-header-title::before {
    font-size: 60px;
  }
}
.modal__voice-header-title::after {
  transform: translateY(min(1.04vw, 15px));
}
@media (width <= 767px) {
  .modal__voice-header-title {
    padding-left: 74px;
  }
}
.modal__voice-header-title-inner {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  padding-top: min(0.35vw, 5px);
}
.modal__voice-position {
  font-size: min(1.11vw, 16px);
  font-weight: 500;
  color: var(--blue-01);
}
@media (width <= 767px) {
  .modal__voice-position {
    font-size: 12px;
  }
}
.modal__voice-name {
  font-size: min(2.78vw, 40px);
  font-weight: 700;
  line-height: 1;
  color: var(--blue-01);
  white-space: nowrap;
}
@media (width <= 767px) {
  .modal__voice-name {
    font-size: 30px;
  }
}
.modal__voice-honorific {
  font-size: min(1.22vw, 22px);
  color: var(--blue-01);
}
@media (width <= 767px) {
  .modal__voice-honorific {
    font-size: 15px;
  }
}
.modal__voice-body {
  display: flex;
  justify-content: center;
  margin-top: min(2.08vw, 30px);
}
@media (width <= 767px) {
  .modal__voice-body {
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    margin-top: 20px;
  }
}
.modal__voice-text-wrapper {
  flex: 1;
  padding-right: min(1.74vw, 25px);
}
@media (width <= 767px) {
  .modal__voice-text-wrapper {
    padding-right: 0;
  }
}
.modal__voice-title {
  font-size: 20px;
  font-weight: 700;
  line-height: 140%;
  background: linear-gradient(142.23deg, #516ed6 12.3%, #3620c7 89.4%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: min(1.39vw, 20px);
}
@media (width <= 767px) {
  .modal__voice-title {
    font-size: 16px;
    margin-bottom: 10px;
  }
}
.modal__voice-text {
  font-size: 16px;
  font-size: min(1.11vw, 16px);
  font-weight: 400;
  line-height: 180%;
  color: var(--color-black);
}
@media (width <= 767px) {
  .modal__voice-text {
    font-size: 12px;
  }
}
.modal__voice-img-wrapper {
  width: min(27.57vw, 397px);
  flex-shrink: 0;
}
.modal__voice-img-wrapper img {
  width: 100%;
  height: auto;
}
@media (width <= 767px) {
  .modal__voice-img-wrapper {
    width: 100%;
    max-width: 345px;
    margin-top: 20px;
  }
}

body.is-modal-open {
  overflow: hidden;
}