/*
Theme Name:   nihonbashi-child
Theme URI:    https://nihonbashi-marketing.com/
Description:  日本橋マーケティング — Lightning Child Theme
Author:       Nihonbashi Marketing
Template:     lightning
Version:      1.0.0
License:      GNU General Public License v2 or later
License URI:  http://www.gnu.org/licenses/gpl-2.0.html
Text Domain:  nihonbashi-child
*/

/* =====================================================================
   0. Lightning デフォルト UI の無効化
   ===================================================================== */
.site-header,.l-header,#vk_header,.vk_header,
.vk_pageHeader,.vk_pageHeader--style-full,
.footer-widget-area,.l-footer,.vk_footer,.site-footer {
    display: none !important;
}
.l-main,.l-col--main,.l-col--full,#main {
    max-width: 100% !important;
    padding: 0 !important; margin: 0 !important;
    float: none !important; width: 100% !important;
}
.site-body-container.container,.l-container { max-width: 100% !important; padding: 0 !important; }
.site-body { padding: 0 !important; }
.main-section { margin-top: 0 !important; margin-bottom: 0 !important; }
.entry-header,.page-header { display: none !important; }
.wp-block-html { margin: 0; }
body.page .entry-content { max-width: 100% !important; padding: 0 !important; }

/* =====================================================================
   1. カスタムプロパティ（全ページ共通デザイントークン）
   ===================================================================== */
:root {
  --navy:        #1b3a6b;
  --navy-dark:   #102548;
  --navy-mid:    #2c5294;
  --navy-light:  #eef3fb;
  --navy-pale:   #f5f8ff;
  --gold:        #c8881a;
  --gold-light:  #fef3dc;
  --gold-mid:    #e6a830;
  --white:       #ffffff;
  --off:         #f6f7f9;
  --ink:         #1a1f2e;
  --ink-mid:     #3d4560;
  --ink-soft:    #6b7490;
  --text:        #1a1f2e;
  --text-sub:    #6b7490;
  --border:      #d0daf0;
  --green-cta:   #1a4d2e;
  --green-light: #e8f5e9;
  --r:           6px;
  --radius:      6px;
  --max:         1100px;
  --t:           0.22s ease;
  --font:        'Noto Sans JP', sans-serif;
  --sh-n:        0 4px 20px rgba(27,58,107,0.15);
  --shadow:      0 4px 20px rgba(27,58,107,0.15);
  --sh-hov:      0 8px 32px rgba(27,58,107,0.22);
}

/* =====================================================================
   2. リセット＆ベース
   ===================================================================== */
*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }
body {
  font-family: var(--font);
  color: var(--ink);
  background: var(--white);
  line-height: 1.75;
  -webkit-font-smoothing: antialiased;
  padding-top: 64px; /* ヘッダー追従固定分 */
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }
.wrap { max-width: var(--max); margin: 0 auto; padding: 0 28px; }

/* =====================================================================
   3. カスタムヘッダー
   ===================================================================== */
.hd {
  position: fixed; top: 0; left: 0; right: 0; width: 100%; z-index: 1000;
  background: var(--white); border-bottom: 1px solid var(--border);
}
.hd__in {
  display: flex; align-items: center; justify-content: space-between;
  max-width: var(--max); margin: 0 auto;
  padding: 0 20px 0 28px; height: 64px;
}
.hd__logo img { height: 36px; width: auto; }
.hd__logo-text { font-size: 1.1rem; font-weight: 700; color: var(--navy); }
.gnav { display: flex; align-items: center; gap: 4px; }
.gnav a {
  font-size: 14px; font-weight: 400; color: var(--navy);
  padding: 7px 14px; border-radius: 4px;
  border-bottom: 2px solid transparent; transition: all var(--t);
}
.gnav a:hover,.gnav a.active {
  color: var(--navy-dark); border-bottom-color: var(--gold); font-weight: 500;
}
.gnav .cta-btn {
  background: var(--navy); color: var(--white);
  padding: 8px 20px; border-radius: var(--r);
  border-bottom: none; font-weight: 700; margin-left: 8px;
}
.gnav .cta-btn:hover {
  background: var(--navy-dark); transform: translateY(-1px); box-shadow: var(--sh-n);
}
.burger {
  display: none; flex-direction: column; gap: 5px;
  cursor: pointer; background: none; border: none; padding: 6px;
}
.burger span {
  display: block; width: 24px; height: 2px;
  background: var(--navy); border-radius: 2px; transition: var(--t);
}

/* =====================================================================
   4. カスタムフッター
   ===================================================================== */
.ft-bar { background: var(--navy-dark); padding: 26px 0; }
.ft-bar__in {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 14px;
}
.ft-nav { display: flex; gap: 20px; flex-wrap: wrap; }
.ft-nav a { font-size: 12px; color: rgba(255,255,255,0.55); transition: color var(--t); }
.ft-nav a:hover { color: var(--gold-mid); }
.ft-copy { font-size: 11px; color: rgba(255,255,255,0.30); }

/* =====================================================================
   5. TOPページ専用スタイル
   ===================================================================== */
/* ============================================================
   DESIGN TOKENS — Navy × Gold
   ============================================================ */


*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font);color:var(--ink);background:var(--white);line-height:1.75;padding-top:64px}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
.wrap{max-width:var(--max);margin:0 auto;padding:0 28px}

/* ======== HEADER ======== */
.hd{
  position:fixed;top:0;left:0;right:0;width:100%;z-index:1000;
  background:var(--white);
  border-bottom:1px solid var(--border);
}
.hd__in{
  display:flex;align-items:center;justify-content:space-between;
  max-width:var(--max);margin:0 auto;
  padding:0 20px 0 28px;height:64px;
}
.hd__logo img{height:36px;width:auto}
.gnav{display:flex;align-items:center;gap:4px;padding-right:20px}
.gnav a{
  font-size:14px;font-weight:400;color:var(--navy);
  padding:7px 14px;border-radius:4px;
  border-bottom:2px solid transparent;
  transition:all var(--t);
}
.gnav a:hover{color:var(--navy-dark);border-bottom-color:var(--gold);font-weight:500}
.gnav .cta-btn{
  background:var(--navy);color:var(--white);
  padding:8px 20px;border-radius:var(--r);
  border-bottom:none;font-weight:700;margin-left:8px;
}
.gnav .cta-btn:hover{background:var(--navy-dark);transform:translateY(-1px);box-shadow:var(--sh-n)}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px}
.burger span{display:block;width:24px;height:2px;background:var(--navy);border-radius:2px}

