/* 共通
---------------------------*/
/* フォントサイズ */
:root {
  --h1-en-font-size: clamp(28px, 4vw, 32px);
  --h1-font-size: 15px;
  --h2-font-size: clamp(22px, 3vw, 26px);
  --h2-s-font-size: 19px;
  --ttl-font-size: clamp(40px, 5vw, 80px);
}
/* 余白 */
:root {
  --rn-sec-margin-xl: 240px;
  --rn-sec-margin-lg: 120px;
  --rn-sec-margin-md: 100px;
  --rn-sec-margin-ms: 80px;
  --rn-sec-margin-sm: 60px;
  --rn-sec-margin-s: 40px;
  --rn-sec-margin-xs: 32px;
  --rn-sec-margin-xsm: 24px;
  --rn-sec-margin-xxs: 16px;
  --rn-sec-margin-xxxs: 8px;
  --rn-header-height: 80px; /* ヘッダーの高さ（PC） */
  --rn-header-height-sp: 60px; /* ヘッダーの高さ（SP） */
}
/* 色 */
:root {
  --skyblue: #e1edeb;
  --pink: #f4e3e0;
  --lightyellow: #f8eddc;
  --green: #7dbb88;
  --coral: #e08691;
  --orange: #e79b37;
  --orange-flame: #ed6d00;
  --orange-dark: #ea5504;
  --gray: #5a5858;
  --gray-light: #efece7;
  --gray-light2: #e4e5e3;
}
/* Macでの文字の太りを抑え、スッキリ見せる設定 */
body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.recruite-rn__h1-en {
  font-family: "Lato", serif;
  font-size: var(--h1-en-font-size);
  display: block;
  font-weight: 700;
  margin-bottom: 8px;
  letter-spacing: 0.1em;
}
.recruite-rn__h1 {
  font-size: var(--h1-font-size);
  margin-bottom: 0;
  font-weight: 500;
}
.recruite-rn__h2 {
  font-size: var(--h2-font-size);
  letter-spacing: 0.1em;
  margin-bottom: 0;
  font-weight: 500;
}
.recruite-rn__h2-s {
  font-size: var(--h2-s-font-size);
  /* letter-spacing: 0.1em; */
  font-weight: 500;
  margin-bottom: 0;
  line-height: 1.5;
}
.recruit-rn-ttl-sec {
  margin-top: var(--rn-sec-margin-lg);
}
.recruit-rn-ttl-sec__txt {
  margin-top: var(--rn-sec-margin-xs);
  font-weight: 400;
  font-size: 16px;
  margin-bottom: 0;
  line-height: 2;
}
@media (max-width: 767px) {
  .recruit-rn-ttl-sec {
    margin-top: var(--rn-sec-margin-sm);
  }
}

/* display
---------------------------*/
.pc-inline-block {
  display: inline-block;
}

@media (max-width: 767px) {
  .pc-inline-block {
    display: none !important;
  }
}

/* btn
---------------------------*/
.recruite-rn-btn {
  display: flex;
  align-items: center;
  gap: var(--rn-sec-margin-xxs);
  text-decoration: none;
  transition: opacity 0.3s ease;
}
.recruite-rn-btn:hover {
  opacity: 0.7;
}
.recruite-rn-btn:hover .recruite-rn-btn__img img {
  animation: slideRightLeft 0.6s ease forwards;
}
.recruite-rn-btn__txt {
  color: #000;
  font-size: 16px;
  margin: 0;
  font-weight: 500;
}
.recruite-rn-btn__img {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  border: 1px solid #000;
  padding: 10px;
  border-radius: 8px;
  text-decoration: none;
  overflow: hidden;
  width: 48px;
  height: 48px;
}
.recruite-rn-btn__img img {
  width: 26px;
  transition: transform 0.6s ease;
}
@keyframes slideRightLeft {
  0% {
    transform: translateX(0);
  }
  50% {
    transform: translateX(100%);
    opacity: 0;
  }
  51% {
    transform: translateX(-100%);
    opacity: 0;
  }
  100% {
    transform: translateX(0);
    opacity: 1;
  }
}
@media (max-width: 767px) {
  .recruite-rn-btn__img {
    width: 38px;
    height: 38px;
  }
  .recruite-rn-btn__img img {
    width: 16px;
  }
}

/* btn-noborder（枠線なしボタン）
---------------------------*/
.recruite-rn-btn-noborder {
  display: flex;
  align-items: center;
  gap: var(--rn-sec-margin-xxs);
  text-decoration: none;
  transition: opacity 0.3s ease;
}
.recruite-rn-btn-noborder:hover {
  opacity: 0.7;
}
.recruite-rn-btn-noborder:hover .recruite-rn-btn-noborder__img img {
  animation: slideRightLeft 0.6s ease forwards;
}
.recruite-rn-btn-noborder__txt {
  color: #000;
  font-size: 16px;
  margin: 0;
  font-weight: 500;
  letter-spacing: 0.1em;
}
.recruite-rn-btn-noborder__img {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
}
.recruite-rn-btn-noborder__img img {
  width: 16px;
  transition: transform 0.6s ease;
}

/* btn-full（フルワイドボタン）
---------------------------*/
.recruite-rn-btn-full {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--rn-sec-margin-xxs);
  width: 100%;
  padding: var(--rn-sec-margin-xxs) var(--rn-sec-margin-xs);
  background-color: #000;
  border-radius: 8px;
  text-decoration: none;
  transition: opacity 0.3s ease;
}
.recruite-rn-btn-full:hover {
  opacity: 1;
  filter: opacity(0.8);
}
.recruite-rn-btn-full:hover .recruite-rn-btn-full__img img {
  animation: slideRightLeft 0.6s ease forwards;
}
.recruite-rn-btn-full__txt {
  color: #fff;
  font-size: 18px;
  font-weight: 700;
  margin: 0;
  letter-spacing: 0.05em;
}
.recruite-rn-btn-full__img {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  background-color: #fff;
  padding: 10px;
  border-radius: 8px;
  overflow: hidden;
  margin: 0;
  width: 48px;
  height: 48px;
}
.recruite-rn-btn-full__img img {
  width: 26px;
  transition: transform 0.6s ease;
}

@media (max-width: 767px) {
  .recruite-rn-btn-full {
    padding: var(--rn-sec-margin-xxs);
  }
  .recruite-rn-btn-full__txt {
    font-size: 16px;
  }
  .recruite-rn-btn-full__img {
    width: 38px;
    height: 38px;
  }
  .recruite-rn-btn-full__img img {
    width: 16px;
  }
}

/* animation
---------------------------*/
@keyframes fadeInBase {
  from {
    opacity: 0;
    transform: translate3d(0, 32px, 0);
  }

  to {
    opacity: 1;
    transform: none;
  }
}

.fadeInBase {
  animation-name: fadeInBase;
}
@keyframes fadeInLeftSlight {
  from {
    opacity: 0;
    transform: translate3d(-16px, 0, 0);
  }
  to {
    opacity: 1;
    transform: none;
  }
}

.fadeInLeftSlight {
  animation-name: fadeInLeftSlight;
}

