.toc__link:first-child {
  background-color: var(--color-green);
  color: #fff;
}

.lead-block {
  padding: 8rem 0 0;
  display: grid;
  gap: 4rem;
}
@media (768px <= width) {
  .lead-block {
    padding: 12rem 0 16rem;
    gap: 8.2rem;
  }
}
@media (768px <= width) {
  .lead-block__wrap--01 {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    align-items: center;
  }
  .lead-block__wrap--01 *:nth-last-child(1) {
    order: 1;
  }
  .lead-block__wrap--01 *:nth-last-child(2) {
    order: 2;
  }
  .lead-block__wrap--01 *:nth-last-child(3) {
    order: 3;
  }
  .lead-block__wrap--01 *:nth-last-child(4) {
    order: 4;
  }
  .lead-block__wrap--01 *:nth-last-child(5) {
    order: 5;
  }
  .lead-block__wrap--01 *:nth-last-child(6) {
    order: 6;
  }
  .lead-block__wrap--01 *:nth-last-child(7) {
    order: 7;
  }
  .lead-block__wrap--01 *:nth-last-child(8) {
    order: 8;
  }
  .lead-block__wrap--01 *:nth-last-child(9) {
    order: 9;
  }
}
@media (768px <= width) {
  .lead-block__wrap--02 {
    margin: 0 max(50% - 80rem, 6rem) 0 max(50% - 90rem, 3rem);
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    align-items: center;
  }
  .lead-block__wrap--02 *:nth-last-child(1) {
    order: 1;
  }
  .lead-block__wrap--02 *:nth-last-child(2) {
    order: 2;
  }
  .lead-block__wrap--02 *:nth-last-child(3) {
    order: 3;
  }
  .lead-block__wrap--02 *:nth-last-child(4) {
    order: 4;
  }
  .lead-block__wrap--02 *:nth-last-child(5) {
    order: 5;
  }
  .lead-block__wrap--02 *:nth-last-child(6) {
    order: 6;
  }
  .lead-block__wrap--02 *:nth-last-child(7) {
    order: 7;
  }
  .lead-block__wrap--02 *:nth-last-child(8) {
    order: 8;
  }
  .lead-block__wrap--02 *:nth-last-child(9) {
    order: 9;
  }
}
.lead-block__wrap--01 .lead-block__img-wrap {
  margin-left: 2rem;
}
.lead-block__wrap--01 .lead-block__img-wrap img {
  border-radius: 12rem 0 0 1rem;
}
@media (768px <= width) {
  .lead-block__wrap--01 .lead-block__img-wrap {
    margin-left: auto;
    width: calc(100% - 8.4rem);
  }
  .lead-block__wrap--01 .lead-block__img-wrap img {
    border-radius: 12rem 0 0 2rem;
    width: 100%;
  }
}
.lead-block__wrap--02 .lead-block__img-wrap {
  margin: 4rem 2rem 0;
}
.lead-block__wrap--02 .lead-block__img-wrap img {
  border-radius: 1rem;
}
@media (768px <= width) {
  .lead-block__wrap--02 .lead-block__img-wrap {
    margin: 0;
  }
  .lead-block__wrap--02 .lead-block__img-wrap img {
    border-radius: 2rem;
  }
}
.lead-block__textbox {
  margin: 0 2rem;
}
@media (768px <= width) {
  .lead-block__textbox {
    margin: 0;
  }
}
.lead-block__wrap--01 .lead-block__textbox {
  margin-top: 4rem;
  font-size: 2.6rem;
  font-weight: 700;
  line-height: 166%;
}
@media (768px <= width) {
  .lead-block__wrap--01 .lead-block__textbox {
    font-size: 5.2rem;
    margin-top: 0;
    margin-left: max(100% - 80rem, 6rem);
  }
}
.lead-block__wrap--02 .lead-block__textbox {
  line-height: 250%;
}
@media (768px <= width) {
  .lead-block__wrap--02 .lead-block__textbox {
    font-size: 1.8rem;
    width: calc(100% - 8.4rem);
    margin-left: auto;
  }
}

