    /* ── サービスページ専用スタイル ── */

    .service-intro {
      font-family: var(--font-serif);
      font-size: 1.05rem;
      color: var(--text-mid);
      line-height: 2.1;
      margin-bottom: 16px;
    }
    .service-note {
      font-size: 0.85rem;
      color: var(--text-soft);
      line-height: 1.9;
      background: var(--accent-light);
      border-left: 3px solid var(--accent);
      padding: 16px 20px;
      border-radius: 0 6px 6px 0;
      margin-top: 16px;
    }

    /* サービスカード */
    .service-cards {
      display: flex;
      flex-direction: column;
      gap: 40px;
      margin-top: 56px;
    }

    .service-card {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 0;
      border: 1px solid var(--border);
      border-radius: 12px;
      overflow: hidden;
      background: var(--white);
    }
    .service-card-body {
      padding: 40px 36px;
    }
    .service-card-aside {
      background: var(--off-white);
      border-left: 1px solid var(--border);
      padding: 40px 32px;
      display: flex;
      flex-direction: column;
      justify-content: space-between;
    }

    .service-type {
      display: inline-block;
      font-size: 0.65rem;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: var(--accent);
      font-weight: 600;
      margin-bottom: 12px;
    }
    .service-title {
      font-family: var(--font-serif);
      font-size: 1.5rem;
      font-weight: 400;
      color: var(--text-dark);
      margin-bottom: 16px;
      line-height: 1.4;
    }
    .service-desc {
      font-size: 0.88rem;
      color: var(--text-mid);
      line-height: 2.1;
      margin-bottom: 24px;
    }
    .service-points {
      display: flex;
      flex-direction: column;
      gap: 10px;
    }
    .service-point {
      display: flex;
      align-items: baseline;
      gap: 10px;
      font-size: 0.85rem;
      color: var(--text-mid);
      line-height: 1.6;
    }
    .service-point::before {
      content: '—';
      color: var(--accent);
      font-size: 0.72rem;
      flex-shrink: 0;
    }

    .service-price-block {
      margin-bottom: 24px;
    }
    .service-price-label {
      font-size: 0.68rem;
      letter-spacing: 0.12em;
      color: var(--text-soft);
      text-transform: uppercase;
      margin-bottom: 8px;
    }
    .service-price {
      font-family: var(--font-serif);
      font-size: 1.8rem;
      font-weight: 400;
      color: var(--text-dark);
      line-height: 1.2;
    }
    .service-price span {
      font-size: 0.85rem;
      color: var(--text-soft);
      font-family: var(--font-sans);
      margin-left: 4px;
    }
    .service-price-sub {
      font-size: 0.75rem;
      color: var(--text-soft);
      margin-top: 4px;
    }

    .service-tags {
      display: flex;
      flex-wrap: wrap;
      gap: 6px;
      margin-bottom: 28px;
    }
    .service-tag {
      font-size: 0.68rem;
      color: var(--accent);
      background: var(--accent-light);
      padding: 3px 10px;
      border-radius: 2px;
    }

    /* 比較テーブル */
    .compare-section { margin-top: 80px; }
    .compare-table {
      width: 100%;
      border-collapse: collapse;
      margin-top: 32px;
      font-size: 0.87rem;
    }
    .compare-table th,
    .compare-table td {
      padding: 14px 20px;
      text-align: left;
      border-bottom: 1px solid var(--border);
      vertical-align: middle;
    }
    .compare-table thead th {
      background: var(--text-dark);
      color: var(--white);
      font-weight: 500;
      font-size: 0.8rem;
      letter-spacing: 0.04em;
    }
    .compare-table thead th:first-child { border-radius: 6px 0 0 0; }
    .compare-table thead th:last-child  { border-radius: 0 6px 0 0; }
    .compare-table tbody tr:nth-child(even) { background: var(--off-white); }
    .compare-table tbody tr:hover { background: var(--accent-light); }
    .compare-table .check { color: var(--accent); font-weight: 600; }
    .compare-table .dash  { color: var(--text-soft); }

    /* 向いている / 向いていない */
    .fit-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 28px;
      margin-top: 40px;
    }
    .fit-card { border-radius: 8px; padding: 30px 26px; }
    .fit-yes { background: var(--accent-light); border: 1px solid #c5d9ca; }
    .fit-no  { background: var(--light-gray);   border: 1px solid var(--border); }
    .fit-label {
      font-size: 0.68rem; letter-spacing: 0.14em;
      font-weight: 700; margin-bottom: 18px;
    }
    .fit-yes .fit-label { color: var(--accent); }
    .fit-no  .fit-label { color: var(--text-soft); }
    .fit-list li {
      font-size: 0.87rem; color: var(--text-mid); line-height: 1.65;
      display: flex; align-items: baseline; gap: 9px; margin-bottom: 11px;
    }
    .fit-yes .fit-list li::before { content: '—'; color: var(--accent); }
    .fit-no  .fit-list li::before { content: '—'; color: var(--text-soft); }
    .fit-note {
      margin-top: 24px; font-size: 0.82rem;
      color: var(--text-soft); text-align: center; line-height: 1.8;
    }

    /* 締め CTA */
    .final-cta { text-align: center; max-width: 520px; margin: 0 auto; }
    .final-cta-pre { font-family: var(--font-serif); font-size: 1.02rem; color: var(--text-mid); line-height: 2; margin-bottom: 32px; }
    .final-cta-title { font-family: var(--font-serif); font-size: clamp(1.4rem, 4vw, 1.9rem); font-weight: 400; color: var(--text-dark); line-height: 1.55; margin-bottom: 14px; }
    .final-cta-sub { font-size: 0.87rem; color: var(--text-soft); line-height: 2; margin-bottom: 32px; }
    .final-cta-note { font-size: 0.73rem; color: var(--text-soft); margin-top: 12px; }

    @media (max-width: 860px) {
      .service-card { grid-template-columns: 1fr; }
      .service-card-aside { border-left: none; border-top: 1px solid var(--border); }
      .fit-grid { grid-template-columns: 1fr; gap: 16px; }
      .compare-table { font-size: 0.8rem; }
      .compare-table th,
      .compare-table td { padding: 11px 12px; }
    }
    @media (max-width: 520px) {
      .service-card-body,
      .service-card-aside { padding: 28px 20px; }
      .compare-table { display: block; overflow-x: auto; }
    }
  
