/* 真似元: honda-recruit.jp/
   - 上部に細い赤いブランドバーとロゴ + 横並び日本語ナビ
   - ヒーロー写真の上に巨大な日本語キャッチコピー
   - 右側に固定の赤い縦長 CTA パネル(2〜3枚)
   - 「Challenge to the sky / Electrification / AI for Mobility」3カラム
   - About / Driving the Edge / Honda People / Internship Workshop の写真リンク
   - 黒帯フッターに白文字の大量リンクが6カラム
*/
@import url('./fonts.css');

*,*:before,*:after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:#fff;
  color:#222;
  font-family:var(--p29-font-body);
  font-size:14px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ===== ヘッダー(ロゴ赤帯 + 日本語ナビ) ===== */
.p29-skip{position:absolute;left:-9999px}
.p29-skip:focus{position:fixed;top:8px;left:8px;background:#cc0000;color:#fff;padding:6px 12px;z-index:9999}

.p29-header{
  position:relative;
  display:grid;
  grid-template-columns:auto 1fr;
  align-items:center;
  gap:24px;
  padding:14px 28px;
  border-bottom:1px solid #eee;
  background:#fff;
  z-index:5;
}
.p29-header__brand{display:flex;align-items:center;gap:14px;font-family:var(--p29-font-display);font-weight:700}
.p29-header__logo{
  background:#cc0000;color:#fff;
  font-weight:900;font-size:20px;letter-spacing:.04em;
  padding:6px 12px;line-height:1;border-radius:1px;
  font-family:var(--p29-font-display);
}
.p29-header__tag{font-size:10px;color:#777;line-height:1.4;letter-spacing:.04em}
.p29-header__tag b{display:block;color:#222;font-size:11px;font-weight:700}

.p29-nav{display:flex;justify-content:flex-end;align-items:center;gap:30px;flex-wrap:wrap}
.p29-nav a{display:inline-flex;flex-direction:column;align-items:center;line-height:1.2;font-size:11px;color:#222;padding:8px 4px;border-bottom:2px solid transparent}
.p29-nav a:hover{border-bottom-color:#cc0000;color:#cc0000}
.p29-nav a b{font-family:var(--p29-font-display);font-weight:600;font-size:14px;letter-spacing:.04em;margin-bottom:4px}

/* ===== ヒーロー ===== */
.p29-hero{position:relative;background:#000;overflow:hidden}
.p29-hero__media{position:relative;height:min(620px,72vh);overflow:hidden}
.p29-hero__media img{width:100%;height:100%;object-fit:cover;opacity:.85}
.p29-hero__copy{
  position:absolute;left:6%;bottom:18%;
  font-family:var(--p29-font-body);
  font-weight:700;
  color:#fff;
  font-size:clamp(36px,5.2vw,68px);
  line-height:1.25;
  letter-spacing:.04em;
  text-shadow:0 2px 14px rgba(0,0,0,.35);
  margin:0;
}
.p29-hero__copy span{display:block}

/* 右側 赤いCTA縦パネル */
.p29-cta-stack{
  position:absolute;top:32px;right:28px;
  display:flex;flex-direction:column;gap:6px;
  width:180px;z-index:4;
}
.p29-cta-stack a{
  display:block;background:#cc0000;color:#fff;
  padding:14px 14px 16px;
  font-size:11px;line-height:1.55;
  border:1px solid #cc0000;
  position:relative;
  transition:background .2s;
}
.p29-cta-stack a:hover{background:#a30000}
.p29-cta-stack a small{
  display:inline-block;
  background:#fff;color:#cc0000;
  font-family:var(--p29-font-display);font-weight:700;font-size:10px;
  padding:2px 6px;margin-bottom:8px;letter-spacing:.04em;
}
.p29-cta-stack a b{display:block;font-size:12px;line-height:1.5;font-weight:700}
.p29-cta-stack a:after{content:"›";position:absolute;right:10px;bottom:10px;font-size:14px}

/* ===== Driving the Edge 3カラム(空への挑戦 / Electrification / AI for Mobility) ===== */
.p29-projects{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:#eee;
  padding:64px 28px;
  background:#fff;
}
.p29-projects__head{grid-column:1/-1;text-align:center;margin-bottom:24px}
.p29-projects__head h2{font-family:var(--p29-font-display);font-weight:600;font-size:34px;letter-spacing:.06em;margin:0 0 6px;color:#222}
.p29-projects__head p{margin:0;font-size:12px;color:#888;letter-spacing:.1em}

.p29-project{
  position:relative;display:block;background:#fff;
  border-right:1px solid #eee;
}
.p29-project:last-child{border-right:0}
.p29-project__photo{aspect-ratio:4/3;overflow:hidden;background:#000}
.p29-project__photo img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.p29-project:hover .p29-project__photo img{transform:scale(1.04)}
.p29-project__cap{padding:18px 8px 8px}
.p29-project__cap h3{margin:0 0 4px;font-family:var(--p29-font-display);font-weight:600;font-style:italic;font-size:22px;color:#222}
.p29-project__cap p{margin:0;font-size:11px;color:#777;letter-spacing:.06em}

/* ===== About Honda / Driving the Edge / People / Internship 大型タイル ===== */
.p29-bigtiles{
  display:grid;grid-template-columns:1fr 1fr;
  gap:1px;background:#fff;
  padding:0 28px 60px;
}
.p29-bigtile{
  position:relative;display:block;
  background:#fff;
  overflow:hidden;
}
.p29-bigtile__photo{aspect-ratio:16/10;overflow:hidden;background:#000}
.p29-bigtile__photo img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.p29-bigtile:hover .p29-bigtile__photo img{transform:scale(1.04)}
.p29-bigtile__cap{
  position:absolute;left:18px;top:18px;
  color:#fff;
}
.p29-bigtile__cap h3{font-family:var(--p29-font-display);font-weight:600;font-size:26px;letter-spacing:.04em;margin:0 0 4px;text-shadow:0 2px 8px rgba(0,0,0,.4)}
.p29-bigtile__cap p{margin:0;font-size:11px;letter-spacing:.06em;text-shadow:0 2px 8px rgba(0,0,0,.5)}

/* ===== 黒帯 大量リンクフッター ===== */
.p29-foot{
  background:#000;color:#fff;
  padding:48px 28px 24px;
  font-size:11px;line-height:1.85;
}
.p29-foot__cols{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:32px;
  border-top:1px solid #333;
  padding-top:32px;
}
.p29-foot__col h4{
  font-family:var(--p29-font-display);font-weight:600;
  font-size:12px;letter-spacing:.08em;
  margin:0 0 14px;color:#fff;
  border-bottom:1px solid #444;padding-bottom:8px;
}
.p29-foot__col ul{list-style:none;margin:0;padding:0}
.p29-foot__col li{margin:0 0 6px}
.p29-foot__col li a{color:#ccc;font-size:11px}
.p29-foot__col li a:hover{color:#cc0000}
.p29-foot__col li small{color:#777;font-size:10px;margin-left:4px}

.p29-foot__base{
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;
  margin-top:40px;padding-top:18px;border-top:1px solid #333;
  font-size:10px;color:#999;letter-spacing:.06em;
}
.p29-foot__base a{color:#ccc;margin-right:18px}
.p29-foot__base a:hover{color:#cc0000}
.p29-foot__base .p29-foot__credit{flex-basis:100%;text-align:right;font-size:10px;color:#666;margin-top:8px}

/* ===== 下層共通: ページヒーロー ===== */
.p29-page{padding:0 0 80px}
.p29-page__hero{
  position:relative;background:#f5f5f5;
  display:grid;place-items:center;
  padding:80px 28px 60px;
  text-align:center;
}
.p29-page__hero__media{
  width:100%;max-width:1080px;aspect-ratio:16/6;overflow:hidden;background:#000;margin-bottom:24px;
}
.p29-page__hero__media img{width:100%;height:100%;object-fit:cover;opacity:.9}
.p29-page__hero h1{
  font-family:var(--p29-font-display);font-weight:600;font-style:italic;
  font-size:clamp(32px,5vw,52px);
  margin:0 0 6px;letter-spacing:.04em;
}
.p29-page__hero p{margin:0;font-size:13px;color:#888;letter-spacing:.06em}
.p29-page__crumb{max-width:1080px;margin:18px auto 0;padding:0 28px;font-size:11px;color:#777}
.p29-page__crumb a{color:#cc0000}
.p29-page__inner{max-width:880px;margin:48px auto 0;padding:0 28px}
.p29-page__lead{font-size:14px;line-height:2;color:#444;text-align:center;margin:0 0 40px}

/* ===== Jobs 一覧 ===== */
.p29-jobs__grid{
  max-width:1080px;margin:0 auto;padding:0 28px;
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:#eee;
}
.p29-jobcard{
  background:#fff;display:block;padding:0 0 24px;
  border-right:1px solid #eee;border-bottom:1px solid #eee;
}
.p29-jobcard__plate{aspect-ratio:4/3;overflow:hidden;background:#000;position:relative}
.p29-jobcard__plate img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.p29-jobcard:hover .p29-jobcard__plate img{transform:scale(1.04)}
.p29-jobcard__code{margin:18px 18px 4px;font-family:var(--p29-font-display);font-size:11px;letter-spacing:.08em;color:#cc0000;font-weight:600}
.p29-jobcard__title{margin:0 18px 4px;font-size:18px;font-weight:700;color:#222}
.p29-jobcard__sub{margin:0 18px 12px;font-size:12px;color:#777;line-height:1.6}
.p29-jobcard__meta{display:flex;flex-wrap:wrap;gap:8px;margin:0 18px}
.p29-jobcard__meta span{font-size:11px;color:#555;background:#f5f5f5;padding:4px 8px;border-radius:1px}
.p29-jobcard__meta b{display:inline;color:#cc0000;font-weight:700;margin-right:6px}

/* ===== Job 詳細 ===== */
.p29-job__hero{
  position:relative;background:#000;color:#fff;
}
.p29-job__hero__img{position:relative;height:380px;overflow:hidden}
.p29-job__hero__img img{width:100%;height:100%;object-fit:cover;opacity:.7}
.p29-job__hero__num{
  position:absolute;left:28px;bottom:24px;
  font-family:var(--p29-font-display);font-weight:600;font-style:italic;
  font-size:64px;color:#cc0000;line-height:1;
}
.p29-job__hero__label{
  position:absolute;left:120px;bottom:34px;
  font-size:12px;letter-spacing:.1em;color:#fff;
}
.p29-job__hero__title{
  font-family:var(--p29-font-display);font-weight:600;font-style:italic;
  font-size:clamp(28px,4vw,42px);
  color:#222;background:#fff;
  margin:0;padding:24px 28px 6px;letter-spacing:.04em;
}
.p29-job__hero__sub{background:#fff;color:#444;margin:0;padding:0 28px 20px;font-size:14px}
.p29-job__hero__meta{
  background:#fff;color:#222;margin:0;padding:0 28px 36px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px;
  border-bottom:1px solid #eee;
}
.p29-job__hero__meta div{padding:12px 0;border-top:2px solid #cc0000}
.p29-job__hero__meta dt{font-size:10px;color:#888;letter-spacing:.1em;margin-bottom:4px}
.p29-job__hero__meta dd{margin:0;font-size:13px;font-weight:700;color:#222}

.p29-job__sec{max-width:880px;margin:48px auto;padding:0 28px}
.p29-job__sec__bar{display:flex;align-items:baseline;gap:16px;border-bottom:1px solid #ddd;padding-bottom:10px;margin-bottom:20px}
.p29-job__sec__bar__tag{background:#cc0000;color:#fff;font-size:11px;padding:4px 10px;letter-spacing:.06em}
.p29-job__sec__bar__title{font-family:var(--p29-font-display);font-weight:600;font-style:italic;font-size:22px;color:#cc0000;letter-spacing:.04em}
.p29-job__sec p{font-size:14px;line-height:2;color:#444}
.p29-job__sec ul{padding-left:20px;margin:0}
.p29-job__sec li{font-size:14px;line-height:1.9;color:#444;margin-bottom:4px}

/* 1日の流れ */
.p29-day{display:grid;gap:0}
.p29-day__row{display:grid;grid-template-columns:120px 1fr;gap:24px;padding:18px 0;border-bottom:1px dashed #eee}
.p29-day__time{font-family:var(--p29-font-display);font-weight:600;font-size:22px;color:#cc0000;letter-spacing:.04em}
.p29-day__body h4{margin:0 0 4px;font-size:15px;font-weight:700;color:#222}
.p29-day__body p{margin:0;font-size:13px;color:#666;line-height:1.7}

/* 募集要項テーブル */
.p29-reqtable{width:100%;border-collapse:collapse;background:#fff}
.p29-reqtable tr{border-top:1px solid #eee}
.p29-reqtable tr:last-child{border-bottom:1px solid #eee}
.p29-reqtable th{
  width:180px;text-align:left;padding:18px 16px;
  background:#fafafa;font-size:12px;color:#cc0000;font-weight:700;
  vertical-align:top;letter-spacing:.04em;
}
.p29-reqtable td{padding:18px 16px;font-size:14px;color:#444;line-height:1.8}

/* FAQ */
.p29-faqlist{display:grid;gap:1px;background:#eee;border:1px solid #eee}
.p29-faqitem{background:#fff;padding:0}
.p29-faqitem summary{
  list-style:none;cursor:pointer;
  padding:18px 24px;font-size:14px;font-weight:700;color:#222;
  display:flex;align-items:center;gap:14px;
}
.p29-faqitem summary:before{
  content:"Q";display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;background:#cc0000;color:#fff;font-family:var(--p29-font-display);font-weight:700;font-size:14px;border-radius:1px;flex-shrink:0;
}
.p29-faqitem[open] summary{border-bottom:1px solid #eee}
.p29-faqitem > div{padding:16px 24px 22px 66px;font-size:13px;color:#555;line-height:1.9;position:relative}
.p29-faqitem > div:before{
  content:"A";position:absolute;left:24px;top:18px;
  display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;background:#222;color:#fff;font-family:var(--p29-font-display);font-weight:700;font-size:14px;border-radius:1px;
}

/* フォーム */
.p29-form{display:grid;gap:18px;max-width:680px;margin:24px auto 0}
.p29-form > div{display:grid;gap:6px}
.p29-form label{font-size:12px;font-weight:700;color:#222;letter-spacing:.04em}
.p29-form label small{background:#cc0000;color:#fff;font-size:10px;padding:1px 6px;margin-left:6px;font-weight:400;letter-spacing:.04em}
.p29-form input,.p29-form select,.p29-form textarea{
  font:inherit;padding:12px 14px;border:1px solid #ccc;background:#fff;color:#222;border-radius:1px;
}
.p29-form input:focus,.p29-form select:focus,.p29-form textarea:focus{outline:2px solid #cc0000;outline-offset:-1px;border-color:#cc0000}
.p29-form button{
  margin-top:12px;padding:16px;
  background:#cc0000;color:#fff;border:0;
  font-family:var(--p29-font-display);font-weight:700;font-size:14px;letter-spacing:.1em;
  cursor:pointer;border-radius:1px;
}
.p29-form button:hover{background:#a30000}
.p29-form__note{font-size:11px;color:#888;text-align:center;margin:0 0 24px}

/* 沿革 history */
.p29-history{border-left:2px solid #cc0000;padding-left:24px;margin:0}
.p29-history__row{display:grid;grid-template-columns:100px 1fr;gap:20px;padding:14px 0;border-bottom:1px solid #eee}
.p29-history__year{font-family:var(--p29-font-display);font-weight:600;font-size:20px;color:#cc0000}
.p29-history__event{font-size:14px;color:#444;line-height:1.7}

/* トップメッセージ */
.p29-message{max-width:880px;margin:60px auto;padding:0 28px}
.p29-message__head{display:grid;grid-template-columns:200px 1fr;gap:32px;align-items:end;margin-bottom:32px;border-bottom:2px solid #cc0000;padding-bottom:24px}
.p29-message__head img{width:200px;height:200px;object-fit:cover}
.p29-message__head h2{font-family:var(--p29-font-display);font-weight:600;font-style:italic;font-size:28px;color:#222;margin:0 0 8px;letter-spacing:.04em}
.p29-message__head p{margin:0;font-size:13px;color:#777}
.p29-message__lead{font-size:18px;font-weight:700;color:#cc0000;line-height:1.7;margin:0 0 24px}
.p29-message__body{font-size:14px;color:#444;line-height:2;white-space:pre-line}
.p29-message__sign{margin-top:32px;text-align:right;font-size:13px;color:#222}
.p29-message__sign b{font-size:18px;display:block;margin-top:4px}

/* モーション */
.p29-reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease var(--p29-delay,0ms),transform .7s ease var(--p29-delay,0ms)}
.p29-reveal.p29-in{opacity:1;transform:none}

/* ===== レスポンシブ ===== */
@media (max-width:900px){
  .p29-header{grid-template-columns:1fr;gap:12px}
  .p29-nav{justify-content:flex-start;gap:18px}
  .p29-nav a{font-size:10px}
  .p29-nav a b{font-size:12px}
  .p29-cta-stack{position:static;width:auto;flex-direction:row;flex-wrap:wrap;padding:12px;background:#000}
  .p29-cta-stack a{flex:1 1 240px}
  .p29-hero__media{height:60vh;min-height:380px}
  .p29-hero__copy{left:5%;bottom:10%;font-size:32px}
  .p29-projects{grid-template-columns:1fr;padding:40px 18px}
  .p29-project{border-right:0;border-bottom:1px solid #eee}
  .p29-bigtiles{grid-template-columns:1fr;padding:0 18px 40px}
  .p29-foot__cols{grid-template-columns:1fr 1fr;gap:24px}
  .p29-jobs__grid{grid-template-columns:1fr;padding:0 18px}
  .p29-jobcard{border-right:0}
  .p29-job__hero__meta{grid-template-columns:1fr 1fr;padding:0 18px 24px}
  .p29-message__head{grid-template-columns:1fr;text-align:left}
  .p29-message__head img{width:140px;height:140px}
  .p29-day__row{grid-template-columns:80px 1fr;gap:12px}
  .p29-history__row{grid-template-columns:80px 1fr;gap:12px}
}