.aboutus {
  padding: 8rem 0;
  position: relative;
}
@media (768px <= width) {
  .aboutus {
    padding: 16rem 0;
  }
}
.aboutus::before {
  content: "";
  width: 100%;
  position: absolute;
  top: 29.8rem;
  bottom: 0;
  background: var(--color-bg);
  border-radius: 0 2rem 0 12rem;
  z-index: -1;
}
@media (768px <= width) {
  .aboutus::before {
    top: 0;
    right: 0;
    left: max(50% - 60rem, 18rem);
    border-radius: 16rem 0 0 3rem;
    width: auto;
  }
}
.aboutus__headline {
  margin: 0 2rem;
}
@media (768px <= width) {
  .aboutus__headline {
    margin: 0 max(50% - 80rem, 6rem);
  }
}
.aboutus__body {
  margin-top: 3.5rem;
}
@media (768px <= width) {
  .aboutus__body {
    margin-top: 10rem;
    display: grid;
    grid-template-columns: 50% auto;
    gap: min(8.3333333333%, 16rem);
    align-items: center;
  }
}
.aboutus__img-wrap {
  margin-right: 2rem;
}
.aboutus__img-wrap img {
  border-radius: 0 12rem 1rem 0;
}
@media (768px <= width) {
  .aboutus__img-wrap {
    margin: 0;
  }
  .aboutus__img-wrap img {
    width: 100%;
    border-radius: 0 2rem 16rem 0;
  }
}
.aboutus__textbox {
  margin-top: 4rem;
  margin-left: 2rem;
  margin-right: 2rem;
}
@media (768px <= width) {
  .aboutus__textbox {
    margin-top: 0;
    margin-left: 0;
    margin-right: max(50% - 32rem, 6rem);
  }
}
.aboutus__lead {
  font-size: 2.6rem;
  font-weight: 700;
  line-height: 166%;
}
.aboutus__text {
  margin-top: 3rem;
  line-height: 200%;
}

.ourappeal {
  padding: 8rem 2rem;
}
@media (768px <= width) {
  .ourappeal {
    padding: 16rem max(50% - 80rem, 6rem);
    display: grid;
    grid-template-columns: 50rem auto;
  }
}
.ourappeal__discription {
  padding: 3rem 0;
  text-align: center;
  border-bottom: 1px solid var(--color-gray);
  font-size: 2.2rem;
  font-weight: 700;
}
.ourappeal__discription span.green {
  font-size: 4.2rem;
  font-weight: 500;
}
@media (768px <= width) {
  .ourappeal__discription {
    text-align: left;
    border: none;
    padding: 0;
    margin-top: 10rem;
    font-size: 3.2rem;
  }
  .ourappeal__discription span.green {
    font-size: 6rem;
  }
}
@media (768px <= width) {
  .ourappeal__content {
    border-top: 1px solid var(--color-gray);
  }
}
.ourappeal__item {
  border-bottom: 1px solid var(--color-gray);
  padding: 3rem 0;
  display: grid;
  gap: 3rem;
}
@media (768px <= width) {
  .ourappeal__item {
    padding: 6rem 0;
    grid-template-columns: 67fr 43fr;
    gap: min(7.2727272727%, 8rem);
    align-items: start;
  }
  .ourappeal__item > *:nth-last-child(1) {
    order: 1;
  }
  .ourappeal__item > *:nth-last-child(2) {
    order: 2;
  }
}
.ourappeal__img-wrap img {
  border-radius: 1rem;
}
.ourappeal__textbox {
  display: grid;
  grid-template-columns: 4rem auto;
}
@media (768px <= width) {
  .ourappeal__textbox {
    grid-template-columns: clamp(6rem, 20.3389830508%, 12rem) auto;
  }
}
.ourappeal__title, .ourappeal__copy, .ourappeal__text {
  grid-column: 2/3;
}
.ourappeal__num {
  font-size: 2rem;
  color: var(--color-green);
  align-self: center;
}
@media (768px <= width) {
  .ourappeal__num {
    font-size: 2.2rem;
    transform: translateY(-0.1em);
  }
}
.ourappeal__title {
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 166%;
}
@media (768px <= width) {
  .ourappeal__title {
    font-size: 2.6rem;
  }
}
.ourappeal__copy {
  margin-top: 1.5rem;
  font-size: 1.7rem;
  font-weight: 700;
  line-height: 166%;
  background-color: var(--color-green);
  color: #fff;
  border-radius: 100rem;
  justify-self: start;
  padding: 0.3rem 1.5rem;
}
@media (768px <= width) {
  .ourappeal__copy {
    font-size: 2rem;
    padding: 0.4rem 3rem;
  }
}
.ourappeal__text {
  margin-top: 2rem;
  line-height: 200%;
}