/* ======== HERO — CSS-only decoration ======== */
/* 背景: navy グラデーション + 対角グリッド線 + 浮遊円 */
.hero{
  position:relative;
  min-height:580px;
  display:flex;align-items:center;justify-content:center;
  text-align:center;
  overflow:hidden;
  background:linear-gradient(140deg, var(--navy-dark) 0%, var(--navy) 50%, var(--navy-mid) 100%);
}
/* 対角グリッド — ::before */
.hero::before{
  content:'';
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size:60px 60px;
  transform:rotate(-8deg) scale(1.3);
}
/* 大きな装飾円 — ::after */
.hero::after{
  content:'';
  position:absolute;bottom:-2px;left:0;right:0;height:80px;
  background:var(--white);
  clip-path:polygon(0 100%,100% 0,100% 100%);
}
/* 浮遊円 — span要素で代替 */
.hero__deco-a{
  position:absolute;top:-80px;right:-80px;
  width:400px;height:400px;
  border-radius:50%;
  background:rgba(200,136,26,0.12);
  pointer-events:none;
}
.hero__deco-b{
  position:absolute;bottom:-120px;left:-60px;
  width:320px;height:320px;
  border-radius:50%;
  background:rgba(255,255,255,0.05);
  pointer-events:none;
}
.hero__deco-c{
  position:absolute;top:60px;right:280px;
  width:100px;height:100px;
  border-radius:50%;
  background:rgba(200,136,26,0.18);
  pointer-events:none;
}
.hero__inner{
  position:relative;z-index:1;
  padding:80px 28px 120px;max-width:var(--max);width:100%;
}
.hero__tag{
  display:inline-block;
  border:1px solid rgba(200,136,26,0.55);
  color:var(--gold-mid);
  font-size:11px;font-weight:700;letter-spacing:.18em;
  padding:4px 16px;border-radius:20px;margin-bottom:24px;
  text-transform:uppercase;
}
.hero__h1{
  font-size:clamp(36px,6vw,68px);
  font-weight:900;color:var(--white);
  line-height:1.15;letter-spacing:-.01em;margin-bottom:20px;
}
.hero__h1 em{
  font-style:normal;color:var(--gold-mid);
  position:relative;display:inline-block;
}
/* emの下線装飾 */
.hero__h1 em::after{
  content:'';
  position:absolute;left:0;bottom:-4px;right:0;height:3px;
  background:var(--gold-mid);border-radius:2px;opacity:.6;
}
.hero__sub{
  font-size:clamp(17px,2.2vw,22px);font-weight:700;
  color:rgba(255,255,255,0.80);margin-bottom:16px;
}
.hero__body{
  font-size:16px;color:rgba(255,255,255,0.65);
  margin-bottom:40px;max-width:480px;
  margin-left:auto;margin-right:auto;line-height:1.9;
}
.hero__btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ======== BUTTONS ======== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  font-family:var(--font);font-weight:700;font-size:15px;
  padding:14px 34px;border-radius:var(--r);
  cursor:pointer;transition:all var(--t);border:2px solid transparent;
}
.btn--solid{background:var(--gold);color:var(--white);border-color:var(--gold)}
.btn--solid:hover{background:#a86d10;transform:translateY(-2px);box-shadow:0 6px 20px rgba(200,136,26,0.35)}
.btn--navy{background:var(--navy);color:var(--white);border-color:var(--navy)}
.btn--navy:hover{background:var(--navy-dark);transform:translateY(-2px);box-shadow:var(--sh-n)}
.btn--outline-n{background:transparent;color:var(--navy);border-color:var(--navy)}
.btn--outline-n:hover{background:var(--navy);color:var(--white)}
.btn--outline-w{background:transparent;color:var(--white);border-color:rgba(255,255,255,0.65)}
.btn--outline-w:hover{background:rgba(255,255,255,0.12)}
.btn--ghost-g{background:var(--gold-light);color:var(--gold);border-color:var(--gold-light)}
.btn--ghost-g:hover{background:#fde8b0;transform:translateY(-2px)}
.btn--lg{padding:16px 40px;font-size:16px}

/* ======== SECTION WRAPPERS ======== */
.sec{padding:88px 0}
.sec--off{background:var(--off)}
.sec--pale{background:var(--navy-pale)}
.sec--gold-pale{background:var(--gold-light)}
.sec--navy{background:var(--navy)}
/* 対角カット */
.sec--clip-top{clip-path:polygon(0 40px,100% 0,100% 100%,0 100%);margin-top:-40px;padding-top:120px}
.sec--clip-both{clip-path:polygon(0 40px,100% 0,100% calc(100% - 40px),0 100%);margin-top:-40px;padding-top:120px;padding-bottom:120px}

/* ======== セクション見出し ======== */
.sh{margin-bottom:56px}
.sh--center{text-align:center}
.sh__label{
  display:inline-block;font-size:11px;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--gold);margin-bottom:10px;
}
.sh__label--w{color:rgba(255,255,255,0.60)}
.sh__h{font-size:clamp(24px,3.2vw,38px);font-weight:900;color:var(--ink);line-height:1.25}
.sh__h--w{color:var(--white)}
.sh__line{
  display:block;width:48px;height:4px;
  background:var(--gold);border-radius:2px;margin-top:14px;
}
.sh--center .sh__line{margin-left:auto;margin-right:auto}
.sh__line--w{background:var(--gold-mid)}
.sh__sub{margin-top:16px;font-size:15px;color:var(--ink-soft);line-height:1.9}

/* ======== 課題セクション ======== */
/* 背景: ドットグリッドパターン */
.sec--dotgrid{
  background-color:var(--off);
  background-image:radial-gradient(circle, var(--border) 1.5px, transparent 1.5px);
  background-size:28px 28px;
}
.problem-grid{
  display:grid;grid-template-columns:1fr 1fr;
  grid-template-rows:auto auto;gap:24px;
}
.problem-grid .pc:first-child{grid-column:1;grid-row:1}
.problem-grid .pc:nth-child(2){grid-column:2;grid-row:1}
.problem-grid .pc:nth-child(3){grid-column:1/-1}
/* アウトラインカード — ナビー版 */
.pc{
  border:2px solid var(--navy);border-radius:var(--r);
  padding:32px 28px;position:relative;
  background:var(--white);
  transition:transform var(--t),box-shadow var(--t),background var(--t);
}
.pc:hover{transform:translateY(-4px);box-shadow:var(--sh-hov);background:var(--navy-pale)}
.pc__num{
  font-size:56px;font-weight:900;
  color:var(--navy-light);line-height:1;
  position:absolute;top:20px;right:24px;
  letter-spacing:-.04em;user-select:none;
}
.pc__tag{
  font-size:11px;font-weight:700;letter-spacing:.12em;
  color:var(--gold);text-transform:uppercase;margin-bottom:12px;
}
.pc__h{font-size:17px;font-weight:900;color:var(--navy);line-height:1.4;margin-bottom:12px}
.pc__p{font-size:14px;color:var(--ink-mid);line-height:1.85}
.pc--wide{display:grid;grid-template-columns:1fr 2fr;gap:24px;align-items:center}
.pc--wide .pc__num{position:static;font-size:64px;color:var(--navy-light)}

/* ======== サービス概要 ======== */
/* 右側: CSSドット装飾ボックス */
.overview-layout{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.overview-deco{
  position:relative;
  border-radius:12px;
  background:linear-gradient(135deg, var(--navy) 0%, var(--navy-mid) 100%);
  height:340px;
  overflow:hidden;
  box-shadow:var(--sh-hov);
}
/* 装飾: 大きな円 */
.overview-deco::before{
  content:'';
  position:absolute;top:-60px;right:-60px;
  width:280px;height:280px;border-radius:50%;
  background:rgba(200,136,26,0.20);
}
.overview-deco::after{
  content:'';
  position:absolute;bottom:-80px;left:-40px;
  width:240px;height:240px;border-radius:50%;
  background:rgba(255,255,255,0.07);
}
/* 内部テキスト装飾 */
.overview-deco__inner{
  position:relative;z-index:1;
  height:100%;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:20px;padding:32px;
}
.overview-deco__tag{
  font-size:11px;font-weight:700;letter-spacing:.18em;
  color:var(--gold-mid);text-transform:uppercase;
}
.overview-deco__big{
  font-size:clamp(32px,4vw,52px);font-weight:900;
  color:var(--white);text-align:center;line-height:1.3;
}
.overview-deco__big span{color:var(--gold-mid)}
.overview-deco__line{width:48px;height:3px;background:var(--gold-mid);border-radius:2px}
.overview-deco__note{
  font-size:13px;color:rgba(255,255,255,0.65);text-align:center;line-height:1.7;
}
/* テキスト側 */
.overview-tag{font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.overview-h{font-size:clamp(22px,2.8vw,32px);font-weight:900;color:var(--ink);line-height:1.3;margin-bottom:18px}
.overview-body{font-size:15px;color:var(--ink-mid);line-height:1.9;margin-bottom:32px}
.feat-list{display:flex;flex-direction:column;gap:14px}
.feat{
  display:flex;align-items:flex-start;gap:14px;
  padding:16px 18px;
  border-left:4px solid var(--gold);
  background:var(--gold-light);
  border-radius:0 var(--r) var(--r) 0;
}
.feat__mark{
  width:24px;height:24px;flex-shrink:0;
  background:var(--gold);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--white);font-size:12px;font-weight:900;margin-top:1px;
}
.feat__h{font-size:14px;font-weight:900;color:var(--gold);margin-bottom:3px}
.feat__p{font-size:13px;color:var(--ink-mid);line-height:1.7}

/* ======== WEB広告 ======== */
/* 背景: 斜線ストライプ */
.sec--stripe{
  background-color:var(--off);
  background-image:repeating-linear-gradient(
    -45deg,
    transparent,transparent 12px,
    rgba(27,58,107,0.03) 12px,rgba(27,58,107,0.03) 13px
  );
}
.ad-header-row{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;margin-bottom:48px}
.ad-header-deco{
  border-radius:10px;overflow:hidden;
  background:linear-gradient(135deg,var(--navy-pale) 0%, var(--border) 100%);
  height:240px;position:relative;
  box-shadow:var(--sh-n);display:flex;align-items:center;justify-content:center;
}
.ad-header-deco::before{
  content:'WEB広告';
  font-size:100px;font-weight:900;
  color:rgba(27,58,107,0.06);
  font-family:var(--font);
  position:absolute;
  user-select:none;
}
.ad-header-deco__badges{
  position:relative;z-index:1;
  display:flex;flex-wrap:wrap;gap:10px;justify-content:center;padding:20px;
}
.ad-badge{
  background:var(--navy);color:var(--white);
  font-size:13px;font-weight:700;
  padding:8px 18px;border-radius:4px;
  box-shadow:0 2px 8px rgba(27,58,107,0.30);
}
.ad-h{font-size:clamp(20px,2.6vw,30px);font-weight:900;color:var(--ink);margin-bottom:14px}
.ad-p{font-size:15px;color:var(--ink-mid);line-height:1.9}
/* 4枚タイル */
.media-tiles{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--border);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;
}
.mt{
  background:var(--white);padding:28px 20px;
  display:flex;flex-direction:column;gap:10px;
  transition:background var(--t),transform var(--t);
}
.mt:hover{background:var(--navy-pale);transform:scale(1.02);z-index:1;box-shadow:var(--sh-n)}
.mt__num{
  font-size:28px;font-weight:900;
  color:var(--navy-light);line-height:1;margin-bottom:4px;
}
.mt__h{font-size:14px;font-weight:900;color:var(--navy);line-height:1.45}
.mt__link{
  margin-top:auto;font-size:12px;font-weight:700;color:var(--gold);
  display:inline-flex;align-items:center;gap:4px;
  border-bottom:1px solid var(--gold);width:fit-content;transition:gap var(--t);
}
.mt:hover .mt__link{gap:8px}

/* ======== SEO ======== */
/* 右側デコ: CSSのみ */
.seo-layout{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.seo-deco{
  border-radius:10px;overflow:hidden;
  background:linear-gradient(160deg, #1b3a6b 0%, #2c5294 60%, #1a5c6e 100%);
  height:280px;position:relative;
  box-shadow:var(--sh-n);
  display:flex;align-items:center;justify-content:center;
}
.seo-deco::before{
  content:'SEO';
  position:absolute;
  font-size:130px;font-weight:900;
  color:rgba(255,255,255,0.06);
  font-family:var(--font);letter-spacing:-.04em;
  user-select:none;
}
.seo-deco::after{
  content:'';
  position:absolute;bottom:-40px;right:-40px;
  width:160px;height:160px;border-radius:50%;
  background:rgba(200,136,26,0.18);
}
.seo-deco__inner{
  position:relative;z-index:1;
  text-align:center;padding:24px;
}
.seo-deco__label{font-size:11px;font-weight:700;letter-spacing:.18em;color:var(--gold-mid);margin-bottom:12px}
.seo-deco__title{font-size:28px;font-weight:900;color:var(--white);line-height:1.3;margin-bottom:8px}
.seo-deco__sub{font-size:13px;color:rgba(255,255,255,0.65)}
.seo-h{font-size:clamp(20px,2.6vw,30px);font-weight:900;color:var(--navy);margin-bottom:14px}
.seo-p{font-size:15px;color:var(--ink-mid);line-height:1.9;margin-bottom:28px}
.seo-card{
  border:2px solid var(--navy);border-radius:var(--r);
  padding:24px;display:flex;gap:18px;align-items:flex-start;
  transition:transform var(--t),box-shadow var(--t);
}
.seo-card:hover{transform:translateY(-3px);box-shadow:var(--sh-n)}
.seo-card__ic{font-size:32px;flex-shrink:0}
.seo-card__h{font-size:15px;font-weight:900;color:var(--navy);margin-bottom:6px}
.seo-card__p{font-size:14px;color:var(--ink-mid);line-height:1.8}
.seo-card__lnk{display:inline-block;margin-top:10px;font-size:13px;font-weight:700;color:var(--gold)}
.seo-card__lnk:hover{text-decoration:underline}

/* ======== 料金 ======== */
.pricing-2col{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.pt-block__h{
  font-size:16px;font-weight:900;color:var(--white);
  background:var(--navy);padding:12px 16px;border-radius:var(--r) var(--r) 0 0;
  border-left:4px solid var(--gold);
}
.pt{width:100%;border-collapse:collapse;font-size:14px;border:1px solid var(--border);border-top:none}
.pt th{background:var(--navy-pale);padding:10px 14px;font-weight:700;color:var(--navy);text-align:left;border-bottom:1px solid var(--border)}
.pt td{padding:10px 14px;border-bottom:1px solid var(--border);color:var(--ink)}
.pt tr:last-child td{border-bottom:none}
.pt tr:nth-child(even) td{background:var(--off)}
.free-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.ft{background:var(--gold);color:var(--white);font-size:12px;font-weight:700;padding:4px 14px;border-radius:20px}
.pricing-links{display:flex;gap:16px;justify-content:center;margin-top:40px;flex-wrap:wrap}

/* ======== FAQ ======== */
.faq-wrap{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
.faq{border-radius:var(--r);overflow:hidden;border:1px solid var(--border)}
.faq__q{
  display:flex;align-items:flex-start;justify-content:space-between;gap:12px;
  padding:17px 20px;cursor:pointer;background:var(--white);transition:background var(--t);
}
.faq__q:hover{background:var(--navy-pale)}
.faq__q-inner{display:flex;align-items:flex-start;gap:12px;flex:1}
.faq__q-badge{
  min-width:28px;height:28px;
  background:var(--gold);color:var(--white);
  border-radius:4px;display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:900;flex-shrink:0;margin-top:1px;
}
.faq__q-text{font-size:14px;font-weight:700;color:var(--navy);line-height:1.6}
.faq__toggle{font-size:22px;color:var(--gold);flex-shrink:0;transition:transform var(--t);line-height:1;margin-top:2px}
.faq.open .faq__toggle{transform:rotate(45deg)}
.faq__a{
  display:none;padding:16px 20px 16px 60px;
  font-size:14px;color:var(--ink-mid);line-height:1.85;
  background:var(--navy-pale);border-top:1px solid var(--border);
}
.faq.open .faq__a{display:block}

/* ======== 会社概要 ======== */
.company-layout{display:grid;grid-template-columns:5fr 7fr;gap:48px;align-items:start}
.company-lead{font-size:15px;color:var(--ink-mid);line-height:1.9;margin-bottom:24px}
.company-lnk{
  display:inline-flex;align-items:center;gap:6px;
  font-size:14px;font-weight:700;color:var(--navy);
  border-bottom:2px solid var(--gold);padding-bottom:2px;
}
.company-lnk:hover{color:var(--navy-dark)}
.ctbl{width:100%;border-collapse:collapse;font-size:14px}
.ctbl th{
  width:120px;padding:10px 14px;vertical-align:top;
  background:var(--navy-pale);font-weight:700;color:var(--navy);
  border-bottom:1px solid var(--border);white-space:nowrap;
  border-left:3px solid var(--gold);
}
.ctbl td{padding:10px 14px;border-bottom:1px solid var(--border);vertical-align:top}

/* ======== 最終CTA ======== */
/* navy背景 + 大きなタイポ装飾 */
.fcta{
  text-align:center;position:relative;overflow:hidden;
  background:linear-gradient(135deg, var(--navy-dark) 0%, var(--navy) 60%, var(--navy-mid) 100%);
}
.fcta::before{
  content:'CONTACT';
  position:absolute;
  font-size:clamp(80px,12vw,160px);font-weight:900;
  color:rgba(255,255,255,0.04);
  top:50%;left:50%;transform:translate(-50%,-50%);
  white-space:nowrap;letter-spacing:.08em;
  user-select:none;pointer-events:none;
  font-family:var(--font);
}
/* 右下装飾円 */
.fcta::after{
  content:'';
  position:absolute;bottom:-80px;right:-80px;
  width:280px;height:280px;border-radius:50%;
  background:rgba(200,136,26,0.15);
  pointer-events:none;
}
.fcta__deco-tl{
  position:absolute;top:-60px;left:-60px;
  width:200px;height:200px;border-radius:50%;
  background:rgba(255,255,255,0.04);
  pointer-events:none;
}
.fcta__inner{position:relative;z-index:1;padding:88px 28px;max-width:680px;margin:0 auto}
.fcta__h{font-size:clamp(24px,3.2vw,38px);font-weight:900;color:var(--white);margin-bottom:20px;line-height:1.3}
.fcta__p{font-size:15px;color:rgba(255,255,255,0.78);line-height:1.9;margin-bottom:36px}
.fcta__btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ======== FOOTER ======== */
.ft-bar{background:var(--navy-dark);padding:26px 0}
.ft-bar__in{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px}
.ft-nav{display:flex;gap:20px;flex-wrap:wrap}
.ft-nav a{font-size:12px;color:rgba(255,255,255,0.55);transition:color var(--t)}
.ft-nav a:hover{color:var(--gold-mid)}
.ft-copy{font-size:11px;color:rgba(255,255,255,0.30)}

/* ======== RESPONSIVE ======== */
@media(max-width:1023px){
  .media-tiles{grid-template-columns:repeat(2,1fr)}
  .pricing-2col{grid-template-columns:1fr}
  .ad-header-row,.overview-layout,.seo-layout,.company-layout{grid-template-columns:1fr;gap:32px}
  .seo-layout{direction:ltr}
}
@media(max-width:767px){
  .gnav{display:none;position:absolute;top:64px;left:0;right:0;z-index:999}
  .gnav.open{
    display:flex;flex-direction:column;gap:0;
    background:var(--white);border-bottom:1px solid var(--border);padding:12px 20px;
  }
  .gnav.open a{padding:11px 4px;border-bottom:1px solid var(--border)}
  .gnav.open a:last-child{border:none}
  .gnav.open .cta-btn{margin:8px 0 0;text-align:center}
  .burger{display:flex}
  #vk-mobile-nav-menu-btn,.vk-mobile-nav-menu-btn{display:none !important}
  .problem-grid{grid-template-columns:1fr}
  .problem-grid .pc:first-child,.problem-grid .pc:nth-child(2),.problem-grid .pc:nth-child(3){grid-column:1;grid-row:auto}
  .pc--wide{grid-template-columns:1fr;gap:8px}
  .media-tiles{grid-template-columns:1fr 1fr}
  .sec{padding:60px 0}
  .hero{min-height:auto}
  .hero__inner{padding:60px 20px 100px}
  .hero__btns{flex-direction:column;align-items:center}
  .fcta__btns{flex-direction:column;align-items:center}
  .pricing-links{flex-direction:column;align-items:center}
  .overview-deco,.seo-deco,.ad-header-deco{height:200px}
  .ad-header-deco::before{font-size:52px}

  /* SP: サービス詳細ドロップダウンを常に展開 */
  .gnav.open .gnav-dropdown {
    display: flex;
    flex-direction: column;
    width: 100%;
  }
  .gnav.open .gnav-dropdown__menu {
    display: block !important;
    position: static;
    box-shadow: none;
    border: none;
    border-radius: 0;
    padding: 0;
    min-width: unset;
    background: transparent;
    white-space: normal;
  }
  .gnav.open .gnav-dropdown__menu li a {
    padding: 11px 4px 11px 20px;
    font-size: 13px;
    color: var(--navy);
    font-weight: 400;
    border-bottom: 1px solid var(--border);
  }
  .gnav.open .gnav-dropdown__trigger {
    border-bottom: 1px solid var(--border);
  }
}

/* =====================================================================
   6. サービス詳細ハブ＆各サービスページ共通スタイル
   ===================================================================== */
/* ===== BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}


.wrap{max-width:var(--max);margin:0 auto;padding:0 28px}

.hd{
  position:fixed;top:0;left:0;right:0;width:100%;z-index:1000;
  background:var(--white);
  border-bottom:1px solid var(--border);
}
.hd__in{
  display:flex;align-items:center;justify-content:space-between;
  max-width:var(--max);margin:0 auto;
  padding:0 20px 0 28px;height:64px;
}
.hd__logo img{height:36px;width:auto}
.gnav{display:flex;align-items:center;gap:4px;padding-right:20px}
.gnav a{
  font-size:14px;font-weight:400;color:var(--navy);
  padding:7px 14px;border-radius:4px;
  border-bottom:2px solid transparent;
  transition:all var(--t);
}
.gnav a:hover{color:var(--navy-dark);border-bottom-color:var(--gold);font-weight:500}
.gnav .cta-btn{
  background:var(--navy);color:var(--white);
  padding:8px 20px;border-radius:var(--r);
  border-bottom:none;font-weight:700;margin-left:8px;
}
.gnav .cta-btn:hover{background:var(--navy-dark);transform:translateY(-1px);box-shadow:var(--sh-n)}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px}
.burger span{display:block;width:24px;height:2px;background:var(--navy);border-radius:2px}

.ft-bar{background:var(--navy-dark);padding:26px 0}
.ft-bar__in{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px}
.ft-nav{display:flex;gap:20px;flex-wrap:wrap}
.ft-nav a{font-size:12px;color:rgba(255,255,255,0.55);transition:color var(--t)}
.ft-nav a:hover{color:var(--gold-mid)}
.ft-copy{font-size:11px;color:rgba(255,255,255,0.30)}

/* ===== HERO ===== */
.page-hero{
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-dark) 60%,#0d1e3e 100%);
  color:#fff;padding:72px 20px 80px;
  position:relative;overflow:hidden;
  clip-path:polygon(0 0,100% 0,100% 85%,0 100%);
  margin-bottom:-40px;
}
.page-hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 80% 50%,rgba(200,136,26,.15) 0%,transparent 60%),
             radial-gradient(circle at 20% 80%,rgba(255,255,255,.04) 0%,transparent 40%);
}
/* grid dots */
.page-hero::after{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px);
  background-size:28px 28px;
}
.hero-inner{
  max-width:800px;margin:0 auto;
  position:relative;z-index:1;text-align:center;
}
.hero-badge{
  display:inline-block;
  background:rgba(200,136,26,.2);border:1px solid rgba(200,136,26,.5);
  color:var(--gold-light);font-size:12px;font-weight:700;
  padding:4px 16px;border-radius:20px;letter-spacing:.1em;
  margin-bottom:20px;text-transform:uppercase;
}
.hero-title{
  font-size:clamp(2rem,5vw,3rem);font-weight:700;
  line-height:1.3;margin-bottom:16px;
}
.hero-title span{color:var(--gold);}
.hero-sub{
  font-size:clamp(1rem,2vw,1.15rem);
  opacity:.85;margin-bottom:32px;
}
.hero-tags{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;}
.hero-tag{
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
  color:#fff;padding:6px 16px;border-radius:20px;
  font-size:13px;font-weight:500;
}

/* ===== SECTION BASE ===== */
.section{padding:80px 20px;}
.container{max-width:1100px;margin:0 auto;}
.section-eyebrow{
  display:inline-block;
  color:var(--gold);font-size:12px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  margin-bottom:12px;
}
.section-title{
  font-size:clamp(1.6rem,3vw,2.2rem);font-weight:700;
  color:var(--navy);line-height:1.4;margin-bottom:12px;
}
.section-title span{color:var(--gold);}
.section-lead{
  color:#555;font-size:1rem;max-width:600px;
  margin-bottom:48px;
}
.section-divider{
  width:48px;height:4px;
  background:linear-gradient(90deg,var(--gold),var(--gold-light));
  border-radius:2px;margin-bottom:20px;
}

/* ===== WEB AD SECTION ===== */
.webad-section{background:#fff;padding-top:100px;}
.webad-section .container{position:relative;}

.service-block{
  display:grid;grid-template-columns:1fr 1fr;gap:48px;
  align-items:start;margin-bottom:48px;
}
.service-block-info{}
.service-block-detail{
  background:var(--ice);border-radius:12px;
  padding:32px;border-left:4px solid var(--navy);
}
.service-block-detail h3{
  font-size:1.1rem;font-weight:700;color:var(--navy);
  margin-bottom:16px;display:flex;align-items:center;gap:8px;
}
.service-block-detail h3 .dot{
  width:8px;height:8px;background:var(--gold);border-radius:50%;
}
.service-block-detail ul{list-style:none;display:flex;flex-direction:column;gap:10px;}
.service-block-detail ul li{
  font-size:0.95rem;color:var(--dark);
  display:flex;align-items:flex-start;gap:8px;padding-left:4px;
}
.service-block-detail ul li::before{
  content:'✓';color:var(--gold);font-weight:700;flex-shrink:0;margin-top:1px;
}

/* Media Cards */
.media-cards{
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px;
  margin-top:32px;
}
.media-card{
  background:#fff;border:1.5px solid var(--border);
  border-radius:12px;padding:24px 16px;
  text-align:center;transition:all .25s;
  position:relative;overflow:hidden;
}
.media-card::before{
  content:'';position:absolute;top:0;left:0;right:0;
  height:4px;background:linear-gradient(90deg,var(--navy),var(--gold));
  transform:scaleX(0);transition:transform .25s;transform-origin:left;
}
.media-card:hover{
  box-shadow:var(--shadow);transform:translateY(-4px);
  border-color:var(--navy);
}
.media-card:hover::before{transform:scaleX(1);}
.media-icon{
  width:56px;height:56px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 12px;font-size:22px;
}
.media-icon.google{background:#fde8e8;}
.media-icon.yahoo{background:#fff2e0;}
.media-icon.meta{background:#e8eeff;}
.media-icon.x{background:#e8e8e8;}
.media-card h4{font-size:0.95rem;font-weight:700;color:var(--navy);margin-bottom:6px;}
.media-card p{font-size:0.82rem;color:#666;line-height:1.6;margin-bottom:12px;}
.media-card-link{
  font-size:0.82rem;color:var(--gold);font-weight:700;
  display:inline-flex;align-items:center;gap:4px;
}
.media-card-link::after{content:'→';}

/* ===== SEO SECTION ===== */
.seo-section{background:var(--ice);position:relative;overflow:hidden;}
.seo-section::before{
  content:'SEO';
  position:absolute;right:-20px;top:50%;transform:translateY(-50%);
  font-size:180px;font-weight:700;
  color:rgba(27,58,107,.05);line-height:1;pointer-events:none;
  letter-spacing:-10px;
}
.seo-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;}
.seo-features{display:flex;flex-direction:column;gap:16px;margin-top:24px;}
.seo-feature{
  background:#fff;border-radius:10px;padding:20px 24px;
  display:flex;align-items:flex-start;gap:16px;
  box-shadow:0 2px 8px rgba(27,58,107,.06);
  border-left:3px solid var(--gold);
}
.seo-feature-num{
  width:36px;height:36px;background:var(--navy);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:13px;font-weight:700;flex-shrink:0;
}
.seo-feature-body h4{font-size:0.95rem;font-weight:700;color:var(--navy);margin-bottom:4px;}
.seo-feature-body p{font-size:0.88rem;color:#555;}

.seo-industries{margin-top:32px;}
.seo-industries h3{
  font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:16px;
  display:flex;align-items:center;gap:8px;
}
.seo-industries h3::before{
  content:'';width:4px;height:18px;background:var(--gold);border-radius:2px;
}
.industry-tags{display:flex;flex-wrap:wrap;gap:8px;}
.industry-tag{
  background:var(--navy);color:#fff;
  padding:6px 14px;border-radius:20px;
  font-size:0.82rem;font-weight:500;
}

/* ===== OPTION SECTION ===== */
.option-section{background:#fff;}
.option-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
}
.option-card{
  border:1px solid var(--border);border-radius:10px;
  padding:24px;transition:all .2s;
  position:relative;
}
.option-card:hover{
  border-color:var(--gold);box-shadow:var(--shadow);
}
.option-card-header{
  display:flex;align-items:center;gap:10px;margin-bottom:12px;
}
.option-icon{
  width:40px;height:40px;background:var(--ice);
  border-radius:8px;display:flex;align-items:center;
  justify-content:center;font-size:18px;flex-shrink:0;
}
.option-card h4{font-size:0.95rem;font-weight:700;color:var(--navy);}
.option-price{
  font-size:1.1rem;font-weight:700;color:var(--gold);
  margin-bottom:8px;
}
.option-price small{font-size:0.8rem;color:#888;font-weight:400;}
.option-card p{font-size:0.85rem;color:#666;line-height:1.6;}

/* ===== PRICING GUIDE ===== */
.pricing-guide{background:var(--navy);color:#fff;position:relative;overflow:hidden;}
.pricing-guide::before{
  content:'';position:absolute;top:-60px;right:-60px;
  width:240px;height:240px;
  background:rgba(200,136,26,.12);border-radius:50%;
}
.pricing-guide::after{
  content:'';position:absolute;bottom:-40px;left:-40px;
  width:160px;height:160px;
  background:rgba(255,255,255,.04);border-radius:50%;
}
.pricing-inner{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:48px;
  align-items:center;position:relative;z-index:1;
}
.pricing-text h2{
  font-size:clamp(1.6rem,3vw,2.2rem);font-weight:700;
  color:#fff;margin-bottom:16px;line-height:1.4;
}
.pricing-text h2 span{color:var(--gold);}
.pricing-text p{opacity:.85;font-size:0.95rem;line-height:1.8;}
.pricing-cards{display:flex;flex-direction:column;gap:16px;}
.pricing-row{
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);
  border-radius:10px;padding:20px 24px;
  display:flex;justify-content:space-between;align-items:center;
}
.pricing-row-label{font-size:0.9rem;font-weight:500;opacity:.9;}
.pricing-row-val{
  font-size:1.3rem;font-weight:700;color:var(--gold);
}
.pricing-row-val small{font-size:0.75rem;color:rgba(255,255,255,.6);font-weight:400;margin-left:4px;}
.pricing-note{
  font-size:0.82rem;opacity:.65;margin-top:12px;text-align:center;
}
.pricing-cta-row{
  display:flex;gap:12px;margin-top:24px;flex-wrap:wrap;
}
.btn-gold{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--gold);color:#fff;
  padding:12px 28px;border-radius:var(--radius);
  font-weight:700;font-size:0.95rem;
  transition:background .2s;
}
.btn-gold:hover{background:#a86e10;}
.btn-outline-white{
  display:inline-flex;align-items:center;gap:6px;
  background:transparent;color:#fff;
  border:2px solid rgba(255,255,255,.4);
  padding:10px 28px;border-radius:var(--radius);
  font-weight:700;font-size:0.95rem;
  transition:border-color .2s;
}
.btn-outline-white:hover{border-color:#fff;}

/* ===== FAQ ===== */
.faq-section{background:var(--ice);}
.faq-list{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:12px;}
.faq-item{
  background:#fff;border-radius:10px;
  border:1px solid var(--border);overflow:hidden;
}
.faq-q{
  padding:20px 24px;cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;
  gap:16px;transition:background .15s;
}
.faq-q:hover{background:var(--ice);}
.faq-q-text{font-weight:700;color:var(--navy);font-size:0.95rem;display:flex;align-items:flex-start;gap:10px;}
.faq-q-text::before{
  content:'Q';background:var(--navy);color:#fff;
  width:22px;height:22px;border-radius:4px;
  font-size:12px;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;margin-top:1px;
}
.faq-toggle{
  width:24px;height:24px;border-radius:50%;
  background:var(--ice);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:transform .25s,background .15s;
  font-size:14px;color:var(--navy);
}
.faq-item.open .faq-toggle{transform:rotate(45deg);background:var(--navy);color:#fff;}
.faq-a{
  max-height:0;overflow:hidden;transition:max-height .35s ease;
}
.faq-item.open .faq-a{max-height:300px;}
.faq-a-inner{
  padding:0 24px 20px 24px;
  border-top:1px solid var(--border);
  padding-top:16px;
}
.faq-a-inner p{
  font-size:0.9rem;color:#444;line-height:1.8;
  display:flex;align-items:flex-start;gap:10px;
}
.faq-a-inner p > span{flex:1;}
.faq-a-inner p::before{
  content:'A';background:var(--gold);color:#fff;
  width:22px;height:22px;border-radius:4px;
  font-size:12px;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;margin-top:2px;
}

/* ===== FINAL CTA ===== */
.final-cta{
  background:linear-gradient(135deg,var(--green-cta) 0%,#0f3620 100%);
  color:#fff;padding:80px 20px;
  text-align:center;position:relative;overflow:hidden;
}
.final-cta::before{
  content:'';position:absolute;
  top:-80px;right:-80px;
  width:300px;height:300px;
  background:rgba(255,255,255,.04);border-radius:50%;
}
.final-cta::after{
  content:'';position:absolute;
  bottom:-60px;left:-60px;
  width:200px;height:200px;
  background:rgba(255,255,255,.03);border-radius:50%;
}
.final-cta h2{
  font-size:clamp(1.6rem,3vw,2.2rem);font-weight:700;
  margin-bottom:16px;position:relative;z-index:1;
}
.final-cta p{
  opacity:.85;font-size:1rem;
  margin-bottom:36px;position:relative;z-index:1;
}
.cta-buttons{
  display:flex;gap:16px;justify-content:center;flex-wrap:wrap;
  position:relative;z-index:1;
}
.btn-white{
  display:inline-flex;align-items:center;gap:6px;
  background:#fff;color:var(--green-cta);
  padding:14px 36px;border-radius:var(--radius);
  font-weight:700;font-size:1rem;
  transition:box-shadow .2s;
}
.btn-white:hover{box-shadow:0 4px 16px rgba(0,0,0,.25);}
.btn-outline-green{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--green-light);color:var(--green-cta);
  padding:14px 36px;border-radius:var(--radius);
  font-weight:700;font-size:1rem;
  transition:background .2s;
}
.btn-outline-green:hover{background:#c8e6cb;}

/* ===== FOOTER ===== */




.footer-nav a:hover{color:#fff;}


/* ===== BREADCRUMB ===== */
.breadcrumb{background:var(--ice-dark);padding:12px 20px;}
.breadcrumb-inner{max-width:1100px;margin:0 auto;}
.breadcrumb ul{
  display:flex;gap:8px;list-style:none;
  font-size:12px;color:#888;flex-wrap:wrap;
}
.breadcrumb ul li a{color:var(--navy);text-decoration:none;}
.breadcrumb ul li a:hover{text-decoration:underline;}
.breadcrumb ul li + li::before{content:'›';margin-right:8px;}

/* ===== HAMBURGER (mobile) ===== */



/* ===== RESPONSIVE ===== */
@media(max-width:1023px){
  .service-block{grid-template-columns:1fr;}
  .media-cards{grid-template-columns:repeat(2,1fr);}
  .seo-grid{grid-template-columns:1fr;}
  .option-grid{grid-template-columns:repeat(2,1fr);}
  .pricing-inner{grid-template-columns:1fr;}
}
@media(max-width:767px){
  .global-nav{display:none;}
  .hamburger{display:flex;}
  .page-hero{padding:56px 20px 72px;clip-path:polygon(0 0,100% 0,100% 92%,0 100%);}
  .section{padding:56px 20px;}
  .media-cards{grid-template-columns:1fr 1fr;}
  .option-grid{grid-template-columns:1fr;}
  .pricing-cta-row{flex-direction:column;}
  .cta-buttons{flex-direction:column;align-items:center;}
  .seo-section::before{font-size:100px;}
}

/* =====================================================================
   7. 料金・導入・会社・相談・問い合わせ ページ共通スタイル
   ===================================================================== */
/* ===== root variables ===== */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font);color:var(--text);background:#fff;line-height:1.7;padding-top:64px}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto}
.wrap{max-width:1080px;margin:0 auto;padding:0 24px}

/* header / footer ── top_v6と同一 */
.hd{background:#fff;border-bottom:1px solid var(--border);position:fixed;top:0;left:0;right:0;width:100%;z-index:1000}
.hd__in{display:flex;align-items:center;justify-content:space-between;height:64px}
.hd-logo{font-size:1.1rem;font-weight:700;color:var(--navy)}
.gnav{display:flex;gap:24px;align-items:center}
.gnav a{font-size:.88rem;color:var(--text);transition:color .2s}
.gnav a:hover,.gnav a.active{color:var(--gold)}
.gnav .btn-cta{background:var(--gold);color:#fff;padding:8px 18px;border-radius:4px;font-size:.85rem;font-weight:700}
.gnav .btn-cta:hover{background:var(--gold-light);color:var(--navy)}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.burger span{display:block;width:24px;height:2px;background:var(--navy);border-radius:2px;transition:.3s}
.ft-bar{background:var(--navy);color:#fff;padding:32px 0}
.ft-bar__in{display:flex;flex-direction:column;align-items:center;gap:16px}
.ft-nav{display:flex;flex-wrap:wrap;justify-content:center;gap:16px}
.ft-nav a{color:#ccc;font-size:.85rem}
.ft-nav a:hover{color:#fff}
.ft-copy{font-size:.8rem;color:#aaa}

/* ── breadcrumb ── */
.breadcrumb{background:#f7f8fa;padding:10px 0;font-size:.82rem;color:var(--text-sub)}
.breadcrumb ol{display:flex;flex-wrap:wrap;gap:4px;list-style:none}
.breadcrumb li+li::before{content:"›";margin-right:4px}
.breadcrumb a{color:var(--text-sub);text-decoration:underline}

/* ── hero ── */
.hero{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-light) 100%);color:#fff;padding:72px 0 56px;text-align:center}
.hero h1{font-size:clamp(1.6rem,4vw,2.4rem);font-weight:700;margin-bottom:12px}
.hero p{font-size:1rem;color:rgba(255,255,255,.85);max-width:640px;margin:0 auto}

/* ── sections ── */
.sec{padding:72px 0}
.sec--gray{background:#f7f8fa}
.sec-ttl{text-align:center;margin-bottom:40px}
.sec-ttl h2{font-size:clamp(1.25rem,3vw,1.75rem);font-weight:700;color:var(--navy)}
.sec-ttl h2::after{content:'';display:block;width:48px;height:3px;background:var(--gold);margin:10px auto 0}
.sec-ttl p{color:var(--text-sub);margin-top:12px;font-size:.95rem}

/* ── table ── */
.fee-table{width:100%;border-collapse:collapse;margin-top:8px;font-size:.95rem}
.fee-table th,.fee-table td{border:1px solid var(--border);padding:12px 16px;text-align:left}
.fee-table thead th{background:var(--navy);color:#fff;font-weight:700}
.fee-table tbody tr:nth-child(even){background:#f7f8fa}
.fee-table tbody tr:hover{background:#eef2f8}
.fee-table .highlight td{background:var(--gold-light)!important;font-weight:700}

/* ── cards (3col) ── */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:8px}
.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:28px 24px;box-shadow:var(--shadow)}
.card-icon{font-size:2rem;margin-bottom:12px}
.card h3{font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:8px}
.card p{font-size:.9rem;color:var(--text-sub);line-height:1.65}

/* ── flow steps ── */
.flow-list{display:flex;flex-direction:column;gap:0;max-width:720px;margin:0 auto}
.flow-item{display:flex;gap:20px;align-items:flex-start;position:relative;padding-bottom:40px}
.flow-item:last-child{padding-bottom:0}
.flow-item:not(:last-child)::after{content:'';position:absolute;left:26px;top:52px;bottom:0;width:2px;background:var(--gold);opacity:.4}
.flow-num{flex-shrink:0;width:52px;height:52px;border-radius:50%;background:var(--navy);color:#fff;font-size:1.1rem;font-weight:700;display:flex;align-items:center;justify-content:center}
.flow-body h3{font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:4px}
.flow-body p{font-size:.9rem;color:var(--text-sub)}

/* ── FAQ accordion ── */
.faq-list{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.faq-q{width:100%;background:#fff;border:none;padding:18px 20px;font-size:.95rem;font-weight:700;color:var(--navy);cursor:pointer;text-align:left;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq-q::after{content:'+';font-size:1.2rem;flex-shrink:0;transition:transform .3s}
.faq-section .faq-q::after{display:none} /* serviceページはfaq-toggleスパンを使用 */
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{display:none;padding:16px 20px;font-size:.9rem;color:var(--text-sub);background:#f9f9f9;line-height:1.75}
.faq-item.open .faq-a{display:block}

/* ── final CTA ── */
.final-cta{background:linear-gradient(135deg,var(--green-cta) 0%,#0f3620 100%);color:#fff;padding:80px 0;text-align:center}
.final-cta h2{font-size:clamp(1.3rem,3vw,1.9rem);font-weight:700;margin-bottom:12px}
.final-cta p{color:rgba(255,255,255,.85);margin-bottom:32px;font-size:.95rem}
.btn-white{display:inline-block;background:#fff;color:var(--green-cta);font-weight:700;padding:16px 40px;border-radius:4px;font-size:1rem;transition:box-shadow .2s}
.btn-white:hover{box-shadow:0 4px 16px rgba(0,0,0,.25)}

/* ── info table (company) ── */
.info-table{width:100%;border-collapse:collapse;font-size:.93rem}
.info-table th,.info-table td{border:1px solid var(--border);padding:14px 18px;vertical-align:top}
.info-table th{background:#f7f8fa;font-weight:700;color:var(--navy);width:160px}

/* ── form ── */
.form-wrap{max-width:680px;margin:0 auto}
.form-row{margin-bottom:24px}
.form-row label{display:block;font-size:.9rem;font-weight:700;margin-bottom:6px;color:var(--navy)}
.form-row input,.form-row select,.form-row textarea{width:100%;border:1px solid var(--border);border-radius:4px;padding:12px 14px;font-size:.95rem;font-family:var(--font)}
.form-row textarea{resize:vertical}
.form-row .req{color:#c00;margin-left:4px;font-size:.8rem}
.form-row .opt{color:#888;margin-left:4px;font-size:.8rem}
.form-row .hint{font-size:.82rem;color:var(--text-sub);margin-top:4px}
.privacy-check{display:flex;gap:10px;align-items:flex-start;font-size:.88rem;color:var(--text-sub);margin-bottom:28px}
.privacy-check input{margin-top:3px}
.privacy-check a{color:var(--navy);text-decoration:underline}
.btn-submit{display:block;width:100%;background:var(--navy);color:#fff;font-weight:700;padding:16px;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background .2s}
.btn-submit:hover{background:var(--navy-light)}

/* ── thanks ── */
.thanks-wrap{max-width:640px;margin:0 auto;text-align:center;padding:72px 24px}
.thanks-wrap h2{font-size:1.6rem;font-weight:700;color:var(--navy);margin-bottom:20px}
.thanks-wrap p{font-size:.95rem;color:var(--text-sub);line-height:1.85;margin-bottom:12px}
.thanks-contact{background:#f7f8fa;border-radius:var(--radius);padding:24px;margin:32px 0}
.thanks-contact p{color:var(--text);font-weight:700;font-size:1rem}
.thanks-contact span{display:block;font-size:1.4rem;font-weight:700;color:var(--navy);margin-top:4px}
.thanks-contact small{font-size:.82rem;color:var(--text-sub);font-weight:400}
.btn-back{display:inline-block;background:var(--navy);color:#fff;font-weight:700;padding:14px 36px;border-radius:4px;margin-top:24px}
.btn-back:hover{background:var(--navy-light)}

/* ── pricing highlight ── */
.fee-note{background:var(--gold-light);border-left:4px solid var(--gold);padding:14px 18px;border-radius:0 4px 4px 0;font-size:.9rem;margin-top:16px;color:var(--text)}
.option-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:8px}
.option-item{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.option-item h4{font-size:.95rem;font-weight:700;color:var(--navy);margin-bottom:6px}
.option-item p{font-size:.9rem;color:var(--text-sub)}
.option-price{font-size:1.05rem;font-weight:700;color:var(--gold);margin-top:8px}
.calc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:8px}
.calc-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}
.calc-card h4{font-size:.9rem;color:var(--text-sub);margin-bottom:12px}
.calc-card .calc-row{display:flex;justify-content:space-between;font-size:.9rem;padding:6px 0;border-bottom:1px dashed var(--border)}
.calc-card .calc-total{display:flex;justify-content:space-between;font-weight:700;font-size:1rem;color:var(--navy);padding-top:10px}
.pay-list{list-style:none;max-width:600px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
.pay-list li{display:flex;gap:12px;align-items:flex-start;font-size:.93rem}
.pay-list li::before{content:'●';color:var(--gold);flex-shrink:0}
.tag-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.tag{background:var(--navy);color:#fff;border-radius:20px;padding:6px 16px;font-size:.85rem}

/* ── access ── */
.access-list{list-style:none;margin-top:8px;display:flex;flex-direction:column;gap:8px}
.access-list li{display:flex;gap:12px;align-items:baseline;font-size:.93rem}
.access-list li::before{content:'🚉';flex-shrink:0}
.map-placeholder{width:100%;height:360px;background:#eee;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:#888;font-size:.9rem;margin-top:20px}
.map-embed{width:100%;height:360px;border:0;border-radius:var(--radius);margin-top:20px}

/* ── consultation flow ── */
.consult-flow{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:8px}
.cf-item{text-align:center}
.cf-num{width:40px;height:40px;border-radius:50%;background:var(--navy);color:#fff;font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto 10px}
.cf-item h4{font-size:.9rem;font-weight:700;color:var(--navy);margin-bottom:4px}
.cf-item p{font-size:.82rem;color:var(--text-sub)}
.cf-arrow{display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:var(--gold)}
.hearing-list,.guidance-list{list-style:none;display:flex;flex-direction:column;gap:8px;max-width:640px;margin-top:12px}
.hearing-list li,.guidance-list li{display:flex;gap:10px;font-size:.93rem}
.hearing-list li::before,.guidance-list li::before{content:'✔';color:var(--gold);flex-shrink:0;margin-top:2px}
.radio-group,.check-group{display:block !important;width:100% !important;margin-top:6px}


/* ── responsive ── */
@media(max-width:768px){
  .card-grid{grid-template-columns:1fr}
  .option-grid{grid-template-columns:1fr}
  .calc-grid{grid-template-columns:1fr}
  .consult-flow{grid-template-columns:1fr 1fr}
  .info-table th{width:120px}
  .gnav{display:none}
  .burger{display:flex}
  #vk-mobile-nav-menu-btn,.vk-mobile-nav-menu-btn{display:none !important}
  .gnav.open{display:flex;flex-direction:column;position:fixed;top:64px;left:0;right:0;background:#fff;padding:20px;border-bottom:1px solid var(--border);box-shadow:0 4px 12px rgba(0,0,0,.1)}
}
@media(max-width:480px){
  .fee-table{font-size:.82rem}
  .fee-table th,.fee-table td{padding:8px 10px}
  .consult-flow{grid-template-columns:1fr}
  .flow-item:not(:last-child)::after{display:none}
}

/* =====================================================================
   8. レスポンシブ補完
   ===================================================================== */
@media (max-width: 768px) {
  .gnav { display: none; }
  .burger { display: flex; }
  .gnav.open {
    display: flex; flex-direction: column;
    position: fixed; top: 64px; left: 0; right: 0;
    background: var(--white); padding: 16px 24px;
    border-bottom: 1px solid var(--border);
    box-shadow: 0 4px 12px rgba(0,0,0,0.10);
    z-index: 999;
  }
  .gnav.open a { padding: 10px 0; border-bottom: 1px solid var(--navy-light); }
  .hd__in { padding: 0 16px; }
  .wrap { padding: 0 16px; }
}

/* ======== グロナビ ドロップダウン ======== */
.gnav-dropdown {
  position: relative;
  display: inline-block;
}
.gnav-dropdown__trigger {
  /* 既存の gnav a と同等スタイル */
}
.gnav-dropdown__menu {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 220px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--r);
  box-shadow: var(--sh-n);
  list-style: none;
  margin: 0;
  padding: 6px 0;
  z-index: 1000;
  white-space: nowrap;
}
.gnav-dropdown:hover .gnav-dropdown__menu,
.gnav-dropdown__menu:hover {
  display: block;
}
.gnav-dropdown__menu li {
  margin: 0;
  padding: 0;
}
.gnav-dropdown__menu li a {
  display: block;
  padding: 10px 18px;
  font-size: 0.88rem;
  color: var(--ink);
  font-weight: 500;
  text-decoration: none;
  transition: background var(--t), color var(--t);
}
.gnav-dropdown__menu li a:hover {
  background: var(--navy-light);
  color: var(--navy);
}

/* =====================================================================
   flow ページ専用追加スタイル
   ===================================================================== */

/* ── FV hero テキスト補完 ── */
.hero .hero-sub-copy {
  font-size: 1.05rem;
  font-weight: 700;
  color: rgba(255,255,255,.95);
  max-width: 640px;
  margin: 0 auto 14px;
  letter-spacing: .03em;
}
.hero .hero-body-copy {
  font-size: .95rem;
  color: rgba(255,255,255,.82);
  max-width: 640px;
  margin: 0 auto;
  line-height: 1.85;
}

/* ── タイムライン表 ── */
.tl-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.tl-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .93rem;
  min-width: 480px;
}
.tl-table thead tr {
  background: var(--navy);
  color: #fff;
}
.tl-table thead th {
  padding: 12px 16px;
  font-weight: 700;
  text-align: center;
  border: 1px solid var(--navy-mid);
}
.tl-th-step  { width: 70px; }
.tl-th-title { text-align: left !important; }
.tl-th-who   { width: 100px; }

.tl-table tbody tr {
  background: #fff;
  border-bottom: 1px solid var(--border);
  transition: background .15s;
}
.tl-table tbody tr:hover { background: var(--navy-pale); }
.tl-row--alt { background: var(--off) !important; }
.tl-row--alt:hover { background: var(--navy-pale) !important; }

.tl-num-cell  { text-align: center; padding: 14px 10px; border: 1px solid var(--border); }
.tl-title-cell { padding: 14px 16px; border: 1px solid var(--border); font-weight: 600; color: var(--navy); }
.tl-check-cell { text-align: center; padding: 14px 10px; border: 1px solid var(--border); font-size: 1.1rem; }

.tl-badge {
  display: inline-flex;
  align-items: center; justify-content: center;
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--navy);
  color: #fff;
  font-weight: 700;
  font-size: .9rem;
}
.tl-dot {
  color: var(--navy-mid);
  font-size: 1rem;
  font-weight: 700;
}
.tl-dot--both    { color: var(--gold); }
.tl-dot--sub     { color: var(--navy); }
.tl-dot--support { color: var(--ink-soft); }
.tl-dash { color: var(--border); font-size: 1.1rem; }

/* 凡例 */
.tl-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 16px 28px;
  list-style: none;
  margin-top: 16px;
  font-size: .82rem;
  color: var(--text-sub);
  align-items: center;
}
.tl-legend li { display: flex; align-items: center; gap: 6px; }

/* ── CTA ボタン 2連 ── */
.final-cta__btns {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}
.btn-white--outline {
  background: transparent !important;
  color: #fff !important;
  border: 2px solid rgba(255,255,255,.7);
}
.btn-white--outline:hover {
  background: rgba(255,255,255,.12) !important;
  box-shadow: none !important;
}

@media (max-width: 600px) {
  .hero .hero-sub-copy  { font-size: .95rem; }
  .hero .hero-body-copy { font-size: .88rem; }
  .tl-th-who { width: 72px; }
  .tl-legend { gap: 10px 18px; }
  .final-cta__btns { flex-direction: column; align-items: center; }
}

/* =====================================================================
   privacy ページ専用スタイル
   ===================================================================== */

/* ── ページ全体の幅制限 ── */
.pp-body {
  max-width: 800px;
  margin: 0 auto;
}

/* ── リード文 ── */
.pp-lead {
  background: var(--navy-pale);
  border-left: 4px solid var(--navy-mid);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 20px 24px;
  margin-bottom: 40px;
  font-size: .95rem;
  line-height: 1.85;
  color: var(--ink-mid);
}

/* ── 目次 ── */
.pp-toc {
  background: var(--off);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 24px 28px;
  margin-bottom: 48px;
}
.pp-toc::before {
  content: '目次';
  display: block;
  font-size: .78rem;
  font-weight: 700;
  color: var(--text-sub);
  letter-spacing: .12em;
  text-transform: uppercase;
  margin-bottom: 12px;
}
.pp-toc__list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
  counter-reset: toc-cnt;
}
.pp-toc__list li {
  counter-increment: toc-cnt;
  display: flex;
  align-items: baseline;
  gap: 10px;
  font-size: .9rem;
}
.pp-toc__list li::before {
  content: counter(toc-cnt, cjk-decimal) '．';
  color: var(--navy-mid);
  font-weight: 700;
  font-size: .82rem;
  flex-shrink: 0;
}
.pp-toc__list a {
  color: var(--navy);
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: color var(--t);
}
.pp-toc__list a:hover { color: var(--gold); }

/* ── 各条文セクション ── */
.pp-article {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.pp-section {
  padding: 32px 0;
  border-bottom: 1px solid var(--border);
  scroll-margin-top: 80px; /* 固定ヘッダー分オフセット */
}
.pp-section:first-child { padding-top: 0; }
.pp-section:last-child  { border-bottom: none; }

/* 見出し行 */
.pp-section__head {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 14px;
}
.pp-num {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--navy);
  color: #fff;
  font-size: .85rem;
  font-weight: 700;
  font-family: var(--font);
}
.pp-section__title {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--navy);
  line-height: 1.4;
}

/* 本文 */
.pp-section__body p {
  font-size: .93rem;
  color: var(--ink-mid);
  line-height: 1.9;
}

/* 連絡先ボックス */
.pp-contact-box {
  margin-top: 20px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px 24px;
  box-shadow: var(--shadow);
}
.pp-dl { display: flex; flex-direction: column; gap: 12px; }
.pp-dl__row {
  display: flex;
  gap: 16px;
  align-items: baseline;
  font-size: .9rem;
}
.pp-dl__row dt {
  font-weight: 700;
  color: var(--navy);
  white-space: nowrap;
  flex-shrink: 0;
  min-width: 180px;
}
.pp-dl__row dd { color: var(--ink-mid); }
.pp-dl__row dd a {
  color: var(--navy-mid);
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: color var(--t);
}
.pp-dl__row dd a:hover { color: var(--gold); }

/* ── SP対応 ── */
@media (max-width: 600px) {
  .pp-lead  { padding: 16px 18px; font-size: .9rem; }
  .pp-toc   { padding: 18px 20px; }
  .pp-toc__list li { font-size: .88rem; }
  .pp-section { padding: 24px 0; }
  .pp-num   { width: 30px; height: 30px; font-size: .78rem; }
  .pp-section__title { font-size: .98rem; }
  .pp-section__body p { font-size: .88rem; }
  .pp-dl__row { flex-direction: column; gap: 4px; }
  .pp-dl__row dt { min-width: unset; }
}

/* ================================================
   CF7 ラジオ・チェックボックス 縦並び修正
   .wpcf7-list-item は CF7 が inline-block で出力するため
   全階層を block 化して縦積みにする
   ================================================ */
.radio-group .wpcf7-form-control-wrap,
.check-group  .wpcf7-form-control-wrap {
  display: block !important;
  width: 100% !important;
}
.radio-group .wpcf7-form-control,
.check-group  .wpcf7-form-control {
  display: block !important;
  width: 100% !important;
}
.radio-group .wpcf7-list-item,
.check-group  .wpcf7-list-item {
  display: block !important;
  width: 100% !important;
  margin: 0 0 10px 0 !important;
}
.radio-group .wpcf7-list-item:last-child,
.check-group  .wpcf7-list-item:last-child {
  margin-bottom: 0 !important;
}
.radio-group .wpcf7-list-item label,
.check-group  .wpcf7-list-item label {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  cursor: pointer;
  font-size: .9rem;
}

/* =====================================================================
   ── サービス詳細ページ専用スタイル（/service/google/, yahoo/, meta/, x/, seo/）
   ── 旧 style-fix.css より統合
   ===================================================================== */

/* ─── ページヒーロー ─── */
.page-hero{
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-dark) 60%,#0d1e3e 100%);
  color:#fff;padding:72px 20px 80px;
  position:relative;overflow:hidden;
  clip-path:polygon(0 0,100% 0,100% 85%,0 100%);
  margin-bottom:-40px;
}
.page-hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(circle at 80% 50%,rgba(200,136,26,.18) 0%,transparent 55%),
    radial-gradient(circle at 20% 80%,rgba(44,82,148,.25) 0%,transparent 45%);
}
.page-hero::after{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:28px 28px;
}
.hero-inner{
  max-width:860px;margin:0 auto;
  position:relative;z-index:1;text-align:center;
}
.hero-title{font-size:clamp(1.7rem,4.5vw,2.8rem);font-weight:800;line-height:1.25;margin-bottom:14px;}
.hero-title span{color:var(--gold);}
.hero-sub{font-size:clamp(0.95rem,2vw,1.12rem);opacity:.88;margin-bottom:16px;}
.hero-body{font-size:0.97rem;opacity:.82;line-height:1.9;max-width:680px;margin:0 auto 32px;}
.hero-tags{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:24px;}
.hero-tag{
  background:rgba(255,255,255,.12);backdrop-filter:blur(4px);
  border:1px solid rgba(255,255,255,.25);
  color:#fff;border-radius:20px;padding:6px 18px;
  font-size:0.85rem;font-weight:500;
}
.hero-tag.highlight{background:var(--gold);border-color:var(--gold);color:#fff;font-weight:700;}


/* ─── 特徴カード（3カラムグリッド） ─── */
.features-section{background:var(--navy-pale);}
.feature-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.feature-card{
  background:#fff;border-radius:12px;padding:32px 28px;
  border:1.5px solid var(--border);
  position:relative;overflow:hidden;
  transition:all var(--t);
}
.feature-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--navy),var(--gold));
  opacity:0;transition:opacity var(--t);
}
.feature-card:hover{transform:translateY(-4px);box-shadow:var(--sh-hov);border-color:var(--navy-mid);}
.feature-card:hover::before{opacity:1;}
.feature-card-icon{font-size:36px;margin-bottom:16px;display:block;}
.feature-card h3{font-size:1.05rem;font-weight:700;color:var(--navy);margin-bottom:8px;padding-bottom:10px;border-bottom:1px solid var(--border);}
.feature-card p{font-size:0.9rem;color:var(--ink-soft);line-height:1.75;}

/* ─── 推奨業種（サービス詳細ページ用） ─── */
.industry-section{background:#fff;}
.industry-box{
  background:var(--navy);border-radius:16px;
  padding:40px 48px;
  display:grid;grid-template-columns:220px 1fr;gap:40px;align-items:center;
}
.industry-label h3{font-size:1.1rem;font-weight:700;color:#fff;margin-bottom:8px;}
.industry-label p{font-size:0.85rem;color:rgba(255,255,255,.65);line-height:1.7;}
.industry-box .industry-tags{display:flex;flex-wrap:wrap;gap:10px;}
.industry-box .industry-tag{
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);
  color:#fff;border-radius:20px;padding:7px 18px;
  font-size:0.85rem;font-weight:500;transition:all var(--t);
}
.industry-box .industry-tag:hover{background:rgba(255,255,255,.22);}

/* ─── 提供内容（2カラムグリッド） ─── */
.service-list-section{background:var(--navy-pale);}
.service-list{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;max-width:860px;}
.service-list-item{
  background:#fff;border-radius:10px;padding:22px 24px;
  border:1.5px solid var(--border);
  display:flex;align-items:flex-start;gap:14px;
  transition:all var(--t);
}
.service-list-item:hover{transform:translateY(-2px);box-shadow:var(--sh-n);border-color:var(--navy-light);}
.service-list-item span{font-size:0.9rem;color:var(--ink);font-weight:500;line-height:1.6;}
.service-num{
  width:36px;height:36px;flex-shrink:0;
  background:var(--navy);border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:13px;font-weight:700;
}

/* ─── 契約条件 ─── */
.contract-section{background:#fff;}
.contract-list{display:flex;flex-direction:column;gap:12px;max-width:720px;}
.contract-item{
  background:var(--navy-pale);border-radius:10px;
  padding:20px 24px;border-left:4px solid var(--gold);
  display:flex;align-items:flex-start;gap:12px;
}
.contract-item::before{content:'✓';color:var(--gold);font-weight:700;font-size:1rem;flex-shrink:0;margin-top:1px;}
.contract-item p{font-size:0.92rem;color:var(--ink);line-height:1.65;}

/* ─── 料金セクション ─── */
.pricing-section{
  background:var(--navy);color:#fff;
  padding:80px 20px;position:relative;overflow:hidden;
}
.pricing-section::before{
  content:'';position:absolute;
  width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(200,136,26,.15),transparent 70%);
  top:-120px;right:-100px;
}
.pricing-section::after{
  content:'';position:absolute;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.04),transparent 70%);
  bottom:-100px;left:-80px;
}
.pricing-section .pricing-inner{display:block;margin:0 auto;max-width:760px;position:relative;z-index:1;}
.pricing-section .pricing-inner .section-eyebrow{color:var(--gold-mid);}
.pricing-section .pricing-inner .section-eyebrow::after{background:rgba(255,255,255,.2);}
.pricing-section .pricing-inner h2{font-size:clamp(1.3rem,3vw,1.8rem);font-weight:800;color:#fff;margin:0 0 16px;}
.pricing-section .pricing-inner p{font-size:0.95rem;color:rgba(255,255,255,.8);line-height:1.8;margin-bottom:8px;}
.pricing-cta-area{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:32px;}
.btn-gold{
  display:inline-block;
  background:linear-gradient(135deg,var(--gold),var(--gold-mid));
  color:#fff;font-weight:700;padding:14px 36px;
  border-radius:var(--r);font-size:1rem;
  box-shadow:0 4px 16px rgba(200,136,26,.4);
  transition:all var(--t);
}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(200,136,26,.5);}
.btn-outline-white{
  display:inline-block;background:transparent;color:#fff;
  border:2px solid rgba(255,255,255,.6);
  padding:14px 36px;border-radius:var(--r);
  font-weight:700;font-size:1rem;transition:all var(--t);
}
.btn-outline-white:hover{border-color:#fff;background:rgba(255,255,255,.08);}

/* ─── FAQ ─── */
.faq-section{background:var(--off);}
.faq-list{max-width:760px;display:flex;flex-direction:column;gap:10px;}
.faq-item{background:#fff;border-radius:var(--r);border:1px solid var(--border);overflow:hidden;transition:box-shadow var(--t);}
.faq-item:hover{box-shadow:var(--sh-n);}
.faq-q{width:100%;background:none;border:none;display:flex;align-items:center;justify-content:space-between;padding:18px 20px;cursor:pointer;text-align:left;gap:12px;}
.faq-q-text{font-size:0.95rem;font-weight:700;color:var(--navy);display:flex;align-items:center;gap:10px;}
.faq-q-text::before{content:'Q';display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--navy);color:#fff;font-size:0.75rem;font-weight:800;flex-shrink:0;}
.faq-toggle{width:28px;height:28px;border-radius:50%;background:var(--navy-light);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.1rem;color:var(--navy);transition:transform var(--t),background var(--t);}
.faq-item.open .faq-toggle{transform:rotate(45deg);background:var(--navy);color:#fff;}
.faq-a{display:none;padding:0 20px 20px 54px;}
.faq-item.open .faq-a{display:block;}
.faq-a-inner{font-size:0.9rem;color:var(--ink-soft);line-height:1.8;}

/* ─── Final CTA ─── */
.final-cta{
  background:linear-gradient(135deg,var(--green-cta) 0%,#0f3620 100%);
  color:#fff;padding:80px 20px;text-align:center;
  position:relative;overflow:hidden;
}
.final-cta::before{content:'';position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.05),transparent 70%);top:-200px;right:-150px;pointer-events:none;}
.final-cta h2{font-size:clamp(1.3rem,3vw,1.85rem);font-weight:800;margin-bottom:12px;}
.final-cta p{font-size:0.95rem;opacity:.85;margin-bottom:32px;}
.cta-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}
.btn-white{display:inline-block;background:#fff;color:var(--green-cta);font-weight:700;padding:15px 40px;border-radius:var(--r);font-size:1rem;box-shadow:0 4px 16px rgba(0,0,0,.2);transition:all var(--t);}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(0,0,0,.3);}
.btn-outline-green{display:inline-block;background:rgba(255,255,255,.12);color:#fff;border:2px solid rgba(255,255,255,.5);padding:15px 40px;border-radius:var(--r);font-weight:700;font-size:1rem;transition:all var(--t);}
.btn-outline-green:hover{background:rgba(255,255,255,.2);border-color:#fff;}

/* ─── SEO代行：導入フロー ─── */
.flow-section{background:var(--navy-pale);}
.flow-steps{display:flex;flex-direction:column;gap:0;max-width:760px;margin:0 auto;}
.flow-step{display:grid;grid-template-columns:72px 1fr;gap:20px;align-items:flex-start;position:relative;}
.flow-step:not(:last-child)::after{content:'';position:absolute;left:35px;top:52px;bottom:-20px;width:2px;background:linear-gradient(to bottom,var(--navy),var(--navy-light));}
.flow-step-num{width:52px;height:52px;flex-shrink:0;background:var(--navy);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:700;position:relative;z-index:1;box-shadow:0 0 0 6px var(--navy-pale);margin:0 auto;}
.flow-step-body{background:#fff;border-radius:12px;padding:22px 26px;border:1px solid var(--border);margin-bottom:20px;}
.flow-step-body h4{font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:6px;}
.flow-step-body p{font-size:0.9rem;color:var(--ink-soft);line-height:1.75;}

/* ─── Lightning コンテナ幅 上書き ─── */
.site-body-container.container{max-width:100% !important;padding-left:0 !important;padding-right:0 !important;width:100% !important;}
.main-section{max-width:100% !important;padding:0 !important;width:100% !important;}
.entry-body{max-width:100% !important;padding:0 !important;}
.entry .entry-body .page-hero,
.entry .entry-body .section,
.entry .entry-body .features-section,
.entry .entry-body .industry-section,
.entry .entry-body .service-list-section,
.entry .entry-body .contract-section,
.entry .entry-body .pricing-section,
.entry .entry-body .faq-section,
.entry .entry-body .final-cta,
.entry .entry-body .flow-section {
  margin-left: calc(-1 * var(--wp--style--root--padding-left, 0px));
  margin-right: calc(-1 * var(--wp--style--root--padding-right, 0px));
}

/* ─── レスポンシブ（サービス詳細ページ） ─── */
@media (max-width: 900px) {
  .industry-box{grid-template-columns:1fr;padding:28px 24px;gap:20px;}
}
@media (max-width: 768px) {
  .feature-cards{grid-template-columns:1fr;}
  .service-list{grid-template-columns:1fr;}
  .flow-step{grid-template-columns:52px 1fr;gap:12px;}
  .flow-step:not(:last-child)::after{left:25px;}
  .section{padding:56px 16px;}
  .page-hero{padding:52px 16px 64px;}
  .pricing-section{padding:56px 16px;}
  .final-cta{padding:56px 16px;}
}
@media (max-width: 480px) {
  .hero-title{font-size:1.5rem;}
  .cta-buttons{flex-direction:column;align-items:center;}
  .pricing-cta-area{flex-direction:column;align-items:center;}
  .industry-box{padding:20px 18px;}
  .feature-card{padding:22px 18px;}
  .contract-item{padding:16px 18px;}
}
