@charset "UTF-8";
/* =========================================================
   Service page (body.is-service-page) – legacy service.css 移植
   layout.css の :not(.front-page) 強制ルールを打ち消す + 本来のレイアウトを復活
========================================================= */

/* ===== Color vars / typography (this page only) ===== */
body.is-service-page{
	--gd:#082e22;--gm:#0f6e56;--gl:#1d9e75;--gp:#e1f5ee;--gs:#f2faf7;
	--ink:#1a1a18;--im:#3d3d3a;--il:#6e6e6a;--iu:#9e9e9a;--bd:#e0ddd6;--bg:#fafaf8;--wh:#ffffff;
	--red:#e24b4a;--amber:#BA7517;
	--svc-serif:'Noto Serif JP',serif;--svc-sans:'Noto Sans JP',sans-serif;
	--r:12px;
	background:var(--bg)!important;
}

/* ===== Reset: layout.css の subpage 上書きを無効化 ===== */
html body#body.is-service-page,
html body#body.is-service-page .l-body,
html body#body.is-service-page .l-contents,
html body#body.is-service-page .l-main,
html body#body.is-service-page .c-entry,
html body#body.is-service-page .c-entry__body,
html body#body.is-service-page .c-entry__content{ background:var(--bg)!important; color:var(--ink)!important; }

html body#body.is-service-page article.c-entry,
html body#body.is-service-page div.c-entry,
html body#body.is-service-page .c-entry__header,
html body#body.is-service-page .c-entry__body,
html body#body.is-service-page .c-entry__footer,
html body#body.is-service-page .c-entry__aside{ max-width:none!important; margin-inline:0!important; padding-inline:0!important; }

/* デフォルトのページタイトル（h1）と page-header を非表示（hero側に独自タイトル） */
html body#body.is-service-page .c-entry__header,
html body#body.is-service-page .p-page-header,
html body#body.is-service-page .c-entry__title{ display:none!important; }

/* 見出し色・フォント・borderの強制を解除
   ※ .p-top-contact（TOPと共通のCTAコンポーネント）配下は除外する */
html body#body.is-service-page h1:not(:where(.p-top-contact, .p-top-contact *)),
html body#body.is-service-page h2:not(:where(.p-top-contact, .p-top-contact *)),
html body#body.is-service-page h3:not(:where(.p-top-contact, .p-top-contact *)),
html body#body.is-service-page h4:not(:where(.p-top-contact, .p-top-contact *)),
html body#body.is-service-page h5:not(:where(.p-top-contact, .p-top-contact *)),
html body#body.is-service-page h6:not(:where(.p-top-contact, .p-top-contact *)){ color:inherit!important; font-family:var(--svc-sans)!important; font-weight:600!important; line-height:1.4!important; letter-spacing:normal!important; }
html body#body.is-service-page .c-entry__body h2:not(:where(.p-top-contact, .p-top-contact *)),
html body#body.is-service-page .c-entry__body h3:not(:where(.p-top-contact, .p-top-contact *)),
html body#body.is-service-page .c-entry__body h4:not(:where(.p-top-contact, .p-top-contact *)){ font-size:inherit!important; font-weight:inherit!important; color:inherit!important; border:none!important; padding:0!important; margin:0!important; line-height:inherit!important; letter-spacing:normal!important; }
html body#body.is-service-page .c-entry__body p:not(:where(.p-top-contact, .p-top-contact *)){ line-height:inherit!important; margin:0!important; color:inherit!important; }
html body#body.is-service-page .c-entry__body ul:not(:where(.p-top-contact, .p-top-contact *)),
html body#body.is-service-page .c-entry__body ol:not(:where(.p-top-contact, .p-top-contact *)){ list-style:none!important; padding-left:0!important; margin:0!important; }
html body#body.is-service-page .c-entry__body li:not(:where(.p-top-contact, .p-top-contact *)){ margin:0!important; line-height:inherit!important; color:inherit!important; }
html body#body.is-service-page .c-entry__body li:not(:where(.p-top-contact, .p-top-contact *))::marker{ color:inherit; }
html body#body.is-service-page .c-entry__body strong:not(:where(.p-top-contact, .p-top-contact *)){ color:inherit!important; }
html body#body.is-service-page .c-entry__body a:not(:where(.p-top-contact, .p-top-contact *)){ text-decoration:none!important; }

html body#body.is-service-page p:not(:where(.p-top-contact, .p-top-contact *)),
html body#body.is-service-page li:not(:where(.p-top-contact, .p-top-contact *)),
html body#body.is-service-page td:not(:where(.p-top-contact, .p-top-contact *)),
html body#body.is-service-page th:not(:where(.p-top-contact, .p-top-contact *)),
html body#body.is-service-page dt:not(:where(.p-top-contact, .p-top-contact *)),
html body#body.is-service-page dd:not(:where(.p-top-contact, .p-top-contact *)),
html body#body.is-service-page label:not(:where(.p-top-contact, .p-top-contact *)),
html body#body.is-service-page span:not(.rh-hamburger span):not(:where(.p-top-contact, .p-top-contact *)){ color:inherit!important; }
html body#body.is-service-page a:not([class*="rh-"]):not([class*="l-header"]):not([class*="c-btn"]):not([class*="nav-"]):not(.btn):not(.btn-primary):not(.btn-ghost):not(:where(.p-top-contact, .p-top-contact *)){ color:inherit!important; }

