/* =====================================================================
   Front Journal — company.css
   企業ページ（companies/*.html）共通CSSの正本／単一ソース
   ---------------------------------------------------------------------
   ■ 使い方：<head> 内の tokens.css の直後に1行追加
     <link rel="stylesheet" href="/assets/css/company.css">
   ■ 対象：companies/letara.html, companies/floatmeal.html ほか企業詳細ページ
   ■ 抽出元：letara.html / floatmeal.html のインライン<style>3ブロック（完全一致確認済み）
   ■ 経緯：1083+92+22=1197行のCSSが letara/floatmeal で完全二重化していた
     ものを正本化（2026-06-26）。デザイン変更はこのファイルだけ編集＝両ページに即反映
   ■ TODO：article.css と重複する宣言の整理（Issue #27 続行）／
     企業ページ専用クラス（.easy-banner, .point-banner, .hero, .toc 等）と
     article.css 共通クラスの境界明確化
   ===================================================================== */

/* ===== Block 1: ベース・ヒーロー・本文・企業ページ専用UI ===== */
  /* カラー・スケール・余白は tokens.css の正本を使用（直書き:root廃止・2026-06-24 FJトンマナ統一） */
  * { box-sizing: border-box; }
  html { scroll-behavior: smooth; }
  body {
    margin: 0;
    font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Yu Gothic", Meiryo, sans-serif;
    color: var(--text);
    background: #F4F6F9;
    line-height: 1.80;
    font-size: 16px;
    -webkit-font-smoothing: antialiased;
    letter-spacing: 0.02em;
  }
  body * { font-family: inherit; }
  img { max-width: 100%; display: block; }
  a { color: inherit; text-decoration: none; }

  /* ヘッダー */
  .site-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 48px;
    border-bottom: 1px solid var(--navy-line);
    background: var(--bg);
    position: sticky;
    top: 0;
    z-index: 50;
  }
  .site-header .logo {
    font-size: 16px;
    letter-spacing: 0.12em;
    color: var(--navy);
    font-weight: 700;
  }
  .site-header nav {
    display: flex;
    gap: 32px;
    font-size: 14px;
    letter-spacing: 0.08em;
    color: var(--text-soft);
    font-weight: 500;
  }
  .site-header nav a:hover { color: var(--navy); }

  /* ヒーロー */
  /* 記事サムネイル（キー画像） */
  .article-thumb {
    width: 100%;
    max-width: 920px;
    margin: 0 auto;
    aspect-ratio: 16 / 9;
    overflow: hidden;
  }
  .article-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  /* パンくずリスト */
  .breadcrumb {
    max-width: 1200px;
    margin: 16px auto 0;
    padding: 0 24px;
    font-size: 13px;
    color: var(--text-soft);
    letter-spacing: 0.05em;
  }
  .breadcrumb a { color: var(--text-soft); text-decoration: none; }
  .breadcrumb a:hover { color: var(--navy); text-decoration: underline; }
  .breadcrumb .sep { margin: 0 8px; color: #c8cfdc; }
  .breadcrumb .current { color: var(--navy); font-weight: 700; }

  .hero-thumb { aspect-ratio: 16/9; max-height: 720px; overflow: hidden; background: #FFD93D; width: 100%; }
  .hero-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .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; }
  .hero {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    max-height: 720px;
    overflow: hidden;
    background: var(--navy);
  }
  .hero-img {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, #0f1e3d 0%, #1a3a6e 50%, #047857 100%);
    filter: brightness(0.85) saturate(1);
  }
  .hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(15,30,61,0.3) 0%, rgba(15,30,61,0.85) 100%);
  }
  .hero-content {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 56px;
    padding: 0 64px;
    color: #fff;
  }
  .hero-meta {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    margin-bottom: 24px;
  }
  .hero-meta .tag {
    background: rgba(255,255,255,0.15);
    border: 1px solid rgba(255,255,255,0.45);
    padding: 8px 18px;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.15em;
  }
  .hero h1 {
    font-size: 34px;
    line-height: 1.3;
    margin: 0 0 14px;
    font-weight: 900;
    letter-spacing: 0.02em;
  }
  .hero .en {
    font-size: 16px;
    opacity: 0.78;
    margin-bottom: 20px;
    letter-spacing: 0.18em;
    font-weight: 500;
  }
  .hero .catchcopy {
    font-size: 22px;
    font-weight: 500;
    letter-spacing: 0.05em;
    max-width: 880px;
    line-height: 1.7;
  }

  /* POINT 3バナー：コンテナは解説バナー(article=920px)と幅揃え */
  .points-wrap {
    max-width: 920px;
    margin: var(--section-gap) auto 0;
    padding: 0 24px;
  }
  .points-label {
    font-size: 13px;
    letter-spacing: 0.3em;
    color: var(--navy);
    font-weight: 700;
    margin-bottom: 18px;
    text-align: center;
  }
  .points {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
  }
  .point-card {
    background: var(--bg-blue);
    padding: 32px 24px;
    text-align: center;
  }
  .point-card .key {
    font-size: 22px;
    font-weight: 900;
    color: var(--navy);
    margin: 0 0 14px;
    line-height: 1.5;
    letter-spacing: 0.02em;
  }
  .point-card .desc {
    font-size: 16px;
    color: var(--text-soft);
    line-height: 1.8;
    letter-spacing: 0.03em;
  }

  /* 目次（テキストリンクのみ） */
  .toc-wrap {
    max-width: 920px;
    margin: var(--section-gap) auto 0;
    padding: 0 24px;
  }
  .toc-label {
    font-size: 13px;
    letter-spacing: 0.3em;
    color: var(--navy);
    font-weight: 700;
    margin-bottom: 18px;
  }
  ol.toc {
    margin: 0;
    padding-left: 0;
    list-style: none;
  }
  ol.toc li {
    padding: 6px 0;
    font-size: 16px;
    line-height: 1.7;
    font-weight: 500;
  }
  ol.toc li a {
    color: var(--text);
    transition: color 0.2s;
    text-decoration: none;
    display: inline-block;
  }
  ol.toc li a:hover { color: var(--navy); text-decoration: underline; }
  ol.toc li a::before {
    content: "→ ";
    color: var(--navy);
    margin-right: 4px;
  }

  /* 記事本文 */
  article { max-width: 920px; margin: 0 auto; padding: 8px 24px; }
  article:first-of-type > h2.chapter:first-child { margin-top: 0; }
  article p { font-size: 16px; line-height: 1.80; margin: 0 0 24px; color: var(--text); letter-spacing: 0.03em; }

  /* 章タイトル */
  h2.chapter {
    margin: var(--section-gap) 0 24px;
    padding: 12px 22px;
    background: var(--navy);
    color: #ffffff;
    font-size: 26px;
    line-height: 1.4;
    font-weight: 900;
    letter-spacing: 0.04em;
    border-radius: 4px;
  }
  /* リード見出し（軽量・緑文字・下線なし） */
  h2.lead {
    margin: 18px 0 14px;
    padding: 0;
    background: none;
    color: var(--accent);
    font-size: 22px;
    line-height: 1.45;
    font-weight: 900;
    letter-spacing: 0.02em;
    border: 0;
    border-radius: 0;
  }
  @media (max-width: 720px) {
    h2.lead { font-size: 19px; margin: 14px 0 12px; }
  }
  /* 「解説」バナー（tam-banner流用・ラベル違い・通常文サイズ） */
  .easy-banner {
    position: relative;
    background: var(--bg-blue);
    border: none;
    border-radius: 10px;
    padding: 42px 28px 22px;
    margin: 8px 0 28px;
  }
  .easy-banner::before {
    content: "解説";
    position: absolute;
    top: -1px; left: -1px;
    background: var(--navy);
    color: #fff;
    padding: 6px 16px;
    font-size: 14px;
    font-weight: 900;
    letter-spacing: 0.15em;
    border-radius: 8px 0 8px 0;
  }
  .easy-banner p {
    margin: 0;
    color: var(--text);
    font-size: 16px;
    font-weight: 400;
    line-height: 1.80;
    letter-spacing: 0.03em;
  }

  /* POINTバナー（解説バナーと同型・ラベル「POINT」） */
  .point-banner {
    position: relative;
    background: var(--bg-blue);
    border: none;
    border-radius: 10px;
    padding: 42px 28px 22px;
    margin: 8px 0 16px;
  }
  .point-banner:last-child { margin-bottom: 0; }
  .point-banner::before {
    content: "POINT";
    position: absolute;
    top: -1px; left: -1px;
    background: var(--navy);
    color: #fff;
    padding: 6px 16px;
    font-size: 14px;
    font-weight: 900;
    letter-spacing: 0.18em;
    border-radius: 8px 0 8px 0;
  }
  .point-banner p {
    margin: 0;
    color: var(--text);
    font-size: 16px;
    font-weight: 400;
    line-height: 1.80;
    letter-spacing: 0.03em;
  }
  /* TAMバナー（章3冒頭の市場規模アピール）— 強化版 */
  .tam-banner {
    position: relative;
    background: var(--bg-blue);
    border: none;
    border-radius: 10px;
    padding: 42px 28px 22px;
    margin: 8px 0 28px;
  }
  .tam-banner::before {
    content: "市場規模";
    position: absolute;
    top: -1px; left: -1px;
    background: var(--navy);
    color: #fff;
    padding: 6px 16px;
    font-size: 14px;
    font-weight: 900;
    letter-spacing: 0.15em;
    border-radius: 8px 0 8px 0;
  }
  .tam-banner ul {
    margin: 0; padding-left: 22px;
    color: var(--navy);
  }
  .tam-banner ul li {
    font-size: 16px;
    font-weight: 700;
    line-height: 1.85;
    margin-bottom: 4px;
  }
  .tam-banner ul li:last-child { margin-bottom: 0; }
  .tam-banner small {
    display: block;
    margin-top: 12px;
    color: var(--text-soft);
    font-size: 12px;
    font-weight: 500;
  }
  /* 記事サマリーブロック（パンくず直下） */
  .article-summary {
    max-width: 920px;
    margin: 24px auto 40px;
    padding: 0 24px;
  }
  .article-summary .company-name {
    font-size: 30px;
    font-weight: 900;
    color: var(--navy);
    margin: 0 0 18px;
    line-height: 1.3;
    letter-spacing: 0.02em;
  }
  .article-summary .company-pr {
    font-size: 16px;
    line-height: 1.80;
    color: var(--text);
    margin: 0;
  }
  /* 提供画像のキャプション規約 */
  .provided-caption {
    color: #9ca3af;
    font-size: 13px;
    margin-top: 6px;
    text-align: center;
  }
  /* 章4：事業解説（図解の下に並べる短い行） */
  .biz-line {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    padding: 10px 0;
    border-bottom: 1px solid var(--navy-line);
    font-size: 16px;
    line-height: 1.7;
  }
  .biz-line:last-child { border-bottom: none; }
  .biz-line .num {
    flex-shrink: 0;
    width: 32px; height: 32px;
    border-radius: 50%;
    background: var(--navy);
    color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-size: 15px; font-weight: 900;
  }
  .biz-line .body { color: var(--text); }
  .biz-line .body strong { color: var(--navy); margin-right: 6px; }
  h3.sub {
    font-size: 24px;
    color: var(--navy);
    margin: 32px 0 14px;
    font-weight: 700;
    letter-spacing: 0.04em;
    padding-left: 14px;
    border-left: 4px solid var(--navy);
  }

  /* 章/小見出し直下のイントロ */
  .intro {
    font-size: 16px;
    line-height: 1.80;
    color: var(--text);
    margin: 0 0 24px;
    letter-spacing: 0.03em;
  }

  /* 事業リスト（ハイライト箱と同じ形式） */
  .biz-list {
    margin: 28px 0 36px;
    padding: 0;
    list-style: none;
  }
  .biz-list > li {
    margin-bottom: 20px;
    padding: 32px 36px;
    background: var(--bg-blue);
    border-radius: 4px;
  }
  .biz-list > li:last-child { margin-bottom: 0; }
  .biz-list > li .biz-name {
    font-size: 22px;
    font-weight: 700;
    color: var(--navy);
    margin: 0 0 18px;
    letter-spacing: 0.02em;
  }
  .biz-section-label {
    font-size: 15px;
    font-weight: 700;
    color: var(--navy);
    margin: 18px 0 8px;
    letter-spacing: 0.04em;
  }
  .biz-bullets {
    margin: 0 0 6px;
    padding-left: 22px;
  }
  .biz-bullets li {
    font-size: 16px;
    color: var(--text);
    line-height: 1.80;
    margin-bottom: 10px;
  }
  .biz-bullets li:last-child { margin-bottom: 0; }

  /* 図解プレースホルダー（自然な高さ・左罫線なし） */
  .figure-block {
    background: var(--bg-blue);
    padding: 40px 28px;
    margin: 28px 0 36px;
    color: var(--navy);
    font-weight: 700;
    letter-spacing: 0.06em;
    font-size: 22px;
    line-height: 1.7;
    text-align: center;
  }
  .figure-block .desc {
    display: block;
    margin-top: 14px;
    font-size: 16px;
    font-weight: 500;
    color: var(--text-soft);
    letter-spacing: 0.03em;
    line-height: 1.8;
  }

  /* 写真エリア（16:9） */
  figure {
    margin: 24px 0;
  }
  figure .img-wrap {
    width: 100%;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background: var(--bg-soft);
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    box-shadow: 0 2px 12px rgba(15,30,61,0.06);
  }
  /* 重要キーワードマーカー */
  .mk {
    background: linear-gradient(transparent 60%, #e8f5fc 60%);
    padding: 0 2px;
  }
  figure .img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  figure figcaption {
    font-size: 13px;
    color: var(--muted);
    margin-top: 12px;
    text-align: center;
    letter-spacing: 0.05em;
  }

  /* フルブリード写真（16:9） */
  .fullbleed {
    margin: 40px calc(50% - 50vw);
    width: 100vw;
    aspect-ratio: 16 / 9;
    max-height: 540px;
    overflow: hidden;
    background: var(--navy);
    position: relative;
  }
  .fullbleed img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.88;
  }

  /* ハイライト箱 */
  .highlight {
    background: var(--bg-blue);
    padding: 32px 36px;
    margin: 28px 0;
    border-radius: 4px;
  }
  .highlight .label {
    font-size: 13px;
    letter-spacing: 0.25em;
    color: var(--navy);
    font-weight: 700;
    margin-bottom: 14px;
  }
  .highlight ul {
    margin: 0;
    padding-left: 22px;
  }
  .highlight ul li {
    font-size: 16px;
    color: var(--text);
    line-height: 1.80;
    margin-bottom: 10px;
  }
  .highlight ul li:last-child { margin-bottom: 0; }

  /* データテーブル */
  .data-table {
    width: 100%;
    border-collapse: collapse;
    margin: 36px 0;
    font-size: 16px;
  }
  .data-table th,
  .data-table td {
    padding: 16px 18px;
    text-align: left;
    border-bottom: 1px solid var(--navy-line);
  }
  .data-table th {
    background: var(--bg-blue-dark);
    color: var(--navy);
    font-weight: 700;
    letter-spacing: 0.05em;
    font-size: 15px;
  }
  .data-table td.num {
    font-weight: 700;
    color: var(--navy);
  }

  /* ビフォー／アフター（縦配置） */
  .ba {
    display: grid;
    grid-template-columns: 1fr;
    gap: 18px;
    margin: 36px 0;
    position: relative;
  }
  .ba-arrow {
    text-align: center;
    color: var(--navy);
    font-size: 28px;
    font-weight: 700;
    line-height: 1;
    margin: 4px 0;
  }
  .ba-card {
    padding: 32px 28px;
    border: 1px solid var(--navy-line);
    border-radius: 4px;
    background: #fff;
  }
  .ba-card .label {
    font-size: 12px;
    letter-spacing: 0.3em;
    margin-bottom: 14px;
    font-weight: 700;
    color: var(--navy);
  }
  .ba-after {
    background: var(--bg-blue);
    border-color: var(--navy);
  }
  .ba-card strong {
    display: block;
    font-size: 16px;
    margin-bottom: 14px;
    font-weight: 700;
    color: var(--navy);
  }
  .ba-card ul {
    margin: 0;
    padding-left: 20px;
    font-size: 15px;
    line-height: 1.80;
    color: var(--text);
  }
  .ba-card li {
    margin-bottom: 6px;
  }

  /* 事業カード */
  .biz-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
    margin: 32px 0;
  }
  .biz-card {
    padding: 28px 32px;
    background: var(--bg-soft);
    border-radius: 4px;
  }
  .biz-card .label {
    font-size: 12px;
    letter-spacing: 0.3em;
    color: var(--navy);
    font-weight: 700;
    margin-bottom: 8px;
  }
  .biz-card h4 {
    margin: 0 0 12px;
    font-size: 22px;
    font-weight: 700;
    color: var(--text);
    letter-spacing: 0.02em;
  }
  .biz-card p {
    font-size: 16px;
    color: var(--text);
    margin: 0;
    line-height: 1.9;
  }

  /* 会社概要テーブル */
  .company-info-wrap {
    max-width: 920px;
    margin: var(--section-gap) auto 0;
    padding: 0 24px;
  }
  .company-info-label {
    display: inline-block;
    font-size: 26px;
    background: var(--navy);
    color: #ffffff;
    font-weight: 900;
    padding: 12px 22px;
    margin-bottom: 28px;
    letter-spacing: 0.04em;
    border-radius: 4px;
  }
  .company-info-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 16px;
  }
  .company-info-table th,
  .company-info-table td {
    padding: 18px 24px;
    text-align: left;
    border-bottom: 1px solid var(--navy-line);
    vertical-align: top;
    line-height: 1.9;
  }
  .company-info-table th {
    background: var(--bg-soft);
    color: var(--navy);
    font-weight: 700;
    width: 160px;
    letter-spacing: 0.05em;
  }

  /* 採用情報カード */
  .careers-wrap {
    max-width: 1080px;
    margin: var(--section-gap) auto 0;
    padding: 0 24px;
  }
  .careers-label {
    font-size: 32px;
    color: var(--navy);
    font-weight: 900;
    margin-bottom: 8px;
    letter-spacing: 0.04em;
  }
  .careers-sub {
    font-size: 15px;
    color: var(--text);
    margin-bottom: 28px;
    letter-spacing: 0.05em;
  }
  .careers {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
  }
  .career-card {
    background: #fff;
    border: 1px solid var(--navy-line);
    padding: 28px 24px;
    transition: all 0.2s;
    text-align: left;
  }
  .career-card:hover {
    border-color: var(--navy);
    transform: translateY(-2px);
  }
  .career-card .cat {
    font-size: 12px;
    color: var(--navy);
    font-weight: 700;
    letter-spacing: 0.2em;
    margin-bottom: 12px;
  }
  .career-card .ttl {
    font-size: 19px;
    font-weight: 700;
    color: var(--text);
    margin: 0 0 16px;
    line-height: 1.5;
    letter-spacing: 0.02em;
  }
  .career-card .arrow {
    font-size: 13px;
    color: var(--navy);
    font-weight: 700;
    letter-spacing: 0.1em;
  }

  /* CTA */
  .cta {
    background: var(--navy);
    color: #fff;
    text-align: center;
    padding: 88px 32px;
    margin-top: var(--section-gap);
  }
  .cta h3 {
    font-size: 32px;
    font-weight: 700;
    margin: 0 0 18px;
    letter-spacing: 0.05em;
    line-height: 1.7;
  }
  .cta p {
    font-size: 15px;
    opacity: 0.85;
    margin: 0 0 32px;
    letter-spacing: 0.05em;
  }
  .cta-buttons {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
  }
  .btn {
    display: inline-block;
    padding: 16px 40px;
    font-size: 14px;
    letter-spacing: 0.2em;
    font-weight: 700;
    text-decoration: none;
    transition: all 0.2s;
    border: 1.5px solid #fff;
    border-radius: 2px;
  }
  .btn-primary { background: #fff; color: var(--navy); }
  .btn-primary:hover { background: transparent; color: #fff; }
  .btn-outline { background: transparent; color: #fff; }
  .btn-outline:hover { background: #fff; color: var(--navy); }

  footer {
    padding: 40px 48px;
    background: var(--bg);
    font-size: 13px;
    color: var(--muted);
    text-align: center;
    border-top: 1px solid var(--navy-line);
    line-height: 2;
  }
  footer a { color: var(--navy); }

  /* ===== カード化レイアウト ===== */
  body { background: var(--bg-soft); }
  .article-thumb { max-width: 1280px; margin: 24px auto 0; border-radius: 10px; box-shadow: 0 2px 10px rgba(15,30,61,0.08); }
  /* カードグループラッパー */
  .card-wrap {
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 2px 10px rgba(15,30,61,0.06);
    padding: 36px 48px;
    margin: 20px auto;
    max-width: 1280px;
  }
  /* カード内の子要素の余白整理 */
  .card-wrap > .article-summary,
  .card-wrap > .points-wrap,
  .card-wrap > article,
  .card-wrap > .company-info-wrap {
    background: transparent !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 auto !important;
    max-width: none !important;
  }
  .card-wrap > * + * { margin-top: 32px !important; }
  .card-wrap > article > h2.chapter:first-child,
  .card-wrap > .company-info-wrap > h2.chapter:first-child,
  .card-wrap > article:first-child > h2.chapter:first-child { margin-top: 0; }
  .card-wrap > *:last-child > *:last-child { margin-bottom: 0; }
  /* 見出し前の余白を広げる */
  .card-wrap article h2.chapter { margin-top: 56px !important; }
  .card-wrap article h2.chapter:first-child,
  .card-wrap article > h2.chapter:first-of-type:first-child { margin-top: 0 !important; }
  .card-wrap article h3.sub { margin-top: 56px !important; }
  .card-wrap article h3.sub + p { margin-top: 0; }
  .card-wrap article p + h3.sub,
  .card-wrap article .easy-banner + h3.sub { margin-top: 56px !important; }
  /* ===== /カード化レイアウト ===== */

  @media (max-width: 768px) {
    body { font-size: 16px; }
    .card-wrap { padding: 24px 20px !important; margin: 14px 16px; }
    .site-header { padding: 14px 20px; }
    .site-header nav { display: none; }
    .hero-content { padding: 0 24px; bottom: 28px; }
    .hero h1 { font-size: 32px; }
    .hero .catchcopy { font-size: 15px; }
    .hero .en { font-size: 13px; }
    .points { grid-template-columns: 1fr 1fr; }
    .point-card .key { font-size: 16px; }
    .toc-wrap { margin-top: 40px; }
    article { padding: 48px 20px; }
    article p { font-size: 16px; }
    h2.chapter { margin: 60px 0 24px; font-size: 28px; padding-top: 16px; }
    h3.sub { font-size: 19px; }
    .figure-block { font-size: 16px; padding: 28px 20px; }
    .figure-block .desc { font-size: 13px; }
    .ba { grid-template-columns: 1fr; }
    .company-info-table th { width: 110px; padding: 14px 12px; }
    .company-info-table td { padding: 14px 12px; }
    .company-info-label { font-size: 24px; }
    .careers { grid-template-columns: 1fr 1fr; }
    .careers-label { font-size: 24px; }
    .cta { padding: 60px 24px; }
    .cta h3 { font-size: 22px; }
    .data-table { font-size: 13px; }
    .data-table th, .data-table td { padding: 12px 10px; }
    .biz-card h4 { font-size: 16px; }
    .biz-card p { font-size: 14px; }
    .highlight ul li { font-size: 15px; }
  }

  /* 関連求人セクション */
  .related-jobs-wrap { max-width: 920px; margin: 30px auto; padding: 0 24px; }
  .related-jobs-label {
    font-size: 22px; font-weight: 900; color: var(--navy);
    margin-bottom: 6px; letter-spacing: 0.02em;
  }
  .related-jobs-sub {
    font-size: 13px; color: var(--text-soft);
    margin-bottom: 20px; letter-spacing: 0.04em;
  }
  .related-jobs-list { display: flex; flex-direction: column; gap: 12px; }
  .job-item {
    background: #ffffff; border-radius: 12px;
    padding: 24px 28px;
    box-shadow: 0 2px 8px rgba(15,30,61,0.06);
    display: block; position: relative;
    transition: transform .2s ease, box-shadow .2s ease;
    color: inherit; text-decoration: none;
  }
  .job-item:hover { transform: translateY(-2px); box-shadow: 0 4px 16px rgba(15,30,61,0.10); }
  .job-updated {
    position: absolute; top: 14px; right: 18px;
    font-size: 11px; color: var(--muted);
    font-weight: 500; letter-spacing: 0.02em;
  }
  .job-company {
    font-size: 13px; font-weight: 700; color: #059669;
    letter-spacing: 0.02em; margin-bottom: 6px;
  }
  .job-title {
    font-size: 19px; font-weight: 900; color: var(--navy);
    line-height: 1.6; letter-spacing: 0.01em; margin: 0 0 8px;
  }
  .job-meta { display: flex; gap: 14px; font-size: 13px; color: var(--text-soft); }
  .related-jobs-more {
    display: inline-block; margin-top: 18px;
    font-size: 13px; font-weight: 700; color: var(--navy);
    letter-spacing: 0.05em;
  }
  .related-jobs-more:hover { text-decoration: underline; }
  @media (max-width: 768px) {
    .related-jobs-wrap { padding: 0 18px; margin: 20px auto; }
    .job-title { font-size: 16px; }
    .job-item { padding: 18px 20px; }
  }

  /* 関連求人セクション v3：TOPヒーローと同じ研究室画像＋navy×green オーバーレイ */
  .jobs-cta {
    position: relative;
    color: #fff;
    padding: 56px 32px;
    margin-top: 40px;
    background-image: url("/assets/about/260528_about_lab.jpg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    overflow: hidden;
  }
  .jobs-cta::before {
    content: ""; position: absolute; inset: 0;
    background:
      linear-gradient(135deg, rgba(15,30,61,0.82) 0%, rgba(5,150,105,0.22) 100%),
      rgba(15,30,61,0.65);
    pointer-events: none;
  }
  .jobs-cta > * { position: relative; z-index: 1; }
  .jobs-cta-inner {
    max-width: 920px;
    margin: 0 auto;
  }
  .jobs-cta h2 {
    font-size: 28px;
    font-weight: 900;
    margin: 0 0 10px;
    letter-spacing: 0.04em;
    text-align: center;
    line-height: 1.5;
  }
  .jobs-cta .lead {
    font-size: 14px;
    opacity: 0.92;
    margin: 0 0 28px;
    text-align: center;
    letter-spacing: 0.04em;
  }
  .jobs-cta .related-jobs-list {
    display: flex; flex-direction: column; gap: 12px;
    margin-bottom: 24px;
  }
  .jobs-cta .job-item {
    background: #ffffff; border-radius: 10px;
    padding: 22px 26px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
    display: block; position: relative;
    transition: transform .2s ease, box-shadow .2s ease;
    color: inherit; text-decoration: none;
  }
  .jobs-cta .job-item:hover { transform: translateY(-2px); box-shadow: 0 4px 16px rgba(0,0,0,0.20); }
  .jobs-cta .job-updated {
    position: absolute; top: 12px; right: 18px;
    font-size: 11px; color: var(--muted);
    font-weight: 500; letter-spacing: 0.02em;
  }
  .jobs-cta .job-company {
    font-size: 12px; font-weight: 700; color: #047857;
    letter-spacing: 0.04em; margin-bottom: 6px;
  }
  .jobs-cta .job-title {
    font-size: 16px; font-weight: 900; color: var(--navy);
    line-height: 1.55; letter-spacing: 0.01em; margin: 0 0 6px;
  }
  .jobs-cta .job-meta { display: flex; gap: 14px; font-size: 12px; color: var(--text-soft); }
  .jobs-cta-actions {
    text-align: center; margin-top: 28px;
  }
  .jobs-cta-actions a {
    display: inline-block;
    padding: 14px 32px;
    background: #ffffff;
    color: #047857;
    border-radius: 999px;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-decoration: none;
    transition: opacity .2s ease;
    margin: 0 6px;
  }
  .jobs-cta-actions a:hover { opacity: 0.88; }
  .jobs-cta-actions a.outline {
    background: transparent;
    color: #ffffff;
    border: 1.5px solid #ffffff;
  }
  @media (max-width: 768px) {
    .jobs-cta { padding: 40px 20px; }
    .jobs-cta h2 { font-size: 22px; }
    .jobs-cta .job-title { font-size: 16px; }
    .jobs-cta .job-item { padding: 18px 20px; }
    .jobs-cta-actions a { display: block; margin: 8px auto; max-width: 260px; }
  }

  /* ===== v1.14: Material Symbols ＋ カード型 ＋ 解説バナー ===== */
  .material-symbols-outlined {
    font-family: 'Material Symbols Outlined' !important;
    font-weight: normal !important;
    font-style: normal !important;
    line-height: 1;
    letter-spacing: normal;
    text-transform: none;
    display: inline-block;
    white-space: nowrap;
    word-wrap: normal;
    direction: ltr;
    font-feature-settings: 'liga';
    -webkit-font-feature-settings: 'liga';
    -webkit-font-smoothing: antialiased;
    font-variation-settings: 'FILL' 0, 'wght' 500, 'GRAD' 0, 'opsz' 24;
    vertical-align: -5px;
  }
  .card-grid { display: grid; gap: 16px; margin: 16px 0 28px; grid-template-columns: repeat(3, 1fr); }
  .card-grid.cols-2 { grid-template-columns: repeat(2, 1fr); }
  .ic-card { background: #fff; border: 2px solid var(--accent); border-radius: 14px; padding: 22px 24px; }
  .ic-card .ic-header { display: flex; align-items: center; gap: 14px; margin-bottom: 12px; }
  .ic-card .ic-circle { width: 44px; height: 44px; border-radius: 999px; background: var(--accent); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
  .ic-card .ic-circle .material-symbols-outlined { font-size: 24px; color: #fff; font-variation-settings: 'FILL' 0, 'wght' 600, 'GRAD' 0, 'opsz' 24; margin: 0; vertical-align: 0; }
  .ic-card h4 { font-size: 19px; font-weight: 900; color: var(--accent); margin: 0; letter-spacing: 0.02em; line-height: 1.3; }
  .ic-card p { font-size: 16px; line-height: 1.80; color: var(--text); margin: 0; letter-spacing: 0.02em; }
  .v13-points { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin: 18px 0 8px; }
  .v13-point { background: #fff; border: 2px solid var(--accent); border-radius: 14px; padding: 22px 24px; text-align: left; }
  .v13-point .v13-header { display: flex; align-items: center; gap: 14px; margin-bottom: 12px; }
  .v13-point .badge { width: 44px; height: 44px; border-radius: 999px; background: var(--accent); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
  .v13-point .badge .material-symbols-outlined { font-size: 24px; color: #fff; font-variation-settings: 'FILL' 0, 'wght' 600, 'GRAD' 0, 'opsz' 24; vertical-align: 0; margin: 0; }
  .v13-point .label { font-size: 19px; font-weight: 900; color: var(--accent); letter-spacing: 0.02em; line-height: 1.3; margin: 0; }
  .v13-point .body { margin: 0; font-size: 16px; line-height: 1.80; color: var(--text); letter-spacing: 0.02em; }
  .explainer { position: relative; background: var(--bg-blue); border-radius: 10px; padding: 64px 24px 22px; margin: 24px 0 32px; }
  .explainer::before { content: "FrontJournalの解説"; position: absolute; top: -1px; left: -1px; background: var(--navy) url("/assets/icons/fj_explainer_idea.svg") no-repeat 14px 50%; background-size: 22px 22px; color: #fff; padding: 10px 22px 10px 46px; font-size: 16px; font-weight: 900; letter-spacing: 0.06em; line-height: 1.4; border-radius: 8px 0 8px 0; }
  .explainer dl { margin: 0; padding: 0; }
  .explainer dt { font-weight: 900; color: var(--navy); font-size: 16px; margin-top: 16px; letter-spacing: 0.02em; line-height: 1.6; }
  .explainer dt:first-child { margin-top: 0; }
  .explainer dd { margin: 6px 0 0 0; color: var(--text); font-size: 16px; line-height: 1.80; letter-spacing: 0.02em; }
  @media (max-width: 768px) {
    .card-grid, .card-grid.cols-2, .v13-points { grid-template-columns: 1fr; }
    .ic-card, .v13-point { padding: 18px 20px; border-radius: 12px; }
    .ic-card .ic-circle, .v13-point .badge { width: 40px; height: 40px; }
    .ic-card .ic-circle .material-symbols-outlined, .v13-point .badge .material-symbols-outlined { font-size: 22px; }
    .ic-card h4, .v13-point .label { font-size: 16px; }
    .ic-card p, .v13-point .body { font-size: 16px; line-height: 1.80; }
    .explainer { padding: 56px 18px 18px; }
    .explainer dt, .explainer dd { font-size: 15px; }
    .explainer::before { font-size: 14px; padding: 8px 16px 8px 40px; background-size: 20px 20px; background-position: 12px 50%; }
  }
  /* ===== /v1.14 ===== */

/* ===== Block 2: グローバルヘッダー/フッター（global-chrome-overrides） ===== */
/* === Global Header / Footer Override（TOP統一版） === */
.site-header {
  display: flex !important; justify-content: space-between; align-items: center;
  padding: 16px 40px !important;
  background: rgba(255,255,255,0.92) !important;
  backdrop-filter: saturate(180%) blur(12px);
  -webkit-backdrop-filter: saturate(180%) blur(12px);
  box-shadow: 0 2px 6px rgba(15,30,61,0.06), 0 1px 2px rgba(15,30,61,0.04) !important;
  position: sticky !important; top: 0 !important; z-index: 50 !important;
  border-bottom: none !important;
}
.site-header .header-inner { display: contents; }
.site-header .logo a, .site-header .site-logo { display: inline-flex; align-items: center; }
.site-header .logo img, .site-header .site-logo img { height: 50px !important; width: auto !important; display: block; }
.site-header nav { display: flex !important; gap: 26px; font-size: 13px; letter-spacing: 0.08em; color: #4a5363; font-weight: 500; align-items: center; }
.site-header nav ul { list-style: none; display: flex; gap: 26px; margin: 0; padding: 0; align-items: center; }
.site-header nav a { color: #4a5363; text-decoration: none; font-size: 13px; font-weight: 500; letter-spacing: 0.08em; }
.site-header nav a:hover { color: #0f1e3d; }
.site-header nav a.active { color: #0f1e3d; font-weight: 700; }
.site-header nav a.nav-cta {
  background: #0f1e3d; color: #fff !important;
  padding: 6px 16px; border-radius: 999px; font-size: 12px; line-height: 1.6;
  font-weight: 700; letter-spacing: 0.08em;
  transition: background 0.2s ease, transform 0.2s ease;
}
.site-header nav a.nav-cta:hover { background: #059669; color: #fff !important; transform: translateY(-1px); }

/* ハンバーガー */
.nav-toggle { display: none; }
.hamburger { display: none; cursor: pointer; width: 36px; height: 36px; position: relative; z-index: 60; }
.hamburger span { position: absolute; left: 6px; width: 24px; height: 2px; background: #0f1e3d; border-radius: 1px; transition: transform 0.25s ease, opacity 0.2s ease, top 0.25s ease; }
.hamburger span:nth-child(1) { top: 11px; }
.hamburger span:nth-child(2) { top: 17px; }
.hamburger span:nth-child(3) { top: 23px; }
.nav-toggle:checked ~ .hamburger span:nth-child(1) { top: 17px; transform: rotate(45deg); }
.nav-toggle:checked ~ .hamburger span:nth-child(2) { opacity: 0; }
.nav-toggle:checked ~ .hamburger span:nth-child(3) { top: 17px; transform: rotate(-45deg); }

@media (max-width: 768px) {
  .hamburger { display: block; }
  .site-header nav {
    display: flex !important;
    position: fixed; top: 0; right: -100%; height: 100vh; width: min(82vw, 320px);
    background: #fff; flex-direction: column; align-items: flex-start;
    padding: 80px 28px 32px; gap: 4px; box-shadow: -8px 0 32px rgba(15,30,61,0.18);
    transition: right 0.3s ease; z-index: 55; overflow-y: auto;
  }
  .site-header nav ul { flex-direction: column; gap: 0; width: 100%; align-items: flex-start; }
  .site-header nav ul li { width: 100%; }
  .nav-toggle:checked ~ nav { right: 0; }
  .site-header nav a { width: 100%; padding: 14px 12px; font-size: 15px; border-bottom: 1px solid #eef1f6; letter-spacing: 0.06em; }
  .site-header nav a:last-child { border-bottom: none; }
  .site-header nav a.nav-cta {
    background: #0f1e3d; color: #fff !important;
    padding: 14px 18px; margin-top: 12px; text-align: center;
    border-bottom: none !important; border-radius: 999px;
  }
  body.nav-open { overflow: hidden; }
}
@media (max-width: 600px) {
  .site-header { padding: 14px 18px !important; }
}

/* フッター */
footer.site-footer, .site-footer {
  background: #0f1e3d !important; color: #fff !important; padding: 48px 48px 24px !important;
  margin-top: 40px;
}
.site-footer .footer-inner {
  max-width: 1180px !important; margin: 0 auto !important;
  display: flex !important; justify-content: space-between !important; align-items: center !important;
  flex-wrap: wrap; gap: 24px; text-align: left !important;
}
.site-footer .footer-brand img { height: 56px; width: auto; display: block; }
.site-footer .footer-links { display: flex !important; gap: 28px; flex-wrap: wrap; }
.site-footer .footer-links a { color: #fff !important; text-decoration: none; font-size: 13px; opacity: 0.8; letter-spacing: 0.06em; transition: opacity 0.2s ease; }
.site-footer .footer-links a:hover { opacity: 1; color: #7adfb3 !important; }
.site-footer .footer-bottom {
  max-width: 1180px; margin: 32px auto 0 !important; padding-top: 20px;
  border-top: 1px solid rgba(255,255,255,0.1);
  font-size: 12px; opacity: 0.6; letter-spacing: 0.05em; text-align: center !important;
  color: #fff !important;
}
@media (max-width: 900px) {
  .site-footer .footer-inner { flex-direction: column; text-align: center !important; gap: 20px; }
  .site-footer .footer-links { justify-content: center; }
}
@media (max-width: 600px) {
  footer.site-footer, .site-footer { padding: 48px 20px 16px !important; }
}

/* ===== Block 3: article構造の!important上書き（card-wrap/h2.chapter/breadcrumb等） ===== */
.fig-inline{margin:20px 0 30px}.fig-inline img{width:100%;height:auto;display:block;border-radius:10px}
.card-wrap{max-width:920px!important;padding:36px 40px!important;margin:60px auto!important;box-shadow:0 4px 16px rgba(15,30,61,.10)!important}
.article-thumb + .card-wrap{margin-top:18px!important}
h2.chapter{margin:72px 0 12px!important;padding:14px 22px!important;background:var(--navy)!important;color:#fff!important;font-size:26px!important;line-height:1.4!important;font-weight:900!important;letter-spacing:.04em!important;border-radius:4px!important}
.card-wrap > article > h2.chapter:first-of-type:first-child,.card-wrap > .company-info-wrap > h2.chapter:first-of-type:first-child{margin:-36px -40px 16px!important;border-radius:10px 10px 0 0!important;padding:18px 40px!important}
h3.sub{font-size:24px!important;color:var(--accent)!important;margin:32px 0 14px!important;font-weight:700!important;letter-spacing:.04em!important;line-height:1.45!important;border-left:none!important;padding-left:0!important}
.card-wrap article :is(p, ul, table, div, figure) + h3.sub{border-top:1px solid var(--navy-line)!important;padding-top: 20px!important;margin-top:40px!important}
.breadcrumb{max-width:920px!important;margin:0 auto!important;padding:20px 24px 0!important;font-size:12px!important;color:var(--text-soft)!important;letter-spacing:.06em!important}
.breadcrumb .sep{margin:0 8px!important;color:var(--muted)!important}.breadcrumb .current{color:var(--navy)!important;font-weight:700!important}
.article-thumb{max-width:920px!important;margin:24px auto 0!important;padding:0!important;background:none!important;border:none!important}
.article-thumb img{width:100%!important;height:auto!important;aspect-ratio:16/9!important;object-fit:cover!important;display:block!important;border-radius:10px!important;box-shadow:0 2px 10px rgba(15,30,61,.08)!important}
.article-title{font-size:34px!important;font-weight:900!important;color:var(--navy)!important;margin:0 0 16px!important;line-height:1.4!important}
.intro{font-size: 16px;line-height: 1.80;color:var(--text);margin:0 0 24px}
.takeaway-box{background:var(--bg-blue);border-radius:10px;padding:0 28px 22px;margin:36px 0 28px;overflow:hidden}
.takeaway-box .label{display:inline-flex;align-items:center;background:var(--navy);color:#fff;padding:8px 20px;font-size:16px;font-weight:900;letter-spacing:.08em;border-radius:8px 0 8px 0;margin:0 0 16px -28px}
.takeaway-box ul{padding-left:22px;margin:6px 0 0}.takeaway-box li{font-size: 16px;line-height:1.8;padding:4px 0;color:var(--text)}
.takeaway-box li::marker{color:var(--accent)}
.takeaway-box li{padding:8px 0}
.takeaway-box li strong{display:block;color:var(--navy);font-weight:900}
.takeaway-box li .gd{display:block;padding-left:1.3em;margin-top:2px;color:var(--text)}