@keyframes bang {
  0% {
    opacity: 0;
    transform: scale(0.3);
  }
  10% {
    opacity: 1;
    transform: scale(1.3);
  }
  25% {
    opacity: 1;
    transform: scale(0.9);
  }
  60% {
    opacity: 1;
    transform: scale(1);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

.bang {
  transform-origin: center center;
  animation-name: bang;
  animation-duration: 1s;
  animation-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  animation-iteration-count: 1;
  animation-fill-mode: both;
}

@keyframes fadeInEmphasis {
  0% {
    opacity: 0;
    transform: translate3d(0, 100%, 0);
  }
  20% {
    opacity: 1;
    transform: translate3d(0, -8px, 0);
  }
  60% {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
  100% {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

.fadeInEmphasis {
  animation: fadeInEmphasis 1s cubic-bezier(0.4, 0, 0.2, 1) both;
}

/* カワジュンの想いアニメーション */
.eachTextAnime {
  display: flex;
  align-items: baseline;
  gap: 0.5em;
  overflow: hidden;
}

/* 文字コンテナ */
.eachTextAnime__text {
  display: flex;
  font-weight: 600;
}

/* 1文字ずつ */
.eachTextAnime__text span {
  transform: translateY(4px);
  opacity: 0;
  animation-delay: var(--delay, 0s);
}

/* 表示トリガー */
.eachTextAnime.appeartext .eachTextAnime__text span {
  animation: text_anime_on 0.6s ease-out var(--delay, 0s) forwards;
}

.eachTextAnime__text {
  position: relative;
  padding-left: 40px;
}
.eachTextAnime__text::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  width: 30px;
  height: 1px;
  border-top: 1px solid #000;
}
@media (max-width: 767px) {
  .recruit-philosophy__desc {
    display: inline-block;
  }
  /* スマホではflexを維持しながら折り返しを有効にする */
  .eachTextAnime {
    overflow: visible;
  }
  .eachTextAnime__text {
    display: flex;
    flex-wrap: wrap;
  }
}

/* スマホ用：文字ごとに左からほわっとフェードイン */
@-webkit-keyframes charFadeInSmooth {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(-3px, 0, 0);
    transform: translate3d(-3px, 0, 0);
  }
  100% {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes charFadeInSmooth {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(-3px, 0, 0);
    transform: translate3d(-3px, 0, 0);
  }
  100% {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

/* 以前のスライドイン（未使用だが残す） */
@-webkit-keyframes slideInFromLeft {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-10px) scale(0.98);
    transform: translateX(-10px) scale(0.98);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0) scale(1);
    transform: translateX(0) scale(1);
  }
}

@keyframes slideInFromLeft {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-10px) scale(0.98);
    transform: translateX(-10px) scale(0.98);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0) scale(1);
    transform: translateX(0) scale(1);
  }
}

