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

/* 真似元: hitachi.co.jp/recruit/newgraduate/
   観察結果(キャプチャより):
   - 上部に黒帯の HITACHI ロゴ + 右上ユーティリティ(言語 / お問い合わせ / 検索)
   - その下に Hitachi Global の白いグローバルナビ(製品・ソリューション / 企業情報 / 採用)
   - 大型ヒーロー: 「What's next for our future?」+ 副題 + 4分割の現場写真
   - 「採用情報」赤いバナー(2027 新卒採用 Mypage / インターンシップ Mypage)
   - 縦並び 3 セクション: SOCIETY(社会課題を解決する事業) / JOB(多様な職種と業務) /
     CAREER(挑戦・成長を支援する人への投資) — 各セクションは左テキスト・右大型写真
   - 「日立の手応え五体感覚」の小さなリンク3枚カード
   - 社員インタビュー 4 件カード(横スクロール風)
   - 採用情報の赤帯バナー(中央寄せ・5 つの白タブボタン)
   - 「もっと日立を知る」3 枚カード
   - 手書き署名のような演出が「ごあいさつ」ページに登場(Klee One/明朝の毛筆)
   - 主色: 赤 #E60012 / 黒 #0C0C0C / 白 / グレー */
:root{
  --p12-bg:#fff;
  --p12-ink:#0c0c0c;
  --p12-ink-soft:#3a3a3a;
  --p12-mute:#7a7a7a;
  --p12-line:#e6e6e6;
  --p12-line-soft:#f0f0f0;
  --p12-paper:#f6f6f6;
  --p12-red:#E60012;
  --p12-red-dark:#B3000E;
  --p12-red-soft:#F2D7DA;
  --p12-blue:#1F3A8A; /* セカンダリ(ホバー等) */
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{background:var(--p12-bg);color:var(--p12-ink);font-family:var(--p12-font-body);font-weight:400;font-size:14px;line-height:1.8;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}

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

.p12-topbar{background:#0c0c0c;color:#fff;padding:8px 28px;display:flex;justify-content:space-between;align-items:center;font-size:11px}
.p12-topbar__logo{font-family:var(--p12-font-display);font-weight:800;font-size:22px;letter-spacing:.04em;color:#fff;display:flex;align-items:center;gap:14px}
.p12-topbar__util{display:flex;gap:18px;align-items:center;font-size:11.5px}
.p12-topbar__util a{color:#fff;display:inline-flex;gap:5px;align-items:center;opacity:.9}
.p12-topbar__util a:hover{opacity:1}
.p12-topbar__util a::before{content:"";display:inline-block;width:14px;height:14px;border:1px solid #fff;border-radius:50%}

.p12-header{position:sticky;top:0;z-index:30;background:#fff;border-bottom:1px solid var(--p12-line);padding:0 28px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:24px;min-height:54px}
.p12-header__brand{font-family:var(--p12-font-display);font-weight:600;font-size:14px;color:var(--p12-ink);letter-spacing:.02em}
.p12-header__nav{display:flex;gap:0;align-items:stretch;height:54px}
.p12-header__nav a{display:flex;align-items:center;padding:0 18px;font-size:13px;color:var(--p12-ink);font-weight:500;border-left:1px solid var(--p12-line-soft);position:relative}
.p12-header__nav a:last-child{border-right:1px solid var(--p12-line-soft)}
.p12-header__nav a.is-current{background:var(--p12-red);color:#fff}
.p12-header__nav a::after{content:" ▾";font-size:9px;color:var(--p12-mute);margin-left:6px}
.p12-header__nav a.is-current::after{color:#fff}
.p12-header__util{display:flex;gap:14px;align-items:center;font-size:11.5px;color:var(--p12-mute)}

/* ===== HERO ===== */
.p12-hero{position:relative;background:#fff;padding:48px 28px 0;border-bottom:1px solid var(--p12-line)}
.p12-hero__copy{max-width:1100px;margin:0 auto 28px}
.p12-hero__copy h1{font-family:var(--p12-font-display);font-weight:300;font-size:clamp(40px,6vw,84px);line-height:1.05;letter-spacing:-.01em;margin:0 0 14px;color:var(--p12-ink)}
.p12-hero__copy h1 em{font-style:italic;font-weight:400;color:var(--p12-ink)}
.p12-hero__copy p{font-size:16px;line-height:1.8;color:var(--p12-ink-soft);margin:0;font-weight:500}
.p12-hero__photos{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:6px;padding-bottom:36px}
.p12-hero__photos div{aspect-ratio:1/1.05;overflow:hidden;background:var(--p12-paper)}
.p12-hero__photos img{width:100%;height:100%;object-fit:cover}
.p12-hero__pause{position:absolute;right:28px;bottom:50px;width:34px;height:34px;border-radius:50%;background:rgba(0,0,0,.6);color:#fff;display:grid;place-items:center;font-size:11px}

/* ===== 採用情報 赤バナー ===== */
.p12-recruitbar{background:linear-gradient(90deg,var(--p12-red) 0%,var(--p12-red-dark) 100%);padding:32px 28px;text-align:center}
.p12-recruitbar__title{font-family:var(--p12-font-body);font-weight:700;font-size:18px;color:#fff;margin:0 0 18px;letter-spacing:.06em}
.p12-recruitbar__tabs{max-width:980px;margin:0 auto;display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
.p12-recruitbar__tabs a{background:#fff;color:var(--p12-red);padding:14px 12px;font-size:13px;font-weight:700;letter-spacing:.04em;display:flex;align-items:center;justify-content:center;gap:6px;border-radius:30px}
.p12-recruitbar__tabs a::after{content:"›";font-weight:300;color:var(--p12-red);font-size:18px}
.p12-recruitbar__tabs a.is-on{background:var(--p12-red-dark);color:#fff;border:1px solid #fff}
.p12-recruitbar__tabs a.is-on::after{color:#fff}

/* ===== 大型 Mypage ボックス2列 ===== */
.p12-mypages{max-width:1100px;margin:36px auto 0;padding:0 28px;display:grid;grid-template-columns:1fr 1fr;gap:14px}
.p12-mypages a{display:flex;justify-content:space-between;align-items:center;padding:24px 28px;background:#fff;border:1px solid var(--p12-line);font-weight:700;font-size:15px;color:var(--p12-ink)}
.p12-mypages a:hover{border-color:var(--p12-red)}
.p12-mypages a::after{content:"›";color:var(--p12-red);font-size:22px;font-weight:300}
.p12-mypages a small{display:block;font-family:var(--p12-font-display);font-size:10px;font-weight:600;color:var(--p12-mute);letter-spacing:.16em;margin-bottom:4px}

/* ===== Hitachi Next Stories(中央寄せのフルワイドリンク) ===== */
.p12-nextstories{max-width:1100px;margin:14px auto 60px;padding:0 28px}
.p12-nextstories a{display:flex;justify-content:space-between;align-items:center;padding:22px 28px;background:var(--p12-paper);font-weight:700;font-size:15px;color:var(--p12-ink)}
.p12-nextstories a::after{content:"›";color:var(--p12-red);font-size:22px;font-weight:300}

/* ===== 大型イントロ(写真3枚 + 縦書きリード) ===== */
.p12-intro{max-width:1100px;margin:0 auto 80px;padding:0 28px;display:grid;grid-template-columns:1fr 1.2fr;gap:60px;align-items:start}
.p12-intro__photos{display:grid;grid-template-columns:1fr 1fr;gap:14px;grid-auto-rows:200px}
.p12-intro__photos div{overflow:hidden;background:var(--p12-paper)}
.p12-intro__photos div:nth-child(1){grid-row:span 2}
.p12-intro__photos div:nth-child(3){grid-column:span 2}
.p12-intro__photos img{width:100%;height:100%;object-fit:cover}
.p12-intro__text h2{font-family:var(--p12-font-body);font-weight:700;font-size:clamp(24px,2.6vw,34px);line-height:1.55;letter-spacing:.04em;margin:0 0 28px;color:var(--p12-ink)}
.p12-intro__text p{font-size:14.5px;line-height:2;color:var(--p12-ink-soft);margin:0 0 16px}
.p12-intro__links{margin-top:30px;border-top:1px solid var(--p12-line);padding-top:20px}
.p12-intro__links h3{font-size:13px;font-weight:700;margin:0 0 12px;color:var(--p12-red);letter-spacing:.04em}
.p12-intro__links a{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border:1px solid var(--p12-line);font-size:13px;color:var(--p12-ink);margin-bottom:8px}
.p12-intro__links a small{display:block;font-size:11px;color:var(--p12-mute);margin-top:3px}
.p12-intro__links a::after{content:"›";color:var(--p12-red);font-size:18px;font-weight:300}

/* ===== 3大セクション SOCIETY / JOB / CAREER ===== */
.p12-block{max-width:1100px;margin:0 auto;padding:80px 28px;display:grid;grid-template-columns:0.85fr 1.15fr;gap:60px;align-items:center}
.p12-block--reverse{grid-template-columns:1.15fr 0.85fr}
.p12-block--reverse .p12-block__txt{order:2}
.p12-block__txt small{font-family:var(--p12-font-display);font-weight:700;font-size:14px;letter-spacing:.2em;color:var(--p12-red);display:block;margin-bottom:14px}
.p12-block__txt h2{font-family:var(--p12-font-body);font-weight:700;font-size:clamp(30px,3.4vw,44px);line-height:1.4;letter-spacing:.02em;margin:0 0 24px;color:var(--p12-ink)}
.p12-block__txt p{font-size:14.5px;line-height:2;color:var(--p12-ink-soft);margin:0 0 18px}
.p12-block__txt a.p12-block__more{display:inline-flex;align-items:center;gap:10px;font-size:13px;font-weight:700;color:var(--p12-red);border:1px solid var(--p12-red);padding:10px 22px;margin-top:14px;border-radius:30px}
.p12-block__txt a.p12-block__more::after{content:"›";font-weight:300;font-size:16px}
.p12-block__img{overflow:hidden;background:var(--p12-paper);aspect-ratio:4/3}
.p12-block__img img{width:100%;height:100%;object-fit:cover}

/* ===== 「日立の人」カード(横スクロール風4枚) ===== */
.p12-people{max-width:1100px;margin:0 auto;padding:40px 28px 80px}
.p12-people__title{font-family:var(--p12-font-body);font-weight:700;font-size:18px;color:var(--p12-ink);margin:0 0 24px;text-align:center;letter-spacing:.04em}
.p12-people__title em{font-style:normal;color:var(--p12-red)}
.p12-people__row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.p12-people__card{background:#fff;border:1px solid var(--p12-line);padding:0;text-decoration:none;color:var(--p12-ink);display:flex;flex-direction:column}
.p12-people__card__img{aspect-ratio:4/3;overflow:hidden;background:var(--p12-paper)}
.p12-people__card__img img{width:100%;height:100%;object-fit:cover}
.p12-people__card__body{padding:14px 16px 18px;flex:1;display:flex;flex-direction:column;gap:6px}
.p12-people__card__body small{font-family:var(--p12-font-display);font-weight:700;font-size:10px;color:var(--p12-red);letter-spacing:.14em}
.p12-people__card__body strong{font-size:13.5px;font-weight:700;color:var(--p12-ink);line-height:1.55}
.p12-people__more{display:block;text-align:right;margin-top:18px;font-size:12px;color:var(--p12-red);font-weight:700}

/* ===== 採用情報 大型赤バナー(下部) ===== */
.p12-recruitbar2{background:var(--p12-red);padding:48px 28px;color:#fff;text-align:center;margin-top:60px}
.p12-recruitbar2 strong{display:block;font-size:22px;font-weight:700;margin-bottom:8px}
.p12-recruitbar2 small{font-size:12px;opacity:.85;display:block;margin-bottom:24px}
.p12-recruitbar2 .p12-recruitbar__tabs{max-width:880px}

/* ===== 「もっと日立を知る」3枚カード ===== */
.p12-more{max-width:1100px;margin:60px auto;padding:0 28px}
.p12-more__title{font-family:var(--p12-font-body);font-weight:700;font-size:24px;text-align:center;margin:0 0 30px;color:var(--p12-ink)}
.p12-more__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.p12-more__card{background:#fff;border:1px solid var(--p12-line);padding:0;text-decoration:none;color:var(--p12-ink)}
.p12-more__card__img{aspect-ratio:16/10;overflow:hidden;background:var(--p12-paper)}
.p12-more__card__img img{width:100%;height:100%;object-fit:cover}
.p12-more__card__body{padding:20px 22px 24px}
.p12-more__card__body h3{font-family:var(--p12-font-display);font-weight:700;font-size:18px;color:var(--p12-ink);margin:0 0 8px;letter-spacing:.02em}
.p12-more__card__body p{font-size:12.5px;line-height:1.7;color:var(--p12-ink-soft);margin:0 0 14px}
.p12-more__card__body .p12-more__btn{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--p12-red);border:1px solid var(--p12-red);padding:6px 14px;border-radius:30px}
.p12-more__card__body .p12-more__btn::after{content:"›";font-weight:300;font-size:14px}

/* ===== FOOTER ===== */
.p12-foot{background:#fff;color:var(--p12-ink);padding:0;border-top:1px solid var(--p12-line)}
.p12-foot__home{background:var(--p12-red);color:#fff;padding:18px 28px;font-family:var(--p12-font-display);font-weight:700;font-size:14px;letter-spacing:.06em;text-align:left;max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:8px}
.p12-foot__home::after{content:"›";font-size:18px;font-weight:300}
.p12-foot__cols{max-width:1200px;margin:0 auto;padding:32px 28px 24px;display:grid;grid-template-columns:repeat(4,1fr);gap:32px;font-size:12.5px}
.p12-foot__col h4{font-family:var(--p12-font-body);font-weight:700;font-size:13px;color:var(--p12-ink);margin:0 0 14px;display:flex;align-items:center;gap:8px}
.p12-foot__col h4::after{content:"›";color:var(--p12-mute);font-weight:300;font-size:14px}
.p12-foot__col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.p12-foot__col a{font-size:12px;color:var(--p12-ink-soft);display:flex;justify-content:space-between;align-items:center}
.p12-foot__col a::after{content:"›";color:var(--p12-mute);font-weight:300;font-size:14px}
.p12-foot__col a:hover{color:var(--p12-red)}
.p12-foot__brand{max-width:1200px;margin:0 auto;padding:24px 28px 24px;border-top:1px solid var(--p12-line);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;font-size:11px;color:var(--p12-mute)}
.p12-foot__brand strong{font-family:var(--p12-font-display);font-weight:800;font-size:18px;color:var(--p12-ink);letter-spacing:.04em}
.p12-foot__social{display:flex;gap:10px}
.p12-foot__social span{width:24px;height:24px;border-radius:50%;background:var(--p12-paper);display:grid;place-items:center;font-size:10px;color:var(--p12-ink)}
.p12-foot__legal{max-width:1200px;margin:0 auto;padding:8px 28px 20px;font-size:10.5px;color:var(--p12-mute);display:flex;flex-wrap:wrap;gap:18px;justify-content:flex-end}

@media (max-width:880px){
  .p12-topbar{padding:6px 14px}
  .p12-header{grid-template-columns:1fr auto;padding:0 14px}
  .p12-header__nav{display:none}
  .p12-hero{padding:28px 14px 0}
  .p12-hero__photos{grid-template-columns:repeat(2,1fr)}
  .p12-recruitbar__tabs{grid-template-columns:1fr 1fr}
  .p12-mypages{grid-template-columns:1fr;padding:0 14px}
  .p12-intro,.p12-block,.p12-block--reverse{grid-template-columns:1fr;gap:30px;padding:40px 14px}
  .p12-block--reverse .p12-block__txt{order:0}
  .p12-people__row,.p12-more__grid{grid-template-columns:1fr 1fr}
  .p12-foot__cols{grid-template-columns:1fr 1fr;padding:24px 14px}
}

/* ============================================================
   下層ページ共通(日立 企業情報・ごあいさつ ページ準拠)
   ------------------------------------------------------------
   - 上部にパンくず + 大見出し
   - 「ごあいさつ」風: 左本文 + 右人物写真 + 末尾に手書き署名
   - 「企業情報」風: 数字スタッツバー + サムネカードグリッド
   ============================================================ */
.p12-page{background:#fff;padding-top:0}
.p12-page__head{max-width:1100px;margin:0 auto;padding:36px 28px 24px}
.p12-page__crumb{font-size:12px;color:var(--p12-mute);margin:0 0 22px;display:flex;gap:8px;align-items:center}
.p12-page__crumb a{color:var(--p12-mute)}
.p12-page__crumb a:first-child{color:var(--p12-red)}
.p12-page__crumb a:first-child::before{content:"›";color:var(--p12-red);margin-right:4px}
.p12-page__crumb span{color:var(--p12-mute)}
.p12-page__title{font-family:var(--p12-font-body);font-weight:700;font-size:clamp(32px,4.2vw,52px);letter-spacing:.02em;color:var(--p12-ink);margin:0 0 24px;line-height:1.2}
.p12-page__lead{font-size:14.5px;line-height:2;color:var(--p12-ink-soft);margin:0 0 24px;max-width:74ch}

.p12-page__inner{max-width:1100px;margin:0 auto;padding:0 28px 80px}

/* スタッツバー(数字4つ・赤帯) */
.p12-stats{background:linear-gradient(90deg,var(--p12-red) 0%,var(--p12-red-dark) 100%);color:#fff;padding:36px 28px;margin:40px 0 60px}
.p12-stats__inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center;align-items:center}
.p12-stats__inner__lead{grid-column:1 / -1;font-size:14px;text-align:center;font-weight:500;margin-bottom:18px}
.p12-stats__item__num{font-family:var(--p12-font-display);font-weight:700;font-size:36px;line-height:1;color:#fff}
.p12-stats__item__num small{font-size:14px;font-weight:500;margin-left:4px}
.p12-stats__item__label{font-size:11.5px;color:#fff;opacity:.9;margin-top:8px;display:block;letter-spacing:.04em}

/* ===== JOBS index — 「多様な職種と業務」サムネカードグリッド ===== */
.p12-jobs__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;max-width:1100px;margin:0 auto;padding:0 28px 60px}
.p12-jobcard{background:#fff;border:1px solid var(--p12-line);text-decoration:none;color:var(--p12-ink);display:flex;flex-direction:column;transition:border-color .25s ease,transform .25s ease}
.p12-jobcard:hover{border-color:var(--p12-red);transform:translateY(-2px)}
.p12-jobcard__plate{aspect-ratio:4/3;overflow:hidden;background:var(--p12-paper);position:relative}
.p12-jobcard__plate img{width:100%;height:100%;object-fit:cover}
.p12-jobcard__plate::before{content:attr(data-code);position:absolute;left:14px;top:14px;background:var(--p12-red);color:#fff;padding:5px 12px;font-family:var(--p12-font-display);font-weight:700;font-size:11px;letter-spacing:.12em}
.p12-jobcard__body{padding:18px 20px 22px;display:flex;flex-direction:column;gap:6px;flex:1}
.p12-jobcard__title{font-family:var(--p12-font-body);font-weight:700;font-size:17px;color:var(--p12-ink);margin:0;line-height:1.45}
.p12-jobcard__sub{font-size:12.5px;color:var(--p12-ink-soft);margin:4px 0 10px;line-height:1.7}
.p12-jobcard__meta{margin-top:auto;padding-top:14px;border-top:1px solid var(--p12-line-soft);font-size:11.5px;color:var(--p12-ink-soft);display:flex;flex-wrap:wrap;gap:10px}
.p12-jobcard__meta b{color:var(--p12-red);margin-right:4px}
.p12-jobcard__more{margin-top:14px;color:var(--p12-red);font-size:12px;font-weight:700;display:flex;align-items:center;gap:4px}
.p12-jobcard__more::after{content:"›";font-weight:300;font-size:16px}
@media (max-width:880px){.p12-jobs__grid{grid-template-columns:1fr;padding:0 14px}}

/* ===== JOB 詳細(座談会ページ風 縦長レイアウト) ===== */
.p12-job__hero{background:var(--p12-paper);padding:0;margin-bottom:0;border-bottom:1px solid var(--p12-line)}
.p12-job__hero__img{position:relative;height:380px;overflow:hidden;background:#0c0c0c}
.p12-job__hero__img img{width:100%;height:100%;object-fit:cover;opacity:.92}
.p12-job__hero__num{position:absolute;left:28px;bottom:28px;background:var(--p12-red);color:#fff;padding:6px 14px;font-family:var(--p12-font-display);font-weight:700;font-size:13px;letter-spacing:.14em;z-index:2}
.p12-job__hero__label{position:absolute;left:90px;bottom:28px;background:#fff;color:var(--p12-ink);padding:6px 14px;font-weight:700;font-size:13px;z-index:2}
.p12-job__hero__inner{max-width:1100px;margin:0 auto;padding:36px 28px}
.p12-job__hero__title{font-family:var(--p12-font-body);font-weight:700;font-size:clamp(28px,3.8vw,46px);letter-spacing:.02em;line-height:1.3;color:var(--p12-ink);margin:0 0 14px}
.p12-job__hero__sub{font-size:14.5px;line-height:1.9;color:var(--p12-ink-soft);margin:0 0 22px;max-width:74ch}
.p12-job__hero__meta{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;padding-top:18px;border-top:1px solid var(--p12-line);font-size:12.5px;margin:0}
.p12-job__hero__meta dt{font-family:var(--p12-font-display);font-size:10px;letter-spacing:.16em;color:var(--p12-red);font-weight:700;margin:0 0 4px}
.p12-job__hero__meta dd{margin:0;color:var(--p12-ink);font-weight:700;font-size:14px}
@media (max-width:880px){.p12-job__hero__meta{grid-template-columns:1fr 1fr}}

.p12-job__sec{max-width:1100px;margin:0 auto;padding:40px 28px}
.p12-job__sec__bar{display:flex;align-items:center;gap:14px;margin:0 0 22px;padding-bottom:14px;border-bottom:2px solid var(--p12-red)}
.p12-job__sec__bar__tag{background:var(--p12-red);color:#fff;padding:7px 14px;font-family:var(--p12-font-display);font-weight:700;font-size:11px;letter-spacing:.14em}
.p12-job__sec__bar__title{font-family:var(--p12-font-body);font-weight:700;font-size:20px;color:var(--p12-ink);letter-spacing:.04em}
.p12-job__sec p{font-size:14.5px;line-height:1.95;color:var(--p12-ink);margin:0 0 14px}
.p12-job__sec ul{padding-left:1.4em;margin:0;font-size:14.5px;line-height:1.95}
.p12-job__sec ul li{margin:0 0 6px}

/* 1日の流れ — 縦並びの時刻表 */
.p12-day{display:flex;flex-direction:column;border-top:1px solid var(--p12-line)}
.p12-day__row{display:grid;grid-template-columns:120px 1fr;gap:0;border-bottom:1px solid var(--p12-line)}
.p12-day__time{padding:18px 16px;font-family:var(--p12-font-display);font-weight:700;font-size:18px;color:var(--p12-red);background:#fff;display:flex;align-items:center;justify-content:center;border-right:1px solid var(--p12-line)}
.p12-day__body{padding:18px 22px;background:#fff}
.p12-day__body h4{font-family:var(--p12-font-body);font-weight:700;font-size:15px;margin:0 0 6px;color:var(--p12-ink)}
.p12-day__body p{font-size:13.5px;color:var(--p12-ink-soft);margin:0;line-height:1.75}

/* requirements table */
.p12-reqtable{width:100%;border-collapse:collapse;font-size:14px;border-top:2px solid var(--p12-red)}
.p12-reqtable tr{border-bottom:1px solid var(--p12-line)}
.p12-reqtable th{font-family:var(--p12-font-body);font-weight:700;font-size:13px;color:var(--p12-red);text-align:left;padding:18px 20px 18px 0;width:180px;vertical-align:top;background:#fff;letter-spacing:.04em}
.p12-reqtable td{padding:18px 0;color:var(--p12-ink);line-height:1.95}

/* faq */
.p12-faqlist{border-top:2px solid var(--p12-red);max-width:880px;margin:0 auto}
.p12-faqitem{border-bottom:1px solid var(--p12-line);background:#fff}
.p12-faqitem summary{font-family:var(--p12-font-body);font-weight:700;font-size:15px;color:var(--p12-ink);cursor:pointer;list-style:none;padding:20px 0;display:flex;gap:18px;align-items:flex-start}
.p12-faqitem summary::-webkit-details-marker{display:none}
.p12-faqitem summary::before{content:"Q.";font-family:var(--p12-font-display);font-weight:700;color:var(--p12-red);font-size:20px;line-height:1;flex-shrink:0}
.p12-faqitem summary::after{content:"+";margin-left:auto;color:var(--p12-red);font-size:20px;font-weight:300}
.p12-faqitem[open] summary::after{content:"−"}
.p12-faqitem div{padding:0 0 20px 36px;font-size:14px;color:var(--p12-ink-soft);line-height:1.95;display:flex;gap:18px}
.p12-faqitem div::before{content:"A.";font-family:var(--p12-font-display);font-weight:700;color:var(--p12-ink);font-size:20px;line-height:1;flex-shrink:0;margin-left:-36px}

/* apply form */
.p12-form{display:grid;gap:22px;max-width:720px;margin:0 auto}
.p12-form__note{font-size:12.5px;color:var(--p12-ink-soft);background:var(--p12-paper);padding:16px 22px;border-left:3px solid var(--p12-red);max-width:720px;margin:0 auto 24px;line-height:1.85}
.p12-form label{display:block;font-family:var(--p12-font-body);font-weight:700;font-size:12.5px;color:var(--p12-ink);margin:0 0 8px;letter-spacing:.04em}
.p12-form label small{font-weight:500;color:var(--p12-red);margin-left:6px;font-size:10.5px;background:var(--p12-red-soft);padding:2px 7px;border-radius:3px}
.p12-form input,.p12-form select,.p12-form textarea{width:100%;font:inherit;padding:14px 16px;border:1px solid var(--p12-line);background:#fff;color:var(--p12-ink);border-radius:0;font-size:14px}
.p12-form input:focus,.p12-form select:focus,.p12-form textarea:focus{outline:none;border-color:var(--p12-red);box-shadow:0 0 0 3px rgba(230,0,18,.1)}
.p12-form button{background:var(--p12-red);color:#fff;padding:18px 56px;font-family:var(--p12-font-body);font-weight:700;font-size:14px;letter-spacing:.14em;border:0;cursor:pointer;justify-self:center;margin-top:6px;border-radius:30px}
.p12-form button:hover{background:var(--p12-red-dark)}

/* history */
.p12-history{border-top:2px solid var(--p12-red);max-width:880px;margin:0 auto}
.p12-history__row{display:grid;grid-template-columns:120px 1fr;gap:24px;padding:20px 0;border-bottom:1px solid var(--p12-line)}
.p12-history__year{font-family:var(--p12-font-display);font-weight:700;font-size:20px;color:var(--p12-red);letter-spacing:.04em}
.p12-history__event{font-size:14px;color:var(--p12-ink);line-height:1.85}

/* message — ごあいさつ風(本文左 + 人物写真右 + 末尾に手書き署名) */
.p12-message{display:grid;grid-template-columns:1fr 0.6fr;gap:48px;align-items:start;max-width:1100px;margin:0 auto;padding:0 28px 40px}
.p12-message__body{font-size:14.5px;line-height:2;color:var(--p12-ink);white-space:pre-line}
.p12-message__lead{font-family:var(--p12-font-body);font-weight:700;font-size:20px;line-height:1.6;color:var(--p12-ink);margin:0 0 24px;padding-bottom:18px;border-bottom:1px solid var(--p12-line)}
.p12-message__photo{position:relative}
.p12-message__photo img{width:100%;aspect-ratio:3/4;object-fit:cover;background:var(--p12-paper)}
.p12-message__sign{margin-top:36px;padding-top:24px;border-top:1px solid var(--p12-line);max-width:520px}
.p12-message__sign__role{font-size:12px;color:var(--p12-ink-soft);margin:0 0 8px;letter-spacing:.06em}
.p12-message__sign__name{font-family:var(--p12-font-hand);font-weight:600;font-size:32px;letter-spacing:.4em;color:var(--p12-ink);margin:0;line-height:1.2}
@media (max-width:880px){.p12-message{grid-template-columns:1fr;padding:0 14px 30px}}

/* ========= 動的要素 ========= */
html.p12-motion-ready .p12-hero__copy h1,
html.p12-motion-ready .p12-hero__copy p{opacity:0;transform:translateY(20px);transition:opacity 1s ease,transform 1s ease}
html.p12-motion-ready .p12-loaded .p12-hero__copy h1,
html.p12-motion-ready .p12-loaded .p12-hero__copy p{opacity:1;transform:none}
html.p12-motion-ready .p12-hero__photos div{opacity:0;transform:translateY(20px);transition:opacity .8s ease,transform .8s ease}
html.p12-motion-ready .p12-loaded .p12-hero__photos div{opacity:1;transform:none}
html.p12-motion-ready .p12-hero__photos div:nth-child(1){transition-delay:.1s}
html.p12-motion-ready .p12-hero__photos div:nth-child(2){transition-delay:.2s}
html.p12-motion-ready .p12-hero__photos div:nth-child(3){transition-delay:.3s}
html.p12-motion-ready .p12-hero__photos div:nth-child(4){transition-delay:.4s}
html.p12-motion-ready .p12-reveal{opacity:0;transform:translateY(16px);transition:opacity .8s ease var(--p12-delay,0ms),transform .8s ease var(--p12-delay,0ms)}
html.p12-motion-ready .p12-reveal.p12-in{opacity:1;transform:none}

/* 手書き署名のフェードイン演出(ペン走り風) */
html.p12-motion-ready .p12-message__sign__name{opacity:0;transition:opacity 1.4s ease .3s,letter-spacing 1.4s ease .3s;letter-spacing:.8em}
html.p12-motion-ready .p12-message__sign__name.p12-in{opacity:1;letter-spacing:.4em}
