:root {
  --breakpoint-sp-max: 767px;
  --breakpoint-pc-min: 768px;
  --page-max: 480px;
  --gutter: 5.333333333vw;
  --menu-color: #87232e;
  --menu-size: 72px;
  --color-brand: #8c2a30;
  --color-brand-dark: #59090e;
  --color-accent: #ab3038;
  --color-text: #323232;
  --color-text-sub: #333333;
  --color-white: #ffffff;
  --color-frame: #f0d6d4;
  --color-separate: #F1999F;
  --bg-cream: #fbf6ef;
  --bg-page: #efe6d6;
  --bg-reason: #fcefec;
  --bg-point: #fdf4f2;
  --bg-faq: #F7EFEB;
  --font-base: "Zen Kaku Gothic New", "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Yu Gothic", sans-serif;
  --font-en: "Jost", "Zen Kaku Gothic New", sans-serif;
  --font-hand: "Zen Kurenaido", "Zen Kaku Gothic New", sans-serif;
}

@font-face {
  font-family: "Zen Kaku Gothic New";
  font-style: normal;
  font-weight: 300;
  src: url("/student-work/fonts/ZenKakuGothicNew/Light.ttf") format("truetype");
}
@font-face {
  font-family: "Jost";
  font-style: normal;
  font-weight: 300;
  src: url("/student-work/fonts/Jost/Jost-Light.ttf") format("truetype");
}
@font-face {
  font-family: "Zen Kaku Gothic New";
  font-style: normal;
  font-weight: 400;
  src: url("/student-work/fonts/ZenKakuGothicNew/Regular.ttf") format("truetype");
}
@font-face {
  font-family: "Jost";
  font-style: normal;
  font-weight: 400;
  src: url("/student-work/fonts/Jost/Jost-Regular.ttf") format("truetype");
}
@font-face {
  font-family: "Zen Kaku Gothic New";
  font-style: normal;
  font-weight: 500;
  src: url("/student-work/fonts/ZenKakuGothicNew/Medium.ttf") format("truetype");
}
@font-face {
  font-family: "Jost";
  font-style: normal;
  font-weight: 500;
  src: url("/student-work/fonts/Jost/Jost-Medium.ttf") format("truetype");
}
@font-face {
  font-family: "Zen Kaku Gothic New";
  font-style: normal;
  font-weight: 700;
  src: url("/student-work/fonts/ZenKakuGothicNew/Bold.ttf") format("truetype");
}
@font-face {
  font-family: "Jost";
  font-style: normal;
  font-weight: 700;
  src: url("/student-work/fonts/Jost/Jost-Bold.ttf") format("truetype");
}
@font-face {
  font-family: "Zen Kaku Gothic New";
  font-style: normal;
  font-weight: 900;
  src: url("/student-work/fonts/ZenKakuGothicNew/Black.ttf") format("truetype");
}
@font-face {
  font-family: "Jost";
  font-style: normal;
  font-weight: 900;
  src: url("/student-work/fonts/Jost/Jost-Black.ttf") format("truetype");
}
@font-face {
  font-family: "Zen Kurenaido";
  font-style: normal;
  font-weight: 400;
  src: url("/student-work/fonts/ZenKurenaido/Regular.ttf") format("truetype");
}
body {
  background-color: #fff;
}

button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  appearance: none;
}

.u-pc-only {
  display: none;
}

@media (min-width: 768px) {
  .u-sp-only {
    display: none !important;
  }
  .u-pc-only {
    display: block;
  }
}
.u-visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  white-space: nowrap;
  border: 0;
}

.l-page {
  width: 100%;
  margin-inline: auto;
  background-color: white;
  overflow: clip;
}

.l-main {
  display: block;
  overflow: clip;
  background: var(--bg-faq);
}

.l-inner {
  padding-inline: var(--gutter);
}
@media (min-width: 768px) {
  .l-inner {
    max-width: calc(1100px + var(--gutter) * 2);
    margin-inline: auto;
    padding-inline: var(--gutter);
    box-sizing: border-box;
  }
}

.p-cta {
  padding-bottom: 21.33333333vw;
  background-color: var(--bg-faq);
}
@media (min-width: 768px) {
  .p-cta {
    padding-bottom: 69px;
  }
}
.p-cta__banner {
  margin: 0 auto;
  position: sticky !important;
  bottom: 0;
  z-index: 100;
}
.p-cta__banner.fixed {
  position: relative !important;
}

.c-separator {
  height: 0.5333333333vw;
  background-image: url("/student-work/assets/images/common/separator_dot.svg");
  background-repeat: repeat-x;
  background-size: 4vw 0.5333333333vw;
}
@media (min-width: 768px) {
  .c-separator {
    height: 2px;
    background-size: 15px 2px;
  }
}

.c-background {
  background-image: url("/student-work/assets/images/common/background.png");
  background-repeat: repeat;
  background-size: 100px 100px;
}

