  /* ============================================================
     HoiCa LP — 「園の一日に、そっと寄り添う」
     共通CSSのトークンをこのページ用に上書きする
     ============================================================ */
  /* デザイントークンは common.css :root に昇格済み（ここでは再定義しない） */

  body {
    font-family: 'Noto Sans JP', sans-serif;
    background: var(--paper);
    color: var(--ink);
    line-height: 1.85;
    -webkit-font-smoothing: antialiased;
  }
  .wrap { max-width: 1080px; margin: 0 auto; padding-left: 24px; padding-right: 24px; }

  ::selection { background: var(--orange-soft); }
  a { color: inherit; }
  img { display: block; max-width: 100%; }
  :focus-visible { outline: 3px solid var(--orange); outline-offset: 3px; border-radius: 4px; }

  /* ---- 共通の見出し部品 ---- */
  .eyebrow {
    display: inline-flex; align-items: center; gap: 9px;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 600; font-size: 15px; color: var(--wood);
    margin-bottom: 14px;
  }
  .eyebrow::before {
    content: ''; width: 22px; height: 2px; border-radius: 2px;
    background: var(--wood); opacity: .7;
  }
  h2.title {
    font-family: 'Zen Maru Gothic', sans-serif;
    font-weight: 900; font-size: clamp(26px, 3.6vw, 36px);
    line-height: 1.45; letter-spacing: .01em; color: var(--ink);
  }
  .lead { font-size: 16px; color: var(--ink-soft); margin-top: 14px; max-width: 58em; }

  /* ---- ボタン ---- */
  .btn {
    display: inline-flex; align-items: center; gap: 8px;
    font-family: 'Zen Maru Gothic', sans-serif; font-weight: 700;
    border-radius: 999px; padding: 14px 28px; font-size: 15px;
    text-decoration: none; cursor: pointer; border: 2px solid transparent;
    transition: transform .12s ease, box-shadow .15s ease, background .15s ease;
  }
  .btn svg { width: 17px; height: 17px; }
  .btn-orange { background: var(--orange); color: #fff; box-shadow: 0 10px 22px -12px rgba(236,102,50,.8); }
  .btn-orange:hover { transform: translateY(-2px); box-shadow: 0 16px 26px -12px rgba(236,102,50,.85); }
  .btn-leaf { background: var(--leaf); color: #fff; box-shadow: 0 10px 22px -12px rgba(63,168,106,.8); }
  .btn-leaf:hover { transform: translateY(-2px); box-shadow: 0 16px 26px -12px rgba(63,168,106,.85); }
  .btn-ghost { background: var(--card); color: var(--ink); border-color: var(--line); }
  .btn-ghost:hover { transform: translateY(-2px); border-color: var(--wood); }

  /* ============================================================
     STICKY NAV
     ============================================================ */
  .sticky-bar {
    position: fixed; top: 0; left: 0; right: 0; z-index: 100;
    display: flex; align-items: center; justify-content: space-between;
    padding: 14px 32px;
    background: rgba(251,245,236,0.82); backdrop-filter: blur(10px);
    border-bottom: 1px solid transparent; transition: border-color .2s, box-shadow .2s, padding .2s;
  }
  .sticky-bar.scrolled { border-bottom-color: var(--line); box-shadow: 0 6px 20px -16px rgba(74,46,22,.6); padding-top: 11px; padding-bottom: 11px; }
  .sticky-bar .logo img { height: 30px; }
  .nav-links { display: flex; align-items: center; gap: 26px; }
  .nav-links a { font-size: 14px; font-weight: 500; color: var(--ink-soft); text-decoration: none; transition: color .15s; }
  .nav-links a:hover { color: var(--orange-ink); }
  .nav-cta { font-size: 14px !important; padding: 10px 20px; }

  /* ============================================================
     HERO
     ============================================================ */
  .hero { padding: 0 0 36px; }
  /* 非対称フルブリード：写真は右端まで全高、文字は中央寄せ列の左半分（他セクションと左端が揃う） */
  .hero-stage { position: relative; }
  .hero-copy { max-width: 1080px; margin: 0 auto; padding: 132px 24px 80px; }
  .hero-copy .inner { max-width: 484px; position: relative; z-index: 1; }
  .hero-tag {
    display: inline-flex; align-items: center; gap: 8px;
    font-family: 'Noto Sans JP', sans-serif; font-weight: 600; font-size: 14px;
    color: var(--leaf-dark); background: var(--leaf-soft);
    padding: 7px 16px; border-radius: 999px; margin-bottom: 22px;
  }
  .hero h1 {
    font-family: 'Zen Maru Gothic', sans-serif; font-weight: 900;
    font-size: clamp(29px, 4.0vw, 43px); line-height: 1.34; letter-spacing: .005em;
    color: var(--ink);
  }
  /* アンカー遷移時に固定ナビへ隠れないように */
  #day, #case, #pricing, #faq, #contact { scroll-margin-top: 84px; }
  .hero h1 .mark { color: var(--orange); position: relative; white-space: nowrap; }
  .hero h1 .mark::after {
    content: ''; position: absolute; left: -2px; right: -2px; bottom: 4px; height: 10px; z-index: -1;
    background: var(--orange-soft); border-radius: 6px;
  }
  .hero p.sub { font-size: 16px; color: var(--ink-soft); margin: 22px 0 30px; max-width: 30em; }
  .hero-cta { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; }
  .hero-note { display: flex; gap: 18px; flex-wrap: wrap; margin-top: 22px; font-size: 13px; color: var(--ink-soft); }
  .hero-note span { display: inline-flex; align-items: center; gap: 6px; }
  .hero-note svg { width: 16px; height: 16px; color: var(--leaf); flex-shrink: 0; }

  /* Hero photo — 右半分を全高でフルブリード */
  .hero-photo { position: absolute; top: 0; right: 0; bottom: 0; left: 50%; overflow: hidden; }
  .hero-photo img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 38%; }
  /* 左側の紙色へ自然になじませるフェード */
  .hero-photo::after { content: ''; position: absolute; inset: 0; pointer-events: none;
    background: linear-gradient(90deg, var(--paper) 0%, rgba(251,245,236,0) 18%); }
  /* 写真の上に置く小さな実績チップ */
  .hero-chip {
    position: absolute; left: 28px; bottom: 26px; z-index: 1;
    background: rgba(255,255,255,0.94); backdrop-filter: blur(4px);
    border-radius: 14px; padding: 11px 16px 11px 12px;
    box-shadow: var(--shadow); display: flex; align-items: center; gap: 11px;
  }
  .hero-chip .ic { width: 36px; height: 36px; border-radius: 11px; background: var(--leaf-soft); color: var(--leaf-dark); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
  .hero-chip .ic svg { width: 19px; height: 19px; }
  .hero-chip small { display: block; font-size: 11px; color: var(--ink-faint); }
  .hero-chip strong { font-family: 'Zen Maru Gothic', sans-serif; font-size: 13.5px; color: var(--ink); }

  /* ============================================================
     DAY RIBBON (signature) — 一日の光の帯
     ============================================================ */
  .ribbon-band { margin-top: 40px; }
  .ribbon {
    position: relative; border-radius: var(--radius-lg);
    padding: 30px 36px 26px;
    background: linear-gradient(95deg,
      #FBE0CC 0%, #FDEBD8 22%, #FBF5EC 46%, #EAF2EA 60%, #FBF0DE 80%, #F4D6B2 100%);
    border: 1px solid var(--wood-soft);
  }
  .ribbon-head {
    font-family: 'Noto Sans JP', sans-serif; font-weight: 600; font-size: 14px;
    color: var(--wood); text-align: center; margin-bottom: 22px;
  }
  .ribbon-track {
    display: grid; grid-template-columns: repeat(5, 1fr); position: relative;
  }
  /* 点線（クレヨン風）の時間軸 */
  .ribbon-track::before {
    content: ''; position: absolute; left: 10%; right: 10%; top: 7px; height: 0;
    border-top: 2px dotted var(--wood); opacity: .55;
  }
  .stop { text-align: center; position: relative; }
  .stop .dot {
    width: 16px; height: 16px; border-radius: 50%; background: #fff;
    border: 3px solid var(--orange); margin: 0 auto 12px; position: relative; z-index: 1;
  }
  .stop:nth-child(2) .dot { border-color: #F08A3C; }
  .stop:nth-child(3) .dot { border-color: var(--leaf); }
  .stop:nth-child(4) .dot { border-color: #E8A23C; }
  .stop:nth-child(5) .dot { border-color: var(--wood); }
  .stop .time { font-family: 'Zen Maru Gothic', sans-serif; font-weight: 700; font-size: 15px; color: var(--ink); letter-spacing: .02em; }
  .stop .what { font-size: 12px; color: var(--ink-soft); margin-top: 2px; }

  /* ============================================================
     NEWS
     ============================================================ */
  .news { margin-top: 48px; }
  .news-inner {
    display: flex; align-items: stretch; border: 1px solid var(--line);
    border-radius: 14px; overflow: hidden; background: var(--card);
  }
  .news-label {
    font-family: 'Zen Maru Gothic', sans-serif; font-weight: 700; font-size: 13px; color: #fff;
    background: var(--wood); padding: 0 22px; display: flex; align-items: center; flex-shrink: 0;
  }
  .news-list { list-style: none; flex: 1; }
  .news-list li { display: flex; align-items: center; gap: 16px; padding: 12px 22px; border-bottom: 1px solid var(--line); font-size: 13.5px; }
  .news-list li:last-child { border-bottom: none; }
  .news-date { color: var(--ink-faint); white-space: nowrap; font-variant-numeric: tabular-nums; }
  .news-list a { color: var(--ink); text-decoration: none; }
  .news-list a:hover { color: var(--orange-ink); text-decoration: underline; }
  .news-all { align-self: center; flex-shrink: 0; padding: 0 20px; font-size: 13px; font-weight: 700; color: var(--orange-ink); text-decoration: none; border-left: 1px solid var(--line); align-self: stretch; display: flex; align-items: center; }
  .news-all:hover { text-decoration: underline; }

  /* ============================================================
     PROOF (導入園)
     ============================================================ */
  .proof { padding: 40px 0 8px; text-align: center; }
  .proof p { font-size: 13px; color: var(--ink-faint); margin-bottom: 16px; }
  .proof-row { display: flex; justify-content: center; align-items: center; gap: 14px 28px; flex-wrap: wrap; }
  .proof-row span { font-family: 'Zen Maru Gothic', sans-serif; font-weight: 700; font-size: 15px; color: var(--ink-soft); opacity: .8; }
  .proof-row span::before { content: '🌱'; display: none; }

  /* 想い（CREED）— 現行サイトの理念を継ぐ温度のあるブロック */
  .creed { padding: 76px 0 8px; text-align: center; }
  .creed .title { margin-top: 4px; }
  .creed-body { max-width: 50em; margin: 22px auto 0; }
  .creed-body p { font-size: 15.5px; color: var(--ink-soft); line-height: 2; }
  .creed-body p + p { margin-top: 14px; }
  .creed-values { list-style: none; display: flex; justify-content: center; flex-wrap: wrap; gap: 10px 14px; margin: 28px 0 0; padding: 0; }
  .creed-values li { display: inline-flex; align-items: center; gap: 7px; font-family: 'Zen Maru Gothic', sans-serif; font-weight: 700; font-size: 13.5px; color: var(--leaf-dark); background: var(--leaf-soft); padding: 8px 16px; border-radius: 999px; }
  .creed-values li::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--leaf); flex-shrink: 0; }
  /* スマホでは左揃え（PCは中央のまま） */
  @media (max-width: 768px) {
    .creed { text-align: left; }
    .creed-body { margin-left: 0; margin-right: 0; }
    .creed-values { justify-content: flex-start; }
  }

  /* ============================================================
     DAY TIMELINE (features) — 園の一日に寄り添う
     ============================================================ */
  .day { padding: 80px 0 76px; }
  .day-track { margin-top: 52px; position: relative; }
  .moment { position: relative; display: grid; grid-template-columns: 132px 1fr; gap: 0; padding-bottom: 56px; }
  .moment:last-child { padding-bottom: 0; }
  /* 縦の時間軸（点線） */
  .moment::before {
    content: ''; position: absolute; left: 53px; top: 14px; bottom: -14px;
    border-left: 2px dotted var(--wood); opacity: .5;
  }
  .moment:last-child::before { display: none; }
  .moment .rail { position: relative; }
  .moment .clock {
    width: 86px; height: 86px; border-radius: 50%; background: var(--card);
    border: 2px solid var(--wood-soft); box-shadow: var(--shadow-sm);
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    position: relative; z-index: 1;
  }
  .moment .clock .t { font-family: 'Zen Maru Gothic', sans-serif; font-weight: 900; font-size: 19px; color: var(--orange); line-height: 1; }
  .moment .clock .p { font-family: 'Noto Sans JP', sans-serif; font-size: 12px; color: var(--wood); margin-top: 4px; }
  .moment.leaf .clock .t { color: var(--leaf-dark); }

  .moment .panel {
    display: grid; grid-template-columns: 1fr 1.15fr; gap: 0;
    background: var(--card); border: 1px solid var(--line); border-radius: var(--radius-lg);
    overflow: hidden; box-shadow: var(--shadow-sm);
  }
  .moment.flip .panel { grid-template-columns: 1.15fr 1fr; }
  .moment.flip .panel .ph-text { order: 2; }
  .moment.flip .panel .ph-img { order: 1; }
  .moment .ph-img { position: relative; min-height: 220px; }
  .moment .ph-img img { width: 100%; height: 100%; object-fit: cover; position: absolute; inset: 0; }
  .moment .ph-text { padding: 30px 32px; }
  .moment .ph-tag {
    display: inline-flex; align-items: center; gap: 7px;
    font-family: 'Zen Maru Gothic', sans-serif; font-weight: 700; font-size: 12.5px;
    padding: 5px 13px; border-radius: 999px; margin-bottom: 12px;
    background: var(--orange-soft); color: var(--orange-ink);
  }
  .moment .ph-tag svg { width: 15px; height: 15px; }
  .moment.leaf .ph-tag { background: var(--leaf-soft); color: var(--leaf-dark); }
  .moment .ph-text h3 { font-family: 'Zen Maru Gothic', sans-serif; font-weight: 700; font-size: 20px; line-height: 1.5; margin-bottom: 10px; }
  .moment .ph-text p { font-size: 14px; color: var(--ink-soft); line-height: 1.85; }
  .moment .ph-link { display: inline-flex; align-items: center; gap: 5px; margin-top: 16px; font-family: 'Zen Maru Gothic', sans-serif; font-weight: 700; font-size: 13.5px; color: var(--orange-ink); text-decoration: none; }
  .moment.leaf .ph-link { color: var(--leaf-dark); }
  .moment .ph-link:hover { gap: 9px; }
  .moment .ph-link svg { width: 14px; height: 14px; }
  .day-foot { text-align: center; margin-top: 36px; font-size: 12.5px; color: var(--ink-faint); }

  /* ============================================================
     CHANGE STRIP — 現場で起きた変化
     ============================================================ */
  .change { background: var(--paper-2); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: 56px 0; }
  .change-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
  .change-item { text-align: center; }
  .change-item .big { font-family: 'Zen Maru Gothic', sans-serif; font-weight: 900; font-size: clamp(30px, 4vw, 40px); color: var(--orange); line-height: 1.1; }
  .change-item .big small { font-size: 16px; color: var(--ink-soft); font-weight: 700; }
  .change-item.leaf .big { color: var(--leaf-dark); }
  .change-item .cap { font-size: 13.5px; color: var(--ink-soft); margin-top: 8px; line-height: 1.7; }
  .change-item .src { font-size: 11px; color: var(--ink-faint); margin-top: 6px; }
  /* 見出しと各数字の小ラベル（3つを「始める→使う→続ける」の筋として読ませる） */
  .change-head { text-align: center; margin-bottom: 44px; }
  .change-head .eyebrow { display: inline-flex; }
  @media (max-width: 768px) { .change-head .title { font-size: 23px; } }
  .change-item .label { font-family: 'Zen Maru Gothic', sans-serif; font-weight: 700; font-size: 12.5px; letter-spacing: .04em; color: var(--wood); margin-bottom: 8px; }

  /* ============================================================
     CASE / INTERVIEW
     ============================================================ */
  .case { padding: 84px 0; }
  .case-quote {
    position: relative; background: var(--leaf); border-radius: var(--radius-lg);
    padding: 52px 56px; overflow: hidden; margin-top: 28px;
  }
  .case-quote::before {
    content: '\201C'; position: absolute; top: -28px; left: 28px; font-family: Georgia, serif;
    font-size: 200px; color: rgba(255,255,255,.16); line-height: 1; pointer-events: none;
  }
  .case-quote blockquote {
    font-family: 'Noto Sans JP', sans-serif; font-weight: 500; font-size: clamp(19px, 2.4vw, 25px);
    line-height: 1.78; color: #fff; position: relative;
  }
  .case-quote blockquote strong { background: rgba(255,255,255,.22); border-radius: 4px; padding: 0 4px; }
  .case-quote .attr { margin-top: 18px; font-size: 13.5px; color: rgba(255,255,255,.82); }

  .case-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 16px; }
  .ccard { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 24px 26px; }
  .ccard .h { display: flex; align-items: center; gap: 8px; font-family: 'Zen Maru Gothic', sans-serif; font-weight: 700; font-size: 13.5px; color: var(--orange-ink); margin-bottom: 10px; }
  .ccard .h svg { width: 17px; height: 17px; flex-shrink: 0; }
  .ccard p { font-size: 13.5px; color: var(--ink-soft); line-height: 1.85; }
  .ccard .pull { margin-top: 12px; padding: 11px 15px; background: var(--orange-soft); border-left: 3px solid var(--orange); border-radius: 0 10px 10px 0; font-family: 'Noto Sans JP', sans-serif; font-weight: 500; font-size: 13.5px; color: var(--ink); }

  .case-profile { display: flex; align-items: center; gap: 20px; background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 18px 26px; margin-top: 16px; }
  .case-profile .av { width: 60px; height: 60px; border-radius: 50%; overflow: hidden; flex-shrink: 0; border: 2px solid var(--wood-soft); }
  .case-profile .av img { width: 100%; height: 100%; object-fit: cover; }
  .case-profile strong { font-family: 'Zen Maru Gothic', sans-serif; font-weight: 700; font-size: 15px; display: block; }
  .case-profile .tags { display: flex; gap: 7px; flex-wrap: wrap; margin-top: 7px; }
  .case-profile .tags span { font-size: 11px; font-weight: 700; padding: 3px 10px; border-radius: 999px; background: var(--leaf-soft); color: var(--leaf-dark); }
  .case-profile .more { margin-left: auto; font-family: 'Zen Maru Gothic', sans-serif; font-weight: 700; font-size: 13px; color: var(--orange-ink); text-decoration: none; white-space: nowrap; }
  .case-profile .more:hover { text-decoration: underline; }

  /* ============================================================
     PRICING
     ============================================================ */
  .pricing { padding: 84px 0; }
  .pricing-head { text-align: center; }
  .pricing-head .eyebrow, .pricing-head .lead { display: inline-flex; }
  .pricing-head .lead { display: block; margin: 14px auto 0; }
  .price-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; max-width: 720px; margin: 44px auto 0; }
  .pcard { position: relative; background: var(--card); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 36px 30px; text-align: center; }
  .pcard.feat { border: 2px solid var(--orange); box-shadow: var(--shadow); }
  .pcard .badge { position: absolute; top: -14px; left: 50%; transform: translateX(-50%); background: var(--orange); color: #fff; font-family: 'Zen Maru Gothic', sans-serif; font-weight: 700; font-size: 12px; padding: 5px 16px; border-radius: 999px; white-space: nowrap; }
  .pcard .ptype { font-size: 14px; color: var(--ink-soft); margin-bottom: 10px; }
  .pcard .pnum { font-family: 'Zen Maru Gothic', sans-serif; font-weight: 900; font-size: 50px; color: var(--orange); line-height: 1; }
  .pcard .pnum small { font-size: 17px; font-weight: 700; color: var(--ink-soft); }
  .pcard .pdesc { font-size: 13px; color: var(--ink-faint); margin: 8px 0 22px; }
  .pcard .btn { width: 100%; justify-content: center; }
  .price-note { text-align: center; font-size: 12.5px; color: var(--ink-faint); margin-top: 22px; }

  /* ============================================================
     STEPS — 始め方（footpath）
     ============================================================ */
  .steps { background: var(--leaf-soft); border-top: 1px solid #DCEBE0; border-bottom: 1px solid #DCEBE0; padding: 80px 0; }
  .steps-head { text-align: center; }
  .steps-head .eyebrow { color: var(--leaf-dark); }
  .steps-head .eyebrow::before { background: var(--leaf-dark); }
  .steps-row { display: grid; grid-template-columns: repeat(5, 1fr); gap: 0; margin-top: 48px; position: relative; }
  .steps-row::before { content: ''; position: absolute; left: 10%; right: 10%; top: 23px; border-top: 2px dotted var(--leaf); opacity: .55; }
  .step { text-align: center; position: relative; padding: 0 8px; }
  .step .n { width: 48px; height: 48px; border-radius: 50%; background: var(--leaf); color: #fff; font-family: 'Zen Maru Gothic', sans-serif; font-weight: 900; font-size: 17px; display: flex; align-items: center; justify-content: center; margin: 0 auto 14px; position: relative; z-index: 1; box-shadow: 0 8px 16px -10px rgba(45,138,84,.9); }
  .step h4 { font-family: 'Zen Maru Gothic', sans-serif; font-weight: 700; font-size: 14px; margin-bottom: 5px; }
  .step p { font-size: 12px; color: var(--ink-soft); line-height: 1.7; }

  /* ============================================================
     FINAL CTA
     ============================================================ */
  .final { padding: 88px 0; text-align: center; position: relative; overflow: hidden; }
  .final::before {
    content: ''; position: absolute; inset: 0; z-index: -1;
    background: radial-gradient(120% 90% at 50% -10%, var(--orange-soft) 0%, var(--paper) 60%);
  }
  .final .pill { display: inline-flex; align-items: center; gap: 7px; font-family: 'Noto Sans JP', sans-serif; font-weight: 600; font-size: 14px; color: var(--orange-ink); background: #fff; border: 1px solid var(--orange-soft); padding: 7px 18px; border-radius: 999px; margin-bottom: 20px; }
  .final h2 { font-family: 'Zen Maru Gothic', sans-serif; font-weight: 900; font-size: clamp(28px, 4.4vw, 42px); line-height: 1.4; }
  .final .big-sub { font-family: 'Zen Maru Gothic', sans-serif; font-weight: 700; font-size: 18px; margin-top: 16px; }
  .final p.note-line { font-size: 15px; color: var(--ink-soft); margin-top: 10px; }
  .final-cta { display: flex; justify-content: center; gap: 14px; flex-wrap: wrap; margin-top: 30px; }
  .final .tail { font-size: 12.5px; color: var(--ink-faint); margin-top: 18px; }

  /* ============================================================
     FAQ
     ============================================================ */
  .faq { padding: 84px 0; max-width: 800px; }
  .faq-list { margin-top: 28px; }
  .faq-item { border-bottom: 1px solid var(--line); }
  .faq-item summary { list-style: none; cursor: pointer; display: flex; align-items: center; gap: 14px; padding: 20px 0; font-family: 'Zen Maru Gothic', sans-serif; font-weight: 700; font-size: 15.5px; }
  .faq-item summary::-webkit-details-marker { display: none; }
  .faq-item summary .q { width: 26px; height: 26px; flex-shrink: 0; border-radius: 50%; background: var(--orange-soft); color: var(--orange-ink); font-size: 13px; display: flex; align-items: center; justify-content: center; font-weight: 900; }
  .faq-item summary .chev { margin-left: auto; color: var(--wood); transition: transform .2s; }
  .faq-item summary .chev svg { width: 18px; height: 18px; }
  .faq-item[open] summary .chev { transform: rotate(180deg); }
  .faq-item .a { padding: 0 0 22px 40px; font-size: 14px; color: var(--ink-soft); line-height: 1.9; }
  .faq-foot { text-align: center; margin-top: 40px; }
  .faq-foot p { font-size: 14px; color: var(--ink-soft); margin-bottom: 16px; }

  /* ============================================================
     ASSURANCE（安心：個人情報・サポート・補助金）
     ============================================================ */
  .assure { padding: 84px 0; background: var(--paper-2); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
  .assure .inner { max-width: 1080px; margin: 0 auto; padding: 0 24px; }
  .assure-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 40px; }
  .acard { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 30px 26px; box-shadow: var(--shadow-sm); }
  .acard .ic { width: 48px; height: 48px; border-radius: 14px; display: flex; align-items: center; justify-content: center; margin-bottom: 16px; }
  .acard .ic svg { width: 24px; height: 24px; }
  .acard.leaf .ic { background: var(--leaf-soft); color: var(--leaf-dark); }
  .acard.orange .ic { background: var(--orange-soft); color: var(--orange-ink); }
  .acard.wood .ic { background: var(--wood-soft); color: var(--wood); }
  .acard h3 { font-family: 'Zen Maru Gothic', sans-serif; font-weight: 700; font-size: 17px; margin-bottom: 8px; }
  .acard p { font-size: 13.5px; color: var(--ink-soft); line-height: 1.85; }
  @media (max-width: 768px) { .assure-grid { grid-template-columns: 1fr; } }

  /* ============================================================
     FOOTER
     ============================================================ */
  footer { background: var(--ink); color: rgba(255,255,255,.7); padding: 44px 0; text-align: center; }
  footer .footer-logo { display: flex; justify-content: center; margin-bottom: 14px; }
  footer .footer-logo img { height: 30px; filter: brightness(0) invert(1); opacity: .92; }
  footer p { font-size: 12.5px; }
  footer p + p { margin-top: 8px; color: rgba(255,255,255,.45); }

  /* ============================================================
     RESPONSIVE
     ============================================================ */
  @media (max-width: 900px) {
    /* 写真を本文の下にフル幅で重ねる積み上げレイアウトへ */
    .hero-copy { padding: 112px 24px 0; max-width: none; }
    .hero-copy .inner { max-width: none; }
    .hero-photo { position: static; left: auto; width: 100%; height: 320px; margin-top: 28px; }
    .hero-photo::after { display: none; }
    .hero-chip { left: 18px; bottom: 18px; }
    .case-cards { grid-template-columns: 1fr; }
  }
  @media (max-width: 720px) {
    .wrap { padding-left: 18px; padding-right: 18px; }
    .nav-links { display: none; }
    .hero-copy { padding-top: 96px; padding-left: 18px; padding-right: 18px; }
    .ribbon { padding: 24px 18px; }
    .ribbon-track { grid-template-columns: repeat(2, 1fr); gap: 22px 8px; }
    .ribbon-track::before { display: none; }
    .news-inner { flex-direction: column; }
    .news-label { padding: 8px 22px; }
    .news-all { border-left: none; border-top: 1px solid var(--line); justify-content: center; }
    .moment { grid-template-columns: 64px 1fr; }
    .moment::before { left: 31px; }
    .moment .clock { width: 64px; height: 64px; }
    .moment .clock .t { font-size: 15px; }
    .moment .panel, .moment.flip .panel { grid-template-columns: 1fr; }
    .moment.flip .panel .ph-text { order: 2; }
    .moment.flip .panel .ph-img { order: 1; }
    .moment .ph-img { min-height: 180px; }
    /* 細い列＋大きめ見出しで末尾1〜2文字が泣き別れるのを防ぐ：余白を詰め、見出しを少しだけ小さく */
    .moment .ph-text { padding: 26px 22px; }
    .moment .ph-text h3 { font-size: 17px; }
    .change-grid { grid-template-columns: 1fr; gap: 26px; }
    .case-quote { padding: 36px 26px; }
    /* 狭幅で「インタビュー全文を読む →」が縮まず横はみ出ししないよう折り返す */
    .case-profile { flex-wrap: wrap; }
    .case-profile .more { margin-top: 4px; }
    .price-grid { grid-template-columns: 1fr; }
    .steps-row { grid-template-columns: 1fr 1fr; gap: 28px 8px; }
    .steps-row::before { display: none; }
  }

  /* モバイル: ハンバーガー化に合わせてヘッダーを60px固定・旧アンカーナビは隠す */
  @media (max-width: 768px) {
    .sticky-bar { height: 60px; padding: 0 18px; }
    .sticky-bar.scrolled { padding: 0 18px; }
    .nav-links { display: none; }
    .nav-cta { white-space: nowrap; padding: 9px 16px; }
  }

  @media (prefers-reduced-motion: reduce) {
    * { transition: none !important; scroll-behavior: auto !important; }
  }
