/* 真似元: toyota-recruit.com/career/
   トヨタ採用（キャリア）の白〜ベージュ地、TOYOTA赤(#e60012)、ピン形シンボル、
   黒帯のグローバルナビ＋赤いCTA、ベージュ地に黒文字の余白多めレイアウト。 */

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

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--p30-font-body);
  color:#1a1a1a;
  background:#f3efe6; /* トヨタ採用 トップの淡いベージュ地 */
  line-height:1.75;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;background:none;border:0;color:inherit}

:root{
  --p30-red:#e60012;        /* TOYOTAロゴ赤 */
  --p30-red-dark:#b8000e;
  --p30-ink:#1a1a1a;        /* 本文 */
  --p30-ink-2:#333;
  --p30-gray:#666;
  --p30-line:#d8d3c6;
  --p30-beige:#f3efe6;
  --p30-beige-2:#ece6d7;
  --p30-cream:#faf6ec;
  --p30-foot:#222;
  --p30-foot-2:#1a1a1a;
}

/* スキップリンク */
.p30-skip{position:absolute;left:-999px;top:0}
.p30-skip:focus{left:8px;top:8px;background:#000;color:#fff;padding:8px 12px;z-index:9999}

/* ===== ヘッダー ===== */
.p30-header{
  position:fixed;inset:0 0 auto 0;height:64px;z-index:100;
  background:rgba(255,255,255,.96);
  border-bottom:1px solid var(--p30-line);
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:24px;
  padding:0 24px;
  transition:box-shadow .25s ease;
}
.p30-header.is-scrolled{box-shadow:0 6px 18px rgba(0,0,0,.08)}
.p30-header__brand{display:flex;align-items:baseline;gap:10px;font-family:var(--p30-font-display)}
.p30-header__brand strong{color:var(--p30-red);font-size:22px;font-weight:900;letter-spacing:.04em}
.p30-header__brand small{font-size:11px;font-weight:700;color:var(--p30-ink);letter-spacing:.18em}

.p30-header__nav{display:flex;align-items:center;gap:22px;font-size:13.5px;font-weight:700}
.p30-header__nav a{color:var(--p30-ink);position:relative;padding:6px 2px}
.p30-header__nav a:hover{color:var(--p30-red)}
.p30-header__nav a.is-on::after{
  content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;background:var(--p30-red)
}

.p30-header__util{display:flex;align-items:center;gap:10px}
.p30-header__util a{
  font-family:var(--p30-font-display);
  font-size:12px;font-weight:800;letter-spacing:.1em;
  padding:10px 18px;border-radius:999px;
}
.p30-header__util .p30-cta-red{background:var(--p30-red);color:#fff}
.p30-header__util .p30-cta-red:hover{background:var(--p30-red-dark)}
.p30-header__util .p30-cta-line{border:1.5px solid var(--p30-ink);color:var(--p30-ink)}

/* ===== サブナビ（キャリア採用 一覧 / 全本部募集 / ソフトウェア など） ===== */
.p30-subnav{
  position:fixed;top:64px;left:0;right:0;z-index:99;
  background:#fff;border-bottom:1px solid var(--p30-line);
  display:flex;align-items:center;gap:8px;
  padding:0 24px;height:48px;overflow-x:auto;
}
.p30-subnav__tag{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 12px;border-radius:999px;
  background:#000;color:#fff;font-size:12px;font-weight:700;letter-spacing:.04em;
  flex-shrink:0;
}
.p30-subnav__tag::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--p30-red)}
.p30-subnav a{
  font-size:12.5px;color:var(--p30-ink);padding:8px 12px;white-space:nowrap;font-weight:600;
}
.p30-subnav a:hover{color:var(--p30-red)}
.p30-subnav a.is-on{color:var(--p30-red);font-weight:800}

main{padding-top:112px}

