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

/* 真似元: recruit.yamatojk.co.jp/ (ヤマト住建 新卒・中途採用情報サイト)
   観察結果:
   - ヘッダ: 左に小ロゴ + RECRUTING SITE、右に「採用SNSはこちら」(SNSアイコン3つ)
     + 角丸ピル状「新卒エントリー →」(青) と「中途エントリー →」(濃い青/紫)
   - 各ページの大型タイトル: 英語(Company / Message / Our Jobs / Entry 等)
     ヤマトブルー、太字、下に丸ぽち + 日本語サブタイトル
   - 写真は上部全幅で、青のオーバーレイ
   - 採用ステップ(3ステップ)の番号付きリスト
   - 卒年カード: 青色背景の大型カード(2027年卒など)に白の角丸ピル CTA
   - フッタ: 白背景、3列のリンク、左にロゴ+RECRUITING SITE+住所
   - 主色: #2856E0 系のロイヤルブルー / 中途は #4C58D9 系の紫寄りブルー / 白
*/
:root{
  --p45-bg:#fff;
  --p45-ink:#111;
  --p45-ink-soft:#3a3f4a;
  --p45-mute:#7a8090;
  --p45-line:#e4e7ee;
  --p45-paper:#f5f7fb;
  --p45-blue:#2856E0;        /* 新卒・メイン */
  --p45-blue-deep:#1A3FB8;
  --p45-blue-mid:#3D6BF0;
  --p45-purple:#4C58D9;      /* 中途 */
  --p45-overlay:rgba(40,86,224,.62);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{background:var(--p45-bg);color:var(--p45-ink);font-family:var(--p45-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}

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

.p45-header{position:sticky;top:0;z-index:30;background:#fff;border-bottom:1px solid var(--p45-line);padding:14px 24px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:24px}
.p45-header__brand{display:flex;align-items:center;gap:14px;text-decoration:none;color:var(--p45-ink)}
.p45-header__brand__mark{width:34px;height:34px;border-radius:50%;background:var(--p45-blue);display:grid;place-items:center;color:#fff;font-family:var(--p45-font-display);font-weight:800;font-size:14px;letter-spacing:.02em}
.p45-header__brand__txt{display:flex;flex-direction:column;line-height:1.15}
.p45-header__brand__txt strong{font-family:var(--p45-font-body);font-weight:700;font-size:13.5px;color:var(--p45-ink);letter-spacing:.04em}
.p45-header__brand__txt small{font-family:var(--p45-font-display);font-weight:600;font-size:10px;letter-spacing:.18em;color:var(--p45-mute);margin-top:3px}
.p45-header__util{display:flex;align-items:center;gap:12px;font-size:12px}
.p45-header__sns{display:flex;align-items:center;gap:10px;background:var(--p45-paper);padding:8px 14px;border-radius:30px;font-size:11.5px;color:var(--p45-ink-soft);font-weight:600}
.p45-header__sns__icons{display:flex;gap:6px}
.p45-header__sns__icons a{width:22px;height:22px;border-radius:50%;background:#fff;display:grid;place-items:center;color:var(--p45-blue);font-size:10px;font-weight:700;border:1px solid var(--p45-line)}
.p45-header__cta{display:flex;gap:10px}
.p45-header__cta a{display:inline-flex;align-items:center;gap:8px;padding:11px 20px;border-radius:30px;font-family:var(--p45-font-body);font-weight:700;font-size:12px;letter-spacing:.04em;color:#fff}
.p45-header__cta a.p45-cta--new{background:var(--p45-blue)}
.p45-header__cta a.p45-cta--mid{background:var(--p45-purple)}
.p45-header__cta a::after{content:"→";font-size:11px}
.p45-header__hb{width:42px;height:42px;background:#3c4250;border:0;cursor:pointer;display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;border-radius:6px}
.p45-header__hb span{display:block;width:18px;height:2px;background:#fff}

/* ===== HERO (top) ===== */
.p45-hero{position:relative;background:#fff;overflow:hidden;padding:60px 24px 0}
.p45-hero__inner{max-width:1180px;margin:0 auto;position:relative}
.p45-hero__copy{font-family:var(--p45-font-body);font-weight:900;font-size:clamp(28px,4.2vw,52px);line-height:1.4;letter-spacing:.04em;color:var(--p45-blue);margin:0 0 22px}
.p45-hero__copy small{display:block;font-family:var(--p45-font-display);font-weight:700;font-size:13px;letter-spacing:.18em;color:var(--p45-mute);margin-bottom:10px}
.p45-hero__lead{font-size:14.5px;line-height:1.95;color:var(--p45-ink-soft);max-width:60ch;margin:0 0 36px}
.p45-hero__photo{position:relative;width:100%;height:min(46vh,420px);overflow:hidden;border-radius:0}
.p45-hero__photo img{width:100%;height:100%;object-fit:cover}
.p45-hero__photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(40,86,224,.18))}

/* ===== ヒーロー直下 青ブロック (ヤマトの大型青エリアを借用) ===== */
.p45-bigblock{background:var(--p45-blue);color:#fff;padding:60px 24px;margin-top:0}
.p45-bigblock__inner{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.p45-bigblock h2{font-family:var(--p45-font-display);font-weight:800;font-size:clamp(34px,4vw,52px);letter-spacing:.04em;margin:0 0 16px;line-height:1.2}
.p45-bigblock h2 small{display:block;font-family:var(--p45-font-body);font-weight:600;font-size:14px;letter-spacing:.1em;color:#cfdaff;margin-top:8px}
.p45-bigblock p{font-size:14px;line-height:1.95;color:#e6ecff;margin:0 0 24px;max-width:48ch}
.p45-bigblock__cta{display:inline-flex;align-items:center;gap:10px;background:#fff;color:var(--p45-blue);padding:14px 28px;border-radius:40px;font-family:var(--p45-font-body);font-weight:700;font-size:13.5px;letter-spacing:.04em}
.p45-bigblock__cta::after{content:"→"}
.p45-bigblock__nums{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.p45-bigblock__num{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);padding:24px 22px;border-radius:18px}
.p45-bigblock__num strong{font-family:var(--p45-font-display);font-weight:800;font-size:36px;color:#fff;display:block;line-height:1}
.p45-bigblock__num strong em{font-style:normal;font-size:14px;font-weight:600;margin-left:4px;color:#cfdaff}
.p45-bigblock__num span{display:block;font-size:12.5px;color:#cfdaff;margin-top:8px;letter-spacing:.04em}
.p45-bigblock__num small{display:block;font-size:11px;color:#a8b6e8;margin-top:4px}

/* ===== ページタイトル(英語大見出し+丸ぽち+日本語サブ) ===== */
.p45-pagetitle{padding:60px 24px 24px;background:#fff}
.p45-pagetitle__inner{max-width:1180px;margin:0 auto}
.p45-pagetitle h1{font-family:var(--p45-font-display);font-weight:800;font-size:clamp(40px,6vw,72px);color:var(--p45-blue);margin:0;letter-spacing:.02em;line-height:1.05}
.p45-pagetitle__sub{display:flex;align-items:center;gap:10px;font-size:13.5px;font-weight:600;color:var(--p45-ink);margin-top:14px;letter-spacing:.04em}
.p45-pagetitle__sub::before{content:"";display:inline-block;width:14px;height:14px;border-radius:50%;border:2px solid var(--p45-blue);background:transparent}

/* ===== トップ: セクションA (採用メッセージ) ===== */
.p45-section{padding:80px 24px;background:#fff}
.p45-section--paper{background:var(--p45-paper)}
.p45-section__inner{max-width:1180px;margin:0 auto}
.p45-section__head{margin-bottom:48px}
.p45-section__head h2{font-family:var(--p45-font-display);font-weight:800;font-size:clamp(36px,4.8vw,60px);color:var(--p45-blue);margin:0;letter-spacing:.02em;line-height:1.1}
.p45-section__head__sub{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:600;color:var(--p45-ink);margin-top:12px}
.p45-section__head__sub::before{content:"";display:inline-block;width:12px;height:12px;border-radius:50%;border:2px solid var(--p45-blue)}

/* メッセージカード(トップ用ダイジェスト) */
.p45-msgcard{display:grid;grid-template-columns:360px 1fr;gap:48px;align-items:center;background:#fff;border:1px solid var(--p45-line);border-radius:20px;padding:36px;overflow:hidden}
.p45-msgcard__photo img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:14px}
.p45-msgcard__body h3{font-family:var(--p45-font-body);font-weight:800;font-size:clamp(20px,2.4vw,28px);color:var(--p45-ink);margin:0 0 16px;line-height:1.5}
.p45-msgcard__body p{font-size:14.5px;line-height:1.95;color:var(--p45-ink-soft);margin:0 0 20px}
.p45-msgcard__body__sign{font-size:12.5px;color:var(--p45-mute);font-weight:600}
.p45-msgcard__body__sign b{display:block;font-size:15px;color:var(--p45-ink);margin-top:2px}
.p45-msgcard__more{display:inline-flex;align-items:center;gap:8px;margin-top:18px;font-family:var(--p45-font-body);font-weight:700;font-size:12.5px;color:var(--p45-blue);border:1px solid var(--p45-blue);padding:10px 24px;border-radius:30px}
.p45-msgcard__more::after{content:"→"}

/* 職種カード3つ(トップのOur Jobs ダイジェスト) */
.p45-jobs__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.p45-jobcard{background:#fff;border:1px solid var(--p45-line);border-radius:18px;overflow:hidden;display:flex;flex-direction:column;transition:transform .25s ease, box-shadow .25s ease}
.p45-jobcard:hover{transform:translateY(-3px);box-shadow:0 12px 32px -16px rgba(40,86,224,.32)}
.p45-jobcard__photo{aspect-ratio:4/3;overflow:hidden;position:relative;background:var(--p45-blue)}
.p45-jobcard__photo img{width:100%;height:100%;object-fit:cover;opacity:.88}
.p45-jobcard__photo::after{content:"";position:absolute;inset:0;background:linear-gradient(160deg,rgba(40,86,224,.32),transparent 50%)}
.p45-jobcard__title{font-family:var(--p45-font-body);font-weight:800;font-size:22px;color:var(--p45-ink);text-align:center;padding:24px 16px 8px;margin:0}
.p45-jobcard__title::after{content:"";display:block;width:32px;height:2px;background:var(--p45-blue);margin:14px auto 0}
.p45-jobcard__sub{font-size:13px;color:var(--p45-ink-soft);text-align:center;padding:0 24px;margin:8px 0 0;line-height:1.85}
.p45-jobcard__meta{display:flex;justify-content:center;gap:18px;flex-wrap:wrap;font-size:11.5px;color:var(--p45-mute);margin:18px 0 0;padding:0 24px}
.p45-jobcard__meta b{color:var(--p45-ink);margin-right:4px}
.p45-jobcard__cta{display:inline-flex;align-items:center;gap:8px;margin:22px auto 28px;padding:10px 24px;border-radius:30px;border:1px solid var(--p45-line);background:#fff;color:var(--p45-ink-soft);font-size:12px;font-weight:600}
.p45-jobcard__cta::after{content:"→";color:var(--p45-blue)}

/* 卒年/応募タイル */
.p45-entrygrid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:18px}
.p45-entrytile{background:var(--p45-blue);color:#fff;padding:36px;border-radius:18px;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;min-height:180px}
.p45-entrytile--mid{background:var(--p45-purple)}
.p45-entrytile h3{font-family:var(--p45-font-display);font-weight:800;font-size:clamp(28px,3.4vw,42px);margin:0 0 4px;letter-spacing:.02em}
.p45-entrytile h3 small{font-size:14px;font-weight:600;margin-left:4px}
.p45-entrytile p{font-size:12.5px;color:#dfe7ff;margin:0 0 18px;letter-spacing:.04em}
.p45-entrytile a{background:#fff;color:var(--p45-blue);padding:11px 22px;border-radius:30px;font-weight:700;font-size:12.5px;display:inline-flex;align-items:center;gap:8px}
.p45-entrytile--mid a{color:var(--p45-purple)}
.p45-entrytile a::after{content:"→"}
.p45-entrytile--featured{grid-column:span 2;flex-direction:row;justify-content:space-between;align-items:center;padding:36px 48px}
.p45-entrytile--featured>div{flex:1}

/* ===== トップ: 数字バッジ4つ(横並び) ===== */
.p45-numrow{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;background:#fff;padding:0}
.p45-numtile{padding:30px 24px;border:1px solid var(--p45-line);border-radius:16px;background:#fff;text-align:center}
.p45-numtile strong{font-family:var(--p45-font-display);font-weight:800;font-size:42px;color:var(--p45-blue);line-height:1;display:block}
.p45-numtile strong em{font-style:normal;font-size:16px;font-weight:700;color:var(--p45-blue);margin-left:4px}
.p45-numtile span{display:block;margin-top:10px;font-weight:700;font-size:13px;color:var(--p45-ink)}
.p45-numtile small{display:block;margin-top:4px;font-size:11px;color:var(--p45-mute)}

/* ===== Voices (社員の声 ダイジェスト) ===== */
.p45-voices{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.p45-voice{display:grid;grid-template-columns:140px 1fr;gap:20px;background:#fff;border:1px solid var(--p45-line);border-radius:18px;padding:20px;align-items:center}
.p45-voice img{width:140px;height:140px;object-fit:cover;border-radius:50%}
.p45-voice b{display:block;font-size:15px;color:var(--p45-ink);font-weight:800;margin-bottom:2px}
.p45-voice small{display:block;font-size:11.5px;color:var(--p45-mute);margin-bottom:10px}
.p45-voice p{font-size:13px;line-height:1.85;color:var(--p45-ink-soft);margin:0}

/* ===== 大型CTAバナー(top下部) ===== */
.p45-ctaband{background:var(--p45-blue);color:#fff;padding:60px 24px;text-align:center}
.p45-ctaband h2{font-family:var(--p45-font-display);font-weight:800;font-size:clamp(32px,4vw,52px);margin:0 0 12px;letter-spacing:.02em}
.p45-ctaband p{font-size:14px;color:#cfdaff;margin:0 0 28px}
.p45-ctaband__btns{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}
.p45-ctaband__btns a{display:inline-flex;align-items:center;gap:10px;background:#fff;color:var(--p45-blue);padding:14px 32px;border-radius:40px;font-weight:700;font-size:13.5px}
.p45-ctaband__btns a:nth-child(2){background:transparent;color:#fff;border:1px solid #fff}
.p45-ctaband__btns a::after{content:"→"}

/* ===== FOOTER ===== */
.p45-foot{background:#fff;color:var(--p45-ink-soft);padding:60px 24px 30px;border-top:1px solid var(--p45-line)}
.p45-foot__inner{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1.2fr 2fr;gap:48px;align-items:flex-start}
.p45-foot__brand{display:flex;flex-direction:column;gap:6px}
.p45-foot__brand__line{display:flex;align-items:center;gap:14px}
.p45-foot__brand__mark{width:38px;height:38px;border-radius:50%;background:var(--p45-blue);display:grid;place-items:center;color:#fff;font-family:var(--p45-font-display);font-weight:800;font-size:15px}
.p45-foot__brand__name{font-family:var(--p45-font-body);font-weight:800;font-size:18px;color:var(--p45-ink)}
.p45-foot__brand__site{font-family:var(--p45-font-display);font-weight:700;font-size:12px;letter-spacing:.16em;color:var(--p45-mute);margin-top:8px}
.p45-foot__brand__addr{font-size:11.5px;color:var(--p45-mute);line-height:1.8;margin-top:14px}
.p45-foot__cols{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;font-size:12.5px}
.p45-foot__col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.p45-foot__col a{font-size:12.5px;color:var(--p45-ink-soft);line-height:1.6}
.p45-foot__col a:hover{color:var(--p45-blue)}
.p45-foot__bot{max-width:1180px;margin:36px auto 0;padding-top:20px;border-top:1px solid var(--p45-line);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;font-size:11px;color:var(--p45-mute)}

/* ===== 下層共通 (page) ===== */
.p45-page{background:#fff}
.p45-page__hero{position:relative;padding:0;margin:0;overflow:hidden;background:var(--p45-blue)}
.p45-page__hero__img{position:relative;height:280px;overflow:hidden;background:#0a1f5a}
.p45-page__hero__img img{width:100%;height:100%;object-fit:cover;opacity:.55}
.p45-page__hero__img::after{content:"";position:absolute;inset:0;background:var(--p45-overlay)}
.p45-page__hero__title{max-width:1180px;margin:-60px auto 0;padding:0 24px;position:relative;z-index:2}
.p45-page__hero__title h1{font-family:var(--p45-font-display);font-weight:800;font-size:clamp(44px,6.4vw,82px);color:var(--p45-blue);margin:0;letter-spacing:.02em;line-height:1.05;background:#fff;padding:30px 30px 0;display:inline-block}
.p45-page__hero__title__sub{display:flex;align-items:center;gap:10px;font-size:13.5px;font-weight:600;color:var(--p45-ink);background:#fff;padding:6px 30px 26px;letter-spacing:.04em}
.p45-page__hero__title__sub::before{content:"";display:inline-block;width:14px;height:14px;border-radius:50%;border:2px solid var(--p45-blue)}

.p45-page__crumb{font-size:11.5px;color:var(--p45-mute);max-width:1180px;margin:18px auto 0;padding:0 24px;letter-spacing:.06em}
.p45-page__crumb a{color:var(--p45-mute)}
.p45-page__crumb a:hover{color:var(--p45-blue)}
.p45-page__inner{max-width:1180px;margin:0 auto;padding:48px 24px 64px}
.p45-page__lead{font-size:15px;line-height:1.95;color:var(--p45-ink-soft);margin:0 0 40px;max-width:64ch}

/* ===== JOBS index ===== */
/* 既存 .p45-jobs__grid を流用しつつ、jobs ページ用に追加スタイル */
.p45-page .p45-jobs__grid{margin-top:24px}

/* ===== JOBS detail ===== */
.p45-job__hero{position:relative;background:#fff;padding:0;margin:0;overflow:hidden}
.p45-job__hero__img{height:340px;overflow:hidden;position:relative;background:#0a1f5a}
.p45-job__hero__img img{width:100%;height:100%;object-fit:cover;opacity:.7}
.p45-job__hero__img::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--p45-overlay),rgba(76,88,217,.45))}
.p45-job__hero__inner{max-width:1180px;margin:-80px auto 0;padding:30px;background:#fff;position:relative;z-index:2;border-radius:18px 18px 0 0;border:1px solid var(--p45-line);border-bottom:0}
.p45-job__hero__code{font-family:var(--p45-font-display);font-weight:700;font-size:12px;letter-spacing:.18em;color:var(--p45-blue);margin:0 0 8px}
.p45-job__hero__inner h1{font-family:var(--p45-font-body);font-weight:800;font-size:clamp(28px,4vw,42px);color:var(--p45-ink);margin:0 0 8px;letter-spacing:.02em;line-height:1.3}
.p45-job__hero__inner h1 small{display:block;font-size:14px;color:var(--p45-ink-soft);font-weight:600;margin-top:6px;letter-spacing:.02em}
.p45-job__hero__lead{font-size:14.5px;line-height:1.95;color:var(--p45-ink-soft);margin:18px 0 24px}
.p45-job__hero__meta{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:18px 0 0;border-top:1px solid var(--p45-line)}
.p45-job__hero__meta dt{font-family:var(--p45-font-display);font-size:10.5px;letter-spacing:.18em;color:var(--p45-mute);font-weight:700;margin:0 0 6px}
.p45-job__hero__meta dd{margin:0;font-size:14px;font-weight:700;color:var(--p45-ink)}

.p45-job__sec{max-width:1180px;margin:0 auto;padding:0 30px 56px;background:#fff;border-left:1px solid var(--p45-line);border-right:1px solid var(--p45-line)}
.p45-job__sec:last-of-type{border-bottom:1px solid var(--p45-line);border-radius:0 0 18px 18px;padding-bottom:48px}
.p45-job__sec__head{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:700;color:var(--p45-blue);margin:0 0 22px;padding-top:40px;border-top:1px solid var(--p45-line)}
.p45-job__sec__head::before{content:"";display:inline-block;width:12px;height:12px;border-radius:50%;border:2px solid var(--p45-blue)}
.p45-job__sec__head__en{font-family:var(--p45-font-display);font-weight:800;font-size:13px;letter-spacing:.18em;color:var(--p45-mute);margin-left:8px;border-left:1px solid var(--p45-line);padding-left:10px}
.p45-job__sec h2{font-family:var(--p45-font-body);font-weight:800;font-size:22px;color:var(--p45-ink);margin:0 0 18px;line-height:1.5}
.p45-job__sec p{font-size:14.5px;line-height:1.95;color:var(--p45-ink);margin:0 0 14px}
.p45-job__sec ul{padding-left:0;list-style:none;margin:0;font-size:14.5px;line-height:1.95}
.p45-job__sec ul li{padding-left:22px;position:relative;margin:0 0 6px}
.p45-job__sec ul li::before{content:"";position:absolute;left:0;top:.7em;width:10px;height:10px;border-radius:50%;background:var(--p45-blue)}

/* 1日の流れ — 番号付き縦タイムライン */
.p45-day{display:flex;flex-direction:column;gap:14px;margin-top:16px}
.p45-day__row{display:grid;grid-template-columns:110px 1fr;gap:18px;align-items:flex-start;border:1px solid var(--p45-line);border-radius:14px;overflow:hidden;background:#fff}
.p45-day__time{background:var(--p45-blue);color:#fff;font-family:var(--p45-font-display);font-weight:800;font-size:18px;letter-spacing:.04em;display:flex;align-items:center;justify-content:center;padding:18px 0;align-self:stretch}
.p45-day__body{padding:18px 22px}
.p45-day__body h4{margin:0 0 6px;font-size:14.5px;font-weight:800;color:var(--p45-ink);font-family:var(--p45-font-body)}
.p45-day__body p{margin:0;font-size:13px;color:var(--p45-ink-soft);line-height:1.75}

/* ===== requirements table ===== */
.p45-reqtable{width:100%;border-collapse:collapse;font-size:14px;border-top:2px solid var(--p45-blue);background:#fff}
.p45-reqtable tr{border-bottom:1px solid var(--p45-line)}
.p45-reqtable th{font-family:var(--p45-font-body);font-weight:700;font-size:13px;color:var(--p45-blue);text-align:left;padding:22px 20px 22px 0;width:200px;vertical-align:top;background:#fff}
.p45-reqtable td{padding:22px 0;color:var(--p45-ink);line-height:1.95}

/* ===== FAQ ===== */
.p45-faqlist{border-top:2px solid var(--p45-blue);max-width:920px;margin:0 auto}
.p45-faqitem{border-bottom:1px solid var(--p45-line);background:#fff}
.p45-faqitem summary{font-family:var(--p45-font-body);font-weight:700;font-size:15px;color:var(--p45-ink);cursor:pointer;list-style:none;padding:22px 4px;display:flex;gap:18px;align-items:flex-start}
.p45-faqitem summary::-webkit-details-marker{display:none}
.p45-faqitem summary::before{content:"Q";font-family:var(--p45-font-display);font-weight:800;color:#fff;background:var(--p45-blue);font-size:13px;width:28px;height:28px;border-radius:50%;display:grid;place-items:center;flex-shrink:0}
.p45-faqitem summary::after{content:"+";margin-left:auto;color:var(--p45-blue);font-size:22px;font-weight:300;align-self:center}
.p45-faqitem[open] summary::after{content:"−"}
.p45-faqitem div{padding:0 4px 22px 46px;font-size:14px;color:var(--p45-ink-soft);line-height:1.95;display:flex;gap:18px}
.p45-faqitem div::before{content:"A";font-family:var(--p45-font-display);font-weight:800;color:#fff;background:var(--p45-purple);font-size:13px;width:28px;height:28px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;margin-left:-46px}

/* ===== Apply form ===== */
.p45-applyhead{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;background:var(--p45-paper);padding:30px;border-radius:18px;margin:0 0 40px}
.p45-applyhead h3{font-family:var(--p45-font-body);font-weight:800;font-size:15px;color:var(--p45-ink);margin:0 0 12px;grid-column:1/-1;display:flex;align-items:center;gap:8px}
.p45-applyhead h3::before{content:"";display:inline-block;width:12px;height:12px;border-radius:50%;border:2px solid var(--p45-blue)}
.p45-applyhead__step{background:#fff;border-radius:14px;padding:18px 20px;display:flex;align-items:center;gap:14px;font-size:13px;color:var(--p45-ink-soft);border:1px solid var(--p45-line)}
.p45-applyhead__step__num{width:28px;height:28px;border-radius:50%;background:var(--p45-blue);color:#fff;display:grid;place-items:center;font-family:var(--p45-font-display);font-weight:800;font-size:13px;flex-shrink:0}

.p45-form{display:grid;gap:22px;max-width:760px;margin:0 auto;background:#fff;border:1px solid var(--p45-line);padding:36px;border-radius:18px}
.p45-form__note{font-size:12.5px;color:var(--p45-ink-soft);background:var(--p45-paper);padding:16px 22px;border-radius:10px;max-width:760px;margin:0 auto 24px;line-height:1.85}
.p45-form label{display:block;font-family:var(--p45-font-body);font-weight:700;font-size:13px;color:var(--p45-ink);margin:0 0 8px;letter-spacing:.02em}
.p45-form label small{font-weight:700;color:#fff;background:var(--p45-blue);padding:2px 8px;border-radius:10px;margin-left:8px;font-size:10.5px}
.p45-form input,.p45-form select,.p45-form textarea{width:100%;font:inherit;padding:14px 16px;border:1px solid var(--p45-line);background:#fff;color:var(--p45-ink);border-radius:10px;font-size:14px}
.p45-form input:focus,.p45-form select:focus,.p45-form textarea:focus{outline:none;border-color:var(--p45-blue);box-shadow:0 0 0 3px rgba(40,86,224,.14)}
.p45-form button{background:var(--p45-blue);color:#fff;padding:16px 56px;font-family:var(--p45-font-body);font-weight:700;font-size:14px;letter-spacing:.04em;border:0;cursor:pointer;justify-self:center;margin-top:6px;border-radius:40px;display:inline-flex;align-items:center;gap:10px}
.p45-form button::after{content:"→"}
.p45-form button:hover{background:var(--p45-blue-deep)}

/* ===== history ===== */
.p45-history{max-width:920px;margin:0 auto;border-top:2px solid var(--p45-blue)}
.p45-history__row{display:grid;grid-template-columns:130px 1fr;gap:24px;padding:22px 0;border-bottom:1px solid var(--p45-line);align-items:flex-start}
.p45-history__year{font-family:var(--p45-font-display);font-weight:800;font-size:22px;color:var(--p45-blue);letter-spacing:.02em}
.p45-history__event{font-size:14px;color:var(--p45-ink);line-height:1.85}

/* ===== Message page ===== */
.p45-message{max-width:920px;margin:0 auto}
.p45-message__lead{font-family:var(--p45-font-body);font-weight:800;font-size:clamp(20px,2.6vw,28px);line-height:1.6;color:var(--p45-blue);margin:0 0 24px;padding-bottom:24px;border-bottom:1px solid var(--p45-line)}
.p45-message__body{font-size:14.5px;line-height:2.05;color:var(--p45-ink);white-space:pre-line}
.p45-message__sign{margin-top:32px;text-align:right;font-size:13px;color:var(--p45-mute);font-weight:600}
.p45-message__sign b{display:block;font-size:17px;color:var(--p45-ink);margin-top:4px}

/* ===== motion ===== */
html.p45-motion-ready .p45-reveal{opacity:0;transform:translateY(16px);transition:opacity .8s ease var(--p45-delay,0ms),transform .8s ease var(--p45-delay,0ms)}
html.p45-motion-ready .p45-reveal.p45-in{opacity:1;transform:none}
html.p45-motion-ready .p45-hero__photo img{transition:transform 9s ease;transform:scale(1.06)}
html.p45-motion-ready .p45-hero__photo.p45-loaded img{transform:scale(1.0)}

/* ===== Responsive ===== */
@media (max-width:980px){
  .p45-header{grid-template-columns:auto auto;gap:12px;padding:12px 16px}
  .p45-header__util{display:none}
  .p45-header__hb{display:flex}
  .p45-bigblock__inner{grid-template-columns:1fr;gap:32px}
  .p45-msgcard{grid-template-columns:1fr;gap:24px;padding:24px}
  .p45-msgcard__photo img{max-width:280px;margin:0 auto}
  .p45-jobs__grid{grid-template-columns:1fr}
  .p45-entrygrid{grid-template-columns:1fr}
  .p45-entrytile--featured{grid-column:auto;flex-direction:column;align-items:flex-start;padding:30px}
  .p45-numrow{grid-template-columns:repeat(2,1fr)}
  .p45-voices{grid-template-columns:1fr}
  .p45-voice{grid-template-columns:90px 1fr}
  .p45-voice img{width:90px;height:90px}
  .p45-foot__inner{grid-template-columns:1fr;gap:32px}
  .p45-foot__cols{grid-template-columns:repeat(2,1fr)}
  .p45-page__hero__title h1{font-size:42px;padding:24px 20px 0}
  .p45-page__hero__title__sub{padding:6px 20px 20px}
  .p45-job__hero__meta{grid-template-columns:1fr 1fr}
  .p45-applyhead{grid-template-columns:1fr}
}
