/* =========================================================
   Food Link コーポレートサイト v2
   Fantasy.co 風 / 白×黒×オレンジ / 1ページ長尺LP
   ---------------------------------------------------------
   編集ポイント:
   - 色 → :root の --c-* を書き換え
   - フォント → :root の --ff-* を書き換え
   ========================================================= */

/* ---------- リセット ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
img,svg,video{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{background:none;border:none;font:inherit;color:inherit;cursor:pointer}
ul{list-style:none}

/* ---------- デザイントークン ---------- */
:root{
  /* カラー（白×黒×オレンジ） */
  --c-bg:#FAFAFA;
  --c-bg-pure:#FFFFFF;
  --c-bg-dark:#0A0A0A;
  --c-text:#0A0A0A;
  --c-text-dim:#666666;
  --c-text-mute:#999999;
  --c-line:#E5E5E5;
  --c-line-dark:#1F1F1F;
  --c-accent:#FF5A1F;
  --c-accent-soft:#FF7A45;

  /* フォント */
  --ff-jp:"Noto Sans JP","Hiragino Kaku Gothic ProN","Yu Gothic",system-ui,sans-serif;
  --ff-en:"Inter","Helvetica Neue",Arial,sans-serif;
  --ff-display:"Anton","Bebas Neue","Noto Sans JP",sans-serif;

  /* レイアウト */
  --maxw:1400px;
  --px:clamp(20px,4vw,56px);
  --section-py:clamp(96px,14vw,220px);

  /* タイポ */
  --fs-hero:clamp(56px,14vw,220px);
  --fs-display:clamp(40px,9vw,140px);
  --fs-h2:clamp(32px,5vw,72px);
  --fs-h3:clamp(20px,2.2vw,28px);
  --fs-body:clamp(14px,1.5vw,16px);
  --fs-sm:13px;

  /* イージング */
  --ease:cubic-bezier(.19,1,.22,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

/* ---------- ベース ---------- */
html{font-family:var(--ff-jp);background:var(--c-bg);color:var(--c-text)}
body{
  font-family:var(--ff-jp);
  font-size:var(--fs-body);
  line-height:1.8;
  color:var(--c-text);
  background:var(--c-bg);
  font-feature-settings:"palt";
  letter-spacing:0.01em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

::selection{background:var(--c-accent);color:var(--c-bg-pure)}

.container{max-width:var(--maxw);margin:0 auto;padding-left:var(--px);padding-right:var(--px)}

/* ---------- ヘッダー ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:20px 0;
  transition:background-color .4s var(--ease),padding .4s var(--ease),box-shadow .4s var(--ease);
  background:transparent;
}
.site-header.is-scrolled{
  background:rgba(250,250,250,.85);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  padding:14px 0;
  border-bottom:1px solid var(--c-line);
}
.site-header__inner{
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  max-width:var(--maxw);margin:0 auto;padding-left:var(--px);padding-right:var(--px);
}
.site-header__logo{
  font-family:var(--ff-en);font-weight:700;font-size:18px;letter-spacing:.05em;
  color:var(--c-text);
  display:flex;align-items:center;gap:8px;
}
.site-header__logo-mark{
  font-family:var(--ff-display);font-size:22px;line-height:1;color:var(--c-accent);
}
.site-nav{display:flex;align-items:center;gap:32px}
.site-nav__link{
  font-family:var(--ff-en);font-size:13px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;
  color:var(--c-text);position:relative;padding:6px 0;
  transition:color .2s;
}
.site-nav__link::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--c-accent);
  transform:scaleX(0);transform-origin:right;transition:transform .4s var(--ease);
}
.site-nav__link:hover{color:var(--c-accent)}
.site-nav__link:hover::after,.site-nav__link.is-current::after{
  transform:scaleX(1);transform-origin:left;
}
.site-nav__cta{
  font-family:var(--ff-en);font-size:13px;font-weight:700;letter-spacing:.1em;
  background:var(--c-accent);color:#fff;padding:12px 22px;border-radius:999px;
  transition:transform .2s, background .2s;
}
.site-nav__cta:hover{background:var(--c-accent-soft);transform:translateY(-1px);color:#fff}
.site-nav__cta::after{display:none}

/* ハンバーガー */
.nav-toggle{
  display:none;width:32px;height:32px;position:relative;z-index:110;
}
.nav-toggle span{
  display:block;width:24px;height:2px;background:var(--c-text);margin:5px auto;
  transition:transform .3s var(--ease),opacity .3s,background .3s;
}
.site-nav.is-open ~ .nav-toggle span,
.nav-toggle.is-open span{background:#fff}
.nav-toggle.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.is-open span:nth-child(2){opacity:0}
.nav-toggle.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media (max-width:768px){
  .nav-toggle{display:block}
  .site-nav{
    position:fixed;inset:0;background:var(--c-bg-dark);
    flex-direction:column;justify-content:center;gap:32px;
    transform:translateX(100%);transition:transform .5s var(--ease);
    mix-blend-mode:normal;
  }
  .site-nav.is-open{transform:translateX(0)}
  .site-nav__link{font-size:24px;color:#fff}
  .site-nav__cta{padding:16px 32px;font-size:14px}
}

/* ---------- 共通：セクション ---------- */
.section{padding-top:var(--section-py);padding-bottom:var(--section-py);position:relative}
.section--dark{background:var(--c-bg-dark);color:#fff}
.section--dark .text-dim,.section--dark .eyebrow{color:rgba(255,255,255,.5)}

.eyebrow{
  font-family:var(--ff-en);font-size:12px;font-weight:600;letter-spacing:.3em;
  text-transform:uppercase;color:var(--c-accent);margin-bottom:24px;
  display:inline-flex;align-items:center;gap:12px;
}
.eyebrow::before{
  content:"";width:32px;height:1px;background:var(--c-accent);display:inline-block;
}

.h2{
  font-family:var(--ff-jp);font-weight:900;
  font-size:var(--fs-h2);line-height:1.15;letter-spacing:-.01em;
  margin-bottom:48px;
}
.h2--display{font-family:var(--ff-display);font-weight:400;letter-spacing:.02em;line-height:.95}

.lead{
  font-size:clamp(15px,1.7vw,18px);line-height:1.95;color:var(--c-text-dim);
  max-width:680px;
}
.section--dark .lead{color:rgba(255,255,255,.7)}

.text-accent{color:var(--c-accent)}
.text-dim{color:var(--c-text-dim)}

/* ---------- Hero ---------- */
.hero{
  min-height:100vh;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:160px 0 80px;
  position:relative;
  background:var(--c-bg-pure);
  overflow:hidden;
}
.hero__inner{
  max-width:var(--maxw);margin:0 auto;
  padding-left:var(--px);padding-right:var(--px);
  width:100%;position:relative;z-index:2;
}
.hero__eyebrow{
  font-family:var(--ff-en);font-size:13px;font-weight:600;letter-spacing:.3em;
  text-transform:uppercase;color:var(--c-accent);margin-bottom:32px;
  display:flex;align-items:center;gap:16px;
}
.hero__eyebrow::before{
  content:"";width:40px;height:1px;background:var(--c-accent);
}
.hero__title{
  font-family:var(--ff-jp);font-weight:900;
  font-size:clamp(40px,8vw,120px);line-height:1.1;letter-spacing:-.02em;
  margin-bottom:48px;color:var(--c-text);
}
.hero__title span{display:block}
.hero__title em{
  font-style:normal;color:var(--c-accent);
}
.hero__meta{
  display:flex;flex-wrap:wrap;gap:24px 64px;
  border-top:1px solid var(--c-line);padding-top:32px;
  font-size:14px;color:var(--c-text-dim);
}
.hero__meta-item{display:flex;flex-direction:column;gap:4px}
.hero__meta-item small{
  font-family:var(--ff-en);font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--c-text-mute);
}
.hero__meta-item strong{font-weight:700;color:var(--c-text);font-size:16px}

.hero__scroll{
  position:absolute;bottom:32px;right:var(--px);
  font-family:var(--ff-en);font-size:11px;letter-spacing:.3em;
  text-transform:uppercase;color:var(--c-text-mute);
  display:flex;align-items:center;gap:8px;
  writing-mode:vertical-rl;
}
.hero__scroll::after{
  content:"";width:1px;height:48px;background:var(--c-text);
  animation:scrollHint 2s ease-in-out infinite;
}
@keyframes scrollHint{
  0%,100%{transform:scaleY(0);transform-origin:top}
  50%{transform:scaleY(1)}
}

/* ---------- マーキー（2行・逆方向） ---------- */
.marquee{
  overflow:hidden;
  border-top:1px solid var(--c-line);border-bottom:1px solid var(--c-line);
  padding:18px 0;background:var(--c-bg-pure);
}
.marquee + .marquee{border-top:none}
.marquee--dark{background:var(--c-bg-dark);border-color:var(--c-line-dark)}
.marquee--reverse .marquee__track{animation-direction:reverse;font-style:italic}
.marquee--reverse .marquee__track span::after{color:var(--c-text)}
.marquee__track{
  display:flex;gap:48px;white-space:nowrap;
  animation:marquee 38s linear infinite;
  font-family:var(--ff-display);font-size:clamp(26px,3.8vw,52px);
  line-height:1;letter-spacing:.02em;
  will-change:transform;
}
.marquee__track span{display:inline-flex;align-items:center;gap:48px}
.marquee__track span::after{
  content:"●";color:var(--c-accent);font-family:var(--ff-en);font-size:.4em;
}
.marquee--dark .marquee__track{color:#fff}
@keyframes marquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* ---------- 引用大セクション ---------- */
.quote-section{
  padding:var(--section-py) 0;background:var(--c-bg-pure);
}
.quote{
  max-width:1200px;margin:0 auto;padding:0 var(--px);
}
.quote__text{
  font-family:var(--ff-jp);font-weight:900;
  font-size:clamp(28px,5.5vw,80px);line-height:1.3;letter-spacing:-.01em;
}
.quote__text em{font-style:normal;color:var(--c-accent)}
.quote__caption{
  margin-top:48px;display:flex;align-items:center;gap:16px;
  font-family:var(--ff-en);font-size:12px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--c-text-mute);
}
.quote__caption::before{
  content:"";width:48px;height:1px;background:var(--c-text-mute);
}

/* ---------- なぜ営業代行か（カード並び） ---------- */
.why{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
@media (max-width:900px){.why{grid-template-columns:1fr;gap:48px}}
.why__body p{
  margin-bottom:1.8em;font-size:clamp(15px,1.6vw,17px);
  line-height:1.95;color:var(--c-text-dim);
}
.why__body p strong{color:var(--c-text);font-weight:700}
.why__list{display:grid;gap:16px}
.why__list-item{
  padding:24px;border:1px solid var(--c-line);border-radius:4px;
  background:var(--c-bg-pure);
  display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:center;
  transition:border-color .3s,transform .3s var(--ease);
}
.why__list-item:hover{border-color:var(--c-accent);transform:translateX(4px)}
.why__list-num{
  font-family:var(--ff-display);font-size:36px;color:var(--c-accent);line-height:1;
}
.why__list-body strong{display:block;font-weight:700;margin-bottom:4px}
.why__list-body span{font-size:13px;color:var(--c-text-dim);line-height:1.7}

/* ---------- 巨大数字（暗背景） ---------- */
.big-numbers{
  background:var(--c-bg-dark);color:#fff;
  padding:var(--section-py) 0;
  position:relative;overflow:hidden;
}
.big-numbers__grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--c-line-dark);
  margin-top:64px;
}
@media (max-width:900px){
  .big-numbers__grid{grid-template-columns:1fr}
}
.big-num{
  padding:64px 24px;border-right:1px solid var(--c-line-dark);
  border-bottom:1px solid var(--c-line-dark);
}
.big-num:last-child{border-right:none}
@media (max-width:900px){
  .big-num{border-right:none}
}
.big-num__value{
  font-family:var(--ff-display);font-size:clamp(80px,16vw,240px);
  line-height:.85;color:#fff;letter-spacing:-.04em;
  margin-bottom:24px;display:block;
}
.big-num__value sup{
  font-size:.35em;font-weight:400;color:var(--c-accent);
  margin-left:8px;vertical-align:super;
}
.big-num__label{
  font-family:var(--ff-en);font-size:12px;letter-spacing:.2em;
  text-transform:uppercase;color:rgba(255,255,255,.5);
  margin-bottom:12px;
}
.big-num__desc{font-size:14px;color:rgba(255,255,255,.7);line-height:1.7}

.big-numbers__caption{
  margin-top:64px;font-size:clamp(18px,2.2vw,28px);
  line-height:1.6;color:rgba(255,255,255,.9);
  border-top:1px solid var(--c-line-dark);padding-top:48px;
}

/* ---------- Philosophy（超巨大） ---------- */
.philosophy{
  padding:var(--section-py) 0;background:var(--c-bg);position:relative;
}
.philosophy__inner{max-width:1600px;margin:0 auto;padding:0 var(--px)}
.philosophy__title{
  font-family:var(--ff-display);font-size:var(--fs-display);
  line-height:.92;letter-spacing:-.02em;color:var(--c-text);
}
.philosophy__title em{font-style:normal;color:var(--c-accent)}
.philosophy__body{
  margin-top:64px;max-width:720px;font-size:clamp(16px,1.8vw,20px);
  line-height:2;color:var(--c-text-dim);
}

/* ---------- Values（3つの掟） ---------- */
.values{display:grid;gap:0}
.value-row{
  display:grid;grid-template-columns:120px 1fr;gap:48px;
  padding:80px 0;border-top:1px solid var(--c-line);
  align-items:start;
}
.value-row:last-child{border-bottom:1px solid var(--c-line)}
@media (max-width:768px){
  .value-row{grid-template-columns:1fr;gap:24px;padding:56px 0}
}
.value-row__num{
  font-family:var(--ff-display);font-size:clamp(48px,7vw,96px);
  color:var(--c-accent);line-height:1;letter-spacing:-.02em;
}
.value-row__title{
  font-family:var(--ff-jp);font-weight:900;
  font-size:clamp(24px,3.5vw,44px);line-height:1.3;letter-spacing:-.005em;
  margin-bottom:24px;
}
.value-row__body{
  font-size:clamp(14px,1.5vw,17px);line-height:1.95;color:var(--c-text-dim);
  max-width:720px;
}
.value-row__body strong{color:var(--c-text);font-weight:700}

/* ---------- 給与テーブル ---------- */
.salary{display:grid;gap:48px}
.salary-table{
  border-top:1px solid var(--c-line);
  border-bottom:1px solid var(--c-line);
}
.salary-row{
  display:grid;grid-template-columns:120px 1fr 160px 100px;
  gap:24px;padding:24px 0;border-bottom:1px solid var(--c-line);
  align-items:center;
}
.salary-row:last-child{border-bottom:none}
.salary-row--head{
  font-family:var(--ff-en);font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--c-text-mute);font-weight:600;
}
.salary-rank{
  font-family:var(--ff-display);font-size:32px;color:var(--c-accent);line-height:1;
}
.salary-rank small{
  font-family:var(--ff-jp);font-size:12px;color:var(--c-text-dim);
  display:block;margin-top:4px;letter-spacing:.05em;
}
.salary-cond{font-size:14px;color:var(--c-text-dim);line-height:1.6}
.salary-base{font-family:var(--ff-en);font-weight:700;font-size:18px}
.salary-inc{font-family:var(--ff-en);font-weight:700;font-size:18px;color:var(--c-accent)}

@media (max-width:768px){
  .salary-row{grid-template-columns:80px 1fr;gap:16px}
  .salary-cond{grid-column:1/-1;font-size:12px;padding-top:0}
  .salary-row--head{display:none}
  .salary-base::before{content:"固定 ";color:var(--c-text-mute);font-weight:400;font-size:12px}
  .salary-inc::before{content:"インセン ";color:var(--c-text-mute);font-weight:400;font-size:12px}
}

/* 年収シミュレーション */
.sim-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
@media (max-width:768px){.sim-grid{grid-template-columns:1fr}}
.sim{
  padding:40px 32px;background:var(--c-bg-pure);border:1px solid var(--c-line);
  position:relative;overflow:hidden;
  transition:transform .4s var(--ease),border-color .3s;
}
.sim:hover{transform:translateY(-4px);border-color:var(--c-accent)}
.sim--top{
  background:var(--c-bg-dark);color:#fff;border-color:var(--c-bg-dark);
}
.sim__rank{
  font-family:var(--ff-display);font-size:28px;color:var(--c-accent);line-height:1;
  margin-bottom:8px;
}
.sim__cond{font-size:12px;color:var(--c-text-mute);margin-bottom:32px;letter-spacing:.05em}
.sim--top .sim__cond{color:rgba(255,255,255,.5)}
.sim__amount{
  font-family:var(--ff-display);font-size:clamp(56px,8vw,96px);
  line-height:.95;letter-spacing:-.03em;color:var(--c-text);margin-bottom:8px;
}
.sim--top .sim__amount{color:#fff}
.sim__amount sup{font-size:.4em;font-weight:400;margin-left:8px;vertical-align:super}
.sim__unit{font-size:13px;color:var(--c-text-mute);margin-bottom:24px}
.sim--top .sim__unit{color:rgba(255,255,255,.5)}
.sim__detail{
  border-top:1px solid var(--c-line);padding-top:20px;
  font-size:13px;line-height:1.8;color:var(--c-text-dim);
}
.sim--top .sim__detail{border-color:var(--c-line-dark);color:rgba(255,255,255,.7)}

/* ---------- 独立支援 ---------- */
.grad{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:48px}
@media (max-width:768px){.grad{grid-template-columns:1fr}}
.grad-card{
  padding:48px 32px;background:var(--c-bg-pure);border:1px solid var(--c-line);
  border-radius:4px;
  transition:transform .4s var(--ease),border-color .3s;
}
.grad-card:hover{transform:translateY(-4px);border-color:var(--c-accent)}
.grad-card__icon{
  font-family:var(--ff-display);font-size:48px;color:var(--c-accent);line-height:1;
  margin-bottom:24px;
}
.grad-card__title{
  font-weight:900;font-size:22px;margin-bottom:16px;line-height:1.4;
}
.grad-card__body{font-size:14px;line-height:1.85;color:var(--c-text-dim)}

/* ---------- WHO ---------- */
.who-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px}
@media (max-width:900px){.who-grid{grid-template-columns:1fr;gap:48px}}
.who-col h3{
  font-weight:900;font-size:clamp(22px,2.6vw,32px);line-height:1.3;
  margin-bottom:32px;
  display:flex;align-items:center;gap:12px;
}
.who-col h3::before{
  content:"";width:8px;height:8px;background:var(--c-accent);display:inline-block;
}
.who-col--ng h3::before{background:var(--c-text)}
.who-list{display:grid;gap:16px}
.who-list li{
  padding:24px;background:var(--c-bg-pure);border:1px solid var(--c-line);
  border-radius:4px;
  font-size:15px;line-height:1.7;
}
.who-list li strong{display:block;font-weight:700;margin-bottom:4px}
.who-list li span{font-size:13px;color:var(--c-text-dim)}
.who-col--ng .who-list li{background:#FFF5F0;border-color:#FFD9C8}

/* ---------- 募集要項 ---------- */
.job{
  display:grid;grid-template-columns:1fr 1fr;gap:24px 64px;
  border-top:1px solid var(--c-line);padding-top:48px;
}
@media (max-width:768px){.job{grid-template-columns:1fr;gap:8px;padding-top:32px}}
.job__item{
  padding:20px 0;border-bottom:1px solid var(--c-line);
  display:grid;grid-template-columns:140px 1fr;gap:16px;
}
.job__item dt{
  font-family:var(--ff-en);font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--c-text-mute);font-weight:600;
}
.job__item dd{font-size:14px;line-height:1.8}

/* ---------- CEOメッセージ ---------- */
.ceo{
  display:grid;grid-template-columns:1fr 1.5fr;gap:64px;align-items:start;
}
@media (max-width:900px){.ceo{grid-template-columns:1fr;gap:32px}}
.ceo__photo{
  aspect-ratio:4/5;background:linear-gradient(135deg,#1a1a1a 0%,#333 100%);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.4);font-size:12px;border-radius:4px;
  font-family:var(--ff-en);letter-spacing:.1em;text-transform:uppercase;
}
.ceo__body{font-size:clamp(15px,1.6vw,17px);line-height:1.95;color:var(--c-text-dim)}
.ceo__body p{margin-bottom:1.6em}
.ceo__body p strong{color:var(--c-text);font-weight:700}
.ceo__sign{margin-top:32px;padding-top:24px;border-top:1px solid var(--c-line)}
.ceo__sign small{
  font-family:var(--ff-en);font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--c-text-mute);
}
.ceo__sign strong{display:block;font-size:18px;margin-top:4px;font-weight:700;color:var(--c-text)}

/* ---------- 会社情報 ---------- */
.company-info{
  display:grid;grid-template-columns:1fr 1fr;gap:24px 64px;
}
@media (max-width:768px){.company-info{grid-template-columns:1fr;gap:8px}}
.company-info__item{
  padding:24px 0;border-bottom:1px solid var(--c-line);
  display:grid;grid-template-columns:140px 1fr;gap:16px;align-items:start;
}
.company-info__item dt{
  font-family:var(--ff-en);font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--c-text-mute);font-weight:600;padding-top:4px;
}
.company-info__item dd{font-size:14px;line-height:1.8}

/* ---------- Final CTA ---------- */
.final-cta{
  background:var(--c-bg-dark);color:#fff;
  padding:var(--section-py) 0;
  position:relative;overflow:hidden;text-align:center;
}
.final-cta .big-numbers__bg img{
  filter:brightness(.35) grayscale(.4) contrast(1.1);
}
.final-cta__inner{max-width:1200px;margin:0 auto;padding:0 var(--px);position:relative;z-index:2}
.final-cta__title{
  font-family:var(--ff-display);font-size:clamp(72px,16vw,260px);
  line-height:.88;letter-spacing:-.02em;color:#fff;
  margin-bottom:48px;
}
.final-cta__title em{font-style:normal;color:var(--c-accent)}
.final-cta__lead{
  font-size:clamp(15px,2vw,20px);line-height:1.8;color:rgba(255,255,255,.7);
  max-width:560px;margin:0 auto 56px;
}

/* ---------- ボタン ---------- */
.btn{
  display:inline-flex;align-items:center;gap:12px;
  padding:18px 36px;font-weight:700;font-size:14px;letter-spacing:.08em;
  border-radius:999px;border:1px solid transparent;
  transition:all .3s var(--ease);text-transform:uppercase;
  font-family:var(--ff-en);
}
.btn--primary{background:var(--c-accent);color:#fff}
.btn--primary:hover{background:var(--c-accent-soft);transform:translateY(-2px);box-shadow:0 16px 32px rgba(255,90,31,.3)}
.btn--dark{background:var(--c-text);color:#fff}
.btn--dark:hover{background:#222;transform:translateY(-2px)}
.btn--outline{background:transparent;color:inherit;border-color:currentColor}
.btn--outline:hover{background:currentColor;color:var(--c-bg-pure)}
.btn--ghost{background:transparent;color:inherit;padding:8px 0;border-radius:0;border-bottom:1px solid currentColor}
.btn--large{padding:22px 44px;font-size:15px}
.btn__arrow{display:inline-block;transition:transform .3s var(--ease)}
.btn:hover .btn__arrow{transform:translateX(6px)}

/* ---------- フォーム ---------- */
.page-hero{padding:160px 0 80px;background:var(--c-bg-pure)}
.page-hero__inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--px)}
.page-hero__title{
  font-family:var(--ff-display);font-size:var(--fs-display);
  line-height:.95;letter-spacing:-.01em;margin-bottom:24px;
}
.page-hero__lead{font-size:clamp(15px,1.7vw,18px);color:var(--c-text-dim);max-width:680px;line-height:1.85}

.form{display:grid;gap:24px;max-width:680px}
.form__group{display:grid;gap:8px}
.form__group--subtle{opacity:.82}
.form__label{
  font-family:var(--ff-en);font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;font-weight:700;color:var(--c-text);
  display:flex;align-items:center;gap:8px;
}
.form__required{
  font-family:var(--ff-en);font-size:10px;color:var(--c-accent);
  padding:2px 8px;border:1px solid var(--c-accent);border-radius:4px;
  letter-spacing:.1em;
}
.form__optional{
  font-family:var(--ff-en);font-size:10px;color:var(--c-text-mute);
  padding:2px 8px;border:1px solid var(--c-line);border-radius:4px;
  letter-spacing:.1em;
}
.form__input,.form__textarea,.form__select{
  width:100%;padding:16px 20px;background:var(--c-bg-pure);
  border:1px solid var(--c-line);border-radius:4px;color:var(--c-text);
  font-family:var(--ff-jp);font-size:15px;
  transition:border-color .2s;
}
.form__input:focus,.form__textarea:focus,.form__select:focus{
  outline:none;border-color:var(--c-accent);
}
.form__textarea{min-height:180px;resize:vertical;line-height:1.7}
.form__tabs{
  display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--c-line);
  border-radius:999px;overflow:hidden;padding:4px;background:var(--c-bg);
}
.form__tab{
  padding:12px 16px;text-align:center;font-weight:700;font-size:13px;
  color:var(--c-text-dim);cursor:pointer;transition:all .3s var(--ease);
  border-radius:999px;letter-spacing:.05em;
}
.form__tab.is-active{background:var(--c-text);color:#fff}
.form__submit{justify-self:start;margin-top:8px}
.form__notice{font-size:12px;color:var(--c-text-mute);line-height:1.7}
.form__status{padding:16px;border-radius:4px;font-size:13px;display:none}
.form__status.is-success{display:block;background:#F0FFF4;border:1px solid #C6F6D5;color:#22543D}
.form__status.is-error{display:block;background:#FFF5F5;border:1px solid #FED7D7;color:#742A2A}

/* ---------- フッター ---------- */
.site-footer{
  background:var(--c-bg-pure);border-top:1px solid var(--c-line);
  padding:80px 0 40px;
}
.site-footer__grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:64px;
}
@media (max-width:768px){.site-footer__grid{grid-template-columns:1fr 1fr;gap:32px}}
@media (max-width:480px){.site-footer__grid{grid-template-columns:1fr}}
.site-footer__brand{display:flex;flex-direction:column;gap:16px}
.site-footer__logo{
  font-family:var(--ff-display);font-size:32px;letter-spacing:.02em;
  display:flex;align-items:baseline;gap:4px;line-height:1;color:var(--c-text);
}
.site-footer__logo small{font-family:var(--ff-en);font-size:11px;color:var(--c-accent);letter-spacing:.2em;text-transform:uppercase;font-weight:600}
.site-footer__tagline{font-size:13px;color:var(--c-text-dim);line-height:1.85;max-width:320px}
.site-footer__heading{
  font-family:var(--ff-en);font-size:11px;font-weight:700;letter-spacing:.2em;
  color:var(--c-accent);margin-bottom:20px;text-transform:uppercase;
}
.site-footer__list{display:flex;flex-direction:column;gap:12px}
.site-footer__link{font-size:13px;color:var(--c-text-dim);transition:color .2s}
.site-footer__link:hover{color:var(--c-accent)}
.site-footer__bottom{
  border-top:1px solid var(--c-line);padding-top:32px;
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  flex-wrap:wrap;font-size:12px;color:var(--c-text-mute);
  font-family:var(--ff-en);letter-spacing:.05em;
}
.site-footer__kw{
  margin-top:32px;padding-top:24px;border-top:1px solid var(--c-line);
  font-size:11px;color:var(--c-text-mute);line-height:1.8;letter-spacing:.05em;
}

/* ---------- v2.5 強調語ホバー演出 ---------- */
.brief__body strong,.ceo__body strong,.value-row__body strong,
.lead strong,.why__body strong{
  position:relative;display:inline;
  background-image:linear-gradient(transparent 60%,rgba(255,90,31,0) 60%);
  transition:background-image .5s var(--ease);
}
.brief__body strong:hover,.ceo__body strong:hover,
.value-row__body strong:hover,.lead strong:hover,.why__body strong:hover{
  background-image:linear-gradient(transparent 60%,rgba(255,90,31,.25) 60%);
}

/* ---------- v2.5 画像ホバー大型化 ---------- */
.svc-card__img,.feature-img,.split__media{
  cursor:pointer;
}
.svc-card:hover .svc-card__img img{transform:scale(1.08);filter:grayscale(0) contrast(1.05)}
.feature-img:hover img{transform:scale(1.05);filter:grayscale(0) contrast(1.05)}
.split__media:hover img{transform:scale(1.06);filter:grayscale(0) contrast(1.05)}

/* ---------- v2.5 カーソル追従ドット ---------- */
.cursor-dot{
  position:fixed;top:0;left:0;width:12px;height:12px;
  background:var(--c-accent);border-radius:50%;
  transform:translate(-50%,-50%);
  pointer-events:none;z-index:9999;
  mix-blend-mode:difference;
  transition:width .25s var(--ease),height .25s var(--ease),background .2s;
  will-change:transform;
}
.cursor-dot.is-hover{width:32px;height:32px;background:var(--c-accent-soft)}
@media (max-width:900px),(pointer:coarse){.cursor-dot{display:none}}

/* ---------- v2.5 セクション飾り英字（既存利用） ---------- */
.section{position:relative}

/* ---------- v2.6 モバイル最適化 ---------- */
@media (max-width:768px){
  /* sticky chapter はモバイルでは静的に */
  .chapter{position:static;backdrop-filter:none;-webkit-backdrop-filter:none;margin-bottom:32px;padding-bottom:16px}
  /* floating-en の溢れを抑制 */
  .floating-en{font-size:clamp(60px,18vw,140px)!important}
  /* マーキーの速度を上げて見やすく */
  .marquee__track{animation-duration:24s;font-size:clamp(20px,5vw,28px)}
  .marquee{padding:14px 0}
  /* Hero のスクロールインジケータを画面端ギリギリに */
  .hero__scroll{display:none}
  /* Hero padding 調整 */
  .hero{padding:100px 0 60px;min-height:auto}
  /* Final CTA タイトル */
  .final-cta__title{font-size:clamp(48px,12vw,80px)!important}
  /* Hero タイトル */
  .hero__title{font-size:clamp(32px,9vw,56px)}
  /* Hero メタを縦並び風 */
  .hero__meta{flex-direction:column;gap:12px}
  /* 各セクションの余白短縮 */
  :root{--section-py:clamp(56px,12vw,96px)}
  /* record-hero モバイルでフォントサイズ調整 */
  .record-hero__num{font-size:clamp(56px,16vw,100px)}
  .record-hero__main{padding:32px 24px}
  /* split を縦並びに */
  .split,.brief,.why,.ceo{grid-template-columns:1fr!important}
  /* svc-grid を 1 列に */
  .svc-grid,.market,.grad,.credibility{grid-template-columns:1fr!important}
  /* sim-grid 1 列に */
  .sim-grid,.salary-sim{grid-template-columns:1fr!important}
  /* values-row モバイル調整 */
  .value-row{grid-template-columns:1fr;gap:16px;padding:48px 0}
  /* 大型ホバー演出はモバイルで無効化（タップで誤動作回避） */
  .svc-card:hover .svc-card__img img,
  .feature-img:hover img,
  .split__media:hover img{transform:none;filter:grayscale(1) contrast(1.05)}
  /* nav__cta が小さくならないように */
  .site-nav__cta{padding:14px 24px}
}

@media (max-width:480px){
  /* 極小画面で h2 サイズ調整 */
  .h2{font-size:clamp(24px,7vw,32px)}
  .hero__title{font-size:clamp(28px,8vw,44px)}
  .container,.hero__inner{padding-left:20px;padding-right:20px}
  /* マーキー2行目を非表示にしてシンプル化 */
  .marquee--reverse{display:none}
  /* record-sub 1列に */
  .record-sub{grid-template-columns:1fr}
  /* segments 1列に */
  .segments{grid-template-columns:1fr}
  /* sticky最大幅対策で chapter は2行に */
  .chapter{flex-direction:column;align-items:flex-start;gap:8px}
}

/* ---------- 横スクロール防止 ---------- */
html,body{overflow-x:hidden;max-width:100vw}

/* ---------- ユーティリティ ---------- */
.text-center{text-align:center}
.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}
.mt-6{margin-top:48px}.mt-8{margin-top:64px}.mt-10{margin-top:80px}
.uline{position:relative;display:inline-block}
.uline::after{
  content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;
  background:var(--c-accent);transform:scaleX(0);transform-origin:right;
  transition:transform .5s var(--ease);
}
.uline:hover::after{transform:scaleX(1);transform-origin:left}

/* ---------- アニメーション ---------- */
.fade-up{opacity:0;transform:translateY(40px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.fade-up.is-visible{opacity:1;transform:translateY(0)}
.fade-in{opacity:0;transition:opacity 1.2s var(--ease)}
.fade-in.is-visible{opacity:1}
.stagger > *{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.stagger.is-visible > *{opacity:1;transform:translateY(0)}
.stagger.is-visible > *:nth-child(1){transition-delay:0s}
.stagger.is-visible > *:nth-child(2){transition-delay:.1s}
.stagger.is-visible > *:nth-child(3){transition-delay:.2s}
.stagger.is-visible > *:nth-child(4){transition-delay:.3s}
.stagger.is-visible > *:nth-child(5){transition-delay:.4s}
.stagger.is-visible > *:nth-child(6){transition-delay:.5s}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important}
  .marquee__track{animation:none}
}

/* =========================================================
   v2.1 追加スタイル — 情報密度・プロフェッショナル感UP
   ========================================================= */

/* ---------- ヘッダー数字バッジ ---------- */
.hero__badges{
  display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px;
}
.hero__badge{
  font-family:var(--ff-en);font-size:11px;letter-spacing:.15em;text-transform:uppercase;
  padding:6px 12px;border:1px solid var(--c-line);border-radius:999px;
  color:var(--c-text-dim);font-weight:600;
  background:rgba(255,255,255,.5);backdrop-filter:blur(4px);
}
.hero__badge--accent{background:var(--c-accent);color:#fff;border-color:var(--c-accent)}

/* ---------- インデックス（目次） ---------- */
.index-section{
  background:var(--c-bg-pure);
  border-top:1px solid var(--c-line);border-bottom:1px solid var(--c-line);
  padding:48px 0;
}
.index-list{
  display:grid;grid-template-columns:repeat(5,1fr);gap:0;
  border-left:1px solid var(--c-line);
}
@media (max-width:900px){.index-list{grid-template-columns:repeat(2,1fr)}}
.index-list a{
  padding:20px 24px;border-right:1px solid var(--c-line);
  display:flex;flex-direction:column;gap:8px;
  transition:background .3s;
}
.index-list a:hover{background:var(--c-bg)}
.index-list__num{
  font-family:var(--ff-en);font-size:11px;color:var(--c-accent);
  letter-spacing:.2em;font-weight:700;
}
.index-list__label{font-size:13px;font-weight:700;color:var(--c-text)}
.index-list__en{
  font-family:var(--ff-en);font-size:10px;letter-spacing:.15em;
  color:var(--c-text-mute);text-transform:uppercase;
}

/* ---------- セクションヘッダー（章番号付き、sticky動作） ---------- */
.chapter{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:32px;flex-wrap:wrap;margin-bottom:64px;
  border-bottom:1px solid var(--c-line);padding-bottom:18px;
  position:sticky;top:80px;background:inherit;z-index:5;
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.section--dark .chapter{background:var(--c-bg-dark)}
.final-cta .chapter{position:static}
.chapter__num{
  font-family:var(--ff-en);font-size:13px;letter-spacing:.3em;
  color:var(--c-text-mute);font-weight:600;text-transform:uppercase;
}
.chapter__num em{font-style:normal;color:var(--c-accent);font-weight:700}
.chapter__meta{
  font-family:var(--ff-en);font-size:11px;letter-spacing:.2em;
  color:var(--c-text-mute);text-transform:uppercase;
}

.section--dark .chapter{border-color:var(--c-line-dark)}
.section--dark .chapter__num,.section--dark .chapter__meta{color:rgba(255,255,255,.5)}

/* ---------- About Brief ---------- */
.brief{
  display:grid;grid-template-columns:1.3fr 1fr;gap:80px;
  border-top:1px solid var(--c-line);padding-top:64px;
}
@media (max-width:900px){.brief{grid-template-columns:1fr;gap:48px}}
.brief__body{
  font-size:clamp(16px,1.8vw,20px);line-height:1.95;color:var(--c-text);
}
.brief__body p{margin-bottom:1.4em}
.brief__body p strong{font-weight:700;background:linear-gradient(transparent 60%,rgba(255,90,31,.25) 60%);padding:0 2px}
.brief__stats{
  display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--c-line);
  border:1px solid var(--c-line);
}
.brief__stat{
  background:var(--c-bg-pure);padding:32px 24px;
}
.brief__stat-num{
  font-family:var(--ff-display);font-size:clamp(40px,5vw,72px);line-height:.9;
  color:var(--c-text);letter-spacing:-.02em;margin-bottom:8px;
}
.brief__stat-num sup{font-size:.4em;color:var(--c-accent);margin-left:4px}
.brief__stat-label{
  font-family:var(--ff-en);font-size:11px;letter-spacing:.2em;
  color:var(--c-text-mute);text-transform:uppercase;font-weight:600;
}
.brief__stat-note{
  font-size:11px;color:var(--c-text-mute);margin-top:8px;line-height:1.6;
}

/* ---------- 市場データ ---------- */
.market{
  display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:48px;
}
@media (max-width:900px){.market{grid-template-columns:1fr}}
.market-card{
  padding:40px 32px;background:var(--c-bg-pure);border:1px solid var(--c-line);
  position:relative;
}
.market-card__src{
  font-family:var(--ff-en);font-size:10px;letter-spacing:.2em;
  color:var(--c-text-mute);text-transform:uppercase;margin-bottom:24px;
  display:flex;align-items:center;gap:8px;
}
.market-card__src::before{
  content:"";width:6px;height:6px;background:var(--c-accent);border-radius:50%;
}
.market-card__value{
  font-family:var(--ff-display);font-size:clamp(48px,6vw,72px);
  line-height:.95;letter-spacing:-.02em;color:var(--c-text);margin-bottom:16px;
}
.market-card__value sup{font-size:.4em;color:var(--c-accent);margin-left:4px}
.market-card__title{
  font-weight:700;font-size:17px;margin-bottom:12px;line-height:1.5;
}
.market-card__body{font-size:13px;color:var(--c-text-dim);line-height:1.8}

/* ---------- タイムライン ---------- */
.timeline{
  display:grid;grid-template-columns:repeat(5,1fr);gap:0;
  margin-top:48px;border-top:2px solid var(--c-text);
}
@media (max-width:900px){
  .timeline{grid-template-columns:1fr;border-top:none;border-left:2px solid var(--c-text)}
}
.timeline-item{
  padding:32px 24px;border-right:1px solid var(--c-line);position:relative;
}
.timeline-item:last-child{border-right:none}
.timeline-item::before{
  content:"";position:absolute;top:-6px;left:0;width:10px;height:10px;
  background:var(--c-accent);border-radius:50%;
}
@media (max-width:900px){
  .timeline-item{border-right:none;border-bottom:1px solid var(--c-line);padding:24px 24px 32px}
  .timeline-item::before{top:24px;left:-6px}
}
.timeline-item__year{
  font-family:var(--ff-en);font-size:13px;letter-spacing:.2em;
  color:var(--c-accent);font-weight:700;margin-bottom:8px;
}
.timeline-item__title{
  font-weight:900;font-size:18px;margin-bottom:12px;line-height:1.4;
}
.timeline-item__body{font-size:13px;color:var(--c-text-dim);line-height:1.85}
.timeline-item__income{
  margin-top:16px;padding-top:16px;border-top:1px dashed var(--c-line);
  font-family:var(--ff-en);font-weight:700;font-size:15px;color:var(--c-text);
}
.timeline-item__income small{
  display:block;font-family:var(--ff-en);font-size:10px;color:var(--c-text-mute);
  letter-spacing:.15em;text-transform:uppercase;margin-bottom:4px;font-weight:600;
}

/* ---------- メンバーボイス ---------- */
.voices{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:48px}
@media (max-width:900px){.voices{grid-template-columns:1fr}}
.voice{
  background:var(--c-bg-pure);padding:40px 32px;border:1px solid var(--c-line);
  position:relative;
}
.voice__quote-mark{
  position:absolute;top:24px;right:24px;
  font-family:var(--ff-display);font-size:80px;line-height:1;
  color:var(--c-line);
}
.voice__rank{
  font-family:var(--ff-display);font-size:24px;color:var(--c-accent);line-height:1;
  margin-bottom:8px;
}
.voice__meta{
  font-family:var(--ff-en);font-size:11px;letter-spacing:.15em;
  color:var(--c-text-mute);text-transform:uppercase;margin-bottom:24px;
}
.voice__body{
  font-size:15px;line-height:1.9;color:var(--c-text);
  font-weight:500;margin-bottom:24px;
}
.voice__body strong{
  background:linear-gradient(transparent 60%,rgba(255,90,31,.2) 60%);padding:0 2px;font-weight:700;
}
.voice__profile{
  border-top:1px solid var(--c-line);padding-top:16px;
  font-size:12px;color:var(--c-text-dim);line-height:1.7;
}
.voice__profile strong{display:block;font-weight:700;color:var(--c-text);margin-bottom:4px}

/* ---------- 比較表（プロフェッショナル） ---------- */
.compare{
  margin-top:48px;border:1px solid var(--c-line);background:var(--c-bg-pure);
  overflow-x:auto;
}
.compare table{width:100%;border-collapse:collapse;min-width:720px}
.compare th,.compare td{
  padding:20px 24px;text-align:left;border-bottom:1px solid var(--c-line);
  vertical-align:top;
}
.compare thead th{
  background:var(--c-bg);
  font-family:var(--ff-en);font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--c-text-mute);font-weight:700;
}
.compare thead th:first-child{background:var(--c-text);color:#fff}
.compare thead th.is-us{background:var(--c-accent);color:#fff}
.compare tbody th{
  font-family:var(--ff-en);font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--c-text-mute);font-weight:700;
  background:var(--c-bg);
}
.compare td{font-size:14px;line-height:1.7;color:var(--c-text-dim)}
.compare td.is-us{
  background:rgba(255,90,31,.04);color:var(--c-text);font-weight:600;
}
.compare td.is-us strong{color:var(--c-accent)}

/* ---------- FAQ ---------- */
.faq{margin-top:48px;border-top:1px solid var(--c-line)}
.faq__item{
  border-bottom:1px solid var(--c-line);
}
.faq__q{
  width:100%;padding:28px 0;display:grid;
  grid-template-columns:48px 1fr 48px;gap:16px;align-items:center;
  text-align:left;cursor:pointer;transition:color .2s;
}
.faq__q-num{
  font-family:var(--ff-en);font-size:12px;letter-spacing:.2em;
  color:var(--c-accent);font-weight:700;
}
.faq__q-text{
  font-weight:700;font-size:clamp(15px,1.8vw,18px);line-height:1.5;
  color:var(--c-text);
}
.faq__q-mark{
  font-family:var(--ff-en);font-size:24px;color:var(--c-text);
  transition:transform .3s var(--ease);text-align:right;
}
.faq__item.is-open .faq__q-mark{transform:rotate(45deg)}
.faq__a{
  max-height:0;overflow:hidden;transition:max-height .5s var(--ease);
  font-size:14px;line-height:1.95;color:var(--c-text-dim);
}
.faq__a-inner{padding:0 0 32px 64px;max-width:880px}
.faq__a-inner p{margin-bottom:1em}
.faq__a-inner strong{color:var(--c-text);font-weight:700}

/* ---------- CEO Letter（手紙形式） ---------- */
.letter{
  max-width:880px;margin:48px auto 0;padding:64px;
  background:var(--c-bg-pure);border:1px solid var(--c-line);
  position:relative;
}
@media (max-width:768px){.letter{padding:40px 28px}}
.letter::before{
  content:"";position:absolute;top:0;left:0;width:8px;height:100%;background:var(--c-accent);
}
.letter__meta{
  font-family:var(--ff-en);font-size:11px;letter-spacing:.2em;
  color:var(--c-text-mute);text-transform:uppercase;margin-bottom:32px;
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
}
.letter__greeting{
  font-weight:700;font-size:clamp(20px,2.4vw,28px);line-height:1.5;
  margin-bottom:32px;
}
.letter__body{font-size:clamp(14px,1.6vw,16px);line-height:2;color:var(--c-text)}
.letter__body p{margin-bottom:1.5em}
.letter__body p strong{font-weight:700;background:linear-gradient(transparent 60%,rgba(255,90,31,.25) 60%);padding:0 2px}
.letter__sign{
  margin-top:48px;padding-top:32px;border-top:1px solid var(--c-line);
  display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;
}
.letter__sign-name{
  font-family:var(--ff-display);font-size:28px;line-height:1;color:var(--c-text);
}
.letter__sign-meta{
  font-family:var(--ff-en);font-size:11px;letter-spacing:.2em;
  color:var(--c-text-mute);text-transform:uppercase;text-align:right;
}

/* ---------- 注釈ボックス（補強情報） ---------- */
.note-box{
  margin-top:32px;padding:24px 28px;background:var(--c-bg);
  border-left:3px solid var(--c-accent);font-size:13px;line-height:1.85;
  color:var(--c-text-dim);
}
.note-box strong{
  display:block;font-family:var(--ff-en);font-size:11px;letter-spacing:.2em;
  color:var(--c-accent);text-transform:uppercase;margin-bottom:8px;
}

/* ---------- データバー（給与累積） ---------- */
.cumulative{
  margin-top:48px;display:grid;gap:20px;
}
.cum-row{
  display:grid;grid-template-columns:80px 1fr 140px;gap:24px;align-items:center;
}
@media (max-width:640px){
  .cum-row{grid-template-columns:60px 1fr 100px;gap:12px}
}
.cum-row__year{
  font-family:var(--ff-en);font-weight:700;font-size:13px;
  letter-spacing:.15em;color:var(--c-text-mute);text-transform:uppercase;
}
.cum-row__bar{
  height:32px;background:var(--c-bg);border:1px solid var(--c-line);
  position:relative;overflow:hidden;
}
.cum-row__bar-fill{
  position:absolute;left:0;top:0;bottom:0;
  background:linear-gradient(90deg,var(--c-text) 0%,var(--c-accent) 100%);
  transition:width 1.6s var(--ease);width:0;
}
.cum-row.is-visible .cum-row__bar-fill{width:var(--w)}
.cum-row__value{
  font-family:var(--ff-en);font-weight:700;font-size:16px;
  color:var(--c-text);text-align:right;
}

/* ---------- セクション内の小タイトル ---------- */
.sub-title{
  font-weight:900;font-size:clamp(20px,2.4vw,32px);line-height:1.4;
  margin:80px 0 32px;display:flex;align-items:center;gap:16px;
}
.sub-title::before{
  content:"";width:32px;height:2px;background:var(--c-accent);
}

/* ---------- 引用ブロック ---------- */
.pullquote{
  margin:64px 0;padding:48px 64px;background:var(--c-bg);
  border-left:4px solid var(--c-accent);
  font-size:clamp(20px,2.4vw,28px);font-weight:700;line-height:1.6;
  color:var(--c-text);position:relative;
}
@media (max-width:768px){.pullquote{padding:32px 28px}}
.pullquote em{font-style:normal;color:var(--c-accent)}
.pullquote cite{
  display:block;margin-top:16px;font-family:var(--ff-en);font-size:11px;
  letter-spacing:.2em;color:var(--c-text-mute);text-transform:uppercase;
  font-weight:600;font-style:normal;
}

/* ---------- セクションエンドのデバイダー ---------- */
.divider{
  border:none;height:1px;background:var(--c-line);
  margin:0;
}

/* =========================================================
   v2.2 追加 — ビジュアル/画像系スタイル
   ========================================================= */

/* ---------- Hero ビジュアル背景 ---------- */
.hero{position:relative}
.hero__bg{
  position:absolute;inset:0;z-index:0;overflow:hidden;
}
.hero__bg img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(.2) contrast(1.05);
}
.hero__bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(250,250,250,.7) 0%,rgba(250,250,250,.92) 60%,#FAFAFA 100%);
}
.hero__inner{position:relative;z-index:2}

/* ---------- v2.7 Trust Hero ---------- */
.hero--trust{
  min-height:100svh;
  justify-content:center;
  padding:150px 0 88px;
  background:
    radial-gradient(circle at 78% 16%,rgba(255,90,31,.16),transparent 30%),
    linear-gradient(135deg,#fff 0%,#f7f4ef 46%,#fff 100%);
}
.hero--trust .hero__bg img{
  filter:grayscale(.18) contrast(1.05) brightness(1.06);
  opacity:.28;
}
.hero--trust .hero__bg::after{
  background:
    linear-gradient(90deg,rgba(250,250,250,.98) 0%,rgba(250,250,250,.88) 54%,rgba(250,250,250,.74) 100%),
    linear-gradient(180deg,rgba(250,250,250,.58) 0%,#FAFAFA 100%);
}
.hero__inner--grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(340px,420px);
  align-items:center;
  gap:clamp(32px,5vw,72px);
}
.hero__copy{position:relative;z-index:3}
.hero--trust .hero__title{
  font-size:clamp(44px,5.75vw,88px);
  max-width:760px;
}
.hero--trust .hero__title em{
  white-space:nowrap;
}
.hero__actions{
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
  margin-bottom:34px;
}
.hero__meta--compact{
  max-width:820px;
  padding-top:24px;
  gap:18px 42px;
}
.hero-dashboard{
  position:relative;
  z-index:2;
  background:rgba(10,10,10,.92);
  color:#fff;
  border:1px solid rgba(255,255,255,.12);
  border-radius:28px;
  padding:28px;
  box-shadow:0 40px 100px rgba(10,10,10,.2);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  overflow:hidden;
}
.hero-dashboard::before{
  content:"";
  position:absolute;
  inset:-40% -30% auto auto;
  width:280px;
  height:280px;
  background:radial-gradient(circle,rgba(255,90,31,.44),transparent 64%);
  pointer-events:none;
}
.hero-dashboard__top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  margin-bottom:32px;
  position:relative;
  z-index:1;
  font-family:var(--ff-en);
  letter-spacing:.18em;
  text-transform:uppercase;
  font-size:11px;
  color:rgba(255,255,255,.64);
}
.hero-dashboard__top strong{
  color:#fff;
  background:var(--c-accent);
  padding:5px 10px;
  border-radius:999px;
  font-size:10px;
}
.hero-dashboard__main{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  position:relative;
  z-index:1;
}
.hero-dashboard__main > div{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.1);
  border-radius:20px;
  padding:22px 18px;
}
.hero-dashboard__main small,
.hero-dashboard__main span{
  display:block;
  font-family:var(--ff-en);
  font-size:10px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(255,255,255,.55);
  line-height:1.4;
}
.hero-dashboard__main strong{
  display:block;
  font-family:var(--ff-display);
  font-size:clamp(54px,6vw,92px);
  line-height:.9;
  color:#fff;
  margin:18px 0 10px;
}
.hero-flow{
  display:grid;
  gap:10px;
  margin:18px 0;
  position:relative;
  z-index:1;
}
.hero-flow div{
  display:flex;
  align-items:center;
  gap:12px;
  padding:14px 16px;
  border-radius:16px;
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.82);
  font-weight:700;
}
.hero-flow span{
  font-family:var(--ff-en);
  font-size:11px;
  letter-spacing:.16em;
  color:var(--c-accent);
}
.hero-dashboard__note{
  position:relative;
  z-index:1;
  border-top:1px solid rgba(255,255,255,.12);
  padding-top:18px;
  color:rgba(255,255,255,.66);
  font-size:13px;
  line-height:1.7;
}
@media (max-width:1000px){
  .hero__inner--grid{grid-template-columns:1fr}
  .hero-dashboard{max-width:620px}
}
@media (max-width:768px){
  .hero--trust{padding:116px 0 60px}
  .hero__actions .btn{width:100%;justify-content:center}
  .hero-dashboard{border-radius:22px;padding:20px}
  .hero-dashboard__main{grid-template-columns:1fr}
}

/* ヒーロー右側のサブビジュアル */
.hero__visual{
  position:absolute;right:var(--px);top:50%;transform:translateY(-50%);
  width:42%;max-width:560px;aspect-ratio:3/4;
  z-index:1;overflow:hidden;border-radius:4px;
  display:none;
}
@media (min-width:1100px){.hero__visual{display:block}}
.hero__visual img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(.15) contrast(1.05);
  transition:transform 1.5s var(--ease);
}
.hero__visual:hover img{transform:scale(1.05)}
.hero__visual-label{
  position:absolute;left:0;bottom:0;right:0;
  padding:16px 20px;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.7));
  color:#fff;font-family:var(--ff-en);font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;
}

