:root {
  --color-1:#211E1E;
  --color-2:#CB2026;
  --color-3:#F7F7F7;
  --color-4:#FFF;
  --color-5:#EDEDED;
  --color-6:#868686;
  --color-7:#3B2828;
  --color-8:#C4BEBE;
  --color-9:#413636;
  --color-10:#262222;
  --color-11:#3e3e3e;
  --gutter-1: max(1.56vw,25px);
  --pad-1: max(175px,9.1vw);
}
@media (max-width: 767px) {
  :root {
    --pad-1: 32vw;
    --gutter-1: 5.3vw;
  }
}

@keyframes scroll-text {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-100%);
  }
}
.u-d-none--pc {
  display: none;
}
@media (max-width: 767px) {
  .u-d-none--pc {
    display: inline-block;
  }
}

.u-d-none--sp {
  display: inline-block;
}
@media (max-width: 767px) {
  .u-d-none--sp {
    display: none;
  }
}

.u-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip-path: inset(50%);
  white-space: nowrap;
  border: 0;
}

html {
  margin-top: 0 !important;
  scroll-behavior: smooth;
  font-feature-settings: "palt";
  letter-spacing: 0.1em;
  line-height: 1.8;
  font-family: "Noto Sans JP", sans-serif;
  font-size: min(16px, 1.3vw);
  color: var(--color-1);
}
@media (max-width: 767px) {
  html {
    font-size: 4.26vw;
  }
}
@media (max-width: 767px) {
  html {
    font-size: min(13px, 1.1vw);
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  html {
    font-size: 3.46vw;
  }
}

body {
  overflow-x: hidden;
  position: relative;
  background-color: var(--color-3);
}
body::before {
  content: "";
  width: 100%;
  height: 100%;
  background-color: black;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  opacity: 0;
  visibility: hidden;
  transition: 0.3s ease;
}
body.is-fixed {
  overflow: hidden;
}
body.is-fixed::before {
  opacity: 0.4;
  visibility: visible;
}

input:focus,
textarea:focus {
  outline: solid 2px #0054fb;
}

select {
  cursor: pointer;
}

::placeholder {
  color: rgb(110, 110, 110);
}

.wpcf7-not-valid-tip {
  display: none;
}

.wpcf7-spinner {
  display: none;
}

.wpcf7-list-item {
  margin: 0;
  display: flex;
}

form .wpcf7-response-output {
  border: none !important;
  background-color: rgb(246, 246, 246);
  color: red;
  padding: 20px !important;
  margin-top: 20px;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
  margin: 0 !important;
}
@media (max-width: 767px) {
  form .wpcf7-response-output {
    grid-template-columns: 1fr;
    padding: 4vw;
    gap: 2vw;
    font-size: min(14px, 1.2vw);
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  form .wpcf7-response-output {
    font-size: 3.73vw;
  }
}
form .wpcf7-response-output::before {
  content: "!";
  font-size: min(20px, 1.8vw);
  line-height: 1;
  font-weight: bold;
  background-color: red;
  color: #fff;
  aspect-ratio: 1/1;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (max-width: 767px) {
  form .wpcf7-response-output::before {
    font-size: 5.33vw;
  }
}
@media (max-width: 767px) {
  form .wpcf7-response-output::before {
    width: 10vw;
  }
}
form .wpcf7-response-output.hidden {
  display: none;
}
form.sent .wpcf7-response-output {
  color: green;
}
form.sent .wpcf7-response-output::before {
  display: none;
}

.error-message,
.program-error {
  display: none;
  color: red;
  font-size: min(14px, 1.2vw);
}
@media (max-width: 767px) {
  .error-message,
  .program-error {
    font-size: 3.73vw;
  }
}
@media (max-width: 767px) {
  .error-message,
  .program-error {
    font-size: min(12px, 1vw);
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .error-message,
  .program-error {
    font-size: 3.2vw;
  }
}

.swiper-pagination {
  top: auto !important;
  bottom: auto !important;
  left: auto !important;
  right: auto !important;
  position: relative !important;
  transition: none !important;
}
.swiper-pagination-bullet {
  opacity: 1 !important;
  margin: 0 !important;
}

.swiper-button-prev,
.swiper-button-next {
  top: 50%;
  left: auto;
  bottom: auto;
  right: auto;
  translate: 0 -50%;
  height: fit-content;
  width: fit-content;
  margin-top: 0;
}
.swiper-button-prev::after,
.swiper-button-next::after {
  display: none;
}

.swiper-button-prev {
  rotate: 180deg;
}

summary {
  display: flex;
  list-style: none;
}

summary::-webkit-details-marker {
  display: none;
}

svg {
  overflow: visible;
}

.grecaptcha-badge {
  visibility: hidden !important;
}

input[type=date] {
  user-select: none;
  max-width: 30vw;
}
input[type=date]::-webkit-calendar-picker-indicator {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  background: transparent;
  z-index: 1;
}
input[type=date]::-webkit-date-and-time-value {
  text-align: left;
}

textarea {
  resize: vertical;
}

.input-date {
  max-width: 30vw;
}

.ui-datepicker .ui-datepicker-current {
  display: none;
}

#wpseo-readability-filter,
#wpseo-filter {
  display: none !important;
}

.c-open-nav {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 999999998;
  width: 100vw;
  height: 100vh;
  overflow: scroll;
  transition: 0.4s cubic-bezier(0.25, 1, 0.5, 1);
  translate: 100% 0;
  display: none;
}
@media (max-width: 767px) {
  .c-open-nav {
    display: block;
  }
}
.c-open-nav.is-active {
  translate: 0 0;
}
.c-open-nav__inner {
  padding: 24vw var(--gutter-1) 16vw;
  background-color: var(--color-1);
  color: var(--color-4);
}
.c-open-nav__main > span {
  color: var(--color-4);
  opacity: 0.4;
  font-family: "Figtree", sans-serif;
  letter-spacing: 0;
  font-size: min(12px, 1vw);
  line-height: 1;
  font-weight: 300;
  display: flex;
}
@media (max-width: 767px) {
  .c-open-nav__main > span {
    font-size: 3.2vw;
  }
}
.c-open-nav__main nav {
  display: grid;
  grid-template-columns: 1fr;
  padding-top: 3vw;
}
.c-open-nav__main nav a {
  padding: 6vw 0;
  border-bottom: solid 1px var(--color-11);
  font-size: min(30px, 2.5vw);
  font-weight: 300;
  line-height: 1;
}
@media (max-width: 767px) {
  .c-open-nav__main nav a {
    font-size: 8vw;
  }
}
@media (max-width: 767px) {
  .c-open-nav__main nav a {
    font-size: min(16px, 1.3vw);
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .c-open-nav__main nav a {
    font-size: 4.26vw;
  }
}
.c-open-nav__main nav a:nth-of-type(1) {
  border-top: solid 1px var(--color-11);
}
.c-open-nav__company {
  padding-top: 27vw;
}
.c-open-nav__company__logo img {
  width: 44.5vw;
}
.c-open-nav__company__address {
  display: flex;
  flex-direction: column;
  gap: 2.6vw;
  padding-top: 5.3vw;
}
.c-open-nav__company__address p {
  font-size: min(12px, 1vw);
  opacity: 0.5;
  line-height: 1.3;
}
@media (max-width: 767px) {
  .c-open-nav__company__address p {
    font-size: 3.2vw;
  }
}
.c-open-nav__company__links {
  margin-top: 8vw;
  padding-top: 4vw;
  border-top: solid 1px var(--color-4);
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 2.6vw;
  opacity: 0.5;
}
.c-open-nav__company__links a {
  font-size: min(10px, 0.9vw);
  line-height: 1;
}
@media (max-width: 767px) {
  .c-open-nav__company__links a {
    font-size: 2.6vw;
  }
}
.c-open-nav__company__links > span {
  width: 1px;
  background-color: var(--color-4);
}
.c-open-nav__bottom {
  padding-top: 45vw;
}
.c-open-nav__bottom__tag {
  padding: 2vw 3.5vw;
  border-radius: 4px;
  background-color: var(--color-2);
  color: var(--color-4);
  display: flex;
  align-items: center;
  gap: 2vw;
  font-family: "Figtree", sans-serif;
  letter-spacing: 0;
  font-size: min(12px, 1vw);
  line-height: 1;
  width: fit-content;
}
@media (max-width: 767px) {
  .c-open-nav__bottom__tag {
    font-size: 3.2vw;
  }
}
.c-open-nav__bottom__tag img {
  width: 7.7vw;
}
.c-open-nav__bottom > p {
  font-size: 9vw;
  line-height: 1.1;
  font-weight: 700;
  padding: 5vw 0 10vw;
}
.c-open-nav__bottom > span {
  font-family: "Figtree", sans-serif;
  letter-spacing: 0;
  font-size: min(10px, 0.9vw);
  line-height: 1;
  opacity: 0.4;
}
@media (max-width: 767px) {
  .c-open-nav__bottom > span {
    font-size: 2.6vw;
  }
}

.c-bg-animation-texts {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.1vw;
  rotate: -7deg;
  width: 200vw;
}
@media (max-width: 767px) {
  .c-bg-animation-texts {
    gap: 10vw;
  }
}
.c-bg-animation-texts__item {
  --anim-time: 50s;
  display: flex;
  align-items: center;
  overflow: hidden;
}
.c-bg-animation-texts__item span {
  white-space: nowrap;
  font-size: 17vw;
  line-height: 0.8;
  color: var(--color-2);
  font-family: "Figtree", sans-serif;
  letter-spacing: 0;
  font-weight: 800;
  animation: scroll-text var(--anim-time) linear infinite;
}
@media (max-width: 767px) {
  .c-bg-animation-texts__item span {
    font-size: 48.2vw;
  }
}
.c-bg-animation-texts__item span:after {
  content: attr(data-text);
  margin-left: 2vw;
}
.c-bg-animation-texts__item:nth-of-type(2n) span {
  color: transparent;
  -webkit-text-stroke: 1px var(--color-2);
  animation-direction: reverse;
}

.c-vertical-animation-text {
  position: absolute;
  right: min(120px, 6vw);
  top: 0;
  z-index: -1;
}
@media (max-width: 767px) {
  .c-vertical-animation-text {
    right: -5vw;
  }
}
.c-vertical-animation-text__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  overflow: hidden;
}
.c-vertical-animation-text__item span {
  white-space: nowrap;
  font-size: 17vw;
  line-height: 1.2;
  color: transparent;
  -webkit-text-stroke: 1px var(--color-2);
  font-family: "Figtree", sans-serif;
  letter-spacing: 0;
  font-weight: 800;
  writing-mode: vertical-lr;
  animation: vertical-text 300s -300s linear infinite;
}
@media (max-width: 767px) {
  .c-vertical-animation-text__item span {
    font-size: 17.6vw;
    animation-duration: 150s;
    animation-delay: -150s;
  }
}
@keyframes vertical-text {
  0% {
    transform: translateY(0);
  }
  100% {
    transform: translateY(-100%);
  }
}
.c-vertical-animation-text__item span:after {
  content: attr(data-text);
  margin-left: 2vw;
}
.c-vertical-animation-text__item:nth-of-type(2n) span {
  color: transparent;
  -webkit-text-stroke: 1px var(--color-2);
  animation-direction: reverse;
}
.c-vertical-animation-text.is-white .c-vertical-animation-text__item span {
  -webkit-text-stroke: 1px var(--color-4);
}

.c-ill-copy {
  font-family: "Figtree", sans-serif;
  letter-spacing: 0;
  font-size: min(12px, 1vw);
  line-height: 1;
  width: 100%;
  opacity: 0.3;
  text-align: right;
}
@media (max-width: 767px) {
  .c-ill-copy {
    font-size: 3.2vw;
  }
}
@media (max-width: 767px) {
  .c-ill-copy {
    font-size: min(10px, 0.9vw);
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .c-ill-copy {
    font-size: 2.6vw;
  }
}

.c-heading-1 {
  display: flex;
  align-items: center;
  gap: 18px;
}
@media (max-width: 767px) {
  .c-heading-1 {
    gap: 3.2vw;
  }
}
.c-heading-1__tag {
  padding: 10px 14px;
  display: flex;
  align-items: center;
  gap: 11px;
  background-color: var(--color-2);
  border-radius: 4px;
}
@media (max-width: 767px) {
  .c-heading-1__tag {
    gap: 2.1vw;
    padding: 1.6vw 2.6vw;
  }
}
.c-heading-1__tag img {
  width: min(45px, 5vw);
}
@media (max-width: 767px) {
  .c-heading-1__tag img {
    width: 9.3vw;
  }
}
.c-heading-1__tag > span {
  font-family: "Figtree", sans-serif;
  letter-spacing: 0;
  font-size: min(16px, 1.3vw);
  color: var(--color-4);
  line-height: 1;
}
@media (max-width: 767px) {
  .c-heading-1__tag > span {
    font-size: 4.26vw;
  }
}
@media (max-width: 767px) {
  .c-heading-1__tag > span {
    font-size: min(12px, 1vw);
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .c-heading-1__tag > span {
    font-size: 3.2vw;
  }
}
.c-heading-1 h2 {
  color: var(--color-2);
  font-size: min(20px, 1.8vw);
  font-weight: 700;
}
@media (max-width: 767px) {
  .c-heading-1 h2 {
    font-size: 5.33vw;
  }
}
@media (max-width: 767px) {
  .c-heading-1 h2 {
    font-size: min(12px, 1vw);
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .c-heading-1 h2 {
    font-size: 3.2vw;
  }
}
.c-heading-1.is-white .c-heading-1__tag {
  background-color: var(--color-4);
}
.c-heading-1.is-white .c-heading-1__tag > span {
  color: var(--color-2);
}
.c-heading-1.is-white h2 {
  color: var(--color-4);
}

.c-section-heading {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: var(--pad-1) 0 70px;
}
@media (max-width: 767px) {
  .c-section-heading {
    gap: 10vw;
    padding-bottom: 10.6vw;
  }
}
.c-section-heading__inner {
  width: 84vw;
}
@media (max-width: 767px) {
  .c-section-heading__inner {
    width: calc(100vw - var(--gutter-1) * 2);
  }
}
.c-section-heading__inner > p {
  font-size: min(18px, 1.5vw);
  font-weight: 500;
  padding-left: 50px;
  max-width: 63vw;
  text-align: justify;
}
@media (max-width: 767px) {
  .c-section-heading__inner > p {
    font-size: 4.8vw;
  }
}
@media (max-width: 767px) {
  .c-section-heading__inner > p {
    font-size: min(14px, 1.2vw);
    padding-left: 0;
    max-width: 75vw;
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .c-section-heading__inner > p {
    font-size: 3.73vw;
  }
}
.c-section-heading__lead {
  font-size: clamp(50px, 4.79vw, 92px);
  font-weight: 700;
  line-height: 1.2;
  padding: 40px 0;
}
@media (max-width: 767px) {
  .c-section-heading__lead {
    font-size: 9.6vw;
    padding: 5.3vw 0;
    white-space: nowrap;
  }
}
.c-section-heading__lead span {
  display: flex;
  background-image: linear-gradient(to right, var(--color-2), var(--color-2));
  background-size: 100% 100%;
  background-position: bottom left;
  background-repeat: no-repeat;
  color: var(--color-4);
  padding: 0 15px 5px;
  display: flex;
  width: fit-content;
}
@media (max-width: 767px) {
  .c-section-heading__lead span {
    padding: 0.4vw 2.6vw 1vw;
  }
}
.c-section-heading.is-white {
  color: var(--color-4);
}
.c-section-heading.is-white .c-section-heading__lead span {
  background-image: linear-gradient(to right, var(--color-4), var(--color-4));
  color: var(--color-2);
}
.c-section-heading.is-white .c-section-heading__lead span.is-red {
  background-image: linear-gradient(to right, var(--color-2), var(--color-2));
  color: var(--color-4);
}

.c-entry-btn {
  width: min(150px, 10vw);
  aspect-ratio: 1/1;
  border-radius: 50%;
  background-color: var(--color-2);
  position: fixed;
  bottom: var(--gutter-1);
  right: var(--gutter-1);
  z-index: 999;
  transition: 0.3s ease;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (max-width: 767px) {
  .c-entry-btn {
    width: 18.6vw;
    bottom: 2.6vw;
    right: 2.6vw;
  }
}
.c-entry-btn__wheel {
  width: 69.3%;
}
.c-entry-btn__text {
  animation: entry-btn 10s linear infinite forwards;
  position: absolute;
  inset: 0;
  scale: 0.91;
}
@keyframes entry-btn {
  0% {
    rotate: 0;
  }
  100% {
    rotate: -1turn;
  }
}
@media (min-width: 767px) and (hover: hover) and (pointer: fine) {
  .c-entry-btn:hover {
    background-color: var(--color-1);
  }
}

.c-interview-modal {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 999999997;
  opacity: 0;
  visibility: hidden;
}
@media (max-width: 767px) {
  .c-interview-modal {
    bottom: auto;
    top: 0;
  }
}
.c-interview-modal.is-open {
  opacity: 1;
  visibility: visible;
}
.c-interview-modal__overlay {
  position: absolute;
  z-index: -1;
  inset: 0;
  backdrop-filter: blur(27px);
  --webkit-backdrop-filter: blur(27px);
  background-color: rgba(0, 0, 0, 0.3);
}
.c-interview-modal__close-btn {
  position: fixed;
  top: var(--gutter-1);
  right: var(--gutter-1);
  z-index: 99999999999;
  width: 3vw;
  aspect-ratio: 1/1;
  border-radius: 8px;
  border: solid 1px var(--color-4);
  transition: 0.3s ease;
  cursor: pointer;
}
@media (max-width: 767px) {
  .c-interview-modal__close-btn {
    width: 12vw;
    border-radius: 4px;
    top: auto;
    bottom: 2.6vw;
    right: 2.6vw;
    background-color: var(--color-4);
  }
}
.c-interview-modal__close-btn span {
  width: 100%;
  height: 100%;
  display: flex;
  transition: 0.3s ease;
  rotate: 45deg;
}
.c-interview-modal__close-btn span::before, .c-interview-modal__close-btn span::after {
  content: "";
  width: 25%;
  height: 1px;
  background-color: var(--color-4);
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  transition: 0.3s ease;
}
@media (max-width: 767px) {
  .c-interview-modal__close-btn span::before, .c-interview-modal__close-btn span::after {
    background-color: var(--color-1);
  }
}
.c-interview-modal__close-btn span::before {
  rotate: 90deg;
}
@media (min-width: 767px) and (hover: hover) and (pointer: fine) {
  .c-interview-modal__close-btn:hover {
    background-color: var(--color-4);
  }
  .c-interview-modal__close-btn:hover span {
    translate: 1% 0;
  }
  .c-interview-modal__close-btn:hover span::before, .c-interview-modal__close-btn:hover span::after {
    background-color: var(--color-1);
  }
  .c-interview-modal__close-btn:hover span::before {
    rotate: 1turn;
    top: 52%;
    width: 30%;
  }
  .c-interview-modal__close-btn:hover span::after {
    rotate: 225deg;
    top: 48%;
    left: 58%;
    width: 10%;
  }
}
.c-interview-modal.is-open {
  visibility: visible;
  opacity: 1;
}
.c-interview-modal__inner {
  overflow: hidden;
  display: grid;
  grid-template-columns: 1fr 1fr;
  height: 100vh;
}
@media (max-width: 767px) {
  .c-interview-modal__inner {
    grid-template-columns: 1fr;
    padding: 24vw var(--gutter-1);
    overflow: auto;
    gap: 7vw;
  }
}
@media (max-width: 767px) {
  .c-interview-modal__img {
    aspect-ratio: 335/219;
  }
}
.c-interview-modal__img img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.c-interview-modal__texts {
  padding: 8.3vw 6.7vw;
  color: var(--color-4);
  height: 100vh;
  overflow: auto;
}
@media (max-width: 767px) {
  .c-interview-modal__texts {
    height: auto;
    overflow: visible;
    padding: 0;
  }
}
.c-interview-modal__texts__heading__lead {
  font-size: min(56px, 3vw);
  line-height: 1.25;
  font-weight: 700;
}
@media (max-width: 767px) {
  .c-interview-modal__texts__heading__lead {
    font-size: 8vw;
  }
}
.c-interview-modal__texts__heading__name {
  font-size: min(14px, 1.2vw);
  line-height: 1.2;
  font-weight: 500;
  display: flex;
  align-items: stretch;
  gap: 0.9vw;
  opacity: 0.6;
  padding-top: 20px;
}
@media (max-width: 767px) {
  .c-interview-modal__texts__heading__name {
    font-size: 3.73vw;
  }
}
@media (max-width: 767px) {
  .c-interview-modal__texts__heading__name {
    font-size: min(11px, 0.95vw);
    padding-top: 4vw;
    gap: 2vw;
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .c-interview-modal__texts__heading__name {
    font-size: 2.93vw;
  }
}
.c-interview-modal__texts__heading__name > span {
  width: 1px;
  background-color: var(--color-4);
}
.c-interview-modal__texts__contents__heading {
  padding-top: 80px;
}
@media (max-width: 767px) {
  .c-interview-modal__texts__contents__heading {
    padding-top: 17vw;
  }
}
.c-interview-modal__texts__contents__heading__q {
  font-family: "Figtree", sans-serif;
  letter-spacing: 0;
  font-weight: 500;
  color: var(--color-2);
  background-color: var(--color-4);
  width: fit-content;
  line-height: 1;
  padding: 0 10px;
}
@media (max-width: 767px) {
  .c-interview-modal__texts__contents__heading__q {
    font-size: min(16px, 1.3vw);
    padding: 0 2vw;
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .c-interview-modal__texts__contents__heading__q {
    font-size: 4.26vw;
  }
}
.c-interview-modal__texts__contents__heading p {
  font-size: min(25px, 2vw);
  font-weight: 600;
  line-height: 1.32;
  padding-top: 10px;
}
@media (max-width: 767px) {
  .c-interview-modal__texts__contents__heading p {
    font-size: 6.66vw;
  }
}
@media (max-width: 767px) {
  .c-interview-modal__texts__contents__heading p {
    font-size: min(18px, 1.5vw);
    padding-top: 3.5vw;
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .c-interview-modal__texts__contents__heading p {
    font-size: 4.8vw;
  }
}
.c-interview-modal__texts__contents > p {
  padding-top: 25px;
  text-align: justify;
}
@media (max-width: 767px) {
  .c-interview-modal__texts__contents > p {
    font-size: min(14px, 1.2vw);
    padding-top: 5.3vw;
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .c-interview-modal__texts__contents > p {
    font-size: 3.73vw;
  }
}
.c-interview-modal__texts__contents__img {
  width: 100%;
  aspect-ratio: 708/398;
  border-radius: 10px;
  overflow: clip;
  margin-top: 40px;
}
@media (max-width: 767px) {
  .c-interview-modal__texts__contents__img {
    aspect-ratio: 334/132;
    border-radius: 4px;
    margin-top: 8vw;
  }
}
.c-interview-modal__texts__contents__img img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.c-header__logo {
  position: fixed;
  top: 30px;
  left: var(--gutter-1);
  top: var(--gutter-1);
  z-index: 9999999999;
  mix-blend-mode: difference;
}
@media (max-width: 767px) {
  .c-header__logo {
    left: 2.6vw;
    top: 2.6vw;
  }
}
.c-header__logo img {
  width: min(218px, 20vw);
}
@media (max-width: 767px) {
  .c-header__logo img {
    width: 31.4vw;
  }
}
.c-header__nav {
  position: fixed;
  right: var(--gutter-1);
  top: var(--gutter-1);
  z-index: 999;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 3px;
}
@media (max-width: 767px) {
  .c-header__nav {
    display: none;
  }
}
.c-header__nav a {
  padding: 5px 10px 7px;
  border-radius: 4px;
  background-color: var(--color-2);
  color: var(--color-4);
  border: solid 1px transparent;
  font-weight: 600;
  line-height: 1;
  display: flex;
  align-items: center;
}
.c-header__nav a::after {
  content: "-";
  margin-left: -5px;
  visibility: hidden;
  opacity: 0;
  transition: 0.3s ease;
}
@media (min-width: 767px) and (hover: hover) and (pointer: fine) {
  .c-header__nav a:hover {
    color: var(--color-2);
    border-color: var(--color-2);
    background-color: var(--color-4);
  }
  .c-header__nav a:hover::after {
    margin-left: 10px;
    opacity: 1;
    visibility: visible;
  }
}
.c-header__hamburger {
  display: none;
  justify-content: center;
  align-items: center;
  width: 12vw;
  aspect-ratio: 1/1;
  border-radius: 4px;
  background-color: var(--color-2);
  cursor: pointer;
  position: fixed;
  top: 2.6vw;
  right: 2.6vw;
  z-index: 9999999999;
}
@media (max-width: 767px) {
  .c-header__hamburger {
    display: flex;
  }
}
.c-header__hamburger span {
  width: 31%;
  height: 1px;
  transition: 0.3s ease;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}
.c-header__hamburger span::before, .c-header__hamburger span::after {
  content: "";
  width: 100%;
  height: 100%;
  background-color: var(--color-4);
  position: absolute;
  top: 0;
  left: 0;
  transition: 0.3s ease;
}
.c-header__hamburger span::before {
  top: -0.5vw;
}
.c-header__hamburger span::after {
  top: 0.5vw;
}
.c-header__hamburger.is-active span {
  rotate: 45deg;
  gap: 0;
}
.c-header__hamburger.is-active span::before, .c-header__hamburger.is-active span::after {
  top: 0;
}
.c-header__hamburger.is-active span::after {
  rotate: 270deg;
}

.c-footer {
  padding: max(4vw, 50px) max(4.7vw, 50px) max(6.35vw, 120px);
  background-color: var(--color-10);
  color: var(--color-4);
}
@media (max-width: 767px) {
  .c-footer {
    padding: 18.6vw var(--gutter-1);
  }
}
.c-footer__top {
  display: flex;
  justify-content: space-between;
}
.c-footer__top p {
  font-size: max(4.16vw, 40px);
  line-height: 1.1;
  font-weight: 700;
}
@media (max-width: 767px) {
  .c-footer__top p {
    display: none;
  }
}
.c-footer__top__nav {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 25px;
}
@media (max-width: 767px) {
  .c-footer__top__nav {
    align-items: flex-start;
    gap: 5.3vw;
  }
}
.c-footer__top__nav > span {
  font-family: "Figtree", sans-serif;
  letter-spacing: 0;
  font-size: min(16px, 1.3vw);
  opacity: 0.4;
}
@media (max-width: 767px) {
  .c-footer__top__nav > span {
    font-size: 4.26vw;
  }
}
@media (max-width: 767px) {
  .c-footer__top__nav > span {
    font-size: min(12px, 1vw);
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .c-footer__top__nav > span {
    font-size: 3.2vw;
  }
}
.c-footer__top__nav nav {
  display: grid;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 20px;
}
@media (max-width: 767px) {
  .c-footer__top__nav nav {
    align-items: flex-start;
    gap: 4vw;
  }
}
.c-footer__top__nav nav a {
  font-size: min(16px, 1.3vw);
  font-weight: 600;
  line-height: 1;
  padding-left: 10px;
  transition: 0.3s ease;
}
@media (max-width: 767px) {
  .c-footer__top__nav nav a {
    font-size: 4.26vw;
  }
}
@media (max-width: 767px) {
  .c-footer__top__nav nav a {
    font-size: min(14px, 1.2vw);
    padding: 0;
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .c-footer__top__nav nav a {
    font-size: 3.73vw;
  }
}
@media (min-width: 767px) and (hover: hover) and (pointer: fine) {
  .c-footer__top__nav nav a:hover {
    background-color: var(--color-2);
    padding-right: 20px;
  }
}
.c-footer__mid {
  padding: 86px 0 40px;
  border-bottom: solid 1px var(--color-4);
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}
@media (max-width: 767px) {
  .c-footer__mid {
    padding: 18.6vw 0 8vw;
    flex-direction: column-reverse;
    align-items: flex-start;
    gap: 5.3vw;
  }
}
.c-footer__mid__address p {
  opacity: 0.5;
  letter-spacing: 0.05em;
}
.c-footer__mid__address p:nth-of-type(1) {
  font-size: min(18px, 1.5vw);
}
@media (max-width: 767px) {
  .c-footer__mid__address p:nth-of-type(1) {
    font-size: 4.8vw;
  }
}
@media (max-width: 767px) {
  .c-footer__mid__address p:nth-of-type(1) {
    font-size: min(12px, 1vw);
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .c-footer__mid__address p:nth-of-type(1) {
    font-size: 3.2vw;
  }
}
.c-footer__mid__address p:nth-of-type(2) {
  font-size: min(16px, 1.3vw);
  padding-top: 10px;
  line-height: 1.5;
}
@media (max-width: 767px) {
  .c-footer__mid__address p:nth-of-type(2) {
    font-size: 4.26vw;
  }
}
@media (max-width: 767px) {
  .c-footer__mid__address p:nth-of-type(2) {
    font-size: min(12px, 1vw);
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .c-footer__mid__address p:nth-of-type(2) {
    font-size: 3.2vw;
  }
}
.c-footer__mid__address p:nth-of-type(2) a:nth-of-type(1) {
  text-decoration: underline;
  transition: 0.3s ease;
}
@media (min-width: 767px) and (hover: hover) and (pointer: fine) {
  .c-footer__mid__address p:nth-of-type(2) a:nth-of-type(1):hover {
    opacity: 0.3;
  }
}
.c-footer__mid__tag {
  padding: max(0.625vw, 10px) max(1.1vw, 20px);
  border-radius: 6px;
  background-color: var(--color-2);
  color: var(--color-4);
  display: flex;
  align-items: center;
  gap: 15px;
  font-family: "Figtree", sans-serif;
  letter-spacing: 0;
  font-size: clamp(14px, 1.35vw, 26px);
  line-height: 1;
  width: fit-content;
}
@media (max-width: 767px) {
  .c-footer__mid__tag {
    display: none;
  }
}
.c-footer__mid__tag img {
  width: max(3.4vw, 40px);
}
.c-footer__mid__logo img {
  width: max(200px, 11.3vw);
}
@media (max-width: 767px) {
  .c-footer__mid__logo img {
    width: 44.2vw;
  }
}
.c-footer__bot {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding-top: 40px;
}
@media (max-width: 767px) {
  .c-footer__bot {
    flex-direction: column;
    padding-top: 4.5vw;
    gap: 45vw;
  }
}
.c-footer__bot > span {
  font-size: min(12px, 1vw);
  font-family: "Figtree", sans-serif;
  letter-spacing: 0;
  opacity: 0.4;
}
@media (max-width: 767px) {
  .c-footer__bot > span {
    font-size: 3.2vw;
  }
}
@media (max-width: 767px) {
  .c-footer__bot > span {
    display: none;
  }
}
.c-footer__bot__nav {
  opacity: 0.5;
  display: flex;
  align-items: stretch;
  flex-wrap: wrap;
  gap: min(27px, 1.4vw);
}
@media (max-width: 767px) {
  .c-footer__bot__nav {
    gap: 3.5vw;
  }
}
.c-footer__bot__nav a {
  font-size: min(14px, 1.2vw);
  line-height: 1;
  transition: 0.3s ease;
}
@media (max-width: 767px) {
  .c-footer__bot__nav a {
    font-size: 3.73vw;
  }
}
@media (max-width: 767px) {
  .c-footer__bot__nav a {
    font-size: min(10px, 0.9vw);
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .c-footer__bot__nav a {
    font-size: 2.6vw;
  }
}
@media (min-width: 767px) and (hover: hover) and (pointer: fine) {
  .c-footer__bot__nav a:hover {
    opacity: 0.5;
  }
}
.c-footer__bot__nav > span {
  width: 1px;
  background-color: var(--color-4);
}
.c-footer__bot__sp {
  display: none;
  flex-direction: column;
}
@media (max-width: 767px) {
  .c-footer__bot__sp {
    display: flex;
  }
}
.c-footer__bot__sp__tag {
  padding: 2vw 3.5vw;
  border-radius: 4px;
  background-color: var(--color-2);
  color: var(--color-4);
  display: flex;
  align-items: center;
  gap: 2vw;
  font-family: "Figtree", sans-serif;
  letter-spacing: 0;
  font-size: min(12px, 1vw);
  line-height: 1;
  width: fit-content;
}
@media (max-width: 767px) {
  .c-footer__bot__sp__tag {
    font-size: 3.2vw;
  }
}
.c-footer__bot__sp__tag img {
  width: 7.7vw;
}
.c-footer__bot__sp > p {
  font-size: 9vw;
  line-height: 1.1;
  font-weight: 700;
  padding: 5vw 0 10vw;
}
.c-footer__bot__sp > span {
  font-family: "Figtree", sans-serif;
  letter-spacing: 0;
  font-size: min(10px, 0.9vw);
  line-height: 1;
  opacity: 0.4;
}
@media (max-width: 767px) {
  .c-footer__bot__sp > span {
    font-size: 2.6vw;
  }
}

.p-top__section-1 {
  position: relative;
  padding: var(--gutter-1);
  display: flex;
  align-items: flex-end;
  width: 100vw;
  height: 100vh;
  min-height: 700px;
  overflow: clip;
}
@media (max-width: 1200px) {
  .p-top__section-1 {
    max-height: 700px;
  }
}
@media (max-width: 767px) {
  .p-top__section-1 {
    height: auto;
    min-height: auto;
    max-height: none;
    padding: 0;
    flex-direction: column;
    align-items: center;
  }
}
.p-top__section-1__bg {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -3;
  width: 100%;
  height: 100%;
}
.p-top__section-1__bg img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.p-top__section-1__img {
  height: 81%;
  position: absolute;
  bottom: 0;
  left: 50%;
  z-index: -1;
  translate: -50% 0;
}
@media (max-width: 767px) {
  .p-top__section-1__img {
    position: relative;
    left: 0;
    translate: 0;
    height: auto;
    width: 100%;
    aspect-ratio: 375/430;
    display: flex;
    justify-content: center;
    align-items: flex-end;
  }
}
.p-top__section-1__img img {
  height: 100%;
}
@media (max-width: 767px) {
  .p-top__section-1__img img {
    height: auto;
    width: 97%;
  }
}
.p-top__section-1__texts {
  line-height: 1;
  clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
}
@media (max-width: 767px) {
  .p-top__section-1__texts {
    width: 100vw;
    padding: 17.5vh var(--gutter-1) 9vw;
    background-color: var(--color-1);
  }
}
.p-top__section-1__texts__tag {
  padding: max(0.625vw, 10px) max(1.1vw, 20px);
  border-radius: 6px;
  background-color: var(--color-2);
  color: var(--color-4);
  display: flex;
  align-items: center;
  gap: 15px;
  font-family: "Figtree", sans-serif;
  letter-spacing: 0;
  font-size: max(1.35vw, 18px);
  width: fit-content;
}
@media (max-width: 767px) {
  .p-top__section-1__texts__tag {
    font-size: min(14px, 1.2vw);
    border-radius: 4px;
    padding: 2.4vw 2.9vw;
    gap: 2.1vw;
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-top__section-1__texts__tag {
    font-size: 3.73vw;
  }
}
.p-top__section-1__texts__tag img {
  width: max(3.4vw, 40px);
}
@media (max-width: 767px) {
  .p-top__section-1__texts__tag img {
    width: 9.2vw;
  }
}
.p-top__section-1__texts > p {
  font-size: max(40px, 4.1vw);
  font-weight: 700;
  color: var(--color-4);
  background-color: var(--color-1);
  padding: max(1.04vw, 18px) max(2.44vw, 40px) max(1.3vw, 22px);
  border-radius: 10px;
  margin-top: 10px;
}
@media (max-width: 767px) {
  .p-top__section-1__texts > p {
    padding: 0;
    line-height: 1.2;
    margin-top: 5.6vw;
    font-size: 11.2vw;
    white-space: nowrap;
  }
}
.p-top__section-1 .c-bg-animation-texts {
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  z-index: -2;
}
.p-top__section-2 {
  background-color: var(--color-2);
  padding-bottom: 115px;
}
@media (max-width: 767px) {
  .p-top__section-2 {
    padding-bottom: 18.6vw;
  }
}
.p-top__section-2__main {
  display: grid;
  grid-template-columns: 40.3vw 1fr;
  gap: 8vw;
  padding: var(--pad-1) var(--gutter-1);
  position: relative;
  overflow: clip;
}
@media (max-width: 767px) {
  .p-top__section-2__main {
    grid-template-columns: 1fr;
    gap: 0;
    padding-bottom: 16vw;
  }
}
.p-top__section-2__main__img {
  height: auto;
  aspect-ratio: 775/540;
  border-radius: 10px;
  overflow: clip;
  position: sticky;
  top: 20vh;
}
@media (max-width: 767px) {
  .p-top__section-2__main__img {
    display: none;
  }
}
.p-top__section-2__main__img img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.p-top__section-2__main__right {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  color: var(--color-4);
}
.p-top__section-2__main__right__heading {
  width: 100%;
  display: flex;
  justify-content: flex-end;
}
.p-top__section-2__main__right__heading__inner {
  display: flex;
  flex-direction: column;
  gap: max(2.3vw, 30px);
}
@media (max-width: 767px) {
  .p-top__section-2__main__right__heading__inner {
    gap: 5.3vw;
    align-items: flex-end;
  }
}
.p-top__section-2__main__right__heading__inner > p {
  text-align: right;
  font-size: max(40px, 5.57vw);
  line-height: 1.1;
  font-weight: 700;
  width: fit-content;
  white-space: nowrap;
}
@media (max-width: 767px) {
  .p-top__section-2__main__right__heading__inner > p {
    font-size: min(40px, 3vw);
    line-height: 1.2;
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-top__section-2__main__right__heading__inner > p {
    font-size: 10.6vw;
  }
}
.p-top__section-2__main__right__img {
  display: none;
  width: 100%;
  aspect-ratio: 335/194;
  border-radius: 6px;
  overflow: hidden;
  margin-top: 8vw;
}
@media (max-width: 767px) {
  .p-top__section-2__main__right__img {
    display: flex;
  }
}
.p-top__section-2__main__right__img img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
@media (max-width: 767px) {
  .p-top__section-2__main__right__img img {
    transform-origin: bottom;
    scale: 1.03;
  }
}
.p-top__section-2__main__right > p {
  padding-top: 105px;
  font-size: max(18px, 1.3vw);
  font-weight: 600;
  line-height: 1.8;
  letter-spacing: 0.09em;
}
@media (max-width: 767px) {
  .p-top__section-2__main__right > p {
    font-size: min(16px, 1.3vw);
    padding-top: 10.6vw;
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-top__section-2__main__right > p {
    font-size: 4.26vw;
  }
}
.p-top__section-2__main > img {
  position: absolute;
  bottom: 0;
  right: -5.1vw;
  z-index: 0;
  opacity: 0.1;
  width: 43.6vw;
}
@media (max-width: 767px) {
  .p-top__section-2__main > img {
    width: 75vw;
    right: -11vw;
    bottom: -5.3vw;
  }
}
.p-top__section-2__slider {
  overflow: hidden;
  padding: 0 var(--gutter-1);
}
.p-top__section-2__slider .swiper {
  overflow: visible;
}
.p-top__section-2__slider .swiper .swiper-wrapper {
  -webkit-transition-timing-function: linear !important;
  -o-transition-timing-function: linear !important;
  transition-timing-function: linear !important;
}
.p-top__section-2__slider .swiper .swiper-wrapper .swiper-slide {
  aspect-ratio: 508/669;
  border-radius: 10px;
  overflow: clip;
}
.p-top__section-2__slider .swiper .swiper-wrapper .swiper-slide img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.p-top__section-3 {
  overflow: hidden;
  position: relative;
}
.p-top__section-3__item__img {
  width: 100vw;
  height: max(39vw, 500px);
  position: relative;
}
@media (max-width: 767px) {
  .p-top__section-3__item__img {
    height: auto;
    aspect-ratio: 375/246;
  }
}
.p-top__section-3__item__img > img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.p-top__section-3__item__img__heading {
  position: absolute;
  bottom: 14%;
  left: 0;
  z-index: 3;
}
@media (max-width: 767px) {
  .p-top__section-3__item__img__heading {
    bottom: 6.9vw;
  }
}
.p-top__section-3__item__img__heading__no {
  font-family: "Figtree", sans-serif;
  letter-spacing: 0;
  font-weight: 600;
  font-style: italic;
  font-size: max(10.4vw, 100px);
  color: var(--color-4);
  letter-spacing: -0.05em;
  line-height: 0.7;
}
@media (max-width: 767px) {
  .p-top__section-3__item__img__heading__no {
    font-size: 16vw;
  }
}
.p-top__section-3__item__img__heading__no.is-red {
  color: var(--color-2);
}
.p-top__section-3__item__img__heading h3 {
  font-size: max(3.1vw, 40px);
  line-height: 1.1;
  font-weight: 700;
  display: flex;
  flex-direction: column;
  gap: 6px;
  width: fit-content;
  margin-left: 57px;
}
@media (max-width: 767px) {
  .p-top__section-3__item__img__heading h3 {
    font-size: min(25px, 2vw);
    margin-left: var(--gutter-1);
    gap: 0.8vw;
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-top__section-3__item__img__heading h3 {
    font-size: 6.66vw;
  }
}
.p-top__section-3__item__img__heading h3 .line {
  background-image: linear-gradient(to right, var(--color-4), var(--color-4));
  background-size: 100% 100%;
  background-position: bottom left;
  background-repeat: no-repeat;
  padding: 0 15px 2px;
  width: fit-content;
}
@media (max-width: 767px) {
  .p-top__section-3__item__img__heading h3 .line {
    padding: 0.2vw 1.2vw 0.4vw;
  }
}
.p-top__section-3__item__img__heading h3 .line span {
  color: var(--color-2);
}
.p-top__section-3__item__texts {
  position: relative;
  padding: 5.5vw var(--gutter-1) 80px;
  background-color: var(--color-2);
  display: flex;
  justify-content: space-between;
  gap: 50px;
  flex-wrap: wrap;
}
@media (max-width: 767px) {
  .p-top__section-3__item__texts {
    padding: 8.5vw var(--gutter-1) 21vw;
    display: grid;
    grid-template-columns: 1fr;
    gap: 10.6vw;
  }
}
.p-top__section-3__item__texts__loop {
  display: flex;
  align-items: center;
  overflow: hidden;
  position: absolute;
  top: -5vw;
  left: 0;
  z-index: 1;
}
@media (max-width: 767px) {
  .p-top__section-3__item__texts__loop {
    top: -6vw;
  }
}
.p-top__section-3__item__texts__loop span {
  white-space: nowrap;
  font-size: 7.4vw;
  line-height: 1.2;
  color: var(--color-4);
  font-family: "Figtree", sans-serif;
  letter-spacing: 0;
  font-weight: 700;
  animation: scroll-text 50s linear infinite;
}
@media (max-width: 767px) {
  .p-top__section-3__item__texts__loop span {
    font-size: 10.1vw;
  }
}
.p-top__section-3__item__texts__loop span:after {
  content: attr(data-text);
  margin-left: 2vw;
}
.p-top__section-3__item__texts > p {
  max-width: 540px;
  color: var(--color-4);
  text-align: justify;
}
@media (max-width: 767px) {
  .p-top__section-3__item__texts > p {
    max-width: none;
  }
}
.p-top__section-3__item__texts__list {
  display: flex;
  align-items: stretch;
  gap: min(20px, 1vw);
  flex-wrap: wrap;
  position: relative;
}
@media (max-width: 767px) {
  .p-top__section-3__item__texts__list {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2.1vw;
  }
}
.p-top__section-3__item__texts__list .c-ill-copy {
  position: absolute;
  left: 0;
  bottom: -20px;
  width: fit-content;
  color: var(--color-4);
}
@media (max-width: 767px) {
  .p-top__section-3__item__texts__list .c-ill-copy {
    left: auto;
    right: 0;
    bottom: -5vw;
  }
}
.p-top__section-3__item__texts__list__item {
  padding: 15px;
  border-radius: 10px;
  background-color: var(--color-4);
  width: min(294px, 27vw);
  position: relative;
}
@media (max-width: 767px) {
  .p-top__section-3__item__texts__list__item {
    padding: 3.2vw;
    border-radius: 6px;
    width: 100%;
  }
}
.p-top__section-3__item__texts__list__item__tag {
  padding: 2px 10px;
  border-radius: 6px;
  width: fit-content;
  font-size: min(16px, 1.3vw);
  background-color: var(--color-2);
  color: var(--color-4);
  font-weight: 500;
}
@media (max-width: 767px) {
  .p-top__section-3__item__texts__list__item__tag {
    font-size: 4.26vw;
  }
}
@media (max-width: 767px) {
  .p-top__section-3__item__texts__list__item__tag {
    font-size: min(12px, 1vw);
    padding: 0.2vw 3.2vw 0.4vw;
    border-radius: 5px;
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-top__section-3__item__texts__list__item__tag {
    font-size: 3.2vw;
  }
}
.p-top__section-3__item__texts__list__item__img {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 30px 0;
}
@media (max-width: 767px) {
  .p-top__section-3__item__texts__list__item__img {
    position: absolute;
    right: 0;
    top: 0;
    height: 100%;
    padding: 3vw 6vw;
  }
}
.p-top__section-3__item__texts__list__item__img img {
  width: 80%;
}
@media (max-width: 767px) {
  .p-top__section-3__item__texts__list__item__img img {
    height: 100%;
    width: auto;
  }
}
.p-top__section-3__item__texts__list__item__number {
  display: flex;
  justify-content: flex-end;
  align-items: flex-end;
  gap: 4px;
  font-size: min(20px, 1.8vw);
  font-weight: 600;
  letter-spacing: 0;
}
@media (max-width: 767px) {
  .p-top__section-3__item__texts__list__item__number {
    font-size: 5.33vw;
  }
}
@media (max-width: 767px) {
  .p-top__section-3__item__texts__list__item__number {
    justify-content: flex-start;
    padding-top: 5.3vw;
    gap: 0.5vw;
    font-weight: 800;
  }
}
.p-top__section-3__item__texts__list__item__number span {
  font-family: "Figtree", sans-serif;
  letter-spacing: 0;
  font-size: max(4.16vw, 80px);
  font-weight: 700;
  color: var(--color-2);
  line-height: 0.9;
  letter-spacing: -0.03em;
  padding-right: 4px;
  font-weight: 700 !important;
}
@media (max-width: 767px) {
  .p-top__section-3__item__texts__list__item__number span {
    font-size: 21.3vw;
    padding-right: 1vw;
  }
}
@media (max-width: 767px) {
  .p-top__section-3__item__texts__list__item.overtime .p-top__section-3__item__texts__list__item__number {
    font-size: min(16px, 1.3vw);
    line-height: 2;
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-top__section-3__item__texts__list__item.overtime .p-top__section-3__item__texts__list__item__number {
    font-size: 4.26vw;
  }
}
.p-top__section-3__item:nth-of-type(2n+1) .p-top__section-3__item__texts__loop span {
  animation-direction: reverse;
}
.p-top__section-4 {
  overflow: hidden;
  position: relative;
  padding-bottom: var(--pad-1);
}
@media (max-width: 1200px) {
  .p-top__section-4 {
    padding-bottom: 21vw;
  }
}
.p-top__section-4::before {
  content: "";
  width: 100%;
  height: 100%;
  background-color: var(--color-4);
  position: absolute;
  top: 0;
  left: 0;
  z-index: -9;
}
.p-top__section-4__contents {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 15px;
  padding: 0 var(--gutter-1);
}
@media (max-width: 1200px) {
  .p-top__section-4__contents {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: 767px) {
  .p-top__section-4__contents {
    grid-template-columns: 1fr 1fr;
    gap: 1.6vw;
  }
}
.p-top__section-4__contents__item {
  padding: 25px;
  border-radius: 12px;
  background-color: var(--color-5);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  gap: 45px;
}
@media (max-width: 767px) {
  .p-top__section-4__contents__item {
    padding: 3.7vw 2.9vw;
    border-radius: 4px;
    gap: 6vw;
  }
}
.p-top__section-4__contents__item__tag {
  width: 100%;
  position: relative;
  left: -25px;
}
@media (max-width: 767px) {
  .p-top__section-4__contents__item__tag {
    left: -2.9vw;
  }
}
.p-top__section-4__contents__item__tag h3 {
  width: fit-content;
  padding: 2px 25px;
  background-color: var(--color-1);
  color: var(--color-4);
  border-radius: 0 7px 7px 0;
  font-size: min(20px, 1.5vw);
  font-weight: 600;
  letter-spacing: 0.03em;
  white-space: nowrap;
}
@media (max-width: 767px) {
  .p-top__section-4__contents__item__tag h3 {
    border-radius: 0 3px 3px 0;
    font-size: min(12px, 1vw);
    padding: 0.2vw 3.5vw;
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-top__section-4__contents__item__tag h3 {
    font-size: 3.2vw;
  }
}
.p-top__section-4__contents__item__main {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 35px;
  width: 100%;
}
@media (max-width: 767px) {
  .p-top__section-4__contents__item__main {
    gap: 4.5vw;
  }
}
.p-top__section-4__contents__item__main__img {
  width: 64.6%;
}
@media (max-width: 767px) {
  .p-top__section-4__contents__item__main__img {
    width: 85%;
  }
}
.p-top__section-4__contents__item__main__img img {
  width: 100%;
}
.p-top__section-4__contents__item__main__texts {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: flex-end;
  gap: 4px;
  line-height: 1;
  font-size: min(30px, 2vw);
  font-weight: 700;
}
@media (max-width: 767px) {
  .p-top__section-4__contents__item__main__texts {
    gap: 0.5vw;
    font-size: min(15px, 1.3vw);
    letter-spacing: 0;
    font-weight: 800;
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-top__section-4__contents__item__main__texts {
    font-size: 4vw;
  }
}
.p-top__section-4__contents__item__main__texts span {
  font-family: "Figtree", sans-serif;
  letter-spacing: 0;
  font-size: max(6.1vw, 40px);
  line-height: 0.65;
  letter-spacing: -0.03em;
  color: var(--color-2);
  padding-right: 0.5vw;
  font-weight: 700 !important;
}
@media (max-width: 767px) {
  .p-top__section-4__contents__item__main__texts span {
    font-size: 13.6vw;
  }
}
.p-top__section-4__contents__item__note {
  width: 100%;
  font-size: min(15px, 1.3vw);
  color: var(--color-6);
  line-height: 1.2;
  letter-spacing: 0;
  display: flex;
  justify-content: flex-end;
  align-items: flex-end;
  padding-top: 30px;
}
@media (max-width: 767px) {
  .p-top__section-4__contents__item__note {
    font-size: 4vw;
  }
}
@media (max-width: 767px) {
  .p-top__section-4__contents__item__note {
    font-size: min(8px, 0.8vw);
    padding-top: 2vw;
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-top__section-4__contents__item__note {
    font-size: 2.13vw;
  }
}
.p-top__section-4__contents__item.is-achievement {
  grid-column: span 2;
}
.p-top__section-4__contents__item.is-achievement .p-top__section-4__contents__item__main {
  display: grid;
  grid-template-columns: 341fr 383fr;
  padding: 0 2vw;
}
.p-top__section-4__contents__item.is-achievement .p-top__section-4__contents__item__main__img {
  width: auto;
}
.p-top__section-4__contents__item.is-achievement .p-top__section-4__contents__item__main__texts {
  width: auto;
  display: inline-block;
  font-size: min(20px, 1.8vw);
  line-height: 1.4;
  letter-spacing: 0.05em;
  text-wrap: pretty;
}
@media (max-width: 767px) {
  .p-top__section-4__contents__item.is-achievement .p-top__section-4__contents__item__main__texts {
    font-size: 5.33vw;
  }
}
@media (max-width: 767px) {
  .p-top__section-4__contents__item.is-achievement .p-top__section-4__contents__item__main__texts {
    font-size: min(12px, 1vw);
    white-space: nowrap;
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-top__section-4__contents__item.is-achievement .p-top__section-4__contents__item__main__texts {
    font-size: 3.2vw;
  }
}
.p-top__section-4__contents__item.is-achievement .p-top__section-4__contents__item__main__texts span {
  font-family: "Noto Sans JP", sans-serif;
  font-size: max(3.1vw, 40px);
  line-height: 1.2;
  font-weight: 800 !important;
}
@media (max-width: 767px) {
  .p-top__section-4__contents__item.is-achievement .p-top__section-4__contents__item__main__texts span {
    font-size: 6.5vw;
  }
}
.p-top__section-4__contents__item.is-achievement .p-top__section-4__contents__item__note {
  padding-top: 0;
}
@media (max-width: 767px) {
  .p-top__section-4__contents__item.is-achievement .p-top__section-4__contents__item__note {
    padding-top: 2vw;
  }
}
.p-top__section-4__contents__item.is-inspection {
  grid-column: span 2;
}
@media (max-width: 1200px) {
  .p-top__section-4__contents__item.is-inspection {
    order: 1;
  }
}
@media (max-width: 767px) {
  .p-top__section-4__contents__item.is-inspection {
    order: 0;
  }
}
.p-top__section-4__contents__item.is-inspection .p-top__section-4__contents__item__main {
  flex-direction: row;
  justify-content: space-between;
  padding: 0 4vw;
  gap: 3vw;
}
@media (max-width: 767px) {
  .p-top__section-4__contents__item.is-inspection .p-top__section-4__contents__item__main {
    padding: 0 6vw 0 2vw;
    gap: 4vw;
  }
}
.p-top__section-4__contents__item.is-inspection .p-top__section-4__contents__item__main__img {
  width: 50%;
}
.p-top__section-4__contents__item.is-inspection .p-top__section-4__contents__item__main__texts {
  display: inline-block;
  width: auto;
  text-align: right;
  line-height: 1.4;
}
.p-top__section-4__contents__item.is-inspection .p-top__section-4__contents__item__main__texts span {
  padding: 0;
}
.p-top__section-4__contents__item.is-inspection .p-top__section-4__contents__item__note {
  padding-top: 0;
}
.p-top__section-4 .c-ill-copy {
  padding: 10px var(--gutter-1) 0;
}
@media (max-width: 767px) {
  .p-top__section-4 .c-ill-copy {
    padding-top: 2vw;
  }
}
.p-top__section-5 {
  overflow: hidden;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-bottom: var(--pad-1);
}
@media (max-width: 767px) {
  .p-top__section-5 {
    padding-bottom: 21vw;
  }
}
.p-top__section-5::before {
  content: "";
  width: 100%;
  height: 100%;
  background-color: var(--color-2);
  position: absolute;
  top: 0;
  left: 0;
  z-index: -9;
}
.p-top__section-5__contents {
  width: 84vw;
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.1vw;
}
@media (max-width: 767px) {
  .p-top__section-5__contents {
    width: calc(100vw - var(--gutter-1) * 2);
  }
}
@media (max-width: 767px) {
  .p-top__section-5__contents {
    width: 100vw;
    gap: 4vw;
  }
}
.p-top__section-5__contents__item-wrap {
  display: flex;
}
@media (max-width: 767px) {
  .p-top__section-5__contents__item-wrap:nth-of-type(2n+1) {
    justify-content: flex-end;
  }
}
@media (max-width: 767px) {
  .p-top__section-5__contents__item-wrap:nth-of-type(2n+1) .p-top__section-5__contents__item {
    border-radius: 8px 0 0 8px;
  }
}
.p-top__section-5__contents__item-wrap:nth-of-type(2n) {
  justify-content: flex-end;
}
@media (max-width: 767px) {
  .p-top__section-5__contents__item-wrap:nth-of-type(2n) {
    justify-content: flex-start;
  }
}
@media (max-width: 767px) {
  .p-top__section-5__contents__item-wrap:nth-of-type(2n) .p-top__section-5__contents__item {
    border-radius: 0 8px 8px 0;
  }
}
.p-top__section-5__contents__item {
  width: 67.4vw;
  background-color: var(--color-7);
  border-radius: max(0.62vw, 6px);
  padding: min(30px, 1.7vw);
  display: grid;
  grid-template-columns: 30vw 1fr;
  gap: 2.3vw;
  color: var(--color-4);
  cursor: pointer;
  transition: 0.3s ease;
  min-height: 180px;
}
@media (max-width: 767px) {
  .p-top__section-5__contents__item {
    width: 85vw;
    border-radius: 0;
    padding: 3.7vw;
    grid-template-columns: 1fr;
    gap: 3vw;
    min-height: auto;
  }
}
.p-top__section-5__contents__item__img {
  aspect-ratio: 580/268;
  border-radius: 8px;
  overflow: hidden;
  position: relative;
}
@media (max-width: 767px) {
  .p-top__section-5__contents__item__img {
    width: 63.4vw;
    aspect-ratio: 239/125;
  }
}
.p-top__section-5__contents__item__img img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  transition: 0.3s ease-in-out;
}
.p-top__section-5__contents__item__img img:nth-of-type(2) {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  opacity: 0;
}
.p-top__section-5__contents__item__texts {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 20px;
}
@media (max-width: 767px) {
  .p-top__section-5__contents__item__texts {
    flex-direction: row;
    align-items: flex-end;
    gap: 2vw;
  }
}
.p-top__section-5__contents__item__texts__main__lead {
  font-size: min(40px, 2.4vw);
  font-weight: 700;
  line-height: 1.25;
}
@media (max-width: 767px) {
  .p-top__section-5__contents__item__texts__main__lead {
    font-size: min(18px, 1.5vw);
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-top__section-5__contents__item__texts__main__lead {
    font-size: 4.8vw;
  }
}
.p-top__section-5__contents__item__texts__main__name {
  font-size: min(16px, 1vw);
  line-height: 1;
  opacity: 0.6;
  display: flex;
  align-items: stretch;
  gap: 1vw;
  padding-top: 1vw;
}
@media (max-width: 767px) {
  .p-top__section-5__contents__item__texts__main__name {
    font-size: min(8px, 0.8vw);
    padding-top: 4vw;
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-top__section-5__contents__item__texts__main__name {
    font-size: 2.13vw;
  }
}
.p-top__section-5__contents__item__texts__main__name > span {
  width: 1px;
  background-color: var(--color-4);
}
.p-top__section-5__contents__item__texts__bottom {
  display: flex;
  justify-content: flex-end;
}
.p-top__section-5__contents__item__texts__bottom__btn {
  width: 3vw;
  height: -webkit-fill-available;
  aspect-ratio: 1/1;
  border-radius: max(0.42vw, 4px);
  border: solid 1px var(--color-4);
  position: relative;
  transition: 0.3s ease;
}
@media (max-width: 767px) {
  .p-top__section-5__contents__item__texts__bottom__btn {
    width: 7.5vw;
    border-radius: 4px;
  }
}
.p-top__section-5__contents__item__texts__bottom__btn span {
  width: 100%;
  height: 100%;
  display: flex;
  transition: 0.3s ease;
}
.p-top__section-5__contents__item__texts__bottom__btn span::before, .p-top__section-5__contents__item__texts__bottom__btn span::after {
  content: "";
  width: 25%;
  height: 1px;
  background-color: var(--color-4);
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  transition: 0.3s ease;
}
.p-top__section-5__contents__item__texts__bottom__btn span::before {
  rotate: 90deg;
}
@media (min-width: 767px) and (hover: hover) and (pointer: fine) {
  .p-top__section-5__contents__item:hover {
    background-color: var(--color-1);
    box-shadow: 0px 0px 6px 0px rgba(0, 0, 0, 0.45);
    scale: 1.02;
  }
  .p-top__section-5__contents__item:hover .p-top__section-5__contents__item__texts__bottom__btn {
    background-color: var(--color-4);
  }
  .p-top__section-5__contents__item:hover .p-top__section-5__contents__item__texts__bottom__btn span {
    translate: 1% 1%;
  }
  .p-top__section-5__contents__item:hover .p-top__section-5__contents__item__texts__bottom__btn span::before, .p-top__section-5__contents__item:hover .p-top__section-5__contents__item__texts__bottom__btn span::after {
    background-color: var(--color-1);
  }
  .p-top__section-5__contents__item:hover .p-top__section-5__contents__item__texts__bottom__btn span::before {
    rotate: 1turn;
    top: 52%;
    width: 30%;
  }
  .p-top__section-5__contents__item:hover .p-top__section-5__contents__item__texts__bottom__btn span::after {
    rotate: 225deg;
    top: 48%;
    left: 58%;
    width: 10%;
  }
  .p-top__section-5__contents__item:hover .p-top__section-5__contents__item__img img:nth-of-type(2) {
    opacity: 0;
  }
  .p-top__section-5__contents__item:hover .p-top__section-5__contents__item__img img:nth-of-type(2) {
    opacity: 1;
  }
}
.p-top__section-6 {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-bottom: var(--pad-1);
}
@media (max-width: 767px) {
  .p-top__section-6 {
    padding-bottom: 21vw;
  }
}
@media (max-width: 767px) {
  .p-top__section-6 .c-section-heading__inner > p {
    max-width: none;
  }
}
.p-top__section-6__contents {
  width: 84vw;
}
@media (max-width: 767px) {
  .p-top__section-6__contents {
    width: calc(100vw - var(--gutter-1) * 2);
  }
}
.p-top__section-6__contents__item {
  border-bottom: solid 1px var(--color-1);
  padding: max(3.1vw, 60px) 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
}
@media (max-width: 767px) {
  .p-top__section-6__contents__item {
    grid-template-columns: 1fr;
    padding: 5vw 0 10.6vw;
  }
}
.p-top__section-6__contents__item:nth-of-type(1) {
  border-top: solid 1px var(--color-1);
}
.p-top__section-6__contents__item__heading {
  padding-right: 40px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 50px;
}
@media (max-width: 767px) {
  .p-top__section-6__contents__item__heading {
    padding-right: 0;
  }
}
.p-top__section-6__contents__item__heading h3 {
  font-size: min(30px, 2.5vw);
  font-weight: 700;
  line-height: 1.2;
}
@media (max-width: 767px) {
  .p-top__section-6__contents__item__heading h3 {
    font-size: 8vw;
  }
}
@media (max-width: 767px) {
  .p-top__section-6__contents__item__heading h3 {
    font-size: min(18px, 1.5vw);
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-top__section-6__contents__item__heading h3 {
    font-size: 4.8vw;
  }
}
.p-top__section-6__contents__item__heading__illust {
  width: fit-content;
  padding: 33px 57px;
  border-radius: 10px;
  background-color: var(--color-4);
}
@media (max-width: 767px) {
  .p-top__section-6__contents__item__heading__illust {
    display: none;
  }
}
.p-top__section-6__contents__item__heading__illust img {
  width: min(261px, 20vw);
}
@media (max-width: 767px) {
  .p-top__section-6__contents__item__main {
    padding-top: 15vw;
  }
}
.p-top__section-6__contents__item__main ul {
  display: grid;
  grid-template-columns: 1fr;
  gap: 15px;
}
@media (max-width: 767px) {
  .p-top__section-6__contents__item__main ul {
    gap: 2.1vw;
  }
}
.p-top__section-6__contents__item__main ul li {
  padding: 25px 30px;
  border-radius: 10px;
  background-color: var(--color-4);
}
@media (max-width: 767px) {
  .p-top__section-6__contents__item__main ul li {
    padding: 4vw 5.3vw;
    border-radius: 6px;
  }
}
.p-top__section-6__contents__item__main ul li h4 {
  font-size: min(20px, 1.8vw);
  line-height: 1.4;
  font-weight: 800;
  color: var(--color-2);
  border-bottom: solid 1px var(--color-5);
  padding-bottom: 12px;
  margin-bottom: 12px;
}
@media (max-width: 767px) {
  .p-top__section-6__contents__item__main ul li h4 {
    font-size: 5.33vw;
  }
}
@media (max-width: 767px) {
  .p-top__section-6__contents__item__main ul li h4 {
    font-size: min(16px, 1.3vw);
    padding-bottom: 3vw;
    margin-bottom: 3vw;
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-top__section-6__contents__item__main ul li h4 {
    font-size: 4.26vw;
  }
}
.p-top__section-6__contents__item__main ul li > p {
  font-size: min(14px, 1.2vw);
}
@media (max-width: 767px) {
  .p-top__section-6__contents__item__main ul li > p {
    font-size: 3.73vw;
  }
}
@media (max-width: 767px) {
  .p-top__section-6__contents__item__main ul li > p {
    font-size: min(13px, 1.1vw);
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-top__section-6__contents__item__main ul li > p {
    font-size: 3.46vw;
  }
}
.p-top__section-6__contents__item__illust {
  width: 50%;
  aspect-ratio: 1/1;
  display: none;
  justify-content: center;
  align-items: center;
  margin-top: 21vw;
  border-radius: 6px;
  background-color: var(--color-4);
}
@media (max-width: 767px) {
  .p-top__section-6__contents__item__illust {
    display: flex;
  }
}
.p-top__section-6__contents__item__illust img {
  width: 70%;
}
.p-top__section-6 .c-ill-copy {
  padding-top: 10px;
}
@media (max-width: 767px) {
  .p-top__section-6 .c-ill-copy {
    padding-top: 2vw;
  }
}
.p-top__section-7 {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-bottom: var(--pad-1);
}
.p-top__section-7::before {
  content: "";
  width: 100%;
  height: 100%;
  background-color: var(--color-4);
  position: absolute;
  top: 0;
  left: 0;
  z-index: -9;
}
@media (max-width: 767px) {
  .p-top__section-7 .c-section-heading__inner > p {
    max-width: none;
  }
}
.p-top__section-7__tab {
  width: 84vw;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: min(100px, 7vw);
}
@media (max-width: 767px) {
  .p-top__section-7__tab {
    width: calc(100vw - var(--gutter-1) * 2);
  }
}
@media (max-width: 767px) {
  .p-top__section-7__tab {
    grid-template-columns: 1fr;
    gap: 14vw;
  }
}
.p-top__section-7__tab__nav {
  display: grid;
  grid-template-columns: 1fr;
  gap: 5px;
  height: fit-content;
  position: sticky;
  top: 20vh;
  z-index: 9;
}
@media (max-width: 767px) {
  .p-top__section-7__tab__nav {
    display: flex;
    flex-wrap: wrap;
    gap: 1.4vw 1.5vw;
    top: 85dvh;
    max-width: 70vw;
  }
}
.p-top__section-7__tab__nav__item {
  min-width: 15.4vw;
  padding: min(1vw, 18px) min(2vw, 36px);
  font-size: min(20px, 1.8vw);
  line-height: 1.4;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 12px;
  border-radius: 8px;
  cursor: pointer;
  position: relative;
  transition: 0.3s ease;
  background-color: var(--color-4);
}
@media (max-width: 767px) {
  .p-top__section-7__tab__nav__item {
    font-size: 5.33vw;
  }
}
@media (max-width: 767px) {
  .p-top__section-7__tab__nav__item {
    font-size: min(14px, 1.2vw);
    padding: 1.5vw 3vw;
    border-radius: 4px;
    gap: 2vw;
    border: solid 1px var(--color-1);
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-top__section-7__tab__nav__item {
    font-size: 3.73vw;
  }
}
.p-top__section-7__tab__nav__item::before {
  content: "";
  width: min(15px, 1.2vw);
  aspect-ratio: 1/1;
  border-radius: 3px;
  background-color: var(--color-2);
  scale: 0;
  transition: scale 0.3s ease;
}
@media (max-width: 767px) {
  .p-top__section-7__tab__nav__item::before {
    width: 2vw;
    border-radius: 2px;
  }
}
.p-top__section-7__tab__nav__item.is-active {
  background-color: var(--color-3);
}
.p-top__section-7__tab__nav__item.is-active::before {
  display: flex;
  scale: 1;
}
@media (min-width: 767px) and (hover: hover) and (pointer: fine) {
  .p-top__section-7__tab__nav__item:hover {
    background-color: var(--color-3);
  }
}
.p-top__section-7__tab__contents {
  border-left: solid 1px var(--color-8);
  padding-left: min(60px, 4vw);
}
@media (max-width: 767px) {
  .p-top__section-7__tab__contents {
    border: none;
    padding: 0;
    padding-bottom: 30vw;
  }
}
.p-top__section-7__tab__contents__item {
  display: none;
  grid-template-columns: 1fr;
}
.p-top__section-7__tab__contents__item.is-active {
  display: grid;
}
.p-top__section-7__tab__contents__item h3 {
  font-size: min(50px, 3.5vw);
  font-weight: 700;
  line-height: 1.4;
  padding: 25px 0 45px;
}
@media (max-width: 767px) {
  .p-top__section-7__tab__contents__item h3 {
    font-size: 13.3vw;
  }
}
@media (max-width: 767px) {
  .p-top__section-7__tab__contents__item h3 {
    font-size: min(25px, 2vw);
    padding: 0 0 6.6vw;
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-top__section-7__tab__contents__item h3 {
    font-size: 6.66vw;
  }
}
.p-top__section-7__tab__contents__item > ul li {
  border-bottom: solid 1px var(--color-8);
  padding: 55px 0;
  display: grid;
  grid-template-columns: min(214px, 12vw) 1fr;
}
@media (max-width: 767px) {
  .p-top__section-7__tab__contents__item > ul li {
    padding: 7vw 0;
    grid-template-columns: 1fr;
    gap: 3.5vw;
  }
}
.p-top__section-7__tab__contents__item > ul li:nth-of-type(1) {
  border-top: solid 1px var(--color-8);
}
.p-top__section-7__tab__contents__item > ul li h4 {
  padding: 0 min(33px, 2vw);
  font-size: min(18px, 1.5vw);
  font-weight: 700;
  position: relative;
}
@media (max-width: 767px) {
  .p-top__section-7__tab__contents__item > ul li h4 {
    font-size: 4.8vw;
  }
}
@media (max-width: 767px) {
  .p-top__section-7__tab__contents__item > ul li h4 {
    padding: 0;
    font-size: min(14px, 1.2vw);
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-top__section-7__tab__contents__item > ul li h4 {
    font-size: 3.73vw;
  }
}
.p-top__section-7__tab__contents__item > ul li h4::before {
  content: "";
  width: 1px;
  height: calc(100% + 40px);
  background-color: var(--color-8);
  position: absolute;
  top: 50%;
  right: 0;
  translate: 0 -50%;
}
@media (max-width: 767px) {
  .p-top__section-7__tab__contents__item > ul li h4::before {
    display: none;
  }
}
.p-top__section-7__tab__contents__item > ul li > p {
  padding-left: 45px;
  font-size: min(18px, 1.5vw);
  max-width: 700px;
}
@media (max-width: 767px) {
  .p-top__section-7__tab__contents__item > ul li > p {
    font-size: 4.8vw;
  }
}
@media (max-width: 767px) {
  .p-top__section-7__tab__contents__item > ul li > p {
    padding: 0;
    font-size: min(14px, 1.2vw);
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-top__section-7__tab__contents__item > ul li > p {
    font-size: 3.73vw;
  }
}
.p-top__section-7__tab__contents__item > ul li > p a {
  text-decoration: underline;
  transition: 0.3s ease;
}
@media (min-width: 767px) and (hover: hover) and (pointer: fine) {
  .p-top__section-7__tab__contents__item > ul li > p a:hover {
    opacity: 0.5;
  }
}
.p-top__section-8 {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  overflow: clip;
  padding-bottom: var(--pad-1);
}
@media (max-width: 767px) {
  .p-top__section-8 {
    padding-bottom: 21vw;
  }
}
.p-top__section-8::before {
  content: "";
  width: 100%;
  height: 100%;
  background-color: var(--color-1);
  position: absolute;
  top: 0;
  left: 0;
  z-index: -9;
}
@media (max-width: 767px) {
  .p-top__section-8 .c-section-heading__inner > p {
    max-width: none;
  }
}
.p-top__section-8 .c-bg-animation-texts {
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  z-index: -1;
  opacity: 0.3;
}
.p-top__section-8__contents {
  width: min(806px, 90%);
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
}
@media (max-width: 767px) {
  .p-top__section-8__contents {
    width: 84vw;
    gap: 2.6vw;
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-top__section-8__contents {
    width: calc(100vw - var(--gutter-1) * 2);
  }
}
.p-top__section-8__contents__item {
  padding: 35px 40px;
  border-radius: 12px;
  background-color: var(--color-7);
  color: var(--color-4);
}
@media (max-width: 767px) {
  .p-top__section-8__contents__item {
    padding: 5.3vw;
    border-radius: 10px;
  }
}
.p-top__section-8__contents__item h3 {
  font-size: min(25px, 2vw);
  font-weight: 700;
  line-height: 1.3;
  display: flex;
  align-items: stretch;
  gap: 12px;
  padding-bottom: 90px;
}
@media (max-width: 767px) {
  .p-top__section-8__contents__item h3 {
    font-size: 6.66vw;
  }
}
@media (max-width: 767px) {
  .p-top__section-8__contents__item h3 {
    font-size: min(18px, 1.5vw);
    gap: 2.5vw;
    padding-bottom: 10.6vw;
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-top__section-8__contents__item h3 {
    font-size: 4.8vw;
  }
}
.p-top__section-8__contents__item h3::before {
  content: "";
  width: 8px;
  background-color: var(--color-2);
}
@media (max-width: 767px) {
  .p-top__section-8__contents__item h3::before {
    width: 1.8vw;
  }
}
.p-top__section-8__contents__item__main.is-tel {
  display: flex;
  flex-direction: column;
}
.p-top__section-8__contents__item__main.is-tel a {
  font-family: "Figtree", sans-serif;
  letter-spacing: 0;
  font-size: min(80px, 5vw);
  font-weight: 700;
  line-height: 1;
}
@media (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-tel a {
    font-size: 9.3vw;
  }
}
.p-top__section-8__contents__item__main.is-tel > span {
  font-size: min(16px, 1.3vw);
  opacity: 0.5;
  font-weight: 300;
  letter-spacing: 0.03em;
}
@media (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-tel > span {
    font-size: 4.26vw;
  }
}
@media (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-tel > span {
    font-size: min(10px, 0.9vw);
    padding-top: 1vw;
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-tel > span {
    font-size: 2.6vw;
  }
}
.p-top__section-8__contents__item__main.is-entry .form {
  display: flex;
  flex-direction: column;
}
.p-top__section-8__contents__item__main.is-entry .form__list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 25px;
}
@media (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-entry .form__list {
    gap: 4vw;
  }
}
.p-top__section-8__contents__item__main.is-entry .form__list__item__heading label {
  font-size: min(18px, 1.5vw);
  font-weight: 600;
  line-height: 1;
}
@media (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-entry .form__list__item__heading label {
    font-size: 4.8vw;
  }
}
@media (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-entry .form__list__item__heading label {
    font-size: min(14px, 1.2vw);
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-entry .form__list__item__heading label {
    font-size: 3.73vw;
  }
}
.p-top__section-8__contents__item__main.is-entry .form__list__item__heading label span {
  color: var(--color-2);
  padding-left: 2px;
}
.p-top__section-8__contents__item__main.is-entry .form__list__item__body {
  padding-top: 6px;
}
@media (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-entry .form__list__item__body {
    padding-top: 1vw;
  }
}
.p-top__section-8__contents__item__main.is-entry .form__list__item__body input,
.p-top__section-8__contents__item__main.is-entry .form__list__item__body select,
.p-top__section-8__contents__item__main.is-entry .form__list__item__body textarea {
  padding: 10px 20px;
  border-radius: 6px;
  background-color: var(--color-9);
  width: 100%;
  font-size: clamp(16px, 0.94vw, 18px);
}
@media (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-entry .form__list__item__body input,
  .p-top__section-8__contents__item__main.is-entry .form__list__item__body select,
  .p-top__section-8__contents__item__main.is-entry .form__list__item__body textarea {
    font-size: max(16px, 4.26vw);
    border-radius: 4px;
    padding: 1.4vw 3vw;
  }
}
.p-top__section-8__contents__item__main.is-entry .form__list__item__body textarea {
  min-height: 200px;
  height: 200px;
}
@media (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-entry .form__list__item__body textarea {
    min-height: 30vw;
    height: 30vw;
  }
}
.p-top__section-8__contents__item__main.is-entry .form__acceptance {
  padding: 45px 0 10px;
}
@media (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-entry .form__acceptance {
    padding: 12vw 0 3vw;
  }
}
.p-top__section-8__contents__item__main.is-entry .form__acceptance label {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
}
.p-top__section-8__contents__item__main.is-entry .form__acceptance label input {
  appearance: none;
  width: 20px;
  height: auto;
  aspect-ratio: 1/1;
  border-radius: 1px;
  background-color: var(--color-9);
  position: relative;
  cursor: pointer;
}
@media (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-entry .form__acceptance label input {
    width: 5.3vw;
  }
}
.p-top__section-8__contents__item__main.is-entry .form__acceptance label input::before {
  content: "";
  width: 60%;
  height: 30%;
  border-bottom: solid 2px var(--color-4);
  border-left: solid 2px var(--color-4);
  position: absolute;
  top: 45%;
  left: 52%;
  translate: -50% -50%;
  rotate: -43deg;
  display: none;
}
.p-top__section-8__contents__item__main.is-entry .form__acceptance label input:checked::before {
  display: flex;
}
.p-top__section-8__contents__item__main.is-entry .form__acceptance label a {
  text-decoration: underline;
}
@media (min-width: 767px) and (hover: hover) and (pointer: fine) {
  .p-top__section-8__contents__item__main.is-entry .form__acceptance label a:hover {
    opacity: 0.5;
  }
}
.p-top__section-8__contents__item__main.is-entry .form__btn {
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: var(--color-2);
  color: var(--color-4);
  border-radius: 6px;
  width: 100%;
  text-align: center;
  height: min(128px, 11vw);
  font-size: min(25px, 2vw);
  font-weight: 500;
  transition: 0.3s ease;
  cursor: pointer;
}
@media (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-entry .form__btn {
    font-size: 6.66vw;
  }
}
@media (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-entry .form__btn {
    height: 17vw;
    font-size: min(15px, 1.3vw);
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-entry .form__btn {
    font-size: 4vw;
  }
}
.p-top__section-8__contents__item__main.is-entry .form__btn[disabled] {
  pointer-events: none;
  background-color: rgb(92, 92, 92);
}
@media (min-width: 767px) and (hover: hover) and (pointer: fine) {
  .p-top__section-8__contents__item__main.is-entry .form__btn:hover {
    background-color: var(--color-1);
  }
}
.p-top__section-8__contents__item__main.is-entry .confirm {
  display: none;
  flex-direction: column;
  gap: 40px;
}
@media (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-entry .confirm {
    gap: 8vw;
  }
}
.p-top__section-8__contents__item__main.is-entry .confirm > p {
  font-size: min(30px, 2.5vw);
  font-weight: 600;
}
@media (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-entry .confirm > p {
    font-size: 8vw;
  }
}
@media (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-entry .confirm > p {
    font-size: min(18px, 1.5vw);
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-entry .confirm > p {
    font-size: 4.8vw;
  }
}
.p-top__section-8__contents__item__main.is-entry .confirm__list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
@media (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-entry .confirm__list {
    gap: 3vw;
  }
}
.p-top__section-8__contents__item__main.is-entry .confirm__list__item p:nth-of-type(1) {
  font-size: min(14px, 1.2vw);
  line-height: 1;
  opacity: 0.5;
}
@media (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-entry .confirm__list__item p:nth-of-type(1) {
    font-size: 3.73vw;
  }
}
.p-top__section-8__contents__item__main.is-entry .confirm__list__item p:nth-of-type(2) {
  font-size: clamp(16px, 0.94vw, 18px);
}
@media (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-entry .confirm__list__item p:nth-of-type(2) {
    font-size: min(16px, 1.3vw);
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-entry .confirm__list__item p:nth-of-type(2) {
    font-size: 4.26vw;
  }
}
.p-top__section-8__contents__item__main.is-entry .confirm__btn {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
@media (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-entry .confirm__btn {
    gap: 3vw;
  }
}
.p-top__section-8__contents__item__main.is-entry .confirm__btn input {
  background-color: var(--color-2);
  color: var(--color-4);
  border-radius: 6px;
  width: 100%;
  text-align: center;
  height: min(128px, 11vw);
  font-size: min(25px, 2vw);
  font-weight: 500;
  transition: 0.3s ease;
}
@media (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-entry .confirm__btn input {
    font-size: 6.66vw;
  }
}
@media (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-entry .confirm__btn input {
    height: 17vw;
    font-size: min(15px, 1.3vw);
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-top__section-8__contents__item__main.is-entry .confirm__btn input {
    font-size: 4vw;
  }
}
@media (min-width: 767px) and (hover: hover) and (pointer: fine) {
  .p-top__section-8__contents__item__main.is-entry .confirm__btn input:hover {
    background-color: #780408;
  }
}
.p-top__section-8__contents__item__main.is-entry .confirm__btn input:nth-of-type(1) {
  background-color: var(--color-1);
}
@media (min-width: 767px) and (hover: hover) and (pointer: fine) {
  .p-top__section-8__contents__item__main.is-entry .confirm__btn input:nth-of-type(1):hover {
    background-color: rgb(92, 92, 92);
  }
}

.p-entry-thanks {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0 var(--gutter-1);
  min-height: 80vh;
}
.p-entry-thanks__inner {
  padding: 200px 0;
  width: min(100%, 700px);
}
@media (max-width: 767px) {
  .p-entry-thanks__inner {
    padding: 30vh 0 20vh;
  }
}
.p-entry-thanks__inner h1 {
  font-size: min(40px, 3vw);
  font-weight: 700;
}
@media (max-width: 767px) {
  .p-entry-thanks__inner h1 {
    font-size: 10.6vw;
  }
}
@media (max-width: 767px) {
  .p-entry-thanks__inner h1 {
    font-size: min(25px, 2vw);
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-entry-thanks__inner h1 {
    font-size: 6.66vw;
  }
}
.p-entry-thanks__inner > p {
  font-size: min(16px, 1.3vw);
  padding: 30px 0 50px;
}
@media (max-width: 767px) {
  .p-entry-thanks__inner > p {
    font-size: 4.26vw;
  }
}
@media (max-width: 767px) {
  .p-entry-thanks__inner > p {
    font-size: min(14px, 1.2vw);
    padding: 7vw 0 12vw;
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-entry-thanks__inner > p {
    font-size: 3.73vw;
  }
}
.p-entry-thanks__inner > p a {
  text-decoration: underline;
  white-space: nowrap;
}
.p-entry-thanks__inner > a {
  padding: 15px 30px;
  background-color: var(--color-2);
  color: var(--color-4);
  border: solid 1px var(--color-2);
  font-size: min(14px, 1.2vw);
  line-height: 1;
  border-radius: 4px;
  transition: 0.3s ease;
}
@media (max-width: 767px) {
  .p-entry-thanks__inner > a {
    font-size: 3.73vw;
  }
}
@media (max-width: 767px) {
  .p-entry-thanks__inner > a {
    font-size: min(12px, 1vw);
    padding: 3vw 7vw;
  }
}
@media (max-width: 767px) and (max-width: 767px) {
  .p-entry-thanks__inner > a {
    font-size: 3.2vw;
  }
}
@media (min-width: 767px) and (hover: hover) and (pointer: fine) {
  .p-entry-thanks__inner > a:hover {
    background-color: transparent;
    color: var(--color-2);
  }
}