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

/* 真似元: career.fjtex.co.jp/ (フジテックス・中途採用サイト)
   観察結果:
   - 白背景・コーポレートの強いネイビーブルー(#1B3B8F系)を基調
   - ヘッダー: 左に「FUJITEX + 中途採用」ロゴ、右に4つのナビ(会社を知る/社員を知る/制度・環境を知る/ENTRYの青角丸ボタン)
   - ヒーロー: 6人の人物写真グリッド(暗く処理)+ 中央白文字「未来は、すべての人の前に開かれている」
   - 会社情報帯: 40th Anniversary 表記
   - 募集中の職種カード: 【業種】【職務】の青ラベル + 部署名 + 求人タイトル
   - FAQ: Q1, Q2... 連番付きのアコーディオン
   - 「会社を知る/社員を知る/制度・環境を知る」セクションは青背景のラベル帯で区切る
   - 事業紹介: 2列グリッド (写真+見出し+説明) ×6
   - 社員インタビュー: 横並びカード
   - 制度・環境: 3×2のテキストカード
   - フッター: 濃紺、コピーライト中央 */
:root{
  --p47-bg:#ffffff;
  --p47-bg-soft:#f4f6fb;
  --p47-ink:#0e1d3a;
  --p47-ink-soft:#3a4a6a;
  --p47-mute:#6e7a92;
  --p47-line:#d8dde6;
  --p47-line-soft:#eef1f6;
  --p47-blue:#1B3B8F;
  --p47-blue-dark:#0F2768;
  --p47-blue-light:#3a5dba;
  --p47-blue-pale:#e7ecf7;
  --p47-red:#d8423a;
  --p47-gold:#c98b35;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{background:var(--p47-bg);color:var(--p47-ink);font-family:var(--p47-font-body);font-weight:500;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}

/* ===== HEADER ===== */
.p47-skip{position:absolute;left:-9999px;top:0;background:var(--p47-blue);color:#fff;padding:8px 14px}
.p47-skip:focus{left:14px;top:14px;z-index:100}

.p47-header{position:sticky;top:0;z-index:30;background:#fff;border-bottom:1px solid var(--p47-line-soft);padding:14px 36px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:36px}
.p47-header__brand{display:flex;align-items:baseline;gap:14px;text-decoration:none}
.p47-header__brand strong{font-family:var(--p47-font-display);font-weight:800;font-size:28px;letter-spacing:.02em;color:var(--p47-blue);line-height:1}
.p47-header__brand small{color:var(--p47-ink);font-weight:700;font-size:13px;letter-spacing:.18em}
.p47-header__nav{display:flex;justify-content:flex-end;align-items:center;gap:32px}
.p47-header__nav a{font-size:13px;color:var(--p47-ink);font-weight:700;letter-spacing:.06em;display:inline-flex;align-items:center;gap:4px}
.p47-header__nav a::after{content:"\\25BE";font-size:9px;color:var(--p47-blue);margin-left:2px}
.p47-header__nav a.p47-noarrow::after{content:""}
.p47-header__entry{background:var(--p47-blue);color:#fff;padding:12px 28px;border-radius:999px;font-family:var(--p47-font-display);font-weight:700;font-size:12px;letter-spacing:.18em;display:inline-flex;align-items:center;gap:8px}
.p47-header__entry::after{content:"\\203A";font-size:14px;line-height:1}

/* ===== HERO ===== */
.p47-hero{position:relative;background:#0a142a;color:#fff;overflow:hidden}
.p47-hero__grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr);gap:2px;height:min(72vh,640px);position:absolute;inset:0}
.p47-hero__grid span{background-position:center;background-size:cover;filter:brightness(.45) saturate(.85)}
.p47-hero__inner{position:relative;height:min(72vh,640px);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0 24px;text-align:center;z-index:2}
.p47-hero__eyebrow{font-family:var(--p47-font-display);font-weight:700;font-size:12px;letter-spacing:.28em;color:#7ba3e8;margin:0 0 18px}
.p47-hero__h1{font-family:var(--p47-font-body);font-weight:900;font-size:clamp(26px,3.6vw,46px);line-height:1.55;letter-spacing:.06em;margin:0;color:#fff}
.p47-hero__h1 span{display:block}
.p47-hero__sub{font-size:14px;line-height:2;color:#d2dcef;margin:22px 0 0;letter-spacing:.04em;max-width:680px}
.p47-hero__scroll{position:absolute;right:36px;bottom:28px;color:#fff;font-family:var(--p47-font-display);font-size:10px;letter-spacing:.3em;writing-mode:vertical-rl;z-index:3}
.p47-hero__scroll::after{content:"";display:block;width:1px;height:48px;background:#fff;margin:12px auto 0}

/* ===== Anniv 帯 ===== */
.p47-anniv{background:#fff;padding:36px 28px;display:flex;justify-content:center;align-items:center;gap:36px;border-bottom:1px solid var(--p47-line-soft)}
.p47-anniv__badge{font-family:var(--p47-font-display);font-weight:800;color:var(--p47-blue);font-size:14px;letter-spacing:.16em;border:1px solid var(--p47-blue);padding:10px 22px;border-radius:999px;display:inline-flex;align-items:baseline;gap:8px}
.p47-anniv__badge b{font-size:30px;letter-spacing:.02em}
.p47-anniv__txt{font-size:13px;color:var(--p47-ink-soft);line-height:1.7;max-width:520px}
.p47-anniv__txt a{color:var(--p47-blue);text-decoration:underline}

/* ===== セクション帯ラベル (会社を知る / 社員を知る / 制度・環境を知る) ===== */
.p47-secbar{background:var(--p47-blue);color:#fff;text-align:center;padding:22px 24px}
.p47-secbar h2{margin:0;font-size:22px;font-weight:900;letter-spacing:.16em}
.p47-secbar small{display:block;font-family:var(--p47-font-display);font-size:11px;letter-spacing:.3em;color:#aebfe2;font-weight:600;margin-bottom:4px}

/* ===== 募集中の職種 (TOP) ===== */
.p47-careers{padding:48px 24px 60px;background:var(--p47-bg-soft)}
.p47-careers__head{max-width:1080px;margin:0 auto 28px}
.p47-careers__head small{font-family:var(--p47-font-display);font-weight:700;font-size:11px;letter-spacing:.28em;color:var(--p47-blue);display:block;margin-bottom:8px}
.p47-careers__head h2{margin:0;font-size:22px;font-weight:900;letter-spacing:.06em;color:var(--p47-ink)}
.p47-careers__grid{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.p47-jobline{background:#fff;border:1px solid var(--p47-line);padding:18px 22px;display:flex;justify-content:space-between;align-items:center;gap:18px;transition:transform .25s ease,box-shadow .25s ease}
.p47-jobline:hover{transform:translateY(-2px);box-shadow:0 8px 24px -16px rgba(15,39,104,.4)}
.p47-jobline__tags{display:flex;flex-direction:column;gap:6px;flex:1}
.p47-jobline__tagrow{display:flex;gap:8px;flex-wrap:wrap}
.p47-jobline__tag{font-family:var(--p47-font-display);font-weight:700;font-size:10px;letter-spacing:.16em;background:var(--p47-blue);color:#fff;padding:3px 10px;border-radius:2px}
.p47-jobline__tag--w{background:#fff;color:var(--p47-blue);border:1px solid var(--p47-blue)}
.p47-jobline__title{font-size:14px;font-weight:700;color:var(--p47-ink);line-height:1.5}
.p47-jobline__title small{display:block;font-size:11px;color:var(--p47-mute);font-weight:500;margin-top:2px}
.p47-jobline__arrow{width:32px;height:32px;border-radius:50%;background:var(--p47-blue);color:#fff;display:grid;place-items:center;font-size:14px;flex-shrink:0}
.p47-jobline__arrow::before{content:"\\203A"}

/* ===== FAQ 帯リスト ===== */
.p47-faqstrip{padding:48px 24px 64px;background:var(--p47-bg-soft);border-top:1px solid var(--p47-line-soft)}
.p47-faqstrip__head{max-width:1080px;margin:0 auto 24px}
.p47-faqstrip__head small{font-family:var(--p47-font-display);font-weight:700;font-size:11px;letter-spacing:.28em;color:var(--p47-blue);display:block;margin-bottom:8px}
.p47-faqstrip__head h2{margin:0;font-size:22px;font-weight:900;letter-spacing:.06em;color:var(--p47-ink)}
.p47-faqstrip__list{max-width:1080px;margin:0 auto}
.p47-faqitem{background:#fff;border:1px solid var(--p47-line);margin-bottom:8px}
.p47-faqitem > summary{list-style:none;cursor:pointer;padding:16px 22px;display:flex;align-items:center;gap:16px;font-size:13px;font-weight:700;color:var(--p47-ink)}
.p47-faqitem > summary::-webkit-details-marker{display:none}
.p47-faqitem > summary::before{content:"Q" attr(data-n);font-family:var(--p47-font-display);font-weight:800;color:#fff;background:var(--p47-blue);width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-size:12px;flex-shrink:0}
.p47-faqitem > summary::after{content:"\\25BE";margin-left:auto;color:var(--p47-blue);transition:transform .25s ease}
.p47-faqitem[open] > summary::after{transform:rotate(180deg)}
.p47-faqitem > div{padding:0 22px 18px 68px;color:var(--p47-ink-soft);font-size:13px;line-height:1.9}

/* counter for FAQ */
.p47-faqstrip__list{counter-reset:p47faq}
.p47-faqitem{counter-increment:p47faq}
.p47-faqitem > summary::before{content:"Q" counter(p47faq)}

/* ===== 事業紹介 (TOPで「会社を知る」セクション) ===== */
.p47-biz{background:var(--p47-blue);padding:54px 24px 72px;color:#fff}
.p47-biz__inner{max-width:1080px;margin:0 auto}
.p47-biz__head{text-align:center;margin-bottom:28px}
.p47-biz__head small{font-family:var(--p47-font-display);font-weight:700;font-size:11px;letter-spacing:.28em;color:#aebfe2;display:block;margin-bottom:6px}
.p47-biz__head h3{margin:0;font-size:22px;font-weight:900;letter-spacing:.18em;color:#fff}
.p47-biz__lead{text-align:center;font-size:13px;color:#dbe3f4;margin:0 auto 28px;max-width:680px;line-height:1.95}
.p47-biz__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.p47-bizcard{background:#fff;color:var(--p47-ink);padding:18px;display:grid;grid-template-columns:140px 1fr;gap:16px;align-items:start}
.p47-bizcard__img{width:140px;aspect-ratio:4/3;background:#0a142a;overflow:hidden}
.p47-bizcard__img img{width:100%;height:100%;object-fit:cover}
.p47-bizcard__body h4{margin:0 0 6px;font-size:14px;font-weight:900;color:var(--p47-ink);letter-spacing:.04em;display:flex;align-items:center;gap:8px}
.p47-bizcard__body h4 b{font-family:var(--p47-font-display);font-size:9px;letter-spacing:.16em;color:var(--p47-blue);background:var(--p47-blue-pale);padding:3px 8px;border-radius:2px;font-weight:700;line-height:1}
.p47-bizcard__body p{margin:0;font-size:11.5px;line-height:1.7;color:var(--p47-ink-soft)}
.p47-bizcard__body small{display:block;margin-top:8px;font-size:10.5px;color:var(--p47-mute);line-height:1.7}

/* ===== 社員を知る ===== */
.p47-voices{background:#fff;padding:54px 24px 64px}
.p47-voices__inner{max-width:1080px;margin:0 auto}
.p47-voices__head{margin-bottom:24px}
.p47-voices__head small{font-family:var(--p47-font-display);font-weight:700;font-size:11px;letter-spacing:.28em;color:var(--p47-blue);display:block;margin-bottom:6px}
.p47-voices__head h3{margin:0;font-size:20px;font-weight:900;color:var(--p47-ink);letter-spacing:.06em}
.p47-voices__lead{font-size:13px;color:var(--p47-ink-soft);line-height:1.95;margin:0 0 28px;max-width:880px}
.p47-voices__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.p47-vcard{position:relative;aspect-ratio:4/3;overflow:hidden;background:#0a142a}
.p47-vcard img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.p47-vcard:hover img{transform:scale(1.04)}
.p47-vcard__cap{position:absolute;left:18px;bottom:18px;color:#fff;font-weight:900;font-size:16px;line-height:1.4;text-shadow:0 2px 12px rgba(0,0,0,.6);max-width:88%}
.p47-vcard__cap small{display:block;font-family:var(--p47-font-display);font-size:10px;letter-spacing:.2em;color:#fff;margin-bottom:6px;opacity:.9;font-weight:600}
.p47-vcard__cap b{display:block;font-size:11px;font-weight:600;color:#cfd8ec;margin-top:8px;letter-spacing:.02em}

/* ===== 制度・環境 ===== */
.p47-perks{background:#fff;padding:54px 24px 80px}
.p47-perks__inner{max-width:1080px;margin:0 auto}
.p47-perks__head{margin-bottom:28px}
.p47-perks__head small{font-family:var(--p47-font-display);font-weight:700;font-size:11px;letter-spacing:.28em;color:var(--p47-blue);display:block;margin-bottom:6px}
.p47-perks__head h3{margin:0;font-size:20px;font-weight:900;color:var(--p47-ink);letter-spacing:.06em}
.p47-perks__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.p47-perkcard{background:#fff;border:1px solid var(--p47-line);padding:22px 18px;text-align:left}
.p47-perkcard h4{margin:0 0 10px;font-size:13px;font-weight:900;color:var(--p47-ink);letter-spacing:.04em}
.p47-perkcard p{margin:0;font-size:11.5px;line-height:1.8;color:var(--p47-ink-soft)}
.p47-perkcard small{display:block;margin-top:8px;font-size:10.5px;color:var(--p47-mute)}

/* ===== 大型CTA ===== */
.p47-cta{background:var(--p47-blue);color:#fff;text-align:center;padding:42px 24px;display:flex;justify-content:center;align-items:center;gap:28px;flex-wrap:wrap}
.p47-cta p{margin:0;font-size:13px;color:#dbe3f4;flex:1 1 100%}
.p47-cta a{background:#fff;color:var(--p47-blue);padding:14px 36px;border-radius:999px;font-family:var(--p47-font-display);font-weight:700;font-size:13px;letter-spacing:.18em;display:inline-flex;align-items:center;gap:10px}
.p47-cta a::after{content:"\\203A";font-size:16px;line-height:1}
.p47-cta a.p47-cta--ghost{background:transparent;color:#fff;border:1px solid #fff}

/* ===== FOOTER ===== */
.p47-foot{background:var(--p47-blue-dark);color:#fff;padding:24px 24px}
.p47-foot__nav{max-width:1080px;margin:0 auto 18px;display:flex;justify-content:center;gap:32px;flex-wrap:wrap;font-size:12px;font-weight:700}
.p47-foot__nav a{color:#fff;letter-spacing:.04em;text-decoration:underline}
.p47-foot__bar{background:#06122e;text-align:center;color:#fff;font-size:11px;padding:14px;margin:0 -24px -24px}
.p47-foot__bar small{color:#b8c5e0;letter-spacing:.06em}

/* ===========================================================
   下層ページ共通
   =========================================================== */
.p47-page{background:#fff;color:var(--p47-ink)}
.p47-page__hero{background:var(--p47-blue);color:#fff;padding:64px 24px 48px;text-align:center}
.p47-page__hero small{font-family:var(--p47-font-display);font-weight:700;font-size:11px;letter-spacing:.3em;color:#aebfe2;display:block;margin-bottom:10px}
.p47-page__hero h1{margin:0;font-size:clamp(24px,3vw,34px);font-weight:900;letter-spacing:.12em;color:#fff}
.p47-page__crumb{max-width:1080px;margin:18px auto 8px;padding:0 24px;font-size:11px;color:var(--p47-mute);letter-spacing:.04em}
.p47-page__crumb a{color:var(--p47-blue);text-decoration:none}
.p47-page__inner{max-width:1080px;margin:0 auto;padding:32px 24px 80px}
.p47-page__lead{font-size:14px;line-height:2;color:var(--p47-ink-soft);margin:0 0 32px;max-width:780px}

/* === jobs/index === */
.p47-jobs__grid{max-width:1080px;margin:0 auto 60px;padding:0 24px;display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.p47-jobcard{background:#fff;border:1px solid var(--p47-line);overflow:hidden;display:flex;flex-direction:column;transition:transform .25s ease,box-shadow .25s ease}
.p47-jobcard:hover{transform:translateY(-3px);box-shadow:0 14px 30px -22px rgba(15,39,104,.45)}
.p47-jobcard__plate{aspect-ratio:16/9;overflow:hidden;background:#0a142a;position:relative}
.p47-jobcard__plate img{width:100%;height:100%;object-fit:cover}
.p47-jobcard__body{padding:18px 22px 24px}
.p47-jobcard__tags{display:flex;gap:6px;margin-bottom:10px}
.p47-jobcard__tag{font-family:var(--p47-font-display);font-weight:700;font-size:10px;letter-spacing:.16em;background:var(--p47-blue);color:#fff;padding:3px 10px;border-radius:2px}
.p47-jobcard__code{font-family:var(--p47-font-display);font-size:11px;color:var(--p47-mute);letter-spacing:.16em;font-weight:600;margin:0 0 4px}
.p47-jobcard__title{font-size:18px;font-weight:900;color:var(--p47-ink);margin:0 0 4px;letter-spacing:.02em}
.p47-jobcard__sub{font-size:12px;color:var(--p47-mute);margin:0 0 12px}
.p47-jobcard__meta{font-size:12px;color:var(--p47-ink-soft);line-height:1.7;border-top:1px solid var(--p47-line-soft);padding-top:10px;display:grid;grid-template-columns:auto 1fr;gap:4px 12px}
.p47-jobcard__meta b{font-weight:700;color:var(--p47-blue);font-size:11px}

/* === jobs/detail === */
.p47-job__hero{background:#fff;padding:48px 24px 28px;border-bottom:1px solid var(--p47-line-soft)}
.p47-job__hero__inner{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:1.2fr 1fr;gap:36px;align-items:center}
.p47-job__hero__txt small{font-family:var(--p47-font-display);font-weight:700;font-size:11px;letter-spacing:.28em;color:var(--p47-blue);display:block;margin-bottom:10px}
.p47-job__hero__txt h1{margin:0 0 12px;font-size:clamp(22px,2.4vw,30px);font-weight:900;color:var(--p47-ink);letter-spacing:.04em;line-height:1.4}
.p47-job__hero__txt p{font-size:13px;color:var(--p47-ink-soft);line-height:1.95;margin:0 0 18px}
.p47-job__hero__meta{display:grid;grid-template-columns:repeat(2,1fr);gap:6px 18px;font-size:12px;color:var(--p47-ink-soft);border-top:1px solid var(--p47-line-soft);padding-top:14px}
.p47-job__hero__meta div{display:flex;gap:10px;line-height:1.8}
.p47-job__hero__meta dt{color:var(--p47-blue);font-weight:700;font-size:11px;letter-spacing:.06em;min-width:54px}
.p47-job__hero__meta dd{margin:0;color:var(--p47-ink);font-weight:600}
.p47-job__hero__img{aspect-ratio:4/3;overflow:hidden;background:#0a142a;position:relative}
.p47-job__hero__img img{width:100%;height:100%;object-fit:cover}
.p47-job__hero__img span{position:absolute;left:14px;top:14px;background:var(--p47-blue);color:#fff;padding:4px 12px;font-family:var(--p47-font-display);font-weight:700;font-size:11px;letter-spacing:.16em}

.p47-job__sec{max-width:980px;margin:0 auto;padding:36px 24px;border-bottom:1px solid var(--p47-line-soft)}
.p47-job__sec__head{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.p47-job__sec__head b{background:var(--p47-blue);color:#fff;padding:6px 14px;font-size:11px;font-weight:700;letter-spacing:.12em}
.p47-job__sec__head small{font-family:var(--p47-font-display);font-size:11px;letter-spacing:.28em;color:var(--p47-blue);font-weight:700}
.p47-job__sec h3{margin:0 0 14px;font-size:18px;font-weight:900;color:var(--p47-ink);letter-spacing:.04em}
.p47-job__sec p{font-size:13px;line-height:2;color:var(--p47-ink-soft);margin:0 0 12px}
.p47-job__sec ul{margin:0;padding-left:20px}
.p47-job__sec ul li{font-size:13px;line-height:1.9;color:var(--p47-ink-soft);margin-bottom:4px}
.p47-job__sec ul li::marker{color:var(--p47-blue)}

/* === 1日の流れ === */
.p47-day{position:relative;padding:0}
.p47-day__row{display:grid;grid-template-columns:90px 1fr;gap:24px;padding:14px 0;border-bottom:1px dashed var(--p47-line)}
.p47-day__row:last-child{border-bottom:0}
.p47-day__time{font-family:var(--p47-font-display);font-weight:800;color:var(--p47-blue);font-size:20px;letter-spacing:.04em;line-height:1.2}
.p47-day__body h4{margin:0 0 4px;font-size:13px;font-weight:800;color:var(--p47-ink)}
.p47-day__body p{margin:0;font-size:12px;color:var(--p47-ink-soft);line-height:1.7}

/* === reqtable === */
.p47-reqtable{width:100%;border-collapse:collapse;background:#fff;border-top:1px solid var(--p47-line);border-bottom:1px solid var(--p47-line)}
.p47-reqtable th,.p47-reqtable td{padding:16px 18px;font-size:13px;text-align:left;border-bottom:1px solid var(--p47-line-soft);vertical-align:top;line-height:1.85}
.p47-reqtable th{background:var(--p47-bg-soft);color:var(--p47-blue);font-weight:700;width:180px;letter-spacing:.04em}
.p47-reqtable td{color:var(--p47-ink-soft)}
.p47-reqtable tr:last-child th,.p47-reqtable tr:last-child td{border-bottom:0}

/* === faqlist (lower page) === */
.p47-faqlist{counter-reset:p47faq2}
.p47-faqlist .p47-faqitem{counter-increment:p47faq2}
.p47-faqlist .p47-faqitem > summary::before{content:"Q" counter(p47faq2)}

/* === Form (apply) === */
.p47-form{max-width:760px;margin:0 auto;display:grid;gap:22px}
.p47-form > div{display:flex;flex-direction:column;gap:8px}
.p47-form label{font-size:13px;font-weight:700;color:var(--p47-ink);display:flex;align-items:center;gap:8px}
.p47-form label small{background:var(--p47-red);color:#fff;font-size:10px;padding:2px 8px;border-radius:2px;font-weight:700;letter-spacing:.06em}
.p47-form input,.p47-form select,.p47-form textarea{font:inherit;font-size:13px;padding:14px 14px;border:1px solid var(--p47-line);background:#fff;color:var(--p47-ink);border-radius:4px;width:100%}
.p47-form textarea{min-height:140px;resize:vertical}
.p47-form input:focus,.p47-form select:focus,.p47-form textarea:focus{outline:2px solid var(--p47-blue);outline-offset:2px;border-color:var(--p47-blue)}
.p47-form__note{font-size:12px;color:var(--p47-mute);line-height:1.85;margin:0 auto 18px;max-width:760px;background:var(--p47-bg-soft);padding:14px 18px;border-radius:4px}
.p47-form button{justify-self:center;background:var(--p47-blue);color:#fff;border:0;padding:18px 64px;border-radius:999px;font-family:var(--p47-font-display);font-weight:700;font-size:14px;letter-spacing:.18em;cursor:pointer;display:inline-flex;align-items:center;gap:14px;margin-top:8px}
.p47-form button::after{content:"\\203A";font-size:18px;line-height:1}
.p47-form button:hover{background:var(--p47-blue-dark)}

/* === history (company) === */
.p47-history{max-width:780px;margin:0 auto;border-left:2px solid var(--p47-blue);padding-left:24px}
.p47-history__row{display:grid;grid-template-columns:90px 1fr;gap:20px;padding:14px 0;border-bottom:1px dashed var(--p47-line)}
.p47-history__row:last-child{border-bottom:0}
.p47-history__year{font-family:var(--p47-font-display);font-weight:800;color:var(--p47-blue);font-size:18px;letter-spacing:.04em;line-height:1.2}
.p47-history__event{font-size:13px;color:var(--p47-ink-soft);line-height:1.85}

/* === message (top message) === */
.p47-message{max-width:880px;margin:0 auto;padding:40px 0;display:grid;grid-template-columns:200px 1fr;gap:36px;align-items:start}
.p47-message__photo{width:200px;height:200px;border-radius:50%;overflow:hidden;background:#0a142a}
.p47-message__photo img{width:100%;height:100%;object-fit:cover}
.p47-message__body h2{margin:0 0 18px;font-size:22px;font-weight:900;color:var(--p47-ink);letter-spacing:.06em;line-height:1.5}
.p47-message__body p{font-size:13.5px;line-height:2.1;color:var(--p47-ink-soft);margin:0 0 14px;white-space:pre-line}
.p47-message__sign{margin-top:24px;font-size:12px;color:var(--p47-mute)}
.p47-message__sign b{display:block;font-size:18px;color:var(--p47-ink);font-weight:800;margin-top:4px;letter-spacing:.04em}

/* ===== Reveal ===== */
.p47-reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease;transition-delay:var(--p47-delay,0ms)}
.p47-reveal.p47-in{opacity:1;transform:none}
.p47-hero{opacity:0;transition:opacity .8s ease}
.p47-hero.p47-loaded{opacity:1}

/* ===== Responsive ===== */
@media (max-width: 880px){
  .p47-header{grid-template-columns:auto auto;padding:14px 18px;gap:12px}
  .p47-header__nav{display:none}
  .p47-anniv{flex-direction:column;text-align:center;gap:18px;padding:28px 18px}
  .p47-hero__grid{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(3,1fr)}
  .p47-careers__grid,.p47-biz__grid,.p47-voices__grid,.p47-perks__grid,.p47-jobs__grid{grid-template-columns:1fr}
  .p47-bizcard{grid-template-columns:1fr}
  .p47-bizcard__img{width:100%}
  .p47-job__hero__inner{grid-template-columns:1fr}
  .p47-message{grid-template-columns:1fr;text-align:center}
  .p47-message__photo{margin:0 auto}
  .p47-reqtable th{width:110px;font-size:12px}
  .p47-cta{flex-direction:column;gap:18px}
}
