/*
Theme Name: Canvas M&F
Theme URI: https://canvas-jp.co.jp/
Author: Hisanori Nakagami
Author URI: https://canvas-jp.co.jp/
Description: Canvas M&F公式リユースサイト用テーマ（公式リユース特化／Header・Footer分割）
Version: 1.1
License: GNU General Public License v2 or later
Text Domain: canvas-mf
*/

:root{
  --bg:#f7f8fb;--surface:#ffffff;--ink:#0f1e16;--muted:#5a6b63;--brand:#167a5a;--brand-2:#0e3c2e;--accent:#ff7a2c;--line:rgba(20,30,40,.12);
  --green-soft:#e7f6ef;--red-soft:#ffe9ea;--mint:#e9fbf4;
  --radius:18px;--shadow:0 10px 24px rgba(16,24,40,.08);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font:16px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Hiragino Kaku Gothic ProN","Hiragino Sans",Meiryo,"Noto Sans JP",sans-serif}
a{color:var(--brand);text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 20px}
header.site{position:sticky;top:0;z-index:20;background:#fff;border-bottom:1px solid var(--line)}
.site__inner{display:flex;align-items:center;justify-content:space-between;gap:12px;height:64px}
.logo{font-weight:800;letter-spacing:.02em;font-size:20px}
.logo b{color:var(--brand)}
nav ul{display:flex;gap:18px;list-style:none;margin:0;padding:0}
nav a{color:#1c2b24;font-weight:600}
.cta-mini{display:inline-flex;align-items:center;gap:10px;background:var(--brand);color:#fff;padding:10px 14px;border-radius:12px}
.hero{background:linear-gradient(180deg,#ffffff, var(--bg));border-bottom:1px solid var(--line)}
.hero__in{padding:48px 0;display:grid;grid-template-columns:1.1fr .9fr;gap:28px}
.eyebrow{color:#617186;font-size:14px;letter-spacing:.08em}
h1{font-size:40px;line-height:1.2;margin:.2em 0 .4em}
.lead{color:var(--muted);font-size:18px}
.btns{display:flex;gap:14px;flex-wrap:wrap;margin-top:22px}
.btn{display:inline-flex;align-items:center;gap:10px;border-radius:14px;padding:14px 18px;font-weight:700}
.btn--primary{background:var(--brand);color:#fff}
.btn--ghost{border:1px solid var(--line);background:#fff}
.hero__card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:18px}
section{padding:56px 0}
.section-eyebrow{color:#617186;font-size:14px;letter-spacing:.08em;margin:0 0 8px}
.section-title{font-size:28px;font-weight:800;color:var(--brand-2);margin:0 0 20px}
.compare{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.card{border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}
.card--cons{background:var(--red-soft)}
.card--pros{background:var(--green-soft)}
.card__head{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.badge{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;font-weight:800;color:#fff}
.badge--ng{background:#e74c3c}
.badge--ok{background:#158f66}
.list{list-style:none;margin:0;padding:6px 0 0}
.list li{display:flex;gap:12px;align-items:flex-start;padding:10px;border-radius:12px}
.list strong{display:block}
.list small{display:block;opacity:.85}
.list--cons li{color:#b43939}
.list--pros li{color:#0d5b45}
.ic{display:grid;place-items:center;min-width:24px}
.strengths{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.pill{background:#fff;border-radius:16px;padding:16px;box-shadow:var(--shadow)}
.pill h4{margin:4px 0 6px;font-size:16px}
.pill p{margin:0;color:#4a5a68}
.industries{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.industry{background:#fff;border-radius:16px;padding:18px;box-shadow:var(--shadow)}
.industry h5{margin:0 0 6px;font-size:16px}
.industry p{margin:0;color:#4a5a68}
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.step{background:#fff;border-radius:16px;padding:18px;box-shadow:var(--shadow);position:relative}
.step .num{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:50%;display:grid;place-items:center;background:var(--mint);color:#0d5b45;font-weight:800}
.effects{display:grid;grid-template-columns:2fr 1fr;gap:24px}
.effects .grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.effect{background:#fff;border-radius:16px;padding:18px;box-shadow:var(--shadow)}
.chips{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.chip{background:#fff;border-radius:14px;padding:14px;box-shadow:var(--shadow)}
.wasabi{background:#fff;border-radius:16px;box-shadow:var(--shadow);padding:32px;margin:32px 0}
.wasabi h3{margin-top:0;color:var(--brand-2)}
.wasabi p{margin:0 0 12px;color:#4a5a68}
.wasabi .btn-row{margin-top:12px}
.cta{background:#16232a;color:#e6eef0}
.cta .wrap{display:grid;grid-template-columns:1.2fr .8fr;gap:28px;align-items:center}
.cta h3{font-size:26px;margin:0 0 8px}
.cta p{margin:0 0 14px;color:#a8bac2}
.cta .panel{background:#23333b;border:1px solid rgba(255,255,255,.08);padding:18px;border-radius:14px}
footer{background:#0f1a1f;color:#a9b8bf}
footer .cols{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px}
footer h6{color:#e6eef0;margin:0 0 8px}
@media (max-width: 1024px){
  .hero__in{grid-template-columns:1fr}
  .effects{grid-template-columns:1fr}
  .cta .wrap{grid-template-columns:1fr}
}
@media (max-width: 860px){
  nav ul{display:none}
  .compare{grid-template-columns:1fr}
  .strengths{grid-template-columns:1fr 1fr}
  .industries{grid-template-columns:1fr 1fr}
  .process{grid-template-columns:1fr 1fr}
  footer .cols{grid-template-columns:1fr}
}
@media (max-width: 520px){
  .strengths,.industries,.process{grid-template-columns:1fr}
  h1{font-size:32px}
}

/* ==== Header responsive & CTA ==== */
.nav-toggle{display:none;position:relative;width:44px;height:44px;border:0;background:transparent;cursor:pointer}
.nav-toggle span{position:absolute;left:10px;right:10px;height:2px;background:#0f1e16;border-radius:2px;transition:.2s}
.nav-toggle span:nth-child(1){top:14px}
.nav-toggle span:nth-child(2){top:21px}
.nav-toggle span:nth-child(3){top:28px}
.header-cta{display:inline-flex;align-items:center;gap:10px;background:var(--brand);color:#fff;padding:10px 14px;border-radius:12px;margin-left:10px}
.site-nav{display:flex;align-items:center;gap:18px}
.site-nav .menu{display:flex;gap:18px;list-style:none;margin:0;padding:0}

@media (max-width: 860px){
  .nav-toggle{display:block}
  .site-nav{position:absolute;top:64px;right:12px;display:none;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:12px;z-index:30}
  .site-nav.is-open{display:flex}
  .site-nav .menu{flex-direction:column;gap:8px}
  .header-cta{width:100%;justify-content:center;margin:6px 0 0}
}

/* custom logo size */
.custom-logo{max-height:40px;height:auto;width:auto}

/* ==== Dropdown (PC: hover / SP: tap open) ==== */
.site-nav .menu > li{position:relative}
.site-nav .menu .sub-menu{
  position:absolute; top:100%; right:0; min-width:220px;
  background:#fff; border:1px solid var(--line); border-radius:12px;
  box-shadow:var(--shadow); padding:8px 10px; display:none; z-index:40;
}
.site-nav .menu .sub-menu a{display:block; padding:10px 12px; white-space:nowrap}

/* PC: hover で表示 */
@media (min-width:861px){
  .site-nav .menu > li:hover > .sub-menu{display:block}
}

/* SP: クリックで開閉 */
@media (max-width:860px){
  .site-nav .menu .sub-menu{
    position:static; border:0; box-shadow:none; padding:0; margin-left:8px; display:none;
  }
  .site-nav .menu li.open > .sub-menu{display:block}
  .site-nav .menu li.menu-item-has-children > a{position:relative; padding-right:30px}
  .site-nav .menu li.menu-item-has-children > a::after{
    content:"▾"; position:absolute; right:4px; top:50%; transform:translateY(-50%);
    font-size:14px; opacity:.8;
  }
}

.site-nav .menu a .sub-en{display:block; font-size:11px; letter-spacing:.08em; opacity:.65; margin-top:2px}

/* ===== Nav two-line labels (JP + EN) ===== */
.site-nav .menu > li > a{
  position:relative; line-height:1.1; font-weight:700; letter-spacing:.02em;
}
.site-nav .menu > li > a::after{
  content: attr(title);
  display:block;
  font-size:11px; letter-spacing:.08em; opacity:.65;
  margin-top:4px; font-weight:600;
}

/* モバイルは英語サブを非表示&行間ゆったり */
@media (max-width:860px){
  .site-nav .menu > li > a::after{ display:none; }
}

/* ===== Sticky shadow on scroll ===== */
header.site.is-stuck{
  box-shadow: 0 6px 18px rgba(16,24,40,.06);
  background: rgba(255,255,255,.96);
  backdrop-filter: saturate(160%) blur(6px);
}

/* ===== Hero: full-width video background ===== */
.hero--video{ position:relative; overflow:hidden; border-bottom:1px solid var(--line); }
.hero--video .hero-bg{ position:absolute; inset:0; z-index:0; }
.hero--video .hero-video{
  width:100%; height:100%; object-fit:cover; object-position:center;
  display:block; background:#0f1e16;
}
.hero--video .hero-overlay{
  position:absolute; inset:0;
  /* 左を少し濃くしてテキスト可読性UP */
  background:linear-gradient(90deg, rgba(15,30,22,.55) 0%, rgba(15,30,22,.35) 40%, rgba(15,30,22,.15) 65%, rgba(15,30,22,0) 85%);
}
.hero--video .wrap{ position:relative; z-index:1; }
.hero--video .hero__in{
  /* 既存の2カラムを単列に上書き */
  display:flex; align-items:center;
  padding:96px 0; min-height:520px;
}
.hero--video .lead{ color:#e8f0ec; }         /* 動画上で少し明るめ */
.hero--video h1{ color:#eaf6f1; }

/* モバイル */
@media (max-width: 860px){
  .hero--video .hero__in{ padding:72px 0; min-height:420px; }
}

/* Hero の本文幅を制御して読みやすく */
.hero--video .hero__in > div{ max-width: 720px; }       /* 左側のテキスト枠を狭める */
.lead{
  max-width: 52ch;            /* 1行あたり約52文字で折り返す */
  text-wrap: balance;         /* 行の見た目バランスを自動調整（対応ブラウザで有効） */
  line-height: 1.9;
}
@media (max-width: 860px){
  .hero--video .hero__in > div{ max-width: 100%; }
  .lead{ max-width: 100%; }
}
/* ==== Hero: mobile spacing & readability ==== */
@media (max-width: 860px){
  /* 左右の余白をしっかり確保（iPhoneノッチにも対応） */
  .hero--video .wrap{
    padding-left: max(28px, env(safe-area-inset-left, 0px) + 16px);
    padding-right: max(28px, env(safe-area-inset-right, 0px) + 16px);
  }

  /* タイポ調整（大きすぎ問題を緩和） */
  .hero--video h1{
    font-size: clamp(28px, 8.5vw, 36px);
    line-height: 1.25;
  }
  .hero--video .lead{
    font-size: 16px;
    max-width: 38ch;   /* 行幅を短くして読みやすく */
  }

  /* ボタンは縦並びで押しやすく */
  .hero--video .btns{
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
  }
  .hero--video .btn{
    width: 100%;
    justify-content: center;
  }
}
/* 明るい場面での可読性UP */
.hero--video h1,
.hero--video .lead{ text-shadow:0 2px 6px rgba(0,0,0,.18); }

@media (max-width:860px){
  /* モバイルはオーバーレイを少し濃く */
  .hero--video .hero-overlay{
    background:linear-gradient(90deg,
      rgba(15,30,22,.72) 0%,
      rgba(15,30,22,.42) 45%,
      rgba(15,30,22,.18) 70%,
      rgba(15,30,22,0) 85%);
  }
}

/* ===== CONCEPT: 中央寄せ＆カードの均等配置 ===== */

/* セクション中身を中央に寄せる（テキストもカードも） */
.concept--simple .concept__text{
  max-width: 1120px;   /* ラップ幅より少し狭くして左右に余白 */
  margin: 0 auto;      /* 中央寄せ */
}

.concept--simple .concept__list li strong {
  display:block;
  margin-bottom:6px;   /* タイトルと本文の間隔 */
  font-weight:700;
  color:var(--brand-2);
}
.concept--simple .concept__list li {
  line-height:1.6;     /* 本文の行間 */
}


.concept-boxes{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  margin-top:28px;
}
.concept-boxes .box{
  background:#fff;
  border-radius:16px;
  box-shadow:0 6px 18px rgba(0,0,0,.06);
  padding:20px;
  text-align:center;
}
.concept-boxes .icon{
  font-size:32px;
  margin-bottom:12px;
}
.concept-boxes h4{
  font-size:18px;
  margin:0 0 8px;
  color:var(--brand-2);
}
.concept-boxes p{
  margin:0;
  color:#555;
}

/* スマホ表示（768px以下）は1列 */
@media (max-width: 768px){
  .concept-boxes{
    grid-template-columns:1fr;
  }
}

/* ===== 修正版 Compare: Monotone ===== */
.compare--mono .cmp-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}

.compare--mono .cmp-panel{
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  padding:20px;
  box-shadow:0 8px 24px rgba(16,24,40,.06);
}

.compare--mono .cmp-panel--ng{ background:#fafafa; }
.compare--mono .cmp-panel--ok{ background:#f9fbfa; }

.compare--mono .cmp-head{
  display:flex; align-items:center; gap:10px;
  margin-bottom:16px;
}
.compare--mono .cmp-head h3{ margin:0; font-size:20px; }
.compare--mono .cmp-mark{
  width:28px; height:28px;
  border-radius:50%; display:grid; place-items:center;
  font-weight:700; font-size:16px; color:#fff;
}
.compare--mono .cmp-panel--ok .cmp-mark{ background:#3a7d62; }
.compare--mono .cmp-panel--ng .cmp-mark{ background:#b25b5b; }

/* 各 li をカード化 */
.compare--mono .cmp-list{
  list-style:none;
  margin:0; padding:0;
  display:grid;
  gap:14px;
}
.compare--mono .cmp-list li{
  background:#fff;
  border:1px solid rgba(16,24,40,.1);
  border-radius:12px;
  padding:12px 14px;
  line-height:1.5;
}
.compare--mono .cmp-panel--ng .cmp-list li{ background:#fdfdfd; }
.compare--mono .cmp-panel--ok .cmp-list li{ background:#ffffff; }

.compare--mono .cmp-list strong{ display:block; margin-bottom:4px; }
.compare--mono .cmp-list small{ display:block; color:#6b7a72; font-size:14px; }

/* マーク付きのインライン記号を削除 */
.compare--mono .bullet{ display:none; }

/* モバイル時は1カラム */
@media (max-width:860px){
  .compare--mono .cmp-grid{ grid-template-columns:1fr; }
}
/* ===== Compare セクションの中央寄せ ===== */
#compare.compare--mono {
  padding: 60px 0;
  background: #f9fafb; /* 薄いグレー背景（任意） */
}

#compare.compare--mono .wrap {
  max-width: 1120px;      /* 他セクションと揃える */
  margin: 0 auto;
  padding: 0 20px;
}

#compare.compare--mono .section-eyebrow,
#compare.compare--mono .section-title {
  text-align: center;     /* 見出しを中央揃え */
  margin-bottom: 40px;
}

.compare--mono .cmp-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}

@media (max-width: 860px){
  .compare--mono .cmp-grid {
    grid-template-columns: 1fr;
  }
}
/* 1) 旧 .compare のグリッド指定を無効化（このセクションだけ） */
#compare.compare--mono{ display:block; }

/* 2) 見出しを他セクションと同じ左寄せ＋幅も統一 */
#compare.compare--mono .wrap{
  max-width:1180px;   /* .wrap と合わせる */
  margin:0 auto;
  padding:0 20px;
}
#compare.compare--mono .section-eyebrow,
#compare.compare--mono .section-title{
  text-align:left;          /* ← 左寄せに戻す */
  margin:0 0 20px;          /* 共通の余白 */
}
/* フッター直上のセクション（お問い合わせ促進セクション）の背景を暗めに */
.cta {
  background: #141a22; /* 現在の dark セクションより少し明るめのトーン */
}

/* フッター本体は暗さを維持しつつ境界線を追加 */
footer {
  background: #0f1a1f;
  border-top: 1px solid var(--line);
}

/* セクション内容に余白を追加して視覚的余裕を確保 */
.cta, footer {
  padding-top: 52px;
  padding-bottom: 52px;
}

/* ===== CTA をライト、フッターをダークのままに分離 ===== */

/* お問い合わせ誘導セクション（ライトに） */
.cta{
  background: #e7f6ef;            /* ← ライトミントに変更 */
  color: var(--ink);               /* 文字は通常色 */
  padding: 64px 0;                 /* 余白を広めにして“面”で見せる */
}
.cta h3{
  color: var(--brand-2);
}
.cta p{
  color: #4a5a68;                  /* 読みやすい中間色 */
}
.cta .panel{
  background: #fff;                /* ライト背景の上でも読めるよう白カードに */
  border: 1px solid var(--line);
  color: var(--ink);
}

/* セクション境界を明確に（CTAの下に薄い影、フッター上に罫線） */
.cta{ box-shadow: inset 0 -1px 0 rgba(16,24,40,.10); }
footer{
  background: #0f1a1f;             /* 既存のダークを維持 */
  border-top: 1px solid rgba(255,255,255,.06);
  padding: 48px 0;
}

/* ===== Footer ===== */
footer {
  background: #0f1a1f;
  color: #a9b8bf;
  font-size: 14px;
}

footer .footer-cols {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 28px;
  padding: 48px 0;
}

footer h6 {
  color: #e6eef0;
  font-size: 16px;
  margin: 0 0 12px;
}

footer p {
  margin: 0;
  line-height: 1.6;
}

.footer-menu {
  list-style: none;
  margin: 0;
  padding: 0;
}
.footer-menu li {
  margin-bottom: 6px;
}
.footer-menu a {
  color: #a9b8bf;
  text-decoration: none;
}
.footer-menu a:hover {
  color: #fff;
}

footer .copy {
  border-top: 1px solid rgba(255,255,255,.1);
  padding: 16px 0;
  text-align: center;
  font-size: 13px;
}

/* モバイルは縦積み */
@media (max-width: 768px) {
  footer .footer-cols {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .footer-menu {
    display: inline-block;
  }
}

/* --- CTAリッチ版の微調整 --- */
.cta--rich .wrap{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:28px;
  align-items:start;
}

.cta--rich .points{
  list-style:none;
  margin:12px 0 18px;
  padding:0;
  display:grid;
  gap:8px;
}
.cta--rich .points li{
  position:relative;
  padding-left:1.25em;
  line-height:1.6;
}
.cta--rich .points li::before{
  content:"✔";
  position:absolute;
  left:0; top:0;
  color:var(--brand);
  font-weight:700;
}

.cta--rich .cta-actions{ margin-top:10px; }
.cta--rich .note{
  display:block;
  margin-top:10px;
  color:#647a72;
  font-size:13px;
}

.contact-card{
  background:#fff !important;          /* ライト背景でも読みやすく */
  border:1px solid var(--line);
  border-radius:14px;
  padding:18px;
}
.contact-card .tel{
  font-size:18px; font-weight:800; margin:6px 0;
}
.contact-card .tel a{
  color:var(--brand); text-decoration:none;
}
.contact-card .hours{
  color:#4a5a68; font-size:14px;
}

/* モバイルは縦積み */
@media (max-width: 1024px){
  .cta--rich .wrap{ grid-template-columns:1fr; }
}

/* ===== strengths with images ===== */
.strengths-section{ padding:56px 0; }
.strengths-plus{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:20px;
}

.s-card{
  background:#fff;
  border-radius:20px;
  overflow:hidden;
  box-shadow: 0 10px 24px rgba(16,24,40,.08);
  transition: transform .2s ease, box-shadow .2s ease;
}
.s-card:hover{
  transform: translateY(-3px);
  box-shadow: 0 16px 32px rgba(16,24,40,.12);
}

/* 上部の画像 */
.s-media{
  position:relative;
  height:160px;                /* 高さはお好みで */
  background:#e9eef0;
}
.s-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.s-media::after{
  /* 画像のコントラストを少し整え、文字と干渉しないように */
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 50%, rgba(0,0,0,.15) 100%);
  pointer-events:none;
}

/* 本文 */
.s-body{ padding:18px 18px 20px; }
.s-body h3{
  margin:0 0 8px;
  font-size:18px;
  color:var(--brand-2);
}
.s-body p{
  margin:0;
  color:#4a5a68;
  line-height:1.7;
}

/* レスポンシブ */
@media (max-width: 1200px){
  .s-media{ height:150px; }
}
@media (max-width: 1024px){
  .strengths-plus{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px){
  .strengths-plus{ grid-template-columns: 1fr; }
  .s-media{ height:180px; } /* モバイルは少し高めに */
}

/* ==== Simple cards (list view) ==== */
.industries-modal .ind-grid{
  display:grid; gap:18px;
  grid-template-columns: repeat(3,1fr);
}
@media (max-width: 1024px){ .industries-modal .ind-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width: 640px){ .industries-modal .ind-grid{ grid-template-columns:1fr; } }

.ind-card{
  background:#fff; border:1px solid var(--line);
  border-radius:16px; padding:18px; box-shadow:var(--shadow);
}
.ind-card h3{ margin:0 0 8px; color:var(--brand-2); }
.ind-card .bullets{ margin:0 0 10px; padding-left:1.2em; }
.ind-card .bullets li{ margin:.2em 0; }

/* ==== Modal ==== */
.modal{ position:fixed; inset:0; display:none; z-index:1000; }
.modal.is-open{ display:block; }
.modal__overlay{
  position:absolute; inset:0; background:rgba(10,20,20,.48);
}
.modal__dialog{
  position:relative; z-index:1; max-width:920px; width:92%;
  margin:40px auto; background:#fff; border-radius:16px; overflow:hidden;
  box-shadow:0 20px 40px rgba(0,0,0,.25);
}
.modal__close{
  position:absolute; top:10px; right:10px;
  width:36px; height:36px; border-radius:50%; border:0;
  background:#0f1e16; color:#fff; font-size:20px; cursor:pointer;
}
.modal__body{ display:grid; grid-template-columns: 1fr 1fr; gap:0; }
@media (max-width: 860px){ .modal__body{ grid-template-columns:1fr; } }

.modal-hero{ background:#eaeff1; height:100%; min-height:260px; }
.modal-hero img{ width:100%; height:100%; object-fit:cover; display:block; }

.modal-content{ padding:20px 22px; }
.modal-content h3{ margin:0 0 10px; color:var(--brand-2); }
.modal-content p{ margin:0 0 10px; color:#4a5a68; line-height:1.7; }
.modal-content ul{ margin:0; padding-left:1.2em; }


/* ====== Process: 元の4カードレイアウトを復元 ====== */
#process { padding: 56px 0; }
#process .wrap { max-width: 1180px; margin: 0 auto; padding: 0 20px; }

#process .section-eyebrow {
  color:#617186; font-size:14px; letter-spacing:.08em; margin:0 0 8px;
}
#process .section-title{
  font-size:28px; font-weight:800; color:var(--brand-2); margin:0 0 20px;
}

.process{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:16px;
}

.step{
  background:#fff;
  border-radius:16px;
  padding:18px;
  box-shadow: var(--shadow);
  position:relative;
}
.step h4{ margin: 0 0 10px; font-size: 18px; font-weight: 800; color: var(--brand-2); }
.step p{ margin:0; color:#4a5a68; line-height:1.7; }

.step .num{
  position:absolute; top:12px; right:12px;
  width:32px; height:32px; border-radius:50%;
  display:grid; place-items:center;
  background:var(--mint); color:#0d5b45; font-weight:800;
}

/* レスポンシブ（元仕様に準拠） */
@media (max-width: 860px){
  .process{ grid-template-columns: 1fr 1fr; }
}
@media (max-width: 520px){
  .process{ grid-template-columns: 1fr; }
}