.workenvironment {
  padding: 8rem 2rem;
  position: relative;
}
@media (768px <= width) {
  .workenvironment {
    padding: 16rem max(50% - 80rem, 6rem);
    display: grid;
    grid-template-columns: 50rem auto;
  }
}
.workenvironment::before {
  content: "";
  width: 100%;
  background-color: var(--color-bg);
  position: absolute;
  z-index: -1;
  left: 0;
  top: 0;
  bottom: 0;
  border-radius: 0 12rem 2rem 0;
}
@media (768px <= width) {
  .workenvironment::before {
    right: max(50% - 60rem, 16rem);
    width: auto;
  }
}
.workenvironment__lead-catch {
  margin-top: 3.5rem;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 166%;
}
@media (768px <= width) {
  .workenvironment__lead-catch {
    margin-top: 10rem;
    font-size: 3.2rem;
  }
}
.workenvironment__lead-text {
  margin-top: 2rem;
  line-height: 200%;
}
@media (768px <= width) {
  .workenvironment__lead-text {
    margin-top: 0;
  }
}
.workenvironment__list {
  margin-top: 5rem;
  display: grid;
  gap: 2rem;
}
@media (768px <= width) {
  .workenvironment__list {
    margin-top: 8rem;
  }
}
.workenvironment__item {
  background-color: #fff;
  border-radius: 1rem;
  padding: 3rem 2rem 4rem;
  display: grid;
  grid-template-columns: 10rem auto;
  gap: 2rem;
}
@media (768px <= width) {
  .workenvironment__item {
    grid-template-columns: clamp(10rem, 20.4081632653%, 20rem) auto;
    padding: 6rem;
    border-radius: 2rem;
    gap: 0 clamp(6rem, 10.2040816327%, 10rem);
    align-content: start;
    align-items: start;
  }
}
@media (768px <= width) {
  .workenvironment__item-img-wrap {
    grid-row: span 3;
  }
}
.workenvironment__item-title {
  align-self: center;
  font-size: 2rem;
  font-weight: 700;
}
@media (768px <= width) {
  .workenvironment__item-title {
    font-size: 2.6rem;
  }
}
.workenvironment__item-detail-list {
  grid-column: span 2;
}
@media (768px <= width) {
  .workenvironment__item-detail-list {
    margin-top: 2rem;
    grid-column: 2;
  }
}
.workenvironment__item-detail-item {
  position: relative;
  line-height: 200%;
  padding-left: 1.5rem;
}
.workenvironment__item-detail-item::before {
  content: "";
  width: 0.5rem;
  aspect-ratio: 1;
  background-color: currentColor;
  border-radius: 100rem;
  position: absolute;
  top: calc(1em - 0.25rem);
  left: 0;
}
@media (768px <= width) {
  .workenvironment__item-detail-item > * {
    display: inline;
  }
}
.workenvironment__item-detail-term {
  font-weight: 700;
}
.workenvironment__item-detail-term span {
  font-weight: 400;
  display: inline-block;
  width: 1.5em;
  text-align: center;
}
.interview {
  padding: 8rem 2rem;
}
@media (768px <= width) {
  .interview {
    padding: 16rem max(50% - 80rem, 6rem);
  }
}
.interview__body {
  margin-top: 3.5rem;
}
@media (768px <= width) {
  .interview__body {
    margin-top: 10rem;
  }
}
.interview__item {
  padding: 5rem 0;
}
@media (768px <= width) {
  .interview__item {
    padding: 10rem 0;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }
}
.interview__item:first-child {
  padding-top: 0;
}
.interview__item:last-child {
  padding-bottom: 0;
}
.interview__item + .interview__item {
  border-top: 1px solid var(--color-gray);
}
.interview__item-img-wrap img {
  border-radius: 1rem;
}
@media (768px <= width) {
  .interview__item-img-wrap img {
    border-radius: 2rem;
  }
}
.interview__item-wrap {
  margin-top: 3rem;
}
@media (768px <= width) {
  .interview__item-wrap {
    margin-top: 0;
    padding-left: 15%;
  }
}
.interview__item-num {
  font-size: 4rem;
  font-weight: 500;
  color: var(--color-green);
}
@media (768px <= width) {
  .interview__item-num {
    font-size: 5.8rem;
  }
}
.interview__item-catch {
  margin-top: 2rem;
  font-size: 2.6rem;
  font-weight: 700;
  line-height: 166%;
}
@media (width < 768px) {
  .interview__item-catch br {
    display: none;
  }
}
@media (768px <= width) {
  .interview__item-catch {
    margin-top: 4rem;
    font-size: 3.2rem;
  }
}
.interview__item-tag {
  margin-top: 3rem;
  display: flex;
  gap: 0 0.5rem;
  font-size: 1.3rem;
}
@media (768px <= width) {
  .interview__item-tag {
    margin-top: 4rem;
    gap: 1rem;
    font-size: 1.6rem;
  }
}
.interview__item-store, .interview__item-title {
  border-radius: 100rem;
  padding: 0.5rem 1.5rem;
}
@media (768px <= width) {
  .interview__item-store, .interview__item-title {
    padding: 0.7rem 1.5rem;
  }
}
.interview__item-store {
  border: 1px solid currentColor;
}
.interview__item-title {
  background-color: var(--color-gray);
  color: #fff;
  border: 1px solid var(--color-gray);
}
.interview__item-profile {
  margin-top: 1.5rem;
  display: flex;
  align-items: baseline;
  gap: 1.5rem;
}
@media (768px <= width) {
  .interview__item-profile {
    gap: 3rem;
  }
}
.interview__item-name {
  font-size: 2rem;
  font-weight: 700;
}
@media (768px <= width) {
  .interview__item-name {
    font-size: 2.4rem;
  }
}
.interview__item-join {
  font-size: 1.3rem;
}
@media (768px <= width) {
  .interview__item-join {
    font-size: 1.6rem;
  }
}
.interview__item-textbox {
  margin-top: 4rem;
  padding: 3rem 2rem;
  background: var(--color-bg);
  border-radius: 1rem;
}
@media (768px <= width) {
  .interview__item-textbox {
    padding: 3rem 4rem;
  }
}
.interview__item-work {
  font-weight: 700;
  line-height: 200%;
}
.interview__item-message {
  line-height: 200%;
}