@keyframes text_anime_on {
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

/* スマホ専用の超軽量アニメーション */
@-webkit-keyframes text_anime_on_sp {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(0, 2px, 0);
    transform: translate3d(0, 2px, 0);
  }
  100% {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes text_anime_on_sp {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(0, 2px, 0);
    transform: translate3d(0, 2px, 0);
  }
  100% {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

/* タイトルアニメーション */
@keyframes shrinkIn {
  from {
    opacity: 0;
    /* 手前に出てくるようにZ軸で奥から手前へ移動、かつ縮小から拡大 */
    transform: translate3d(0, 44px, -300px) scale(0.85);
  }
  60% {
    opacity: 1;
    transform: translate3d(0, 0, 20px) scale(1);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
  }
}

.shrinkIn {
  display: inline-block; /* transform-origin が期待通り効くように */
  transform-origin: center center;
  backface-visibility: hidden;
  will-change: transform, opacity, filter;
  animation: shrinkIn 0.85s cubic-bezier(0.2, 0.9, 0.2, 1) both;
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translate3d(0, 16px, 0);
  }

  to {
    opacity: 1;
    transform: none;
  }
}

.fadeInUp {
  animation-name: fadeInUp;
}

/* カワジュンの想い
---------------------------*/
.recruit-philosophy {
  line-height: 2;
}

.recruit-philosophy-sec01 {
  margin-top: var(--rn-sec-margin-lg);
}
.recruit-philosophy-sec01__h3 {
  font-size: clamp(20px, 3vw, 24px);
  font-weight: 500;
  line-height: 1.6;
  margin: 0;
  margin-top: var(--rn-sec-margin-xs);
}
.recruit-philosophy-sec01__txt01 {
  margin: 0;
  margin-top: var(--rn-sec-margin-xs);
  line-height: 1.6;
}
.recruit-philosophy-sec02 {
  margin-top: var(--rn-sec-margin-lg);
}
.recruit-philosophy-sec02__row {
  display: flex;
  gap: var(--rn-sec-margin-xs);
}
.recruit-philosophy-sec03 {
  margin-top: var(--rn-sec-margin-lg);
}
.recruit-philosophy-sec04 {
  margin-top: var(--rn-sec-margin-lg);
}
.recruit-philosophy-sec05 {
  margin-top: var(--rn-sec-margin-lg);
}
.recruit-philosophy-sec05__txt {
  margin: 0;
  margin-top: var(--rn-sec-margin-xs);
}
@media (max-width: 767px) {
  .recruit-philosophy-sec01 {
    margin-top: var(--rn-sec-margin-sm);
  }
  .recruit-philosophy-sec02 {
    margin-top: var(--rn-sec-margin-sm);
  }
  .recruit-philosophy-sec02__row {
    flex-wrap: wrap;
    gap: var(--rn-sec-margin-xxs);
  }
  .recruit-philosophy-sec03 {
    margin-top: var(--rn-sec-margin-sm);
  }
  .recruit-philosophy-sec04 {
    margin-top: var(--rn-sec-margin-sm);
  }
  .recruit-philosophy-sec05 {
    margin-top: var(--rn-sec-margin-sm);
  }
}

/* 共通 */
.recruit-philosophy__lead {
  margin: 0;
  margin-bottom: var(--rn-sec-margin-xs);
}
.recruit-philosophy__lead-en {
  font-family: "Lato", serif;
  font-size: 26px;
  font-weight: 500;
  letter-spacing: 0.1em;
  margin: 0;
}
.recruit-philosophy__lead-ja {
  font-size: 14px;
  font-weight: 400;
  margin: 0;
  margin-top: 8px;
}

.recruit-philosophy__list {
  list-style: none;
  margin-top: var(--rn-sec-margin-s);
}

.recruit-philosophy__item {
  margin-top: var(--rn-sec-margin-xs);
}
.recruit-philosophy__item-ttl {
  display: flex;
  align-items: baseline;
  gap: 12px;
  margin: 0 0 8px 0;
  font-size: 18px;
  font-weight: 500;
}
.recruit-philosophy__number {
  display: inline-block;
  text-align: center;
  font-weight: 500;
  font-size: 20px;
}
.recruit-philosophy__desc {
  margin: 0;
  margin-left: var(--rn-sec-margin-s);
  margin-top: var(--rn-sec-margin-xxxs);
  font-size: 15px;
  line-height: 1.6;
}
.recruit-philosophy__note {
  margin-left: var(--rn-sec-margin-s);
  margin-top: 10px;
  display: block;
  font-size: 14px;
  color: var(--orange-flame);
}
.recruit-philosophy__icon-img {
  width: 130px;
  vertical-align: middle;
}
.recruit-philosophy__icon-figcaption {
  display: inline-block;
  font-weight: 600;
  line-height: 1.6;
}
@media (max-width: 767px) {
  /* .recruit-philosophy {
    margin-top: var(--rn-sec-margin-sm);
  } */
  .recruit-philosophy__list {
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .recruit-philosophy__desc,
  .recruit-philosophy__note {
    margin-left: 0;
  }
  .recruit-philosophy__desc,
  .recruit-philosophy__note {
    margin-left: 1.5em;
  }
  .recruit-philosophy__item-ttl {
    font-size: 16px;
    gap: 0;
    margin-bottom: 0;
  }
  .recruit-philosophy__number {
    min-width: 28px;
    height: 28px;
    line-height: 28px;
    font-size: 18px;
  }
  .recruit-philosophy__icon-figcaption {
    margin-top: var(--rn-sec-margin-xxxs);
  }
}

/* 数字でひもとく
---------------------------*/
.recruit-facts {
  line-height: 2;
}

.recruit-facts-sec01,
.recruit-facts-sec02,
.recruit-facts-sec03 {
  margin-top: var(--rn-sec-margin-lg);
}
.recruit-facts-sec01 .recruite-rn__h2-s,
.recruit-facts-sec02 .recruite-rn__h2-s,
.recruit-facts-sec03 .recruite-rn__h2-s {
  margin-bottom: 2em;
}
.recruit-facts__row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-auto-rows: 1fr;
  grid-column-gap: var(--rn-sec-margin-s);
  grid-row-gap: var(--rn-sec-margin-xs);
}
.recruit-facts__col {
  border-radius: 24px;
  padding: 20px var(--rn-sec-margin-xxs);
  text-align: center;
}

.recruit-facts__row[data-color="skyblue"] .recruit-facts__col {
  background-color: var(--skyblue);
}
.recruit-facts__row[data-color="pink"] .recruit-facts__col {
  background-color: var(--pink);
}
.recruit-facts__row[data-color="lightyellow"] .recruit-facts__col {
  background-color: var(--lightyellow);
}

.recruit-facts__img {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.recruit-facts__img {
  max-width: 150px;
  width: 100%;
  margin: 0 auto;
}
.recruit-facts__h3 {
  font-size: 23px;
  white-space: nowrap;
  line-height: 1.3;
  display: flex;
  flex-direction: column;
  align-items: center;
  font-weight: 400;
  margin: 0;
}
.recruit-facts__h3 span {
  font-size: 18px;
}
.recruit-facts__num {
  font-family: "D-DIN", "Noto Sans JP", sans-serif;
  font-size: var(--ttl-font-size);
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.05em;
  margin: 0;
  margin-top: var(--rn-sec-margin-xxs);
  display: flex;
  align-items: baseline;
  justify-content: center;
}
.recruit-facts__num.marign {
  margin-top: var(--rn-sec-margin-s);
}
.recruit-facts__num span {
  font-size: 30px;
}
.recruit-facts__num-prefix {
  order: -1;
  margin-right: 0.2em;
}
@media (max-width: 1023px) {
  .recruit-facts__row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-column-gap: var(--rn-sec-margin-xxs);
    grid-row-gap: var(--rn-sec-margin-xxs);
  }
}
@media (max-width: 767px) {
  .recruit-facts {
    margin-bottom: var(--rn-sec-margin-sm);
  }
  .recruit-facts-sec01,
  .recruit-facts-sec02,
  .recruit-facts-sec03 {
    margin-top: var(--rn-sec-margin-sm);
  }
  .recruit-facts__row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .recruit-facts__h3 {
    font-size: 14px;
  }
  .recruit-facts__h3 span {
    font-size: 11px;
  }
  .recruit-facts__img {
    max-width: 100px;
  }
  .recruit-facts__num span {
    font-size: 14px;
  }
  .recruit-facts__num.marign {
    margin-top: var(--rn-sec-margin-xs);
  }
}

/* ページ内リンク用のスクロール調整 */
.recruit-facts-sec03 {
  scroll-margin-top: var(--rn-header-height);
}

/* 働く環境
---------------------------*/
.work-environment {
  line-height: 2;
}
.work-environment h2 {
  line-height: 2;
  font-weight: 500;
}
.work-environment h3 {
  line-height: 2;
  font-weight: 500;
}

/* ページ内リンク用のスクロール調整 */
.work-environment-sec01,
.work-environment-sec02,
.work-environment-sec03 {
  scroll-margin-top: var(--rn-header-height);
}

/* 働く環境 - 共通ボーダースタイル */
.work-environment-rink-sec,
.work-environment-sec04,
.work-environment-sec05 {
  position: relative;
  border-top: 1px solid var(--gray);
  padding-top: var(--rn-sec-margin-xs);
}
.work-environment-rink-sec::before,
.work-environment-sec04::before,
.work-environment-sec05::before {
  content: "";
  position: absolute;
  top: -1px;
  left: -15px;
  right: -15px;
  border-top: 1px solid var(--gray);
}
.work-environment-rink-sec::after,
.work-environment-sec04::after,
.work-environment-sec05::after {
  content: "";
  position: absolute;
  top: -1px;
  left: -15px;
  right: -15px;
  height: 60px;
  border-left: 1px solid var(--gray);
}

.work-environment-rink-sec {
  margin-top: var(--rn-sec-margin-lg);
}
.work-environment-rink-sec .recruite-rn__h2-s {
  margin-bottom: 2em;
}
.work-environment-rink-sec__h3 {
  color: #000;
  font-size: 16px;
  margin-top: var(--rn-sec-margin-xs);
  margin-bottom: 0;
  text-align: center;
}
h3.work-environment-rink-sec__h3 {
  line-height: 1.5;
  font-weight: 400;
}

.work-environment__row {
  display: flex;
  gap: 4%;
  justify-content: flex-start;
}
.work-environment__col {
  flex: 0 1 160px;
}
.work-environment__col a:hover {
  filter: brightness(105%);
  opacity: 1;
}

.work-environment__flex {
  display: flex;
  align-items: self-end;
  gap: var(--rn-sec-margin-xxs);
  margin-bottom: 2em;
}
.work-environment__img {
  max-width: 64px;
}
.work-environment__h2 {
  font-size: 20px;
  margin-bottom: 0;
}
.work-environment__h3 {
  font-size: 16px;
  font-weight: 400;
  margin-bottom: 0;
}
.work-environment__dl {
  margin-top: var(--rn-sec-margin-sm);
  font-size: 16px;
}
.work-environment__dt {
  font-weight: 500;
}
.work-environment__dt:not(:first-child) {
  margin-top: var(--rn-sec-margin-xs);
}
.work-environment__dd {
  margin: 0;
}

.work-environment-sec01,
.work-environment-sec02,
.work-environment-sec03 {
  margin-top: var(--rn-sec-margin-lg);
}
.work-environment-sec04,
.work-environment-sec05 {
  margin-top: var(--rn-sec-margin-lg);
}
.work-environment-sec01 .work-environment__h2 {
  color: var(--green);
}
.work-environment-sec02 .work-environment__h2 {
  color: var(--coral);
}
.work-environment-sec03 .work-environment__h2 {
  color: var(--orange);
}

.work-environment-sec04 .recruite-rn__h2-s,
.work-environment-sec05 .recruite-rn__h2-s {
  margin-bottom: 2em;
}
.work-environment-sec05__row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-auto-rows: 1fr;
  gap: var(--rn-sec-margin-xs);
}
.work-environment-sec05__col {
  background-color: var(--gray-light);
  border-radius: 16px;
  padding: var(--rn-sec-margin-xs);
}
.work-environment-sec05__h3 {
  font-size: 18px;
  margin: 0;
}
.work-environment-sec05__txt {
  margin: 0;
}
@media (max-width: 1280px) {
  .work-environment-rink-sec::before,
  .work-environment-sec04::before,
  .work-environment-sec05::before {
    left: -10px;
    right: -10px;
  }
  .work-environment-rink-sec::after,
  .work-environment-sec04::after,
  .work-environment-sec05::after {
    left: -10px;
  }
}
@media (max-width: 1023px) {
  .work-environment-sec05__row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (max-width: 767px) {
  .work-environment-rink-sec {
    margin-top: var(--rn-sec-margin-sm);
    padding-top: var(--rn-sec-margin-xxs);
  }
  .work-environment-rink-sec::after {
    height: 36px;
  }
  .work-environment-sec01,
  .work-environment-sec02,
  .work-environment-sec03 {
    margin-top: var(--rn-sec-margin-sm);
  }
  .work-environment-sec04,
  .work-environment-sec05 {
    margin-top: var(--rn-sec-margin-sm);
  }
  .work-environment-sec05__row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--rn-sec-margin-xxs);
    grid-auto-rows: auto;
  }
  .work-environment-sec05__col {
    padding: var(--rn-sec-margin-xsm);
  }
  h3.work-environment-rink-sec__h3 {
    line-height: 1.5 !important;
    font-size: 14px;
  }
}
@media (max-width: 639px) {
  .work-environment-sec05__row {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }
}

/* 採用トップ
---------------------------*/
.recruit-archive {
  line-height: 2;
  padding-bottom: var(--rn-sec-margin-lg);
}
.recruit-archive h2 {
  line-height: 2;
}
.recruit-archive-sec01__h2 {
  text-align: left;
}
.recruit-archive__btn img {
  width: 100%;
}
.recruit-archive-sec02 video {
  vertical-align: bottom;
}
.recruit-archive__item:last-child {
  padding-bottom: 0;
}
@media (max-width: 767px) {
  .recruit-archive {
    padding-bottom: var(--rn-sec-margin-sm);
  }
  .recruit-archive__item:last-child {
    padding-bottom: 0;
  }
}

/* 新卒採用トップ
---------------------------*/
.rn-graduate {
  line-height: 2;
  padding-top: 0;
  padding-bottom: 0;
}
.rn-graduate .recruite-rn-btn-noborder {
  z-index: 1;
}
.work-environment h2 {
  line-height: 2;
}
.work-environment h3 {
  line-height: 2;
}

