/* ===== Page-specific overrides ===== */
  .svc-hero__title { font-size: clamp(24px, 2.6vw, 34px); line-height: 1.45; }

  /* Executive Summary lead - full width */
  .svc-summary-lead--full {
    font-family: var(--font-jp); font-weight: 700;
    font-size: clamp(20px, 2.2vw, 28px); line-height: 1.75;
    letter-spacing: 0.02em; color: var(--color-text);
    max-width: none; margin: 0 0 40px;
  }
  .svc-summary-lead--full em { font-style: normal; color: var(--color-accent); font-weight: 900; }

  /* 15 Solutions — 3 independent rounded cards (1 row), with item-hover reaction */
  .svc-15 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; counter-reset: svc15; }
  .svc-15__col {
    padding: 40px 28px 32px;
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: 24px;
    text-align: center;
    transition: transform var(--transition), border-color var(--transition), box-shadow var(--transition);
  }
  .svc-15__col:hover {
    border-color: var(--color-accent);
    transform: translateY(-3px);
    box-shadow: 0 18px 40px -22px rgba(216,90,48,0.25);
  }
  .svc-15__head {
    font-family: var(--font-jp); font-weight: 900;
    font-size: 17px; letter-spacing: 0.08em; color: #fff;
    padding: 10px 22px; border-radius: 999px;
    display: inline-block; margin: 0 0 28px;
  }
  .svc-15__head--strategy { background: var(--color-text); }
  .svc-15__head--ops { background: var(--color-accent); }
  .svc-15__head--impl { background: #5a5a5a; }
  .svc-15__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
  .svc-15__list li {
    counter-increment: svc15;
    font-family: var(--font-jp); font-weight: 800;
    font-size: 15px; color: var(--color-text);
    padding: 14px 18px;
    background: var(--color-bg-alt);
    border: 1px solid transparent;
    border-radius: 12px;
    display: flex; align-items: center; gap: 14px;
    text-align: left;
    cursor: default;
    transition: background var(--transition), border-color var(--transition), transform 240ms cubic-bezier(0.22,1,0.36,1), box-shadow var(--transition);
  }
  .svc-15__list li:hover {
    background: #fff;
    border-color: var(--color-accent);
    transform: translateX(4px);
    box-shadow: 0 8px 18px -10px rgba(216,90,48,0.28);
  }
  .svc-15__list li::before {
    content: counter(svc15, decimal-leading-zero);
    font-family: var(--font-en); font-weight: 900;
    font-size: 13px; letter-spacing: 0.04em;
    color: var(--color-accent);
    flex-shrink: 0;
    min-width: 28px;
    transition: transform 240ms cubic-bezier(0.22,1,0.36,1), color var(--transition);
  }
  .svc-15__list li:hover::before {
    color: var(--color-accent-dark);
    transform: scale(1.18);
  }

  /* Problems — larger version */
  .svc-problems-x { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
  .svc-problem-x { padding: 48px 38px; background: #fff; border: 1px solid var(--color-border); border-radius: 24px; transition: all var(--transition); position: relative; }
  .svc-problem-x:hover { transform: translateY(-3px); border-color: var(--color-text); box-shadow: 0 14px 36px -18px rgba(20,20,20,0.18); }
  .svc-problem-x__cat { font-family: var(--font-en); font-weight: 800; font-size: 12px; letter-spacing: 0.16em; color: var(--color-accent); margin-bottom: 14px; text-transform: uppercase; }
  .svc-problem-x__title {
    font-family: var(--font-jp); font-weight: 900;
    font-size: clamp(20px, 2.1vw, 26px); line-height: 1.4;
    letter-spacing: 0.02em; color: var(--color-text);
    margin: 0 0 28px; padding-bottom: 22px;
    border-bottom: 1px solid var(--color-border);
    word-break: keep-all;
  }
  .svc-problem-x__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 14px; }
  .svc-problem-x__list li {
    font-family: var(--font-jp); font-weight: 500;
    font-size: 14.5px; line-height: 1.75;
    color: var(--color-text-sub); padding-left: 22px; position: relative;
  }
  .svc-problem-x__list li::before {
    content: ""; position: absolute; left: 0; top: 10px;
    width: 12px; height: 2px; background: var(--color-accent);
  }

  /* Solution pillars — bigger */
  .svc-pillars { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
  .svc-pillar { padding: 48px 36px; background: #fff; border: 1px solid var(--color-border); border-radius: 28px; text-align: center; transition: all var(--transition); display: flex; flex-direction: column; }
  .svc-pillar:hover { border-color: var(--color-accent); transform: translateY(-4px); box-shadow: 0 16px 40px -20px rgba(216,90,48,0.3); }
  .svc-pillar__icon-slot {
    width: 120px; height: 120px;
    margin: 0 auto 20px;
    display: flex; align-items: center; justify-content: center;
  }
  .svc-pillar__icon-slot img {
    width: 100%; height: 100%; object-fit: contain;
    display: block;
  }
  .svc-pillar__title {
    font-family: var(--font-jp); font-weight: 900;
    font-size: clamp(18px, 2vw, 24px); line-height: 1.5;
    color: var(--color-text); margin: 0 0 18px;
    word-break: keep-all;
  }
  .svc-pillar__body { font-family: var(--font-jp); font-weight: 500; font-size: 13.5px; line-height: 1.95; color: var(--color-text-sub); margin: 0 0 24px; flex: 1; }
  .svc-pillar__tags { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; }
  .svc-pillar__tag {
    font-family: var(--font-jp); font-weight: 800;
    font-size: 12.5px; letter-spacing: 0.02em;
    padding: 8px 4px; border-radius: var(--radius-pill);
    background: var(--color-accent); color: #fff;
    text-align: center; white-space: nowrap;
  }

  /* Animated jump-arrow at Problems → Solution boundary */
  .svc-jump-arrow {
    position: absolute; left: 50%; bottom: -36px;
    transform: translateX(-50%);
    width: 72px; height: 72px;
    border-radius: 50%;
    background: var(--color-accent); color: #fff;
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 14px 32px -12px rgba(216,90,48,0.55);
    z-index: 5; cursor: pointer;
    animation: svcJumpBounce 1.6s ease-in-out infinite;
    transition: background var(--transition), transform var(--transition);
  }
  .svc-jump-arrow:hover { background: var(--color-accent-dark); }
  .svc-jump-arrow svg { width: 28px; height: 28px; }
  @keyframes svcJumpBounce {
    0%, 100% { transform: translateX(-50%) translateY(0); }
    50%      { transform: translateX(-50%) translateY(10px); }
  }
  @media (prefers-reduced-motion: reduce) { .svc-jump-arrow { animation: none; } }

  /* Process — single-row rounded cards, hover applies to whole card */
  .svc-pflow {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 14px;
    position: relative;
    padding: 12px 0;
  }
  .svc-pflow__card {
    background: #fff;
    border: 2px solid var(--color-border);
    border-radius: 20px;
    padding: 28px 16px 24px;
    position: relative;
    text-align: center;
    display: flex; flex-direction: column;
    align-items: center;
    cursor: default;
    z-index: 1;
    transition:
      border-color 280ms cubic-bezier(0.22, 1, 0.36, 1),
      transform 280ms cubic-bezier(0.22, 1, 0.36, 1),
      box-shadow 280ms cubic-bezier(0.22, 1, 0.36, 1),
      background 280ms ease;
  }
  .svc-pflow__card:hover {
    border-color: var(--color-accent);
    transform: translateY(-8px);
    box-shadow: 0 24px 46px -18px rgba(216,90,48,0.34);
    background: linear-gradient(180deg, #fff 0%, #FFF6F0 100%);
  }
  .svc-pflow__phase {
    font-family: var(--font-en); font-weight: 800;
    font-size: 10px; letter-spacing: 0.18em;
    color: var(--color-accent);
    line-height: 1; margin-bottom: 6px;
  }
  .svc-pflow__num {
    font-family: var(--font-en); font-weight: 900;
    font-size: 40px; line-height: 1;
    color: var(--color-accent); letter-spacing: -0.02em;
    margin-bottom: 22px;
    transition: transform 280ms cubic-bezier(0.34, 1.56, 0.64, 1);
  }
  .svc-pflow__card:hover .svc-pflow__num { transform: scale(1.12); }
  .svc-pflow__title {
    font-family: var(--font-jp); font-weight: 900;
    font-size: clamp(16px, 1.6vw, 19px); line-height: 1.4;
    color: var(--color-text); margin: 0 0 22px;
    letter-spacing: 0.02em; word-break: keep-all;
  }
  .svc-pflow__tags {
    display: flex; flex-direction: column; gap: 8px;
    width: 100%;
  }
  .svc-pflow__tag {
    font-family: var(--font-jp); font-weight: 800;
    font-size: 14px; letter-spacing: 0.02em;
    padding: 10px 10px; border-radius: var(--radius-pill);
    background: var(--color-accent); color: #fff;
    text-align: center; line-height: 1.4;
    word-break: keep-all; white-space: normal;
    transition: transform 240ms cubic-bezier(0.22,1,0.36,1);
  }
  .svc-pflow__card:hover .svc-pflow__tag { transform: translateY(-1px); }

  /* Connector arrows between adjacent cards (timeline feel) */
  .svc-pflow__card:not(:last-child)::after {
    content: ""; position: absolute;
    right: -14px; top: 64px;
    width: 0; height: 0;
    border-top: 6px solid transparent;
    border-bottom: 6px solid transparent;
    border-left: 10px solid var(--color-accent);
    z-index: 2;
    opacity: 0.5;
    transition: opacity var(--transition), transform var(--transition);
  }
  .svc-pflow__card:hover::after { opacity: 1; transform: translateX(2px); }

  /* Strengths — no black bg, 2 equal cards with internal numbers */
  .svc-strengths-new { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; align-items: stretch; }
  .svc-strength-x {
    background: #fff; border: 1px solid var(--color-border);
    border-radius: 28px; padding: 44px 40px;
    display: flex; flex-direction: column;
  }
  .svc-strength-x__num {
    font-family: var(--font-en); font-weight: 900;
    font-size: 12px; letter-spacing: 0.16em;
    color: var(--color-accent); margin-bottom: 8px;
  }
  .svc-strength-x__title {
    font-family: var(--font-jp); font-weight: 900;
    font-size: clamp(22px, 2.4vw, 28px); line-height: 1.4;
    color: var(--color-text); margin: 0 0 16px;
  }
  .svc-strength-x__title a { color: var(--color-accent); text-decoration: none; }
  .svc-strength-x__title a:hover { text-decoration: underline; }
  .svc-strength-x__title .ext { font-family: var(--font-en); font-size: 14px; margin-left: 6px; vertical-align: middle; }
  .svc-strength-x__lead {
    font-family: var(--font-jp); font-weight: 500;
    font-size: 14px; line-height: 1.95;
    color: var(--color-text-sub); margin: 0 0 28px;
  }
  /* Internal stat grid */
  .svc-strength-x__stats {
    display: grid; grid-template-columns: repeat(2, 1fr); gap: 0;
    border-top: 1px solid var(--color-border);
    margin-bottom: 24px;
  }
  .svc-strength-x__stat {
    padding: 18px 12px; border-bottom: 1px solid var(--color-border);
    border-right: 1px solid var(--color-border);
  }
  .svc-strength-x__stat:nth-child(2n) { border-right: none; }
  .svc-strength-x__stat-num {
    font-family: var(--font-en); font-weight: 800;
    font-size: clamp(22px, 2.4vw, 28px); line-height: 1;
    color: var(--color-accent); margin-bottom: 6px;
  }
  .svc-strength-x__stat-num .unit { font-size: 0.5em; color: var(--color-text-sub); margin-left: 4px; letter-spacing: 0; }
  .svc-strength-x__stat-label {
    font-family: var(--font-jp); font-weight: 700;
    font-size: 11px; letter-spacing: 0.04em;
    color: var(--color-text-sub); line-height: 1.4;
  }
  /* Strength image / tool preview */
  .svc-strength-x__visuals { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 24px; }
  .svc-strength-x__visual {
    aspect-ratio: 16 / 10;
    border-radius: 14px; overflow: hidden;
    background: linear-gradient(135deg, #1a1a1a 0%, #0f0f0f 100%);
    position: relative;
    display: flex; align-items: center; justify-content: center;
    flex-direction: column;
  }
  .svc-strength-x__visual--small { aspect-ratio: 5 / 3; }
  .svc-strength-x__visual--photo { aspect-ratio: 500 / 480; background: #fff; }
  .svc-strength-x__visual--photo::before { display: none; }
  .svc-strength-x__visual--photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .svc-strength-x__visual-cap {
    position: absolute; bottom: 8px; right: 10px;
    z-index: 2;
    font-family: var(--font-mono); font-size: 9.5px;
    color: rgba(255,255,255,0.55); letter-spacing: 0.04em;
  }
  .svc-strength-x__visual::before {
    content: ""; position: absolute; inset: 0;
    background:
      radial-gradient(ellipse at 30% 30%, rgba(216,90,48,0.18) 0%, transparent 50%),
      radial-gradient(ellipse at 80% 80%, rgba(255,255,255,0.06) 0%, transparent 50%);
  }
  .svc-strength-x__visual-mock {
    position: relative; z-index: 1;
    display: flex; flex-direction: column; gap: 6px;
    width: 80%;
  }
  .svc-strength-x__visual-mock-row {
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 8px; padding: 10px 14px;
    display: flex; justify-content: space-between; align-items: center;
    font-family: var(--font-mono); font-size: 11px;
    color: rgba(255,255,255,0.85);
  }
  .svc-strength-x__visual-mock-row em { color: var(--color-accent); font-style: normal; font-weight: 700; }
  .svc-strength-x__features { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
  .svc-strength-x__features li {
    font-family: var(--font-jp); font-weight: 500;
    font-size: 13px; line-height: 1.6;
    color: var(--color-text); padding-left: 22px; position: relative;
  }
  .svc-strength-x__features li::before {
    content: "✓"; position: absolute; left: 0;
    color: var(--color-accent); font-weight: 800; font-size: 12px;
  }
  .svc-strength-x__features li b {
    font-weight: 800; color: var(--color-text); margin-right: 4px;
  }

  /* Case Study — more visual */
  .svc-case-v {
    display: grid; grid-template-columns: 1fr 1fr; gap: 0;
    border: 1px solid var(--color-border); border-radius: 24px; overflow: hidden;
  }
  .svc-case-v__col { padding: 40px; }
  /* Case bg — outer section is white now, so make BEFORE darker/cream for distinction */
  .svc-case-v { background: #fff; }
  .svc-case-v__col--before { background: var(--color-paper); }
  .svc-case-v__col--after { background: #fff; border-left: 1px solid var(--color-border); }
  .svc-case-v__tag {
    display: inline-block; padding: 6px 14px;
    border-radius: var(--radius-pill);
    font-family: var(--font-en); font-weight: 800;
    font-size: 11px; letter-spacing: 0.14em; margin-bottom: 18px;
  }
  .svc-case-v__tag--before { background: rgba(20,20,20,0.08); color: var(--color-text-sub); }
  .svc-case-v__tag--after { background: var(--color-accent); color: #fff; }
  .svc-case-v__head {
    font-family: var(--font-jp); font-weight: 900;
    font-size: 18px; line-height: 1.5;
    color: var(--color-text); margin: 0 0 24px;
  }
  /* Achievement visual */
  .svc-case-v__chart {
    background: var(--color-bg); border-radius: 14px; padding: 28px 24px;
    margin-bottom: 24px;
    display: flex; align-items: flex-end; gap: 16px;
  }
  .svc-case-v__bar-wrap { flex: 1; text-align: center; }
  .svc-case-v__bar {
    background: linear-gradient(180deg, var(--color-accent) 0%, var(--color-accent-dark) 100%);
    border-radius: 6px 6px 0 0; margin-bottom: 8px;
    position: relative;
  }
  .svc-case-v__bar--before { background: linear-gradient(180deg, #C8C5BD 0%, #A8A59E 100%); height: 8px; }
  .svc-case-v__bar--after { height: 120px; }
  .svc-case-v__bar-label {
    font-family: var(--font-en); font-weight: 800;
    font-size: 11px; letter-spacing: 0.06em;
    color: var(--color-text-sub);
  }
  .svc-case-v__bar-val {
    font-family: var(--font-en); font-weight: 900;
    font-size: 18px; line-height: 1; color: var(--color-text);
    margin-bottom: 4px;
  }
  .svc-case-v__bar--after .svc-case-v__bar-val { color: var(--color-accent); }
  .svc-case-v__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
  .svc-case-v__list li {
    font-family: var(--font-jp); font-weight: 500;
    font-size: 13px; line-height: 1.75; color: var(--color-text-sub);
    padding-left: 22px; position: relative;
  }
  .svc-case-v__list--before li::before { content: "✕"; position: absolute; left: 0; color: var(--color-text-mute); font-weight: 700; }
  .svc-case-v__list--after li::before { content: "✓"; position: absolute; left: 0; color: var(--color-accent); font-weight: 800; }

  /* AFTER列は淡い暖色wash(ダーク不使用)で主役化＋チャート枠の高さを揃える */
  .svc-case-v__col--after { background: linear-gradient(160deg, #FFF3EC 0%, #FCE7DB 100%); border-left: none; }
  .svc-case-v__col--after .svc-case-v__chart { background: #fff; border: 1px solid rgba(216,90,48,0.16); }
  .svc-case-v__bar--after { box-shadow: 0 10px 24px -10px rgba(216,90,48,0.4); }
  .svc-case-v__chart { min-height: 232px; }

  /* Large CTA at bottom of page — generous bottom spacing before footer area */
  .svc-page-cta {
    padding: 120px max(40px, 8.3vw) 100px;
    background: linear-gradient(180deg, var(--color-bg-alt) 0%, var(--color-bg) 100%);
    text-align: center;
  }
  .svc-page-cta__title {
    font-family: var(--font-jp); font-weight: 900;
    font-size: clamp(28px, 3.4vw, 42px); line-height: 1.4;
    color: var(--color-text); margin: 0 0 24px;
    letter-spacing: 0.02em;
  }
  .svc-page-cta__title .dot { color: var(--color-accent); }
  .svc-page-cta__body {
    font-family: var(--font-jp); font-weight: 500;
    font-size: clamp(14.5px, 1.3vw, 16px); line-height: 2;
    color: var(--color-text-sub); margin: 0 auto 48px;
    max-width: 680px;
  }
  .svc-page-cta__ctas { display: inline-flex; gap: 16px; flex-wrap: wrap; justify-content: center; margin-bottom: 64px; }
  .svc-page-cta__ctas .svc-hero__cta { padding: 18px 36px; font-size: 15px; }

  /* Slide thumbnails */
  .svc-slides { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; max-width: 1180px; margin: 0 auto; }
  .svc-slide {
    aspect-ratio: 16 / 9;
    background: #fff; border: 1px solid var(--color-border);
    border-radius: 6px; overflow: hidden;
    transition: all var(--transition);
    display: block;
    position: relative; text-decoration: none; color: inherit;
  }
  .svc-slide:hover { transform: translateY(-3px); border-color: var(--color-accent); box-shadow: 0 14px 32px -18px rgba(216,90,48,0.25); }
  .svc-slide__img {
    display: block; width: 100%; height: 100%; object-fit: cover;
    background: #fff;
  }
  .svc-slides-note {
    text-align: center; margin-top: 20px;
    font-family: var(--font-jp); font-weight: 500;
    font-size: 12px; color: var(--color-text-mute);
  }

  @media (max-width: 1024px) {
    .svc-15 { grid-template-columns: 1fr; }
    .svc-15__col { border-right: none; border-bottom: 1px solid var(--color-border); }
    .svc-15__col:last-child { border-bottom: none; }
    .svc-problems-x, .svc-pillars { grid-template-columns: 1fr; }
    .svc-flow { grid-template-columns: 1fr; gap: 28px; }
    .svc-flow-card:not(:last-child)::after { content: none; }
    .svc-flow-link { display: none; }
    .svc-strengths-new { grid-template-columns: 1fr; }
    .svc-case-v { grid-template-columns: 1fr; }
    .svc-case-v__col--after { border-left: none; border-top: 1px solid var(--color-border); }
    .svc-slides { grid-template-columns: repeat(2, 1fr); max-width: 720px; }
  }
  @media (max-width: 600px) {
    .svc-slides { grid-template-columns: 1fr; max-width: 400px; }
  }
