/* =========================================================
   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{
  color:var(--c-text);
  display:flex;align-items:center;
  min-width:178px;
}
.site-header__logo-img{
  display:block;
  width:auto;
  height:34px;
  max-width:210px;
  object-fit:contain;
}
.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:linear-gradient(90deg,var(--c-accent),#ffb13a);margin:5px auto;
  border-radius:999px;
  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;z-index:105;background:#fff;
    flex-direction:column;justify-content:center;gap:32px;
    transform:translateX(100%);transition:transform .5s var(--ease);
    mix-blend-mode:normal;
    box-shadow:inset 0 0 0 1px rgba(255,90,31,.12);
  }
  .site-nav.is-open{transform:translateX(0)}
  .site-nav__link{font-size:24px;color:var(--c-text)}
  .site-nav__link:hover{color:var(--c-accent)}
  .site-nav__cta{padding:16px 32px;font-size:14px}
  .nav-toggle.is-open span{background:linear-gradient(90deg,var(--c-accent),#ffb13a)}
}

/* ---------- 共通：セクション ---------- */
.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;white-space:nowrap;
}
.big-num__value sup{
  font-size:.35em;font-weight:400;color:var(--c-accent);
  margin-left:8px;vertical-align:super;white-space:nowrap;
}
.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:clamp(110px,13vw,170px) 0;
  position:relative;overflow:hidden;text-align:center;
}
.final-cta .big-numbers__bg img{
  filter:brightness(.32) grayscale(.25) contrast(1.08);
}
.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(56px,8.8vw,142px);
  line-height:.94;letter-spacing:-.02em;color:#fff;
  margin:0 auto 38px;
  max-width:1100px;
}
.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:720px;margin:0 auto 48px;
}

/* ---------- ボタン ---------- */
.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__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}
.business-wizard[hidden],
.standard-form[hidden]{display:none !important}
.standard-form{display:grid;gap:24px}
body.contact-business .page-hero{display:none}
body.contact-business .contact-section{padding-top:122px !important}
body.contact-business .form{
  max-width:720px;
  margin:0 auto;
}
body.contact-business .form__type-tabs,
body.contact-business .form__notice{
  display:none;
}