.rn-graduate-mv__video-wrap {
  position: fixed;
  width: 100%;
  height: calc(100svh - 72px);
  margin-top: 72px;
  z-index: -1;
}
.rn-graduate-mv {
  position: relative;
  height: 100svh;
}

.rn-graduate-mv__video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.rn-graduate-mv__copy {
  position: absolute;
  top: 36%;
  left: 50%;
  transform: translateX(-50%);
  max-width: 1260px;
  width: 100%;
  z-index: 10;
  padding: 0 15px;
}

.rn-graduate-mv__h2 {
  color: #fff;
  font-size: clamp(32px, 5vw, 52px);
  margin: 0;
  line-height: 1.5;
  font-weight: 700;
}
.rn-graduate-mv__txt {
  max-width: 1260px;
  width: 100%;
  margin: auto;
  padding: 0 15px;
  margin-bottom: 100svh;
}

.rn-graduate-mv__txt p {
  color: #fff;
  font-size: 16px;
  margin: 0;
  line-height: 2;
  font-weight: 500;
}
.rn-graduate-mv__txt p:not(:first-child) {
  margin-top: var(--rn-sec-margin-xs);
}

.rn-graduate-sec01 {
  padding: var(--rn-sec-margin-lg) 0;
  background-color: var(--gray-light2);
}
.rn-graduate-sec01__h3 {
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0.1em;
  margin-bottom: 20px;
}
.rn-graduate-sec01__item {
  font-size: 16px;
  line-height: 1.6;
}
.rn-graduate-sec01__item:not(:last-child) {
  margin-bottom: 8px;
}
@media (max-width: 767px) {
  .rn-graduate-mv__video-wrap {
    height: calc(100svh - 60px);
    margin-top: 60px;
  }
  .rn-graduate-sec01 {
    padding: var(--rn-sec-margin-sm) 0;
  }
}

/* カワジュンについて */
.rn-graduate-sec02 {
  padding: var(--rn-sec-margin-lg) 0;
  background-color: var(--lightyellow);
}
.rn-graduate-sec02 .recruite-rn__h2-s {
  margin-bottom: 2em;
}
.rn-graduate-sec02__row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-auto-rows: 1fr;
  gap: var(--rn-sec-margin-xs);
}
.rn-graduate-sec02__link {
  text-decoration: none;
  display: block;
  transition: filter 0.3s ease;
}
.rn-graduate-sec02__link:hover {
  opacity: 1;
  filter: brightness(105%);
}
.rn-graduate-sec02__img {
  position: relative;
  margin: 0;
}
.rn-graduate-sec02__img img {
  width: 100%;
  height: auto;
  display: block;
}
.rn-graduate-sec02__caption {
  position: absolute;
  top: var(--rn-sec-margin-xs);
  left: var(--rn-sec-margin-xs);
  color: #000;
}
.rn-graduate-sec02__h3 {
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0.1em;
  margin: 0;
  line-height: 1.4;
}
.rn-graduate-sec02__h3 span {
  display: block;
  font-size: 14px;
  font-weight: 400;
  margin-top: 4px;
}

@media (max-width: 767px) {
  .rn-graduate-sec02 {
    padding: var(--rn-sec-margin-sm) 0;
  }
  .rn-graduate-sec02__row {
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: var(--rn-sec-margin-xxs);
  }
  .rn-graduate-sec02__caption {
    top: var(--rn-sec-margin-xxs);
    left: var(--rn-sec-margin-xxs);
  }
  .rn-graduate-sec02__h3 {
    font-size: 18px;
  }
  .rn-graduate-sec02__h3 span {
    font-size: 13px;
  }
}

/* 社員ストーリー インタビュー × 仕事紹介 */
.rn-graduate-sec03 {
  padding-top: var(--rn-sec-margin-lg);
  padding-bottom: var(--rn-sec-margin-lg);
  background: var(--skyblue);
}
.rn-graduate-sec03 .recruite-rn__h2-s {
  margin-bottom: 2em;
}
.rn-graduate-sec03__row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-auto-rows: 1fr;
  gap: var(--rn-sec-margin-s);
}

.rn-graduate-sec03__link {
  display: block;
  text-decoration: none;
  color: inherit;
}

/* ▼ 画像ラッパー */
.rn-graduate-sec03__img {
  position: relative;
  overflow: hidden;
  border-radius: 10px;
}

.rn-graduate-sec03__img img {
  width: 100%;
  height: auto;
  display: block;
  transition: transform 0.3s ease;
}

/* ▼ hover時にズーム */
.rn-graduate-sec03__link:hover {
  opacity: 1;
}
.rn-graduate-sec03__link:hover .rn-graduate-sec03__img img {
  transform: scale(1.05);
  filter: brightness(105%);
}

.rn-graduate-sec03__caption {
  margin-top: var(--rn-sec-margin-xsm);
}

.rn-graduate-sec03__h3 {
  font-size: 16px;
  font-weight: 400;
  line-height: 1.4;
  margin: 0;
}
.rn-graduate-sec03__ttl {
  font-size: 18px;
  font-weight: 600;
  line-height: 1.4;
  margin: 0;
  margin-bottom: 10px;
  text-align: center;
}
.rn-graduate-sec03__h3 span {
  display: block;
  line-height: 1.5;
}
.rn-graduate-sec03__ttl-img {
  margin-top: var(--rn-sec-margin-s);
}
@media (max-width: 767px) {
  .rn-graduate-sec03 {
    padding-top: var(--rn-sec-margin-sm);
    padding-bottom: var(--rn-sec-margin-sm);
  }

  .rn-graduate-sec03 .container {
    padding: 0;
  }
  .rn-graduate-sec03 .recruite-rn__h2-s {
    padding: 0 30px;
  }
}

/* SP用スライダー */
.rn-graduate-sec03-slider {
  position: relative;
  background: var(--skyblue);
}
.rn-graduate-sec03-slider .rn-graduate-sec03__col {
  padding: 0 8px;
}
.rn-graduate-sec03-slider .slick-dots {
  bottom: -30px;
  background: var(--skyblue);
}
.rn-graduate-sec03-slider .slick-dots li button:before {
  font-size: 20px;
  color: var(--gray);
}
.rn-graduate-sec03-slider .slick-dots li.slick-active button:before {
  color: #000;
}
.rn-graduate-sec03-slider .slick-arrow {
  width: 32px;
  height: 32px;
  z-index: 10;
}
.rn-graduate-sec03-slider .slick-arrow:before {
  font-size: 20px;
  color: #fff;
}
.rn-graduate-sec03-slider .slick-prev {
  left: 15px;
}
.rn-graduate-sec03-slider .slick-next {
  right: 15px;
}

/* 若手社員のリアル */
/* 社員ストーリー インタビュー × 仕事紹介 */
.rn-graduate-sec04 {
  background: var(--skyblue);
  margin-top: -39px;
  margin-bottom: -39px;
}
.rn-graduate-sec04 .recruite-rn__h2-s {
  margin-bottom: 2em;
}
.rn-graduate-sec04__row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-auto-rows: 1fr;
  gap: var(--rn-sec-margin-xs);
  align-items: center;
}

.rn-graduate-sec04__txt {
  margin-top: 0;
  margin-bottom: var(--rn-sec-margin-xxs);
  line-height: 1.6;
}
.rn-graduate-sec04__btn-wrap {
  margin-top: var(--rn-sec-margin-xs);
}
@media (max-width: 767px) {
  .rn-graduate-sec04 {
    margin-top: 0;
    margin-bottom: 0;
    background: var(--lightyellow);
    padding: var(--rn-sec-margin-sm) 0;
  }
  .rn-graduate-sec04__row {
    display: flex;
    gap: 0;
  }
  .rn-graduate-sec04__img {
    max-width: 560px;
    width: 100%;
    margin-top: var(--rn-sec-margin-xs);
  }
}

