/* ============================================================
   従業員インタビュー ページ専用スタイル
   すべて .interview-page 配下にスコープし、他ページへ影響しないようにする
   （components.css / recruit.css のクラスとは衝突しない）

   サイズは可能な限り clamp()/rem/% を用いた可変値にして、
   1つのブレークポイントに頼らず滑らかにレスポンシブ対応する。
   （1px のヘアラインのみ意図的に px のまま）
   ============================================================ */

/* フォントはサイト共通（--c-font）を継承し、他ページと統一する */
.interview-page{background:#EEF3FA}
.interview-page *{box-sizing:border-box}

.interview-page .interviews{max-width:50rem;margin:0 auto;padding:clamp(2rem,6vw,3.75rem) clamp(1rem,4vw,1.25rem) clamp(2.5rem,7vw,5rem)}
.interview-page .interview-section{margin-bottom:0;scroll-margin-top:6rem}
.interview-page .int-header{display:flex;align-items:center;gap:1.25rem;margin-bottom:clamp(1.5rem,4vw,2.25rem)}
.interview-page .int-num-badge{background:#30A1AF;color:#fff;font-size:0.6875rem;font-weight:700;letter-spacing:0.125rem;padding:0.25rem 0.625rem;border-radius:0.25rem;white-space:nowrap}
.interview-page .int-divider{flex:1;height:1px;background:#a8dde3}

/* プロフィール */
.interview-page .int-profile{position:relative;display:flex;align-items:center;gap:clamp(1.25rem,4vw,2.5rem);margin-bottom:clamp(1.75rem,4vw,2.5rem);padding:clamp(1.5rem,4vw,2.5rem) clamp(1.5rem,4vw,2.75rem);background:linear-gradient(135deg,#ffffff 0%,#eef8f9 100%);border-radius:1.125rem;box-shadow:0 0.75rem 2rem rgba(48,161,175,0.13);overflow:hidden}
/* 左端のティールアクセントバー */
.interview-page .int-profile::before{content:"";position:absolute;left:0;top:0;bottom:0;width:0.375rem;background:linear-gradient(#30A1AF,#1c7d8a)}
/* 背景の装飾的なクオーテーション */
.interview-page .int-profile::after{content:"\201D";position:absolute;right:clamp(1rem,3vw,1.75rem);top:-0.5em;font-family:Georgia,'Times New Roman',serif;font-size:clamp(6rem,18vw,11.875rem);line-height:1;color:rgba(48,161,175,0.08);pointer-events:none}

.interview-page .int-profile-img{position:relative;z-index:1;width:clamp(7.5rem,26vw,11.5rem);height:clamp(7.5rem,26vw,11.5rem);flex-shrink:0;border-radius:50%;overflow:hidden;border:0.25rem solid #fff;box-shadow:0 0.5rem 1.5rem rgba(0,0,0,0.18),0 0 0 0.1875rem rgba(48,161,175,0.45)}
.interview-page .int-profile-img img{width:100%;height:100%;object-fit:cover;object-position:center 10%}
/* U.K. のプロフィール写真だけ調整。scale=ズーム倍率、object-position=表示位置（左右 上下） */
.interview-page .int-profile-img img[src*="uk-profile"]{transform:scale(1.2);object-position:center 20%}

.interview-page .int-profile-body{position:relative;z-index:1}
.interview-page .int-profile-head{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.interview-page .int-profile-badge{display:inline-block;background:#30A1AF;color:#fff;font-size:0.75rem;font-weight:700;letter-spacing:0.0938rem;padding:0.3125rem 1rem;border-radius:999px}
.interview-page .int-profile-name{font-size:clamp(1.5rem,5vw,2.25rem);font-weight:900;color:#1a1a1a;letter-spacing:0.125rem;line-height:1}
/* 旧クラス（後方互換） */
.interview-page .int-profile-tagline{position:relative;font-size:clamp(1rem,2.5vw,1.125rem);color:#333;font-weight:700;padding-left:1.125rem;margin-top:1.125rem;line-height:1.8;border-left:0.25rem solid #30A1AF}

/* 「インタビューを読む」トグル（JS有効時のみ表示） */
.interview-page .int-toggle{display:none}
.interview-page .js-collapsible .int-toggle{position:absolute;z-index:2;right:clamp(1.5rem,4vw,2.75rem);bottom:clamp(1.25rem,3.5vw,2rem);display:flex;align-items:center;gap:0.5rem;padding:0.625rem 1.5rem;border:1px solid #d4dde2;border-radius:999px;background:#f1f4f6;color:#444;font-family:inherit;font-size:0.875rem;font-weight:700;letter-spacing:0.0625rem;cursor:pointer;transition:background .2s,border-color .2s,transform .2s}
.interview-page .js-collapsible .int-toggle:hover{background:#e6ebee;border-color:#c2ccd2;transform:translateY(-0.125rem)}
.interview-page .int-toggle__icon{display:inline-block;font-size:0.75rem;transition:transform .3s}
.interview-page .js-collapsible.is-open .int-toggle__icon{transform:rotate(180deg)}
/* 未展開のときはアイコンを上下に揺らして「隠れている」ことを示す */
.interview-page .js-collapsible:not(.is-open) .int-toggle__icon{animation:int-bounce 1.4s ease-in-out infinite}
@keyframes int-bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(0.1875rem)}}

/* カードがクリック可能であることを示す */
.interview-page .js-collapsible .int-profile{cursor:pointer;transition:transform .2s,box-shadow .2s}
.interview-page .js-collapsible .int-profile:hover{transform:translateY(-0.1875rem);box-shadow:0 1rem 2.5rem rgba(48,161,175,0.2)}

/* 折りたたみ領域：JS有効かつ未展開のとき隠す（JS無効時は常に表示＝SEO対応） */
.interview-page .js-collapsible:not(.is-open) .qa-collapse{display:none}

/* INTERVIEWラベル */
.interview-page .int-label{font-size:0.6875rem;font-weight:700;color:#30A1AF;letter-spacing:0.1875rem;margin-bottom:1.75rem;display:block}

/* Q&Aブロック */
.interview-page .qa-block{position:relative;padding:clamp(1.75rem,5vw,2.5rem) 0;border-top:1px solid #d0dfe8}
.interview-page .qa-block:last-child{border-bottom:1px solid #d0dfe8}
/* 番号の縦位置は --qa-num-top で調整する（既定 0.625rem）。
   各番号ごとの調整は下の「番号の縦位置 個別調整」ブロックで行う。 */
.interview-page .qa-num{font-size:clamp(3rem,12vw,5rem);font-weight:900;color:rgba(48,161,175,0.12);line-height:1;position:absolute;top:var(--qa-num-top,0.625rem);left:-0.625rem;font-family:'Arial Black',sans-serif;letter-spacing:-0.125rem;right:auto}

/* ============================================================
   番号の縦位置 調整
   すべての番号を「設問の高さに合わせて」同じ位置に揃える。

   ・番号は親要素の上端からの距離(top)で配置される。
   ・各設問の上には余白(padding)があり、その大きさが
       - 先頭の番号(01・06)が入るブロック … clamp(1.75rem,5vw,2.5rem)
       - 続きの番号(02〜05・07〜09)が入るブロック … 1.25rem
     と異なるため、同じ top では高さがズレていた。
   ・そこで「設問より何 rem 上に番号を出すか」を --qa-num-rise に集約し、
     それぞれの余白から差し引くことで、全番号を設問に対して同じ高さに揃える。

   ★全番号をまとめて上下に動かしたいときは、この --qa-num-rise だけ変える。
     値を大きくすると番号が上へ、小さく（マイナスに）すると下へ動く。
   ============================================================ */
.interview-page{ --qa-num-rise: 1.6rem; }
/* 先頭の番号（各インタビューの最初の設問）：親ブロックの余白を基準にする */
.interview-page .qa-num--01,
.interview-page .qa-num--06{ --qa-num-top: calc(clamp(1.75rem,5vw,2.5rem) - var(--qa-num-rise)); }
/* 続きの番号（サブ設問）：サブブロックの余白(1.25rem)を基準にする */
.interview-page .qa-num--02,
.interview-page .qa-num--03,
.interview-page .qa-num--04,
.interview-page .qa-num--05,
.interview-page .qa-num--07,
.interview-page .qa-num--08,
.interview-page .qa-num--09{ --qa-num-top: calc(1.25rem - var(--qa-num-rise)); }
.interview-page .qa-num--right{left:auto;right:0}
/* 中央寄せ(margin:auto)すると入れ子の番号(02/05/09)の基準位置がずれるため、左揃えにして全番号を縦に揃える */
.interview-page .qa-body{padding-left:0}
.interview-page .qa-q{font-size:1.125rem;font-weight:700;color:#1a1a1a;margin-bottom:1rem;line-height:1.6;position:relative}
.interview-page .qa-a{font-size:1rem;color:#333;line-height:2;letter-spacing:0.01em;position:relative}
.interview-page .qa-sub{margin-top:1.875rem;padding-top:1.25rem;position:relative}

/* Q&A内の写真（テキストを回り込ませるフロート配置） */
.interview-page .qa-figure{margin-bottom:1rem;width:44%;border-radius:0.75rem;overflow:hidden;box-shadow:0 0.25rem 1.25rem rgba(0,0,0,0.10)}
.interview-page .qa-figure--right{float:right;margin-left:clamp(1.5rem,3.5vw,2.75rem)}
.interview-page .qa-figure--left{float:left;margin-right:clamp(1.5rem,3.5vw,2.75rem)}
.interview-page .qa-figure img{width:100%;height:auto;display:block}
.interview-page .qa-clear{clear:both}

/* スマホ：プロフィールを縦積みに、番号は左揃え、写真は全幅 */
@media(max-width:600px){
  .interview-page .qa-num,
  .interview-page .qa-num--right{left:0;right:auto}
  .interview-page .int-profile{flex-direction:column;text-align:center}
  .interview-page .int-profile-head{justify-content:center}
  .interview-page .int-profile-tagline{text-align:left}
  .interview-page .js-collapsible .int-toggle{position:static;margin:1.25rem auto 0}
  .interview-page .qa-figure{float:none!important;width:100%!important;margin:0 0 1rem 0!important}
}

/* モーションを抑える設定のユーザーにはアニメーションを無効化 */
@media(prefers-reduced-motion:reduce){
  .interview-page .js-collapsible:not(.is-open) .int-toggle__icon{animation:none}
  .interview-page .int-toggle,
  .interview-page .js-collapsible .int-profile{transition:none}
}

/* ============================================================
   統合ページ（インタビュー＋採用情報）専用
   ※ interview.css はこのページからのみ読み込まれるため、
     .combine-divider / .policy-main 配下の指定も他ページに影響しない
   ============================================================ */

/* 2つのセクションの境目を明示する区切りタイトル */
.combine-divider{position:relative;margin:clamp(3rem,7vw,4.5rem) 0 1.75rem;padding-bottom:0.85rem;font-size:clamp(1.5rem,4vw,2rem);font-weight:900;color:#15333b;letter-spacing:0.05em;border-bottom:2px solid #cfe4e8;scroll-margin-top:6rem}
.combine-divider--lead{margin-top:0}
@media(max-width:48rem){.combine-divider{scroll-margin-top:4.5rem}}
.combine-divider::after{content:"";position:absolute;left:0;bottom:-2px;width:3.5rem;height:2px;background:#30A1AF}
.combine-divider__en{margin-left:0.75rem;font-family:Arial,Helvetica,sans-serif;font-size:0.5em;font-weight:700;color:#30A1AF;letter-spacing:0.18em;white-space:nowrap}

/* サイドバー付きカラム内に収めるためインタビューの背景・余白を調整 */
.policy-main .interview-page{background:transparent}
.policy-main .interview-page .interviews{max-width:none;padding:0 0 0 0.75rem}

/* ============================================================
   募集概要テーブル内の整形（職種タグ／キー‐説明リスト／給与ブロック）
   ============================================================ */

/* 職種名：ピル型タグ */
.recruit-tags{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:0.5rem}
.recruit-tags li{background:#e9f8fa;color:#1c7d8a;border:1px solid #b8e2e8;border-radius:999px;padding:0.3rem 0.9rem;font-size:0.9375rem;font-weight:700}

/* 「項目…説明」を見やすいリストに */
.recruit-deflist{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:0.7rem}
.recruit-deflist li{display:flex;flex-wrap:wrap;gap:0.15rem 0.9rem;align-items:baseline}
.recruit-deflist__key{flex:0 0 auto;min-width:8rem;font-weight:700;color:#1c7d8a;position:relative;padding-left:0.95rem}
.recruit-deflist__key::before{content:"";position:absolute;left:0;top:0.5em;width:0.4rem;height:0.4rem;border-radius:50%;background:#30A1AF}

/* 待遇：給与ブロック */
.pay{display:flex;flex-direction:column;gap:0.9rem}
.pay__head{margin:0;font-weight:700;color:#1c7d8a;border-left:0.25rem solid #30A1AF;padding-left:0.6rem}
.pay__case{background:#f4fafb;border:1px solid #e1eef0;border-radius:0.625rem;padding:0.85rem 1rem}
.pay__case p{margin:0.15rem 0}
.pay__tag{display:inline-block;background:#30A1AF;color:#fff;font-size:0.75rem;font-weight:700;border-radius:999px;padding:0.15rem 0.75rem;margin-bottom:0.45rem}
.pay__case strong{font-size:1.0625rem;color:#15333b}
.pay__note{color:#888;font-size:0.85rem}
.pay__meta{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:0.45rem}
.pay__meta li{display:flex;gap:0.85rem;align-items:baseline}
.pay__meta .pay__k{flex:0 0 3.25rem;font-weight:700;color:#1c7d8a}

/* スマホでは項目名を上・説明を下に積む */
@media(max-width:600px){
  .recruit-deflist__key{min-width:100%}
}