/* ---------- フィーチャー画像（セクション内大型） ---------- */
.feature-img{
  position:relative;width:100%;aspect-ratio:16/9;
  overflow:hidden;background:var(--c-bg);
  margin:32px 0;
}
.feature-img img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(1) contrast(1.05);
  transition:transform 1.2s var(--ease),filter .8s;
}
.feature-img:hover img{transform:scale(1.02);filter:grayscale(.5) contrast(1.05)}
.feature-img__caption{
  position:absolute;left:0;bottom:0;padding:24px 32px;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.7));
  color:#fff;
  font-family:var(--ff-en);font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;width:100%;
}

/* ---------- 2カラム（テキスト + 画像） ---------- */
.split{
  display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;
}
@media (max-width:900px){.split{grid-template-columns:1fr;gap:32px}}
.split--reverse{direction:rtl}
.split--reverse > *{direction:ltr}
.split__media{
  aspect-ratio:4/5;overflow:hidden;background:var(--c-bg);
  position:relative;
}
.split__media img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(1) contrast(1.05);
  transition:transform 1.4s var(--ease),filter .8s;
}
.split__media:hover img{transform:scale(1.04);filter:grayscale(.5) contrast(1.05)}
.split__media-tag{
  position:absolute;top:24px;left:24px;
  background:var(--c-accent);color:#fff;
  font-family:var(--ff-en);font-size:11px;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;
  padding:6px 12px;border-radius:999px;
}