.rn-graduate-sec05 {
  padding-top: var(--rn-sec-margin-lg);
  background: var(--skyblue);
}
.rn-graduate-sec05 .recruite-rn__h2-s {
  margin-bottom: 2em;
}
.rn-graduate-sec05__h3 {
  font-size: 18px;
  font-weight: 500;
  margin-top: 0;
  margin-bottom: var(--rn-sec-margin-xxxs);
}
.rn-graduate-sec05__txt {
  margin-top: 0;
  margin-bottom: var(--rn-sec-margin-xxs);
  line-height: 1.6;
}
@media (max-width: 767px) {
  .rn-graduate-sec05 {
    padding: var(--rn-sec-margin-sm) 0;
  }
}

/* カワジュンの仕事・取り組みを知る */
.rn-graduate-sec06 {
  padding-top: var(--rn-sec-margin-lg);
  /* padding-bottom: var(--rn-sec-margin-lg); */
  background: var(--skyblue);
}
.rn-graduate-sec06 .recruite-rn__h2-s {
  margin-bottom: 2em;
}

/* スライダー */
.rn-graduate-slider-wrap {
  position: relative;
}
.rn-graduate-slider {
  position: relative;
}
.rn-graduate-slider__item {
  padding: 0 8px;
}
.rn-graduate-slider__link {
  display: block;
  text-decoration: none;
  color: inherit;
  transition: opacity 0.3s ease;
}
.rn-graduate-slider__link:hover {
  opacity: 0.8;
}

/* 画像エリア */
.rn-graduate-slider__img {
  position: relative;
  margin: 0;
  overflow: hidden;
  background-color: #c5c5c5;
}
.rn-graduate-slider__img img {
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  display: block;
}

/* テキストエリア */
.rn-graduate-slider__body {
  padding: var(--rn-sec-margin-xxs) 0 0;
}
.rn-graduate-slider__h3 {
  font-size: 18px;
  font-weight: 500;
  margin: 0;
  margin-bottom: 8px;
  line-height: 1.5;
}
.rn-graduate-slider__txt {
  font-size: 14px;
  line-height: 1.8;
  margin: 0;
  color: var(--gray);
}

/* VIEW MOREボタン */
.rn-graduate-slider__more {
  display: flex;
  justify-content: flex-end;
}

.rn-graduate-slider .slick-dots {
  bottom: -60px;
}
.rn-graduate-slider .slick-dots li button:before {
  font-size: 20px;
  color: var(--gray);
}
.rn-graduate-slider .slick-dots li.slick-active button:before {
  color: #000;
}
@media (max-width: 767px) {
  .rn-graduate-slider__more {
    padding-top: var(--rn-sec-margin-s);
    justify-content: center;
  }
  .rn-graduate-slider .slick-dots {
    bottom: -50px;
  }
}

@media (max-width: 767px) {
  .rn-graduate-sec06 {
    padding: var(--rn-sec-margin-sm) 0;
    background: var(--lightyellow);
  }
  .rn-graduate-slider__img-ttl {
    font-size: 16px;
  }
  .rn-graduate-slider__h3 {
    font-size: 14px;
  }
  .rn-graduate-slider__txt {
    font-size: 13px;
  }
}

/* ページ内リンク用のスクロール調整（新卒採用ページ） */
#recruit-info,
#about,
#employee-stories,
#young-employee,
#showroom,
#our-work,
#recruitment {
  scroll-margin-top: var(--rn-header-height);
}

/* 採用情報 */
.rn-graduate-sec07 {
  padding-top: var(--rn-sec-margin-lg);
  padding-bottom: var(--rn-sec-margin-lg);
  background: var(--skyblue);
}
.rn-graduate-sec07 .recruite-rn__h2-s {
  margin-bottom: 2em;
}
.rn-graduate-sec07 .recruite-rn-btn-full {
  margin-top: var(--rn-sec-margin-sm);
}
@media (max-width: 767px) {
  .rn-graduate-sec07 {
    padding-top: var(--rn-sec-margin-sm);
    padding-bottom: var(--rn-sec-margin-sm);
  }
  .rn-graduate-sec07 .recruite-rn-btn-full {
    margin-top: var(--rn-sec-margin-s);
    padding: 12px;
  }
}

/* 採用サイトヘッダー */
.custom-recruit-top-page .header {
  background: var(--recruit-beige);
}
.custom-recruit-top-page .contact-menu--recruit > a {
  display: block;
  padding: 4px 32px;
  text-decoration: none;
  border: 1px solid var(--recruit-black);
  line-height: 1.45;
}
.custom-recruit-top-page .header__wrapper {
  background: transparent;
}
@media (max-width: 767px) {
  .custom-recruit-top-page .header__wrapper {
    padding: 15px 15px;
  }
  .custom-recruit-top-page .entry-menu--recruit {
    margin-right: 0;
  }
  .custom-recruit-top-page .entry-menu--recruit > a {
    padding: 4px 12px;
    font-size: 12px;
  }
  .custom-recruit-top-page .contact-menu--recruit > a {
    padding: 4px 12px;
    font-size: 12px;
  }
  .custom-recruit-top-page .header__right--recruit {
    display: flex;
    gap: 8px;
  }
}
.entry-menu--recruit > a {
  padding: 4px 38px;
}

/* ショールーム
---------------------------*/
.rn-showroom {
  line-height: 2;
  padding-top: 0;
}
.rn-showroom-move-sec video {
  height: 100%;
  width: 100%;
  object-fit: cover;
}
@media (min-width: 768px) {
  .rn-showroom-move-sec {
    position: relative;
    height: 100svh;
  }
  .rn-showroom-move-sec video {
    display: block;
    object-position: center bottom;
  }
}
.rn-showroom-sec01 {
  padding-top: var(--rn-sec-margin-lg);
}
.rn-showroom__row {
  display: flex;
  gap: var(--rn-sec-margin-xs);
}
.rn-showroom__col-left {
  flex: 0 1 37%;
  display: flex;
  flex-direction: column;
}
.rn-showroom__col-right {
  width: 63%;
  flex: 0 1 63%;
}
.rn-showroom__h2 {
  font-size: var(--h2-font-size);
  letter-spacing: 0.1em;
  margin-bottom: 0;
  font-weight: 500;
}
.rn-showroom__subttl {
  margin-bottom: 0;
  font-weight: 400;
  font-size: 12px;
  display: block;
  letter-spacing: normal;
  margin-top: 4px;
  line-height: 1.5;
}
.rn-showroom__h3 {
  font-size: 12px;
  font-weight: 400;
  margin-top: 16px;
  margin-bottom: 0;
  line-height: 1.5;
}
.rn-showroom__h3:not(:first-of-type) {
  margin-top: var(--rn-sec-margin-xxs);
}
.rn-showroom__txt {
  font-size: 16px;
  margin-bottom: 0;
  margin-top: var(--rn-sec-margin-xsm);
}
.rn-showroom__btn {
  display: inline-block;
  background-color: #000;
  color: var(--orange);
  font-size: 14px;
  font-weight: 500;
  padding: 8px 24px;
  text-decoration: none;
  margin-top: var(--rn-sec-margin-xs);
  transition: opacity 0.3s ease;
  margin-top: auto;
  width: fit-content;
  min-width: 290px;
  text-align: center;
}
.rn-showroom__btn:hover {
  opacity: 1;
  color: var(--orange);
  filter: brightness(110%);
}

.rn-showroom-sec02,
.rn-showroom-sec03,
.rn-showroom-sec04 {
  padding-top: var(--rn-sec-margin-lg);
}
@media (max-width: 767px) {
  .rn-showroom {
    padding-top: 60px;
  }
  .rn-showroom-sec01 {
    padding-top: var(--rn-sec-margin-sm);
  }
  .rn-showroom__row {
    flex-direction: column;
    gap: var(--rn-sec-margin-xsm);
  }
  .rn-showroom__col-left,
  .rn-showroom__col-right {
    width: 100%;
    max-width: 100%;
    margin: 0;
    padding: 0;
  }
  .rn-showroom__btn {
    width: 100%;
    margin-top: var(--rn-sec-margin-xsm);
  }
  .rn-showroom__txt {
    line-height: 1.6;
  }
  .rn-showroom-sec04 {
    margin-bottom: 30px;
  }
}

/* ショールームスライダー */
.rn-showroom__slider.slick-dotted {
  margin-bottom: 0;
}

