/* =============================================================
   Pixeom Theme — app.css
   Benchlingテイスト（ディープネイビー × クリーン）を参考にした
   ディープテック向けコーポレートデザイン。
   コンテンツは株式会社Pixeom。
   ============================================================= */

/* ---------- Design Tokens（Benchling 実測パレット）----------
   Hero背景=白、見出し=濃紺#000650、アクセント=鮮やかな青#000db5
   色面リズム: 白 / 水色#d3e4fc / 濃紺#000650 / 薄水色#f0f6fe */
:root {
  /* Brand */
  --c-ink:        #000650;   /* 濃紺（見出し・濃色面・主要文字） */
  --c-navy:       #000650;   /* （互換用エイリアス） */
  --c-navy-2:     #0a1170;   /* グラデ用のわずかに明るい濃紺 */
  --c-accent:     #000db5;   /* アクセント（鮮やかな青・ボタン） */
  --c-accent-2:   #2b41e0;   /* ホバー */
  --c-on-dark-accent: #7d93ff; /* 濃色面上での強調文字 */
  --c-glow:       #7d93ff;   /* 濃色面上のグロー/アクセント（タイムラインのドット・年月・bannerリード等）。定義漏れを補完 */

  /* Neutral / 面 */
  --c-white:      #ffffff;
  --c-sky:        #d3e4fc;   /* Hero周辺の淡い水色面 */
  --c-off:        #f0f6fe;   /* 薄い水色の面 */
  --c-mist:       #eef3fc;   /* さらに薄い面 */
  --c-line:       #dde6f4;   /* 罫線 */
  --c-text:       #1a2238;   /* 本文（やや青み） */
  --c-muted:      #50607d;   /* 補助テキスト */
  --c-muted-2:    #8893ab;

  /* Typography — Geist（Graphik代替の中立グロテスク）。和文は Noto Sans JP（太さがしっかり出る） */
  --f-display: "Geist", "Noto Sans JP", system-ui, sans-serif;
  --f-body:    "Geist", "Noto Sans JP", system-ui, sans-serif;

  /* Layout */
  --maxw: 1160px;
  --gutter: clamp(1.25rem, 4vw, 2.5rem);
  --radius: 14px;
  --radius-lg: 22px;

  /* Motion */
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

/* ---------- Reset / Base ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; scroll-padding-top: 84px; }
.admin-bar { scroll-padding-top: 116px; } /* ログイン時はヘッダー84px+管理バー32px分 */
body {
  margin: 0;
  font-family: var(--f-body);
  color: var(--c-text);
  background: var(--c-white);
  line-height: 1.7;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
h1, h2, h3, h4 { font-family: var(--f-display); line-height: 1.12; letter-spacing: -0.025em; margin: 0; font-weight: 700; text-wrap: balance; }
/* 和文見出しは Noto Sans JP の 900（Black）でしっかり太く。チープさを排し、存在感を出す。 */
.lang-ja h1, .lang-ja h2, .lang-ja h3 { font-weight: 900; }
/* 本文は読みやすい行末に（対応ブラウザ） */
p { text-wrap: pretty; }

/* 日本語の見出し：英単語/熟語の途中改行を防ぐ。長すぎる場合のみ anywhere で逃がす。 */
.lang-ja h1, .lang-ja h2, .lang-ja h3 {
  word-break: keep-all;
  line-break: strict;
  overflow-wrap: anywhere;
}
/* リード文・サブコピー：禁則（line-break: strict）を活かし、句読点が行頭に来ないようにする。
   anywhere は句読点の行頭送りを無効化してしまうため使わず、break-word で長語のみ逃がす。 */
.lang-ja .hero__sub, .lang-ja .section-lead {
  word-break: normal;
  line-break: strict;
  overflow-wrap: break-word;
}
/* カード等の短い本文は keep-all + 禁則のみ（句読点の行頭送りを防ぐため anywhere は使わない） */
.lang-ja .card p, .lang-ja .contrast__card p, .lang-ja .member__bio,
.lang-ja .news-card__title {
  word-break: normal;
  line-break: strict;
}

/* ---------- Layout helpers ---------- */
.container { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); }
.section { padding-block: clamp(3.25rem, 6vw, 5.5rem); }
.section--tight { padding-block: clamp(2.5rem, 4.5vw, 4rem); }
.eyebrow {
  font-family: var(--f-display);
  font-size: 0.78rem; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--c-accent);
  margin: 0 0 0.85rem;
}
.section-title { font-size: clamp(2.1rem, 4.4vw, 3.4rem); font-weight: 700; color: var(--c-ink); line-height: 1.18; letter-spacing: -0.03em; }
.lang-ja .section-title { font-weight: 900; line-height: 1.28; }
.section-lead { margin-top: 1.35rem; max-width: 56ch; color: var(--c-muted); font-size: 1.125rem; line-height: 1.8; }