.c-fade-in {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.c-fade-in.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.c-banner-s {
  display: block;
  width: 89.333vw;
  height: 27.4666666667vw;
  position: relative;
  background-image: url("/student-work/assets/images/banner/background-s.png");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  transition: scale 0.4s ease-out;
}
@media (min-width: 768px) {
  .c-banner-s {
    width: 335px;
    height: 103px;
  }
}
.c-banner-s > h2 {
  position: absolute;
  top: 50%;
  right: 5.066666667vw;
  transform: translate(0, -50%);
  color: var(--color-white);
  font-family: "Zen Kaku Gothic New";
  font-size: 3.733333333vw;
  font-style: normal;
  font-weight: 700;
  line-height: 1.23;
  text-align: start;
}
@media (min-width: 768px) {
  .c-banner-s > h2 {
    right: 19px;
    font-size: 14px;
  }
}
.c-banner-s > h2 > span {
  font-size: 4.8vw;
}
@media (min-width: 768px) {
  .c-banner-s > h2 > span {
    font-size: 18px;
  }
}
.c-banner-s:hover {
  scale: 1.05;
}

.c-banner {
  display: block;
  width: 89.333vw;
  height: 27.4666666667vw;
  position: relative;
  background-image: url("/student-work/assets/images/banner/background-s.png");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  transition: scale 0.4s ease-out;
}
@media (min-width: 768px) {
  .c-banner {
    width: 750px;
    height: 167px;
    background-image: url("/student-work/assets/images/banner/background.png");
  }
}
.c-banner > h2 {
  position: absolute;
  top: 50%;
  right: 5.066666667vw;
  transform: translate(0, -50%);
  color: var(--color-white);
  font-family: "Zen Kaku Gothic New";
  font-size: 3.733333333vw;
  font-style: normal;
  font-weight: 700;
  line-height: 1.23;
  text-align: start;
}
@media (min-width: 768px) {
  .c-banner > h2 {
    top: 65%;
    transform: translate(0, -65%);
    right: 142px;
    font-size: 25px;
  }
}
.c-banner > h2 > span {
  font-size: 4.8vw;
}
@media (min-width: 768px) {
  .c-banner > h2 > span {
    font-size: 32px;
  }
}
.c-banner:hover {
  scale: 1.05;
}

.c-job-card {
  background-color: var(--color-white);
  border-radius: 4.266666667vw;
}
.c-job-card__heading {
  width: 100%;
  height: 21.33333333vw;
  background-size: cover;
  background-repeat: no-repeat;
  border-top-left-radius: 4.266666667vw;
  border-top-right-radius: 4.266666667vw;
  display: flex;
  justify-content: center;
  align-items: center;
}
.c-job-card__heading.hall {
  background-color: var(--color-accent);
}
.c-job-card__heading.hall > h3::before {
  width: 10.66666667vw;
  height: 8.8vw;
  left: -12.8vw;
  background-image: url("/student-work/assets/images/reason/hall_heading_left.png");
}
.c-job-card__heading.hall > h3::after {
  width: 10.66666667vw;
  height: 9.450666667vw;
  right: -13.33333333vw;
  background-image: url("/student-work/assets/images/reason/hall_heading_right.png");
}
.c-job-card__heading.kitchen {
  background-color: var(--color-brand-dark);
}
.c-job-card__heading.kitchen > h3::before {
  width: 5.866666667vw;
  height: 11.73333333vw;
  left: -7.466666667vw;
  background-image: url("/student-work/assets/images/reason/kitchen_heading_left.png");
}
.c-job-card__heading.kitchen > h3::after {
  width: 12.26666667vw;
  height: 8.266666667vw;
  right: -17.6vw;
  background-image: url("/student-work/assets/images/reason/kitchen_heading_right.png");
}
.c-job-card__heading > h3 {
  color: var(--color-white);
  font-family: var(--font-base);
  font-size: 5.333333333vw;
  font-weight: 700;
  line-height: 1.3;
  position: relative;
}
.c-job-card__heading > h3 > span {
  font-size: 8.533333333vw;
  margin-right: 1.066666667vw;
}
.c-job-card__heading > h3::before, .c-job-card__heading > h3::after {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.c-job-card__list {
  display: flex;
  flex-direction: column;
  gap: 6.4vw;
  padding: 8.533333333vw 6.4vw;
}
.c-job-card__item:not(:last-child) {
  padding-bottom: 6.4vw;
  border-bottom: 1px solid #A18C86;
}
.c-job-card__item-heading {
  display: flex;
  justify-content: center;
  margin-bottom: 4.266666667vw;
}
.c-job-card__item-heading > h4 {
  color: var(--color-text);
  font-family: var(--font-base);
  font-size: 5.333333333vw;
  font-weight: 700;
  line-height: 1.7;
  position: relative;
}
.c-job-card__item-heading > h4::before {
  content: "";
  position: absolute;
  width: 4.8vw;
  height: 8vw;
  top: 50%;
  left: -6.133333333vw;
  transform: translateY(-50%);
  background-image: url("/student-work/assets/images/reason/ic_hash.png");
  background-size: cover;
  background-repeat: no-repeat;
}
.c-job-card__item-body {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4.266666667vw;
}
.c-job-card__item-body > img {
  width: 42.66666667vw;
  height: 42.66666667vw;
  border-radius: 50%;
  object-fit: cover;
}
.c-job-card__item-body > p {
  color: var(--color-text);
  font-family: var(--font-base);
  font-size: 4.266666667vw;
  font-weight: 700;
  line-height: 1.8;
  text-align: left;
}

.c-feature__title {
  font-weight: 700;
  font-size: 19px;
  line-height: 1.4;
  text-align: center;
  color: var(--color-text);
}

.c-feature__hash {
  color: var(--color-brand);
  margin-right: 0.15em;
  font-weight: 900;
}

.c-feature__body {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-top: 16px;
}

.c-feature__photo {
  flex: 0 0 auto;
  width: 120px;
  height: 120px;
  border-radius: 50%;
  object-fit: cover;
}

.c-feature__text {
  flex: 1 1 0;
  min-width: 0;
  font-weight: 500;
  font-size: 14px;
  line-height: 1.8;
  color: var(--color-text);
}

@media (min-width: 768px) {
  .c-job-card {
    border-radius: 16px;
  }
  .c-job-card__heading {
    width: 100%;
    height: 83px;
    border-top-left-radius: 16px;
    border-top-right-radius: 16px;
  }
  .c-job-card__heading.hall > h3::before {
    width: 53.25px;
    height: 43.57px;
    left: -73.25px;
  }
  .c-job-card__heading.hall > h3::after {
    width: 59.58px;
    height: 52.789px;
    right: -85.58px;
  }
  .c-job-card__heading.kitchen > h3::before {
    width: 27.49px;
    height: 55.02px;
    left: -47.49px;
  }
  .c-job-card__heading.kitchen > h3::after {
    width: 55px;
    height: 36px;
    right: -75px;
  }
  .c-job-card__heading > h3 {
    font-size: 32px;
  }
  .c-job-card__heading > h3 > span {
    font-size: 42px;
    margin-right: 4px;
  }
  .c-job-card__list {
    flex-direction: row;
    justify-content: center;
    gap: 1px;
    padding: 36px 40px;
  }
  .c-job-card__item {
    width: min(272px, 18.88888889vw);
    padding-inline: 35px;
  }
  .c-job-card__item:not(:last-child) {
    padding-bottom: 0;
    border-bottom: 0;
    border-right: 1px solid #A18C86;
  }
  .c-job-card__item-heading {
    display: flex;
    justify-content: center;
    margin-bottom: 32px;
  }
  .c-job-card__item-heading > h4 {
    font-size: min(22px, 1.527777778vw);
  }
  .c-job-card__item-heading > h4::before {
    width: 23px;
    height: 38px;
    left: -28px;
  }
  .c-job-card__item-body {
    gap: 25px;
  }
  .c-job-card__item-body > img {
    width: min(209px, 14.51388889vw);
    height: min(209px, 14.51388889vw);
  }
  .c-job-card__item-body > p {
    font-size: 16px;
  }
  .c-feature {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .c-feature__title {
    font-size: 20px;
  }
  .c-feature__body {
    flex-direction: column;
    align-items: center;
    gap: 18px;
    width: 100%;
  }
  .c-feature__photo {
    width: 130px;
    height: 130px;
  }
  .c-feature__text {
    flex: 0 0 auto;
    width: 100%;
    font-size: 14px;
  }
}
.c-voice {
  display: grid;
  grid-row: span 2;
  grid-template-rows: subgrid;
  position: relative;
  background-color: var(--bg-faq);
  margin-top: 22.66666667vw;
  border-radius: 4.266666667vw;
}
.c-voice__photo {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: -22.66666667vw;
  width: 58.66666667vw;
}
.c-voice__photo img {
  width: 100%;
  height: auto;
}
.c-voice__text {
  margin: 33.06666667vw 6.4vw 0;
  color: var(--color-text);
  font-family: var(--font-base);
  font-size: 4.266666667vw;
  font-weight: 500;
  line-height: 1.8;
  text-align: start;
}
.c-voice__point {
  margin: 0 6.4vw 10.66666667vw;
  text-align: start;
}
.c-voice__point-heading {
  display: flex;
  gap: 4.8vw;
}
.c-voice__point-heading > div {
  flex: 1;
}
.c-voice__point-label {
  color: #5C3A3D;
  font-family: var(--font-en);
  font-size: 5.866666667vw;
  font-weight: 400;
  line-height: 1.3%;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}
.c-voice__point-text {
  margin-top: 8vw;
  color: var(--color-text);
  font-size: 4.8vw;
  font-weight: 700;
  line-height: 1.6;
}

@media (min-width: 768px) {
  .c-voice {
    margin-top: min(152px, 10.55555556vw);
    gap: 50px;
    border-radius: 16px;
  }
  .c-voice__photo {
    top: max(-152px, -10.55555556vw);
    width: min(378px, 26.25vw);
  }
  .c-voice__text {
    margin: min(218px, 15.13888889vw) 56px 0;
    font-size: 16px;
  }
  .c-voice__point {
    margin: 0 56px 56px;
  }
  .c-voice__point-heading {
    gap: 18px;
  }
  .c-voice__point-label {
    font-size: 28px;
  }
  .c-voice__point-text {
    margin-top: 38px;
    font-size: 18px;
  }
}
.c-interview {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.c-interview__card {
  position: relative;
  width: 89.33333333vw;
  padding: 10.66666667vw 5.333333333vw 0;
  z-index: 1;
}
.c-interview__card-inner {
  box-sizing: border-box;
}
.c-interview__card-inner > picture {
  position: relative;
}
.c-interview__card-inner > picture > img {
  width: 100%;
  height: auto;
}
.c-interview__card::before {
  content: "";
  position: absolute;
  width: 18.66666667vw;
  height: 23.42133333vw;
  z-index: -1;
  top: 1.066666667vw;
  left: 0;
  background-size: cover;
  background-repeat: no-repeat;
  background-image: url("/student-work/assets/images/interview/deco_outer_sp.png");
}
.c-interview__card-summary {
  position: absolute;
  left: 3.2vw;
  bottom: 7.466666667vw;
  text-align: left;
  font-family: var(--font-base);
}
.c-interview__card-summary p {
  color: var(--color-text);
  font-size: 5.333333333vw;
  font-style: normal;
  font-weight: 500;
  line-height: 1.3;
  padding: 2.6vw 5.866666667vw 9vw;
  background-image: url("/student-work/assets/images/interview/balloon.png");
  background-size: contain;
  background-repeat: no-repeat;
}
.c-interview__card-summary p > span {
  font-size: 4.8vw;
  font-weight: 700;
  letter-spacing: -0.03em;
}
.c-interview__card-summary p > span > strong {
  font-size: 8.533333333vw;
}
.c-interview__card-summary h3 {
  width: 63.73333333vw;
  margin-top: 1.066666667vw;
  margin-left: 4.266666667vw;
  padding: 2.666666667vw 4.266666667vw 3.2vw;
  background-color: var(--color-white);
  border: 0.5333333333vw solid var(--color-brand);
  border-radius: 1.333333333vw;
  font-size: 6.933333333vw;
  font-style: normal;
  font-weight: 700;
  line-height: 1.3;
  color: var(--color-text);
}

.c-interview__detail {
  display: none;
  flex-direction: column;
  gap: 10.66666667vw;
  margin-top: 10.66666667vw;
  margin-inline: 5.333333333vw;
}
.c-interview__detail-item {
  display: flex;
  flex-direction: column;
  gap: 6.4vw;
}
.c-interview__detail-pic {
  display: flex;
  justify-content: center;
}
.c-interview__detail-pic > picture {
  width: 69.6vw;
}
.c-interview__detail-pic > picture img {
  width: 100%;
  height: auto;
}
.c-interview__detail-block {
  font-family: var(--font-base);
  text-align: start;
}
.c-interview__detail-block > h3 {
  color: var(--color-accent);
  font-size: 4.8vw;
  font-weight: 700;
  line-height: 1.7;
  padding-bottom: 4.266666667vw;
}
.c-interview__detail-block > p {
  margin-top: 5.333333333vw;
  color: var(--color-text);
  font-size: 4.266666667vw;
  font-weight: 500;
  line-height: 1.8;
}

.c-interview.is-open .c-interview__detail {
  display: flex;
}

@media (min-width: 768px) {
  .c-interview__card {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0;
  }
  .c-interview__card::before {
    width: 230px;
    height: 202px;
    top: auto;
    left: -142px;
    bottom: -20px;
    background-image: url("/student-work/assets/images/interview/deco_outer.png");
  }
  .c-interview__card-summary {
    left: 48px;
    bottom: auto;
    top: 50%;
    transform: translateY(-50%);
  }
  .c-interview__card-summary p {
    font-size: 20px;
    padding: 14px 22px 34px;
    width: fit-content;
  }
  .c-interview__card-summary p > span {
    font-size: 18px;
  }
  .c-interview__card-summary p > span > strong {
    font-size: 32px;
  }
  .c-interview__card-summary h3 {
    width: auto;
    margin-top: 8px;
    margin-left: 20px;
    padding: 10px 24px 8px;
    border: 2px solid var(--color-brand);
    border-radius: 5px;
    font-size: 32px;
  }
  .c-interview__detail {
    display: none;
    flex-direction: column;
    gap: 36px;
    margin-top: 64px;
    margin-inline: auto;
    padding-inline: 30px;
    max-width: 1100px;
  }
  .c-interview__detail-item {
    flex-direction: row;
    gap: 77px;
  }
  .c-interview__detail-item:nth-of-type(even) {
    flex-direction: row-reverse;
  }
  .c-interview__detail-pic {
    display: flex;
    justify-content: start;
  }
  .c-interview__detail-pic > picture {
    width: 261px;
  }
  .c-interview__detail-pic > picture img {
    width: 100%;
    height: auto;
  }
  .c-interview__detail-block {
    flex: 1;
  }
  .c-interview__detail-block > h3 {
    font-size: 20px;
    padding-bottom: 16px;
  }
  .c-interview__detail-block > p {
    margin-top: 20px;
    font-size: 16px;
  }
}
.c-toggle {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 72.26666667vw;
  max-width: 100%;
  height: 17.06666667vw;
  margin-top: 10.66666667vw;
  padding: 2.666666667vw;
  background-color: var(--color-brand);
  border: 0;
  border-radius: 16vw;
  color: var(--color-white);
  font-family: var(--font-base);
  font-weight: 700;
  font-size: 5.333333333vw;
  letter-spacing: 0.07em;
  line-height: 1.8;
  transition: background-color 0.3s ease, color 0.3s ease;
}
.c-toggle::after {
  content: "";
  position: absolute;
  right: 4.8vw;
  top: 50%;
  transform: translateY(-50%);
  width: 3.2vw;
  height: 4.266666667vw;
  background-image: url("/student-work/assets/images/common/ic_arrow.png");
  background-size: contain;
  background-repeat: no-repeat;
  transition: rotate 0.3s ease;
  transform-origin: center top;
  rotate: 0deg;
}
.c-toggle[aria-expanded=true]::after {
  rotate: 180deg;
}
.c-toggle:focus-visible {
  outline: 3px solid var(--color-brand-dark);
  outline-offset: 2px;
}
.c-toggle:hover {
  scale: 1.05;
  background-color: var(--color-white);
  color: var(--color-brand);
  border: 2px solid var(--color-brand);
}
.c-toggle:hover::after {
  background-image: url("/student-work/assets/images/common/ic_arrow_accent.png");
}

@media (min-width: 768px) {
  .c-toggle {
    width: 330px;
    max-width: 100%;
    height: 64px;
    margin-top: -44px;
    padding: 10px;
    border-radius: 60px;
    font-size: 20px;
    z-index: 10;
  }
  .c-toggle::after {
    right: 32px;
    width: 12px;
    height: 16px;
  }
  .c-toggle[aria-expanded=true] {
    margin-top: 64px;
  }
}
.c-faq {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.c-faq__item {
  background-color: var(--color-white);
  border-radius: 12px;
  box-shadow: 0 2px 8px rgba(140, 42, 48, 0.06);
}

.c-faq__q {
  display: flex;
  align-items: center;
  gap: 2.133333333vw;
  width: 100%;
  padding: 6.4vw;
  background: transparent;
  border: 0;
  text-align: left;
  color: var(--color-text);
  opacity: 1;
  transition: opacity 0.3s ease-out;
}
.c-faq__q-wrapper {
  display: flex;
  align-items: flex-start;
  gap: 1.066666667vw;
}
.c-faq__q:hover {
  opacity: 0.7;
}

.c-faq__mark {
  flex: 0 0 auto;
  font-family: var(--font-en);
  font-weight: 500;
  font-size: 6.4vw;
  line-height: 1.3;
  color: var(--color-brand);
}

.c-faq__question {
  flex: 1 1 0;
  min-width: 0;
  padding-top: 2px;
  font-family: var(--font-base);
  font-weight: 700;
  font-size: 4.8vw;
  line-height: 1.5;
}

.c-faq__icon {
  position: relative;
  flex: 0 0 auto;
  width: 6.4vw;
  height: 6.4vw;
  background-color: var(--color-brand);
  border-radius: 50%;
}
.c-faq__icon::before, .c-faq__icon::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 3.733333333vw;
  height: 0.5333333333vw;
  background-color: var(--color-white);
  transform: translate(-50%, -50%);
}
.c-faq__icon::after {
  transform: translate(-50%, -50%) rotate(90deg);
  transition: opacity 0.2s ease;
}

.c-faq__a {
  display: none;
  padding: 0 6.4vw 6.4vw;
}
.c-faq__a p {
  font-weight: 500;
  font-family: var(--font-base);
  font-size: 4.266666667vw;
  line-height: 1.8;
  text-align: left;
  color: var(--color-text);
}

.c-faq__item.is-open .c-faq__icon::after {
  opacity: 0;
}

.c-faq__item.is-open .c-faq__q {
  padding-bottom: 4.266666667vw;
}

.c-faq__item.is-open .c-faq__a {
  display: block;
}

@media (min-width: 768px) {
  .c-faq {
    gap: 16px;
  }
  .c-faq__q {
    padding: 24px 32px;
    justify-content: space-between;
  }
  .c-faq__q-wrapper {
    align-items: center;
    gap: 20px;
  }
  .c-faq__mark {
    font-size: 44px;
  }
  .c-faq__question {
    font-size: 22px;
    line-height: 1.8;
  }
  .c-faq__a {
    padding: 0 24px 24px;
    max-width: 760px;
    margin-inline: auto;
  }
  .c-faq__a p {
    font-size: 18px;
    line-height: 1.7;
  }
  .c-faq__icon {
    width: 34px;
    height: 34px;
  }
  .c-faq__icon::before, .c-faq__icon::after {
    width: 20px;
    height: 2px;
  }
  .c-faq__item.is-open .c-faq__q {
    padding-bottom: 8px;
  }
}
.p-header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  z-index: 100;
}
.p-header.is-scrolled {
  background-color: var(--color-white);
  box-shadow: 0 0 20px 0 rgba(89, 9, 14, 0.1);
}
.p-header__inner {
  padding: min(2.133333333vw, 8px) min(3.2vw, 12px);
  display: flex;
  flex-direction: column;
}
@media (min-width: 1240px) {
  .p-header__inner {
    padding: 6px 130px 6px 42px;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
  }
}
.p-header__stores {
  display: flex;
  gap: min(3.2vw, 12px);
  justify-content: center;
  margin-top: min(5.866666667vw, 22px);
}
.p-header__stores img {
  width: min(11.73333333vw, 44px);
  height: auto;
}
@media (min-width: 768px) {
  .p-header__stores img {
    width: 44px;
  }
}
@media (min-width: 768px) {
  .p-header__stores {
    gap: 12px;
    justify-content: flex-start;
  }
}
.p-header__logo {
  width: 49.86666667vw;
  display: block;
}
.p-header__logo > img {
  width: 100%;
  height: auto;
}
@media (min-width: 768px) {
  .p-header__logo {
    width: 268px;
  }
}
.p-header__sub > h1 {
  color: var(--color-text-sub);
  font-family: "Zen Kaku Gothic New";
  font-size: min(2.4vw, 16px);
  font-style: normal;
  font-weight: 700;
  line-height: 1.5;
  text-align: start;
  display: flex;
  flex-direction: column;
  gap: min(2.133333333vw, 8px);
}
@media (min-width: 1240px) {
  .p-header__sub > h1 {
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.06);
    font-size: 16px;
    line-height: 1.4;
    text-align: end;
    width: auto;
    gap: 8px;
  }
}
.p-header__heading-main {
  font-size: min(3.2vw, 12px);
  font-weight: 500;
  line-height: 1.3;
}
@media (min-width: 1240px) {
  .p-header__heading-main {
    font-size: 16px;
    font-weight: 700;
    line-height: 1.5;
  }
}
.p-header__heading-sub {
  text-align: center;
  font-size: min(4.266666667vw, 16px);
}
@media (min-width: 1240px) {
  .p-header__heading-sub {
    text-align: end;
    font-size: 16px;
  }
}
.p-header__nav {
  position: fixed;
  top: 2.133333333vw;
  right: 3.2vw;
  z-index: 110;
}
@media (min-width: 1240px) {
  .p-header__nav {
    top: 34px;
    right: 42px;
  }
}

.p-nav {
  position: fixed;
  top: 0;
  right: 0;
  width: 100vw;
  height: 100vh;
  background-color: #F7EFEB;
  z-index: 105;
  display: none;
  overflow-y: auto;
}
@media (min-width: 1240px) {
  .p-nav {
    width: 335px;
    height: auto;
    top: 16px;
    right: 16px;
    border-radius: 32px;
    padding: 0 42px 80px;
  }
}
.p-nav.is-open {
  display: block;
}
.p-nav__banner {
  margin: 0 auto;
}
.p-nav__banner-container {
  margin-top: 134px;
}
.p-nav__list {
  margin-top: 8.533333333vw;
}
@media (min-width: 768px) {
  .p-nav__list {
    margin-top: 40px;
  }
}
.p-nav__item {
  border-top: 2px solid #A7121C;
}
.p-nav__item > a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 8vw;
  padding: 4.266666667vw 5.333333333vw;
  color: var(--color-text-sub);
  text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.06);
  font-family: "Zen Kaku Gothic New";
  font-size: 4.8vw;
  font-style: normal;
  font-weight: 700;
  line-height: 1.3;
  text-decoration: none;
  text-align: start;
}
@media (min-width: 768px) {
  .p-nav__item > a {
    height: 30px;
    padding: 16px 20px;
    font-size: 18px;
  }
}
.p-nav__item > a::after {
  content: "";
  width: 6.4vw;
  height: 6.4vw;
  background-image: url("/student-work/assets/images/common/chevron.png");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
@media (min-width: 768px) {
  .p-nav__item > a::after {
    width: 24px;
    height: 24px;
  }
}
.p-nav__item:last-child {
  border-bottom: 2px solid #A7121C;
}

.menu-btn {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  border: 2px solid var(--color-brand);
  background: white;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: background-color 0.25s ease, border-color 0.25s ease;
}
@media (min-width: 768px) {
  .menu-btn {
    width: 72px;
    height: 72px;
    gap: 10px;
  }
}
.menu-btn__label {
  color: var(--color-brand);
  font-family: "Zen Kaku Gothic New";
  font-size: 10px;
  font-weight: 500;
  line-height: 1;
}
@media (min-width: 768px) {
  .menu-btn__label {
    font-size: 12px;
    font-weight: 400;
    letter-spacing: 0.24px;
  }
}
.menu-btn__icon {
  width: 22.7px;
  height: 2px;
  border-radius: 1px;
  background-color: var(--color-brand);
  position: relative;
  margin: 7px 0;
  transition: transform 0.3s ease-out;
}
.menu-btn__icon::before, .menu-btn__icon::after {
  content: "";
  width: 22.7px;
  height: 2px;
  border-radius: 1px;
  background-color: var(--color-brand);
  position: absolute;
  left: 0;
  transition: transform 0.3s ease-out;
}
.menu-btn__icon::before {
  top: -7px;
}
.menu-btn__icon::after {
  top: 7px;
}
.menu-btn:hover {
  background-color: var(--color-brand);
  scale: 1.05;
}
.menu-btn:hover .menu-btn__icon {
  background-color: white;
}
.menu-btn:hover .menu-btn__icon::before, .menu-btn:hover .menu-btn__icon::after {
  background-color: white;
}
.menu-btn:hover .menu-btn__label {
  color: white;
}
.menu-btn.is-open .menu-btn__icon {
  background: transparent;
}
.menu-btn.is-open .menu-btn__icon::before {
  top: 0;
  transform: rotate(45deg);
}
.menu-btn.is-open .menu-btn__icon::after {
  top: 0;
  transform: rotate(-45deg);
}

.p-hero {
  position: relative;
  display: block;
  padding-block: 30.4vw 10.66666667vw;
  width: 100vw;
  height: 170.4vw;
}
.p-hero__background {
  width: 100%;
  height: 100%;
  background-image: url("/student-work/assets/images/hero/keyvisual_sp.png");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.p-hero__catch {
  position: absolute;
  bottom: 37.33333333vw;
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5.066666667vw;
}
.p-hero__catch-main {
  position: relative;
  width: 69.6vw;
}
.p-hero__catch-main img {
  width: 100%;
}
.p-hero__catch-main::before, .p-hero__catch-main::after {
  content: "";
  position: absolute;
  width: 13.86666667vw;
  height: 19.2vw;
  bottom: 0;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}
.p-hero__catch-main::before {
  left: -13.86666667vw;
  background-image: url("/student-work/assets/images/hero/main_deco_left_sp.png");
}
.p-hero__catch-main::after {
  right: -13.86666667vw;
  background-image: url("/student-work/assets/images/hero/main_deco_right_sp.png");
}
.p-hero__catch-sub {
  width: 76.26666667vw;
}
.p-hero__catch-sub img {
  width: 100%;
}

@media (min-width: 768px) {
  .p-hero {
    padding-block: 112px 0;
    width: 100vw;
    height: 845px;
  }
  .p-hero__background {
    background-image: url("/student-work/assets/images/hero/keyvisual.png");
    background-size: 1730px auto;
    background-position: center top;
  }
  .p-hero__catch {
    position: absolute;
    bottom: 190px;
    gap: 20px;
  }
  .p-hero__catch-main {
    max-width: 832px;
    width: 100%;
  }
  .p-hero__catch-main::before, .p-hero__catch-main::after {
    width: 78px;
    height: 85px;
  }
  .p-hero__catch-main::before {
    left: -100px;
    background-image: url("/student-work/assets/images/hero/main_deco_left.png");
  }
  .p-hero__catch-main::after {
    right: -100px;
    background-image: url("/student-work/assets/images/hero/main_deco_right.png");
  }
  .p-hero__catch-sub {
    max-width: 1005px;
    width: 100%;
  }
}
.p-intro {
  position: relative;
  background-color: var(--color-white);
}
.p-intro__inner {
  padding-inline: 5.333333333vw;
}
.p-intro__body {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6.4vw;
}
.p-intro__pic img {
  width: 100%;
  height: auto;
}
.p-intro__lead {
  font-family: var(--font-base);
  font-size: 4.266666667vw;
  line-height: 2.3;
  font-weight: 700;
  text-align: center;
  color: var(--color-text);
}
.p-intro__trail {
  position: relative;
  margin-top: 17.06666667vw;
  width: 100%;
  height: 22.93333333vw;
  background-size: cover;
  background-repeat: no-repeat;
  background-image: url("/student-work/assets/images/intro/bottom_sp.png");
}
.p-intro__trail::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 4.546666667vw;
  height: 21.33333333vw;
  background-size: cover;
  background-repeat: no-repeat;
  background-image: url("/student-work/assets/images/intro/ic_scroll_arrow.png");
}

@media (min-width: 768px) {
  .p-intro__body {
    flex-direction: row;
    gap: 8px;
    align-items: flex-start;
    justify-content: center;
  }
  .p-intro__inner {
    max-width: 1440px;
    margin: 0 auto 0;
    padding-top: 32px;
    padding-inline: 0;
    position: relative;
    z-index: 1;
  }
  .p-intro__pic img {
    width: 100%;
    height: auto;
  }
  .p-intro__pic.lead {
    width: min(342px, 23.75vw);
  }
  .p-intro__pic.trail {
    width: min(332px, 23.05555556vw);
  }
  .p-intro__lead {
    font-size: min(18px, 1.25vw);
    margin-top: 19px;
  }
  .p-intro__trail {
    margin-top: max(-148px, -10.27777778vw);
    width: 100%;
    height: 10.27777778vw;
    background-image: url("/student-work/assets/images/intro/bottom.png");
    background-color: #F7EFEB;
    background-size: 100% 100%;
  }
  .p-intro__trail::before {
    width: min(39px, 2.708333333vw);
    height: min(183px, 12.70833333vw);
    bottom: max(-127px, -8.819444444vw);
    background-image: url("/student-work/assets/images/intro/ic_scroll_arrow.png");
  }
}
.p-reason {
  background-color: var(--bg-faq);
  padding-block: 17.33333333vw 21.33333333vw;
}

.p-reason__head {
  position: relative;
  margin-top: 2.133333333vw;
  padding: 8.533333333vw 0 6.4vw;
  border: 4px solid #59090E;
}
.p-reason__head-en {
  position: absolute;
  top: -3.466666667vw;
  left: 50%;
  padding-inline: 4.266666667vw;
  transform: translateX(-50%);
  color: #5C3A3D;
  font-family: var(--font-en);
  font-size: 5.333333333vw;
  font-weight: 500;
  line-height: 1.3;
  background-color: var(--bg-faq);
}
.p-reason__head-ja {
  display: flex;
  flex-direction: column;
  color: #59090E;
  text-align: center;
  font-family: var(--font-base);
  font-size: 6.4vw;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: -0.03em;
  align-items: center;
}
.p-reason__head-ja > picture {
  width: 42.66666667vw;
}
.p-reason__head-ja > picture > img {
  width: 100%;
  height: auto;
}
.p-reason__head::before, .p-reason__head::after {
  content: "";
  position: absolute;
  bottom: 6.4vw;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.p-reason__head::before {
  left: -3.2vw;
  width: 18.4vw;
  height: 14.4vw;
  background-image: url("/student-work/assets/images/reason/heading_deco_left.png");
}
.p-reason__head::after {
  right: -4.533333333vw;
  width: 21.33333333vw;
  height: 16vw;
  background-image: url("/student-work/assets/images/reason/heading_deco_right.png");
}

.p-reason__lead {
  margin-block: 10.66666667vw;
  font-family: var(--font-base);
  font-weight: 700;
  font-size: 4.266666667vw;
  line-height: 1.8;
  text-align: center;
  color: var(--color-text);
}

.p-reason__box {
  display: flex;
  flex-direction: column;
  gap: 6.4vw;
}

@media (min-width: 768px) {
  .p-reason {
    padding-block: min(188px, 13.05555556vw);
  }
  .p-reason__head {
    margin: 19px auto;
    padding: 12px 0;
    max-width: 724px;
  }
  .p-reason__head-en {
    position: absolute;
    top: -19px;
    padding-inline: 24px;
    font-size: 30px;
    line-height: 1.3;
  }
  .p-reason__head-ja {
    flex-direction: row;
    text-align: center;
    font-family: var(--font-base);
    font-size: 46px;
    justify-content: center;
  }
  .p-reason__head-ja > picture {
    width: 210px;
  }
  .p-reason__head-ja > picture > img {
    width: 100%;
    height: auto;
  }
  .p-reason__head::before, .p-reason__head::after {
    content: "";
    position: absolute;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  .p-reason__head::before {
    left: -261px;
    bottom: 11.2px;
    width: 201px;
    height: 158px;
    background-image: url("/student-work/assets/images/reason/heading_deco_left.png");
  }
  .p-reason__head::after {
    right: -281px;
    bottom: 0;
    width: 234px;
    height: 175px;
    background-image: url("/student-work/assets/images/reason/heading_deco_right.png");
  }
  .p-reason__lead {
    margin-block: 48px 56px;
    font-size: 16px;
  }
  .p-reason__box {
    gap: 72px;
  }
}
.p-point {
  background-color: var(--color-white);
  padding-bottom: 21.33333333vw;
  position: relative;
}
.p-point__heading-sp {
  width: 100%;
  height: 0;
  padding-top: 13.33333333vw;
}
.p-point__heading-deco {
  position: absolute;
  top: -7.2vw;
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;
  height: 61.46666667vw;
  background-image: url("/student-work/assets/images/point/heading_deco_sp.png");
  background-position: center;
  background-size: cover;
}
.p-point__head-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  color: var(--color-brand-dark);
  width: fit-content;
  margin-inline: auto;
}
.p-point__head-inner > p {
  width: fit-content;
  position: relative;
  font-family: var(--font-base);
  font-size: 18px;
  font-weight: 500;
  line-height: 1.3;
  letter-spacing: 0.02em;
  margin-bottom: 4.266666667vw;
}
.p-point__head-inner > p::before, .p-point__head-inner > p::after {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 5.226666667vw;
  height: 5.333333333vw;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.p-point__head-inner > p::before {
  left: -9.493333333vw;
  background-image: url("/student-work/assets/images/common/title-deco-left.png");
}
.p-point__head-inner > p::after {
  right: -9.493333333vw;
  background-image: url("/student-work/assets/images/common/title-deco-right.png");
}
.p-point__head-inner > h2 {
  font-size: 6.4vw;
  font-weight: 700;
  line-height: 1.6;
  margin-bottom: 10.66666667vw;
  display: flex;
  flex-direction: column;
}
.p-point__head-inner > h2 > span {
  width: 60.26666667vw;
}
.p-point__head-inner > h2 > span img {
  width: 100%;
  height: auto;
}

.p-point > .l-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: 48px;
  margin-top: 8px;
}

@media (min-width: 768px) {
  .p-point {
    padding-bottom: 104px;
  }
  .p-point__heading-sp, .p-point__heading-deco {
    display: none;
  }
  .p-point__head {
    padding-top: 117px;
    color: var(--color-brand-dark);
  }
  .p-point__head-inner {
    position: relative;
  }
  .p-point__head-inner > p {
    font-size: 30px;
    margin-bottom: 0;
  }
  .p-point__head-inner > p::before, .p-point__head-inner > p::after {
    width: 49px;
    height: 50px;
    transform: none;
    top: 0;
  }
  .p-point__head-inner > p::before {
    left: -59px;
  }
  .p-point__head-inner > p::after {
    right: -59px;
  }
  .p-point__head-inner > h2 {
    font-size: 46px;
    line-height: 1.3;
    margin-bottom: 0;
    flex-direction: row;
    align-items: center;
    gap: 4px;
  }
  .p-point__head-inner > h2 > span {
    width: 266px;
  }
  .p-point__head-inner::before {
    content: "";
    position: absolute;
    width: 220px;
    height: 190px;
    left: -242px;
    bottom: 0;
    background-image: url("/student-work/assets/images/point/heading_deco_left.png");
    background-size: cover;
    background-repeat: no-repeat;
  }
  .p-point__head-inner::after {
    content: "";
    position: absolute;
    width: 220px;
    height: 190px;
    right: -242px;
    bottom: 0;
    background-image: url("/student-work/assets/images/point/heading_deco_right.png");
    background-size: cover;
    background-repeat: no-repeat;
  }
  .p-point > .l-inner {
    grid-template-columns: repeat(2, 1fr);
    justify-content: center;
    gap: 44px;
    margin-top: 56px;
  }
}
.p-interview {
  background-color: var(--color-white);
  padding-bottom: 21.33333333vw;
}

.p-interview__head {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding-block: 10.66666667vw;
  background-color: var(--color-white);
}

.p-interview__title {
  display: flex;
  flex-direction: column;
  align-items: center;
  line-height: 1.3;
  text-align: center;
  position: relative;
}
.p-interview__title-ja {
  font-family: var(--font-hand);
  font-size: 4.266666667vw;
  letter-spacing: -0.02em;
  font-weight: 400;
  color: var(--color-brand-dark);
}
.p-interview__title-en {
  font-family: var(--font-en);
  font-weight: 500;
  font-size: 8.533333333vw;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: #5c3a3d;
}
.p-interview__title::before, .p-interview__title::after {
  content: "";
  position: absolute;
  width: 9.408vw;
  height: 9.6vw;
  bottom: 0;
  background-size: cover;
  background-repeat: no-repeat;
}
.p-interview__title::before {
  left: -12.21333333vw;
  background-image: url("/student-work/assets/images/common/title-deco-left.png");
}
.p-interview__title::after {
  right: -12.21333333vw;
  background-image: url("/student-work/assets/images/common/title-deco-right.png");
}

.p-interview__list {
  display: flex;
  flex-direction: column;
  gap: 21.33333333vw;
}

@media (min-width: 768px) {
  .p-interview {
    padding-bottom: 120px;
  }
  .p-interview__head {
    display: flex;
    align-items: flex-end;
    justify-content: center;
    padding-block: 120px 48px;
    background-color: var(--color-white);
  }
  .p-interview__title-ja {
    font-size: 16px;
  }
  .p-interview__title-en {
    font-size: 44px;
  }
  .p-interview__title::before, .p-interview__title::after {
    width: 49px;
    height: 50px;
  }
  .p-interview__title::before {
    left: -59px;
  }
  .p-interview__title::after {
    right: -59px;
  }
  .p-interview__list {
    max-width: 1440px;
    margin: 0 auto;
    gap: 80px;
  }
}
.p-yokubari {
  position: relative;
  width: 100vw;
}
.p-yokubari__heading {
  width: 100%;
  height: 24.72222222vw;
  background-image: url("/student-work/assets/images/yokubari/lead_background.png");
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: 100% 101%;
}
.p-yokubari__content {
  background-color: #8C2A30;
  position: relative;
  padding-bottom: 21.33333333vw;
}
.p-yokubari__deco-tl {
  position: absolute;
  top: -3.46666667vw;
  left: 12.26666667vw;
  width: 12.26666667vw;
  height: 10.08vw;
  background-image: url("/student-work/assets/images/yokubari/deco_tl_sp.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}
.p-yokubari__deco-tr, .p-yokubari__deco-bl, .p-yokubari__deco-br {
  display: none;
}
.p-yokubari__catch {
  width: 100vw;
  font-family: var(--font-base);
  color: white;
  position: relative;
  padding-top: 12vw;
}
.p-yokubari__catch-sub {
  font-size: 4.266666667vw;
  font-weight: 700;
  line-height: 1.3%;
  margin-bottom: 2.133333333vw;
}
.p-yokubari__catch-mark {
  display: inline-block;
  padding: 1.066666667vw 2.933333333vw 1.546666667vw 3.466666667vw;
  background-image: url("/student-work/assets/images/yokubari/text-deco.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 100% 100%;
  font-family: "Zen Kurenaido";
  font-size: 5.333333333vw;
  font-weight: 400;
  line-height: 1.3;
}
.p-yokubari__catch-main {
  margin: 0;
  text-shadow: 1px 1px 1.316px rgba(0, 0, 0, 0.25);
  font-family: var(--font-base);
  font-size: 9.6vw;
  font-style: normal;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: -0.05em;
}
.p-yokubari__catch-deco-tl, .p-yokubari__catch-deco-tr {
  display: none;
}
.p-yokubari__catch-deco-br {
  content: "";
  position: absolute;
  width: 6.133333333vw;
  height: 6.4vw;
  background-image: url("/student-work/assets/images/yokubari/deco_br_sp.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  bottom: 1.066666667vw;
  right: 16vw;
}
.p-yokubari__catch-deco-br2 {
  content: "";
  position: absolute;
  width: 11.46666667vw;
  height: 12vw;
  background-image: url("/student-work/assets/images/yokubari/deco_br2_sp.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  bottom: -7.266666667vw;
  right: 4.266666667vw;
}
.p-yokubari__box {
  margin-top: 10.66666667vw;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  row-gap: 2.133333333vw;
  column-gap: 1.866666667vw;
}
.p-yokubari__item {
  width: 43.73333333vw;
  height: 43.73333333vw;
  background-color: var(--color-white);
  border-radius: 6.4vw;
  display: flex;
  flex-direction: column;
  gap: 1.066666667vw;
  align-items: center;
}
.p-yokubari__item > picture {
  margin-top: 6.4vw;
  width: 21.33333333vw;
}
.p-yokubari__item > picture > img {
  width: 100%;
  height: auto;
}
.p-yokubari__item > h3 {
  color: var(--color-text);
  font-family: var(--font-base);
  font-size: 5.333333333vw;
  font-weight: 700;
  line-height: 1.8;
}
.p-yokubari__points {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.133333333vw;
  margin: 10.66666667vw 5.333333333vw 0;
  text-align: start;
}
.p-yokubari__points-item {
  font-family: var(--font-base);
  font-size: 5.866666667vw;
  font-weight: 700;
  line-height: 1.4;
  color: var(--color-white);
  position: relative;
  padding-left: 11.2vw;
  margin-block: 2.4vw;
}
.p-yokubari__points-item::before {
  content: "";
  position: absolute;
  width: 6.4vw;
  height: 8.533333333vw;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  background-image: url("/student-work/assets/images/yokubari/ic_checkmark.png");
  background-size: cover;
  background-repeat: no-repeat;
}
.p-yokubari__points-item > span {
  color: #FFDF40;
}
.p-yokubari__points-item > span > strong {
  font-size: 8vw;
}
.p-yokubari__trailing {
  width: 100vw;
  height: 2.666666667vw;
  background-color: #8C2A30;
  background-image: url("/student-work/assets/images/yokubari/trail_background_sp.png");
  background-repeat: repeat-x;
  background-position: center bottom;
  background-size: 100% 100%;
}

@media (min-width: 768px) {
  .p-yokubari {
    margin-top: max(-60px, -4.166666667vw);
  }
  .p-yokubari__heading {
    position: relative;
    bottom: max(-60px, -4.166666667vw);
  }
  .p-yokubari__deco-tl {
    display: none;
  }
  .p-yokubari__deco-tr {
    position: absolute;
    top: -8.46666667vw;
    right: 276px;
    width: 160px;
    height: 141px;
    background-image: url("/student-work/assets/images/yokubari/deco_tr.png");
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
  }
  .p-yokubari__catch {
    z-index: 10;
    position: relative;
    width: fit-content;
    margin: 0 auto;
    padding-top: 0;
  }
  .p-yokubari__catch-sub {
    font-size: 30px;
    margin-bottom: 6px;
  }
  .p-yokubari__catch-mark {
    display: inline-block;
    padding: 9px 23px;
    font-size: 36px;
  }
  .p-yokubari__catch-main {
    font-size: 56px;
  }
  .p-yokubari__catch-deco-tl {
    display: block;
    position: absolute;
    top: 8px;
    left: -248.35px;
    width: 123.35px;
    height: 108.55px;
    background-image: url("/student-work/assets/images/yokubari/deco_tl.png");
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
  }
  .p-yokubari__catch-deco-tr {
    display: block;
    position: absolute;
    bottom: -98px;
    right: -295px;
    width: 160px;
    height: 141px;
    background-image: url("/student-work/assets/images/yokubari/deco_tr.png");
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
  }
  .p-yokubari__catch-deco-br, .p-yokubari__catch-deco-br2 {
    display: none;
  }
  .p-yokubari__content {
    color: transparent;
    padding-bottom: 0;
  }
  .p-yokubari__box {
    background-color: #8C2A30;
    margin-top: 0;
    padding-top: 64px;
    gap: 45px;
  }
  .p-yokubari__item {
    width: min(210px, 14.58333333vw);
    height: min(210px, 14.58333333vw);
    border-radius: 24px;
    gap: 4px;
  }
  .p-yokubari__item > picture {
    margin-top: min(32px, 2.222222222vw);
    width: min(110px, 7.638888889vw);
  }
  .p-yokubari__item > h3 {
    font-size: min(24px, 1.666666667vw);
  }
  .p-yokubari__points {
    grid-template-columns: repeat(2, 1fr);
    align-items: center;
    row-gap: 44px;
    column-gap: 56px;
    margin: 72px auto 0;
    padding-bottom: 55px;
    width: min(822px, 60vw);
    position: relative;
  }
  .p-yokubari__points-item {
    font-size: min(26px, 1.805555556vw);
    padding-left: min(51px, 3.541666667vw);
    margin-block: 3.5px;
  }
  .p-yokubari__points-item::before {
    width: min(33px, 2.291666667vw);
    height: min(43px, 2.986111111vw);
  }
  .p-yokubari__points-item > span > strong {
    font-size: min(36px, 2.5vw);
  }
  .p-yokubari__points::before {
    content: "";
    position: absolute;
    width: 109.1px;
    height: 96.01px;
    top: -45px;
    left: -258.1px;
    background-image: url("/student-work/assets/images/yokubari/deco_bl.png");
    background-size: cover;
    background-repeat: no-repeat;
  }
  .p-yokubari__points::after {
    content: "";
    position: absolute;
    width: 106.068px;
    height: 93.34px;
    top: -71px;
    right: -255.068px;
    background-image: url("/student-work/assets/images/yokubari/deco_bl.png");
    background-size: cover;
    background-repeat: no-repeat;
  }
  .p-yokubari__trailing {
    height: 118px;
    background-size: 100% 118px;
    background-image: url("/student-work/assets/images/yokubari/trail_background.png");
  }
  .p-yokubari__pc {
    display: block;
    width: 100%;
  }
}
.p-salary {
  background-color: white;
  padding-block: 21.33333333vw;
}

.p-salary__visual {
  display: flex;
  justify-content: center;
}
.p-salary__visual img {
  width: 89.33333333vw;
  height: auto;
}

@media (min-width: 768px) {
  .p-salary {
    padding-block: 0;
  }
  .p-salary__visual img {
    width: 100%;
    max-width: 1440px;
  }
}
.p-faq {
  background-color: var(--bg-faq);
  padding-block: 21.33333333vw;
  border-top-left-radius: 10.66666667vw;
  border-top-right-radius: 10.66666667vw;
  padding-bottom: 21.33333333vw;
}

.p-faq__head {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 10.66666667vw;
}

.p-faq__head-en {
  position: relative;
  font-family: var(--font-en);
  font-size: 5.333333333vw;
  font-weight: 500;
  line-height: 1.3;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: #5C3A3D;
}
.p-faq__head-en::before, .p-faq__head-en::after {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 5.226666667vw;
  height: 5.333333333vw;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.p-faq__head-en::before {
  left: -9.493333333vw;
  background-image: url("/student-work/assets/images/common/title-deco-left.png");
}
.p-faq__head-en::after {
  right: -9.493333333vw;
  background-image: url("/student-work/assets/images/common/title-deco-right.png");
}

.p-faq__head-ja {
  font-weight: 700;
  font-family: "Zen Kaku Gothic New";
  font-size: 6.933333333vw;
  line-height: 1.3;
  letter-spacing: -0.03em;
  color: var(--color-brand-dark);
}

@media (min-width: 768px) {
  .p-faq {
    padding-block: 100px;
    border-radius: 0;
    padding-bottom: 56px;
  }
  .p-faq > .l-inner {
    max-width: 964px;
    margin-inline: auto;
  }
  .p-faq__head {
    margin-bottom: 56px;
  }
  .p-faq__head-en {
    font-size: 30px;
  }
  .p-faq__head-en::before, .p-faq__head-en::after {
    width: 49px;
    height: 50px;
    transform: none;
    top: 0;
  }
  .p-faq__head-en::before {
    left: -74px;
    background-image: url("/student-work/assets/images/common/title-deco-left.png");
  }
  .p-faq__head-en::after {
    right: -74px;
    background-image: url("/student-work/assets/images/common/title-deco-right.png");
  }
  .p-faq__head-ja {
    font-size: 46px;
    margin-top: 8px;
  }
}
.p-footer {
  background-color: var(--color-accent);
  color: var(--color-white);
  padding: min(5.333333333vw, 20px);
  font-family: var(--font-base);
}
.p-footer__inner {
  display: flex;
  flex-direction: column;
  gap: min(2.666666667vw, 10px);
}

.p-footer__company {
  display: flex;
  flex-direction: column;
  gap: min(2.666666667vw, 10px);
}

.p-footer__name,
.p-footer__copy,
.p-footer__powered {
  font-size: min(3.2vw, 14px);
  font-style: normal;
  font-weight: 400;
  line-height: 1.4;
  text-align: left;
}

.p-footer__powered a {
  color: white;
}

.p-footer__link {
  text-align: right;
}
.p-footer__link a {
  font-size: min(3.2vw, 14px);
  color: white;
  text-decoration: underline;
}

@media (min-width: 1240px) {
  .p-footer {
    padding: 20px;
  }
  .p-footer__inner {
    justify-content: space-between;
    flex-direction: row;
  }
  .p-footer__company {
    flex-direction: row;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 6px 24px;
  }
  .p-footer__name,
  .p-footer__copy,
  .p-footer__powered {
    font-size: 14px;
  }
  .p-footer__link a {
    font-size: 14px;
  }
}