.rn-showroom__slider,
.slick-list,
.slick-track {
  height: auto !important;
}
.rn-showroom__slider .slick-dots {
  bottom: -30px;
}
.rn-showroom__slider .slick-dots li button:before {
  font-size: 20px;
  color: var(--gray);
}
.rn-showroom__slider .slick-dots li.slick-active button:before {
  color: #000;
}

/* 新卒採用ヘッダー */
.custom-recruit-page {
  .header {
    background: var(--recruit-beige);
  }
  .header__wrapper {
    background: transparent;
  }
}

/* ========================================
   新卒採用サイト用ヘッダー（recruit配下ページ）
======================================== */
.header--recruit-sub {
  position: relative;
}

.header--recruit-sub .header__right--recruit-sub {
  display: flex;
  align-items: center;
  gap: 8px;
}

.header__right--recruit-sub__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px 16px;
  border: 1px solid #000;
  border-radius: 0;
  background: #000;
  color: #fff;
  text-decoration: none;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.4;
  text-align: center;
  white-space: nowrap;
  transition: all 0.3s ease;
}

.header__right--recruit-sub__btn:hover {
  background: #333;
  color: #fff;
}

/* MY PAGE / ENTRY ボタンのスタイル（PC：横並び） */
.header__right--recruit-sub__btn--mypage {
  font-family: "din-2014", sans-serif;
  font-weight: 700;
  font-style: normal;
}

/* PCでスラッシュを表示 */
.btn-mypage__line {
  display: inline;
}

.btn-mypage__line::before {
  content: "/";
  margin: 0 4px;
}

/* ハンバーガーメニューボタン */
.recruit-menu-btn {
  width: 32px;
  height: 32px;
  background: none;
  border: none;
  cursor: pointer;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: 8px;
  outline: none;
}

.recruit-menu-btn:focus {
  outline: none;
}

.recruit-menu-btn span {
  display: block;
  width: 32px;
  height: 2px;
  background: #000;
  position: relative;
  transition: all 0.3s ease;
}

.recruit-menu-btn span::before,
.recruit-menu-btn span::after {
  content: "";
  display: block;
  width: 32px;
  height: 2px;
  background: #000;
  position: absolute;
  left: 0;
  transition: all 0.3s ease;
}

.recruit-menu-btn span::before {
  top: -8px;
}

.recruit-menu-btn span::after {
  bottom: -8px;
}

/* メニューオープン時のハンバーガーアイコン（×に変化） */
.is-recruit-menu-open .recruit-menu-btn span {
  background: transparent;
}

.is-recruit-menu-open .recruit-menu-btn span::before {
  top: 0;
  transform: rotate(30deg);
}

.is-recruit-menu-open .recruit-menu-btn span::after {
  bottom: 0;
  transform: rotate(-30deg);
}

/* ナビゲーションメニュー */
.recruit-gnav {
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  max-height: calc(100vh - var(--rn-header-height));
  overflow-y: auto;
  background: var(--recruit-beige);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: all 0.3s ease;
  z-index: 100;
  /* border-top: 1px solid #ddd; */
  color: #000;
}

.is-recruit-menu-open .recruit-gnav {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.recruit-gnav__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: var(--rn-sec-margin-lg) 15px;
}

.recruit-gnav__row {
  display: flex;
  gap: 80px;
}

.recruit-gnav__col {
  flex: 1;
}

.recruit-gnav__section {
  margin-bottom: 32px;
  display: flex;
  align-items: flex-start;
  gap: 16px;
}

.recruit-gnav__section:last-child {
  margin-bottom: 0;
}

.recruit-gnav__title {
  font-size: 18px;
  font-weight: 500;
  margin: 0;
  padding-right: 16px;
  white-space: nowrap;
}

/* リストがあるセクションのみボーダーを表示（リスト側に設定） */
.recruit-gnav__section:has(.recruit-gnav__list) .recruit-gnav__title {
  border-right: none;
  max-width: 150px;
  width: 100%;
}

.recruit-gnav__title a {
  color: #000;
  text-decoration: none;
  transition: opacity 0.3s ease;
}

.recruit-gnav__title a:hover {
  opacity: 0.6;
}

.recruit-gnav__title span {
  font-size: 14px;
  font-weight: 400;
  margin-left: 8px;
}

.recruit-gnav__list {
  list-style: none;
  margin: 0;
  padding: 0 0 0 16px;
  border-left: 1px solid #000;
}

.recruit-gnav__list li {
  margin-bottom: 8px;
}

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

.recruit-gnav__list a {
  color: #000;
  text-decoration: none;
  font-size: 15px;
  transition: opacity 0.3s ease;
}

.recruit-gnav__list a:hover {
  opacity: 0.6;
}

.recruit-gnav-ex-icon {
  width: 12px;
  height: 12px;
  margin-left: 4px;
  vertical-align: middle;
}

/* SP対応 */
@media (max-width: 767px) {
  /* スマホ用ロゴ：画像の下にテキスト表示 */
  .header--recruit-sub .header__wrapper__logo a {
    flex-direction: column;
    align-items: flex-start;
  }

  .header--recruit-sub .header__wrapper__logo a img {
    width: 91px;
    height: auto;
  }

  .header--recruit-sub .header__wrapper__logo--recruit {
    margin-top: 4px;
    font-size: 13px;
  }

  /* スマホ用ボタン：丸い形 */
  .header__right--recruit-sub__btn {
    width: 64px;
    height: 64px;
    padding: 0;
    border: none;
    border-radius: 50%;
    font-size: 12px;
  }

  /* MY PAGE / ENTRY ボタン：縦並び */
  .header__right--recruit-sub__btn--mypage {
    flex-direction: column;
    gap: 2px;
  }

  .btn-mypage__top,
  .btn-mypage__bottom {
    font-size: 11px;
    letter-spacing: 0.05em;
  }

  .btn-mypage__line {
    display: block;
    width: 76%;
    height: 1px;
    background: #fff;
  }

  .btn-mypage__line::before {
    content: none;
  }

  .recruit-gnav {
    max-height: calc(100vh - var(--rn-header-height-sp));
  }

  .recruit-gnav__inner {
    padding: var(--rn-sec-margin-sm) 15px;
  }

  .recruit-gnav__row {
    flex-direction: column;
    gap: 0;
  }

  .recruit-gnav__col {
    flex: none;
  }
  .recruit-gnav__col:first-child {
    margin-bottom: var(--rn-sec-margin-xsm);
  }

  .recruit-gnav__section {
    margin-bottom: var(--rn-sec-margin-xsm);
  }

  .recruit-gnav__title {
    font-size: 14px;
    margin-bottom: 8px;
  }

  .recruit-gnav__list a {
    font-size: 13px;
  }
  .header--recruit-sub .header__right--recruit-sub {
    margin-top: 20px;
  }
  .custom-recruit-page .header__wrapper {
    height: 60px;
  }
  .header__right--recruit-sub {
    z-index: 101;
  }
}

@media (max-width: 330px) {
  .header__right--recruit-sub__btn {
    width: 54px;
    height: 54px;
    font-size: 9px;
  }

  .btn-mypage__top,
  .btn-mypage__bottom {
    font-size: 8px;
  }

  .recruit-menu-btn {
    width: 28px;
    height: 28px;
    margin-left: 4px;
  }

  .recruit-menu-btn span,
  .recruit-menu-btn span::before,
  .recruit-menu-btn span::after {
    width: 20px;
  }
}

/* =============================================
   Recruit Sub-Footer
============================================= */
.sub-footer--recruit {
  background-color: var(--recruit-beige);
  padding: 60px 0 40px;
}

.sub-footer--recruit .container {
  max-width: 1260px;
  width: 100%;
  margin: 0 auto;
  padding: 0 15px;
}

.sub-footer--recruit .sub-footer__row {
  display: flex;
  /* flex-wrap: wrap; */
  justify-content: space-between;
  gap: 40px;
}

/* ロゴエリア */
.sub-footer--recruit .sub-footer__col--logo {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-width: 180px;
}

.sub-footer--recruit .logo_wrapper {
  margin-bottom: var(--rn-sec-margin-xsm);
}

.sub-footer--recruit .sub-footer__logo {
  width: 140px;
  height: auto;
  margin-bottom: 8px;
}

.sub-footer--recruit .sub-footer__site-name {
  font-size: 13px;
  color: #000;
  margin: 0;
  letter-spacing: 0.05em;
  font-weight: 500;
}