/* ---------- Buttons ---------- */
/* ボタン: Benchling実測準拠（14px/weight500/字間-0.28px/影なし/radius50px/pad14-24px） */
.btn {
  --b-bg: var(--c-accent); --b-fg: #fff;
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-family: var(--f-display); font-weight: 500; font-size: 0.9rem; letter-spacing: -0.01em;
  padding: 0.875rem 1.5rem; border-radius: 50px; border: 1px solid transparent;
  background: var(--b-bg); color: var(--b-fg);
  cursor: pointer; transition: transform .3s ease, background .3s ease;
  box-shadow: none;
}
.btn:hover { background: var(--c-accent-2); transform: translateY(-1px); }
.btn--ghost { --b-bg: transparent; --b-fg: var(--c-ink); border-color: var(--c-line); box-shadow: none; }
.btn--ghost:hover { background: var(--c-mist); border-color: var(--c-mist); }
.btn--on-dark { --b-bg: #fff; --b-fg: var(--c-ink); box-shadow: 0 12px 36px -14px rgba(0,0,0,.6); }
.btn .arrow { transition: transform .25s var(--ease); }
.btn:hover .arrow { transform: translateX(3px); }

/* ---------- Header ---------- */
.site-header {
  position: fixed; inset: 0 0 auto 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; padding: 1rem var(--gutter);
  transition: background .35s var(--ease), box-shadow .35s var(--ease), padding .35s var(--ease);
}
/* ログイン中（管理バー表示時）は固定ヘッダーを管理バーの高さ分だけ下げる。
   これをしないと top:0 のヘッダーが WP 管理バーに重なり、メニューが操作不能になる。
   ※管理バーはログインユーザーにのみ表示され、本番の一般訪問者には影響しない。 */
.admin-bar .site-header { top: 32px; }
@media screen and (max-width: 782px) {
  .admin-bar .site-header { top: 46px; }
}
/* 透明状態（最上部）でも背景画像の上でナビが読めるよう、上端に薄い白グラデを敷く。
   ::before は装飾なのでクリックを透過させる。is-scrolled 時は白背景になるので消す。 */
.site-header::before {
  content: ""; position: absolute; inset: 0; z-index: -1; pointer-events: none;
  background: linear-gradient(180deg, rgba(248,250,254,.92) 0%, rgba(248,250,254,.55) 60%, rgba(248,250,254,0) 100%);
  transition: opacity .35s var(--ease);
}
.site-header.is-scrolled::before { opacity: 0; }
.site-header.is-scrolled {
  background: rgba(255,255,255,.86);
  backdrop-filter: saturate(150%) blur(12px);
  box-shadow: 0 1px 0 var(--c-line);
  padding-block: 0.75rem;
}
.brand { display: inline-flex; align-items: center; gap: .5rem; font-family: var(--f-display); font-weight: 700; font-size: 1.3rem; letter-spacing: -0.02em; color: var(--c-ink); }
.brand__mark { width: 28px; height: auto; display: block; }
.brand__text { line-height: 1; }
.nav { display: flex; align-items: center; gap: 1.75rem; }
.nav a { font-size: 0.92rem; font-weight: 600; color: var(--c-ink); opacity: .78; transition: opacity .25s var(--ease), color .25s var(--ease); }
.nav a:hover { opacity: 1; }
.lang-switch { display: inline-flex; gap: .5rem; align-items: center; font-size: .82rem; font-family: var(--f-display); font-weight: 600; }
.lang-switch a { opacity: .55; }
.lang-switch a.is-active { opacity: 1; }
.nav-toggle { display: none; }

/* ---------- Hero（Benchling実測：白〜水色背景・濃紺の細い大見出し）---------- */
.hero {
  position: relative; overflow: hidden; color: var(--c-ink); isolation: isolate;
  background: linear-gradient(180deg, #ffffff 0%, var(--c-sky) 100%);
  padding-top: clamp(8rem, 14vw, 11rem);
  padding-bottom: clamp(4rem, 8vw, 6.5rem);
}

/* ===== Hero 全面背景画像版（青み基調の分子/PSM画像を全面に敷き、前面にコピー） =====
   画像は左が淡く右に分子/PSM。左〜見出し範囲を白マスクで確実に読ませる。 */
.hero--media {
  min-height: clamp(560px, 82vh, 800px); display: flex; align-items: center;
  background: linear-gradient(180deg, #eaf2fd 0%, var(--c-sky) 100%);
}
.hero--media > .container { position: relative; z-index: 2; width: 100%; }
/* 背景レイヤー（全面・複数画像のスライドショー） */
.hero__bg { position: absolute; inset: 0; z-index: 0; }
/* 各スライドを重ね、is-active のものだけ不透明に。切り替えはクロスフェード。 */
.hero__slide {
  position: absolute; inset: 0;
  background-size: cover; background-position: center right;
  opacity: 0; transition: opacity 1.6s var(--ease);
  will-change: opacity;
}
.hero__slide.is-active { opacity: 1; }
@media (prefers-reduced-motion: reduce) {
  /* reduced-motion でも巡回は継続するが、クロスフェードは短く控えめにする
     （長い 1.6s のフェードは"動き"が大きいので 0.4s に抑え、穏やかな切替にする）。 */
  .hero__slide { transition: opacity .4s linear; }
}
/* 可読性マスク：左から白で、見出し（「をつくる」含む）が乗る範囲まで
   しっかり不透明にしてから抜く。右側は画像をそのまま見せる。
   下端はサイト水色へフェードして次セクションへ繋ぐ。 */
.hero--media::before {
  content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    linear-gradient(90deg,
      rgba(248,250,254,.98) 0%,
      rgba(248,250,254,.97) 42%,
      rgba(248,250,254,.82) 58%,
      rgba(248,250,254,.3) 78%,
      rgba(248,250,254,0) 92%),
    linear-gradient(180deg, transparent 70%, var(--c-sky) 100%);
}
/* 前面コピーは左寄せ・読みやすい最大幅 */
.hero--media .hero__copy { max-width: 34rem; }
.hero--media .hero__trust { position: relative; z-index: 2; }
@media (max-width: 860px) {
  /* タブレット以下は画像を薄く敷き、上から白フェードでテキスト可読性を最優先 */
  .hero--media::before {
    background: linear-gradient(180deg, rgba(248,250,254,.95) 0%, rgba(248,250,254,.78) 48%, var(--c-sky) 100%);
  }
  .hero--media .hero__copy { max-width: none; }
}
.hero__grid {
  position: relative; z-index: 1;
  display: grid; grid-template-columns: 1fr 1.05fr; gap: clamp(1.5rem, 4vw, 3.5rem);
  align-items: center;
}
.hero__copy { max-width: 38rem; }
.hero__badge {
  display:inline-flex; align-items:center; gap:.5rem; margin-bottom:1.6rem;
  padding:.4rem .9rem; border-radius:999px; border:1px solid rgba(0,6,80,.14);
  background:rgba(255,255,255,.6); font-family:var(--f-display); font-weight:500;
  font-size:.78rem; letter-spacing:.02em; color:var(--c-ink);
}
.hero__badge::before { content:""; width:7px; height:7px; border-radius:999px; background:var(--c-accent); }
.hero h1 {
  font-size: clamp(3.1rem, 6.4vw, 5.4rem); font-weight: 700; line-height: 1.12;
  letter-spacing: -0.04em; color: var(--c-ink);
}
.lang-ja .hero h1 { font-weight: 900; line-height: 1.2; }
.hero h1 .nowrap { white-space: nowrap; }
/* 「世界標準」= 動くグラデーション文字 + 描かれる蛍光ペン */
.hero h1 em {
  font-style: normal; position: relative; display: inline-block; isolation: isolate;
  /* 色が流れるグラデ（背景を横にスライド）。青基調は維持。
     左右対称のグラデ（中央が明、両端が濃紺）にして、background-position を
     左端⇄右端で「往復(alternate)」させる。これにより、繰り返しの境目で位置が
     ジャンプして見える不自然さ（旧 0%→320% の片道ループ）が無くなり、
     光が左右にゆっくり揺れる滑らかな動きになる。
     ease-in-out で端での折り返しが自然に。 */
  background: linear-gradient(100deg,
    #001a9e 0%, #1f4dff 25%, #4db8ff 42%, #eaf2ff 50%, #4db8ff 58%, #1f4dff 75%, #001a9e 100%);
  background-size: 220% 100%;
  -webkit-background-clip: text; background-clip: text; color: transparent;
  padding: 0 .1em;
  animation: emFlow 5s ease-in-out infinite alternate;
}
@keyframes emFlow { from { background-position: 0% 50%; } to { background-position: 100% 50%; } }
.hero h1 em::before { /* 蛍光ペンの下線ハイライト（左→右に描かれる） */
  content:""; position:absolute; z-index:-1; left:0; bottom:.06em; height:.4em; width:100%;
  background: linear-gradient(90deg, rgba(43,76,255,.22), rgba(0,194,255,.28));
  border-radius: 4px; transform: rotate(-0.8deg); transform-origin: left center;
  animation: emPen 1s var(--ease) .5s both;
}
@keyframes emPen { from{ transform: rotate(-0.8deg) scaleX(0); } to{ transform: rotate(-0.8deg) scaleX(1); } }
/* em の色が流れるグラデは「点滅・視差」ではなく穏やかな色変化なので、
   reduced-motion でも継続する（Hero スライドショーと方針を統一）。
   ただし蛍光ペン下線の"描かれる"初回アニメ（emPen）だけは動きが出るため止める。 */
@media (prefers-reduced-motion: reduce) { .hero h1 em::before { animation: none; } }
/* 動くタイポ（見出し下で言葉が入れ替わる） */
.hero__rotator { margin: 1.1rem 0 0; font-family: var(--f-display); font-weight: 600; font-size: clamp(1.15rem, 2vw, 1.5rem); color: var(--c-ink); display: flex; align-items: baseline; gap: .15em; flex-wrap: wrap; }
.hero__rotator-prefix { color: var(--c-muted); font-weight: 500; }
.hero__rotator-words { position: relative; color: var(--c-accent); display: inline-block; min-width: 4.5em; }
.hero__rotator-words.is-swapping { animation: rotWord .45s var(--ease); }
@keyframes rotWord { 0%{ opacity:0; transform: translateY(0.4em); } 100%{ opacity:1; transform:none; } }
.hero__sub { margin-top: 1.4rem; font-size: clamp(1.06rem, 1.45vw, 1.2rem); color: var(--c-muted); max-width: 42ch; line-height: 1.9; text-wrap: pretty; }
.hero__cta { margin-top: 2.4rem; display: flex; gap: .8rem; flex-wrap: wrap; }
.hero__cta .btn--on-dark { --b-bg: var(--c-accent); --b-fg: #fff; box-shadow: 0 18px 40px -18px rgba(0,13,181,.5); }
.hero__cta .btn--ghost { --b-fg: var(--c-ink); border-color: rgba(0,6,80,.18); background: transparent; }
.hero__cta .btn--ghost:hover { background: rgba(0,6,80,.05); border-color: rgba(0,6,80,.12); }

/* Hero右の製品ビジュアル（濃紺の面・影で浮かせる） */
.hero__visual {
  position: relative; border-radius: var(--radius-lg); overflow: hidden;
  aspect-ratio: 5/4;
  background: radial-gradient(130% 130% at 70% 15%, #0a1170, var(--c-ink));
  box-shadow: 0 50px 90px -38px rgba(0,6,80,.14);
  display: grid; place-items: center;
}
.hero__visual img { width: 100%; height: 100%; object-fit: cover; animation: heroFloat 7s ease-in-out infinite; }
@keyframes heroFloat { 0%,100%{ transform: translateY(0) scale(1); } 50%{ transform: translateY(-10px) scale(1.012); } }
.hero__visual::after { /* 微細な光のスイープ（動画的な明滅） */
  content:""; position:absolute; inset:0; z-index:2; pointer-events:none;
  background: linear-gradient(115deg, transparent 40%, rgba(125,147,255,.12) 50%, transparent 60%);
  background-size: 250% 100%; animation: heroSweep 6s ease-in-out infinite;
}
@keyframes heroSweep { 0%{ background-position: 130% 0; } 60%,100%{ background-position: -30% 0; } }
@media (prefers-reduced-motion: reduce) { .hero__visual img { animation: none; } .hero__visual::after { animation: none; } }

/* Hero 動画（白基調・分子⇄行列ループ）。動画自体が動くので浮遊アニメは付けない。
   背景は動画の白基調に合わせ、光スイープ（::after）も動画時は不要なため抑制。
   動画素材は 16:9（中央に分子⇄行列）。枠を 16:10 に寄せて左右の切れを最小化し、
   object-position:center で構図の中心を保つ。 */
/* 動画は素材どおり 16:9 枠で見せる（縦長枠に押し込むと左右が切れるため）。 */
.hero__visual:has(.hero__video) { background: #f4f7fb; aspect-ratio: 16/9; }
.hero__visual:has(.hero__video)::after { display: none; }
.hero__video { width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; }
.hero__visual-ph { color: rgba(255,255,255,.4); font-family: var(--f-display); letter-spacing: .04em; }

/* Hero右ビジュアル：分子 → 近接スコア行列（画像が来るまでのSVG/CSS） */
.hero-viz { display:flex; align-items:center; justify-content:center; gap:clamp(.5rem,2.5vw,1.75rem); width:100%; padding:clamp(1.25rem,4vw,2.5rem); }
.hero-viz__mol { width:clamp(120px,15vw,170px); height:auto; }
.hero-viz__mol line { stroke:rgba(255,255,255,.35); stroke-width:2.5; }
.hero-viz__mol circle { fill:#cdd8ff; }
.hero-viz__mol circle.a { fill:var(--c-on-dark-accent); filter:drop-shadow(0 0 8px rgba(125,147,255,.8)); animation: vizPulse 3s var(--ease) infinite; }
@keyframes vizPulse { 0%,100%{opacity:.7;} 50%{opacity:1;} }
.hero-viz__arrow { color:var(--c-on-dark-accent); font-size:1.5rem; }
.hero-viz__matrix { display:grid; grid-template-columns:repeat(6,1fr); gap:4px; width:clamp(108px,14vw,152px); }
.hero-viz__matrix span { aspect-ratio:1; border-radius:3px; background:var(--c-on-dark-accent); opacity:0; animation: vizCell .5s var(--ease) forwards; animation-delay:var(--d); }
@keyframes vizCell { to { opacity:var(--o); } }

/* Hero下の信頼バー */
.hero__trust { position: relative; z-index:1; margin-top: clamp(2.75rem,5vw,4rem); padding-top: clamp(1.75rem,3vw,2.25rem); border-top:1px solid rgba(0,6,80,.12); display:flex; align-items:center; gap:1.5rem; flex-wrap:wrap; }
.hero__trust .label { font-family:var(--f-display); font-weight:600; letter-spacing:.12em; text-transform:uppercase; font-size:.7rem; color:var(--c-muted-2); }
.hero__trust .items { display:flex; gap:1.75rem; flex-wrap:wrap; color:var(--c-muted); font-weight:500; font-size:.9rem; }

/* ---------- 宣言帯（角丸パネル＋背景画像はみ出し / Benchling型） ---------- */
.banner { padding-block: clamp(2rem, 5vw, 4rem); background: linear-gradient(180deg, var(--c-sky), #fff); }
.banner > .container {
  position: relative; overflow: hidden; isolation: isolate;
  background: linear-gradient(150deg, #060a30, var(--c-ink) 60%, #0a1170);
  color: #fff; border-radius: var(--radius-lg);
  padding: clamp(2.75rem, 6vw, 5rem) clamp(1.75rem, 5vw, 4.5rem);
  box-shadow: 0 50px 90px -45px rgba(0,6,80,.14);
}
.banner > .container::before { /* 右側に分子データ画像をはみ出させる */
  content:""; position:absolute; inset:0 -5% -10% 40%; z-index:0; opacity:.5;
  background-image:url('../img/abstract-data.webp'); background-size:cover; background-position:left center;
  mask-image: linear-gradient(90deg, transparent, #000 55%);
}
.banner__lead, .banner__main { position: relative; z-index: 1; }
.banner__lead { font-family: var(--f-display); color: var(--c-glow); font-size: .95rem; letter-spacing: .08em; margin: 0 0 1rem; }
.banner__main { font-family: var(--f-display); font-weight: 700; font-size: clamp(1.7rem, 3.6vw, 2.9rem); line-height: 1.28; letter-spacing: -0.02em; color: #fff; max-width: 22ch; margin: 0; }
/* keep-all は読点の前で折り返しを許し「、」が行頭/行末に来る原因になるため使わない。
   line-break: strict（禁則）+ break-word（長語のみ逃がす）で句読点の不自然な改行を防ぐ。 */
.lang-ja .banner__main { font-weight: 900; word-break: normal; line-break: strict; overflow-wrap: break-word; }

/* スクリーンリーダー専用（視覚的に隠す） */
.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* タイプライター演出（banner__main） */
.banner__main[data-typewriter] { min-height: calc(2em * 1.28); } /* 2行ぶんの高さを確保しガタつき防止 */
.banner__typed { white-space: pre-wrap; }
/* 点滅キャレット（縦棒） */
.banner__caret {
  display: inline-block; width: .055em; height: .92em; margin-left: .04em;
  transform: translateY(.1em); background: var(--c-glow, #7d93ff);
  animation: caretBlink 1s steps(1) infinite;
}
.banner__caret.is-done { animation: caretBlink .8s steps(1) infinite; }
.banner__caret.is-hidden { opacity: 0; animation: none; transition: opacity .4s ease; }
@keyframes caretBlink { 0%,50%{ opacity: 1; } 50.01%,100%{ opacity: 0; } }
@media (prefers-reduced-motion: reduce) { .banner__caret { animation: none; } }

/* ---------- Generic dark section ---------- */
.section--dark { position: relative; isolation: isolate; background: linear-gradient(165deg, var(--c-ink), var(--c-navy)); color: #fff; overflow: hidden; }
.section--dark::before { content:""; position:absolute; inset:0; z-index:-1; opacity:.28; background-image:url('../img/grid-bg.webp'); background-size:cover; background-position:center; mix-blend-mode:screen; }
/* 色トランジション：濃紺の上端だけわずかに明るい濃紺から入れ、白面からの落差の"硬さ"を和らげる。
   多彩化はしない（同じ濃紺の濃淡のみ）。下端はそのまま濃く締めて重心をつくる。 */
.section--dark::after {
  content: ""; position: absolute; inset: 0 0 auto 0; height: clamp(80px, 14vw, 160px); z-index: -1; pointer-events: none;
  background: linear-gradient(180deg, #0a1170 0%, rgba(10,17,112,0) 100%);
}
.section--dark .container { position: relative; z-index: 1; }
.section--dark .section-title { color: #fff; }
.section--dark .section-lead { color: rgba(255,255,255,.8); }
.section--off { background: var(--c-off); }

/* ---------- Statement セクション（主役カット：大きな問いを言葉で立てる） ----------
   「全セクション同じ強度」のテンプレ感を壊すための"強"セクション。
   見出しを特大にして、ここで一度立ち止まらせる緩急をつくる。 */
.section--statement { padding-block: clamp(4.5rem, 9vw, 8rem); }
.statement-title {
  font-family: var(--f-display); color: var(--c-ink);
  font-size: clamp(2.4rem, 5.6vw, 4.6rem); line-height: 1.18; letter-spacing: -0.035em;
  font-weight: 700; max-width: 18ch; text-wrap: balance;
}
.lang-ja .statement-title { font-weight: 900; line-height: 1.32; }
/* 問いの一部を青で強調したい場合に em を使う（i18n 側で <em> を入れれば効く） */
.statement-title em { font-style: normal; color: var(--c-accent); }
.statement-lead {
  margin-top: clamp(1.5rem, 3vw, 2.25rem); max-width: 60ch;
  color: var(--c-muted); font-size: clamp(1.05rem, 1.6vw, 1.22rem); line-height: 1.95;
}

/* ---------- What We Do / contrast ---------- */
.contrast {
  display: grid; grid-template-columns: 1fr auto 1fr; align-items: stretch;
  gap: clamp(.75rem, 2.5vw, 1.75rem);
  /* 間延び解消：主役見出しの直後に置くので余白を詰める */
  margin-top: clamp(2.5rem, 4.5vw, 3.5rem);
}
.contrast__card {
  border-radius: var(--radius-lg); overflow: hidden;
  border: 1px solid var(--c-line); background: #fff; height: 100%;
  display: flex; flex-direction: column;
}
.contrast__media { aspect-ratio: 16/10; overflow: hidden; background: var(--c-mist); }
.contrast__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.contrast__body { padding: clamp(1.4rem, 2.6vw, 2rem); }
.contrast__card p { margin: 0; font-size: .98rem; line-height: 1.85; }
.contrast__card--before { background: #fff; }
.contrast__card--before .contrast__media { background: linear-gradient(135deg, #e7ecf6, #f3f6fc); }
.contrast__card--before p { color: var(--c-muted); }
.contrast__card--after { border-color: transparent; box-shadow: 0 36px 70px -34px rgba(0,6,80,.14); }
.contrast__card--after .contrast__media { background: radial-gradient(130% 130% at 60% 20%, #1b2a8a, #16205f); }
/* 紺が強すぎて重い指摘（2026-05-28）→ 明るめのネイビーに緩和し、白文字の可読性も確保 */
.contrast__card--after .contrast__body { background: #1c2c7a; }
.contrast__card--after p { color: rgba(255,255,255,.92); }
.contrast__card h3 { font-size: 1.3rem; margin-bottom: .6rem; }
.contrast__card--before h3 { color: var(--c-ink); }
.contrast__card--after h3 { color: #fff; }
.contrast__tag { display:inline-block; font-size: .7rem; letter-spacing: .14em; text-transform: uppercase; font-weight: 600; margin-bottom:.5rem; }
.contrast__card--before .contrast__tag { color: var(--c-muted-2); }
.contrast__card--after .contrast__tag { display:inline-block; color: #fff; background: var(--c-accent); padding:.25rem .6rem; border-radius:999px; letter-spacing:.1em; }
/* 矢印は2枚のカードの縦中央に配置する（align-items:stretch で引き伸ばされた
   セル内で、文字が上端に寄らないよう grid + place-items:center で中央に置く）。 */
.contrast__arrow { color: var(--c-accent); font-size: 1.8rem; font-weight: 400; display: grid; place-items: center; }

/* ---------- Feature / split（Benchling型：背景パネル＋浮く画像＋はみ出し）---------- */
.split { display: grid; grid-template-columns: 1.02fr .98fr; gap: clamp(1.5rem, 4vw, 4rem); align-items: center; }
.split--reverse .split__media { order: -1; }
/* メディアを薄水色パネルの上に置き、画像が浮いて少しはみ出す多層構造 */
.split__media {
  position: relative; border-radius: var(--radius-lg); aspect-ratio: 4/3;
  background: linear-gradient(155deg, var(--c-sky), var(--c-mist));
  padding: clamp(1.25rem, 3vw, 2.25rem);
  display: grid; place-items: center;
}
.split__media::after { /* 角の装飾ドット（signature） */
  content:""; position:absolute; width:90px; height:90px; right:-14px; bottom:-14px; z-index:2;
  background-image: radial-gradient(var(--c-accent) 2px, transparent 2px); background-size: 16px 16px; opacity:.5;
}
.split__media > img, .split__media > .psm-diagram, .split__media > .rd-glyph, .split__media > .hero-viz {
  position: relative; z-index: 1; width: 100%; height: 100%; border-radius: calc(var(--radius-lg) - 6px);
  box-shadow: 0 30px 60px -28px rgba(0,6,80,.14); object-fit: cover;
}
/* 主役ビジュアルが画面に入った瞬間、ごくゆっくりズームイン（"生きている"質感。過剰にしない）。
   split__media 自身が .reveal を持つ（front-page）。JS無効時は初期表示なので scale も無効化。 */
.split__media { overflow: hidden; }
.js-reveal .split__media.reveal > img { transition: transform 1.6s var(--ease); transform: scale(1.06); }
.js-reveal .split__media.reveal.is-visible > img { transform: scale(1); }
@media (prefers-reduced-motion: reduce) {
  .js-reveal .split__media.reveal > img { transition: none; transform: none; }
}
.split__media--psm, .split__media--rd { /* PSM/RDは濃紺ビジュアルなのでパネルも濃紺寄せ */
  background: linear-gradient(155deg, #e4ebfa, var(--c-sky));
}
.split__media img { width: 100%; height: 100%; object-fit: cover; }
/* PSM コンセプト図（画像が来るまでのCSS製ビジュアル） */
.split__media--psm { background: linear-gradient(155deg, var(--c-ink), var(--c-navy)); border-color: transparent; aspect-ratio: 4/3; }
.psm-diagram { display: flex; align-items: center; justify-content: center; gap: clamp(.75rem,3vw,2rem); width: 100%; padding: clamp(1.25rem,4vw,2.5rem); }
.psm-diagram small { display: block; text-align: center; margin-top: .9rem; color: rgba(255,255,255,.65); font-family: var(--f-display); font-size: .72rem; letter-spacing: .08em; }
.psm-diagram__mol { position: relative; width: clamp(86px,12vw,128px); height: clamp(86px,12vw,128px); }
.psm-node { position: absolute; width: 18px; height: 18px; border-radius: 999px; background: #fff; box-shadow: 0 0 0 4px rgba(255,255,255,.12); }
.psm-node.n1 { top: 6%; left: 40%; background: #6f86ff; }
.psm-node.n2 { top: 44%; left: 6%; }
.psm-node.n3 { top: 50%; right: 8%; background: #6f86ff; }
.psm-node.n4 { bottom: 6%; left: 46%; }
.psm-bond { position: absolute; height: 2px; background: rgba(255,255,255,.4); transform-origin: left center; }
.psm-bond.b1 { top: 16%; left: 44%; width: 38%; transform: rotate(38deg); }
.psm-bond.b2 { top: 22%; left: 16%; width: 36%; transform: rotate(70deg); }
.psm-bond.b3 { top: 54%; left: 18%; width: 60%; transform: rotate(8deg); }
.psm-diagram__arrow { color: var(--c-accent-2); font-size: 1.6rem; font-weight: 700; }
.psm-diagram__matrix { display: grid; grid-template-columns: repeat(5, 1fr); gap: 3px; width: clamp(96px,13vw,136px); }
.psm-diagram__matrix span { aspect-ratio: 1; border-radius: 3px; background: rgba(111,134,255, calc(0.18 + var(--v) * 0.8)); }
.psm-diagram__matrix small { grid-column: 1 / -1; }

/* ---------- Approach（3手法比較・ダーク背景） ---------- */
.approach-grid {
  display: grid; grid-template-columns: 1fr auto 1fr auto 1fr; align-items: stretch;
  gap: clamp(.5rem, 1.5vw, 1.25rem); margin-top: clamp(2.25rem, 4vw, 3rem);
}
.approach-step {
  position: relative; border-radius: var(--radius-lg); padding: clamp(1.4rem, 2.5vw, 2rem);
  border: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.03);
  transition: transform .4s var(--ease, ease), border-color .4s, background .4s;
}
.approach-step__ic {
  display: inline-grid; place-items: center; width: 2.75rem; height: 2.75rem; margin-bottom: 1rem;
  border-radius: 12px; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1);
}
.approach-step__ic svg { width: 1.4rem; height: 1.4rem; stroke: rgba(255,255,255,.55); stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; fill: none; }
.approach-step__ic svg circle { fill: rgba(255,255,255,.55); stroke: none; }
.approach-step:hover { transform: translateY(-4px); border-color: rgba(255,255,255,.22); }
.approach-step__idx { font-family: var(--f-display); font-size: .8rem; font-weight: 700; color: rgba(255,255,255,.4); letter-spacing: .1em; }
.approach-step h3 { font-size: 1.05rem; margin: .6rem 0 .55rem; color: #fff; line-height: 1.4; }
.approach-step p { margin: 0; color: rgba(255,255,255,.7); font-size: .92rem; line-height: 1.8; }
.approach-step--after { background: linear-gradient(160deg, rgba(43,76,255,.35), rgba(43,76,255,.12)); border-color: rgba(111,134,255,.5); box-shadow: 0 30px 60px -30px rgba(43,76,255,.6); }
.approach-step--after .approach-step__ic { background: rgba(125,147,255,.2); border-color: rgba(125,147,255,.45); }
.approach-step--after .approach-step__ic svg { stroke: #fff; }
.approach-step--after .approach-step__ic svg circle { fill: #fff; }
.approach-step--after h3 { color: #fff; }
.approach-step--after p { color: rgba(255,255,255,.85); }
.approach-arrow { display: grid; place-items: center; color: var(--c-accent-2); font-size: 1.5rem; font-weight: 700; }

/* ---------- R&D ---------- */
.split__media--rd { background: linear-gradient(150deg, var(--c-navy), var(--c-ink)); }
.rd-glyph { position: relative; width: 60%; height: 60%; }
.rd-glyph span { position: absolute; border-radius: 999px; background: rgba(111,134,255,.55); box-shadow: 0 0 24px rgba(111,134,255,.5); }
.rd-glyph span:nth-child(1){ width:22%; height:22%; top:10%; left:14%; }
.rd-glyph span:nth-child(2){ width:16%; height:16%; top:44%; left:60%; background:#fff; }
.rd-glyph span:nth-child(3){ width:28%; height:28%; top:58%; left:20%; }
.rd-glyph span:nth-child(4){ width:14%; height:14%; top:18%; left:64%; }
.rd-note { display:flex; gap:1.1rem; align-items:flex-start; margin-top: 1.9rem; padding: 1.6rem 1.75rem; background: linear-gradient(135deg, #f5f8fe, var(--c-mist)); border:1px solid var(--c-line); border-radius: var(--radius-lg); }
.rd-note__icon { flex:0 0 auto; display:grid; grid-template-columns:repeat(3,1fr); gap:3px; width:38px; height:38px; padding:6px; border-radius:9px; background:var(--c-ink); }
.rd-note__icon i { border-radius:2px; background:var(--c-glow); opacity:.55; }
.rd-note__icon i:nth-child(1), .rd-note__icon i:nth-child(5), .rd-note__icon i:nth-child(9) { opacity:1; background:#fff; }
.rd-note h3 { font-size: 1.05rem; color: var(--c-ink); margin: .1rem 0 .5rem; }
.rd-note p { margin: 0; color: var(--c-muted); font-size: .92rem; line-height: 1.85; }

/* ---------- IP / 特許 ---------- */
.ip-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; margin-top: clamp(2rem,4vw,2.75rem); }
/* カードが1枚だけのときは右が空かないよう全幅で表示する。 */
.ip-card:only-child { grid-column: 1 / -1; }
.ip-card { position: relative; overflow: hidden; padding: 1.75rem; border: 1px solid var(--c-line); border-radius: var(--radius); background: #fff; transition: transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease); }
.ip-card:hover { transform: translateY(-3px); box-shadow: 0 24px 50px -30px rgba(10,16,86,.3); border-color: rgba(0,13,181,.25); }
/* 右上のドットグリッド装飾（PSM行列モチーフ） */
.ip-card__deco { position: absolute; top: 1.4rem; right: 1.4rem; display: grid; grid-template-columns: repeat(4, 6px); gap: 5px; opacity: .5; pointer-events: none; }
.ip-card__deco i { width: 6px; height: 6px; border-radius: 2px; background: var(--c-sky); }
.ip-card:hover .ip-card__deco i { background: var(--c-on-dark-accent); }
.ip-card__ic { display: inline-grid; place-items: center; width: 2.6rem; height: 2.6rem; border-radius: 12px; background: var(--c-mist); margin-bottom: 1rem; }
.ip-card__ic svg { width: 1.35rem; height: 1.35rem; stroke: var(--c-accent); stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; fill: none; }
.ip-card__no { display:inline-block; font-family: var(--f-display); font-weight: 700; font-size: .85rem; color: var(--c-accent); letter-spacing: .04em; padding: .25rem .7rem; border: 1px solid var(--c-line); border-radius: 999px; }
.ip-card__title { font-size: 1.1rem; color: var(--c-ink); margin: .9rem 0 .5rem; line-height: 1.45; }
.ip-card__meta { color: var(--c-muted); font-size: .85rem; }

/* ---------- Roadmap timeline（ダーク） ---------- */
/* タイムライン（左）＋ VISION（右）の2カラム。右の余白を活かす配置。 */
.roadmap-flow {
  display: grid; grid-template-columns: 1fr 0.82fr; gap: clamp(2rem, 5vw, 4.5rem);
  align-items: center; margin-top: clamp(2.25rem, 4vw, 3rem);
}
/* ロードマップ：時系列の縦タイムライン（年月 | ●ライン | 内容） */
.timeline { list-style: none; margin: 0; padding: 0; position: relative; max-width: 100%; }
.timeline::before { /* 縦ライン: ドット列の中心(年月7rem + gap1.25rem の位置)を通す */
  content:""; position:absolute; left: calc(7rem + 1.25rem); top: 14px; bottom: 14px; width: 2px;
  background: linear-gradient(180deg, var(--c-accent), var(--c-glow));
  transform: translateX(-1px);
}
.timeline__item {
  position: relative; display: grid; grid-template-columns: 7rem 2.5rem 1fr; align-items: center;
  gap: 0; padding: .75rem 0;
}
.timeline__step { display:none; }
.timeline__when { font-family: var(--f-display); font-weight: 600; font-size: 1rem; color: var(--c-glow); text-align: left; }
.timeline__dot {
  position: relative; justify-self: center; width: 14px; height: 14px; border-radius:999px; z-index:1;
  background: var(--c-accent); box-shadow: 0 0 0 4px rgba(0,6,80,1), 0 0 0 6px rgba(43,76,255,.3), 0 0 14px rgba(125,147,255,.6);
}
.timeline__item:last-child .timeline__dot { background: var(--c-glow); box-shadow: 0 0 0 4px rgba(0,6,80,1), 0 0 0 6px rgba(125,147,255,.35), 0 0 18px var(--c-glow); }
/* スクロールで項目が現れた瞬間、ドットがポンと光る（時系列が順に点灯していく印象）。
   ::after の波紋リングが一度広がって消える。 */
.timeline__dot::after {
  content: ""; position: absolute; inset: 0; border-radius: 999px;
  box-shadow: 0 0 0 0 rgba(125,147,255,.7); opacity: 0;
}
.js-reveal .timeline__item.is-visible .timeline__dot { animation: dotLight .7s var(--ease) both; }
.js-reveal .timeline__item.is-visible .timeline__dot::after { animation: dotRipple .9s var(--ease) both; }
@keyframes dotLight {
  0%   { transform: scale(.4); box-shadow: 0 0 0 4px rgba(0,6,80,1), 0 0 0 6px rgba(43,76,255,.1), 0 0 6px rgba(125,147,255,.2); }
  55%  { transform: scale(1.25); box-shadow: 0 0 0 4px rgba(0,6,80,1), 0 0 0 8px rgba(125,147,255,.55), 0 0 26px rgba(125,147,255,1); }
  100% { transform: scale(1); }
}
@keyframes dotRipple {
  0%   { opacity: .8; box-shadow: 0 0 0 0 rgba(125,147,255,.55); }
  100% { opacity: 0; box-shadow: 0 0 0 16px rgba(125,147,255,0); }
}
@media (prefers-reduced-motion: reduce) {
  .js-reveal .timeline__item.is-visible .timeline__dot,
  .js-reveal .timeline__item.is-visible .timeline__dot::after { animation: none; }
}
.timeline__what { color: rgba(255,255,255,.92); font-size: 1.02rem; line-height: 1.6; padding-left: .75rem; }
/* ゴール: 最終ステップの先（縦ライン延長上）に配置 */
.exit-box { position: relative; margin: 0; padding: clamp(1.75rem,3vw,2.5rem); background: linear-gradient(150deg, rgba(0,13,181,.28), rgba(125,147,255,.10)); border: 1px solid rgba(125,147,255,.35); border-radius: var(--radius-lg); }
/* 2カラム時はタイムラインとの縦繋ぎマーカーは出さない（横並びのため） */
.exit-box__marker { display: none; }
.exit-box__label { display:inline-block; font-family:var(--f-display); font-weight:700; font-size:.68rem; letter-spacing:.16em; color:var(--c-glow); margin-bottom:.5rem; }
.exit-box h3 { color: #fff; font-size: 1.2rem; margin: 0 0 .65rem; }
.exit-box p { color: rgba(255,255,255,.85); margin: 0; font-size: .95rem; line-height: 1.85; }
@media (max-width: 920px) { .roadmap-flow { grid-template-columns: 1fr; gap: 2rem; } }

/* ---------- UIモック（HTML/CSS製の製品画面・多層） ---------- */
.ui-mock-wrap {
  position: relative; padding: clamp(1.5rem, 3vw, 2.5rem);
  border-radius: var(--radius-lg);
  background: linear-gradient(150deg, var(--c-sky), #eaf1fd);
}
.ui-mock { border-radius: 14px; }
.ui-mock--back {
  position: absolute; top: 6%; right: 4%; width: 80%; height: 88%;
  background: #fff; border:1px solid var(--c-line); border-radius: 14px;
  box-shadow: 0 20px 40px -30px rgba(0,6,80,.14); opacity:.5; z-index:0;
  transform: rotate(2deg);
}
.ui-mock--front {
  position: relative; z-index: 1; background: #fff; overflow: hidden;
  border: 1px solid rgba(0,6,80,.08);
  box-shadow: 0 40px 80px -34px rgba(0,6,80,.14);
}
.ui-mock__bar { display:flex; align-items:center; gap:7px; padding:.7rem 1rem; border-bottom:1px solid var(--c-line); background:#f7f9fd; }
.ui-dot { width:9px; height:9px; border-radius:999px; background:#d3dbea; }
.ui-dot:nth-child(1){ background:#ff6058; } .ui-dot:nth-child(2){ background:#ffbd2e; } .ui-dot:nth-child(3){ background:#28c840; }
.ui-mock__title { margin-left:.6rem; font-family:var(--f-display); font-weight:600; font-size:.82rem; color:var(--c-ink); }
.ui-mock__body { padding: 1.1rem 1.2rem 1.3rem; }
.ui-mock__head { display:flex; justify-content:space-between; align-items:flex-start; gap:1rem; margin-bottom:1rem; }
.ui-mock__sub { font-size:.72rem; color:var(--c-muted-2); }
.ui-mock__query { display:inline-flex; align-items:center; gap:.4rem; margin-top:.3rem; font-family:var(--f-display); font-weight:600; font-size:.95rem; color:var(--c-ink); }
.ui-q-ic { display:inline-grid; place-items:center; width:22px; height:22px; border-radius:6px; background:var(--c-mist); color:var(--c-accent); font-size:.85rem; }
.ui-mock__status { display:inline-flex; align-items:center; gap:.4rem; font-size:.7rem; font-weight:600; color:var(--c-accent); background:rgba(0,13,181,.07); padding:.3rem .6rem; border-radius:999px; white-space:nowrap; }
.ui-pulse { width:6px; height:6px; border-radius:999px; background:var(--c-accent); animation:uiPulse 1.6s ease-in-out infinite; }
@keyframes uiPulse { 0%,100%{opacity:.4; transform:scale(.8);} 50%{opacity:1; transform:scale(1.1);} }
.ui-mock__matrix { display:grid; grid-template-columns:repeat(12,1fr); gap:3px; padding:.85rem; background:linear-gradient(150deg,#0a1170,var(--c-ink)); border-radius:10px; margin-bottom:1rem; }
.ui-mock__matrix span { aspect-ratio:1; border-radius:2px; background:#7d93ff; opacity:var(--o,.5); will-change:opacity; animation:uiCell 3s ease-in-out infinite; }
.ui-mock__matrix span:nth-child(3n){ animation-delay:.4s; } .ui-mock__matrix span:nth-child(5n){ animation-delay:.9s; } .ui-mock__matrix span:nth-child(7n){ animation-delay:1.3s; }
@keyframes uiCell { 0%,100%{ opacity:var(--o); } 50%{ opacity:1; } }
.ui-mock__list { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:.5rem; }
.ui-mock__list li { display:grid; grid-template-columns:auto 1fr auto auto; align-items:center; gap:.7rem; padding:.6rem .7rem; border:1px solid var(--c-line); border-radius:9px; }
.ui-mol { width:22px; height:22px; border-radius:6px; background:radial-gradient(circle at 60% 35%, var(--c-glow), var(--c-ink)); }
.ui-name { font-family:var(--f-display); font-weight:500; font-size:.82rem; color:var(--c-ink); }
.ui-tag { font-size:.68rem; color:var(--c-muted); background:var(--c-mist); padding:.18rem .5rem; border-radius:999px; }
.ui-score { font-family:var(--f-display); font-weight:700; font-size:.82rem; color:var(--c-accent); }
.ui-mock__metrics { display:grid; grid-template-columns:1fr 1fr; gap:.7rem; margin-top:1rem; }
.ui-mock__metrics div { padding:.7rem .8rem; background:var(--c-mist); border-radius:9px; }
.ui-mock__metrics span { display:block; font-size:.68rem; color:var(--c-muted-2); }
.ui-mock__metrics strong { font-family:var(--f-display); font-weight:700; font-size:1.05rem; color:var(--c-ink); }

/* ---------- 技術の3ポイント（アイコン付きリスト） ---------- */
.tech-points { list-style:none; margin: clamp(1.75rem,3vw,2.5rem) 0 0; padding:0; display:flex; flex-direction:column; gap:.5rem; }
.tech-points li { display:flex; gap:1rem; align-items:flex-start; padding:1.1rem 1rem; border-radius:var(--radius); transition: background .25s var(--ease); }
.tech-points li:hover { background: var(--c-mist); }
.tech-points__ic { flex:0 0 auto; display:grid; place-items:center; width:44px; height:44px; border-radius:12px; background:var(--c-ink); }
.tech-points__ic svg { width:22px; height:22px; fill:none; stroke:#9db0ff; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; }
.tech-points h3 { font-size:1.1rem; color:var(--c-ink); margin:.1rem 0 .35rem; }
.tech-points p { margin:0; color:var(--c-muted); font-size:.95rem; line-height:1.8; }

/* ---------- Card grid (business) ---------- */
.cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; margin-top: 3rem; }
.card {
  border-radius: var(--radius); padding: 1.75rem; background: #fff; border: 1px solid var(--c-line);
  transition: transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease);
}
.card:hover { transform: translateY(-4px); box-shadow: 0 24px 50px -28px rgba(10,16,86,.35); border-color: transparent; }
.card__icon { display:inline-grid; place-items:center; width:48px; height:48px; border-radius:12px; background:var(--c-ink); margin-bottom:1.1rem; }
.card__icon svg { width:24px; height:24px; display:block; }
.card__icon svg * { stroke:#9db0ff; stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round; fill:none; }
.card__icon svg circle { fill:rgba(157,176,255,.18); }
.card__num { display:block; font-family: var(--f-display); font-weight: 600; color: var(--c-accent); font-size: .82rem; letter-spacing: .12em; }
.card h3 { font-size: 1.2rem; margin: .4rem 0 .6rem; color: var(--c-ink); }
.card p { color: var(--c-muted); font-size: .96rem; margin: 0; }

/* ---------- Business flow（左sticky見出し + 右スクロール3項目・タベテク的） ---------- */
.biz-flow {
  display: grid;
  grid-template-columns: minmax(280px, 38%) 1fr;
  gap: clamp(2.5rem, 5vw, 5rem);
  align-items: start;
}
/* 左カラム: スクロール中も画面に追従して残る見出し */
.biz-flow__head {
  position: sticky;
  top: 120px;
  align-self: start;
}
.biz-flow__head .section-title { margin-top: .5rem; }
.biz-flow__head .section-lead { margin-top: 1.25rem; max-width: 34ch; }

/* 右カラム: 縦に積む各サービス項目 */
.biz-flow__list { list-style: none; margin: 0; padding: 0; display: grid; gap: clamp(3.5rem, 7vw, 7rem); }
.biz-item { display: grid; gap: 1.25rem; }
.biz-item__num {
  font-family: var(--f-display); font-weight: 600; color: var(--c-accent);
  font-size: 1rem; letter-spacing: .14em;
}
.biz-item__title { font-size: clamp(1.35rem, 2.2vw, 1.75rem); margin: 0; color: var(--c-ink); line-height: 1.35; }
.biz-item__desc { color: var(--c-muted); font-size: 1.02rem; line-height: 1.8; margin: 0; max-width: 46ch; }
/* 各項目の画像（スクロールで現れる主役ビジュアル） */
.biz-item__media {
  border-radius: var(--radius-lg); overflow: hidden;
  aspect-ratio: 16/10; background: var(--c-mist);
  border: 1px solid var(--c-line);
}
.biz-item__media:empty { display: none; } /* 画像未配置のときは枠を出さない */
.biz-item__media img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform .9s var(--ease);
}
.biz-item.is-visible .biz-item__media img { transform: scale(1.02); }

@media (max-width: 860px) {
  .biz-flow { grid-template-columns: 1fr; gap: 2.5rem; }
  .biz-flow__head { position: static; top: auto; }
  .biz-flow__list { gap: 3rem; }
  .biz-item__desc { max-width: none; }
}

/* ---------- Team ---------- */
.team { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; margin-top: 2.5rem; }
.member { text-align: left; }
.member__photo { aspect-ratio: 1; border-radius: var(--radius); background: var(--c-mist); overflow: hidden; margin-bottom: 1rem; }
.member__photo img { width: 100%; height: 100%; object-fit: cover; }
/* 実写真が来るまでのプレースホルダ：濃紺＋PSM格子＋イニシャル */
.member__photo--ph { position: relative; display: grid; place-items: center; background: radial-gradient(120% 120% at 70% 20%, #0a1170, var(--c-ink)); }
.member__photo--ph::before { content:""; position:absolute; inset:0; opacity:.4; background-image: radial-gradient(var(--c-glow) 1px, transparent 1px); background-size: 22px 22px; mask-image: radial-gradient(closest-side at 50% 50%, #000, transparent 75%); }
.member__initial { position:relative; font-family: var(--f-display); font-weight: 500; font-size: 3.2rem; color: rgba(255,255,255,.92); }
.member__name { font-family: var(--f-display); font-weight: 600; color: var(--c-ink); font-size: 1.1rem; }
.member__role { color: var(--c-accent); font-size: .82rem; font-weight: 600; margin-top: .2rem; letter-spacing: .01em; }
.member__lead { color: var(--c-text); font-size: .92rem; font-weight: 500; margin: .85rem 0 0; line-height: 1.7; }
.member__bio { color: var(--c-muted); font-size: .86rem; margin-top: .5rem; line-height: 1.85; }
.member__tags { margin-top: .9rem; padding-top: .85rem; border-top: 1px solid var(--c-line); color: var(--c-muted-2); font-size: .76rem; font-family: var(--f-display); letter-spacing: .02em; }

/* ---------- Info table (company) ---------- */
.info { margin-top: 2rem; border-top: 1px solid var(--c-line); }
.info__row { display: grid; grid-template-columns: 200px 1fr; gap: 1rem; padding: 1rem 0; border-bottom: 1px solid var(--c-line); }
.info__row dt { font-family: var(--f-display); font-weight: 600; color: var(--c-ink); font-size: .95rem; }
.info__row dd { margin: 0; color: var(--c-muted); }

/* ---------- News ---------- */
/* 見出し行：タイトルと「すべて見る」を両端に */
.news-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 1rem; flex-wrap: wrap; }
.news-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; margin-top: 2.5rem; }
.news-card { display: flex; flex-direction: column; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--c-line); background: #fff; transition: transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease); }
.news-card__link { display: flex; flex-direction: column; height: 100%; }
.news-card:hover { transform: translateY(-4px); box-shadow: 0 24px 50px -30px rgba(10,16,86,.3); }
.news-card__thumb { aspect-ratio: 16/9; background: var(--c-mist); overflow: hidden; }
.news-card__thumb img { width: 100%; height: 100%; object-fit: cover; }
/* アイキャッチ未設定時のPSMドットグリッド・プレースホルダ */
.news-card__thumb--ph { background: linear-gradient(135deg, var(--c-ink), var(--c-navy)); display: grid; place-items: center; }
.news-card__glyph { display: grid; grid-template-columns: repeat(8, 1fr); gap: 5px; width: 56%; }
.news-card__glyph i { aspect-ratio: 1; border-radius: 2px; background: rgba(125,147,255, var(--o)); transition: opacity .4s var(--ease); }
.news-card:hover .news-card__glyph i { background: rgba(160,180,255, var(--o)); }
.news-card__body { padding: 1.25rem 1.4rem 1.6rem; display: flex; flex-direction: column; gap: .4rem; flex: 1; }
.news-card__date { font-size: .8rem; color: var(--c-muted-2); font-family: var(--f-display); }
.news-card__title { font-size: 1.05rem; color: var(--c-ink); font-family: var(--f-display); font-weight: 600; line-height: 1.4; }
.news-card__more { margin-top: auto; padding-top: .5rem; font-family: var(--f-display); font-weight: 600; font-size: .82rem; color: var(--c-accent); opacity: 0; transform: translateY(4px); transition: opacity .3s var(--ease), transform .3s var(--ease); display: inline-flex; align-items: center; gap: .35rem; }
.news-card__more .arrow { transition: transform .25s var(--ease); }

/* ---------- News カルーセル（中央フォーカス型・Benchling参照） ----------
   中央のスライドが大きく鮮明、左右はスケールダウン＋淡くして "peek" させる。
   横スライドで次々めくる。スワイプ・矢印・ドットで操作。 */
.news-carousel { margin-top: clamp(2.5rem, 5vw, 3.5rem); }
/* viewport は左右の peek を見せるため container をはみ出して広げる（負マージン） */
.news-carousel__viewport {
  overflow: hidden; margin-inline: calc(var(--gutter) * -1);
  padding-inline: var(--gutter); -webkit-mask-image: none;
}
.news-carousel__track {
  list-style: none; margin: 0; padding: 1rem 0; display: flex; gap: clamp(1rem, 2.5vw, 1.75rem);
  transition: transform .6s var(--ease); will-change: transform;
}
/* 1枚あたりの幅：中央を主役にするため画面の約58%。左右がpeekする。 */
.news-carousel__slide {
  flex: 0 0 58%; max-width: 640px;
  opacity: .42; transform: scale(.93); filter: saturate(.8);
  transition: opacity .6s var(--ease), transform .6s var(--ease), filter .6s var(--ease), box-shadow .6s var(--ease);
}
/* 中央（アクティブ）スライド：鮮明・大きく・影で浮かせる */
.news-carousel__slide.is-current {
  opacity: 1; transform: scale(1); filter: none;
}
.news-carousel__slide.is-current .news-card { box-shadow: 0 40px 80px -36px rgba(0,6,80,.28); border-color: transparent; }
.news-carousel__slide.is-current .news-card__more { opacity: 1; transform: none; }
.news-carousel__slide.is-current .news-card:hover .news-card__more .arrow { transform: translateX(3px); }
.news-carousel__slide .news-card { height: 100%; }
/* 中央スライドのサムネは少し背を高く（主役感） */
.news-carousel__slide.is-current .news-card__thumb { aspect-ratio: 16/10; }

/* コントロール（矢印＋ドット） */
.news-carousel__controls { display: flex; align-items: center; justify-content: center; gap: 1.25rem; margin-top: clamp(1.5rem, 3vw, 2.25rem); }
.news-carousel__btn {
  display: inline-grid; place-items: center; width: 44px; height: 44px; border-radius: 999px;
  border: 1px solid var(--c-line); background: #fff; color: var(--c-ink); cursor: pointer;
  transition: background .25s var(--ease), border-color .25s var(--ease), transform .25s var(--ease), opacity .25s var(--ease);
}
.news-carousel__btn:hover { background: var(--c-ink); color: #fff; border-color: var(--c-ink); transform: translateY(-2px); }
.news-carousel__btn:disabled { opacity: .35; cursor: default; transform: none; }
.news-carousel__btn .arrow { font-size: 1.1rem; line-height: 1; }
.news-carousel__dots { display: flex; align-items: center; gap: .5rem; }
.news-carousel__dot {
  width: 8px; height: 8px; border-radius: 999px; border: 0; padding: 0; cursor: pointer;
  background: var(--c-line); transition: background .25s var(--ease), width .25s var(--ease);
}
.news-carousel__dot.is-active { background: var(--c-accent); width: 22px; }
@media (prefers-reduced-motion: reduce) {
  .news-carousel__track, .news-carousel__slide { transition: none; }
}
@media (max-width: 860px) {
  /* モバイルは中央フォーカスを強めに（左右のpeekは細く） */
  .news-carousel__slide { flex-basis: 82%; }
}

/* ---------- Single news（ニュース詳細） ---------- */
.single-news__head { padding-top: clamp(7.5rem, 12vw, 10rem); padding-bottom: clamp(1.75rem, 3.5vw, 2.75rem); background: linear-gradient(180deg, #eaf2fd 0%, var(--c-off) 100%); }
/* 見出しエリアの中身を本文と同じ 720px 軸に揃える（見出しと本文の左端を一致させる）。
   以前は見出しが container 全幅・本文が 720px 中央寄せで、軸がズレて本文が右に偏って見えた。 */
.single-news__head > .container > * { max-width: 720px; margin-inline: auto; }
.single-news__back { display: inline-flex; align-items: center; gap: .35rem; font-size: .9rem; font-weight: 600; color: var(--c-accent); margin-bottom: 1.5rem; transition: opacity .2s var(--ease); }
.single-news__back:hover { opacity: .7; }
.single-news__meta { display: flex; align-items: center; gap: .9rem; flex-wrap: wrap; margin-bottom: 1rem; }
.single-news__meta time { font-family: var(--f-display); font-size: .92rem; color: var(--c-muted); }
.single-news__cat { font-size: .72rem; font-weight: 700; letter-spacing: .08em; color: #fff; background: var(--c-accent); padding: .25rem .7rem; border-radius: 999px; }
.single-news__title { font-size: clamp(1.9rem, 4.2vw, 3rem); line-height: 1.3; color: var(--c-ink); max-width: 720px; text-wrap: balance; }
.lang-ja .single-news__title { font-weight: 900; word-break: normal; line-break: strict; overflow-wrap: break-word; }
/* アイキャッチ */
.single-news__hero { background: var(--c-off); padding-bottom: clamp(1.5rem, 3vw, 2.5rem); }
.single-news__thumb { width: 100%; max-width: 860px; margin: 0 auto; display: block; border-radius: var(--radius-lg); aspect-ratio: 16/9; object-fit: cover; }
/* 本文組版：読みやすい行長と縦リズム */
/* 本文の上余白：見出しエリア直下に続くので詰めすぎず空けすぎず。
   アイキャッチが無い記事でも見出しと本文が間延びしないバランスにする。 */
.single-news__body { padding: clamp(2rem, 3.5vw, 2.75rem) 0 clamp(3.5rem, 7vw, 6rem); }
.single-news__content { max-width: 720px; margin: 0 auto; color: var(--c-text); font-size: 1.08rem; line-height: 1.95; }
.single-news__content > * + * { margin-top: 1.5rem; }
.single-news__content h2 { font-size: 1.5rem; font-weight: 700; color: var(--c-ink); margin-top: 2.5rem; line-height: 1.4; }
.single-news__content h3 { font-size: 1.2rem; font-weight: 700; color: var(--c-ink); margin-top: 2rem; }
.single-news__content a { color: var(--c-accent); text-decoration: underline; text-underline-offset: 2px; }
.single-news__content img { max-width: 100%; height: auto; border-radius: var(--radius); }
/* 本文中の画像（figure）：上下に余白、キャプションは小さく中央に */
.single-news__content figure { margin: clamp(1.75rem, 3vw, 2.5rem) 0; }
.single-news__content figure img { width: 100%; display: block; border-radius: var(--radius-lg); }
.single-news__content figcaption { margin-top: .65rem; text-align: center; font-size: .82rem; color: var(--c-muted-2); line-height: 1.6; }
.single-news__content ul, .single-news__content ol { padding-left: 1.4em; }
.single-news__content li + li { margin-top: .5rem; }
.single-news__content blockquote { border-left: 3px solid var(--c-accent); padding-left: 1.2rem; color: var(--c-muted); font-style: normal; }
.single-news__nav { max-width: 720px; margin: clamp(2.5rem, 5vw, 4rem) auto 0; padding-top: 2rem; border-top: 1px solid var(--c-line); }
/* アーカイブ：空表示 */
.news-archive { padding-top: clamp(6rem, 10vw, 8rem); }
.news-archive__empty { color: var(--c-muted); margin-top: 2rem; }

/* ---------- 404 ---------- */
.error-404 { min-height: 70vh; display: flex; align-items: center; background: linear-gradient(180deg, #eaf2fd 0%, var(--c-off) 100%); padding: clamp(7rem, 12vw, 10rem) 0 clamp(4rem, 8vw, 6rem); }
.error-404__code { font-family: var(--f-display); font-weight: 900; font-size: clamp(4rem, 14vw, 8rem); line-height: 1; color: var(--c-accent); letter-spacing: -0.04em; opacity: .9; }
.error-404__title { font-size: clamp(1.6rem, 4vw, 2.4rem); color: var(--c-ink); margin-top: .5rem; }
.lang-ja .error-404__title { font-weight: 900; }
.error-404__lead { color: var(--c-muted); font-size: 1.05rem; line-height: 1.9; margin-top: 1rem; max-width: 40ch; }
.error-404__actions { margin-top: 2.25rem; }

/* ---------- 固定ページ ---------- */
.page-default__head { padding-top: clamp(7.5rem, 12vw, 10rem); padding-bottom: clamp(1.5rem, 3vw, 2.25rem); background: linear-gradient(180deg, #eaf2fd 0%, var(--c-off) 100%); }
.page-default__title { font-size: clamp(1.9rem, 4.2vw, 2.8rem); color: var(--c-ink); line-height: 1.3; }
.lang-ja .page-default__title { font-weight: 900; }
.page-default__body { padding: clamp(2.5rem, 5vw, 4rem) 0 clamp(3.5rem, 7vw, 6rem); }
.page-default__content { max-width: 760px; margin: 0 auto; color: var(--c-text); font-size: 1.06rem; line-height: 1.95; }
.page-default__content > * + * { margin-top: 1.4rem; }
.page-default__content h2 { font-size: 1.45rem; font-weight: 700; color: var(--c-ink); margin-top: 2.4rem; }
.page-default__content h3 { font-size: 1.18rem; font-weight: 700; color: var(--c-ink); margin-top: 1.8rem; }
.page-default__content a { color: var(--c-accent); text-decoration: underline; text-underline-offset: 2px; }
.page-default__content ul, .page-default__content ol { padding-left: 1.4em; }
/* 日本語本文の禁則処理：括弧・読点が行頭/行末に来る不自然な改行を防ぐ。
   長文ページ（固定ページ・法務ページ）に必須。英単語/URLは break-word で逃がす。 */
.lang-ja .page-default__content p,
.lang-ja .page-default__content li,
.lang-ja .legal-content p,
.lang-ja .legal-content li,
.lang-ja .legal-info dd {
  line-break: strict;
  overflow-wrap: break-word;
  word-break: normal;
}

/* ---------- 法務ページ（プライバシーポリシー・利用規約等） ---------- */
.legal-content h2 { font-size: 1.25rem; margin-top: 2.6rem; padding-bottom: .5rem; border-bottom: 1px solid var(--c-line); }
.legal-content h3 { font-size: 1.02rem; margin-top: 1.6rem; color: var(--c-muted); }
.legal-content ol, .legal-content ul { margin-top: .8rem; }
.legal-content li { margin: .4rem 0; }
/* 事業者情報・問い合わせ窓口の定義リスト */
.legal-info { margin: 1rem 0 0; border-top: 1px solid var(--c-line); }
.legal-info > div { display: grid; grid-template-columns: 180px 1fr; gap: 1rem; padding: .85rem 0; border-bottom: 1px solid var(--c-line); }
.legal-info dt { font-family: var(--f-display); font-weight: 600; color: var(--c-ink); font-size: .92rem; margin: 0; }
.legal-info dd { margin: 0; color: var(--c-muted); }
@media (max-width: 640px) {
  .legal-info > div { grid-template-columns: 1fr; gap: .2rem; }
}

/* ---------- Contact ---------- */
.contact-wrap { display: grid; grid-template-columns: .9fr 1.1fr; gap: clamp(1.5rem,4vw,3.5rem); align-items: start; }
.contact .wpcf7 input[type=text], .contact .wpcf7 input[type=email], .contact .wpcf7 textarea {
  width: 100%; padding: .9rem 1rem; border: 1px solid rgba(255,255,255,.25); border-radius: 10px;
  background: rgba(255,255,255,.06); color: #fff; font-family: var(--f-body); font-size: 1rem; margin-top: .35rem;
}
.contact .wpcf7 input::placeholder, .contact .wpcf7 textarea::placeholder { color: rgba(255,255,255,.5); }
.contact .wpcf7 label { display: block; margin-bottom: 1rem; color: rgba(255,255,255,.85); font-size: .9rem; }
.contact .wpcf7 input[type=submit] {
  background: #fff; color: var(--c-ink); border: none; padding: .9rem 1.8rem; border-radius: 999px;
  font-family: var(--f-display); font-weight: 600; cursor: pointer; transition: transform .25s var(--ease);
}
.contact .wpcf7 input[type=submit]:hover { transform: translateY(-2px); }

/* ---------- Pixeom static form (CF7差し替え前) ---------- */
.pixeom-form { display: flex; flex-direction: column; gap: 1.1rem; }
.pixeom-form .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.pixeom-form label { display: flex; flex-direction: column; gap: .4rem; }
.pixeom-form label span { color: rgba(255,255,255,.85); font-size: .85rem; font-family: var(--f-display); font-weight: 500; }
.pixeom-form label span i { color: var(--c-accent-2); font-style: normal; margin-left: .25rem; }
.pixeom-form input, .pixeom-form textarea {
  width: 100%; padding: .85rem 1rem; border: 1px solid rgba(255,255,255,.18); border-radius: 11px;
  background: rgba(255,255,255,.05); color: #fff; font-family: var(--f-body); font-size: 1rem;
  transition: border-color .25s var(--ease), background .25s var(--ease);
}
.pixeom-form input::placeholder, .pixeom-form textarea::placeholder { color: rgba(255,255,255,.4); }
.pixeom-form input:focus, .pixeom-form textarea:focus { outline: none; border-color: var(--c-accent-2); background: rgba(255,255,255,.08); }
.pixeom-form textarea { resize: vertical; min-height: 120px; }
.pixeom-form .form-submit { align-self: flex-start; margin-top: .4rem; }
@media (max-width: 560px) { .pixeom-form .form-row { grid-template-columns: 1fr; } }

/* ---------- Footer ---------- */
.site-footer { background: var(--c-ink); color: rgba(255,255,255,.7); padding-block: clamp(3rem,6vw,4.5rem); }
.site-footer .brand { color: #fff; }
.footer-grid { display: flex; justify-content: space-between; gap: 2rem; flex-wrap: wrap; }
.footer-nav { display: flex; gap: 1.5rem; flex-wrap: wrap; font-size: .9rem; }
.footer-copy { font-size: .8rem; color: rgba(255,255,255,.45); margin: 0; }
/* フッター下部: プライバシーポリシー＋コピーライト */
.footer-meta { margin-top: 2.5rem; padding-top: 1.25rem; border-top: 1px solid rgba(255,255,255,.12); display: flex; justify-content: space-between; align-items: center; gap: 1rem; flex-wrap: wrap; }
.footer-meta__link { font-size: .82rem; color: rgba(255,255,255,.7); transition: color .25s var(--ease); }
.footer-meta__link:hover { color: #fff; }

/* ---------- Scroll reveal ----------
   プログレッシブエンハンスメント:
   JSが reveal を初期化したときだけ body.js-reveal が付与され、初期非表示になる。
   JS無効・クローラ・撮影ツールではコンテンツは常に表示される。 */
.js-reveal .reveal { opacity: 0; transform: translateY(24px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.js-reveal .reveal.is-visible { opacity: 1; transform: none; }
/* stagger: 子要素を時間差でフェードイン */
.js-reveal [data-stagger] > * { opacity: 0; transform: translateY(16px); transition: opacity .6s var(--ease), transform .6s var(--ease); }
.js-reveal [data-stagger] > *.is-visible { opacity: 1; transform: none; }

/* 登場アニメの3段階化（全部同じ登場＝単調さの解消）。
   reveal(脇役・既存) / reveal--rise(主役カード・画像) / data-stagger(リスト順次)。
   主役だけ移動量と尺を上げ、画面に入った時の"重み"を変える。 */
.js-reveal .reveal--rise { opacity: 0; transform: translateY(40px) scale(.96); transition: opacity .9s var(--ease), transform .9s var(--ease); }
.js-reveal .reveal--rise.is-visible { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  .js-reveal .reveal, .js-reveal .reveal--rise, .js-reveal [data-stagger] > * { opacity: 1; transform: none; transition: none; }
}

/* ---------- ホバー徹底（Benchling級のマイクロインタラクション） ---------- */
/* 経営陣カード */
.member { transition: transform .35s var(--ease); }
.member:hover { transform: translateY(-5px); }
.member:hover .member__photo { box-shadow: 0 24px 48px -24px rgba(0,6,80,.14); }
.member__photo { transition: box-shadow .35s var(--ease); }
/* ニュースカードの画像ズーム */
.news-card__thumb { overflow: hidden; }
.news-card__thumb img { transition: transform .5s var(--ease); }
.news-card:hover .news-card__thumb img { transform: scale(1.05); }
.news-card__title { transition: color .25s var(--ease); }
.news-card:hover .news-card__title { color: var(--c-accent); }
/* フッター・ナビのリンク下線 */
.footer-nav a, .nav a { position: relative; }
.footer-nav a::after { content:""; position:absolute; left:0; right:100%; bottom:-3px; height:1px; background:currentColor; transition: right .3s var(--ease); }
.footer-nav a:hover::after { right:0; }
/* 会社情報の行ハイライト */
.info__row { transition: background .25s var(--ease); border-radius: 6px; }
.info__row:hover { background: var(--c-mist); }
/* 事業カードのアイコン回り込み */
.card { transition: transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease); }
.card:hover .card__icon { background: var(--c-accent); }
.card__icon { transition: background .3s var(--ease); }
/* CTAボタンの矢印は既存。リンク全般のフォーカス可視化 */
a:focus-visible, button:focus-visible { outline: 2px solid var(--c-accent); outline-offset: 3px; border-radius: 4px; }

/* ============================================================
   緩急（リズム）設計 — テンプレ感を壊すための強弱クラス
   各セクションを「同じ強度」で並べないために、余白と見出しに段差をつける。
   色は青基調のまま。多彩化はしない。
   ============================================================ */
/* 強セクション：上下に大きく呼吸させ、見出しも特大に（主役カット） */
.section--lg { padding-block: clamp(4.5rem, 9vw, 8rem); }
.section--lg .section-title { font-size: clamp(2.4rem, 5vw, 4rem); }
/* 弱セクション：詰めて密度を上げ、リズムの谷をつくる */
.section--sm { padding-block: clamp(2.25rem, 4vw, 3.25rem); }
/* 濃紺セクションは"密"に寄せて重心をつくる。淡い白セクションとの対比で緩急が出る。 */
.section--dark { padding-block: clamp(3.5rem, 7vw, 6rem); }
/* さらに薄い面（白セクションが連続する単調さを抑える。青系の濃淡のみ） */
.section--mist { background: var(--c-mist); }
/* eyebrow に短い罫を添えて"見出しの入り"に意図を持たせる（全部同じ入りを避ける） */
.eyebrow { display: inline-flex; align-items: center; gap: .6rem; }
.eyebrow::before { content: ""; width: 1.6rem; height: 1px; background: currentColor; opacity: .5; }
.section--dark .eyebrow { color: var(--c-on-dark-accent); }

/* ---------- Responsive ---------- */
@media (max-width: 920px) {
  .hero__grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .hero__visual { aspect-ratio: 16/10; }
  /* 1カラムでは見出しを溢れさせない（nowrap はデスクトップ2カラム時のみ有効） */
  .hero h1 .nowrap { white-space: normal; }
  .contrast { grid-template-columns: 1fr; }
  /* 縦並びでは矢印を下向きに。reveal の transform:none と競合しないよう
     文字を隠して疑似要素で「↓」を出す（rotate は is-visible に上書きされるため）。 */
  .contrast__arrow { font-size: 0; line-height: 0; }
  .contrast__arrow::before { content: "\2193"; font-size: 1.8rem; line-height: 1; }
  .split, .contact-wrap { grid-template-columns: 1fr; }
  .approach-grid { grid-template-columns: 1fr; }
  .approach-arrow { padding: .25rem 0; font-size: 0; line-height: 0; }
  .approach-arrow::before { content: "\2193"; font-size: 1.5rem; line-height: 1; }
  .ip-grid { grid-template-columns: 1fr; }
  /* スマホ: 年月(4.25rem) | ドット(1.5rem) | 内容(1fr)。
     縦線はドット列の中心を通す = 4.25rem + 1.5rem/2 = 5rem。 */
  .timeline__item { grid-template-columns: 4.25rem 1.5rem minmax(0, 1fr); gap: 0; align-items: start; }
  .timeline::before { left: 5rem; top: 18px; bottom: 18px; }
  .timeline__dot { left: auto; margin-top: 4px; } /* 年月テキストの1行目と高さを合わせる */
  .timeline__when { font-size: .82rem; line-height: 1.5; }
  /* 内容: 右に切れないよう minmax(0,1fr) のトラック内で確実に折り返す。
     読点・括弧の禁則を効かせ、長語のみ break-word で逃がす。 */
  .timeline__what { font-size: .92rem; padding-left: .6rem; }
  .lang-ja .timeline__what { word-break: normal; line-break: strict; overflow-wrap: break-word; }
  .ui-mock--back { display:none; }
  .split--reverse .split__media { order: 0; }
  .cards, .team, .news-grid { grid-template-columns: 1fr 1fr; }
  /* タブレット以下はナビをハンバーガーに（横並びだと潰れるため） */
  .nav { display: none; }
  .nav.is-open { display: flex; position: fixed; inset: 64px 0 auto 0; flex-direction: column; background: #fff; padding: 1.5rem var(--gutter); box-shadow: 0 20px 40px -20px rgba(0,0,0,.25); gap: 1.25rem; z-index: 60; }
  .nav.is-open a { color: var(--c-ink); }
  .nav-toggle { display: inline-flex; flex-direction: column; gap: 4px; background: none; border: 0; cursor: pointer; padding: 8px; }
  .nav-toggle span { width: 22px; height: 2px; background: var(--c-ink); transition: background .3s; }
}
@media (max-width: 640px) {
  .cards, .team, .news-grid { grid-template-columns: 1fr; }
  .info__row { grid-template-columns: 1fr; gap: .25rem; }
  /* 長い和文見出しがモバイルで最後の1文字だけ孤立しないよう、わずかに縮小＋字間を詰める */
  .lang-ja .section-title { font-size: clamp(1.85rem, 7.2vw, 2.2rem); letter-spacing: -0.04em; }

  /* ============================================================
     スマホ再設計：split の主役ビジュアル化
     PCの「薄水色パネル＋4:3＋装飾ドット」という飾り枠を解除し、
     画像を全幅・角丸・16:10 でベタ置きにする。重い箱→主役カットへ。
     ============================================================ */
  .split__media {
    background: none; padding: 0; aspect-ratio: 16 / 10;
    border-radius: var(--radius-lg); overflow: hidden;
  }
  .split__media::after { display: none; } /* 角の装飾ドットはモバイルで消す（ノイズ削減） */
  .split__media > img,
  .split__media > .psm-diagram,
  .split__media > .rd-glyph,
  .split__media > .hero-viz {
    border-radius: var(--radius-lg);
    box-shadow: 0 24px 50px -30px rgba(0,6,80,.22);
  }
  /* PSM/RD の濃紺ビジュアルは枠なしでも映えるよう、CSS製フォールバック図にだけ背景を残す */
  .split__media--psm:has(.psm-diagram),
  .split__media--rd:has(.rd-glyph) {
    background: linear-gradient(155deg, var(--c-ink), var(--c-navy));
    padding: clamp(1.25rem, 4vw, 2rem); place-items: center;
  }

  /* 画像の順序を「見出し・説明 → 画像」に統一（Business の正しい作法に合わせる）。
     現DOMは [テキスト塊(.reveal)][画像(.split__media)]。
     テキストを先・画像を後に固定し、「説明を読んでから主役画像」の自然な読み順にする。 */
  #technology .split,
  #rd .split { display: flex; flex-direction: column; }
  #technology .split > .reveal:not(.split__media),
  #rd .split > .reveal:not(.split__media) { order: 0; }
  #technology .split__media,
  #rd .split__media { order: 1; margin-top: 1.75rem; }

  /* ============================================================
     What We Do：最初の"問い"で画面を支配させる
     ============================================================ */
  .statement-title { font-size: clamp(2.0rem, 8vw, 2.6rem); }
  /* After カード（PSM・濃紺）を主役として一段持ち上げる */
  .contrast__card--after { box-shadow: 0 30px 64px -28px rgba(0,6,80,.4); }

  /* ============================================================
     ④ Approach：縦積み＋下向き矢印 → 横スワイプ（scroll-snap）
     後半の濃紺の塊が縦に伸びる単調さを「横に動く」体験で破る。
     News カルーセルと演出言語を揃える。JS不要。
     ============================================================ */
  .approach-grid {
    display: flex; grid-template-columns: none;
    gap: 1rem; overflow-x: auto; scroll-snap-type: x mandatory;
    /* container の左右パディングをはみ出して端まで使い、最後のカードの後にも余白を作る */
    margin-inline: calc(var(--gutter) * -1);
    padding: .5rem var(--gutter) 1rem;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .approach-grid::-webkit-scrollbar { display: none; }
  .approach-step {
    flex: 0 0 78%; scroll-snap-align: center;
  }
  .approach-step--after { flex-basis: 82%; } /* 主役は少し大きく */
  .approach-arrow { display: none; } /* 横並びでは矢印は不要 */

  /* ============================================================
     ⑥ Company 経営陣：縦3枚 → 横スワイプ
     ============================================================ */
  .team {
    display: flex; grid-template-columns: none;
    gap: 1rem; overflow-x: auto; scroll-snap-type: x mandatory;
    margin-inline: calc(var(--gutter) * -1);
    padding: .5rem var(--gutter) 1rem;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .team::-webkit-scrollbar { display: none; }
  .member { flex: 0 0 80%; scroll-snap-align: center; }

  /* ============================================================
     ⑦ banner 宣言帯：狭幅で背景画像が右に寄りすぎないよう全面に薄く敷く
     ============================================================ */
  .banner > .container::before {
    inset: 0; opacity: .35;
    mask-image: linear-gradient(180deg, transparent, #000 40%, #000 80%, transparent);
  }
}
