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

/* 真似元: 株式会社オンワードコーポレートデザイン 採用サイト onward-shoji.co.jp/recruit/
   観察:
   - 全体淡いブルーグレーグラデ背景 #eef1f5 → 上部ほのかな青
   - 本文色 #344549(青みのあるダークインク)
   - アクセント色: ロイヤルブルー #1B3D8F
   - 上ヘッダ: ロゴ + 横並びリンク + 右に「お問い合わせ」濃紺ピル
   - 大型英字見出し(About Us / Message / History 等)+ 小さい日本語キャプション
   - 「Brand」中央配置の円形サービス系統図
   - 番号付き(01)(02) 大型カード(左にラベル、右にダミーグラフィック領域)
   - 下部に Message / Philosophy / History のグレーグラデパネル3枚
   - お問い合わせはタイル4枚(ユニフォーム種類アイコン的)
   - History は年代帯(暗い夜景写真+白文字)+ 右に小カード3枚並び
   - 主な装飾: 青の細い実線、グラデーション、白カード+影なし */

:root{
  --p39-bg:#eef1f5;
  --p39-bg-top:linear-gradient(180deg,#dbe6f3 0%,#eef1f5 62%);
  --p39-card:#ffffff;
  --p39-ink:#344549;
  --p39-ink-soft:#5a6c70;
  --p39-mute:#8a96a0;
  --p39-line:#dbe2ea;
  --p39-line-soft:#e6ecf2;
  --p39-blue:#1B3D8F;
  --p39-blue-dark:#11296A;
  --p39-blue-light:#2C57B5;
  --p39-sky:#e6edf8;
  --p39-panel-grad:linear-gradient(180deg,#c9d2dc 0%,#9aa6b2 100%);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{background:var(--p39-bg);color:var(--p39-ink);font-family:var(--p39-font-body);font-size:14px;line-height:1.85;-webkit-font-smoothing:antialiased}
body{background:var(--p39-bg);min-height:100vh}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}

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

/* ===== HEADER ===== */
.p39-header{position:sticky;top:0;z-index:30;background:rgba(255,255,255,.94);backdrop-filter:blur(10px);border-bottom:1px solid var(--p39-line);padding:14px 36px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:28px}
.p39-header__brand{display:flex;flex-direction:column;line-height:1.15;color:var(--p39-ink)}
.p39-header__brand strong{font-weight:900;font-size:15px;letter-spacing:.16em;color:var(--p39-blue-dark)}
.p39-header__brand small{font-size:9.5px;letter-spacing:.04em;color:var(--p39-ink-soft);margin-top:3px;font-weight:500}
.p39-header__nav{display:flex;justify-content:flex-end;gap:24px;font-size:12px;font-weight:700;letter-spacing:.04em}
.p39-header__nav a{color:var(--p39-ink);padding:6px 2px;position:relative}
.p39-header__nav a:hover{color:var(--p39-blue)}
.p39-header__cta{display:flex;gap:10px;align-items:center}
.p39-header__cta a{background:var(--p39-blue);color:#fff;padding:11px 22px;font-size:11.5px;letter-spacing:.08em;font-weight:700;border-radius:24px;display:inline-flex;align-items:center;gap:8px}
.p39-header__cta a::before{content:"✉";font-size:11px}
.p39-header__cta a:hover{background:var(--p39-blue-dark)}

/* ===== HERO ===== */
.p39-hero{position:relative;background:var(--p39-bg-top);padding:80px 36px 60px;overflow:hidden}
.p39-hero::before{content:"";position:absolute;top:0;right:0;width:55%;height:100%;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.7),transparent 60%);pointer-events:none}
.p39-hero__inner{max-width:1200px;margin:0 auto;position:relative;z-index:1}
.p39-hero__eyebrow{font-size:11px;letter-spacing:.2em;color:var(--p39-blue);font-weight:700;margin-bottom:10px}
.p39-hero__crumb{font-size:10.5px;color:var(--p39-mute);position:absolute;top:0;right:0;letter-spacing:.06em}
.p39-hero__title{font-size:clamp(38px,5.6vw,72px);font-weight:300;color:var(--p39-blue-dark);letter-spacing:.04em;line-height:1.1;margin:0 0 12px;font-family:var(--p39-font-display)}
.p39-hero__sub{font-size:13px;color:var(--p39-ink-soft);font-weight:500;letter-spacing:.06em;margin:0 0 36px}
.p39-hero__photo{position:relative;width:100%;aspect-ratio:16/7;background:#0c1632;overflow:hidden;border-radius:2px;margin-top:24px}
.p39-hero__photo img{width:100%;height:100%;object-fit:cover;opacity:.94}
.p39-hero__copy{position:absolute;left:6%;bottom:10%;color:#fff;font-size:clamp(20px,2.8vw,36px);font-weight:300;letter-spacing:.12em;line-height:1.5;text-shadow:0 2px 14px rgba(0,0,0,.55)}
.p39-hero__copy em{font-style:normal;color:#fff;border-bottom:1px solid #fff;padding-bottom:2px;font-weight:500;letter-spacing:.16em}
.p39-hero__lead{margin-top:36px;text-align:center;font-size:14px;color:var(--p39-ink-soft);line-height:2;max-width:760px;margin-left:auto;margin-right:auto}
.p39-hero__btn{margin:34px auto 0;display:inline-flex;background:var(--p39-card);color:var(--p39-blue-dark);padding:14px 36px;font-size:12px;letter-spacing:.12em;font-weight:700;border:1px solid var(--p39-line);align-items:center;gap:10px}
.p39-hero__btn::after{content:"→";color:var(--p39-blue);font-size:13px}
.p39-hero__btns{text-align:center}

/* ===== Section common ===== */
.p39-section{padding:80px 36px;background:transparent}
.p39-section__inner{max-width:1200px;margin:0 auto}
.p39-section__head{margin-bottom:48px;text-align:center}
.p39-section__head h2{font-size:clamp(28px,3.4vw,42px);font-weight:300;color:var(--p39-blue-dark);letter-spacing:.06em;line-height:1.15;margin:0 0 6px;font-family:var(--p39-font-display)}
.p39-section__head small{font-size:11px;color:var(--p39-ink-soft);letter-spacing:.08em;font-weight:500;display:block}

/* ===== ブロック(オンワード「私たちの顧客ブランド支援」風 番号付きカード) ===== */
.p39-block{background:var(--p39-card);border-radius:8px;padding:48px 56px;margin-bottom:22px;display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:center;min-height:280px}
.p39-block__num{font-family:var(--p39-font-serif);font-size:13px;color:var(--p39-ink-soft);letter-spacing:.06em;margin-bottom:18px}
.p39-block__title{font-size:22px;color:var(--p39-ink);font-weight:700;letter-spacing:.06em;line-height:1.5;margin:0 0 16px}
.p39-block__title em{font-style:normal;color:var(--p39-ink);border-bottom:1px solid var(--p39-blue);padding-bottom:2px}
.p39-block__body{font-size:12.5px;color:var(--p39-ink-soft);line-height:2;margin:0 0 22px}
.p39-block__cta{display:inline-flex;background:var(--p39-blue);color:#fff;padding:11px 22px;font-size:11px;letter-spacing:.1em;font-weight:700;align-items:center;gap:10px;border-radius:2px}
.p39-block__cta::after{content:"→"}
.p39-block__visual{background:#f1f4f8;border-radius:6px;aspect-ratio:4/3;display:grid;place-items:center;position:relative;overflow:hidden}
.p39-block__visual img{width:100%;height:100%;object-fit:cover}

/* ブランドダイアグラム(中央 BRAND + 4衛星) */
.p39-diagram{position:relative;width:100%;aspect-ratio:1.2/1;display:grid;place-items:center}
.p39-diagram__center{width:120px;height:120px;border-radius:50%;background:var(--p39-blue);color:#fff;display:grid;place-items:center;font-weight:700;font-size:16px;letter-spacing:.06em;box-shadow:0 8px 26px rgba(27,61,143,.25)}
.p39-diagram__sat{position:absolute;width:78px;height:78px;border-radius:50%;background:#fff;border:1px solid var(--p39-line);display:grid;place-items:center;text-align:center;font-size:9.5px;line-height:1.35;color:var(--p39-ink);font-weight:700;letter-spacing:.04em;padding:6px;transition:transform .25s}
.p39-diagram__sat.is-on{transform:scale(1.05)}
.p39-diagram__sat::before{content:"";position:absolute;width:8px;height:8px;border-radius:50%;background:var(--p39-blue);top:-3px;left:50%;transform:translateX(-50%)}
.p39-diagram__sat--n{top:6%;left:50%;transform:translateX(-50%)}
.p39-diagram__sat--e{top:50%;right:8%;transform:translateY(-50%)}
.p39-diagram__sat--w{top:50%;left:8%;transform:translateY(-50%)}
.p39-diagram__sat--sw{bottom:8%;left:24%}
.p39-diagram__sat--se{bottom:8%;right:24%}

/* ===== 数字パネル (はみ出さない4枚) ===== */
.p39-numbers{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:42px}
.p39-numbercard{background:var(--p39-card);padding:32px 22px;border-radius:6px;border-top:3px solid var(--p39-blue)}
.p39-numbercard__label{font-size:10.5px;color:var(--p39-ink-soft);letter-spacing:.1em;font-weight:700;margin-bottom:12px}
.p39-numbercard__num{font-family:var(--p39-font-serif);font-size:54px;color:var(--p39-blue-dark);line-height:1;font-weight:400}
.p39-numbercard__unit{font-size:14px;color:var(--p39-ink-soft);margin-left:4px;font-weight:500}
.p39-numbercard__note{font-size:10px;color:var(--p39-mute);margin-top:14px;line-height:1.5}

/* ===== Recruit 紹介帯(オンワードのフッタ上にある Recruit セクション風) ===== */
.p39-recruit{margin:80px auto 0;max-width:1200px;background:var(--p39-blue);color:#fff;padding:60px 56px;border-radius:6px;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.p39-recruit__label{font-size:11px;letter-spacing:.2em;font-weight:700;margin-bottom:14px;opacity:.7}
.p39-recruit__title{font-size:clamp(24px,2.6vw,34px);font-weight:300;letter-spacing:.04em;line-height:1.45;margin:0 0 18px;color:#fff}
.p39-recruit__title em{font-style:normal;font-weight:500}
.p39-recruit__body{font-size:12.5px;line-height:2;color:#cfd8eb;margin:0 0 22px}
.p39-recruit__btn{display:inline-flex;background:#fff;color:var(--p39-blue);padding:13px 26px;font-size:11px;letter-spacing:.12em;font-weight:700;align-items:center;gap:10px}
.p39-recruit__btn::after{content:"→"}
.p39-recruit__photo{position:relative;aspect-ratio:4/3;overflow:hidden;border-radius:4px}
.p39-recruit__photo img{width:100%;height:100%;object-fit:cover}

/* ===== 下層共通ヒーロー ===== */
.p39-page{background:transparent}
.p39-page__hero{background:var(--p39-bg-top);padding:80px 36px 60px;position:relative;overflow:hidden}
.p39-page__hero::before{content:"";position:absolute;top:0;right:0;width:55%;height:100%;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.7),transparent 60%);pointer-events:none}
.p39-page__hero__inner{max-width:1200px;margin:0 auto;position:relative;z-index:1;display:flex;justify-content:space-between;align-items:flex-end}
.p39-page__hero h1{font-size:clamp(42px,5.6vw,72px);font-weight:300;color:var(--p39-blue-dark);letter-spacing:.04em;line-height:1.1;margin:0;font-family:var(--p39-font-display)}
.p39-page__hero h1 small{display:block;font-size:13px;color:var(--p39-ink-soft);font-weight:500;letter-spacing:.06em;margin-top:14px}
.p39-page__crumb{font-size:10.5px;color:var(--p39-mute);letter-spacing:.06em;text-align:right}
.p39-page__crumb a{color:var(--p39-mute)}
.p39-page__crumb a:hover{color:var(--p39-blue)}

.p39-page__inner{max-width:1200px;margin:0 auto;padding:60px 36px}
.p39-page__lead{font-size:13.5px;color:var(--p39-ink);line-height:2.1;margin:0 0 48px;max-width:780px}
.p39-page__sec-head{margin:60px 0 28px;display:flex;flex-direction:column}
.p39-page__sec-head h2{font-size:22px;font-weight:700;color:var(--p39-ink);letter-spacing:.06em;margin:0}
.p39-page__sec-head small{font-size:10.5px;color:var(--p39-ink-soft);letter-spacing:.08em;font-weight:500;margin-top:4px}

/* ===== JOBS グリッド (下層共通必須) ===== */
.p39-jobs__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:24px}
.p39-jobcard{background:var(--p39-card);border-radius:6px;overflow:hidden;display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s;border:1px solid var(--p39-line-soft)}
.p39-jobcard:hover{transform:translateY(-4px);box-shadow:0 16px 38px -18px rgba(27,61,143,.25)}
.p39-jobcard__photo{aspect-ratio:4/3;overflow:hidden;position:relative}
.p39-jobcard__photo img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.p39-jobcard:hover .p39-jobcard__photo img{transform:scale(1.05)}
.p39-jobcard__photo::after{content:"";position:absolute;left:14px;top:14px;background:var(--p39-blue);color:#fff;font-size:9.5px;font-weight:700;padding:4px 10px;letter-spacing:.1em}
.p39-jobcard__body{padding:24px 24px 28px;flex:1;display:flex;flex-direction:column;gap:8px}
.p39-jobcard__code{font-size:10px;color:var(--p39-blue);font-weight:700;letter-spacing:.1em}
.p39-jobcard__title{font-size:18px;font-weight:700;color:var(--p39-ink);letter-spacing:.04em;margin:0;line-height:1.4}
.p39-jobcard__sub{font-size:11.5px;color:var(--p39-ink-soft);margin:4px 0 16px}
.p39-jobcard__meta{display:flex;flex-direction:column;gap:6px;border-top:1px solid var(--p39-line-soft);padding-top:14px;margin-top:auto;font-size:11px}
.p39-jobcard__meta span{display:flex;justify-content:space-between;color:var(--p39-ink-soft)}
.p39-jobcard__meta b{color:var(--p39-ink);font-weight:700;letter-spacing:.04em}
.p39-jobcard__more{margin-top:14px;font-size:10.5px;color:var(--p39-blue);font-weight:700;letter-spacing:.1em}
.p39-jobcard__more::after{content:" →"}

/* ===== JOB DETAIL ヒーロー ===== */
.p39-job__hero{background:var(--p39-bg-top);padding:80px 36px 60px;position:relative;overflow:hidden}
.p39-job__hero::before{content:"";position:absolute;top:0;right:0;width:55%;height:100%;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.7),transparent 60%);pointer-events:none}
.p39-job__hero__inner{max-width:1200px;margin:0 auto;position:relative;z-index:1}
.p39-job__hero__code{font-size:11px;color:var(--p39-blue);font-weight:700;letter-spacing:.16em;margin-bottom:14px}
.p39-job__hero__title{font-size:clamp(32px,4.6vw,56px);font-weight:300;color:var(--p39-blue-dark);letter-spacing:.04em;line-height:1.15;margin:0 0 12px;font-family:var(--p39-font-display)}
.p39-job__hero__sub{font-size:13.5px;color:var(--p39-ink-soft);font-weight:500;max-width:680px;line-height:2;margin:0 0 36px}
.p39-job__hero__photo{margin-top:32px;border-radius:4px;overflow:hidden;aspect-ratio:16/7}
.p39-job__hero__photo img{width:100%;height:100%;object-fit:cover}
.p39-job__hero__meta{display:grid;grid-template-columns:repeat(4,1fr);gap:0;background:#fff;margin-top:28px;border-radius:4px;overflow:hidden;border:1px solid var(--p39-line)}
.p39-job__hero__meta>div{padding:18px 22px;border-right:1px solid var(--p39-line)}
.p39-job__hero__meta>div:last-child{border-right:0}
.p39-job__hero__meta dt{font-size:10px;color:var(--p39-ink-soft);letter-spacing:.1em;font-weight:700;margin-bottom:6px}
.p39-job__hero__meta dd{margin:0;font-size:13px;color:var(--p39-ink);font-weight:700}

/* ===== JOB SEC (下層共通必須 / 詳細セクション) ===== */
.p39-job__sec{margin:48px auto;max-width:1200px;padding:0 36px}
.p39-job__sec__bar{display:flex;align-items:baseline;gap:18px;border-bottom:1px solid var(--p39-line);padding-bottom:14px;margin-bottom:28px}
.p39-job__sec__bar__tag{font-size:11px;color:var(--p39-blue);font-weight:700;letter-spacing:.12em;padding:5px 12px;background:var(--p39-sky);border-radius:2px}
.p39-job__sec__bar__title{font-size:22px;color:var(--p39-ink);font-weight:300;letter-spacing:.1em;font-family:var(--p39-font-display)}
.p39-job__sec p{font-size:13px;line-height:2.1;color:var(--p39-ink-soft);margin:0 0 14px}
.p39-job__sec ul{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.p39-job__sec ul li{padding:14px 18px;background:var(--p39-card);border-radius:4px;border-left:3px solid var(--p39-blue);font-size:13px;color:var(--p39-ink)}

/* ===== DAY (1日の流れ - 下層共通必須) ===== */
.p39-day{display:flex;flex-direction:column;gap:0;position:relative}
.p39-day::before{content:"";position:absolute;left:84px;top:14px;bottom:14px;width:1px;background:var(--p39-line)}
.p39-day__row{display:grid;grid-template-columns:120px 1fr;gap:32px;padding:18px 0;align-items:flex-start;position:relative}
.p39-day__time{font-family:var(--p39-font-serif);font-size:24px;color:var(--p39-blue-dark);font-weight:500;line-height:1;letter-spacing:.04em;position:relative}
.p39-day__time::after{content:"";position:absolute;right:-22px;top:5px;width:10px;height:10px;border-radius:50%;background:var(--p39-blue);border:3px solid #fff;box-shadow:0 0 0 1px var(--p39-line)}
.p39-day__body h4{font-size:14px;color:var(--p39-ink);margin:0 0 4px;font-weight:700;letter-spacing:.04em}
.p39-day__body p{font-size:12px;color:var(--p39-ink-soft);margin:0;line-height:1.85}

/* ===== REQTABLE (下層共通必須) ===== */
.p39-reqtable{width:100%;border-collapse:collapse;background:var(--p39-card);border-radius:4px;overflow:hidden}
.p39-reqtable tr{border-bottom:1px solid var(--p39-line-soft)}
.p39-reqtable tr:last-child{border-bottom:0}
.p39-reqtable th{background:#f4f7fb;color:var(--p39-blue-dark);font-weight:700;font-size:12px;letter-spacing:.06em;padding:18px 24px;text-align:left;width:200px;vertical-align:top;border-right:1px solid var(--p39-line-soft)}
.p39-reqtable td{padding:18px 24px;font-size:13px;color:var(--p39-ink);line-height:1.85}

/* ===== FAQLIST (下層共通必須) ===== */
.p39-faqlist{display:flex;flex-direction:column;gap:12px}
.p39-faqitem{background:var(--p39-card);border-radius:4px;border:1px solid var(--p39-line-soft);overflow:hidden}
.p39-faqitem summary{padding:20px 56px 20px 28px;cursor:pointer;list-style:none;font-size:13.5px;color:var(--p39-ink);font-weight:700;position:relative;letter-spacing:.02em}
.p39-faqitem summary::-webkit-details-marker{display:none}
.p39-faqitem summary::before{content:"Q";position:absolute;left:28px;top:50%;transform:translateY(-50%);color:var(--p39-blue);font-family:var(--p39-font-serif);font-weight:500;font-size:20px;display:none}
.p39-faqitem summary::after{content:"+";position:absolute;right:28px;top:50%;transform:translateY(-50%);font-size:22px;color:var(--p39-blue);font-weight:300;transition:transform .25s}
.p39-faqitem[open] summary::after{content:"−"}
.p39-faqitem>div{padding:0 28px 22px;font-size:13px;color:var(--p39-ink-soft);line-height:2;border-top:1px solid var(--p39-line-soft);padding-top:18px}

/* ===== FORM (下層共通必須) ===== */
.p39-form{display:grid;gap:18px;background:var(--p39-card);padding:48px 56px;border-radius:6px;border:1px solid var(--p39-line)}
.p39-form>div{display:flex;flex-direction:column;gap:6px}
.p39-form label{font-size:11.5px;color:var(--p39-ink);font-weight:700;letter-spacing:.06em}
.p39-form label small{background:var(--p39-blue);color:#fff;font-size:9.5px;padding:2px 7px;border-radius:2px;margin-left:8px;letter-spacing:.08em;font-weight:700}
.p39-form input,.p39-form textarea,.p39-form select{padding:12px 14px;background:#f4f7fb;border:1px solid var(--p39-line);border-radius:3px;font:inherit;color:var(--p39-ink);font-size:13px;outline:none}
.p39-form input:focus,.p39-form textarea:focus,.p39-form select:focus{border-color:var(--p39-blue);background:#fff}
.p39-form button{margin-top:14px;background:var(--p39-blue);color:#fff;border:0;padding:16px 36px;font-size:12px;letter-spacing:.16em;font-weight:700;cursor:pointer;border-radius:2px;justify-self:start}
.p39-form button:hover{background:var(--p39-blue-dark)}
.p39-form__note{font-size:11px;color:var(--p39-ink-soft);margin:0 0 18px;line-height:1.85}

/* ===== HISTORY (下層共通必須) ===== */
.p39-history{display:grid;gap:14px}
.p39-history__era{background:var(--p39-card);border-radius:4px;display:grid;grid-template-columns:240px 1fr;gap:0;overflow:hidden;border:1px solid var(--p39-line-soft)}
.p39-history__era__cover{background:#0c1632 center/cover no-repeat;color:#fff;padding:38px 28px;display:flex;flex-direction:column;justify-content:flex-end;position:relative;min-height:200px}
.p39-history__era__cover::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,22,50,.2),rgba(11,22,50,.85))}
.p39-history__era__cover span,.p39-history__era__cover b{position:relative;z-index:1}
.p39-history__era__cover span{font-size:11.5px;letter-spacing:.16em;font-weight:500;opacity:.85;margin-bottom:8px}
.p39-history__era__cover b{font-family:var(--p39-font-serif);font-size:32px;font-weight:400;letter-spacing:.04em;line-height:1.1;color:#fff}
.p39-history__era__cover em{position:relative;z-index:1;display:block;font-style:normal;font-size:10.5px;letter-spacing:.16em;color:#fff;opacity:.65;margin-top:14px}
.p39-history__era__body{padding:32px 36px;background:#fff;display:flex;flex-direction:column;justify-content:center}
.p39-history__era__year{font-size:10.5px;color:var(--p39-blue);letter-spacing:.16em;font-weight:700;margin-bottom:10px}
.p39-history__era__title{font-size:16px;color:var(--p39-ink);font-weight:700;line-height:1.55;margin:0 0 8px;letter-spacing:.04em}
.p39-history__era__text{font-size:12.5px;color:var(--p39-ink-soft);line-height:1.95;margin:0}

/* ===== MESSAGE (下層共通必須) ===== */
.p39-message{position:relative;background:var(--p39-card);border-radius:6px;padding:0;overflow:hidden;margin-top:32px;border:1px solid var(--p39-line)}
.p39-message__inner{padding:60px 60px;display:grid;grid-template-columns:1fr 280px;gap:48px;align-items:flex-start}
.p39-message__title{font-size:24px;color:var(--p39-blue-dark);font-weight:700;letter-spacing:.04em;line-height:1.6;margin:0 0 24px}
.p39-message__body{font-size:13px;color:var(--p39-ink);line-height:2.15;margin:0;white-space:pre-wrap}
.p39-message__sign{font-size:12px;color:var(--p39-ink-soft);margin-top:28px;letter-spacing:.04em}
.p39-message__sign b{display:block;font-size:18px;color:var(--p39-ink);margin-top:6px;letter-spacing:.06em}
.p39-message__photo{border-radius:4px;overflow:hidden;aspect-ratio:1/1.2}
.p39-message__photo img{width:100%;height:100%;object-fit:cover}

/* ===== VOICE (社員の声) ===== */
.p39-voice{background:var(--p39-card);border-radius:6px;padding:36px 40px;display:grid;grid-template-columns:140px 1fr;gap:32px;margin-bottom:18px;border:1px solid var(--p39-line-soft)}
.p39-voice__photo{aspect-ratio:1/1;border-radius:50%;overflow:hidden}
.p39-voice__photo img{width:100%;height:100%;object-fit:cover}
.p39-voice__name{font-size:14px;color:var(--p39-ink);font-weight:700;margin:0 0 4px;letter-spacing:.04em}
.p39-voice__attr{font-size:11px;color:var(--p39-blue);letter-spacing:.1em;font-weight:700;margin-bottom:14px}
.p39-voice__quote{font-size:13px;color:var(--p39-ink);line-height:2;margin:0;font-style:normal}
.p39-voice__quote::before{content:"\201C";color:var(--p39-blue);font-family:var(--p39-font-serif);font-size:28px;margin-right:6px;line-height:0;vertical-align:-8px;font-weight:500}

/* ===== カード・ピル (オンワード下部の Message/Philosophy/History グラデパネル) ===== */
.p39-pills{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:60px}
.p39-card-pill{background:var(--p39-panel-grad);color:#fff;padding:36px 32px;border-radius:6px;display:flex;flex-direction:column;justify-content:flex-end;min-height:180px;position:relative;overflow:hidden;transition:transform .3s}
.p39-card-pill:hover{transform:translateY(-3px)}
.p39-card-pill h3{font-family:var(--p39-font-display);font-size:26px;font-weight:300;letter-spacing:.04em;margin:0 0 4px;color:#fff}
.p39-card-pill small{font-size:11px;color:#fff;opacity:.85;letter-spacing:.08em;font-weight:500}
.p39-card-pill::after{content:"+";position:absolute;right:24px;top:24px;background:rgba(255,255,255,.12);color:#fff;width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-weight:300;font-size:16px}

/* ===== Contact tiles (お問い合わせ4枚) ===== */
.p39-contact-tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:48px}
.p39-contact-tile{background:var(--p39-card);border-radius:4px;padding:32px 24px;text-align:center;border:1px solid var(--p39-line-soft);transition:transform .3s,border-color .3s}
.p39-contact-tile:hover{transform:translateY(-3px);border-color:var(--p39-blue)}
.p39-contact-tile__icon{width:54px;height:54px;margin:0 auto 14px;background:var(--p39-sky);border-radius:50%;display:grid;place-items:center;color:var(--p39-blue);font-size:22px}
.p39-contact-tile__title{font-size:13px;color:var(--p39-ink);font-weight:700;margin:0;letter-spacing:.04em}
.p39-contact-tile__sub{font-size:10.5px;color:var(--p39-ink-soft);margin-top:4px;letter-spacing:.04em}

/* ===== FOOTER ===== */
.p39-foot{background:#fff;border-top:1px solid var(--p39-line);padding:48px 36px 24px;margin-top:80px}
.p39-foot__inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 2fr;gap:48px;align-items:flex-start;padding-bottom:36px;border-bottom:1px solid var(--p39-line-soft)}
.p39-foot__brand strong{display:block;font-weight:900;font-size:18px;color:var(--p39-blue-dark);letter-spacing:.12em;margin-bottom:6px}
.p39-foot__brand small{font-size:10.5px;color:var(--p39-ink-soft);letter-spacing:.04em;line-height:1.9;display:block}
.p39-foot__nav{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;font-size:11.5px}
.p39-foot__nav a{color:var(--p39-ink);display:block;padding:5px 0;letter-spacing:.04em}
.p39-foot__nav a:hover{color:var(--p39-blue)}
.p39-foot__nav b{display:block;color:var(--p39-blue-dark);font-weight:700;letter-spacing:.08em;font-size:10px;margin-bottom:8px}
.p39-foot__base{max-width:1200px;margin:0 auto;padding-top:24px;display:flex;justify-content:space-between;font-size:10px;color:var(--p39-mute);letter-spacing:.04em}

/* ===== Reveal アニメ ===== */
.p39-motion-ready .p39-reveal{opacity:0;transform:translateY(20px);transition:opacity .8s ease,transform .8s ease;transition-delay:var(--p39-delay,0ms)}
.p39-motion-ready .p39-reveal.p39-in{opacity:1;transform:translateY(0)}
.p39-motion-ready .p39-hero .p39-hero__title,.p39-motion-ready .p39-hero .p39-hero__sub,.p39-motion-ready .p39-hero .p39-hero__photo{opacity:0;transform:translateY(16px);transition:opacity 1s ease,transform 1s ease}
.p39-motion-ready .p39-hero.p39-loaded .p39-hero__title{opacity:1;transform:translateY(0);transition-delay:.1s}
.p39-motion-ready .p39-hero.p39-loaded .p39-hero__sub{opacity:1;transform:translateY(0);transition-delay:.25s}
.p39-motion-ready .p39-hero.p39-loaded .p39-hero__photo{opacity:1;transform:translateY(0);transition-delay:.4s}

/* ===== Responsive ===== */
@media (max-width:920px){
  .p39-header{grid-template-columns:1fr auto;padding:12px 18px;gap:12px}
  .p39-header__nav{display:none}
  .p39-hero,.p39-section,.p39-page__hero,.p39-job__hero{padding-left:18px;padding-right:18px}
  .p39-block{grid-template-columns:1fr;padding:32px 24px;gap:24px}
  .p39-numbers{grid-template-columns:repeat(2,1fr)}
  .p39-jobs__grid{grid-template-columns:1fr}
  .p39-recruit{grid-template-columns:1fr;padding:40px 28px}
  .p39-pills{grid-template-columns:1fr}
  .p39-contact-tiles{grid-template-columns:repeat(2,1fr)}
  .p39-message__inner{grid-template-columns:1fr;padding:36px 28px}
  .p39-history__era{grid-template-columns:1fr}
  .p39-job__hero__meta{grid-template-columns:repeat(2,1fr)}
  .p39-job__hero__meta>div:nth-child(2n){border-right:0}
  .p39-reqtable th{width:120px;padding:14px 16px;font-size:11px}
  .p39-reqtable td{padding:14px 16px;font-size:12px}
  .p39-form{padding:28px 22px}
  .p39-foot__inner{grid-template-columns:1fr}
  .p39-foot__nav{grid-template-columns:repeat(2,1fr)}
  .p39-foot__base{flex-direction:column;gap:6px}
  .p39-day__row{grid-template-columns:80px 1fr;gap:20px}
  .p39-day::before{left:50px}
  .p39-page__hero__inner{flex-direction:column;align-items:flex-start;gap:20px}
  .p39-voice{grid-template-columns:1fr;text-align:center}
  .p39-voice__photo{width:120px;justify-self:center}
}