.sub-footer--recruit .sub-footer__logo-photo {
  width: 160px;
  height: auto;
}

/* ナビゲーションエリア */
.sub-footer--recruit .sub-footer__col--nav {
  flex: 1;
  min-width: 240px;
  max-width: 320px;
}

.sub-footer--recruit .sub-footer__title {
  font-size: 16px;
  font-weight: 500;
  color: #000;
  margin: 0 0 20px;
  letter-spacing: 0.05em;
}

.sub-footer--recruit .sub-footer__nav-group {
  margin-bottom: 20px;
  line-height: 1.2;
}

.sub-footer--recruit .sub-footer__nav-group:last-child {
  margin-bottom: 0;
}

/* ボーダー付きナビアイテム */
.sub-footer--recruit .sub-footer__nav-item--with-border {
  display: flex;
  align-items: stretch;
  gap: 16px;
}

.sub-footer--recruit .sub-footer__nav-label {
  font-size: 14px;
  font-weight: 500;
  color: #000;
  white-space: nowrap;
  padding-right: 16px;
  border-right: 1px solid #000;
  line-height: 1.8;
  display: flex;
  align-items: flex-start;
  max-width: 150px;
  width: 100%;
}
@media (min-width: 768px) {
  .sub-footer--recruit .sub-footer__nav-label.recruit {
    width: fit-content;
  }
  .sub-footer--recruit .sub-footer__nav-item--with-border.recruit {
    margin-bottom: 54px;
  }
}

.sub-footer--recruit .sub-footer__nav-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.sub-footer--recruit .sub-footer__nav-list li a {
  font-size: 13px;
  color: #000;
  text-decoration: none;
  transition: opacity 0.3s ease;
  line-height: 1.8;
}

.sub-footer--recruit .sub-footer__nav-list li a:hover {
  opacity: 0.7;
}

/* ナビリンク */
.sub-footer--recruit .sub-footer__nav-link {
  font-size: 14px;
  font-weight: 500;
  color: #000;
  text-decoration: none;
  transition: opacity 0.3s ease;
  display: inline-block;
}

.sub-footer--recruit .sub-footer__nav-link:hover {
  opacity: 0.7;
}

.sub-footer--recruit .sub-footer__nav-link--title {
  font-size: 16px;
  font-weight: 500;
  line-height: 1.2;
  /* margin-bottom: 16px; */
}

.sub-footer--recruit .sub-footer__nav-sub {
  font-size: 12px;
  color: #000;
  margin-left: 8px;
}

/* 外部リンクアイコン */
.sub-footer--recruit .sub-footer__nav-link--external {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.sub-footer--recruit .sub-footer__icon-external {
  display: inline-block;
  width: 14px;
  height: 14px;
}

/* CORPORATE SITEリンク内のロゴ */
.sub-footer--recruit .sub-footer__nav-link--corporate {
  align-items: center;
  font-weight: 700;
}

.sub-footer--recruit .sub-footer__corporate-logo {
  height: 13px;
  width: auto;
  vertical-align: middle;
}

/* Recruit Footer */
.footer--recruit {
  display: block;
  background-color: var(--recruit-beige);
  padding: 0;
}

.footer--recruit .footer__wrap {
  max-width: 1260px;
  width: 100%;
  margin: 0 auto;
  padding: 18px 15px;
}

.footer--recruit .footer__wrap > div {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.footer--recruit .footer__wrap__nav__ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.footer--recruit .footer__wrap__nav__ul__li {
  display: inline-block;
  font-size: 12px;
  position: relative;
  padding-left: 14px;
}

.footer--recruit .footer__wrap__nav__ul__li:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  margin: auto;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4.5px 0 4.5px 4px;
  border-color: transparent transparent transparent #000;
}

.footer--recruit .footer__wrap__nav__ul__li a {
  font-size: 12px;
  color: #000;
  text-decoration: none;
  transition: opacity 0.3s ease;
}

.footer--recruit .footer__wrap__nav__ul__li a:hover {
  opacity: 0.7;
}

.footer--recruit .footer__copyright {
  font-size: 12px;
  color: #000;
}

.footer--recruit .footer__copyright p {
  margin: 0;
}
.sub-footer__nav-list li {
  margin-bottom: 8px !important;
}

/* レスポンシブ */
@media (max-width: 991px) {
  .sub-footer--recruit .sub-footer__row {
    flex-direction: column;
    gap: 32px;
  }

  .sub-footer--recruit .sub-footer__col--nav {
    max-width: 100%;
  }

  .sub-footer--recruit .sub-footer__col--logo {
    flex-direction: row;
    align-items: flex-end;
    gap: 24px;
  }

  .sub-footer--recruit .logo_wrapper {
    margin-bottom: 0;
    display: flex;
    align-items: flex-end;
    gap: 8px;
  }
  .sub-footer--recruit .sub-footer__site-name {
    white-space: nowrap;
    line-height: 1;
  }
  .logo_wrapper__logo-img {
    display: none;
  }
}

@media (max-width: 767px) {
  .footer--recruit .footer__wrap__nav__ul {
    flex-direction: column;
  }
  .footer--recruit li.footer__wrap__nav__ul__li {
    margin: 0;
  }
  .sub-footer--recruit {
    padding: 0;
    padding-top: var(--rn-sec-margin-sm);
  }

  .sub-footer--recruit .sub-footer__row {
    flex-direction: column;
    gap: 16px;
  }
  .sub-footer--recruit .sub-footer__nav-link--title {
    font-size: 14px;
  }
  .sub-footer--recruit .sub-footer__col--logo {
    flex-direction: column;
    align-items: flex-start;
  }

  .sub-footer--recruit .sub-footer__col--nav {
    max-width: 100%;
    min-width: auto;
  }

  .sub-footer--recruit .sub-footer__title {
    margin-top: var(--rn-sec-margin-xsm);
    font-size: 14px;
  }
  .sub-footer--recruit .sub-footer__nav-link--title {
    margin-bottom: 0;
  }

  .sub-footer--recruit .sub-footer__nav-group {
    margin-bottom: 16px;
  }

  .sub-footer--recruit .sub-footer__nav-group:last-child {
    margin-bottom: 0;
  }

  .sub-footer--recruit .sub-footer__nav-item--with-border {
    flex-direction: row;
    gap: 16px;
    align-items: stretch;
  }

  .sub-footer--recruit .sub-footer__nav-label {
    border-right: 1px solid #000;
    border-bottom: none;
    padding-right: 16px;
    padding-bottom: 0;
  }

  .sub-footer--recruit .sub-footer__logo-photo {
    display: block;
    margin-top: var(--rn-sec-margin-xsm);
  }

  /* SP用ポリシーリスト */
  .sub-footer__nav-group--policy {
    margin-top: 8px;
  }

  .sub-footer__policy-list {
    list-style: none;
    margin: 0;
    padding: 0;
  }

  .sub-footer__policy-list li {
    margin-bottom: 8px;
  }

  .sub-footer__policy-list li a {
    font-size: 14px;
    color: #000;
    text-decoration: none;
    transition: opacity 0.3s ease;
  }

  .sub-footer__policy-list li a::before {
    content: ">";
    margin-right: 4px;
  }

  .sub-footer__policy-list li a:hover {
    opacity: 0.7;
  }

  /* SP用footer */
  .footer--recruit {
    padding-top: var(--rn-sec-margin-xsm);
    padding-bottom: var(--rn-sec-margin-sm);
  }

  .footer--recruit .footer__wrap {
    display: block;
    padding: 0 15px;
  }

  .footer--recruit .footer__wrap > div {
    display: none;
  }

  .footer--recruit .sub-footer__logo-photo {
    display: block;
    max-width: 100px;
    margin-top: var(--rn-sec-margin-xsm);
  }

  .footer--recruit .footer__copyright {
    text-align: left;
    margin-top: var(--rn-sec-margin-xsm);
  }
}

/* =============================================
   社員ストーリー 01
============================================= */
.employee-stories {
  padding-bottom: 0;
}
.employee-stories-sec01 {
  margin-top: var(--rn-sec-margin-lg);
}
.employee-stories-sec01__h1 {
  margin-top: var(--rn-sec-margin-xs);
  font-weight: 500;
  font-size: 26px;
  margin-bottom: 0;
  line-height: 1.5;
}
.employee-stories-sec01__txt {
  margin-top: var(--rn-sec-margin-xs);
  font-weight: 400;
  font-size: 16px;
  margin-bottom: 0;
  line-height: 1.6;
}

.employee-stories-sec02 {
  margin-top: var(--rn-sec-margin-lg);
}

.employee-stories-sec02__ttl {
  position: relative;
  z-index: 0;
}

.employee-stories-sec02__ttl::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: -16px;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 996px;
  height: 80px;
  background: url(../images/page/recruit/employee-stories/icons/icon-slash.webp)
    no-repeat center / cover;
  z-index: -1;
}