/* ---------- グリッド画像（事業3つ） ---------- */
.svc-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
@media (max-width:900px){.svc-grid{grid-template-columns:1fr}}
.svc-card{
  background:var(--c-bg-pure);border:1px solid var(--c-line);
  overflow:hidden;display:flex;flex-direction:column;
  transition:transform .4s var(--ease),border-color .3s;
}
.svc-card:hover{transform:translateY(-4px);border-color:var(--c-accent)}
.svc-card__img{
  aspect-ratio:4/3;overflow:hidden;position:relative;
}
.svc-card__img img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(1) contrast(1.05);
  transition:transform 1.2s var(--ease),filter .8s;
}
.svc-card:hover .svc-card__img img{transform:scale(1.04);filter:grayscale(.5) contrast(1.05)}
.svc-card__num{
  position:absolute;top:16px;left:20px;
  font-family:var(--ff-display);font-size:24px;color:#fff;
  background:var(--c-accent);padding:6px 14px;line-height:1;
}
.svc-card__body{padding:32px 28px;flex:1;display:flex;flex-direction:column}
.svc-card__en{
  font-family:var(--ff-en);font-size:11px;letter-spacing:.2em;
  color:var(--c-text-mute);text-transform:uppercase;font-weight:600;
  margin-bottom:8px;
}
.svc-card__title{font-weight:900;font-size:24px;margin-bottom:16px;line-height:1.4}
.svc-card__body p{font-size:14px;line-height:1.85;color:var(--c-text-dim);flex:1}