/* ===== HERO ===== */
.p30-hero{
  position:relative;min-height:78vh;overflow:hidden;
  background:linear-gradient(180deg,#f3efe6 0%, #ece6d7 100%);
  padding:96px 6vw 160px;
}
.p30-hero__copy{
  font-family:var(--p30-font-body);
  font-weight:900;
  font-size:clamp(40px,7.5vw,104px);
  line-height:1.25;letter-spacing:.02em;
  margin:0;color:var(--p30-ink);
  max-width:18em;
}
.p30-hero__copy small{
  display:block;font-size:.32em;font-weight:700;color:var(--p30-gray);
  margin-top:24px;letter-spacing:.08em;
}
.p30-hero__pin{
  position:absolute;right:-4vw;bottom:-8vw;
  width:min(620px,55vw);aspect-ratio:1/1.25;
  opacity:.45;pointer-events:none;
  transform:translateY(40px);
  transition:transform 1.2s ease, opacity 1.2s ease;
  /* ピンの形（trip-tetragram）を inline SVG マスクで再現 */
  background:linear-gradient(180deg,#e1d9c4 0%, #d6cdb2 100%);
  -webkit-mask:radial-gradient(circle at 50% 38%, transparent 0 18%, #000 19%) bottom no-repeat,
        url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 130"><path d="M50 0C22 0 0 22 0 50c0 30 35 55 50 80 15-25 50-50 50-80C100 22 78 0 50 0Z" fill="black"/></svg>') center/contain no-repeat;
          mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 130"><path d="M50 0C22 0 0 22 0 50c0 30 35 55 50 80 15-25 50-50 50-80C100 22 78 0 50 0Z" fill="black"/></svg>') center/contain no-repeat;
}
.p30-hero__pin.p30-loaded{transform:translateY(0);opacity:.5}

.p30-hero__lead{
  margin-top:48px;max-width:560px;font-size:15px;color:var(--p30-ink-2);
  position:relative;z-index:2;
}

/* ===== 帯バナー（お知らせ） ===== */
.p30-news{
  background:#fff;border:1px solid var(--p30-line);
  margin:0 6vw;padding:20px 32px;
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:20px;
  position:relative;z-index:3;margin-top:-60px;
  border-radius:6px;
}
.p30-news__title{
  font-family:var(--p30-font-display);font-size:13px;font-weight:800;letter-spacing:.12em;color:var(--p30-red);
  display:flex;align-items:center;gap:8px;
}
.p30-news__title::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--p30-red)}
.p30-news__list{margin:0;padding:0;list-style:none;font-size:13.5px}
.p30-news__list li{padding:2px 0;color:var(--p30-ink-2)}
.p30-news__list li b{color:var(--p30-ink);margin-right:12px;font-weight:700}
.p30-news__more{font-size:12px;font-weight:700;color:var(--p30-ink);border:1px solid var(--p30-ink);padding:8px 16px;border-radius:999px}

/* ===== セクション見出し ===== */
.p30-sechead{padding:120px 6vw 40px}
.p30-sechead__en{
  font-family:var(--p30-font-display);font-size:14px;font-weight:800;color:var(--p30-red);
  letter-spacing:.18em;margin:0 0 12px;display:flex;align-items:center;gap:10px;
}
.p30-sechead__en::before{content:"";width:18px;height:1px;background:var(--p30-red)}
.p30-sechead__jp{font-size:clamp(28px,3.8vw,44px);font-weight:900;margin:0;letter-spacing:.04em}
.p30-sechead__sub{margin-top:16px;font-size:14.5px;color:var(--p30-gray);max-width:780px}

/* ===== JOB & PEOPLE タイル群（TOP） ===== */
.p30-jobpeople{padding:0 6vw 80px}
.p30-jobpeople__grid{
  display:grid;grid-template-columns:repeat(12,1fr);gap:16px;
}
.p30-jptile{
  position:relative;overflow:hidden;border-radius:8px;
  background:#fff;border:1px solid var(--p30-line);
  aspect-ratio:4/3;
  display:flex;align-items:flex-end;padding:20px;color:#fff;
}
.p30-jptile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.p30-jptile::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(0,0,0,0) 30%,rgba(0,0,0,.7) 100%);
}
.p30-jptile__cap{position:relative;z-index:2;font-weight:800}
.p30-jptile__cap small{display:block;font-family:var(--p30-font-display);font-size:11px;letter-spacing:.16em;opacity:.9;margin-bottom:4px}

.p30-jptile--w6{grid-column:span 6}
.p30-jptile--w4{grid-column:span 4}
.p30-jptile--w3{grid-column:span 3}
.p30-jptile--text{
  background:#fff;color:var(--p30-ink);align-items:flex-start;flex-direction:column;justify-content:center;
}
.p30-jptile--text::after{display:none}
.p30-jptile--text h3{font-size:22px;margin:0 0 8px;font-weight:900}
.p30-jptile--text p{margin:0;font-size:13px;color:var(--p30-gray)}
.p30-jptile--text small{display:block;margin-top:14px;font-family:var(--p30-font-display);color:var(--p30-red);font-weight:800;letter-spacing:.16em;font-size:12px}