.employee-stories-sec02__row {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: var(--rn-sec-margin-xxs);
}
.employee-stories-sec02__col {
  grid-column: span 9;
}

.employee-stories-sec02__meta {
  margin-top: var(--rn-sec-margin-s);
}
.employee-stories-sec02__meta-entry {
  font-size: 16px;
  line-height: 1.5;
  font-weight: 400;
}
.employee-stories-sec02__name {
  font-size: 24px;
  margin: 0;
  margin-top: 8px;
  font-weight: 500;
}
.employee-stories-sec02__name span {
  font-size: 16px;
}
.employee-stories-sec03 {
  margin-top: var(--rn-sec-margin-lg);
}

.employee-stories-sec03__text {
  font-size: 16px;
  margin: 0;
  margin-top: var(--rn-sec-margin-s);
  line-height: 1.6;
}

.employee-stories-sec04 {
  margin-top: var(--rn-sec-margin-lg);
}
.employee-stories-sec04__row {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: var(--rn-sec-margin-xxs);
  margin-top: var(--rn-sec-margin-md);
}
.employee-stories-sec04__col-2 {
  grid-column: span 2;
}
.employee-stories-sec04__col-7 {
  grid-column: span 7;
}
.employee-stories-sec04__clock-img {
  width: 100px;
}
.employee-stories-sec04__time {
  font-family: "Roboto", sans-serif;
  font-size: 20px;
  font-weight: 500;
  line-height: 1;
  margin: 0;
}
.employee-stories-sec04__event {
  font-size: 20px;
  font-weight: 500;
  margin: 0;
  margin-top: 6px;
}
.employee-stories-sec04__description {
  margin: 0;
  margin-top: 6px;
}
.employee-stories-sec04__img {
  margin-top: var(--rn-sec-margin-s);
}

.employee-stories-sec05 {
  margin-top: var(--rn-sec-margin-lg);
}
.employee-stories-sec05__row {
  margin-top: var(--rn-sec-margin-md);
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-column-gap: var(--rn-sec-margin-xxs);
  grid-row-gap: var(--rn-sec-margin-ms);
}
.employee-stories-sec05__col {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.employee-stories-sec05__h3 {
  font-size: 20px;
  font-weight: 500;
  margin: 0;
}
.employee-stories-sec05__img {
  margin-top: var(--rn-sec-margin-xxs);
  max-width: 220px;
  width: 70%;
}
.employee-stories-sec05__h4 {
  font-size: 16px;
  margin: 0;
  margin-top: var(--rn-sec-margin-xxs);
  text-align: center;
  line-height: 1.5;
}
.employee-stories-sec06 {
  margin-top: var(--rn-sec-margin-lg);
  margin-bottom: var(--rn-sec-margin-lg);
}
.employee-stories-sec06__h3 {
  font-size: 20px;
  letter-spacing: 0.1em;
  font-weight: 500;
  margin-bottom: 24px;
}
.employee-stories-sec06__row {
  margin-top: var(--rn-sec-margin-ms);
}
.employee-stories-sec06__row:first-child {
  margin-top: var(--rn-sec-margin-md);
}
.employee-stories-sec06__body {
  position: relative;
  border: 1px solid var(--orange-dark);
  border-radius: 10px;
  display: inline-block;
}
.employee-stories-sec06__bubble {
  position: absolute;
  top: 1px;
  left: 36px;
  width: 20px;
  transform: translateY(-100%);
}
.employee-stories-sec06__txt {
  margin: 0;
  padding: 14px 1em;
  font-size: 19px;
  color: var(--orange-dark);
}

@media (max-width: 1024px) {
  .employee-stories-sec02__ttl::before {
    width: 100%;
    height: 56px;
  }
}
@media (max-width: 767px) {
  .employee-stories-sec01 {
    margin-top: var(--rn-sec-margin-sm);
  }
  .employee-stories-sec02 {
    margin-top: var(--rn-sec-margin-sm);
  }
  .employee-stories-sec02__col {
    grid-column: span 12;
  }
  .employee-stories-sec02__ttl::before {
    content: none;
  }
  .employee-stories-sec02__ttl {
    margin-top: var(--rn-sec-margin-s);
  }
  .employee-stories-sec02__meta {
    margin-top: var(--rn-sec-margin-xsm);
  }
  .employee-stories-sec02__meta-entry {
    font-size: 15px;
  }
  .employee-stories-sec02__name {
    font-size: 20px;
  }
  .employee-stories-sec03 {
    margin-top: var(--rn-sec-margin-sm);
  }
  .employee-stories-sec04 {
    margin-top: var(--rn-sec-margin-sm);
  }

  .employee-stories-sec04__row {
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: var(--rn-sec-margin-xxs);
    margin-top: var(--rn-sec-margin-sm);
  }
  .employee-stories-sec04__col-2 {
    grid-column: span 1;
  }
  .employee-stories-sec04__col-7 {
    grid-column: span 4;
  }
  .employee-stories-sec04__clock-img {
    width: auto;
  }
  .employee-stories-sec04__time {
    font-size: 17px;
  }
  .employee-stories-sec04__event {
    font-size: 17px;
  }
  .employee-stories-sec05 {
    margin-top: var(--rn-sec-margin-sm);
  }
  .employee-stories-sec05__row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-row-gap: var(--rn-sec-margin-sm);
  }
  .employee-stories-sec05__h3 {
    font-size: 17px;
  }
  .employee-stories-sec05__h4 {
    font-size: 14px;
  }
  .employee-stories-sec05__img {
    margin-top: var(--rn-sec-margin-xxxs);
    width: 60%;
  }
  .employee-stories-sec06 {
    margin-top: var(--rn-sec-margin-sm);
    margin-bottom: var(--rn-sec-margin-sm);
  }
  .employee-stories-sec06__row {
    margin-top: var(--rn-sec-margin-s);
  }
  .employee-stories-sec06__h3 {
    font-size: 17px;
  }
  .employee-stories-sec06__txt {
    font-size: 16px;
  }
}

/*  employee-stories__box
 - 共通ボーダースタイル */
.employee-stories__box {
  position: relative;
  border-top: 1px solid var(--gray);
  padding-top: var(--rn-sec-margin-xs);
}
.employee-stories__box::before {
  content: "";
  position: absolute;
  top: -1px;
  left: -15px;
  right: -15px;
  border-top: 1px solid var(--gray);
}
.employee-stories__box::after {
  content: "";
  position: absolute;
  top: -1px;
  left: -15px;
  right: -15px;
  height: 60px;
  border-left: 1px solid var(--gray);
}

@media (max-width: 1280px) {
  .employee-stories__box::before {
    left: -10px;
    right: -10px;
  }
  .employee-stories__box::after {
    left: -10px;
  }
}

@media (max-width: 767px) {
  .employee-stories__box {
    padding-top: var(--rn-sec-margin-xxs);
  }
  .employee-stories__box::after {
    height: 36px;
  }
}

/* 採用サイト調整 */
.recruit-archive__button:first-of-type span {
  max-width: 193px;
}
.recruit-archive__button:nth-last-of-type(2) span {
  letter-spacing: 0.93em;
}
.recruit-archive__button:first-of-type span {
  letter-spacing: 0.25em;
}
@media (max-width: 767px) {
  .recruit-archive__button:first-of-type span {
    max-width: 146px;
  }
  .recruit-archive__button:nth-last-of-type(2) span {
    letter-spacing: 0.79em;
  }
}