/* ---------- CEOフォト ---------- */
.ceo__photo{
  aspect-ratio:4/5;overflow:hidden;
  background:linear-gradient(135deg,#1a1a1a 0%,#333 100%);
  position:relative;
}
.ceo__photo img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(1) contrast(1.05);
}
.ceo__photo-tag{
  position:absolute;bottom:0;left:0;right:0;
  padding:16px 20px;color:#fff;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.8));
  font-family:var(--ff-en);font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;
}

/* ---------- バナー型大画像 ---------- */
.banner-img{
  position:relative;width:100%;aspect-ratio:21/9;
  overflow:hidden;background:#000;
}
.banner-img img{
  width:100%;height:100%;object-fit:cover;
  filter:brightness(.6) contrast(1.1);
}
.banner-img__inner{
  position:absolute;inset:0;display:flex;
  flex-direction:column;justify-content:center;align-items:center;
  text-align:center;color:#fff;padding:32px;
  z-index:2;
}
.banner-img__title{
  font-family:var(--ff-display);font-size:clamp(40px,7vw,96px);
  line-height:1;letter-spacing:-.02em;margin-bottom:24px;
}
.banner-img__title em{font-style:normal;color:var(--c-accent)}
.banner-img__lead{
  font-size:clamp(14px,1.6vw,18px);max-width:560px;line-height:1.7;
  color:rgba(255,255,255,.85);
}

