  :root{
    --teal:#34888C;
    --teal-dark:#2a6e72;
    --teal-tint:#e8f2f2;
    --teal-tint2:#f1f7f7;
    --green:#7CAA2D;
    --green-dark:#5f8420;
    --green-tint:#eef5e0;
    --yellow:#F5E356;
    --yellow-tint:#fdf8d8;
    --orange:#CB6318;
    --orange-tint:#f9ece2;
    --warm-a:#f6ac82;
    --warm-b:#f4d24f;
    --ink:#2D3837;
    --sub:#5d6b6c;
    --line:#e3e9e9;
    --bg:#f5f9f9;
    --white:#fff;
    --radius:16px;
    --radius-sm:10px;
    --shadow:0 10px 30px -12px rgba(31,55,56,.18);
    --shadow-sm:0 4px 14px -8px rgba(31,55,56,.22);
    --shadow-float:0 6px 16px -4px rgba(0,0,0,.5),0 2px 6px rgba(0,0,0,.25);
    --ink-soft:#3a4645;
    --maxw:1000px;
    --fs-micro:.72rem;
    --fs-small:.82rem;
    --fs-body:.92rem;
    --fs-h3:1.12rem;
    --fs-title:1.3rem;
    --fs-h2:1.6rem;
    --fs-xl:2.4rem;
    /* text-safe な濃色（小さい文字・本文・リンクのコントラスト確保用） */
    --orange-dark:#a8470a;
    --green-strong:#4d6b1a;
    --yellow-text:#7a6200;
    --ink-on-yellow:#4a3d00;
    --icon-muted:#aab6b6;
    --line-dashed:#b8c3c3;
    --yellow-hover:#f1da3e;
    --msg-ok:#eaffea;
    --msg-err:#ffe2d2;
    --focus-ring:var(--teal-dark);
    /* 余白スケール（新規はこの範囲から選ぶ） */
    --space-2xs:4px; --space-xs:8px; --space-s:12px; --space-m:16px;
    --space-l:24px; --space-xl:32px; --space-2xl:48px; --space-section:54px;
    /* 動き（モーション） */
    --dur-fast:.15s; --dur-slow:.3s;
    /* 固定ナビ（上部に追従） */
    --navbar-h:56px; --navbar-h-sp:52px; --z-navbar:60;
  }
  *{box-sizing:border-box}
  html{scroll-behavior:smooth;font-size:18px;scrollbar-gutter:stable}
  body{
    font-family:"Noto Sans JP",-apple-system,BlinkMacSystemFont,"Hiragino Sans","Yu Gothic UI",sans-serif;
    background:var(--bg);color:var(--ink);
    line-height:1.85;margin:0;padding-top:var(--navbar-h);
    -webkit-font-smoothing:antialiased;
  }
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
  a{color:var(--teal-dark)}
  :focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px;border-radius:3px}
  .fab:focus-visible,.menu-btn:focus-visible,.cf-submit:focus-visible,.cf-modal-close:focus-visible{outline-color:#fff;outline-offset:3px}

  /* ---------- Hero ---------- */
  .hero{
    position:relative;overflow:hidden;color:#fff;
    background:var(--teal-dark);
  }
  .hero::before{
    content:"";position:absolute;right:-120px;top:-120px;
    width:420px;height:420px;border-radius:50%;
    background:radial-gradient(circle at 30% 30%,rgba(245,227,86,.35),transparent 70%);
  }
  .hero::after{
    content:"";position:absolute;left:-100px;bottom:-160px;
    width:380px;height:380px;border-radius:50%;
    background:radial-gradient(circle at 50% 50%,rgba(124,170,45,.4),transparent 70%);
  }
  .hero-inner{position:relative;z-index:1;padding-top:72px;padding-bottom:90px}
  .hero h1{
    font-size:clamp(2rem,5vw,3rem);font-weight:900;line-height:1.3;
    margin:0 0 18px;letter-spacing:.01em;
  }
  .hero-lead{
    font-size:var(--fs-body);margin:0 0 30px;
    color:rgba(255,255,255,.92);font-weight:400;
  }
  .hero-stats{display:flex;flex-wrap:wrap;margin-top:8px}
  .hero-stat{display:flex;flex-direction:column;padding:2px 34px;position:relative}
  .hero-stat:first-child{padding-left:0}
  .hero-stat + .hero-stat::before{
    content:"";position:absolute;left:0;top:4px;bottom:4px;width:1px;
    background:rgba(255,255,255,.28);
  }
  .hero-stat .l{
    font-size:var(--fs-micro);letter-spacing:.14em;font-weight:400;
    color:rgba(255,255,255,.92);margin-bottom:7px;
  }
  .hero-stat .v{font-size:var(--fs-h2);font-weight:900;line-height:1.2;color:#fff;letter-spacing:.01em}
  .hero-stat .v em{color:var(--yellow);font-style:normal}
  .hero-stat .hint{
    font-size:var(--fs-micro);color:rgba(255,255,255,.9);margin-top:6px;letter-spacing:.02em;line-height:1.5;
  }
  @media(max-width:600px){
    /* スマホで1画面に収まるようヒーロー全体の余白を控えめに（窮屈にならない最小限の縮小） */
    .hero-inner{padding-top:44px;padding-bottom:56px}
    .hero h1{margin-bottom:14px}
    .hero-lead{margin-bottom:20px;line-height:1.7}
    .hero-stats{margin-top:4px}
    .hero-stat{flex:1 1 100%;padding:0;margin-top:12px}
    .hero-stat + .hero-stat::before{display:none}
    .hero-stat .l{margin-bottom:4px}
    .hero-pitch{margin-top:22px}
  }
  /* hero pitch (band) */
  .hero-pitch{margin-top:32px}
  .hero-pitch--band{
    background:var(--yellow);color:var(--ink);border-radius:16px;
    padding:26px 30px;box-shadow:0 16px 36px -16px rgba(0,0,0,.45);
  }
  .hero-pitch--band .main{
    font-size:clamp(1.15rem,4.6vw,2.05rem);font-weight:900;line-height:1.4;margin:0;letter-spacing:.01em;
    overflow-wrap:anywhere;
  }
  .hero-pitch--band .sub{
    font-size:clamp(.92rem,2vw,1.08rem);font-weight:700;color:var(--ink-on-yellow);margin:12px 0 0;line-height:1.7;
    overflow-wrap:anywhere;
  }

  /* ---------- Table of contents ---------- */
  .toc{
    background:var(--white);border:1px solid var(--line);border-radius:var(--radius-sm);
    box-shadow:var(--shadow-sm);padding:14px 26px;
  }
  .toc h2{font-size:var(--fs-h3);font-weight:900;margin:0 0 4px;letter-spacing:.01em}
  .toc-list{list-style:none;margin:0;padding:0;counter-reset:toc}
  /* 罫線は上方向に置く: 全項目に罫線。2段組のときも左列の最終項目に余分な下罫線が残らない */
  .toc-list li{counter-increment:toc;border-top:1px solid var(--line)}
  .toc-list a{
    display:flex;align-items:center;gap:10px;padding:6px 2px;
    color:var(--ink);text-decoration:none;font-size:var(--fs-small);font-weight:400;transition:var(--dur-fast);
  }
  .toc-list a::before{
    content:counter(toc,decimal-leading-zero);
    flex:0 0 auto;min-width:17px;font-size:var(--fs-micro);font-weight:900;color:var(--teal-dark);letter-spacing:.03em;
  }
  .toc-list a::after{
    content:"";flex:0 0 auto;margin-left:auto;width:16px;height:16px;
    background-color:var(--icon-muted);transition:var(--dur-fast);
    -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='12' y1='4' x2='12' y2='20'/%3E%3Cpolyline points='6 14 12 20 18 14'/%3E%3C/svg%3E") center/contain no-repeat;
            mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='12' y1='4' x2='12' y2='20'/%3E%3Cpolyline points='6 14 12 20 18 14'/%3E%3C/svg%3E") center/contain no-repeat;
  }
  .toc-list a:hover{color:var(--teal-dark)}
  .toc-list a:hover::after{background-color:var(--teal-dark);transform:translateY(3px)}
  /* 本文目次: PCは2段組で左列を上から埋めてから右列へ流す・矢印アイコン非表示。スライド目次（.drawer内）は対象外 */
  .toc .toc-list{column-count:2;column-gap:24px}
  .toc .toc-list li{break-inside:avoid}
  .toc .toc-list a::after{display:none}
  /* 項目が少ないときに使う1カラム版: PCでも縦1列で並べる */
  .toc.-single .toc-list{column-count:1}
  /* 子項目（折りたたみグループ内の見出しなど）: 番号を持たずハイフンで字下げ表示。
     高さは通常項目とそろえ、2段組での罫線位置を保つ。 */
  .toc-list li.is-sub{counter-increment:none}
  .toc-list li.is-sub a{padding-left:18px}
  .toc-list li.is-sub a::before{content:"-";color:var(--sub);font-weight:700;min-width:auto}
  /* ドロワー（右からスライドする目次）内では矢印アイコンを出さない（縦並びの目次なので「下へ」のサインは不要） */
  #drawer-body .toc-list a::after{display:none}
  /* ドロワー内の目次は下方向に罫線（drawer-title「目次」の直下に罫線が来ないように、上罫線は使わない） */
  #drawer-body .toc-list li{border-top:none;border-bottom:1px solid var(--line)}
  @media(max-width:680px){
    .toc .toc-list{column-count:1}
  }

  /* ---------- Sections ---------- */
  section{padding:var(--space-section) 0;border-bottom:1px solid var(--line)}
  section:last-of-type{border-bottom:none}
  [id]{scroll-margin-top:16px}/* アンカー着地: 節の上paddingが固定ナビ下に潜り、見出しがナビ直下で止まる値（スマホは下のmedia） */
  /* section の中に置いた要素（callout など）に直接ジャンプするときは、節の padding がないので navbar の高さぶんを足して潜らないようにする */
  .callout[id]{scroll-margin-top:calc(var(--navbar-h) + 16px)}
  #toc{padding:32px 0 40px}
  .section-head{margin:0 0 26px}
  .section-head h2{
    font-size:var(--fs-h2);font-weight:900;margin:0;letter-spacing:.01em;
  }

  h3{font-size:var(--fs-h3);font-weight:700;margin:26px 0 10px}

  /* ---------- Price example card ---------- */
  .estimate{
    background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);
    border:1px solid var(--line);overflow:hidden;
  }
  .estimate + .estimate{margin-top:22px}
  .estimate-head{
    background:var(--teal-dark);
    color:#fff;padding:18px 26px;font-weight:700;font-size:var(--fs-body);
    display:flex;align-items:center;gap:10px;
  }
  .plan-ribbon,.estimate-head .pin{
    background:var(--yellow);color:var(--ink);font-weight:700;border-radius:999px;white-space:nowrap;
  }
  .estimate-head .pin{font-size:var(--fs-micro);padding:3px 10px}
  .estimate-body{padding:14px 26px 22px}
  .estimate-row{
    display:flex;justify-content:space-between;align-items:baseline;gap:16px;
    padding:13px 0;border-bottom:1px dashed var(--line);
  }
  .estimate-row .label{color:var(--ink);font-size:var(--fs-body)}
  .estimate-row .val{font-weight:700;white-space:nowrap;color:var(--ink)}
  .estimate-row.total{
    border-bottom:none;margin-top:6px;padding-top:18px;
    border-top:2px solid var(--teal-tint);
  }
  .estimate-row.total .label{font-weight:700;font-size:var(--fs-body)}
  .estimate-row.total .val{color:var(--teal);font-size:var(--fs-h2)}
  .estimate-foot{
    background:var(--teal-tint2);padding:14px 26px;font-size:var(--fs-small);color:var(--sub);
  }
  .estimate-foot b{color:var(--teal-dark)}

  /* ---------- Plan diagram (クイック ＋ オプション ＝ カスタムの関係図) ---------- */
  .plan-diagram{
    display:grid;
    grid-template-columns:minmax(0,1fr) auto minmax(0,1fr) auto minmax(0,1fr);
    grid-template-rows:auto auto auto auto;
    column-gap:14px;margin:0 0 34px;
  }
  .plan-diagram .box{
    display:grid;grid-template-rows:subgrid;grid-row:1 / span 4;grid-template-columns:1fr;row-gap:8px;
    background:var(--white);border:1px solid var(--line);
    border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);
    padding:18px 16px 16px;text-align:center;
  }
  .plan-diagram .box .role{
    align-self:start;justify-self:center;
    font-size:var(--fs-micro);font-weight:900;letter-spacing:.06em;color:var(--teal-dark);
    background:var(--teal-tint);padding:3px 10px;border-radius:999px;
  }
  .plan-diagram .box .name{align-self:center;font-size:var(--fs-title);font-weight:900;color:var(--ink);line-height:1.3;margin:0}
  .plan-diagram .box .num{align-self:center;font-size:var(--fs-h2);font-weight:900;color:var(--teal);letter-spacing:.02em}
  .plan-diagram .box .sub{align-self:start;font-size:var(--fs-small);color:var(--sub);line-height:1.6}
  .plan-diagram .op{
    grid-row:1 / span 4;align-self:center;
    display:flex;align-items:center;justify-content:center;
    font-size:var(--fs-h2);font-weight:900;color:var(--sub);padding:0 2px;
  }
  @media(max-width:720px){
    .plan-diagram{display:flex;flex-direction:column;gap:8px;margin:0 0 28px}
    .plan-diagram .box{display:flex;flex-direction:column;align-items:center;justify-content:center;grid-row:auto;padding:14px 16px;gap:6px}
    /* flex 縦並びでは grid の align-self が「左寄せ」として効いてしまうので解除して中央寄せに戻す */
    .plan-diagram .box .role,
    .plan-diagram .box .name,
    .plan-diagram .box .num,
    .plan-diagram .box .sub{align-self:auto}
    .plan-diagram .op{grid-row:auto;padding:0;font-size:var(--fs-h3)}
    /* イコールはスマホで縦並びになったときだけ90度回転（縦方向の区切りとして自然に見える） */
    .plan-diagram .op-rot{transform:rotate(90deg)}
  }

  /* ---------- Flow (制作の流れ) ---------- */
  /* grid-template-columns は HTML 側の inline style で「1fr auto 1fr auto 1fr ...」のように指定する。inline 未指定時は1列縦積みのフォールバック */
  .flow{display:grid;grid-template-rows:auto auto auto;grid-template-columns:1fr;column-gap:8px;row-gap:8px;align-items:stretch;margin:0}
  .flow .step{
    display:grid;grid-template-rows:subgrid;grid-row:1 / span 3;row-gap:6px;
    background:var(--white);border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);
    padding:16px 14px 14px;text-align:center;
  }
  .flow .step .num{
    align-self:start;justify-self:center;
    display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;
    background:var(--teal);color:#fff;font-weight:900;font-size:var(--fs-small);line-height:1;
  }
  .flow .step .ttl{align-self:center;font-weight:900;color:var(--ink);font-size:var(--fs-body);line-height:1.35;margin:0}
  .flow .step .desc{align-self:start;font-size:var(--fs-small);color:var(--sub);line-height:1.6;margin:0;text-align:left}
  /* 短文（1行）のステップは .desc に .-center を付けて中央寄せに切り替える */
  .flow .step .desc.-center{text-align:center}
  .flow .arrow{
    grid-row:1 / span 3;align-self:center;
    display:flex;align-items:center;justify-content:center;
    font-size:var(--fs-h3);color:var(--sub);font-weight:900;padding:0;
  }
  @media(max-width:720px){
    .flow{display:flex;flex-direction:column;gap:8px}
    .flow .step{
      display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto;
      column-gap:10px;row-gap:6px;grid-row:auto;padding:12px 14px;text-align:left;
    }
    .flow .step .num{grid-row:1;grid-column:1;justify-self:start;align-self:center}
    .flow .step .ttl{grid-row:1;grid-column:2;align-self:center;text-align:left}
    .flow .step .desc{grid-row:2;grid-column:1 / -1;text-align:left}
    .flow .step .desc.-center{text-align:left}
    .flow .arrow{grid-row:auto;font-size:var(--fs-body);padding:0;transform:rotate(90deg)}
  }

  /* ---------- 修正回数の数え方 図解 ---------- */
  .rev-diagram{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:14px 0 22px}
  .rev-set{
    background:var(--white);border:1px solid var(--line);border-radius:var(--radius-sm);
    padding:14px 16px;
  }
  .rev-set .rev-label{
    font-size:var(--fs-body);font-weight:900;color:var(--teal-dark);
    margin:0 0 10px;text-align:center;letter-spacing:.02em;
  }
  .rev-set .parts{
    display:flex;flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;
  }
  .rev-set .parts li{
    padding:6px 12px;
    background:var(--bg);border:1px solid var(--line);border-radius:6px;
    color:var(--ink);font-size:var(--fs-small);line-height:1.4;
  }
  @media(max-width:680px){
    .rev-diagram{grid-template-columns:1fr}
  }

  /* ---------- Plan cards ---------- */
  .plan-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
  @media(max-width:680px){.plan-grid{grid-template-columns:1fr}}
  .plan{
    position:relative;background:var(--white);border-radius:var(--radius);
    border:1px solid var(--line);box-shadow:var(--shadow-sm);
    padding:30px 26px;display:flex;flex-direction:column;
  }
  .plan--featured{
    border:2px solid var(--teal);box-shadow:var(--shadow);
  }
  .plan-ribbon{
    position:absolute;top:-13px;left:26px;font-size:var(--fs-small);
    padding:5px 16px;box-shadow:var(--shadow-sm);
    display:flex;align-items:center;gap:6px;
  }
  .plan h3{margin:0 0 4px;font-size:var(--fs-title);font-weight:900}
  .plan .plan-tag{font-size:var(--fs-small);color:var(--teal-dark);font-weight:600;margin:0 0 14px}
  .plan-price{display:flex;align-items:baseline;flex-wrap:wrap;gap:3px;margin:0 0 2px}
  .plan-price .num{font-size:var(--fs-xl);font-weight:900;line-height:1;color:var(--teal-dark)}
  .plan-price .unit{font-size:var(--fs-h3);font-weight:700;color:var(--teal-dark)}
  /* 「＋ 各オプション代」のような追加表示。PCは同一行、スマホは下段に折り返す */
  .plan-price-add{font-size:var(--fs-h3);font-weight:700;color:var(--teal-dark);margin-left:6px}
  @media(max-width:680px){
    .plan-price-add{flex-basis:100%;margin-left:0;font-size:var(--fs-body);line-height:1.5}
  }
  .plan-price-note{font-size:var(--fs-small);color:var(--sub);margin:0 0 16px}
  .plan-desc{font-size:var(--fs-body);color:var(--sub);margin:0 0 16px;line-height:1.8}
  .plan-features{list-style:none;margin:auto 0 0;padding:16px 0 0;border-top:1px solid var(--line)}
  .plan-features li{
    position:relative;padding-left:28px;margin:11px 0;font-size:var(--fs-body);line-height:1.6;
  }
  .plan-features li::before{
    content:"";position:absolute;left:0;top:4px;width:18px;height:18px;border-radius:50%;
    background:var(--green) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/12px no-repeat;
  }
  .plan-features li small{
    display:block;font-size:var(--fs-small);color:var(--sub);margin-top:3px;font-weight:400;line-height:1.6;
  }
  .plan-link{
    display:inline-flex;align-items:center;gap:6px;margin:18px 0 0;
    font-size:var(--fs-body);font-weight:700;color:var(--teal-dark);text-decoration:none;
    background:var(--teal-tint);padding:9px 16px;border-radius:999px;
    border:1px solid var(--teal-tint);align-self:flex-start;transition:var(--dur-fast);
  }
  .plan-link:hover{background:var(--teal-tint2);border-color:var(--teal);color:var(--teal-dark)}

  /* ---------- Included feature grid ---------- */
  .feature-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-m)}
  @media(max-width:680px){.feature-grid{grid-template-columns:1fr}}
  .feature{
    background:var(--white);border:1px solid var(--line);border-radius:var(--radius-sm);
    padding:18px 20px;display:flex;gap:14px;box-shadow:var(--shadow-sm);
  }
  .feature .ic{
    flex:0 0 auto;width:34px;height:34px;border-radius:50%;
    background:var(--green-tint);display:grid;place-items:center;
  }
  .feature .ic svg{width:18px;height:18px;stroke:var(--green-dark)}
  .feature h3,.feature h4{margin:0 0 4px;font-size:var(--fs-body);font-weight:700}
  .feature p{margin:0;font-size:var(--fs-small);color:var(--sub);line-height:1.7}

  /* ---------- Tables ---------- */
  .table-card{
    background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
    box-shadow:var(--shadow-sm);overflow:hidden;
  }
  .table-scroll{overflow-x:auto}
  table{width:100%;border-collapse:collapse;font-size:var(--fs-body);min-width:520px}
  thead th{
    background:var(--teal);color:#fff;text-align:left;font-weight:700;
    padding:14px 18px;font-size:var(--fs-small);white-space:nowrap;
  }
  tbody td{padding:14px 18px;border-top:1px solid var(--line);vertical-align:top;line-height:1.7}
  tbody tr:nth-child(even){background:var(--teal-tint)}
  td.price-col{white-space:nowrap;font-weight:700;color:var(--teal-dark);font-size:var(--fs-body)}
  td.note-col{font-size:var(--fs-small);color:var(--sub)}
  td .strong-price{font-size:var(--fs-body)}
  /* two-column info tables */
  .table-2col table{min-width:0}
  .table-2col tbody tr:nth-child(even){background:transparent}
  .table-2col tbody th{
    background:var(--teal-tint);color:var(--teal-dark);text-align:left;font-weight:700;
    padding:14px 18px;border-top:1px solid var(--line);width:38%;font-size:var(--fs-body);vertical-align:top;
  }
  .table-2col tbody tr:first-child th,.table-2col tbody tr:first-child td{border-top:none}

  /* ---------- Badges ---------- */
  .badge{
    display:inline-flex;align-items:center;gap:4px;font-size:var(--fs-micro);font-weight:700;
    padding:3px 10px;border-radius:999px;margin-left:6px;vertical-align:middle;white-space:nowrap;
  }
  .badge.in{background:var(--green-tint);color:var(--green-strong)}
  .badge.no{background:var(--orange-tint);color:var(--orange-dark)}
  .badge.free{background:var(--yellow-tint);color:var(--yellow-text)}

  /* ---------- Callout / note ---------- */
  .copy{font-size:var(--fs-body);color:var(--ink);margin:14px 0 0;line-height:1.85}
  .note{font-size:var(--fs-small);color:var(--sub);margin:14px 0 0}
  /* 米印リスト: <ul class="note"> で書く。※ がマーカー化し、2行目以降は字下げされる。<li>テキストに「※」は含めない */
  ul.note{list-style:none;padding:0}
  ul.note li{position:relative;padding-left:1.1em;line-height:1.85}
  ul.note li + li{margin-top:4px}
  ul.note li::before{content:"※";position:absolute;left:0;top:0}
  .callout{
    background:var(--white);border:2px dashed var(--line-dashed);
    border-radius:var(--radius-sm);padding:16px 20px;margin:16px 0;
    font-size:var(--fs-body);color:var(--ink-soft);line-height:1.85;
  }
  .callout.warn{border-color:var(--orange);background:var(--orange-tint)}
  .callout.tip{border-color:var(--green);background:var(--green-tint)}
  .callout p{margin:0 0 12px}
  .callout p:last-child{margin-bottom:0}
  .callout .ttl{font-weight:900;font-size:var(--fs-body);color:var(--ink);display:block;margin-bottom:4px}
  .b-caution{color:var(--orange-dark)}
  .b-safe{color:var(--teal-dark)}
  .callout.tip b,.callout.tip .ttl{color:var(--green-strong)}
  .rights-title{
    font-size:var(--fs-body);font-weight:900;color:var(--green-strong);margin:14px 0 6px;letter-spacing:.01em;
  }
  .rights-title:first-child{margin-top:0}
  .rights{list-style:none;margin:0;padding:0}
  .rights li{
    position:relative;padding-left:28px;margin:8px 0;font-size:var(--fs-body);line-height:1.7;
  }
  .rights li.ok::before,.rights li.no::before{
    position:absolute;left:0;top:1px;font-size:var(--fs-body);
  }
  .rights li.ok::before{content:"⭕"}
  .rights li.no::before{content:"❌"}
  /* panel: 点線なし・枠なし・影なしの白背景まとまり。本文がほとんどデザインのない文章ばかりのセクションで、寂しさをなくし読みやすさを保つために本文を白地でまとめる */
  .panel{
    background:var(--white);border-radius:var(--radius-sm);
    padding:18px 22px;margin:16px 0;
    font-size:var(--fs-body);color:var(--ink);line-height:1.85;
  }
  .panel > :first-child{margin-top:0}
  .panel > :last-child{margin-bottom:0}

  /* term link */
  a.term{
    color:var(--teal);text-decoration:underline;text-decoration-style:dotted;
    text-underline-offset:3px;font-weight:400;
  }
  a.term:hover{color:var(--teal-dark)}

  /* ---------- Glossary ---------- */
  .gloss{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-m)}
  @media(max-width:680px){.gloss{grid-template-columns:1fr}}
  .gloss-card{
    background:var(--white);border:1px solid var(--line);border-radius:var(--radius-sm);
    padding:18px 20px;box-shadow:var(--shadow-sm);
  }
  .gloss-card dt{
    font-weight:700;color:var(--teal-dark);font-size:var(--fs-body);margin:0 0 6px;
    display:flex;align-items:center;gap:8px;
  }
  .gloss-card dt::before{
    content:"";width:8px;height:8px;border-radius:50%;background:var(--green);flex:0 0 auto;
  }
  .gloss-card dd{margin:0;font-size:var(--fs-small);color:var(--sub);line-height:1.8}

  /* ---------- Compare cards ---------- */
  .compare{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-m);margin:18px 0 0}
  @media(max-width:680px){.compare{grid-template-columns:1fr}}
  .compare-card{
    background:var(--white);border:1px solid var(--line);border-radius:var(--radius-sm);
    overflow:hidden;box-shadow:var(--shadow-sm);
  }
  .compare-card.yes{border-color:var(--warm-a)}
  .compare-card.no{border-color:var(--warm-b)}
  .compare-card h3,.compare-card h4{margin:0;padding:12px 20px;font-size:var(--fs-body);font-weight:900;color:var(--ink)}
  .compare-card.yes h3,.compare-card.yes h4{background:var(--warm-a)}
  .compare-card.no h3,.compare-card.no h4{background:var(--warm-b)}
  .compare-card ul{list-style:none;margin:0;padding:14px 20px 16px}
  .compare-card li{position:relative;padding-left:24px;margin:9px 0;font-size:var(--fs-body);line-height:1.7;color:var(--ink-soft)}
  .compare-card li::before{
    content:"";position:absolute;left:3px;top:9px;width:9px;height:9px;border-radius:50%;
  }
  .compare-card.yes li::before{background:var(--warm-a)}
  .compare-card.no li::before{background:var(--warm-b)}

  /* ---------- CTA footer ---------- */
  .cta{
    background:var(--teal-dark);color:#fff;text-align:center;
    padding:60px 20px;border-bottom:none;
  }
  .cta h2{font-size:var(--fs-h2);font-weight:900;margin:0 0 12px}
  .cta p{margin:0 auto;max-width:600px;color:rgba(255,255,255,.9);font-size:var(--fs-body)}
  .cta .accent{height:4px;width:60px;background:var(--yellow);margin:0 auto 24px;border-radius:999px}
  footer{background:var(--teal-dark);color:rgba(255,255,255,.88);text-align:center;padding:22px;font-size:var(--fs-small)}

  /* ---------- Mobile ---------- */
  @media(max-width:600px){
    section{padding:40px 0}
    .section-head h2{font-size:var(--fs-title)}
    .hero-pitch--band{padding:18px 16px}

    /* price estimate: stack label / value */
    .estimate-head{padding:16px 18px}
    .estimate-body{padding:6px 18px 18px}
    .estimate-row{flex-direction:column;align-items:flex-start;gap:1px}
    .estimate-row .val{white-space:normal}
    .estimate-row.total{padding-top:14px}
    .estimate-row.total .val{font-size:var(--fs-title)}
    .estimate-foot{padding:14px 18px}

    /* tables: 1枚のテーブル風（縦並びの行が薄い線で区切られる）。
       以前のような行ごとのカード化（影・角丸）はやめて、項目が一覧であることを伝える */
    .table-card{background:var(--white);border:1px solid var(--line);box-shadow:var(--shadow-sm);border-radius:var(--radius);overflow:hidden}
    .table-scroll{overflow:visible}
    table{min-width:0;font-size:var(--fs-body)}
    thead{display:none}
    table,tbody,tr,td,th{display:block;width:auto}
    tbody tr{
      background:transparent;border:none;border-top:1px solid var(--line);
      box-shadow:none;border-radius:0;padding:16px 18px;margin:0;
    }
    tbody tr:first-child{border-top:none}
    /* 既定の zebra（偶数行のティント色）はスマホでは無効化（縦並びで色分けの利点がないため） */
    tbody tr:nth-child(even){background:transparent}
    tbody td{border-top:none;padding:0;margin:3px 0;line-height:1.75}
    /* 1セル目（項目名）はティール帯＋白文字で「見出し」として目立たせる。
       行 padding の外まで負マージンで広げて、行内ヘッダー風に見せる */
    tbody td:first-child{
      background:var(--teal);color:#fff;font-weight:700;font-size:var(--fs-body);
      margin:-16px -18px 10px;padding:10px 18px;border-bottom:none;
    }
    /* 1行目の見出しはテーブル容器の角丸に合わせて上の角を丸める（容器の border 1px を差し引く） */
    tbody tr:first-child td:first-child{
      border-top-left-radius:calc(var(--radius) - 1px);
      border-top-right-radius:calc(var(--radius) - 1px);
    }
    /* ティール背景の上では .term の文字色を白に反転（点線下線も白系に） */
    tbody td:first-child a.term{color:#fff;text-decoration-color:rgba(255,255,255,.7)}
    /* 料金は説明と同じサイズで揃え、間に行 padding 内に収まる薄い区切り線を入れる */
    td.price-col{
      white-space:normal;font-size:var(--fs-body);color:var(--teal-dark);
      padding-bottom:10px;border-bottom:1px solid var(--line);margin-bottom:10px;
    }
    td.note-col{color:var(--sub);font-size:var(--fs-body)}

    /* two-column info table (お支払い) -> label above value */
    .table-2col tbody tr:nth-child(even){background:transparent}
    .table-2col tbody th{
      display:block;width:auto;background:transparent;border-top:none;
      color:var(--teal-dark);font-size:var(--fs-body);padding:0 0 4px;
    }
    .table-2col tbody td{padding:0}
  }

  /* ---------- 制作者について ---------- */
  .about-card{
    background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
    box-shadow:var(--shadow);padding:28px;
    display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
    grid-template-areas:"face cat1 cat2" "facecap cat1cap cat2cap" "text text text";
    align-items:start;
  }
  .a-face{grid-area:face}
  .a-cat1{grid-area:cat1}
  .a-cat2{grid-area:cat2}
  .cap-face{grid-area:facecap}
  .cap-cat1{grid-area:cat1cap}
  .cap-cat2{grid-area:cat2cap}
  .ph-img{width:100%;height:auto;aspect-ratio:1/1;object-fit:cover;border-radius:var(--radius-sm);display:block}
  .cap{text-align:center;font-weight:900;font-size:var(--fs-body);margin:6px 0 0;color:var(--ink)}
  .cap small{display:block;font-weight:400;font-size:var(--fs-small);color:var(--sub);margin-top:3px}
  .about-text{grid-area:text;margin-top:8px}
  .about-text p{margin:0 0 18px;font-size:var(--fs-body);line-height:1.85}
  .about-text p:last-child{margin-bottom:0}
  @media(max-width:600px){
    .about-card{
      grid-template-columns:1fr;
      grid-template-areas:"face" "facecap" "text" "cat1" "cat1cap" "cat2" "cat2cap";
      gap:0;padding:20px;
    }
    .a-face,.a-cat1,.a-cat2{max-width:260px;margin-left:auto;margin-right:auto}
    .a-cat1,.a-cat2{margin-top:18px}
    .about-text{margin-top:16px}
  }

  /* ---------- Contact form ---------- */
  .contact-form{max-width:520px;margin:28px auto 0;text-align:left}
  .cf-row{margin:0 0 16px}
  .contact-form label,.contact-form .cf-label{display:block;font-size:var(--fs-small);font-weight:700;color:#fff;margin:0 0 6px}
  .cf-radio-group{display:flex;flex-direction:column;gap:8px}
  .contact-form .cf-radio{display:flex;align-items:flex-start;gap:8px;margin:0;font-size:var(--fs-body);font-weight:400;color:#fff;cursor:pointer;line-height:1.5}
  .contact-form .cf-radio input[type=radio]{
    width:1.1em;height:1.1em;flex:0 0 auto;margin:0;
    /* 第1行のテキストの垂直中心にラジオの中心を合わせる */
    margin-top:calc((1em * 1.5 - 1.1em) / 2);
    accent-color:var(--yellow);
  }
  .contact-form input[type=radio]:focus,.contact-form input[type=radio]:focus-visible{outline:none}
  .contact-form input,.contact-form textarea{
    width:100%;font:inherit;font-size:var(--fs-body);color:var(--ink);background:#fff;
    border:1px solid rgba(255,255,255,.55);border-radius:var(--radius-sm);padding:12px 14px;line-height:1.6;
  }
  .contact-form textarea{resize:vertical}
  .contact-form input:focus,.contact-form textarea:focus{outline:2px solid var(--yellow);outline-offset:1px}
  .h-captcha{margin-bottom:16px}
  .cf-submit{
    display:block;width:fit-content;margin:4px auto 0;cursor:pointer;background:var(--yellow);color:var(--ink);
    font:inherit;font-weight:900;font-size:var(--fs-body);border:none;border-radius:999px;
    padding:13px 40px;box-shadow:var(--shadow-sm);
  }
  .cf-submit:hover{background:var(--yellow-hover)}
  .cf-hp{display:none !important}
  /* お問い合わせの送信結果モーダル（白カードの主役形＋暗幕） */
  .cf-modal[hidden]{display:none}
  .cf-modal{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:20px}
  .cf-modal-backdrop{position:absolute;inset:0;background:rgba(40,51,50,.55);animation:cf-fade var(--dur-fast) ease}
  .cf-modal-box{position:relative;width:90%;max-width:420px;background:var(--white);color:var(--ink);
    border-radius:var(--radius);box-shadow:var(--shadow);padding:26px 24px;outline:none;animation:cf-pop var(--dur-fast) ease}
  .cf-modal-text{margin:0;font-size:var(--fs-body);font-weight:700;white-space:pre-line}
  .cf-modal-box.err .cf-modal-text{color:var(--orange-dark)}
  .cf-modal-close{margin:20px 0 0;cursor:pointer;background:var(--teal);color:#fff;font:inherit;font-weight:900;
    font-size:var(--fs-body);border:none;border-radius:999px;padding:11px 30px;transition:background var(--dur-fast)}
  .cf-modal-close:hover{background:var(--teal-dark)}
  .cf-modal-close[hidden]{display:none}
  @keyframes cf-fade{from{opacity:0}to{opacity:1}}
  @keyframes cf-pop{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

  /* ---------- 詳細を覗き見するモーダル（ページ内アンカーをクリックで開く） ---------- */
  /* 目次以外の本文中アンカーをスクリプトが拾い、対象セクションを動的に複製して中央に開く。
     幅は本文と同じ最大幅まで広げ、内容が窮屈に見えないようにする。 */
  .pop-modal[hidden]{display:none}
  .pop-modal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px}
  .pop-modal-backdrop{position:absolute;inset:0;background:rgba(40,51,50,.55);animation:cf-fade var(--dur-fast) ease}
  .pop-modal-box{position:relative;width:100%;max-width:1080px;max-height:calc(100vh - 48px);
    background:var(--bg);color:var(--ink);border-radius:var(--radius);box-shadow:var(--shadow);
    display:flex;flex-direction:column;outline:none;animation:cf-pop var(--dur-fast) ease}
  /* × だけの軽い閉じる印。背景・枠なしで、本文と被っても透けて見える位置に置く */
  .pop-modal-close{position:absolute;top:6px;right:10px;width:28px;height:28px;border:none;
    background:transparent;color:var(--sub);font-size:26px;font-weight:400;line-height:1;
    cursor:pointer;z-index:2;padding:0}
  .pop-modal-close:hover{color:var(--ink)}
  /* × ぶんの余白を上に確保して本文と被らないようにする */
  .pop-modal-body{overflow:auto;padding:36px 28px 32px;border-radius:var(--radius)}
  .pop-modal-body>*:first-child{margin-top:0}
  .pop-modal-body>*:last-child{margin-bottom:0}
  /* セクションを丸ごと複製したときの上余白を詰める（モーダル側の padding に任せる） */
  .pop-modal-body .section-head{margin-top:0}
  /* 複製した .wrap は外側の余白を解除して、モーダル側の余白だけで揃える */
  .pop-modal-body .wrap{padding:0;max-width:none}
  @media(max-width:680px){
    /* 全画面ではなく四辺に背景が見える形にして、別ページに切り替わったように見えるのを防ぐ。
       内側の padding は控えめに、外側の暗幕で「モーダル」感を出す。 */
    .pop-modal{padding:14px}
    .pop-modal-box{max-width:none;width:100%;max-height:calc(100vh - 28px);border-radius:var(--radius)}
    .pop-modal-body{padding:36px 18px 24px;border-radius:var(--radius)}
  }

  /* ---------- Floating contact button ---------- */
  .fab{
    position:fixed;right:16px;bottom:16px;z-index:50;
    display:inline-flex;align-items:center;gap:6px;text-decoration:none;
    background:var(--teal);color:#fff;font-weight:700;font-size:var(--fs-body);
    padding:12px 20px;border:2px solid #fff;border-radius:999px;
    box-shadow:var(--shadow-float);
  }
  .fab:hover{background:var(--teal-dark)}
  @media(max-width:600px){.fab{right:12px;bottom:12px;padding:11px 18px;font-size:var(--fs-small)}}

  /* ---------- 目次ボタン（PCは右上に浮く／スマホはバー内）＋ スライド目次 ---------- */
  .menu-btn{
    position:fixed;top:10px;right:18px;z-index:65;
    display:inline-flex;align-items:center;justify-content:center;
    padding:9px 20px;border:2px solid #fff;border-radius:999px;cursor:pointer;
    background:var(--teal);color:#fff;font:inherit;font-weight:700;font-size:var(--fs-small);
    box-shadow:var(--shadow-float);
    white-space:nowrap;flex-shrink:0;
  }
  .menu-btn:hover{background:var(--teal-dark)}
  .menu-btn:focus-visible{outline-color:#fff;outline-offset:3px}
  .drawer-overlay{
    position:fixed;inset:0;z-index:70;background:rgba(0,0,0,.45);
    opacity:0;visibility:hidden;transition:opacity var(--dur-slow),visibility var(--dur-slow);
  }
  .drawer-overlay.open{opacity:1;visibility:visible}
  .drawer{
    position:fixed;top:0;right:0;z-index:80;height:100%;width:min(300px,82vw);
    background:var(--white);box-shadow:-12px 0 30px -12px rgba(0,0,0,.35);
    transform:translateX(100%);transition:transform var(--dur-slow) ease;
    padding:20px 22px;overflow-y:auto;
  }
  .drawer.open{transform:translateX(0)}
  .drawer-close{
    position:absolute;top:10px;right:35px;width:40px;height:40px;
    display:flex;align-items:center;justify-content:center;
    border:none;background:none;cursor:pointer;
    font-size:var(--fs-h2);line-height:1;color:var(--sub);
  }
  .drawer-title{font-size:var(--fs-h3);font-weight:900;line-height:1;margin:-2px 0 6px}
  /* スライド目次本体はコンパクトに */
  #drawer-body .toc-list a{padding:5px 2px}

  /* ---------- 固定ナビ（上部に追従） ---------- */
  .navbar{
    position:fixed;top:0;left:0;right:0;z-index:var(--z-navbar);height:var(--navbar-h);
    background:var(--white);border-bottom:1px solid var(--line);transition:box-shadow var(--dur-fast);
  }
  .navbar.scrolled{box-shadow:var(--shadow-sm)}
  .navbar-in{
    max-width:var(--maxw);height:100%;margin:0 auto;padding:0 20px;
    display:flex;align-items:center;gap:16px;
  }
  .navbar-brand{display:flex;align-items:center;gap:10px;text-decoration:none;white-space:nowrap;flex-shrink:0}
  .navbar-logo{height:30px;width:auto;display:block}
  .navbar-name{font-weight:900;font-size:var(--fs-body);color:var(--ink);letter-spacing:.01em}
  .navbar-brand:hover .navbar-name{color:var(--teal-dark)}
  .navbar-links{display:flex;align-items:center;gap:22px;list-style:none;margin:0 0 0 auto;padding:0}
  .navbar-links a{color:var(--ink);text-decoration:none;font-size:var(--fs-small);font-weight:700;white-space:nowrap;transition:color var(--dur-fast)}
  .navbar-links a:hover{color:var(--teal-dark)}
  /* PC: 目次は右上に浮くので、リンクが潜らないよう右側を空ける */
  @media(min-width:701px){
    .navbar-in{padding-right:108px}
  }
  /* スマホ: 屋号はロゴのみ。目次はバー内に置く。閉じる×は目次の位置に合わせる */
  @media(max-width:700px){
    .navbar{height:var(--navbar-h-sp)}
    .navbar-name{display:none}
    .navbar-in{padding:0 12px;gap:10px}
    .navbar-links{gap:12px;font-size:var(--fs-micro)}
    .navbar-links a{font-size:var(--fs-micro)}
    .navbar .menu-btn{position:static;z-index:auto;box-shadow:none;padding:7px 12px;font-size:var(--fs-micro)}
    .drawer-close{top:6px;right:28px}
    .drawer-title{margin:-6px 0 4px}
    body{padding-top:var(--navbar-h-sp)}
    [id]{scroll-margin-top:24px}
    .callout[id]{scroll-margin-top:calc(var(--navbar-h-sp) + 24px)}
  }

  /* ---------- 汎用ボタン ---------- */
  .btn{
    display:inline-flex;align-items:center;justify-content:center;gap:8px;text-decoration:none;
    font:inherit;font-weight:700;font-size:var(--fs-body);line-height:1;cursor:pointer;
    padding:13px 28px;border-radius:999px;border:2px solid transparent;
    transition:background var(--dur-fast),border-color var(--dur-fast);
  }
  .btn.-primary{background:var(--teal);color:#fff}
  .btn.-primary:hover{background:var(--teal-dark)}
  .btn.-secondary{background:transparent;color:var(--teal-dark);border-color:var(--teal)}
  .btn.-secondary:hover{background:var(--teal-tint)}
  .btn.-accent{background:var(--yellow);color:var(--ink)}
  .btn.-accent:hover{background:var(--yellow-hover)}
  .btn:disabled,.btn.-disabled{opacity:.5;cursor:not-allowed}
  /* ボタン内に置く「外部リンク（新しいタブで開く）」アイコン。currentColor で文字色に追従。
     SVG の幾何中心は box の上半分に寄っているので、テキストの視覚中心に合うよう少しだけ下にずらす */
  .ic-extlink{width:1em;height:1em;flex:0 0 auto;transform:translateY(.08em)}

  /* ---------- 画像＋キャプション ---------- */
  figure.fig{margin:18px 0;border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;background:var(--white);box-shadow:var(--shadow-sm)}
  figure.fig img,figure.fig .fig-ph{display:block;width:100%;height:auto}
  figure.fig .fig-ph{aspect-ratio:16/9}
  figure.fig figcaption{padding:10px 16px;font-size:var(--fs-small);color:var(--sub);line-height:1.7}

  /* ---------- FAQ / アコーディオン ---------- */
  .faq{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);background:var(--white)}
  .faq details{border-top:1px solid var(--line)}
  .faq details:first-child{border-top:none}
  .faq summary{
    list-style:none;cursor:pointer;padding:16px 20px;font-weight:700;font-size:var(--fs-body);color:var(--ink);
    display:flex;align-items:center;gap:12px;
  }
  .faq summary::-webkit-details-marker{display:none}
  .faq summary::before{
    content:"Q";flex:0 0 auto;width:24px;height:24px;border-radius:50%;
    background:var(--teal-tint);color:var(--teal-dark);font-weight:900;font-size:var(--fs-small);
    display:grid;place-items:center;
  }
  .faq summary::after{
    content:"";margin-left:auto;flex:0 0 auto;width:14px;height:14px;background-color:var(--teal);
    transition:transform var(--dur-fast);
    -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") center/contain no-repeat;
            mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") center/contain no-repeat;
  }
  .faq details[open] summary::after{transform:rotate(180deg)}
  .faq summary:hover{background:var(--teal-tint2)}
  .faq .faq-body{padding:0 20px 18px 56px;font-size:var(--fs-body);color:var(--ink-soft);line-height:1.85}

  /* ---------- お客様の声 ---------- */
  .testimonial{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:24px 26px}
  .testimonial .quote{margin:0;font-size:var(--fs-body);color:var(--ink-soft);line-height:1.9}
  .testimonial .who{display:flex;align-items:center;gap:12px;margin-top:16px}
  .testimonial .who .ph{width:40px;height:40px;border-radius:50%;background:var(--teal-tint);flex:0 0 auto;overflow:hidden}
  .testimonial .who .ph img{width:100%;height:100%;object-fit:cover;display:block}
  .testimonial .who .name{font-weight:700;font-size:var(--fs-small);color:var(--ink)}
  .testimonial .who .name small{display:block;font-weight:400;color:var(--sub);font-size:var(--fs-micro)}

  /* ---------- 制作サンプル（ケースカード） ---------- */
  .case-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-l);margin-top:var(--space-l)}
  @media(max-width:680px){.case-grid{grid-template-columns:1fr}}
  .case{
    display:flex;flex-direction:column;background:var(--white);
    border:1px solid var(--line);border-radius:var(--radius);
    box-shadow:var(--shadow-sm);overflow:hidden;
  }
  .case-thumb{aspect-ratio:16/10;overflow:hidden;background:var(--teal-tint);border-bottom:1px solid var(--line)}
  .case-thumb img{width:100%;height:100%;object-fit:cover;object-position:top;display:block}
  .case-body{padding:20px 22px;display:flex;flex-direction:column;flex:1}
  .case-labels{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin:0 0 8px}
  .case-tag{
    font-size:var(--fs-micro);font-weight:700;color:var(--teal-dark);letter-spacing:.02em;
    background:var(--teal-tint);border-radius:999px;padding:3px 11px;
  }
  .case-fict{font-size:var(--fs-micro);color:var(--sub);letter-spacing:.02em}
  .case h3{margin:0 0 8px;font-size:var(--fs-title);font-weight:900;line-height:1.4}
  .case-desc{margin:0 0 18px;font-size:var(--fs-small);color:var(--sub);line-height:1.85}
  .case .btn{margin-top:auto;align-self:flex-start}

  /* ---------- CTA のボタン並び（teal 背景上） ---------- */
  .cta-actions{display:flex;justify-content:center;flex-wrap:wrap;gap:12px;margin-top:26px}
  .btn.-onteal{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
  .btn.-onteal:hover{background:rgba(255,255,255,.12);border-color:#fff}

  /* ---------- Flow tabs (CSS-only タブ。ラジオで切替) ---------- */
  .flow-tabs{margin:0}
  .flow-tab-input{position:absolute;opacity:0;pointer-events:none}
  .flow-tab-hint{
    font-size:var(--fs-small);color:var(--sub);margin:0 0 10px;
  }
  /* スマホでラベルが縦並び（タブ風に見えない）になる帯域では「クリック」を「タップ」に差し替える */
  .flow-tab-hint .-sp{display:none}
  @media(max-width:600px){
    .flow-tab-hint .-pc{display:none}
    .flow-tab-hint .-sp{display:inline}
  }
  .flow-tab-labels{display:flex;gap:6px;margin:0 0 20px;flex-wrap:wrap}
  .flow-tab-label{
    padding:12px 18px 12px 36px;cursor:pointer;font-size:var(--fs-body);font-weight:700;color:var(--ink);
    background:var(--white);border:2px solid var(--line);border-radius:var(--radius-sm);
    transition:color var(--dur-fast),background var(--dur-fast),border-color var(--dur-fast),box-shadow var(--dur-fast);
    line-height:1.4;position:relative;box-shadow:var(--shadow-sm);
  }
  .flow-tab-label::before{
    content:"";position:absolute;left:14px;top:50%;transform:translateY(-50%);
    width:18px;height:18px;box-sizing:border-box;
    border-radius:50%;border:2px solid var(--line);background:var(--white);
    transition:border-color var(--dur-fast),background var(--dur-fast);
  }
  .flow-tab-label::after{
    content:"";position:absolute;left:20px;top:50%;transform:translateY(-50%) scale(0);
    width:6px;height:6px;border-radius:50%;background:#fff;
    transition:transform var(--dur-fast);
  }
  .flow-tab-label:hover{color:var(--teal-dark);border-color:var(--teal);background:var(--teal-tint2)}
  #flow-tab-a:focus-visible ~ .flow-tab-labels .flow-tab-label[for=flow-tab-a],
  #flow-tab-b:focus-visible ~ .flow-tab-labels .flow-tab-label[for=flow-tab-b]{outline:2px solid var(--focus-ring);outline-offset:2px}
  #flow-tab-a:checked ~ .flow-tab-labels .flow-tab-label[for=flow-tab-a],
  #flow-tab-b:checked ~ .flow-tab-labels .flow-tab-label[for=flow-tab-b]{
    color:#fff;background:var(--teal-dark);border-color:var(--teal-dark);
  }
  #flow-tab-a:checked ~ .flow-tab-labels .flow-tab-label[for=flow-tab-a]::before,
  #flow-tab-b:checked ~ .flow-tab-labels .flow-tab-label[for=flow-tab-b]::before{
    background:var(--teal-dark);border-color:#fff;
  }
  #flow-tab-a:checked ~ .flow-tab-labels .flow-tab-label[for=flow-tab-a]::after,
  #flow-tab-b:checked ~ .flow-tab-labels .flow-tab-label[for=flow-tab-b]::after{transform:translateY(-50%) scale(1)}
  .flow-tab-panel{display:none}
  #flow-tab-a:checked ~ .flow-tab-panel-a,
  #flow-tab-b:checked ~ .flow-tab-panel-b{display:block}
  @media(max-width:600px){
    .flow-tab-labels{flex-direction:column}
    .flow-tab-label{padding:11px 16px 11px 36px;font-size:var(--fs-small);width:100%}
  }

  /* ---------- ご契約・規約まわり 折りたたみ（details） ---------- */
  .terms-fold{
    background:var(--white);border:1px solid var(--line);border-radius:var(--radius-sm);
    box-shadow:var(--shadow-sm);margin:0 0 12px;overflow:hidden;
  }
  .terms-fold[id]{scroll-margin-top:calc(var(--navbar-h) + 16px)}
  .terms-fold > summary{
    cursor:pointer;list-style:none;padding:14px 22px;
    display:flex;align-items:center;justify-content:space-between;gap:12px;
    font-size:var(--fs-body);font-weight:900;color:var(--ink);line-height:1.4;
  }
  .terms-fold > summary::-webkit-details-marker{display:none}
  .terms-fold > summary::after{
    content:"";flex:0 0 auto;width:12px;height:12px;
    border-right:2.4px solid var(--teal-dark);border-bottom:2.4px solid var(--teal-dark);
    transform:rotate(45deg) translate(-3px,-3px);
    transition:transform var(--dur-fast);
  }
  .terms-fold[open] > summary::after{transform:rotate(-135deg) translate(-3px,-3px)}
  .terms-fold > summary:hover{background:var(--teal-tint2)}
  .terms-fold-body{padding:22px;border-top:1px solid var(--line)}
  .terms-fold-body > :first-child{margin-top:0}
  .terms-fold-body > h3:first-child{margin-top:6px}
  @media(max-width:680px){
    .terms-fold > summary{padding:12px 16px;font-size:var(--fs-small)}
    .terms-fold-body{padding:18px 16px}
  }
  @media(max-width:600px){
    #terms[id]{scroll-margin-top:calc(var(--navbar-h-sp) + 16px)}
    .terms-fold[id]{scroll-margin-top:calc(var(--navbar-h-sp) + 16px)}
  }

  /* estimate 行の label に <small> を入れた場合（年2以降の補足） */
  .estimate-row .label small{display:block;font-size:var(--fs-micro);color:var(--sub);font-weight:400;margin-top:2px;letter-spacing:.02em}

  /* ---------- 動きの軽減（OS設定を尊重） ---------- */
  @media(prefers-reduced-motion:reduce){
    *,*::before,*::after{
      transition-duration:.001ms!important;animation-duration:.001ms!important;
      animation-iteration-count:1!important;
    }
  }
