@charset "UTF-8";
/*-----------------------------------------

※このスタイルシートはSCSSで生成されています。
cssへの直記入はなさらないようにしてください。

-----------------------------------------*/
/* 変数の定義
--------------------------------------------------*/
/*-----------------------------------------

※このスタイルシートはSCSSで生成されています。
cssへの直記入はなさらないようにしてください。

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

※このスタイルシートはSCSSで生成されています。
cssへの直記入はなさらないようにしてください。

-----------------------------------------*/
/* 色の定義
--------------------------------------------------*/
/* フォントの定義
--------------------------------------------------*/
html,
body,
ul,
ol,
dl,
li,
dt,
dd,
a,
p,
div,
img,
svg,
table,
tr,
th,
td,
figure {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1.6;
  color: #1C1C1C;
  font-feature-settings: "palt";
}

body,
ul,
ol,
dl,
li,
dt,
dd,
p,
div,
img,
svg,
a,
table,
tr,
th,
td,
figure {
  font-size: 1.6rem;
}
@media screen and (max-width: 768px) {
  body,
  ul,
  ol,
  dl,
  li,
  dt,
  dd,
  p,
  div,
  img,
  svg,
  a,
  table,
  tr,
  th,
  td,
  figure {
    font-size: 1.4rem;
  }
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  letter-spacing: 0.04em;
  line-height: 1.5;
  font-weight: 800;
  font-feature-settings: "palt";
}

.en {
  font-family: "Inter Tight", sans-serif;
  font-style: italic;
  letter-spacing: 0;
  line-height: 1;
  font-weight: 700;
  display: inline-block;
}

/* 社員インタビュー一覧
--------------------------------------------------*/
#interview {
  padding: 100px 0 120px;
}
#interview p, #interview span, #interview div {
  overflow-wrap: anywhere;
}
@media screen and (max-width: 999px) {
  #interview {
    padding: 60px 0 80px;
  }
}
#interview .interview_list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 30px;
}
@media screen and (max-width: 999px) {
  #interview .interview_list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media screen and (max-width: 768px) {
  #interview .interview_list {
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: 20px;
  }
}

/* 社員インタビュー詳細：プロフィールカード（Figma: Frame 1410 / node 26319:1945）
--------------------------------------------------*/
#interview_profile {
  padding: 80px 0;
}
@media screen and (max-width: 999px) {
  #interview_profile {
    padding: 60px 0;
  }
}
#interview_profile .interview_profile_frame {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: clamp(20px, 3vw, 50px);
  width: 100%;
  padding: 40px;
  background-color: #fff;
  border-radius: 8px;
}
@media screen and (max-width: 999px) {
  #interview_profile .interview_profile_frame {
    flex-direction: column;
    align-items: stretch;
    gap: 25px;
    padding: clamp(20px, 4vw, 32px);
  }
}
#interview_profile .interview_profile_media {
  flex-shrink: 0;
  width: 42%;
  max-width: 420px;
  aspect-ratio: 420/260;
  border-radius: 10px;
  overflow: hidden;
}
#interview_profile .interview_profile_media img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 999px) {
  #interview_profile .interview_profile_media {
    width: 100%;
    max-width: 100%;
  }
}
#interview_profile .interview_profile_body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
@media screen and (max-width: 999px) {
  #interview_profile .interview_profile_body {
    gap: 15px;
  }
}
#interview_profile .interview_profile_top {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}
#interview_profile .cat_class {
  display: inline-block;
  flex-shrink: 0;
  border: 1px solid #1C1C1C;
  padding: 0 10px;
  font-weight: 500;
}
#interview_profile .meta_line {
  font-size: 1.8rem;
  font-weight: 500;
}
@media screen and (max-width: 999px) {
  #interview_profile .meta_line {
    font-size: 1.6rem;
  }
}
#interview_profile .interview_profile_ttl {
  font-size: clamp(2.4rem, 2.4vw, 3.2rem);
  color: #CE1B21;
  overflow-wrap: anywhere;
}