/* ---------- 数字セクション背景画像 ---------- */
.big-numbers{position:relative}
.big-numbers__bg{
  position:absolute;inset:0;z-index:0;overflow:hidden;
}
.big-numbers__bg img{
  width:100%;height:100%;object-fit:cover;
  filter:brightness(.25) grayscale(.4);
}
.big-numbers > .container{position:relative;z-index:2}

/* ---------- 画像とテキストのオーバーラップレイアウト ---------- */
.overlap-img{
  position:relative;margin:48px 0;
}
.overlap-img__main{
  width:75%;aspect-ratio:16/9;overflow:hidden;
  position:relative;z-index:1;
}
.overlap-img__main img{width:100%;height:100%;object-fit:cover}
.overlap-img__sub{
  position:absolute;right:0;bottom:-48px;
  width:42%;aspect-ratio:4/5;overflow:hidden;
  z-index:2;border:8px solid var(--c-bg);
}
.overlap-img__sub img{width:100%;height:100%;object-fit:cover}
@media (max-width:768px){
  .overlap-img__main{width:100%}
  .overlap-img__sub{width:60%;bottom:-32px}
}

/* ---------- 背景パターン（細かいグリッド） ---------- */
.pattern-grid{
  position:relative;
}
.pattern-grid::before{
  content:"";position:absolute;inset:0;z-index:0;
  background-image:
    linear-gradient(rgba(0,0,0,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(0,0,0,.04) 1px,transparent 1px);
  background-size:48px 48px;
  pointer-events:none;
}
.pattern-grid > *{position:relative;z-index:1}

/* ---------- 装飾的なフローティング英字 ---------- */
.floating-en{
  position:absolute;font-family:var(--ff-display);
  font-size:clamp(80px,16vw,260px);line-height:.85;
  color:rgba(0,0,0,.04);letter-spacing:-.02em;
  pointer-events:none;user-select:none;z-index:0;
}
.section--dark .floating-en{color:rgba(255,255,255,.04)}

/* =========================================================
   v2.3 追加 — Track Record（実績）系
   ========================================================= */

/* ---------- 実績ヘッドライン（巨大数字） ---------- */
.record-hero{
  display:grid;grid-template-columns:1.2fr 1fr;gap:64px;align-items:center;
  margin-top:48px;
}
@media (max-width:900px){.record-hero{grid-template-columns:1fr;gap:32px}}
.record-hero__main{
  padding:48px 56px;background:var(--c-bg-dark);color:#fff;
  position:relative;overflow:hidden;
}
@media (max-width:640px){.record-hero__main{padding:36px 28px}}
.record-hero__num{
  font-family:var(--ff-display);font-size:clamp(80px,14vw,200px);
  line-height:.85;letter-spacing:-.03em;color:#fff;
  margin-bottom:24px;
}
.record-hero__num sup{
  font-size:.35em;color:var(--c-accent);margin-left:8px;vertical-align:super;
}
.record-hero__label{
  font-family:var(--ff-en);font-size:13px;letter-spacing:.25em;
  color:var(--c-accent);text-transform:uppercase;margin-bottom:12px;font-weight:700;
}
.record-hero__desc{
  font-size:15px;line-height:1.85;color:rgba(255,255,255,.7);max-width:480px;
}

/* サブ数字グリッド */
.record-sub{
  display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--c-line);
  border:1px solid var(--c-line);
}
.record-sub__item{
  background:var(--c-bg-pure);padding:28px 24px;
}
.record-sub__num{
  font-family:var(--ff-display);font-size:clamp(36px,4.5vw,56px);
  line-height:.95;letter-spacing:-.02em;color:var(--c-text);margin-bottom:8px;
}
.record-sub__num sup{font-size:.4em;color:var(--c-accent);margin-left:4px}
.record-sub__label{
  font-family:var(--ff-en);font-size:10px;letter-spacing:.2em;
  color:var(--c-text-mute);text-transform:uppercase;font-weight:600;
}
.record-sub__note{font-size:11px;color:var(--c-text-mute);margin-top:8px;line-height:1.6}

