@import url('./fonts.css');

/* 真似元: careers.muji.com/jp/recruit/
   無印良品 新卒採用サイトの構造を観察して移植:
   - 上部: 細いヘッダー(左:ロゴ「良品計画 新卒採用」 右:マイページ/エントリー)
   - ヒーロー: 大型写真 + 左下に「インターンシップ募集中」白タグ + 白大見出し
   - 中央寄せの第二見出し「ぶれず、たゆまずともに挑戦し続ける」
   - 画像+テキスト交互(ビジョン/キャリアプラン)
   - 社員インタビュー3カラム(写真+赤帯コピー)
   - アコーディオン(会社の取り組み)
   - サステナビリティ中央寄せカード
   - 数字データ3列グリッド
   - イベント説明会3列+中央エントリーボタン
   - FAQ アコーディオン
   - プロジェクトストーリー3列
   - 黒フッター(マルチカラム)
============================================================ */
:root{
  --p05-bg:#ffffff;
  --p05-paper:#f5f3ee;
  --p05-ink:#3c3c43;
  --p05-ink-strong:#1a1a1a;
  --p05-ink-soft:#6e6e73;
  --p05-mute:#a0a0a5;
  --p05-line:#e5e5e0;
  --p05-line-soft:#efece5;
  --p05-accent:#b50000;        /* 無印の朱赤 */
  --p05-dark:#1c1c1c;
  --p05-darker:#0e0e0e;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{background:var(--p05-bg);color:var(--p05-ink);font-family:var(--p05-font-body);font-weight:400;font-size:14px;line-height:1.85;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
.p05-skip{position:absolute;left:-9999px;top:0;background:#000;color:#fff;padding:8px 14px;z-index:200}
.p05-skip:focus{left:14px;top:14px}

/* ========== HEADER ========== */
.p05-header{background:#fff;padding:14px 28px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--p05-line);position:sticky;top:0;z-index:50}
.p05-header__brand{display:flex;align-items:baseline;gap:14px}
.p05-header__brand__main{font-family:var(--p05-font-display);font-weight:700;font-size:17px;letter-spacing:.04em;color:var(--p05-ink-strong);border:1px solid var(--p05-ink-strong);padding:4px 10px;background:#fff}
.p05-header__brand__sub{font-size:11.5px;color:var(--p05-ink-strong);letter-spacing:.06em}
.p05-header__util{display:flex;align-items:center;gap:10px}
.p05-header__util a{font-size:12px;padding:9px 22px;border:1px solid var(--p05-line);background:#fff;color:var(--p05-ink-strong);letter-spacing:.04em}
.p05-header__util__entry{background:var(--p05-ink-strong) !important;color:#fff !important;border-color:var(--p05-ink-strong) !important}
.p05-header__menu{background:none;border:0;padding:8px;display:none;flex-direction:column;gap:4px;cursor:pointer}
.p05-header__menu span{display:block;width:22px;height:1.5px;background:var(--p05-ink-strong)}
@media (max-width:880px){
  .p05-header__util a{display:none}
  .p05-header__util__entry{display:inline-block !important}
  .p05-header__menu{display:inline-flex}
}

/* ========== HERO ========== */
.p05-hero{position:relative;background:var(--p05-paper)}
.p05-hero__plate{aspect-ratio:16/9;overflow:hidden;background:#ddd}
.p05-hero__plate img{width:100%;height:100%;object-fit:cover}
.p05-hero__title{position:absolute;left:6%;top:12%;max-width:54%}
.p05-hero__title h1{font-family:var(--p05-font-display);font-weight:900;font-size:clamp(28px,5vw,64px);line-height:1.3;color:#fff;margin:0;text-shadow:0 2px 18px rgba(0,0,0,.45);letter-spacing:.02em}
.p05-hero__badge{position:absolute;left:6%;bottom:8%;background:#fff;padding:18px 22px;text-align:center;min-width:140px;box-shadow:0 8px 24px -10px rgba(0,0,0,.2)}
.p05-hero__badge small{font-size:10.5px;color:var(--p05-ink-soft);letter-spacing:.16em;display:block;margin-bottom:6px}
.p05-hero__badge p{font-family:var(--p05-font-display);font-weight:700;font-size:15px;margin:0;color:var(--p05-ink-strong)}
@media (max-width:780px){
  .p05-hero__plate{aspect-ratio:4/5}
  .p05-hero__title{max-width:80%}
}

/* ========== LEAD ========== */
.p05-lead{background:var(--p05-paper);padding:64px 28px 80px;text-align:center}
.p05-lead h2{font-family:var(--p05-font-display);font-weight:700;font-size:clamp(22px,3vw,32px);line-height:1.6;color:var(--p05-ink-strong);margin:0 0 24px}
.p05-lead p{max-width:680px;margin:0 auto 28px;font-size:14px;line-height:2;color:var(--p05-ink)}
.p05-lead__more{display:inline-block;padding:12px 32px;border:1px solid var(--p05-ink-strong);font-size:12.5px;background:#fff;color:var(--p05-ink-strong);letter-spacing:.05em;transition:background .2s,color .2s}
.p05-lead__more:hover{background:var(--p05-ink-strong);color:#fff}

/* ========== PITCH (当たり前の生活に疑問を持つ) ========== */
.p05-pitch{max-width:1100px;margin:0 auto;padding:80px 28px;display:grid;grid-template-columns:1fr 1.4fr;gap:48px;align-items:start}
.p05-pitch__h{font-family:var(--p05-font-display);font-weight:700;font-size:clamp(20px,2.4vw,28px);line-height:1.6;color:var(--p05-ink-strong);margin:0}
.p05-pitch__body{font-size:14px;line-height:2;color:var(--p05-ink);margin:0}
@media (max-width:780px){.p05-pitch{grid-template-columns:1fr;gap:18px;padding:56px 24px}}

/* ========== FEATURE (画像+テキスト) ========== */
.p05-feature{max-width:1180px;margin:0 auto 24px;padding:36px 28px;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.p05-feature--alt{background:var(--p05-paper);max-width:none;padding:48px max(28px,calc((100vw - 1180px) / 2 + 28px))}
.p05-feature__img{aspect-ratio:4/3;overflow:hidden;background:#ddd}
.p05-feature__img img{width:100%;height:100%;object-fit:cover}
.p05-feature__body{padding:0 14px}
.p05-feature__eyebrow{font-size:11.5px;color:var(--p05-ink-soft);letter-spacing:.14em;margin:0 0 14px;font-weight:500}
.p05-feature__body h3{font-family:var(--p05-font-display);font-weight:700;font-size:clamp(22px,2.6vw,30px);line-height:1.55;color:var(--p05-ink-strong);margin:0 0 18px}
.p05-feature__body p{font-size:13.5px;line-height:2;color:var(--p05-ink);margin:0 0 22px}
.p05-feature__more{display:inline-block;padding:11px 30px;border:1px solid var(--p05-ink-strong);font-size:12px;background:#fff;color:var(--p05-ink-strong);letter-spacing:.05em;transition:background .2s,color .2s}
.p05-feature__more:hover{background:var(--p05-ink-strong);color:#fff}
@media (max-width:880px){.p05-feature,.p05-feature--alt{grid-template-columns:1fr;gap:24px}.p05-feature--alt{padding:48px 24px}}

/* ========== ARTICLES (社員インタビュー) ========== */
.p05-articles{max-width:1180px;margin:0 auto;padding:72px 28px}
.p05-articles__eyebrow{font-size:11.5px;color:var(--p05-ink-soft);letter-spacing:.14em;margin:0 0 10px;font-weight:500}
.p05-articles__h{font-family:var(--p05-font-display);font-weight:700;font-size:clamp(22px,2.8vw,30px);color:var(--p05-ink-strong);margin:0 0 36px;line-height:1.45}
.p05-articles__filter{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:32px}
.p05-articles__filter button{background:#fff;border:1px solid var(--p05-line);padding:10px 18px;font-size:12px;color:var(--p05-ink);cursor:pointer;font:inherit}
.p05-articles__filter button[aria-pressed="true"]{background:var(--p05-ink-strong);color:#fff;border-color:var(--p05-ink-strong)}
.p05-articles__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:28px}
.p05-article{display:block;color:inherit}
.p05-article__plate{aspect-ratio:1/1;background:var(--p05-paper);overflow:hidden;position:relative;margin-bottom:14px}
.p05-article__plate img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.p05-article:hover .p05-article__plate img{transform:scale(1.04)}
.p05-article__band{position:absolute;left:0;right:0;bottom:0;background:var(--p05-accent);color:#fff;padding:10px 14px}
.p05-article__band span{font-size:12px;font-weight:500;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.p05-article__title{font-family:var(--p05-font-display);font-weight:700;font-size:14.5px;color:var(--p05-ink-strong);margin:0 0 4px;line-height:1.55}
.p05-article__sub{font-size:11.5px;color:var(--p05-ink-soft);margin:0 0 8px;letter-spacing:.04em}
.p05-article__more{font-size:11.5px;color:var(--p05-ink-strong);font-weight:500}
.p05-articles__btn{display:block;width:fit-content;margin:8px auto 0;padding:13px 56px;border:1px solid var(--p05-ink-strong);font-size:12.5px;color:var(--p05-ink-strong);background:#fff;letter-spacing:.06em}
.p05-articles__btn:hover{background:var(--p05-ink-strong);color:#fff}
.p05-articles__youth{display:flex;gap:18px;align-items:center;margin-top:36px;padding:18px;background:var(--p05-paper);border:1px solid var(--p05-line)}
.p05-articles__youth img{width:120px;height:72px;object-fit:cover}
.p05-articles__youth p{margin:0;font-size:12.5px}
.p05-articles__youth strong{display:block;font-family:var(--p05-font-display);font-weight:700;font-size:14px;color:var(--p05-ink-strong);margin-top:4px}
.p05-articles__youth a{display:inline-block;margin-top:6px;font-size:11.5px;color:var(--p05-ink-strong);text-decoration:underline}
@media (max-width:880px){.p05-articles__grid{grid-template-columns:1fr}}

/* ========== ACCORDION (会社の取り組み) ========== */
.p05-accord{max-width:1180px;margin:0 auto;padding:48px 28px 24px}
.p05-accord__eyebrow{font-size:11.5px;color:var(--p05-ink-soft);letter-spacing:.14em;margin:0 0 10px}
.p05-accord__h{font-family:var(--p05-font-display);font-weight:700;font-size:clamp(22px,2.8vw,30px);color:var(--p05-ink-strong);margin:0 0 16px}
.p05-accord__lead{font-size:13.5px;color:var(--p05-ink);margin:0 0 24px}
.p05-accord__item{border:1px solid var(--p05-line);margin-bottom:8px;background:#fff}
.p05-accord__item summary{padding:18px 22px;font-weight:500;font-size:14px;color:var(--p05-ink-strong);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center}
.p05-accord__item summary::after{content:"+";font-size:18px;color:var(--p05-ink-soft)}
.p05-accord__item[open] summary::after{content:"−"}
.p05-accord__item div{padding:0 22px 18px;font-size:13.5px;color:var(--p05-ink-soft);line-height:2}

/* ========== SUSTAINABILITY ========== */
.p05-susta{max-width:780px;margin:0 auto;padding:80px 28px 100px;text-align:center}
.p05-susta__eyebrow{font-size:11.5px;color:var(--p05-ink-soft);letter-spacing:.14em;margin:0 0 14px}
.p05-susta__h{font-family:var(--p05-font-display);font-weight:700;font-size:clamp(22px,3vw,32px);line-height:1.55;color:var(--p05-ink-strong);margin:0 0 22px}
.p05-susta p{font-size:13.5px;color:var(--p05-ink);margin:0 0 28px;line-height:2}
.p05-susta__more{display:inline-block;padding:12px 36px;border:1px solid var(--p05-ink-strong);font-size:12.5px;background:#fff;color:var(--p05-ink-strong);letter-spacing:.06em}
.p05-susta__more:hover{background:var(--p05-ink-strong);color:#fff}

/* ========== DATA ========== */
.p05-data{max-width:1180px;margin:0 auto;padding:64px 28px;background:var(--p05-paper)}
.p05-data__eyebrow{font-size:11.5px;color:var(--p05-ink-soft);letter-spacing:.14em;margin:0 0 14px}
.p05-data__h{font-family:var(--p05-font-display);font-weight:700;font-size:clamp(20px,2.4vw,28px);line-height:1.55;color:var(--p05-ink-strong);margin:0 0 22px;max-width:760px}
.p05-data__more{display:inline-block;padding:11px 28px;border:1px solid var(--p05-ink-strong);font-size:12px;color:var(--p05-ink-strong);background:#fff;margin-bottom:48px}
.p05-data__more:hover{background:var(--p05-ink-strong);color:#fff}
.p05-data__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.p05-data__grid--inner{margin-bottom:48px}
.p05-data__item{background:#fff;padding:28px 22px;text-align:left;border:1px solid var(--p05-line)}
.p05-data__label{font-size:11.5px;color:var(--p05-ink-soft);letter-spacing:.04em;margin:0 0 10px;font-weight:500}
.p05-data__value{font-family:var(--p05-font-display);font-weight:700;font-size:44px;line-height:1;color:var(--p05-ink-strong);margin:0 0 12px;letter-spacing:-.02em}
.p05-data__value small{font-size:16px;font-weight:500;margin-left:6px;color:var(--p05-ink-soft)}
.p05-data__note{font-size:11px;color:var(--p05-ink-soft);margin:0;line-height:1.7}
@media (max-width:880px){.p05-data__grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.p05-data__grid{grid-template-columns:1fr}}

/* ========== EVENTS ========== */
.p05-events{max-width:1180px;margin:0 auto;padding:72px 28px}
.p05-events__eyebrow{font-size:11.5px;color:var(--p05-ink-soft);letter-spacing:.14em;margin:0 0 22px}
.p05-events__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:36px}
.p05-event{background:var(--p05-paper);padding:32px 24px;color:inherit;display:block;border:1px solid var(--p05-line);transition:background .2s,border-color .2s}
.p05-event:hover{background:#fff;border-color:var(--p05-ink-strong)}
.p05-event h3{font-family:var(--p05-font-display);font-weight:700;font-size:16px;color:var(--p05-ink-strong);margin:0 0 12px}
.p05-event p{font-size:12.5px;color:var(--p05-ink-soft);margin:0 0 14px;line-height:1.75}
.p05-event span{font-size:11.5px;color:var(--p05-ink-strong);font-weight:500}
.p05-events__entry{text-align:center;padding:32px 24px;background:var(--p05-paper)}
.p05-events__entry p{font-size:13px;color:var(--p05-ink-soft);margin:0 0 18px}
.p05-events__entry__btn{display:inline-block;padding:16px 80px;background:var(--p05-ink-strong);color:#fff;font-size:14px;font-weight:500;letter-spacing:.06em;margin-right:8px}
.p05-events__entry__mp{display:inline-block;padding:16px 36px;background:#fff;color:var(--p05-ink-strong);font-size:13px;border:1px solid var(--p05-ink-strong)}
@media (max-width:780px){.p05-events__grid{grid-template-columns:1fr}.p05-events__entry__btn{display:block;margin:0 auto 10px}.p05-events__entry__mp{display:block;margin:0 auto}}

/* ========== FAQ ========== */
.p05-faq{max-width:980px;margin:0 auto;padding:48px 28px}
.p05-faq__eyebrow{font-size:11.5px;color:var(--p05-ink-soft);letter-spacing:.14em;margin:0 0 20px}
.p05-faqlist{border-top:1px solid var(--p05-line)}
.p05-faqitem{border-bottom:1px solid var(--p05-line);background:#fff}
.p05-faqitem summary{padding:18px 22px;font-size:13.5px;font-weight:500;color:var(--p05-ink-strong);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center}
.p05-faqitem summary::after{content:"+";color:var(--p05-ink-soft);font-size:18px;flex-shrink:0;margin-left:14px}
.p05-faqitem[open] summary::after{content:"−"}
.p05-faqitem div{padding:0 22px 20px;font-size:13px;color:var(--p05-ink-soft);line-height:2}

/* ========== STORIES ========== */
.p05-stories{max-width:1180px;margin:0 auto;padding:72px 28px}
.p05-stories__eyebrow{font-size:11.5px;color:var(--p05-ink-soft);letter-spacing:.14em;margin:0 0 12px}
.p05-stories__h{font-family:var(--p05-font-display);font-weight:700;font-size:clamp(22px,2.6vw,28px);color:var(--p05-ink-strong);margin:0 0 30px}
.p05-stories__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:28px}
.p05-story{color:inherit;display:block}
.p05-story__plate{aspect-ratio:4/3;background:var(--p05-paper);overflow:hidden;margin-bottom:12px}
.p05-story__plate img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.p05-story:hover .p05-story__plate img{transform:scale(1.04)}
.p05-story__title{font-family:var(--p05-font-display);font-weight:500;font-size:13.5px;color:var(--p05-ink-strong);margin:0;line-height:1.65}
.p05-stories__btn{display:block;width:fit-content;margin:0 auto;padding:13px 56px;border:1px solid var(--p05-ink-strong);font-size:12.5px;color:var(--p05-ink-strong);background:#fff;letter-spacing:.06em}
.p05-stories__btn:hover{background:var(--p05-ink-strong);color:#fff}
@media (max-width:880px){.p05-stories__grid{grid-template-columns:1fr}}

/* ========== SUBNAV (footer above) ========== */
.p05-subnav{background:var(--p05-paper);padding:28px;display:flex;flex-direction:column;align-items:center;gap:18px;border-top:1px solid var(--p05-line)}
.p05-subnav__title{font-size:12px;color:var(--p05-ink-soft);letter-spacing:.06em;margin:0}
.p05-subnav__menu{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.p05-subnav__menu a{font-size:11.5px;padding:9px 18px;background:#fff;border:1px solid var(--p05-line);color:var(--p05-ink-strong);letter-spacing:.04em}
.p05-subnav__menu a:hover,.p05-subnav__menu a[aria-current]{background:var(--p05-ink-strong);color:#fff;border-color:var(--p05-ink-strong)}

/* ========== FOOTER ========== */
.p05-foot{background:#fff;padding:48px 28px 24px;border-top:1px solid var(--p05-line)}
.p05-foot__top{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:auto 1fr;gap:48px;padding-bottom:32px;border-bottom:1px solid var(--p05-line)}
.p05-foot__brand{display:flex;flex-direction:column;gap:6px}
.p05-foot__brand__main{font-family:var(--p05-font-display);font-weight:700;font-size:16px;color:var(--p05-ink-strong);border:1px solid var(--p05-ink-strong);padding:5px 11px;background:#fff;width:fit-content}
.p05-foot__brand__sub{font-size:11px;color:var(--p05-ink-strong);letter-spacing:.04em}
.p05-foot__cols{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.p05-foot__col h4{font-size:12px;color:var(--p05-ink-strong);margin:0 0 14px;font-weight:700;letter-spacing:.04em}
.p05-foot__col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.p05-foot__col a{font-size:11.5px;color:var(--p05-ink-soft)}
.p05-foot__col a:hover{color:var(--p05-ink-strong);text-decoration:underline}
.p05-foot__bot{max-width:1280px;margin:24px auto 0;padding-top:18px;display:flex;justify-content:space-between;gap:18px;font-size:10.5px;color:var(--p05-mute);flex-wrap:wrap}
.p05-foot__credit{font-style:italic;opacity:.7}
@media (max-width:880px){.p05-foot__top{grid-template-columns:1fr}.p05-foot__cols{grid-template-columns:1fr 1fr}}

/* ============================================================
   下層ページ共通
============================================================ */
.p05-page{max-width:1100px;margin:0 auto;padding:48px 28px 80px}
.p05-page__crumb{font-size:11px;color:var(--p05-ink-soft);margin:0 0 24px;letter-spacing:.04em}
.p05-page__crumb a{color:var(--p05-ink-soft);text-decoration:underline}
.p05-page__eyebrow{font-size:11.5px;color:var(--p05-ink-soft);letter-spacing:.14em;margin:0 0 14px;font-weight:500}
.p05-page__h{font-family:var(--p05-font-display);font-weight:700;font-size:clamp(28px,4vw,44px);line-height:1.4;color:var(--p05-ink-strong);margin:0 0 28px;letter-spacing:.02em}
.p05-page__lead{font-size:14px;line-height:2;color:var(--p05-ink);margin:0 0 36px;max-width:64ch}
.p05-section__h{font-family:var(--p05-font-display);font-weight:700;font-size:clamp(20px,2.4vw,24px);color:var(--p05-ink-strong);margin:48px 0 18px;padding-bottom:12px;border-bottom:1px solid var(--p05-line)}

/* business/about heads */
.p05-business__head{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:start;margin:0 0 56px}
.p05-business__head__body p{font-size:13.5px;line-height:2;color:var(--p05-ink);margin:0 0 18px}
.p05-business__head__img{aspect-ratio:4/3;overflow:hidden}
.p05-business__head__img img{width:100%;height:100%;object-fit:cover}
.p05-business__split{display:grid;grid-template-columns:1.2fr 1fr;gap:36px;align-items:center;margin:48px 0;background:var(--p05-paper);padding:32px}
.p05-business__split__img{aspect-ratio:4/3;overflow:hidden;background:#ddd}
.p05-business__split__img img{width:100%;height:100%;object-fit:cover}
.p05-business__split__body h3{font-family:var(--p05-font-display);font-weight:700;font-size:clamp(20px,2.4vw,26px);line-height:1.55;color:var(--p05-ink-strong);margin:0 0 14px}
.p05-business__split__body p{font-size:13.5px;line-height:2;color:var(--p05-ink);margin:0}
.p05-business__cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:24px}
.p05-business__card{background:#fff;border:1px solid var(--p05-line);padding:14px}
.p05-business__card__plate{aspect-ratio:4/3;overflow:hidden;background:var(--p05-paper);margin-bottom:14px}
.p05-business__card__plate img{width:100%;height:100%;object-fit:cover}
.p05-business__card h4{font-family:var(--p05-font-display);font-weight:700;font-size:14px;color:var(--p05-ink-strong);margin:0 0 8px}
.p05-business__card p{font-size:12.5px;color:var(--p05-ink-soft);line-height:1.85;margin:0}
@media (max-width:780px){.p05-business__head,.p05-business__split{grid-template-columns:1fr}.p05-business__cards{grid-template-columns:1fr}}

/* career-path */
.p05-careerbar{display:grid;grid-template-columns:160px 1fr;gap:28px;align-items:start;padding:24px 0;border-bottom:1px solid var(--p05-line)}
.p05-careerbar__photo{aspect-ratio:1/1;overflow:hidden;background:var(--p05-paper)}
.p05-careerbar__photo img{width:100%;height:100%;object-fit:cover}
.p05-careerbar__body h4{font-family:var(--p05-font-display);font-weight:700;font-size:16px;color:var(--p05-ink-strong);margin:0 0 6px}
.p05-careerbar__name{font-size:11.5px;color:var(--p05-ink-soft);margin:0 0 18px}
.p05-careerbar__steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding-top:14px;border-top:1px solid var(--p05-line-soft)}
.p05-careerbar__steps span{display:block;font-size:10.5px;color:var(--p05-accent);font-weight:700;letter-spacing:.08em;margin-bottom:6px}
.p05-careerbar__steps p{font-size:12px;color:var(--p05-ink);margin:0;line-height:1.7}
@media (max-width:780px){.p05-careerbar{grid-template-columns:1fr}.p05-careerbar__steps{grid-template-columns:1fr 1fr}}

.p05-careerpath{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;margin:24px 0 48px;padding:32px;background:var(--p05-paper)}
.p05-careerpath__node{padding:16px 24px;background:#fff;border:1px solid var(--p05-line);font-size:13px;font-weight:500;color:var(--p05-ink-strong);text-align:center;min-width:140px}
.p05-careerpath__arrow{font-size:18px;color:var(--p05-ink-soft)}

.p05-trainbox{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:24px 0}
.p05-trainbox__item{background:var(--p05-paper);padding:24px;border:1px solid var(--p05-line)}
.p05-trainbox__item h4{font-family:var(--p05-font-display);font-weight:700;font-size:15px;color:var(--p05-ink-strong);margin:0 0 10px}
.p05-trainbox__item p{font-size:12.5px;color:var(--p05-ink);line-height:1.9;margin:0}
@media (max-width:780px){.p05-trainbox{grid-template-columns:1fr}}

/* history (about) */
.p05-history{border-top:1px solid var(--p05-line);margin:24px 0 48px}
.p05-history__row{display:grid;grid-template-columns:140px 1fr;gap:24px;padding:18px 0;border-bottom:1px solid var(--p05-line)}
.p05-history__year{font-family:var(--p05-font-display);font-weight:700;font-size:18px;color:var(--p05-accent);letter-spacing:.04em}
.p05-history__event{font-size:13.5px;color:var(--p05-ink);line-height:1.85}
.p05-history__head{background:var(--p05-paper);padding:36px;margin:24px 0;display:flex;flex-direction:column;align-items:flex-start;gap:14px}
.p05-history__head h3{font-family:var(--p05-font-display);font-weight:700;font-size:clamp(20px,2.4vw,26px);color:var(--p05-ink-strong);margin:0}
.p05-history__head p{font-size:13px;color:var(--p05-ink);line-height:1.95;margin:0;max-width:64ch}

.p05-message{background:var(--p05-paper);padding:48px 36px;margin-top:48px;border-left:3px solid var(--p05-accent)}
.p05-message__title{font-family:var(--p05-font-display);font-weight:700;font-size:clamp(20px,2.6vw,28px);line-height:1.55;color:var(--p05-ink-strong);margin:0 0 22px}
.p05-message__body{font-size:13.5px;line-height:2.1;color:var(--p05-ink);white-space:pre-line;max-width:64ch}
.p05-message__sign{margin-top:28px;padding-top:14px;border-top:1px solid var(--p05-line);font-size:12px;color:var(--p05-ink-soft)}
.p05-message__sign strong{color:var(--p05-ink-strong);font-weight:700;margin-left:6px;font-size:14px}

/* jobs index */
.p05-jobs__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.p05-jobcard{background:#fff;border:1px solid var(--p05-line);color:inherit;display:flex;flex-direction:column;transition:border-color .2s,transform .2s}
.p05-jobcard:hover{border-color:var(--p05-ink-strong);transform:translateY(-2px)}
.p05-jobcard__plate{aspect-ratio:4/3;overflow:hidden;background:var(--p05-paper)}
.p05-jobcard__plate img{width:100%;height:100%;object-fit:cover}
.p05-jobcard__body{padding:18px 20px}
.p05-jobcard__code{font-size:10.5px;color:var(--p05-ink-soft);letter-spacing:.12em;margin:0 0 6px;font-weight:500}
.p05-jobcard__title{font-family:var(--p05-font-display);font-weight:700;font-size:17px;color:var(--p05-ink-strong);margin:0 0 6px;line-height:1.5}
.p05-jobcard__sub{font-size:12.5px;color:var(--p05-ink-soft);margin:0 0 14px;line-height:1.7}
.p05-jobcard__meta{display:flex;flex-direction:column;gap:6px;font-size:11.5px;color:var(--p05-ink);padding-top:12px;border-top:1px solid var(--p05-line-soft)}
.p05-jobcard__meta b{display:inline-block;width:50px;color:var(--p05-ink-soft);font-weight:500}
@media (max-width:880px){.p05-jobs__grid{grid-template-columns:1fr}}

/* job detail */
.p05-job__hero{background:var(--p05-paper);padding:48px 0;border-bottom:1px solid var(--p05-line)}
.p05-job__hero__inner{max-width:1100px;margin:0 auto;padding:0 28px;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.p05-job__hero__code{font-size:11.5px;letter-spacing:.14em;color:var(--p05-accent);margin:0 0 14px;font-weight:700}
.p05-job__hero__title{font-family:var(--p05-font-display);font-weight:700;font-size:clamp(28px,3.6vw,40px);line-height:1.4;color:var(--p05-ink-strong);margin:0 0 14px}
.p05-job__hero__sub{font-size:14px;line-height:1.85;color:var(--p05-ink);margin:0 0 22px}
.p05-job__hero__meta{display:grid;grid-template-columns:auto 1fr;gap:10px 24px;font-size:13px;padding-top:18px;border-top:1px solid var(--p05-line)}
.p05-job__hero__meta dt{font-size:11px;letter-spacing:.12em;color:var(--p05-ink-soft);font-weight:500}
.p05-job__hero__meta dd{margin:0;color:var(--p05-ink-strong)}
.p05-job__hero__plate{aspect-ratio:4/3;overflow:hidden}
.p05-job__hero__plate img{width:100%;height:100%;object-fit:cover}
@media (max-width:880px){.p05-job__hero__inner{grid-template-columns:1fr;gap:24px}}

.p05-job__sec{max-width:1100px;margin:0 auto;padding:0 28px 36px}
.p05-job__sec__head{font-family:var(--p05-font-display);font-weight:700;font-size:18px;color:var(--p05-ink-strong);margin:24px 0 16px;padding-bottom:10px;border-bottom:1px solid var(--p05-line)}
.p05-job__sec p{font-size:13.5px;line-height:2;color:var(--p05-ink);margin:0 0 12px}
.p05-job__sec ul{padding-left:1.4em;margin:0;font-size:13.5px;line-height:2;color:var(--p05-ink)}

.p05-day{display:grid;grid-template-columns:100px 1fr;background:#fff;border:1px solid var(--p05-line)}
.p05-day__row{display:contents}
.p05-day__time{background:var(--p05-paper);color:var(--p05-ink-strong);padding:16px 20px;font-family:var(--p05-font-display);font-weight:700;font-size:14px;border-bottom:1px solid var(--p05-line);display:flex;align-items:center}
.p05-day__body{padding:16px 22px;border-bottom:1px solid var(--p05-line)}
.p05-day__body h4{font-family:var(--p05-font-display);font-weight:700;font-size:14px;margin:0 0 4px;color:var(--p05-ink-strong)}
.p05-day__body p{font-size:12.5px;color:var(--p05-ink-soft);margin:0}
.p05-day__row:last-child .p05-day__time,.p05-day__row:last-child .p05-day__body{border-bottom:0}

/* requirements table */
.p05-reqtable{width:100%;border-collapse:collapse;border-top:1px solid var(--p05-line);font-size:13.5px}
.p05-reqtable tr{border-bottom:1px solid var(--p05-line)}
.p05-reqtable th{text-align:left;padding:18px 20px 18px 0;width:180px;font-size:12.5px;color:var(--p05-ink-soft);font-weight:500;vertical-align:top;letter-spacing:.04em}
.p05-reqtable td{padding:18px 20px;color:var(--p05-ink);line-height:1.9}

/* form */
.p05-form{display:grid;gap:18px;max-width:680px}
.p05-form label{display:block;font-size:12.5px;color:var(--p05-ink-strong);margin:0 0 6px;font-weight:500}
.p05-form label small{font-weight:400;color:var(--p05-accent);margin-left:6px;font-size:10.5px}
.p05-form input,.p05-form select,.p05-form textarea{width:100%;font:inherit;padding:12px 14px;border:1px solid var(--p05-line);background:#fff;color:var(--p05-ink);border-radius:0}
.p05-form input:focus,.p05-form select:focus,.p05-form textarea:focus{outline:none;border-color:var(--p05-ink-strong)}
.p05-form button{background:var(--p05-ink-strong);color:#fff;padding:14px 56px;font-weight:500;font-size:13.5px;border:0;cursor:pointer;justify-self:start;letter-spacing:.08em}
.p05-form button:hover{background:#000}
.p05-form__note{font-size:11.5px;color:var(--p05-ink-soft);background:var(--p05-paper);padding:14px 18px;border-left:2px solid var(--p05-accent);margin-bottom:24px;line-height:1.85}

/* ============================================================
   Motion (scroll reveal) — 控えめ
============================================================ */
html.p05-motion-ready .p05-reveal{opacity:0;transform:translateY(14px);transition:opacity .8s ease var(--p05-delay,0ms),transform .8s ease var(--p05-delay,0ms)}
html.p05-motion-ready .p05-reveal.p05-in{opacity:1;transform:none}