/* インタビュー詳細：左 sticky（プロフィール＋ナビ）／右 本文
--------------------------------------------------*/
#interview_detail {
  background-color: #fff;
}
#interview_detail p, #interview_detail span, #interview_detail div {
  overflow-wrap: anywhere;
}
#interview_detail .interview_detail_sheet {
  background-color: #fff;
  border-radius: 8px;
  box-sizing: border-box;
}
#interview_detail .interview_detail_panel {
  display: grid;
  grid-template-columns: minmax(0, 360px) minmax(0, 1fr);
  /* start だと左カラムが本文より低くなり、sticky の親ごとスクロールで流れる */
  align-items: stretch;
  box-sizing: border-box;
}
@media screen and (max-width: 999px) {
  #interview_detail .interview_detail_panel {
    grid-template-columns: 1fr;
  }
}
#interview_detail .interview_detail_sidebar {
  display: flex;
  flex-direction: column;
  border-right: 1px solid #DFDFDF;
  align-self: stretch;
  min-height: 0;
}
@media screen and (max-width: 999px) {
  #interview_detail .interview_detail_sidebar {
    display: block;
    border-right: none;
    border-bottom: 1px solid #DFDFDF;
  }
}
#interview_detail .interview_detail_sticky {
  position: sticky;
  top: 110px;
  align-self: flex-start;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  gap: 40px;
  padding: 60px 0 100px;
}
@media screen and (max-width: 999px) {
  #interview_detail .interview_detail_sticky {
    position: static;
    top: auto;
    padding-top: clamp(20px, 5vw, 32px);
    padding-bottom: 32px;
  }
}
#interview_detail .interview_profile_card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 0 40px 40px 0;
  border-bottom: 1px solid #DFDFDF;
}
@media screen and (max-width: 999px) {
  #interview_detail .interview_profile_card {
    padding: 0 0 32px;
  }
}
#interview_detail .interview_profile_meta {
  display: flex;
  flex-direction: column;
  gap: 6px;
  align-items: flex-start;
}
#interview_detail .interview_profile_meta .cat_class {
  display: inline-block;
  border: 1px solid #1C1C1C;
  padding: 0 10px;
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.04em;
  color: #1C1C1C;
}
#interview_detail .interview_profile_meta .meta_line {
  font-size: 1.4rem;
  font-weight: 500;
}
#interview_detail .interview_profile_ttl {
  font-size: 2rem;
  color: #CE1B21;
}
#interview_detail .interview_nav {
  padding-right: 40px;
}
@media screen and (max-width: 999px) {
  #interview_detail .interview_nav {
    padding: 0;
  }
}
#interview_detail .interview_nav_list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 15px;
}
#interview_detail .interview_nav_list li {
  margin: 0;
}
#interview_detail .interview_nav_list a {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0.04em;
  color: #888484;
  text-decoration: none;
  box-sizing: border-box;
  transition: color 0.2s ease;
}
#interview_detail .interview_nav_list a:hover {
  color: #CE1B21;
}
#interview_detail .interview_nav_list a:hover .interview_nav_num,
#interview_detail .interview_nav_list a:hover .interview_nav_txt {
  color: #CE1B21;
}
#interview_detail .interview_nav_list .interview_nav_num {
  flex-shrink: 0;
  min-width: 2.2ch;
  font-family: "Inter", sans-serif;
  font-weight: 700;
  font-size: 1.4rem;
  line-height: 1.6;
  letter-spacing: 0;
  color: #888484;
}
#interview_detail .interview_nav_list .interview_nav_txt {
  flex: 1;
  min-width: 0;
  position: relative;
  padding-left: 13px;
}
#interview_detail .interview_nav_list .interview_nav_txt::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.7em;
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background-color: #CE1B21;
  opacity: 0;
}
#interview_detail .interview_nav_list li.is-current a {
  color: #CE1B21;
}
#interview_detail .interview_nav_list li.is-current a .interview_nav_num,
#interview_detail .interview_nav_list li.is-current a .interview_nav_txt {
  color: #CE1B21;
}
#interview_detail .interview_nav_list li.is-current a .interview_nav_num::before,
#interview_detail .interview_nav_list li.is-current a .interview_nav_txt::before {
  opacity: 1;
}
#interview_detail .interview_detail_main {
  background-color: #fff;
  min-width: 0;
}
#interview_detail .interview_detail_body {
  padding: 60px 0 100px clamp(40px, 5.71vw, 80px);
}
@media screen and (max-width: 999px) {
  #interview_detail .interview_detail_body {
    padding: 60px 0;
  }
}
#interview_detail .interview_detail_kv {
  margin: 0 0 48px;
  border-radius: 8px;
  overflow: hidden;
}
#interview_detail .interview_detail_kv img {
  display: block;
  width: 100%;
  height: auto;
}
@media screen and (max-width: 999px) {
  #interview_detail .interview_detail_kv {
    margin-bottom: 40px;
    border-radius: 6px;
  }
}
#interview_detail .interview_q_block {
  /* ナビクリック時：右カラムの見出しがビューポート上端から 110px(sticky)+60px で止まる */
  scroll-margin-top: 170px;
}
#interview_detail {
  /* + だと article 間の改行・空白テキストや HTML コメントで隣接にならず未マッチになるため ~ を使う */
}
#interview_detail .interview_detail_body > .interview_q_block ~ .interview_q_block {
  margin-top: 70px;
}
@media screen and (max-width: 999px) {
  #interview_detail .interview_detail_body > .interview_q_block ~ .interview_q_block {
    margin-top: 50px;
  }
}
#interview_detail .interview_q_ttl {
  display: flex;
  align-items: baseline;
  gap: 15px;
  padding-bottom: 20px;
  margin-bottom: 30px;
  border-bottom: 1px solid #DFDFDF;
}
@media screen and (max-width: 999px) {
  #interview_detail .interview_q_ttl {
    padding-bottom: 15px;
    margin-bottom: 20px;
  }
}
#interview_detail .interview_q_num {
  flex-shrink: 0;
  font-size: clamp(2.4rem, 2.4vw, 3.2rem);
  font-weight: 800;
}
@media screen and (max-width: 999px) {
  #interview_detail .interview_q_num {
    font-size: 2rem;
  }
}
#interview_detail .interview_q_txt {
  flex: 1;
  font-size: clamp(2.4rem, 2.4vw, 3.2rem);
  font-weight: 700;
  line-height: 1.4;
}
@media screen and (max-width: 999px) {
  #interview_detail .interview_q_txt {
    font-size: 2rem;
  }
}
#interview_detail .interview_q_img {
  margin-top: 30px;
  border-radius: 8px;
  overflow: hidden;
  aspect-ratio: 760/500;
}
@media screen and (max-width: 999px) {
  #interview_detail .interview_q_img {
    margin-top: 20px;
  }
}
#interview_detail .interview_q_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
#interview_detail {
  /* 1日の仕事の流れ（可変件数 → JS で前半／後半の2列に分割） */
}
#interview_detail .interview_q_block--day_schedule .interview_day_schedule {
  border-radius: 8px;
  background-color: #EDEDED;
  padding: 15px;
}
@media screen and (max-width: 768px) {
  #interview_detail .interview_q_block--day_schedule .interview_day_schedule {
    padding: 10px;
  }
}
#interview_detail .interview_q_block--day_schedule .interview_day_schedule_head {
  padding: 5px 10px;
  text-align: center;
  font-size: clamp(2rem, 2vw, 2.4rem);
  color: #fff;
  background-color: #717171;
}
#interview_detail .interview_q_block--day_schedule .interview_day_schedule_body {
  padding: 30px;
}
@media screen and (max-width: 768px) {
  #interview_detail .interview_q_block--day_schedule .interview_day_schedule_body {
    padding: 20px 10px;
  }
}
#interview_detail .interview_q_block--day_schedule .interview_day_schedule_cols {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px 40px;
  align-items: start;
}
@media screen and (max-width: 999px) {
  #interview_detail .interview_q_block--day_schedule .interview_day_schedule_cols {
    grid-template-columns: 1fr;
    gap: 15px;
    /* 一列表示で2ブロックに分かれているとき、縦線を区切りなく一本に */
  }
  #interview_detail .interview_q_block--day_schedule .interview_day_schedule_cols:has(> .interview_day_schedule_col:nth-child(2)) {
    position: relative;
  }
  #interview_detail .interview_q_block--day_schedule .interview_day_schedule_cols:has(> .interview_day_schedule_col:nth-child(2))::before {
    content: "";
    position: absolute;
    left: 10px;
    top: 0.9rem;
    bottom: 0.9rem;
    width: 1px;
    background-color: #CE1B21;
    border-radius: 1px;
    transform: translateX(-50%);
    z-index: 0;
  }
  #interview_detail .interview_q_block--day_schedule .interview_day_schedule_cols:has(> .interview_day_schedule_col:nth-child(2)) .interview_day_schedule_list::before {
    display: none;
  }
}
#interview_detail .interview_q_block--day_schedule .interview_day_schedule_col {
  min-width: 0;
}
#interview_detail .interview_q_block--day_schedule {
  /* 赤線の中心 = ●の中心（リスト左端から 10px）。●は時間の疑似要素（数字に対して縦中央） */
}
#interview_detail .interview_q_block--day_schedule .interview_day_schedule_list {
  list-style: none;
  margin: 0;
  padding: 0;
  position: relative;
}
#interview_detail .interview_q_block--day_schedule .interview_day_schedule_list::before {
  content: "";
  position: absolute;
  /* 太さが変わっても中心は $day-schedule-cx に一致（calc の端数より translate の方が安定） */
  left: 10px;
  top: 0.9rem;
  bottom: 0.9rem;
  width: 1px;
  background-color: #CE1B21;
  border-radius: 1px;
  transform: translateX(-50%);
}
#interview_detail .interview_q_block--day_schedule {
  /* PC・2列分割時：左列の線は下を少しはみ出し／右列の線は上を少しはみ出し（右列の下端ははみ出さない） */
}
@media screen and (min-width: 1000px) {
  #interview_detail .interview_q_block--day_schedule .interview_day_schedule_cols:has(> .interview_day_schedule_col:nth-child(2)) .interview_day_schedule_col:nth-child(1) .interview_day_schedule_list::before {
    bottom: -6px;
  }
  #interview_detail .interview_q_block--day_schedule .interview_day_schedule_cols:has(> .interview_day_schedule_col:nth-child(2)) .interview_day_schedule_col:nth-child(2) .interview_day_schedule_list::before {
    top: -6px;
    bottom: calc(0.5em + 4px);
  }
}
#interview_detail .interview_q_block--day_schedule .interview_day_schedule_list li {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 6px 10px;
  margin-bottom: 20px;
  padding-left: 22px;
}
#interview_detail .interview_q_block--day_schedule .interview_day_schedule_list li:last-child {
  margin-bottom: 0;
}
@media screen and (max-width: 768px) {
  #interview_detail .interview_q_block--day_schedule .interview_day_schedule_list li {
    margin-bottom: 15px;
  }
}
#interview_detail .interview_q_block--day_schedule .interview_day_schedule_time {
  position: relative;
  flex: 0 0 60px;
  max-width: 60px;
  line-height: 1.5;
  color: #CE1B21;
}
@media screen and (max-width: 768px) {
  #interview_detail .interview_q_block--day_schedule .interview_day_schedule_time {
    flex: 0 0 50px;
  }
}
#interview_detail .interview_q_block--day_schedule .interview_day_schedule_time::before {
  content: "";
  position: absolute;
  /* 丸の中心 = 線の中心（リスト左から $day-schedule-cx）／時間ボックス基準の X */
  left: calc(10px - 22px);
  top: 50%;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background-color: #CE1B21;
  transform: translate(-50%, -50%);
  z-index: 1;
}
#interview_detail .interview_q_block--day_schedule .interview_day_schedule_txt {
  flex: 1;
  min-width: 0;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.04em;
  color: #1C1C1C;
}
@media screen and (max-width: 768px) {
  #interview_detail .interview_q_block--day_schedule .interview_day_schedule_txt {
    font-size: 1.4rem;
  }
}

/* その他の社員紹介
--------------------------------------------------*/
#other_interview {
  padding: 100px 0 120px;
  overflow: hidden;
}
@media screen and (max-width: 999px) {
  #other_interview {
    padding: 60px 0 80px;
  }
}
#other_interview .wrap_sec_ttl {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: clamp(15px, 3vw, 30px);
}
#other_interview .wrap_sec_ttl .sec_sub__ttl {
  margin-bottom: 0;
}
@media screen and (max-width: 999px) {
  #other_interview .lg_btn {
    margin: 30px auto 0;
  }
}/*# sourceMappingURL=interview.css.map */