.business-wizard{width:100%}
.wizard-card{
  position:relative;
  overflow:hidden;
  min-height:720px;
  padding:22px 24px 28px;
  background:#fff;
  border:1px solid rgba(10,10,10,.08);
  border-radius:38px;
  box-shadow:0 30px 90px rgba(10,10,10,.08);
}
.wizard-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-bottom:22px;
}
.wizard-brand{
  width:96px;
  height:96px;
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
  border-radius:50%;
  background:
    radial-gradient(circle at 34% 22%,rgba(255,255,255,.9),transparent 34%),
    linear-gradient(180deg,rgba(255,255,255,.98),rgba(255,247,239,.96));
  border:1px solid rgba(255,90,31,.16);
  box-shadow:0 14px 36px rgba(255,90,31,.1);
}
.wizard-brand img{
  width:74px;
  height:auto;
  object-fit:contain;
}
.wizard-icon{
  width:46px;
  height:46px;
  border-radius:50%;
  display:grid;
  place-items:center;
  color:#101010;
  background:#fff;
  border:1px solid rgba(10,10,10,.08);
  box-shadow:0 12px 28px rgba(10,10,10,.06);
  font-size:34px;
  line-height:1;
}
.wizard-icon[disabled]{opacity:.22;pointer-events:none}
.wizard-progress{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:7px;
  margin:0 -24px 30px;
  padding:0 0 1px;
}
.wizard-progress span{
  display:block;
  height:5px;
  border-radius:999px;
  background:#e9eaee;
  overflow:hidden;
}
.wizard-progress span.is-active{
  background:linear-gradient(90deg,#ff7a1a 0%,#ff2f7d 54%,#6e37ff 100%);
  box-shadow:0 6px 18px rgba(255,90,31,.24);
}
.wizard-intro{
  text-align:center;
  margin:4px auto 40px;
}
.wizard-kicker{
  color:var(--c-accent);
  font-size:13px;
  font-weight:900;
  letter-spacing:.08em;
  margin-bottom:8px;
}
.wizard-intro h2{
  font-size:clamp(20px,4.4vw,28px);
  line-height:1.45;
  margin-bottom:8px;
}
.wizard-intro p,
.wizard-help{
  color:var(--c-text-dim);
  font-size:14px;
  line-height:1.8;
}
.wizard-step{display:none}
.wizard-step.is-active{
  display:block;
  animation:wizardFade .35s var(--ease-out);
}
.wizard-step h3{
  font-size:clamp(22px,4.8vw,30px);
  line-height:1.45;
  margin-bottom:22px;
  font-weight:900;
}
.wizard-options{
  display:grid;
  gap:14px;
}
.wizard-option{
  min-height:64px;
  padding:0 20px 0 26px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  border-radius:999px;
  border:1px solid #e4e5e8;
  background:#fff;
  color:#101010;
  font-size:16px;
  font-weight:800;
  box-shadow:0 10px 28px rgba(10,10,10,.035);
  transition:border-color .2s,box-shadow .2s,transform .2s;
}
.wizard-option span{
  width:28px;
  height:28px;
  border-radius:50%;
  border:3px solid #747780;
  display:block;
  position:relative;
}
.wizard-option.is-selected{
  border-color:rgba(255,90,31,.52);
  box-shadow:0 14px 34px rgba(255,90,31,.14);
  transform:translateY(-1px);
}
.wizard-option.is-selected span{
  border-color:var(--c-accent);
  background:var(--c-accent);
}
.wizard-option.is-selected span::after{
  content:"";
  position:absolute;
  inset:7px;
  border-radius:50%;
  background:#fff;
}
.wizard-textarea,
.wizard-input{
  width:100%;
  background:#fff;
  border:1px solid #dddfe4;
  border-radius:18px;
  color:#101010;
  font-family:var(--ff-jp);
  font-size:16px;
  font-weight:700;
  outline:none;
  transition:border-color .2s,box-shadow .2s;
}
.wizard-textarea{
  min-height:150px;
  padding:20px;
  resize:vertical;
  line-height:1.7;
  margin-top:16px;
}
.wizard-fields{
  display:grid;
  gap:12px;
}
.wizard-input{
  min-height:58px;
  padding:0 18px;
}
.wizard-textarea:focus,
.wizard-input:focus{
  border-color:rgba(255,90,31,.7);
  box-shadow:0 0 0 4px rgba(255,90,31,.08);
}
.wizard-next,
.wizard-submit{
  width:100%;
  min-height:62px;
  margin-top:22px;
  border-radius:18px;
  background:linear-gradient(90deg,#ff6a24,#ef3f2e);
  color:#fff;
  font-weight:900;
  font-size:16px;
  box-shadow:0 18px 34px rgba(255,90,31,.22);
}
.wizard-submit{
  background:linear-gradient(90deg,#ff6a24,#ff2f7d 62%,#6e37ff);
}
.wizard-next[disabled],
.wizard-submit[disabled]{
  opacity:.45;
  box-shadow:none;
  cursor:not-allowed;
}
.wizard-privacy{
  margin-top:18px;
  color:#777b84;
  font-size:12px;
  line-height:1.7;
}
@keyframes wizardFade{
  from{opacity:0;transform:translateY(14px)}
  to{opacity:1;transform:translateY(0)}
}

@media (max-width:768px){
  body.contact-business .contact-section{padding-top:92px !important}
  .wizard-card{
    min-height:700px;
    padding:18px 20px 24px;
    border-radius:28px;
    box-shadow:0 22px 70px rgba(10,10,10,.06);
  }
  .wizard-progress{margin-left:-20px;margin-right:-20px}
  .wizard-brand{width:78px;height:78px;padding:15px}
  .wizard-brand img{width:60px}
  .wizard-icon{width:40px;height:40px;font-size:30px}
  .wizard-intro{margin-bottom:34px}
  .wizard-step h3{font-size:21px}
  .wizard-option{min-height:58px;font-size:15px}
}
.thanks-actions{
  display:flex;
  gap:16px;
  flex-wrap:wrap;
  align-items:center;
}
.thanks-callback-form{margin:0}
.thanks-callback-form .btn{height:100%}
.thanks-notice{
  max-width:620px;
  padding:16px 18px;
  border-radius:16px;
  background:#fff7ef;
  border:1px solid rgba(255,90,31,.22);
  color:#b63b12;
  font-weight:800;
  line-height:1.7;
}
@media (max-width:768px){
  .thanks-actions .btn{
    width:100%;
    justify-content:center;
  }
  .thanks-callback-form{width:100%}
}

/* ---------- フッター ---------- */
.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 82% 18%,rgba(255,90,31,.18),transparent 28%),
    radial-gradient(circle at 18% 86%,rgba(18,18,18,.06),transparent 30%),
    linear-gradient(135deg,#fff 0%,#f7f4ef 46%,#fff 100%);
}
.hero--trust .hero__bg img{
  filter:grayscale(.18) contrast(1.02) brightness(1.08);
  opacity:.3;
}
.hero--trust .hero__bg::after{
  background:
    linear-gradient(90deg,rgba(250,250,250,.99) 0%,rgba(250,250,250,.93) 54%,rgba(250,250,250,.76) 100%),
    linear-gradient(180deg,rgba(250,250,250,.68) 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-phone{
  position:relative;
  z-index:2;
  justify-self:end;
  margin-top:0;
  width:min(100%,380px);
  padding:12px;
  border-radius:54px;
  background:
    linear-gradient(145deg,#30343c 0%,#07080a 48%,#20242d 100%);
  border:1px solid rgba(255,255,255,.2);
  box-shadow:
    0 42px 110px rgba(10,10,10,.32),
    0 16px 34px rgba(255,90,31,.08),
    inset 0 0 0 1px rgba(255,255,255,.1),
    inset 0 -12px 28px rgba(255,255,255,.035);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  animation:phoneFloat 5.5s ease-in-out infinite;
}
.hero-phone::before{
  content:"";
  position:absolute;
  left:50%;
  top:21px;
  width:126px;
  height:31px;
  transform:translateX(-50%);
  border-radius:999px;
  background:linear-gradient(180deg,#050506,#15161a);
  z-index:3;
  box-shadow:0 13px 28px rgba(0,0,0,.22),inset 24px 0 0 -20px rgba(255,255,255,.14);
}
.hero-phone::after{
  content:"";
  position:absolute;
  right:-3px;
  top:156px;
  width:3px;
  height:68px;
  border-radius:999px;
  background:rgba(10,10,10,.38);
  box-shadow:none;
}
.hero-phone__badge{
  position:absolute;
  z-index:5;
  display:none;
  align-items:center;
  min-height:44px;
  padding:0 17px;
  border-radius:999px;
  background:rgba(255,255,255,.94);
  border:1px solid rgba(10,10,10,.08);
  box-shadow:0 22px 54px rgba(10,10,10,.16);
  color:rgba(10,10,10,.72);
  font-family:var(--ff-en);
  font-size:10.5px;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
  white-space:nowrap;
}
.hero-phone__badge--top{
  top:76px;
  left:-42px;
}
.hero-phone__badge--bottom{
  right:-42px;
  bottom:118px;
  color:#fff;
  background:linear-gradient(135deg,#ff5a1f,#d83c0f);
  border-color:rgba(255,255,255,.22);
  font-family:var(--ff-jp);
  letter-spacing:.04em;
  font-size:12px;
}
@keyframes phoneFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-10px)}
}
.hero-phone__screen{
  position:relative;
  overflow:hidden;
  border-radius:43px;
  padding:45px 17px 20px;
  background:
    radial-gradient(circle at 84% 0%,rgba(255,90,31,.2),transparent 26%),
    linear-gradient(180deg,#f7f8fb 0%,#eef1f6 100%);
  color:#111216;
  min-height:552px;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.14);
}
.hero-phone__island{
  position:absolute;
  left:50%;
  top:23px;
  width:76px;
  height:7px;
  transform:translateX(-50%);
  border-radius:999px;
  background:rgba(255,255,255,.1);
  z-index:4;
}
.hero-phone__screen::before{
  content:"";
  position:absolute;
  inset:-80px -70px auto auto;
  width:260px;
  height:260px;
  background:radial-gradient(circle,rgba(255,90,31,.26),transparent 66%);
  pointer-events:none;
}
.hero-phone__screen::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:9px;
  width:118px;
  height:4px;
  transform:translateX(-50%);
  border-radius:999px;
  background:rgba(10,10,10,.2);
  z-index:4;
}
.hero-phone__topbar{
  position:absolute;
  left:24px;
  right:24px;
  top:14px;
  z-index:4;
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-family:var(--ff-en);
  font-size:11px;
  font-weight:900;
  color:#111216;
  pointer-events:none;
}
.hero-phone__topbar div{
  display:flex;
  align-items:center;
  gap:7px;
}
.hero-phone__icons{
  height:14px;
}
.hero-phone__icons span{
  display:inline-flex;
  align-items:center;
}
.hero-phone__signal{
  align-items:end !important;
  gap:3px;
}
.hero-phone__signal i{
  display:block;
  width:5px;
  border-radius:999px;
  background:currentColor;
  opacity:.96;
}
.hero-phone__signal i:nth-child(1){height:6px}
.hero-phone__signal i:nth-child(2){height:9px}
.hero-phone__signal i:nth-child(3){height:12px}
.hero-phone__wifi{
  width:18px;
  height:13px;
  justify-content:center;
}
.hero-phone__wifi svg{
  display:block;
  width:18px;
  height:13px;
  fill:currentColor;
}
.hero-phone__battery{
  width:24px;
  height:11px;
  border:1.7px solid currentColor;
  border-radius:4px;
  position:relative;
  padding:1.5px;
}
.hero-phone__battery::after{
  content:"";
  position:absolute;
  right:-4px;
  top:3px;
  width:2px;
  height:5px;
  border-radius:2px;
  background:currentColor;
}
.hero-phone__battery i{
  display:block;
  width:100%;
  height:100%;
  border-radius:2px;
  background:currentColor;
}
.hero-phone__status{
  position:relative;
  z-index:2;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
  margin:6px 0 18px;
  font-family:var(--ff-en);
  letter-spacing:.1em;
  text-transform:uppercase;
  font-size:10px;
  color:rgba(17,18,22,.55);
}
.hero-phone__status strong{
  color:#fff;
  background:#111216;
  padding:6px 10px;
  border-radius:999px;
  font-size:10px;
  font-family:var(--ff-jp);
  letter-spacing:.05em;
}
.hero-phone__photo{
  position:relative;
  z-index:1;
  aspect-ratio:16/8.8;
  overflow:hidden;
  border-radius:28px;
  margin-bottom:12px;
  border:1px solid rgba(10,10,10,.08);
  box-shadow:0 18px 46px rgba(14,18,24,.14);
}
.hero-phone__photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  filter:saturate(.98) contrast(1.04) brightness(1.04);
  object-position:center 44%;
}
.hero-phone__photo::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 38%,rgba(0,0,0,.62) 100%);
}
.hero-phone__photo-label{
  position:absolute;
  left:14px;
  right:14px;
  bottom:12px;
  z-index:2;
  color:#fff;
  font-weight:900;
  font-size:12px;
  line-height:1.45;
  text-shadow:0 8px 20px rgba(0,0,0,.34);
}
.hero-phone__metric{
  position:relative;
  z-index:2;
  padding:20px 20px 18px;
  border-radius:28px;
  background:
    radial-gradient(circle at 82% 12%,rgba(255,90,31,.18),transparent 34%),
    linear-gradient(145deg,#fff,#f7f8fb);
  border:1px solid rgba(10,10,10,.07);
  text-align:center;
  box-shadow:0 18px 42px rgba(14,18,24,.11);
}
.hero-phone__metric small{
  display:block;
  font-family:var(--ff-jp);
  font-size:14.5px;
  letter-spacing:.04em;
  color:rgba(17,18,22,.68);
  font-weight:900;
}
.hero-phone__metric strong{
  display:block;
  font-family:var(--ff-en);
  font-weight:900;
  font-size:clamp(82px,6.8vw,100px);
  line-height:1.02;
  margin:10px 0 10px;
  color:#111216;
  letter-spacing:-.01em;
  font-feature-settings:"tnum" 1;
}
.hero-phone__metric span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:148px;
  min-height:40px;
  margin:0 auto;
  padding:0 16px;
  border-radius:999px;
  background:rgba(255,90,31,.1);
  border:1px solid rgba(255,90,31,.28);
  color:var(--c-accent);
  font-weight:900;
  font-size:16px;
  letter-spacing:.06em;
}
.hero-phone__metric b{
  display:block;
  margin:12px auto 0;
  max-width:260px;
  color:rgba(17,18,22,.58);
  font-size:12px;
  line-height:1.65;
}
.hero-phone__metric em{
  display:block;
  margin-top:6px;
  color:rgba(17,18,22,.44);
  font-style:normal;
  font-size:10px;
  line-height:1.45;
}
.hero-phone__kpis{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  margin-top:10px;
}
.hero-phone__kpis div{
  min-height:54px;
  padding:8px 8px;
  border-radius:18px;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(10,10,10,.06);
  box-shadow:0 12px 26px rgba(14,18,24,.07);
}
.hero-phone__kpis strong{
  display:block;
  font-family:var(--ff-en);
  font-size:11px;
  color:var(--c-accent);
  letter-spacing:.08em;
  margin-bottom:4px;
}
.hero-phone__kpis span{
  display:block;
  font-size:11px;
  font-weight:900;
  color:#111216;
}
.hero-phone__growth{
  position:relative;
  z-index:2;
  margin:10px 0 0;
  padding:12px 12px 10px;
  border-radius:18px;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(10,10,10,.06);
  box-shadow:0 12px 26px rgba(14,18,24,.07);
}
.hero-phone__growth-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:8px;
  font-size:10.5px;
  font-weight:900;
  color:rgba(17,18,22,.58);
}
.hero-phone__growth-head strong{
  color:var(--c-accent);
  font-size:11px;
  letter-spacing:.02em;
}
.hero-phone__graph{
  position:relative;
  z-index:2;
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:8px;
  height:42px;
  padding:0 6px;
}
.hero-phone__graph i{
  display:block;
  width:20px;
  border-radius:999px 999px 6px 6px;
  background:linear-gradient(180deg,rgba(255,90,31,.98),rgba(17,18,22,.13));
  box-shadow:0 8px 18px rgba(255,90,31,.18);
  animation:barPulse 2.8s ease-in-out infinite;
}
.hero-phone__graph i:nth-child(2){animation-delay:.12s}
.hero-phone__graph i:nth-child(3){animation-delay:.24s}
.hero-phone__graph i:nth-child(4){animation-delay:.36s}
.hero-phone__graph i:nth-child(5){animation-delay:.48s}
.hero-phone__graph i:nth-child(6){animation-delay:.6s}
@keyframes barPulse{
  0%,100%{opacity:.72;transform:scaleY(.94)}
  50%{opacity:1;transform:scaleY(1.04)}
}
.hero-phone__copy{
  position:relative;
  z-index:2;
  margin:10px 0 12px;
  color:rgba(17,18,22,.66);
  font-size:12.2px;
  line-height:1.65;
  font-weight:700;
}
.hero-phone__steps{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:8px;
}
.hero-phone__steps span{
  display:grid;
  place-items:center;
  min-height:36px;
  border-radius:14px;
  background:#111216;
  border:1px solid rgba(255,255,255,.1);
  color:rgba(255,255,255,.94);
  font-weight:800;
  font-size:12px;
}
.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}
  .hero-phone{justify-self:center;max-width:390px;margin-top:0}
  .hero-phone__badge--top{left:12px;top:-18px}
  .hero-phone__badge--bottom{right:8px;bottom:-18px}
}
@media (max-width:768px){
  .hero--trust{
    min-height:auto;
    padding:96px 0 46px;
  }
  .hero--trust .hero__bg img{
    opacity:.22;
    object-position:center top;
  }
  .hero--trust .hero__bg::after{
    background:
      linear-gradient(180deg,rgba(250,250,250,.96) 0%,rgba(250,250,250,.91) 44%,#FAFAFA 100%),
      linear-gradient(90deg,rgba(250,250,250,.98),rgba(250,250,250,.82));
  }
  .hero__inner--grid{
    gap:28px;
  }
  .hero__copy .lead{
    font-size:14px;
    line-height:1.85;
    margin-bottom:22px !important;
  }
  .hero--trust .hero__title{
    font-size:clamp(33px,10.4vw,48px);
    line-height:1.08;
    margin-bottom:24px;
  }
  .hero--trust .hero__title em{
    display:inline-block;
    white-space:nowrap;
    font-size:clamp(28px,8.1vw,40px);
    letter-spacing:-.08em;
  }
  .hero__eyebrow{
    font-size:10px;
    letter-spacing:.18em;
    margin-bottom:20px;
    gap:10px;
  }
  .hero__eyebrow::before{width:28px}
  .hero__actions .btn{width:100%;justify-content:center}
  .hero__actions{gap:10px;margin-bottom:18px}
  .site-header__logo{min-width:142px}
  .site-header__logo-img{height:28px;max-width:170px}
  .hero__meta--compact{
    display:grid;
    grid-template-columns:1fr;
    gap:10px;
    padding-top:18px;
  }
  .hero__meta-item strong{font-size:14px}
  .hero-dashboard{border-radius:22px;padding:20px}
  .hero-dashboard__main{grid-template-columns:1fr}
  .hero-phone{
    width:100%;
    max-width:328px;
    justify-self:center;
    margin-top:0;
    border-radius:42px;
    padding:9px;
    animation:none;
  }
  .hero-phone__badge{display:none}
  .hero-phone::before{
    top:16px;
    width:104px;
    height:26px;
  }
  .hero-phone::after{display:none}
  .hero-phone__screen{
    min-height:auto;
    border-radius:34px;
    padding:43px 14px 18px;
  }
  .hero-phone__topbar{
    left:22px;
    right:22px;
    top:13px;
    font-size:10px;
  }
  .hero-phone__island{
    top:20px;
    width:60px;
    height:5px;
  }
  .hero-phone__status{
    margin-bottom:14px;
    font-size:8px;
    letter-spacing:.08em;
  }
  .hero-phone__status strong{
    font-size:8px;
    padding:4px 8px;
  }
  .hero-phone__photo{
    aspect-ratio:16/9.2;
    border-radius:22px;
    margin-bottom:14px;
  }
  .hero-phone__metric{
    padding:18px 16px 16px;
    border-radius:22px;
  }
  .hero-phone__metric small{font-size:12px}
  .hero-phone__metric strong{
    font-size:68px;
    line-height:1.02;
    margin:10px 0 10px;
  }
  .hero-phone__metric span{
    min-height:32px;
    min-width:108px;
    font-size:14px;
  }
  .hero-phone__metric b{
    font-size:10.5px;
    margin-top:10px;
    max-width:230px;
  }
  .hero-phone__metric em{
    font-size:9.6px;
    line-height:1.45;
  }
  .hero-phone__kpis{
    gap:6px;
    margin-top:8px;
  }
  .hero-phone__kpis div{
    min-height:54px;
    border-radius:14px;
    padding:8px 5px;
  }
  .hero-phone__kpis span{font-size:10px}
  .hero-phone__graph{
    height:34px;
    gap:6px;
  }
  .hero-phone__graph i{width:15px}
  .hero-phone__growth{
    padding:10px 10px 8px;
    border-radius:15px;
  }
  .hero-phone__copy{
    font-size:12.5px;
    line-height:1.7;
    margin:12px 0 14px;
  }
  .hero-phone__steps{gap:6px}
  .hero-phone__steps span{
    min-height:34px;
    border-radius:11px;
    font-size:11px;
  }
}
@media (max-width:420px){
  .hero-phone{max-width:310px}
  .hero-phone__metric strong{font-size:60px}
  .hero-phone__copy{font-size:12px}
}

/* ヒーロー右側のサブビジュアル */
.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)}