.requirement {
  padding: 0 2rem;
}
@media (768px <= width) {
  .requirement {
    padding: 0;
    margin: 0 max(50% - 80rem, 6rem);
  }
}
.requirement__body {
  margin-top: 3.5rem;
  display: grid;
  gap: 2rem;
}
@media (768px <= width) {
  .requirement__body {
    margin: 10rem max(50% - 70rem, 12rem) 0;
  }
}
.requirement__body .text {
  font-size: 1.8rem;
  line-height: 166%;
}
.requirement__item {
  background: var(--color-bg);
  border-radius: 1rem;
  padding: 2rem;
}
@media (768px <= width) {
  .requirement__item {
    padding: 4rem;
  }
}
.requirement__item.open .requirement__item-header::before {
  height: 0.1rem;
}
.requirement__item-header {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  position: relative;
}
@media (768px <= width) {
  .requirement__item-header {
    gap: 2rem;
    cursor: pointer;
  }
}
.requirement__item-header::before, .requirement__item-header::after {
  content: "";
  background: currentColor;
  position: absolute;
}
.requirement__item-header::before {
  width: 0.1rem;
  height: 1.9rem;
  right: 0.9rem;
}
@media (768px <= width) {
  .requirement__item-header::before {
    height: 3rem;
    right: 1.45rem;
  }
}
.requirement__item-header::after {
  width: 1.9rem;
  height: 0.1rem;
  right: 0rem;
}
@media (768px <= width) {
  .requirement__item-header::after {
    width: 3rem;
  }
}
.requirement__item-term {
  width: 10rem;
  text-align: center;
  border-radius: 100rem;
  padding: 0.6rem;
  font-size: 1.3rem;
  font-weight: 700;
  color: #fff;
  background: var(--color-gray);
}
@media (768px <= width) {
  .requirement__item-term {
    width: 14.8rem;
    font-size: 1.8rem;
    line-height: 166%;
    padding: 0.3rem;
  }
}
.requirement__item-name {
  font-size: 2rem;
  font-weight: 700;
}
@media (768px <= width) {
  .requirement__item-name {
    font-size: 2.6rem;
    line-height: 166%;
  }
}
.requirement__item-body {
  display: none;
}
.requirement__item-list {
  margin-top: 2.4rem;
  border-radius: 1rem;
  background: url(../images/recruit/bg.webp);
  padding: 0.5rem 2rem 3rem;
  margin-bottom: 3rem;
}
@media (768px <= width) {
  .requirement__item-list {
    margin-top: 3.5rem;
    border-radius: 2rem;
    padding: 6rem;
  }
}
.requirement__item:first-child .requirement__item-body {
  display: block;
}
.requirement__item-row {
  padding: 3rem 0;
  display: grid;
  gap: 1rem;
  line-height: 200%;
  border-bottom: 1px solid var(--color-gray);
}
@media (768px <= width) {
  .requirement__item-row {
    padding: 4rem 0;
    display: grid;
    grid-template-columns: 30rem auto;
    gap: 0;
  }
  .requirement__item-row:first-child {
    padding-top: 0;
  }
}
.requirement__item-th {
  font-weight: 700;
}
.requirement__item-content-list li {
  padding-left: 1.5rem;
  position: relative;
}
.requirement__item-content-list li::before {
  content: "";
  width: 0.5rem;
  aspect-ratio: 1;
  background: currentColor;
  border-radius: 100rem;
  position: absolute;
  left: 0;
  top: calc(1em - 0.25rem);
}
.requirement__item-link {
  margin-left: auto;
  margin-right: auto;
}

