/* guardian.css — for-guardian/index.html メインコンテンツ用 CSS */
.headline {
  background-color: var(--color_white);
  padding: 3rem 0 6rem;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.headline_title {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.headline_title_ja {
  font-size: var(--fs-28-36);
  color: var(--color_blue);
}

.headline_title_en {
  font-size: var(--fs-18-20);
  color: var(--color_sky);
}

/* ----- 保護者の皆さまへ ----- */
.message {
  position: relative;
  padding: 0rem 0 12rem;
  background-image: linear-gradient(135deg, #F3FBFF 25%, transparent 25%, transparent 50%, #F3FBFF 50%, #F3FBFF 75%, transparent 75%, transparent);
  background-size: 100px 100px;
  background-color: #ffffff;
}

.message.section_curving::before {
  background-image: linear-gradient(135deg, #F3FBFF 23%, transparent 22%, transparent 48%, #F3FBFF 44%, #F3FBFF 73%, transparent 73%, transparent);
  background-size: 100px 100px;
  background-color: #ffffff;
}

.message_inner {
  max-width: calc(1024px + 4rem);
  margin: 0 auto;
  padding: var(--pad-inner-pc);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6rem;
}

@media (max-width: 768px) {
  .message_inner {
    padding: var(--pad-inner-sp);
    gap: 3rem;
  }
}

.message_lead_container {
  display: flex;
  align-items: center;
  width: 100%;
  justify-content: flex-end;
  position: relative;
}

@media (max-width: 768px) {
  .message_lead_container {
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem;
  }
}

.message_lead {
  position: absolute;
  left: 0;
  bottom: 1rem;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.5rem;
  font-size: var(--fs-24-44);
  color: var(--color_white);
  font-weight: var(--font_bold);
}

@media (max-width: 768px) {
  .message_lead {
    display: none;
  }
}

.message_lead--sp-only {
  display: none;
}

@media (max-width: 768px) {
  .message_lead--sp-only {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    width: 100%;
  }

  .message_lead_line--sp-only {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.5rem;
    font-size: clamp(1.25rem, 0.057rem + 5.09vw, 2.5rem);
    color: var(--color_blue);
    font-weight: var(--font_bold);
    word-break: auto-phrase;
  }
}

.message_lead_line {
  position: relative;
  padding: .5rem 2rem .5rem 1rem;
  line-height: 1.2;
  filter: drop-shadow(2px 2px 2px rgba(0, 0, 0, .3));
}

.message_lead_line::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background-color: var(--color_sky);
  clip-path: polygon(0 0, 100% 0%, 95% 100%, 0% 100%);
}

@media (max-width: 768px) {
  .message_lead {
    position: static;
  }
}

.message_figure {
  width: 100%;
  max-width: 810px;
  aspect-ratio: 2 / 1;
  overflow: hidden;
  border-radius: 1rem;
}

.message_figure_image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.message_title {
  font-size: var(--fs-24-32);
  font-weight: var(--font_bold);
  font-family: serif;
}

.message_contents {
  display: flex;
  flex-direction: column;
  gap: 2em;
  max-width: 848px;
}

.message_contents p {
  font-size: var(--fs-18-20);
  line-height: 2;
}

/* ----- エスケイケイのお仕事 ----- */
.works {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 12rem 0 24rem;
  background-image: radial-gradient(#B9E6FA 2px, transparent 2px), radial-gradient(#B9E6FA 2px, transparent 2px);
  background-size: 40px 40px;
  background-position: 0 0, 20px 20px;
  background-color: #57C7F9;
  position: relative;
}

@media (max-width: 768px) {
  .works {
    padding: 14rem 0 18rem;
  }
}

@media (max-width: 425px) {
  .works {
    padding: 14rem 0 12rem;
  }
}

.works_decoration_illust {
  position: absolute;
  max-width: 380px;
  aspect-ratio: 1 / 1;
  top: 0;
  left: 5%;
  transform: translateY(-50%);
}

.works_inner {
  max-width: calc(1024px + 4rem);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--pad-inner-pc);
  gap: 3.5rem;
}

@media (max-width: 768px) {
  .works_inner {
    padding: var(--pad-inner-sp);
  }
}

.works_header {
  text-align: center;
}

.works_heading {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  margin: 0;
}

.works_heading_ja {
  font-size: var(--fs-28-36);
  font-weight: var(--font_bold);
  color: var(--color_white);
}

.works_heading_en {
  font-size: var(--fs-18-20);
  font-weight: var(--font_bold);
  color: var(--color_yellow-deep);
}

.works_lead {
  margin: 0;
  text-align: center;
  font-size: var(--fs-18-24);
  color: var(--color_white);
}

.works_products {
  list-style: none;
  display: flex;
  gap: 3rem;
  width: 100%;
  justify-content: center;
}

@media (max-width: 768px) {
  .works_products {
    align-items: center;
    flex-wrap: wrap;
  }
}

@media (max-width: 425px) {
  .works_products {
    flex-direction: column;
  }
}

.works_product_figure {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  align-items: center;
}

.works_product_label {
  font-size: 1.5rem;
  font-weight: var(--font_semibold);
  color: var(--color_white);
  text-align: center;
}

.works_decoration_photo {
  position: absolute;
  bottom: 0;
  transform: translateY(50%);
  width: 100%;
  max-width: 912px;
  margin: 0;
  overflow: hidden;
  padding: 0 1rem;
}

.works_decoration_photo_image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: 1rem;
}

/* ----- 安心して働ける職場 ----- */
.supportive {
  background-color: var(--color_blue-pale);
  padding: 24rem 0 6rem;
}

@media (max-width: 768px) {
  .supportive {
    padding: 18rem 0 0;
  }
}

@media (max-width: 425px) {
  .supportive {
    padding: 12rem 0 0;
  }
}

.supportive_inner {
  max-width: calc(1024px + 4rem);
  margin: 0 auto;
  padding: var(--pad-inner-pc);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5rem;
}

@media (max-width: 768px) {
  .supportive_inner {
    padding: var(--pad-inner-sp);
    gap: 3rem;
  }
}

.supportive_header {
  text-align: center;
  margin-bottom: 2rem;
}

.supportive_heading {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.supportive_heading_ja {
  font-size: var(--fs-28-36);
  font-weight: var(--font_bold);
  color: var(--color_blue);
}

.supportive_heading_en {
  font-size: var(--fs-18-20);
  font-weight: var(--font_bold);
  color: var(--color_yellow-deep);
}

.supportive_intro {
  margin: 0 auto 2.5rem;
  max-width: 848px;
  font-size: var(--fs-18-24);
  line-height: 1.8;
}

.supportive_list {
  max-width: 53rem;
  display: flex;
  flex-direction: column;
  gap: 10rem;
  counter-reset: supportive-step;
}

@media (max-width: 768px) {
  .supportive_list {
    gap: 6rem;
  }
}

.supportive_item {
  counter-increment: supportive-step;
  position: relative;
  padding: 3.5rem 2rem 2rem;
  background: var(--color_white);
  border: 2px solid #097DD4;
  border-radius: 0.75rem;
}

@media (max-width: 768px) {
  .supportive_item {
    padding: 3.25rem 1.25rem 1.5rem;
  }
}

.supportive_item:last-child {
  margin-bottom: 0;
}

.supportive_item::before {
  content: counter(supportive-step);
  position: absolute;
  top: 0;
  left: 0;
  transform: translate(20%, -90%);
  font-size: var(--fs-48-72);
  font-weight: var(--font_bold);
  line-height: 1;
  color: var(--color_white);
  text-shadow: 2px 0 0 #097DD4,
    -2px 0 0 #097DD4,
    0 2px 0 #097DD4,
    0 -2px 0 #097DD4,
    1.5px 1.5px 0 #097DD4,
    -1.5px 1.5px 0 #097DD4,
    1.5px -1.5px 0 #097DD4,
    -1.5px -1.5px 0 #097DD4,
    6px 0px 0px rgba(0, 0, 0, 0.3);
  z-index: 1;
}

.supportive_item_title {
  position: absolute;
  top: 0px;
  left: 50%;
  transform: translate(-50%, -50%);
  margin: 0;
  padding: 1rem 3rem;
  font-size: var(--fs-20-28);
  font-weight: var(--font_medium);
  color: var(--color_white);
  background: #097DD4;
  border-radius: 0.5rem;
  z-index: 1;
  text-align: center;
  width: max-content;
}

@media (max-width: 768px) {
  .supportive_item_title {
    word-break: keep-all;
    padding: 0.65rem 1.25rem;
    width: auto;
  }
}

.supportive_bullets {
  margin: 0;
  padding-left: 0;
  color: #333;
  list-style: none;
}

.supportive_bullets li {
  display: flex;
  align-items: flex-start;
  gap: 0.65em;
  margin-bottom: 0.5em;
  font-size: var(--fs-18-20);
  line-height: 1.8;
}

.supportive_bullets li::before {
  content: "";
  flex: 0 0 12px;
  width: 12px;
  height: 12px;
  margin-top: calc((1em * 1.8 - 12px) / 2);
  border-radius: 50%;
  background: var(--color_sky);
}

.supportive_bullets li:last-child {
  margin-bottom: 0;
}

.supportive_outro {
  position: relative;
  display: flex;
  justify-content: center;
}

@media (max-width: 768px) {
  .supportive_outro {
    width: 85%;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
  }
}

@media (max-width: 425px) {
  .supportive_outro {
    width: 100%;
  }
}

.supportive_outro_comment {
  position: relative;
  display: flex;
  justify-content: center;
  width: min(100%, 860px);
  margin-inline: auto;
  overflow: hidden;
}

.supportive_outro_image {
  display: block;
  width: auto;
  max-width: none;
  height: auto;
}

.supportive_outro_text {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  margin-top: 1.5rem;
  padding: clamp(1rem, 3vw, 2.25rem) clamp(1rem, 5vw, 3rem);
}

@media (max-width: 768px) {
  .supportive_outro_comment {
    width: 100%;
    max-width: none;
    margin-inline: 0;
    overflow: visible;
    background-color: var(--color_white);
    border-radius: 1rem;
    box-shadow: 0 4px 14px rgba(0, 87, 175, 0.12);
    margin-bottom: 1rem;
  }

  .supportive_outro_image {
    display: none;
  }

  .supportive_outro_text {
    position: static;
    inset: auto;
    display: block;
    margin-top: 0;
    padding: clamp(1rem, 4vw, 1.5rem) clamp(1rem, 4vw, 1.25rem);
  }

  .supportive_outro_comment::before {
    content: "";
    position: absolute;
    border-style: solid;
    border-color: transparent transparent transparent var(--color_white);
    top: auto;
    bottom: 0;
    right: 0;
    transform: translate(-70%, 100%);
    border-width: 0px 0 24px 32px;
  }

  .supportive_outro_lead {
    max-width: none;
  }
}

.supportive_outro_title {
  position: relative;
  z-index: 0;
  display: inline-flex;
  justify-content: center;
  margin: 0 0 1.25rem;
  font-size: var(--fs-20-28);
  font-weight: var(--font_bold);
  line-height: 1.3;
}

.supportive_outro_title::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0.1em;
  z-index: -1;
  width: 100%;
  height: 0.5em;
  background-color: var(--color_yellow);
  transform: skewX(-18deg);
}

.supportive_outro_lead {
  color: #333;
  font-size: var(--fs-16-20);
  font-weight: var(--font_medium);
  line-height: 1.8;
  text-align: center;
  margin: 0;
  max-width: 34em;
}

.supportive_outro_illust {
  position: absolute;
  right: 0;
  bottom: 0;
  max-width: 247px;
  height: auto;
  width: 100%;
  transform: translate(0, 50%);
}

@media (max-width: 768px) {
  .supportive_outro_illust {
    position: static;
    width: min(45vw, 200px);
    transform: none;
    align-self: flex-end;
    margin-top: 0;
  }
}

/* ----- インターンシップ ----- */
.internship {
  padding: 9rem 0;
  background: var(--color_blue);
  position: relative;
}

.internship_inner {
  max-width: calc(1024px + 4rem);
  margin: 0 auto;
  padding: var(--pad-inner-pc);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6rem;
  position: relative;
}

@media (max-width: 768px) {
  .internship_inner {
    padding: var(--pad-inner-sp);
  }
}

.internship_header {
  text-align: center;
  margin-bottom: 2rem;
}

.internship_heading {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  margin: 0;
}

.internship_heading_ja {
  font-size: var(--fs-28-36);
  font-weight: var(--font_bold);
  color: var(--color_white);
}

.internship_heading_en {
  font-size: var(--fs-18-20);
  font-weight: var(--font_bold);
  color: var(--color_yellow-deep);
}

.internship_body {
  padding: 2rem 4rem 4rem 4rem;
  background-color: var(--color_white);
  border-radius: 1rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3rem;
  max-width: 1000px;
  width: 100%;
}

@media (max-width: 768px) {
  .internship_body {
    padding: 2rem;
  }
}

@media (max-width: 425px) {
  .internship_body {
    padding: 1rem 1rem 9rem;
  }
}

.internship_body_decoration {
  display: flex;
  justify-content: space-between;
  width: 100%;
}

.internship_body_decoration_image_left {
  width: 100%;
  height: auto;
  max-width: clamp(7.5rem, 4.859rem + 11.27vw, 15rem);
}

.internship_body_decoration_image_right {
  transform: scale(-1, 1);
  width: 100%;
  height: auto;
  max-width: clamp(7.5rem, 4.859rem + 11.27vw, 15rem);
}

.internship_catch {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2rem;
}

.internship_catch_main {
  font-size: var(--fs-28-46);
  font-weight: var(--font_bold);
  position: relative;
  z-index: 0;
  text-align: center;
  display: inline-flex;
  justify-content: center;
  flex-direction: column;
  margin: 0;
  word-break: auto-phrase;
}

.internship_catch_main::after {
  content: "";
  position: absolute;
  bottom: 0.2em;
  z-index: -1;
  width: 100%;
  height: 20px;
  background-color: var(--color_yellow);
  transform: skewX(-18deg);
}

.internship_catch_sub {
  margin: 0;
  font-size: var(--fs-22-32);
}

@media (max-width: 425px) {
  .internship_catch_sub {
    display: flex;
    flex-direction: column;
    width: 100%;
  }

  .internship_catch_sub > span:last-of-type {
    text-align: right;
  }
}

.internship_intro {
  max-width: 48rem;
  font-size: var(--fs-18-20);
  font-weight: var(--font_medium);
  line-height: 1.8;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.internship_days_title {
  font-size: var(--fs-22-32);
  font-weight: var(--font_bold);
  text-align: left;
  width: 100%;
  margin-top: 4rem;
}

@media (max-width: 768px) {
  .internship_days_title {
    text-align: center;
    margin-top: 0;
  }
}

.internship_days {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8rem;
  width: 100%;
}

@media (max-width: 768px) {
  .internship_days {
    gap: 4rem;
  }
}

.day {
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
  position: relative;
  padding: 2.5rem;
  background-color: var(--color_white);
  border-radius: 1rem;
  width: 100%;
  border: 2px solid var(--color_sky);
}

@media (max-width: 768px) {
  .day {
    padding: 1.25rem;
    gap: 0;
  }
}

@media (max-width: 425px) {
  .day {
    padding: 1rem;
  }
}

.day:nth-of-type(2) {
  border: 2px solid #097DD4;
}

.day:nth-of-type(3) {
  border: 2px solid var(--color_blue);
}

.day_label {
  font-weight: var(--font_medium);
  width: clamp(5rem, 3.8rem + 5.12vw, 7rem);
  padding-bottom: 20px;
  aspect-ratio: 1 /1;
  height: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color_sky);
  color: var(--color_white);
  clip-path: polygon(0 0, 100% 0%, 100% 70%, 50% 100%, 0 70%);
  line-height: 1;
  position: absolute;
  top: 0px;
  left: 16px;
  transform: translateY(-20%);
}

@media (max-width: 768px) {
  .day_label {
    order: 1;
  }
}

.day_label > span:nth-of-type(1) {
  font-size: var(--fs-30-50);
}

.day_label > span:nth-of-type(2) {
  font-size: var(--fs-18-28);
  padding-top: 1%;
}

.day_title {
  font-size: var(--fs-24-40);
  font-weight: var(--font_bold);
  color: var(--color_sky);
  padding: 0 17rem 0 8rem;
  word-break: keep-all;
}

@media (max-width: 768px) {
  .day_title {
    padding: 0 0 0 7rem;
    order: 2;
    word-break: auto-phrase;
  }
}

@media (max-width: 425px) {
  .day_title {
    padding: 0 0 0 5.5rem;
  }
}

.day_decoration {
  position: absolute;
  top: 0;
  right: 0px;
  transform: translateY(-50%);
}

@media (max-width: 768px) {
  .day_decoration {
    position: static;
    order: 4;
    transform: none;
  }
}

.day_decoration_illust {
  max-width: clamp(12.5rem, 9.381rem + 11.74vw, 18.188rem);
  height: auto;
  width: 100%;
}

@media (max-width: 768px) {
  .day_decoration_illust {
    margin: 1rem 0 -1.5rem auto;
    z-index: 1;
    position: relative;
  }
}

.day_lead {
  font-size: var(--fs-18-24);
  font-weight: var(--font_semibold);
}

@media (max-width: 768px) {
  .day_lead {
    order: 3;
    margin-top: 3rem;
  }
}

.day_contents {
  display: flex;
  gap: 1rem;
  justify-content: space-between;
}

@media (max-width: 768px) {
  .day_contents {
    flex-direction: column-reverse;
    order: 5;
  }
}

.day_list {
  list-style: disc;
  display: flex;
  flex-direction: column;
  gap: .5rem;
  margin: 0;
  padding-left: 1em;
  font-size: var(--fs-16-18);
  max-width: 376px;
  width: 100%;
}

@media (max-width: 768px) {
  .day_list {
    max-width: 100%;
  }
}

.day_contents_figure {
  flex: 1;
}

.day_contents_figure_image {
  border-radius: .5rem;
}

.internship_closing {
  max-width: 48rem;
  display: flex;
  gap: 3rem;
  flex-direction: column;
  align-items: center;
}

.internship_closing_title {
  font-size: 1.875rem;
  font-weight: var(--font_bold);
  position: relative;
  z-index: 0;
  text-align: center;
  display: inline-flex;
  justify-content: center;
  flex-direction: column;
  margin-top: 4rem;
}

.internship_closing_title::after {
  content: "";
  position: absolute;
  bottom: 0.2em;
  z-index: -1;
  width: 100%;
  height: 20px;
  background-color: var(--color_yellow);
  transform: skewX(-18deg);
}

.internship_closing_text {
  font-size: var(--fs-18-20);
  line-height: 1.8;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.internship_decoration_illust {
  position: absolute;
  bottom: 0;
  left: 0;
  transform: translate(-50%, 50%);
  z-index: 2;
  width: clamp(7.625rem, 5.468rem + 9.2vw, 13.75rem);
  align-self: flex-end;
}

@media (max-width: 768px) {
  .internship_decoration_illust {
    transform: translate(0%, 90%);
  }
}

@media (max-width: 425px) {
  .internship_decoration_illust {
    transform: translate(0, 70%);
  }
}

/* ----------------------------------------------

募集要項 CTA

---------------------------------------------- */
.recruitment {
  position: relative;
  z-index: 1;
  padding: 0 0 12rem 0;
  background-image: radial-gradient(#fff 2px, transparent 2px), radial-gradient(#fff 2px, transparent 2px);
  background-size: 40px 40px;
  background-position: 0 0, 20px 20px;
  background-color: #FFEE7D;
}

@media (max-width: 425px) {
  .recruitment {
    padding: 3rem 0 12rem;
  }
}

.recruitment.section_curving::before {
  background-image: radial-gradient(#fff 2px, transparent 2px), radial-gradient(#fff 2px, transparent 2px);
  background-size: 40px 40px;
  background-position: 0 18px, 20px 36px;
  background-color: #FFEE7D;
}

.recruitment_inner {
  max-width: 1200px;
  margin: 0 auto;
  padding-left: 1rem;
  padding-right: 1rem;
}

.recruitment_cta {
  display: flex;
  align-items: center;
  flex-direction: column;
  position: relative;
}

.recruitment_text {
  display: flex;
  text-align: center;
  color: var(--color_blue);
  font-weight: var(--font_bold);
  gap: 1rem;
  word-break: keep-all;
  font-size: var(--fs-16-18);
  position: absolute;
  bottom: 0;
  transform: translateY(-50%);
}

@media (max-width: 768px) {
  .recruitment_text {
    transform: translateY(-250%);
  }
}

.recruitment_text::before,
.recruitment_text::after {
  content: "";
  width: 5px;
  background-color: var(--color_blue);
  align-self: stretch;
  border-radius: 1rem;
}

.recruitment_text::before {
  transform: rotate(-25deg);
}

.recruitment_text::after {
  transform: rotate(25deg);
}

.recruitment_illust_figure {
  display: flex;
  gap: 1rem;
  justify-content: space-between;
  width: 100%;
  max-width: 800px;
}

@media (max-width: 768px) {
  .recruitment_illust_figure {
    justify-content: space-around;
  }
}

.recruitment_illust_figure_image {
  max-width: 192px;
  height: auto;
  width: clamp(9.125rem, 7.633rem + 5.82vw, 12rem);
}

.recruitment_link {
  width: 100%;
  max-width: 800px;
  padding: 2.5rem;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: var(--color_white);
  margin: auto;
  flex-direction: column;
  line-height: 1;
  gap: 8px;
  color: var(--color_blue);
  border: solid 5px var(--color_blue);
  border-radius: 10px;
  text-decoration: none;
  box-sizing: border-box;
}

.recruitment_link > span:first-of-type {
  font-size: var(--fs-20-40);
  font-weight: var(--font_bold);
}

.recruitment_link > span:last-of-type {
  font-size: var(--fs-16-20);
  font-weight: var(--font_bold);
}