/* 本ページのベースタイポ（.p-top-contact 配下は除外） */
body.is-service-page{ font-family:var(--svc-sans); color:var(--ink); font-size:16px; line-height:1.8; }
body.is-service-page p:not(:where(.p-top-contact, .p-top-contact *)){ line-height:1.95; }
body.is-service-page h1:not(:where(.p-top-contact, .p-top-contact *)){ font-size:clamp(24px,3.4vw,38px); }
body.is-service-page h2:not(:where(.p-top-contact, .p-top-contact *)){ font-size:clamp(22px,3.5vw,34px); }
body.is-service-page h3:not(:where(.p-top-contact, .p-top-contact *)){ font-size:clamp(17px,2.5vw,22px); }
body.is-service-page h4:not(:where(.p-top-contact, .p-top-contact *)){ font-size:16px; }

/* ===== Layout helpers ===== */
body.is-service-page .container{ max-width:980px; margin:0 auto; padding:0 24px; }
body.is-service-page .container-sm{ max-width:720px; margin:0 auto; padding:0 24px; }
body.is-service-page .sec{ padding:96px 0; }
body.is-service-page .sec-alt{ background:var(--wh); }
body.is-service-page .sec-dark{ background:#2e5a3b; color:var(--wh); }
body.is-service-page .eyebrow{ font-family:var(--svc-sans); font-size:13px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:#e29447; margin-bottom:14px; display:block; }
body.is-service-page .sec-head{ text-align:center; margin-bottom:60px; }
/* === H2 統一スタイル：大・緑・センター === */
html body#body.is-service-page .sec-head h2{ font-size:clamp(24px,3.4vw,40px)!important; font-weight:800!important; color:#2e5a3b!important; line-height:1.45!important; letter-spacing:.02em!important; margin:0 0 18px!important; text-align:center!important; padding:0!important; border:none!important; }
html body#body.is-service-page .sec-head p{ font-size:clamp(14px,1.4vw,16px)!important; color:#6e6e6a!important; max-width:720px; margin:0 auto!important; line-height:1.85!important; text-align:center!important; }
/* sec-dark（暗背景）の H2・サブ文字は白 */
html body#body.is-service-page .sec-dark .sec-head h2{ color:#ffffff!important; font-size:clamp(24px,3.4vw,40px)!important; font-weight:800!important; line-height:1.45!important; letter-spacing:.02em!important; margin:0 0 18px!important; text-align:center!important; padding:0!important; border:none!important; }
html body#body.is-service-page .sec-dark .sec-head p{ color:rgba(255,255,255,.65)!important; }
html body#body.is-service-page .sec-dark .eyebrow{ color:#ffd180!important; }
body.is-service-page .tag{ display:inline-block; font-size:11px; font-weight:700; letter-spacing:.06em; padding:3px 10px; border-radius:100px; }
body.is-service-page .tag-green{ background:var(--gp); color:var(--gm); }
body.is-service-page .tag-red{ background:#fff0f0; color:#c33; }
body.is-service-page .tag-dark{ background:rgba(29,158,117,.2); border:1px solid rgba(29,158,117,.4); color:#6ed9b5; }

/* ===== HERO（明るいデザイン版） ===== */
body.is-service-page .hero{ background:transparent; color:#1f1d1a; padding:0; position:relative; overflow:hidden; }
body.is-service-page .hero::before,
body.is-service-page .hero::after{ display:none; }
/* HERO: 右側はウィンドウ右端まで突き抜けるフルブリードレイアウト */
body.is-service-page .hero-grid{ display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1.3fr); gap:64px; align-items:center; }
body.is-service-page .hero-content{ min-width:0; padding-left:max(24px, calc((100vw - 980px) / 2)); padding-right:0; }
body.is-service-page .hero-image{ min-width:0; }
body.is-service-page .hero-image img{ display:block; width:100%; height:auto; aspect-ratio:4/3; object-fit:cover; border-radius:12px 0 0 12px; box-shadow:0 24px 60px -20px rgba(0,0,0,.18); }
html body#body.is-service-page .hero h1{ color:#2e5a3b!important; margin-bottom:22px!important; max-width:780px; }
html body#body.is-service-page .hero h1 em{ font-style:normal; color:#2e5a3b!important; }
html body#body.is-service-page .hero-lead{ font-size:clamp(15px,2vw,17px); color:#1f1d1a!important; max-width:600px; margin-bottom:44px!important; line-height:2.05!important; }
html body#body.is-service-page .hero-cta-row{ display:flex; align-items:center; gap:20px; flex-wrap:wrap; margin-top:30px; margin-bottom:56px; }
html body#body.is-service-page .hero-eyebrow{ font-family:var(--svc-sans); font-size:13px!important; font-weight:700; letter-spacing:.14em; color:#e29447!important; text-transform:uppercase; margin:0 0 18px!important; line-height:1; }
body.is-service-page .btn{ display:inline-block; font-family:var(--svc-sans); font-weight:700; text-decoration:none; border:none; cursor:pointer; transition:all .2s; }
body.is-service-page .btn-primary{ background:#e29447; color:#ffffff!important; font-size:16px; padding:18px 44px; border-radius:100px; }
body.is-service-page .btn-primary:hover{ background:#c97a2c; transform:translateY(-2px); box-shadow:0 8px 24px rgba(226,148,71,.35); }
/* layout.css の subpage a 色強制（緑）に勝つため #body で詳細度ブースト */
html body#body.is-service-page a.btn.btn-primary,
html body#body.is-service-page a.btn.btn-primary:hover,
html body#body.is-service-page a.btn.btn-primary:visited{ color:#ffffff!important; background:#e29447; }
html body#body.is-service-page a.btn.btn-primary:hover{ background:#c97a2c; }

/* ===== LEARN MORE ===== */
body.is-service-page .learn-more__cta{ text-align:center; }

/* ===== ALERT BAND ===== */
body.is-service-page .alert-band{ background:var(--wh); border:1px solid #f1c97a; border-left:4px solid #e29447; border-radius:var(--r); padding:22px 26px; margin:0 0 36px; box-shadow:0 4px 14px rgba(0,0,0,.18); }
body.is-service-page .alert-inner{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; }
body.is-service-page .alert-icon{ font-size:28px; flex-shrink:0; }
body.is-service-page .alert-text{ font-size:15px; color:var(--ink)!important; line-height:1.85!important; flex:1; min-width:240px; }
body.is-service-page .alert-text strong{ color:#b8631c!important; font-weight:700; }

/* ===== PROBLEM (3カード版) ===== */
body.is-service-page .problem3-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:32px; margin-bottom:48px; }
body.is-service-page .problem3-card{ background:#fff; border:1px solid #e0ddd6; border-radius:12px; padding:32px 28px; text-align:center; transition:transform .2s,box-shadow .2s; display:flex; flex-direction:column; align-items:center; }
body.is-service-page .problem3-card:hover{ transform:translateY(-4px); box-shadow:0 12px 32px rgba(0,0,0,.08); }
html body#body.is-service-page .problem3-card h3{ order:1; font-size:19px!important; font-weight:700!important; color:#2e5a3b!important; line-height:1.5!important; margin:0 0 20px!important; letter-spacing:.02em; text-align:center!important; padding:0!important; border:none!important; }
body.is-service-page .problem3-card .problem3-illust{ order:2; width:140px; height:140px; margin:0 auto 20px; flex-shrink:0; }
body.is-service-page .problem3-card .problem3-illust img{ width:100%; height:100%; display:block; object-fit:contain; }
body.is-service-page .problem3-card p{ order:3; font-size:14px; color:#6e6e6a!important; line-height:1.85!important; text-align:left; margin:0!important; }

@media(max-width:820px){
	body.is-service-page .problem3-grid{ grid-template-columns:1fr; gap:20px; }
	body.is-service-page .problem3-card{ padding:28px 24px; }
	body.is-service-page .problem3-card .problem3-illust{ width:120px; height:120px; }
}

/* ===== PROBLEM (旧 6カード版・互換用) ===== */
body.is-service-page .problem-intro-box{ background:var(--wh); border:1px solid var(--bd); border-radius:var(--r); padding:36px 40px; margin-bottom:48px; }
body.is-service-page .problem-intro-box p{ font-size:17px; color:var(--im)!important; line-height:2.1!important; }
body.is-service-page .problem-intro-box p strong{ color:var(--ink)!important; font-weight:700; }
body.is-service-page .problem-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:20px; margin-bottom:48px; }
body.is-service-page .prob-card{ background:var(--wh); border:1px solid var(--bd); border-radius:var(--r); padding:28px 24px; position:relative; overflow:hidden; }
body.is-service-page .prob-card::before{ content:''; position:absolute; top:0; left:0; width:4px; height:100%; background:var(--red); border-radius:4px 0 0 4px; }
body.is-service-page .prob-card-num{ font-family:var(--svc-serif); font-size:36px; font-weight:700; color:rgba(226,75,74,.1)!important; line-height:1; margin-bottom:8px; }
body.is-service-page .prob-card h3{ font-size:16px!important; margin-bottom:10px!important; color:var(--ink)!important; }
body.is-service-page .prob-card p{ font-size:14px; color:var(--il)!important; line-height:1.85!important; }
body.is-service-page .prob-conclusion{ background:transparent; border-radius:0; padding:32px 24px 0; text-align:center; }
html body#body.is-service-page .prob-conclusion p{ font-size:17px!important; color:#1a1a18!important; line-height:2.05!important; }
html body#body.is-service-page .prob-conclusion strong{ color:#2e5a3b!important; font-weight:700; }

/* ===== AI WARNING ===== */
body.is-service-page .ai-warning-wrap{ background:var(--wh); border:1px solid var(--bd); border-radius:var(--r); padding:48px 52px; margin-bottom:40px; box-shadow:0 8px 28px rgba(0,0,0,.18); }
body.is-service-page .ai-warning-head{ display:flex; align-items:center; gap:14px; margin-bottom:20px; padding-bottom:16px; border-bottom:1px solid var(--bd); }
body.is-service-page .ai-warning-icon{ font-size:32px; flex-shrink:0; }
html body#body.is-service-page .ai-warning-head h3{ font-family:var(--svc-sans)!important; font-size:20px!important; color:var(--gd)!important; font-weight:700!important; margin:0!important; }
html body#body.is-service-page .sec-dark .ai-warning-wrap .ai-warning-lead{ font-size:16px; color:var(--ink)!important; line-height:2.0!important; margin-bottom:32px!important; }
html body#body.is-service-page .sec-dark .ai-warning-wrap .ai-warning-lead strong{ color:var(--gm)!important; font-weight:700!important; }
body.is-service-page .ai-gap-grid{ display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-bottom:32px; }
body.is-service-page .ai-gap-card{ border-radius:10px; padding:24px 22px; }
body.is-service-page .ai-gap-card.no{ background:#f7f5f0; border:1px solid var(--bd); }
body.is-service-page .ai-gap-card.yes{ background:var(--gs); border:1px solid #b3e6d0; }
body.is-service-page .ai-gap-label{ font-size:12px; font-weight:700; letter-spacing:.04em; margin-bottom:12px; display:inline-block; padding:5px 11px; border-radius:999px; }
html body#body.is-service-page .ai-gap-card.no .ai-gap-label{ color:var(--im)!important; background:#ece9e0; border:1px solid var(--bd); }
html body#body.is-service-page .ai-gap-card.yes .ai-gap-label{ color:#fff!important; background:var(--gm); }
html body#body.is-service-page .ai-gap-card h4{ font-size:15px!important; font-weight:700!important; margin-bottom:10px!important; line-height:1.55!important; }
html body#body.is-service-page .ai-gap-card.no h4{ color:var(--ink)!important; }
html body#body.is-service-page .ai-gap-card.yes h4{ color:var(--gd)!important; }
body.is-service-page .ai-gap-card ul{ list-style:none!important; padding:0!important; }
body.is-service-page .ai-gap-card ul li{ font-size:13px; line-height:1.7!important; padding:6px 0 6px 18px!important; position:relative; border-bottom:1px solid rgba(0,0,0,.06); }
body.is-service-page .ai-gap-card ul li:last-child{ border-bottom:none; }
html body#body.is-service-page .ai-gap-card.no ul li{ color:var(--il)!important; }
body.is-service-page .ai-gap-card.no ul li::before{ content:'×'; position:absolute; left:0; color:var(--iu); font-size:12px; top:6px; }
html body#body.is-service-page .ai-gap-card.yes ul li{ color:var(--im)!important; }
body.is-service-page .ai-gap-card.yes ul li::before{ content:'✓'; position:absolute; left:0; color:var(--gl); font-size:12px; top:6px; }
html body#body.is-service-page .ai-warning-conclusion{ background:var(--gs); border:1px solid #b3e6d0; border-left:4px solid var(--gm); border-radius:8px; padding:20px 24px; font-size:15px; color:var(--ink)!important; line-height:1.9; text-align:left; }
html body#body.is-service-page .ai-warning-conclusion strong{ color:var(--gm)!important; font-weight:700; display:block; margin-bottom:6px; }

/* ===== CGO 中間見出し ===== */
body.is-service-page .cgo-section-head{ text-align:center; margin:48px 0 28px; }
html body#body.is-service-page .cgo-section-head h3.cgo-section-title{ font-size:clamp(20px,2.4vw,26px)!important; font-weight:700!important; color:#2e5a3b!important; line-height:1.5!important; margin:0 0 10px!important; padding:0 0 8px!important; letter-spacing:.04em!important; text-align:center!important; display:inline-block; border-top:none!important; border-left:none!important; border-right:none!important; border-bottom:3px solid #2e5a3b!important; }
html body#body.is-service-page .cgo-section-head p.cgo-section-sub{ font-size:14px!important; color:#6e6e6a!important; line-height:1.7!important; margin:0!important; text-align:center!important; }

/* ===== CGO ===== */
body.is-service-page .cgo-simple{ background:var(--gs); border:1px solid #b3e6d0; border-radius:var(--r); padding:36px 40px; margin-bottom:36px; }
body.is-service-page .cgo-simple-head{ font-size:13px; font-weight:700; letter-spacing:.08em; color:var(--gm)!important; text-transform:uppercase; margin-bottom:14px; }
body.is-service-page .cgo-simple p{ font-size:16px; color:var(--im)!important; line-height:2.1!important; }
body.is-service-page .cgo-analogy{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; border:1px solid var(--bd); border-radius:var(--r); overflow:hidden; margin-bottom:36px; }
body.is-service-page .cgo-analogy-col{ padding:24px 20px; text-align:center; border-right:1px solid var(--bd); background:var(--wh); }
body.is-service-page .cgo-analogy-col:last-child{ border-right:none; }
body.is-service-page .cgo-analogy-col.mid{ background:var(--gd); color:var(--wh); }
body.is-service-page .cgo-analogy-icon{ font-size:28px; margin-bottom:10px; }
body.is-service-page .cgo-analogy-title{ font-size:13px; font-weight:700; margin-bottom:8px; }
body.is-service-page .cgo-analogy-col.mid .cgo-analogy-title{ color:var(--wh)!important; }
body.is-service-page .cgo-analogy-desc{ font-size:12px; color:var(--il)!important; line-height:1.7!important; }
body.is-service-page .cgo-analogy-col.mid .cgo-analogy-desc{ color:rgba(255,255,255,.7)!important; }
body.is-service-page .cgo-table-wrap{ border:1px solid var(--bd); border-radius:var(--r); overflow:hidden; margin-bottom:36px; }
body.is-service-page .cgo-table-head{ display:grid; grid-template-columns:120px 1fr 1fr; }
body.is-service-page .cgo-table-th{ padding:14px 20px; font-size:12px; font-weight:700; letter-spacing:.04em; text-align:left; }
body.is-service-page .cgo-table-th.label{ background:#f5f4f0; color:var(--iu)!important; }
body.is-service-page .cgo-table-th.cmo{ background:#f5f4f0; color:var(--im)!important; border-left:1px solid var(--bd); }
body.is-service-page .cgo-table-th.cgo{ background:var(--gd); color:var(--wh)!important; border-left:1px solid rgba(255,255,255,.1); }
body.is-service-page .cgo-table-row{ display:grid; grid-template-columns:120px 1fr 1fr; border-top:1px solid var(--bd); }
body.is-service-page .cgo-table-cell{ padding:13px 20px; font-size:14px; line-height:1.7!important; }
body.is-service-page .cgo-table-cell.label{ font-size:11px; font-weight:700; letter-spacing:.06em; color:var(--iu)!important; text-transform:uppercase; background:#fafaf8; display:flex; align-items:center; }
body.is-service-page .cgo-table-cell.cmo{ color:var(--il)!important; border-left:1px solid var(--bd); background:var(--wh); }
body.is-service-page .cgo-table-cell.cgo{ color:var(--ink)!important; font-weight:500; border-left:1px solid var(--bd); background:var(--gs); }
body.is-service-page .cgo-context-box{ background:var(--wh); border:1px solid var(--bd); border-left:4px solid var(--gl); border-radius:var(--r); padding:28px 32px; }
body.is-service-page .cgo-context-box p{ font-size:15px; color:var(--im)!important; line-height:2.1!important; }

/* ===== VALUE / VS ===== */
body.is-service-page .value-lead{ font-size:17px; line-height:2.1!important; color:var(--im)!important; max-width:none; margin:0 0 52px!important; text-align:left; }

/* === 成長の好循環カード === */
body.is-service-page .growth-loop{ max-width:none; margin:0 0 40px; padding:48px 56px; background:var(--wh); border:1px solid var(--bd); border-radius:16px; box-shadow:0 4px 24px -12px rgba(0,0,0,.06); }
html body#body.is-service-page .growth-loop .growth-loop__title{ font-size:12px!important; font-weight:700!important; letter-spacing:.14em!important; color:#9e9e9a!important; text-transform:uppercase; text-align:center!important; margin:0 0 32px!important; line-height:1!important; }
body.is-service-page .growth-loop__list{ list-style:none!important; margin:0!important; padding:0!important; display:flex; flex-direction:column; gap:0; }
body.is-service-page .growth-loop__item{ display:grid; grid-template-columns:48px 64px 1fr; gap:20px; align-items:center; padding:22px 24px; background:#fafaf8; border:1px solid var(--bd); border-radius:12px; }
body.is-service-page .growth-loop__item--last{ background:linear-gradient(135deg,#e1f5ee 0%,#f2faf7 100%); border-color:#b3e6d0; }
body.is-service-page .growth-loop__num{ display:flex; align-items:center; justify-content:center; width:48px; height:48px; border-radius:50%; background:#fff; border:2px solid #1d9e75; }
body.is-service-page .growth-loop__num span{ font-family:var(--svc-sans); font-size:14px; font-weight:800; color:#1d9e75!important; letter-spacing:.04em; }
body.is-service-page .growth-loop__item--last .growth-loop__num{ background:#1d9e75; border-color:#1d9e75; }
body.is-service-page .growth-loop__item--last .growth-loop__num span{ color:#fff!important; }
body.is-service-page .growth-loop__icon{ font-size:36px; line-height:1; text-align:center; }
body.is-service-page .growth-loop__body{ min-width:0; }
html body#body.is-service-page .growth-loop__body .growth-loop__step{ font-size:18px!important; font-weight:700!important; color:#1a1a18!important; line-height:1.4!important; margin:0 0 4px!important; padding:0!important; border:none!important; letter-spacing:.02em; text-align:left!important; }
html body#body.is-service-page .growth-loop__body .growth-loop__desc{ font-size:13px!important; color:#6e6e6a!important; line-height:1.7!important; margin:0!important; text-align:left!important; }

body.is-service-page .growth-loop__arrow{ list-style:none!important; text-align:center; font-size:24px; color:#1d9e75!important; line-height:1; padding:6px 0; font-weight:700; }

html body#body.is-service-page .growth-loop__note{ font-size:14px!important; color:#3d3d3a!important; text-align:center!important; line-height:1.85!important; margin:32px 0 0!important; padding-top:28px; border-top:1px dashed var(--bd); }
html body#body.is-service-page .growth-loop__note strong{ color:#0f6e56!important; font-weight:700; }

@media(max-width:760px){
	body.is-service-page .growth-loop{ padding:32px 20px; }
	body.is-service-page .growth-loop__item{ grid-template-columns:40px 48px 1fr; gap:14px; padding:18px 16px; }
	body.is-service-page .growth-loop__num{ width:40px; height:40px; }
	body.is-service-page .growth-loop__icon{ font-size:28px; }
	html body#body.is-service-page .growth-loop__body .growth-loop__step{ font-size:16px!important; }
}
body.is-service-page .vs-grid{ display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:28px; }
body.is-service-page .vs-card{ border-radius:var(--r); padding:28px 26px; }
body.is-service-page .vs-card.bad{ background:var(--wh); border:1px solid var(--bd); }
body.is-service-page .vs-card.good{ background:var(--gs); border:1px solid #b3e6d0; }
body.is-service-page .vs-label{ font-size:13px; font-weight:700; letter-spacing:.04em; margin-bottom:14px; display:inline-block; padding:6px 12px; border-radius:999px; }
html body#body.is-service-page .vs-card.bad .vs-label{ color:var(--im)!important; background:#f1efe9; border:1px solid var(--bd); }
html body#body.is-service-page .vs-card.good .vs-label{ color:#fff!important; background:var(--gm); }
body.is-service-page .vs-card h3{ font-size:17px!important; margin-bottom:10px!important; }
body.is-service-page .vs-card p{ font-size:14px; color:var(--il)!important; line-height:1.85!important; margin-bottom:14px!important; }
body.is-service-page .vs-card ul{ list-style:none!important; }
body.is-service-page .vs-card ul li{ font-size:13px; color:var(--il)!important; padding:5px 0 5px 18px!important; position:relative; line-height:1.6!important; border-bottom:1px solid rgba(0,0,0,.06); }
body.is-service-page .vs-card ul li:last-child{ border-bottom:none; }
body.is-service-page .vs-card.bad ul li::before{ content:'×'; position:absolute; left:0; color:var(--iu); font-size:12px; top:6px; }
body.is-service-page .vs-card.good ul li::before{ content:'✓'; position:absolute; left:0; color:var(--gl); font-size:12px; top:6px; }

/* ===== SERVICES ===== */
body.is-service-page .svc-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(290px,1fr)); gap:20px; margin-bottom:32px; }
body.is-service-page .svc-card{ background:var(--bg); border:1px solid var(--bd); border-radius:var(--r); padding:28px 24px; transition:box-shadow .2s,transform .2s; }
body.is-service-page .svc-card:hover{ box-shadow:0 4px 24px rgba(0,0,0,.08); transform:translateY(-2px); }
body.is-service-page .svc-card.featured{ border-color:var(--gl); background:var(--gs); }
body.is-service-page .svc-icon{ width:48px; height:48px; background:var(--gp); border-radius:12px; display:flex; align-items:center; justify-content:center; margin-bottom:16px; font-size:22px; }
body.is-service-page .svc-card.featured .svc-icon{ background:rgba(29,158,117,.2); }
body.is-service-page .svc-card h3{ font-size:16px!important; margin-bottom:10px!important; }
body.is-service-page .svc-card p{ font-size:14px; color:var(--il)!important; line-height:1.85!important; margin-bottom:14px!important; }
body.is-service-page .svc-detail{ font-size:13px; color:var(--im)!important; background:var(--wh); border-radius:8px; padding:12px 14px; line-height:1.75; }
body.is-service-page .svc-card.featured .svc-detail{ background:rgba(255,255,255,.65); }
body.is-service-page .svc-detail-label{ font-size:10px; font-weight:700; letter-spacing:.08em; color:var(--gm)!important; text-transform:uppercase; margin-bottom:6px; display:block; }
body.is-service-page .svc-footer{ background:transparent; color:var(--ink); border-radius:0; padding:28px 36px; text-align:center; }
body.is-service-page .svc-footer p{ font-size:15px; color:var(--ink)!important; line-height:2.1!important; }
body.is-service-page .svc-footer strong{ color:var(--gm)!important; font-weight:700; }

/* ===== PRICING ===== */
body.is-service-page .price-intro{ max-width:680px; margin:0 auto 40px!important; text-align:center; }
body.is-service-page .price-intro p{ font-size:16px; color:var(--il)!important; line-height:2!important; }
body.is-service-page .price-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-bottom:20px; }
body.is-service-page .price-card{ background:var(--wh); border:1px solid var(--bd); border-radius:var(--r); overflow:hidden; transition:transform .2s,box-shadow .2s; }
body.is-service-page .price-card:hover{ transform:translateY(-4px); box-shadow:0 10px 32px rgba(0,0,0,.1); }
body.is-service-page .price-card.feat{ border-color:#e29447; box-shadow:0 0 0 2px #e29447; }
body.is-service-page .price-head{ padding:22px 22px 18px; border-bottom:1px solid var(--bd); }
body.is-service-page .price-card.feat .price-head{ background:#e29447; border-bottom-color:rgba(255,255,255,.25); }
body.is-service-page .price-badge{ display:inline-block; font-size:11px; font-weight:700; letter-spacing:.06em; padding:3px 10px; border-radius:100px; margin-bottom:10px; }
html body.is-service-page span.price-badge.def{ background:#f0ede6!important; color:#3d3d3a!important; }
html body.is-service-page span.price-badge.fea{ background:#fff!important; color:#e29447!important; }
body.is-service-page .price-stores{ font-size:14px; font-weight:500; color:var(--im)!important; margin-bottom:6px; }
html body#body.is-service-page .price-card.feat .price-stores{ color:#fff!important; }
body.is-service-page .price-amount{ font-family:var(--svc-sans); font-size:28px; font-weight:700; color:var(--ink)!important; line-height:1.2; letter-spacing:.01em; }
html body#body.is-service-page .price-card.feat .price-amount{ color:#fff!important; }
body.is-service-page .price-amount span{ font-size:13px; font-weight:400; color:var(--iu)!important; }
html body#body.is-service-page .price-card.feat .price-amount span{ color:rgba(255,255,255,.85)!important; }
body.is-service-page .price-body{ padding:18px 22px; }
body.is-service-page .price-row{ display:flex; justify-content:space-between; font-size:13px; padding:7px 0; border-bottom:1px solid var(--bd); color:var(--im)!important; }
body.is-service-page .price-row:last-child{ border-bottom:none; }
body.is-service-page .price-row strong{ color:var(--ink)!important; font-weight:500; }
body.is-service-page .price-note{ font-size:12px; color:var(--iu)!important; text-align:center; margin-top:8px; }

/* ===== ROI ===== */
body.is-service-page .roi-intro{ max-width:720px; margin:0 auto; }
html body#body.is-service-page .roi-intro p{ font-size:clamp(14px,1.4vw,16px)!important; color:#6e6e6a!important; line-height:1.95!important; text-align:center!important; margin:0 auto 40px!important; }
body.is-service-page .roi-table-wrap{ border:1px solid var(--bd); border-radius:var(--r); overflow:hidden; margin-bottom:40px; overflow-x:auto; }
body.is-service-page .roi-table{ width:100%; border-collapse:collapse; font-size:14px; min-width:600px; }
body.is-service-page .roi-table thead tr{ background:var(--gd); }
html body#body.is-service-page .roi-table th{ padding:14px 18px; text-align:left; color:rgba(255,255,255,.95)!important; font-weight:500; font-size:12px; letter-spacing:.04em; }
body.is-service-page .roi-table td{ padding:14px 18px; border-bottom:1px solid var(--bd); color:var(--im)!important; background:var(--wh); }
body.is-service-page .roi-table tr:last-child td{ border-bottom:none; }
body.is-service-page .roi-table td.hi{ font-weight:700; color:var(--gm)!important; font-size:15px; }
body.is-service-page .roi-table td.sc{ font-weight:500; color:var(--ink)!important; }
body.is-service-page .driver-grid{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
body.is-service-page .driver{ background:var(--wh); border:1px solid var(--bd); border-radius:var(--r); padding:22px 20px; }
body.is-service-page .driver-head{ display:flex; align-items:center; gap:10px; margin-bottom:10px; }
body.is-service-page .driver-num{ font-size:11px; font-weight:700; color:var(--wh)!important; background:var(--gl); border-radius:50%; width:22px; height:22px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
body.is-service-page .driver-title{ font-size:15px; font-weight:600; color:var(--ink)!important; }
body.is-service-page .driver-body{ font-size:14px; color:var(--im)!important; line-height:1.85!important; margin-bottom:10px!important; }
body.is-service-page .driver-example{ font-size:13px; color:var(--gm)!important; background:var(--gs); padding:8px 12px; border-radius:6px; line-height:1.65; }

/* ===== ROADMAP ===== */
body.is-service-page .rm-intro{ max-width:720px; margin:0 auto; }
html body#body.is-service-page .rm-intro p{ font-size:clamp(14px,1.4vw,16px)!important; color:#6e6e6a!important; line-height:1.95!important; text-align:center!important; margin:0 auto 40px!important; }
body.is-service-page .roadmap{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; border:1px solid var(--bd); border-radius:var(--r); overflow:hidden; margin-bottom:32px; background:var(--wh); }
body.is-service-page .rm-phase{ padding:28px 24px; border-right:1px solid var(--bd); }
body.is-service-page .rm-phase:last-child{ border-right:none; }
body.is-service-page .rm-num{ font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--gl)!important; margin-bottom:6px; }
html body#body.is-service-page .rm-title{ font-size:22px!important; font-weight:700!important; color:var(--gm)!important; margin-bottom:14px!important; line-height:1.45!important; letter-spacing:.01em; }
body.is-service-page .rm-goal{ font-size:12px; color:var(--wh)!important; background:var(--gm); padding:5px 10px; border-radius:4px; display:inline-block; margin-bottom:16px; line-height:1.6; }
body.is-service-page .rm-items{ list-style:none!important; margin-bottom:16px!important; }
body.is-service-page .rm-items li{ font-size:13px; color:var(--im)!important; padding:5px 0 5px 16px!important; position:relative; line-height:1.6!important; border-bottom:1px solid var(--bd); }
body.is-service-page .rm-items li:last-child{ border-bottom:none; }
body.is-service-page .rm-items li::before{ content:''; position:absolute; left:0; top:13px; width:5px; height:5px; border-radius:50%; background:var(--gl); }
body.is-service-page .rm-ratio{ margin-top:16px; padding-top:16px; border-top:1px solid var(--bd); }
body.is-service-page .rm-ratio-lbl{ font-size:11px; color:var(--iu)!important; margin-bottom:6px; }
body.is-service-page .rm-bar{ height:7px; background:var(--bd); border-radius:4px; overflow:hidden; }
body.is-service-page .rm-bar-fill{ height:100%; background:var(--gl); border-radius:4px; }
body.is-service-page .rm-ratio-desc{ font-size:11px; color:var(--iu)!important; margin-top:5px; }
body.is-service-page .rm-note{ background:var(--gs); border:1px solid #b3e6d0; border-radius:var(--r); padding:24px 32px; text-align:center; }
body.is-service-page .rm-note p{ font-size:15px; color:var(--im)!important; line-height:2.1!important; }

/* ===== STEP ===== */
body.is-service-page .step-list{ display:flex; flex-direction:column; gap:0; max-width:720px; margin:0 auto; }
body.is-service-page .step-item{ display:flex; gap:24px; padding:28px 0; border-bottom:1px solid var(--bd); position:relative; }
body.is-service-page .step-item:last-child{ border-bottom:none; }
body.is-service-page .step-left{ display:flex; flex-direction:column; align-items:center; flex-shrink:0; }
body.is-service-page .step-num{ width:44px; height:44px; border-radius:50%; background:var(--gd); color:var(--wh)!important; font-family:var(--svc-serif); font-size:16px; font-weight:600; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
body.is-service-page .step-line{ width:1px; flex:1; background:var(--bd); margin-top:8px; }
body.is-service-page .step-item:last-child .step-line{ display:none; }
body.is-service-page .step-right{ flex:1; padding-top:8px; }
html body#body.is-service-page .step-right h3{ font-size:21px!important; font-weight:700!important; color:var(--gm)!important; margin-bottom:12px!important; line-height:1.5!important; letter-spacing:.01em; }
body.is-service-page .step-right p{ font-size:14px; color:var(--il)!important; line-height:1.85!important; }
body.is-service-page .step-badge{ display:inline-block; font-size:11px; font-weight:700; padding:2px 8px; border-radius:4px; margin-bottom:8px; }

/* ===== FAQ ===== */
body.is-service-page .faq-list{ max-width:760px; margin:0 auto; }
body.is-service-page .faq-item{ border:1px solid var(--bd); border-radius:var(--r); margin-bottom:10px; overflow:hidden; }
body.is-service-page .faq-q{ width:100%; background:var(--wh); border:none; padding:20px 24px; text-align:left; font-family:var(--svc-sans); font-size:15px; font-weight:500; color:var(--ink)!important; cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:16px; transition:background .15s; }
body.is-service-page .faq-q:hover{ background:var(--bg); }
body.is-service-page .faq-icon{ width:26px; height:26px; border-radius:50%; background:var(--gp); color:var(--gm)!important; display:flex; align-items:center; justify-content:center; font-size:20px; font-weight:300; flex-shrink:0; transition:transform .2s,background .2s; }
body.is-service-page .faq-item.open .faq-icon{ transform:rotate(45deg); background:var(--gl); color:var(--wh)!important; }
body.is-service-page .faq-a{ display:none; padding:0 24px 22px; background:var(--wh); border-top:1px solid var(--bd); }
body.is-service-page .faq-a p{ padding-top:16px!important; font-size:14px; color:var(--im)!important; line-height:1.95!important; }
body.is-service-page .faq-item.open .faq-a{ display:block; }

/* ===== CTA は base.css の .p-top-contact* を共通利用（TOPと同一） ===== */

/* ===== RESPONSIVE ===== */
@media(max-width:760px){
	body.is-service-page .sec{ padding:64px 0; }
	body.is-service-page .hero{ padding:0 0 64px; }
	body.is-service-page .hero-grid{ grid-template-columns:1fr; gap:32px; }
	body.is-service-page .hero-content{ padding-left:24px; padding-right:24px; }
	body.is-service-page .hero-image img{ aspect-ratio:16/10; border-radius:12px 0 0 12px; }
	body.is-service-page .hero-stat{ padding:0 20px 0 0; margin-right:20px; }
	body.is-service-page .price-grid{ grid-template-columns:1fr; }
	body.is-service-page .roadmap{ grid-template-columns:1fr; }
	body.is-service-page .rm-phase{ border-right:none; border-bottom:1px solid var(--bd); }
	body.is-service-page .rm-phase:last-child{ border-bottom:none; }
	body.is-service-page .vs-grid{ grid-template-columns:1fr; }
	body.is-service-page .driver-grid{ grid-template-columns:1fr; }
	body.is-service-page .cgo-analogy{ grid-template-columns:1fr; }
	body.is-service-page .cgo-analogy-col{ border-right:none; border-bottom:1px solid var(--bd); }
	body.is-service-page .cgo-analogy-col:last-child{ border-bottom:none; }
	body.is-service-page .cgo-table-head,
	body.is-service-page .cgo-table-row{ grid-template-columns:80px 1fr 1fr; }
	body.is-service-page .ai-gap-grid{ grid-template-columns:1fr; }
	body.is-service-page .ai-warning-wrap{ padding:28px 22px; }
	body.is-service-page .prob-conclusion{ padding:28px 22px; }
	body.is-service-page .hero-cta-row{ flex-direction:column; align-items:flex-start; }
}