.faq {
  padding: 8rem 2rem 0;
}
@media (768px <= width) {
  .faq {
    padding: 16rem 0 0;
    margin: 0 max(50% - 80rem, 6rem);
  }
}
.faq__list {
  margin-top: 1rem;
}
@media (768px <= width) {
  .faq__list {
    margin: 0 max(50% - 70rem, 12rem);
    margin-top: 6rem;
  }
}
.faq__item {
  padding: 2.5rem 0;
  border-bottom: 1px solid var(--color-gray);
  display: grid;
  gap: 1rem;
}
@media (768px <= width) {
  .faq__item {
    padding: 4rem 0;
    gap: 2rem;
  }
}
.faq__question, .faq__answer {
  display: grid;
  grid-template-columns: 4rem auto;
  align-items: first baseline;
  gap: 2rem;
}
@media (768px <= width) {
  .faq__question, .faq__answer {
    grid-template-columns: 6rem auto;
    gap: 3rem;
  }
}
.faq__question i, .faq__answer i {
  border-radius: 100rem;
  aspect-ratio: 1;
  display: grid;
  place-content: center;
  font-size: 2rem;
  font-style: normal;
  color: #fff;
}
@media (768px <= width) {
  .faq__question i, .faq__answer i {
    font-size: 2.6rem;
  }
}
.faq__question {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 166%;
}
.faq__question i {
  background-color: #a09d92;
}
@media (768px <= width) {
  .faq__question {
    font-size: 2.2rem;
  }
}
.faq__answer {
  line-height: 200%;
}
.faq__answer i {
  background-color: var(--color-green);
}

.entry {
  margin: 0 2rem;
  padding: 4rem 0 5rem;
  position: relative;
}
@media (768px <= width) {
  .entry {
    margin: 0 max(50% - 80rem, 6rem);
    padding: 10rem 0 12rem;
  }
}
.entry::after {
  content: "";
  width: 100%;
  height: 1px;
  background-image: linear-gradient(to right, black 50%, transparent 50%);
  background-size: 9px 1px;
  background-repeat: repeat-x;
  background-position: left top;
  position: absolute;
  left: 0;
}
.entry::before {
  top: 0;
}
.entry::after {
  bottom: 0;
}
.entry__title {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 1rem;
}
@media (768px <= width) {
  .entry__title {
    gap: 0 1.5rem;
  }
}
.entry__title .name {
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 166%;
  text-align: center;
}
@media (768px <= width) {
  .entry__title .name {
    font-size: 3.2rem;
  }
}
@media (768px <= width) {
  .entry__title::before, .entry__title::after {
    content: "";
    width: 2rem;
    aspect-ratio: 1;
    background: url('data:image/svg+xml;charset=utf8, <svg width="22" height="22" viewBox="0 0 22 22" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M8.64746 8.64746C12.6861 12.8076 16.8245 16.946 21.0002 21.0002" stroke="%233E3A2A" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/><path d="M1 1C2.45528 2.45528 3.90745 3.90745 5.36273 5.36273" stroke="%233E3A2A" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/></svg>');
    display: block;
  }
}
.entry__title::after {
  transform: scaleX(-1);
}
.entry__text {
  margin-top: 2rem;
  text-align: center;
  line-height: 200%;
}
@media (768px <= width) {
  .entry__text {
    margin-top: 4rem;
  }
}
.entry__btn {
  margin-top: 3rem;
  background-color: #fff;
  padding: 3rem;
  border-radius: 1rem;
}
@media (768px <= width) {
  .entry__btn {
    margin-top: 5rem;
    margin-left: auto;
    margin-right: auto;
    width: 58rem;
    border-radius: 2rem;
  }
}
.entry__link.btn {
  width: 100%;
}
@media (768px <= width) {
  .entry__link.btn {
    width: 35rem;
    margin-left: auto;
    margin-right: auto;
  }
}