/* ---------- 業態カード ---------- */
.segments{
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:48px;
}
@media (max-width:900px){.segments{grid-template-columns:repeat(2,1fr)}}
.segment{
  padding:32px 24px;background:var(--c-bg-pure);
  border:1px solid var(--c-line);position:relative;
  transition:border-color .3s,transform .3s var(--ease);
}
.segment:hover{border-color:var(--c-accent);transform:translateY(-2px)}
.segment__label{
  font-family:var(--ff-en);font-size:10px;letter-spacing:.2em;
  color:var(--c-accent);font-weight:700;margin-bottom:12px;text-transform:uppercase;
}
.segment__name{
  font-weight:900;font-size:18px;line-height:1.4;margin-bottom:8px;
}
.segment__count{
  font-family:var(--ff-en);font-size:13px;color:var(--c-text-dim);
  font-weight:600;
}
.segment__count strong{color:var(--c-text);font-size:16px}

/* ---------- 月次推移バー ---------- */
.trend{
  margin-top:48px;
}
.trend__row{
  display:grid;grid-template-columns:80px 1fr 80px;
  gap:16px;align-items:center;padding:14px 0;
  border-bottom:1px solid var(--c-line);
}
.trend__row:last-child{border-bottom:none}
.trend__month{
  font-family:var(--ff-en);font-size:12px;color:var(--c-text-mute);
  letter-spacing:.1em;font-weight:600;
}
.trend__bar{
  height:14px;background:var(--c-bg);position:relative;overflow:hidden;
  border:1px solid var(--c-line);
}
.trend__bar-fill{
  position:absolute;left:0;top:0;bottom:0;
  background:linear-gradient(90deg,var(--c-text) 0%,var(--c-accent) 100%);
  width:0;transition:width 1.4s var(--ease);
}
.trend__row.is-visible .trend__bar-fill{width:var(--w)}
.trend__count{
  font-family:var(--ff-en);font-weight:700;font-size:14px;text-align:right;
}

/* ---------- 信頼性バッジ ---------- */
.credibility{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px;
}
@media (max-width:900px){.credibility{grid-template-columns:1fr}}
.cred{
  padding:32px;background:var(--c-bg);border:1px solid var(--c-line);
}
.cred__icon{
  width:48px;height:48px;display:flex;align-items:center;justify-content:center;
  background:var(--c-text);color:#fff;font-family:var(--ff-display);
  font-size:24px;line-height:1;margin-bottom:20px;
}
.cred__title{font-weight:900;font-size:18px;margin-bottom:12px;line-height:1.4}
.cred__body{font-size:13px;line-height:1.85;color:var(--c-text-dim)}