/* ===== 数値で紐解く ===== */
.p30-figures{
  padding:80px 6vw 120px;background:var(--p30-cream);
  position:relative;overflow:hidden;
}
.p30-figures__pin{
  position:absolute;right:-6vw;top:-4vw;width:min(420px,40vw);aspect-ratio:1/1.25;
  background:linear-gradient(180deg,#efe8d3 0%, #e5dcc0 100%);opacity:.6;pointer-events:none;
  -webkit-mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 130"><path d="M50 0C22 0 0 22 0 50c0 30 35 55 50 80 15-25 50-50 50-80C100 22 78 0 50 0Z" fill="black"/></svg>') center/contain no-repeat;
          mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 130"><path d="M50 0C22 0 0 22 0 50c0 30 35 55 50 80 15-25 50-50 50-80C100 22 78 0 50 0Z" fill="black"/></svg>') center/contain no-repeat;
}
.p30-figures__row{
  display:grid;grid-template-columns:repeat(4,1fr);gap:32px;position:relative;z-index:2;
}
.p30-number{
  background:#fff;border:1px solid var(--p30-line);border-radius:6px;
  padding:32px 24px;text-align:left;
}
.p30-number__label{
  font-family:var(--p30-font-display);font-size:11px;font-weight:800;color:var(--p30-red);
  letter-spacing:.14em;margin-bottom:14px;
}
.p30-number__value{font-size:48px;font-weight:900;line-height:1;color:var(--p30-ink);font-family:var(--p30-font-display)}
.p30-number__unit{font-size:18px;font-weight:700;margin-left:4px}
.p30-number__jp{margin-top:12px;font-size:13.5px;font-weight:700}
.p30-number__note{margin-top:6px;font-size:11.5px;color:var(--p30-gray)}

/* ===== 下層共通: ページヒーロー ===== */
.p30-page{padding-bottom:120px}
.p30-page__hero{
  position:relative;padding:64px 6vw 56px;
  background:linear-gradient(180deg,#f3efe6 0%, #ece6d7 100%);
  overflow:hidden;
}
.p30-page__hero__pin{
  position:absolute;right:6vw;top:24px;width:160px;aspect-ratio:1/1.25;
  background:linear-gradient(180deg,#e8e0c6 0%, #ddd2b3 100%);opacity:.7;
  -webkit-mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 130"><path d="M50 0C22 0 0 22 0 50c0 30 35 55 50 80 15-25 50-50 50-80C100 22 78 0 50 0Z" fill="black"/></svg>') center/contain no-repeat;
          mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 130"><path d="M50 0C22 0 0 22 0 50c0 30 35 55 50 80 15-25 50-50 50-80C100 22 78 0 50 0Z" fill="black"/></svg>') center/contain no-repeat;
}
.p30-page__hero__row{display:flex;align-items:center;gap:18px}
.p30-page__hero__pinicon{
  width:36px;height:36px;background:var(--p30-red);
  -webkit-mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 130"><path d="M50 0C22 0 0 22 0 50c0 30 35 55 50 80 15-25 50-50 50-80C100 22 78 0 50 0ZM50 70a20 20 0 1 1 0-40 20 20 0 0 1 0 40Z" fill="black"/></svg>') center/contain no-repeat;
          mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 130"><path d="M50 0C22 0 0 22 0 50c0 30 35 55 50 80 15-25 50-50 50-80C100 22 78 0 50 0ZM50 70a20 20 0 1 1 0-40 20 20 0 0 1 0 40Z" fill="black"/></svg>') center/contain no-repeat;
  flex-shrink:0;
}
.p30-page__hero__title{
  font-size:clamp(28px,4vw,40px);font-weight:900;margin:0;display:flex;align-items:baseline;gap:14px;
}
.p30-page__hero__title small{font-size:14px;font-weight:700;color:var(--p30-gray);letter-spacing:.04em}
.p30-page__hero__en{
  font-family:var(--p30-font-display);font-size:13px;font-weight:700;color:var(--p30-gray);
  letter-spacing:.16em;margin-top:8px;
}
.p30-page__crumb{
  padding:18px 6vw 0;font-size:12px;color:var(--p30-gray);background:#fff;
}
.p30-page__crumb a{color:var(--p30-ink);margin-right:6px}
.p30-page__crumb a:hover{color:var(--p30-red)}
.p30-page__inner{padding:48px 6vw;max-width:1280px;margin:0 auto}
.p30-page__lead{font-size:14.5px;color:var(--p30-ink-2);margin-bottom:32px;max-width:780px}

/* ===== 職種一覧（COURSE） ===== */
.p30-course{padding:32px 6vw}
.p30-course__head{
  font-family:var(--p30-font-display);font-size:12px;font-weight:800;color:var(--p30-red);
  letter-spacing:.16em;margin-bottom:8px;
}
.p30-course__title{
  font-size:24px;font-weight:900;margin:0 0 24px;
  border-bottom:2px solid var(--p30-red);padding-bottom:8px;display:inline-block;
}
.p30-filter{
  background:#fff;border:1px solid var(--p30-line);border-radius:6px;
  padding:18px 22px;margin-bottom:24px;
  display:flex;flex-wrap:wrap;align-items:center;gap:10px;
}
.p30-filter__label{
  font-size:13px;font-weight:800;display:flex;align-items:center;gap:8px;margin-right:8px;
}
.p30-filter__label::before{
  content:"";display:inline-block;width:14px;height:14px;background:var(--p30-ink);
  -webkit-mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16"><path d="M1 2h14L9 9v5l-2 1V9L1 2Z" fill="black"/></svg>') center/contain no-repeat;
          mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16"><path d="M1 2h14L9 9v5l-2 1V9L1 2Z" fill="black"/></svg>') center/contain no-repeat;
}
.p30-filter button{
  padding:8px 16px;border-radius:999px;font-size:12.5px;font-weight:700;
  border:1px solid var(--p30-line);background:#fff;color:var(--p30-ink-2);transition:all .2s ease;
}
.p30-filter button:hover{border-color:var(--p30-ink)}
.p30-filter button.is-on{background:var(--p30-ink);color:#fff;border-color:var(--p30-ink)}

.p30-courselist{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--p30-line)}
.p30-courserow{
  display:grid;grid-template-columns:auto 1fr auto;align-items:start;gap:20px;
  padding:24px 8px;border-bottom:1px solid var(--p30-line);
  text-decoration:none;color:inherit;transition:background .2s ease;
}
.p30-courserow:hover{background:#fff}
.p30-courserow__dot{
  width:10px;height:10px;border-radius:50%;background:var(--p30-red);margin-top:10px;
}
.p30-courserow__body h3{margin:0 0 6px;font-size:17px;font-weight:900}
.p30-courserow__body p{margin:0;font-size:13.5px;color:var(--p30-ink-2)}
.p30-courserow__arrow{
  width:36px;height:36px;border-radius:50%;border:1px solid var(--p30-ink);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:4px;
  transition:all .2s ease;
}
.p30-courserow:hover .p30-courserow__arrow{background:var(--p30-red);border-color:var(--p30-red);color:#fff}
.p30-courserow__arrow::after{content:"›";font-size:18px;line-height:1;font-weight:700}

/* ===== Business Flow（横長プロセス図） ===== */
.p30-flow{padding:80px 6vw}
.p30-flow__head{
  font-family:var(--p30-font-display);font-size:13px;font-weight:800;color:var(--p30-red);
  letter-spacing:.14em;margin-bottom:8px;
}
.p30-flow__title{font-size:24px;font-weight:900;margin:0 0 32px}
.p30-flow__bar{
  background:#1a1a1a;color:#fff;border-radius:6px;
  padding:18px 24px;display:flex;align-items:center;gap:12px;
  font-family:var(--p30-font-display);font-size:13px;font-weight:700;letter-spacing:.05em;
  overflow-x:auto;margin-bottom:24px;
}
.p30-flow__step{
  display:inline-flex;align-items:center;gap:10px;white-space:nowrap;flex-shrink:0;
}
.p30-flow__step::after{content:"›";color:var(--p30-red);font-weight:800;margin-left:6px;font-size:18px}
.p30-flow__step:last-child::after{display:none}
.p30-flow__step b{color:#fff;font-weight:700}

/* ===== 共通 jobs grid / jobcard（職種一覧 カード） ===== */
.p30-jobs__grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;
  margin-top:32px;
}
.p30-jobcard{
  display:flex;flex-direction:column;background:#fff;border:1px solid var(--p30-line);border-radius:8px;
  overflow:hidden;text-decoration:none;color:inherit;transition:transform .25s ease, box-shadow .25s ease;
}
.p30-jobcard:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(0,0,0,.08)}
.p30-jobcard__photo{aspect-ratio:4/3;overflow:hidden;background:#eee}
.p30-jobcard__photo img{width:100%;height:100%;object-fit:cover}
.p30-jobcard__body{padding:22px}
.p30-jobcard__code{
  font-family:var(--p30-font-display);font-size:11px;font-weight:800;color:var(--p30-red);
  letter-spacing:.14em;margin:0 0 8px;
}
.p30-jobcard__title{font-size:19px;font-weight:900;margin:0 0 6px}
.p30-jobcard__sub{margin:0 0 14px;font-size:13px;color:var(--p30-gray)}
.p30-jobcard__meta{display:flex;flex-direction:column;gap:6px;font-size:12.5px}
.p30-jobcard__meta b{display:inline-block;width:50px;color:var(--p30-gray);font-weight:700}

/* ===== 詳細: job hero ===== */
.p30-job__hero{
  position:relative;padding:64px 6vw;display:grid;
  grid-template-columns:1.1fr 1fr;gap:48px;align-items:center;
  background:linear-gradient(180deg,#f3efe6 0%, #ece6d7 100%);
}
.p30-job__hero__photo{aspect-ratio:4/3;overflow:hidden;border-radius:8px}
.p30-job__hero__photo img{width:100%;height:100%;object-fit:cover}
.p30-job__hero__body small{
  font-family:var(--p30-font-display);font-size:12px;font-weight:800;color:var(--p30-red);
  letter-spacing:.16em;
}
.p30-job__hero__body h1{font-size:clamp(28px,3.6vw,40px);font-weight:900;margin:8px 0 14px;letter-spacing:.02em}
.p30-job__hero__body .p30-job__hero__lead{font-size:15px;color:var(--p30-ink-2);margin-bottom:24px}
.p30-job__hero__meta{
  display:grid;grid-template-columns:1fr 1fr;gap:14px 24px;
  background:#fff;border-radius:6px;padding:18px 22px;border:1px solid var(--p30-line);margin:0;
}
.p30-job__hero__meta div{margin:0}
.p30-job__hero__meta dt{font-size:11px;font-weight:800;color:var(--p30-red);letter-spacing:.14em;margin-bottom:4px;font-family:var(--p30-font-display)}
.p30-job__hero__meta dd{margin:0;font-size:14px;font-weight:700}

/* ===== job sec（詳細ページ 各セクション） ===== */
.p30-job__sec{padding:48px 6vw;border-bottom:1px solid var(--p30-line)}
.p30-job__sec__bar{
  display:flex;align-items:baseline;gap:14px;margin-bottom:24px;
}
.p30-job__sec__bar__tag{
  background:var(--p30-ink);color:#fff;padding:6px 14px;border-radius:999px;
  font-size:12px;font-weight:800;letter-spacing:.06em;
}
.p30-job__sec__bar__title{
  font-family:var(--p30-font-display);font-size:18px;font-weight:800;color:var(--p30-red);letter-spacing:.12em;
}
.p30-job__sec p{margin:0 0 12px;font-size:14.5px;color:var(--p30-ink-2)}
.p30-job__sec ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px}
.p30-job__sec ul li{
  padding:10px 14px 10px 28px;background:#fff;border:1px solid var(--p30-line);border-radius:4px;
  font-size:14px;position:relative;
}
.p30-job__sec ul li::before{
  content:"";position:absolute;left:12px;top:50%;transform:translateY(-50%);
  width:8px;height:8px;border-radius:50%;background:var(--p30-red);
}

/* ===== 1日の流れ (p30-day) ===== */
.p30-day{display:flex;flex-direction:column;gap:0;position:relative;padding-left:18px}
.p30-day::before{content:"";position:absolute;left:6px;top:8px;bottom:8px;width:1px;background:var(--p30-line)}
.p30-day__row{display:grid;grid-template-columns:90px 1fr;gap:24px;padding:16px 0;position:relative}
.p30-day__row::before{
  content:"";position:absolute;left:-15px;top:22px;width:13px;height:13px;border-radius:50%;
  background:#fff;border:2.5px solid var(--p30-red);
}
.p30-day__time{
  font-family:var(--p30-font-display);font-size:16px;font-weight:800;color:var(--p30-ink);
  letter-spacing:.04em;
}
.p30-day__body h4{margin:0 0 4px;font-size:15px;font-weight:800}
.p30-day__body p{margin:0;font-size:13.5px;color:var(--p30-gray)}

/* ===== requirements 表 (p30-reqtable) ===== */
.p30-reqtable{
  width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--p30-line);
  font-size:14px;
}
.p30-reqtable tr{border-bottom:1px solid var(--p30-line)}
.p30-reqtable tr:last-child{border-bottom:0}
.p30-reqtable th{
  width:160px;background:var(--p30-beige-2);text-align:left;padding:18px 24px;font-weight:800;font-size:13px;
  border-right:1px solid var(--p30-line);vertical-align:top;
}
.p30-reqtable td{padding:18px 24px;color:var(--p30-ink-2);vertical-align:top}

/* ===== FAQ (p30-faqlist) ===== */
.p30-faqlist{display:flex;flex-direction:column;gap:12px}
.p30-faqitem{
  background:#fff;border:1px solid var(--p30-line);border-radius:6px;overflow:hidden;
}
.p30-faqitem summary{
  list-style:none;cursor:pointer;padding:18px 24px 18px 64px;
  font-weight:800;font-size:15px;position:relative;
}
.p30-faqitem summary::-webkit-details-marker{display:none}
.p30-faqitem summary::before{
  content:"Q";position:absolute;left:24px;top:50%;transform:translateY(-50%);
  width:28px;height:28px;border-radius:50%;background:var(--p30-red);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--p30-font-display);font-weight:900;font-size:14px;
}
.p30-faqitem summary::after{
  content:"+";position:absolute;right:24px;top:50%;transform:translateY(-50%);
  font-size:22px;color:var(--p30-ink);font-weight:300;transition:transform .25s ease;
}
.p30-faqitem[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.p30-faqitem > div{
  padding:0 24px 22px 64px;font-size:14px;color:var(--p30-ink-2);position:relative;
}
.p30-faqitem > div::before{
  content:"A";position:absolute;left:24px;top:0;
  width:28px;height:28px;border-radius:50%;background:var(--p30-ink);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--p30-font-display);font-weight:900;font-size:14px;
}

/* ===== Apply / Form (p30-form) ===== */
.p30-form{
  background:#fff;border:1px solid var(--p30-line);border-radius:8px;padding:36px 32px;
  display:flex;flex-direction:column;gap:18px;
}
.p30-form > div{display:flex;flex-direction:column;gap:6px}
.p30-form label{font-size:13.5px;font-weight:800;display:flex;align-items:center;gap:8px}
.p30-form label small{
  background:var(--p30-red);color:#fff;font-size:10px;font-weight:800;
  padding:2px 8px;border-radius:3px;letter-spacing:.04em;
}
.p30-form input,.p30-form select,.p30-form textarea{
  border:1px solid var(--p30-line);background:#faf6ec;border-radius:4px;
  padding:12px 14px;font:inherit;font-size:14px;color:var(--p30-ink);
}
.p30-form input:focus,.p30-form select:focus,.p30-form textarea:focus{
  outline:none;border-color:var(--p30-red);background:#fff;
}
.p30-form textarea{resize:vertical;min-height:120px}
.p30-form button{
  align-self:center;margin-top:14px;
  background:var(--p30-red);color:#fff;font-family:var(--p30-font-display);
  font-weight:800;letter-spacing:.12em;font-size:14px;
  padding:16px 64px;border-radius:999px;transition:background .2s ease;
}
.p30-form button:hover{background:var(--p30-red-dark)}
.p30-form__note{font-size:12.5px;color:var(--p30-gray);margin-bottom:14px}

/* ===== 沿革 (p30-history) ===== */
.p30-history{display:flex;flex-direction:column;border-left:2px solid var(--p30-red);margin-left:8px}
.p30-history__row{
  display:grid;grid-template-columns:120px 1fr;gap:24px;padding:18px 24px;position:relative;
}
.p30-history__row::before{
  content:"";position:absolute;left:-7px;top:24px;width:12px;height:12px;border-radius:50%;
  background:#fff;border:2.5px solid var(--p30-red);
}
.p30-history__year{
  font-family:var(--p30-font-display);font-size:18px;font-weight:800;color:var(--p30-red);
  letter-spacing:.04em;
}
.p30-history__event{font-size:14px;color:var(--p30-ink-2)}

/* ===== TOP MESSAGE (p30-message) ===== */
.p30-message{
  display:grid;grid-template-columns:.8fr 1.2fr;gap:48px;align-items:center;
  background:#fff;border:1px solid var(--p30-line);border-radius:8px;padding:48px;
  margin-top:40px;position:relative;overflow:hidden;
}
.p30-message__photo img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:6px}
.p30-message__title{
  font-family:var(--p30-font-display);font-size:12px;font-weight:800;color:var(--p30-red);
  letter-spacing:.16em;margin:0 0 8px;
}
.p30-message__lead{
  font-size:clamp(22px,2.4vw,28px);font-weight:900;margin:0 0 18px;line-height:1.5;
}
.p30-message__body{font-size:14.5px;color:var(--p30-ink-2);white-space:pre-line;margin:0 0 20px}
.p30-message__sign{margin:0;font-size:13px}
.p30-message__sign b{font-size:18px;display:block;margin-top:4px}

/* ===== フッターCTA帯 ===== */
.p30-cta{
  background:var(--p30-red);color:#fff;padding:48px 6vw;text-align:center;
  display:flex;justify-content:center;align-items:center;gap:24px;flex-wrap:wrap;
}
.p30-cta strong{font-family:var(--p30-font-display);font-size:24px;font-weight:900;letter-spacing:.06em}
.p30-cta a{
  background:#fff;color:var(--p30-red);padding:16px 42px;border-radius:999px;
  font-family:var(--p30-font-display);font-weight:800;letter-spacing:.1em;font-size:13px;
}
.p30-cta a:hover{background:#000;color:#fff}

/* ===== フッター ===== */
.p30-foot{background:var(--p30-foot);color:#bbb;padding:64px 6vw 32px}
.p30-foot__brand{display:flex;align-items:baseline;gap:14px;margin-bottom:32px}
.p30-foot__brand strong{font-family:var(--p30-font-display);color:var(--p30-red);font-size:24px;font-weight:900;letter-spacing:.04em}
.p30-foot__brand small{color:#fff;font-size:11px;font-weight:700;letter-spacing:.18em}
.p30-foot__cols{
  display:grid;grid-template-columns:repeat(5,1fr);gap:32px;margin-bottom:40px;
  padding-top:32px;border-top:1px solid #333;
}
.p30-foot__col h4{
  font-family:var(--p30-font-display);color:#fff;font-size:12px;font-weight:800;
  letter-spacing:.14em;margin:0 0 12px;
}
.p30-foot__col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.p30-foot__col a{font-size:12.5px;color:#bbb}
.p30-foot__col a:hover{color:#fff}
.p30-foot__legal{
  padding-top:24px;border-top:1px solid #333;font-size:11.5px;color:#888;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;
}
.p30-foot__legal b{color:var(--p30-red);margin-right:8px}

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

/* ===== Responsive ===== */
@media (max-width:980px){
  .p30-jobpeople__grid{grid-template-columns:repeat(6,1fr)}
  .p30-jptile--w6{grid-column:span 6}
  .p30-jptile--w4,.p30-jptile--w3{grid-column:span 3}
  .p30-figures__row{grid-template-columns:repeat(2,1fr)}
  .p30-job__hero{grid-template-columns:1fr}
  .p30-message{grid-template-columns:1fr;padding:32px}
  .p30-foot__cols{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:640px){
  .p30-header{grid-template-columns:1fr auto;padding:0 16px;height:56px}
  .p30-header__nav{display:none}
  .p30-subnav{top:56px;padding:0 16px}
  main{padding-top:104px}
  .p30-news{grid-template-columns:1fr;text-align:left}
  .p30-jobpeople__grid{grid-template-columns:1fr}
  .p30-jptile--w6,.p30-jptile--w4,.p30-jptile--w3{grid-column:auto}
  .p30-figures__row{grid-template-columns:1fr}
  .p30-courserow{grid-template-columns:auto 1fr;gap:14px}
  .p30-courserow__arrow{display:none}
  .p30-job__hero__meta{grid-template-columns:1fr}
  .p30-reqtable th{width:110px;padding:14px 12px}
  .p30-reqtable td{padding:14px 12px}
  .p30-foot__cols{grid-template-columns:1fr 1fr}
  .p30-cta{flex-direction:column}
}
