/* =========================================================
   Job is Well — Landing Page
   Design tokens (完成イメージ・背景画像から抽出)
   ========================================================= */
:root {
  /* colors */
  --color-primary:        #0236AE;   /* 一次アクション青 */
  --color-primary-deep:   #0026A4;   /* 濃いボタン */
  --color-primary-hover:  #042B8C;
  --color-headline:       #14246E;   /* 見出し濃紺インク */
  --color-navy:           #001657;   /* セクション濃紺背景に合わせた地色 */
  --color-navy-deep:      #001C5B;
  --color-on-primary:     #FFFFFF;
  --color-on-navy:        #FFFFFF;
  --color-on-navy-sub:    #C5D0EC;
  --color-text-body:      #3A4252;
  --color-text-sub:       #5B6473;
  --color-badge-border:   #C3D2F5;
  --color-badge-text:     #1E3DA6;
  --color-surface:        #FBFCFE;   /* 暖色寄りの白(純白は不使用) */
  --color-surface-2:      #F4F7FC;
  --color-hairline:       #E4E8F0;
  --color-gold:           #EAE0C2;   /* 実績数字のシャンパンゴールド */
  --color-tag:            #163A8C;

  /* typography */
  --font-base: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "游ゴシック", "Yu Gothic", sans-serif;
  --font-serif: "Noto Serif JP", "Times New Roman", "YuMincho", serif;

  /* radius */
  --r-sm: 6px;
  --r-md: 10px;
  --r-card: 16px;
  --r-pill: 999px;

  /* layout */
  --content: 1200px;
  --page-x: 56px;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-base);
  color: var(--color-text-body);
  background: #eef1f7;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  line-height: 1.6;
}
img { max-width: 100%; display: block; }
a { color: inherit; }

/* 全ブロック共通: 横幅1600pxで中央寄せ、背景画像はcover */
.block {
  position: relative;
  max-width: 1600px;
  margin: 0 auto;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}

/* 共通パーツ ---------------------------------------------- */
.cta__arrow { font-size: 1em; line-height: 1; }

.btn {
  font-family: var(--font-base);
  font-weight: 700;
  font-size: 14.5px;
  border: none;
  border-radius: var(--r-sm);
  cursor: pointer;
  white-space: nowrap;
  transition: background .15s ease, color .15s ease, transform .1s ease;
}
.btn:active { transform: translateY(1px); }
.btn--download {
  background: rgba(255,255,255,0.85);
  color: var(--color-primary);
  border: 1.5px solid var(--color-primary);
  padding: 10px 22px;
}
.btn--download:hover { background: #fff; }
.btn--contact {
  background: var(--color-primary-deep);
  color: var(--color-on-primary);
  padding: 11px 24px;
}
.btn--contact:hover { background: var(--color-primary-hover); }

/* pill button (私たちの想いを見る / 一覧を見る / 会社案内) */
.btn-pill {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  min-width: 260px;
  padding: 17px 26px;
  background: #fff;
  color: var(--color-headline);
  font-weight: 700;
  font-size: 16px;
  border-radius: var(--r-sm);
  text-decoration: none;
  transition: background .15s ease, transform .1s ease, box-shadow .15s ease;
}
.btn-pill .cta__arrow { color: var(--color-primary); }
.btn-pill:hover { box-shadow: 0 6px 18px rgba(0,0,0,.15); transform: translateY(-1px); }
.btn-pill--sm { min-width: 160px; padding: 11px 20px; font-size: 14px; border: 1.5px solid var(--color-primary); }
.btn-pill--outline {
  background: transparent;
  color: #fff;
  border: 1.5px solid rgba(255,255,255,.6);
  min-width: 220px;
  padding: 12px 22px;
  font-size: 14px;
}
.btn-pill--outline .cta__arrow { color: #fff; }
.btn-pill--outline:hover { background: rgba(255,255,255,.12); }

.section-title {
  color: var(--color-headline);
  font-weight: 800;
  font-size: 30px;
  letter-spacing: .04em;
}
.section-title--center { text-align: center; }

/* =========================================================
   BLOCK 01 : Hero
   ========================================================= */
.block--hero {
  background-image: url("assets/block_01_bg.png");
  background-position: center right;
}
.hero__inner { position: relative; z-index: 2; padding: 28px var(--page-x) 0; }
.nav { display: flex; align-items: center; gap: 26px; }
.nav__logo {
  font-family: var(--font-serif);
  font-weight: 700;
  font-size: 28px;
  letter-spacing: .01em;
  color: #0C1330;
  white-space: nowrap;
}
.nav__badge {
  font-size: 12.5px; font-weight: 700;
  color: var(--color-badge-text);
  border: 1.5px solid var(--color-badge-border);
  border-radius: var(--r-pill);
  padding: 7px 16px; white-space: nowrap;
  background: rgba(255,255,255,.4);
}
.nav__menu { display: flex; gap: 28px; margin-left: auto; }
.nav__menu a { font-size: 15px; font-weight: 700; color: #1B2440; text-decoration: none; white-space: nowrap; transition: color .15s; }
.nav__menu a:hover { color: var(--color-primary); }
.nav__actions { display: flex; gap: 12px; margin-left: 24px; }

.hero__copy { max-width: 620px; padding-top: 56px; padding-bottom: 60px; }
.hero__title { color: var(--color-headline); font-weight: 800; font-size: 56px; line-height: 1.32; letter-spacing: .005em; }
.hero__title span { white-space: nowrap; }
.hero__lead { color: var(--color-headline); font-weight: 700; font-size: 28px; line-height: 1.5; margin-top: 28px; }
.hero__desc { color: var(--color-text-sub); font-size: 16px; line-height: 2; margin-top: 26px; font-weight: 500; }
.hero__cta { display: flex; gap: 20px; margin-top: 40px; }
.cta {
  display: inline-flex; align-items: center; justify-content: space-between;
  gap: 24px; min-width: 290px; font-size: 16px; font-weight: 700;
  border-radius: var(--r-sm); padding: 18px 24px; text-decoration: none;
  white-space: nowrap; transition: background .15s ease, transform .1s ease;
}
.cta:active { transform: translateY(1px); }
.cta--primary { background: var(--color-primary); color: var(--color-on-primary); }
.cta--primary:hover { background: var(--color-primary-hover); }
.cta--ghost { background: rgba(255,255,255,.7); color: var(--color-headline); border: 1.5px solid #B9C6E6; }
.cta--ghost:hover { background: #fff; }
.cta--ghost .cta__arrow { color: var(--color-primary); }

.features {
  position: relative; z-index: 2;
  margin: 0 var(--page-x) 40px;
  background: var(--color-surface);
  border-radius: 18px;
  box-shadow: 0 18px 50px rgba(20,36,110,.10);
  display: grid; grid-template-columns: repeat(4,1fr);
}
.feature { padding: 36px 28px; border-right: 1px solid var(--color-hairline); }
.feature:last-child { border-right: none; }
.feature__head { display: flex; align-items: flex-start; gap: 14px; }
.feature__icon { flex: 0 0 auto; width: 44px; height: 44px; color: var(--color-primary); }
.feature__icon svg { width: 100%; height: 100%; }
.feature__title { color: var(--color-headline); font-size: 16px; font-weight: 800; line-height: 1.45; padding-top: 2px; }
.feature__desc { color: var(--color-text-sub); font-size: 13.5px; line-height: 1.85; margin-top: 18px; font-weight: 500; }

/* =========================================================
   BLOCK 02 : Mission
   ========================================================= */
.block--mission {
  background-image: url("assets/block_02_bg.png");
  background-color: var(--color-navy);
}
.mission__inner {
  max-width: var(--content); margin: 0 auto;
  padding: 70px var(--page-x);
}
.mission__eyebrow { color: #fff; font-weight: 700; font-size: 15px; letter-spacing: .18em; }
.mission__title { color: #fff; font-weight: 800; font-size: 40px; line-height: 1.45; margin-top: 18px; letter-spacing: .02em; }
.mission__desc { color: var(--color-on-navy-sub); font-size: 15px; line-height: 2.1; margin-top: 26px; }
.block--mission .btn-pill { margin-top: 36px; }

/* =========================================================
   BLOCK 03 : Steps
   ========================================================= */
.block--steps {
  background-image: url("assets/block_03_bg.png");
  background-color: var(--color-surface);
}
.steps__inner { max-width: var(--content); margin: 0 auto; padding: 64px var(--page-x); }
.steps__eyebrow { text-align: center; color: var(--color-primary); font-weight: 700; font-size: 16px; }
.steps__slash { color: var(--color-primary); margin: 0 6px; font-weight: 400; }
.steps__title { text-align: center; color: var(--color-headline); font-weight: 800; font-size: 30px; margin-top: 10px; letter-spacing: .03em; }
.steps__list {
  list-style: none; margin-top: 40px;
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px;
  align-items: stretch;
}
.step {
  position: relative;
  background: #fff;
  border: 1px solid #E6ECF6;
  border-radius: var(--r-card);
  padding: 30px 16px 26px;
  text-align: center;
}
.step:not(:last-child)::after {
  content: "\203A";
  position: absolute; top: 50%; right: -13px; transform: translateY(-50%);
  color: var(--color-primary); font-size: 22px; font-weight: 700; z-index: 3;
}
.step__icon { display: block; width: 52px; height: 52px; margin: 0 auto 16px; color: var(--color-primary); }
.step__icon svg { width: 100%; height: 100%; }
.step__title { color: var(--color-headline); font-weight: 700; font-size: 14.5px; line-height: 1.5; }
.step__title b { color: var(--color-primary); font-weight: 800; margin-right: 2px; }
.step__desc { color: var(--color-text-sub); font-size: 12.5px; line-height: 1.7; margin-top: 10px; }

/* =========================================================
   BLOCK 04 : Stats
   ========================================================= */
.block--stats {
  background-image: url("assets/block_04_bg.png");
  background-color: var(--color-navy);
}
.stats__inner { max-width: var(--content); margin: 0 auto; padding: 56px var(--page-x); }
.stats__title { text-align: center; color: #fff; font-weight: 800; font-size: 28px; letter-spacing: .04em; }
.stats__grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 22px; margin-top: 36px; }
.stat {
  border: 1px solid rgba(255,255,255,.28);
  border-radius: var(--r-card);
  padding: 24px 18px 26px;
  text-align: center;
}
.stat__label { color: #fff; font-size: 14px; font-weight: 600; }
.stat__num {
  color: var(--color-gold);
  font-weight: 800; font-size: 52px; line-height: 1.1; margin: 8px 0 12px;
  letter-spacing: .01em;
}
.stat__unit { font-size: 17px; font-weight: 700; margin-left: 4px; }
.stat__note { color: var(--color-on-navy-sub); font-size: 12.5px; line-height: 1.7; }

/* =========================================================
   BLOCK 05 : Voices + News
   ========================================================= */
.block--voices {
  background-image: url("assets/block_05_bg.png");
  background-color: var(--color-surface-2);
}
.voices__inner { max-width: var(--content); margin: 0 auto; padding: 60px var(--page-x) 64px; }

.voices__carousel { position: relative; margin-top: 36px; }
.voices__arrow {
  position: absolute; top: 38%; transform: translateY(-50%);
  width: 40px; height: 40px; border-radius: 50%;
  border: 1px solid #C5CEDF; background: #fff; color: var(--color-headline);
  font-size: 20px; cursor: pointer; z-index: 4;
  display: grid; place-items: center;
}
.voices__arrow--prev { left: -52px; }
.voices__arrow--next { right: -52px; }
.voices__grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; }
.voice-card {
  background: #fff; border-radius: var(--r-card); overflow: hidden;
  box-shadow: 0 8px 22px rgba(20,36,110,.07);
}
.voice-card__media { position: relative; height: 150px; background-size: cover; background-position: center; }
.voice-card__media--1 { background-image: linear-gradient(135deg,#7d8aa0,#4a5870); }
.voice-card__media--2 { background-image: linear-gradient(135deg,#9aa6b8,#6b7686); }
.voice-card__media--3 { background-image: linear-gradient(135deg,#5b6b86,#37425a); }
.voice-card__media--4 { background-image: linear-gradient(135deg,#6f7a8c,#3f4960); }
.voice-card__tag {
  position: absolute; left: 0; bottom: 12px;
  background: var(--color-tag); color: #fff;
  font-size: 12px; font-weight: 700; padding: 4px 12px;
}
.voice-card__body { padding: 18px 18px 22px; }
.voice-card__name { color: var(--color-headline); font-weight: 800; font-size: 15px; }
.voice-card__sub { color: #9AA2B0; font-size: 11px; margin-top: 2px; }
.voice-card__text { color: var(--color-text-sub); font-size: 13px; line-height: 1.8; margin-top: 12px; }

.news__head { display: flex; align-items: center; justify-content: center; position: relative; margin-top: 64px; }
.news__more { position: absolute; right: 0; }
.news__grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; margin-top: 30px; }
.news-card { cursor: pointer; }
.news-card__media { height: 120px; border-radius: 10px; background-size: cover; background-position: center; }
.news-card__media--1 { background-image: linear-gradient(135deg,#8e9aae,#59647c); }
.news-card__media--2 { background-image: linear-gradient(135deg,#a7b2c4,#6f7a8e); }
.news-card__media--3 { background-image: linear-gradient(135deg,#7e8aa0,#4f5a72); }
.news-card__media--4 { background-image: linear-gradient(135deg,#9ba6b8,#677386); }
.news-card__meta { display: flex; align-items: center; gap: 10px; margin-top: 14px; }
.news-card__meta time { color: #6B7384; font-size: 12.5px; font-weight: 600; }
.news-card__cat { font-size: 11px; font-weight: 700; color: var(--color-primary); background: #E7EDFA; padding: 3px 10px; border-radius: 4px; }
.news-card__cat--gray { color: #6B7384; background: #E8EAEF; }
.news-card__title { color: var(--color-headline); font-weight: 700; font-size: 14.5px; line-height: 1.6; margin-top: 10px; }

/* =========================================================
   BLOCK 06 : CTA banner
   ========================================================= */
.block--cta {
  background-image: url("assets/block_06_bg.png");
  background-color: var(--color-navy);
  background-position: center;
}
.cta-banner__inner { max-width: var(--content); margin: 0 auto; padding: 64px var(--page-x); text-align: center; }
.cta-banner__title { color: #fff; font-weight: 800; font-size: 36px; letter-spacing: .03em; text-shadow: 0 2px 12px rgba(0,0,0,.25); }
.cta-banner__lead { color: #Eaf0ff; font-size: 17px; margin-top: 16px; text-shadow: 0 1px 8px rgba(0,0,0,.25); }
.cta-banner__btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 40px;
  margin-top: 30px; min-width: 420px;
  background: var(--color-primary-deep); color: #fff;
  font-weight: 700; font-size: 18px;
  padding: 20px 36px; border-radius: var(--r-sm); text-decoration: none;
  box-shadow: 0 8px 24px rgba(0,0,0,.3);
  transition: background .15s ease, transform .1s ease;
}
.cta-banner__btn:hover { background: var(--color-primary-hover); }
.cta-banner__btn:active { transform: translateY(1px); }

/* =========================================================
   BLOCK 07 : Footer
   ========================================================= */
.block--footer {
  background-image: url("assets/block_07_bg.png");
  background-color: var(--color-navy);
  color: #fff;
}
.footer__inner { max-width: var(--content); margin: 0 auto; padding: 56px var(--page-x) 30px; }
.footer__top { display: flex; gap: 50px; }
.footer__brand { flex: 0 0 250px; }
.footer__logo { font-family: var(--font-serif); font-weight: 700; font-size: 26px; color: #fff; }
.footer__brand-desc { color: var(--color-on-navy-sub); font-size: 13px; line-height: 1.9; margin: 16px 0 20px; }
.footer__cols { display: grid; grid-template-columns: repeat(6,1fr); gap: 24px; flex: 1; }
.footer__col-title { font-weight: 700; font-size: 14px; margin-bottom: 14px; color: #fff; }
.footer__col a { display: block; color: var(--color-on-navy-sub); font-size: 12.5px; text-decoration: none; margin-bottom: 9px; transition: color .15s; }
.footer__col a:hover { color: #fff; }

.footer__contact { display: grid; grid-template-columns: 1fr 1.2fr 1.2fr; gap: 20px; margin-top: 44px; }
.contact-box {
  border-radius: var(--r-md); padding: 20px 26px;
  display: flex; flex-direction: column; justify-content: center;
  text-decoration: none;
}
.contact-box--tel { background: #fff; color: #14224a; }
.contact-box__label { font-size: 12px; font-weight: 600; }
.contact-box__tel { font-size: 28px; font-weight: 800; letter-spacing: .02em; display: flex; align-items: center; gap: 10px; }
.contact-box__ico { font-size: 22px; }
.contact-box__hours { font-size: 11px; color: #6B7384; }

.contact-box--form, .contact-box--dl {
  flex-direction: row; align-items: center; gap: 16px;
  font-weight: 800; font-size: 19px;
  transition: transform .1s ease, box-shadow .15s ease;
}
.contact-box--form { background: var(--color-primary-deep); color: #fff; }
.contact-box--dl { background: #EDEFF2; color: #14224a; }
.contact-box--form:hover, .contact-box--dl:hover { box-shadow: 0 8px 22px rgba(0,0,0,.25); transform: translateY(-1px); }
.contact-box__ico--lg { font-size: 26px; }
.contact-box__main { flex: 1; line-height: 1.35; }
.contact-box__main small { font-size: 12px; font-weight: 600; opacity: .85; }
.contact-box--form .cta__arrow, .contact-box--dl .cta__arrow { font-size: 22px; }

.footer__bottom {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: 40px; padding-top: 22px;
  border-top: 1px solid rgba(255,255,255,.15);
}
.footer__legal { display: flex; gap: 28px; }
.footer__legal a { color: var(--color-on-navy-sub); font-size: 12.5px; text-decoration: none; }
.footer__legal a:hover { color: #fff; }
.footer__copy { color: var(--color-on-navy-sub); font-size: 12px; }

/* page top button */
.pagetop {
  position: fixed; right: 24px; bottom: 24px;
  width: 46px; height: 46px; border-radius: 50%;
  background: #fff; color: var(--color-headline);
  display: grid; place-items: center; text-decoration: none;
  box-shadow: 0 4px 14px rgba(0,0,0,.2); font-size: 20px; z-index: 50;
}

/* =========================================================
   Responsive (PC primary, graceful down to tablet)
   ========================================================= */
@media (max-width: 1280px) {
  :root { --page-x: 36px; }
  .hero__title { font-size: 48px; }
}
@media (max-width: 1080px) {
  .nav__menu { display: none; }
  .hero__title { font-size: 40px; }
  .hero__title span { white-space: normal; }
  .hero__lead { font-size: 22px; }
  .features { grid-template-columns: repeat(2,1fr); }
  .feature:nth-child(2) { border-right: none; }
  .feature:nth-child(-n+2) { border-bottom: 1px solid var(--color-hairline); }
  .steps__list { grid-template-columns: repeat(2,1fr); }
  .step:not(:last-child)::after { display: none; }
  .stats__grid { grid-template-columns: repeat(2,1fr); }
  .voices__grid, .news__grid { grid-template-columns: repeat(2,1fr); }
  .voices__arrow { display: none; }
  .footer__top { flex-direction: column; }
  .footer__cols { grid-template-columns: repeat(3,1fr); }
  .footer__contact { grid-template-columns: 1fr; }
  .cta-banner__btn { min-width: 0; width: 100%; }
}
@media (max-width: 680px) {
  :root { --page-x: 18px; }
  .hero__inner { padding-top: 16px; }
  .nav__badge { display: none; }
  .hero__copy {
    background: linear-gradient(90deg, rgba(248,250,253,.92), rgba(248,250,253,.78) 70%, rgba(248,250,253,0));
    border-radius: 12px; padding: 22px 14px 26px; margin-top: 10px;
  }
  .hero__title { font-size: 30px; line-height: 1.4; }
  .hero__lead { font-size: 19px; }
  .hero__desc { color: var(--color-text-body); }
  .hero__desc br { display: none; }
  .hero__cta { flex-direction: column; }
  .cta { min-width: 0; width: 100%; }
  .features { grid-template-columns: 1fr; }
  .feature { border-right: none !important; border-bottom: 1px solid var(--color-hairline); }
  .feature:last-child { border-bottom: none; }
  .mission__title { font-size: 28px; }
  .mission__desc br { display: none; }
  .steps__list { grid-template-columns: 1fr; }
  .steps__title, .stats__title, .cta-banner__title { font-size: 22px; }
  .stats__grid { grid-template-columns: 1fr; }
  .stat__num { font-size: 44px; }
  .voices__grid, .news__grid { grid-template-columns: 1fr; }
  .news__more { position: static; margin-top: 14px; }
  .news__head { flex-direction: column; }
  .footer__cols { grid-template-columns: repeat(2,1fr); }
  .footer__bottom { flex-direction: column; gap: 14px; align-items: flex-start; }
  .cta-banner__btn { font-size: 15px; padding: 16px 20px; gap: 16px; }
}
@media (prefers-reduced-motion: reduce) { * { transition: none !important; scroll-behavior: auto; } }
